/* ============================================================
   DiasForce Finance — CSS v4 Final
   ============================================================ */
:root,
[data-theme="dark"]{
  --bg:#07111d;--panel:#0d1829;
  --text:#e2e8f0;--muted:#64748b;--border:#1e3a5f;
  --green:#22c55e;--red:#ef4444;--yellow:#f59e0b;
  --blue:#38bdf8;--cyan:#22d3ee;--purple:#a78bfa;
  --green-dim:rgba(34,197,94,.15);--red-dim:rgba(239,68,68,.15);
  --yellow-dim:rgba(245,158,11,.15);--blue-dim:rgba(56,189,248,.15);
  --radius:14px;--radius-sm:9px;--shadow:0 8px 32px rgba(0,0,0,.35);
  --nav-h:60px;
  --bg-grad-1:rgba(56,189,248,.09);
  --bg-grad-2:rgba(34,197,94,.07);
  --bg-grad-3:#07111d;--bg-grad-4:#090f1c;--bg-grad-5:#0a1220;
  --panel-bg-1:rgba(13,24,41,.97);
  --panel-bg-2:rgba(9,15,28,.97);
  --input-bg:#08111e;
  --table-th:#07101c;
}

/* ═══ TEMA CLARO ═══ */
[data-theme="light"]{
  --bg:#f8fafc;--panel:#ffffff;
  --text:#0f172a;--muted:#64748b;--border:#e2e8f0;
  --green:#16a34a;--red:#dc2626;--yellow:#d97706;
  --blue:#0284c7;--cyan:#0891b2;--purple:#7c3aed;
  --green-dim:rgba(22,163,74,.12);--red-dim:rgba(220,38,38,.12);
  --yellow-dim:rgba(217,119,6,.12);--blue-dim:rgba(2,132,199,.12);
  --shadow:0 4px 18px rgba(15,23,42,.08);
  --bg-grad-1:rgba(2,132,199,.05);
  --bg-grad-2:rgba(22,163,74,.04);
  --bg-grad-3:#f8fafc;--bg-grad-4:#f1f5f9;--bg-grad-5:#e2e8f0;
  --panel-bg-1:rgba(255,255,255,.98);
  --panel-bg-2:rgba(248,250,252,.98);
  --input-bg:#ffffff;
  --table-th:#f1f5f9;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',system-ui,Arial,sans-serif;font-size:14px;color:var(--text);line-height:1.5;
  background:radial-gradient(circle at 15% 15%,var(--bg-grad-1),transparent 40%),
             radial-gradient(circle at 85% 85%,var(--bg-grad-2),transparent 40%),
             linear-gradient(135deg,var(--bg-grad-3),var(--bg-grad-4) 55%,var(--bg-grad-5));
  min-height:100vh;transition:background .3s ease,color .3s ease}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}

/* ── WRAP ── */
.wrap{max-width:1600px;margin:0 auto;padding:18px 20px;position:relative}
.wrap::before{content:'';position:fixed;inset:0;
  background:url('../img/logo.png') center 80px no-repeat;
  background-size:min(1100px,80vw);opacity:.07;filter:blur(3px);pointer-events:none;z-index:0}
.wrap>*{position:relative;z-index:1}

/* ── AUTH ── */
.center{min-height:100vh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:24px;padding:20px}
.login-screen::before{content:'';position:fixed;inset:0;
  background:url('../img/logo.png') center 80px no-repeat;
  background-size:min(700px,85vw);opacity:.1;filter:blur(10px);pointer-events:none}
.login-logo{position:relative;z-index:1}
.login-logo img{width:320px;max-width:85vw;filter:drop-shadow(0 12px 28px rgba(0,0,0,.5));transition:transform .3s;display:block}
.login-logo img:hover{transform:scale(1.06)}
.auth-card{width:min(430px,100%);background:linear-gradient(160deg,var(--panel-bg-1),var(--panel-bg-2));
  border:1px solid var(--border);border-radius:20px;padding:32px;box-shadow:var(--shadow);position:relative;z-index:1}
