@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#f7f7f8;--card:#fff;--text:#0B0F19;--text-2:#1A1F2B;--muted:#6B7280;--border:#ECEEF1;
  --primary:#E8742B;--primary-2:#F2965A;--primary-soft:#FBF1E8;
  --dark:#0B0F19;--dark-2:#1A1F2B;
  --success:#10b981;--danger:#ef4444;--warn:#f59e0b;
  --shadow-sm:0 1px 2px rgba(11,15,25,.04);
  --shadow:0 2px 6px rgba(11,15,25,.04),0 1px 2px rgba(11,15,25,.05);
  --shadow-lg:0 12px 32px -8px rgba(11,15,25,.12),0 4px 12px -2px rgba(11,15,25,.06);
  --radius:16px;--radius-sm:10px;
}
html,body{background:var(--bg);color:var(--text);font-family:'Inter',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

.layout{display:grid;grid-template-columns:264px 1fr;min-height:100vh}
.sidebar{background:#fff;border-right:1px solid var(--border);padding:20px 14px;display:flex;flex-direction:column;gap:4px;position:sticky;top:0;height:100vh;overflow-y:auto}

/* Brand com logo SVG */
.brand{display:flex;align-items:center;gap:11px;padding:4px 8px 16px}
.brand-logo{width:38px;height:38px;border-radius:11px;background:#fff;border:1px solid var(--border);display:grid;place-items:center;flex-shrink:0;box-shadow:var(--shadow-sm)}
.brand-logo svg{width:24px;height:24px}
.brand b{font-size:17px;font-weight:700;letter-spacing:-.01em;color:var(--dark)}
.brand b .ai{color:var(--primary)}
.brand small{display:block;color:var(--muted);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;margin-top:2px}

.mode-pill{display:inline-flex;align-items:center;gap:6px;background:var(--primary-soft);color:var(--primary);font-weight:700;font-size:10.5px;padding:6px 11px;border-radius:999px;margin:0 8px 16px;width:fit-content;text-transform:uppercase;letter-spacing:.06em}

.search{margin:0 6px 18px;position:relative}
.search input{width:100%;background:#F3F4F6;border:1px solid transparent;border-radius:11px;padding:10px 14px 10px 36px;font-size:13px;outline:none;transition:.15s;font-family:inherit}
.search input:focus{background:#fff;border-color:var(--border);box-shadow:var(--shadow-sm)}
.search:before{content:"⌕";position:absolute;left:13px;top:9px;color:var(--muted);font-size:14px}
.search kbd{position:absolute;right:8px;top:8px;background:#fff;border:1px solid var(--border);border-radius:6px;font-size:10px;padding:2px 7px;color:var(--muted);font-family:inherit}

.nav-section{padding:12px 14px 6px;font-size:10px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;font-weight:700}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;color:#374151;font-weight:500;font-size:13.5px;transition:.12s}
.nav a:hover{background:#F5F6F8;color:var(--dark)}
.nav a.active{background:var(--primary-soft);color:var(--primary);font-weight:600}
.nav a .ico{width:18px;display:inline-block;text-align:center;font-size:14px;opacity:.85}
.nav a.active .ico{opacity:1}
.nav a .badge{margin-left:auto;background:var(--primary-soft);color:var(--primary);font-size:9.5px;padding:2px 8px;border-radius:999px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}

.sidebar-footer{margin-top:auto;border-top:1px solid var(--border);padding-top:10px}
.logout-link{color:#dc2626;padding:9px 12px;display:flex;gap:11px;font-weight:600;font-size:13px;border-radius:10px}
.logout-link:hover{background:#fef2f2}
.user-card{display:flex;align-items:center;gap:11px;padding:10px 8px;margin-top:4px}
.avatar{width:36px;height:36px;border-radius:11px;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px;box-shadow:0 4px 12px -4px rgba(232,116,43,.5)}
.user-card b{display:block;font-size:13px;color:var(--dark);font-weight:600}
.user-card small{color:var(--muted);font-size:11px}

.main{padding:32px 40px 60px;max-width:1320px;width:100%}
.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:26px;flex-wrap:wrap}
.greet small{color:var(--muted);text-transform:uppercase;font-size:11px;letter-spacing:.08em;font-weight:700}
.greet h1{font-size:32px;margin:6px 0 4px;font-weight:700;letter-spacing:-.025em;color:var(--dark)}
.greet h1 .name{color:var(--primary)}
.greet p{color:var(--muted);font-size:14.5px}
.actions{display:flex;gap:10px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border);background:#fff;color:var(--dark);padding:11px 18px;border-radius:12px;font-weight:600;cursor:pointer;font-size:13.5px;transition:.15s;font-family:inherit;text-decoration:none}
.btn:hover{background:#F5F6F8;transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-dark{background:var(--dark);color:#fff;border-color:var(--dark)}
.btn-dark:hover{background:var(--dark-2)}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;border:none;box-shadow:0 6px 16px -6px rgba(232,116,43,.5)}
.btn-primary:hover{filter:brightness(1.05);box-shadow:0 10px 24px -6px rgba(232,116,43,.55)}

.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm)}
.card h3{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-weight:700}
.card .value{font-size:24px;font-weight:700;letter-spacing:-.02em}
.grid{display:grid;gap:16px}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:2fr 1fr}
@media(max-width:1100px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:1fr}.grid-2{grid-template-columns:1fr}}

.checkin{background:linear-gradient(135deg,#FBF1E8,#FFE3D0);border:1px solid #FFD2B0;border-radius:var(--radius);padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:18px;flex-wrap:wrap}
.checkin .left{display:flex;align-items:flex-start;gap:14px}
.checkin .heart{font-size:24px}
.checkin h4{font-size:11px;color:var(--primary);text-transform:uppercase;letter-spacing:.08em;font-weight:700;margin-bottom:4px}
.checkin h2{font-size:19px;font-weight:700;margin-bottom:4px;color:var(--dark)}
.checkin p{color:#7A4A2B;font-size:13px}
.checkin .opts{display:flex;gap:8px;flex-wrap:wrap}
.opt{background:#fff;border:1px solid #FFD2B0;padding:10px 15px;border-radius:11px;font-weight:600;font-size:13px;display:inline-flex;align-items:center;gap:6px;cursor:pointer;font-family:inherit;transition:.15s}
.opt:hover{background:#FFF8F2;transform:translateY(-1px)}

.bills{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}
.bills .icon{width:46px;height:46px;border-radius:13px;background:var(--dark);color:#fff;display:grid;place-items:center;font-size:18px}
.bills .info b{display:block;font-size:14.5px;color:var(--dark);font-weight:600}
.bills .info small{color:var(--muted);font-size:12.5px}
.link{color:var(--primary);font-weight:600;font-size:13px}
.link:hover{text-decoration:underline}

.profit{background:linear-gradient(135deg,#fff,#FFF6EE);border:1px solid #FFD2B0;border-radius:var(--radius);padding:24px;display:grid;grid-template-columns:2fr 1fr;gap:22px;margin-bottom:18px;box-shadow:var(--shadow)}
@media(max-width:900px){.profit{grid-template-columns:1fr}}
.profit .tag{display:inline-flex;align-items:center;gap:7px;color:var(--primary);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}
.profit .tag .dot{width:8px;height:8px;background:var(--success);border-radius:50%;box-shadow:0 0 0 3px rgba(16,185,129,.2)}
.profit .big{font-size:50px;font-weight:800;color:var(--primary);line-height:1.05;margin-bottom:12px;letter-spacing:-.03em}
.profit .desc{color:var(--muted);max-width:480px;margin-bottom:16px;font-size:14px}
.health-tag{display:inline-flex;align-items:center;gap:8px;background:#ECFDF5;color:#047857;border:1px solid #A7F3D0;padding:9px 14px;border-radius:11px;font-size:12.5px;font-weight:600}
.meta{background:#fff;border:1px solid #FFD2B0;border-radius:13px;padding:18px}
.meta h3{margin-bottom:6px}
.meta .v{font-size:24px;font-weight:700;margin-bottom:12px;letter-spacing:-.02em}
.bar{height:8px;background:#FFEEDB;border-radius:999px;overflow:hidden;margin-bottom:8px}
.bar > i{display:block;height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-2));border-radius:999px;transition:width .6s}
.meta .row{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-top:4px}

.kpi{background:#fff;border:1px solid var(--border);border-radius:13px;padding:18px;transition:.15s}
.kpi:hover{box-shadow:var(--shadow);transform:translateY(-1px)}
.kpi .top{display:flex;align-items:center;justify-content:space-between;color:var(--muted);font-size:12.5px;margin-bottom:10px;font-weight:500}
.kpi .v{font-size:24px;font-weight:700;letter-spacing:-.02em}
.kpi .v.pos{color:var(--success)}.kpi .v.neg{color:var(--danger)}.kpi .v.pri{color:var(--primary)}

.tri{display:grid;grid-template-columns:1fr 1.1fr 1fr;gap:16px}
@media(max-width:1100px){.tri{grid-template-columns:1fr}}
.health .score{font-size:52px;color:var(--primary);font-weight:800;line-height:1;letter-spacing:-.03em}
.health .score small{font-size:14px;color:var(--muted);font-weight:500}
.health .label{font-weight:700;margin:6px 0 12px;color:var(--dark)}
.health ul{list-style:none;font-size:12.5px;margin-top:12px}
.health ul li{display:flex;justify-content:space-between;padding:6px 0;color:var(--muted);border-top:1px dashed var(--border)}
.health ul li b{color:var(--success);font-weight:700}
.forecast{background:linear-gradient(135deg,#0B0F19,#1A1F2B);color:#fff;border:none;position:relative;overflow:hidden}
.forecast:before{content:"";position:absolute;top:-30%;right:-20%;width:200px;height:200px;background:radial-gradient(circle,rgba(232,116,43,.25),transparent 70%)}
.forecast h3{color:#F2965A;position:relative}
.forecast .v{font-size:32px;color:var(--primary);font-weight:800;margin:10px 0;letter-spacing:-.02em;position:relative}
.forecast > *{position:relative}
.forecast .info{background:rgba(232,116,43,.13);border:1px solid rgba(232,116,43,.28);border-radius:11px;padding:11px;font-size:12px;margin-top:12px}
.tax .v{color:var(--dark)}
.tax .due{display:flex;justify-content:space-between;background:#FFFAF5;border:1px solid #FFE1CC;border-radius:11px;padding:11px;font-size:13px;margin-top:14px;align-items:center}

table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:13px 16px;border-bottom:1px solid var(--border);font-size:13.5px}
th{background:#FAFAFB;color:var(--muted);font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;font-weight:700}
tr:last-child td{border-bottom:none}
tbody tr:hover{background:#FAFAFB}
.badge-status{padding:4px 11px;border-radius:999px;font-size:11px;font-weight:600;text-transform:capitalize}
.b-new{background:#DBEAFE;color:#1E40AF}
.b-ok{background:#D1FAE5;color:#065F46}
.b-pend{background:#FEF3C7;color:#92400E}

.login-bg{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#FBF1E8 0%,#FFE3D0 100%);padding:24px;position:relative;overflow:hidden}
.login-bg:before{content:"";position:absolute;top:-200px;right:-200px;width:500px;height:500px;background:radial-gradient(circle,rgba(232,116,43,.15),transparent 70%)}
.login-bg:after{content:"";position:absolute;bottom:-200px;left:-200px;width:500px;height:500px;background:radial-gradient(circle,rgba(11,15,25,.08),transparent 70%)}
.login-card{background:#fff;border-radius:20px;padding:40px;width:100%;max-width:430px;box-shadow:0 24px 60px rgba(0,0,0,.08);position:relative;z-index:1}
.login-card .brand{justify-content:center;margin-bottom:20px;padding:0}
.login-card h2{text-align:center;font-size:24px;margin-bottom:6px;font-weight:700;letter-spacing:-.02em}
.login-card p.sub{text-align:center;color:var(--muted);margin-bottom:24px}
.field{margin-bottom:14px}
.field label{display:block;font-size:11px;color:var(--muted);font-weight:700;margin-bottom:7px;text-transform:uppercase;letter-spacing:.06em}
.field input,.field select{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:11px;font-size:14px;outline:none;font-family:inherit;background:#fff;transition:.15s}
.field input:focus,.field select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(232,116,43,.12)}
.alert{background:#FEE2E2;color:#991B1B;border:1px solid #FECACA;padding:11px 14px;border-radius:11px;font-size:13px;margin-bottom:14px}
.btn-block{width:100%;justify-content:center;padding:13px}

.section-title{font-size:19px;font-weight:700;margin:24px 0 14px;letter-spacing:-.01em}
.empty{text-align:center;color:var(--muted);padding:36px}

/* ============ DARK MODE ============ */
html[data-theme="dark"]{
  --bg:#0B0F19;--card:#141925;--text:#E5E7EB;--text-2:#F3F4F6;--muted:#9CA3AF;--border:#1F2633;
  --primary-soft:#2A1408;--dark:#F3F4F6;--dark-2:#E5E7EB;
}
html[data-theme="dark"] body{background:var(--bg);color:var(--text)}
html[data-theme="dark"] .sidebar{background:#0F1420;border-right-color:var(--border)}
html[data-theme="dark"] .brand b{color:#fff}
html[data-theme="dark"] .brand-logo{background:#1A1F2B;border-color:var(--border)}
html[data-theme="dark"] .search input{background:#1A1F2B;color:var(--text)}
html[data-theme="dark"] .search input:focus{background:#222838;border-color:var(--border)}
html[data-theme="dark"] .nav a{color:#CBD5E1}
html[data-theme="dark"] .nav a:hover{background:#1A1F2B;color:#fff}
html[data-theme="dark"] .nav a.active{background:rgba(232,116,43,.12);color:var(--primary)}
html[data-theme="dark"] .card{background:var(--card);border-color:var(--border);color:var(--text)}
html[data-theme="dark"] .card .value,html[data-theme="dark"] .greet h1,html[data-theme="dark"] .bills .info b,html[data-theme="dark"] .user-card b{color:#fff}
html[data-theme="dark"] .btn{background:#1A1F2B;color:var(--text);border-color:var(--border)}
html[data-theme="dark"] .btn:hover{background:#222838}
html[data-theme="dark"] .btn-dark{background:#fff;color:#0B0F19;border-color:#fff}
html[data-theme="dark"] .checkin{background:linear-gradient(135deg,#2A1408,#3D1810);border-color:#5a2510}
html[data-theme="dark"] .checkin h2{color:#fff}
html[data-theme="dark"] .checkin p{color:#FFD2B0}
html[data-theme="dark"] .opt{background:#1A1F2B;color:#fff;border-color:#5a2510}
html[data-theme="dark"] .profit{background:linear-gradient(135deg,#141925,#2A1408);border-color:#5a2510}
html[data-theme="dark"] .meta{background:#1A1F2B;border-color:#5a2510;color:var(--text)}
html[data-theme="dark"] .health-tag{background:rgba(16,185,129,.12);color:#6ee7b7;border-color:rgba(16,185,129,.3)}
html[data-theme="dark"] table{color:var(--text)}
html[data-theme="dark"] th,html[data-theme="dark"] td{border-color:var(--border)!important}
html[data-theme="dark"] thead{background:#1A1F2B!important}
html[data-theme="dark"] input,html[data-theme="dark"] select,html[data-theme="dark"] textarea{background:#1A1F2B!important;color:var(--text)!important;border-color:var(--border)!important}

/* Theme toggle button */
.theme-toggle{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;background:transparent;border:1px solid var(--border);border-radius:10px;color:var(--text);font-weight:600;font-size:13px;cursor:pointer;font-family:inherit;margin-bottom:6px;transition:.15s}
.theme-toggle:hover{background:#F5F6F8}
html[data-theme="dark"] .theme-toggle:hover{background:#1A1F2B}
.theme-toggle .ico-moon{display:none}
html[data-theme="dark"] .theme-toggle .ico-sun{display:none}
html[data-theme="dark"] .theme-toggle .ico-moon{display:inline}

/* ============== v5: Perfil, Configurações, Plano ============== */
.alert-success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0;padding:12px 16px;border-radius:10px;margin-bottom:14px;font-weight:600}
.alert{background:#fef2f2;color:#991b1b;border:1px solid #fecaca;padding:12px 16px;border-radius:10px;margin-bottom:14px}
.card-title{font-size:18px;font-weight:700;margin-bottom:4px;color:var(--dark);text-transform:none;letter-spacing:0}
.card-sub{color:var(--muted);font-size:13.5px;margin-bottom:0}
.field label{display:block;font-size:12px;font-weight:600;color:var(--text);margin-bottom:6px;text-transform:none;letter-spacing:0}
.field input,.field select,.field textarea{width:100%;padding:11px 14px;border:1px solid var(--border);border-radius:10px;font-size:14px;background:var(--card);color:var(--text);font-family:inherit;outline:none;transition:.15s}
.field input:focus,.field select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(232,116,43,.12)}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:700px){.row-2,.row-3{grid-template-columns:1fr}}

.grid-2-perfil{grid-template-columns:2fr 1fr;gap:18px}
@media(max-width:1100px){.grid-2-perfil{grid-template-columns:1fr}}

.avatar-row{display:flex;gap:14px;align-items:center;padding:14px;background:var(--bg);border-radius:12px}
.avatar-big{width:60px;height:60px;border-radius:14px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;display:grid;place-items:center;font-weight:700;font-size:18px;overflow:hidden;flex-shrink:0}
.avatar-big img{width:100%;height:100%;object-fit:cover}
.user-card .avatar img{width:100%;height:100%;object-fit:cover;border-radius:11px}

.sec-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--border)}
.sec-row:last-of-type{border-bottom:none}
.sec-row b{display:block;font-size:14px;color:var(--text)}
.sec-row small{display:block;color:var(--muted);font-size:12.5px;margin-top:2px}

/* Tabs */
.cfg-tabs{display:flex;gap:6px;margin-bottom:18px;flex-wrap:wrap;background:var(--card);padding:6px;border-radius:14px;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.cfg-tabs a{padding:10px 16px;border-radius:10px;color:var(--muted);font-weight:600;font-size:13.5px;transition:.15s}
.cfg-tabs a:hover{background:var(--bg);color:var(--text)}
.cfg-tabs a.active{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;box-shadow:0 6px 14px -6px rgba(232,116,43,.5)}

/* Tabela */
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;padding:10px 14px;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:700;border-bottom:1px solid var(--border)}
.tbl td{padding:14px;border-bottom:1px solid var(--border);font-size:14px}
.tbl tr.grp td{background:var(--bg);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding:8px 14px}
.chip{display:inline-block;background:var(--primary-soft);color:var(--primary);padding:4px 10px;border-radius:999px;font-size:11.5px;font-weight:600}
.ico-btn{background:transparent;border:none;color:var(--danger);font-size:18px;cursor:pointer;width:30px;height:30px;border-radius:8px;transition:.15s}
.ico-btn:hover{background:#fef2f2}

/* Toggle switch */
.toggle-row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid var(--border)}
.toggle-row:last-child{border-bottom:none}
.toggle-row b{font-size:14px;color:var(--text)}
.toggle-row small{display:block;color:var(--muted);font-size:12.5px;margin-top:2px}
.switch{appearance:none;width:44px;height:24px;background:#cbd5e1;border-radius:999px;position:relative;cursor:pointer;transition:.2s;flex-shrink:0}
.switch:checked{background:var(--primary)}
.switch:before{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 2px 4px rgba(0,0,0,.2)}
.switch:checked:before{left:22px}

/* Theme/moeda picker cards */
.theme-card{display:block;padding:16px;border:2px solid var(--border);border-radius:12px;cursor:pointer;transition:.15s;background:var(--card)}
.theme-card:hover{border-color:var(--primary-2)}
.theme-card.sel{border-color:var(--primary);background:var(--primary-soft)}
.theme-card b{display:block;font-size:14px;color:var(--text);margin-bottom:4px}
.theme-card small{color:var(--muted);font-size:12px}

.danger-row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:16px;border:1px solid #fecaca;background:#fef2f2;border-radius:12px;margin-top:14px;flex-wrap:wrap}
html[data-theme="dark"] .danger-row{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.3)}

/* Trial banner */
.trial-banner{background:linear-gradient(135deg,#FBF1E8,#FFE3D0);border:1px solid #FFD2B0;border-radius:12px;padding:12px 18px;display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px;font-size:13.5px;color:#7A4A2B;flex-wrap:wrap}
html[data-theme="dark"] .trial-banner{background:linear-gradient(135deg,#2A1408,#3D1810);color:#FFD2B0;border-color:#5a2510}

/* Plano */
.trial-card h2{font-size:22px;margin:6px 0 4px;color:var(--text)}
.pill-trial{display:inline-flex;align-items:center;gap:6px;background:#dbeafe;color:#1e40af;padding:6px 14px;border-radius:999px;font-weight:700;font-size:12px}
.pill-active{display:inline-flex;align-items:center;gap:6px;background:#d1fae5;color:#065f46;padding:6px 14px;border-radius:999px;font-weight:700;font-size:12px}
.ciclo-toggle{display:flex;justify-content:center;gap:6px;background:var(--card);padding:5px;border-radius:999px;border:1px solid var(--border);width:fit-content;margin:14px auto}
.ciclo-toggle button{background:transparent;border:none;padding:8px 22px;border-radius:999px;font-weight:600;cursor:pointer;color:var(--muted);font-family:inherit;font-size:13px}
.ciclo-toggle button.on{background:var(--dark);color:#fff}
html[data-theme="dark"] .ciclo-toggle button.on{background:var(--primary);color:#fff}
.save{background:#10b981;color:#fff;font-size:10px;padding:2px 6px;border-radius:6px;margin-left:4px}
.pcard{position:relative;display:flex;flex-direction:column}
.pcard.pop{border-color:var(--primary);box-shadow:0 12px 32px -8px rgba(232,116,43,.25)}
.badge-pop{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;padding:5px 14px;border-radius:999px;font-size:11px;font-weight:700}
.price-block{padding:18px 0;border-bottom:1px solid var(--border);margin:14px 0}
.price-block b{font-size:38px;font-weight:800;letter-spacing:-.02em;color:var(--text)}
.price-block small{color:var(--muted);font-size:14px;margin-left:4px}
.price-sub{color:var(--muted);font-size:12.5px;margin-top:6px}
.price-a,.pcard:not(.anual) .price-a{display:none}
.pcard.anual .price-a{display:block}
.pcard.anual .price-m{display:none}
.feat{list-style:none;display:grid;gap:8px;font-size:13.5px;color:var(--text);margin:8px 0}
.feat li{color:var(--text)}
.prov-sel{padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--card);color:var(--text);font-family:inherit;font-size:13px}
.btn-block{width:100%;justify-content:center}

/* Add-form styled */
.add-form{background:linear-gradient(135deg,var(--primary-soft),var(--card));border:1px solid var(--border);border-radius:14px;padding:20px 22px;margin-bottom:20px;box-shadow:0 4px 14px -8px rgba(0,0,0,.08)}
.add-form h4{margin:0 0 14px;font-size:15px;color:var(--text);font-weight:700;display:flex;align-items:center;gap:8px}
.add-form h4::before{content:"+";display:inline-grid;place-items:center;width:24px;height:24px;border-radius:8px;background:var(--primary);color:#fff;font-weight:800;font-size:16px}
.add-form .field label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}
.add-form input,.add-form select{width:100%;padding:11px 13px;border:1px solid var(--border);border-radius:9px;background:var(--card);font-size:14px;color:var(--text);transition:.15s}
.add-form input:focus,.add-form select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}
.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px;padding-top:14px;border-top:1px solid var(--border)}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--muted);padding:9px 16px;border-radius:9px;font-weight:600;cursor:pointer}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}

/* === Botões refinados (premium look) === */
.btn{position:relative;overflow:hidden;letter-spacing:.01em;padding:11px 20px;border-radius:11px}
.btn-primary{
  background:linear-gradient(135deg,#FF7A30,#E85F1A 60%,#D44E0E);
  color:#fff;border:none;
  box-shadow:0 4px 12px -3px rgba(232,95,26,.45),inset 0 1px 0 rgba(255,255,255,.25);
  text-shadow:0 1px 0 rgba(0,0,0,.08);
}
.btn-primary:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 20px -4px rgba(232,95,26,.55),inset 0 1px 0 rgba(255,255,255,.3);
  filter:brightness(1.04);
}
.btn-primary:active{transform:translateY(0);box-shadow:0 3px 8px -2px rgba(232,95,26,.4)}
.btn-primary::after{
  content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.18),transparent 55%);
  pointer-events:none;border-radius:inherit;
}
.btn-dark{
  background:linear-gradient(135deg,#1F2937,#0F172A);color:#fff;border-color:#0F172A;
  box-shadow:0 4px 12px -3px rgba(15,23,42,.4),inset 0 1px 0 rgba(255,255,255,.08);
}
.btn-dark:hover{transform:translateY(-1px);box-shadow:0 8px 18px -4px rgba(15,23,42,.5)}

/* === Inputs globais polidos === */
.card input[type=text],.card input[type=email],.card input[type=password],
.card input[type=number],.card input[type=date],.card input[type=tel],
.card input:not([type]),.card select,.card textarea{
  width:100%;padding:11px 13px;border:1.5px solid var(--border);border-radius:10px;
  background:var(--card);font-size:14px;color:var(--text);
  transition:border-color .15s,box-shadow .15s,background .15s;
  font-family:inherit;
}
.card input:focus,.card select:focus,.card textarea:focus{
  outline:none;border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(232,116,43,.12);
  background:var(--card);
}
.card input::placeholder{color:#9CA3AF}

/* === Cards das seções de perfil/segurança === */
.sec-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:22px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.sec-card h3{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:700;margin:0 0 4px;color:var(--text)}
.sec-card .sub{color:var(--muted);font-size:13px;margin:0 0 18px}
.sec-row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:14px 0;border-bottom:1px dashed var(--border);flex-wrap:wrap}
.sec-row:last-child{border-bottom:none;padding-bottom:0}
.sec-row > div:first-child{flex:1;min-width:180px}
.sec-row b{display:block;font-size:14px;color:var(--text);margin-bottom:2px}
.sec-row small{color:var(--muted);font-size:12.5px}
.status-off{display:inline-block;padding:2px 8px;border-radius:6px;background:#FEF3C7;color:#92400E;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-top:4px}
.status-on{display:inline-block;padding:2px 8px;border-radius:6px;background:#D1FAE5;color:#065F46;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-top:4px}

/* Pills/chips arredondados */
.chip{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-size:12px;font-weight:600}


/* ============================================================
   MOBILE RESPONSIVO v2 — drawer + topbar + bottom nav polidos
   ============================================================ */
.mobile-topbar{display:none}
.mobile-bottomnav{display:none}
.sidebar-backdrop{display:none}

@media(max-width:820px){
  html,body{overflow-x:hidden}
  body{padding-bottom:78px !important}
  .layout{display:block !important;grid-template-columns:none !important}

  /* Sidebar vira drawer off-canvas */
  .sidebar{
    position:fixed !important;top:0;left:0;bottom:0;
    width:86% !important;max-width:330px;
    z-index:90;transform:translateX(-105%);
    transition:transform .28s cubic-bezier(.4,0,.2,1);
    box-shadow:0 24px 60px rgba(0,0,0,.25);
    height:100vh;height:100dvh;
    padding:18px 12px 24px;
  }
  body.menu-open .sidebar{transform:translateX(0)}
  .sidebar-backdrop{
    position:fixed;inset:0;background:rgba(11,15,25,.55);
    z-index:80;backdrop-filter:blur(3px);
    opacity:0;pointer-events:none;transition:opacity .25s ease;
  }
  body.menu-open .sidebar-backdrop{display:block;opacity:1;pointer-events:auto}

  /* Conteúdo principal full width */
  .main{padding:14px !important;max-width:100% !important;width:100% !important;margin:0 !important}

  /* Topbar mobile */
  .mobile-topbar{
    display:flex;align-items:center;justify-content:space-between;gap:10px;
    background:#fff;border-bottom:1px solid var(--border);
    padding:10px 14px;position:sticky;top:0;z-index:70;
    box-shadow:0 1px 3px rgba(11,15,25,.04);
  }
  html[data-theme="dark"] .mobile-topbar{background:#0F1420;border-color:#1E2536}
  .mobile-topbar .menu-btn{
    background:var(--primary-soft);border:none;color:var(--primary);
    width:42px;height:42px;border-radius:12px;font-size:22px;cursor:pointer;
    display:grid;place-items:center;font-weight:700;
    transition:transform .15s ease;
  }
  .mobile-topbar .menu-btn:active{transform:scale(.92)}
  .mobile-topbar .brand-mini{
    display:flex;align-items:center;gap:8px;font-weight:800;font-size:16px;
    flex:1;justify-content:center;
  }
  .mobile-topbar .brand-mini svg{width:30px;height:30px}

  /* Bottom nav */
  .mobile-bottomnav{
    display:grid;grid-template-columns:repeat(5,1fr);align-items:end;
    position:fixed;bottom:0;left:0;right:0;background:#fff;
    border-top:1px solid var(--border);z-index:75;
    padding:10px 6px max(10px,env(safe-area-inset-bottom));
    box-shadow:0 -4px 16px rgba(11,15,25,.06);
  }
  html[data-theme="dark"] .mobile-bottomnav{background:#0F1420;border-color:#1E2536}
  .mobile-bottomnav a{
    display:flex;flex-direction:column;align-items:center;gap:3px;
    font-size:10.5px;font-weight:600;color:var(--muted);
    padding:4px 2px;text-decoration:none;
  }
  .mobile-bottomnav a.active{color:var(--primary)}
  .mobile-bottomnav .ico{font-size:20px;line-height:1}
  .mobile-bottomnav .center{
    background:linear-gradient(135deg,var(--primary) 0%,#FF7A30 100%);
    color:#fff !important;width:54px;height:54px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    margin-top:-26px;box-shadow:0 10px 24px rgba(232,116,43,.45);
    font-size:24px;
  }
  .mobile-bottomnav .center .ico{color:#fff;font-size:22px}

  /* Ajustes gerais de cards/grids no mobile */
  .grid-4,.grid-3,.grid-2,.grid-2-perfil,.tri,.profit,.row-2,.row-3{
    grid-template-columns:1fr !important;gap:12px;
  }
  .card{padding:16px;border-radius:14px}
  h1{font-size:24px !important;line-height:1.15}
  h2{font-size:18px}
  .trial-banner{
    font-size:12px;padding:12px 14px;flex-direction:column;align-items:flex-start;gap:8px;
    border-radius:12px;
  }
  .trial-banner a,.trial-banner button{width:100%;text-align:center}

  /* Formulários: campos empilhados ao invés de squeeze horizontal */
  form .form-row,form .row,form fieldset,
  table.form-table tr{display:flex;flex-direction:column;gap:10px}
  input,select,textarea{width:100% !important;font-size:15px !important}

  /* Tabelas com scroll horizontal */
  .table-wrap,.scroll-x{overflow-x:auto;-webkit-overflow-scrolling:touch}
  table{min-width:540px;font-size:13px}
}

@media(max-width:480px){
  .main{padding:10px !important}
  h1{font-size:21px !important}
  .mobile-topbar .brand-mini{font-size:15px}
}

/* Fix user-card overflow no rodapé da sidebar */
.user-card{min-width:0}
.user-card>div:last-child{min-width:0;flex:1;overflow:hidden}
.user-card b{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;display:block}
.user-card small{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;display:block}
.avatar{flex-shrink:0}

/* ============ DARK MODE FIX v11 — legibilidade completa ============ */
html[data-theme="dark"] .kpi{background:var(--card);border-color:var(--border);color:var(--text)}
html[data-theme="dark"] .kpi .v{color:#fff}
html[data-theme="dark"] .kpi .v.pos{color:#34d399}
html[data-theme="dark"] .kpi .v.neg{color:#f87171}
html[data-theme="dark"] .kpi .v.pri{color:var(--primary)}
html[data-theme="dark"] .kpi .top{color:var(--muted)}

/* Tabelas e cabeçalhos brancos */
html[data-theme="dark"] .tbl,
html[data-theme="dark"] .tbl th,
html[data-theme="dark"] .tbl td{background:transparent;color:var(--text);border-color:var(--border)}
html[data-theme="dark"] .tbl th{background:#1A1F2B!important;color:#CBD5E1!important}
html[data-theme="dark"] .tbl tr.grp td{background:#1A1F2B!important;color:#CBD5E1!important}
html[data-theme="dark"] .tbl tbody tr:hover td{background:rgba(255,255,255,.02)}

/* Botão escuro vira claro -> garantir contraste */
html[data-theme="dark"] .btn-dark{background:#fff;color:#0B0F19;border-color:#fff}
html[data-theme="dark"] .btn-dark:hover{background:#E5E7EB}

/* Ícones de bills usavam var(--dark) que vira claro */
html[data-theme="dark"] .bills .icon{background:#1A1F2B;color:var(--primary)}

/* Profit hero: texto secundário */
html[data-theme="dark"] .profit .desc{color:#CBD5E1}
html[data-theme="dark"] .meta .v{color:#fff}
html[data-theme="dark"] .meta h3{color:var(--muted)}

/* Health card */
html[data-theme="dark"] .health .label{color:#fff}
html[data-theme="dark"] .health ul li{color:var(--muted);border-color:var(--border)}
html[data-theme="dark"] .health .score small{color:var(--muted)}

/* Alerts */
html[data-theme="dark"] .alert-success{background:rgba(16,185,129,.12);color:#6ee7b7;border-color:rgba(16,185,129,.3)}
html[data-theme="dark"] .alert{background:rgba(239,68,68,.12);color:#fca5a5;border-color:rgba(239,68,68,.3)}

/* Cards de configurações */
html[data-theme="dark"] .card-title{color:#fff}
html[data-theme="dark"] .card-sub{color:var(--muted)}
html[data-theme="dark"] .sec-row b,
html[data-theme="dark"] .toggle-row b{color:#fff}
html[data-theme="dark"] .field label{color:#CBD5E1}
html[data-theme="dark"] .avatar-row{background:#1A1F2B}

/* Tabs configurações */
html[data-theme="dark"] .cfg-tabs{background:var(--card);border-color:var(--border)}
html[data-theme="dark"] .cfg-tabs a{color:#9CA3AF}
html[data-theme="dark"] .cfg-tabs a:hover{background:#1A1F2B;color:#fff}

/* Theme picker */
html[data-theme="dark"] .theme-card{background:#1A1F2B;border-color:var(--border)}
html[data-theme="dark"] .theme-card b{color:#fff}
html[data-theme="dark"] .theme-card.sel{background:rgba(232,116,43,.15);border-color:var(--primary)}

/* Chip / badges */
html[data-theme="dark"] .chip{background:rgba(232,116,43,.15);color:var(--primary)}

/* ico-btn (lixeira) hover */
html[data-theme="dark"] .ico-btn:hover{background:rgba(239,68,68,.15)}

/* Logout */
html[data-theme="dark"] .logout-link{color:#f87171}
html[data-theme="dark"] .logout-link:hover{background:rgba(239,68,68,.12)}

/* Forecast já tem fundo escuro - reforçar borda */
html[data-theme="dark"] .forecast{background:linear-gradient(135deg,#0B0F19,#1A1F2B);border:1px solid var(--border)}

/* Trial card / Plano */
html[data-theme="dark"] .trial-card h2{color:#fff}

/* Search / KBD */
html[data-theme="dark"] .search kbd{background:#1A1F2B;color:var(--muted);border-color:var(--border)}

/* Inputs autofill fix */
html[data-theme="dark"] input:-webkit-autofill{-webkit-text-fill-color:var(--text)!important;-webkit-box-shadow:0 0 0 1000px #1A1F2B inset!important}

/* Genéricos: qualquer texto preto puro vira legível */
html[data-theme="dark"] h1,html[data-theme="dark"] h2,html[data-theme="dark"] h3,html[data-theme="dark"] h4{color:#fff}
html[data-theme="dark"] label{color:#CBD5E1}
html[data-theme="dark"] small{color:var(--muted)}

/* ============ DARK MODE v13 — preto + cinza + laranja sem invisibilidade ============ */
html[data-theme="dark"]{
  --bg:#0D1016;--card:#171B24;--text:#F5F7FA;--text-2:#FFFFFF;--muted:#A7AFBD;--border:#2B3340;
  --primary:#FF7A2F;--primary-2:#FF9A57;--primary-soft:rgba(255,122,47,.14);
  --dark:#F5F7FA;--dark-2:#E7EAF0;
  --shadow-sm:0 1px 2px rgba(0,0,0,.35);
  --shadow:0 10px 30px rgba(0,0,0,.28),0 1px 0 rgba(255,255,255,.03) inset;
  --shadow-lg:0 24px 70px rgba(0,0,0,.42),0 1px 0 rgba(255,255,255,.04) inset;
}
html[data-theme="dark"],html[data-theme="dark"] body{background:#0D1016!important;color:var(--text)!important}
html[data-theme="dark"] .layout{background:#0D1016!important}
html[data-theme="dark"] .main{background:#0D1016!important}
html[data-theme="dark"] .sidebar,html[data-theme="dark"] .mobile-topbar,html[data-theme="dark"] .mobile-bottomnav{background:#111722!important;border-color:#2B3340!important;color:var(--text)!important}
html[data-theme="dark"] .brand-logo{background:#171B24!important;border-color:#343D4C!important;box-shadow:none!important}
html[data-theme="dark"] .brand-logo svg rect:first-child{fill:#F5F7FA!important}
html[data-theme="dark"] .brand b,html[data-theme="dark"] .brand-mini,html[data-theme="dark"] .greet h1,html[data-theme="dark"] .card-title{color:#FFFFFF!important;text-shadow:none!important}
html[data-theme="dark"] .greet small,html[data-theme="dark"] .nav-section{color:#B8C0CF!important}
html[data-theme="dark"] .greet p,html[data-theme="dark"] .card-sub,html[data-theme="dark"] .muted,html[data-theme="dark"] small{color:#A7AFBD!important}

html[data-theme="dark"] .card,html[data-theme="dark"] .kpi,html[data-theme="dark"] .sec-card,html[data-theme="dark"] .login-card,html[data-theme="dark"] .theme-card,html[data-theme="dark"] .meta,html[data-theme="dark"] .add-form{background:#171B24!important;border-color:#2B3340!important;color:#F5F7FA!important;box-shadow:var(--shadow-sm)!important}
html[data-theme="dark"] .card:hover,html[data-theme="dark"] .kpi:hover{border-color:#3A4556!important;box-shadow:var(--shadow)!important}
html[data-theme="dark"] .card *,html[data-theme="dark"] .sec-card *,html[data-theme="dark"] .add-form *,html[data-theme="dark"] .theme-card *,html[data-theme="dark"] .toggle-row *,html[data-theme="dark"] .danger-row *{text-shadow:none}
html[data-theme="dark"] h1,html[data-theme="dark"] h2,html[data-theme="dark"] h3,html[data-theme="dark"] h4,html[data-theme="dark"] b,html[data-theme="dark"] strong,html[data-theme="dark"] .value,html[data-theme="dark"] .v,html[data-theme="dark"] .price-block b{color:#FFFFFF!important}

html[data-theme="dark"] .nav a{color:#D7DCE5!important}
html[data-theme="dark"] .nav a .ico{color:#FF8A3D!important;opacity:1!important}
html[data-theme="dark"] .nav a:hover{background:#1B2230!important;color:#FFFFFF!important}
html[data-theme="dark"] .nav a.active{background:rgba(255,122,47,.18)!important;color:#FFFFFF!important;border:1px solid rgba(255,122,47,.24)!important}
html[data-theme="dark"] .nav a.active .ico,html[data-theme="dark"] .nav a.active span{color:#FF9A57!important}
html[data-theme="dark"] .mode-pill{background:rgba(255,122,47,.16)!important;color:#FFB077!important;border:1px solid rgba(255,122,47,.22)!important}
html[data-theme="dark"] .search input{background:#151B26!important;border-color:#30394A!important;color:#F5F7FA!important}
html[data-theme="dark"] .search input::placeholder{color:#8F98A8!important}
html[data-theme="dark"] .search kbd{background:#0D1016!important;border-color:#343D4C!important;color:#C4CAD5!important}

html[data-theme="dark"] .btn{background:#1C2430!important;border-color:#3A4556!important;color:#F5F7FA!important;box-shadow:none!important}
html[data-theme="dark"] .btn:hover{background:#242D3A!important;color:#FFFFFF!important}
html[data-theme="dark"] .btn-primary,html[data-theme="dark"] .cfg-tabs a.active,html[data-theme="dark"] .mobile-bottomnav .center{background:linear-gradient(135deg,#FF8A3D,#F06418)!important;color:#101217!important;border-color:transparent!important;font-weight:800!important;box-shadow:0 10px 24px rgba(240,100,24,.34)!important;text-shadow:none!important}
html[data-theme="dark"] .btn-primary *,html[data-theme="dark"] .cfg-tabs a.active *,html[data-theme="dark"] .mobile-bottomnav .center *{color:#101217!important}
html[data-theme="dark"] .btn-dark{background:#EDEFF3!important;color:#101217!important;border-color:#EDEFF3!important}
html[data-theme="dark"] .btn-ghost{background:transparent!important;color:#D7DCE5!important;border-color:#3A4556!important}

html[data-theme="dark"] input,html[data-theme="dark"] select,html[data-theme="dark"] textarea{background:#111722!important;color:#F5F7FA!important;border-color:#3A4556!important;caret-color:#FF8A3D!important}
html[data-theme="dark"] input::placeholder,html[data-theme="dark"] textarea::placeholder{color:#8F98A8!important}
html[data-theme="dark"] input:focus,html[data-theme="dark"] select:focus,html[data-theme="dark"] textarea:focus{border-color:#FF8A3D!important;box-shadow:0 0 0 3px rgba(255,122,47,.18)!important;background:#151B26!important}
html[data-theme="dark"] label,html[data-theme="dark"] .field label{color:#D7DCE5!important}

html[data-theme="dark"] .cfg-tabs{background:#171B24!important;border-color:#2B3340!important}
html[data-theme="dark"] .cfg-tabs a{color:#D7DCE5!important}
html[data-theme="dark"] .cfg-tabs a:hover{background:#1C2430!important;color:#FFFFFF!important}
html[data-theme="dark"] .theme-card.sel{background:rgba(255,122,47,.15)!important;border-color:#FF8A3D!important}
html[data-theme="dark"] .theme-card.sel b{color:#FFFFFF!important}

html[data-theme="dark"] table,html[data-theme="dark"] .tbl{color:#F5F7FA!important;background:transparent!important}
html[data-theme="dark"] th,html[data-theme="dark"] .tbl th{background:#111722!important;color:#C7CEDA!important;border-color:#2B3340!important}
html[data-theme="dark"] td,html[data-theme="dark"] .tbl td{color:#F5F7FA!important;border-color:#2B3340!important;background:transparent!important}
html[data-theme="dark"] tbody tr:hover,html[data-theme="dark"] .tbl tbody tr:hover td{background:#1B2230!important}
html[data-theme="dark"] .tbl tr.grp td{background:#111722!important;color:#FFB077!important}

html[data-theme="dark"] .checkin,html[data-theme="dark"] .profit,html[data-theme="dark"] .trial-banner{background:linear-gradient(135deg,#171B24,#211B17)!important;border-color:rgba(255,122,47,.28)!important;color:#F5F7FA!important}
html[data-theme="dark"] .checkin p,html[data-theme="dark"] .profit .desc,html[data-theme="dark"] .trial-banner span{color:#D7DCE5!important}
html[data-theme="dark"] .opt{background:#1C2430!important;color:#F5F7FA!important;border-color:#3A4556!important}
html[data-theme="dark"] .bar{background:#30303A!important}
html[data-theme="dark"] .chip{background:rgba(255,122,47,.16)!important;color:#FFB077!important;border:1px solid rgba(255,122,47,.20)!important}
html[data-theme="dark"] .danger-row{background:rgba(239,68,68,.10)!important;border-color:rgba(248,113,113,.35)!important}
html[data-theme="dark"] .status-off,html[data-theme="dark"] .b-pend{background:rgba(245,158,11,.16)!important;color:#FCD88A!important}
html[data-theme="dark"] .status-on,html[data-theme="dark"] .b-ok{background:rgba(16,185,129,.14)!important;color:#86EFAC!important}
html[data-theme="dark"] .b-new{background:rgba(59,130,246,.16)!important;color:#93C5FD!important}

/* ===== Mobile responsive v15 ===== */
@media (max-width: 768px){
  .main{padding:10px !important}
  h1{font-size:20px !important;line-height:1.2 !important;word-break:break-word}
  h2{font-size:16px !important;line-height:1.25 !important}
  h3{font-size:14px !important}
  .card{padding:12px !important;border-radius:16px !important}
  .kpi{padding:12px !important;border-radius:14px !important}
  .kpi .v{font-size:18px !important}
  .kpi .l,.kpi .top{font-size:10.5px !important}
  .grid-4{grid-template-columns:repeat(2,1fr) !important;gap:8px !important}
  .grid-3{grid-template-columns:repeat(2,1fr) !important;gap:8px !important}
  .grid-2{grid-template-columns:1fr !important;gap:10px !important}
  table{font-size:12px !important}
  th,td{padding:8px 6px !important}
  .btn{padding:10px 12px !important;font-size:13px !important;min-height:42px}
  .btn-primary{padding:11px 14px !important}
  input,select,textarea{font-size:16px !important;padding:11px 12px !important;border-radius:12px !important}
  .hero-profit{font-size:32px !important;line-height:1.05 !important}
  .trial-banner{flex-direction:column;gap:8px;text-align:center;padding:10px 12px !important;font-size:12px !important;border-radius:14px !important}
  .trial-banner .btn{width:100%}
  .mobile-bottomnav a{font-size:10px !important}
  .mobile-topbar{padding:10px 12px !important}
  #pwaInstallBanner{margin:10px !important;padding:12px !important;border-radius:16px !important}
  #pwaInstallBanner > div:first-child{width:38px !important;height:38px !important;font-size:18px !important}
  #pwaInstallBtn{padding:8px 12px !important;font-size:12px !important}
}
@media (max-width: 420px){
  .grid-4,.grid-3{grid-template-columns:1fr !important}
  h1{font-size:19px !important}
  .hero-profit{font-size:28px !important}
  .kpi .v{font-size:20px !important}
  .main{padding:8px !important}
}

/* ============================================================
   MOBILE POLISH v19 — Premium responsive, touch-first
   Mantém identidade (#FF5A00, Inter, branco/cinza) e ajusta
   proporções, espaçamentos e toques pra mobile fluido.
   ============================================================ */

/* Base: evita zoom indesejado iOS, força largura 100% */
html{ -webkit-text-size-adjust:100%; text-size-adjust:100% }
*,*::before,*::after{ box-sizing:border-box }
img,svg,video{ max-width:100%; height:auto }

@media(max-width:820px){
  /* Container fluido com vw */
  body{ font-size:15px; line-height:1.45 }
  .main{ padding:14px 4vw !important; width:100% !important; max-width:100vw !important }

  /* Topbar mobile — logo centralizada e visível */
  .mobile-topbar{
    padding:12px 4vw; gap:12px;
    height:60px;
  }
  .mobile-topbar .menu-btn,
  .mobile-topbar a.menu-btn{
    width:44px !important; height:44px !important;
    border-radius:12px; font-size:22px;
  }
  .mobile-topbar .brand-mini{
    font-size:17px; letter-spacing:-0.01em;
  }
  .mobile-topbar .brand-mini svg{ width:32px; height:32px }
  .mobile-topbar .brand-mini .ai{ color:var(--primary) }

  /* Cards: empilham com respiração */
  .grid{ gap:14px !important }
  .card{
    padding:18px 16px;
    border-radius:16px;
    margin:0;
  }
  .card h3{ font-size:11px; margin-bottom:10px }
  .card .value{ font-size:26px; letter-spacing:-0.025em }
  .card-title{ font-size:17px }
  .card-sub{ font-size:13px; line-height:1.4 }

  /* Topbar de página (não a mobile, mas a interna) */
  .topbar{ flex-direction:column; align-items:stretch; gap:14px; margin-bottom:18px }
  .topbar .greet h1{ font-size:22px !important; margin:2px 0 4px }
  .topbar .greet p{ font-size:13.5px; color:var(--muted) }

  /* Botões touch-friendly mínimo 44px */
  .btn, button.btn, a.btn, .btn-primary, .btn-dark, .btn-ghost{
    min-height:44px; padding:12px 18px;
    font-size:14.5px; border-radius:12px;
    display:inline-flex; align-items:center; justify-content:center;
  }
  .btn-block{ width:100%; min-height:48px; font-size:15px }

  /* Inputs fluídos, sempre 16px+ pra não dar zoom no iOS */
  input,select,textarea{
    min-height:46px !important;
    font-size:16px !important;
    padding:12px 14px !important;
    border-radius:11px !important;
    width:100% !important;
  }
  textarea{ min-height:96px !important; line-height:1.45 }

  /* Tabelas com swipe horizontal */
  .tbl,table{ font-size:13px }
  .tbl-wrap,.scroll-x,.table-wrap{
    margin:0 -4vw;
    padding:0 4vw;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .tbl-wrap::-webkit-scrollbar,.scroll-x::-webkit-scrollbar{ display:none }

  /* Bottom nav: maior, mais respiro */
  .mobile-bottomnav{
    padding:8px 4px max(12px,env(safe-area-inset-bottom));
    height:auto;
  }
  .mobile-bottomnav a{
    min-height:52px;
    padding:6px 2px;
    font-size:11px;
    gap:4px;
    transition:color .15s ease, transform .15s ease;
  }
  .mobile-bottomnav a:active{ transform:scale(.94) }
  .mobile-bottomnav .ico{ font-size:22px }
  .mobile-bottomnav .center{
    width:58px; height:58px;
    margin-top:-22px;
    box-shadow:0 12px 28px rgba(232,116,43,.5);
  }
  .mobile-bottomnav .center .ico{ font-size:26px }

  /* Trial banner mais compacto */
  .trial-banner{
    margin:0 4vw 14px; padding:14px 16px;
    border-radius:14px; gap:10px;
  }
  .trial-banner b{ font-size:13.5px }

  /* Configurações: abas roláveis horizontalmente */
  .cfg-tabs{
    display:flex !important; flex-wrap:nowrap !important;
    overflow-x:auto; -webkit-overflow-scrolling:touch;
    margin:0 -4vw 16px; padding:0 4vw 4px;
    gap:8px; scrollbar-width:none;
  }
  .cfg-tabs::-webkit-scrollbar{ display:none }
  .cfg-tabs a{
    flex-shrink:0; padding:10px 14px;
    font-size:13.5px; border-radius:10px;
    white-space:nowrap;
  }

  /* Alerts e mensagens */
  .alert,.alert-success{ font-size:13.5px; padding:14px; border-radius:12px }

  /* Drawer da sidebar: visual premium */
  .sidebar{
    padding:18px 14px 32px !important;
    border-radius:0 20px 20px 0;
  }
  .sidebar .nav a{
    padding:12px 14px; font-size:14.5px; min-height:44px;
    border-radius:12px;
  }
  .sidebar .nav a .ico{ font-size:16px; width:22px }
  .sidebar-footer{ padding-top:16px }

  /* Forms KPIs e mini-grids */
  .kpi{ padding:16px; border-radius:14px }
  .kpi .v{ font-size:24px }
  .kpi .top{ font-size:11px }
}

/* Telas estreitas (iPhone SE / 360px) */
@media(max-width:380px){
  .main{ padding:12px 3.5vw !important }
  .topbar .greet h1{ font-size:20px !important }
  .card .value{ font-size:23px }
  .mobile-topbar .brand-mini{ font-size:15px }
  .mobile-bottomnav a{ font-size:10px }
  .mobile-bottomnav .ico{ font-size:20px }
  .mobile-bottomnav .center{ width:54px; height:54px }
}

/* Telas grandes (tablet portrait / pequeno desktop) */
@media(min-width:821px) and (max-width:1024px){
  .main{ padding:24px 28px }
  .grid-4{ grid-template-columns:repeat(2,1fr) }
}

/* Garante que nada estoure horizontal */
.main,.card,.topbar,.grid,.tbl,.alert{ min-width:0 }


/* ============================================================
   MOBILE POLISH v20 — Corrige bottom nav overflow, cards 1col,
   tipografia legível, espaçamento generoso, toques 48px+
   ============================================================ */
@media(max-width:820px){
  /* Bottom nav: largura 100% segura, sem overflow */
  .mobile-bottomnav{
    width:100% !important; max-width:100vw !important;
    left:0 !important; right:0 !important;
    box-sizing:border-box !important;
    padding-left:max(6px,env(safe-area-inset-left)) !important;
    padding-right:max(6px,env(safe-area-inset-right)) !important;
    gap:0 !important;
  }
  .mobile-bottomnav a{
    min-width:0 !important;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    box-sizing:border-box;
  }
  .mobile-bottomnav a span:not(.ico){
    max-width:100%; overflow:hidden; text-overflow:ellipsis;
  }

  /* Cards SEMPRE empilham vertical no mobile, com respiro */
  .grid, .grid-2, .grid-3, .grid-4, .grid-5, .tri, .row-2, .row-3, .profit, .grid-2-perfil{
    grid-template-columns:1fr !important;
    gap:16px !important;
  }
  .plans-grid{ grid-template-columns:1fr !important; gap:14px !important }
  .card + .card{ margin-top:0 }

  /* Tipografia mobile mais legível */
  body{ font-size:15.5px !important; line-height:1.5 !important }
  h1{ font-size:22px !important; line-height:1.2 !important }
  h2{ font-size:18px !important; line-height:1.25 !important }
  h3{ font-size:15px !important }
  .card-title{ font-size:16px !important }
  small, .price-sub, .card-sub{ font-size:13px !important; line-height:1.45 !important }

  /* Botões: toque mínimo 48px, peso visual e respiro */
  .btn, button.btn, a.btn, .btn-primary, .btn-dark, .btn-ghost, .btn-block{
    min-height:48px !important;
    padding:13px 18px !important;
    font-size:15px !important;
    border-radius:12px !important;
    letter-spacing:.01em;
  }
  .btn-primary{ box-shadow:0 6px 16px rgba(232,116,43,.28) }
  .btn-block{ width:100% !important }

  /* Forms com mais respiro entre campos */
  form{ display:grid; gap:14px }
  label{ font-size:13.5px; font-weight:600; margin-bottom:4px; display:inline-block }
  input,select,textarea{
    min-height:48px !important;
    padding:13px 14px !important;
    font-size:16px !important;
  }

  /* Container principal sem overflow horizontal */
  html,body{ overflow-x:hidden !important; width:100% !important; max-width:100vw !important }
  .main{ width:100% !important; max-width:100vw !important; box-sizing:border-box !important }

  /* Cabeçalho de página com mais ar */
  .topbar{ margin-bottom:20px !important }

  /* Espaçamento entre seções */
  .card{ margin-bottom:0 !important }
  .main > * + *{ margin-top:14px }
}

/* iPhone SE / 360px — preserva legibilidade */
@media(max-width:380px){
  .mobile-bottomnav a{ font-size:9.5px !important; padding:6px 1px !important }
  .mobile-bottomnav .ico{ font-size:18px !important }
  .mobile-bottomnav .center{ width:50px !important; height:50px !important; margin-top:-18px !important }
  .mobile-bottomnav .center .ico{ font-size:22px !important }
  .btn, .btn-primary{ font-size:14.5px !important; padding:12px 14px !important }
  h1{ font-size:20px !important }
}

/* ===== v49: carrossel de planos, chart switch, espaçamentos ===== */
.plans-carousel{position:relative;margin-top:18px}
.plans-track{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:4px 4px 16px;scroll-padding:4px}
.plans-track::-webkit-scrollbar{display:none}
.plans-track .pcard{flex:0 0 84%;max-width:320px;scroll-snap-align:start;display:flex;flex-direction:column}
@media(min-width:720px){ .plans-track .pcard{flex:0 0 calc(50% - 12px)} }
@media(min-width:1080px){ .plans-track .pcard{flex:0 0 calc(33.333% - 12px)} }
@media(min-width:1320px){ .plans-track .pcard{flex:0 0 calc(25% - 12px)} }
.pc-nav{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;border:1px solid var(--border);background:#fff;color:#0F172A;font-size:24px;line-height:1;display:grid;place-items:center;box-shadow:0 6px 16px -8px rgba(15,23,42,.25);cursor:pointer;z-index:2}
.pc-prev{left:-6px} .pc-next{right:-6px}
.pc-nav:hover{background:var(--primary-soft);color:var(--primary)}
@media(max-width:640px){ .pc-nav{display:none} }
.pc-dots{display:flex;justify-content:center;gap:6px;margin-top:6px}
.pc-dot{width:8px;height:8px;border-radius:50%;background:#cbd5e1;cursor:pointer;transition:all .2s}
.pc-dot.on{background:var(--primary);width:22px;border-radius:4px}

.chart-switch{display:inline-flex;flex-wrap:wrap;gap:4px;background:#f1f5f9;padding:4px;border-radius:10px}
.chart-switch button{background:transparent;border:0;font-size:12.5px;font-weight:600;padding:8px 12px;border-radius:8px;cursor:pointer;color:#475569;min-height:34px}
.chart-switch button.on{background:#fff;color:var(--primary);box-shadow:0 1px 3px rgba(0,0,0,.08)}

/* Espaçamento de formulários e legendas (clientes, estoque, transações, documentos) */
.field{display:flex;flex-direction:column;gap:6px;min-width:0}
.field label{font-size:12.5px;font-weight:600;color:#475569;letter-spacing:.01em}
.field input,.field select,.field textarea{min-height:46px;padding:12px 14px;border:1px solid var(--border);border-radius:12px;font-size:15px;background:#fff;width:100%;box-sizing:border-box}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(255,90,0,.15)}
.row-2,.row-3{display:grid;gap:14px}
.row-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.row-3{grid-template-columns:repeat(3,minmax(0,1fr))}
@media(max-width:720px){ .row-2,.row-3{grid-template-columns:1fr} }
.add-form{padding:18px;border:1px dashed var(--border);border-radius:14px;margin-bottom:18px;background:#fafbfc}
.add-form h4{margin:0 0 14px;font-size:15px}
.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:14px;flex-wrap:wrap}
.card{padding:20px}
@media(max-width:640px){ .card{padding:16px;border-radius:18px} }

/* =========================================================
   v51 — REDESIGN MOBILE-FIRST COMPACTO
   Tipografia menor, mais ar, frases curtas, leitura fácil
   ========================================================= */
@media(max-width:820px){
  html,body{font-size:14.5px;line-height:1.5}

  /* Conteúdo principal mais arejado */
  .main{padding:14px 14px 100px;max-width:100%}
  .topbar{gap:10px;margin-bottom:14px}
  .greet small{font-size:10px;letter-spacing:.1em}
  .greet h1{font-size:22px;margin:4px 0 2px;line-height:1.15;letter-spacing:-.02em}
  .greet p{font-size:13px;color:var(--muted)}

  /* Cards proporcionais e leves */
  .card{padding:14px;border-radius:14px;box-shadow:none;border-color:#EEF0F3}
  .card h3{font-size:10.5px;margin-bottom:6px;letter-spacing:.08em}
  .card .value{font-size:20px;letter-spacing:-.015em}

  /* Grids sempre 1 coluna no mobile, com gap menor */
  .grid,.grid-2,.grid-3,.grid-4{grid-template-columns:1fr;gap:10px}

  /* Botões touch-friendly, mas proporcionais */
  .btn{padding:11px 14px;font-size:13.5px;border-radius:11px;min-height:44px}
  .btn-primary{box-shadow:0 4px 10px -4px rgba(232,116,43,.5)}
  .actions{gap:8px;width:100%}
  .actions .btn{flex:1;justify-content:center}

  /* Inputs e formulários — leitura clara, sem zoom no iOS */
  input,select,textarea{font-size:16px !important;min-height:44px;border-radius:11px;padding:10px 12px}
  textarea{min-height:88px}
  label{font-size:12.5px;font-weight:600;color:var(--text-2);margin-bottom:4px;display:block}
  .field{margin-bottom:12px}

  /* Tabelas viram lista vertical (cada linha um "card mini") */
  table{font-size:13px;border-collapse:separate;border-spacing:0 8px}
  thead{display:none}
  tbody tr{display:block;background:#fff;border:1px solid var(--border);border-radius:12px;padding:10px 12px;margin-bottom:0}
  tbody td{display:flex;justify-content:space-between;gap:10px;padding:4px 0;border:none;font-size:13px}
  tbody td:before{content:attr(data-label);color:var(--muted);font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em}

  /* Check-in / saudações: blocos menores */
  .checkin{padding:14px;border-radius:14px;margin-bottom:12px;gap:10px}
  .checkin h2{font-size:15px;line-height:1.25}
  .checkin p{font-size:12.5px;line-height:1.4}
  .checkin .heart{font-size:20px}

  /* Banners / alertas curtos */
  .trial-banner{padding:10px 14px;font-size:12.5px;border-radius:0;gap:10px;flex-wrap:wrap}
  .trial-banner b{font-size:12.5px}
  .trial-banner .btn{padding:8px 12px;font-size:12px;min-height:36px}

  /* Header mobile menor e proporcional */
  .mobile-header{padding:10px 12px;min-height:54px}
  .mobile-header .brand b{font-size:15px}
  .mobile-header .brand small{display:none}

  /* Bottom nav touch + textos legíveis */
  .mobile-bottomnav{padding:6px 4px calc(6px + env(safe-area-inset-bottom))}
  .mobile-bottomnav a{font-size:10.5px;gap:3px;padding:6px 2px}
  .mobile-bottomnav .ico{font-size:18px}

  /* Seções/títulos internos */
  h2,h3{letter-spacing:-.01em}
  h2{font-size:17px;line-height:1.25;margin-bottom:8px}
  h3{font-size:14.5px;line-height:1.3;margin-bottom:6px}
  p{font-size:13.5px;line-height:1.5;color:var(--text-2)}
  small,.muted{font-size:12px;color:var(--muted)}

  /* Espaçamento entre seções principais */
  .main > *{margin-bottom:14px}
  .main > *:last-child{margin-bottom:0}

  /* Plano carrossel — cards mais altos e claros */
  .plans-track .pcard{flex:0 0 86%;padding:16px;border-radius:16px}
  .pcard h3{font-size:15px}
  .pcard .price-block b{font-size:24px}
  .pcard ul li{font-size:12.5px;padding:4px 0}

  /* Modais / dialogs ocupam quase toda tela */
  .modal,.dialog{margin:8px;border-radius:16px;padding:16px;max-height:92vh}

  /* Lista de transações / agenda — separadores leves */
  .list-item{padding:12px;border-radius:12px;background:#fff;border:1px solid var(--border);margin-bottom:8px;display:flex;align-items:center;gap:12px}
  .list-item .title{font-size:13.5px;font-weight:600;line-height:1.3}
  .list-item .meta{font-size:11.5px;color:var(--muted)}
}

/* Telas estreitas (iPhone SE etc.) */
@media(max-width:380px){
  .main{padding:12px 12px 100px}
  .greet h1{font-size:20px}
  .card .value{font-size:18px}
  .plans-track .pcard{flex:0 0 90%}
}

/* Quando NÃO é dashboard, esconde reforçadamente qualquer faixa de plano */
body.page-trans .trial-banner,
body.page-cli .trial-banner,
body.page-est .trial-banner,
body.page-doc .trial-banner,
body.page-agenda .trial-banner,
body.page-imp .trial-banner,
body.page-imp2 .trial-banner,
body.page-ia .trial-banner,
body.page-wpp .trial-banner,
body.page-lucro .trial-banner,
body.page-cfg .trial-banner,
body.page-perfil .trial-banner{display:none !important}
