/* ============================================================
   Gestión Dyck Manantial — Sistema de diseño (ERP sidebar)
   ============================================================ */

/* ---------- Paletas: NEGRO · BLANCO · DORADO ---------- */
/* Default GLASS: vidrio esmerilado oscuro sobre escena, acentos oro */
:root, [data-theme="glass"] {
  --c-bg:#100e0b; --c-bg-2:#16130e;
  --c-surface:rgba(32,28,21,.55); --c-surface-2:rgba(50,43,32,.55);
  --c-border:rgba(255,255,255,.10); --c-border-2:rgba(255,255,255,.20);
  --c-text:#f7f1e6; --c-text-2:#d8cfbc; --c-muted:#9e9482;
  --c-primary:#d8b450; --c-primary-2:#edca7c; --c-primary-ink:#1c1503;
  --c-accent:#c8a44d; --c-income:#ecca7c; --c-expense:#e8836e; --c-warn:#e6b84d;
  --c-gold:#dcba5e; --c-gold-soft:rgba(220,186,94,.16);
  --c-sidebar:rgba(22,19,13,.55); --c-sidebar-ink:#f7f1e6;
  --glass:18px;
}
[data-theme="oro-claro"] {
  --c-bg:#f7f5f1; --c-bg-2:#ffffff; --c-surface:#ffffff; --c-surface-2:#f3f0ea;
  --c-border:rgba(15,13,8,.09); --c-border-2:rgba(15,13,8,.16);
  --c-text:#15130e; --c-text-2:#403a2f; --c-muted:#8a8070;
  --c-primary:#bf982f; --c-primary-2:#d8b450; --c-primary-ink:#1a1405;
  --c-accent:#c8a44d; --c-income:#9a7415; --c-expense:#b23a2e; --c-warn:#b07d12;
  --c-gold:#c8a44d; --c-gold-soft:rgba(200,164,77,.14);
  --c-sidebar:#121110; --c-sidebar-ink:#f3efe6;
}
/* Oscuro: negro profundo, texto blanco, oro */
[data-theme="oro-noche"] {
  --c-bg:#0d0c0a; --c-bg-2:#141310; --c-surface:#1a1814; --c-surface-2:#231f19;
  --c-border:rgba(255,255,255,.08); --c-border-2:rgba(255,255,255,.16);
  --c-text:#f6f2e9; --c-text-2:#d2cab9; --c-muted:#988f7d;
  --c-primary:#d8b450; --c-primary-2:#e6c878; --c-primary-ink:#1a1405;
  --c-accent:#c8a44d; --c-income:#e6c878; --c-expense:#e07a6e; --c-warn:#e6b84d;
  --c-gold:#d8b450; --c-gold-soft:rgba(216,180,80,.14);
  --c-sidebar:#0a0908; --c-sidebar-ink:#f6f2e9;
}
/* Blanco puro minimal con oro */
[data-theme="marfil"] {
  --c-bg:#fbfaf7; --c-bg-2:#ffffff; --c-surface:#ffffff; --c-surface-2:#f6f4ee;
  --c-border:rgba(20,18,10,.08); --c-border-2:rgba(20,18,10,.14);
  --c-text:#1c1a14; --c-text-2:#4a4438; --c-muted:#928975;
  --c-primary:#a98520; --c-primary-2:#c8a44d; --c-primary-ink:#ffffff;
  --c-accent:#a98520; --c-income:#8a6912; --c-expense:#b23a2e; --c-warn:#a87d12;
  --c-gold:#c8a44d; --c-gold-soft:rgba(169,133,32,.12);
  --c-sidebar:#ffffff; --c-sidebar-ink:#1c1a14;
}
/* Carbón total */
[data-theme="carbon"] {
  --c-bg:#101012; --c-bg-2:#17171a; --c-surface:#1c1c20; --c-surface-2:#26262b;
  --c-border:rgba(255,255,255,.08); --c-border-2:rgba(255,255,255,.16);
  --c-text:#f4f4f5; --c-text-2:#c9c9cf; --c-muted:#8d8d96;
  --c-primary:#d8b450; --c-primary-2:#e6c878; --c-primary-ink:#1a1405;
  --c-accent:#cfcfd6; --c-income:#e6c878; --c-expense:#e07a6e; --c-warn:#e6b84d;
  --c-gold:#d8b450; --c-gold-soft:rgba(216,180,80,.13);
  --c-sidebar:#0c0c0e; --c-sidebar-ink:#f4f4f5;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Inter',system-ui,sans-serif;background:var(--c-bg);color:var(--c-text);
  -webkit-font-smoothing:antialiased;line-height:1.5}
