:root {
    --background: #f8fafc;
    --surface: #ffffff;
    --surface-alt: #f3f6fb;
    --border: #d9e2f0;
    --text-primary: #0f172a;
    --text-secondary: #344256;
    --text-tertiary: #5c6c83;
    --primary: #1d4ed8;
    --primary-hover: #163fae;
    --success: #1d4ed8;
    --warning: #315bbf;
    --danger: #0f172a;
    --info: #5e7ce2;
    --sidebar: #0f172a;
    --sidebar-soft: #111c34;
    --chart-tone-1: #123cbe;
    --chart-tone-2: #2d5ddd;
    --chart-tone-3: #6d8ce8;
    --chart-tone-4: #c8d6f6;
    --radius-sm: 10px;
    --radius-md: 14px;
    --radius-lg: 18px;
    --radius-xl: 24px;
    --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.04);
    --shadow-md: 0 8px 24px rgba(15, 23, 42, 0.08);
    --shadow-lg: 0 20px 40px rgba(15, 23, 42, 0.10);
}

* { box-sizing: border-box; }
html, body { min-height: 100%; }
body {
    margin: 0;
    font-family: "Plus Jakarta Sans", system-ui, sans-serif;
    color: var(--text-primary);
    background: linear-gradient(180deg, #eff4fb 0%, var(--background) 100%);
}

a { color: inherit; text-decoration: none; }
main { display: block; }

.public-shell .container-fluid,
.workspace-main,
.workspace-topbar,
.workspace-sidebar,
.global-filters-bar { padding-left: clamp(1.25rem, 2vw, 2rem); padding-right: clamp(1.25rem, 2vw, 2rem); }

.brand-inline,
.brand-block { display: inline-flex; align-items: center; gap: .85rem; }
.brand-mark {
    width: 3rem;
    height: 3rem;
    border-radius: 18px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, var(--primary), #0f766e);
    color: #fff;
    font-weight: 800;
    letter-spacing: .08em;
}
.brand-inline strong,
.brand-block strong,
.hero-metrics strong,
.summary-card strong,
.metric-card strong,
.highlight-card strong,
.context-mini-list strong { display: block; }
.brand-inline small,
.brand-block small,
.text-muted,
.section-header-block p,
.metric-card small,
.callout-card small { color: var(--text-secondary) !important; }

.hero-kicker,
.section-caption,
.topbar-label,
.nav-group-title,
.note-kicker {
    display: inline-block;
    text-transform: uppercase;
    letter-spacing: .16em;
    font-size: .72rem;
    font-weight: 700;
    color: var(--text-tertiary);
}

.marketing-header { display: flex; justify-content: space-between; align-items: center; gap: 1rem; padding-top: 1.5rem; }
.marketing-nav { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.hero-section { padding-top: 4rem; padding-bottom: 2.5rem; }
.hero-section h1,
.auth-page h1,
.contract-page h1,
.page-hero-card h2 { font-size: clamp(2.2rem, 4vw, 4rem); line-height: 1.05; margin: .8rem 0 1rem; }
.hero-section p,
.auth-page p,
.contract-page p,
.page-hero-card p,
.content-card p,
.metric-card small { line-height: 1.7; color: var(--text-secondary); }

.hero-metrics,
.board-metrics,
.summary-grid,
.sidebar-mini-grid { display: grid; gap: .85rem; grid-template-columns: repeat(auto-fit, minmax(135px, 1fr)); }
.hero-metrics div,
.board-metrics div,
.summary-grid div,
.summary-card,
.sidebar-note,
.content-card,
.metric-card,
.auth-card,
.pricing-card,
.plan-card,
.page-hero-card,
.summary-panel,
.premium-board,
.bar-row-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
}
.hero-metrics div,
.board-metrics div,
.summary-grid div,
.summary-card { padding: 1rem 1.05rem; }
.hero-metrics span,
.board-metrics span,
.summary-card span,
.summary-grid small,
.context-mini-list span { display: block; color: var(--text-tertiary); font-size: .82rem; }

.premium-board {
    padding: 1.5rem;
    background: linear-gradient(160deg, #0f172a 0%, #172554 100%);
    color: #fff;
    border-color: rgba(255,255,255,.08);
}
.premium-board .board-head span,
.premium-board .board-footer span,
.premium-board small { color: rgba(255,255,255,.70); }
.board-bars {
    margin-top: 1.5rem;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    align-items: end;
    gap: .9rem;
    min-height: 180px;
}
.board-bars div { display: flex; flex-direction: column; align-items: center; gap: .65rem; }
.board-bars span {
    display: block;
    width: 100%;
    border-radius: 18px 18px 10px 10px;
    background: linear-gradient(180deg, #60a5fa, #1d4ed8);
}
.board-footer { margin-top: 1.5rem; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.section-block { padding-top: 2rem; padding-bottom: 3rem; }
.pricing-card, .plan-card { padding: 1.4rem; width: 100%; text-align: left; }
.pricing-card.featured, .plan-card.active { border-color: rgba(29, 78, 216, .45); box-shadow: 0 16px 34px rgba(29, 78, 216, .12); }
.plan-card { background: var(--surface); }

.auth-page, .contract-page { padding-top: 2rem; padding-bottom: 2rem; }
.auth-card { padding: 1.7rem; }

.workspace-body { background: linear-gradient(180deg, #eef5ff 0%, var(--background) 35%); }
.workspace-shell { display: grid; grid-template-columns: 300px minmax(0, 1fr); min-height: 100vh; }
.premium-sidebar {
    padding-top: 1.7rem;
    padding-bottom: 1.7rem;
    background: linear-gradient(180deg, var(--sidebar) 0%, var(--sidebar-soft) 100%);
    color: rgba(255,255,255,.92);
    position: sticky;
    top: 0;
    height: 100vh;
    overflow-y: auto;
}
.sidebar-brand small,
.nav-group-title,
.premium-note p,
.note-kicker { color: rgba(255,255,255,.60); }
.nav-group-block { margin-top: 1.7rem; }
.premium-nav-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: .8rem 1rem;
    border-radius: 16px;
    color: rgba(255,255,255,.72);
    margin-top: .25rem;
}
.premium-nav-link.active,
.premium-nav-link:hover {
    background: rgba(255,255,255,.08);
    color: #fff;
}
.nav-badge,
.filter-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: .3rem .8rem;
    background: rgba(29, 78, 216, .08);
    color: var(--primary);
    font-size: .78rem;
    font-weight: 700;
    border: 1px solid rgba(29, 78, 216, .10);
}
.filter-pill.active { background: rgba(29, 78, 216, .12); color: var(--primary-hover); }
.premium-note {
    padding: 1rem;
    margin-top: 1.6rem;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.08);
    box-shadow: none;
}
.sidebar-mini-grid span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    border-radius: 14px;
    background: rgba(255,255,255,.06);
    font-size: .8rem;
}

.premium-content { min-width: 0; }
.premium-topbar {
    padding-top: 1.4rem;
    padding-bottom: 1rem;
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}
.topbar-title { margin: .2rem 0; font-size: 1.85rem; }
.topbar-subtitle { margin: 0; color: var(--text-secondary); }
.topbar-actions { display: flex; gap: .75rem; align-items: center; flex-wrap: wrap; }
.global-filters-bar {
    display: flex;
    flex-wrap: wrap;
    gap: .65rem;
    padding-bottom: 1rem;
}
.premium-main { padding-bottom: 2rem; }

.premium-hero {
    padding: 1.6rem;
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) minmax(300px, .55fr);
    gap: 1rem;
}
.premium-summary-panel {
    padding: 1.35rem;
    background: linear-gradient(160deg, #0f172a 0%, #172554 100%);
    color: #fff;
    border-color: rgba(255,255,255,.08);
}
.premium-summary-panel span,
.premium-summary-panel p,
.premium-summary-panel small { color: rgba(255,255,255,.72); }
.premium-summary-panel strong { font-size: clamp(2rem, 3vw, 3rem); margin-top: .4rem; }
.summary-grid { margin-top: 1rem; }
.summary-grid div { background: rgba(255,255,255,.07); border-color: rgba(255,255,255,.08); box-shadow: none; }
.summary-grid div strong { font-size: 1rem; margin-top: .3rem; }

.metric-card,
.content-card,
.bar-row-card { padding: 1.25rem; }
.premium-metric { min-height: 100%; }
.metric-card span { color: var(--text-tertiary); display: block; }
.metric-card strong { font-size: 1.75rem; margin: .4rem 0; }
.metric-card p { margin: .9rem 0 0; font-weight: 700; }
.premium-card { border-radius: var(--radius-xl); }
.section-header-block h3,
.callout-card h3,
.highlight-card h3 { margin: .45rem 0 .55rem; font-size: 1.25rem; }
.highlight-card strong { font-size: 1.5rem; margin-bottom: .55rem; }
.context-rail { position: sticky; top: 1rem; }
.dark-context-card {
    background: linear-gradient(180deg, #fbfdff 0%, #f3f8fc 100%);
    color: var(--text-primary);
    border-color: rgba(203, 213, 225, .92);
}
.dark-context-card p,
.dark-context-card .section-caption,
.dark-context-card span,
.whatsapp-card p,
.whatsapp-card .section-caption { color: var(--text-secondary); }
.dark-context-card strong { font-size: 2.2rem; margin-bottom: .8rem; }
.context-mini-list { display: grid; gap: .8rem; }
.context-mini-list div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .8rem;
    padding: .9rem 1rem;
    border-radius: 16px;
    background: #ffffff;
    border: 1px solid rgba(226, 232, 240, .9);
}
.whatsapp-card {
    background: linear-gradient(180deg, #f8fcfb 0%, #eef8f5 100%);
    color: var(--text-primary);
    border-color: rgba(203, 213, 225, .92);
}
.whatsapp-preview { display: grid; gap: .8rem; margin-top: 1rem; }
.whatsapp-preview div {
    display: flex;
    justify-content: space-between;
    gap: .7rem;
    padding: .85rem 1rem;
    border-radius: 14px;
    background: #ffffff;
    border: 1px solid rgba(226, 232, 240, .9);
}
.whatsapp-preview span { color: var(--text-secondary); }
.whatsapp-preview strong { color: var(--text-primary); }

.premium-chart-grid { grid-template-columns: 1fr; }
.bar-row-card { border-radius: 20px; background: var(--surface-alt); box-shadow: none; }
.bar-stack { display: grid; gap: .85rem; }
.bar-track {
    height: .72rem;
    border-radius: 999px;
    background: rgba(15, 23, 42, .08);
    overflow: hidden;
    margin: .42rem 0;
}
.bar-fill { display: block; height: 100%; border-radius: 999px; }
.bar-fill.primary { background: linear-gradient(90deg, #1d4ed8, #2563eb); }
.bar-fill.secondary { background: linear-gradient(90deg, #0f766e, #14b8a6); }

.table-modern thead th {
    text-transform: uppercase;
    letter-spacing: .12em;
    font-size: .72rem;
    color: var(--text-tertiary);
    border-bottom-color: var(--border);
}
.table-modern td { border-bottom-color: rgba(15, 23, 42, .06); color: var(--text-primary); }
.table-modern tbody tr:last-child td { border-bottom: 0; }

.tone-positive { border-color: rgba(22, 163, 74, .22); }
.tone-warning { border-color: rgba(217, 119, 6, .22); }
.tone-danger { border-color: rgba(220, 38, 38, .22); }
.tone-info { border-color: rgba(14, 165, 233, .18); }
.tone-positive p:last-child,
.tone-positive .section-caption { color: var(--success); }
.tone-warning p:last-child,
.tone-warning .section-caption { color: var(--warning); }
.tone-danger p:last-child,
.tone-danger .section-caption { color: var(--danger); }
.tone-info p:last-child,
.tone-info .section-caption { color: var(--info); }

@media (max-width: 1399px) {
    .premium-hero { grid-template-columns: 1fr; }
    .context-rail { position: static; }
}

@media (max-width: 1199px) {
    .workspace-shell { grid-template-columns: 1fr; }
    .premium-sidebar {
        position: relative;
        height: auto;
    }
}

@media (max-width: 767px) {
    .marketing-header,
    .premium-topbar { align-items: flex-start; }
    .board-footer,
    .hero-metrics,
    .summary-grid { grid-template-columns: 1fr; }
    .topbar-actions { width: 100%; }
    .board-bars { grid-template-columns: repeat(5, minmax(42px, 1fr)); }
}

.app-body {
    min-height: 100vh;
    background:
        radial-gradient(circle at top right, rgba(29, 78, 216, .08), transparent 20rem),
        radial-gradient(circle at left top, rgba(15, 118, 110, .08), transparent 24rem),
        linear-gradient(180deg, #f7fafc 0%, #f3f7fb 42%, #f8fafc 100%);
}

.admin-body {
    background:
        radial-gradient(circle at top right, rgba(14, 165, 233, .08), transparent 18rem),
        radial-gradient(circle at left top, rgba(29, 78, 216, .07), transparent 22rem),
        linear-gradient(180deg, #f7fafc 0%, #f1f6fb 45%, #f8fafc 100%);
}

.app-shell {
    display: grid;
    grid-template-columns: 290px minmax(0, 1fr);
    min-height: 100vh;
}

.app-sidebar {
    position: sticky;
    top: 0;
    height: 100vh;
    overflow-y: auto;
    padding: 1.6rem 1.2rem;
    background: rgba(255,255,255,.92);
    color: var(--text-primary);
    border-right: 1px solid rgba(203, 213, 225, .92);
    backdrop-filter: blur(14px);
    box-shadow: 24px 0 50px rgba(15, 23, 42, .04);
}

.app-brand {
    display: flex;
    align-items: center;
    gap: .9rem;
    padding: .3rem .2rem 1.2rem;
}

.app-brand-mark {
    width: 2.9rem;
    height: 2.9rem;
    border-radius: 1rem;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, #1d4ed8 0%, #2563eb 55%, #0f766e 100%);
    color: #fff;
    font-weight: 800;
    letter-spacing: .08em;
    box-shadow: 0 18px 34px rgba(37, 99, 235, .22);
}

.app-brand strong,
.app-brand small {
    display: block;
}

.app-brand small,
.app-nav-group p,
.app-sidebar-note p {
    color: var(--text-secondary);
}

.app-nav-group + .app-nav-group {
    margin-top: 1.25rem;
}

.app-nav-group p {
    margin: 0 0 .55rem;
    font-size: .74rem;
    text-transform: uppercase;
    letter-spacing: .15em;
    font-weight: 700;
}

.app-nav-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .9rem;
    padding: .85rem .95rem;
    border-radius: 1.05rem;
    color: var(--text-secondary);
    transition: all .2s ease;
}

.app-nav-link span {
    display: inline-flex;
    align-items: center;
    gap: .7rem;
}

.app-nav-link small {
    min-width: 1.7rem;
    padding: .18rem .45rem;
    border-radius: 999px;
    background: rgba(29, 78, 216, .08);
    color: var(--primary);
    text-align: center;
    font-size: .72rem;
}

.app-nav-link:hover,
.app-nav-link.active {
    color: var(--text-primary);
    background: linear-gradient(135deg, rgba(29, 78, 216, .08), rgba(15, 118, 110, .08));
    box-shadow: inset 0 0 0 1px rgba(29, 78, 216, .10);
}

.app-sidebar-note {
    margin-top: 1.6rem;
    padding: 1rem;
    border-radius: 1.15rem;
    background: linear-gradient(180deg, #f8fbff 0%, #f2f7fb 100%);
    border: 1px solid rgba(203, 213, 225, .9);
}

.app-sidebar-note strong {
    display: block;
    margin: .45rem 0 .35rem;
}

.app-sidebar-footer {
    margin-top: 1.8rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(203, 213, 225, .7);
}

.sidebar-logout {
    min-height: 2.9rem;
}

.app-content {
    min-width: 0;
    padding: 1.35rem 1.35rem 2rem;
}

.app-topbar {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.35rem;
}

.app-topbar h1 {
    margin: .25rem 0 .35rem;
    font-size: clamp(1.5rem, 2vw, 1.8rem);
    line-height: 1.15;
}

.app-topbar p {
    margin: 0;
    color: var(--text-secondary);
    max-width: 54rem;
}

.app-topbar-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .65rem;
    align-items: center;
}

.app-main {
    min-width: 0;
}

.hero-panel,
.surface-card,
.glass-card,
.metric-tile,
.message-sample,
.message-preview {
    border: 1px solid rgba(226, 232, 240, .95);
    border-radius: 1.5rem;
    background: rgba(255,255,255,.96);
    box-shadow: 0 18px 44px rgba(15, 23, 42, .06);
}

.hero-panel {
    display: grid;
    grid-template-columns: minmax(0, 1.3fr) minmax(260px, .7fr);
    gap: 1rem;
    padding: 1.45rem;
    background:
        linear-gradient(145deg, rgba(255,255,255,.96), rgba(255,255,255,.88)),
        linear-gradient(120deg, rgba(14, 165, 233, .07), rgba(15, 118, 110, .06));
}

.hero-copy h2 {
    margin: .45rem 0 .55rem;
    font-size: clamp(1.35rem, 2vw, 1.65rem);
}

.hero-copy p {
    margin: 0;
    color: var(--text-secondary);
    max-width: 46rem;
}

.hero-kpis {
    display: grid;
    gap: .8rem;
}

.glass-card {
    padding: 1rem 1.05rem;
    background: linear-gradient(145deg, rgba(255,255,255,.96), rgba(240, 249, 255, .88));
    backdrop-filter: blur(14px);
}

.glass-card span,
.metric-tile span,
.mini-grid span,
.message-preview strong,
.section-title,
.timeline-item p,
.category-row p {
    color: var(--text-tertiary);
}

.glass-card strong,
.metric-tile strong,
.mini-grid strong {
    display: block;
    margin-top: .3rem;
}

.glass-card strong {
    font-size: 1.5rem;
}

.glass-card small {
    display: block;
    margin-top: .45rem;
    color: var(--text-secondary);
}

.surface-card {
    padding: 1.3rem;
}

.metric-tile {
    min-height: 100%;
    padding: 1.1rem 1.15rem;
}

.metric-tile strong {
    font-size: 1.55rem;
}

.metric-tile small {
    display: block;
    margin-top: .45rem;
    color: var(--text-secondary);
}

.metric-tile p {
    margin: .8rem 0 0;
    font-size: .88rem;
    font-weight: 700;
}

.section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.section-head h3 {
    margin: .25rem 0 0;
    font-size: 1.08rem;
}

.section-head small {
    color: var(--text-secondary);
}

.template-help {
    display: inline-grid;
    place-items: center;
    width: 1.05rem;
    height: 1.05rem;
    margin-left: .25rem;
    border-radius: 999px;
    background: rgba(29, 78, 216, .1);
    color: var(--primary);
    font-size: .72rem;
    font-weight: 800;
    cursor: help;
}

.template-config-note {
    display: grid;
    gap: .25rem;
    padding: .85rem .95rem;
    border-radius: 1rem;
    background: #f8fbff;
    border: 1px solid rgba(226, 232, 240, .9);
}

.template-config-note span {
    color: var(--text-secondary);
    font-size: .86rem;
    line-height: 1.5;
}

.page-intro-panel {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(320px, .8fr);
    gap: 1rem;
    padding: 1.4rem;
    border: 1px solid rgba(226, 232, 240, .95);
    border-radius: 1.5rem;
    background:
        linear-gradient(145deg, rgba(255,255,255,.97), rgba(255,255,255,.92)),
        linear-gradient(120deg, rgba(29, 78, 216, .05), rgba(15, 118, 110, .05));
    box-shadow: 0 24px 60px rgba(15, 23, 42, .06);
}

.page-intro-copy h2 {
    margin: .75rem 0 .65rem;
    font-size: clamp(1.5rem, 2.2vw, 2rem);
    line-height: 1.1;
}

.page-intro-copy p,
.page-summary-primary p {
    margin: 0;
    color: var(--text-secondary);
    line-height: 1.7;
}

.page-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: .55rem;
}

.page-chip {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: .35rem .85rem;
    border-radius: 999px;
    background: rgba(148, 163, 184, .12);
    color: var(--text-secondary);
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .02em;
}

.page-chip-primary {
    background: rgba(29, 78, 216, .10);
    color: var(--primary);
}

.page-intro-summary {
    display: grid;
    gap: .85rem;
}

.page-summary-primary,
.page-summary-grid > div {
    padding: 1rem 1.05rem;
    border-radius: 1.2rem;
    background: #ffffff;
    border: 1px solid rgba(226, 232, 240, .95);
}

.page-summary-primary span,
.page-summary-grid span {
    display: block;
    color: var(--text-tertiary);
    font-size: .82rem;
}

.page-summary-primary strong {
    display: block;
    margin: .35rem 0 .45rem;
    font-size: clamp(1.8rem, 3vw, 2.4rem);
}

.page-summary-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .85rem;
}

.page-summary-grid strong {
    display: block;
    margin-top: .3rem;
    font-size: 1.02rem;
}

.chart-bars {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(88px, 1fr));
    gap: 1rem;
    align-items: end;
    min-height: 18rem;
}

.chart-bar-group {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .65rem;
}

.chart-bar-stack {
    width: 100%;
    min-height: 14rem;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    gap: .55rem;
    padding: .85rem .55rem;
    border-radius: 1.15rem;
    background: linear-gradient(180deg, #f8fbff, #f1f5f9);
}

.bar {
    width: 1.15rem;
    min-height: .5rem;
    border-radius: 999px;
}

.bar.income {
    background: linear-gradient(180deg, #22c55e 0%, #0f766e 100%);
}

.bar.expense {
    background: linear-gradient(180deg, #60a5fa 0%, #2563eb 100%);
}

.timeline-list,
.insight-list,
.category-list,
.message-sample-list {
    display: grid;
    gap: .75rem;
}

.timeline-item,
.insight-row,
.category-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: .95rem 1rem;
    border-radius: 1.1rem;
    background: #f8fbff;
    border: 1px solid rgba(226, 232, 240, .88);
}

.timeline-item strong,
.insight-row strong,
.category-row strong {
    display: block;
    margin-bottom: .2rem;
}

.timeline-item p,
.insight-row p,
.category-row p,
.message-preview p {
    margin: 0;
}

.amount {
    font-weight: 700;
    white-space: nowrap;
}

.amount.positive {
    color: var(--success);
}

.amount.negative {
    color: var(--danger);
}

.insight-row {
    display: block;
}

.mini-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: .8rem;
}

.mini-grid > div {
    padding: .95rem 1rem;
    border-radius: 1.1rem;
    background: #f8fbff;
    border: 1px solid rgba(226, 232, 240, .88);
}

.message-sample {
    padding: .85rem 1rem;
    font-size: .92rem;
}

.message-preview {
    padding: 1rem 1.05rem;
}

.message-preview p {
    margin-top: .45rem;
    color: var(--text-secondary);
}

.category-row > div {
    min-width: 0;
}

.category-row span {
    font-weight: 700;
    white-space: nowrap;
}

.surface-card .form-label,
.auth-card .form-label {
    font-size: .82rem;
    color: var(--text-secondary);
    font-weight: 700;
}

.form-control,
.form-select {
    min-height: 3rem;
    border-radius: 1rem;
    border-color: rgba(203, 213, 225, .92);
    padding-inline: .95rem;
    box-shadow: none;
}

.form-control:focus,
.form-select:focus {
    border-color: rgba(37, 99, 235, .55);
    box-shadow: 0 0 0 .24rem rgba(59, 130, 246, .12);
}

.form-check {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    min-height: 3rem;
    width: 100%;
    padding: .9rem 1rem;
    border-radius: 1rem;
    background: #f8fbff;
    border: 1px solid rgba(226, 232, 240, .9);
}

.form-check-input {
    margin-top: 0;
}

.account-form {
    gap: 1.1rem;
}

.account-toggle {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .75rem;
}

.account-toggle-button {
    min-height: 3.25rem;
    border: 1px solid rgba(203, 213, 225, .92);
    border-radius: 1rem;
    background: #f8fbff;
    color: var(--text-secondary);
    font-weight: 700;
    transition: all .2s ease;
}

.account-toggle-button.active {
    color: #fff;
    border-color: rgba(37, 99, 235, .45);
    background: linear-gradient(135deg, #2563eb 0%, #14b8a6 100%);
    box-shadow: 0 18px 34px rgba(37, 99, 235, .18);
}

.account-section {
    display: none;
    padding: 1rem;
    border-radius: 1.2rem;
    background: linear-gradient(180deg, #fbfdff 0%, #f4f8fc 100%);
    border: 1px solid rgba(226, 232, 240, .92);
}

.account-section.active {
    display: block;
}

.account-section-header h3 {
    margin: .35rem 0;
    font-size: 1.05rem;
}

.account-section-header p {
    margin: 0;
    color: var(--text-secondary);
}

.table-modern {
    --bs-table-bg: transparent;
}

.admin-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 1rem;
}

.kpi-grid-10 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.kpi-grid-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.kpi-grid-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.donut-chart {
    width: min(220px, 68vw);
    aspect-ratio: 1;
    margin-inline: auto;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background:
        radial-gradient(circle, #fff 0 48%, transparent 49%),
        conic-gradient(
            var(--chart-tone-1) 0 calc(var(--segment-1) * 1%),
            var(--chart-tone-2) calc(var(--segment-1) * 1%) calc((var(--segment-1) + var(--segment-2)) * 1%),
            var(--chart-tone-3) calc((var(--segment-1) + var(--segment-2)) * 1%) calc((var(--segment-1) + var(--segment-2) + var(--segment-3)) * 1%),
            var(--chart-tone-4) calc((var(--segment-1) + var(--segment-2) + var(--segment-3)) * 1%) 100%);
    box-shadow: inset 0 0 0 1px rgba(226, 232, 240, .85), 0 22px 44px rgba(15, 23, 42, .08);
}

.donut-chart span {
    display: grid;
    place-items: center;
    width: 6rem;
    height: 6rem;
    border-radius: 50%;
    background: #fff;
    color: var(--text-primary);
    font-weight: 800;
    font-size: 1.35rem;
    box-shadow: 0 14px 30px rgba(15, 23, 42, .08);
}

.chart-legend {
    display: grid;
    gap: .65rem;
}

.chart-legend div {
    display: grid;
    grid-template-columns: 12px minmax(0, 1fr) auto;
    align-items: center;
    gap: .7rem;
    padding: .7rem .8rem;
    border-radius: 1rem;
    background: #f8fbff;
    border: 1px solid rgba(226, 232, 240, .9);
}

.chart-legend span {
    width: .75rem;
    height: .75rem;
    border-radius: 999px;
    background: var(--chart-tone-1);
}

.chart-legend .tone-1 span { background: var(--chart-tone-1); }
.chart-legend .tone-2 span { background: var(--chart-tone-2); }
.chart-legend .tone-3 span { background: var(--chart-tone-3); }
.chart-legend .tone-4 span { background: var(--chart-tone-4); }

.chart-legend small {
    color: var(--text-secondary);
    font-weight: 800;
}

.modern-bars {
    display: grid;
    gap: .9rem;
}

.modern-bar-row {
    display: grid;
    grid-template-columns: minmax(90px, 1fr) minmax(120px, 2fr) auto;
    align-items: center;
    gap: .85rem;
}

.modern-bar-row span,
.modern-bar-row strong {
    font-size: .9rem;
}

.modern-bar-row div {
    height: .9rem;
    border-radius: 999px;
    overflow: hidden;
    background: linear-gradient(90deg, rgba(148, 163, 184, .18), rgba(226, 232, 240, .58));
}

.modern-bar-row i {
    display: block;
    height: 100%;
    min-width: .55rem;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--chart-tone-1), var(--chart-tone-3));
    box-shadow: 0 0 24px rgba(29, 78, 216, .18);
}

.modern-bar-row strong small {
    color: var(--text-muted);
    font-weight: 700;
}

.dual-bar-row,
.ranked-bar-row {
    display: grid;
    grid-template-columns: minmax(86px, 1fr) minmax(140px, 2fr) auto;
    align-items: center;
    gap: .75rem;
    color: var(--text-muted);
    font-size: .84rem;
}

.dual-bar-row > div,
.ranked-bar-row > div {
    display: grid;
    gap: .25rem;
}

.dual-bar-row i,
.dual-bar-row b,
.ranked-bar-row i {
    display: block;
    height: .46rem;
    min-width: .4rem;
    border-radius: 999px;
}

.dual-bar-row i {
    background: #2563eb;
}

.dual-bar-row b {
    background: #10b981;
}

.ranked-bar-row i {
    background: linear-gradient(90deg, #0f766e, #38bdf8);
}

.dual-bar-row strong,
.ranked-bar-row span,
.dual-bar-row span,
.ranked-bar-row strong {
    color: var(--text-primary);
    font-weight: 800;
}

.brazil-region-map {
    position: relative;
    min-height: 310px;
    border-radius: 1.25rem;
    border: 1px solid rgba(15, 23, 42, .08);
    background:
        linear-gradient(135deg, rgba(14, 165, 233, .13), transparent 45%),
        linear-gradient(225deg, rgba(16, 185, 129, .14), transparent 48%),
        #f8fafc;
    overflow: hidden;
}

.brazil-region-map::before {
    content: "";
    position: absolute;
    inset: 2.25rem 3.25rem 2rem 4rem;
    border-radius: 42% 58% 48% 52% / 35% 30% 70% 65%;
    background: rgba(15, 118, 110, .1);
    border: 1px solid rgba(15, 118, 110, .16);
    transform: rotate(-12deg);
}

.region-node {
    position: absolute;
    min-width: 7.25rem;
    padding: .7rem .8rem;
    border-radius: .9rem;
    background: rgba(255, 255, 255, .92);
    border: 1px solid rgba(15, 23, 42, .08);
    box-shadow: 0 16px 35px rgba(15, 23, 42, .1);
}

.region-node strong,
.region-node span {
    display: block;
}

.region-node strong {
    color: var(--text-primary);
    font-size: .82rem;
}

.region-node span {
    color: #0f766e;
    font-size: 1.35rem;
    font-weight: 900;
    line-height: 1.1;
}

.region-sudeste { right: 18%; bottom: 24%; }
.region-sul { right: 24%; bottom: 6%; }
.region-centro-oeste { left: 34%; top: 42%; }
.region-nordeste { right: 8%; top: 20%; }
.region-norte { left: 18%; top: 12%; }
.region-nao-informado { left: 6%; bottom: 8%; }

.line-chart {
    min-height: 17rem;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(70px, 1fr));
    align-items: end;
    gap: .9rem;
    padding: 1rem;
    border-radius: 1.2rem;
    background: linear-gradient(180deg, #f8fbff 0%, #eef6fb 100%);
    border: 1px solid rgba(226, 232, 240, .92);
}

.line-chart.compact {
    min-height: 13rem;
}

.line-point {
    min-height: 12rem;
    display: grid;
    grid-template-rows: 1fr auto auto;
    justify-items: center;
    gap: .4rem;
}

.line-point span {
    align-self: end;
    width: 100%;
    max-width: 2.2rem;
    height: max(.7rem, var(--h));
    border-radius: 1rem 1rem .45rem .45rem;
    background: linear-gradient(180deg, #60a5fa 0%, #1d4ed8 45%, #14b8a6 100%);
    box-shadow: 0 16px 34px rgba(29, 78, 216, .18);
}

.line-point strong,
.line-point small {
    text-align: center;
    font-size: .78rem;
    color: var(--text-secondary);
}

.bar-chart-grid {
    min-height: 18rem;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(72px, 1fr));
    gap: .95rem;
    align-items: end;
    padding: 1rem;
    border-radius: 1.2rem;
    background:
        linear-gradient(180deg, rgba(18, 60, 190, .05), rgba(255,255,255,.92)),
        linear-gradient(180deg, #f7faff 0%, #eef4fb 100%);
    border: 1px solid rgba(217, 226, 240, .92);
}

.bar-chart-column {
    min-height: 14rem;
    display: grid;
    grid-template-rows: auto 1fr auto;
    gap: .55rem;
    align-items: end;
}

.bar-chart-column small,
.bar-chart-column strong {
    text-align: center;
    color: var(--text-secondary);
}

.bar-chart-track {
    position: relative;
    min-height: 11rem;
    border-radius: 1rem;
    background:
        repeating-linear-gradient(
            to top,
            rgba(15, 23, 42, .04) 0,
            rgba(15, 23, 42, .04) 1px,
            transparent 1px,
            transparent 20%
        ),
        linear-gradient(180deg, rgba(255,255,255,.9), rgba(235, 242, 252, .9));
    border: 1px solid rgba(217, 226, 240, .9);
    overflow: hidden;
    display: flex;
    align-items: flex-end;
}

.bar-chart-track i {
    width: 100%;
    min-height: .8rem;
    border-radius: 1rem 1rem .7rem .7rem;
    background: linear-gradient(180deg, var(--chart-tone-3) 0%, var(--chart-tone-2) 46%, var(--chart-tone-1) 100%);
    box-shadow: 0 16px 28px rgba(18, 60, 190, .22);
}

.mini-bars {
    display: grid;
    gap: .85rem;
}

.mini-bar-row {
    display: grid;
    grid-template-columns: 64px minmax(0, 1fr) auto;
    align-items: center;
    gap: .85rem;
}

.mini-bar-row strong,
.mini-bar-row span {
    font-size: .84rem;
}

.mini-bar-row div {
    height: .72rem;
    border-radius: 999px;
    overflow: hidden;
    background: linear-gradient(90deg, rgba(200, 214, 246, .32), rgba(217, 226, 240, .7));
}

.mini-bar-row i {
    display: block;
    height: 100%;
    min-width: .55rem;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--chart-tone-1), var(--chart-tone-2));
}

.settings-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.automation-option,
.admin-check-card {
    display: flex;
    align-items: flex-start;
    gap: .9rem;
    padding: 1rem 1.05rem;
    border-radius: 1.2rem;
    background: linear-gradient(180deg, #fbfdff 0%, #f4f8fc 100%);
    border: 1px solid rgba(217, 226, 240, .92);
    min-height: 100%;
}

.automation-option strong,
.admin-check-card strong {
    display: block;
    margin-bottom: .2rem;
}

.automation-option small,
.admin-check-card small {
    color: var(--text-secondary);
    line-height: 1.55;
}

.admin-check-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.admin-check-card--inline {
    justify-content: space-between;
    align-items: center;
}

.admin-check-card--inline .form-control {
    max-width: 11rem;
}

.profile-view-banner {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.1rem;
    border-radius: 1.2rem;
    background: linear-gradient(135deg, rgba(29, 78, 216, .1), rgba(20, 184, 166, .1));
    border: 1px solid rgba(37, 99, 235, .16);
    box-shadow: 0 18px 44px rgba(15, 23, 42, .06);
}

.profile-view-banner i {
    display: grid;
    place-items: center;
    width: 2.8rem;
    height: 2.8rem;
    border-radius: 1rem;
    color: #fff;
    background: linear-gradient(135deg, #1d4ed8, #14b8a6);
}

.profile-view-banner strong,
.profile-view-banner span {
    display: block;
}

.profile-view-banner span,
.payment-note {
    color: var(--text-secondary);
}

.table-actions,
.action-stack {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
}

.action-stack {
    display: grid;
}

.payment-panel {
    padding: 1rem;
    border-radius: 1.2rem;
    background: linear-gradient(180deg, #fbfdff 0%, #f4f8fc 100%);
    border: 1px solid rgba(226, 232, 240, .92);
}

.payment-panel-error {
    border-color: rgba(239, 68, 68, .35);
    box-shadow: 0 0 0 .22rem rgba(239, 68, 68, .08);
}

.table-modern td,
.table-modern th {
    vertical-align: middle;
    padding-block: .9rem;
}

.table-modern tbody td small {
    color: var(--text-secondary);
}

.tone-positive {
    border-color: rgba(34, 197, 94, .22);
}

.tone-warning {
    border-color: rgba(245, 158, 11, .26);
}

.tone-danger {
    border-color: rgba(239, 68, 68, .22);
}

.tone-info {
    border-color: rgba(14, 165, 233, .22);
}

.tone-positive p:last-child,
.tone-positive .eyebrow {
    color: var(--success);
}

.tone-warning p:last-child,
.tone-warning .eyebrow {
    color: var(--warning);
}

.tone-danger p:last-child,
.tone-danger .eyebrow {
    color: var(--danger);
}

.tone-info p:last-child,
.tone-info .eyebrow {
    color: var(--info);
}

@media (max-width: 1199px) {
    .app-shell {
        grid-template-columns: 1fr;
    }

    .app-sidebar {
        position: relative;
        height: auto;
    }

    .hero-panel {
        grid-template-columns: 1fr;
    }

    .page-intro-panel {
        grid-template-columns: 1fr;
    }

    .kpi-grid-10,
    .kpi-grid-5,
    .kpi-grid-4 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .app-content {
        padding-inline: 1rem;
    }

    .app-topbar {
        flex-direction: column;
    }

    .app-topbar-actions {
        width: 100%;
    }

    .chart-bars {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .page-summary-grid {
        grid-template-columns: 1fr;
    }

    .timeline-item,
    .category-row {
        flex-direction: column;
    }

    .account-toggle {
        grid-template-columns: 1fr;
    }

    .settings-grid,
    .admin-check-grid,
    .kpi-grid-10,
    .kpi-grid-5,
    .kpi-grid-4 {
        grid-template-columns: 1fr;
    }

    .bar-chart-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .admin-check-card--inline {
        align-items: flex-start;
        flex-direction: column;
    }

    .admin-check-card--inline .form-control {
        max-width: none;
        width: 100%;
    }
}
