/* =========================================================================
   MANTO SUPPLY · styles.css (final v3)
   ---------------------------------------------------------------------------
   ▸ LIGHT por padrão (paper-like premium)
   ▸ DARK opt-in via `<html data-theme="dark">` — togglável por usuário
   ▸ Toda a polish do v1+v2 mantida nos dois temas
   ▸ Zero alteração em ids/classes JS
   ========================================================================= */


/* ─── 01 · TOKENS · LIGHT (padrão) ──────────────────────────────────────── */
:root {
    /* Brand */
    --brand-navy:        #0D1B2A;
    --brand-navy-soft:   #1a2f4d;
    --brand-navy-deep:   #081320;
    --brand-gold:        #C9A84C;
    --brand-gold-bright: #E0BE63;
    --brand-gold-deep:   #A88838;
    --brand-gold-soft:   rgba(201, 168, 76, 0.12);
    --brand-bordo:       #8B3247;
    --brand-bordo-soft:  rgba(139, 50, 71, 0.10);

    /* Aliases legados */
    --navy: var(--brand-navy);  --navy-light: var(--brand-navy-soft);
    --gold: var(--brand-gold);  --gold-bright: var(--brand-gold-bright);
    --wine: var(--brand-bordo);

    /* Surfaces — paper */
    --surface-0: #F5F4F0;
    --surface-1: #FFFFFF;
    --surface-2: #FFFFFF;
    --surface-3: #F8F6F0;
    --surface-4: #EFEDE6;
    --bg:         var(--surface-0);
    --bg-soft:    var(--surface-3);
    --card-bg:    var(--surface-1);
    --sidebar-bg: var(--surface-1);

    /* Foreground */
    --text-hi:    #0D1B2A;
    --text:       #1d1d1f;
    --text-muted: #6E6E73;
    --text-faint: #9CA3AF;
    --fg-on-dark: #F5F4F0;

    /* Borders */
    --border:        #E8E6DF;
    --border-strong: #D1CFC8;
    --border-soft:   #EFEDE6;
    --border-gold:   rgba(201, 168, 76, 0.32);

    /* Radii */
    --radius-xs: 4px; --radius-sm: 6px; --radius-md: 8px;
    --radius-lg: 12px; --radius-pill: 999px;

    /* Shadows — calibradas pra light */
    --shadow-rim:      inset 0 1px 0 rgba(255, 255, 255, 0.7);
    --shadow-rim-gold: inset 0 1px 0 rgba(201, 168, 76, 0.35);
    --shadow-1: 0 1px  2px rgba(13, 27, 42, 0.04);
    --shadow-2: 0 4px 16px rgba(13, 27, 42, 0.06);
    --shadow-3: 0 12px 32px rgba(13, 27, 42, 0.10);
    --shadow-gold: 0 8px 24px rgba(201, 168, 76, 0.20);
    --shadow:   var(--shadow-2);

    /* Halos */
    --glow-gold:  0 0 0 1px rgba(201, 168, 76, 0.20), 0 8px 32px -8px rgba(201, 168, 76, 0.30);
    --glow-bordo: 0 0 0 1px rgba(139, 50, 71, 0.20),  0 8px 32px -8px rgba(139, 50, 71, 0.30);

    /* Glassmorphism — light */
    --glass-bg:        rgba(255, 255, 255, 0.78);
    --glass-bg-strong: rgba(255, 255, 255, 0.92);
    --glass-bg-dark:   rgba(13, 27, 42, 0.45);
    --glass-thin:      rgba(255, 255, 255, 0.65);
    --glass-blur:      blur(20px) saturate(140%);
    --glass-blur-lg:   blur(24px) saturate(180%);
    --glass-rim:       inset 0 1px 0 rgba(255, 255, 255, 0.8);

    /* Canvas ambient (vinheta + grain) — quase invisível em light */
    --canvas-vinheta:
        radial-gradient(ellipse 60% 50% at 100% -10%, rgba(201, 168, 76, 0.05) 0%, transparent 55%),
        radial-gradient(ellipse 50% 40% at -10% 110%, rgba(139, 50, 71, 0.03) 0%, transparent 50%);
    --canvas-grain-opacity: 0;
    --canvas-grain-blend: multiply;

    /* Motion */
    --ease-ios:        cubic-bezier(0.22, 0.61, 0.36, 1);
    --ease-emphasized: cubic-bezier(0.16, 1, 0.3, 1);
    --ease-luxe:       cubic-bezier(0.34, 1.56, 0.64, 1);
    --ease-silk:       cubic-bezier(0.4, 0, 0.2, 1);
    --dur-fast: 160ms; --dur-base: 240ms; --dur-slow: 480ms;
    --transition: all var(--dur-base) var(--ease-ios);

    /* Tipografia */
    --font-display: 'Outfit', -apple-system, sans-serif;
    --font-body:    'Inter', -apple-system, system-ui, sans-serif;
    --font-mono:    'JetBrains Mono', 'SF Mono', Menlo, monospace;

    /* Z-index */
    --z-nav: 100; --z-topbar: 200; --z-sidebar: 300;
    --z-dropdown: 400; --z-overlay: 500; --z-modal: 600;
    --z-toast: 700; --z-login: 800;

    /* ── Component tokens (theme-aware) ── */
    --btn-primary-bg: linear-gradient(180deg, var(--brand-navy-soft) 0%, var(--brand-navy) 100%);
    --btn-primary-fg: #fff;
    --btn-primary-shadow:       0 1px 0 rgba(0,0,0,0.06), 0 8px 20px -8px rgba(13, 27, 42, 0.35);
    --btn-primary-shadow-hover: 0 1px 0 rgba(0,0,0,0.06), 0 16px 32px -10px rgba(13, 27, 42, 0.45);
    --btn-primary-shine:        rgba(255, 255, 255, 0.30);

    --card-overlay: linear-gradient(180deg, rgba(13, 27, 42, 0.015) 0%, transparent 30%);
    --card-halo:    radial-gradient(circle at center, rgba(201, 168, 76, 0.16) 0%, transparent 60%);
    --card-shadow:        0 1px 0 rgba(13, 27, 42, 0.03), 0 12px 24px -16px rgba(13, 27, 42, 0.10);
    --card-shadow-hover:  0 1px 0 rgba(13, 27, 42, 0.04), 0 20px 40px -20px rgba(13, 27, 42, 0.18);

    --th-bg: rgba(13, 27, 42, 0.025);
    --row-hover: linear-gradient(
        90deg,
        rgba(201, 168, 76, 0.08) 0%,
        rgba(13, 27, 42, 0.015) 30%,
        transparent 100%
    );

    --featured-bg:
        radial-gradient(ellipse at top right, rgba(201, 168, 76, 0.10) 0%, transparent 55%),
        linear-gradient(180deg, #fff 0%, #FBF8EF 100%);
}


/* ─── 02 · TOKENS · DARK (opt-in via [data-theme="dark"]) ───────────────── */
[data-theme="dark"] {
    --surface-0: #050B14;
    --surface-1: #0A1421;
    --surface-2: #122438;
    --surface-3: #18293E;
    --surface-4: #243752;
    --bg:         var(--surface-0);
    --bg-soft:    var(--surface-2);
    --card-bg:    var(--surface-2);
    --sidebar-bg: var(--surface-1);

    --text-hi:    #F5F4F0;
    --text:       #D8DCE3;
    --text-muted: #8A93A3;
    --text-faint: #5A6478;

    /* Fix legacy aliases for dark mode contrast */
    --navy: #93B4DE;
    --navy-light: #4A6B9C;
    --wine: #D88EA0;

    --border:        rgba(255, 255, 255, 0.06);
    --border-strong: rgba(255, 255, 255, 0.10);
    --border-soft:   rgba(255, 255, 255, 0.04);
    --border-gold:   rgba(201, 168, 76, 0.24);

    --shadow-rim:      inset 0 1px 0 rgba(255, 255, 255, 0.05);
    --shadow-rim-gold: inset 0 1px 0 rgba(201, 168, 76, 0.20);
    --shadow-1: 0 1px  2px rgba(0, 0, 0, 0.40), var(--shadow-rim);
    --shadow-2: 0 4px 16px rgba(0, 0, 0, 0.32), var(--shadow-rim);
    --shadow-3: 0 16px 40px rgba(0, 0, 0, 0.55), var(--shadow-rim);
    --shadow-gold: 0 8px 32px rgba(201, 168, 76, 0.30);

    --glass-bg:        rgba(13, 27, 42, 0.72);
    --glass-bg-strong: rgba(13, 27, 42, 0.88);
    --glass-bg-dark:   rgba(5, 11, 20, 0.78);
    --glass-thin:      rgba(18, 36, 56, 0.55);
    --glass-rim:       inset 0 1px 0 rgba(255, 255, 255, 0.08);

    --canvas-vinheta:
        radial-gradient(ellipse 60% 50% at 100% -10%, rgba(201, 168, 76, 0.08) 0%, transparent 55%),
        radial-gradient(ellipse 50% 40% at -10% 110%, rgba(139, 50, 71, 0.10) 0%, transparent 50%),
        radial-gradient(ellipse 90% 60% at 50% 100%, rgba(13, 27, 42, 0.40) 0%, transparent 70%);
    --canvas-grain-opacity: 0.025;
    --canvas-grain-blend: overlay;

    /* Component tokens overrides */
    --btn-primary-bg: linear-gradient(180deg, var(--brand-gold-bright) 0%, var(--brand-gold) 100%);
    --btn-primary-fg: var(--brand-navy);
    --btn-primary-shadow:       var(--shadow-rim-gold), 0 1px 0 rgba(0, 0, 0, 0.25), 0 8px 20px -8px rgba(201, 168, 76, 0.55);
    --btn-primary-shadow-hover: var(--shadow-rim-gold), 0 1px 0 rgba(0, 0, 0, 0.25), 0 16px 32px -10px rgba(201, 168, 76, 0.65);
    --btn-primary-shine:        rgba(255, 255, 255, 0.45);

    --card-overlay: linear-gradient(180deg, rgba(255, 255, 255, 0.015) 0%, transparent 30%);
    --card-halo:    radial-gradient(circle at center, rgba(201, 168, 76, 0.10) 0%, transparent 60%);
    --card-shadow:        var(--shadow-rim), 0 1px 0 rgba(0, 0, 0, 0.4), 0 12px 24px -16px rgba(0, 0, 0, 0.5);
    --card-shadow-hover:  var(--shadow-rim), 0 1px 0 rgba(0, 0, 0, 0.4), 0 20px 40px -20px rgba(0, 0, 0, 0.7);

    --th-bg: rgba(0, 0, 0, 0.18);
    --row-hover: linear-gradient(
        90deg,
        rgba(201, 168, 76, 0.04) 0%,
        rgba(255, 255, 255, 0.015) 30%,
        transparent 100%
    );

    --featured-bg:
        radial-gradient(ellipse at top right, rgba(201, 168, 76, 0.14) 0%, transparent 55%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.02) 0%, transparent 40%),
        var(--brand-navy-deep);
}