/* Escena de fondo (se ve a través del vidrio) */
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(1100px 720px at 80% -10%, rgba(220,186,94,.22), transparent 55%),
    radial-gradient(820px 560px at 6% 6%, rgba(150,110,45,.16), transparent 55%),
    radial-gradient(1000px 820px at 50% 122%, rgba(70,55,30,.30), transparent 60%),
    linear-gradient(155deg, #1a1610 0%, #100d09 55%, #0a0807 100%);}
.serif,h1,.login-card h2,.tour-pop h4,.stat.feature .val{font-family:'Fraunces','Playfair Display',Georgia,serif;
  letter-spacing:-.01em;font-weight:700}
img,svg{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
input,select,textarea{font:inherit;color:var(--c-text);width:100%;background:none;border:none;outline:none}
a{color:inherit;text-decoration:none}
.hidden{display:none!important}

/* ============ SHELL ============ */
.shell{display:flex;min-height:100vh}

/* ---------- Sidebar ---------- */
.sidebar{width:260px;flex-shrink:0;background:var(--c-sidebar);color:var(--c-sidebar-ink);
  border-right:1px solid var(--c-border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:30}
.sidebar .logo-box{padding:20px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;justify-content:center;
  background:linear-gradient(180deg,rgba(255,255,255,.04),transparent)}
.sidebar .logo-box img{width:118px;height:118px;object-fit:contain;border-radius:16px;background:#fff;padding:7px;
  box-shadow:0 6px 18px rgba(0,0,0,.25)}
.nav{flex:1;overflow-y:auto;padding:12px 12px;display:flex;flex-direction:column;gap:5px}
.nav button{display:flex;align-items:center;gap:13px;width:100%;padding:9px 11px;border-radius:14px;
  color:color-mix(in srgb,var(--c-sidebar-ink) 70%,transparent);transition:.18s cubic-bezier(.22,1,.36,1);text-align:left;position:relative}
.nav .ic-box{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex-shrink:0;
  background:var(--c-gold-soft);color:var(--c-gold);transition:.18s;border:1px solid transparent}
.nav .ic-box svg{width:21px;height:21px}
.nav .lbl{display:flex;flex-direction:column;line-height:1.18;font-size:15px;font-weight:700}
.nav .lbl small{font-size:11px;font-weight:500;opacity:.62;letter-spacing:.01em}
.nav button:hover{background:color-mix(in srgb,var(--c-sidebar-ink) 8%,transparent);color:var(--c-sidebar-ink)}
.nav button:hover .ic-box{transform:translateY(-1px) scale(1.04)}
.nav button.on{background:linear-gradient(110deg,var(--c-primary),var(--c-primary-2));color:var(--c-primary-ink);
  box-shadow:0 10px 24px -10px var(--c-gold),inset 0 1px 0 rgba(255,255,255,.25)}
.nav button.on .lbl small{opacity:.72}
.nav button.on .ic-box{background:rgba(0,0,0,.16);color:var(--c-primary-ink);border-color:rgba(0,0,0,.08)}
.nav button.on::after{content:"";position:absolute;right:11px;width:7px;height:7px;border-radius:50%;background:var(--c-primary-ink);opacity:.55}
.sidebar .foot{padding:14px;border-top:1px solid color-mix(in srgb,var(--c-sidebar-ink) 12%,transparent)}
.user-chip{display:flex;align-items:center;gap:11px;padding:8px;border-radius:12px}
.user-chip .av{width:38px;height:38px;border-radius:50%;background:var(--c-primary);color:var(--c-primary-ink);
  display:grid;place-items:center;font-weight:800;font-size:15px}
.user-chip .nm{font-size:14px;font-weight:700;line-height:1.1}
.user-chip .em{font-size:12px;color:var(--c-muted)}
.logout-btn{display:flex;align-items:center;gap:8px;width:100%;margin-top:8px;padding:10px 12px;border-radius:10px;
  color:color-mix(in srgb,var(--c-sidebar-ink) 55%,transparent);font-size:13px;font-weight:600}
.logout-btn:hover{background:color-mix(in srgb,var(--c-sidebar-ink) 9%,transparent);color:var(--c-expense)}
.user-chip .em{color:color-mix(in srgb,var(--c-sidebar-ink) 50%,transparent)}

/* ---------- Main ---------- */
.main{flex:1;min-width:0;background:
  radial-gradient(900px 500px at 100% -10%,color-mix(in srgb,var(--c-primary) 7%,transparent),transparent 60%),
  var(--c-bg);overflow-x:hidden}
.topbar-mobile{display:none}
.page{padding:30px 34px;max-width:1180px;animation:fade .3s cubic-bezier(.22,1,.36,1)}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.page-head h1{font-size:30px;font-weight:800;letter-spacing:-.02em}
.page-head .sub{color:var(--c-muted);font-size:14.5px;margin-top:2px}

.screen{display:none}
.screen.on{display:block}

/* ---------- Botones ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:12px 20px;border-radius:12px;
  font-weight:700;font-size:14.5px;transition:.18s;white-space:nowrap}
.btn svg{width:18px;height:18px}
.btn-primary{background:linear-gradient(180deg,var(--c-primary-2),var(--c-primary));color:var(--c-primary-ink);
  box-shadow:0 8px 20px -8px var(--c-primary)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 12px 26px -8px var(--c-primary)}
.btn-ghost{background:var(--c-surface);border:1px solid var(--c-border-2);color:var(--c-text)}
.btn-ghost:hover{background:var(--c-surface-2)}
.btn-danger{background:transparent;border:1px solid var(--c-expense);color:var(--c-expense)}
.btn-sm{padding:9px 14px;font-size:13px;border-radius:10px}

/* ---------- Cards / stats ---------- */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.stat{position:relative;background:var(--c-surface);border:1px solid var(--c-border);border-radius:16px;padding:22px 24px;
  box-shadow:0 1px 2px rgba(0,0,0,.04);overflow:hidden;transition:.18s}
.stat::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--c-gold);opacity:.0;transition:.18s}
.stat:hover{border-color:var(--c-border-2);box-shadow:0 8px 24px -14px rgba(0,0,0,.3)}
.stat:hover::before{opacity:.7}
.stat .top{display:flex;align-items:center;justify-content:space-between}
.stat .lbl{font-size:13.5px;color:var(--c-text-2);font-weight:600}
.stat .ico{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:var(--c-gold-soft);color:var(--c-gold)}
.stat .ico svg{width:19px;height:19px}
.stat .val{font-size:27px;font-weight:800;letter-spacing:-.02em;margin-top:14px;white-space:nowrap;
  font-variant-numeric:tabular-nums}
.stat .val.income{color:var(--c-income)} .stat .val.expense{color:var(--c-expense)} .stat .val.warn{color:var(--c-warn)}
.stat .hint{font-size:12.5px;color:var(--c-muted);margin-top:4px}
.stat.feature{grid-column:1/-1;border:1px solid var(--c-gold);
  background:linear-gradient(120deg,var(--c-gold-soft),var(--c-surface) 70%)}
.stat.feature::before{opacity:1;width:4px}
.stat.feature .val{font-size:40px;color:var(--c-gold)}

/* ---------- Gráfico ---------- */
.chart-wrap{width:100%;overflow:hidden}
.chart{width:100%;height:auto;display:block}
.chart-legend{display:flex;gap:20px;margin-bottom:14px;font-size:13px;font-weight:600;color:var(--c-text-2)}
.chart-legend span{display:inline-flex;align-items:center;gap:7px}
.dotc{width:11px;height:11px;border-radius:3px;display:inline-block}
.dotc.gold{background:var(--c-gold)} .dotc.dark{background:var(--c-text);opacity:.82}

/* ---------- Dos columnas (Ganadería / Personal) ---------- */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.col-panel{background:var(--c-surface);border:1px solid var(--c-border);border-radius:18px;padding:22px;
  box-shadow:0 1px 2px rgba(0,0,0,.04);position:relative;overflow:hidden}
.col-panel::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--c-gold)}
.col-panel.personal::before{background:var(--c-text);opacity:.5}
.col-head{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.col-head .ic-box{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--c-gold-soft);color:var(--c-gold)}
.col-head .ic-box svg{width:22px;height:22px}
.col-head h3{font-size:18px;font-weight:800}
.col-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}
.col-stats>div{background:var(--c-surface-2);border-radius:12px;padding:12px 14px;display:flex;flex-direction:column;gap:3px}
.col-stats .k{font-size:11.5px;color:var(--c-muted);font-weight:600}
.col-stats .v{font-size:16px;font-weight:800;font-variant-numeric:tabular-nums}
.col-stats .v.income{color:var(--c-income)} .col-stats .v.expense{color:var(--c-expense)} .col-stats .v.gold{color:var(--c-gold)}
.cc-title{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--c-muted);font-weight:700;margin-bottom:12px}
.cat-row{margin-bottom:13px}
.cat-top{display:flex;justify-content:space-between;align-items:center;font-size:13.5px;margin-bottom:6px}
.cat-top span{display:inline-flex;align-items:center;gap:7px;color:var(--c-text-2);font-weight:600}
.cat-top span svg{width:15px;height:15px;color:var(--c-muted)}
.cat-top b{font-variant-numeric:tabular-nums}
.cat-track{height:8px;border-radius:5px;background:var(--c-surface-2);overflow:hidden}
.cat-fill{height:100%;border-radius:5px;background:linear-gradient(90deg,var(--c-primary),var(--c-gold))}

