/* =========================================================================
   El Liderazgo de Jesús — Micrositio de refuerzo
   Adaptación MOBILE-FIRST del sistema de slides (1920×1080) a layout fluido.
   Reusa los tokens y recetas de sesion1.css (cargado antes que este archivo).
   Identidad: crema sólido para contenido, banner+scrim solo en portada,
   dorado como acento, numerales romanos en contorno, esquinas 4px, mucho aire.
   ========================================================================= */

:root{
  --maxw: 720px;          /* ancho de lectura cómodo en desktop */
  --pad: 22px;            /* padding lateral base (móvil) */
  --radius: 4px;          /* esquinas del sistema */
  --tab-h: 54px;
  /* degradado cálido de respaldo para la portada (si falta el banner) */
  --cover-grad:
    radial-gradient(120% 90% at 20% 0%, rgba(120,92,54,.55), transparent 60%),
    linear-gradient(160deg,#3a2c1c 0%, #221a11 70%);
}

/* ---- reset del lienzo (sesion1.css pinta body en negro para slides) ---- */
html,body{background:var(--cream);color:var(--ink);}
body{
  font-family:var(--sans);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.5;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
:focus-visible{outline:2px solid var(--gold-deep);outline-offset:3px;border-radius:3px;}
::selection{background:rgba(183,137,76,.22);}

.site{max-width:var(--maxw);margin:0 auto;background:var(--cream);min-height:100vh;}

/* ============================ PORTADA ==================================== */
.cover{
  position:relative;overflow:hidden;
  padding:0;color:var(--cream);
  min-height:clamp(360px, 64vh, 540px);
  display:flex;
  background-color:#2b2117;          /* respaldo sólido */
  background-size:cover;background-position:center;
}
/* Si existe assets/banner-COLOR.png se usa; si no (404), cae al degradado.
   Mayor especificidad que `.bg.COLOR` de sesion1.css para controlar el fallback.
   Rutas relativas a /css/ → ../assets/. */
.cover.bg.brown { background-image:url("../assets/banner-brown.png"),  var(--cover-grad); }
.cover.bg.blue  { background-image:url("../assets/banner-blue.png"),   var(--cover-grad); }
.cover.bg.yellow{ background-image:url("../assets/banner-yellow.png"), var(--cover-grad); }
.cover.bg.gray  { background-image:url("../assets/banner-gray.png"),   var(--cover-grad); }
.cover-scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg, rgba(9,7,4,.28) 0%, rgba(9,7,4,.55) 55%, rgba(9,7,4,.82) 100%);}
.cover-inner{
  position:relative;z-index:2;
  display:flex;flex-direction:column;
  padding:calc(env(safe-area-inset-top) + 26px) var(--pad) 30px;
  width:100%;
}
.cover .meta{font-size:13px;letter-spacing:.16em;color:var(--gold-2);}
.cover .meta .r{color:rgba(244,237,225,.62);letter-spacing:.10em;}
.cover .grow{flex:1 1 auto;min-height:48px;}
.cover .kicker{font-size:13px;letter-spacing:.24em;color:var(--gold-2);margin-bottom:12px;}
.cover .title{
  font-size:clamp(34px, 11vw, 60px);
  text-transform:uppercase;letter-spacing:-.02em;line-height:1.0;font-weight:800;
  color:var(--cream);text-wrap:balance;
}
.cover .rule{margin:20px 0 18px;}
.cover-verse{margin:0;}
.cover-verse .verse{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(19px, 5.6vw, 26px);line-height:1.32;color:var(--cream);
}
.cover-verse .ref{
  margin-top:12px;font-family:var(--sans);font-style:normal;
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--gold-2);
}

