/* Consultorías Escalate — "centro de operaciones" editorial, oscuro y premium. */
:root{
  --bg:#0c0e0d;
  --surface:#15191a;
  --surface-2:#1b2122;
  --line:rgba(255,255,255,.075);
  --line-fuerte:rgba(255,255,255,.14);
  --ink:#edf1ef;
  --muted:#8a938f;
  --lima:#b6f09c;
  --ambar:#f5c451;
  --verde:#6ee7a0;
  --rojo:#ff7d7d;
  --r:16px;
  --sombra:0 18px 50px -24px rgba(0,0,0,.8);
  --fluido:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;min-height:100vh;
  font-family:"Hanken Grotesk",system-ui,sans-serif;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  position:relative;overflow-x:hidden;
}
/* atmósfera: destellos cálidos + grano fino */
.glow{position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(60vw 60vw at 82% -10%, rgba(245,196,81,.10), transparent 60%),
    radial-gradient(50vw 50vw at -5% 8%, rgba(182,240,156,.09), transparent 55%);}
body::after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ---------- header ---------- */
.top{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;
  padding:2.4rem clamp(1.2rem,4vw,3.2rem) 1.4rem;}
.kicker{font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.brand h1{font-family:"Fraunces",serif;font-weight:430;font-size:clamp(1.9rem,4.4vw,3.1rem);
  line-height:1.02;margin:.35rem 0 0;letter-spacing:-.015em;}
.brand h1 em{font-style:italic;color:var(--lima);}
.controls{display:flex;gap:.7rem;align-items:center;flex-wrap:wrap;}
.search{position:relative;display:flex;align-items:center;}
.search svg{position:absolute;left:.85rem;width:16px;height:16px;stroke:var(--muted);fill:none;stroke-width:2;stroke-linecap:round;}
input,select,button{font-family:inherit;font-size:.92rem;color:var(--ink);
  background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:.62rem .9rem;transition:border-color .2s,background .2s;}
input{padding-left:2.4rem;min-width:220px;}
input::placeholder{color:var(--muted);}
input:focus,select:focus{outline:none;border-color:var(--lima);}
select{cursor:pointer;}
#refrescar{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:600;}
#refrescar svg{width:15px;height:15px;stroke:var(--lima);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .5s var(--fluido);}
#refrescar:hover{border-color:var(--line-fuerte);background:var(--surface-2);}
#refrescar:hover svg{transform:rotate(-180deg);}

/* ---------- resumen (chips de semáforo) ---------- */
.resumen{display:flex;gap:.7rem;flex-wrap:wrap;padding:.4rem clamp(1.2rem,4vw,3.2rem) 0;}
.chip{display:flex;align-items:center;gap:.6rem;background:var(--surface);border:1px solid var(--line);
  border-radius:999px;padding:.45rem .95rem .45rem .7rem;cursor:pointer;transition:border-color .2s,transform .2s var(--fluido);}
.chip:hover{transform:translateY(-2px);border-color:var(--line-fuerte);}
.chip .n{font-family:"Fraunces",serif;font-size:1.25rem;font-weight:500;line-height:1;}
.chip .l{font-size:.8rem;color:var(--muted);}
.chip .dot{width:9px;height:9px;border-radius:50%;}
.chip.activo{border-color:var(--line-fuerte);background:var(--surface-2);}
.dot.verde,.tarjeta.verde .dot{background:var(--verde);box-shadow:0 0 12px -1px var(--verde);}
.dot.amarillo,.tarjeta.amarillo .dot{background:var(--ambar);box-shadow:0 0 12px -1px var(--ambar);}
.dot.rojo,.tarjeta.rojo .dot{background:var(--rojo);box-shadow:0 0 12px -1px var(--rojo);}

#meta{padding:.9rem clamp(1.2rem,4vw,3.2rem) 0;margin:0;color:var(--muted);font-size:.82rem;letter-spacing:.02em;}

/* ---------- grilla de clientes ---------- */
#grilla{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;
  padding:1.2rem clamp(1.2rem,4vw,3.2rem) 2rem;}
.tarjeta{position:relative;display:grid;grid-template-columns:auto 1fr;gap:.55rem 1rem;align-items:start;
  background:linear-gradient(180deg,var(--surface),var(--surface-2));
  border:1px solid var(--line);border-radius:var(--r);padding:1.15rem 1.25rem;cursor:pointer;
  box-shadow:var(--sombra);overflow:hidden;
  transition:transform .25s var(--fluido),border-color .25s,box-shadow .25s;
  opacity:0;transform:translateY(14px);animation:surge .5s var(--fluido) forwards;}
.tarjeta::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--muted);opacity:.5;}
.tarjeta.verde::before{background:var(--verde)}.tarjeta.amarillo::before{background:var(--ambar)}.tarjeta.rojo::before{background:var(--rojo)}
.tarjeta:hover{transform:translateY(-4px);border-color:var(--line-fuerte);}
.tarjeta .dot{width:11px;height:11px;border-radius:50%;margin-top:.45rem;}
.tarjeta .cuerpo{grid-column:2;}
.tarjeta .cliente{font-family:"Fraunces",serif;font-weight:500;font-size:1.18rem;letter-spacing:-.01em;margin:0;}
.tarjeta .motivo{color:var(--muted);font-size:.86rem;margin:.25rem 0 0;line-height:1.35;}
.tarjeta .prox{grid-column:2;margin-top:.7rem;font-size:.8rem;color:var(--ink);display:flex;gap:.4rem;align-items:center;}
.tarjeta .prox b{font-weight:600}.tarjeta .prox .lbl{color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-size:.66rem;}
@keyframes surge{to{opacity:1;transform:none}}

