/* fuentes via /assets/fonts.css */

/* ============================================================
   BAHÍA INTEGRA — "La edición de hoy"
   Roles de los verdes (LEY — ningún verde fuera de su rol):
     TINTA   #033932  → masthead, cuño, titulares de peso, texto sobre láminas
     SEÑAL   #009E83  → filetes 2px, links, ▲ delta positivo, arco vacaciones, foco
     ECOS    teal #3ABAB4 / mint #C4EFD8 / #EAF6F1 → SOLO fondos y halos, nunca texto
   CÁLIDO   #E2552E  → semántico estricto: "celebrar HOY" + "vence HOY". Jamás adorno.
   ÁMBAR    #E8A33D  → "vence mañana / en riesgo" (cálido más suave)
   ============================================================ */
:root{
  --ground:#FBFAF6; --paper:#FFFFFF;
  --ink:#0C2722; --ink-soft:#46574F; --ink-faint:#8A988F; --line:#DDE5E0;
  --brand:#009E83; --brand-50:#EAF6F1; --brand-100:#C4EFD8; --brand-700:#017A66; --brand-deep:#033932;
  --teal:#3ABAB4; --teal-200:#95D7D1;
  --warm:#E2552E; --warm-soft:#FCEDE6; --amber:#E8A33D; --amber-soft:#FBF1DE;
  --success:#0E8A5F; --rose:#C2466A;
  --honda:#C8102E; --acura:#1A1F2B; --geely:#1C6FB8; --motos:#E27121;
  --f-display:'Bahia Motors',-apple-system,"Segoe UI",system-ui,sans-serif;
  --f-body:'DM Sans',-apple-system,"Segoe UI",system-ui,sans-serif;
  --f-mono:'DM Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --shadow:0 6px 20px rgba(3,57,50,.08);
  --shadow-soft:0 2px 10px rgba(3,57,50,.05);
  --r:14px; --r-sm:10px; --r-lg:20px;
  --sidebar-w:248px; --aside-w:344px; --maxw:1320px;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:var(--f-body); background:var(--ground); color:var(--ink);
  font-size:15px; line-height:1.5; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  font-variant-numeric:tabular-nums;
}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
img{max-width:100%;display:block;}
.mono{font-family:var(--f-mono);font-variant-numeric:tabular-nums;}
.disp{font-family:var(--f-display);}
::selection{background:var(--brand-100);color:var(--brand-deep);}
:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(0,158,131,.35);border-radius:6px;}
::-webkit-scrollbar{width:11px;height:11px;}
::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px;border:3px solid var(--ground);}