/* ============================ TABS ====================================== */
.tabs{
  position:sticky;top:0;z-index:20;
  display:flex;gap:2px;
  background:rgba(244,237,225,.92);
  -webkit-backdrop-filter:saturate(140%) blur(8px);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line);
  padding:0 6px;
  overflow-x:auto;scrollbar-width:none;
}
.tabs::-webkit-scrollbar{display:none;}
.tab{
  flex:1 0 auto;min-width:max-content;
  height:var(--tab-h);
  background:none;border:none;cursor:pointer;
  font-family:var(--sans);font-weight:700;
  font-size:12.5px;letter-spacing:.10em;text-transform:uppercase;
  color:var(--muted);
  padding:0 16px;
  border-bottom:2px solid transparent;
  transition:color .18s ease, border-color .18s ease;
}
.tab[aria-selected="true"]{color:var(--gold-deep);border-bottom-color:var(--gold);}
.tab:hover{color:var(--ink);}

/* ============================ PANELES =================================== */
.panel{padding:30px var(--pad) 16px;animation:fade .3s ease;}
.panel[hidden]{display:none;}
@keyframes fade{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}

/* bloque genérico de sección dentro de un panel */
.block{margin:0 0 38px;}
.block:last-child{margin-bottom:8px;}

.eyebrow{
  font-size:12px;letter-spacing:.24em;text-transform:uppercase;font-weight:700;
  color:var(--gold-deep);margin:0 0 12px;
}
.h-sec{
  font-size:clamp(22px, 6.4vw, 30px);font-weight:800;line-height:1.08;
  text-transform:uppercase;letter-spacing:-.015em;color:var(--ink);margin:0 0 14px;
}
.lead{
  font-size:clamp(18px, 5vw, 22px);line-height:1.4;font-weight:500;color:#2c2519;
}
.body{font-size:clamp(16px,4.4vw,18px);line-height:1.55;color:#3a3225;font-weight:400;}
.muted{color:var(--muted);}
.gold{color:var(--gold-deep);}
.center{text-align:center;}

/* cita interior (sobre crema) */
.verse-block{margin:0;padding:4px 0 0;}
.verse-block .verse{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(20px,5.6vw,26px);line-height:1.3;color:var(--ink);
}
.verse-block .ref{
  display:block;margin-top:10px;font-family:var(--sans);font-style:normal;
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--gold-deep);
}

/* ---------------- Verdades (numeral romano en contorno) ---------------- */
.truth{
  position:relative;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 22px 26px;margin:0 0 22px;overflow:hidden;
}
.truth .roman{
  position:absolute;top:-14px;right:6px;
  font-family:var(--serif);font-weight:600;line-height:.8;
  font-size:clamp(96px,30vw,150px);
  color:transparent;-webkit-text-stroke:2px var(--gold-2);
  opacity:.5;pointer-events:none;
}
.truth .t-ref{
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
  color:var(--gold-deep);margin:0 0 8px;
}
.truth .t-title{
  position:relative;z-index:1;
  font-size:clamp(19px,5.4vw,24px);font-weight:800;line-height:1.14;
  letter-spacing:-.01em;color:var(--ink);max-width:80%;margin:0 0 16px;
}
/* banda de principio (reusa .principio del sistema, re-escalada) */
.principio{
  background:var(--ink);color:var(--cream);border-radius:var(--radius);
  padding:22px 22px;display:flex;gap:16px;align-items:flex-start;margin-top:14px;
}
.principio .qm{
  font-family:var(--serif);font-size:62px;line-height:.7;color:var(--gold-2);
  height:34px;flex-shrink:0;
}
.principio .pt{font-size:clamp(16px,4.4vw,19px);line-height:1.4;font-weight:500;}
.principio .pt b{color:var(--gold-2);font-weight:700;}