.vacio{grid-column:1/-1;text-align:center;color:var(--muted);padding:4rem 1rem;font-size:1rem;}

/* ---------- pestañas ---------- */
.tabs{display:flex;gap:.4rem;padding:.6rem clamp(1.2rem,4vw,3.2rem) 0;}
.tabs button{background:transparent;border:1px solid transparent;border-radius:10px;color:var(--muted);cursor:pointer;font-weight:600;padding:.5rem 1rem;font-size:.92rem;}
.tabs button:hover{color:var(--ink);}
.tabs button.activo{color:var(--ink);background:var(--surface);border-color:var(--line);}

/* ---------- calendario ---------- */
.cal-nav{display:flex;align-items:center;gap:.8rem;padding:1.2rem clamp(1.2rem,4vw,3.2rem) .4rem;}
.cal-nav h2{font-family:"Fraunces",serif;font-weight:450;font-size:1.5rem;margin:0;min-width:11rem;text-transform:capitalize;}
.cal-nav button{background:var(--surface);border:1px solid var(--line);border-radius:10px;color:var(--ink);cursor:pointer;width:2.2rem;height:2.2rem;font-size:1.1rem;line-height:1;}
.cal-nav #cal-hoy{width:auto;padding:0 .9rem;font-size:.85rem;font-weight:600;}
.cal-nav button:hover{border-color:var(--line-fuerte);}
.cal-dows,#cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;padding:0 clamp(1.2rem,4vw,3.2rem);}
.cal-dows{margin:.6rem 0 .3rem;}
.cal-dows span{color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;text-align:center;}
#cal-grid{padding-bottom:2rem;}
.cal-dia{min-height:96px;background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:.45rem .5rem;display:flex;flex-direction:column;gap:3px;overflow:hidden;}
.cal-dia.fuera{opacity:.38;}
.cal-dia.mie{background:linear-gradient(180deg,rgba(182,240,156,.06),var(--surface));border-color:rgba(182,240,156,.18);}
.cal-dia.hoy{outline:1.5px solid var(--lima);}
.cal-num{font-size:.78rem;color:var(--muted);font-weight:600;}
.cal-dia.hoy .cal-num{color:var(--lima);}
.cal-ev{font-size:.68rem;background:var(--surface-2);border-left:2px solid var(--ambar);border-radius:5px;padding:2px 5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cal-dia.mie .cal-ev{border-left-color:var(--lima);}
@media (max-width:720px){.cal-dia{min-height:64px}.cal-ev{font-size:.6rem}.cal-num{font-size:.7rem}}

.pie{padding:1rem clamp(1.2rem,4vw,3.2rem) 3rem;color:var(--muted);font-size:.76rem;border-top:1px solid var(--line);margin-top:1rem;}

/* ---------- ficha (dialog) ---------- */
dialog{border:none;padding:0;background:transparent;max-width:560px;width:92vw;color:var(--ink);}
dialog::backdrop{background:rgba(6,8,7,.66);backdrop-filter:blur(4px);}
.ficha-card{background:linear-gradient(180deg,var(--surface),var(--surface-2));border:1px solid var(--line-fuerte);
  border-radius:20px;padding:1.8rem;box-shadow:0 30px 80px -30px #000;}
.ficha-card h2{font-family:"Fraunces",serif;font-weight:500;font-size:1.7rem;margin:.2rem 0 .1rem;display:flex;align-items:center;gap:.6rem;letter-spacing:-.01em;}
.ficha-card .estado{color:var(--muted);margin:.1rem 0 1.2rem;}
.ficha-card h3{font-size:.74rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);margin:1.3rem 0 .5rem;}
.ficha-card ul{margin:.2rem 0;padding-left:1.1rem;}
.ficha-card li{margin:.3rem 0;line-height:1.4;}
.ficha-card .links{display:flex;gap:.6rem;margin-top:1.5rem;flex-wrap:wrap;}
.ficha-card a{color:#0c0e0d;background:var(--lima);text-decoration:none;font-weight:600;font-size:.86rem;padding:.5rem .95rem;border-radius:10px;transition:transform .2s var(--fluido);}
.ficha-card a.sec{background:transparent;color:var(--ink);border:1px solid var(--line-fuerte);}
.ficha-card a:hover{transform:translateY(-2px);}
.ficha-card .cerrar{margin-top:1.5rem;}
.ficha-card .cerrar button{width:100%;cursor:pointer;background:var(--surface-2);}

/* ---------- login ---------- */
.login{display:grid;place-items:center;min-height:100vh;padding:1rem;}
.card{display:grid;gap:1rem;background:linear-gradient(180deg,var(--surface),var(--surface-2));
  border:1px solid var(--line-fuerte);padding:2.4rem;border-radius:22px;width:min(360px,92vw);box-shadow:var(--sombra);}
.card h1{font-family:"Fraunces",serif;font-weight:450;font-size:1.7rem;margin:0 0 .3rem;letter-spacing:-.01em;}
.card .kicker{margin-bottom:-.4rem;}
.card input{padding-left:.9rem;}
.card button{cursor:pointer;background:var(--lima);color:#0c0e0d;font-weight:700;border:none;padding:.75rem;border-radius:12px;font-size:.95rem;}
.card button:hover{filter:brightness(1.05);}
.card #err{color:var(--rojo);font-size:.85rem;margin:0;min-height:1em;text-align:center;}

@media (max-width:600px){.top{align-items:flex-start}.controls{width:100%}.search,input{flex:1;min-width:0}}
