﻿*{margin:0;padding:0;box-sizing:border-box}
:root{
  --navy:#1B3A6B;--navy-dark:#122850;--navy-light:rgba(27,58,107,0.08);
  --gold:#C8962E;--gold-bg:#FFF6E4;
  --cream:#F7F4EF;--white:#FFFFFF;
  --g50:#F8F6F2;--g100:#EDEAE3;--g300:#C5BFB5;--g500:#857E74;--g700:#524D46;--g900:#2C2720;
  --green:#276B52;--green-bg:#E8F4EF;
  --red:#B83232;--red-bg:#FCEAEA;
  --blue:#2860B8;--blue-bg:#EBF1FC;
  --purple:#6B3FA0;--purple-bg:#F0EAF8;
  --sw:272px;--r:12px;
  --sh:0 1px 4px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --sm:0 4px 16px rgba(27,58,107,.10),0 2px 6px rgba(27,58,107,.06);
  --sl:0 8px 32px rgba(27,58,107,.16),0 4px 12px rgba(27,58,107,.09)
}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--g900);min-height:100vh;font-size:15px}
/* ─── SIDEBAR ─── */
#sidebar{position:fixed;top:0;left:0;width:var(--sw);height:100vh;background:var(--navy);display:flex;flex-direction:column;overflow-y:auto;z-index:100}
.sb-logo{padding:26px 22px 20px;border-bottom:1px solid rgba(255,255,255,.1)}
.sb-logo h1{font-family:'Playfair Display',serif;color:#fff;font-size:21px;font-weight:700;letter-spacing:.3px}
.sb-logo p{color:rgba(255,255,255,.4);font-size:11.5px;margin-top:2px}
.sb-section{padding:14px 0 6px}
.sb-label{padding:0 22px 7px;font-size:10px;font-weight:600;letter-spacing:1.8px;text-transform:uppercase;color:rgba(255,255,255,.28)}
.ni{display:flex;align-items:center;gap:10px;padding:10px 22px;cursor:pointer;color:rgba(255,255,255,.68);font-size:13.5px;transition:all .18s;border-left:3px solid transparent;user-select:none}
.ni:hover{background:rgba(255,255,255,.07);color:#fff}
.ni.active{background:rgba(200,150,46,.14);color:#E8C06A;font-weight:600;border-left-color:var(--gold)}
.ni svg{width:16px;height:16px;flex-shrink:0;opacity:.85}
.ni.active svg{opacity:1}
.sb-foot{margin-top:auto;padding:14px 16px;border-top:1px solid rgba(255,255,255,.07);text-align:center;position:relative;overflow:hidden}
.sb-foot-inner{position:relative;z-index:1;padding:10px 0;display:flex;align-items:center;justify-content:space-between;gap:12px}
.sb-logout{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:none;border-radius:999px;
  background:rgba(255,255,255,.08);color:#F4E8C8;font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:600;
  cursor:pointer;transition:transform .18s,background .18s,box-shadow .18s;white-space:nowrap}
.sb-logout svg{width:14px;height:14px;stroke:currentColor}
.sb-logout:hover{background:rgba(200,150,46,.18);color:#FFF4D2;transform:translateY(-1px);
  box-shadow:0 8px 20px rgba(0,0,0,.15)}
.sb-user{min-width:0;display:flex;flex-direction:column;align-items:flex-end;justify-content:center;text-align:right;padding:6px 10px;border-radius:12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.07);box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}
.sb-user-name{max-width:118px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#FFF7E5;font-size:11.6px;font-weight:700}
.sb-user-meta{max-width:118px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:rgba(244,232,200,.68);font-size:9.5px;letter-spacing:.25px}
.spark{position:absolute;width:3px;height:3px;border-radius:50%;pointer-events:none;animation:sparkFly 2.2s ease-in-out infinite}
.spark:nth-child(1){left:15%;background:#FFE04A;animation-delay:0s;animation-duration:2.1s}
.spark:nth-child(2){left:40%;background:#FF6B9D;animation-delay:.4s;animation-duration:1.9s}
.spark:nth-child(3){left:60%;background:#57F287;animation-delay:.8s;animation-duration:2.4s}
.spark:nth-child(4){left:80%;background:#5DADE2;animation-delay:1.2s;animation-duration:2s}
.spark:nth-child(5){left:28%;background:#A855F7;animation-delay:1.6s;animation-duration:2.3s}
.spark:nth-child(6){left:70%;background:#FFB347;animation-delay:.2s;animation-duration:1.8s}
/* ─── EXTRA VARS ─── */
:root{
  --teal:#0D9488;--teal-bg:#E6FAF8;
  --glow-gold:0 0 18px rgba(200,150,46,.35);
  --glow-navy:0 0 18px rgba(27,58,107,.35);
  --glow-purple:0 0 18px rgba(107,63,160,.4);
}
/* ─── SIDEBAR UPGRADES ─── */
#sidebar{
  background:linear-gradient(180deg,#0F2347 0%,#1B3A6B 45%,#142E58 100%);
  border-right:1px solid rgba(255,255,255,.06);
}
.sb-logo{padding:26px 22px 20px;border-bottom:1px solid rgba(255,255,255,.08);position:relative}
.sb-logo::after{content:"";position:absolute;bottom:0;left:22px;right:22px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(200,150,46,.4),transparent)}
.sb-logo h1{font-family:"Playfair Display",serif;color:#fff;font-size:21px;font-weight:700;
  letter-spacing:.3px;text-shadow:0 0 24px rgba(200,150,46,.4)}
.sb-logo-dot{display:inline-block;width:7px;height:7px;border-radius:50%;
  background:var(--gold);margin-right:7px;animation:pulseDot 2s ease-in-out infinite;
  box-shadow:0 0 8px var(--gold)}
.sb-label{padding:0 22px 7px;font-size:9.5px;font-weight:700;letter-spacing:2.2px;
  text-transform:uppercase;color:rgba(255,255,255,.22);position:relative}
.ni{display:flex;align-items:center;gap:10px;padding:10px 18px 10px 20px;
  cursor:pointer;color:rgba(255,255,255,.62);font-size:13.5px;
  transition:all .22s cubic-bezier(.4,0,.2,1);
  border-left:3px solid transparent;user-select:none;margin:1px 8px;border-radius:9px}
.ni:hover{background:rgba(255,255,255,.08);color:#fff;transform:translateX(2px)}
.ni.active{
  background:linear-gradient(135deg,rgba(200,150,46,.22) 0%,rgba(200,150,46,.08) 100%);
  color:#F0C96A;font-weight:600;border-left-color:var(--gold);
  box-shadow:inset 0 0 14px rgba(200,150,46,.08),0 0 0 1px rgba(200,150,46,.15)}
.ni svg{width:15px;height:15px;flex-shrink:0;opacity:.8;transition:all .22s}
.ni.active svg{opacity:1;filter:drop-shadow(0 0 4px rgba(200,150,46,.6))}
.ni:hover svg{opacity:1}
.sb-section{padding:12px 0 4px}
/* ─── SIDEBAR FOOTER UPGRADE ─── */
.sb-foot{margin-top:auto;padding:14px 16px;border-top:1px solid rgba(255,255,255,.07);
  text-align:center;position:relative;overflow:hidden}
.sb-foot::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(200,150,46,.5),rgba(100,180,255,.4),transparent);
  animation:scanLine 3s linear infinite}
.sb-foot-inner{position:relative;z-index:1;padding:10px 0;display:flex;align-items:center;justify-content:space-between;gap:12px}
.sb-user{backdrop-filter:blur(8px)}
.sb-user-name{font-size:11.8px}
.sb-user-meta{font-size:9.7px}

/* ─── BTN AJUSTAR STOCK ─── */
.btn-adj{background:linear-gradient(135deg,#5B3F8A 0%,#7B52B8 100%);color:#fff;
  box-shadow:0 2px 8px rgba(91,63,138,.35)}
.btn-adj:hover{background:linear-gradient(135deg,#4A3070 0%,#6A42A0 100%);
  transform:translateY(-1px);box-shadow:0 4px 14px rgba(91,63,138,.5)}
/* ─── MAIN BACKGROUND ─── */
#main{margin-left:var(--sw);min-height:100vh;padding:30px 34px;
  background:radial-gradient(ellipse at 80% 0%,rgba(27,58,107,.05) 0%,transparent 60%),
             radial-gradient(ellipse at 20% 100%,rgba(200,150,46,.04) 0%,transparent 50%),
             var(--cream)}
/* ─── PAGE HEADER UPGRADE ─── */
.ph h2{font-family:"Playfair Display",serif;font-size:26px;font-weight:700;
  background:linear-gradient(135deg,var(--navy) 0%,#2A6DB8 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  line-height:1.25}
/* ─── CARD UPGRADES ─── */
.card{background:#fff;border-radius:var(--r);box-shadow:var(--sh);padding:22px;
  border:1px solid rgba(0,0,0,.04);transition:box-shadow .25s}
.card:hover{box-shadow:0 4px 20px rgba(27,58,107,.09),0 1px 4px rgba(27,58,107,.05)}
/* ─── STAT CARD UPGRADES ─── */
.sc{background:#fff;border-radius:var(--r);padding:18px 22px;
  box-shadow:var(--sh);border:1px solid rgba(0,0,0,.04);
  transition:transform .22s,box-shadow .22s;position:relative;overflow:hidden}
.sc::after{content:"";position:absolute;top:-30px;right:-30px;width:80px;height:80px;
  border-radius:50%;background:radial-gradient(circle,rgba(27,58,107,.04),transparent);
  pointer-events:none}
.sc:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(27,58,107,.12)}
/* ─── BUTTON UPGRADES ─── */
.btn-primary{background:linear-gradient(135deg,var(--navy) 0%,#2A5FAA 100%);color:#fff}
.btn-primary:hover{background:linear-gradient(135deg,#122850 0%,var(--navy) 100%);
  transform:translateY(-1px);box-shadow:0 4px 14px rgba(27,58,107,.4)}
.btn-gold{background:linear-gradient(135deg,#C8962E 0%,#E8B848 100%);color:#fff}
.btn-gold:hover{background:linear-gradient(135deg,#b5821d 0%,#c89d2e 100%);
  transform:translateY(-1px);box-shadow:0 4px 14px rgba(200,150,46,.45)}
.btn-success{background:linear-gradient(135deg,var(--green) 0%,#38A07A 100%);color:#fff}
.btn-success:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(39,107,82,.4)}
/* ─── SPARKLE UPGRADE — más cantidad, más color ─── */
.spark{position:absolute;width:4px;height:4px;border-radius:50%;pointer-events:none;
  animation:sparkFly 2.2s ease-in-out infinite}
.spark:nth-child(1){left:10%;background:#FFE04A;animation-delay:0s;animation-duration:2.1s;width:3px;height:3px}
.spark:nth-child(2){left:28%;background:#FF6B9D;animation-delay:.35s;animation-duration:1.9s}
.spark:nth-child(3){left:48%;background:#57F287;animation-delay:.7s;animation-duration:2.4s;width:3px;height:3px}
.spark:nth-child(4){left:68%;background:#5DADE2;animation-delay:1.1s;animation-duration:2s}
.spark:nth-child(5){left:85%;background:#A855F7;animation-delay:1.5s;animation-duration:2.3s;width:3px;height:3px}
.spark:nth-child(6){left:20%;background:#FFB347;animation-delay:.2s;animation-duration:1.8s}
.spark:nth-child(7){left:55%;background:#FF6B9D;animation-delay:.9s;animation-duration:2.6s;width:2px;height:2px}
.spark:nth-child(8){left:75%;background:#FFE04A;animation-delay:1.4s;animation-duration:2s;width:2px;height:2px}
/* ─── KDEX HEADER UPGRADE ─── */
.kdx-head{background:linear-gradient(135deg,#4A2B7A 0%,var(--purple) 40%,#9B5EDE 100%);
  color:#fff;border-radius:10px;padding:16px 20px;margin-bottom:14px;
  display:flex;justify-content:space-between;align-items:center;
  box-shadow:0 4px 14px rgba(107,63,160,.35)}
/* ─── TOAST UPGRADE ─── */
.toast.success{background:linear-gradient(135deg,var(--green),#38A07A);color:#fff}
.toast.error{background:linear-gradient(135deg,var(--red),#D44A4A);color:#fff}
.toast.info{background:linear-gradient(135deg,var(--navy),#2A5FAA);color:#fff}
.toast.warning{background:linear-gradient(135deg,#C8962E,#E8B848);color:#fff}
/* ─── HERO UPGRADE ─── */
.hero h2{font-family:"Playfair Display",serif;font-size:36px;font-weight:700;
  background:linear-gradient(135deg,var(--navy) 0%,#2A6DB8 50%,var(--purple) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  line-height:1.2;margin-bottom:8px}
/* ─── HOME MODULE CARDS UPGRADE ─── */
.mod-card{background:#fff;border:1.5px solid var(--g100);border-radius:16px;
  padding:26px 20px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);
  text-align:center;position:relative;overflow:hidden}
.mod-card:hover{transform:translateY(-7px);box-shadow:0 16px 40px rgba(27,58,107,.15);border-color:transparent}
.mod-card::after{content:"";position:absolute;inset:0;opacity:0;
  background:radial-gradient(circle at 50% 0%,rgba(255,255,255,.6),transparent 70%);
  transition:opacity .3s}
.mod-card:hover::after{opacity:1}
/* ─── SCROLLBAR ─── */
#sidebar::-webkit-scrollbar{width:4px}
#sidebar::-webkit-scrollbar-track{background:transparent}
#sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:4px}
#sidebar::-webkit-scrollbar-thumb:hover{background:rgba(200,150,46,.4)}
/* ─── ANIMATIONS ─── */
@keyframes pulseDot{0%,100%{opacity:1;transform:scale(1);box-shadow:0 0 8px var(--gold)}
  50%{opacity:.7;transform:scale(.8);box-shadow:0 0 14px var(--gold)}}
@keyframes scanLine{0%{opacity:0;transform:translateX(-100%)}
  30%{opacity:1}70%{opacity:1}100%{opacity:0;transform:translateX(100%)}}
@keyframes rbFlow{to{background-position:200% center}}
@keyframes sparkFly{0%{bottom:0;opacity:0;transform:scale(0)}20%{opacity:1;transform:scale(1)}80%{opacity:.6}100%{bottom:52px;opacity:0;transform:scale(.3) translateX(6px)}}
/* ─── MAIN ─── */
/* ─── CARD ─── */
.card+.card{margin-top:18px}
.card-title{font-family:'Playfair Display',serif;font-size:18px;color:var(--navy);margin-bottom:16px;font-weight:600}
/* ─── PAGE HEADER ─── */
.ph{margin-bottom:26px}
.ph h2{font-family:'Playfair Display',serif;font-size:26px;color:var(--navy);font-weight:700}
.ph p{color:var(--g500);margin-top:3px;font-size:13.5px}
.ph-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
/* ─── GRID ─── */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 19px;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:13.5px;font-weight:500;cursor:pointer;border:none;transition:all .18s;white-space:nowrap;line-height:1}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--navy-dark);transform:translateY(-1px);box-shadow:var(--sm)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:#b5821d;transform:translateY(-1px);box-shadow:var(--sm)}
.btn-success{background:var(--green);color:#fff}
.btn-success:hover{background:#1e5540;transform:translateY(-1px)}
.btn-danger{background:var(--red-bg);color:var(--red)}
.btn-danger:hover{background:var(--red);color:#fff}
.btn-purple{background:var(--purple-bg);color:var(--purple)}
.btn-purple:hover{background:var(--purple);color:#fff}
.btn-outline{background:transparent;color:var(--navy);border:1.5px solid var(--g300)}
.btn-outline:hover{border-color:var(--navy);background:var(--navy-light)}
.btn-ghost{background:transparent;color:var(--g500);border:none}
.btn-ghost:hover{color:var(--navy);background:var(--g50)}
.btn-excel{background:#1D6F42;color:#fff}
.btn-excel:hover{background:#155232;transform:translateY(-1px);box-shadow:var(--sm)}
.btn-pdf{background:#D32F2F;color:#fff}
.btn-pdf:hover{background:#b71c1c;transform:translateY(-1px);box-shadow:var(--sm)}
.btn-sm{padding:6px 13px;font-size:12.5px;border-radius:7px}
.btn-lg{padding:13px 26px;font-size:15px;border-radius:10px}
/* ─── FORMS ─── */
.fg{margin-bottom:16px}
.fl{display:block;font-size:12.5px;font-weight:500;color:var(--g700);margin-bottom:5px}
.fc{width:100%;padding:10px 13px;border:1.5px solid var(--g100);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--g900);background:#fff;transition:border-color .2s,box-shadow .2s;outline:none}
.fc:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(27,58,107,.08)}
.fc::placeholder{color:var(--g300)}
select.fc{cursor:pointer}
.fr{display:grid;gap:14px}
.fr.c2{grid-template-columns:1fr 1fr}
.fr.c3{grid-template-columns:1fr 1fr 1fr}
.fr.c4{grid-template-columns:1fr 1fr 1fr 1fr}
/* ─── TABLE ─── */
.tw{overflow-x:auto;border-radius:8px;border:1px solid var(--g100)}
table{width:100%;border-collapse:collapse}
thead{background:var(--g50)}
th{padding:11px 14px;text-align:left;font-size:11.5px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--g500)}
td{padding:12px 14px;font-size:13.5px;color:var(--g700);border-top:1px solid var(--g100)}
tbody tr:hover{background:var(--g50)}
/* ─── STAT CARDS ─── */
.sc-label{font-size:11px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--g500)}
.sc-val{font-family:'Playfair Display',serif;font-size:26px;font-weight:700;color:var(--navy);margin:5px 0 3px}
.sc-sub{font-size:12.5px;color:var(--g500)}
/* ─── BADGES ─── */
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11.5px;font-weight:500}
.bg-green{background:var(--green-bg);color:var(--green)}
.bg-blue{background:var(--blue-bg);color:var(--blue)}
.bg-gold{background:var(--gold-bg);color:var(--gold)}
.bg-red{background:var(--red-bg);color:var(--red)}
.bg-navy{background:var(--navy-light);color:var(--navy)}
.bg-purple{background:var(--purple-bg);color:var(--purple)}
/* ─── ALERT BANNER ─── */
.alert-banner{display:flex;align-items:center;gap:11px;padding:13px 18px;border-radius:10px;margin-bottom:14px;font-size:13.5px}
.alert-banner.warn{background:#FFF8E1;border-left:4px solid #F59E0B;color:#92400E}
.alert-banner.danger{background:var(--red-bg);border-left:4px solid var(--red);color:var(--red)}
/* ─── MODAL ─── */
.mo{position:fixed;inset:0;background:rgba(15,25,45,.55);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}
.mc{background:#fff;border-radius:18px;padding:34px;max-width:460px;width:92%;box-shadow:var(--sl);animation:slideUp .25s ease}
.mc-icon{width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:26px}
.mc h3{font-family:'Playfair Display',serif;font-size:19px;text-align:center;color:var(--navy);margin-bottom:8px}
.mc p{text-align:center;color:var(--g500);font-size:13.5px;line-height:1.65;margin-bottom:22px}
.mc-btns{display:flex;gap:11px;justify-content:center}
.mc-detail{background:var(--g50);border-radius:10px;padding:14px 18px;margin-bottom:18px;font-size:13.5px;line-height:1.9;color:var(--g700)}
.mc-lg{max-width:720px;width:96%;padding:28px}
/* ─── TOAST ─── */
#toast-box{position:fixed;bottom:22px;right:22px;z-index:2000;display:flex;flex-direction:column;gap:9px}
.toast{display:flex;align-items:center;gap:11px;padding:13px 18px;border-radius:10px;min-width:270px;max-width:400px;box-shadow:var(--sl);animation:slideInR .3s ease;font-size:13.5px;font-weight:500}
/* ─── HOME ─── */
.hero{text-align:center;padding:32px 0 24px}
.hero p{font-size:15px;color:var(--g500)}
.mod-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;max-width:740px;margin:26px auto 34px}
.mod-card::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;border-radius:16px 16px 0 0}
.mod-card.v::before{background:linear-gradient(90deg,var(--navy),#2A5FAA)}
.mod-card.c::before{background:linear-gradient(90deg,var(--gold),#E8B848)}
.mod-card.i::before{background:linear-gradient(90deg,var(--purple),#9B5EDE)}
.mod-icon{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:23px}
.mod-card.v .mod-icon{background:var(--navy-light)}
.mod-card.c .mod-icon{background:var(--gold-bg)}
.mod-card.i .mod-icon{background:var(--purple-bg)}
.mod-card h3{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;margin-bottom:6px}
.mod-card.v h3{color:var(--navy)}
.mod-card.c h3{color:var(--gold)}
.mod-card.i h3{color:var(--purple)}
.mod-card p{font-size:12px;color:var(--g500);line-height:1.55;margin-bottom:10px}
.mod-tags{display:flex;flex-wrap:wrap;gap:5px;justify-content:center}
.mod-tag{padding:3px 9px;border-radius:20px;font-size:11px;font-weight:500}
.v .mod-tag{background:var(--navy-light);color:var(--navy)}
.c .mod-tag{background:var(--gold-bg);color:var(--gold)}
.i .mod-tag{background:var(--purple-bg);color:var(--purple)}
/* ─── FILTER BAR ─── */
.fb{background:#fff;border-radius:10px;padding:16px 18px;margin-bottom:18px;box-shadow:var(--sh);border:1px solid var(--g100)}
.fb-row{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}
.fb-g{flex:1;min-width:130px}
.fb-l{font-size:11.5px;font-weight:500;color:var(--g500);margin-bottom:4px}
/* ─── SALE CARDS ─── */
.sc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:14px}
.sv{background:#fff;border-radius:12px;border:1px solid var(--g100);overflow:hidden;transition:box-shadow .2s}
.sv:hover{box-shadow:var(--sm)}
.sv-head{padding:13px 16px;display:flex;justify-content:space-between;align-items:center}
.sv-head.v{background:linear-gradient(135deg,#1B3A6B 0%,#2A5FAA 100%);color:#fff}
.sv-head.c{background:linear-gradient(135deg,#C8962E 0%,#E8B848 100%);color:#fff}
.sv-head h4{font-size:13.5px;font-weight:600}
.sv-head span{font-size:11.5px;opacity:.8}
.sv-body{padding:14px 16px}
.sv-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:13px;color:var(--g700)}
.sv-row:not(:last-child){border-bottom:1px solid var(--g50)}
.sv-row b{color:var(--g900)}
.sv-foot{padding:11px 16px;border-top:1px solid var(--g100);background:var(--g50);display:flex;justify-content:space-between;align-items:center}
/* ─── INVOICE ITEMS TABLE ─── */
.inv-table{width:100%;border-collapse:collapse}
.inv-table th{background:var(--navy);color:rgba(255,255,255,.85);padding:9px 11px;font-size:11.5px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}
.inv-table td{padding:7px 8px;border-top:1px solid var(--g100);vertical-align:middle}
.inv-table .fc{padding:7px 10px;font-size:13px}
.totals-box{background:var(--g50);border-radius:8px;padding:14px 18px}
.tr-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:14px;color:var(--g700)}
.tr-grand{border-top:2px solid var(--navy);margin-top:7px;padding-top:11px;font-size:17px;font-weight:700;color:var(--navy);font-family:'Playfair Display',serif}
/* ─── KARDEX ─── */
.kdx-head{background:linear-gradient(135deg,var(--purple) 0%,#9B5EDE 100%);color:#fff;border-radius:10px;padding:16px 20px;margin-bottom:14px;display:flex;justify-content:space-between;align-items:center}
.kdx-head h4{font-family:'Playfair Display',serif;font-size:17px}
.kdx-head span{font-size:12.5px;opacity:.85}
.kdx-in{color:var(--green);font-weight:600}
.kdx-out{color:var(--red);font-weight:600}
.kdx-bal{color:var(--navy);font-weight:700}
/* ─── EMPTY ─── */
.empty{text-align:center;padding:52px 20px;color:var(--g500)}
.empty .e-icon{font-size:44px;margin-bottom:12px;opacity:.3}
.empty h4{font-size:15px;margin-bottom:6px;color:var(--g700)}
.empty p{font-size:13px}
/* ─── ANALYSIS BARS ─── */
.bar-wrap{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.bar-label{min-width:130px;font-size:13px;color:var(--g700)}
.bar-track{flex:1;background:var(--g100);border-radius:4px;height:10px;overflow:hidden}
.bar-fill{height:100%;border-radius:4px;transition:width .6s ease}
.bar-val{min-width:70px;font-size:13px;font-weight:500;text-align:right;color:var(--g700)}
/* ─── UTILS ─── */
.tr{text-align:right}.tc{text-align:center}.bold{font-weight:600}.serif{font-family:'Playfair Display',serif}
.navy{color:var(--navy)}.gold{color:var(--gold)}.green{color:var(--green)}.red{color:var(--red)}
.mt3{margin-top:12px}.mt4{margin-top:16px}.mt5{margin-top:20px}.mt6{margin-top:24px}
.mb4{margin-bottom:16px}.mb3{margin-bottom:12px}
.flex{display:flex}.ac{align-items:center}.jb{justify-content:space-between}
.gap2{gap:8px}.gap3{gap:12px}
.divider{height:1px;background:var(--g100);margin:20px 0}
/* ─── ANIM ─── */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(18px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes slideInR{from{transform:translateX(105%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes rowFlashGreen{0%{background:#d4f0e3}100%{background:transparent}}
@keyframes rowFlashRed{0%{background:#fde8e8}100%{background:transparent}}
@keyframes rowFlashPurple{0%{background:#f0eaf8}100%{background:transparent}}
@keyframes barGrow{from{width:0}to{}}
@keyframes numberTick{0%{opacity:0;transform:translateY(6px)}100%{opacity:1;transform:translateY(0)}}
.row-in{animation:rowFlashGreen .9s ease-out}
.row-out{animation:rowFlashRed .9s ease-out}
.row-kdx{animation:rowFlashPurple .7s ease-out}
.bar-fill{height:100%;border-radius:4px;animation:barGrow .7s cubic-bezier(.4,0,.2,1) both}
.num-tick{animation:numberTick .4s ease-out both}
.stock-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:5px;animation:pulseDot 2s ease-in-out infinite}
.ve{animation:fadeIn .22s ease}
/* ─── SCROLLBAR ─── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--g300);border-radius:3px}

/* Auth Gate */
#auth-shell{
  min-height:100vh;
  position:relative;
  display:grid;
  place-items:center;
  padding:34px;
  overflow:hidden;
  background:
    radial-gradient(circle at 18% 22%,rgba(255,216,124,.18) 0%,transparent 28%),
    radial-gradient(circle at 83% 16%,rgba(76,138,214,.18) 0%,transparent 24%),
    radial-gradient(circle at 50% 100%,rgba(27,58,107,.12) 0%,transparent 34%),
    linear-gradient(180deg,#FBF6EA 0%,#F5EFE1 46%,#EFE7D8 100%);
}
#auth-shell::before,
#auth-shell::after{
  content:"";
  position:absolute;
  pointer-events:none;
  opacity:.7;
}
#auth-shell::before{
  top:-12%;
  right:-10%;
  width:42vw;
  height:42vw;
  min-width:420px;
  min-height:420px;
  border-radius:47% 53% 60% 40%;
  background:radial-gradient(circle,rgba(255,236,184,.65) 0%,rgba(255,236,184,.18) 44%,transparent 72%);
  animation:authFloatBlob 16s ease-in-out infinite;
}
#auth-shell::after{
  bottom:-18%;
  left:-8%;
  width:38vw;
  height:28vw;
  min-width:360px;
  min-height:260px;
  border-radius:55% 45% 50% 50%;
  background:radial-gradient(circle,rgba(39,107,82,.08) 0%,rgba(39,107,82,.03) 35%,transparent 72%);
  animation:authFloatBlob 20s ease-in-out infinite reverse;
}
.auth-veil{
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(115deg,rgba(255,255,255,.28) 0%,rgba(255,255,255,0) 22%,rgba(255,255,255,.18) 50%,rgba(255,255,255,0) 74%),
    radial-gradient(circle at 20% 80%,rgba(255,255,255,.35) 0%,transparent 22%);
  mix-blend-mode:screen;
}
.auth-lash{
  position:absolute;
  width:38vw;
  max-width:520px;
  height:160px;
  border:2px solid rgba(27,58,107,.12);
  border-color:rgba(27,58,107,.16) transparent transparent transparent;
  border-radius:55% 45% 0 0;
  transform:rotate(-10deg);
  opacity:.6;
  pointer-events:none;
}
.auth-lash--one{
  top:9%;
  left:-6%;
  animation:authWhip 13s ease-in-out infinite;
}
.auth-lash--two{
  right:-9%;
  bottom:10%;
  transform:rotate(168deg);
  border-color:rgba(200,150,46,.22) transparent transparent transparent;
  animation:authWhip 15s ease-in-out infinite reverse;
}
.auth-float-pill{
  position:absolute;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 16px;
  border:none;
  border-radius:999px;
  background:rgba(255,255,255,.52);
  color:var(--navy);
  font-family:'DM Sans',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:.2px;
  box-shadow:0 22px 48px rgba(17,35,63,.10),inset 0 1px 0 rgba(255,255,255,.65);
  backdrop-filter:blur(14px);
  pointer-events:none;
  animation:authFloatChip 10s ease-in-out infinite;
}
.auth-float-pill svg{width:16px;height:16px;stroke:currentColor;opacity:.82}
.auth-float-pill--one{top:12%;right:10%;animation-delay:0s}
.auth-float-pill--two{left:7%;bottom:16%;animation-delay:1.4s}
.auth-float-pill--three{right:14%;bottom:28%;animation-delay:2.6s}
.auth-card{
  position:relative;
  width:min(100%,1080px);
  background:rgba(255,250,243,.76);
  backdrop-filter:blur(18px);
  border:1px solid rgba(27,58,107,.10);
  border-radius:30px;
  box-shadow:0 36px 90px rgba(17,35,63,.16),inset 0 1px 0 rgba(255,255,255,.58);
  padding:30px;
  overflow:hidden;
}
.auth-card{
  width:min(100%,1080px);
}
.auth-card::before{
  content:"";
  position:absolute;
  inset:18px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.44);
  pointer-events:none;
}
.auth-progress{
  position:relative;
  height:18px;
  margin-bottom:22px;
  overflow:visible;
}
.auth-progress-track,
.auth-progress-bar{
  position:absolute;
  left:0;
  top:6px;
  height:6px;
  border-radius:999px;
}
.auth-progress-track{
  width:100%;
  background:linear-gradient(90deg,rgba(27,58,107,.08),rgba(27,58,107,.14));
}
.auth-progress-bar{
  width:0;
  background:linear-gradient(90deg,#234C88 0%,#2F74C0 38%,#D7A643 72%,#F0D47C 100%);
  box-shadow:0 0 18px rgba(47,116,192,.30);
}
.auth-progress-spark,
.auth-progress-burst{
  position:absolute;
  top:0;
  left:0;
  pointer-events:none;
  opacity:0;
}
.auth-progress-spark{
  width:16px;
  height:16px;
  border-radius:50%;
  background:radial-gradient(circle,#FFF7CF 0%,#F0C96A 42%,rgba(240,201,106,0) 72%);
}
.auth-progress-burst{
  width:30px;
  height:30px;
  border-radius:50%;
  background:
    radial-gradient(circle,#FFF9D9 0%,rgba(255,249,217,.44) 36%,transparent 70%),
    conic-gradient(from 0deg,#F4C86B 0deg 42deg,transparent 42deg 84deg,#76AEFF 84deg 128deg,transparent 128deg 168deg,#F4C86B 168deg 210deg,transparent 210deg 360deg);
  mix-blend-mode:screen;
}
.auth-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(360px,.88fr);
  gap:30px;
  align-items:stretch;
  opacity:0;
  transform:translateY(24px);
}
.auth-scene{
  position:relative;
  min-height:520px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:14px 6px 8px;
}
.auth-brand{margin-bottom:20px}
.auth-brand-copy{display:flex;flex-direction:column}
.auth-kicker{
  font-size:11px;
  letter-spacing:2.2px;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:700;
  margin-bottom:6px;
}
.auth-brand h1{
  font-family:"Playfair Display",serif;
  font-size:44px;
  color:var(--navy);
  margin-bottom:2px;
  letter-spacing:-.6px;
}
.auth-brand p{
  color:var(--g500);
  font-size:15px;
  line-height:1.6;
  max-width:520px;
}
.auth-stage-art{
  position:relative;
  min-height:340px;
  border-radius:28px;
  overflow:hidden;
  background:
    radial-gradient(circle at 24% 22%,rgba(255,246,211,.95) 0%,rgba(255,246,211,.55) 19%,transparent 44%),
    radial-gradient(circle at 78% 34%,rgba(121,175,255,.18) 0%,transparent 26%),
    linear-gradient(180deg,rgba(255,255,255,.36) 0%,rgba(255,255,255,.06) 100%);
  border:1px solid rgba(27,58,107,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.58);
}
.auth-stage-glow{
  position:absolute;
  top:26px;
  left:42px;
  width:150px;
  height:150px;
  border-radius:50%;
  background:radial-gradient(circle,#FFF3C9 0%,rgba(255,243,201,.22) 44%,transparent 74%);
  animation:authGlowPulse 7s ease-in-out infinite;
}
.auth-stage-arch{
  position:absolute;
  inset:auto 58px 34px auto;
  width:176px;
  height:230px;
  border:10px solid rgba(27,58,107,.9);
  border-bottom-width:0;
  border-radius:110px 110px 0 0;
  opacity:.85;
}
.auth-stage-shadow{
  position:absolute;
  right:60px;
  bottom:22px;
  width:188px;
  height:34px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(27,58,107,.18) 0%,rgba(27,58,107,.05) 48%,transparent 74%);
  transform:skewX(-18deg);
}
.auth-ledger{
  position:absolute;
  left:58px;
  right:138px;
  bottom:42px;
  padding:22px 24px;
  border-radius:26px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(27,58,107,.08);
  box-shadow:0 20px 38px rgba(17,35,63,.09);
  backdrop-filter:blur(14px);
}
.auth-ledger-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
.auth-ledger-chip{
  display:inline-flex;
  align-items:center;
  padding:7px 12px;
  border-radius:999px;
  background:rgba(27,58,107,.08);
  color:var(--navy);
  font-size:11px;
  font-weight:700;
  letter-spacing:.9px;
  text-transform:uppercase;
}
.auth-ledger-kpi{
  display:inline-flex;
  align-items:center;
  padding:6px 11px;
  border-radius:999px;
  background:rgba(39,107,82,.10);
  color:#245D48;
  font-size:11px;
  font-weight:700;
  letter-spacing:.4px;
}
.auth-ledger-copy{
  display:flex;
  flex-direction:column;
  gap:3px;
  margin-top:14px;
}
.auth-ledger-copy strong{
  font-size:14px;
  color:var(--navy);
  letter-spacing:-.2px;
}
.auth-ledger-copy span{
  font-size:12.5px;
  line-height:1.45;
  color:rgba(27,58,107,.66);
}
.auth-ledger-chart{
  position:relative;
  height:78px;
  margin-top:14px;
  border-radius:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.52) 0%,rgba(255,255,255,.18) 100%);
  border:1px solid rgba(27,58,107,.07);
  overflow:hidden;
}
.auth-ledger-grid{
  position:absolute;
  left:14px;
  right:14px;
  height:1px;
  background:linear-gradient(90deg,rgba(27,58,107,.08),rgba(27,58,107,.02));
}
.auth-ledger-grid--one{top:24px}
.auth-ledger-grid--two{top:50px}
.auth-ledger-plot{
  position:absolute;
  inset:12px 12px 8px 12px;
  width:calc(100% - 24px);
  height:calc(100% - 20px);
}
.auth-ledger-plot-base{
  fill:none;
  stroke-linecap:round;
  stroke-linejoin:round;
  stroke:#3F79BE;
  stroke-width:4;
  filter:drop-shadow(0 4px 10px rgba(63,121,190,.16));
}
.auth-ledger-dot{
  position:absolute;
  width:9px;
  height:9px;
  border-radius:50%;
  box-shadow:0 0 0 4px rgba(255,255,255,.62),0 0 14px rgba(92,151,218,.18);
}
.auth-ledger-dot--one{
  top:24px;
  left:66%;
  background:#3F79BE;
}
.auth-ledger-caption{
  margin-top:12px;
  font-size:12.5px;
  line-height:1.45;
  color:rgba(27,58,107,.66);
}
.auth-stage-lashes{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
}
.auth-stage-lashes path{
  fill:none;
  stroke:rgba(27,58,107,.22);
  stroke-width:4;
  stroke-linecap:round;
  stroke-linejoin:round;
  filter:drop-shadow(0 2px 10px rgba(27,58,107,.05));
}
.auth-stage-orb{
  position:absolute;
  border-radius:50%;
  mix-blend-mode:multiply;
  animation:authFloatOrb 10s ease-in-out infinite;
}
.auth-stage-orb--one{
  top:52px;
  right:124px;
  width:68px;
  height:68px;
  background:radial-gradient(circle,rgba(244,200,107,.45) 0%,rgba(244,200,107,.06) 72%,transparent 76%);
}
.auth-stage-orb--two{
  bottom:138px;
  left:188px;
  width:46px;
  height:46px;
  background:radial-gradient(circle,rgba(118,174,255,.42) 0%,rgba(118,174,255,.08) 72%,transparent 76%);
  animation-delay:1.4s;
}
.auth-panel{
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:24px;
  border-radius:26px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(27,58,107,.08);
  box-shadow:0 22px 52px rgba(17,35,63,.08),inset 0 1px 0 rgba(255,255,255,.7);
}
.auth-panel-top{margin-bottom:20px}
.auth-panel-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 12px;
  border-radius:999px;
  background:rgba(27,58,107,.06);
  color:var(--navy);
  font-size:11px;
  font-weight:700;
  letter-spacing:.9px;
  text-transform:uppercase;
  margin-bottom:12px;
}
.auth-panel-chip-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:linear-gradient(135deg,#F0C96A,#2E8E9A);
  box-shadow:0 0 12px rgba(240,201,106,.6);
}
.auth-panel h2{
  font-family:"Playfair Display",serif;
  font-size:34px;
  color:var(--navy);
  letter-spacing:-.4px;
  margin-bottom:6px;
}
.auth-panel p{
  color:var(--g500);
  font-size:14px;
  line-height:1.55;
}
.auth-panel-top > p:not(.auth-panel-copy){display:none}
.auth-panel-copy{
  color:var(--g500);
  font-size:14px;
  line-height:1.6;
  max-width:420px;
}
.auth-field{margin-bottom:16px}
.auth-input-shell{
  position:relative;
  display:flex;
  align-items:center;
}
.auth-input-icon{
  position:absolute;
  left:15px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:18px;
  height:18px;
  color:rgba(27,58,107,.58);
  pointer-events:none;
}
.auth-input-icon svg{width:18px;height:18px;stroke:currentColor}
.auth-input{
  padding-left:48px;
  border-radius:14px;
  background:rgba(255,255,255,.76);
  border-color:rgba(27,58,107,.10);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.62);
}
.auth-input:focus{
  border-color:rgba(39,107,82,.34);
  box-shadow:0 0 0 3px rgba(39,107,82,.10),inset 0 1px 0 rgba(255,255,255,.76);
}
.auth-submit{
  position:relative;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px 18px 14px 20px;
  border-radius:18px;
  min-height:64px;
  box-shadow:0 18px 30px rgba(27,58,107,.22);
  isolation:isolate;
  transition:transform .24s ease,box-shadow .24s ease,filter .24s ease;
}
.auth-submit::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(115deg,transparent 0%,rgba(255,255,255,.36) 18%,transparent 38%);
  transform:translateX(-130%);
}
.auth-submit::after{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:17px;
  background:radial-gradient(circle at 82% 50%,rgba(255,255,255,.18) 0%,rgba(255,255,255,0) 36%);
  opacity:.7;
  z-index:0;
}
.auth-submit:hover{
  transform:translateY(-1px);
  box-shadow:0 22px 34px rgba(27,58,107,.26);
}
.auth-submit:hover::before{animation:authButtonSweep 1.1s ease}
.auth-submit-copy{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  gap:2px;
  min-height:34px;
  text-align:left;
}
.auth-submit-title{
  font-size:15px;
  font-weight:700;
  letter-spacing:.1px;
  transition:transform .22s ease;
}
.auth-submit-caption{
  font-size:11px;
  line-height:1.15;
  opacity:.78;
  transition:opacity .22s ease,transform .22s ease;
}
.auth-submit-caption--loading{
  position:absolute;
  left:0;
  bottom:0;
  opacity:0;
  transform:translateY(8px);
  white-space:nowrap;
}
.auth-submit-visual{
  position:relative;
  z-index:1;
  width:92px;
  height:30px;
  flex-shrink:0;
}
.auth-submit-orbit{
  position:absolute;
  right:6px;
  top:4px;
  width:60px;
  height:22px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.34);
  background:linear-gradient(90deg,rgba(255,255,255,.08),rgba(255,255,255,.02));
  transition:opacity .22s ease,border-color .22s ease,box-shadow .22s ease;
}
.auth-submit-tail{
  position:absolute;
  right:40px;
  top:11px;
  width:24px;
  height:7px;
  border-radius:999px;
  background:linear-gradient(90deg,rgba(255,249,217,0),rgba(255,249,217,.84));
  filter:blur(1.6px);
  opacity:0;
}
.auth-submit-asteroid{
  position:absolute;
  right:40px;
  top:8px;
  width:14px;
  height:14px;
  border-radius:48% 52% 46% 54%;
  background:
    radial-gradient(circle at 34% 32%,#FFF4CF 0%,#F4D17C 34%,transparent 35%),
    radial-gradient(circle at 72% 62%,rgba(91,49,12,.22) 0%,rgba(91,49,12,0) 36%),
    linear-gradient(145deg,#F4CE74 0%,#DA9A3A 52%,#B56B28 100%);
  box-shadow:0 0 18px rgba(255,216,126,.48),0 6px 14px rgba(17,35,63,.16);
  transform:translate3d(0,0,0);
}
.auth-submit-spark{
  position:absolute;
  width:8px;
  height:8px;
  border-radius:50%;
  opacity:0;
  background:radial-gradient(circle,#FFFCE7 0%,#F3D483 46%,rgba(243,212,131,0) 74%);
  filter:blur(.2px);
}
.auth-submit-spark--one{right:44px;top:3px}
.auth-submit-spark--two{right:28px;top:19px}
.auth-submit-arrow{
  position:absolute;
  right:0;
  top:6px;
  width:18px;
  height:18px;
  stroke:currentColor;
  transition:opacity .22s ease,transform .22s ease;
}
.auth-submit:hover .auth-submit-asteroid{
  animation:authAsteroidIdle 2.2s ease-in-out infinite;
}
.auth-submit:hover .auth-submit-orbit{
  box-shadow:0 0 0 1px rgba(255,255,255,.06),0 0 16px rgba(255,255,255,.14) inset;
}
.auth-note{
  display:flex;
  align-items:center;
  gap:10px;
  margin-top:14px;
  color:var(--g500);
  font-size:0;
}
.auth-note::after{
  content:"Revisamos tu acceso y te llevamos directo a tu espacio correcto.";
  font-size:12.8px;
  line-height:1.45;
}
.auth-note-bullet{
  width:10px;
  height:10px;
  border-radius:50%;
  background:linear-gradient(135deg,#F0C96A,#2E8E9A);
  box-shadow:0 0 10px rgba(240,201,106,.38);
  flex-shrink:0;
}
.auth-form .btn{width:100%}
.auth-error{
  margin-top:14px;
  padding:12px 14px;
  border-radius:12px;
  background:rgba(252,234,234,.95);
  color:var(--red);
  font-size:13px;
  border:1px solid rgba(184,50,50,.12);
  box-shadow:0 10px 20px rgba(184,50,50,.06);
}
.auth-product-signature{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  margin-top:20px;
  padding:16px 18px 0;
  border-top:1px solid rgba(27,58,107,.08);
  text-align:left;
}
.auth-product-mark{
  width:48px;
  height:48px;
  display:grid;
  place-items:center;
  flex-shrink:0;
  border-radius:50%;
  background:
    radial-gradient(circle at 28% 24%,rgba(255,255,255,.98) 0%,rgba(255,255,255,.78) 26%,rgba(255,255,255,.08) 62%),
    linear-gradient(145deg,rgba(255,255,255,.96),rgba(241,247,243,.9));
  border:1px solid rgba(27,58,107,.09);
  box-shadow:0 14px 24px rgba(17,35,63,.09), inset 0 1px 0 rgba(255,255,255,.94);
}
.auth-product-mark img{
  width:28px;
  height:28px;
  display:block;
  object-fit:contain;
  object-position:center;
  filter:drop-shadow(0 4px 8px rgba(17,35,63,.08));
}
.auth-product-copy{
  display:flex;
  flex-direction:column;
  gap:3px;
  max-width:260px;
}
.auth-product-copy strong{
  color:var(--navy);
  font-size:13.5px;
  line-height:1.25;
  letter-spacing:-.15px;
}
.auth-product-copy span{
  color:var(--g500);
  font-size:12.4px;
  line-height:1.4;
}
.auth-product-link{
  margin-top:2px;
  color:#1f4a86;
  font-size:11.6px;
  line-height:1.2;
  letter-spacing:.18px;
  text-decoration:none;
  font-weight:700;
  opacity:.92;
  transition:opacity .18s ease,color .18s ease;
}
.auth-product-link:hover{
  color:#173966;
  opacity:1;
  text-decoration:underline;
}
#auth-shell.auth-shell--booting .auth-progress-bar{animation:authBootBar 1.35s cubic-bezier(.18,.78,.22,1) forwards}
#auth-shell.auth-shell--booting .auth-progress-spark{animation:authBootSpark 1.35s cubic-bezier(.18,.78,.22,1) forwards}
#auth-shell.auth-shell--booting .auth-progress-burst{animation:authBootBurst 1.35s cubic-bezier(.18,.78,.22,1) forwards}
#auth-shell.auth-shell--ready .auth-grid{animation:authGridReveal .7s cubic-bezier(.18,.78,.22,1) forwards}
#auth-shell.auth-shell--submitting .auth-submit{
  filter:saturate(1.06) brightness(1.01);
  transform:translateY(1px) scale(.995);
  box-shadow:0 22px 38px rgba(27,58,107,.30);
}
#auth-shell.auth-shell--submitting .auth-submit::before{animation:authButtonSweep 1.08s linear infinite}
#auth-shell.auth-shell--submitting .auth-submit::after{animation:authSubmitGlow 1.2s ease-in-out infinite}
#auth-shell.auth-shell--submitting .auth-submit-title{transform:translateY(-1px)}
#auth-shell.auth-shell--submitting .auth-submit-caption--idle{
  opacity:0;
  transform:translateY(-8px);
}
#auth-shell.auth-shell--submitting .auth-submit-caption--loading{
  opacity:1;
  transform:translateY(0);
}
#auth-shell.auth-shell--submitting .auth-submit-arrow{
  opacity:.18;
  transform:translateX(8px) scale(.82);
}
#auth-shell.auth-shell--submitting .auth-submit-orbit{
  opacity:.96;
  border-color:rgba(255,246,211,.62);
  box-shadow:0 0 0 1px rgba(255,255,255,.08),0 0 18px rgba(255,244,207,.18) inset;
  animation:authOrbitPulse 1.2s ease-in-out infinite;
}
#auth-shell.auth-shell--submitting .auth-submit-tail{
  opacity:1;
  animation:authAsteroidTail .98s linear infinite;
}
#auth-shell.auth-shell--submitting .auth-submit-asteroid{
  animation:authAsteroidRoll .98s cubic-bezier(.25,.8,.27,1) infinite;
}
#auth-shell.auth-shell--submitting .auth-submit-spark--one{
  animation:authDivineSpark .98s linear infinite;
}
#auth-shell.auth-shell--submitting .auth-submit-spark--two{
  animation:authDivineSpark .98s linear infinite .28s;
}
#app-shell[hidden],#auth-shell[hidden]{display:none!important}

@keyframes authFloatBlob{
  0%,100%{transform:translate3d(0,0,0) rotate(0deg)}
  50%{transform:translate3d(0,18px,0) rotate(6deg)}
}
@keyframes authWhip{
  0%,100%{transform:translate3d(0,0,0) rotate(-10deg)}
  50%{transform:translate3d(12px,-10px,0) rotate(-4deg)}
}
@keyframes authFloatChip{
  0%,100%{transform:translate3d(0,0,0)}
  50%{transform:translate3d(0,-10px,0)}
}
@keyframes authGlowPulse{
  0%,100%{transform:scale(1);opacity:.9}
  50%{transform:scale(1.08);opacity:1}
}
@keyframes authFloatOrb{
  0%,100%{transform:translate3d(0,0,0)}
  50%{transform:translate3d(0,-12px,0)}
}
@keyframes authBootBar{
  0%{width:0}
  78%{width:89%}
  100%{width:100%}
}
@keyframes authBootSpark{
  0%{left:0;opacity:0;transform:scale(.4)}
  12%{opacity:1}
  82%{opacity:1}
  100%{left:calc(100% - 16px);opacity:0;transform:scale(1.2)}
}
@keyframes authBootBurst{
  0%,78%{left:0;opacity:0;transform:scale(.1)}
  89%{left:calc(100% - 30px);opacity:.96;transform:scale(1)}
  100%{left:calc(100% - 30px);opacity:0;transform:scale(1.8)}
}
@keyframes authGridReveal{
  0%{opacity:0;transform:translateY(24px)}
  100%{opacity:1;transform:translateY(0)}
}
@keyframes authButtonSweep{
  0%{transform:translateX(-130%)}
  100%{transform:translateX(130%)}
}
@keyframes authAsteroidIdle{
  0%,100%{transform:translate3d(0,0,0) rotate(0deg)}
  50%{transform:translate3d(4px,-2px,0) rotate(18deg)}
}
@keyframes authOrbitPulse{
  0%,100%{transform:scale(1);opacity:.9}
  50%{transform:scale(1.04);opacity:1}
}
@keyframes authSubmitGlow{
  0%,100%{opacity:.55}
  50%{opacity:.92}
}
@keyframes authAsteroidRoll{
  0%{transform:translate3d(-22px,6px,0) rotate(0deg) scale(.88)}
  24%{transform:translate3d(-8px,-2px,0) rotate(96deg) scale(1)}
  56%{transform:translate3d(12px,0,0) rotate(216deg) scale(1.05)}
  82%{transform:translate3d(26px,5px,0) rotate(312deg) scale(.92)}
  100%{transform:translate3d(-22px,6px,0) rotate(360deg) scale(.88)}
}
@keyframes authAsteroidTail{
  0%{transform:translate3d(-16px,4px,0) scaleX(.35);opacity:0}
  30%{opacity:.92}
  60%{transform:translate3d(6px,-1px,0) scaleX(1)}
  100%{transform:translate3d(22px,5px,0) scaleX(.24);opacity:0}
}
@keyframes authDivineSpark{
  0%{opacity:0;transform:translate3d(-10px,2px,0) scale(.2)}
  18%{opacity:.94}
  100%{opacity:0;transform:translate3d(28px,-12px,0) scale(1.7)}
}

@media (max-width:980px){
  #auth-shell{padding:26px}
  .auth-float-pill{display:none}
  .auth-card{padding:22px}
  .auth-grid{grid-template-columns:1fr;gap:22px}
  .auth-scene{min-height:auto;padding:6px 0 0}
  .auth-brand h1{font-size:38px}
  .auth-stage-art{min-height:260px}
  .auth-ledger{left:28px;right:88px;bottom:26px}
}

@media (max-width:680px){
  #auth-shell{padding:18px}
  .auth-card{padding:16px;border-radius:24px}
  .auth-card::before{inset:10px;border-radius:18px}
  .auth-progress{margin-bottom:16px}
  .auth-brand-row{align-items:flex-start}
  .auth-brand h1{font-size:34px}
  .auth-brand p{font-size:14px}
  .auth-panel{padding:18px;border-radius:20px}
  .auth-panel h2{font-size:28px}
  .auth-stage-art{min-height:220px}
  .auth-ledger{left:18px;right:52px;padding:18px}
  .auth-ledger-chart{height:74px}
  .auth-ledger-copy span{font-size:12px}
  .auth-product-signature{
    margin-top:16px;
    padding:14px 12px 0;
    gap:12px;
  }
  .auth-product-mark{
    width:44px;
    height:44px;
  }
  .auth-product-mark img{
    width:25px;
    height:25px;
  }
  .auth-stage-arch{right:24px;bottom:24px;width:118px;height:156px;border-width:8px}
}

/* Brand Refresh */
:root{--sw:258px}

.auth-brand-row{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:16px;
  margin-bottom:12px;
}

.auth-brand-mark-shell{
  position:relative;
  width:92px;
  height:92px;
  flex-shrink:0;
  display:grid;
  place-items:center;
  border-radius:28px;
  background:linear-gradient(150deg,rgba(255,255,255,.62) 0%,rgba(255,255,255,.24) 100%);
  box-shadow:0 18px 34px rgba(27,58,107,.10),inset 0 1px 0 rgba(255,255,255,.84);
  transition:transform .42s cubic-bezier(.18,.78,.22,1),box-shadow .42s ease,background .42s ease;
}
.auth-brand-mark-shell::before{
  content:"";
  position:absolute;
  inset:7px;
  border-radius:22px;
  border:1px solid rgba(27,58,107,.10);
  background:linear-gradient(145deg,rgba(255,255,255,.24),rgba(255,255,255,0));
  transition:transform .42s cubic-bezier(.18,.78,.22,1),opacity .42s ease,border-color .42s ease;
}
.auth-brand-mark-chip{
  position:absolute;
  display:block;
  background:linear-gradient(155deg,rgba(240,201,106,.92),rgba(47,116,192,.72));
  border-radius:14px 12px 10px 16px;
  opacity:.65;
  box-shadow:0 8px 18px rgba(27,58,107,.12);
  transition:transform .42s cubic-bezier(.18,.78,.22,1),opacity .42s ease;
}
.auth-brand-mark-chip--one{
  top:8px;
  right:-4px;
  width:18px;
  height:18px;
  transform:rotate(14deg);
}
.auth-brand-mark-chip--two{
  left:-6px;
  bottom:10px;
  width:14px;
  height:14px;
  transform:rotate(-16deg);
}

.auth-brand-mark{
  width:84px;
  height:84px;
  flex-shrink:0;
  display:block;
  filter:drop-shadow(0 18px 32px rgba(27,58,107,.16));
  transition:transform .42s cubic-bezier(.18,.78,.22,1),filter .42s ease;
}
.auth-brand-mark-shell:hover{
  transform:translateY(-4px) rotate(-2.5deg);
  box-shadow:0 22px 38px rgba(27,58,107,.14),inset 0 1px 0 rgba(255,255,255,.9);
  background:linear-gradient(150deg,rgba(255,255,255,.72) 0%,rgba(248,240,226,.42) 100%);
}
.auth-brand-mark-shell:hover::before{
  transform:rotate(6deg) scale(1.02);
  opacity:.94;
  border-color:rgba(39,107,82,.20);
}
.auth-brand-mark-shell:hover .auth-brand-mark{
  transform:rotate(4deg) scale(1.05);
  filter:drop-shadow(0 22px 34px rgba(27,58,107,.18)) saturate(1.06);
}
.auth-brand-mark-shell:hover .auth-brand-mark-chip--one{
  transform:translate3d(4px,-3px,0) rotate(28deg);
  opacity:.88;
}
.auth-brand-mark-shell:hover .auth-brand-mark-chip--two{
  transform:translate3d(-4px,4px,0) rotate(-28deg);
  opacity:.88;
}

.sb-logo{
  padding:20px 18px 16px;
}

.sb-logo-row{
  display:flex;
  align-items:center;
  gap:12px;
}

.sb-logo-mark{
  width:44px;
  height:44px;
  flex-shrink:0;
  display:block;
  border-radius:14px;
  box-shadow:0 8px 22px rgba(0,0,0,.18);
}

.sb-logo-copy{
  min-width:0;
}

.sb-logo-copy h1{
  display:flex;
  align-items:center;
  gap:0;
  font-size:20px;
  line-height:1.05;
}

.sb-logo-copy p{
  margin-top:3px;
  font-size:10.5px;
  letter-spacing:.35px;
}

.sb-section{
  padding:9px 0 3px;
}

.sb-label{
  padding:0 18px 6px;
  font-size:9px;
  letter-spacing:2px;
}

.ni{
  margin:1px 6px;
  padding:8px 14px 8px 16px;
  gap:9px;
  font-size:12.8px;
  border-radius:10px;
}

.ni svg{
  width:14px;
  height:14px;
}

.sb-foot{
  padding:12px 14px;
}

.sb-user{
  padding:6px 9px;
  border-radius:11px;
}

.sb-user-name{
  font-size:11.2px;
}

.sb-user-meta{
  font-size:9.2px;
}
