/* ============================================================
   Portal RAT — identidad visual basada en sopnet.cl
   ============================================================ */
:root{
  --navy:#08111F; --navy-2:#0D1623; --navy-3:#122036;
  --accent:#FFBD59; --accent-dark:#E8A63B;
  --bg:#FFFFFF; --bg-soft:#F5F7FA; --border:#E3E8EF;
  --text:#0D1623; --text-soft:#5A6779;
  --ok:#1F9D6B; --ok-bg:#E4F5EE; --warn:#B7791F; --warn-bg:#FDF3E0;
  --danger:#C0392B; --danger-bg:#FBE9E7; --info:#2563EB; --info-bg:#E8EFFD;
  --radius:14px; --radius-lg:22px;
  --shadow:0 6px 24px rgba(8,17,31,.08); --shadow-lg:0 18px 48px rgba(8,17,31,.18);
  --font-head:'Inter',ui-sans-serif,system-ui,'Segoe UI',sans-serif;
  --font-body:'Roboto','Inter',ui-sans-serif,system-ui,'Segoe UI',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-body);color:var(--text);background:var(--bg-soft);line-height:1.6;font-size:16px;
  min-height:100vh;display:flex;flex-direction:column}
main{flex:1}
h1,h2,h3,h4{font-family:var(--font-head);line-height:1.2;color:var(--navy)}
a{color:inherit}
button{font-family:var(--font-head);cursor:pointer}
.container{width:min(1180px,94%);margin:0 auto}

