:root{
  --paper:#fffcf5; --paper-2:#f6f4ea; --paper-3:#f0eee4;
  --ink:#2b2b25; --ink-soft:#65655c; --line:#e3dfce;
  --gold:#9a7b2e; --gold-d:#7d6014; --gold-l:#f3e6c4; --wine:#6e2230;
  --r:8px; --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);
  font-family:"Literata",Georgia,serif;font-size:18px;line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,.serif{font-family:"EB Garamond",Georgia,serif;font-weight:600;color:#1c1c17;line-height:1.15}
a{color:var(--gold-d);text-decoration:none}
a:hover{color:var(--wine)}
img{max-width:100%;display:block}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.label{font-family:"Montserrat",system-ui,sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;font-weight:600}
.rule{height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);border:0;margin:2.4rem auto;max-width:220px}
.muted{color:var(--ink-soft)}
.center{text-align:center}

/* nav */
.nav{position:sticky;top:0;z-index:30;background:rgba(255,252,245,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:62px}
.brand{font-family:"EB Garamond",serif;font-size:1.5rem;font-weight:600;color:#1c1c17}
.brand b{color:var(--gold-d);font-weight:600}
.nav nav{display:flex;gap:26px;align-items:center}
.nav nav a{font-family:"Montserrat",sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;font-weight:600;color:var(--ink-soft)}
.nav nav a.on,.nav nav a:hover{color:var(--gold-d)}
.nav .burger{display:none;background:none;border:0;font-size:1.5rem;color:var(--ink);cursor:pointer}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:"Montserrat",sans-serif;text-transform:uppercase;
  letter-spacing:.08em;font-size:.74rem;font-weight:600;padding:.7rem 1.3rem;border-radius:var(--r);cursor:pointer;border:1px solid var(--gold)}
.btn.fill{background:var(--gold-d);color:#fff;border-color:var(--gold-d)}
.btn.fill:hover{background:var(--wine);border-color:var(--wine)}
.btn.line{background:transparent;color:var(--gold-d)}
.btn.line:hover{background:var(--gold-l)}

/* hero */
.hero{position:relative;min-height:74vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.62) saturate(1.05)}
.hero .bg:after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 30%,rgba(0,0,0,.55))}
.hero .inner{position:relative;z-index:2;padding:2rem}
.hero .kicker{color:#f3e6c4}
.hero h1{font-size:clamp(3rem,9vw,6rem);color:#fff;margin:.2rem 0;text-shadow:0 2px 30px rgba(0,0,0,.4)}
.hero .sub{font-size:1.15rem;color:#f1ede2;margin-bottom:1.6rem}
.hero .cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero .btn.line{color:#fff;border-color:#f3e6c4}
.hero .btn.line:hover{background:rgba(255,255,255,.12)}

/* sections */
section{padding:4.2rem 0}
.sec-h{text-align:center;margin-bottom:2.4rem}
.sec-h h2{font-size:2.3rem}
.sec-h .label{color:var(--gold-d);display:block;margin-bottom:.5rem}

/* grids */
.grid{display:grid;gap:1.5rem}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}

/* city cards */
.city{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:3/4;color:#fff;display:flex;align-items:flex-end}
.city img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.72)}
.city .c{position:relative;padding:1.3rem;z-index:2}
.city h3{color:#fff;font-size:1.7rem;margin:0}
.city .label{color:#f3e6c4}

/* speech cards */
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:1.5rem;transition:.2s}
.card:hover{box-shadow:0 8px 30px rgba(120,96,20,.10);border-color:var(--gold-l);transform:translateY(-2px)}
.chip{display:inline-block;background:var(--gold-d);color:#fff;font-family:"Montserrat",sans-serif;text-transform:uppercase;
  letter-spacing:.1em;font-size:.62rem;font-weight:700;padding:.25rem .6rem;border-radius:99px}
.chip.soft{background:var(--gold-l);color:var(--gold-d)}
.card h3{font-size:1.35rem;margin:.7rem 0 .3rem}
.card .meta{font-family:"Montserrat",sans-serif;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}
.card .ex{margin-top:.6rem;color:#4a4a40;font-size:.96rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

/* book band */
.band{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.band .wrap{display:grid;grid-template-columns:240px 1fr;gap:3rem;align-items:center;padding:3.4rem 24px}
.band .cover{box-shadow:0 18px 40px rgba(0,0,0,.18);border-radius:6px;rotate:-2deg}
.band h2{font-size:2.2rem;margin:.2rem 0 .6rem}

/* filters */
.filters{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center;margin-bottom:2rem}
.filters a{font-family:"Montserrat",sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;font-weight:600;
  padding:.5rem 1rem;border-radius:99px;border:1px solid var(--line);color:var(--ink-soft)}
.filters a.on{background:var(--gold-d);color:#fff;border-color:var(--gold-d)}

/* video cards */
.vcard .thumb{position:relative;aspect-ratio:16/9;border-radius:var(--r);overflow:hidden;background:var(--paper-3)}
.vcard .thumb img{width:100%;height:100%;object-fit:cover}
.vcard .dur{position:absolute;right:.5rem;bottom:.5rem;background:rgba(20,18,12,.82);color:#fff;font-family:"Montserrat",sans-serif;
  font-size:.7rem;padding:.15rem .45rem;border-radius:4px}
.vcard .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:.2s}
.vcard:hover .play{opacity:1}
.vcard .play span{width:54px;height:54px;border-radius:50%;background:var(--gold-d);color:#fff;display:grid;place-items:center;font-size:1.3rem}
.vcard h3{font-size:1.18rem;margin:.6rem 0 .2rem}
.vcard .meta{font-family:"Montserrat",sans-serif;font-size:.7rem;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-soft)}
.featured{margin-bottom:2.6rem}
.featured video,.featured .ph{width:100%;border-radius:var(--r);background:#000;aspect-ratio:16/9}

/* reader */
.reader{max-width:720px;margin:0 auto;padding:3rem 0}
.reader .head{text-align:center;margin-bottom:1.5rem}
.reader h1{font-size:2.6rem;margin:.5rem 0}
.reader .body{font-size:1.16rem;line-height:1.85;text-align:justify}
.reader .body p{margin:0 0 1.1rem}
.reader .body p:first-of-type:first-letter{font-family:"EB Garamond",serif;float:left;font-size:3.6rem;line-height:.8;
  padding:.2rem .5rem 0 0;color:var(--gold-d)}
.reader .nav-arrows{display:flex;justify-content:space-between;border-top:1px solid var(--line);margin-top:2.5rem;padding-top:1.5rem;gap:1rem}
.reader .nav-arrows a{font-family:"Montserrat",sans-serif;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;max-width:46%}

/* layout with sidebar */
.with-aside{display:grid;grid-template-columns:1fr 260px;gap:3rem;max-width:1040px;margin:0 auto}
.aside{position:sticky;top:90px;align-self:start;font-size:.92rem}
.aside h4{font-family:"Montserrat",sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;color:var(--gold-d);margin:0 0 1rem}
.aside ul{list-style:none;padding:0;margin:0}
.aside li{margin:.5rem 0;line-height:1.35}
.aside a.cur{color:var(--wine);font-weight:600}
.aside .bar{border-left:2px solid var(--line);padding-left:1rem}

/* programa timeline */
.tl{max-width:780px;margin:0 auto;position:relative}
.tl .region{font-family:"EB Garamond",serif;font-size:1.9rem;margin:2.4rem 0 1rem;color:var(--gold-d);border-bottom:1px solid var(--line);padding-bottom:.4rem}
.tl .day{position:relative;padding-left:2.2rem;margin-bottom:1.6rem;border-left:2px solid var(--gold-l)}
.tl .day:before{content:"";position:absolute;left:-7px;top:.4rem;width:12px;height:12px;border-radius:50%;background:var(--gold-d);border:2px solid var(--paper)}
.tl .date{font-family:"EB Garamond",serif;font-size:1.5rem;margin-bottom:.5rem}
.tl .acto{margin:0 0 1rem}
.tl .acto .t{font-weight:600}
.tl .acto .h{font-family:"Montserrat",sans-serif;font-size:.7rem;letter-spacing:.08em;color:var(--gold-d);text-transform:uppercase}
.tl .acto .l{color:var(--ink-soft);font-size:.92rem}
.tl .tags{margin-top:.3rem;display:flex;gap:.5rem}
.tl .tags a{font-family:"Montserrat",sans-serif;font-size:.66rem;text-transform:uppercase;letter-spacing:.06em}
.tl .tags .off{color:#bbb;pointer-events:none}

/* footer */
footer{border-top:1px solid var(--line);padding:2.5rem 0;margin-top:2rem;color:var(--ink-soft);font-size:.86rem}
footer .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
footer .lema{font-family:"EB Garamond",serif;font-size:1.2rem;color:var(--gold-d)}

/* login */
.login{min-height:100vh;display:grid;place-items:center;background:linear-gradient(160deg,#1c1c17,#2b2b25)}
.login .box{background:var(--paper);padding:2.6rem;border-radius:12px;max-width:380px;width:92%;text-align:center;box-shadow:0 30px 80px rgba(0,0,0,.4)}
.login h1{font-size:2.2rem}
.login .lema{color:var(--gold-d);font-family:"EB Garamond",serif;font-size:1.1rem;margin-bottom:1.5rem}
.login input{width:100%;padding:.85rem 1rem;border:1px solid var(--line);border-radius:var(--r);font-size:1rem;margin-bottom:1rem;font-family:inherit}
.login .err{color:#a33;font-size:.85rem;margin-bottom:.8rem}
.login .btn{width:100%;justify-content:center}

/* ===== pulido general ===== */
.page-head{background:var(--paper-2);border-bottom:1px solid var(--line);padding:2.6rem 0 1.9rem;margin-bottom:2.4rem}
.page-head h1{font-size:2.8rem;margin:.3rem 0 .9rem}
.page-head .label{color:var(--gold-d)}
.page-head .filters{margin-bottom:0;justify-content:flex-start}
.page-head .lema{font-family:"EB Garamond",serif;font-size:1.25rem;color:var(--gold-d);margin-top:.3rem}

.grouphead{position:relative;border-radius:var(--r);overflow:hidden;padding:1.3rem 1.6rem;margin:0 0 1.4rem;
  display:flex;align-items:center;justify-content:space-between;background-size:cover;background-position:center 35%;color:#fff;min-height:92px}
.grouphead h2{color:#fff;margin:0;font-size:1.9rem;text-shadow:0 1px 12px rgba(0,0,0,.4)}
.grouphead .label{color:#f3e6c4}

.featured{position:relative;margin-bottom:2.8rem;border-radius:12px;overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,.18)}
.featured video{display:block;width:100%;aspect-ratio:16/9;background:#000}
.featured .fcap{padding:1.1rem 1.4rem;background:#1c1c17;color:#fff}
.featured .fcap h3{color:#fff;margin:.45rem 0 .25rem;font-size:1.5rem}
.featured .fcap .meta{color:#cdb98a}
.featured .fcap .chip.soft{background:rgba(243,230,196,.15);color:#f3e6c4}

.vcard h3{transition:color .15s}
.vcard:hover h3{color:var(--gold-d)}
.vcard .thumb{box-shadow:0 6px 18px rgba(0,0,0,.10)}

.hero .stats{display:flex;gap:2.4rem;justify-content:center;margin-top:2rem;flex-wrap:wrap}
.hero .stats b{display:block;font-family:"EB Garamond",serif;font-size:2rem;color:#fff;line-height:1}
.hero .stats span{font-family:"Montserrat",sans-serif;font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:#e8dcc0}
.hero .stats .sep{width:1px;background:rgba(243,230,196,.35)}

@media(max-width:820px){
  .page-head h1{font-size:2.1rem}
  .grouphead{min-height:78px}
  .nav nav{display:none;position:absolute;top:62px;left:0;right:0;background:var(--paper);flex-direction:column;padding:1rem 24px;border-bottom:1px solid var(--line)}
  .nav nav.open{display:flex}
  .nav .burger{display:block}
  .g3,.g2{grid-template-columns:1fr}
  .band .wrap{grid-template-columns:1fr;text-align:center}
  .band .cover{margin:0 auto;rotate:0deg;max-width:200px}
  .with-aside{grid-template-columns:1fr}
  .aside{position:static;border-top:1px solid var(--line);padding-top:1.5rem}
}