/* ---------- LOGIN ---------- */
.login{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;
  background:radial-gradient(120% 120% at 70% 10%, #06463C 0%, #033932 45%, #022a25 100%);
  padding:24px;transition:opacity .45s ease, visibility .45s;}
.login.hide{opacity:0;visibility:hidden;}
.login-card{width:min(420px,100%);text-align:center;color:#EAF6F1;}
.login .mark{width:62px;height:62px;margin:0 auto 22px;filter:drop-shadow(0 8px 24px rgba(0,0,0,.35));}
.login h1{font-family:var(--f-display);font-weight:700;font-size:34px;letter-spacing:-.01em;margin:0 0 10px;color:#fff;}
.login p{color:#9FC4BA;font-size:15px;margin:0 auto 26px;max-width:300px;line-height:1.45;}
.login-field{display:flex;flex-direction:column;gap:12px;}
.login input{font-family:var(--f-body);font-size:15px;letter-spacing:.01em;text-align:left;
  padding:14px 16px;border-radius:12px;border:1.5px solid rgba(255,255,255,.16);background:rgba(255,255,255,.06);color:#fff;
  transition:border-color .2s, box-shadow .2s;}
.login input::placeholder{color:#5e7a72;}
.login input:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(0,158,131,.3);}
.login.err input{animation:shake .4s;}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-8px)}40%{transform:translateX(8px)}60%{transform:translateX(-5px)}80%{transform:translateX(5px)}}
.login button.enter{padding:15px;border-radius:12px;background:var(--brand);color:#fff;font-weight:700;font-size:15px;
  transition:transform .12s, background .2s, box-shadow .2s;box-shadow:0 8px 20px rgba(0,158,131,.28);}
.login button.enter:hover{background:#00b394;}
.login button.enter:active{transform:translateY(2px);box-shadow:0 3px 10px rgba(0,158,131,.3);}
.login .hint{margin-top:18px;font-size:12.5px;color:#5e7a72;font-family:var(--f-mono);letter-spacing:.02em;}
.login .err-msg{color:#FFB59E;font-size:13.5px;min-height:18px;margin-top:14px;opacity:0;transition:opacity .2s;}
.login.err .err-msg{opacity:1;}

/* ---------- SHELL ---------- */
.app{display:none;}
.app.on{display:block;}
.layout{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;}

/* sidebar */
.sidebar{position:sticky;top:0;height:100vh;background:var(--brand-deep);color:#CDE5DD;
  display:flex;flex-direction:column;padding:20px 14px;gap:4px;}
.sidebar .brand{display:flex;align-items:center;gap:11px;padding:6px 8px 20px;}
.sidebar .brand .mark{width:34px;height:34px;}
.sidebar .brand b{font-family:var(--f-display);font-weight:700;font-size:18px;color:#fff;letter-spacing:-.01em;}
.nav{display:flex;flex-direction:column;gap:2px;margin-top:6px;}
.nav a{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:10px;font-size:14.5px;font-weight:500;
  color:#9FC4BA;transition:background .16s,color .16s;}
.nav a .ic{width:18px;height:18px;flex:0 0 18px;opacity:.85;}
.nav a:hover{background:rgba(255,255,255,.06);color:#EAF6F1;}
.nav a.active{background:#fff;color:var(--brand-deep);font-weight:700;}
.nav a.active .ic{opacity:1;}
.nav .badge{margin-left:auto;background:var(--warm);color:#fff;font-family:var(--f-mono);font-size:11px;font-weight:500;
  padding:1px 7px;border-radius:20px;}
.nav a.active .badge{background:var(--warm);}
.side-user{margin-top:auto;display:flex;align-items:center;gap:11px;padding:12px 10px;border-top:1px solid rgba(255,255,255,.1);}
.side-user .av{width:36px;height:36px;}
.side-user .nm{font-size:13.5px;font-weight:600;color:#EAF6F1;line-height:1.2;}
.side-user .rl{font-size:11.5px;color:#7FA89D;}

/* main */
.main-col{min-width:0;display:flex;flex-direction:column;}
.topbar{position:sticky;top:0;z-index:50;height:62px;background:rgba(251,250,246,.86);backdrop-filter:saturate(1.4) blur(10px);
  border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;padding:0 26px;}
.topbar .menu-btn{display:none;}
.topbar .wm{display:none;align-items:center;gap:9px;}
.topbar .wm .mark{width:26px;height:26px;}
.topbar .wm b{font-family:var(--f-display);font-weight:700;font-size:16px;color:var(--brand-deep);}
.search{flex:1;min-width:0;max-width:440px;display:flex;align-items:center;gap:9px;background:var(--paper);border:1px solid var(--line);
  border-radius:11px;padding:9px 13px;color:var(--ink-faint);transition:border-color .18s,box-shadow .18s;}
.search:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px rgba(0,158,131,.12);}
.search input{border:none;background:none;flex:1;min-width:0;width:100%;font-size:14px;color:var(--ink);}
.search input::placeholder{color:var(--ink-faint);}
.search .ic{width:17px;height:17px;color:var(--ink-faint);}
.topbar .spacer{flex:1;}
.topbar .dateline{font-family:var(--f-mono);font-size:11px;font-weight:500;letter-spacing:.13em;color:var(--ink-faint);}
.topbar .bell{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;color:var(--ink-soft);position:relative;}
.topbar .bell:hover{background:var(--brand-50);}
.topbar .bell .dot{position:absolute;top:9px;right:10px;width:7px;height:7px;border-radius:50%;background:var(--warm);border:1.5px solid var(--ground);}
.topbar .av{width:38px;height:38px;}

.av{border-radius:50%;display:grid;place-items:center;font-family:var(--f-body);font-weight:700;color:#fff;font-size:13px;
  background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%);flex:0 0 auto;letter-spacing:.02em;}

/* content grid */
.home{max-width:var(--maxw);margin:0 auto;width:100%;padding:26px 26px 60px;
  display:grid;grid-template-columns:minmax(0,1fr) var(--aside-w);gap:22px 26px;align-items:start;
  grid-template-areas:"hero hero" "portada aside" "pulso aside" "hoy aside" "noticias aside" "folio folio";}
.hero{grid-area:hero;} .portada-wrap{grid-area:portada;} .pulso{grid-area:pulso;}
.hoy{grid-area:hoy;} .noticias{grid-area:noticias;} .aside{grid-area:aside;} .folio{grid-area:folio;}
.aside{position:sticky;top:84px;display:flex;flex-direction:column;gap:18px;}

/* anim base */
.reveal{opacity:0;transform:translateY(9px);}
.app.run .reveal{opacity:1;transform:none;transition:opacity .5s ease, transform .5s cubic-bezier(.2,.7,.2,1);}
.app.run .reveal.d1{transition-delay:.30s}.app.run .reveal.d2{transition-delay:.38s}
.app.run .reveal.d3{transition-delay:.46s}.app.run .reveal.d4{transition-delay:.54s}.app.run .reveal.d5{transition-delay:.62s}

/* ---------- HERO ---------- */
.kicker{font-family:var(--f-mono);font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--brand-700);}
.hero h1{font-family:var(--f-display);font-weight:700;font-size:clamp(26px,4.6vw,38px);letter-spacing:-.01em;line-height:1.05;
  margin:8px 0 6px;color:var(--ink);}
.hero .role{font-size:15px;color:var(--ink-soft);font-weight:500;}
.hero .lead{font-size:clamp(16px,2.2vw,19px);color:var(--ink);margin:12px 0 0;max-width:640px;line-height:1.4;}
.hero .lead b{color:var(--warm);font-weight:700;}
.hero .stats{font-family:var(--f-mono);font-size:12px;color:var(--ink-faint);margin-top:10px;letter-spacing:.01em;}
.flash{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;}
.flash a{display:inline-flex;align-items:center;gap:7px;background:var(--warm-soft);color:#9A3414;font-size:13px;font-weight:600;
  padding:7px 13px;border-radius:30px;border:1px solid #F6D9CC;transition:transform .12s;}
.flash a:hover{transform:translateY(-1px);}
.flash a .em{font-size:14px;}
.rule{height:2px;background:var(--brand);border:none;margin:18px 0 0;width:56px;border-radius:2px;}

/* ---------- PORTADA ---------- */
.portada{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);}
.cover{position:relative;height:230px;overflow:hidden;
  background:linear-gradient(135deg,#022a25 0%,#034a3f 42%,#0b6d6a 78%,#1C6FB8 140%);}
.cover .speed{position:absolute;inset:0;opacity:.5;
  background:repeating-linear-gradient(115deg,transparent 0 38px,rgba(149,215,209,.10) 38px 40px);}
.cover .glow{position:absolute;width:340px;height:340px;right:-70px;top:-120px;border-radius:50%;
  background:radial-gradient(circle,rgba(58,186,180,.55),transparent 65%);filter:blur(8px);}
.cover .wm{position:absolute;right:18px;bottom:-30px;width:190px;opacity:.16;filter:brightness(0) invert(1);}
.cover .ev{position:absolute;left:0;right:0;bottom:26px;height:74px;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.18));
  clip-path:polygon(8% 100%,16% 44%,30% 30%,46% 22%,64% 26%,80% 40%,90% 64%,94% 100%);
  background-color:rgba(2,30,26,.5);}
.cover .badge-new{position:absolute;left:20px;top:18px;background:var(--brand);color:#fff;font-family:var(--f-mono);
  font-size:10.5px;font-weight:500;letter-spacing:.12em;padding:5px 10px;border-radius:6px;}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:6px;
  letter-spacing:.02em;border:1.5px solid currentColor;}
.portada .body{padding:20px 24px 24px;}
.portada .meta{display:flex;align-items:center;gap:10px;margin-bottom:11px;}
.portada .meta .ago{font-family:var(--f-mono);font-size:12px;color:var(--ink-faint);}
.portada h2{font-family:var(--f-display);font-weight:700;font-size:clamp(24px,3.6vw,34px);line-height:1.04;letter-spacing:-.015em;
  margin:0 0 10px;color:var(--ink);}
.portada p{font-size:15.5px;color:var(--ink-soft);margin:0 0 18px;max-width:60ch;line-height:1.5;}
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--brand-deep);color:#fff;font-weight:600;font-size:14px;
  padding:11px 18px;border-radius:10px;transition:transform .12s,background .18s;}
.btn:hover{background:#055247;transform:translateY(-1px);}
.btn:active{transform:translateY(1px) scale(.99);}
.btn.ghost{background:var(--brand-50);color:var(--brand-700);}
.btn.ghost:hover{background:var(--brand-100);}

/* section heads */
.shead{display:flex;align-items:center;justify-content:space-between;margin:0 0 14px;gap:12px;}
.shead h3{font-family:var(--f-display);font-weight:700;font-size:22px;letter-spacing:-.005em;margin:0;color:var(--ink);}
.shead h3 .em{font-size:18px;margin-right:6px;}
.shead a.more{font-size:13px;font-weight:600;color:var(--brand-700);white-space:nowrap;}
.shead a.more:hover{text-decoration:underline;}
.sec{margin-top:6px;}

/* ---------- PULSO / ODÓMETRO ---------- */
.odo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.odo{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:15px 16px;box-shadow:var(--shadow-soft);
  transition:transform .12s,box-shadow .18s;position:relative;overflow:hidden;}
.odo:hover{transform:translateY(-2px);box-shadow:var(--shadow);}
.odo .lbl{font-size:12px;color:var(--ink-soft);font-weight:500;min-height:30px;line-height:1.25;}
.odo .val{font-family:var(--f-mono);font-weight:500;font-size:clamp(26px,3vw,32px);letter-spacing:-.02em;color:var(--ink);margin-top:6px;line-height:1;}
.odo .val .u{font-size:13px;color:var(--ink-faint);font-weight:400;margin-left:4px;letter-spacing:0;}
.odo .delta{display:inline-flex;align-items:center;gap:4px;font-family:var(--f-mono);font-size:12px;font-weight:500;margin-top:9px;}
.odo .delta.up{color:var(--success);} .odo .delta.flat{color:var(--ink-faint);}
.odo .delta .new{background:var(--brand-100);color:var(--brand-deep);padding:2px 7px;border-radius:5px;font-size:10.5px;letter-spacing:.06em;}
.odo .bar{height:5px;border-radius:4px;background:var(--brand-50);margin-top:11px;overflow:hidden;}
.odo .bar i{display:block;height:100%;width:0;background:var(--brand);border-radius:4px;transition:width 1s cubic-bezier(.2,.7,.2,1);}
.pulso-row2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px;}
.tile-vac,.tile-apr{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-soft);}
.arc{position:relative;width:78px;height:78px;flex:0 0 78px;}
.arc svg{transform:rotate(-90deg);}
.arc .ring-bg{fill:none;stroke:var(--brand-50);stroke-width:8;}
.arc .ring-fg{fill:none;stroke:var(--brand);stroke-width:8;stroke-linecap:round;stroke-dasharray:220;stroke-dashoffset:220;transition:stroke-dashoffset 1.1s cubic-bezier(.2,.7,.2,1);}
.arc .ctr{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--f-mono);font-weight:500;font-size:17px;color:var(--ink);}
.tile-vac .t-lbl,.tile-apr .t-lbl{font-size:13px;color:var(--ink-soft);font-weight:500;}
.tile-vac .t-val{font-family:var(--f-display);font-weight:700;font-size:19px;color:var(--ink);margin-top:2px;}
.tile-apr{justify-content:space-between;}
.tile-apr .big{font-family:var(--f-mono);font-weight:500;font-size:38px;color:var(--ink);line-height:1;}
.tile-apr .warn{display:inline-flex;align-items:center;gap:6px;background:var(--warm-soft);color:#9A3414;font-size:11.5px;font-weight:600;padding:4px 9px;border-radius:20px;margin-top:8px;}

/* ---------- HOY EN BAHÍA ---------- */
.hoy-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:18px;box-shadow:var(--shadow-soft);}
.card .ch{font-family:var(--f-mono);font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-faint);font-weight:500;margin-bottom:13px;}
.bday{display:flex;flex-direction:column;align-items:center;text-align:center;}
.bday .ring{position:relative;width:84px;height:84px;margin-bottom:12px;}
.bday .ring .av{width:84px;height:84px;font-size:26px;background:linear-gradient(135deg,#FF8A5E,#E2552E);}
.bday .ring::after{content:"";position:absolute;inset:-6px;border-radius:50%;border:2.5px solid var(--warm);opacity:.55;}
.app.run .bday .ring::after{animation:breathe 3.5s ease-in-out infinite;}
@keyframes breathe{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.06);opacity:.18}}
.bday .nm{font-family:var(--f-display);font-weight:700;font-size:19px;color:var(--ink);}
.bday .rl{font-size:13px;color:var(--ink-soft);margin-top:2px;}
.bday .btn-cele{margin-top:14px;display:inline-flex;align-items:center;gap:8px;background:var(--warm);color:#fff;font-weight:700;font-size:14px;
  padding:10px 20px;border-radius:30px;transition:transform .12s,background .2s;}
.bday .btn-cele:hover{transform:translateY(-1px);}
.bday .btn-cele:active{transform:scale(.97);}
.bday .btn-cele.done{background:var(--success);}
.bday .more{margin-top:14px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.bday .more .mini{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--ink-soft);}
.bday .more .av{width:26px;height:26px;font-size:10px;}

.claps{display:flex;flex-direction:column;gap:13px;}
.clap{display:flex;gap:12px;}
.clap .av{width:38px;height:38px;font-size:12px;}
.clap.gold .av{background:linear-gradient(135deg,#FF8A5E,#E2552E);}
.clap .c-body{flex:1;min-width:0;}
.clap .c-top{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;}
.clap .c-to{font-weight:700;font-size:14px;color:var(--ink);}
.clap .c-of{font-size:11.5px;color:var(--ink-faint);}
.clap .c-of b{color:var(--ink-soft);font-weight:600;}
.clap .c-day{background:var(--warm-soft);color:#9A3414;font-size:10px;font-weight:700;letter-spacing:.04em;padding:2px 7px;border-radius:5px;}
.clap .c-reason{font-size:13px;color:var(--ink-soft);margin:3px 0 7px;line-height:1.4;}
.clap-act{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--brand-700);
  background:var(--brand-50);padding:5px 12px;border-radius:20px;transition:background .18s,color .18s,transform .12s;}
.clap-act:hover{background:var(--brand-100);}
.clap-act:active{transform:scale(.96);}
.clap-act.on{background:var(--warm);color:#fff;}
.clap-act .n{font-family:var(--f-mono);}

.hoy-grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px;}
.hires{display:flex;flex-direction:column;gap:11px;}
.hire{display:flex;align-items:center;gap:11px;}
.hire .av{width:38px;height:38px;font-size:12px;}
.hire .h-nm{font-weight:600;font-size:14px;color:var(--ink);line-height:1.2;}
.hire .h-rl{font-size:12px;color:var(--ink-soft);}
.hire .welcome{margin-left:auto;font-size:12px;font-weight:600;color:var(--brand-700);background:var(--brand-50);
  padding:6px 11px;border-radius:20px;white-space:nowrap;transition:background .18s,transform .12s;}
.hire .welcome:hover{background:var(--brand-100);}
.hire .welcome.done{background:var(--success);color:#fff;}
.leave{display:flex;flex-direction:column;gap:11px;}
.leave .lv{display:flex;align-items:center;gap:11px;}
.leave .av{width:34px;height:34px;font-size:11px;background:linear-gradient(135deg,var(--teal),var(--brand-700));opacity:.92;}
.leave .l-nm{font-weight:600;font-size:13.5px;color:var(--ink);}
.leave .l-until{font-size:12px;color:var(--ink-faint);font-family:var(--f-mono);}

/* ---------- NOTICIAS ---------- */
.news{display:flex;flex-direction:column;}
.news .item{display:flex;gap:16px;padding:16px 0;border-top:1px solid var(--line);align-items:flex-start;transition:padding-left .18s;}
.news .item:first-child{border-top:none;}
.news .item:hover{padding-left:5px;}
.news .thumb{flex:0 0 96px;height:70px;border-radius:10px;overflow:hidden;position:relative;}
.news .thumb .sp{position:absolute;inset:0;opacity:.4;background:repeating-linear-gradient(115deg,transparent 0 16px,rgba(255,255,255,.14) 16px 18px);}
.news .n-body{flex:1;min-width:0;}
.news .n-meta{display:flex;align-items:center;gap:9px;margin-bottom:5px;}
.news .n-meta .ago{font-family:var(--f-mono);font-size:11px;color:var(--ink-faint);}
.news h4{font-family:var(--f-display);font-weight:700;font-size:16.5px;line-height:1.2;margin:0 0 4px;color:var(--ink);}
.news p{font-size:13.5px;color:var(--ink-soft);margin:0;line-height:1.45;}

/* ---------- ASIDE ---------- */
.panel{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-soft);overflow:hidden;}
.panel .p-head{display:flex;align-items:center;justify-content:space-between;padding:15px 17px;border-bottom:1px solid var(--line);}
.panel .p-head h3{font-family:var(--f-display);font-weight:700;font-size:16px;margin:0;color:var(--ink);}
.panel .p-head .cnt{font-family:var(--f-mono);font-size:12px;color:#fff;background:var(--warm);padding:2px 9px;border-radius:20px;font-weight:500;}
.tiles{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--line);}
.tile{background:var(--paper);padding:15px 8px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;
  transition:background .16s,transform .1s;position:relative;}
.tile:hover{background:var(--brand-50);}
.tile:active{transform:scale(.97);}
.tile .ic{width:22px;height:22px;color:var(--brand-700);}
.tile .tl{font-size:11.5px;font-weight:600;color:var(--ink-soft);line-height:1.2;}
.tile .badge{position:absolute;top:8px;right:14px;background:var(--warm);color:#fff;font-family:var(--f-mono);font-size:10px;
  padding:0 6px;border-radius:20px;font-weight:500;}

.inbox{display:flex;flex-direction:column;}
.inbox .row{padding:14px 17px;border-top:1px solid var(--line);transition:background .16s;}
.inbox .row:first-child{border-top:none;}
.inbox .row.done{opacity:.5;}
.inbox .r-top{display:flex;align-items:center;gap:9px;margin-bottom:6px;}
.inbox .r-top .av{width:30px;height:30px;font-size:10.5px;}
.inbox .r-type{font-weight:700;font-size:13.5px;color:var(--ink);}
.inbox .r-person{font-size:11.5px;color:var(--ink-faint);}
.inbox .due{margin-left:auto;font-family:var(--f-mono);font-size:10.5px;font-weight:500;padding:3px 8px;border-radius:6px;white-space:nowrap;}
.inbox .due.hoy{background:var(--warm-soft);color:#9A3414;}
.inbox .due.manana{background:var(--amber-soft);color:#8A5A12;}
.inbox .due.normal{background:var(--brand-50);color:var(--brand-700);}
.inbox .r-detail{font-size:12.5px;color:var(--ink-soft);line-height:1.4;margin:0 0 10px;}
.inbox .r-detail .amt{font-family:var(--f-mono);color:var(--ink);font-weight:500;}
.inbox .r-act{display:flex;gap:8px;}
.inbox .approve{flex:1;background:var(--brand-deep);color:#fff;font-weight:600;font-size:13px;padding:8px;border-radius:8px;
  display:inline-flex;align-items:center;justify-content:center;gap:7px;transition:background .18s,transform .1s;}
.inbox .approve:hover{background:#055247;}
.inbox .approve:active{transform:scale(.98);}
.inbox .approve.done{background:var(--success);}
.inbox .open{background:var(--brand-50);color:var(--brand-700);padding:8px 13px;border-radius:8px;font-size:13px;font-weight:600;}
.inbox .p-foot{padding:12px 17px;border-top:1px solid var(--line);text-align:center;}
.inbox .p-foot a{font-size:13px;font-weight:600;color:var(--brand-700);}

.mine{display:flex;flex-direction:column;}
.mine .m{padding:13px 17px;border-top:1px solid var(--line);}
.mine .m:first-child{border-top:none;}
.mine .m-top{display:flex;align-items:center;gap:8px;margin-bottom:7px;}
.mine .m-type{font-size:13px;font-weight:600;color:var(--ink);line-height:1.25;}
.mine .st{margin-left:auto;font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:5px;white-space:nowrap;}
.mine .st.rev{background:var(--amber-soft);color:#8A5A12;}
.mine .st.apr{background:var(--brand-100);color:var(--brand-deep);}
.mine .steps{display:flex;align-items:center;gap:5px;}
.mine .seg{height:5px;flex:1;border-radius:3px;background:var(--brand-50);overflow:hidden;}
.mine .seg.fill{background:var(--brand);}
.mine .s-lbl{font-size:11.5px;color:var(--ink-soft);margin-top:6px;}
.mine .s-lbl.ok{color:var(--success);font-weight:600;}

.dir .p-body{padding:15px 17px;}
.dir .ppl{display:flex;flex-direction:column;gap:11px;margin-top:13px;}
.dir .pp{display:flex;align-items:center;gap:10px;transition:transform .12s;}
.dir .pp:hover{transform:translateX(2px);}
.dir .pp .av{width:34px;height:34px;font-size:11px;}
.dir .pp .d-nm{font-size:13.5px;font-weight:600;color:var(--ink);line-height:1.2;}
.dir .pp .d-rl{font-size:11.5px;color:var(--ink-faint);}

/* ---------- FOLIO ---------- */
.folio{text-align:center;padding:30px 0 0;border-top:1px solid var(--line);margin-top:8px;color:var(--ink-faint);font-size:13px;}
.folio .mk{width:24px;height:24px;margin:0 auto 10px;opacity:.5;}

/* confetti */
.confetti{position:fixed;pointer-events:none;z-index:900;}
.confetti span{position:absolute;width:8px;height:8px;border-radius:1px;opacity:0;}

/* ---------- RESPONSIVE ---------- */
@media (max-width:1080px){
  :root{--sidebar-w:0px;}
  .sidebar{display:none;}
  .layout{grid-template-columns:1fr;}
  .topbar .menu-btn{display:grid;place-items:center;width:40px;height:40px;border-radius:10px;color:var(--ink-soft);}
  .topbar .wm{display:flex;}
  .topbar .dateline{display:none;}
  .home{grid-template-columns:1fr;display:flex;flex-direction:column;}
  .hero{order:0}.portada-wrap{order:1}.pulso{order:2}.hoy{order:3}.aside{order:4}.noticias{order:5}.folio{order:6}
  .aside{position:static;}
  .search{max-width:none;}
}
@media (max-width:560px){
  .home{padding:18px 15px 50px;}
  .odo-grid{grid-template-columns:1fr 1fr;}
  .hoy-grid,.hoy-grid2,.pulso-row2{grid-template-columns:1fr;}
  .topbar{padding:0 12px;gap:8px;}
  .topbar .bell{display:none;}
  .topbar .wm b{display:none;}
  .cover{height:185px;}
  .portada .body{padding:18px 18px 20px;}
}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none!important;}
  .arc .ring-fg{transition:none!important;}
  .odo .bar i{transition:none!important;}
  .bday .ring::after{animation:none!important;}
}
/* ============================================================
   SUPLEMENTO — páginas internas (directorio, noticias, solicitudes, etc.)
   ============================================================ */
.home.page{display:block;max-width:1080px;margin:0 auto;}
.page-head{display:flex;gap:14px;align-items:flex-start;margin-bottom:24px;}
.page-title{font-family:var(--f-display);font-weight:700;font-size:clamp(24px,4vw,32px);letter-spacing:-.01em;margin:0;color:var(--ink);}
.page-sub{color:var(--ink-soft);font-size:15px;margin:4px 0 0;}
.back-link{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:var(--paper);border:1px solid var(--line);color:var(--ink-soft);flex:0 0 40px;transition:background .16s;}
.back-link:hover{background:var(--brand-50);color:var(--brand-700);}
.empty-state{text-align:center;padding:60px 20px;color:var(--ink-faint);}
.empty-state img{width:40px;opacity:.4;margin:0 auto 14px;}
.empty-state p{font-size:15px;}
.empty-inline{color:var(--ink-faint);font-size:13.5px;padding:6px 0;}

/* filtros */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px;}
.filter{font-size:13px;font-weight:600;padding:8px 14px;border-radius:30px;background:var(--paper);border:1px solid var(--line);color:var(--ink-soft);transition:all .16s;cursor:pointer;}
.filter:hover{border-color:var(--brand);color:var(--brand-700);}
.filter.on{background:var(--brand-deep);color:#fff;border-color:var(--brand-deep);}

/* directorio */
.dir-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;}
.dir-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:18px;display:flex;gap:14px;align-items:center;box-shadow:var(--shadow-soft);transition:transform .12s,box-shadow .18s;}
.dir-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);}
.dir-card .av{width:52px;height:52px;font-size:17px;flex:0 0 52px;}
.dir-card .dc-nm{font-weight:700;font-size:15px;color:var(--ink);line-height:1.2;}
.dir-card .dc-rl{font-size:13px;color:var(--ink-soft);margin-top:2px;}
.dir-card .dc-br{font-size:12px;color:var(--ink-faint);font-family:var(--f-mono);margin-top:4px;}

/* lista genérica */
.list{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-soft);overflow:hidden;}
.list-row{display:flex;gap:14px;align-items:center;padding:16px 18px;border-top:1px solid var(--line);transition:background .14s;}
.list-row:first-child{border-top:none;}
.list-row:hover{background:var(--brand-50);}
.list-row .lr-main{flex:1;min-width:0;}
.list-row .lr-t{font-weight:600;font-size:14.5px;color:var(--ink);}
.list-row .lr-s{font-size:12.5px;color:var(--ink-soft);margin-top:2px;}