/* ---------- Botones ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;border:none;border-radius:12px;
  padding:.72rem 1.4rem;font-weight:700;font-size:.95rem;transition:.2s;text-decoration:none;white-space:nowrap;
  font-family:var(--font-head)}
.btn-primary{background:var(--accent);color:var(--navy)}
.btn-primary:hover{background:var(--accent-dark);transform:translateY(-1px)}
.btn-outline{background:#fff;color:var(--navy);border:2px solid var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}
.btn-ghost{background:transparent;color:var(--text-soft);border:1px solid var(--border);border-radius:10px;
  padding:.5rem .9rem;font-size:.85rem;text-decoration:none;font-family:var(--font-head);font-weight:600;
  display:inline-flex;align-items:center;gap:.4rem;transition:.2s}
.btn-ghost:hover{border-color:var(--navy);color:var(--navy)}
.btn-ghost-dark{color:#C7D2E0;border-color:rgba(255,255,255,.25)}
.btn-ghost-dark:hover{border-color:var(--accent);color:var(--accent)}
.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid transparent;border-radius:10px;
  padding:.5rem .9rem;font-size:.85rem;font-family:var(--font-head);font-weight:600}
.btn-danger:hover{border-color:var(--danger)}
.btn-sm{padding:.4rem .8rem;font-size:.8rem;border-radius:9px}

/* ---------- Header ---------- */
header{background:var(--navy);color:#fff;position:sticky;top:0;z-index:200;box-shadow:0 2px 12px rgba(0,0,0,.25)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:.85rem 0;gap:1rem}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none;color:#fff}
.brand-mark{width:42px;height:42px;border-radius:12px;background:var(--accent);display:grid;place-items:center;
  font-family:var(--font-head);font-weight:800;color:var(--navy);font-size:1.05rem}
.brand-name{font-family:var(--font-head);font-weight:800;font-size:1.15rem}
.brand-name small{display:block;font-weight:400;font-size:.68rem;color:#9FB0C6;letter-spacing:.06em;text-transform:uppercase}
.nav-links{display:flex;gap:1.6rem;list-style:none;align-items:center}
.nav-links a{color:#C7D2E0;text-decoration:none;font-size:.92rem;font-weight:500;transition:.2s}
.nav-links a:hover,.nav-links a.active{color:var(--accent)}
.nav-user{display:flex;align-items:center;gap:.7rem}
.role-chip{background:var(--navy-3);border:1px solid rgba(255,189,89,.4);color:var(--accent);
  border-radius:999px;padding:.3rem .9rem;font-size:.78rem;font-weight:700;font-family:var(--font-head);white-space:nowrap}
.hamburger{display:none;background:none;border:none;color:#fff;font-size:1.7rem;line-height:1}

/* ---------- Hero (bienvenida) ---------- */
.hero{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-3) 60%,#1A2E4A 100%);color:#fff;
  padding:4.2rem 0 4.6rem;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-160px;top:-160px;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,189,89,.16),transparent 65%)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:3rem;align-items:center;position:relative;z-index:1}
.hero .eyebrow{display:inline-block;background:rgba(255,189,89,.14);border:1px solid rgba(255,189,89,.4);
  color:var(--accent);border-radius:999px;padding:.35rem 1rem;font-size:.8rem;font-weight:700;
  font-family:var(--font-head);letter-spacing:.05em;margin-bottom:1.2rem}
.hero h1{color:#fff;font-size:clamp(2rem,4.5vw,3.2rem);font-weight:800;margin-bottom:1.1rem}
.hero h1 span{color:var(--accent)}
.hero p{color:#B9C6D8;font-size:1.06rem;max-width:560px;margin-bottom:1.8rem}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.btn-outline-light{background:transparent;color:var(--accent);border:2px solid rgba(255,255,255,.35);border-radius:999px}
.btn-outline-light:hover{border-color:var(--accent)}
.hero-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);
  padding:1.8rem;backdrop-filter:blur(6px)}
.hero-card h3{color:#fff;font-size:1rem;margin-bottom:1rem}
.hero-card ul{list-style:none}
.hero-card li{display:flex;gap:.6rem;color:#C7D2E0;font-size:.92rem;padding:.42rem 0;border-bottom:1px dashed rgba(255,255,255,.1)}
.hero-card li:last-child{border-bottom:none}
.hero-card li::before{content:"✓";color:var(--accent);font-weight:800}

/* ---------- Secciones de contenido ---------- */
section.bloque{padding:3.4rem 0}
.section-head{max-width:720px;margin-bottom:2.2rem}
.section-head .kicker{color:var(--accent-dark);font-family:var(--font-head);font-weight:800;font-size:.78rem;
  text-transform:uppercase;letter-spacing:.12em}
.section-head h2{font-size:clamp(1.5rem,3vw,2.1rem);font-weight:800;margin:.4rem 0 .7rem}
.section-head p{color:var(--text-soft)}

/* ---------- Guía (pasos) ---------- */
.steps{display:grid;gap:1rem}
.step{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.step-head{display:flex;align-items:center;gap:1rem;padding:1.1rem 1.3rem;cursor:pointer;user-select:none;
  background:#fff;border:none;width:100%;text-align:left}
.step-num{flex:none;width:44px;height:44px;border-radius:12px;background:var(--navy);color:var(--accent);
  display:grid;place-items:center;font-family:var(--font-head);font-weight:800;font-size:1.1rem}
.step-head h3{font-size:1.02rem;flex:1}
.step-head .chev{transition:.25s;color:var(--text-soft);font-size:1.2rem}
.step.open .chev{transform:rotate(180deg)}
.step-body{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--text-soft);font-size:.94rem}
.step.open .step-body{max-height:600px}
.step-body-inner{padding:0 1.3rem 1.3rem 4.6rem}
.step-body ul{margin:.6rem 0 0 1.1rem}
.step-body li{margin:.3rem 0}

/* ---------- Tarjetas (errores / accesos) ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;
  box-shadow:var(--shadow);transition:.2s;text-decoration:none;display:block;color:var(--text)}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.card .icon{width:46px;height:46px;border-radius:12px;background:var(--navy);color:var(--accent);
  display:grid;place-items:center;font-size:1.3rem;margin-bottom:1rem}
.card h3{font-size:1.02rem;margin-bottom:.5rem}
.card p{color:var(--text-soft);font-size:.9rem}
.req-list{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;list-style:none}
.req-list li{background:#fff;border:1px solid var(--border);border-radius:12px;padding:.9rem 1.1rem;
  display:flex;gap:.7rem;align-items:flex-start;font-size:.9rem;box-shadow:var(--shadow)}
.req-list li::before{content:"▸";color:var(--accent-dark);font-weight:800;flex:none}
.cta-band{background:var(--navy);border-radius:var(--radius-lg);color:#fff;padding:2.4rem;display:flex;
  align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.cta-band h2{color:#fff;font-size:1.4rem;margin-bottom:.4rem}
.cta-band p{color:#B9C6D8;max-width:520px}

/* ---------- Contenido ---------- */
.page{padding:2.4rem 0}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;flex-wrap:wrap;margin-bottom:1.6rem}
.page-head .kicker{color:var(--accent-dark);font-family:var(--font-head);font-weight:800;font-size:.78rem;
  text-transform:uppercase;letter-spacing:.12em}
.page-head h1{font-size:clamp(1.4rem,3vw,2rem);font-weight:800;margin-top:.2rem}
.page-head p{color:var(--text-soft);max-width:640px}
.flash{background:var(--ok-bg);color:var(--ok);border:1px solid currentColor;border-radius:12px;
  padding:.8rem 1.2rem;margin-top:1.4rem;font-weight:600;font-family:var(--font-head);font-size:.9rem}
.flash.err{background:var(--danger-bg);color:var(--danger)}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-bottom:1.8rem}
.stat{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem 1.4rem;box-shadow:var(--shadow)}
.stat .num{font-family:var(--font-head);font-size:2rem;font-weight:800;color:var(--navy)}
.stat .lbl{font-size:.85rem;color:var(--text-soft)}
.stat .bar{height:5px;border-radius:5px;background:var(--bg-soft);margin-top:.7rem;overflow:hidden}
.stat .bar i{display:block;height:100%;border-radius:5px;background:var(--accent)}
.stat.s2 .bar i{background:var(--danger)}
.stat.s3 .bar i{background:var(--info)}
.stat.s4 .bar i{background:var(--ok)}

/* ---------- Toolbar / formularios ---------- */
.toolbar{display:flex;gap:.8rem;flex-wrap:wrap;align-items:center;margin-bottom:1.2rem}
.toolbar .grow{flex:1;min-width:220px}
.input,.select,textarea{width:100%;border:1px solid var(--border);border-radius:10px;padding:.65rem .9rem;
  font-family:var(--font-body);font-size:.92rem;background:#fff;color:var(--text);transition:border .2s}
.input:focus,.select:focus,textarea:focus{outline:none;border-color:var(--accent-dark);box-shadow:0 0 0 3px rgba(255,189,89,.25)}
textarea{resize:vertical;min-height:74px}
.w-auto{width:auto}

fieldset{border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem 1.3rem;margin-bottom:1.3rem;background:#fff}
legend{font-family:var(--font-head);font-weight:800;font-size:.82rem;color:var(--navy);text-transform:uppercase;
  letter-spacing:.08em;padding:0 .5rem}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-grid .full{grid-column:1/-1}
label.fld{display:block;font-family:var(--font-head);font-weight:600;font-size:.82rem;color:var(--navy);margin-bottom:.3rem}
label.fld .req{color:var(--danger)}
.check-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.4rem .8rem}
.check-grid label,.switch-row{display:flex;gap:.5rem;align-items:center;font-size:.88rem;cursor:pointer}
.check-grid input,.switch-row input{accent-color:var(--accent-dark);width:16px;height:16px}
.hint{font-size:.78rem;color:var(--text-soft);margin-top:.25rem}
.form-actions{display:flex;justify-content:flex-end;gap:.8rem;margin-top:1.4rem}

/* ---------- Tabla ---------- */
.table-wrap{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:auto;box-shadow:var(--shadow)}
table{width:100%;border-collapse:collapse;min-width:900px}
thead th{background:var(--navy);color:#fff;font-family:var(--font-head);font-size:.78rem;text-transform:uppercase;
  letter-spacing:.06em;padding:.85rem 1rem;text-align:left;white-space:nowrap}
tbody td{padding:.85rem 1rem;border-bottom:1px solid var(--border);font-size:.9rem;vertical-align:top}
tbody tr:hover{background:#FBF8F1}
tbody tr:last-child td{border-bottom:none}
.t-name{font-weight:700;color:var(--navy);font-family:var(--font-head)}
.t-sub{font-size:.78rem;color:var(--text-soft)}
.badge{display:inline-block;border-radius:999px;padding:.18rem .7rem;font-size:.72rem;font-weight:700;
  font-family:var(--font-head);white-space:nowrap}
.b-ok{background:var(--ok-bg);color:var(--ok)}
.b-warn{background:var(--warn-bg);color:var(--warn)}
.b-danger{background:var(--danger-bg);color:var(--danger)}
.b-info{background:var(--info-bg);color:var(--info)}
.b-muted{background:var(--bg-soft);color:var(--text-soft)}
.row-actions{display:flex;gap:.4rem;flex-wrap:wrap}
.row-actions form{display:inline}
.empty{padding:3rem 1rem;text-align:center;color:var(--text-soft)}
.empty strong{display:block;font-family:var(--font-head);color:var(--navy);font-size:1.05rem;margin-bottom:.3rem}

/* ---------- Ficha detalle ---------- */
.detail-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow)}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:.4rem 1.6rem}
.detail-grid .full{grid-column:1/-1}
.dt{font-family:var(--font-head);font-weight:700;font-size:.76rem;color:var(--text-soft);text-transform:uppercase;
  letter-spacing:.06em;margin-top:.9rem}
.dd{font-size:.93rem}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--navy),#1A2E4A);padding:1.5rem}
.login-card{width:min(430px,100%);background:#fff;border-radius:var(--radius-lg);padding:2.4rem;box-shadow:var(--shadow-lg)}
.login-card .brand{margin-bottom:1.6rem;color:var(--navy);justify-content:center;display:flex;align-items:center;gap:.7rem}
.login-card .brand-name{color:var(--navy)}
.login-card h1{font-size:1.25rem;text-align:center;margin-bottom:.3rem}
.login-card>p{text-align:center;color:var(--text-soft);font-size:.9rem;margin-bottom:1.6rem}
.login-card .fld-row{margin-bottom:1rem}
.login-err{background:var(--danger-bg);color:var(--danger);border-radius:10px;padding:.7rem 1rem;
  font-size:.86rem;font-weight:600;margin-bottom:1rem;font-family:var(--font-head)}
.divider{display:flex;align-items:center;gap:.8rem;color:var(--text-soft);font-size:.8rem;margin:1.4rem 0}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--border)}
.sso-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.7rem;background:#fff;color:var(--navy);
  border:1.5px solid var(--border);border-radius:12px;padding:.8rem 1.6rem;font-weight:700;font-size:.92rem;
  text-decoration:none;transition:.2s}
