:root{
  --bg:#06110c;
  --bg2:#10251c;
  --card:#0a1712;
  --line:#1f6b52;
  --line2:#2fb980;
  --text:#eefaf4;
  --muted:#8fbca7;
  --glow:0 0 0 1px rgba(47,185,128,.24),0 0 18px rgba(23,102,71,.18);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;min-height:100%;background:radial-gradient(circle at top,#12281f 0%, #08110d 45%, #030705 100%);font-family:Arial,Helvetica,sans-serif;color:var(--text)}
body{padding:18px}
.wrap{max-width:1280px;margin:0 auto}
.panel{position:relative;background:linear-gradient(180deg,rgba(3,8,18,.96),rgba(2,6,12,.98));border:1px solid rgba(47,185,128,.45);border-radius:24px;box-shadow:var(--glow);padding:20px}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.title{
  position:relative;
  display:inline-block;
  margin:0;
  font-size:clamp(34px,4vw,50px);
  font-weight:900;
  letter-spacing:1.6px;
  text-transform:uppercase;
  line-height:1;
}
.title-glow{
  color:#e7fff4;
  background:linear-gradient(180deg,#ffffff 0%, #e8fff3 24%, #9df0cb 54%, #33b67b 82%, #f4fff8 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  text-shadow:
    0 0 6px rgba(196,235,255,.42),
    0 0 16px rgba(106,188,255,.34),
    0 0 28px rgba(38,121,255,.18);
}
.title::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-10px;
  width:100%;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg,transparent 0%, rgba(170,255,223,.85) 16%, rgba(47,185,128,.92) 50%, rgba(170,255,223,.85) 84%, transparent 100%);
  box-shadow:0 0 18px rgba(47,185,128,.28);
  opacity:.95;
}
.sub{color:var(--muted);font-size:14px}
.grid{display:grid;grid-template-columns:1.1fr .9fr;gap:18px}
.card{background:linear-gradient(180deg,rgba(6,14,28,.95),rgba(3,8,18,.98));border:1px solid rgba(47,185,128,.38);border-radius:20px;padding:16px;box-shadow:var(--glow)}
.card h2{margin:0 0 6px;font-size:24px}
.card p{margin:0 0 14px;color:var(--muted)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
label{font-size:13px;font-weight:700;color:#ffffff}
input,textarea{width:100%;border-radius:14px;border:1px solid rgba(47,185,128,.55);background:#081510;color:#fff;padding:13px 14px;font-size:15px;outline:none;box-shadow:inset 0 0 0 1px rgba(47,185,128,.08)}
textarea{min-height:92px;resize:vertical}

.date-input-wrap{position:relative;width:100%;}
.date-input-wrap input[type="date"]{
  width:100%;
  padding-right:48px;
  color:#fff;
  color-scheme:dark;
}
.date-input-wrap .date-icon{
  position:absolute;
  right:16px;
  top:50%;
  transform:translateY(-50%);
  width:18px;
  height:18px;
  pointer-events:none;
  opacity:.98;
  background-repeat:no-repeat;
  background-position:center;
  background-size:18px 18px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='4' width='18' height='18' rx='2' ry='2'/><line x1='16' y1='2' x2='16' y2='6'/><line x1='8' y1='2' x2='8' y2='6'/><line x1='3' y1='10' x2='21' y2='10'/></svg>");
}
.date-input-wrap input[type="date"]::-webkit-calendar-picker-indicator{
  position:absolute;
  right:0;
  top:0;
  width:48px;
  height:100%;
  margin:0;
  opacity:0;
  cursor:pointer;
}
.date-input-wrap input[type="date"]::-webkit-datetime-edit,
.date-input-wrap input[type="date"]::-webkit-datetime-edit-text,
.date-input-wrap input[type="date"]::-webkit-datetime-edit-month-field,
.date-input-wrap input[type="date"]::-webkit-datetime-edit-day-field,
.date-input-wrap input[type="date"]::-webkit-datetime-edit-year-field{
  color:#fff;
}
.date-input-wrap input[type="date"]::-webkit-clear-button,
.date-input-wrap input[type="date"]::-webkit-inner-spin-button{
  display:none;
}
input:focus,textarea:focus{border-color:#31cc8e;box-shadow:0 0 0 3px rgba(49,204,142,.15), inset 0 0 0 1px rgba(47,185,128,.12)}
.actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:16px}
button{appearance:none;border:none;border-radius:16px;padding:15px 14px;font-size:16px;font-weight:800;cursor:pointer;transition:transform .14s ease,opacity .14s ease,box-shadow .14s ease}
button:active{transform:scale(.985)}
.btn-primary{background:linear-gradient(180deg,#23b574,#176647);color:#fff;box-shadow:0 10px 26px rgba(47,185,128,.28)}
.btn-dark{background:linear-gradient(180deg,#0a1611,#07100c);color:#fff;border:1px solid rgba(47,185,128,.34)}
.btn-wide{grid-column:1/-1}
.status{margin-top:14px;border-radius:14px;padding:12px 14px;background:rgba(23,102,71,.12);border:1px solid rgba(47,185,128,.35);color:#e4fff1;min-height:46px;display:flex;align-items:center;font-weight:700}
.inv-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.inv-count{color:var(--muted);font-size:13px;font-weight:700}
.inventory{display:flex;flex-direction:column;gap:10px}
.item{display:grid;grid-template-columns:1fr;gap:10px;align-items:start;padding:14px;border-radius:14px;background:#081510;border:1px solid rgba(47,185,128,.28)}
.item div{font-size:14px;word-break:break-word}.item-actions{display:flex;gap:8px;flex-wrap:wrap}.item-actions .small-btn{flex:1 1 120px}
.item .meta{color:var(--muted)}
.small-btn{padding:10px 12px;border-radius:12px;font-size:13px}
.btn-danger{background:linear-gradient(180deg,#ff4b4b,#a81818);color:#fff;box-shadow:0 10px 22px rgba(255,75,75,.18)}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.22)}
.undo-bar{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);display:none;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;background:linear-gradient(180deg,rgba(8,16,32,.98),rgba(4,9,18,.98));border:1px solid rgba(47,185,128,.45);box-shadow:var(--glow);z-index:99999;max-width:min(92vw,680px)}
.undo-bar.show{display:flex}
.undo-text{font-size:14px;color:#e4fff1;line-height:1.35}
.note{margin-top:14px;color:var(--muted);font-size:13px;line-height:1.45}
.products-select{display:grid;grid-template-columns:1fr 1fr;gap:10px 12px;margin-top:2px}
.product-option{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:14px;border:1px solid rgba(47,185,128,.38);background:#081510;color:#fff;font-size:14px;font-weight:700;cursor:pointer;box-shadow:inset 0 0 0 1px rgba(47,185,128,.06)}
.product-option input{width:18px;height:18px;accent-color:#31cc8e;cursor:pointer;flex:0 0 auto}
.products-fixed-note{margin-top:10px;border-radius:14px;padding:12px 14px;border:1px solid rgba(47,185,128,.32);background:rgba(23,102,71,.12);color:#e4fff1;font-size:13px;font-weight:700;line-height:1.35}
@media (max-width: 860px){
 body{padding:10px}
 .grid{grid-template-columns:1fr}
 .title{font-size:24px}
 .form-grid{grid-template-columns:1fr}
 .actions{grid-template-columns:1fr 1fr}
 .item{grid-template-columns:1fr;} .item-actions{justify-content:flex-start}
}

/* LOADER */
.loader{
  position:fixed;
  inset:0;
  background:
    radial-gradient(circle at 50% 20%, rgba(30,114,84,.18), transparent 34%),
    radial-gradient(circle at 50% 100%, rgba(6,22,15,.28), transparent 42%),
    linear-gradient(180deg, rgba(2,6,14,.98), rgba(1,4,10,.985));
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  z-index:9999;
  transition:opacity .42s ease, visibility .42s ease;
}
.loader.hidden{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
}
.loader-bg-lines{
  position:absolute;
  inset:0;
  opacity:.13;
  background:
    linear-gradient(90deg, transparent 0%, rgba(47,185,128,.15) 48%, transparent 50%, transparent 100%),
    repeating-linear-gradient(
      90deg,
      transparent 0 78px,
      rgba(72,190,140,.07) 78px 79px
    ),
    repeating-linear-gradient(
      180deg,
      transparent 0 78px,
      rgba(72,190,140,.055) 78px 79px
    );
  animation:loaderGridMove 7s linear infinite;
}
.loader-light-ray{
  position:absolute;
  width:340px;
  height:340px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(76,205,154,.22) 0%, rgba(76,205,154,.08) 36%, transparent 72%);
  filter:blur(12px);
  animation:loaderPulse 1.7s ease-in-out infinite;
}
.loader-core{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:14px;
  transform:translateY(8px);
}
.loader-ring-wrap{
  position:relative;
  width:108px;
  height:108px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.loader-ring{
  width:92px;
  height:92px;
  border-radius:50%;
  border:6px solid rgba(255,255,255,.08);
  border-top-color:#2d84ff;
  border-right-color:#56b0ff;
  box-shadow:
    0 0 0 1px rgba(54,191,138,.08),
    0 0 26px rgba(54,191,138,.18);
  animation:spin .9s linear infinite;
}
.loader-ring-glow{
  position:absolute;
  inset:0;
  border-radius:50%;
  background:radial-gradient(circle, rgba(54,191,138,.22) 0%, rgba(54,191,138,.08) 38%, transparent 68%);
  filter:blur(10px);
  animation:loaderPulse 1.5s ease-in-out infinite;
}
.loader-title{
  font-weight:900;
  font-size:clamp(26px, 4vw, 38px);
  letter-spacing:2.5px;
  color:#eef7ff;
  text-transform:uppercase;
  text-align:center;
  text-shadow:
    0 0 10px rgba(126,195,255,.40),
    0 0 24px rgba(47,185,128,.22);
  animation:loaderTextFloat 1.6s ease-in-out infinite;
}
.loader-sub{
  font-size:13px;
  letter-spacing:4px;
  color:#9fd2ff;
  text-transform:uppercase;
  opacity:.98;
  text-align:center;
}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes loaderPulse{
  0%,100%{transform:scale(.96);opacity:.85}
  50%{transform:scale(1.04);opacity:1}
}
@keyframes loaderTextFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-2px)}
}
@keyframes loaderGridMove{
  from{transform:translate3d(0,0,0)}
  to{transform:translate3d(18px,18px,0)}
}

/* ANIMACIONES SUAVES */
.panel{position:relative;transition:.2s ease;}
.panel:hover{box-shadow:0 0 30px rgba(47,185,128,.2);}
button{transition:.15s;}
button:hover{transform:translateY(-2px);}

/* FIX DEFINITIVO PARA IMPRESIÓN */
@media print{
  html,body{
    background:#fff !important;
    color:#000 !important;
    overflow:visible !important;
    height:auto !important;
    min-height:auto !important;
    margin:0 !important;
    padding:0 !important;
    -webkit-print-color-adjust:exact !important;
    print-color-adjust:exact !important;
  }
  .loader,
  .desktop-zoom-ui{
    display:none !important;
    opacity:0 !important;
    visibility:hidden !important;
  }
  .wrap,
  .panel,
  .card,
  .grid,
  .stage-wrap,
  .page-stage{
    overflow:visible !important;
    height:auto !important;
    min-height:auto !important;
    max-height:none !important;
    transform:none !important;
    filter:none !important;
  }
  body *{
    animation:none !important;
    transition:none !important;
  }
}

/* LOGIN */
body.login-locked > *:not(#loginScreen){
  visibility:hidden !important;
}
#loginScreen{
  position:fixed;
  inset:0;
  z-index:999999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:
    radial-gradient(circle at 20% 20%, rgba(30,93,255,.18), transparent 0 28%),
    radial-gradient(circle at 80% 15%, rgba(77,163,255,.12), transparent 0 24%),
    linear-gradient(180deg,#02060f 0%, #030814 48%, #01040b 100%);
  overflow:hidden;
}
#loginScreen::before{
  content:"";
  position:absolute;
  inset:-20%;
  background:
    repeating-linear-gradient(90deg, transparent 0 54px, rgba(110,170,255,.05) 54px 55px),
    repeating-linear-gradient(180deg, transparent 0 54px, rgba(110,170,255,.04) 54px 55px);
  opacity:.45;
  animation:loginGridMove 10s linear infinite;
}
#loginScreen::after{
  content:"";
  position:absolute;
  width:460px;
  height:460px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(47,185,128,.22) 0%, rgba(47,185,128,.06) 42%, transparent 72%);
  filter:blur(14px);
  animation:loginGlowPulse 3.4s ease-in-out infinite;
}
.login-shell{ position:relative; width:min(100%, 520px); display:flex; justify-content:center; z-index:2; }
.login-box{
  position:relative;
  width:100%;
  padding:30px 28px;
  min-height:520px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  border-radius:28px;
  border:1px solid rgba(63,136,255,.28);
  background:linear-gradient(180deg, rgba(5,11,22,.92), rgba(2,7,16,.96));
  box-shadow:0 18px 60px rgba(0,0,0,.42), 0 0 0 1px rgba(47,185,128,.09), 0 0 34px rgba(47,185,128,.12);
  overflow:hidden;
  backdrop-filter:blur(10px);
}
.login-box::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(84,205,154,.08), transparent 34%, transparent 66%, rgba(84,205,154,.06));
  pointer-events:none;
}
.login-mark{
  width:160px;
  height:160px;
  margin:8px auto 28px;
  border-radius:50%;
  display:grid;
  place-items:center;
  overflow:hidden;
  background:radial-gradient(circle at 35% 28%, rgba(60,200,145,.24), rgba(7,23,52,.92) 56%, rgba(3,10,24,.95) 100%);
  box-shadow: inset 0 0 0 1px rgba(92,169,255,.16), 0 0 0 18px rgba(31,82,180,.08), 0 0 55px rgba(43,132,255,.38);
  position:relative;
  animation:markPulse 3s ease-in-out infinite;
}
.login-mark img{
  width:125px;
  height:125px;
  object-fit:contain;
  display:block;
  transform:translateY(6px);
  filter:drop-shadow(0 0 24px rgba(90,170,255,.42));
  animation:logoFloat 3s ease-in-out infinite, logoGlow 2.5s ease-in-out infinite;
}
.login-box-top{ margin-bottom:18px; text-align:center; }
.login-box-top h3{
  margin:0 0 22px;
  color:#eef6ff;
  font-size:clamp(32px, 7vw, 44px);
  line-height:1.06;
  letter-spacing:3px;
  text-transform:uppercase;
}
.login-field{ display:flex; flex-direction:column; gap:8px; margin-bottom:14px; }
.login-field label{ color:#f5f9ff; font-size:13px; font-weight:800; letter-spacing:.25px; }
.login-input-wrap{ position:relative; }
.login-input-wrap span{ position:absolute; left:14px; top:50%; transform:translateY(-50%); color:#82b5ff; font-size:16px; pointer-events:none; }
.login-box input{
  width:100%;
  padding:15px 14px 15px 44px;
  border-radius:16px;
  border:1px solid rgba(63,136,255,.28);
  background:linear-gradient(180deg,#05101d,#030b17);
  color:#fff;
  outline:none;
  font-size:15px;
  box-shadow:inset 0 0 0 1px rgba(47,185,128,.05);
}
.login-box input::placeholder{ color:transparent; }
.login-box input:focus{ border-color:#3f8cff; box-shadow:0 0 0 3px rgba(63,140,255,.14), inset 0 0 0 1px rgba(63,140,255,.08); }
.login-submit{
  margin-top:8px; width:100%; padding:15px 16px; border:none; border-radius:16px; cursor:pointer;
  color:#fff; font-size:16px; font-weight:900; letter-spacing:.2px;
  background:linear-gradient(180deg,#26b879,#175a3f);
  box-shadow:0 14px 28px rgba(47,185,128,.24);
  transition:transform .16s ease, box-shadow .16s ease, filter .16s ease;
}
.login-submit:hover{ transform:translateY(-2px); filter:brightness(1.05); box-shadow:0 18px 34px rgba(47,185,128,.3); }
#loginError{ min-height:20px; margin-top:12px; color:#ff7f92; font-size:13px; font-weight:800; }
.login-help{ display:none; }
.login-mini-glow{ position:absolute; right:-28px; bottom:-28px; width:140px; height:140px; border-radius:50%; background:radial-gradient(circle, rgba(54,123,255,.22), transparent 66%); pointer-events:none; }
@keyframes loginGridMove{ from{transform:translate3d(0,0,0)} to{transform:translate3d(22px,22px,0)} }
@keyframes loginGlowPulse{ 0%,100%{transform:scale(.96);opacity:.85} 50%{transform:scale(1.05);opacity:1} }
@keyframes markPulse{ 0%,100%{transform:scale(.98)} 50%{transform:scale(1.03)} }
@keyframes logoFloat{ 0%,100%{ transform:translateY(6px) scale(1); } 50%{ transform:translateY(0) scale(1.04); } }
@keyframes logoGlow{ 0%,100%{ filter:drop-shadow(0 0 20px rgba(96,181,255,.5)); } 50%{ filter:drop-shadow(0 0 34px rgba(96,181,255,.9)); } }
@media (max-width: 900px){ .login-box{ min-height:auto; padding:24px 22px; } }
@media (max-width: 560px){ #loginScreen{ padding:14px; } .login-mark{ width:132px; height:132px; } .login-mark img{ width:104px; height:104px; } }

.logout-btn{
  position:absolute;
  top:12px;
  right:18px;
  padding:10px 16px;
  border-radius:14px;
  border:1px solid rgba(255,120,120,.34);
  background:linear-gradient(180deg,#4a0f16,#24070b);
  color:#fff4f4;
  font-size:13px;
  font-weight:900;
  letter-spacing:.2px;
  cursor:pointer;
  box-shadow:
    0 10px 24px rgba(0,0,0,.28),
    0 0 0 1px rgba(255,72,72,.10),
    0 0 22px rgba(255,58,58,.18);
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease, border-color .18s ease, background .18s ease;
}
.logout-btn:hover{
  transform:translateY(-2px);
  filter:brightness(1.08);
  border-color:rgba(255,166,166,.58);
  background:linear-gradient(180deg,#6a141d,#32090f);
  box-shadow:
    0 14px 32px rgba(0,0,0,.34),
    0 0 28px rgba(255,52,52,.26),
    0 0 12px rgba(255,104,104,.20);
}
.logout-btn:active{
  transform:translateY(0) scale(.985);
}
.logout-btn .logout-dot{
  display:inline-block;
  width:8px;
  height:8px;
  margin-right:8px;
  border-radius:50%;
  background:#ff5b66;
  box-shadow:0 0 14px rgba(255,91,102,.85);
  vertical-align:middle;
}



/* ENTRADA SUAVE DEL PANEL */
body.app-enter .topbar,
body.app-enter .card{
  opacity:0;
  transform:translateY(18px);
  filter:blur(4px);
}
body.app-enter .topbar{
  animation:appFadeUp .45s ease .05s forwards;
}
body.app-enter .grid > .card:nth-child(1){
  animation:appFadeUp .5s ease .12s forwards;
}
body.app-enter .grid > .card:nth-child(2){
  animation:appFadeUp .5s ease .20s forwards;
}
@keyframes appFadeUp{
  to{opacity:1;transform:none;filter:none}
}.inventory-toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between;margin-bottom:12px}
.inventory-search{flex:1 1 240px;display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:14px;border:1px solid rgba(47,185,128,.34);background:#081510;box-shadow:inset 0 0 0 1px rgba(47,185,128,.05)}
.inventory-search input{border:none !important;box-shadow:none !important;background:transparent !important;padding:0 !important;height:auto !important}
.inventory-search input:focus{box-shadow:none !important}
.inventory-search-icon{color:#8eb7ff;font-size:14px;line-height:1}
.inventory-pager{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.pager-btn{padding:10px 12px;border-radius:12px;font-size:13px;font-weight:800}
.pager-btn.is-active{background:linear-gradient(180deg,#23b574,#176647);color:#fff;box-shadow:0 10px 24px rgba(47,185,128,.22)}
.pager-info{color:var(--muted);font-size:12px;font-weight:700;padding:0 4px}
@media (max-width: 860px){
  .inventory-toolbar{align-items:stretch}
  .inventory-pager{justify-content:flex-start}
}


.panel-tools{display:flex;flex-wrap:wrap;gap:12px;align-items:stretch;margin:8px 0 16px}
.panel-title-box,.alerts-box{flex:1 1 320px;background:linear-gradient(180deg,rgba(6,14,28,.95),rgba(3,8,18,.98));border:1px solid rgba(47,185,128,.32);border-radius:18px;padding:14px 16px;box-shadow:var(--glow)}
.panel-title-box label,.alerts-box-title{display:block;font-size:13px;font-weight:800;color:#fff;margin:0 0 8px}
.panel-title-input{width:100%;border-radius:14px;border:1px solid rgba(47,185,128,.55);background:#081510;color:#fff;padding:13px 14px;font-size:15px;outline:none;box-shadow:inset 0 0 0 1px rgba(47,185,128,.08)}
.panel-title-input:focus{border-color:#31cc8e;box-shadow:0 0 0 3px rgba(49,204,142,.15), inset 0 0 0 1px rgba(47,185,128,.12)}
.panel-title-note,.alerts-box-note{margin-top:8px;color:var(--muted);font-size:12px;line-height:1.45}
.alerts-box-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.alert-pill{border-radius:14px;padding:12px 12px;background:#081510;border:1px solid rgba(47,185,128,.26);min-height:72px;display:flex;flex-direction:column;justify-content:center}
.alert-pill-label{font-size:12px;font-weight:800;color:#b9d1f4;line-height:1.2}
.alert-pill-value{font-size:24px;font-weight:900;color:#fff;line-height:1;margin-top:6px}
.alert-pill.is-red{border-color:rgba(255,83,83,.26);box-shadow:0 0 0 1px rgba(255,83,83,.05), 0 0 18px rgba(255,83,83,.08)}
.alert-pill.is-yellow{border-color:rgba(255,194,82,.24);box-shadow:0 0 0 1px rgba(255,194,82,.05), 0 0 18px rgba(255,194,82,.06)}
.alert-pill.is-blue{border-color:rgba(87,163,255,.28)}
@media (max-width: 860px){
  .alerts-box-grid{grid-template-columns:1fr}
}


/* LOGIN PROFESIONAL PREMIUM */
body.login-locked > *:not(#loginScreen){
  visibility:hidden !important;
}
#loginScreen{
  position:fixed;
  inset:0;
  z-index:999999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:
    radial-gradient(circle at 18% 20%, rgba(34,102,255,.16), transparent 0 24%),
    radial-gradient(circle at 82% 16%, rgba(0,194,255,.10), transparent 0 20%),
    linear-gradient(180deg,#02060f 0%, #030814 48%, #01040b 100%);
  overflow:hidden;
}
#loginScreen::before{
  content:"";
  position:absolute;
  inset:-12%;
  background:
    repeating-linear-gradient(90deg, transparent 0 66px, rgba(110,170,255,.035) 66px 67px),
    repeating-linear-gradient(180deg, transparent 0 66px, rgba(110,170,255,.03) 66px 67px);
  opacity:.24;
  animation:loginGridMove 16s linear infinite;
}
#loginScreen::after{
  content:"";
  position:absolute;
  width:360px;
  height:360px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(47,185,128,.16) 0%, rgba(47,185,128,.04) 42%, transparent 72%);
  filter:blur(10px);
  animation:loginGlowPulse 5s ease-in-out infinite;
}
.login-shell{
  position:relative;
  width:min(100%, 500px);
  display:flex;
  justify-content:center;
  z-index:2;
}
.login-box{
  position:relative;
  width:100%;
  padding:32px 28px 28px;
  min-height:520px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  border-radius:28px;
  border:1px solid rgba(63,136,255,.24);
  background:
    linear-gradient(180deg, rgba(5,11,22,.92), rgba(2,7,16,.97)),
    radial-gradient(circle at top center, rgba(63,136,255,.06), transparent 60%);
  box-shadow:
    0 18px 48px rgba(0,0,0,.38),
    0 0 0 1px rgba(47,185,128,.08),
    0 0 24px rgba(47,185,128,.10);
  overflow:hidden;
  backdrop-filter:blur(10px);
  animation:loginEnter .55s ease;
}
.login-box::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(84,205,154,.06), transparent 34%, transparent 66%, rgba(84,205,154,.05));
  pointer-events:none;
}
.login-mark{
  width:152px;
  height:152px;
  margin:8px auto 28px;
  border-radius:50%;
  display:grid;
  place-items:center;
  overflow:hidden;
  background:radial-gradient(circle at 35% 28%, rgba(60,200,145,.22), rgba(7,23,52,.92) 56%, rgba(3,10,24,.95) 100%);
  box-shadow:
    inset 0 0 0 1px rgba(92,169,255,.16),
    0 0 0 12px rgba(31,82,180,.06),
    0 0 28px rgba(43,132,255,.18);
  position:relative;
  animation:markPulse 4s ease-in-out infinite;
}
.login-mark img{
  width:118px;
  height:118px;
  object-fit:contain;
  display:block;
  transform:translateY(4px);
  filter:drop-shadow(0 0 16px rgba(90,170,255,.36));
  animation:logoFloat 4s ease-in-out infinite;
}
.login-box-top{
  margin-bottom:18px;
  text-align:center;
}
.login-box-top h3{
  margin:0 0 24px;
  color:#eef6ff;
  font-size:clamp(34px, 7vw, 46px);
  line-height:1.06;
  letter-spacing:3px;
  text-transform:uppercase;
  text-shadow:
    0 0 6px rgba(255,255,255,.55),
    0 0 18px rgba(104,180,255,.42),
    0 0 30px rgba(35,124,255,.18);
}
.login-field{ display:flex; flex-direction:column; gap:8px; margin-bottom:14px; }
.login-field label{
  color:#f5f9ff;
  font-size:13px;
  font-weight:800;
  letter-spacing:.35px;
}
.login-input-wrap{ position:relative; }
.login-input-wrap span{
  position:absolute;
  left:14px;
  top:50%;
  transform:translateY(-50%);
  color:#82b5ff;
  font-size:16px;
  pointer-events:none;
}
.login-box input{
  width:100%;
  padding:16px 14px 16px 46px;
  border-radius:16px;
  border:1px solid rgba(63,136,255,.28);
  background:linear-gradient(180deg,#05101d,#030b17);
  color:#fff;
  outline:none;
  font-size:16px;
  box-shadow:inset 0 0 0 1px rgba(47,185,128,.05);
  transition:border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.login-box input::placeholder{ color:transparent; }
.login-box input:focus{
  border-color:#63b1ff;
  box-shadow:
    0 0 0 3px rgba(63,140,255,.14),
    0 0 18px rgba(63,140,255,.10),
    inset 0 0 0 1px rgba(63,140,255,.08);
  transform:translateY(-1px);
}
.login-submit{
  position:relative;
  overflow:hidden;
  margin-top:10px;
  width:100%;
  padding:16px 16px;
  border:none;
  border-radius:16px;
  cursor:pointer;
  color:#fff;
  font-size:16px;
  font-weight:900;
  letter-spacing:1px;
  background:linear-gradient(180deg,#86f2c0 0%, #31c989 42%, #16734f 100%);
  box-shadow:
    0 18px 30px rgba(20,98,255,.22),
    inset 0 0 14px rgba(255,255,255,.14);
  transition:transform .16s ease, box-shadow .16s ease, filter .16s ease;
}
.login-submit::after{
  content:"";
  position:absolute;
  top:0;
  left:-120%;
  width:70%;
  height:100%;
  background:linear-gradient(120deg, transparent, rgba(255,255,255,.30), transparent);
  transform:skewX(-18deg);
  animation:shine 3.2s infinite;
}
.login-submit:hover{
  transform:translateY(-2px);
  filter:brightness(1.05);
  box-shadow:
    0 22px 34px rgba(20,98,255,.28),
    inset 0 0 14px rgba(255,255,255,.16);
}
#loginError{
  min-height:20px;
  margin-top:12px;
  color:#ff9aa8;
  font-size:13px;
  font-weight:800;
  text-align:center;
}
@keyframes loginGridMove{from{transform:translate3d(0,0,0)}to{transform:translate3d(18px,18px,0)}}
@keyframes loginGlowPulse{0%,100%{transform:scale(.98);opacity:.84}50%{transform:scale(1.02);opacity:1}}
@keyframes markPulse{0%,100%{transform:scale(.99)}50%{transform:scale(1.015)}}
@keyframes logoFloat{0%,100%{transform:translateY(4px)}50%{transform:translateY(-4px)}}
@keyframes loginEnter{from{opacity:0;transform:translateY(22px) scale(.98)}to{opacity:1;transform:none}}
@keyframes shine{0%{left:-120%}100%{left:130%}}
@media (max-width: 560px){
  #loginScreen{padding:14px}
  .login-box{padding:26px 22px 22px;min-height:auto}
  .login-mark{width:130px;height:130px}
  .login-mark img{width:100px;height:100px}
  .login-box-top h3{font-size:30px;letter-spacing:2px}
}



/* =========================================================
   REDISEÑO TOTAL DEL PANEL - SOLO VISUAL
   Mantiene IDs, clases y JavaScript originales.
   ========================================================= */

:root{
  --bg:#f3f6ef;
  --bg2:#e8efe6;
  --card:#ffffff;
  --line:#cfe0d5;
  --line2:#1fa66b;
  --text:#17231e;
  --muted:#5f746a;
  --glow:0 18px 48px rgba(26,55,42,.10);
}

html,body{
  background:
    radial-gradient(circle at 12% 4%, rgba(38,171,110,.14), transparent 28%),
    radial-gradient(circle at 88% 0%, rgba(200,168,93,.13), transparent 24%),
    linear-gradient(135deg,#f6f8f1 0%,#eef4ec 48%,#e5eee6 100%) !important;
  color:#17231e !important;
}

body{
  padding:0 !important;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif !important;
}

/* Login rediseñado */
body.login-locked{
  background:
    radial-gradient(circle at top left, rgba(31,166,107,.22), transparent 34%),
    linear-gradient(135deg,#f4f7ef,#e7efe7) !important;
}

#loginScreen{
  background:
    linear-gradient(120deg, rgba(15,45,31,.92) 0 42%, rgba(244,248,241,.96) 42% 100%),
    radial-gradient(circle at 24% 18%, rgba(44,188,123,.35), transparent 30%) !important;
  align-items:center !important;
  justify-content:center !important;
  padding:34px !important;
}

#loginScreen::before{
  opacity:.08 !important;
  background:
    linear-gradient(90deg, transparent 0 54px, rgba(255,255,255,.75) 55px 56px),
    linear-gradient(180deg, transparent 0 54px, rgba(255,255,255,.75) 55px 56px) !important;
}

#loginScreen::after{
  display:none !important;
}

.login-shell{
  width:min(100%, 980px) !important;
  justify-content:flex-end !important;
}

.login-box{
  width:min(100%, 430px) !important;
  min-height:auto !important;
  padding:34px !important;
  border-radius:30px !important;
  border:1px solid rgba(19,51,35,.08) !important;
  background:rgba(255,255,255,.96) !important;
  color:#13251c !important;
  box-shadow:0 30px 90px rgba(19,51,35,.22) !important;
  backdrop-filter:blur(18px) !important;
}

.login-box::before{
  background:linear-gradient(90deg,#1fa66b,#c59f43,#1fa66b) !important;
  height:6px !important;
  opacity:1 !important;
}

.login-mark{
  width:118px !important;
  height:118px !important;
  margin:0 auto 18px !important;
  border-radius:30px !important;
  background:#f3f7f1 !important;
  border:1px solid #dce8df !important;
  box-shadow:0 18px 36px rgba(20,55,39,.12) !important;
}

.login-mark::before,
.login-mark::after,
.login-mini-glow{
  display:none !important;
}

.login-mark img{
  width:88px !important;
  height:88px !important;
  filter:none !important;
}

.login-box-top h3{
  color:#13251c !important;
  font-size:30px !important;
  letter-spacing:.6px !important;
  text-shadow:none !important;
}

.login-field label{
  color:#2b4739 !important;
  font-size:12px !important;
  text-transform:uppercase !important;
  letter-spacing:.7px !important;
}

.login-input-wrap span{
  color:#1fa66b !important;
}

.login-box input{
  color:#16231d !important;
  background:#f6f8f3 !important;
  border:1px solid #d8e5dc !important;
  border-radius:16px !important;
  box-shadow:none !important;
}

.login-box input:focus{
  border-color:#1fa66b !important;
  box-shadow:0 0 0 4px rgba(31,166,107,.14) !important;
}

.login-submit{
  border-radius:16px !important;
  background:linear-gradient(135deg,#16784f,#27b879) !important;
  box-shadow:0 16px 32px rgba(31,166,107,.24) !important;
}

/* Panel como dashboard con barra lateral */
.wrap{
  max-width:min(1460px, calc(100% - 46px)) !important;
  margin:0 auto !important;
  padding:28px 0 !important;
}

.wrap > .panel{
  display:grid !important;
  grid-template-columns:300px minmax(0,1fr) !important;
  align-items:start !important;
  gap:0 !important;
  min-height:calc(100vh - 56px) !important;
  padding:0 !important;
  overflow:hidden !important;
  border:none !important;
  border-radius:34px !important;
  background:#f8faf5 !important;
  box-shadow:0 28px 90px rgba(26,55,42,.16) !important;
}

.topbar{
  grid-column:1 !important;
  position:sticky !important;
  top:28px !important;
  min-height:calc(100vh - 56px) !important;
  margin:0 !important;
  padding:30px 24px !important;
  align-items:flex-start !important;
  justify-content:flex-start !important;
  border-radius:34px 0 0 34px !important;
  background:
    radial-gradient(circle at 30% 0%, rgba(49,204,142,.22), transparent 30%),
    linear-gradient(180deg,#10251c 0%,#0b1812 100%) !important;
  color:#fff !important;
  box-shadow:inset -1px 0 0 rgba(255,255,255,.06) !important;
}

.topbar > div{
  width:100% !important;
  display:flex !important;
  min-height:calc(100vh - 116px) !important;
  flex-direction:column !important;
  align-items:flex-start !important;
  justify-content:flex-start !important;
  gap:18px !important;
}

.topbar > div::before{
  content:"Panel local";
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  color:#dff8eb;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  font-size:12px;
  font-weight:900;
  letter-spacing:.5px;
  text-transform:uppercase;
}

.topbar > div::after{
  content:"Sin conexión a base de datos";
  margin-top:auto;
  display:block;
  width:100%;
  padding:14px 14px;
  border-radius:18px;
  color:#dcebe2;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.10);
  font-size:13px;
  font-weight:800;
  line-height:1.35;
}

.title{
  width:100% !important;
  margin:8px 0 6px !important;
  font-size:clamp(28px,2.3vw,38px) !important;
  line-height:1.05 !important;
  letter-spacing:.4px !important;
  text-transform:none !important;
}

.title-glow{
  color:#ffffff !important;
  background:none !important;
  -webkit-text-fill-color:#ffffff !important;
  text-shadow:none !important;
}

.title::after{
  display:none !important;
}

.logout-btn{
  position:static !important;
  width:100% !important;
  margin-top:6px !important;
  padding:13px 16px !important;
  border-radius:16px !important;
  border:1px solid rgba(255,255,255,.13) !important;
  color:#fff4f4 !important;
  background:rgba(255,255,255,.08) !important;
  box-shadow:none !important;
}

.logout-btn:hover{
  transform:translateY(-1px) !important;
  border-color:rgba(255,120,120,.36) !important;
  background:rgba(255,91,91,.14) !important;
  box-shadow:none !important;
}

