/* L'Escola Vilafranca — site.css (subpáginas) */
:root{
  --bordeux:#6E1E2C; --bordeux-soft:#843042; --bordeux-ink:#3A0F18;
  --cream:#F7F1EA; --sand:#EDE3D4; --rose:#E7D2CE; --divider:#E9DFD3;
  --sage:#8E9D7E; --ink:#1F1414; --mid:#6B5A56; --paper:#FBF7F1;
  --ok:#3F6E4A; --err:#9A2A2A;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:'Inter',system-ui,sans-serif;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.serif{font-family:'Fraunces',Georgia,serif}
.kicker{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--bordeux);font-weight:600}
.container{max-width:1240px;margin:0 auto;padding:0 32px}
.narrow{max-width:880px;margin:0 auto;padding:0 32px}
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--bordeux);color:#fff;padding:14px 22px;border-radius:2px;font-weight:600;font-size:14px;letter-spacing:.04em;transition:.2s;cursor:pointer;border:none;font-family:inherit}
.btn:hover{background:var(--bordeux-soft)}
.btn-ghost{background:transparent;color:var(--bordeux);border:1px solid var(--bordeux)}
.btn-ghost:hover{background:var(--bordeux);color:#fff}
.rule{height:1px;background:var(--divider)}

/* Top util + header */
.util{background:var(--bordeux-ink);color:#F2DDD8;font-size:12px;letter-spacing:.04em}
.util .container{display:flex;justify-content:space-between;padding:9px 32px}
.util a{opacity:.85}.util a:hover{opacity:1}
.util .util-lang{display:none}                       /* visible sólo en mobile */
.util .util-lang b{color:#fff}
.util .util-lang a{opacity:.85}
.util .util-lang a:hover{opacity:1}
header.site{background:var(--paper);position:sticky;top:0;z-index:50;border-bottom:1px solid var(--divider)}
header.site .row{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:24px}
.logo{display:flex;align-items:center;gap:14px}
.logo img{height:54px;width:auto}
nav.main ul{list-style:none;display:flex;gap:24px}
nav.main a{font-size:15px;color:var(--ink);position:relative;padding:6px 0}
nav.main a:hover{color:var(--bordeux)}
nav.main a.active{color:var(--bordeux)}
nav.main a.active::after{content:"";position:absolute;left:0;right:0;bottom:-8px;height:2px;background:var(--bordeux)}
.lang{font-size:13px;color:var(--mid);letter-spacing:.1em}.lang b{color:var(--bordeux)}
header.site .btn{font-size:15px}                     /* +1px sólo en el header */
.header-actions{display:flex;align-items:center;gap:18px}

/* Page hero (subpáginas) */
.page-hero{padding:80px 0 56px;background:var(--paper);border-bottom:1px solid var(--divider)}
.page-hero .grid{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center}
.page-hero h1{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(40px,4.8vw,72px);line-height:1.02;letter-spacing:-.015em;color:var(--bordeux-ink);margin-top:20px}
.page-hero h1 em{font-style:italic;color:var(--bordeux);font-weight:300}
.page-hero .lede{margin-top:24px;font-size:18px;line-height:1.65;color:var(--mid);max-width:46ch}
.page-hero .cta-row{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}
.page-hero .art{aspect-ratio:5/4;border-radius:2px;overflow:hidden;background:linear-gradient(150deg,var(--rose),var(--sand),var(--cream));position:relative}
.page-hero .art::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 40% 40%,rgba(110,30,44,.18),transparent 55%),radial-gradient(circle at 70% 80%,rgba(142,157,126,.22),transparent 55%)}
.page-hero .art .glyph{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:60%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.5),transparent 70%);box-shadow:inset 0 0 0 1px rgba(110,30,44,.18)}

/* Breadcrumb */
.crumbs{padding:18px 0;font-size:12.5px;color:var(--mid);letter-spacing:.04em;border-bottom:1px solid var(--divider);background:var(--paper)}
.crumbs a{color:var(--bordeux)}.crumbs a:hover{text-decoration:underline}.crumbs span{margin:0 8px;color:var(--divider)}