/* ─── 03 · BASE / RESET / BODY ──────────────────────────────────────────── */
* { margin: 0; padding: 0; box-sizing: border-box; -webkit-font-smoothing: antialiased; }
*:focus { outline: none; }
*:focus-visible { outline: 2px solid var(--brand-gold); outline-offset: 3px; border-radius: 4px; }

html, body { height: 100%; }
body {
    font-family: var(--font-body);
    background: var(--bg);
    color: var(--text);
    overflow: hidden;
    overscroll-behavior: contain;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "ss01", "cv11", "tnum";
    position: relative;
    transition: background 400ms var(--ease-silk), color 400ms var(--ease-silk);
}

body::before {
    content: '';
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background: var(--canvas-vinheta);
    transition: background 400ms var(--ease-silk);
}
body::after {
    content: '';
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    opacity: var(--canvas-grain-opacity);
    mix-blend-mode: var(--canvas-grain-blend);
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='140' height='140'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
    transition: opacity 400ms var(--ease-silk);
}

.app-container, .app-shell { display: flex; height: 100vh; position: relative; z-index: 1; }

.display, h1, h2, .breadcrumb, .kpi-value, .login-tagline,
.page-header h2, .calc-commission-total, .comm-summary-value,
.tier-card-name {
    font-family: var(--font-display);
}

body.privacy-hidden .privacy-sensitive {
    filter: blur(14px);
    pointer-events: none;
    transition: filter 0.3s ease;
    color: var(--text-faint) !important;
}


/* ─── 04 · SIDEBAR (paper glass + rail gold pulsante) ───────────────────── */
.sidebar {
    width: 260px;
    background: var(--sidebar-bg);
    border-right: 1px solid var(--border);
    box-shadow: var(--shadow-rim), 1px 0 0 rgba(255, 255, 255, 0.02);
    display: flex;
    flex-direction: column;
    padding: 1.75rem 1rem;
    flex-shrink: 0;
    z-index: var(--z-sidebar);
    transition: background 400ms var(--ease-silk), border-color 400ms;
}
[data-theme="dark"] .sidebar {
    background: linear-gradient(180deg, var(--glass-bg-strong) 0%, rgba(8, 19, 32, 0.88) 100%);
    backdrop-filter: var(--glass-blur-lg);
    -webkit-backdrop-filter: var(--glass-blur-lg);
}

.sidebar-header {
    padding: 0.5rem 0.4rem 1.5rem;
    border-bottom: 1px solid var(--border);
    margin-bottom: 1.5rem;
    text-align: center;
}
.logo-wrapper { width: 100%; max-width: 140px; margin: 0 auto; }
.sidebar-logo { width: 100%; max-width: 130px; height: auto; object-fit: contain; }

.sidebar-header::after {
    content: 'GESTÃO ELITE';
    display: block;
    font-family: var(--font-body);
    font-size: 0.58rem;
    font-weight: 600;
    color: var(--brand-gold);
    letter-spacing: 0.32em;
    text-align: center;
    margin-top: 0.65rem;
    opacity: 0.85;
}

.sidebar-nav { display: flex; flex-direction: column; gap: 0.15rem; flex: 1; }

.nav-item {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.65rem 1rem;
    min-height: 40px;
    border: none;
    background: transparent;
    color: var(--text-muted);
    border-radius: var(--radius-md);
    cursor: pointer;
    font-family: var(--font-body);
    font-weight: 500;
    font-size: 0.875rem;
    transition: var(--transition);
    width: 100%;
    text-align: left;
}
.nav-item > i, .nav-item > svg {
    width: 17px; height: 17px;
    stroke-width: 1.75;
    opacity: 0.8;
    flex-shrink: 0;
    transition: transform 240ms var(--ease-silk), opacity 240ms;
}
.nav-item:hover {
    background: rgba(13, 27, 42, 0.04);
    color: var(--text-hi);
}
[data-theme="dark"] .nav-item:hover { background: rgba(255, 255, 255, 0.035); }
.nav-item:hover > i, .nav-item:hover > svg { opacity: 1; transform: translateX(2px); }

.nav-item.active {
    background: linear-gradient(90deg, var(--brand-gold-soft) 0%, rgba(201, 168, 76, 0.02) 100%);
    color: var(--text-hi);
    font-weight: 600;
}
.nav-item.active > i, .nav-item.active > svg { color: var(--brand-gold-deep); opacity: 1; }
[data-theme="dark"] .nav-item.active > i,
[data-theme="dark"] .nav-item.active > svg { color: var(--brand-gold); }

.nav-item.active::before {
    content: '';
    position: absolute;
    left: -1rem;
    top: 22%;
    bottom: 22%;
    width: 3px;
    background: var(--brand-gold);
    border-radius: 0 2px 2px 0;
    box-shadow: 0 0 12px rgba(201, 168, 76, 0.55), 0 0 4px rgba(201, 168, 76, 0.85);
    animation: railPulse 3.2s ease-in-out infinite;
}
@keyframes railPulse {
    0%, 100% { box-shadow: 0 0 12px rgba(201, 168, 76, 0.45), 0 0 4px rgba(201, 168, 76, 0.7); }
    50%      { box-shadow: 0 0 20px rgba(201, 168, 76, 0.70), 0 0 6px rgba(201, 168, 76, 0.95); }
}

