/* ═══════════════════════════════════════════════
   WHITE LABEL — padrão do sistema
   (sobrescrito dinamicamente por CSS Variables)
═══════════════════════════════════════════════ */
:root {
  --brand:     #e8455a;
  --brand2:    #f0a832;
  --brand-rgb: 232,69,90;
  --green:  #27c97c; --blue: #4b8ef0; --purple: #9b72f0;
  --cyan:   #22d3ee; --red:  #e8455a; --amber:  #f0a832;
  --bg:  #0b0d12; --bg2: #10131a; --card: #161922;
  --card2: #1c2030; --border: #21263a;
  --text: #eaedf5; --muted: #6b7385; --muted2: #2e3348;
}


/* ═══════════════════════════════════════════════
   FONT SIZE TOKENS (Acessibilidade)
═══════════════════════════════════════════════ */
:root {
  --fs-body: 0.87rem;
  --fs-val: 1.45rem;
  --fs-label: 0.65rem;
  --fs-nav: 0.86rem;
  --fs-card-val: 1.5rem;
  --fs-muted: 0.74rem;
}

/* ═══════════════════════════════════════════════
   LIGHT MODE
═══════════════════════════════════════════════ */
[data-theme="light"] {
  --bg: #f5f5f5;
  --bg2: #ffffff;
  --card: #ffffff;
  --card2: #f0f0f0;
  --border: #e0e0e0;
  --text: #1a1a2e;
  --muted: #555b6e;
  --muted2: #c8ccd8;
}
[data-theme="light"] aside {
  border-right-color: #e0e0e0;
  background: #fafafa;
}
[data-theme="light"] .topbar {
  background: #ffffff;
  border-bottom-color: #e0e0e0;
}
[data-theme="light"] .kcard {
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
  border: 1px solid #e8e8e8;
}
[data-theme="light"] .fg input,
[data-theme="light"] .fg select,
[data-theme="light"] .cfg-input {
  background: #f5f5f5;
  color: #1a1a2e;
  border-color: #d0d0d0;
}
[data-theme="light"] .fg input:focus,
[data-theme="light"] .fg select:focus {
  border-color: var(--brand);
}
[data-theme="light"] .form-grid,
[data-theme="light"] .twrap,
[data-theme="light"] .mcp,
[data-theme="light"] .cfg-section,
[data-theme="light"] .cc,
[data-theme="light"] .ppanel,
[data-theme="light"] .plan-card,
[data-theme="light"] .acard,
[data-theme="light"] .mccard,
[data-theme="light"] .est-card,
[data-theme="light"] .admin-table-wrap,
[data-theme="light"] .ap-meta-form {
  background: #ffffff;
  border-color: #e0e0e0;
}
[data-theme="light"] .ttable thead th {
  background: #f5f5f5;
  color: #555b6e;
}
[data-theme="light"] .ttable tbody tr:hover {
  background: #f9f9f9;
}
[data-theme="light"] .ttable tbody td {
  border-bottom-color: #eee;
}
[data-theme="light"] .mitem.act {
  background: var(--brand);
  color: #fff;
}
[data-theme="light"] .mitem:hover {
  background: #f0f0f0;
}
[data-theme="light"] .auth-box {
  background: #ffffff;
  border-color: #e0e0e0;
  box-shadow: 0 4px 24px rgba(0,0,0,.08);
}
[data-theme="light"] .auth-fg input {
  background: #f5f5f5;
  border-color: #d0d0d0;
  color: #1a1a2e;
}
[data-theme="light"] .auth-tab {
  color: #555b6e;
}
[data-theme="light"] .auth-tab.act {
  background: #f5f5f5;
  color: #1a1a2e;
  box-shadow: 0 1px 4px rgba(0,0,0,.08);
}
[data-theme="light"] .modal {
  background: #ffffff;
  border-color: #e0e0e0;
}
[data-theme="light"] .moverlay {
  background: rgba(0,0,0,.3);
}
[data-theme="light"] .mob-header {
  background: #ffffff;
  border-bottom-color: #e0e0e0;
}
[data-theme="light"] .mob-bottom-nav {
  background: #ffffff;
  border-top-color: #e0e0e0;
}
[data-theme="light"] .fc-mes-pill {
  background: #f0f0f0;
  color: #555b6e;
}
[data-theme="light"] .fc-mes-pill.act {
  background: var(--brand);
  color: #fff;
}
[data-theme="light"] .btn-nm {
  border-color: #d0d0d0;
  color: #555b6e;
}
[data-theme="light"] .side-footer {
  border-top-color: #e0e0e0;
}
[data-theme="light"] .tag.te { background: rgba(39,201,124,.12); color: #1a8a55; }
[data-theme="light"] .tag.ts { background: rgba(232,69,90,.12); color: #c0344a; }
[data-theme="light"] .tag.ti { background: rgba(75,142,240,.12); color: #2a6ad0; }
[data-theme="light"] .ctag { background: #f0f0f0; color: #555b6e; }
[data-theme="light"] .shead { color: #1a1a2e; }

/* ═══════════════════════════════════════════════
   THEME TOGGLE BUTTON
═══════════════════════════════════════════════ */
.theme-toggle {
  background: none;
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--muted);
  cursor: pointer;
  font-size: 1.05rem;
  padding: 5px 9px;
  transition: all .2s;
  line-height: 1;
}
.theme-toggle:hover {
  border-color: var(--brand);
  color: var(--brand);
}

/* ═══════════════════════════════════════════════
   ACCORDION — Limites de Gastos
═══════════════════════════════════════════════ */
.mcp-accordion-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  font-family: 'Syne', sans-serif;
}
.mcp-arrow {
  font-size: .7rem;
  transition: transform .3s ease;
  color: var(--muted);
}
.mcp-arrow.open {
  transform: rotate(180deg);
}
.mcp-body {
  overflow: hidden;
  max-height: 0;
  transition: max-height .35s ease, opacity .3s ease;
  opacity: 0;
}
.mcp-body.open {
  max-height: 600px;
  opacity: 1;
}
.mcp-head-label {
  font-size: .62rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-weight: 700;
  transition: color .2s;
}

*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--border) transparent;}
body{background:var(--bg);color:var(--text);font-family:'Syne',sans-serif;min-height:100vh;font-size:var(--fs-body);}

/* AUTH — estilos base movidos pro bloco AUTH SPLIT DESKTOP no final */
.auth-logo{font-family:'Playfair Display',serif;font-size:2.4rem;background:linear-gradient(135deg,var(--brand),var(--brand2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-align:center;margin-bottom:6px;}
.auth-sub{text-align:center;font-size:.75rem;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:28px;}
.auth-tabs{display:flex;background:var(--bg2);border-radius:10px;padding:4px;margin-bottom:24px;}
.auth-tab{flex:1;text-align:center;padding:8px;border-radius:7px;cursor:pointer;font-size:.82rem;font-weight:600;color:var(--muted);transition:all .2s;}
.auth-tab.act{background:var(--card);color:var(--text);box-shadow:0 1px 6px rgba(0,0,0,.4);}
.auth-fg{display:flex;flex-direction:column;gap:5px;margin-bottom:14px;}
.auth-fg label{font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;}
.auth-fg input{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:11px 13px;color:var(--text);font-family:'Syne',sans-serif;font-size:.85rem;width:100%;transition:border-color .15s;}
.auth-fg input:focus{outline:none;border-color:var(--brand);}
.auth-btn{width:100%;padding:12px;border-radius:9px;border:none;background:var(--brand);color:#fff;font-family:'Syne',sans-serif;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s;margin-top:6px;}
.auth-btn:hover{filter:brightness(1.1);}
.auth-btn:disabled{opacity:.6;cursor:not-allowed;}
.auth-msg{font-size:.78rem;text-align:center;margin-top:10px;min-height:20px;line-height:1.5;}
.auth-msg.err{color:var(--red);}
.auth-msg.ok{color:var(--green);}

/* APP */
#app{display:none;min-height:100vh;}
#app.show{display:flex;height:100vh;overflow:hidden;}

/* SIDEBAR */
aside{width:260px;min-height:100vh;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:40;}
.logo-wrap{padding:24px 18px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;}
.logo-img{width:32px;height:32px;border-radius:8px;flex-shrink:0;object-fit:cover;}
.logo-img-svg{width:40px;height:40px;border-radius:12px;flex-shrink:0;background:var(--brand);display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:1.1rem;color:#fff;font-weight:700;}
.logo-texts{display:flex;flex-direction:column;}
.logo-text{font-family:'Playfair Display',serif;font-size:1.4rem;background:linear-gradient(135deg,var(--brand),var(--brand2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1;}
.logo-sub{font-size:.55rem;color:var(--muted);margin-top:2px;letter-spacing:2px;text-transform:uppercase;}
.snav{display:flex;flex-direction:column;gap:4px;padding:14px 12px 0;}
.ni{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;cursor:pointer;font-size:var(--fs-nav);color:var(--muted);font-weight:600;transition:all .2s;}
.ni span:first-child{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:var(--card2);font-size:1rem;flex-shrink:0;transition:all .2s;}
.ni.act span:first-child{background:rgba(var(--brand-rgb),.18);}
.ni:hover span:first-child{background:rgba(var(--brand-rgb),.1);}
.ni:hover{background:rgba(var(--brand-rgb),.06);color:var(--text);}
.ni.act{background:rgba(var(--brand-rgb),.14);color:var(--brand);border-left:3px solid var(--brand);}
.sdiv{height:1px;background:var(--border);margin:10px 18px;}
.mlist{flex:1;padding:0 10px;overflow-y:auto;}
.mlabel{font-size:.56rem;color:var(--muted);letter-spacing:2px;text-transform:uppercase;padding:0 8px;margin-bottom:7px;}
.mitem{display:flex;align-items:center;justify-content:space-between;padding:7px 11px;border-radius:8px;cursor:pointer;font-size:.78rem;color:var(--muted);font-weight:600;transition:all .15s;margin-bottom:2px;}
.mitem:hover{background:var(--card);color:var(--text);}
.mitem.act{background:var(--brand);color:#fff;}
.dok{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0;}
.dbad{width:6px;height:6px;border-radius:50%;background:var(--red);flex-shrink:0;}
.dem{width:6px;height:6px;border-radius:50%;background:var(--muted2);flex-shrink:0;}
.btn-nm{margin:8px 10px 16px;padding:9px;border:1px dashed var(--border);border-radius:8px;background:none;color:var(--muted);font-family:'Syne',sans-serif;font-size:.76rem;cursor:pointer;width:calc(100% - 20px);transition:all .2s;}
.btn-nm:hover{border-color:var(--brand);color:var(--brand);}
.side-footer{padding:10px 14px;border-top:1px solid var(--border);}
.side-user{font-size:.68rem;color:var(--muted);display:flex;align-items:center;justify-content:space-between;gap:6px;}
.side-email{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;}
.pro-badge{font-size:.58rem;padding:2px 6px;border-radius:4px;font-weight:700;flex-shrink:0;background:linear-gradient(135deg,#f0a832,#e8455a);color:#fff;letter-spacing:.5px;}
.free-badge{font-size:.58rem;padding:2px 6px;border-radius:4px;font-weight:700;flex-shrink:0;background:var(--muted2);color:var(--muted);}
.logout-btn{background:none;border:none;color:var(--muted2);cursor:pointer;font-size:.8rem;padding:3px 5px;border-radius:4px;transition:all .15s;flex-shrink:0;}
.logout-btn:hover{color:var(--red);}

/* MOBILE SIDEBAR TOGGLE */
.mob-header{display:none;padding:12px 16px;background:var(--bg2);border-bottom:1px solid var(--border);align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;}

/* ═══ FILTROS ATIVOS ═══ */
.ctag{
  display:inline-block;padding:4px 10px;border-radius:6px;font-size:.65rem;
  font-weight:600;cursor:pointer;border:1px solid var(--border);
  background:var(--card2);color:var(--muted);transition:all .2s;
  font-family:'Syne',sans-serif;
}
.ctag:hover{border-color:var(--brand);color:var(--brand);}
.ctag.act{
  background:var(--brand);color:#fff;border-color:var(--brand);
  box-shadow:0 2px 8px rgba(232,69,90,.25);
}

@media(max-width:768px){.mob-header{display:flex!important;}}
.mob-logo{font-family:'Playfair Display',serif;font-size:1.3rem;background:linear-gradient(135deg,var(--brand),var(--brand2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.mob-menu-btn{background:none;border:none;color:var(--text);font-size:1.4rem;cursor:pointer;padding:4px 8px;}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:35;}
.sidebar-overlay.show{display:block;}
aside.mob-open{transform:translateX(0)!important;}

/* MAIN */
main{flex:1;display:flex;flex-direction:column;min-width:0;overflow-x:hidden;overflow-y:auto;height:100vh;}
.topbar{padding:14px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg2);position:sticky;top:0;z-index:20;gap:10px;flex-wrap:wrap;}
.tb-title{font-family:'Playfair Display',serif;font-size:1.2rem;flex-shrink:0;}
.tb-right{display:flex;gap:7px;align-items:center;flex-wrap:wrap;}
.sync-wrap{font-size:.62rem;color:var(--muted);display:flex;align-items:center;gap:5px;}
.sync-dot{width:6px;height:6px;border-radius:50%;background:var(--green);}
.sync-dot.busy{background:var(--amber);animation:pulse 1s infinite;}
.sync-dot.err{background:var(--red);}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.3;}}
@keyframes spin{to{transform:rotate(360deg);}}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}

.btn{padding:7px 13px;border-radius:7px;border:none;cursor:pointer;font-family:'Syne',sans-serif;font-size:.74rem;font-weight:700;display:flex;align-items:center;gap:5px;transition:all .2s;white-space:nowrap;}
.btn-r{background:var(--brand);color:#fff;}.btn-r:hover{filter:brightness(1.1);}
.btn-g{background:var(--card);color:var(--muted);border:1px solid var(--border);}.btn-g:hover{color:var(--text);}
.btn-p{background:rgba(155,114,240,.14);color:var(--purple);border:1px solid rgba(155,114,240,.28);}
.btn-c{background:rgba(34,211,238,.1);color:var(--cyan);border:1px solid rgba(34,211,238,.22);}

.content{padding:20px 24px;flex:1;}
.page{display:none;animation:fadeUp .2s ease;}.page.act{display:block;}

/* PAYWALL BANNER */
.paywall-banner{background:linear-gradient(135deg,rgba(240,168,50,.1),rgba(232,69,90,.08));border:1px solid rgba(240,168,50,.3);border-radius:12px;padding:16px 20px;margin-bottom:18px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.paywall-text{font-size:.82rem;color:var(--amber);}
.paywall-text strong{display:block;font-size:.9rem;margin-bottom:3px;}
.paywall-btn{padding:8px 18px;border-radius:8px;border:none;background:linear-gradient(135deg,var(--brand),var(--amber));color:#fff;font-family:'Syne',sans-serif;font-size:.78rem;font-weight:700;cursor:pointer;flex-shrink:0;}

/* KPIs */
.kgrid{display:grid;grid-template-columns:repeat(5,1fr);gap:11px;margin-bottom:18px;}
.kcard{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:15px;position:relative;overflow:hidden;transition:transform .2s;}
.kcard:hover{transform:translateY(-1px);}
.kcard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--kc,var(--brand));}
.klabel{font-size:var(--fs-label);color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:6px;}
.kval{font-family:'Playfair Display',serif;font-size:var(--fs-card-val);line-height:1;}
.ksub{font-size:.62rem;color:var(--muted);margin-top:4px;}
.ok{color:var(--green);}.bad{color:var(--red);}

/* CHARTS */
.crow{display:grid;grid-template-columns:1fr 1fr;gap:13px;margin-bottom:18px;}
.crow3{display:grid;grid-template-columns:repeat(3,1fr);gap:13px;margin-bottom:18px;}
.cc{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:17px;}
.clabel{font-size:.56rem;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:11px;}
.cwrap{height:200px;position:relative;width:100%;}

/* METAS CONFIG */
.mcp{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px;margin-bottom:18px;}
.mcp-head{font-size:.56rem;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;}
.mcp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
.mcp-item{display:flex;flex-direction:column;gap:5px;}
.mcp-name{font-size:.7rem;font-weight:700;}
.mcp-atual{font-size:.6rem;color:var(--muted);}
.mcp-iw{display:flex;align-items:center;gap:5px;background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:7px 9px;transition:border-color .15s;}
.mcp-iw:focus-within{border-color:var(--brand);}
.mcp-px{font-size:.7rem;color:var(--muted);}
.mcp-in{background:none;border:none;outline:none;color:var(--text);font-family:'Syne',sans-serif;font-size:.84rem;font-weight:700;width:100%;}
.mcp-bar{height:4px;background:var(--border);border-radius:999px;margin-top:3px;overflow:hidden;}
.mcp-fill{height:100%;border-radius:999px;transition:width .4s;}
.mcp-hint{font-size:.6rem;color:var(--muted2);}

/* META BARS */
.mbwrap{margin-bottom:11px;}
.mbhead{display:flex;justify-content:space-between;align-items:center;margin-bottom:3px;flex-wrap:wrap;gap:4px;}
.mbname{font-size:.76rem;font-weight:600;}
.mbvals{font-size:.65rem;color:var(--muted);}
.mtrack{height:6px;background:var(--border);border-radius:999px;overflow:hidden;}
.mfill{height:100%;border-radius:999px;transition:width .5s cubic-bezier(.4,0,.2,1);}

/* FORM */
.shead{font-size:.56rem;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:10px;display:flex;align-items:center;gap:10px;}
.shead::after{content:'';flex:1;height:1px;background:var(--border);}
.form-grid{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px;display:flex;gap:9px;align-items:flex-end;margin-bottom:12px;flex-wrap:wrap;}
.fg{display:flex;flex-direction:column;gap:4px;flex:1;min-width:90px;}
.fg label{font-size:.56rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;}
.fg input,.fg select{background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:8px 10px;color:var(--text);font-family:'Syne',sans-serif;font-size:.79rem;width:100%;transition:border-color .15s;}
.fg input:focus,.fg select:focus{outline:none;border-color:var(--brand);}
.fg-fixed{flex:0 0 auto;}

/* TABLE */
.twrap{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:18px;}
.ttable{width:100%;border-collapse:collapse;}
.ttable th{text-align:left;font-size:.56rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;padding:10px 12px;border-bottom:1px solid var(--border);}
.ttable td{padding:9px 12px;font-size:.78rem;border-bottom:1px solid var(--bg2);vertical-align:middle;}
.ttable tr:last-child td{border-bottom:none;}
.ttable tr:hover td{background:var(--card2);}
.tag{display:inline-block;padding:2px 7px;border-radius:4px;font-size:.6rem;font-weight:700;text-transform:uppercase;}
.te{background:rgba(39,201,124,.12);color:var(--green);}
.ts{background:rgba(232,69,90,.12);color:var(--red);}
.ti{background:rgba(75,142,240,.12);color:var(--blue);}

.dbtn{background:none;border:none;color:var(--muted2);cursor:pointer;font-size:.82rem;padding:3px 6px;border-radius:4px;transition:all .15s;}
.dbtn:hover{background:rgba(232,69,90,.1);color:var(--red);}
.empty{padding:28px;text-align:center;color:var(--muted);font-size:.8rem;}

/* ANNUAL TABLE */
.atable{width:100%;border-collapse:collapse;}
.atable th{font-size:.56rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;padding:8px 10px;border-bottom:1px solid var(--border);text-align:right;}
.atable th:first-child{text-align:left;}
.atable td{padding:8px 10px;font-size:.74rem;border-bottom:1px solid var(--bg2);text-align:right;font-family:'Playfair Display',serif;}
.atable td:first-child{text-align:left;font-family:'Syne',sans-serif;font-weight:600;font-size:.72rem;}
.atable tr:last-child td{border-bottom:none;}
.atable tr:hover td{background:var(--card2);}
.sum-row td{color:var(--amber);font-weight:700;border-top:1px solid var(--border);}

/* CARTEIRA */
.pkgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:11px;margin-bottom:18px;}
.provkpi{background:linear-gradient(135deg,rgba(123,92,240,.14),rgba(34,211,238,.06));border:1px solid rgba(123,92,240,.28);border-radius:12px;padding:15px;position:relative;overflow:hidden;}
.provkpi::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#7b5cf0,var(--cyan));}
.plabel{font-size:.56rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--cyan);margin-bottom:4px;}
.pval{font-family:'Playfair Display',serif;font-size:1.4rem;color:var(--cyan);}
.psub{font-size:.6rem;color:rgba(34,211,238,.5);margin-top:3px;}
.clayout{display:grid;grid-template-columns:1fr 280px;gap:13px;margin-bottom:18px;}
.cleft{display:flex;flex-direction:column;gap:13px;}
.agrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.acard{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:13px;position:relative;overflow:hidden;transition:transform .2s,border-color .2s;}
.acard:hover{transform:translateY(-2px);border-color:var(--muted2);}
.acard::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--ac,var(--blue));opacity:.5;}
.ahead{display:flex;align-items:center;gap:8px;margin-bottom:9px;}
.aicon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.aticker{font-family:'Playfair Display',serif;font-size:.9rem;font-weight:700;}
.aclasse{font-size:.57rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;}
.apreco{font-family:'Playfair Display',serif;font-size:1.2rem;margin-bottom:3px;}
.alinha{display:flex;justify-content:space-between;align-items:center;}
.aqtd{font-size:.65rem;color:var(--muted);}
.atotal{font-size:.72rem;font-weight:700;}
.apm{font-size:.62rem;color:var(--muted);margin-top:2px;}
.apl{font-size:.68rem;font-weight:700;margin-top:2px;}
.avar{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;border-radius:4px;font-size:.66rem;font-weight:700;margin-top:5px;}
.vup{background:rgba(39,201,124,.12);color:var(--green);}
.vdown{background:rgba(232,69,90,.12);color:var(--red);}
.aacts{position:absolute;top:7px;right:7px;display:flex;gap:3px;opacity:0;transition:opacity .15s;}
.acard:hover .aacts{opacity:1;}
.aabtn{background:var(--card2);border:none;color:var(--muted);cursor:pointer;font-size:.68rem;padding:3px 5px;border-radius:3px;transition:all .15s;}
.aabtn:hover{color:var(--text);}
.ppanel{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;}
.plist{display:flex;flex-direction:column;gap:6px;margin-top:9px;}
.prow{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:var(--bg);border:1px solid var(--border);border-radius:7px;flex-wrap:wrap;gap:8px;}
.pticker{font-weight:700;font-size:.76rem;}
.pdata{font-size:.62rem;color:var(--muted);}
.pval-c{font-family:'Playfair Display',serif;font-size:.88rem;color:var(--cyan);}
.ptotal{font-size:.62rem;color:rgba(34,211,238,.5);}
.dpanel{display:flex;flex-direction:column;}
.dwrap{height:200px;position:relative;margin-bottom:12px;width:100%;}
.dleg{display:flex;flex-direction:column;gap:6px;}
.drow{display:flex;justify-content:space-between;align-items:center;font-size:.72rem;}
.ddot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.dname{display:flex;align-items:center;gap:7px;color:var(--muted);}
.aprow{display:flex;justify-content:space-between;align-items:center;padding:7px 10px;background:var(--bg);border:1px solid var(--border);border-radius:7px;margin-bottom:5px;font-size:.75rem;flex-wrap:wrap;gap:6px;}
.apval{font-family:'Playfair Display',serif;color:var(--green);}

/* METAS DE VIDA */
.mcgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px;}
.mccard{background:var(--card);border:1px solid var(--border);border-radius:13px;padding:18px;position:relative;overflow:hidden;transition:transform .2s;}
.mccard:hover{transform:translateY(-2px);}
.mccard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--mc,var(--blue));}
.mcname{font-family:'Playfair Display',serif;font-size:1.05rem;margin-bottom:3px;}
.mcdeadline{font-size:.63rem;color:var(--muted);margin-bottom:12px;}
.mcvalues{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:7px;flex-wrap:wrap;gap:4px;}
.mccurrent{font-family:'Playfair Display',serif;font-size:1.3rem;}
.mctarget{font-size:.72rem;color:var(--muted);}
.mcsugg{font-size:.66rem;margin-top:7px;padding:6px 9px;border-radius:6px;background:rgba(75,142,240,.08);color:var(--blue);border:1px solid rgba(75,142,240,.14);}
.mcacts{position:absolute;top:9px;right:9px;display:flex;gap:3px;opacity:0;transition:opacity .15s;}
.mccard:hover .mcacts{opacity:1;}
.mcbtn{background:var(--card2);border:none;color:var(--muted);cursor:pointer;font-size:.68rem;padding:3px 6px;border-radius:4px;font-family:'Syne',sans-serif;transition:all .15s;}
.mcbtn:hover{color:var(--text);}
.mcbtn.del:hover{color:var(--red);}
.mcpct{font-family:'Playfair Display',serif;font-size:1.8rem;position:absolute;bottom:12px;right:14px;opacity:.09;}

/* CONFIGURAÇÕES */
.cfg-section{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px;margin-bottom:14px;}
.cfg-title{font-size:.6rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:14px;}
.cfg-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border);gap:12px;flex-wrap:wrap;}
.cfg-row:last-child{border-bottom:none;padding-bottom:0;}
.cfg-label{font-size:.8rem;font-weight:600;}
.cfg-desc{font-size:.65rem;color:var(--muted);margin-top:2px;}
.cfg-input{background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:7px 10px;color:var(--text);font-family:'Syne',sans-serif;font-size:.8rem;width:200px;transition:border-color .15s;}
.cfg-input:focus{outline:none;border-color:var(--brand);}
.cfg-color-row{display:flex;align-items:center;gap:8px;}
.cfg-save-btn{margin-top:16px;padding:10px 24px;border-radius:8px;border:none;background:var(--brand);color:#fff;font-family:'Syne',sans-serif;font-size:.82rem;font-weight:700;cursor:pointer;transition:all .2s;}
.cfg-save-btn:hover{filter:brightness(1.1);}
.cfg-logo-preview{width:48px;height:48px;border-radius:10px;object-fit:cover;border:1px solid var(--border);}

/* PLANO PRO */
.pro-wall{background:linear-gradient(135deg,rgba(240,168,50,.08),rgba(232,69,90,.06));border:1px solid rgba(240,168,50,.25);border-radius:12px;padding:32px;text-align:center;margin-bottom:18px;}
.pro-wall-icon{font-size:2.5rem;margin-bottom:12px;}
.pro-wall h3{font-family:'Playfair Display',serif;font-size:1.4rem;margin-bottom:8px;}
.pro-wall p{color:var(--muted);font-size:.83rem;max-width:340px;margin:0 auto 18px;line-height:1.6;}
.pro-wall-btn{padding:11px 28px;border-radius:9px;border:none;background:linear-gradient(135deg,var(--brand),var(--amber));color:#fff;font-family:'Syne',sans-serif;font-size:.88rem;font-weight:700;cursor:pointer;}

/* MODAL */
.moverlay{position:fixed;inset:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:100;opacity:0;pointer-events:none;transition:opacity .2s;padding:16px;}
.moverlay.open{opacity:1;pointer-events:all;}
.modal{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px;width:380px;max-width:100%;transform:translateY(16px);transition:transform .2s;}
.moverlay.open .modal{transform:translateY(0);}
.modal h2{font-family:'Playfair Display',serif;font-size:1.35rem;margin-bottom:4px;}
.modal p{color:var(--muted);font-size:.77rem;margin-bottom:14px;line-height:1.6;}
.modal .fg{margin-bottom:11px;}
.mbtns{display:flex;gap:8px;justify-content:flex-end;margin-top:14px;}

/* TOAST */
#toast{position:fixed;bottom:18px;right:18px;background:var(--card);border:1px solid var(--green);color:var(--green);padding:10px 16px;border-radius:10px;font-size:.76rem;font-weight:700;transform:translateY(60px);opacity:0;transition:all .25s;z-index:300;max-width:280px;}
#toast.show{transform:translateY(0);opacity:1;}
#toast.err{border-color:var(--red);color:var(--red);}

.spinner{width:26px;height:26px;border:3px solid var(--border);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite;}
.welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;height:55vh;gap:12px;text-align:center;}
.welcome h2{font-family:'Playfair Display',serif;font-size:1.8rem;}
.welcome p{color:var(--muted);max-width:300px;line-height:1.7;font-size:.83rem;}

/* ═══ RESPONSIVIDADE MOBILE ═══ */
@media(max-width:768px){
  aside{position:fixed;left:0;top:0;bottom:0;transform:translateX(-100%);transition:transform .3s;z-index:40;width:260px;}
  .mob-header{display:flex;}
  main{padding-top:0;}
  .content{padding:12px 14px;}
  .topbar{padding:10px 14px;}
  .kgrid{grid-template-columns:1fr 1fr;gap:9px;}
  .crow,.crow3{grid-template-columns:1fr;gap:11px;}
  .crow .cc,.crow3 .cc{width:100%;}
  .cwrap{height:180px;}
  .pkgrid{grid-template-columns:1fr 1fr;}
  .clayout{grid-template-columns:1fr;}
  .agrid{grid-template-columns:1fr 1fr;}
  .mcgrid{grid-template-columns:1fr;}
  .mcp-grid{grid-template-columns:1fr 1fr;}
  .form-grid{flex-direction:column;}
  .fg{min-width:100%;}
  .ttable{font-size:.72rem;}
  .ttable th,.ttable td{padding:7px 8px;}
  .cfg-input{width:100%;}
  .cfg-row{flex-direction:column;align-items:flex-start;}
  .add-meta-form{flex-direction:column;}
  /* ═══ FIX NOTIFICAÇÕES MOBILE ═══ */
  .notif-wrap{position:static;}
  .tb-right{position:relative;}
  .notif-dropdown{width:calc(100vw - 32px) !important;right:0 !important;left:auto !important;max-width:340px;}
  /* ═══ FIX TABELAS SCROLL LATERAL ═══ */
  .atable{min-width:500px;}
  .admin-table{min-width:600px;}
  .admin-table-wrap{overflow-x:auto;}
}
@media(max-width:480px){
  .kgrid{grid-template-columns:1fr 1fr;}
  .pkgrid{grid-template-columns:1fr;}
  .agrid{grid-template-columns:1fr;}
  .mcp-grid{grid-template-columns:1fr;}
  .auth-box{padding:28px 20px;}
  .kval{font-size:1.1rem;}
}
@media(min-width:1400px){
  .agrid{grid-template-columns:repeat(4,1fr);}
  .kval{font-size:1.5rem;}
}
.add-meta-form{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px;display:flex;gap:9px;align-items:flex-end;margin-bottom:18px;flex-wrap:wrap;}
.ap-meta-form{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px;display:flex;gap:9px;align-items:flex-end;margin-bottom:13px;flex-wrap:wrap;}

/* ═══ FASE 3: CHECKOUT / PLANOS ═══ */
.plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;}
.plan-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:24px;position:relative;transition:transform .2s,border-color .2s;}
.plan-card:hover{transform:translateY(-2px);}
.plan-card.popular{border-color:var(--brand);box-shadow:0 0 0 1px var(--brand);}
.plan-popular-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--brand);color:#fff;font-size:.65rem;font-weight:700;padding:3px 12px;border-radius:999px;letter-spacing:1px;text-transform:uppercase;white-space:nowrap;}
.plan-name{font-family:'Playfair Display',serif;font-size:1.3rem;margin-bottom:4px;}
.plan-price{font-family:'Playfair Display',serif;font-size:2.2rem;color:var(--brand);line-height:1;margin-bottom:4px;}
.plan-price span{font-size:.8rem;color:var(--muted);font-family:'Syne',sans-serif;}
.plan-desc{font-size:.75rem;color:var(--muted);margin-bottom:16px;line-height:1.5;}
.plan-features{list-style:none;margin-bottom:20px;}
.plan-features li{font-size:.78rem;padding:5px 0;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;}
.plan-features li:last-child{border-bottom:none;}
.plan-features .feat-ok{color:var(--green);}
.plan-features .feat-no{color:var(--muted2);}
.plan-btn{width:100%;padding:11px;border-radius:9px;border:none;font-family:'Syne',sans-serif;font-size:.82rem;font-weight:700;cursor:pointer;transition:all .2s;}
.plan-btn-primary{background:var(--brand);color:#fff;}
.plan-btn-primary:hover{filter:brightness(1.1);}
.plan-btn-secondary{background:var(--card2);color:var(--muted);border:1px solid var(--border);}
.plan-btn-secondary:hover{color:var(--text);}
.plan-btn-current{background:var(--card2);color:var(--green);border:1px solid rgba(39,201,124,.3);cursor:default;}

/* PIX modal */
.pix-box{text-align:center;padding:8px 0;}
.pix-qr{width:180px;height:180px;background:var(--bg);border:1px solid var(--border);border-radius:10px;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;font-size:.72rem;color:var(--muted);}
.pix-code{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:.7rem;word-break:break-all;color:var(--cyan);margin-bottom:12px;cursor:pointer;transition:opacity .2s;}
.pix-code:hover{opacity:.8;}
.pix-status{font-size:.75rem;color:var(--muted);display:flex;align-items:center;gap:6px;justify-content:center;}
.pix-spin{width:10px;height:10px;border:2px solid var(--border);border-top-color:var(--green);border-radius:50%;animation:spin .7s linear infinite;}

/* ═══ FASE 4: ADMIN ═══ */
.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;}
.admin-table-wrap{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:18px;}
.admin-table{width:100%;border-collapse:collapse;}
.admin-table th{text-align:left;font-size:.56rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;padding:10px 13px;border-bottom:1px solid var(--border);}
.admin-table td{padding:10px 13px;font-size:.78rem;border-bottom:1px solid var(--bg2);vertical-align:middle;}
.admin-table tr:last-child td{border-bottom:none;}
.admin-table tr:hover td{background:var(--card2);}
.plan-tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.62rem;font-weight:700;text-transform:uppercase;}
.tag-free{background:var(--muted2);color:var(--muted);}
.tag-pro{background:linear-gradient(135deg,rgba(240,168,50,.2),rgba(232,69,90,.2));color:var(--amber);border:1px solid rgba(240,168,50,.3);}
.tag-ent{background:linear-gradient(135deg,rgba(123,92,240,.2),rgba(34,211,238,.15));color:#22d3ee;border:1px solid rgba(123,92,240,.3);}
.tag-admin{background:rgba(75,142,240,.15);color:var(--blue);}
.admin-action-btn{padding:4px 10px;border-radius:5px;border:none;font-family:'Syne',sans-serif;font-size:.68rem;font-weight:700;cursor:pointer;transition:all .15s;}
.btn-activate{background:rgba(39,201,124,.12);color:var(--green);border:1px solid rgba(39,201,124,.25);}
.btn-activate:hover{background:rgba(39,201,124,.22);}
.btn-deactivate{background:rgba(232,69,90,.12);color:var(--red);border:1px solid rgba(232,69,90,.25);}
.btn-deactivate:hover{background:rgba(232,69,90,.22);}
.admin-search{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:9px 12px;color:var(--text);font-family:'Syne',sans-serif;font-size:.8rem;width:280px;margin-bottom:14px;}
.admin-search:focus{outline:none;border-color:var(--brand);}

/* ═══ BUG FIX 800px — gráficos nunca somem ═══ */
@media(max-width:900px){
  .plans-grid{grid-template-columns:1fr;}
  .admin-stats{grid-template-columns:1fr 1fr;}
}
@media(max-width:768px){
  .crow,.crow3{display:flex;flex-direction:column;gap:11px;}
  .crow .cc,.crow3 .cc{width:100%;min-width:0;}
  .cwrap{height:200px !important;width:100% !important;}
  .kgrid{grid-template-columns:1fr 1fr;}
  .clayout{display:flex;flex-direction:column;}
  .agrid{grid-template-columns:1fr 1fr;}
  .mcgrid{grid-template-columns:1fr;}
  .pkgrid{grid-template-columns:1fr 1fr;}
  .mcp-grid{grid-template-columns:1fr 1fr;}
  .form-grid{flex-direction:column;}
  .fg{min-width:100% !important;max-width:100% !important;}
  .plans-grid{grid-template-columns:1fr;}
  .admin-stats{grid-template-columns:1fr 1fr;}
  .admin-search{width:100%;}
  .add-meta-form,.ap-meta-form{flex-direction:column;}
  .ttable th:nth-child(3),.ttable td:nth-child(3){display:none;}
  .twrap{overflow-x:auto;}
}
@media(max-width:480px){
  .kgrid{grid-template-columns:1fr 1fr;}
  .pkgrid{grid-template-columns:1fr;}
  .agrid{grid-template-columns:1fr;}
  .mcp-grid{grid-template-columns:1fr;}
  .admin-stats{grid-template-columns:1fr 1fr;}
  .kval{font-size:1.05rem;}
  .cwrap{height:170px !important;}
}

/* ═══ FIX CENTRALIZAÇÃO MOBILE ═══ */
#mod-antifraude .btn,
#mod-instabilidade .btn,
#mod-pdv-checkout .btn,
#pdv-metodo-btns .btn{
  text-align:center;
  display:flex;
  align-items:center;
  justify-content:center;
}
/* ═══ NOTIFICAÇÕES ═══ */
.notif-wrap{position:relative;}
.notif-bell{background:none;border:1px solid var(--border);border-radius:8px;padding:5px 9px;font-size:1rem;cursor:pointer;position:relative;transition:all .2s;line-height:1;}
.notif-bell:hover{border-color:var(--brand);}
.notif-badge{position:absolute;top:-5px;right:-5px;background:var(--brand);color:#fff;font-size:.55rem;font-weight:700;min-width:16px;height:16px;border-radius:99px;display:flex;align-items:center;justify-content:center;padding:0 4px;font-family:'Syne',sans-serif;}
.notif-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:320px;max-height:400px;background:var(--card);border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 40px rgba(0,0,0,.5);display:none;z-index:200;overflow:hidden;}
.notif-dropdown.open{display:block;animation:fadeUp .15s ease;}
.notif-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted);}
.notif-clear{color:var(--brand);cursor:pointer;font-size:.65rem;text-transform:none;letter-spacing:0;font-weight:600;}
.notif-clear:hover{text-decoration:underline;}
.notif-list{overflow-y:auto;max-height:340px;padding:6px 0;}
.notif-item{display:flex;gap:10px;padding:10px 16px;border-bottom:1px solid var(--border);transition:background .15s;cursor:default;}
.notif-item:last-child{border-bottom:none;}
.notif-item:hover{background:var(--card2);}
.notif-item.unread{background:rgba(var(--brand-rgb),.04);}
.notif-icon{font-size:1.1rem;flex-shrink:0;margin-top:2px;}
.notif-body{flex:1;min-width:0;}
.notif-text{font-size:.76rem;line-height:1.5;color:var(--text);}
.notif-time{font-size:.6rem;color:var(--muted);margin-top:3px;}
.notif-empty{padding:32px 16px;text-align:center;font-size:.78rem;color:var(--muted);}
[data-theme="light"] .notif-dropdown{background:#fff;border-color:#e0e0e0;box-shadow:0 8px 24px rgba(0,0,0,.1);}
@media(max-width:768px){.notif-dropdown{width:280px;right:-40px;}}
/* ═══ AUTH SPLIT DESKTOP ═══ */
#auth-screen { display: none; min-height: 100vh; }
#auth-screen.show { display: flex; flex-direction: row; min-height: 100vh; background: #09060f; }

/* ── PAINEL ESQUERDO ── */
.auth-left {
  flex: 1; background: #0f0a1e;
  border-right: 1px solid #1e1542;
  display: flex; align-items: center; justify-content: center;
  padding: 40px 36px; position: relative; overflow: hidden;
}
.auth-left::before {
  content:''; position:absolute; top:-120px; left:-80px;
  width:500px; height:500px;
  background:radial-gradient(circle,rgba(124,58,237,.12) 0%,transparent 60%);
  pointer-events:none;
}
.auth-left::after {
  content:''; position:absolute; bottom:-100px; right:-60px;
  width:380px; height:380px;
  background:radial-gradient(circle,rgba(99,45,190,.08) 0%,transparent 60%);
  pointer-events:none;
}
.auth-left-inner {
  position:relative; z-index:2;
  width:100%; max-width:580px;
  display:flex; flex-direction:column; gap:28px;
}
.al-brand { display:flex; align-items:center; gap:14px; }
.al-logo-icon {
  width:42px; height:42px; border-radius:12px;
  background:linear-gradient(135deg,#7c3aed,#5b21b6);
  display:flex; align-items:center; justify-content:center;
  font-family:'Playfair Display',serif; font-size:1.2rem; color:#fff; font-weight:700;
}
.al-logo-name {
  font-family:'Playfair Display',serif; font-size:1.4rem;
  background:linear-gradient(135deg,#c4b5fd,#a78bfa);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; line-height:1;
}
.al-logo-sub { font-size:.52rem; color:#7c6fa0; letter-spacing:2px; text-transform:uppercase; margin-top:3px; }

/* Mockup Window */
.al-window {
  background:#130d28; border-radius:10px;
  border:1px solid #2e1f54; overflow:hidden;
  box-shadow:0 24px 64px rgba(0,0,0,.6);
}
.al-topbar {
  background:#1a1035; height:30px;
  display:flex; align-items:center; gap:6px;
  padding:0 12px; border-bottom:1px solid #2a1d48;
}
.al-dot { width:8px; height:8px; border-radius:50%; }
.al-dot.red { background:#ff5f57; }
.al-dot.yellow { background:#febc2e; }
.al-dot.green { background:#28c840; }
.al-topbar-title {
  font-size:.58rem; color:#6b5d8a; margin-left:6px;
  font-family:'Syne',sans-serif; letter-spacing:.04em;
}
.al-body { display:flex; min-height:210px; }
.al-sidebar-mock {
  width:40px; background:#110c24;
  border-right:1px solid #221740;
  display:flex; flex-direction:column; align-items:center;
  padding:10px 0; gap:7px;
}
.al-si { width:22px; height:22px; border-radius:6px; background:#1e1542; }
.al-si.act { background:#4c2d9e; }
.al-content-mock {
  flex:1; padding:10px; display:flex; flex-direction:column; gap:8px;
}

/* KPIs dentro do mockup */
.al-mock-kpis { display:flex; gap:6px; }
.al-mk {
  flex:1; background:#1a1035; border-radius:6px;
  padding:8px 10px; border:1px solid #2a1d48;
}
.al-mk-l { font-size:.5rem; color:#7c6fa0; margin-bottom:3px; }
.al-mk-v { font-size:.9rem; font-weight:700; color:#c4b5fd; font-family:'Playfair Display',serif; }
.al-mk-v.g { color:#6ee7b7; }
.al-mk-v.a { color:#fcd34d; }

/* Charts */
.al-mock-charts { display:flex; gap:6px; }
.al-chart-box {
  flex:1; background:#1a1035; border-radius:6px;
  padding:8px 10px; border:1px solid #2a1d48;
}
.al-chart-label { font-size:.48rem; color:#7c6fa0; margin-bottom:6px; }
.al-bars { display:flex; align-items:flex-end; gap:4px; height:52px; }
.al-bar {
  flex:1; border-radius:2px 2px 0 0; background:#2d1b5e;
  transition:height .6s ease;
}
.al-bar.hi { background:#7c3aed; }
.al-bar.ac { background:#a78bfa; }
.al-spark { width:100%; height:42px; }

/* Table */
.al-mock-table {
  background:#1a1035; border-radius:6px;
  border:1px solid #2a1d48; padding:6px 10px;
}
.al-tr {
  display:flex; justify-content:space-between;
  padding:4px 0; border-bottom:1px solid #1e1542;
}
.al-tr:last-child { border-bottom:none; }
.al-td { font-size:.58rem; color:#9d8fc0; }
.al-td.v { color:#c4b5fd; font-weight:600; }
.al-td.p { color:#6ee7b7; }
.al-td.pe { color:#fcd34d; }

/* Float badge */
.al-float-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:#1a1035; border:1px solid #2e1f54;
  border-radius:8px; padding:8px 14px;
  width:fit-content; align-self:center;
  animation:floatBadge 3s ease-in-out infinite;
  font-size:.65rem; color:#9d8fc0;
}
.al-float-badge b { color:#c4b5fd; }
@keyframes floatBadge { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-5px)} }
.al-badge-dot {
  width:6px; height:6px; border-radius:50%;
  background:#6ee7b7; box-shadow:0 0 6px #6ee7b7;
}

/* Tagline */
.al-tagline-title {
  font-family:'Playfair Display',serif;
  font-size:1.35rem; line-height:1.3; color:#e2d9f3;
}
.al-tagline-sub { font-size:.74rem; color:#7c6fa0; line-height:1.6; margin-top:6px; }

/* ── PAINEL DIREITO ── */
.auth-right {
  width:480px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  padding:48px 44px;
  background:#09060f; border-left:1px solid #1e1542;
}
.auth-right .auth-box {
  background:transparent; border:none; border-radius:0;
  padding:0; box-shadow:none; width:100%; max-width:320px;
}
.auth-form-header { margin-bottom:24px; }
.auth-form-title {
  font-family:'Playfair Display',serif;
  font-size:1.5rem; color:#e2d9f3; line-height:1.2;
}
.auth-form-desc { font-size:.75rem; color:#6b5d8a; margin-top:6px; }

/* Campos auth tema roxo */
.auth-right .auth-tabs { background:#100c20; border-radius:10px; padding:4px; }
.auth-right .auth-tab { color:#6b5d8a; }
.auth-right .auth-tab.act { background:#1a1035; color:#e2d9f3; box-shadow:0 1px 6px rgba(0,0,0,.4); }
.auth-right .auth-fg label { color:#9d8fc0; }
.auth-right .auth-fg input {
  background:#100c20; border:1px solid #2e1f54;
  color:#e2d9f3; border-radius:8px;
}
.auth-right .auth-fg input::placeholder { color:#3d3056; }
.auth-right .auth-fg input:focus { border-color:#7c3aed; }
.auth-right .auth-btn {
  background:#5b21b6; color:#e2d9f3;
  border-radius:9px; font-weight:700; letter-spacing:.03em;
}
.auth-right .auth-btn:hover { background:#6d28d9; filter:none; }
.auth-right .auth-link span { color:#6b5d8a; }
.auth-right .auth-link:hover span { color:#a78bfa; }
.auth-right .auth-msg.err { color:#f87171; }
.auth-right .auth-msg.ok  { color:#6ee7b7; }
.auth-right .auth-logo,
.auth-right .auth-sub { display:none !important; }
.auth-carousel {
  overflow:hidden;
  margin:0 -44px 20px;
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 15%,#000 85%,transparent 100%);
  mask-image:linear-gradient(90deg,transparent 0%,#000 15%,#000 85%,transparent 100%);
}
.auth-carousel-track {
  display:flex;
  gap:10px;
  width:max-content;
  animation:pillScroll 18s linear infinite;
}
@keyframes pillScroll {
  0%   { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}
.auth-pill {
  background:#1a1035;
  border:1px solid #2e1f54;
  border-radius:999px;
  padding:7px 16px;
  font-size:.7rem;
  font-weight:600;
  color:#9d8fc0;
  white-space:nowrap;
  flex-shrink:0;
}

/* ── MOBILE ── */
@media (max-width:768px) {
  #auth-screen.show {
    flex-direction:column; align-items:center;
    justify-content:center; padding:20px; background:var(--bg);
  }
  .auth-left { display:none; }
  .auth-right { width:100%; padding:0; background:transparent; border-left:none; }
  .auth-right .auth-box {
    background:var(--card); border:1px solid var(--border);
    border-radius:20px; padding:32px 24px; max-width:100%;
    box-shadow:0 8px 32px rgba(0,0,0,.3);
  }
  .auth-right .auth-logo {
    font-size:2rem !important;
    margin-bottom:2px !important;
  }
  .auth-right .auth-sub {
    margin-bottom:16px !important;
    font-size:.7rem !important;
  }
  .auth-right .auth-btn {
    padding:14px !important;
    font-size:.92rem !important;
    border-radius:12px !important;
  }
  .auth-right .auth-logo { display:block !important; }
  .auth-right .auth-sub  { display:block !important; }
  .auth-form-header { display:none; }
 .auth-carousel {
    margin:-10px -24px 18px;
  }
  .auth-pill {
    background:var(--card2);
    border:1px solid var(--border);
    color:var(--muted);
  }
  .auth-right .auth-tabs { background:var(--bg2); }
  .auth-right .auth-tab { color:var(--muted); }
  .auth-right .auth-tab.act { background:var(--card); color:var(--text); }
  .auth-right .auth-fg label { color:var(--muted); }
  .auth-right .auth-fg input { background:var(--bg); border-color:var(--border); color:var(--text); }
  .auth-right .auth-fg input:focus { border-color:var(--brand); }
  .auth-right .auth-btn { background:var(--brand); }
  .auth-right .auth-btn:hover { filter:brightness(1.1); }
  .auth-right .auth-link span { color:var(--muted); }
}
@media (max-width:900px) and (min-width:769px) {
  .auth-left-inner { max-width:360px; }
  .auth-right { width:360px; padding:36px 28px; }
  .al-mk-v { font-size:.78rem; }
  .al-tagline-title { font-size:1.15rem; }
}

/* ═══ FIX SCROLL ÚNICO ═══ */
#app.show {
  display: flex;
  height: 100vh;
  overflow: hidden;
}
main {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
  overflow-x: hidden;
  overflow-y: auto;
  height: 100vh;
}