.section{margin-top:26px}
.section-title{font-size:16px;font-weight:800;margin-bottom:14px;display:flex;align-items:center;gap:9px}
.section-title svg{width:19px;height:19px;color:var(--c-primary)}

/* ---------- Sub-tabs (Ganadería) ---------- */
.subtabs{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px;margin-bottom:20px;scrollbar-width:thin}
.subtab{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border-radius:12px;white-space:nowrap;
  font-weight:700;font-size:14px;color:var(--c-text-2);background:var(--c-surface);border:1px solid var(--c-border);transition:.16s}
.subtab svg{width:17px;height:17px;opacity:.85}
.subtab:hover{border-color:var(--c-border-2)}
.subtab.on{background:linear-gradient(110deg,var(--c-primary),var(--c-primary-2));color:var(--c-primary-ink);
  border-color:transparent;box-shadow:0 8px 18px -10px var(--c-gold)}

/* ---------- Panel / tabla ---------- */
.panel{background:var(--c-surface);border:1px solid var(--c-border);border-radius:18px;overflow:hidden;
  box-shadow:0 1px 3px rgba(0,0,0,.04)}
.panel-head{padding:18px 22px;border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between;gap:12px}
.panel-head h3{font-size:16px;font-weight:800}
.panel-body{padding:8px 0}
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--c-muted);
  font-weight:700;padding:12px 22px}