.auth-card h2{font-size:22px;margin-bottom:4px}
.auth-sub{color:var(--muted);font-size:13px;margin-bottom:20px}
.auth-link{text-align:center;margin-top:18px;font-size:13px;color:var(--muted)}
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:5px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.field input,.field select,.field textarea{width:100%}
.mt{margin-top:4px}

/* ── INPUTS ── */
input,select,textarea,button{
  background:var(--input-bg);color:var(--text);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:10px 13px;font-size:14px;
  font-family:inherit;transition:border-color .2s,box-shadow .2s;width:100%}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(56,189,248,.15)}
input::placeholder{color:var(--muted)}
button{cursor:pointer;font-weight:700;width:auto}
select option{background:#08111e}

/* ── BUTTONS ── */
.btn-primary{background:var(--blue);color:#04131f;border-color:var(--blue)}
.btn-primary:hover{filter:brightness(1.1)}
.btn-success{background:var(--green);color:#042010;border-color:var(--green)}
.btn-success:hover{filter:brightness(1.1)}
.btn-warn{background:var(--yellow);color:#1a0e00;border-color:var(--yellow)}
.btn-danger{background:var(--red);color:#1a0202;border-color:var(--red)}
.btn-danger:hover{filter:brightness(1.1)}
.btn-ghost{background:transparent;color:var(--muted);border-color:var(--border)}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue)}
.btn-sm{padding:5px 11px;font-size:12px;border-radius:7px}
.full{width:100%}
button:disabled{opacity:.5;cursor:not-allowed}

/* ── BRAND ── */
.brand-top{display:flex;justify-content:center;align-items:center;margin-bottom:14px;padding-top:4px}
.brand-top img{height:220px;max-width:min(1300px,88vw);filter:drop-shadow(0 14px 36px rgba(0,0,0,.5));transition:transform .3s;object-fit:contain}
.brand-top img:hover{transform:scale(1.04)}

/* ── TOPBAR ── */
.topbar{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.topbar-left p{color:var(--muted);font-size:13px;margin-top:3px}
.topbar-right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* ── TABS DESKTOP ── */
.tabs{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:16px}
.tab-btn{background:#081320;border:1px solid var(--border);color:var(--muted);
  padding:10px 15px;border-radius:11px;font-weight:700;font-size:13px;
  cursor:pointer;transition:all .18s;white-space:nowrap}
.tab-btn:hover{border-color:var(--blue);color:var(--blue)}
.tab-btn.active{background:var(--blue);color:#04131f;border-color:var(--blue);transform:translateY(-1px)}
.tab{display:none}.tab.active{display:block}

/* ── TOOLBAR ── */
.toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:16px}
.toolbar input,.toolbar select{width:auto;min-width:120px}
.badge{background:var(--blue-dim);color:var(--blue);border:1px solid rgba(56,189,248,.25);
  padding:4px 12px;border-radius:999px;font-size:12px;font-weight:700}

/* ── CARDS / PANELS ── */
.card,.panel{background:linear-gradient(160deg,var(--panel-bg-1),var(--panel-bg-2));
  border:1px solid var(--border);border-radius:var(--radius);padding:16px;
  box-shadow:0 4px 18px rgba(0,0,0,.22)}
.card h3,.panel h3{font-size:12px;color:var(--muted);text-transform:uppercase;
  letter-spacing:.5px;margin-bottom:10px;font-weight:700}
.card h2,.panel h2{font-size:16px;margin-bottom:12px;font-weight:700}
.value{font-size:26px;font-weight:800;line-height:1.1}

/* KPI cores */
.card.kpi-receita .value{color:var(--green)}
.card.kpi-despesa .value{color:var(--red)}
.card.kpi-pendente .value{color:var(--yellow)}
.card.kpi-saldo-pos .value{color:var(--green)}
.card.kpi-saldo-neg .value{color:var(--red)}

/* ── GRIDS ── */
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;margin-bottom:16px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:16px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:16px}
.two-col{display:grid;grid-template-columns:1.4fr 1fr;gap:14px;margin-bottom:16px}
.form-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px;margin-top:12px}
.panel-mb{margin-bottom:14px}

/* ── CORES ── */
.pos{color:var(--green)}.neg{color:var(--red)}.warn{color:var(--yellow)}.info{color:var(--blue)}

/* ── PILLS ── */
.pill{display:inline-flex;align-items:center;gap:4px;padding:4px 11px;border-radius:999px;font-size:12px;font-weight:700;white-space:nowrap}
.pill-green{background:var(--green-dim);color:#86efac;border:1px solid rgba(34,197,94,.25)}
.pill-red{background:var(--red-dim);color:#fca5a5;border:1px solid rgba(239,68,68,.25)}
.pill-yellow{background:var(--yellow-dim);color:#fde68a;border:1px solid rgba(245,158,11,.25)}
.pill-blue{background:var(--blue-dim);color:#93c5fd;border:1px solid rgba(56,189,248,.25)}
.pill-purple{background:rgba(167,139,250,.15);color:#c4b5fd;border:1px solid rgba(167,139,250,.25)}

/* ── TABLE ── */
.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);margin-top:10px}
table{width:100%;border-collapse:collapse;min-width:700px}
th{background:var(--table-th);color:var(--blue);padding:11px 10px;text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.4px;position:sticky;top:0;z-index:2}
td{padding:10px;border-top:1px solid rgba(30,58,95,.4);vertical-align:middle;font-size:13px}
tr:hover td{background:rgba(56,189,248,.04)}
.td-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap}

/* ── PROGRESS ── */
.progress{width:100%;height:12px;background:rgba(8,17,30,.8);border:1px solid var(--border);border-radius:999px;overflow:hidden;margin-top:6px}
.progress-bar{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--green),var(--cyan));transition:width .5s ease}
.progress-bar.warn{background:linear-gradient(90deg,var(--yellow),#fb923c)}
.progress-bar.danger{background:linear-gradient(90deg,var(--red),#f97316)}

/* ── ALERTS ── */
.alert{padding:13px 16px;border-radius:var(--radius-sm);font-weight:600;margin-bottom:14px;font-size:13px}
.alert-good{background:var(--green-dim);border:1px solid rgba(34,197,94,.3);color:#86efac}
.alert-warn{background:var(--yellow-dim);border:1px solid rgba(245,158,11,.3);color:#fde68a}
.alert-err{background:var(--red-dim);border:1px solid rgba(239,68,68,.3);color:#fca5a5}

/* ── TOAST ── */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{padding:13px 18px;border-radius:11px;font-size:13px;font-weight:700;box-shadow:0 8px 24px rgba(0,0,0,.4);pointer-events:none;opacity:0;transform:translateY(12px);transition:opacity .3s,transform .3s;max-width:320px}
.toast.show{opacity:1;transform:translateY(0)}
.toast-ok{background:#052e16;border:1px solid rgba(34,197,94,.4);color:#86efac}
.toast-err{background:#1a0202;border:1px solid rgba(239,68,68,.4);color:#fca5a5}
.toast-warn{background:#1c0e00;border:1px solid rgba(245,158,11,.4);color:#fde68a}
.toast-info{background:#04131f;border:1px solid rgba(56,189,248,.4);color:#93c5fd}

/* ── SPINNER ── */
.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── ITEM CARD ── */
.item-card{background:var(--panel-bg-2);border:1px solid var(--border);border-radius:11px;padding:13px 14px;margin-bottom:8px;display:flex;flex-direction:column;gap:6px}
.item-card-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px}
.item-card-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}

/* ── MISC ── */
.small{font-size:12px;color:var(--muted)}
.flex{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.sep{height:1px;background:var(--border);margin:14px 0}
.mb{margin-bottom:12px}

/* ══════════════════════════════════════
   MOBILE NAV FIXA
   ══════════════════════════════════════ */
.mob-nav{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:1000;
  background:rgba(6,12,24,.97);
  border-top:1px solid rgba(30,58,95,.7);
  backdrop-filter:blur(24px);
  height:var(--nav-h);
  grid-template-columns:1fr 1fr 1fr;
  align-items:stretch;
}
.mob-nav-btn{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;border:none;background:none;color:var(--muted);
  font-size:10px;font-weight:700;cursor:pointer;
  width:100%;height:100%;border-radius:0;padding:6px 4px;
  transition:color .15s;letter-spacing:.3px;
}
.mob-nav-btn span:first-child{font-size:22px;line-height:1}
.mob-nav-btn.active{color:var(--blue)}
.mob-nav-add{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;border:none;background:none;cursor:pointer;
  width:100%;height:100%;border-radius:0;padding:6px 4px;
  font-size:10px;font-weight:700;color:var(--green);letter-spacing:.3px;
}
.mob-add-circle{
  width:46px;height:46px;border-radius:50%;
  background:linear-gradient(135deg,#22c55e,#16a34a);
  display:flex;align-items:center;justify-content:center;
  font-size:24px;color:#fff;
  box-shadow:0 3px 16px rgba(34,197,94,.45);
  line-height:1;
}

/* ── DRAWER ── */
.mob-overlay{
  display:none;position:fixed;inset:0;z-index:998;
  background:rgba(0,0,0,.55);backdrop-filter:blur(4px);
}
.mob-overlay.open{display:block}
.mob-drawer{
  position:fixed;bottom:var(--nav-h);left:0;right:0;z-index:999;
  background:var(--panel-bg-1);
  border-top:1px solid var(--border);
  border-radius:20px 20px 0 0;
  padding:12px 16px 16px;
  transform:translateY(100%);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
}
.mob-drawer.open{transform:translateY(0)}
.mob-drawer-pill{width:40px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 14px}
.mob-drawer-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px;
}
.mob-drawer-btn{
  display:flex;flex-direction:column;align-items:center;gap:5px;
  padding:13px 6px;border-radius:13px;
  background:rgba(255,255,255,.04);border:1px solid rgba(30,58,95,.5);
  cursor:pointer;color:var(--muted);font-size:11px;font-weight:700;
  transition:all .15s;width:100%;
  letter-spacing:.2px;
}
.mob-drawer-btn span:first-child{font-size:22px}
.mob-drawer-btn:active{color:var(--blue);border-color:rgba(56,189,248,.4);background:rgba(56,189,248,.08)}

/* ════════════════════════════════
   MOBILE ≤ 768px
   ════════════════════════════════ */
@media(max-width:768px){
  /* Esconder desktop */
  .brand-top{display:none !important}
  .tabs{display:none !important}
  .topbar-right .btn-ghost{display:none}

  /* Topbar minimalista */
  .topbar{
    position:sticky;top:0;z-index:100;
    background:rgba(6,12,24,.96);
    backdrop-filter:blur(20px);
    border-bottom:1px solid var(--border);
    padding:10px 14px;margin-bottom:0;
  }
  .topbar-left{gap:10px !important}
  .topbar-left img{width:34px !important;height:34px !important}
  .topbar-left>div>div:first-child{font-size:14px;font-weight:700}
  .topbar-left p{display:none !important}

  /* Wrap com padding p/ nav */
  .wrap{padding:0;padding-bottom:calc(var(--nav-h) + 12px)}
  .wrap .tab{padding:12px 14px 4px}
  .toolbar{margin:10px 14px 10px;padding:8px 12px;
    background:var(--panel-bg-2);border-radius:12px;gap:6px}
  .toolbar label{display:none}
  #saldoBanner,#countBadge{display:none}

  /* KPIs 2x2 */
  .grid4{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:10px}
  .grid3,.grid2,.two-col{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}

  /* Cards */
  .card,.panel{padding:12px;border-radius:12px}
  .value{font-size:20px}
  .panel h2{font-size:15px}

  /* Tabela */
  table{min-width:440px}
  th,td{padding:8px 6px;font-size:12px}
  table th:nth-child(3),table td:nth-child(3),
  table th:nth-child(6),table td:nth-child(6){display:none}

  /* Toast acima da nav */
  #toast-container{bottom:calc(var(--nav-h) + 10px);right:10px;left:10px}
  .toast{max-width:100%}

  /* Mostrar nav */
  .mob-nav{display:grid}
}

@media(min-width:769px){
  .mob-nav,.mob-drawer,.mob-overlay{display:none !important}
}
@media(max-width:1100px){
  .grid4{grid-template-columns:repeat(2,1fr)}
  .two-col{grid-template-columns:1fr}
}
/* ══════════════════════════════════════════
   MOBILE NAV — Adicione no FINAL do style.css
   ══════════════════════════════════════════ */

/* Nav fixa na base — sempre visível */
.mob-nav {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 9000;
  height: 62px;
  background: rgba(6, 11, 22, 0.98);
  border-top: 1px solid rgba(30, 58, 95, 0.8);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  grid-template-columns: 1fr 1fr 1fr;
  align-items: stretch;
  /* NUNCA se move */
  transform: none !important;
  transition: none !important;
}

.mob-nav-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  background: none;
  border: none;
  border-radius: 0;
  color: var(--muted);
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
  width: 100%;
  height: 100%;
  padding: 6px 4px;
  letter-spacing: .3px;
  transition: color .15s;
}
.mob-nav-btn:active { opacity: .7; }

.mob-nav-icon { font-size: 22px; line-height: 1; }

/* Botão lançar com círculo verde */
.mob-nav-lancar {
  color: var(--green);
}
.mob-nav-add {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, #22c55e, #16a34a);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  color: #fff;
  line-height: 1;
  box-shadow: 0 3px 16px rgba(34, 197, 94, .5);
  margin-bottom: 1px;
}

/* Overlay escuro atrás do drawer */
.mob-bg {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 8998;
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.mob-bg.aberto { display: block; }

.mob-sheet {
  display: none;
  position: fixed;
  left: 0; right: 0;
  bottom: 62px;
  z-index: 8999;
  background: rgba(9, 15, 28, 0.99);
  border-top: 1px solid var(--border);
  border-radius: 20px 20px 0 0;
  padding: 10px 14px 20px;
  max-height: 75vh;
  overflow-y: auto;
  transform: translateY(100%);
  transition: transform .3s cubic-bezier(.4, 0, .2, 1);
}
.mob-sheet.aberto {
  display: block;
  transform: translateY(0);
}

.mob-sheet-pill {
  width: 38px; height: 4px;
  background: var(--border);
  border-radius: 2px;
  margin: 0 auto 14px;
}

.mob-sheet-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}

.mob-sheet-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 12px 4px;
  border-radius: 13px;
  background: rgba(255, 255, 255, .04);
  border: 1px solid rgba(30, 58, 95, .5);
  cursor: pointer;
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  width: 100%;
  transition: all .15s;
  letter-spacing: .2px;
}
.mob-sheet-btn span { font-size: 22px; }
.mob-sheet-btn:active {
  color: var(--blue);
  border-color: rgba(56, 189, 248, .4);
  background: rgba(56, 189, 248, .08);
}

/* ════════════════════════
   MOBILE LAYOUT ≤ 768px
   ════════════════════════ */
@media (max-width: 768px) {

  /* Mostrar nav */
  .mob-nav { display: grid; }

  /* Esconder tudo do desktop */
  .brand-top { display: none !important; }
  .tabs { display: none !important; }
  .topbar-right .btn-ghost { display: none; }

  /* Topbar grudada no topo, compacta */
  .topbar {
    position: sticky;
    top: 0; z-index: 500;
    background: rgba(6, 11, 22, 0.97);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--border);
    padding: 10px 14px;
    margin-bottom: 0;
  }
  .topbar-left { gap: 10px !important; }
  .topbar-left img { width: 34px !important; height: 34px !important; }
  .topbar-left > div > div:first-child { font-size: 14px; font-weight: 700; }
  .topbar-left p { display: none !important; }

  /* Conteúdo com espaço para nav */
  .wrap {
    padding: 0;
    padding-bottom: 70px;
  }
  .wrap .tab { padding: 12px 14px 6px; }

  /* Toolbar simples */
  .toolbar {
    margin: 10px 14px;
    padding: 8px 12px;
    background: rgba(8, 14, 26, .8);
    border-radius: 12px;
    gap: 6px;
  }
  .toolbar label { display: none; }
  #saldoBanner, #countBadge { display: none; }

  /* KPIs 2 colunas */
  .grid4 { grid-template-columns: repeat(2, 1fr); gap: 8px; margin-bottom: 10px; }
  .grid3, .grid2, .two-col { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }

  /* Cards menores */
  .card, .panel { padding: 12px; border-radius: 12px; }
  .value { font-size: 20px; }
  .panel h2 { font-size: 15px; }

  /* Tabela com scroll */
  table { min-width: 440px; }
  th, td { padding: 8px 6px; font-size: 12px; }
  table th:nth-child(3), table td:nth-child(3),
  table th:nth-child(6), table td:nth-child(6) { display: none; }

  /* Toast acima da nav */
  #toast-container {
    bottom: 70px;
    right: 10px; left: 10px;
  }
  .toast { max-width: 100%; }
}

/* Desktop: esconder tudo mobile */
@media (min-width: 769px) {
  .mob-nav,
  .mob-sheet,
  .mob-bg { display: none !important; }
}

@media (max-width: 1100px) {
  .grid4 { grid-template-columns: repeat(2, 1fr); }
  .two-col { grid-template-columns: 1fr; }
}

/* ═══ TRANSIÇÕES DE TEMA ═══ */
.card,.panel,input,select,textarea,button,.tab-btn,.mob-nav,.mob-sheet,.topbar{
  transition:background .25s ease,border-color .25s ease,color .25s ease,box-shadow .25s ease;
}

/* ═══ TOGGLE DE TEMA ═══ */
.theme-toggle{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:999px;cursor:pointer;
  background:var(--panel-bg-2);border:1px solid var(--border);
  color:var(--text);font-size:13px;font-weight:600;
  transition:all .2s;
}
.theme-toggle:hover{border-color:var(--blue);transform:translateY(-1px)}
.theme-toggle .ic{font-size:18px;line-height:1}

/* ═══ FOOTER GLOBAL ═══ */
.df-footer{
  text-align:center;padding:24px 16px;margin-top:30px;
  border-top:1px solid var(--border);font-size:12px;color:var(--muted);
}
.df-footer a{margin:0 8px;color:var(--muted);text-decoration:none}
.df-footer a:hover{color:var(--blue);text-decoration:underline}

/* ═══ TOUR DE BOAS-VINDAS ═══ */
.welcome-tour{
  position:fixed;inset:0;z-index:9500;
  background:rgba(0,0,0,.75);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:20px;
}
.welcome-card{
  background:var(--panel-bg-1);border:1px solid var(--border);
  border-radius:20px;padding:32px;max-width:520px;width:100%;
  box-shadow:0 24px 64px rgba(0,0,0,.5);
  text-align:center;
}
.welcome-card h2{font-size:24px;margin-bottom:8px}
.welcome-card p{color:var(--muted);margin-bottom:20px;line-height:1.7}
.welcome-steps{display:flex;flex-direction:column;gap:10px;margin:20px 0;text-align:left}
.welcome-step{
  display:flex;align-items:center;gap:14px;padding:13px 16px;
  background:var(--panel-bg-2);border:1px solid var(--border);
  border-radius:12px;
}
.welcome-step .num{
  width:28px;height:28px;border-radius:50%;
  background:var(--blue);color:white;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;flex-shrink:0;
}
.welcome-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}