.sso-btn:hover{border-color:var(--navy)}
.sso-btn .ms{display:inline-grid;grid-template-columns:repeat(2,8px);gap:1.5px}
.sso-btn .ms i{width:8px;height:8px}
.sso-btn .ms i:nth-child(1){background:#F25022}.sso-btn .ms i:nth-child(2){background:#7FBA00}
.sso-btn .ms i:nth-child(3){background:#00A4EF}.sso-btn .ms i:nth-child(4){background:#FFB900}

/* ---------- Footer ---------- */
footer{background:var(--navy);color:#8FA2BA;padding:3rem 0 2rem;margin-top:2.5rem}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:2rem;margin-bottom:2rem}
footer h4{color:#fff;font-size:.9rem;margin-bottom:.8rem}
footer .foot-grid ul{list-style:none}
footer .foot-grid li{margin:.35rem 0;font-size:.86rem}
footer a{color:#8FA2BA;text-decoration:none}
footer a:hover{color:var(--accent)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:1.4rem;font-size:.8rem;display:flex;
  justify-content:space-between;flex-wrap:wrap;gap:.6rem}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .stats{grid-template-columns:repeat(2,1fr)}
  .hero-grid{grid-template-columns:1fr}
  .cards,.req-list{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--navy);
    flex-direction:column;padding:1rem 1.5rem;gap:1rem;align-items:flex-start;border-top:1px solid rgba(255,255,255,.1)}
  .nav-links.open{display:flex}
  .hamburger{display:block}
  .role-chip{display:none}
  .stats,.form-grid,.detail-grid,.cards,.req-list,.foot-grid{grid-template-columns:1fr}
  .form-grid .full{grid-column:1}
  .step-body-inner{padding:0 1.3rem 1.3rem}
  .cta-band{padding:1.8rem}
  section.bloque{padding:2.4rem 0}
}
@media print{
  header,.toolbar,.row-actions,footer{display:none!important}
  .table-wrap{border:none;box-shadow:none}
  table{min-width:0;font-size:9pt}
}
