/* ==========================================================================
   WARPATH — Sistema interno (portal alumno + panel admin)
   Reutiliza la identidad del sitio: rojo/negro, Barlow Condensed.
   ========================================================================== */
@font-face{font-family:'Barlow Condensed';src:url('../fonts/BarlowCondensed-700.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Barlow Condensed';src:url('../fonts/BarlowCondensed-600.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'Barlow';src:url('../fonts/Barlow-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Barlow';src:url('../fonts/Barlow-500.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Barlow';src:url('../fonts/Barlow-600.woff2') format('woff2');font-weight:600;font-display:swap}

:root{
  --red:#E11D2A;--red-dark:#B3141F;--red-glow:rgba(225,29,42,.4);
  --bg:#0A0A0B;--ink:#121214;--surface:#18181B;--surface-2:#202024;--border:#2A2A2E;
  --white:#F8FAFC;--muted:#A1A1AA;--muted-2:#71717A;
  --green:#22C55E;--amber:#F59E0B;--rose:#EF4444;--blue:#3B82F6;
  --fhead:'Barlow Condensed','Bahnschrift SemiBold Condensed','Bahnschrift','Oswald','Arial Narrow',sans-serif;
  --fbody:'Barlow',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --r:14px;--r-sm:9px;--ease:cubic-bezier(.22,.61,.36,1);--side:248px;
}
*,*::before,*::after{box-sizing:border-box}*{margin:0}
body{font-family:var(--fbody);background:var(--bg);color:var(--white);line-height:1.6;font-size:15px;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer}ul{list-style:none;padding:0}
h1,h2,h3,h4{font-family:var(--fhead);font-weight:700;text-transform:uppercase;letter-spacing:.01em;line-height:1.05}
img,svg{display:block;max-width:100%}
.muted{color:var(--muted)}.center{text-align:center}

/* ---------- Botones ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--fhead);font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:15px;padding:11px 20px;border:1.5px solid var(--red);border-radius:var(--r-sm);background:var(--red);color:#fff;min-height:42px;transition:filter .2s,box-shadow .2s,transform .12s,background .2s,color .2s}
.btn:hover{filter:brightness(1.08);box-shadow:0 6px 20px var(--red-glow)}
.btn:active{transform:translateY(1px)}
.btn--ghost{background:transparent;color:var(--white);border-color:var(--border)}
.btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.05);box-shadow:none;filter:none}
.btn--sm{padding:7px 14px;min-height:34px;font-size:13px}
.btn--ok{background:var(--green);border-color:var(--green)}
.btn--danger{background:transparent;border-color:var(--rose);color:var(--rose)}
.btn--danger:hover{background:var(--rose);color:#fff}
.btn--block{width:100%}

/* ---------- Campos ---------- */
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--fhead);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:12px;color:var(--muted);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-sm);color:var(--white);padding:12px 14px;font:inherit;transition:border-color .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--red)}
.field textarea{min-height:96px;resize:vertical}
.field .hint{font-size:12px;color:var(--muted-2);margin-top:6px}

/* ---------- Tarjetas ---------- */
.card{background:linear-gradient(180deg,var(--surface),var(--ink));border:1px solid var(--border);border-radius:var(--r);padding:22px}
.card__title{font-size:18px;margin-bottom:4px}

/* ---------- Badges ---------- */
.badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--fhead);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:12px;padding:4px 10px;border-radius:100px;border:1px solid transparent}
.badge::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.b-green{color:var(--green);background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.3)}
.b-amber{color:var(--amber);background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.3)}
.b-rose{color:var(--rose);background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.3)}
.b-blue{color:var(--blue);background:rgba(59,130,246,.12);border-color:rgba(59,130,246,.3)}
.b-gray{color:var(--muted);background:rgba(161,161,170,.1);border-color:var(--border)}

