/* ============================================================================
   GGWO MEXICO — Estilos de la app (diseño aprobado en el prototipo).
   No es necesario editar este archivo para actualizar contenido: usa content.js
   ============================================================================ */

:root{
  --navy:#16314C; --navy-2:#1E3A5F;
  --warm:#DD7F45; --warm-soft:#F2D9C5;
  --brand:#7E97CC; --brand-soft:#E5EAF5;
  --cream:#F6EFE3; --cream-2:#FBF7EF;
  --ink:#1E2A36; --muted:#6C7A89; --line:#E4DBCB; --page:#DED7C8;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; background:var(--page);
  font-family:'Inter',system-ui,-apple-system,sans-serif; color:var(--ink);
  -webkit-font-smoothing:antialiased;
}

/* Contenedor tipo app: pantalla completa en móvil, centrado en escritorio */
.app{
  width:100%; max-width:430px; margin:0 auto;
  height:100dvh; min-height:100vh;
  background:var(--cream);
  display:flex; flex-direction:column; overflow:hidden;
  box-shadow:0 0 40px rgba(22,49,76,.12);
}

/* Encabezado */
.topbar{
  background:var(--navy); color:var(--cream-2);
  padding:calc(14px + env(safe-area-inset-top)) 18px 14px;
  display:flex; align-items:center; justify-content:center; gap:12px; flex-shrink:0;
}
.logo-chip{line-height:0; flex-shrink:0}
.logo-chip img{height:34px; width:auto; display:block}
.topbar .name{font-family:'Fraunces',Georgia,serif; font-size:19px; font-weight:600}
.topbar .sub{font-size:11px; color:#aebccb; margin-top:1px}

/* Zona de pantallas (scroll) */
.screens{flex:1; overflow-y:auto; -webkit-overflow-scrolling:touch; position:relative}
.screen{display:none; padding:18px 18px 28px; animation:fade .25s ease}
.screen.active{display:block}
@keyframes fade{from{opacity:0; transform:translateY(6px)} to{opacity:1; transform:none}}
@media (prefers-reduced-motion:reduce){ .screen, .detail{animation:none} }

.eyebrow{font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--warm); font-weight:600; margin:2px 0 10px}
h2.section{font-family:'Fraunces',Georgia,serif; font-size:23px; color:var(--navy); margin:0 0 14px}
h3.block{font-size:13px; letter-spacing:.04em; text-transform:uppercase; color:var(--muted); font-weight:600; margin:22px 0 10px; display:flex; align-items:center; justify-content:space-between}
h3.block .hint{font-size:10px; color:var(--brand); text-transform:none; letter-spacing:0; font-weight:500}

.card{background:var(--cream-2); border:1px solid var(--line); border-radius:16px; padding:15px 16px; margin-bottom:11px}
.card .when{font-size:12px; color:var(--warm); font-weight:600}
.card .title{font-family:'Fraunces',Georgia,serif; font-size:17px; color:var(--navy); margin:3px 0 2px}
.card .where{font-size:13px; color:var(--muted)}
.card .preacher{font-size:12.5px; color:var(--muted); margin-top:1px}