/* chips de referencia */
.refs-hint{
  font-size:12.5px;color:var(--gold-deep);opacity:.85;margin:0 0 12px;
}
.refs{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px;}
.chip{
  border:1px solid var(--line);border-radius:999px;
  padding:8px 15px;font-size:13px;font-weight:600;
  color:var(--gold-deep);background:rgba(183,137,76,.06);white-space:nowrap;
}
/* chips que revelan el versículo al tocarlos */
.chip-tap{
  font-family:var(--sans);cursor:pointer;
  display:inline-flex;align-items:center;gap:7px;
  transition:background .15s ease,border-color .15s ease,color .15s ease;
}
.chip-tap::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--gold);flex-shrink:0;transition:background .15s ease;
}
.chip-tap:hover{background:rgba(183,137,76,.14);border-color:var(--gold);}
.chip-tap.is-open{background:var(--gold);border-color:var(--gold);color:#fff;}
.chip-tap.is-open::before{background:#fff;}

/* panel del texto del versículo revelado */
.verse-reveal{
  margin-top:14px;padding:18px 20px;
  background:rgba(183,137,76,.06);
  border-left:3px solid var(--gold);border-radius:10px;
  animation:vp-fade .2s ease;
}
.verse-reveal .vp-text{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(16px,4.4vw,19px);line-height:1.45;color:var(--ink);
}
.verse-reveal .vp-ref{
  margin-top:10px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  font-weight:700;color:var(--gold-deep);
}
@keyframes vp-fade{from{opacity:0;transform:translateY(-4px);}to{opacity:1;transform:none;}}

/* ---------------- Lista numerada de síntesis (.nlist) ------------------ */
.nlist{display:flex;flex-direction:column;gap:18px;}
.nrow{display:grid;grid-template-columns:46px 1fr;gap:16px;align-items:start;}
.nrow .n{font-family:var(--serif);font-size:44px;font-weight:600;color:var(--gold);line-height:.86;}
.nrow .nc .h{font-size:clamp(16px,4.4vw,18px);font-weight:600;color:#231d14;line-height:1.32;}

/* ---------------- Banda de tesis / cierre ------------------------------ */
.thesis{
  background:var(--ink);color:var(--cream);border-radius:var(--radius);
  padding:34px 24px;text-align:center;margin:30px 0 8px;
}
.thesis .verse{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(20px,5.8vw,28px);line-height:1.34;color:var(--cream);
}
.thesis .verse b{color:var(--gold-2);font-style:normal;font-weight:600;}

/* ============================ FLASHCARDS =============================== */
.fc-help{font-size:14px;color:var(--muted);margin:0 0 18px;}
.fc-grid{display:flex;flex-direction:column;gap:16px;}
.flashcard{
  background:none;border:none;padding:0;width:100%;cursor:pointer;
  perspective:1400px;font-family:inherit;text-align:left;
}
.fc-inner{
  position:relative;width:100%;min-height:188px;
  transition:transform .55s cubic-bezier(.4,.16,.2,1);
  transform-style:preserve-3d;
}
.flashcard.is-flipped .fc-inner{transform:rotateY(180deg);}
.fc-face{
  position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;
  border-radius:var(--radius);padding:24px 22px;
  display:flex;flex-direction:column;justify-content:center;gap:12px;
}
.fc-front{background:var(--paper);border:1px solid var(--line);}
.fc-back{background:var(--ink);border:1px solid rgba(184,138,79,.4);transform:rotateY(180deg);}
.fc-kind{
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;color:var(--gold-deep);
}
.fc-back .fc-kind{color:var(--gold-2);}
.fc-front .fc-text{font-size:clamp(18px,5vw,21px);line-height:1.3;font-weight:600;color:#2c2519;}
.fc-back .fc-text{font-size:clamp(16px,4.6vw,19px);line-height:1.42;color:var(--cream);}
.fc-back .fc-text.scripture{font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(18px,5vw,22px);}
.fc-ref{font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--gold-2);margin-top:auto;}
.fc-flip-hint{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.fc-back .fc-flip-hint{color:rgba(244,237,225,.45);}

/* ============================ QUIZ ===================================== */
.quiz-intro{font-size:14px;color:var(--muted);margin:0 0 22px;line-height:1.5;}
.q{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px 20px;margin:0 0 18px;
}
.q-num{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:var(--gold-deep);margin:0 0 10px;}
.q-text{font-size:clamp(17px,4.6vw,19px);font-weight:600;line-height:1.35;color:#231d14;margin:0 0 16px;}
.opts{display:flex;flex-direction:column;gap:10px;}
.opt{
  display:flex;align-items:flex-start;gap:12px;width:100%;text-align:left;
  background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);
  padding:14px 15px;font-family:inherit;font-size:15.5px;line-height:1.35;color:#2c2519;
  cursor:pointer;transition:border-color .15s,background .15s;
}
.opt:hover:not(:disabled){border-color:var(--gold-2);}
.opt .mark{
  flex-shrink:0;width:22px;height:22px;border-radius:999px;border:1.5px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:transparent;
  margin-top:1px;
}
.opt:disabled{cursor:default;}
.opt.correct{border-color:var(--gold);background:rgba(183,137,76,.10);}
.opt.correct .mark{border-color:var(--gold);background:var(--gold);color:var(--ink);}
.opt.wrong{border-color:#9a7b5a;background:rgba(154,123,90,.10);opacity:.92;}
.opt.wrong .mark{border-color:#9a7b5a;color:#9a7b5a;}
.opt.dim{opacity:.5;}
.explain{
  margin-top:14px;padding:14px 16px;border-left:3px solid var(--gold);
  background:rgba(183,137,76,.07);border-radius:0 var(--radius) var(--radius) 0;
  font-size:14.5px;line-height:1.5;color:#3a3225;
}
.explain .verdict{display:block;font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:12px;margin-bottom:6px;}
.explain .verdict.ok{color:var(--gold-deep);}
.explain .verdict.no{color:#8a6a44;}

/* resumen "qué repasar" (sin puntaje) */
.review{
  background:var(--ink);color:var(--cream);border-radius:var(--radius);
  padding:28px 24px;margin-top:26px;
}
.review h3{font-size:clamp(18px,5vw,22px);text-transform:uppercase;letter-spacing:-.01em;color:var(--cream);margin:0 0 8px;}
.review .lead{color:var(--cream);font-size:16px;margin-bottom:18px;}
.review ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:12px;}
.review li{display:grid;grid-template-columns:18px 1fr;gap:12px;font-size:15px;line-height:1.4;color:rgba(244,237,225,.9);}
.review li::before{content:"·";color:var(--gold-2);font-size:26px;line-height:.6;}
.review .allgood{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--gold-2);}
.btn-row{margin-top:20px;}

/* ============================ AUTOEVALUACIÓN =========================== */
.ae-intro{font-size:15px;line-height:1.55;color:#3a3225;margin:0 0 6px;}
.ae-scalelegend{font-size:12.5px;color:var(--muted);margin:0 0 24px;line-height:1.5;}
.ae-q{border-top:1px solid var(--line);padding:20px 0 4px;}
.ae-q:first-of-type{border-top:none;}
.ae-q .ae-text{font-size:clamp(16px,4.4vw,18px);font-weight:600;line-height:1.34;color:#231d14;margin:0 0 14px;}
.likert{display:flex;gap:8px;justify-content:space-between;}
.lk{
  flex:1;aspect-ratio:1/1;max-width:58px;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  font-family:var(--serif);font-size:22px;font-weight:600;color:var(--muted);
  cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;
}
.lk:hover{border-color:var(--gold-2);}
.lk[aria-pressed="true"]{background:var(--gold);border-color:var(--gold-deep);color:var(--ink);}
.lk-ends{display:flex;justify-content:space-between;margin-top:8px;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-weight:600;}

.ae-submit{
  width:100%;margin-top:26px;
  background:var(--ink);color:var(--cream);border:none;border-radius:var(--radius);
  padding:18px;font-family:var(--sans);font-weight:700;font-size:14px;
  letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:opacity .15s;
}
.ae-submit:disabled{opacity:.4;cursor:not-allowed;}
.ae-submit:not(:disabled):hover{background:var(--ink-2);}

/* resultado: perfil por banda (sin número crudo) */
.profile{
  background:var(--ink);color:var(--cream);border-radius:var(--radius);
  padding:30px 24px;margin-top:8px;text-align:center;
}
.profile .eyebrow{color:var(--gold-2);}
.profile .band-name{
  font-family:var(--serif);font-style:italic;font-weight:600;
  font-size:clamp(30px,9vw,46px);color:var(--gold-2);line-height:1.05;margin:6px 0 14px;
}
.profile .bands-meter{display:flex;gap:6px;justify-content:center;margin:0 0 20px;}
.profile .bm{height:6px;width:46px;border-radius:999px;background:rgba(244,237,225,.18);}
.profile .bm.on{background:var(--gold-2);}
.profile .reco{font-size:clamp(15px,4.4vw,17px);line-height:1.55;color:rgba(244,237,225,.92);text-align:left;}
.profile .reco b{color:var(--gold-2);}
.profile .ae-redo{
  margin-top:22px;background:none;border:1px solid var(--gold-2);color:var(--gold-2);
  border-radius:999px;padding:11px 22px;font-family:var(--sans);font-weight:700;
  font-size:12px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;
}

/* reflexión global (sin puntuación) */
.global-ref{margin-top:30px;border-top:1px solid var(--line);padding-top:26px;}
.global-ref .note{font-size:13px;color:var(--muted);margin:0 0 16px;font-style:italic;}
.global-ref ol{margin:0;padding-left:0;list-style:none;counter-reset:g;display:flex;flex-direction:column;gap:14px;}
.global-ref li{counter-increment:g;display:grid;grid-template-columns:30px 1fr;gap:12px;
  font-size:clamp(15px,4.2vw,17px);line-height:1.4;color:#2c2519;}
.global-ref li::before{content:counter(g);font-family:var(--serif);font-weight:600;font-size:26px;color:var(--gold);line-height:1;}

.ae-closing{margin-top:28px;text-align:center;}
.ae-closing .verse{font-family:var(--serif);font-style:italic;font-size:clamp(18px,5vw,22px);color:var(--ink);line-height:1.4;}

/* ============================ PROGRESO ================================= */
.done-pill{
  display:inline-flex;align-items:center;gap:7px;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
  color:var(--gold-deep);background:rgba(183,137,76,.08);
  border:1px solid var(--line);border-radius:999px;padding:5px 12px;margin-bottom:18px;
}
.done-pill::before{content:"✓";color:var(--gold);font-weight:800;}
.tab .tdot{display:inline-block;width:5px;height:5px;border-radius:999px;background:var(--gold);margin-left:6px;vertical-align:middle;opacity:0;transition:opacity .2s;}
.tab.tab-done .tdot{opacity:1;}

/* ============================ FOOTER / BOOT ============================ */
.site-footer{
  margin-top:34px;padding:24px var(--pad) calc(env(safe-area-inset-bottom) + 28px);
  border-top:1px solid var(--line);
  font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);
  display:flex;gap:10px;justify-content:center;font-weight:600;
}
.site-footer .sep{color:var(--gold);}

.boot{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  background:var(--cream);z-index:50;}
.boot .verse{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--muted);}
.boot.err .verse{color:#8a6a44;}
body.ready .boot{display:none;}

/* botón genérico de acento */
.btn{
  display:inline-block;background:var(--gold);color:var(--ink);
  border:none;border-radius:999px;padding:12px 24px;
  font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.08em;
  text-transform:uppercase;cursor:pointer;transition:background .15s;
}
.btn:hover{background:var(--gold-2);}
.btn.ghost{background:none;border:1px solid var(--gold);color:var(--gold-deep);}

/* ============================ DESKTOP ENHANCE ========================== */
@media (min-width:560px){
  :root{--pad:34px;}
  .cover-inner{padding-top:calc(env(safe-area-inset-top) + 34px);}
  .fc-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
}
@media (min-width:760px){
  :root{--pad:0px;}
  .site{box-shadow:0 0 0 1px var(--line);}
  .cover-inner,.panel,.tabs,.site-footer{padding-left:44px;padding-right:44px;}
  .tabs{padding-top:0;padding-bottom:0;}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;}
  .fc-inner{transition:none;}
}