/* Generic section */
section.block{padding:100px 0}
section.block.cream{background:var(--cream)}
section.block.sand{background:var(--sand)}
section.block.dark{background:var(--bordeux-ink);color:#F4E2DE}
section.block.dark h2,section.block.dark h3{color:#fff}
section.block .block-head{max-width:780px;margin:0 auto 56px;text-align:center}
section.block .block-head h2{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(34px,4vw,52px);line-height:1.08;color:var(--bordeux-ink);margin-top:14px}
section.block .block-head h2 em{font-style:italic;color:var(--bordeux)}
section.block .block-head p{color:var(--mid);margin-top:18px;font-size:17px;line-height:1.7}
section.block.dark .block-head p{color:var(--rose)}

/* Editorial prose */
.prose{font-size:18px;line-height:1.8;color:#2b2220}
.prose p{margin-bottom:18px}
.prose p:first-of-type::first-letter{font-family:'Fraunces',serif;font-size:80px;float:left;line-height:.85;color:var(--bordeux);padding:6px 10px 0 0}
.prose h3{font-family:'Fraunces',serif;font-weight:500;font-size:28px;color:var(--bordeux-ink);margin:40px 0 14px;letter-spacing:-.005em}
.prose h3 em{font-style:italic;color:var(--bordeux)}
.prose ul,.prose ol{margin:14px 0 22px 22px;color:#2b2220}
.prose li{margin-bottom:10px;padding-left:6px}
.prose blockquote{font-family:'Fraunces',serif;font-style:italic;font-size:24px;line-height:1.45;color:var(--bordeux-ink);border-left:2px solid var(--bordeux);padding:6px 0 6px 22px;margin:28px 0}

/* Two-column copy */
.split{display:grid;grid-template-columns:0.7fr 1.4fr;gap:60px}

/* Card grid */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.card{background:#fff;border:1px solid var(--divider);padding:32px 28px;position:relative;display:flex;flex-direction:column;gap:14px;min-height:340px;border-radius:2px}
.card .num{position:absolute;top:18px;right:24px;font-family:'Fraunces',serif;font-style:italic;color:var(--rose);font-size:38px;line-height:1}
.card .ph{aspect-ratio:5/4;background:linear-gradient(135deg,var(--rose),var(--sand));border-radius:2px;overflow:hidden;margin:-12px -8px 6px;position:relative}
.card .ph img{width:100%;height:100%;object-fit:cover}
.card h3{font-family:'Fraunces',serif;font-size:22px;font-weight:500;color:var(--bordeux-ink);line-height:1.2}
.card h3 em{font-style:italic;color:var(--bordeux)}
.card p{font-size:14.5px;color:var(--mid);line-height:1.65}
.card ul{list-style:none;font-size:12.5px;color:var(--ink);margin-top:auto;padding-top:14px;border-top:1px solid var(--divider)}
.card ul li{padding:5px 0;display:flex;justify-content:space-between;gap:10px}
.card ul li b{color:var(--bordeux);font-weight:600}
.card .more{margin-top:14px;font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--bordeux);border-bottom:1px solid var(--bordeux);padding-bottom:3px;align-self:flex-start;font-weight:600}

/* Stat band */
/* Photo feature: foto destacada después del hero (WEB 4) */
.photo-feature{padding:48px 0;background:var(--paper)}
.photo-feature .container{max-width:1080px}
.photo-feature img{width:100%;height:auto;max-height:560px;object-fit:cover;border-radius:14px;box-shadow:0 24px 48px -24px rgba(58,15,24,.35);display:block}
.photo-feature.gallery-2 .container{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:1240px}
@media (max-width:760px){
  .photo-feature{padding:32px 0}
  .photo-feature.gallery-2 .container{grid-template-columns:1fr}
}

.stats{padding:80px 0;background:var(--bordeux-ink);color:#F4E2DE}
.stats .grid{display:grid;grid-template-columns:1.1fr 1fr 1fr 1fr;gap:42px;align-items:center}
.stats h3{font-family:'Fraunces',serif;font-size:32px;font-weight:400;line-height:1.15;color:#fff}
.stats h3 em{font-style:italic;color:var(--rose)}
.stats .stat b{display:block;font-family:'Fraunces',serif;font-size:56px;font-weight:300;color:#fff;letter-spacing:-.02em;line-height:1}
.stats .stat span{display:block;margin-top:10px;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--rose);max-width:22ch}

/* Method */
.method-list{list-style:none;counter-reset:m;max-width:880px;margin:0 auto}
.method-list li{counter-increment:m;padding:28px 0 28px 64px;border-bottom:1px solid var(--divider);position:relative}
.method-list li::before{content:counter(m,decimal-leading-zero);position:absolute;left:0;top:30px;font-family:'Fraunces',serif;color:var(--bordeux);font-size:22px}
.method-list li h4{font-family:'Fraunces',serif;font-weight:500;font-size:22px;color:var(--bordeux-ink);margin-bottom:6px}
.method-list li p{color:var(--mid);font-size:15px;line-height:1.65}

/* Tables (horarios) */
table.data{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--divider);font-size:14px}
table.data thead{background:var(--cream)}
table.data th{text-align:left;padding:16px 18px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--bordeux);font-weight:600;border-bottom:1px solid var(--divider)}
table.data td{padding:16px 18px;border-bottom:1px solid var(--divider);vertical-align:top;color:var(--ink)}
table.data tbody tr:last-child td{border-bottom:none}
table.data tbody tr:hover{background:var(--paper)}
table.data td.day{font-family:'Fraunces',serif;font-style:italic;color:var(--bordeux);font-size:16px;font-weight:500}
table.data td.hour{font-variant-numeric:tabular-nums;color:var(--mid);font-weight:500}
table.data td.price{font-family:'Fraunces',serif;font-size:20px;color:var(--bordeux-ink);font-weight:500;text-align:right;letter-spacing:-.01em}
table.data .tag,table.data .badge{display:inline-block;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;padding:3px 8px;border-radius:999px;font-weight:600}
table.data .tag{background:var(--rose);color:var(--bordeux);margin-left:6px}
table.data .badge{background:var(--sage);color:#fff}
.skeleton{background:linear-gradient(90deg,var(--divider) 0%,var(--cream) 50%,var(--divider) 100%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:2px;height:18px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.empty,.error{padding:36px;text-align:center;color:var(--mid);background:#fff;border:1px solid var(--divider);border-radius:2px}
.error{color:var(--err);border-color:#E8C9C9;background:#FBF3F3}
.error b{display:block;color:var(--err);font-family:'Fraunces',serif;font-size:18px;margin-bottom:6px}

/* Tabs */
.tabs{display:flex;border-bottom:1px solid var(--divider);gap:30px;margin-bottom:30px;flex-wrap:wrap}
.tabs button{background:none;border:none;font-family:inherit;font-size:14px;color:var(--mid);padding:14px 0;cursor:pointer;letter-spacing:.08em;text-transform:uppercase;font-weight:600;position:relative;transition:.2s}
.tabs button.active{color:var(--bordeux)}
.tabs button.active::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--bordeux)}
.tabs button:hover{color:var(--bordeux)}
.tabs .filter{margin-left:auto;display:flex;gap:8px;align-items:center;padding:8px 0}
.tabs .filter label{font-size:11.5px;color:var(--mid);letter-spacing:.12em;text-transform:uppercase}
.tabs .filter select{font-family:inherit;font-size:13px;padding:6px 10px;border:1px solid var(--divider);background:#fff;color:var(--ink);border-radius:2px}
.panel{display:none}.panel.active{display:block}

/* Forms */
.form-card{background:#fff;border:1px solid var(--divider);padding:40px 40px 32px;max-width:760px;margin:0 auto;border-radius:2px}
.form-card h3{font-family:'Fraunces',serif;font-weight:500;font-size:28px;color:var(--bordeux-ink);line-height:1.2;margin-bottom:8px}
.form-card h3 em{font-style:italic;color:var(--bordeux)}
.form-card > p{color:var(--mid);font-size:15px;margin-bottom:24px}
.field{margin-bottom:20px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.field label{display:block;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--bordeux);margin-bottom:8px;font-weight:600}
.field label .req{color:var(--err)}
.field input,.field textarea,.field select{width:100%;font-family:inherit;font-size:15px;padding:12px 14px;border:1px solid var(--divider);background:var(--paper);color:var(--ink);border-radius:2px;outline:none;transition:.2s}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--bordeux);background:#fff}
.field textarea{min-height:120px;resize:vertical;font-family:inherit}
.field .hint{font-size:12px;color:var(--mid);margin-top:6px}
.hp{position:absolute;left:-9999px;height:0;width:0;opacity:0;pointer-events:none}
.legal{font-size:12px;color:var(--mid);margin-top:14px;line-height:1.6}
.legal a{color:var(--bordeux);border-bottom:1px solid var(--bordeux)}
.form-actions{margin-top:8px;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}
.form-actions .btn{min-width:200px;justify-content:center}
.form-status{display:none;padding:14px 18px;border-radius:2px;margin-top:18px;font-size:14px}
.form-status.ok{display:block;background:#EFF5EF;border:1px solid #C4DEC8;color:var(--ok)}
.form-status.err{display:block;background:#FBF3F3;border:1px solid #E8C9C9;color:var(--err)}
.form-status.loading{display:block;background:var(--cream);border:1px solid var(--divider);color:var(--mid)}

/* FUNDAE band */
.fundae{padding:80px 0}
.fundae .box{background:var(--bordeux);color:#fff;padding:48px 52px;display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center;border-radius:2px}
.fundae h3{font-family:'Fraunces',serif;font-size:32px;font-weight:400;line-height:1.15}
.fundae h3 em{font-style:italic;color:var(--rose)}
.fundae p{color:#F2DDD8;margin-top:12px;font-size:15px;line-height:1.65;max-width:46ch}
.fundae .right{text-align:right}
.fundae .right .big{font-family:'Fraunces',serif;font-size:80px;line-height:1;font-weight:300}
.fundae .right .lbl{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--rose);margin-top:8px}
.fundae .right .btn{background:#fff;color:var(--bordeux);margin-top:18px}

/* CTA Final */
.cta-final{padding:100px 0;text-align:center;background:var(--cream)}
.cta-final h2{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(34px,4vw,54px);line-height:1.1;color:var(--bordeux-ink);max-width:18ch;margin:18px auto 0;letter-spacing:-.015em}
.cta-final h2 em{font-style:italic;color:var(--bordeux);font-weight:400}
.cta-final p{margin:18px auto 0;color:var(--mid);font-size:17px;line-height:1.7;max-width:54ch}
.cta-final .cta-row{margin-top:30px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* Footer */
footer.site{background:var(--cream);padding:80px 0 28px;color:var(--ink);font-size:14px;border-top:1px solid var(--divider)}
footer.site .grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px}
footer.site h5{font-family:'Fraunces',serif;font-weight:500;font-size:14px;letter-spacing:.18em;text-transform:uppercase;color:var(--bordeux);margin-bottom:18px}
footer.site ul{list-style:none}
footer.site li{padding:6px 0;color:var(--mid)}
footer.site li a:hover{color:var(--bordeux)}
footer.site .brand p{color:var(--mid);max-width:36ch;margin-top:18px}
footer.site .colophon{margin-top:60px;padding-top:24px;border-top:1px solid var(--divider);display:flex;justify-content:space-between;color:var(--mid);font-size:12px;gap:18px;flex-wrap:wrap}

@media (max-width:980px){
  .page-hero .grid,.split,.card-grid,.stats .grid,.fundae .box,footer.site .grid,.field-row{grid-template-columns:1fr}
  nav.main{display:none}
  .form-card{padding:30px 24px}
  table.data{font-size:13px}
  table.data th,table.data td{padding:12px 12px}
  .fundae .right{text-align:left}
}

/* ============================================================
   MODERN OVERRIDE LAYER — propagates across the site
   Source: option-a-modern. Lighter background, pill buttons,
   rounder cards, soft shadows, frosted header.
   ============================================================ */
:root{
  --paper:#FCFAF6;
  --cream:#F2EDE4;
  --sand:#E7DECC;
  --rose:#EBD7D3;
  --divider:#EDE4D5;
  --radius-card:20px;
  --radius-soft:14px;
  --shadow-soft:0 8px 24px -10px rgba(58,15,24,.10), 0 0 0 1px rgba(110,30,44,.05);
  --shadow-hover:0 24px 48px -18px rgba(58,15,24,.18), 0 0 0 1px rgba(110,30,44,.10);
}
body{background:var(--paper)}

/* Pill buttons */
.btn,.btn-ghost{border-radius:999px!important;padding:14px 28px;letter-spacing:.06em;transition:transform .2s ease,background .2s ease,color .2s ease,box-shadow .2s ease}
.btn{box-shadow:0 6px 16px -8px rgba(110,30,44,.4)}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 24px -8px rgba(110,30,44,.5)}
.btn-ghost{background:rgba(255,255,255,.6);backdrop-filter:blur(8px)}
.btn-ghost:hover{background:var(--bordeux);color:#fff}

/* Sticky header with frosted glass */
header.site{background:rgba(252,250,246,.85);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(110,30,44,.08)}
nav.main a.active::after{height:3px;border-radius:2px;bottom:-10px}

/* Generic .card (subpages) with shadow not hard border */
.card{border:none!important;border-radius:var(--radius-card)!important;box-shadow:var(--shadow-soft);background:#fff;transition:transform .25s ease,box-shadow .25s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.card .ph{border-radius:14px!important}

/* Page hero */
.page-hero .art{border-radius:var(--radius-card)!important}

/* Tables (horarios) — rounded wrapper */
table.data{border:none;box-shadow:var(--shadow-soft);border-radius:var(--radius-card);overflow:hidden}
table.data thead{background:var(--cream)}
table.data tbody tr:hover{background:var(--paper)}

/* Form cards */
.form-card{border:none!important;border-radius:24px!important;box-shadow:var(--shadow-soft);background:#fff;padding:44px 44px 36px}
.field input,.field textarea,.field select{border:1px solid var(--divider);border-radius:14px;padding:14px 16px;background:#fff;transition:border-color .2s,box-shadow .2s}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--bordeux);box-shadow:0 0 0 4px rgba(110,30,44,.08);outline:none}
.form-status{border-radius:14px!important}
.form-status.ok,.form-status.err,.form-status.loading{border:none;box-shadow:0 4px 12px -4px rgba(58,15,24,.15)}

/* FUNDAE band */
.fundae .box{border-radius:24px!important;padding:60px 64px;box-shadow:0 32px 60px -32px rgba(58,15,24,.5)}
@media (max-width:980px){.fundae .box{padding:44px 32px;border-radius:20px!important}}

/* Stats band */
.stats{padding:80px 0}

/* Method list — softer dividers */
.method-list li{padding:32px 0 32px 80px;border-bottom:1px solid var(--divider)}

/* Footer gradient + no hard top border */
footer.site{border-top:none;background:linear-gradient(180deg,var(--cream),var(--paper))}

/* Crumbs softer */
.crumbs{background:transparent;border-bottom:none;padding:14px 0;font-size:12px}

/* Util bar lighter accent */
.util{background:var(--bordeux-ink)}

/* CTA final softer */
.cta-final{padding:120px 0;background:linear-gradient(180deg,var(--cream),var(--paper))}

/* Skeleton + empty states */
.empty,.error{border-radius:var(--radius-card)!important;border:none;box-shadow:var(--shadow-soft)}
.empty{background:#fff;color:var(--mid)}

/* Bio page (quienes-somos) avatar already round; add softer shadow */
.avatar{box-shadow:0 16px 36px -16px rgba(110,30,44,.4),0 0 0 1px rgba(110,30,44,.08)!important}

/* Generic 2px radius killer for any leftover squared elements served from inline styles
   Note: page-specific elements that need true 2px should use !important inline. */
.tag,.badge{border-radius:999px!important}

/* prefers-reduced-motion */
@media (prefers-reduced-motion:reduce){
  .card,.btn,header.site{transition:none}
  .card:hover,.btn:hover{transform:none}
}

/* ============================================================
   HAMBURGER MENU — MOBILE DRAWER v3
   Fix: escape containing block (header.site backdrop-filter)
        + scroll lock iOS-safe + fondo sólido
   ============================================================ */
.menu-toggle{
  display:none;
  width:44px;height:44px;
  border:none;background:transparent;cursor:pointer;
  padding:0;position:relative;
  border-radius:999px;
  transition:background .2s;
  flex:none;
}
.menu-toggle:hover{background:var(--cream)}
.menu-toggle span{
  position:absolute;left:10px;width:24px;height:2px;
  background:var(--bordeux);border-radius:2px;
  transition:transform .3s ease,opacity .2s ease,top .3s ease;
}
.menu-toggle span:nth-child(1){top:14px}
.menu-toggle span:nth-child(2){top:21px}
.menu-toggle span:nth-child(3){top:28px}

.menu-close{
  display:none;
  position:fixed;top:18px;right:18px;
  width:56px;height:56px;
  background:var(--bordeux);
  border:none;cursor:pointer;color:#fff;
  border-radius:999px;
  align-items:center;justify-content:center;
  font-size:0;line-height:0;
  box-shadow:0 8px 20px -8px rgba(110,30,44,.5);
  z-index:10000;
  transition:transform .2s ease,background .2s ease;
}
.menu-close::before,.menu-close::after{
  content:"";position:absolute;
  width:26px;height:2.5px;background:#fff;border-radius:2px;
  left:50%;top:50%;
}
.menu-close::before{transform:translate(-50%,-50%) rotate(45deg)}
.menu-close::after{transform:translate(-50%,-50%) rotate(-45deg)}
.menu-close:hover,.menu-close:active{transform:scale(1.08);background:var(--bordeux-soft)}
body.menu-open .menu-close{display:flex}

@media (max-width:980px){
  .menu-toggle{display:block}

  /* Util bar mobile: ocultar texto "Vilafranca · Barcelona", mostrar lang toggle a la derecha */
  .util .util-place{display:none}
  .util .util-lang{display:inline-flex;align-items:center;gap:4px;font-size:12.5px;letter-spacing:.06em;white-space:nowrap}
  .util .util-lang b{color:#fff}
  .util .container{
    justify-content:space-around;
    gap:8px;
    padding:8px 14px;
    font-size:12.5px;
    flex-wrap:nowrap;
  }
  .util .container > span{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
  .util svg{width:13px;height:13px}

  /* Header font bump +1px en mobile */
  nav.main a{font-size:21px}             /* 20→21 dentro del drawer */
  .header-actions .btn{font-size:13px;padding:11px 18px}

  /* Quitar backdrop-filter del header en móvil para no atrapar al fixed del drawer */
  header.site{
    backdrop-filter:none!important;
    -webkit-backdrop-filter:none!important;
    background:var(--paper)!important;
  }

  /* Drawer fullscreen viewport con fondo SÓLIDO */
  nav.main{
    display:flex!important;
    flex-direction:column;
    justify-content:center;
    align-items:stretch;
    position:fixed!important;
    top:0;left:0;right:0;bottom:0;
    width:100vw;height:100vh;height:100dvh;
    background:#FCFAF6;
    z-index:9999;
    transform:translateX(100%);
    transition:transform .4s cubic-bezier(.4,0,.2,1),visibility 0s linear .4s;
    visibility:hidden;
    padding:80px 28px 32px;
    margin:0;
    box-sizing:border-box;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  body.menu-open nav.main{
    transform:translateX(0);
    visibility:visible;
    transition:transform .4s cubic-bezier(.4,0,.2,1);
  }
  body.menu-open .menu-toggle{display:none}

  nav.main ul{
    flex-direction:column;
    gap:0;
    width:100%;max-width:520px;margin:0 auto;
    align-items:stretch;
    list-style:none;
    padding:0;
  }
  nav.main li{border-bottom:1px solid var(--divider)}
  nav.main li:last-child{border-bottom:none}
  nav.main a{
    display:block;
    font-family:'Fraunces',Georgia,serif;
    font-size:20px;line-height:1.15;
    padding:14px 4px;
    color:var(--bordeux-ink);
    font-weight:400;
    letter-spacing:-.005em;
    text-decoration:none;
    transition:color .2s,padding .2s;
  }
  nav.main a:hover,nav.main a:focus{color:var(--bordeux);padding-left:12px;outline:none}
  nav.main a.active{color:var(--bordeux);font-style:italic}
  nav.main a.active::after{display:none}

  .header-actions{gap:8px}
  .header-actions .lang{display:none}
  .header-actions .btn{padding:10px 16px;font-size:12px}

  @media (max-height:640px){
    nav.main{padding-top:72px}
    nav.main a{font-size:18px;padding:11px 4px}
  }
  @media (max-height:560px){
    nav.main a{font-size:16px;padding:9px 4px}
  }
}

body.menu-open{overflow:hidden}

@media (prefers-reduced-motion:reduce){
  nav.main{transition:none}
  .menu-close{transition:none}
}