/* ---------- Tablas ---------- */
.table{width:100%;border-collapse:collapse}
.table th{font-family:var(--fhead);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:12px;color:var(--muted);text-align:left;padding:12px 14px;border-bottom:1px solid var(--border)}
.table td{padding:14px;border-bottom:1px solid var(--border);font-size:14px;vertical-align:middle}
.table tr:hover td{background:rgba(255,255,255,.02)}
.table tr:last-child td{border-bottom:0}
.avatar{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-family:var(--fhead);font-weight:700;color:#fff;background:linear-gradient(135deg,var(--red),var(--red-dark));font-size:15px;flex:0 0 auto}
.user-cell{display:flex;align-items:center;gap:12px}
.user-cell small{display:block;color:var(--muted);font-size:12px}

/* ---------- Auth (login/registro) ---------- */
.auth{min-height:100vh;display:grid;place-items:center;padding:24px;background:
  radial-gradient(60% 60% at 50% 0%,rgba(225,29,42,.16),transparent 60%),var(--bg)}
.auth__card{width:100%;max-width:420px;background:linear-gradient(180deg,var(--surface),var(--ink));border:1px solid var(--border);border-radius:18px;padding:36px 32px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.auth__logo{height:90px;margin:0 auto 18px}
.auth h1{font-size:30px;text-align:center;margin-bottom:4px}
.auth .sub{text-align:center;color:var(--muted);margin-bottom:26px;font-size:14px}
.auth__alt{text-align:center;margin-top:20px;color:var(--muted);font-size:14px}
.auth__alt a{color:var(--red);font-weight:600}

/* ---------- App shell ---------- */
.shell{display:grid;grid-template-columns:var(--side) 1fr;min-height:100vh}
.sidebar{background:var(--ink);border-right:1px solid var(--border);padding:22px 16px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.sidebar__brand{display:flex;align-items:center;gap:10px;padding:0 6px 20px;margin-bottom:10px;border-bottom:1px solid var(--border)}
.sidebar__brand img{height:54px}
.side-nav{display:flex;flex-direction:column;gap:3px;margin-top:8px}
.side-nav a{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:10px;color:var(--muted);font-weight:500;transition:background .2s,color .2s}
.side-nav a svg{width:19px;height:19px;flex:0 0 auto}
.side-nav a:hover{background:var(--surface);color:var(--white)}
.side-nav a.active{background:rgba(225,29,42,.14);color:#fff}
.side-nav a.active svg{color:var(--red)}
.side-sep{font-family:var(--fhead);font-weight:600;text-transform:uppercase;letter-spacing:.14em;font-size:11px;color:var(--muted-2);padding:16px 12px 6px}
.sidebar__foot{margin-top:auto;padding-top:16px;border-top:1px solid var(--border)}
.main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 28px;border-bottom:1px solid var(--border);background:rgba(10,10,11,.6);backdrop-filter:blur(8px);position:sticky;top:0;z-index:10}
.topbar h1{font-size:24px}
.topbar__user{display:flex;align-items:center;gap:10px}
.content{padding:28px;display:flex;flex-direction:column;gap:24px}

/* ---------- Stat cards ---------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}
.stat{background:linear-gradient(180deg,var(--surface),var(--ink));border:1px solid var(--border);border-left:3px solid var(--red);border-radius:var(--r);padding:18px 20px}
.stat__label{font-family:var(--fhead);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:12px;color:var(--muted)}
.stat__value{font-family:var(--fhead);font-weight:700;font-size:38px;line-height:1.1;margin-top:6px}
.stat__sub{font-size:12px;color:var(--muted);margin-top:2px}
.stat--green{border-left-color:var(--green)}.stat--amber{border-left-color:var(--amber)}.stat--blue{border-left-color:var(--blue)}

/* ---------- Membresía (alumno) ---------- */
.mem{display:grid;grid-template-columns:1.3fr 1fr;gap:20px}
.mem__hero{background:linear-gradient(135deg,var(--red-dark),var(--red));border-radius:var(--r);padding:28px;position:relative;overflow:hidden}
.mem__hero::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 120% at 0 0,rgba(0,0,0,.3),transparent 60%)}
.mem__hero>*{position:relative;z-index:1}
.mem__state{font-family:var(--fhead);font-weight:700;text-transform:uppercase;font-size:34px}
.mem__days{font-size:54px;font-family:var(--fhead);font-weight:700;line-height:1}
.mem__bar{height:8px;border-radius:100px;background:rgba(0,0,0,.3);margin-top:16px;overflow:hidden}
.mem__bar i{display:block;height:100%;background:#fff;border-radius:100px}

/* ---------- CMS ---------- */
.cms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}
.cms-item{border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden;background:var(--surface)}
.cms-item__img{height:120px;background-size:cover;background-position:center;background-color:var(--surface-2)}
.cms-item__body{padding:12px}
.cms-item__body h4{font-size:15px}
.cms-item__row{display:flex;align-items:center;justify-content:space-between;margin-top:8px}

/* Toggle switch */
.switch{position:relative;display:inline-flex;align-items:center;cursor:pointer;gap:8px;font-size:13px;color:var(--muted)}
.switch input{display:none}
.switch .track{width:40px;height:22px;border-radius:100px;background:var(--surface-2);border:1px solid var(--border);position:relative;transition:background .2s}
.switch .track::after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--muted);transition:transform .2s,background .2s}
.switch input:checked + .track{background:rgba(34,197,94,.3);border-color:var(--green)}
.switch input:checked + .track::after{transform:translateX(18px);background:var(--green)}