.table td{padding:14px 22px;border-top:1px solid var(--c-border)}
.table tr:hover td{background:var(--c-surface-2)}
.table .num{text-align:right;font-variant-numeric:tabular-nums;font-weight:700}
.table .actions{display:flex;gap:6px;justify-content:flex-end}
.iconbtn{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:var(--c-surface-2);
  border:1px solid var(--c-border);color:var(--c-text-2);transition:.15s}
.iconbtn:hover{color:var(--c-text);border-color:var(--c-border-2)}
.iconbtn.danger:hover{color:var(--c-expense);border-color:var(--c-expense)}
.iconbtn.ok:hover{color:var(--c-income);border-color:var(--c-income)}
.iconbtn svg{width:17px;height:17px}

.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:20px;font-size:12px;font-weight:700}
.badge.ok{background:color-mix(in srgb,var(--c-income) 16%,transparent);color:var(--c-income)}
.badge.pend{background:color-mix(in srgb,var(--c-warn) 18%,transparent);color:var(--c-warn)}
.badge.off{background:var(--c-surface-2);color:var(--c-muted)}
.badge.gan{background:var(--c-gold-soft);color:var(--c-gold)}
.badge.per{background:color-mix(in srgb,var(--c-text) 12%,transparent);color:var(--c-text-2)}