.hero{background:linear-gradient(160deg,var(--navy),var(--navy-2)); color:var(--cream-2); border-radius:20px; padding:20px; margin-bottom:6px; position:relative; overflow:hidden}
.hero:after{content:""; position:absolute; right:-30px; top:-30px; width:120px; height:120px; border-radius:50%; background:rgba(126,151,204,.28)}
.hero .tag{font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:#cdd8e3; font-weight:600}
.hero h2{font-family:'Fraunces',Georgia,serif; font-size:24px; margin:6px 0 8px; position:relative}
.hero p{font-size:13.5px; line-height:1.5; color:#cdd8e3; margin:0; position:relative}

/* Anuncios deslizables */
.ann-scroll{display:flex; gap:12px; overflow-x:auto; padding:4px 2px 10px; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch}
.ann-scroll::-webkit-scrollbar{height:5px}
.ann-scroll::-webkit-scrollbar-thumb{background:#cdc4b2; border-radius:3px}
.ann{scroll-snap-align:start; flex:0 0 215px; background:var(--cream-2); border:1px solid var(--line); border-radius:16px; overflow:hidden; cursor:pointer; text-align:left; padding:0; font-family:inherit; transition:transform .12s ease}
.ann:active{transform:scale(.98)}
.ann .top{height:74px; background:linear-gradient(135deg,var(--brand),#5f78b3); display:flex; align-items:flex-end; padding:10px 12px}
.ann .tag{font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:#fff; background:rgba(0,0,0,.18); padding:3px 8px; border-radius:999px; font-weight:600}
.ann .body{padding:11px 13px 13px}
.ann .t{font-family:'Fraunces',Georgia,serif; font-size:15px; color:var(--navy); line-height:1.25; margin-bottom:5px}
.ann .b{font-size:12px; color:var(--muted); line-height:1.4}
.ann .more{font-size:11.5px; color:var(--warm); font-weight:600; margin-top:9px}

/* Agenda */
.agenda-item{display:flex; gap:12px; align-items:center; background:var(--cream-2); border:1px solid var(--line); border-radius:14px; padding:11px 13px; margin-bottom:9px}
.date-chip{flex:0 0 50px; background:var(--brand-soft); border-radius:11px; text-align:center; padding:7px 0}
.date-chip .d{font-family:'Fraunces',Georgia,serif; font-size:20px; color:var(--navy); line-height:1}
.date-chip .mo{font-size:10px; text-transform:uppercase; letter-spacing:.06em; color:#5f78b3; margin-top:2px}
.agenda-item .info .nm{font-size:14.5px; font-weight:600; color:var(--ink)}
.agenda-item .info .meta{font-size:12px; color:var(--muted); margin-top:2px}
.agenda-item .info .dow{font-size:11px; color:var(--warm); font-weight:600; text-transform:capitalize}

.row{display:flex; justify-content:space-between; align-items:baseline; padding:11px 2px; border-bottom:1px solid var(--line)}
.row:last-child{border-bottom:none}
.row .l{font-size:14px; color:var(--ink); font-weight:500}
.row .r{font-size:12.5px; color:var(--muted); text-align:right}

.btn{display:inline-flex; align-items:center; gap:7px; border:none; cursor:pointer; font-family:inherit; font-size:13px; font-weight:600; border-radius:10px; padding:9px 14px; transition:transform .12s ease; text-decoration:none}
.btn:active{transform:scale(.97)}
.btn-wa{background:#1F8F4E; color:#fff}
.btn-wa[disabled]{background:#cdd3cd; color:#7c857c; cursor:not-allowed}
.btn-copy{background:var(--navy); color:var(--cream-2); padding:7px 12px; font-size:12px}
.btn-ghost{background:transparent; color:var(--warm); border:1px solid var(--warm)}

.ver-pill{display:inline-block; background:var(--warm-soft); color:#9a4b1d; font-size:12px; font-weight:600; padding:5px 12px; border-radius:999px; margin-bottom:14px}
.scripture{font-family:'Fraunces',Georgia,serif; font-size:19px; line-height:1.7; color:#243441}
.scripture .vn{font-size:11px; color:var(--warm); vertical-align:super; font-weight:600; margin-right:3px}
.credit{font-size:10.5px; color:#9aa6b2; line-height:1.5; margin-top:22px; border-top:1px solid var(--line); padding-top:12px}

.player{display:flex; align-items:center; gap:12px; background:var(--navy); border-radius:14px; padding:12px 14px; margin:10px 0 4px}
.play{width:38px; height:38px; border-radius:50%; background:var(--warm); display:flex; align-items:center; justify-content:center; flex-shrink:0; border:none; cursor:pointer}
.bar{flex:1; height:4px; background:rgba(255,255,255,.25); border-radius:3px; position:relative; overflow:hidden}
.bar > i{position:absolute; left:0; top:0; height:100%; width:0; background:var(--warm); border-radius:3px}
.ptime{font-size:11px; color:#aebccb; min-width:84px; text-align:right}
.player .bar{cursor:pointer}
.player .bar > i{transition:width .15s linear}
.audio-pending{font-size:12.5px; color:var(--muted); background:var(--cream-2); border:1px dashed var(--line); border-radius:12px; padding:11px 13px; margin:10px 0 4px}
.ai-box{background:var(--cream-2); border:1px solid var(--line); border-left:3px solid var(--warm); border-radius:0 12px 12px 0; padding:13px 15px; margin-top:10px}
.ai-box .lab{font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--warm); font-weight:600; margin-bottom:6px}
.ai-box p{font-size:13.5px; line-height:1.55; margin:0; color:#3a4754}
.ai-box ul{margin:6px 0 0; padding-left:18px}
.ai-box li{font-size:13.5px; line-height:1.5; margin-bottom:4px; color:#3a4754}

.data-line{display:flex; justify-content:space-between; align-items:center; padding:13px 0; border-bottom:1px solid var(--line)}
.data-line:last-child{border-bottom:none}
.data-line .k{font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted)}
.data-line .v{font-size:15px; font-family:'Fraunces',Georgia,serif; color:var(--navy)}
.note{font-size:12px; background:var(--warm-soft); border-radius:12px; padding:11px 13px; line-height:1.5; margin-top:16px; color:#8a4a23}
.placeholder-flag{font-size:11px; color:#9a4b1d; background:#fbeede; border:1px dashed #e3b48d; border-radius:10px; padding:8px 11px; margin-bottom:14px; line-height:1.45}
.muted-note{font-size:12.5px;color:var(--muted);margin-top:14px;line-height:1.5}

/* Lector de la Biblia */
.bible-controls{display:flex; gap:8px; margin-bottom:12px}
.bible-dd{position:relative; flex:1; min-width:0}
.bible-dd-btn{width:100%; display:flex; align-items:center; justify-content:space-between; gap:6px; font-family:inherit; font-size:13px; font-weight:600; padding:10px 12px; border:1px solid var(--line); border-radius:10px; background:var(--cream-2); color:var(--navy); cursor:pointer; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.bible-dd-btn[aria-expanded="true"]{border-color:var(--brand); box-shadow:0 0 0 3px var(--brand-soft)}
.bible-dd-panel{position:absolute; top:calc(100% + 6px); left:0; right:0; z-index:20; background:var(--cream-2); border:1px solid var(--line); border-radius:12px; padding:6px; box-shadow:0 14px 34px rgba(22,49,76,.20); max-height:300px; overflow-y:auto}
.bible-dd-opt{display:block; width:100%; text-align:left; font-family:inherit; font-size:13.5px; padding:10px 12px; border:none; background:none; color:var(--ink); cursor:pointer; border-radius:8px}
.bible-dd-opt:hover{background:var(--brand-soft)}
.bible-dd-opt.sel{background:var(--navy); color:var(--cream-2); font-weight:600}
.bible-picker-btn{flex:1.1; min-width:0; font-family:inherit; font-size:13px; font-weight:600; padding:10px 12px; border:1px solid var(--line); border-radius:10px; background:var(--cream-2); color:var(--navy); cursor:pointer; text-align:left; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.bible-picker-panel{background:var(--cream-2); border:1px solid var(--line); border-radius:14px; padding:12px; margin-bottom:14px; max-height:48vh; overflow-y:auto}
.bk-group{margin-bottom:10px}
.bk-title{font-size:11px; text-transform:uppercase; letter-spacing:.06em; color:var(--muted); font-weight:600; margin:6px 2px 8px}
.bk-grid{display:grid; grid-template-columns:1fr 1fr; gap:6px}
.bk{font-family:inherit; font-size:13px; text-align:left; padding:8px 10px; border:1px solid var(--line); border-radius:9px; background:var(--cream); color:var(--ink); cursor:pointer}
.bk:active{transform:scale(.98)}
.bk-back{font-family:inherit; font-size:12px; font-weight:600; color:var(--warm); background:none; border:none; cursor:pointer; padding:2px 2px 8px}
.ch-grid{display:grid; grid-template-columns:repeat(5,1fr); gap:6px}
.ch{font-family:inherit; font-size:14px; padding:9px 0; border:1px solid var(--line); border-radius:9px; background:var(--cream); color:var(--navy); font-weight:600; cursor:pointer}
.ch:active{transform:scale(.95)}
.bible-text{margin-top:2px; min-height:120px}
.bible-text .p{margin:0 0 12px}
.bible-text .yv-vlbl{font-size:11px; color:var(--warm); vertical-align:super; font-weight:600; margin-right:3px}
.bible-text .yv-f, .bible-text .yv-fn{display:none}
.bible-text .yv-s, .bible-text .yv-s1{font-family:'Inter',sans-serif; font-size:12px; letter-spacing:.04em; text-transform:uppercase; color:var(--muted); font-weight:600; margin:18px 0 8px; display:block}
.bible-loading, .bible-error{font-family:'Inter',sans-serif; font-size:13.5px; color:var(--muted); line-height:1.5}
.bible-nav{display:flex; justify-content:space-between; gap:10px; margin:18px 0 4px}
.bible-nav button{flex:1; font-family:inherit; font-size:13px; font-weight:600; padding:10px; border:1px solid var(--warm); border-radius:10px; background:transparent; color:var(--warm); cursor:pointer}
.bible-nav button:active{transform:scale(.98)}
.bible-nav button:disabled{opacity:.35; cursor:not-allowed}

/* Detalle de anuncio (overlay) */
.detail{position:absolute; inset:0; background:var(--cream); z-index:5; display:none; flex-direction:column; animation:slide .25s ease}
.detail.open{display:flex}
@keyframes slide{from{transform:translateX(14px); opacity:0} to{transform:none; opacity:1}}
.detail .dhead{height:150px; background:linear-gradient(135deg,var(--brand),#5f78b3); display:flex; align-items:flex-end; padding:16px}
.detail .dhead .tag{font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:#fff; background:rgba(0,0,0,.18); padding:4px 9px; border-radius:999px; font-weight:600}
.back{position:absolute; top:14px; left:14px; background:rgba(255,255,255,.92); border:none; border-radius:10px; padding:8px 11px; font-family:inherit; font-size:13px; font-weight:600; color:var(--navy); cursor:pointer; display:flex; align-items:center; gap:5px}
.detail .dbody{padding:18px; overflow-y:auto}
.detail h2{font-family:'Fraunces',Georgia,serif; font-size:22px; color:var(--navy); margin:0 0 10px}
.detail p{font-size:14px; line-height:1.6; color:#3a4754; margin:0 0 12px}
.detail .dmeta{font-size:13px; color:var(--muted); display:flex; gap:8px; align-items:center; margin-bottom:6px}
.detail .dmeta b{color:var(--navy); font-weight:600}

/* Barra de pestañas */
.tabbar{display:flex; background:var(--cream-2); border-top:1px solid var(--line); flex-shrink:0; padding:8px 4px calc(10px + env(safe-area-inset-bottom))}
.tab{flex:1; background:none; border:none; cursor:pointer; font-family:inherit; padding:6px 2px; color:var(--muted); display:flex; flex-direction:column; align-items:center; gap:4px}
.tab .ico{width:22px; height:22px}
.tab .lbl{font-size:10.5px; font-weight:500}
.tab.active{color:var(--navy)}
.tab.active .ico{color:var(--warm)}
.tab:focus-visible{outline:2px solid var(--warm); outline-offset:2px; border-radius:8px}