.nav-logout { color: var(--brand-bordo) !important; }
.nav-logout:hover { background: var(--brand-bordo-soft); }

.nav-divider { height: 1px; background: var(--border); margin: 0.75rem 0.5rem; flex-shrink: 0; }
.nav-item[data-tab="configuracoes"] { margin-top: auto; }

/* Badge — pull para a direita usando margin-left:auto (substitui absolute do original) */
.nav-alert-badge {
    margin-left: auto;
    position: static;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: 9px;
    background: var(--brand-bordo);
    color: #fff;
    font-family: var(--font-body);
    font-size: 0.62rem;
    font-weight: 700;
    line-height: 18px;
    text-align: center;
    box-shadow: 0 0 0 1px rgba(139, 50, 71, 0.4), 0 0 8px rgba(139, 50, 71, 0.25);
    pointer-events: none;
}
.mobile-nav-list .nav-alert-badge { margin-left: auto; }


/* ─── 05 · TOP-BAR (frosted + live dot) ─────────────────────────────────── */
.main-content { flex-grow: 1; overflow-y: auto; padding: 0; }

.top-bar {
    position: sticky;
    top: 0;
    height: 64px;
    padding: 0 clamp(1rem, 2vw + 0.5rem, 2.5rem);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    background: var(--glass-thin);
    backdrop-filter: var(--glass-blur-lg);
    -webkit-backdrop-filter: var(--glass-blur-lg);
    border-bottom: 1px solid var(--border);
    box-shadow: var(--glass-rim), 0 1px 0 rgba(13, 27, 42, 0.02);
    z-index: var(--z-topbar);
}
[data-theme="dark"] .top-bar {
    box-shadow: var(--glass-rim), 0 1px 0 rgba(0, 0, 0, 0.4);
}
.top-bar::after {
    content: '';
    position: absolute;
    left: 0; right: 0; bottom: -1px;
    height: 1px;
    background: linear-gradient(90deg, transparent 0%, rgba(201, 168, 76, 0.35) 50%, transparent 100%);
    opacity: 0;
    transition: opacity 400ms;
}
.top-bar.scrolled::after { opacity: 1; }

.breadcrumb {
    font-family: var(--font-display);
    font-weight: 400;
    font-size: 1.2rem;
    color: var(--text-hi);
    letter-spacing: -0.01em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
    flex: 1;
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
}
.breadcrumb::before {
    content: '';
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--brand-gold);
    box-shadow: 0 0 10px var(--brand-gold);
    animation: livePulse 2.4s ease-in-out infinite;
    flex-shrink: 0;
}
@keyframes livePulse {
    0%, 100% { opacity: 0.55; transform: scale(0.85); }
    50%      { opacity: 1;    transform: scale(1); }
}

.top-bar-actions { display: flex; align-items: center; gap: 0.5rem; flex-shrink: 0; }

.content-body { padding: 2.25rem 2.75rem 3rem; }


/* ─── 06 · BENTO GRID + CARDS ───────────────────────────────────────────── */
.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 1.25rem;
    margin-bottom: 2.5rem;
}
/* Aliases legacy (continuam funcionando) */
.card-1 { grid-column: span 3; }
.card-2 { grid-column: span 4; }
.card-3 { grid-column: span 6; }
.card-4 { grid-column: span 8; }
.card-6 { grid-column: span 12; }
/* Novos helpers */
.card-span-3 { grid-column: span 3; }
.card-span-4 { grid-column: span 4; }
.card-span-5 { grid-column: span 5; }
.card-span-6 { grid-column: span 6; }
.card-span-7 { grid-column: span 7; }
.card-span-8 { grid-column: span 8; }
.card-span-12 { grid-column: span 12; }

.card {
    background: var(--card-overlay), var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 1.5rem 1.6rem;
    box-shadow: var(--shadow-rim), var(--card-shadow);
    min-height: 140px;
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    transition: transform 280ms var(--ease-silk),
                border-color 280ms,
                box-shadow 400ms var(--ease-silk),
                background 400ms;
}
.card::after {
    content: '';
    position: absolute;
    top: -40%; right: -20%;
    width: 60%; height: 80%;
    background: var(--card-halo);
    opacity: 0;
    transition: opacity 400ms var(--ease-silk);
    pointer-events: none;
}
.card:hover {
    border-color: var(--border-strong);
    transform: translateY(-2px);
    box-shadow: var(--shadow-rim), var(--card-shadow-hover);
}
.card:hover::after { opacity: 1; }

.card-accent::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent 0%, var(--brand-gold) 50%, transparent 100%);
}

/* Featured / countdown */
.countdown-card, .featured-card {
    background: var(--featured-bg);
    border-color: var(--border-gold);
    box-shadow: var(--shadow-rim-gold), var(--glow-gold);
}
.countdown-card .kpi-label, .featured-card .kpi-label { color: var(--brand-gold-deep); }
[data-theme="dark"] .countdown-card .kpi-label,
[data-theme="dark"] .featured-card .kpi-label { color: rgba(201, 168, 76, 0.9); }
[data-theme="dark"] .countdown-card .kpi-value,
[data-theme="dark"] .featured-card .kpi-value { color: var(--text-hi); }