/* catálogo de solicitudes */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;}
.cat-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:20px;box-shadow:var(--shadow-soft);transition:transform .12s,box-shadow .18s,border-color .18s;display:block;}
.cat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--brand);}
.cat-card .cc-ic{width:44px;height:44px;border-radius:12px;background:var(--brand-50);color:var(--brand-700);display:grid;place-items:center;margin-bottom:14px;font-size:20px;}
.cat-card .cc-cat{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);}
.cat-card h4{font-family:var(--f-display);font-weight:700;font-size:17px;margin:4px 0 6px;color:var(--ink);}
.cat-card p{font-size:13px;color:var(--ink-soft);margin:0;line-height:1.45;}

/* formularios */
.form{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:24px;box-shadow:var(--shadow-soft);max-width:640px;}
.field{margin-bottom:18px;}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:7px;}
.field input,.field textarea,.field select{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;font-size:14.5px;color:var(--ink);background:var(--ground);font-family:var(--f-body);transition:border-color .16s,box-shadow .16s;}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(0,158,131,.12);background:var(--paper);}
.field textarea{min-height:90px;resize:vertical;}
.field .req{color:var(--warm);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.btn-row{display:flex;gap:10px;margin-top:8px;}
.btn-lg{padding:13px 22px;font-size:15px;}
.wf-steps{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0 22px;}
.wf-step{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:var(--ink-soft);background:var(--brand-50);padding:6px 12px;border-radius:20px;}
.wf-step .n{width:18px;height:18px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-family:var(--f-mono);font-size:11px;}

/* detalle (noticia / empleado) */
.detail{max-width:760px;}
.detail .cover-lg{height:300px;border-radius:var(--r-lg);overflow:hidden;position:relative;margin-bottom:24px;background-size:cover;background-position:center;}
.detail h1{font-family:var(--f-display);font-weight:700;font-size:clamp(26px,4.4vw,40px);line-height:1.06;letter-spacing:-.015em;margin:0 0 12px;color:var(--ink);}
.detail .dek{font-size:18px;color:var(--ink-soft);line-height:1.5;margin:0 0 20px;}
.detail .meta{display:flex;align-items:center;gap:10px;margin-bottom:16px;}
.detail .article{font-size:16px;line-height:1.7;color:var(--ink);}
.detail .article p{margin:0 0 16px;}
.detail .article b{color:var(--ink);font-weight:700;}

/* perfil */
.prof-hero{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;display:flex;gap:22px;align-items:center;box-shadow:var(--shadow-soft);margin-bottom:20px;flex-wrap:wrap;}
.prof-hero .av{width:88px;height:88px;font-size:30px;flex:0 0 88px;}
.prof-hero .ph-nm{font-family:var(--f-display);font-weight:700;font-size:26px;color:var(--ink);}
.prof-hero .ph-rl{font-size:15px;color:var(--ink-soft);margin-top:3px;}
.prof-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;}
.prof-item{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;}
.prof-item .pi-l{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);}
.prof-item .pi-v{font-size:15px;color:var(--ink);font-weight:500;margin-top:5px;}

