/* =====================================================
   Intranet Evolia — Sistema visual rediseño 2026
   Tokens, shell, componentes reutilizables.
   Inspirado en evolia.es: Geist + Instrument Serif + JetBrains Mono.
   ===================================================== */

:root{
  --bg:#f3f1ea; --panel:#fff; --paper-2:#ebe7da;
  --ink:#0a0a0c; --ink-2:#1d1d22;
  --muted:#6b6859; --rule:#e3dfd2; --rule-2:#d9d4c2;
  --accent:#1b17ff; --accent-soft:rgba(27,23,255,.08);
  --good:#0e8a4a; --warn:#b86618; --bad:#c12a2a;

  --serif:'Instrument Serif',serif;
  --sans:'Geist',system-ui,-apple-system,Segoe UI,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,Menlo,monospace;

  --side-w:240px;
  --pad-x:32px;
  --safe-bottom:env(safe-area-inset-bottom,0px);

  --r-sm:6px; --r-md:8px; --r-lg:12px; --r-xl:14px;
}

*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:14px;-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;color:inherit}
img,svg{max-width:100%}
::selection{background:var(--accent);color:#fff}

/* ============== APP SHELL ============== */
.app{display:grid;grid-template-columns:var(--side-w) minmax(0,1fr);min-height:100vh}

/* ============== SIDEBAR ============== */
.side{background:var(--ink);color:var(--bg);padding:18px 0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:30}
.side-head{padding:0 22px 22px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px}
.side-logo{height:24px;color:var(--accent);flex-shrink:0}
.side-brand{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.5);line-height:1.4}
.side-close{display:none;margin-left:auto;background:none;border:0;width:32px;height:32px;color:rgba(255,255,255,.7);font-size:22px;cursor:pointer;border-radius:6px;line-height:1}
.side-close:hover{background:rgba(255,255,255,.06);color:#fff}
.side-section{padding:18px 22px 6px;font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.35)}
.nav{padding:4px 12px;display:flex;flex-direction:column;gap:2px}
.nav a{display:flex;align-items:center;gap:12px;padding:9px 10px;border-radius:6px;font-size:13px;color:rgba(255,255,255,.7);transition:all .12s;position:relative;min-height:36px}
.nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.nav a.active{background:var(--accent);color:#fff;font-weight:500}
.nav-badge{margin-left:auto;font-family:var(--mono);font-size:10px;background:var(--accent);color:#fff;padding:2px 6px;border-radius:8px;font-weight:500}
.nav a.active .nav-badge{background:#fff;color:var(--accent)}
.nav a:not(.active) .nav-badge{background:rgba(255,255,255,.1);color:rgba(255,255,255,.7)}
.nav-badge.danger{background:var(--bad)}
.side-foot{margin-top:auto;padding:18px 22px calc(18px + var(--safe-bottom));border-top:1px solid rgba(255,255,255,.08);font-size:12px;display:flex;align-items:center;gap:10px}
.avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;flex-shrink:0;text-transform:uppercase}
.me-name{font-weight:500;color:#fff;line-height:1.2}
.me-role{font-family:var(--mono);font-size:10px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.1em;margin-top:2px}

/* Branding pie de sidebar (logo Evolia) */
.side-evolia{padding:14px 22px calc(16px + var(--safe-bottom));border-top:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;align-items:flex-start;gap:6px}
.side-evolia-logo{height:18px;width:auto;opacity:.85}
.side-evolia-meta{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.4)}

/* Drawer scrim */
.scrim{display:none;position:fixed;inset:0;background:rgba(10,10,12,.5);z-index:25;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}
.scrim.open{display:block}

/* ============== MAIN ============== */
.main{padding:24px var(--pad-x) 64px;min-width:0}

/* Top bar */
.topbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px}
.top-left{display:flex;align-items:center;gap:12px;min-width:0;flex:1}
.menu-btn{display:none;width:38px;height:38px;border:1px solid var(--rule);background:#fff;border-radius:8px;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;color:var(--ink)}
.menu-btn svg{width:18px;height:18px}
.crumb{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:flex;gap:10px;align-items:center;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.crumb .sep{color:var(--rule-2)}
.top-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}
.search{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#fff;border:1px solid var(--rule);border-radius:8px;width:300px;font-size:13px;color:var(--muted);cursor:pointer}
.search:hover{border-color:var(--ink)}
.search kbd{margin-left:auto;font-family:var(--mono);font-size:10px;background:var(--bg);padding:2px 6px;border:1px solid var(--rule);border-radius:3px;flex-shrink:0}
.search-mobile{display:none}
.icon-btn{width:38px;height:38px;border:1px solid var(--rule);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:8px;color:var(--ink);position:relative;flex-shrink:0}
.icon-btn:hover{border-color:var(--ink)}
.icon-btn svg{width:16px;height:16px}
.icon-btn .badge{position:absolute;top:7px;right:7px;width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 2px #fff}

/* ============== GREETING + CLOCK ============== */
.greet{display:grid;grid-template-columns:1.2fr 1fr;gap:20px;margin-bottom:24px}
.greet-card{background:linear-gradient(135deg,var(--ink) 0%,#1a1a22 100%);color:var(--bg);padding:28px 32px;border-radius:14px;position:relative;overflow:hidden}
.greet-card::after{content:'';position:absolute;right:-40px;top:-40px;width:280px;height:220px;background:var(--accent);clip-path:polygon(55% 0,100% 0,45% 100%,0 100%);opacity:.18;pointer-events:none}
.greet-eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:10px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.greet-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--good);box-shadow:0 0 0 4px rgba(14,138,74,.25);flex-shrink:0}
.greet-eyebrow .dot.muted{background:#999;box-shadow:0 0 0 4px rgba(153,153,153,.2)}
.greet-eyebrow .dot.live{background:var(--accent);box-shadow:0 0 0 4px rgba(27,23,255,.25)}
.greet-h{font-family:var(--serif);font-size:clamp(30px,5vw,42px);line-height:1.05;margin:0;font-weight:400;letter-spacing:-.01em}
.greet-h em{font-style:italic;color:var(--accent)}
.greet-sub{margin:14px 0 0;font-size:14px;color:rgba(255,255,255,.7);line-height:1.55;max-width:54ch;position:relative;z-index:1}
.greet-sub b{color:#fff;font-weight:500}

.clock-card{background:#fff;border:1px solid var(--rule);border-radius:14px;padding:24px;display:flex;flex-direction:column;justify-content:space-between;position:relative;gap:14px}
.clock-state{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:8px}
.clock-state .dot{width:7px;height:7px;background:var(--accent);border-radius:50%;box-shadow:0 0 0 4px rgba(27,23,255,.18);flex-shrink:0}
.clock-state.off{color:var(--muted)}
.clock-state.off .dot{background:var(--muted);box-shadow:0 0 0 4px rgba(107,104,89,.18)}
.clock-time{font-family:var(--mono);font-size:clamp(30px,5vw,38px);font-weight:500;letter-spacing:-.02em;line-height:1}
.clock-info{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;font-size:12px;color:var(--muted)}
.clock-info > div{min-width:0}
.clock-info b{color:var(--ink);font-weight:500;display:block;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.clock-actions{display:flex;gap:6px}
.pulse{flex:1;padding:10px 14px;font-size:12px;font-weight:500;border:1px solid var(--ink);background:#fff;cursor:pointer;border-radius:6px;min-height:38px}
.pulse:hover{background:var(--ink);color:#fff}
.pulse.go{background:var(--accent);color:#fff;border-color:var(--accent)}
.pulse.go:hover{background:#1610d6}

/* ============== KPIs ============== */
.kpis{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:24px}
.kpi{background:#fff;border:1px solid var(--rule);border-radius:12px;padding:18px 20px;position:relative;min-width:0}
.kpi-label{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;gap:6px;min-width:0}
.kpi-label > span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.kpi-label .trend{padding:2px 8px;border-radius:10px;font-size:9px;background:rgba(14,138,74,.1);color:var(--good);flex-shrink:0;white-space:nowrap}
.kpi-label .trend.dn{background:rgba(193,42,42,.1);color:var(--bad)}
.kpi-label .trend.muted{background:var(--bg);color:var(--muted)}
.kpi-value{font-family:var(--serif);font-size:clamp(28px,4vw,36px);line-height:1;font-weight:400;letter-spacing:-.01em}
.kpi-value em{font-style:italic;color:var(--accent)}
.kpi-meta{font-size:12px;color:var(--muted);margin-top:6px;line-height:1.4}

/* ============== PANELS ============== */
.grid{display:grid;grid-template-columns:1.5fr 1fr;gap:24px}
.panel{background:#fff;border:1px solid var(--rule);border-radius:12px;padding:24px;min-width:0}
.panel-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;gap:12px}
.panel-title{font-family:var(--serif);font-size:22px;font-weight:400;margin:0;letter-spacing:-.01em}
.panel-title em{font-style:italic;color:var(--accent)}
.panel-link{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;flex-shrink:0;white-space:nowrap}
.panel-link:hover{color:var(--accent)}

/* Activity row pattern */
.row{display:grid;grid-template-columns:54px minmax(0,1fr) auto auto;gap:14px;padding:11px 0;border-bottom:1px solid var(--rule);align-items:center;font-size:13px}
.row:last-child{border-bottom:0}
.row .t{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.05em;white-space:nowrap}
.row .what{font-weight:500;line-height:1.3;min-width:0;overflow:hidden}
.row .what .who{display:block;font-weight:400;color:var(--muted);font-size:11px;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row .dur{font-family:var(--mono);font-size:11px;color:var(--muted);white-space:nowrap}
.row .pill{font-family:var(--mono);font-size:9px;letter-spacing:.12em;padding:3px 8px;border-radius:10px;text-transform:uppercase;white-space:nowrap}
.pill.done{background:rgba(14,138,74,.1);color:var(--good)}
.pill.now{background:var(--accent);color:#fff}
.pill.next{background:var(--bg);color:var(--muted);border:1px solid var(--rule)}
.pill.warn{background:rgba(184,102,24,.1);color:var(--warn)}

/* Tasks */
.tasks{display:flex;flex-direction:column;gap:10px}
.task{display:flex;gap:12px;padding:12px 14px;border:1px solid var(--rule);border-radius:8px;align-items:flex-start;cursor:pointer;transition:border .15s;color:inherit}
.task:hover{border-color:var(--ink)}
.task .check{width:18px;height:18px;border:1.5px solid var(--rule-2);border-radius:5px;flex-shrink:0;margin-top:1px}
.task.urgent .check{border-color:var(--accent)}
.task-body{flex:1;font-size:13px;line-height:1.4;min-width:0}
.task-body b{display:block;font-weight:500}
.task-body .meta{font-family:var(--mono);font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-top:4px}
.task.urgent .meta{color:var(--accent)}

/* Bars */
.bars{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;align-items:end;height:80px;margin-top:10px}
.bar{background:linear-gradient(180deg,var(--accent),#5b58ff);border-radius:3px 3px 0 0;position:relative;min-height:4px}
.bar.neg{background:linear-gradient(180deg,#e0d8ff,#c8c0e8)}
.bar.now{outline:2px solid var(--ink);outline-offset:2px}
.bar-labels{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;margin-top:6px;font-family:var(--mono);font-size:10px;color:var(--muted);text-align:center}

/* Inner section title */
.subpanel{margin-top:16px;padding-top:16px;border-top:1px solid var(--rule)}
.subpanel-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:10px}
.subpanel-h h3{font-family:var(--serif);font-size:18px;font-weight:400;margin:0;letter-spacing:-.005em}
.subpanel-h h3 em{font-style:italic;color:var(--accent)}

/* Notification list */
.notif-list{display:flex;flex-direction:column;gap:0}
.notif-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:12px;align-items:center;padding:10px 0;border-bottom:1px solid var(--rule);font-size:13px}
.notif-row:last-child{border-bottom:0}
.notif-row .nt-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);flex-shrink:0}
.notif-row .nt-dot.read{background:var(--rule-2)}
.notif-row .nt-text{min-width:0}
.notif-row .nt-text b{display:block;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.notif-row .nt-text span{font-family:var(--mono);font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:2px;display:block}
.notif-row .nt-when{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.05em;white-space:nowrap}

/* Module grid (alt to two-col) */
.mod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.mod-card{background:#fff;border:1px solid var(--rule);border-radius:12px;padding:18px 20px;display:flex;flex-direction:column;gap:8px;color:inherit;transition:all .15s}
.mod-card:hover{border-color:var(--ink);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink)}
.mod-card .ic{width:30px;height:30px;border-radius:8px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;font-family:var(--mono)}
.mod-card b{font-weight:500;font-size:14px;line-height:1.3}
.mod-card span{font-size:12px;color:var(--muted);line-height:1.45}
.mod-card .arr{margin-top:auto;padding-top:8px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--accent);text-transform:uppercase}

/* Section header above grids */
.section-h{display:flex;justify-content:space-between;align-items:baseline;margin:20px 0 12px;gap:12px}
.section-h h2{font-family:var(--serif);font-weight:400;font-size:22px;letter-spacing:-.01em;margin:0}
.section-h h2 em{font-style:italic;color:var(--accent)}
.section-h .more{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}

/* ============== RESPONSIVE ============== */
@media (max-width:1280px){
  :root{--pad-x:24px}
  .kpis{gap:12px}
  .kpi{padding:16px 18px}
}
@media (max-width:1080px){
  .kpis{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid{grid-template-columns:1fr;gap:16px}
  .greet{gap:16px}
}
@media (max-width:880px){
  :root{--pad-x:18px}
  .app{grid-template-columns:1fr}
  .menu-btn{display:flex}
  .side{position:fixed;top:0;left:0;height:100vh;width:min(280px,86vw);transform:translateX(-100%);transition:transform .25s ease}
  .side.open{transform:translateX(0);box-shadow:8px 0 32px rgba(0,0,0,.25)}
  .side-close{display:flex;align-items:center;justify-content:center}
  .greet{grid-template-columns:1fr}
  .greet-card{padding:24px 22px}
  .greet-card::after{width:200px;height:160px;right:-30px;top:-30px}
  .clock-card{padding:20px}
  .search{width:200px}
  .search > span:nth-child(2){display:none}
  .panel{padding:20px}
}
@media (max-width:640px){
  :root{--pad-x:14px}
  .main{padding-top:18px;padding-bottom:48px}
  .topbar{margin-bottom:18px}
  .crumb{font-size:10px;letter-spacing:.14em}
  .crumb .sep, .crumb > span:first-child{display:none}
  .search{display:none}
  .search-mobile{display:flex}
  .greet-card{padding:22px 20px}
  .greet-eyebrow{font-size:9px;letter-spacing:.18em}
  .clock-info{grid-template-columns:repeat(2,1fr)}
  .clock-info > div:nth-child(3){display:none}
  .kpis{gap:10px;margin-bottom:18px}
  .kpi{padding:14px 16px}
  .kpi-label{font-size:9px;letter-spacing:.1em}
  .kpi-meta{font-size:11px}
  .row{grid-template-columns:46px minmax(0,1fr) auto;column-gap:10px;row-gap:4px;padding:12px 0}
  .row .pill{grid-column:3;grid-row:1}
  .row .dur{grid-column:2 / span 2;grid-row:2;text-align:left;font-size:10px;letter-spacing:.05em;justify-self:start}
  .row .what{grid-row:1}
  .row .t{grid-row:1}
  .panel{padding:18px;border-radius:10px}
  .panel-title{font-size:20px}
  .bars{height:60px}
}
@media (max-width:420px){
  .kpis{grid-template-columns:1fr}
  .greet-card{padding:20px 18px}
  .greet-h{font-size:28px}
  .clock-time{font-size:30px}
  .pulse{padding:10px;font-size:11px}
  .top-actions{gap:6px}
  .icon-btn,.menu-btn{width:36px;height:36px}
  .side-foot .me-role{display:none}
}

@media (prefers-reduced-motion:reduce){
  .side{transition:none}
  .mod-card:hover{transform:none}
}