/* KPI typography */
.kpi-label {
    font-family: var(--font-body);
    font-size: 0.68rem;
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: 0.45rem;
}
.kpi-label > i, .kpi-label > svg { width: 13px; height: 13px; stroke-width: 1.5; opacity: 0.7; }
.kpi-value {
    font-family: var(--font-display);
    font-size: clamp(2.2rem, 2.6vw, 2.8rem);
    font-weight: 300;
    color: var(--text-hi);
    letter-spacing: -0.025em;
    line-height: 0.95;
    font-variant-numeric: tabular-nums;
}
.kpi-value .currency, .kpi-value .unit {
    font-size: 0.5em;
    color: var(--text-muted);
    font-weight: 400;
    margin: 0 0.15em;
}
.kpi-sub {
    font-family: var(--font-body);
    font-size: 0.76rem;
    font-weight: 500;
    margin-top: 0.85rem;
    color: var(--text-muted);
    display: flex;
    align-items: center;
    gap: 0.3rem;
}
.kpi-sub > i, .kpi-sub > svg { width: 13px; height: 13px; stroke-width: 2; }
.kpi-sub.up   { color: #2e7d32; }
.kpi-sub.down { color: #c62828; }
.kpi-sub.gold { color: var(--brand-gold-deep); }
[data-theme="dark"] .kpi-sub.up   { color: #7AC79B; }
[data-theme="dark"] .kpi-sub.down { color: #D88080; }
[data-theme="dark"] .kpi-sub.gold { color: var(--brand-gold); }

/* ─── 07 · TABELAS ──────────────────────────────────────────────────────── */
.table-container {
    background: var(--card-overlay), var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-rim), var(--card-shadow);
    overflow: hidden;
}
.table-container { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.table-container table { min-width: 600px; }

table { width: 100%; border-collapse: collapse; }
th {
    text-align: left;
    padding: 0.9rem 1.5rem;
    font-family: var(--font-body);
    font-size: 0.62rem;
    font-weight: 700;
    color: var(--text-muted);
    border-bottom: 1px solid var(--border);
    background: var(--th-bg);
    text-transform: uppercase;
    letter-spacing: 0.14em;
}
td {
    padding: 1.1rem 1.5rem;
    border-bottom: 1px solid var(--border);
    font-size: 0.88rem;
    color: var(--text);
    vertical-align: middle;
}
tbody tr { transition: background 200ms var(--ease-silk); }
tbody tr:hover td { background: var(--row-hover); }
tbody tr:last-child td { border-bottom: none; }

td.mono {
    font-family: var(--font-mono);
    font-size: 0.78rem;
    color: var(--text-muted);
    font-weight: 500;
}
td.amount, td[data-amount] {
    font-family: var(--font-display);
    font-weight: 400;
    font-size: 0.95rem;
    color: var(--text-hi);
    letter-spacing: -0.01em;
    font-variant-numeric: tabular-nums;
}


/* ─── 08 · BADGES ───────────────────────────────────────────────────────── */
.badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.25rem 0.55rem;
    border-radius: 4px;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    font-family: var(--font-body);
    border: 1px solid transparent;
}
.badge::before {
    content: '';
    width: 5px; height: 5px;
    border-radius: 50%;
    background: currentColor;
    box-shadow: 0 0 6px currentColor;
}
.badge-gold,
.badge-yellow  { background: var(--brand-gold-soft);    color: var(--brand-gold-deep);   border-color: rgba(201, 168, 76, 0.30); }
.badge-success,
.badge-green   { background: rgba(46, 125, 50, 0.10);   color: #1f6028;                  border-color: rgba(46, 125, 50, 0.25); }
.badge-info,
.badge-blue    { background: rgba(13, 27, 42, 0.06);    color: var(--brand-navy);        border-color: rgba(13, 27, 42, 0.15); }
.badge-bordo,
.badge-wine,
.badge-red     { background: var(--brand-bordo-soft);   color: var(--brand-bordo);       border-color: rgba(139, 50, 71, 0.25); }
.badge-muted   { background: rgba(13, 27, 42, 0.04);    color: var(--text-muted);        border-color: var(--border); }

[data-theme="dark"] .badge-success,
[data-theme="dark"] .badge-green   { background: rgba(122, 199, 155, 0.10); color: #7AC79B; border-color: rgba(122, 199, 155, 0.20); }
[data-theme="dark"] .badge-info,
[data-theme="dark"] .badge-blue    { background: rgba(120, 160, 220, 0.10); color: #93B4DE; border-color: rgba(120, 160, 220, 0.20); }
[data-theme="dark"] .badge-bordo,
[data-theme="dark"] .badge-wine,
[data-theme="dark"] .badge-red     { background: var(--brand-bordo-soft); color: #D88EA0; border-color: rgba(216, 142, 160, 0.20); }
[data-theme="dark"] .badge-gold,
[data-theme="dark"] .badge-yellow  { background: var(--brand-gold-soft); color: var(--brand-gold); border-color: rgba(201, 168, 76, 0.20); }
[data-theme="dark"] .badge-muted   { background: rgba(255, 255, 255, 0.04); color: var(--text-muted); border-color: var(--border); }


/* ─── 09 · FORMS ────────────────────────────────────────────────────────── */
.form-group { margin-bottom: 1.25rem; }
.form-group label {
    display: block;
    font-family: var(--font-body);
    font-size: 0.68rem;
    font-weight: 700;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 0.5rem;
}
.form-control {
    width: 100%;
    padding: 0.85rem 1.1rem;
    background: var(--bg-soft);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--text-hi);
    transition: var(--transition);
}
.form-control::placeholder { color: var(--text-faint); }
.form-control:hover { border-color: var(--border-strong); }
.form-control:focus {
    background: var(--surface-1);
    border-color: var(--brand-gold);
    box-shadow: 0 0 0 4px rgba(201, 168, 76, 0.12);
    outline: none;
}
[data-theme="dark"] .form-control:focus { background: var(--surface-1); }

select.form-control {
    appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C9A84C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 1em;
    padding-right: 2.5rem;
}


/* ─── 10 · BUTTONS (primário com shine sweep) ───────────────────────────── */
.btn-primary {
    position: relative;
    overflow: hidden;
    background: var(--btn-primary-bg);
    color: var(--btn-primary-fg);
    border: none;
    padding: 0.65rem 1.25rem;
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-weight: 600;
    font-size: 0.88rem;
    letter-spacing: 0.005em;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    box-shadow: var(--btn-primary-shadow);
    transition: transform 240ms var(--ease-luxe),
                box-shadow 240ms var(--ease-silk),
                filter 160ms;
}
.btn-primary::before {
    content: '';
    position: absolute;
    top: 0; left: -100%;
    width: 60%; height: 100%;
    background: linear-gradient(100deg, transparent 20%, var(--btn-primary-shine) 50%, transparent 80%);
    transform: skewX(-20deg);
    transition: left 700ms var(--ease-silk);
}
.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: var(--btn-primary-shadow-hover);
}
.btn-primary:hover::before { left: 130%; }
.btn-primary:active { transform: translateY(0); filter: brightness(0.96); }
.btn-primary > i, .btn-primary > svg { width: 15px; height: 15px; stroke-width: 2; }

/* SECONDARY / GHOST */
.btn-ghost, .btn-secondary {
    background: transparent;
    color: var(--text-muted);
    border: 1px solid var(--border);
    padding: 0.55rem 1rem;
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-weight: 500;
    font-size: 0.85rem;
    cursor: pointer;
    transition: var(--transition);
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}
.btn-ghost:hover, .btn-secondary:hover {
    background: var(--bg-soft);
    color: var(--text-hi);
    border-color: var(--border-strong);
}
[data-theme="dark"] .btn-ghost:hover,
[data-theme="dark"] .btn-secondary:hover { background: rgba(255, 255, 255, 0.04); }
.btn-ghost > i, .btn-ghost > svg, .btn-secondary > i, .btn-secondary > svg { width: 15px; height: 15px; stroke-width: 1.75; }

/* ICON BUTTON */
.btn-icon {
    width: 38px; height: 38px;
    border-radius: var(--radius-md);
    border: 1px solid var(--border);
    background: var(--surface-1);
    color: var(--text-muted);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: var(--transition);
    position: relative;
}
[data-theme="dark"] .btn-icon { background: rgba(255, 255, 255, 0.025); }
.btn-icon:hover {
    background: var(--bg-soft);
    border-color: var(--border-strong);
    color: var(--text-hi);
}
[data-theme="dark"] .btn-icon:hover { background: var(--surface-3); }
.btn-icon > i, .btn-icon > svg { width: 17px; height: 17px; stroke-width: 1.75; }

/* "+" add-global ativo */
.btn-add-global { transition: all 0.2s ease; }
.btn-add-global.active {
    background: var(--brand-navy);
    border-color: var(--brand-navy);
    color: #fff;
}
[data-theme="dark"] .btn-add-global.active {
    background: var(--brand-gold);
    border-color: var(--brand-gold);
    color: var(--brand-navy);
}
.btn-add-global.active > i, .btn-add-global.active > svg { transform: rotate(45deg); }


/* ─── 11 · THEME TOGGLE BUTTON ──────────────────────────────────────────── */
/* Botão de alternância sol ↔ lua. Veja snippet HTML+JS abaixo. */
.btn-theme-toggle { position: relative; }
.btn-theme-toggle .theme-icon-light { display: none; }
[data-theme="dark"] .btn-theme-toggle .theme-icon-dark { display: none; }
[data-theme="dark"] .btn-theme-toggle .theme-icon-light { display: inline-block; color: var(--brand-gold); }
.btn-theme-toggle:hover > i, .btn-theme-toggle:hover > svg {
    transform: rotate(20deg);
    transition: transform 300ms var(--ease-luxe);
}


/* ─── 12 · SEARCH BAR (caso adicione) ───────────────────────────────────── */
/* Seletores robustos: funciona com <i data-lucide> antes E depois da
   substituição por <svg> que o lucide.createIcons() faz. */
.search-bar {
    position: relative;
    flex: 1;
    max-width: 360px;
    margin-left: 1rem;
}
.search-bar > i, .search-bar > svg.lucide, .search-bar > svg {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    width: 16px; height: 16px;
    color: var(--text-faint);
    pointer-events: none;
    stroke-width: 1.75;
}
.search-bar input {
    width: 100%;
    padding: 0.5rem 2.5rem 0.5rem 2.25rem;
    background: var(--bg-soft);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    color: var(--text-hi);
    font-family: var(--font-body);
    font-size: 0.85rem;
    transition: var(--transition);
}
.search-bar input::placeholder { color: var(--text-faint); }
.search-bar input:focus {
    background: var(--surface-1);
    border-color: var(--brand-gold);
    box-shadow: 0 0 0 4px rgba(201, 168, 76, 0.10);
    outline: none;
}
.search-bar kbd {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    background: var(--surface-1);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 2px 5px;
    font-family: var(--font-mono);
    font-size: 0.65rem;
    color: var(--text-muted);
}


/* ─── 13 · MODAL & DROPDOWN ─────────────────────────────────────────────── */
.modal-overlay {
    position: fixed;
    inset: 0;
    background: var(--glass-bg-dark);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    z-index: var(--z-modal);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--dur-base) var(--ease-ios);
}
.modal-overlay.active { opacity: 1; pointer-events: auto; }

.modal-container {
    background: var(--surface-1);
    border: 1px solid var(--border);
    width: 90%;
    max-width: 600px;
    max-height: 88vh;
    overflow-y: auto;
    border-radius: var(--radius-lg);
    padding: 2.25rem;
    box-shadow: var(--shadow-3);
    color: var(--text);
    transform: translateY(16px) scale(0.98);
    transition: transform var(--dur-slow) var(--ease-emphasized);
}
[data-theme="dark"] .modal-container { background: var(--surface-2); }
.modal-overlay.active .modal-container { transform: translateY(0) scale(1); }

@media (max-width: 768px) {
    .modal-overlay { align-items: flex-end; }
    .modal-container {
        width: 100%; max-width: 100%;
        padding: 1.5rem;
        border-radius: 16px 16px 0 0;
        max-height: 92vh;
        transform: translateY(100%);
    }
    .modal-overlay.active .modal-container { transform: translateY(0); }
}

.add-menu-wrapper { position: relative; }
.global-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    background: var(--surface-1);
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-3);
    min-width: 210px;
    padding: 0.5rem;
    z-index: 5000;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
[data-theme="dark"] .global-dropdown { background: var(--surface-3); }
.global-dropdown[hidden] { display: none !important; }
.dropdown-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.7rem 0.9rem;
    background: transparent;
    border: none;
    border-radius: 6px;
    font-size: 0.875rem;
    font-family: var(--font-body);
    font-weight: 600;
    color: var(--text);
    cursor: pointer;
    transition: background 0.15s ease;
    text-align: left;
    width: 100%;
}
.dropdown-item:hover { background: var(--bg-soft); color: var(--text-hi); }
[data-theme="dark"] .dropdown-item:hover { background: var(--surface-4); }
.dropdown-item > i, .dropdown-item > svg { width: 16px; height: 16px; flex-shrink: 0; }


/* ─── 14 · TOAST ────────────────────────────────────────────────────────── */
#toast-container {
    position: fixed;
    bottom: 30px;
    right: 30px;
    z-index: var(--z-toast);
    display: flex;
    flex-direction: column;
    gap: 10px;
    pointer-events: none;
}
.toast {
    background: var(--brand-navy);
    color: var(--fg-on-dark);
    border: 1px solid transparent;
    padding: 0.95rem 1.4rem;
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-weight: 600;
    font-size: 0.9rem;
    box-shadow: var(--shadow-3);
    transform: translateX(120%);
    opacity: 0;
    transition: transform var(--dur-slow) var(--ease-emphasized),
                opacity   var(--dur-slow) var(--ease-emphasized);
    display: flex;
    align-items: center;
    gap: 0.75rem;
    pointer-events: auto;
}
[data-theme="dark"] .toast {
    background: var(--surface-3);
    color: var(--text-hi);
    border-color: var(--border);
}
.toast.show { transform: translateX(0); opacity: 1; }
.toast.gold {
    background: var(--brand-gold);
    color: var(--brand-navy);
    border-color: var(--brand-gold-deep);
}
.toast.wine, .toast.red {
    background: var(--brand-bordo);
    color: #fff;
    border-color: rgba(139, 50, 71, 0.6);
}
@media (max-width: 768px) {
    #toast-container { bottom: 90px; right: 15px; left: 15px; align-items: center; }
    .toast { width: 100%; justify-content: center; }
}


/* ─── 15 · STATUS-SELECT INLINE ─────────────────────────────────────────── */
.status-select {
    appearance: none;
    -webkit-appearance: none;
    border: none;
    padding: 0.3rem 0.75rem;
    border-radius: 100px;
    font-size: 0.72rem;
    font-weight: 700;
    font-family: var(--font-display);
    cursor: pointer;
    text-align: center;
    transition: all 0.2s ease;
    outline: none;
    min-width: 130px;
}
.status-select:hover { opacity: 0.85; }
.status-select-badge-yellow { background: var(--brand-gold-soft);    color: var(--brand-gold-deep); }
.status-select-badge-blue   { background: rgba(13, 27, 42, 0.06);    color: var(--brand-navy); }
.status-select-badge-green  { background: rgba(46, 125, 50, 0.10);   color: #1f6028; }
.status-select-badge-wine   { background: var(--brand-bordo-soft);   color: var(--brand-bordo); }
[data-theme="dark"] .status-select-badge-yellow { background: var(--brand-gold-soft);    color: var(--brand-gold); }
[data-theme="dark"] .status-select-badge-blue   { background: rgba(120, 160, 220, 0.10); color: #93B4DE; }
[data-theme="dark"] .status-select-badge-green  { background: rgba(122, 199, 155, 0.10); color: #7AC79B; }
[data-theme="dark"] .status-select-badge-wine   { background: var(--brand-bordo-soft);   color: #D88EA0; }


/* ─── 16 · LOGIN ────────────────────────────────────────────────────────── */
#login-overlay {
    position: fixed;
    inset: 0;
    background: var(--bg);
    z-index: var(--z-login);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
}
.login-card {
    background: var(--surface-1);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 2.5rem 2rem;
    width: 100%;
    max-width: 400px;
    display: flex;
    flex-direction: column;
    align-items: center;
    box-shadow: var(--shadow-3), var(--shadow-rim);
    position: relative;
    overflow: hidden;
}
.login-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent 0%, var(--brand-gold) 50%, transparent 100%);
}
.login-logo { width: 120px; height: auto; margin-bottom: 1.25rem; object-fit: contain; }
.login-tagline {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 500;
    color: var(--text-hi);
    margin-bottom: 0.3rem;
    letter-spacing: -0.02em;
}
.login-sub { font-size: 0.85rem; color: var(--text-muted); margin-bottom: 2rem; }
.login-field { width: 100%; margin-bottom: 1rem; }
.login-field label {
    display: block;
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--text-muted);
    margin-bottom: 0.4rem;
}
.btn-login-cta {
    width: 100%;
    background: var(--brand-navy);
    color: #fff;
    border: none;
    padding: 0.9rem 1.5rem;
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    transition: all 0.25s var(--ease-silk);
    margin-top: 0.5rem;
    margin-bottom: 1.5rem;
    box-shadow: var(--shadow-1);
}
.btn-login-cta:hover {
    background: var(--brand-navy-soft);
    transform: translateY(-2px);
    box-shadow: var(--shadow-3);
}
[data-theme="dark"] .btn-login-cta { background: var(--brand-gold); color: var(--brand-navy); box-shadow: var(--shadow-rim-gold), var(--shadow-1); }
[data-theme="dark"] .btn-login-cta:hover { background: var(--brand-gold-bright); box-shadow: var(--shadow-rim-gold), var(--shadow-gold); }
.login-footer { font-size: 0.7rem; color: var(--text-faint); text-align: center; }
@media (max-width: 480px) {
    .login-card { padding: 2rem 1.5rem; margin: 1rem; border-radius: 18px; }
    .login-tagline { font-size: 1.25rem; }
}

/* ─── 17 · PAGE HEADER + SECTION LABEL ──────────────────────────────────── */
.page-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2rem;
    margin-top: 1rem;
}
.page-header h2 {
    font-family: var(--font-display);
    font-size: 1.8rem;
    font-weight: 500;
    color: var(--text-hi);
    margin-bottom: 0.25rem;
    letter-spacing: -0.02em;
}
.page-header p { color: var(--text-muted); font-size: 0.9rem; }
.section-label {
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--text-muted);
    margin-bottom: 1rem;
}


