/* ---- Grupo Your design tokens ---- */
:root {
    --gy-pink:        #e60f78;
    --gy-pink-dark:   #b80c60;
    --gy-bg:          #eeeeee;
    --gy-card:        #ffffff;
    --gy-input-bg:    #e9e9e9;
    --gy-text:        #3f3f3f;
    --gy-text-dim:    #424242;
    --gy-line:        #e0e1e2;
    --gy-default-bg:  #efefef;
}

html, body {
    background-color: var(--gy-bg);
    color: var(--gy-text);
    font-family: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    min-height: 100%;
}

body { min-height: 100vh; }

a { color: var(--gy-text-dim); text-decoration: none; transition: color .25s; }
a:hover { color: var(--gy-pink); }

/* ---- Button overrides to match the portal ---- */
.btn { border: 0 !important; border-radius: 10px; transition: background-color .25s, color .25s; }
.btn-primary, .btn-primary:focus { background-color: var(--gy-pink) !important; color: #fff; }
.btn-primary:hover, .btn-primary:active { background-color: var(--gy-pink-dark) !important; color: #fff; }
.btn-info, .btn-info:focus { background-color: var(--gy-pink-dark) !important; color: #fff; }
.btn-default { background-color: var(--gy-default-bg) !important; color: var(--gy-text); }

/* Pill-shaped call-to-action (used for the login button) */
.btn-pill { width: 100%; height: 60px; border-radius: 30px !important; font-size: 1.25rem; font-weight: 600; }

/* ---- Inputs ---- */
.form-control, .form-control:focus {
    background-color: var(--gy-input-bg);
    border: 0;
    border-radius: 25px;
    height: 50px;
    font-size: 16px;
    text-indent: 15px;
    box-shadow: none !important;
    outline: none !important;
}

/* Signup form stacks tighter */
.form-signin .form-control { font-size: 18px; }

/* ---- Card / box ---- */
.card-gy {
    background-color: var(--gy-card);
    border-radius: 10px;
    padding: 3rem;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
}

@media (max-width: 575.98px) {
    .card-gy { padding: 1.5rem; }
}

/* ---- Navbar ---- */
.navbar-gy {
    background-color: #fff;
    border-bottom: 1px solid var(--gy-line);
    padding: 0.75rem 1.5rem;
}
.navbar-gy .brand {
    font-weight: 700;
    color: var(--gy-text);
    font-size: 1.1rem;
    letter-spacing: 0.02em;
}
.navbar-gy .brand:hover { color: var(--gy-pink); }
.navbar-gy .nav-link { color: var(--gy-text-dim); font-weight: 500; padding: 0.5rem 1rem; }
.navbar-gy .nav-link:hover,
.navbar-gy .nav-link.active { color: var(--gy-pink); }
.navbar-gy .logo { height: 36px; }

/* ---- Accents and helpers ---- */
.client-color  { color: var(--gy-pink) !important; }
.client-line   { height: 1px; background-color: var(--gy-pink); width: 100%; margin: 1rem 0; }
.client-border { border-radius: 10px; }
.hero-title    { font-size: 2.25rem; font-weight: 700; letter-spacing: -0.01em; }
.hero-subtitle { font-size: 1.1rem; color: var(--gy-text-dim); font-weight: 400; }

.flash-stack { max-width: 560px; margin: 1rem auto 0 auto; }

/* Footer links on auth cards */
.auth-footer a { font-size: 0.85rem; color: var(--gy-text-dim); }
.auth-footer a:hover { color: var(--gy-pink); }

/* "Portal Cliente"-style heading on the login card */
.card-heading { font-size: 2.2rem; font-weight: 700; line-height: 1.1; margin: 1rem 0 0.25rem 0; }
.card-subheading { color: var(--gy-text-dim); font-size: 0.95rem; margin-bottom: 2rem; }

/* Admin metrics tiles */
.metric-tile {
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: 12px;
    padding: 1rem 1.1rem;
    height: 100%;
}
/* Public-facing navbar brand (used pre-login; hides the firm's logo) */
.navbar-public-brand {
    color: var(--gy-pink);
    font-weight: 700;
    font-size: 1.25rem;
    letter-spacing: -0.01em;
}

.metric-label { font-size: 0.8rem; color: var(--gy-text-dim); text-transform: uppercase; letter-spacing: 0.04em; }
.metric-value { font-size: 2rem; font-weight: 700; color: var(--gy-pink); line-height: 1.1; margin-top: 0.2rem; }
.metric-sub   { font-size: 0.85rem; color: var(--gy-text-dim); margin-top: 0.25rem; }

/* Generic table used on metrics + users list */
.metrics-table thead th {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--gy-text-dim);
    border-bottom: 1px solid var(--gy-line);
}
.metrics-table tbody td { border-bottom: 1px solid var(--gy-line); }
.metrics-table a { color: var(--gy-pink); font-weight: 500; }

/* Role badges */
.badge {
    font-size: 0.72rem;
    font-weight: 600;
    padding: 0.3em 0.7em;
    border-radius: 999px;
    letter-spacing: 0.04em;
}
.badge-admin { background: var(--gy-pink); color: #fff; }
.badge-user  { background: var(--gy-default-bg); color: var(--gy-text); }

/* Daily distribution bar chart */
.day-chart {
    display: flex;
    align-items: flex-end;
    gap: 3px;
    height: 160px;
    padding: 0.75rem;
    background: #fff;
    border: 1px solid var(--gy-line);
    border-radius: 12px;
}
.day-col {
    flex: 1 1 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    height: 100%;
    min-width: 0;
}
.day-bar-wrap { flex: 1 1 auto; display: flex; align-items: flex-end; width: 100%; }
.day-bar {
    width: 100%;
    background: var(--gy-pink);
    border-radius: 3px 3px 0 0;
    min-height: 1px;
    transition: height .2s;
}
.day-label {
    font-size: 0.62rem;
    color: var(--gy-text-dim);
    margin-top: 4px;
    line-height: 1;
}
