@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');
:root{
  --bg:#eef2f7; --bg2:#e6ecf5; --card:#ffffff; --ink:#0f172a; --muted:#64748b; --line:#e6ebf2;
  --brand:#0a6fb0; --brand2:#0090d4; --brand-d:#004f87;
  --brand-grad:linear-gradient(135deg,#004f87 0%,#0a6fb0 55%,#0098db 100%);
  --accent:#f0c000; --accent-d:#d4a800;
  --green:#16a34a; --amber:#d97706; --red:#dc2626; --violet:#7c3aed;
  --radius:16px; --radius-sm:11px;
  --shadow:0 6px 24px rgba(15,23,42,.08); --shadow-lg:0 18px 48px rgba(15,23,42,.16);
  --shadow-brand:0 10px 26px rgba(10,111,176,.32);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,-apple-system,Segoe UI,Arial,sans-serif;
  background:radial-gradient(1200px 600px at 100% -10%,#dbe5f5 0,transparent 60%),
             radial-gradient(900px 500px at -10% 110%,#e7e0fb 0,transparent 55%),var(--bg);
  color:var(--ink);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:var(--brand);text-decoration:none;transition:color .15s}
a:hover{text-decoration:underline}
img{max-width:100%}
.container{max-width:1180px;margin:0 auto;padding:0 20px}
.muted{color:var(--muted)}.small{font-size:13px}.center{text-align:center}
.mt{margin-top:18px}.mb{margin-bottom:18px}

/* ===== Animaciones ===== */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pop{0%{opacity:0;transform:scale(.94)}60%{transform:scale(1.02)}100%{opacity:1;transform:scale(1)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@keyframes gradShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes shine{0%{transform:translateX(-120%)}60%,100%{transform:translateX(220%)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
@keyframes blob{0%,100%{border-radius:42% 58% 60% 40%/45% 45% 55% 55%}50%{border-radius:60% 40% 45% 55%/55% 60% 40% 45%}}

/* ===== Botones ===== */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--brand-grad);background-size:160% 160%;color:#fff;border:none;
  padding:11px 19px;border-radius:12px;font-weight:600;cursor:pointer;font-size:14px;font-family:inherit;
  box-shadow:var(--shadow-brand);transition:transform .16s cubic-bezier(.34,1.56,.64,1),box-shadow .16s,filter .16s;
  overflow:hidden;text-decoration:none}
.btn::after{content:"";position:absolute;top:0;left:0;width:40%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.45),transparent);transform:translateX(-150%)}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(10,111,176,.42);text-decoration:none}
.btn:hover::after{animation:shine .9s ease}
.btn:active{transform:translateY(0) scale(.98)}
.btn.sec{background:#fff;color:var(--ink);border:1px solid var(--line);box-shadow:var(--shadow)}
.btn.sec:hover{background:#f8fafc;box-shadow:var(--shadow-lg)}
.btn.ghost{background:transparent;color:var(--brand);box-shadow:none}
.btn.danger{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 10px 26px rgba(220,38,38,.32)}
.btn.green{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 10px 26px rgba(22,163,74,.3)}
.btn.sm{padding:7px 13px;font-size:13px;border-radius:9px;box-shadow:none}
.btn.sm:hover{box-shadow:var(--shadow)}
.btn.block{width:100%}

/* ===== Formularios ===== */
label{display:block;font-weight:600;margin:14px 0 6px;font-size:13.5px;color:#334155}
input,select,textarea{width:100%;padding:11px 13px;border:1.5px solid var(--line);border-radius:11px;
  font-size:14px;font-family:inherit;background:#fff;color:var(--ink);transition:border-color .18s,box-shadow .18s,transform .18s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px rgba(10,111,176,.14)}
textarea{min-height:130px;resize:vertical}
.row{display:flex;gap:16px;flex-wrap:wrap}.row>.col{flex:1;min-width:220px}
.hint{font-size:12.5px;color:var(--muted);margin-top:5px}

/* ===== Tarjetas ===== */
.card{background:var(--card);border:1px solid rgba(226,232,240,.9);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:24px;animation:fadeUp .5s both;transition:box-shadow .2s,transform .2s}
.card:hover{box-shadow:var(--shadow-lg)}
.card h2,.card h3{margin-top:0}
.grid-2>*,.grid-3>*,.kpis>*,.tiles>*{animation:fadeUp .5s both}
.grid-2>*:nth-child(2),.grid-3>*:nth-child(2),.kpis>*:nth-child(2),.tiles>*:nth-child(2){animation-delay:.06s}
.grid-3>*:nth-child(3),.kpis>*:nth-child(3){animation-delay:.12s}
.kpis>*:nth-child(4){animation-delay:.18s}

/* ===== Public nav ===== */
.public-nav{background:var(--brand-grad);background-size:200% 200%;animation:gradShift 14s ease infinite;
  color:#fff;box-shadow:0 6px 24px rgba(10,111,176,.22);position:sticky;top:0;z-index:20}
.public-nav .container{display:flex;align-items:center;justify-content:space-between;height:66px}
.public-nav .brand{font-weight:800;font-size:18px;color:#fff;letter-spacing:.2px;display:flex;align-items:center;gap:10px}
.public-nav .brand .logo{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.18);
  backdrop-filter:blur(6px);display:grid;place-items:center;font-size:19px}
.public-nav a{color:#e0e7ff;font-weight:600}
.public-nav a:hover{color:#fff;text-decoration:none}

/* ===== Hero ===== */
.hero{position:relative;background:var(--brand-grad);background-size:220% 220%;animation:gradShift 16s ease infinite;
  color:#fff;padding:64px 0 100px;text-align:center;overflow:hidden}
.hero::before,.hero::after{content:"";position:absolute;width:340px;height:340px;
  background:rgba(255,255,255,.10);animation:blob 14s ease-in-out infinite,floaty 9s ease-in-out infinite}
.hero::before{top:-120px;right:-80px}
.hero::after{bottom:-150px;left:-90px;animation-duration:18s,11s;background:rgba(240,192,0,.16)}
.hero h1{position:relative;font-size:38px;margin:0 0 12px;font-weight:800;letter-spacing:-.5px;animation:fadeUp .6s both}
.hero p{position:relative;font-size:17px;color:#e0e7ff;max-width:640px;margin:0 auto;animation:fadeUp .6s .1s both}
.hero-cards{margin-top:-62px;position:relative;z-index:2}
.tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.tile{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:26px;display:flex;gap:16px;
  align-items:flex-start;border:1px solid var(--line);transition:transform .2s,box-shadow .2s}
.tile:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.tile .ic{width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,#eff6ff,#dbeafe);color:var(--brand);
  display:grid;place-items:center;font-size:25px;flex:none;transition:transform .25s}
.tile:hover .ic{transform:scale(1.08) rotate(-4deg)}
.tile h3{margin:0 0 6px}

/* ===== Badges ===== */
.badge{display:inline-block;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:700}
.b-open{background:#dbeafe;color:#1e40af}.b-prog{background:#fef3c7;color:#92400e}
.b-wait{background:#ede9fe;color:#5b21b6}.b-closed{background:#dcfce7;color:#166534}
.pri{font-size:12px;font-weight:700;padding:3px 9px;border-radius:7px}
.pri-low{background:#f1f5f9;color:#475569}.pri-medium{background:#dbeafe;color:#1e40af}
.pri-high{background:#fed7aa;color:#9a3412}.pri-urgent{background:#fee2e2;color:#991b1b;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,.35)}50%{box-shadow:0 0 0 5px rgba(220,38,38,0)}}

/* ===== Tablas ===== */
table.data{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
table.data th,table.data td{padding:13px 15px;text-align:left;border-bottom:1px solid var(--line);font-size:14px}
table.data th{background:#f8fafc;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700}
table.data tbody tr{transition:background .15s}
table.data tr:hover td{background:#f5f8ff}
table.data tr:last-child td{border-bottom:none}

/* ===== Panel (sidebar) ===== */
.layout{display:flex;min-height:100vh}
.sidebar{width:252px;background:linear-gradient(180deg,#0b1220,#0f172a);color:#cbd5e1;flex:none;
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;box-shadow:4px 0 24px rgba(2,6,23,.18);z-index:30}
.sidebar .brand{padding:20px 22px;color:#fff;font-weight:800;font-size:16px;border-bottom:1px solid #1e293b;display:flex;align-items:center;gap:10px}
.sidebar .brand .logo{width:34px;height:34px;border-radius:10px;background:var(--brand-grad);display:grid;place-items:center;box-shadow:var(--shadow-brand)}
.sidebar nav{padding:12px 12px;flex:1;overflow:auto}
.sidebar nav .sec-t{font-size:10.5px;text-transform:uppercase;letter-spacing:.7px;color:#64748b;padding:16px 12px 6px;font-weight:700}
.sidebar nav a{position:relative;display:flex;align-items:center;gap:12px;color:#cbd5e1;padding:11px 13px;border-radius:11px;font-weight:600;font-size:14px;margin-bottom:3px;transition:background .16s,color .16s,transform .16s}
.sidebar nav a span:first-child{font-size:17px;width:20px;text-align:center}
.sidebar nav a:hover{background:#1e293b;color:#fff;text-decoration:none;transform:translateX(3px)}
.sidebar nav a.active{background:var(--brand-grad);color:#fff;box-shadow:var(--shadow-brand)}
.sidebar .who{padding:15px 18px;border-top:1px solid #1e293b;font-size:13px}
.sidebar .who b{color:#fff}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{background:rgba(255,255,255,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
  padding:14px 26px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:15}
.topbar h1{font-size:19px;margin:0;font-weight:700}
.content{padding:26px;flex:1;animation:fadeIn .4s both}

/* ===== KPIs ===== */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}
.kpi{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;
  box-shadow:var(--shadow);overflow:hidden;transition:transform .2s,box-shadow .2s}
.kpi::before{content:"";position:absolute;left:0;top:0;height:100%;width:5px;background:var(--brand-grad)}
.kpi:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.kpi .n{font-size:32px;font-weight:800;line-height:1;letter-spacing:-.5px}
.kpi .l{color:var(--muted);font-size:13px;margin-top:7px;font-weight:600}
.kpi .ic{float:right;width:46px;height:46px;border-radius:13px;display:grid;place-items:center;font-size:21px;transition:transform .25s}
.kpi:hover .ic{transform:translateY(-3px) scale(1.07)}
.k-blue::before{background:linear-gradient(180deg,#0a6fb0,#004f87)}.k-blue .ic{background:#eef6fb;color:#0a6fb0}
.k-amber::before{background:linear-gradient(180deg,#fbbf24,#d97706)}.k-amber .ic{background:#fffbeb;color:#d97706}
.k-violet::before{background:linear-gradient(180deg,#a78bfa,#7c3aed)}.k-violet .ic{background:#f5f3ff;color:#7c3aed}
.k-green::before{background:linear-gradient(180deg,#34d399,#16a34a)}.k-green .ic{background:#f0fdf4;color:#16a34a}

/* ===== Grids ===== */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

/* ===== Conversación ===== */
.thread{display:flex;flex-direction:column;gap:14px}
.msg{border:1px solid var(--line);border-radius:14px;padding:15px 17px;background:#fff;box-shadow:0 2px 8px rgba(15,23,42,.04);animation:fadeUp .4s both}
.msg.agent{background:linear-gradient(135deg,#eff6ff,#f5f9ff);border-color:#bfdbfe}
.msg.internal{background:linear-gradient(135deg,#fffbeb,#fefce8);border-color:#fde68a}
.msg.system{background:#f8fafc;border-style:dashed;color:var(--muted);font-size:13px;box-shadow:none}
.msg .meta{font-size:12.5px;color:var(--muted);margin-bottom:6px;display:flex;justify-content:space-between;gap:10px}
.msg .body{white-space:pre-line}
.att-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:11px}
.att{display:inline-flex;align-items:center;gap:7px;background:#f1f5f9;border:1px solid var(--line);padding:6px 11px;border-radius:9px;font-size:12.5px;transition:background .15s,transform .15s}
.att:hover{background:#e2e8f0;transform:translateY(-1px);text-decoration:none}

/* ===== Flash ===== */
.flash{padding:14px 16px;border-radius:12px;margin-bottom:16px;font-weight:600;font-size:14px;
  animation:slideDown .35s both;display:flex;align-items:center;gap:8px}
.flash.success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}
.flash.error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}
.flash.info{background:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}

/* ===== Auth ===== */
.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:20px;position:relative;overflow:hidden;
  background:var(--brand-grad);background-size:220% 220%;animation:gradShift 16s ease infinite}
.auth-wrap::before,.auth-wrap::after{content:"";position:absolute;width:420px;height:420px;background:rgba(255,255,255,.08);animation:blob 16s ease-in-out infinite}
.auth-wrap::before{top:-160px;left:-120px}.auth-wrap::after{bottom:-180px;right:-120px;animation-duration:20s}
.auth-card{position:relative;background:#fff;border-radius:22px;box-shadow:0 30px 70px rgba(2,6,23,.34);padding:36px;width:100%;max-width:420px;animation:pop .5s both;z-index:2}
.auth-card .logo{width:58px;height:58px;border-radius:16px;background:var(--brand-grad);display:grid;place-items:center;color:#fff;font-size:27px;margin:0 auto 14px;box-shadow:var(--shadow-brand);animation:floaty 6s ease-in-out infinite}

.tag{display:inline-block;background:#eff6ff;color:#1e40af;border-radius:9px;padding:4px 11px;font-size:12.5px;font-weight:700;margin:2px}
.divider{height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent);margin:20px 0}
.chart-box{position:relative;height:300px}
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:18px}
.toolbar .grow{flex:1}
.menu-btn{display:none}
@media(max-width:860px){
  .kpis,.grid-2,.grid-3,.tiles{grid-template-columns:1fr}
  .hero h1{font-size:30px}
  .sidebar{position:fixed;left:-272px;z-index:60;transition:left .25s}
  .sidebar.open{left:0}
  .menu-btn{display:inline-flex!important}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}

/* ============================================================
   COMPONENTES PREMIUM (v2)
   ============================================================ */

/* Avatar con iniciales */
.avatar{width:38px;height:38px;border-radius:11px;background:var(--brand-grad);color:#fff;
  display:grid;place-items:center;font-weight:700;font-size:14px;flex:none;box-shadow:var(--shadow-brand)}
.avatar.lg{width:46px;height:46px;border-radius:13px;font-size:16px}
.sidebar .who-row{display:flex;align-items:center;gap:11px}

/* Topbar con título + subtítulo */
.topbar .ttl{display:flex;flex-direction:column;line-height:1.2}
.topbar .ttl small{color:var(--muted);font-size:12.5px;font-weight:500;margin-top:2px}
.topbar .right{display:flex;align-items:center;gap:14px}
.topbar .right .hi{text-align:right;font-size:13px}
.topbar .right .hi b{display:block;font-size:13.5px}

/* Título de sección dentro de tarjetas */
.sec-head{display:flex;align-items:center;gap:12px;margin:0 0 16px}
.sec-head .chip{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,#eff6ff,#dbeafe);
  color:var(--brand);display:grid;place-items:center;font-size:18px;flex:none}
.sec-head h3,.sec-head h2{margin:0}
.sec-head .sub{color:var(--muted);font-size:12.5px;font-weight:500}
.sec-head .spacer{flex:1}

/* Hero estadísticas */
.hero-stats{position:relative;z-index:2;display:flex;justify-content:center;gap:38px;margin-top:26px;flex-wrap:wrap;animation:fadeUp .6s .2s both}
.hero-stats .s{color:#fff;text-align:center}
.hero-stats .s b{display:block;font-size:26px;font-weight:800;letter-spacing:-.5px}
.hero-stats .s span{color:#dbeafe;font-size:13px}

/* Cómo funciona (pasos) */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;counter-reset:step}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;position:relative;
  box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.step .num{counter-increment:step;width:40px;height:40px;border-radius:12px;background:var(--brand-grad);
  color:#fff;display:grid;place-items:center;font-weight:800;margin-bottom:14px;box-shadow:var(--shadow-brand)}
.step .num::before{content:counter(step)}
.step h4{margin:0 0 6px;font-size:16px}
.step p{margin:0;color:var(--muted);font-size:14px}

/* Features */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.feature{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;
  box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.feature .fic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;font-size:21px;margin-bottom:12px;
  background:linear-gradient(135deg,#eef2ff,#e0e7ff);color:var(--brand2)}
.feature h4{margin:0 0 6px;font-size:15.5px}
.feature p{margin:0;color:var(--muted);font-size:13.5px}

/* Bloques de sección pública */
.block{padding:54px 0}
.block .eyebrow{text-align:center;color:var(--brand);font-weight:700;font-size:13px;letter-spacing:1px;text-transform:uppercase;margin-bottom:6px}
.block h2{text-align:center;font-size:28px;margin:0 0 8px;letter-spacing:-.4px}
.block h2::after{content:"";display:block;width:56px;height:4px;border-radius:99px;background:var(--accent);margin:12px auto 0}
.block .lead{text-align:center;color:var(--muted);max-width:560px;margin:0 auto 34px}

/* Cabecera de páginas públicas (tickets/consulta) */
.ptitle{display:flex;align-items:center;gap:14px;margin:0 auto 20px;max-width:760px}
.ptitle .chip{width:48px;height:48px;border-radius:14px;background:var(--brand-grad);color:#fff;
  display:grid;place-items:center;font-size:23px;box-shadow:var(--shadow-brand);flex:none}
.ptitle h2{margin:0;font-size:23px}
.ptitle p{margin:2px 0 0;color:var(--muted);font-size:14px}

/* Estado vacío */
.empty{text-align:center;padding:40px 20px;color:var(--muted)}
.empty .ic{font-size:42px;opacity:.5;margin-bottom:8px}

/* Footer público */
.site-footer{background:#0b1220;color:#94a3b8;padding:40px 0 26px;margin-top:20px}
.site-footer .cols{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;margin-bottom:24px}
.site-footer .brand{color:#fff;font-weight:800;font-size:17px;display:flex;align-items:center;gap:10px;margin-bottom:8px}
.site-footer .brand .logo{width:34px;height:34px;border-radius:10px;background:var(--brand-grad);display:grid;place-items:center}
.site-footer a{color:#cbd5e1;display:block;margin:6px 0;font-size:14px}
.site-footer .bottom{border-top:1px solid #1e293b;padding-top:18px;font-size:13px;text-align:center}

/* Stepper de progreso en formularios */
.form-steps{display:flex;gap:8px;margin-bottom:22px}
.form-steps .fs{flex:1;height:5px;border-radius:99px;background:var(--line)}
.form-steps .fs.on{background:var(--brand-grad)}

/* Chips de filtro/segment */
.seg{display:inline-flex;background:#eef2f7;border-radius:11px;padding:4px;gap:4px}
.seg a{padding:7px 13px;border-radius:8px;font-size:13px;font-weight:600;color:var(--muted)}
.seg a.on{background:#fff;color:var(--ink);box-shadow:var(--shadow)}
.seg a:hover{text-decoration:none;color:var(--ink)}

/* Refinamiento de inputs grandes en públicas */
.card.elevate{box-shadow:var(--shadow-lg)}


/* ===== Logo Siteck ===== */
.logo-chip{background:#fff;border-radius:10px;padding:5px 9px;display:inline-grid;place-items:center;box-shadow:0 3px 10px rgba(2,6,23,.16);line-height:0}
.logo-chip img{height:26px;display:block}
.logo-xl{background:#fff;border-radius:18px;padding:16px 20px;display:inline-grid;place-items:center;box-shadow:0 12px 30px rgba(2,6,23,.18);margin:0 auto 16px;line-height:0}
.logo-xl img{height:54px;display:block}
.site-footer .logo-chip{box-shadow:none}


/* ============================================================
   AJUSTES v4 — barra superior pública (blanca) + footer + sidebar
   ============================================================ */

/* ---- Barra superior pública: fondo blanco, logo a color real ---- */
.public-nav{background:#fff;animation:none;border-bottom:1px solid var(--line);box-shadow:0 2px 16px rgba(2,6,23,.05)}
.public-nav .container{height:72px}
.public-nav .brand{display:flex;align-items:center;color:var(--ink)}
.public-nav .brand .brand-logo{height:34px;width:auto;display:block}
.public-nav .brand .brand-sub{font-weight:700;font-size:15px;color:#64748b;
  padding-left:13px;margin-left:13px;border-left:1px solid var(--line)}
.public-nav .nav-links{display:flex;align-items:center;gap:4px}
.public-nav .nav-links a{color:#334155;font-weight:600;font-size:14.5px;padding:9px 15px;border-radius:10px;
  transition:background .15s,color .15s}
.public-nav .nav-links a:not(.btn):hover{background:#f1f5f9;color:var(--brand);text-decoration:none}
.public-nav .nav-links a.btn{color:#fff;margin-left:8px}
.public-nav .nav-links a.btn:hover{color:#fff;background:var(--brand-grad);filter:brightness(1.07)}
@media(max-width:660px){
  .public-nav .container{height:auto;flex-direction:column;gap:10px;padding-top:12px;padding-bottom:12px}
  .public-nav .brand-sub{display:none}
  .public-nav .nav-links{flex-wrap:wrap;justify-content:center}
}

/* ---- Panel: barra lateral CLARA estilo Siteck ---- */
.sidebar{background:#fff;color:#475569;border-right:1px solid var(--line);box-shadow:2px 0 22px rgba(2,6,23,.05)}
.sidebar .brand{gap:0;border-bottom:1px solid var(--line)}
.sidebar .brand .brand-logo{height:30px;width:auto;display:block}
.sidebar .brand .brand-sub{font-weight:700;font-size:15px;color:#64748b;
  padding-left:12px;margin-left:12px;border-left:1px solid var(--line)}
.sidebar nav .sec-t{color:#94a3b8}
.sidebar nav a{color:#475569;position:relative}
.sidebar nav a:hover{background:#f1f5f9;color:var(--brand)}
.sidebar nav a.active{background:var(--brand-grad);color:#fff;
  box-shadow:inset 3px 0 0 var(--accent),0 8px 18px rgba(10,111,176,.26)}
.sidebar .who{border-top:1px solid var(--line)}
.sidebar .who b{color:var(--ink)}
.sidebar .who .muted{color:#94a3b8}
.sidebar .logout-link{color:var(--brand);font-weight:600;display:inline-block;margin-top:10px}
.sidebar .logout-link:hover{color:var(--brand-d)}

/* ---- Login ---- */
.logo-xl img{height:46px}

/* ---- Footer: tipografía mejorada ---- */
.site-footer{padding:48px 0 28px}
.site-footer .cols{gap:48px}
.site-footer .brand{font-size:17px;font-weight:800;letter-spacing:-.2px;margin-bottom:12px;color:#fff}
.site-footer .brand .logo-chip{background:#fff;padding:5px 9px;border-radius:9px}
.site-footer .brand .logo-chip img{height:24px}
.site-footer p{font-size:13.5px;line-height:1.65;color:#9aa7b8}
.site-footer .col-title{color:#fff;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.site-footer a{color:#aab6c6;display:block;margin:8px 0;font-size:14px;font-weight:500;transition:color .15s,transform .15s}
.site-footer a:hover{color:#fff;text-decoration:none;transform:translateX(2px)}
.site-footer .bottom{border-top:1px solid #1c2940;padding-top:18px;margin-top:8px;font-size:12.5px;letter-spacing:.2px;color:#7c899b;text-align:center}