/* ─── 18 · COMMISSIONS / TIERS ──────────────────────────────────────────── */
.comm-summary-bar {
    display: flex;
    background: var(--surface-1);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    margin-bottom: 2rem;
    overflow: hidden;
    box-shadow: var(--shadow-rim), var(--shadow-1);
}
[data-theme="dark"] .comm-summary-bar { background: var(--surface-2); }
.comm-summary-item {
    flex: 1;
    padding: 1.25rem 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    border-right: 1px solid var(--border);
}
.comm-summary-item:last-child { border-right: none; }
.comm-summary-label {
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--text-muted);
}
.comm-summary-value {
    font-family: var(--font-display);
    font-size: 1.3rem;
    font-weight: 500;
    color: var(--text-hi);
    letter-spacing: -0.01em;
}
.comm-summary-value.gold    { color: var(--brand-gold-deep); }
.comm-summary-value.success { color: #1f6028; }
.comm-summary-value.wine    { color: var(--brand-bordo); }
[data-theme="dark"] .comm-summary-value.gold    { color: var(--brand-gold); }
[data-theme="dark"] .comm-summary-value.success { color: #7AC79B; }
[data-theme="dark"] .comm-summary-value.wine    { color: #D88EA0; }

.comm-tier-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.3rem 0.8rem;
    border-radius: 100px;
    font-family: var(--font-body);
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.comm-tier-badge.badge-sm { font-size: 0.62rem; padding: 0.2rem 0.6rem; }
.tier-base    { background: rgba(168, 136, 56, 0.10); color: var(--brand-gold-deep);   border: 1px solid rgba(168, 136, 56, 0.25); }
.tier-titular { background: var(--brand-gold-soft);   color: var(--brand-gold-deep);   border: 1px solid var(--border-gold); }
.tier-lenda   { background: rgba(224, 190, 99, 0.18); color: #78350f;                  border: 1px solid var(--brand-gold); }
.tier-none    { background: rgba(13, 27, 42, 0.03);   color: var(--text-muted);        border: 1px solid var(--border); }
[data-theme="dark"] .tier-titular { color: var(--brand-gold); }
[data-theme="dark"] .tier-lenda   { color: var(--brand-gold-bright); }
[data-theme="dark"] .tier-none    { background: rgba(255, 255, 255, 0.03); }

.btn-share-extrato {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    background: var(--brand-navy);
    color: #fff;
    border: none;
    padding: 0.6rem 1rem;
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: 0.8rem;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.2s ease;
    white-space: nowrap;
}
.btn-share-extrato:hover { background: var(--brand-navy-soft); transform: translateY(-1px); }

.tier-cards-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}
.tier-card {
    background: var(--surface-1);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 2rem 1.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    position: relative;
    transition: all 0.25s var(--ease-silk);
    box-shadow: var(--shadow-rim), var(--shadow-1);
    color: var(--text);
}
[data-theme="dark"] .tier-card { background: var(--surface-2); }
.tier-card:hover {
    border-color: var(--border-strong);
    transform: translateY(-3px);
    box-shadow: var(--shadow-rim), var(--shadow-2);
}
.tier-card-popular {
    border-color: var(--border-gold);
    box-shadow: var(--shadow-gold), var(--shadow-rim-gold);
}
.tier-card-active {
    background:
        radial-gradient(ellipse at top, rgba(201, 168, 76, 0.08) 0%, transparent 60%),
        var(--surface-1);
    border-color: var(--border-gold);
    box-shadow: var(--shadow-2);
}
[data-theme="dark"] .tier-card-active {
    background:
        radial-gradient(ellipse at top, rgba(201, 168, 76, 0.06) 0%, transparent 60%),
        var(--surface-2);
    box-shadow: var(--shadow-3);
}
.tier-popular-badge {
    position: absolute;
    top: -14px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--brand-gold);
    color: var(--brand-navy);
    font-family: var(--font-body);
    font-size: 0.65rem;
    font-weight: 700;
    padding: 0.25rem 1rem;
    border-radius: 100px;
    white-space: nowrap;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    box-shadow: var(--shadow-rim-gold);
}
.tier-card-icon { font-size: 2rem; line-height: 1; color: var(--brand-gold); }
.tier-card-name {
    font-family: var(--font-display);
    font-size: 1.3rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.tier-card-name.base    { color: var(--brand-gold-deep); }
.tier-card-name.titular { color: var(--brand-gold-deep); }
.tier-card-name.lenda   { color: var(--brand-gold); }
[data-theme="dark"] .tier-card-name.titular { color: var(--brand-gold); }
[data-theme="dark"] .tier-card-name.lenda   { color: var(--brand-gold-bright); }
.tier-card-faixa {
    font-size: 0.8rem;
    color: var(--text-muted);
    font-weight: 600;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--border);
}
.tier-card-values { display: flex; flex-direction: column; gap: 0.6rem; }
.tier-value-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.875rem;
}
.tier-value-label { color: var(--text-muted); font-weight: 600; }
.tier-value-amount { font-family: var(--font-display); font-weight: 600; color: var(--text-hi); }

.calc-card {
    background: var(--surface-1);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 2rem;
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: 2.5rem;
    align-items: start;
    box-shadow: var(--shadow-rim), var(--shadow-1);
    color: var(--text);
}
[data-theme="dark"] .calc-card { background: var(--surface-2); }
.calc-output { display: flex; flex-direction: column; align-items: flex-start; gap: 1rem; }
.calc-commission-total {
    font-family: var(--font-display);
    font-size: 3rem;
    font-weight: 300;
    color: var(--brand-gold-deep);
    letter-spacing: -0.03em;
    line-height: 1;
    text-shadow: 0 0 24px rgba(201, 168, 76, 0.20);
}
[data-theme="dark"] .calc-commission-total { color: var(--brand-gold); }
.calc-progress-bar {
    width: 100%;
    height: 8px;
    background: var(--surface-3);
    border-radius: 100px;
    overflow: hidden;
}
[data-theme="dark"] .calc-progress-bar { background: rgba(255, 255, 255, 0.05); }
.calc-progress-fill {
    height: 100%;
    background: var(--brand-gold);
    box-shadow: 0 0 8px rgba(201, 168, 76, 0.4);
    border-radius: 100px;
    transition: width var(--dur-slow) var(--ease-ios);
}
.calc-msg { font-size: 0.85rem; color: var(--text-muted); font-weight: 500; line-height: 1.5; }

.comm-table-totals {
    display: flex;
    gap: 2rem;
    padding: 1rem 1.5rem;
    border-bottom: 1px solid var(--border);
    background: var(--th-bg);
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text);
}
.btn-status-toggle {
    border: none;
    padding: 0.3rem 0.85rem;
    border-radius: 100px;
    font-size: 0.72rem;
    font-weight: 700;
    font-family: var(--font-display);
    cursor: pointer;
    transition: all 0.2s;
}
.status-pago     { background: rgba(46, 125, 50, 0.10);  color: #1f6028; }
.status-pago:hover { background: rgba(46, 125, 50, 0.20); }
.status-pendente { background: var(--brand-bordo-soft);  color: var(--brand-bordo); }
.status-pendente:hover { background: rgba(139, 50, 71, 0.22); }
[data-theme="dark"] .status-pago     { background: rgba(122, 199, 155, 0.12); color: #7AC79B; }
[data-theme="dark"] .status-pendente { background: var(--brand-bordo-soft); color: #D88EA0; }


/* ─── 19 · FINANCE LIST + GLASS UI ──────────────────────────────────────── */
.finance-list { display: flex; flex-direction: column; gap: 0.75rem; padding: 1.5rem; background: transparent; }
.finance-list-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--surface-1);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 1rem 1.25rem;
    transition: var(--transition);
}
[data-theme="dark"] .finance-list-item { background: var(--surface-2); }
.finance-list-item:hover {
    background: var(--bg-soft);
    border-color: var(--border-strong);
    transform: translateY(-1px);
    box-shadow: var(--shadow-1);
}
[data-theme="dark"] .finance-list-item:hover { background: var(--surface-3); }
.finance-item-left { display: flex; flex-direction: column; gap: 0.25rem; }
.finance-item-title { font-weight: 700; color: var(--text-hi); font-size: 0.95rem; }
.finance-item-meta { font-size: 0.75rem; color: var(--text-muted); display: flex; align-items: center; gap: 0.5rem; }
.finance-item-right { display: flex; align-items: center; gap: 1.25rem; }
.finance-item-value-group { display: flex; flex-direction: column; align-items: flex-end; gap: 0.25rem; }
.finance-item-val { font-family: var(--font-display); font-weight: 500; font-size: 1rem; letter-spacing: -0.01em; }
.val-wine  { color: var(--brand-bordo); }
.val-gold  { color: var(--brand-gold-deep); }
.val-green { color: #1f6028; }
[data-theme="dark"] .val-wine  { color: #D88EA0; }
[data-theme="dark"] .val-gold  { color: var(--brand-gold); }
[data-theme="dark"] .val-green { color: #7AC79B; }
.finance-item-date { font-size: 0.7rem; font-weight: 700; color: var(--text-muted); }
.finance-item-actions { display: flex; gap: 0.25rem; opacity: 0; transition: var(--transition); }
.finance-list-item:hover .finance-item-actions { opacity: 1; }
@media (max-width: 768px) {
    .finance-item-actions { opacity: 1; }
    .finance-list-item { padding: 0.75rem 1rem; }
}

.finance-glass-container {
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-2);
    overflow: hidden;
    margin-top: 1.5rem;
}
[data-theme="dark"] .finance-glass-container { background: var(--surface-2); backdrop-filter: none; }
.finance-tabs {
    display: flex;
    background: var(--th-bg);
    border-bottom: 1px solid var(--border);
    padding: 0.5rem 1rem 0 1rem;
    gap: 1rem;
}
.fin-tab {
    background: transparent;
    border: none;
    padding: 1rem 1.5rem;
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--text-muted);
    cursor: pointer;
    position: relative;
    transition: var(--transition);
}
.fin-tab:hover { color: var(--text-hi); }
.fin-tab.active { color: var(--text-hi); }
.fin-tab.active::after {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--brand-gold);
    border-radius: 2px 2px 0 0;
    box-shadow: 0 0 8px rgba(201, 168, 76, 0.5);
}

.finance-tab-content { padding: 1.5rem; }
.modern-table-wrapper { width: 100%; overflow-x: auto; }
.modern-table { width: 100%; border-collapse: separate; border-spacing: 0; }
.modern-table th {
    text-align: left;
    padding: 1rem;
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--text-muted);
    font-weight: 700;
    border-bottom: 1px solid var(--border);
}
.modern-table td { padding: 1.1rem 1rem; border-bottom: 1px solid var(--border); vertical-align: middle; color: var(--text); }
.modern-table tr:hover td { background: var(--row-hover); }
.modern-table tr:last-child td { border-bottom: none; }