.pill-amount{font-weight:800;font-variant-numeric:tabular-nums}
.pill-amount.income{color:var(--c-income)} .pill-amount.expense{color:var(--c-expense)}

.empty{text-align:center;color:var(--c-muted);padding:40px 16px;font-size:14px}
.empty svg{width:40px;height:40px;margin:0 auto 12px;color:var(--c-border-2);stroke-width:1.5}

/* ---------- Filtros / segmentos ---------- */
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:18px}
.segment{display:inline-flex;gap:4px;background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:12px;padding:4px}
.segment button{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:9px;font-weight:600;
  font-size:13.5px;color:var(--c-muted);transition:.16s}
.segment button svg{width:16px;height:16px}
.segment button.on{background:var(--c-surface);color:var(--c-text);box-shadow:0 1px 3px rgba(0,0,0,.1)}

/* ---------- FAB gasto rápido ---------- */
.fab{position:fixed;right:26px;bottom:26px;z-index:60;display:flex;align-items:center;gap:9px;
  height:58px;padding:0 22px 0 18px;border-radius:30px;
  background:linear-gradient(150deg,var(--c-primary-2),var(--c-primary));color:var(--c-primary-ink);
  font-weight:800;font-size:15px;box-shadow:0 14px 30px -10px var(--c-gold),inset 0 1px 0 rgba(255,255,255,.3);
  transition:.2s cubic-bezier(.22,1,.36,1)}
.fab::after{content:"Gasto rápido"}
.fab:hover{transform:translateY(-2px);box-shadow:0 20px 40px -12px var(--c-gold)}
.fab:active{transform:scale(.96)}
.fab svg{width:24px;height:24px}
@media (max-width:560px){ .fab{right:16px;bottom:16px;padding:0;width:56px;height:56px;justify-content:center} .fab::after{display:none} }

/* ============ FORM / MODAL ============ */
.modal-bg{position:fixed;inset:0;z-index:80;background:rgba(10,8,4,.5);backdrop-filter:blur(3px);
  display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:.22s}
.modal-bg.open{opacity:1;pointer-events:auto}
.modal{background:var(--c-bg-2);border:1px solid var(--c-border-2);border-radius:20px;width:100%;max-width:640px;
  max-height:92vh;overflow-y:auto;transform:translateY(14px) scale(.98);transition:.26s cubic-bezier(.22,1,.36,1)}
.modal-bg.open .modal{transform:none}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--c-border);position:sticky;top:0;background:var(--c-bg-2);z-index:1}
.modal-head h3{font-size:19px;font-weight:800}
.modal-body{padding:22px 24px}
.modal-foot{padding:16px 24px;border-top:1px solid var(--c-border);display:flex;gap:10px;justify-content:flex-end;position:sticky;bottom:0;background:var(--c-bg-2)}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{margin-bottom:2px}
.field.col-2{grid-column:1/-1}
.field label{display:block;font-size:12px;font-weight:700;color:var(--c-text-2);margin-bottom:6px}
.field label .req{color:var(--c-expense)}
.control{display:flex;align-items:center;gap:9px;background:var(--c-surface-2);border:1px solid var(--c-border-2);
  border-radius:11px;padding:12px 14px;transition:.16s}
.control:focus-within{border-color:var(--c-primary)}
.control .prefix{color:var(--c-muted);font-weight:700;font-size:13px}
select.control{appearance:none;cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,var(--c-muted) 50%),linear-gradient(135deg,var(--c-muted) 50%,transparent 50%);background-position:calc(100% - 18px) 18px,calc(100% - 13px) 18px;background-size:5px 5px,5px 5px;background-repeat:no-repeat}
select.control option,select.control optgroup{background:#211d16;color:#fff}
textarea.control{resize:vertical;min-height:62px}
.amount-big{font-size:26px;font-weight:800}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border-radius:10px;background:var(--c-surface-2);
  border:1px solid var(--c-border-2);font-weight:600;font-size:13.5px;transition:.15s}
