/* Catálogo de Prédicas — Iglesia Viña Volcanes (interno)
   Tokens de marca tomados de vinavolcanes.cl (Automatic.css). */
:root{
  --primary:#5c6c4a; --primary-hover:#6a7c55; --primary-dark:#414c34;
  --primary-semi-light:#a7b795; --primary-light:#d9e0d1; --primary-ultra-light:#f2f5f0;
  --primary-trans:rgba(92,108,74,.15);
  --ink:#1a1a1a; --ink-soft:#404040; --gray:#636363;
  --line:#e7e9e3; --gray-light:#d9d9d9; --gray-ultra-light:#f3f4f1;
  --bg:#f6f8f3; --surface:#fff;
  --radius:14px; --radius-sm:9px;
  --shadow:0 1px 2px rgba(26,30,21,.06), 0 6px 20px rgba(26,30,21,.05);
  --font:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}

.site-header{background:var(--ink);color:#fff;padding:16px 24px;display:flex;align-items:center;gap:18px}
.site-header img{height:34px;width:auto;display:block}
.site-header .titles{display:flex;flex-direction:column;line-height:1.25}
.site-header h1{font-size:16px;margin:0;font-weight:600;letter-spacing:.2px}
.site-header .tag{font-size:12px;color:#b9c1ad}
.site-header .spacer{flex:1}
.site-header .badge{font-size:11px;border:1px solid rgba(255,255,255,.25);color:#cdd5c2;padding:4px 10px;border-radius:999px;white-space:nowrap}

.wrap{max-width:1200px;margin:0 auto;padding:0 24px 24px}

.filters{position:sticky;top:0;z-index:20;background:var(--bg);padding:16px 0;border-bottom:1px solid var(--line);
  display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.filters .search{flex:1;min-width:220px}
input[type="search"],select{font:inherit;color:var(--ink);background:var(--surface);border:1px solid var(--gray-light);
  border-radius:var(--radius-sm);padding:9px 12px;outline:none;width:100%}
input[type="search"]:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-trans)}
select{cursor:pointer}
.count{font-size:13px;color:var(--gray);margin:14px 2px}

/* Grilla de tarjetas (sin expansión en sitio → no se desordena) */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:16px;display:flex;flex-direction:column;gap:9px;cursor:pointer;transition:transform .12s ease, box-shadow .12s ease}
.card:hover{transform:translateY(-2px);box-shadow:0 2px 4px rgba(26,30,21,.07),0 14px 34px rgba(26,30,21,.09)}
.card:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
.card .top{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.date{font-size:12px;font-weight:600;color:var(--primary-dark);background:var(--primary-ultra-light);
  border:1px solid var(--primary-light);padding:3px 9px;border-radius:999px;white-space:nowrap}
.preacher{font-size:13px;color:var(--gray);font-weight:600;text-align:right}
.title{font-size:15.5px;font-weight:650;margin:0;color:var(--ink);line-height:1.3}
.passages{font-size:12px;color:var(--gray)}
.meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:12px;color:var(--ink-soft)}
.range{font-variant-numeric:tabular-nums;background:var(--gray-ultra-light);padding:2px 8px;border-radius:7px}
.flags{display:flex;flex-wrap:wrap;gap:5px}
.flag{font-size:11px;padding:1px 8px;border-radius:999px;background:#fdf3d6;color:#8a6d12;border:1px solid #f0e2b0;cursor:help}
.flag.especial{background:var(--primary-ultra-light);color:var(--primary-dark);border-color:var(--primary-light)}
.flag.no_sermon,.flag.bad_range,.flag.preacher_mismatch,.flag.error_subtitulos,.flag.error_analisis{background:#fbe6e6;color:#9c2a2a;border-color:#f0c4c4}
.flag.sin_subtitulos,.flag.incompleto{background:#eceff3;color:#5b6470;border-color:#d7dde4}
.card-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:auto;padding-top:6px}
.detalle{font-size:12px;color:var(--primary);font-weight:600;white-space:nowrap}
.card:hover .detalle{text-decoration:underline}
.card.incomplete{border-style:dashed;background:#fbfbf9}
.card.incomplete .title{color:var(--ink-soft);font-weight:600}

.btn{font:inherit;font-size:12.5px;font-weight:600;border-radius:999px;padding:7px 13px;cursor:pointer;border:1px solid transparent;display:inline-flex;align-items:center;gap:6px;text-decoration:none}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-hover);text-decoration:none}
.btn-ghost{background:transparent;border-color:var(--gray-light);color:var(--ink-soft)}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary-dark);text-decoration:none}

.site-footer{margin-top:30px;padding:22px 24px;background:var(--ink);color:#b9c1ad;font-size:12px;text-align:center}
.empty{padding:60px 0;text-align:center;color:var(--gray)}

/* Modal de detalle */
.modal[hidden]{display:none}
.modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}
.modal-backdrop{position:absolute;inset:0;background:rgba(20,24,16,.55);backdrop-filter:blur(3px)}
.modal-card{position:relative;background:var(--surface);border-radius:16px;max-width:660px;width:100%;max-height:86vh;
  overflow:auto;box-shadow:0 24px 70px rgba(0,0,0,.35);padding:26px 26px 22px;animation:pop .14s ease}
@keyframes pop{from{transform:translateY(8px) scale(.985);opacity:0}to{transform:none;opacity:1}}
.modal-close{position:absolute;top:10px;right:12px;border:none;background:transparent;font-size:26px;line-height:1;
  color:var(--gray);cursor:pointer;padding:2px 9px;border-radius:8px}
.modal-close:hover{background:var(--gray-ultra-light);color:var(--ink)}
.m-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:2px 30px 6px 0}
.m-title{font-size:21px;margin:4px 0 6px;line-height:1.25}
.m-range{font-size:13px;color:var(--ink-soft);margin:6px 0}
.m-desc{font-size:14.5px;color:var(--ink-soft);margin:12px 0}
.modal-card h3{font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--primary-dark);margin:18px 0 8px}
.m-outline{margin:0;padding-left:20px}
.m-outline li{margin:7px 0;font-size:14px}
.m-outline b{font-weight:650}
.modal-card blockquote{margin:8px 0;padding:8px 12px;border-left:3px solid var(--primary-light);
  background:var(--primary-ultra-light);border-radius:0 8px 8px 0;font-style:italic;color:var(--ink-soft);font-size:13.5px}
.note{font-size:13px;color:var(--ink-soft);background:var(--gray-ultra-light);border-radius:9px;padding:9px 11px;margin:10px 0}
.banner{background:#eceff3;color:#41505f;border:1px solid #d7dde4;border-radius:9px;padding:11px 13px;font-size:13px;margin:12px 0}
.kws{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.kw{font-size:11.5px;background:var(--gray-ultra-light);color:var(--ink-soft);padding:3px 9px;border-radius:999px}
.m-actions{display:flex;gap:8px;margin-top:20px;flex-wrap:wrap}

@media(max-width:640px){
  .grid{grid-template-columns:1fr}
  .site-header{flex-wrap:wrap;gap:12px}
  .site-header .badge{order:3}
  .modal{padding:0}
  .modal-card{max-height:100vh;border-radius:0}
}