.modern-badge {
    display: inline-block;
    padding: 0.3rem 0.6rem;
    background: var(--bg-soft);
    color: var(--text-muted);
    border-radius: 6px;
    font-size: 0.7rem;
    font-weight: 700;
    border: 1px solid var(--border);
}
.modern-badge.gold { background: var(--brand-gold-soft); color: var(--brand-gold-deep); border-color: rgba(201, 168, 76, 0.30); }
[data-theme="dark"] .modern-badge.gold { color: var(--brand-gold); border-color: rgba(201, 168, 76, 0.25); }

.empty-state { text-align: center; padding: 3rem !important; color: var(--text-muted); font-weight: 600; }
.row-actions { display: flex; justify-content: flex-end; gap: 0.25rem; opacity: 0.4; transition: var(--transition); }
.modern-table tr:hover .row-actions { opacity: 1; }
.glass-kpi { background: var(--glass-bg) !important; border: 1px solid var(--border) !important; backdrop-filter: blur(10px); }
[data-theme="dark"] .glass-kpi { background: var(--surface-2) !important; backdrop-filter: none; }


/* ─── 20 · SETTINGS ─────────────────────────────────────────────────────── */
.settings-grid { display: grid; grid-template-columns: 320px 1fr; gap: 1.5rem; align-items: start; }
.settings-col { display: flex; flex-direction: column; gap: 1.25rem; }
.settings-card {
    padding: 1.5rem;
    background: var(--surface-1);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-rim), var(--shadow-1);
    color: var(--text);
}
[data-theme="dark"] .settings-card { background: var(--surface-2); }
.settings-card-title {
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--text-muted);
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.25rem;
}
@media (max-width: 768px) { .settings-grid { grid-template-columns: 1fr; } }