.chip svg{width:17px;height:17px}
.chip.on{background:var(--c-primary);color:var(--c-primary-ink);border-color:transparent}

/* sub-tabla de items (animales) */
.subtable{width:100%;border-collapse:collapse;font-size:13px;margin-top:8px}
.subtable th{text-align:left;color:var(--c-muted);font-size:11px;text-transform:uppercase;padding:6px 8px;font-weight:700}
.subtable td{padding:6px 8px;border-top:1px solid var(--c-border)}

/* ============ LOGIN ============ */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(800px 500px at 50% 0,color-mix(in srgb,var(--c-primary) 14%,transparent),transparent 60%),var(--c-bg)}
.login-card{width:100%;max-width:410px;background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:24px;padding:34px 30px;box-shadow:0 30px 60px -30px rgba(0,0,0,.4);text-align:center}
.login-card .logo{width:120px;height:120px;object-fit:contain;margin:0 auto 18px;background:#fff;border-radius:20px;padding:8px;border:1px solid var(--c-border)}
.login-card h2{font-size:24px;font-weight:800}
.login-card .sub{color:var(--c-muted);font-size:14px;margin-bottom:24px}
.btn-google{display:flex;align-items:center;justify-content:center;gap:11px;width:100%;padding:13px;border-radius:12px;
  background:#fff;color:#1f1f1f;border:1px solid #dadce0;font-weight:700;font-size:15px;transition:.16s}
.btn-google:hover{box-shadow:0 4px 14px rgba(0,0,0,.12)}
.divider{display:flex;align-items:center;gap:12px;color:var(--c-muted);font-size:12px;margin:20px 0}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--c-border-2)}
.login-card .field{text-align:left;margin-bottom:14px}
.note-soft{font-size:12.5px;color:var(--c-muted);margin-top:14px;min-height:16px;line-height:1.5}
.auth-toggle{font-size:13px;color:var(--c-muted);margin-top:14px;cursor:pointer}
.auth-toggle b{color:var(--c-primary-2)}
.e2e{display:inline-flex;align-items:center;gap:7px;margin-top:18px;font-size:12px;font-weight:600;
  color:var(--c-text-2);background:var(--c-gold-soft);border:1px solid var(--c-border);
  padding:8px 14px;border-radius:20px}
.e2e svg{width:14px;height:14px;color:var(--c-gold)}

/* ============ TOAST ============ */
#toast{position:fixed;left:50%;bottom:30px;transform:translateX(-50%) translateY(10px);z-index:120;
  background:var(--c-text);color:var(--c-bg);padding:13px 22px;border-radius:13px;font-weight:600;font-size:14px;
  box-shadow:0 14px 34px rgba(0,0,0,.3);opacity:0;pointer-events:none;transition:.28s}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ============ TOUR (globitos onboarding) ============ */
.tour-bg{position:fixed;inset:0;z-index:100;background:rgba(8,6,3,.62);opacity:0;pointer-events:none;transition:.25s}
.tour-bg.open{opacity:1;pointer-events:auto}
.tour-spot{position:fixed;z-index:101;border-radius:14px;box-shadow:0 0 0 4px var(--c-primary),0 0 0 9999px rgba(8,6,3,.62);
  transition:.3s cubic-bezier(.22,1,.36,1);pointer-events:none}
.tour-pop{position:fixed;z-index:102;max-width:300px;background:var(--c-surface);border:1px solid var(--c-border-2);
  border-radius:16px;padding:18px 20px;box-shadow:0 20px 50px -20px rgba(0,0,0,.5);transition:.3s cubic-bezier(.22,1,.36,1)}
.tour-pop .step{font-size:12px;font-weight:700;color:var(--c-primary);margin-bottom:4px;display:flex;align-items:center;gap:6px}
.tour-pop h4{font-size:17px;font-weight:800;margin-bottom:5px}
.tour-pop p{font-size:13.5px;color:var(--c-text-2);margin-bottom:14px}
.tour-pop .row{display:flex;gap:8px;align-items:center;justify-content:space-between}
.tour-pop .dots{display:flex;gap:5px}
.tour-pop .dots i{width:7px;height:7px;border-radius:50%;background:var(--c-border-2)}
.tour-pop .dots i.on{background:var(--c-primary)}