/* beneficios */
.bf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;}
.bf-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:22px;box-shadow:var(--shadow-soft);transition:transform .12s,box-shadow .18s;}
.bf-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);}
.bf-card .bf-ic{width:46px;height:46px;border-radius:12px;background:var(--brand-100);color:var(--brand-deep);display:grid;place-items:center;font-size:22px;margin-bottom:14px;}
.bf-card .bf-cat{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--brand-700);}
.bf-card h4{font-family:var(--f-display);font-weight:700;font-size:17px;margin:4px 0 7px;color:var(--ink);}
.bf-card p{font-size:13.5px;color:var(--ink-soft);margin:0;line-height:1.5;}

/* bandeja completa */
.appr-row{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:18px;box-shadow:var(--shadow-soft);margin-bottom:12px;transition:opacity .3s;}
.appr-row.done{opacity:.5;}
.appr-row .ar-top{display:flex;align-items:center;gap:12px;margin-bottom:12px;}
.appr-row .ar-type{font-family:var(--f-display);font-weight:700;font-size:16px;color:var(--ink);}
.appr-row .ar-detail{font-size:14px;color:var(--ink-soft);line-height:1.5;margin:0 0 14px;}

/* drawer móvil */
@media (max-width:1080px){
  body.drawer .sidebar{display:flex;position:fixed;top:0;bottom:0;left:0;width:260px;z-index:200;box-shadow:4px 0 24px rgba(0,0,0,.2);}
  .drawer-backdrop{display:none;position:fixed;inset:0;z-index:199;background:rgba(3,57,50,.5);}
  body.drawer .drawer-backdrop{display:block;}
  .form-row{grid-template-columns:1fr;}
}