/* ─── 21 · MOBILE NAV + HAMBURGER ───────────────────────────────────────── */
.btn-hamburger {
    display: none;
    border: none;
    background: transparent;
    padding: 0;
    width: auto;
    height: auto;
    margin-right: 1rem;
    color: var(--text-hi);
}
.btn-mobile-settings { display: none; }

@media (max-width: 768px) {
    .btn-hamburger        { display: flex; align-items: center; justify-content: center; }
    .btn-mobile-settings  { display: flex; }
    .sidebar              { display: none !important; }
    .main-content         { padding: 0; height: 100vh; }
    .content-body         { padding: 1.5rem; }
    .dashboard-grid       { grid-template-columns: 1fr; }
    .card-1, .card-2, .card-3, .card-4, .card-6,
    .card-span-3, .card-span-4, .card-span-5,
    .card-span-6, .card-span-7, .card-span-8 { grid-column: span 1; }
    .page-header          { flex-direction: column; align-items: flex-start; gap: 1rem; }
    .nav-divider          { display: none; }
}
@media (max-width: 1280px) {
    .content-body { padding: 1.75rem 2rem 2.5rem; }
    .dashboard-grid { gap: 1rem; }
}
@media (max-width: 900px) {
    .dashboard-grid { grid-template-columns: repeat(6, 1fr); }
    .card-span-3, .card-span-4 { grid-column: span 3; }
    .card-span-5, .card-span-7, .card-span-8 { grid-column: span 6; }
}

.mobile-nav-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: var(--glass-bg-dark);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    z-index: var(--z-overlay);
}
.mobile-nav-overlay.open { display: block; }
.mobile-nav-panel {
    position: absolute;
    top: 0; left: 0; bottom: 0;
    width: 280px;
    background: var(--surface-1);
    border-right: 1px solid var(--border);
    box-shadow: 24px 0 60px rgba(13, 27, 42, 0.15);
    display: flex;
    flex-direction: column;
    transform: translateX(-100%);
    transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}
[data-theme="dark"] .mobile-nav-panel { background: var(--surface-1); box-shadow: 24px 0 60px rgba(0, 0, 0, 0.5); }
.mobile-nav-overlay.open .mobile-nav-panel { transform: translateX(0); }
.mobile-nav-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.25rem 1rem;
    border-bottom: 1px solid var(--border);
}
.mobile-nav-logo { width: 120px; height: auto; }
.mobile-nav-list { display: flex; flex-direction: column; gap: 0.25rem; padding: 1rem; overflow-y: auto; flex: 1; }
.mobile-nav-list .nav-item {
    flex-direction: row !important;
    justify-content: flex-start !important;
    gap: 0.75rem !important;
    padding: 0.85rem 1rem !important;
    width: 100% !important;
    min-width: unset !important;
    font-size: 0.9rem !important;
}
.mobile-nav-list .nav-item span { display: block !important; }


/* ─── 22 · ANIMATIONS / SKELETONS / SAVE FEEDBACK ───────────────────────── */
@keyframes mt-fade-up {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}
.mt-enter > * { opacity: 0; animation: mt-fade-up var(--dur-slow) var(--ease-ios) forwards; }
.mt-enter > *:nth-child(1) { animation-delay:   0ms; }
.mt-enter > *:nth-child(2) { animation-delay:  60ms; }
.mt-enter > *:nth-child(3) { animation-delay: 120ms; }
.mt-enter > *:nth-child(4) { animation-delay: 180ms; }
.mt-enter > *:nth-child(5) { animation-delay: 240ms; }
.mt-enter > *:nth-child(6) { animation-delay: 300ms; }
.mt-enter > *:nth-child(7) { animation-delay: 360ms; }
.mt-enter > *:nth-child(8) { animation-delay: 420ms; }
.mt-enter > *:nth-child(n+9) { animation-delay: 480ms; }

.skeleton {
    background: linear-gradient(90deg, var(--bg-soft) 0%, var(--surface-1) 50%, var(--bg-soft) 100%);
    background-size: 200% 100%;
    border-radius: var(--radius-md);
    animation: skeleton-shimmer 1.6s var(--ease-ios) infinite;
    color: transparent !important;
    pointer-events: none;
}
[data-theme="dark"] .skeleton { background: linear-gradient(90deg, var(--surface-2) 0%, var(--surface-3) 50%, var(--surface-2) 100%); background-size: 200% 100%; }
.skeleton-line  { height: 0.85rem; margin-bottom: 0.5rem; }
.skeleton-line:last-child { width: 60%; margin-bottom: 0; }
.skeleton-block { height: 120px; }
.skeleton-kpi   { height: 2.6rem; width: 60%; margin-top: 0.75rem; }
@keyframes skeleton-shimmer {
    0%   { background-position:  200% 0; }
    100% { background-position: -200% 0; }
}