/* ---------- Theme grid (ajustes) ---------- */
.theme-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.theme-card{border:2px solid var(--c-border-2);border-radius:14px;padding:13px;cursor:pointer;transition:.16s;background:var(--c-surface)}
.theme-card.on{border-color:var(--c-primary)}
.theme-card .sw-row{display:flex;gap:5px;margin-bottom:8px}
.theme-card .sw{width:24px;height:24px;border-radius:7px;border:1px solid var(--c-border)}
.theme-card .nm{font-size:12.5px;font-weight:700}

/* ============ RESPONSIVE ============ */
@media (max-width:900px){
  .sidebar{position:fixed;left:0;top:0;transform:translateX(-100%);transition:transform .28s cubic-bezier(.22,1,.36,1);box-shadow:0 0 40px rgba(0,0,0,.3)}
  .sidebar.open{transform:none}
  .topbar-mobile{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;
    background:var(--c-sidebar);border-bottom:1px solid var(--c-border);position:sticky;top:0;z-index:25}
  .topbar-mobile .ham{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:var(--c-surface-2)}
  .topbar-mobile .ttl{font-weight:800;font-size:16px}
  .topbar-mobile img{height:38px;width:38px;object-fit:contain;border-radius:9px;background:#fff;padding:3px}
  .scrim{position:fixed;inset:0;z-index:29;background:rgba(0,0,0,.4);opacity:0;pointer-events:none;transition:.25s}
  .scrim.open{opacity:1;pointer-events:auto}
  .page{padding:20px 16px}
  .page-head h1{font-size:24px}
  .form-grid{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  .table-wrap{overflow-x:auto}
  .table{min-width:560px}
}
@media (min-width:901px){ .scrim{display:none} }
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ============================================================
   GLASS THEME — vidrio esmerilado (tema 'glass')
   ============================================================ */
[data-theme="glass"] .main{ background:transparent; }

/* Superficies de vidrio con desenfoque del fondo */
[data-theme="glass"] .sidebar,
[data-theme="glass"] .stat,
[data-theme="glass"] .panel,
[data-theme="glass"] .col-panel,
[data-theme="glass"] .subtab,
[data-theme="glass"] .modal,
[data-theme="glass"] .login-card,
[data-theme="glass"] .topbar-mobile,
[data-theme="glass"] .segment{
  backdrop-filter:blur(var(--glass)) saturate(1.3);
  -webkit-backdrop-filter:blur(var(--glass)) saturate(1.3);
}
/* Brillo superior sutil + sombra de profundidad en tarjetas */
[data-theme="glass"] .stat,
[data-theme="glass"] .panel,
[data-theme="glass"] .col-panel{
  box-shadow:0 18px 50px -22px rgba(0,0,0,.75), inset 0 1px 0 rgba(255,255,255,.10);
}
[data-theme="glass"] .control,
[data-theme="glass"] .chip,
[data-theme="glass"] .iconbtn,
[data-theme="glass"] .badge.off{ background:rgba(255,255,255,.06); }
[data-theme="glass"] .table tr:hover td{ background:rgba(255,255,255,.05); }
[data-theme="glass"] .modal{ background:rgba(24,21,15,.85); }
[data-theme="glass"] .modal-head,[data-theme="glass"] .modal-foot{ background:transparent; }

/* Marco flotante tipo "slab" de vidrio (desktop) */
@media (min-width:901px){
  [data-theme="glass"] .shell{
    margin:18px; height:calc(100vh - 36px); border-radius:30px; overflow:hidden;
    border:1px solid rgba(255,255,255,.16);
    box-shadow:0 50px 110px -40px rgba(0,0,0,.8), inset 0 1px 0 rgba(255,255,255,.10);
    background:rgba(255,255,255,.03);
  }
  [data-theme="glass"] .sidebar{ position:relative; height:auto; top:auto;
    border-right:1px solid rgba(255,255,255,.10); }
  [data-theme="glass"] .main{ height:100%; overflow-y:auto; }
}
[data-theme="glass"] .fab{ box-shadow:0 16px 40px -12px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.12) inset; }
