  :root{
    --navy:#0f2138; --navy-2:#16304f;
    --side:#0e2036; --side-hover:#18304d; --side-active:#1c3a5e;
    --blue:#2f6bff; --blue-hi:#1f57e6;
    --bg:#f6f7f9; --card:#ffffff; --line:#e7e9ee; --line-2:#eef0f4;
    --ink:#1d2733; --mut:#6b7585; --dim:#9aa3b0;
    --green:#1f9d6b; --amber:#e0a008; --red:#d64242;
    --r:10px;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--ink);font-size:14px;display:flex;min-height:100vh}

  /* ===== SIDEBAR ===== */
  .side{width:230px;background:var(--side);color:#cdd6e4;display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto}
  .side .logo{padding:22px 20px 18px;text-align:center;border-bottom:1px solid rgba(255,255,255,.07)}
  .side .logo .wave{font-size:1.55rem;font-weight:700;color:#fff;line-height:1;letter-spacing:.02em}
  .side .logo .wave b{color:#4ea3e0}
  .side .logo .sub{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:#7e8ca5;margin-top:8px}
  .side .seclbl{font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:#5f6f8a;padding:18px 20px 6px;font-weight:600}
  .side a{display:flex;align-items:center;gap:11px;padding:10px 20px;color:#b8c2d4;text-decoration:none;font-size:.88rem;font-weight:500;border-left:3px solid transparent}
  .side a .ic{width:17px;text-align:center;opacity:.85}
  .side a:hover{background:var(--side-hover);color:#fff}
  .side a.activo{background:var(--side-active);color:#fff;border-left-color:var(--blue);font-weight:600}
  .side .foot{margin-top:auto;border-top:1px solid rgba(255,255,255,.07);padding:8px 0}
  .side .foot a{font-size:.84rem;color:#9fb0c8}

  /* ===== MAIN ===== */
  .main{flex:1;display:flex;flex-direction:column;min-width:0}
  .topbar{display:flex;align-items:center;gap:18px;padding:16px 28px;background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}
  .topbar .pt{font-size:1.15rem;font-weight:700;color:var(--ink)}
  .search{margin-left:auto;display:flex;align-items:center;gap:9px;background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:8px 13px;width:340px;color:var(--dim);font-size:.85rem}
  .search .kbd{margin-left:auto;font-size:.68rem;background:#fff;border:1px solid var(--line);border-radius:5px;padding:1px 6px;color:var(--mut)}
  .bell{width:38px;height:38px;border:1px solid var(--line);border-radius:8px;display:grid;place-items:center;color:var(--mut);font-size:1rem}

  .content{padding:26px 28px;overflow:auto}
  /* progress bar segmented */
  .prog{display:flex;gap:5px;margin-bottom:18px}
  .prog span{height:7px;border-radius:4px;flex:1;background:#dfe3ea}
  .prog span.on{background:linear-gradient(90deg,#5aa0ff,#2f6bff)}

  .crumb{display:flex;align-items:center;gap:8px;color:var(--mut);font-size:.84rem;margin-bottom:14px}
  .crumb .actions{margin-left:auto;display:flex;gap:8px}
  .btn{border:1px solid var(--line);background:#fff;border-radius:8px;padding:7px 13px;font-size:.82rem;color:var(--ink);font-weight:600;cursor:pointer;display:inline-flex;gap:7px;align-items:center}
  .btn.primary{background:var(--blue);border-color:var(--blue);color:#fff}
  .btn.primary:hover{background:var(--blue-hi)}

  .ptitle{font-size:1.9rem;font-weight:700;letter-spacing:-.02em;margin-bottom:8px}
  .pdesc{color:var(--mut);max-width:80ch;line-height:1.55;margin-bottom:16px}
  .linkchip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:8px;padding:7px 12px;font-size:.82rem;color:var(--blue);font-weight:600;margin-bottom:14px}
  .pills{display:flex;gap:9px;align-items:center;flex-wrap:wrap;margin-bottom:8px}
  .pill{display:inline-flex;align-items:center;gap:6px;font-size:.76rem;font-weight:600;padding:5px 11px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--mut)}
  .pill .dot{width:7px;height:7px;border-radius:50%}
  .pill.activo{color:var(--green)} .pill.activo .dot{background:var(--green)}
  .pill.p2{background:#fff7e6;border-color:#f3e2bc;color:#a9810f}
  .pill.empresa{color:#7a52d0} .pill.empresa .dot{background:#7a52d0}

  /* tabs */
  .tabs{display:flex;gap:24px;border-bottom:1px solid var(--line);margin:18px 0 22px}
  .tabs a{padding:11px 2px;color:var(--mut);text-decoration:none;font-size:.9rem;font-weight:600;border-bottom:2px solid transparent}
  .tabs a.activo{color:var(--ink);border-bottom-color:var(--blue)}

  /* layout body: main + rail */
  .body{display:grid;grid-template-columns:1fr 300px;gap:22px;align-items:start}

  .card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:20px}
  .card+.card{margin-top:18px}
  .card h3{font-size:1rem;font-weight:700;margin-bottom:2px}
  .card .meta{color:var(--mut);font-size:.8rem;margin-bottom:16px}
  .cardhead{display:flex;align-items:center;gap:11px;margin-bottom:16px}
  .cardhead .ico{width:34px;height:34px;border-radius:8px;background:#eef3ff;color:var(--blue);display:grid;place-items:center;font-size:1.05rem}
  .cardhead .ha{margin-left:auto;display:flex;gap:8px}

  /* KPIs */
  .kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
  .kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;position:relative;overflow:hidden}
  .kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--blue)}
  .kpi .n{font-size:1.9rem;font-weight:700;letter-spacing:-.02em}
  .kpi .l{color:var(--mut);font-size:.78rem;margin-top:5px}
  .kpi.r::before{background:var(--red)} .kpi.a::before{background:var(--amber)} .kpi.g::before{background:var(--green)}

  /* component-style cards grid */
  .grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
  .comp{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:9px;padding:12px 14px}
  .comp .mono{width:34px;height:34px;border-radius:8px;background:#eef0f4;color:var(--mut);display:grid;place-items:center;font-weight:700;font-size:.72rem}
  .comp .nm{font-weight:600}
  .comp .vs{font-size:.74rem;color:var(--mut);display:flex;align-items:center;gap:6px;margin-top:2px}
  .comp .vs .dot{width:6px;height:6px;border-radius:50%;background:var(--green)}

  /* chart */
  .bars{display:flex;align-items:flex-end;gap:14px;height:170px;padding-top:10px}
  .bars .b{flex:1;display:flex;flex-direction:column;align-items:center;gap:7px;height:100%}
  .bars .b .bar{width:100%;background:linear-gradient(180deg,#3f74e8,#2f6bff);border-radius:6px 6px 0 0;margin-top:auto}
  .bars .b small{color:var(--mut);font-size:.72rem}

  table{width:100%;border-collapse:collapse;font-size:.84rem}
  th,td{text-align:left;padding:9px 8px;border-bottom:1px solid var(--line-2)}
  th{color:var(--mut);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em}
  td.num{text-align:right;font-variant-numeric:tabular-nums}

  /* right rail */
  .rail .card{padding:16px 18px}
  .rail .row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--line-2);font-size:.84rem}
  .rail .row:last-child{border-bottom:none}
  .rail .row .k{color:var(--mut)}
  .rail .cta{width:100%;justify-content:center;margin-bottom:4px}
  .rail .note{font-size:.8rem;color:var(--mut);line-height:1.5;margin-bottom:12px}

  /* floating assistant */
  .fab{position:fixed;right:24px;bottom:24px;width:56px;height:56px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-size:1.5rem;box-shadow:0 10px 26px rgba(15,33,56,.35);cursor:pointer}

.oculto{display:none}
.chart{width:100%}

/* ===== Login ===== */
.login-body{display:grid;place-items:center;min-height:100vh;
  background:radial-gradient(900px 500px at 80% -10%,#16304f 0%,#0e2036 55%,#0b1626 100%)}
.login-card{background:#fff;border-radius:16px;padding:38px 40px;width:380px;text-align:center;
  box-shadow:0 30px 70px -30px rgba(0,0,0,.6);border-top:4px solid var(--blue)}
.login-logo .wave{font-size:1.5rem;font-weight:700;color:var(--navy);line-height:1.1}
.login-logo .wave b{color:var(--blue)}
.login-title{font-size:1.35rem;font-weight:700;margin-top:16px;color:var(--ink)}
.login-sub{color:var(--mut);font-size:.86rem;margin:6px 0 22px}
.login-input{width:100%;border:1px solid var(--line);border-radius:9px;padding:12px 14px;
  font-size:.92rem;margin-bottom:12px;font-family:'Inter',sans-serif}
.login-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(47,107,255,.18)}
.login-btn{width:100%;justify-content:center;margin-top:4px;padding:12px}
.login-error{background:#fdecea;border:1px solid #f3c0b8;color:var(--red);
  padding:10px;border-radius:8px;font-size:.84rem;margin-bottom:14px}
/* ===== Inicio (landing) ===== */
.hero{margin:.2rem 0 1.6rem 0;border-left:3px solid var(--blue);padding-left:1.1rem}
.hero-titulo{font-size:2.3rem;font-weight:700;letter-spacing:-.02em;margin-top:.3rem}
.hero-bajada{color:var(--mut);max-width:70ch;line-height:1.6;margin-top:.6rem}
.pilares{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px;margin:.6rem 0 1.6rem}
.pilar{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:24px;position:relative}
.pilar .num{position:absolute;top:-11px;left:22px;background:#eef3ff;color:var(--blue);border:1px solid #cfe0ff;border-radius:999px;padding:2px 10px;font-size:.72rem;font-weight:700}
.pilar .ico{font-size:1.5rem;margin:.3rem 0 .5rem}
.pilar .tit{font-weight:700;color:var(--navy);margin-bottom:.4rem}
.pilar .desc{color:var(--mut);font-size:.9rem;line-height:1.55;margin-bottom:.7rem}
.pilar .donde{color:var(--dim);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.accesos{display:flex;gap:10px;flex-wrap:wrap}
.accesos .btn{text-decoration:none}
/* ===== Embebidos (iframe) ===== */
.embed-frame{width:100%;border:1px solid var(--line);border-radius:10px;background:#fff}
.embed-link{font-size:.84rem;color:var(--mut);margin:10px 0}
.embed-link a{color:var(--blue);font-weight:600}

/* ===== Copilot chat ===== */
.chat{display:flex;flex-direction:column;gap:10px;max-height:50vh;overflow-y:auto;padding:6px 2px}
.chat-msg{max-width:78%;padding:10px 14px;border-radius:12px;font-size:.92rem;line-height:1.5;white-space:pre-wrap}
.chat-user{align-self:flex-end;background:var(--navy);color:#fff;border-bottom-right-radius:4px}
.chat-bot{align-self:flex-start;background:#eef0f4;color:var(--ink);border-bottom-left-radius:4px}
.chat-ejemplos{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.chip{border:1px solid var(--line);background:#fff;border-radius:999px;padding:6px 12px;font-size:.8rem;color:var(--navy);cursor:pointer;font-family:'Inter',sans-serif}
.chip:hover{background:#eef3ff;border-color:#cfe0ff}

/* ===== Automotor: siniestros ===== */
.sin-filtros{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.sin-filtros select,.sin-filtros input{padding:6px 10px;border:1px solid var(--line);border-radius:8px;font-family:'Inter',sans-serif;font-size:.85rem}
.sin-filtros input{flex:1;min-width:200px}
#sf-tabla{max-height:48vh;overflow:auto}
#sf-tabla table tbody tr{cursor:pointer}
#sf-tabla table tbody tr:hover{background:#eef3ff}
#sf-tabla table tbody tr.sel{background:#dde9ff}
.det-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px 18px;margin-top:8px}
.det-grid div b{color:var(--navy)}