.row-saving { opacity: 0.6; transition: opacity 0.2s ease; }
.row-saving .status-select { cursor: wait; }
@keyframes mantoSavedFlash {
    0%   { background-color: rgba(201, 168, 76, 0.22); }
    100% { background-color: transparent; }
}
.row-saved-flash, .row-saved-flash td { animation: mantoSavedFlash 1.2s ease-out; }
@keyframes mantoSavedError {
    0%   { background-color: rgba(139, 50, 71, 0.22); }
    100% { background-color: transparent; }
}
.row-saved-error, .row-saved-error td { animation: mantoSavedError 1.5s ease-out; }


/* ─── 23 · RESPONSIVO COMMISSIONS ───────────────────────────────────────── */
@media (max-width: 768px) {
    .comm-summary-bar { flex-wrap: wrap; border-radius: var(--radius-md); }
    .comm-summary-item { flex: 0 0 50%; border-right: none; border-bottom: 1px solid var(--border); }
    .comm-summary-item:last-child,
    .comm-summary-item:nth-last-child(-n+2) { border-bottom: none; }
    .tier-cards-grid { grid-template-columns: 1fr; }
    .calc-card { grid-template-columns: 1fr; gap: 1.5rem; }
    .calc-commission-total { font-size: 2rem; }
    .comm-table-totals { flex-direction: column; gap: 0.5rem; }
}


/* ─── 24 · REDUCED MOTION ───────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    .nav-item.active::before,
    .breadcrumb::before { animation: none; }
    .mt-enter > * { animation: none; opacity: 1; }
    .row-saved-flash, .row-saved-error,
    .row-saved-flash td, .row-saved-error td {
        animation: none;
        background-color: transparent !important;
    }
    .btn-primary::before { transition: none; }
}


/* ─── 25 · PATCH MOBILE-FIRST (v4) ──────────────────────────────────────── */
@media (max-width: 768px) {
    /* 1. Touch targets >= 44px */
    .nav-item { min-height: 48px !important; padding: 0.85rem 1rem !important; }
    .btn-icon { width: 44px !important; height: 44px !important; }
    .status-select { min-height: 44px; padding: 0.5rem 1rem; font-size: 0.8rem; }
    .btn-primary, .btn-secondary, .btn-ghost, .btn-login-cta { min-height: 48px; }

    /* 2. iOS Input Auto-zoom prevention */
    .form-control, input, select, textarea { font-size: 16px !important; }

    /* 3. Tipografia escalonada & Padding */
    .content-body { padding: 1.25rem 1rem 3rem !important; }
    .card { padding: 1.25rem 1rem !important; }
    .kpi-value { font-size: 2.2rem !important; }
    th { font-size: 0.75rem !important; padding: 0.75rem 1rem !important; }
    td { font-size: 0.95rem !important; padding: 1rem !important; }
    .breadcrumb { max-width: 200px; }

    /* 4. Safe-area insets */
    .top-bar {
        padding-top: max(0.5rem, env(safe-area-inset-top));
        height: auto;
        min-height: 64px;
    }
    .mobile-nav-panel {
        padding-top: env(safe-area-inset-top);
        padding-bottom: env(safe-area-inset-bottom);
        width: 85vw;
        max-width: 320px;
    }
    #toast-container {
        bottom: max(90px, env(safe-area-inset-bottom) + 20px) !important;
    }

    /* 5. Modal drag handle (visual) */
    .modal-container::before {
        content: '';
        display: block;
        width: 40px;
        height: 4px;
        background: var(--border-strong);
        border-radius: 10px;
        margin: -0.5rem auto 1.5rem auto;
    }
}

/* ─── 26 · MOBILE HARDENING (v5) ────────────────────────────────────────── */

/* 1. Tap delay zero — interativos respondem instantâneo no touch */
.nav-item, .btn-primary, .btn-secondary, .btn-ghost, .btn-icon,
.btn-login-cta, .btn-share-extrato, .btn-status-toggle,
.dropdown-item, .fin-tab, .status-select, .card,
.finance-list-item, .tier-card, .row-action {
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
}

/* 2. Press states (hover é mentira em touch) */
@media (hover: none) and (pointer: coarse) {
    .card:active            { transform: scale(0.985); transition: transform 80ms; }
    .btn-primary:active     { transform: scale(0.96); }
    .btn-icon:active        { background: var(--bg-soft); }
    .nav-item:active        { background: rgba(13, 27, 42, 0.08); }
    .dropdown-item:active   { background: var(--bg-soft); }
    .finance-list-item:active { transform: scale(0.99); }

    /* Hover effects "pulando" causam jitter em scroll touch → desabilita */
    .card:hover              { transform: none; }
    .finance-list-item:hover { transform: none; }
    .btn-primary:hover       { transform: none; }
    .card:hover::after       { opacity: 0; }
}
[data-theme="dark"] .nav-item:active { background: rgba(255, 255, 255, 0.06); }

/* 3. Safe-area no body + home indicator do iPhone */
@supports (padding: env(safe-area-inset-bottom)) {
    .main-content   { padding-bottom: env(safe-area-inset-bottom); }
    .content-body   { padding-bottom: calc(3rem + env(safe-area-inset-bottom)) !important; }
    #login-overlay  { padding-bottom: calc(16px + env(safe-area-inset-bottom)); }
}

/* 4. Top-bar com safe-area mais robusta (evita cortar conteúdo no scroll) */
@media (max-width: 768px) {
    .top-bar {
        padding-top: env(safe-area-inset-top);
        padding-bottom: 0;
        height: calc(64px + env(safe-area-inset-top));
        min-height: unset;
    }
    /* Empurra o content-body pra baixo do real (não-sticky-ignored) */
    .main-content {
        padding-top: 0;
        scroll-padding-top: 64px;
    }
}

/* 5. Modal drag handle só no bottom-sheet (evita aparecer em desktop) */
@media (max-width: 768px) {
    .modal-container::before {
        /* Confirma que só aparece no sheet mode — em desktop a media não casa */
        position: sticky;
        top: 0;
        z-index: 1;
        background: linear-gradient(180deg, var(--surface-1) 60%, transparent);
        padding-top: 0.5rem;
    }
}
[data-theme="dark"] .modal-container::before {
    background: linear-gradient(180deg, var(--surface-2) 60%, transparent);
}

/* 6. Sub-label "GESTÃO ELITE" no mobile-nav-header (paridade visual c/ desktop) */
.mobile-nav-header::after {
    content: 'GESTÃO ELITE';
    position: absolute;
    bottom: 6px;
    left: 1rem;
    font-size: 0.55rem;
    font-weight: 600;
    color: var(--brand-gold);
    letter-spacing: 0.32em;
    opacity: 0.75;
    pointer-events: none;
}
.mobile-nav-header { position: relative; padding-bottom: 1.5rem; }

/* 7. Long-press feedback nas linhas de tabela (alternativa ao hover) */
@media (hover: none) {
    tbody tr:active td       { background: var(--row-hover) !important; }
    .modern-table tr:active .row-actions,
    .finance-list-item:active .finance-item-actions { opacity: 1 !important; }
}

/* 8. Status-select padding (overrides v4 corrigem cliques precisos) */
@media (max-width: 768px) {
    .status-select {
        min-height: 44px;
        padding: 0.5rem 1.5rem 0.5rem 1rem;
        background-position: right 0.5rem center;
    }

    /* FIX MOBILE: Tabelas não estouram a tela, ganham scroll horizontal */
    .table-wrapper, .table-container, .modern-table-wrapper {
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    table {
        min-width: 650px; /* Força o scroll horizontal para manter layout da tabela */
    }

    /* FIX MOBILE: Cards do Dashboard não ficam esmagados, eles "empilham" */
    .dashboard-grid {
        display: flex !important;
        flex-direction: column !important;
        gap: 1rem;
    }
    .card {
        width: 100% !important;
    }
}