.section-head{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.tabs{display:flex;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:100px;padding:4px}
.tabs button{border:0;background:transparent;color:var(--muted);font-family:var(--fhead);font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:13px;padding:7px 16px;border-radius:100px}
.tabs button.active{background:var(--red);color:#fff}

@media(max-width:880px){
  .shell{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-260px;z-index:50;transition:left .25s;width:248px}
  .sidebar.open{left:0}
  .mem{grid-template-columns:1fr}
  .content{padding:18px}
  .topbar{padding:14px 18px}
}

/* ---------- Modal de vista previa (estilo del sitio público) ---------- */
.pv-overlay{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.75);backdrop-filter:blur(4px);display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto}
.pv-overlay.open{display:flex}
.pv-modal{width:100%;max-width:760px;background:var(--bg);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:0 40px 100px rgba(0,0,0,.6)}
.pv-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:1px solid var(--border);background:var(--ink)}
.pv-bar span{font-family:var(--fhead);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:13px;color:var(--muted)}
.pv-close{background:none;border:1px solid var(--border);color:#fff;border-radius:8px;width:34px;height:34px;cursor:pointer}
.pv-article{padding:40px clamp(20px,5vw,56px) 56px}
.pv-article .pv-title{font-family:var(--fhead);font-weight:800;text-transform:uppercase;font-size:clamp(30px,5vw,48px);line-height:1.02;letter-spacing:-.01em;margin-bottom:6px}
.pv-eyebrow{font-family:var(--fhead);font-weight:700;text-transform:uppercase;letter-spacing:.2em;font-size:13px;color:var(--red)}
.pv-body{margin-top:26px;color:#d4d4d8;font-size:17px;line-height:1.75}
.pv-body h1,.pv-body h2,.pv-body h3{font-family:var(--fhead);font-weight:700;text-transform:uppercase;color:#fff;margin:26px 0 10px;line-height:1.1}
.pv-body h2{font-size:28px}.pv-body h3{font-size:22px}
.pv-body p{margin:0 0 16px}
.pv-body a{color:var(--red);text-decoration:underline}
.pv-body ul,.pv-body ol{margin:0 0 16px 22px}.pv-body li{margin-bottom:6px}
.pv-body blockquote{border-left:3px solid var(--red);padding:6px 0 6px 18px;margin:20px 0;color:#fff;font-size:20px;font-style:italic}
.pv-body img{max-width:100%;border-radius:12px;margin:18px 0}
.pv-body iframe,.post-body iframe{width:100%;aspect-ratio:16/9;height:auto;border:0;border-radius:12px;margin:18px 0;display:block}
.ql-editor iframe{width:100%;aspect-ratio:16/9;height:auto;border:0;border-radius:10px;display:block;margin:12px 0}
