/* ============================================================
   CID · PORTAL DE CLIENTES · Diseño claro/amigable (2026-04-25)
   Override del tema dark de catalogo.css con paleta sagrada clara.
   Mantiene TODAS las clases para no romper cliente.js.
   ============================================================ */

/* ═══ Variables sobrescritas (paleta sagrada CLARA) ═══ */
body {
  --bg: #f5f3ee;
  --bg2: #ffffff;
  --bg3: #faf8f3;
  --ink: #0a0a0a;
  --ink2: #404040;
  --ink3: #888;
  --rule: #e5e5e0;
  --rule-soft: #efeee8;
  --orange: #c4ff00;       /* renombrado virtualmente: el "orange" es verde limón */
  --orange-d: #a8e000;
  --red: #ef4444;
  --green: #22c55e;
  --amber: #f59e0b;
  --blue: #3b82f6;
  --purple: #a855f7;
  background: var(--bg) !important;
  color: var(--ink) !important;
  font-family: 'Inter', system-ui, sans-serif !important;
}

/* ═══ Reset portal ═══ */
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:14px}

/* ═══ Top bar ═══ */
.topbar{
  background:#0a0a0a;
  color:#fafafa;
  border-bottom:none;
  padding:7px 0;
}
.topbar .wrap{
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  font-family:'Oswald',sans-serif;
  font-size:10.5px;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;
}
.topbar strong{color:#c4ff00;font-weight:800}
.topbar .loc{color:#999}

/* ═══ Header / nav ═══ */
header.site{
  background:#fff;
  border-bottom:1px solid var(--rule);
  position:sticky;top:0;z-index:90;
  backdrop-filter:blur(12px);
}
header.site .wrap{
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  padding:14px 18px;max-width:1280px;margin:0 auto;
}
header.site .brand{display:flex;align-items:center;gap:12px;color:var(--ink);text-decoration:none}
header.site .brand img{height:42px;width:auto;filter:brightness(0) invert(0)}
header.site .brand-txt .b1{
  font-family:'Archivo Black',sans-serif;
  font-size:13px;letter-spacing:.06em;color:var(--ink);
}
header.site .brand-txt .b2{
  font-family:'Oswald',sans-serif;
  font-size:10px;letter-spacing:.22em;color:var(--ink3);
  text-transform:uppercase;margin-top:2px;
}
header.site .nav-cta{display:flex;gap:10px;align-items:center}
.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:10px 16px;border-radius:99px;
  font-family:'Inter',sans-serif;font-weight:700;font-size:13px;
  text-decoration:none;
  border:1.5px solid transparent;
  transition:all .15s;
  cursor:pointer;
}
.btn-ghost{
  border-color:var(--rule);color:var(--ink);background:#fff;
}
.btn-ghost:hover{border-color:var(--ink);background:#fafafa}
.btn-wa{
  background:#22c55e;color:#fff;
}
.btn-wa:hover{background:#16a34a;transform:translateY(-1px)}
.btn-orange{
  background:#c4ff00;color:#0a0a0a;
  border:none;
}
.btn-orange:hover{background:#a8e000;transform:translateY(-1px);box-shadow:0 4px 14px rgba(196,255,0,.4)}

/* ═══ Botón primario ═══ */
.btn.btn-primary{
  width:100%;
  padding:14px 18px;
  font-size:13px;
  letter-spacing:.06em;
  justify-content:center;
  margin-top:18px;
  font-family:'Archivo Black',sans-serif;
  text-transform:uppercase;
  border-radius:99px;
  background:#c4ff00;
  color:#0a0a0a;
  box-shadow:0 4px 14px rgba(196,255,0,.3);
}
.btn.btn-primary:hover{background:#a8e000;transform:translateY(-2px);box-shadow:0 8px 22px rgba(196,255,0,.5)}
.btn.btn-primary.small{
  width:auto;padding:10px 18px;font-size:12px;margin-top:0;
}
.btn.btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}
.bt-sp{
  width:14px;height:14px;
  border:2px solid rgba(10,10,10,.25);
  border-top-color:#0a0a0a;
  border-radius:50%;
  animation:spin .7s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ═══ Wrap general ═══ */
.wrap{max-width:1280px;margin:0 auto;padding:0 18px}

/* ═══ HERO DEL PORTAL ═══ */
.portal-hero{
  position:relative;
  padding:64px 0 56px;
  border-bottom:6px solid #c4ff00;
  overflow:hidden;
  background:
    radial-gradient(ellipse 90% 70% at 50% 0%, rgba(196,255,0,.12), transparent 70%),
    var(--bg);
}
.portal-hero .grommet{display:none}  /* eliminamos grommets industrial */
.portal-hero-in{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:48px;
  align-items:center;
}
.portal-hero .spec-top{
  display:inline-flex;
  align-items:center;gap:10px;
  background:#0a0a0a;color:#c4ff00;
  padding:7px 14px;border-radius:99px;
  font-family:'Archivo Black',sans-serif;
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  margin-bottom:24px;width:fit-content;
  border-bottom:none;padding-bottom:7px;justify-content:center;
}
.portal-hero .spec-top::before{
  content:"";width:7px;height:7px;border-radius:50%;background:#c4ff00;
  animation:hero-blink 1.5s infinite;
}
@keyframes hero-blink{0%,100%{opacity:1}50%{opacity:.35}}
.portal-hero .spec-top span{display:inline-block}
.portal-hero .spec-top span:not(:first-child){
  padding-left:10px;border-left:1px solid rgba(196,255,0,.3);margin-left:5px;
}
.portal-hero h1{
  font-family:'Archivo Black','Anton',sans-serif;
  font-weight:800;
  font-size:clamp(40px,7vw,86px);
  line-height:.92;letter-spacing:-2px;
  color:var(--ink);
  text-transform:uppercase;
  margin:0;
}
.portal-hero h1 .accent{
  color:#0a0a0a;
  background:#c4ff00;
  padding:0 12px;
  display:inline-block;
  transform:rotate(-1deg);
}
.portal-hero h1 .amp{color:#c4ff00;background:#0a0a0a;padding:0 6px;font-weight:800}
.portal-hero .hero-sub{
  margin-top:22px;max-width:520px;
  font-size:clamp(15px,1.5vw,17px);color:var(--ink2);line-height:1.55;
}
.portal-hero .hero-sub strong{color:var(--ink);font-weight:700}

/* ═══ Lista benefits ═══ */
.benefits{
  list-style:none;margin:28px 0 0;padding:0;
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  background:#fff;
  border:1px solid var(--rule);
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 4px 14px rgba(0,0,0,.04);
}
.benefits li{
  display:flex;align-items:center;gap:12px;
  padding:14px 18px;
  border-bottom:1px solid var(--rule);
  font-size:14px;color:var(--ink);
  font-weight:500;
  background:#fff;
}
.benefits li:nth-child(odd){border-right:1px solid var(--rule)}
.benefits li:nth-child(odd):not(:last-child){padding-right:18px}
.benefits li:nth-last-child(-n+2){border-bottom:none}
.benefits li b{
  display:inline-flex;align-items:center;justify-content:center;
  width:26px;height:26px;border-radius:50%;
  background:#c4ff00;
  font-family:'Archivo Black',sans-serif;
  font-size:10px;letter-spacing:0;color:#0a0a0a;font-weight:800;
  flex-shrink:0;
}

/* ═══ Trust row ═══ */
.trust-row{
  display:flex;gap:8px;flex-wrap:wrap;
  margin-top:20px;
}
.tb{
  background:#0a0a0a;color:#c4ff00;
  border:none;
  padding:7px 12px;border-radius:99px;
  font-family:'Oswald',sans-serif;
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:700;
}

/* ═══ AUTH CARD ═══ */
.auth-card{
  background:#fff;
  border:1px solid var(--rule);
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 12px 40px rgba(0,0,0,.08),0 2px 0 #c4ff00 inset;
}
.tabs{
  display:flex;border-bottom:1px solid var(--rule);
  background:var(--bg3);
}
.tab{
  flex:1;padding:18px 10px;
  font-family:'Archivo Black',sans-serif;
  font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink3);
  border-bottom:3px solid transparent;
  transition:color .2s, border-color .2s, background .2s;
}
.tab.active{color:var(--ink);border-bottom-color:#c4ff00;background:#fff}
.tab:hover:not(.active){color:var(--ink)}

.form{padding:28px 28px 24px}
.lbl{
  display:block;
  font-family:'Oswald',sans-serif;
  font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;
  color:var(--ink2);
  margin-bottom:7px;margin-top:16px;
}
.lbl:first-child,
.form > .lbl:first-of-type{margin-top:0}
.req{color:var(--red);font-weight:700}
.opt{color:var(--ink3);font-weight:400;font-size:10px;letter-spacing:.12em}

.form input[type=text],
.form input[type=tel],
.form input[type=email],
.form input[type=password]{
  width:100%;padding:14px 16px;
  background:#fff;
  border:1.5px solid var(--rule);
  border-radius:10px;
  color:var(--ink);
  font-family:'Inter',sans-serif;font-size:15px;
  transition:border-color .15s, background .15s, box-shadow .15s;
}
.form input:focus{
  outline:none;
  border-color:#0a0a0a;
  box-shadow:0 0 0 3px rgba(196,255,0,.25);
}
.form input::placeholder{color:var(--ink3)}

.input-wrap{position:relative;display:flex;align-items:stretch}
.input-wrap input{flex:1}
.input-wrap .ipref + input{padding-left:54px}
.ipref{
  position:absolute;left:14px;top:50%;transform:translateY(-50%);
  font-family:'Inter',sans-serif;
  font-weight:700;color:var(--ink);font-size:14px;letter-spacing:.02em;
  pointer-events:none;
  z-index:2;
}
.input-wrap input[type=password]{padding-right:62px}
.eye{
  position:absolute;right:8px;top:50%;transform:translateY(-50%);
  padding:6px 12px;border-radius:99px;
  font-family:'Oswald',sans-serif;
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;
  color:var(--ink2);
  border:1.5px solid var(--rule);
  background:#fff;
  transition:all .15s;
}
.eye:hover{color:#0a0a0a;border-color:#0a0a0a}

.chk{
  display:flex;align-items:flex-start;gap:10px;
  font-size:13px;color:var(--ink2);margin-top:18px;cursor:pointer;
  line-height:1.5;
}
.chk input{width:18px;height:18px;margin-top:1px;accent-color:#0a0a0a;flex-shrink:0}
.chk a{color:#0a0a0a;font-weight:700;text-decoration:underline}

.link{
  display:block;text-align:center;
  margin-top:14px;
  font-family:'Oswald',sans-serif;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  color:var(--ink3);
}
.link:hover{color:#0a0a0a}

.auth-msg{
  margin:0 28px 22px;padding:13px 16px;
  border-radius:10px;font-size:13px;line-height:1.5;
  display:none;
  border:1px solid transparent;font-weight:500;
}
.auth-msg.err{display:block;background:#fef2f2;color:#991b1b;border-color:#fecaca}
.auth-msg.ok{display:block;background:#f0fdf4;color:#166534;border-color:#bbf7d0}
.auth-msg.info{display:block;background:#eff6ff;color:#1e40af;border-color:#bfdbfe}

/* ═══ Sections ═══ */
.section{padding:56px 0;border-top:1px solid var(--rule);background:#fff}
.section:nth-of-type(even){background:var(--bg)}
.section-head{
  display:flex;justify-content:space-between;align-items:flex-end;gap:14px;
  margin-bottom:32px;padding-bottom:18px;border-bottom:2px solid var(--ink);
  flex-wrap:wrap;
}
.section-head h2{
  font-family:'Archivo Black',sans-serif;
  font-size:clamp(26px,4vw,40px);
  letter-spacing:-1px;text-transform:uppercase;
  color:var(--ink);margin:0;line-height:1;
}
.section-head .index{
  font-family:'Oswald',sans-serif;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink3);font-weight:600;
}

/* ═══ Steps ═══ */
.steps{
  display:grid;grid-template-columns:repeat(5,1fr);gap:16px;
}
.step{
  background:#fff;
  border:1px solid var(--rule);border-radius:14px;
  padding:22px 18px;
  transition:transform .2s,border-color .2s,box-shadow .2s;
}
.step:hover{transform:translateY(-4px);border-color:#c4ff00;box-shadow:0 12px 30px rgba(0,0,0,.08)}
.step .n{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:50%;
  background:#c4ff00;
  font-family:'Archivo Black',sans-serif;
  font-size:16px;color:#0a0a0a;font-weight:800;
  margin-bottom:14px;
}
.step h3{
  font-family:'Archivo Black',sans-serif;
  font-size:17px;letter-spacing:-.3px;text-transform:uppercase;
  color:var(--ink);margin:0 0 8px;line-height:1;
}
.step p{font-size:13.5px;color:var(--ink2);line-height:1.55;margin:0}

/* ═══ Contact / seguridad ═══ */
.contact{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
}
.contact-card{
  background:#fff;border:1px solid var(--rule);border-radius:14px;padding:22px;
}
.contact-card .label{
  font-family:'Oswald',sans-serif;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink3);font-weight:700;margin-bottom:6px;
}
.contact-card .val{
  font-family:'Archivo Black',sans-serif;
  font-size:18px;letter-spacing:-.3px;text-transform:uppercase;
  color:var(--ink);line-height:1.05;margin-bottom:10px;
}
.contact-card .sec-p{
  color:var(--ink2);font-size:13.5px;line-height:1.6;margin-top:0;
}
.contact-card .sec-p a{color:#0a0a0a;font-weight:700;text-decoration:underline}

/* ═══ Footer ═══ */
footer.site{
  background:#0a0a0a;color:#fff;padding:24px 0;margin-top:64px;
}
footer.site .wrap{
  display:flex;justify-content:space-between;align-items:center;gap:18px;
  flex-wrap:wrap;
}
footer.site .f-brand{display:flex;align-items:center;gap:14px}
footer.site .f-brand img{height:36px;width:auto}
footer.site .f-meta{
  font-family:'Oswald',sans-serif;
  font-size:11px;letter-spacing:.18em;color:#bbb;
  text-transform:uppercase;font-weight:600;
}
footer.site .f-meta a{color:#bbb;transition:color .15s}
footer.site .f-meta a:hover{color:#c4ff00}
footer.site .f-meta .sep{color:#555;margin:0 4px}

/* ════════════════════════════════════════════════
   DASHBOARD
   ════════════════════════════════════════════════ */
.dash-wrap{
  max-width:1160px;margin:0 auto;
  padding:36px 18px 80px;
}
.dash-head{
  display:flex;justify-content:space-between;align-items:flex-end;gap:16px;
  margin-bottom:28px;padding-bottom:18px;
  border-bottom:2px solid var(--ink);
  flex-wrap:wrap;
}
.dash-hi{
  font-family:'Archivo Black','Anton',sans-serif;
  font-size:clamp(28px,4.5vw,42px);
  font-weight:800;letter-spacing:-1px;text-transform:uppercase;
  color:var(--ink);line-height:1;
}
.dash-sub{
  font-family:'Oswald',sans-serif;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink3);margin-top:8px;font-weight:600;
}
.btn-out{
  padding:10px 16px;border-radius:99px;
  border:1.5px solid var(--rule);
  background:#fff;color:var(--ink2);
  font-family:'Oswald',sans-serif;
  font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
  transition:all .2s;
}
.btn-out:hover{border-color:var(--red);color:var(--red);background:#fef2f2}

/* ═══ Dashboard tabs ═══ */
.dash-tabs{
  display:flex;gap:6px;
  margin-bottom:28px;
  background:transparent;
  border:none;
  flex-wrap:wrap;
}
.dtab{
  flex:1;min-width:140px;
  padding:14px 18px;border-radius:12px;
  font-family:'Archivo Black',sans-serif;
  font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink2);
  background:#fff;
  border:1.5px solid var(--rule);
  transition:all .2s;
}
.dtab.active{
  background:#0a0a0a;color:#c4ff00;border-color:#0a0a0a;
  box-shadow:0 4px 14px rgba(0,0,0,.15);
}
.dtab:hover:not(.active){color:var(--ink);border-color:var(--ink)}

.dash-panel{min-height:300px}
.muted{color:var(--ink3);font-size:13.5px}

/* ═══ Empty state ═══ */
.empty{
  background:#fff;padding:60px 30px;
  border:2px dashed var(--rule);border-radius:18px;
  text-align:center;
}
.empty-ic{
  font-family:'Archivo Black',sans-serif;
  font-size:56px;line-height:1;color:#c4ff00;margin-bottom:14px;
  background:#0a0a0a;width:80px;height:80px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;
}
.empty h3{
  font-family:'Archivo Black',sans-serif;
  font-size:24px;letter-spacing:-.5px;text-transform:uppercase;
  color:var(--ink);margin:0 0 10px;
}
.empty p{color:var(--ink2);font-size:14.5px;max-width:420px;margin:0 auto;line-height:1.55}
.empty .btn-primary{max-width:320px;margin:24px auto 0;display:inline-flex}

/* ═══ Cotización / Pedido cards · NUEVO LAYOUT v2 (jerarquía + borrar) ═══ */
.cot-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(360px,1fr));
  gap:24px;
}
.cot-card{
  background:#fff;
  border:1.5px solid var(--rule);
  border-radius:18px;
  display:flex;flex-direction:column;
  transition:all .25s;
  overflow:hidden;
  box-shadow:0 4px 16px rgba(0,0,0,.05),0 1px 0 rgba(0,0,0,.03);
  cursor:pointer;
  outline:none;
}
.cot-card:hover{border-color:#c4ff00;transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.1),0 0 0 4px rgba(196,255,0,.12)}
.cot-card:focus-visible{border-color:#0a0a0a;box-shadow:0 0 0 4px rgba(196,255,0,.3)}

/* Header de la card · folio + status */
.cot-card-top{
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:16px 20px 12px;
  border-bottom:1px dashed var(--rule);
  flex-wrap:wrap;
}
.cot-card-folio-row{display:flex;align-items:center;gap:8px}
.cot-card-folio{
  font-family:'Archivo Black',sans-serif;
  font-size:13px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ink);font-weight:800;
}

/* Cuerpo · producto + fecha */
.cot-card-product{padding:18px 20px 14px;flex:1}
.cot-card-name{
  font-family:'Archivo Black',sans-serif;
  font-size:18px;line-height:1.2;letter-spacing:-.4px;
  color:var(--ink);margin:0 0 8px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.cot-card-date{
  font-family:'Oswald',sans-serif;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink3);margin:0;font-weight:600;
}

/* Precio gigante */
.cot-card-price{
  display:flex;flex-direction:column;align-items:flex-start;gap:4px;
  padding:0 20px 18px;
}
.cot-card-price-lbl{
  font-family:'Oswald',sans-serif;
  font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink3);font-weight:700;
}
.cot-card-price-val{
  font-family:'Archivo Black',sans-serif;
  font-size:30px;line-height:1;letter-spacing:-.8px;
  color:var(--ink);
}

/* Footer acciones · pagar | editar | borrar */
.cot-card-actions{
  display:flex;align-items:center;gap:10px;
  padding:14px 20px 18px;
  border-top:1px solid var(--rule);
  background:var(--bg3);
  flex-wrap:wrap;
}
.cot-cta-pri{
  flex:1;min-width:140px;
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  background:#c4ff00;color:#0a0a0a;
  border:none;border-radius:99px;
  padding:12px 16px;
  font-family:'Archivo Black',sans-serif;
  font-size:12.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  cursor:pointer;
  box-shadow:0 4px 14px rgba(196,255,0,.3);
  transition:all .15s;
  text-decoration:none;
}
.cot-cta-pri:hover{background:#0a0a0a;color:#c4ff00;transform:translateY(-2px);box-shadow:0 8px 22px rgba(0,0,0,.2)}
.cot-cta-pri svg{flex-shrink:0}

.cot-cta-sec{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  background:#fff;color:var(--ink);
  border:1.5px solid var(--rule);border-radius:99px;
  padding:11px 16px;
  font-family:'Oswald',sans-serif;
  font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  cursor:pointer;
  transition:all .15s;
  text-decoration:none;
}
.cot-cta-sec:hover{border-color:var(--ink);background:#faf8f3}
.cot-cta-sec svg{flex-shrink:0;stroke-width:2.4}

/* Botón borrar · papelera discreta · solo destaca al hover */
.cot-cta-del{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;
  background:#fff;color:var(--ink3);
  border:1.5px solid var(--rule);border-radius:50%;
  cursor:pointer;
  transition:all .15s;
  flex-shrink:0;
}
.cot-cta-del:hover{background:#fef2f2;color:#dc2626;border-color:#fca5a5;transform:scale(1.05)}
.cot-cta-del:active{transform:scale(.95)}
.cot-cta-del svg{stroke-width:2.2}

/* Mobile · 1 columna · cards más anchas */
@media (max-width:560px){
  .cot-grid{grid-template-columns:1fr;gap:16px}
  .cot-card-name{font-size:16px}
  .cot-card-price-val{font-size:26px}
  .cot-card-actions{flex-direction:row;gap:8px}
  .cot-cta-pri{min-width:0;flex:1}
}
.cot-head{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  padding:14px 18px;border-bottom:1px solid var(--rule);
  background:var(--bg3);
}
.cot-folio{
  font-family:'Archivo Black',sans-serif;
  font-size:12px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink);font-weight:800;
}
.cot-estado{
  font-family:'Oswald',sans-serif;
  font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;
  padding:5px 11px;border-radius:99px;
  color:#fff;background:#888;
  border:none;
}
.cot-estado-nueva{background:#fef3c7;color:#854d0e;border:1px solid #fde68a}
.cot-estado-cotizacion_enviada{background:#fef3c7;color:#854d0e;border:1px solid #fde68a}
.cot-estado-cotizado{background:#fef3c7;color:#854d0e;border:1px solid #fde68a}
.cot-estado-por_pagar{background:#fed7aa;color:#7c2d12;border:1px solid #fdba74}
.cot-estado-aprobado{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}
.cot-estado-en_produccion{background:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}
.cot-estado-listo{background:#fae8ff;color:#86198f;border:1px solid #f5d0fe}
.cot-estado-entregado{background:#c4ff00;color:#0a0a0a;border:1px solid #a8e000}
.cot-estado-cerrado{background:#0a0a0a;color:#c4ff00;border:1px solid #0a0a0a}
.cot-estado-descartado{background:#f3f4f6;color:#525252;border:1px solid #d1d5db}
.cot-estado-con_pedo{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}

/* ═══════════════════════════════════════════════════════════
   TRACKING VISUAL · Recibido → Diseño → Producción → Listo → Entregado
═══════════════════════════════════════════════════════════ */
.trk-wrap{
  padding:18px 18px 16px;
  background:linear-gradient(180deg,rgba(196,255,0,.06) 0%,transparent 100%);
  border-top:1px solid var(--rule);
}
.trk-head{
  display:flex;justify-content:space-between;align-items:center;
  font-family:'Oswald',sans-serif;
  font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink3);margin-bottom:14px;font-weight:700;
}
.trk-head-now{color:#0a0a0a;font-weight:800}
.trk-line{
  display:grid;grid-template-columns:repeat(5,1fr);
  position:relative;
  padding:0 14px;
}
.trk-line::before{
  content:"";
  position:absolute;top:12px;left:14px;right:14px;height:3px;border-radius:99px;
  background:var(--rule);
  z-index:0;
}
.trk-line::after{
  content:"";
  position:absolute;top:12px;left:14px;height:3px;border-radius:99px;
  background:#c4ff00;
  z-index:1;transition:width .6s cubic-bezier(.4,1,.6,1);
  box-shadow:0 0 12px rgba(196,255,0,.4);
  width:var(--trk-progress,0%);
}
.trk-step{
  display:flex;flex-direction:column;align-items:center;gap:7px;
  position:relative;z-index:2;
}
.trk-dot{
  width:28px;height:28px;border-radius:50%;
  background:#fff;border:2.5px solid var(--rule);
  display:grid;place-items:center;
  color:var(--ink3);
  transition:all .35s ease;
  position:relative;
}
.trk-dot svg{width:13px;height:13px;stroke-width:2.5}
.trk-label{
  font-family:'Oswald',sans-serif;
  font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink3);text-align:center;line-height:1.25;font-weight:700;
  max-width:70px;
  transition:color .35s;
}
.trk-step.done .trk-dot{
  background:#c4ff00;border-color:#c4ff00;color:#0a0a0a;
}
.trk-step.done .trk-label{color:var(--ink2)}
.trk-step.now .trk-dot{
  background:#0a0a0a;border-color:#0a0a0a;color:#c4ff00;
  box-shadow:0 0 0 0 rgba(10,10,10,.5);
  animation:trkPulse 1.8s ease-out infinite;
  transform:scale(1.18);
}
.trk-step.now .trk-label{color:#0a0a0a;font-weight:800}
@keyframes trkPulse{
  0%{box-shadow:0 0 0 0 rgba(10,10,10,.4)}
  70%{box-shadow:0 0 0 14px rgba(10,10,10,0)}
  100%{box-shadow:0 0 0 0 rgba(10,10,10,0)}
}
.trk-wrap.complete .trk-step .trk-dot{background:#c4ff00;border-color:#c4ff00;color:#0a0a0a;animation:none;transform:scale(1)}
.trk-wrap.complete .trk-line::after{width:100%}
.trk-wrap.complete .trk-step .trk-label{color:var(--ink)}

@media (max-width:480px){
  .trk-label{font-size:9px;max-width:55px;letter-spacing:.08em}
  .trk-dot{width:22px;height:22px}
  .trk-dot svg{width:11px;height:11px}
  .trk-line::before,.trk-line::after{top:10px}
}

/* ═══ ETA ═══ */
.trk-eta{
  margin-top:14px;padding:12px 14px;
  border:1.5px solid var(--rule);border-radius:12px;
  display:flex;align-items:center;gap:10px;
  font-family:'Inter',sans-serif;
  font-size:13px;color:var(--ink2);
  background:#fff;font-weight:500;
}
.trk-eta b{color:var(--ink);font-weight:800}
.trk-eta-ico{font-size:16px;flex-shrink:0}
.trk-eta-txt{line-height:1.4}
.trk-eta-soon{border-color:#fbbf24;background:#fffbeb;color:#92400e}
.trk-eta-soon b{color:#92400e}
.trk-eta-today{border-color:#c4ff00;background:#fbffe5;color:#365314;animation:etaPulse 1.5s ease-in-out infinite}
.trk-eta-today b{color:#365314}
@keyframes etaPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(196,255,0,.35)}
  50%{box-shadow:0 0 0 6px rgba(196,255,0,0)}
}
.trk-eta-late{border-color:#ef4444;background:#fef2f2;color:#991b1b}
.trk-eta-late b{color:#991b1b}
.trk-eta-done{border-color:#86efac;background:#f0fdf4;color:#166534}
.trk-eta-done b{color:#166534}

/* ═══ Botón 1-click re-order ═══ */
.btn-reorder{
  background:#c4ff00;
  color:#0a0a0a;
  border:none;
  padding:10px 16px;
  border-radius:99px;
  font-family:'Archivo Black',sans-serif;
  font-weight:800;
  font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  cursor:pointer;
  display:inline-flex;align-items:center;gap:7px;
  transition:transform .15s,box-shadow .2s,background .2s;
  box-shadow:0 4px 14px rgba(196,255,0,.3);
}
.btn-reorder:hover{
  background:#0a0a0a;color:#c4ff00;
  transform:translateY(-2px) scale(1.02);
  box-shadow:0 8px 22px rgba(0,0,0,.2);
}
.btn-reorder:active{transform:scale(.96)}
.btn-reorder svg{flex-shrink:0;stroke-width:2.5}
@media (max-width:480px){
  .btn-reorder{font-size:11px;padding:9px 13px}
}

.cot-body{padding:18px 18px;flex:1}
.cot-resumen{
  font-size:14.5px;color:var(--ink);line-height:1.55;margin-bottom:12px;
}
.cot-resumen strong{font-family:'Archivo Black',sans-serif;font-weight:800;color:var(--ink)}
.cot-meta{
  font-family:'Oswald',sans-serif;
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink3);font-weight:600;
  display:flex;gap:14px;flex-wrap:wrap;
}
.saldo-box{
  margin-top:12px;padding:11px 14px;border-radius:10px;
  background:#fffbeb;
  border:1px solid #fbbf24;
  font-size:13px;color:#854d0e;
}
.saldo-box b{color:#92400e;font-weight:800}
.saldo-ok{
  margin-top:12px;padding:11px 14px;border-radius:10px;
  background:#f0fdf4;
  border:1px solid #86efac;
  font-size:13px;color:#166534;font-weight:600;
}

.cot-foot{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  padding:14px 18px;
  border-top:1px solid var(--rule);
  background:var(--bg3);
  flex-wrap:wrap;
}
.cot-total small{
  display:block;
  font-family:'Oswald',sans-serif;
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink3);margin-bottom:3px;font-weight:700;
}
.cot-total b{
  font-family:'Archivo Black',sans-serif;
  font-size:24px;font-weight:800;color:var(--ink);letter-spacing:-.5px;
}
.cot-acts{display:flex;gap:6px;flex-wrap:wrap}
.btn-sec{
  background:#fff;
  border:1.5px solid var(--rule);
  padding:9px 14px;border-radius:99px;
  font-family:'Oswald',sans-serif;
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;
  color:var(--ink2);
  transition:all .2s;
}
.btn-sec:hover{border-color:#0a0a0a;color:#0a0a0a;background:#fafafa}

/* ═══ Perfil ═══ */
.perfil{max-width:560px;margin:0 auto}
.perf-card{
  background:#fff;
  border:1px solid var(--rule);border-radius:18px;
  padding:30px 30px 26px;
  box-shadow:0 4px 14px rgba(0,0,0,.04);
}
.perf-card h3{
  font-family:'Archivo Black',sans-serif;
  font-size:24px;letter-spacing:-.5px;text-transform:uppercase;
  color:var(--ink);margin:0 0 22px;
  padding-bottom:14px;border-bottom:2px solid var(--ink);
}
.perf-row{margin-bottom:14px}
.perf-row label{
  display:block;
  font-family:'Oswald',sans-serif;
  font-size:11px;letter-spacing:.15em;text-transform:uppercase;font-weight:700;
  color:var(--ink2);margin-bottom:7px;
}
.perf-row input{
  width:100%;padding:13px 16px;
  background:#fff;
  border:1.5px solid var(--rule);border-radius:10px;
  color:var(--ink);
  font-size:14.5px;
  transition:all .15s;
}
.perf-row input:disabled{background:var(--bg3);color:var(--ink3);cursor:not-allowed}
.perf-row input:focus{outline:none;border-color:#0a0a0a;box-shadow:0 0 0 3px rgba(196,255,0,.25)}
.perf-card .btn-primary{margin-top:8px}

/* ═══ Subir archivo ═══ */
.upload-box{
  background:#fff;
  border:1px solid var(--rule);border-radius:18px;
  padding:32px;
  max-width:760px;margin:0 auto;
  box-shadow:0 4px 14px rgba(0,0,0,.04);
}
.up-head{margin-bottom:24px;text-align:center}
.up-head h3{
  font-family:'Archivo Black',sans-serif;
  font-size:30px;letter-spacing:-.5px;text-transform:uppercase;
  color:var(--ink);margin:0 0 6px;
}
.up-head .muted{
  font-family:'Oswald',sans-serif;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink3);font-weight:600;
}
.up-folio{margin-bottom:22px}
.up-folio label{
  display:block;
  font-family:'Oswald',sans-serif;
  font-size:11px;letter-spacing:.15em;text-transform:uppercase;font-weight:700;
  color:var(--ink2);margin-bottom:7px;
}
.up-folio select{
  width:100%;padding:13px 16px;
  background:#fff;
  border:1.5px solid var(--rule);border-radius:10px;
  color:var(--ink);
  font-family:'Inter',sans-serif;font-size:14.5px;
}
.up-folio select:focus{outline:none;border-color:#0a0a0a;box-shadow:0 0 0 3px rgba(196,255,0,.25)}

.up-sources{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px;
}
.up-src{
  display:flex;flex-direction:column;align-items:center;
  padding:30px 16px;border-radius:14px;
  background:var(--bg3);
  border:2px dashed var(--rule);
  cursor:pointer;
  transition:all .2s;
  text-align:center;
}
.up-src:hover{
  background:#fff;border-color:#c4ff00;border-style:solid;transform:translateY(-3px);
  box-shadow:0 14px 30px rgba(0,0,0,.08);
}
.up-ic{
  font-family:'Archivo Black',sans-serif;
  font-size:42px;line-height:1;color:#c4ff00;margin-bottom:10px;
  background:#0a0a0a;width:64px;height:64px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.up-src b{
  font-size:14.5px;color:var(--ink);font-weight:700;letter-spacing:0;
}
.up-src small{
  font-family:'Oswald',sans-serif;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink3);margin-top:5px;font-weight:600;
}
.up-prog{
  margin-top:18px;padding:16px;border-radius:12px;
  background:#fff;border:1.5px solid var(--rule);
}
.up-prog-bar{height:6px;background:var(--bg3);border-radius:99px;overflow:hidden;margin-bottom:10px}
#up-prog-fill{height:100%;background:#c4ff00;border-radius:99px;transition:width .3s}
.up-prog-tx{
  font-family:'Oswald',sans-serif;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);font-weight:700;
}
.up-ok{
  margin-top:14px;padding:14px;border-radius:12px;
  background:#f0fdf4;
  border:1px solid #86efac;
  color:#166534;font-size:13.5px;font-weight:500;
}
.up-err{
  margin-top:14px;padding:14px;border-radius:12px;
  background:#fef2f2;
  border:1px solid #fecaca;
  color:#991b1b;font-size:13.5px;font-weight:500;
}
.up-note{
  margin-top:18px;padding:14px;border-radius:12px;
  background:var(--bg3);border:1px solid var(--rule);
  font-size:12.5px;color:var(--ink2);line-height:1.6;
}
.up-note b{color:#0a0a0a;font-weight:700}

/* ═══ Spinner overlay & Toast ═══ */
.spinner{
  position:fixed;inset:0;z-index:9999;
  background:rgba(245,243,238,.85);
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(6px);
}
.sp-ring{
  width:48px;height:48px;
  border:3px solid rgba(10,10,10,.12);
  border-top-color:#c4ff00;
  border-radius:50%;
  animation:spin .8s linear infinite;
}
.toast{
  position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(180%);
  background:#0a0a0a;color:#fff;
  border-radius:99px;
  padding:14px 24px;
  font-family:'Oswald',sans-serif;
  font-size:13px;letter-spacing:.08em;text-transform:uppercase;font-weight:700;
  box-shadow:0 12px 40px rgba(0,0,0,.3);
  z-index:9998;max-width:92%;text-align:center;
  transition:transform .35s cubic-bezier(.2,.9,.3,1);
}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.ok{background:#22c55e}
.toast.err{background:#ef4444}
.toast.warn{background:#c4ff00;color:#0a0a0a}
.toast.info{background:#3b82f6}

/* ═══ FAB WhatsApp ═══ */
.fab{
  position:fixed;bottom:22px;right:22px;z-index:80;
  width:60px;height:60px;border-radius:50%;
  background:#22c55e;color:#fff;
  display:grid;place-items:center;
  box-shadow:0 8px 24px rgba(34,197,94,.4);
  transition:all .2s;
  text-decoration:none;
}
.fab:hover{transform:scale(1.1);box-shadow:0 12px 32px rgba(34,197,94,.55)}
.fab svg{width:28px;height:28px}

/* ═══ Responsive ═══ */
@media (max-width:1100px){
  .steps{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:900px){
  .portal-hero{padding:48px 0 40px}
  .portal-hero-in{grid-template-columns:1fr;gap:36px}
  .benefits{grid-template-columns:1fr}
  .benefits li:nth-child(odd){border-right:none;padding-right:18px}
  .dash-tabs{flex-direction:column;gap:6px}
  .dtab{border-right:none;min-width:0}
  .up-sources{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .steps{grid-template-columns:repeat(2,1fr)}
  footer.site .wrap{flex-direction:column;align-items:flex-start;gap:14px;text-align:left}
}
@media (max-width:640px){
  .portal-hero{padding:36px 0 32px}
  .form{padding:24px 22px 22px}
  .auth-msg{margin:0 22px 20px}
  .cot-grid{grid-template-columns:1fr}
  .cot-foot{flex-direction:column;align-items:flex-start}
  .cot-acts{width:100%;justify-content:flex-end}
  .dash-head{flex-direction:column;align-items:flex-start}
  .upload-box{padding:24px 20px}
  .perf-card{padding:24px 22px}
  .steps{grid-template-columns:1fr}
}
