:root{
  --bg:#0a0a0a;
  --bg-2:#141414;
  --bg-3:#1c1c1c;
  --ink:#f5efe2;
  --ink-soft:#cfc8b8;
  --muted:#8a8475;
  --line:#2a2825;
  --line-soft:#1f1d1a;
  --serif:"Playfair Display", "Georgia", serif;
  --script:"Pinyon Script", "Allura", cursive;
  --sans:"Outfit", system-ui, sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--bg)}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.6;font-weight:400;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1120px;margin:0 auto;padding:0 28px}
.narrow{max-width:780px;margin:0 auto;padding:0 28px}

/* Type */
.label{font-family:var(--sans);font-size:10px;letter-spacing:.4em;text-transform:uppercase;font-weight:400;color:var(--ink-soft)}
.script{font-family:var(--script);font-weight:400;color:var(--ink)}
h1,h2,h3,h4,h5,h6{font-family:var(--serif);font-weight:400;letter-spacing:-.005em;line-height:1.15}
h2.title{font-size:clamp(32px,4vw,50px);font-weight:500;letter-spacing:-.005em;text-align:center}
h2.title em{font-style:italic;color:var(--ink-soft);font-weight:400}
p{font-size:15.5px;line-height:1.75;font-weight:400;color:var(--ink-soft)}
.lead{font-size:16px;line-height:1.7;color:var(--ink-soft);max-width:58ch}

.ornament{display:flex;align-items:center;justify-content:center;gap:18px;color:var(--ink-soft);margin:0 auto}
.ornament .ln{width:80px;height:1px;background:currentColor;opacity:.3}
.ornament .dot{width:5px;height:5px;border:1px solid currentColor;border-radius:50%;opacity:.6}

/* Nav */
nav.top{position:sticky;top:0;z-index:50;background:rgba(10,10,10,.85);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line-soft)}
nav .row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:32px;padding:14px 36px;max-width:1280px;margin:0 auto}
.nav-l{display:flex;gap:34px;justify-self:start;align-items:center}
.nav-r{display:flex;gap:34px;justify-self:end;align-items:center}
nav a.link{font-size:12px;letter-spacing:.28em;text-transform:uppercase;font-weight:500;color:var(--ink);transition:color .2s;position:relative;padding:4px 0}
nav a.link:hover{color:#fff;opacity:.85}
nav a.link.active{color:var(--ink)}
nav a.link.active::after{content:"";position:absolute;left:50%;bottom:-2px;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--ink)}
.nav-brand{justify-self:center;display:flex;align-items:center;gap:10px}
.nav-brand img{height:42px;width:auto;filter:invert(1) brightness(1.15) contrast(1.1)}
.nav-cta{font-size:12px;letter-spacing:.28em;text-transform:uppercase;font-weight:600;border:1px solid var(--ink);padding:11px 22px;border-radius:999px;color:var(--ink);transition:all .25s}
.nav-cta:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
@media (max-width:980px){.nav-l,.nav-r .link{display:none}nav .row{grid-template-columns:1fr auto;padding:12px 20px}.nav-brand{justify-self:start}}

/* Nav dropdown (Sucursales) */
.nav-dd{position:relative;display:inline-flex;align-items:center}
.nav-dd > a.link{display:inline-flex;align-items:center;gap:6px}
.nav-dd > a.link::after{content:"";width:4px;height:4px;border-right:1px solid currentColor;border-bottom:1px solid currentColor;transform:rotate(45deg) translate(-1px,-1px);opacity:.7;margin-left:6px;transition:transform .2s}
.nav-dd:hover > a.link::after,.nav-dd:focus-within > a.link::after{transform:rotate(225deg) translate(-1px,-1px)}
.nav-dd .panel{position:absolute;top:calc(100% + 14px);left:50%;transform:translate(-50%,-6px);background:rgba(14,14,14,.96);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid var(--line);border-radius:18px;padding:14px;min-width:300px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .25s ease, transform .25s ease, visibility 0s linear .25s;box-shadow:0 24px 60px rgba(0,0,0,.5);z-index:100}
.nav-dd:hover .panel,.nav-dd:focus-within .panel{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%,0);transition:opacity .25s ease, transform .25s ease, visibility 0s linear 0s}
.nav-dd .panel::before{content:"";position:absolute;top:-8px;left:0;right:0;height:14px}
.nav-dd .panel a{display:flex;align-items:baseline;gap:14px;padding:11px 16px;border-radius:10px;font-family:var(--sans);font-size:13px;font-weight:400;letter-spacing:.01em;color:var(--ink);text-transform:none;transition:background .2s, color .2s}
.nav-dd .panel a:hover{background:var(--bg-3);color:#fff}
.nav-dd .panel a .num{font-family:var(--serif);font-style:italic;font-size:12px;color:var(--muted);min-width:24px;font-weight:400}
.nav-dd .panel a small{display:block;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-top:3px;font-weight:400}
.nav-dd .panel .group{font-size:9px;letter-spacing:.38em;text-transform:uppercase;color:var(--muted);padding:14px 16px 8px;font-weight:500}
.nav-dd .panel .group:first-child{padding-top:6px}
.nav-dd .panel .sep{height:1px;background:var(--line-soft);margin:6px 10px}

/* Compact sucursal grid (8 locales) */
.sucs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1180px;margin:0 auto}
.sucs-grid > .feat{grid-column:span 3}
@media (max-width:980px){.sucs-grid{grid-template-columns:repeat(2,1fr)}.sucs-grid > .feat{grid-column:span 2}}
@media (max-width:640px){.sucs-grid{grid-template-columns:1fr}.sucs-grid > .feat{grid-column:span 1}}
.suc-mini{background:var(--bg-2);border:1px solid var(--line);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:all .3s;position:relative}
.suc-mini:hover{border-color:var(--ink-soft);transform:translateY(-2px)}
.suc-mini .ph{aspect-ratio:4/3;background:#000;position:relative;border-bottom:1px solid rgba(245,239,226,.18);overflow:hidden}
.suc-mini .ph::before{content:"";position:absolute;inset:0;background-image:url('logo-napoleon.jpg');background-repeat:no-repeat;background-position:center;background-size:48% auto;filter:invert(1) brightness(2) contrast(.5);opacity:.16;pointer-events:none;z-index:1}
.suc-mini .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2}
.suc-mini .ph:has(img)::before{display:none}
.suc-mini .ph .placeholder-tag{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:3;font-family:var(--sans);font-size:9px;letter-spacing:.38em;text-transform:uppercase;color:var(--muted);font-weight:400}
.suc-mini .num{position:absolute;top:14px;left:16px;z-index:4;font-family:var(--serif);font-style:italic;font-size:13px;color:var(--ink);background:rgba(10,10,10,.7);backdrop-filter:blur(8px);padding:4px 10px;border-radius:999px;border:1px solid rgba(245,239,226,.18)}
.suc-mini .body{padding:22px 24px 24px;display:flex;flex-direction:column;gap:6px;flex:1}
.suc-mini .kicker{font-size:9px;letter-spacing:.4em;text-transform:uppercase;color:var(--muted);font-weight:500;margin-bottom:4px}
.suc-mini h3{font-family:var(--serif);font-size:22px;font-weight:500;letter-spacing:-.01em;line-height:1.2}
.suc-mini .where{font-family:var(--script);font-size:22px;color:var(--ink-soft);line-height:1;margin:2px 0 8px}
.suc-mini p{font-size:13px;color:var(--muted);line-height:1.55;margin-bottom:4px}
.suc-mini .meta{margin-top:auto;padding-top:14px;border-top:1px solid var(--line-soft);display:flex;justify-content:space-between;align-items:center;gap:10px;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft)}
.suc-mini .meta .go{font-family:var(--sans);transition:color .2s}
.suc-mini:hover .meta .go{color:#fff}

/* Carta tabs */
.carta-tabs{display:flex;justify-content:center;gap:6px;flex-wrap:wrap;max-width:880px;margin:0 auto 56px;border:1px solid var(--line);border-radius:999px;padding:6px;background:var(--bg-2)}
.carta-tabs a{padding:10px 22px;font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-soft);border-radius:999px;font-weight:500;transition:all .25s;font-family:var(--sans)}
.carta-tabs a:hover{color:var(--ink)}
.carta-tabs a.active{background:var(--ink);color:var(--bg)}
@media (max-width:600px){.carta-tabs{border-radius:18px;padding:8px}.carta-tabs a{padding:8px 14px;letter-spacing:.18em;font-size:9.5px}}

.menu-block{max-width:880px;margin:0 auto 80px;scroll-margin-top:100px}
.menu-block-head{text-align:center;margin-bottom:40px;padding-bottom:24px;border-bottom:1px solid var(--line-soft);position:relative}
.menu-block-head .badge{display:inline-block;font-size:9px;letter-spacing:.4em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:7px 18px;margin-bottom:18px;font-weight:500}
.menu-block-head h2{font-family:var(--serif);font-size:clamp(34px,4vw,52px);font-weight:500;letter-spacing:-.01em;margin-bottom:8px}
.menu-block-head h2 em{font-style:italic;color:var(--ink-soft);font-weight:400}
.menu-block-head .where{font-family:var(--script);font-size:clamp(22px,2.4vw,30px);color:var(--ink-soft);line-height:1;margin:4px 0 14px}
.menu-block-head p{max-width:50ch;margin:14px auto 0;font-size:14.5px}

.menu-placeholder{background:var(--bg-2);border:1px dashed var(--line);border-radius:18px;padding:64px 40px;text-align:center;margin-top:24px}
.menu-placeholder .pin{display:inline-flex;align-items:center;gap:10px;font-size:9px;letter-spacing:.4em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.menu-placeholder .pin::before,.menu-placeholder .pin::after{content:"";width:18px;height:1px;background:currentColor;opacity:.6}
.menu-placeholder h4{font-family:var(--serif);font-style:italic;font-size:26px;font-weight:500;margin-bottom:10px;letter-spacing:-.005em}
.menu-placeholder p{font-size:14px;max-width:42ch;margin:0 auto;color:var(--ink-soft)}
.menu-placeholder .pdf-slot{margin-top:28px;padding:18px 24px;background:var(--bg);border:1px solid var(--line-soft);border-radius:12px;display:inline-flex;align-items:center;gap:14px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.menu-placeholder .pdf-slot::before{content:"";width:32px;height:40px;background:linear-gradient(135deg,var(--bg-3) 0%,var(--bg-2) 100%);border:1px solid var(--line);border-radius:3px;flex-shrink:0;position:relative}

/* Galería pro */
.galeria-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:10px;max-width:1280px;margin:0 auto;grid-auto-flow:dense}
.gp{background:#000;border:1px solid rgba(245,239,226,.18);border-radius:8px;overflow:hidden;position:relative;aspect-ratio:1/1}
.gp.tall{grid-row:span 2;aspect-ratio:1/2}
.gp.wide{grid-column:span 2;aspect-ratio:2/1}
.gp.big{grid-column:span 2;grid-row:span 2;aspect-ratio:1/1}
.gp::before{content:"";position:absolute;inset:0;background-image:url('logo-napoleon.jpg');background-repeat:no-repeat;background-position:center;background-size:50% auto;filter:invert(1) brightness(2) contrast(.5);opacity:.14;pointer-events:none;z-index:1}
.gp img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2;transition:transform .6s ease}
.gp:hover img{transform:scale(1.04)}
.gp:has(img)::before{display:none}
.gp.empty{display:flex;align-items:center;justify-content:center}
.gp.empty::after{content:attr(data-tag);position:relative;z-index:3;font-family:var(--sans);font-size:9px;letter-spacing:.38em;text-transform:uppercase;color:var(--muted);font-weight:400;text-align:center;padding:12px;line-height:1.6}
.gp .item-col{grid-column:span 3}
@media (max-width:980px){.galeria-grid{grid-template-columns:repeat(6,1fr)}}
@media (max-width:640px){.galeria-grid{grid-template-columns:repeat(4,1fr);gap:6px}.gp.big{grid-column:span 2;grid-row:span 2}}

/* Galería section header (filter chips) */
.gal-filters{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin-bottom:40px}
.gal-filters span{padding:8px 18px;border:1px solid var(--line);border-radius:999px;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-soft);font-weight:500;cursor:pointer;transition:all .2s ease;user-select:none}
.gal-filters span:hover{border-color:var(--ink-soft);color:var(--ink)}
.gal-filters span.on{background:var(--ink);color:var(--bg);border-color:var(--ink)}

/* Contact: instagram video / como llegar card */
.video-card{display:grid;grid-template-columns:1fr 1.1fr;gap:0;max-width:1180px;margin:0 auto;background:var(--bg-2);border:1px solid var(--line);border-radius:22px;overflow:hidden;align-items:stretch}
.video-card .video-side{position:relative;min-height:380px;background:linear-gradient(135deg,#1a1a1a 0%,#0a0a0a 100%);display:flex;align-items:center;justify-content:center;overflow:hidden}
.video-card .video-side::before{content:"";position:absolute;inset:0;background-image:url('logo-napoleon.jpg');background-repeat:no-repeat;background-position:center;background-size:50% auto;filter:invert(1) brightness(2) contrast(.5);opacity:.08;pointer-events:none}
.video-card .play{position:relative;z-index:2;width:84px;height:84px;border-radius:50%;border:1px solid var(--ink);display:flex;align-items:center;justify-content:center;color:var(--ink);background:rgba(245,239,226,.05);backdrop-filter:blur(8px);transition:all .3s}
.video-card a:hover .play{background:var(--ink);color:var(--bg);transform:scale(1.05)}
.video-card .video-meta{position:absolute;left:24px;bottom:24px;z-index:2;font-family:var(--sans);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-soft);display:flex;align-items:center;gap:10px}
.video-card .video-meta::before{content:"";width:6px;height:6px;background:#e1306c;border-radius:50%}
.video-card .text{padding:48px 48px;display:flex;flex-direction:column;justify-content:center}
.video-card .text .label{display:inline-flex;align-items:center;gap:14px;margin-bottom:18px}
.video-card .text .label::before{content:"";width:24px;height:1px;background:currentColor;opacity:.5}
.video-card .text h3{font-family:var(--serif);font-size:clamp(28px,3.4vw,40px);font-weight:500;line-height:1.15;letter-spacing:-.015em;margin-bottom:12px}
.video-card .text h3 em{font-style:italic;color:var(--ink-soft);font-weight:400}
.video-card .text .scr{font-family:var(--script);font-size:clamp(22px,2.4vw,32px);color:var(--ink-soft);line-height:1.1;margin:4px 0 18px}
.video-card .text p{max-width:42ch;margin-bottom:24px;font-size:14.5px}
.video-card .text .actions{display:flex;gap:10px;flex-wrap:wrap}
@media (max-width:880px){.video-card{grid-template-columns:1fr}.video-card .video-side{min-height:280px;aspect-ratio:16/10}.video-card .text{padding:40px 28px}}

/* Casa matriz callout */
.matriz-card{max-width:880px;margin:0 auto;background:var(--bg-2);border:1px solid var(--line);border-radius:22px;padding:48px 56px;text-align:center;position:relative;overflow:hidden}
.matriz-card::before{content:"";position:absolute;inset:0;background-image:url('logo-napoleon.jpg');background-repeat:no-repeat;background-position:right -40px center;background-size:auto 110%;filter:invert(1) brightness(2) contrast(.5);opacity:.05;pointer-events:none}
.matriz-card .label{display:inline-flex;align-items:center;gap:14px;margin-bottom:18px;position:relative;z-index:1}
.matriz-card .label::before,.matriz-card .label::after{content:"";width:24px;height:1px;background:currentColor;opacity:.6}
.matriz-card h3{font-family:var(--serif);font-size:clamp(28px,3.4vw,38px);font-weight:500;letter-spacing:-.01em;margin-bottom:8px;position:relative;z-index:1}
.matriz-card h3 em{font-style:italic;color:var(--ink-soft);font-weight:400}
.matriz-card .addr{font-family:var(--script);font-size:clamp(28px,3vw,40px);color:var(--ink-soft);line-height:1;margin:8px 0 16px;position:relative;z-index:1}
.matriz-card .extra{font-size:13px;color:var(--muted);max-width:46ch;margin:0 auto 24px;position:relative;z-index:1}
.matriz-card .actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}
@media (max-width:600px){.matriz-card{padding:36px 24px}}

/* ===================================================================
   PILLARS (3 categorías de sucursales en home)
   =================================================================== */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:1200px;margin:0 auto}
.pillar{background:var(--bg-2);border:1px solid var(--line);border-radius:22px;padding:42px 36px 36px;text-decoration:none;color:var(--ink);display:flex;flex-direction:column;gap:14px;transition:all .35s ease;position:relative;overflow:hidden}
.pillar::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:0;height:1px;background:var(--ink);transition:width .4s ease}
.pillar:hover{border-color:var(--ink-soft);transform:translateY(-3px);background:#161513}
.pillar:hover::before{width:60%}
.pillar .p-num{position:absolute;top:28px;right:32px;font-family:var(--serif);font-style:italic;font-size:54px;color:var(--ink);opacity:.12;font-weight:400;line-height:1;transition:opacity .3s}
.pillar:hover .p-num{opacity:.22}
.pillar .p-cat{font-size:9px;letter-spacing:.42em;text-transform:uppercase;color:var(--muted);font-weight:600;display:inline-flex;align-items:center;gap:10px}
.pillar .p-cat::before{content:"";width:18px;height:1px;background:currentColor;opacity:.6}
.pillar .p-title{font-family:var(--serif);font-size:28px;font-weight:500;letter-spacing:-.01em;line-height:1.15;font-style:italic;color:var(--ink);margin:2px 0 6px}
.pillar .p-list{list-style:none;margin:14px 0 0;padding:18px 0 0;display:flex;flex-direction:column;gap:14px;border-top:1px solid var(--line-soft)}
.pillar .p-list li{font-family:var(--sans);font-size:14px;color:var(--ink);font-weight:500;letter-spacing:.005em;display:flex;flex-direction:column;gap:3px}
.pillar .p-list li small{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:400}
.pillar .p-link{margin-top:auto;padding-top:22px;font-size:10px;letter-spacing:.34em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;transition:color .2s ease}
.pillar:hover .p-link{color:#fff}

@media (max-width:980px){
  .pillars{grid-template-columns:1fr;gap:14px;max-width:560px}
  .pillar{padding:32px 28px 28px}
  .pillar .p-num{font-size:42px;top:24px;right:26px}
  .pillar .p-title{font-size:24px}
  .pillar .p-list li{font-size:14px}
}

/* ===================================================================
   OFICIOS (4 disciplinas en home)
   =================================================================== */
.oficios{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;max-width:1240px;margin:0 auto}
.oficio{position:relative;border-radius:18px;overflow:hidden;background:var(--bg-2);border:1px solid var(--line);aspect-ratio:3/4;display:flex;flex-direction:column;justify-content:flex-end;color:var(--ink);transition:transform .35s ease, border-color .35s ease;text-decoration:none}
.oficio:hover{transform:translateY(-4px);border-color:var(--ink-soft)}
.oficio .o-ph{position:absolute;inset:0;overflow:hidden;z-index:0}
.oficio .o-ph img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease;filter:brightness(.65) saturate(.95)}
.oficio:hover .o-ph img{transform:scale(1.06);filter:brightness(.72) saturate(1)}
.oficio::after{content:"";position:absolute;inset:0;background:linear-gradient(to top, rgba(10,10,10,.96) 0%, rgba(10,10,10,.78) 35%, rgba(10,10,10,.25) 75%, rgba(10,10,10,.05) 100%);z-index:1;pointer-events:none}
.oficio .o-num{position:absolute;top:20px;left:22px;z-index:2;font-family:var(--serif);font-style:italic;font-size:18px;color:var(--ink);opacity:.85;letter-spacing:.04em;display:inline-flex;align-items:center;gap:10px;font-weight:400}
.oficio .o-num::after{content:"";width:22px;height:1px;background:currentColor;opacity:.5}
.oficio .o-body{position:relative;z-index:2;padding:0 24px 28px}
.oficio h4{font-family:var(--serif);font-size:24px;font-weight:500;letter-spacing:-.005em;line-height:1.15;margin-bottom:8px}
.oficio p{font-size:13px;color:var(--ink-soft);line-height:1.55;max-width:30ch;margin:0}

@media (max-width:980px){
  .oficios{grid-template-columns:repeat(2,1fr);gap:14px;max-width:720px}
  .oficio{aspect-ratio:4/5}
}
@media (max-width:560px){
  .oficios{grid-template-columns:1fr;max-width:420px;gap:14px}
  .oficio{aspect-ratio:16/11}
  .oficio .o-body{padding:0 22px 24px}
  .oficio h4{font-size:22px}
}

/* Footer nav additions */
footer .links a.active{color:var(--ink)}

/* Page intro after hero */
.page-intro{max-width:780px;margin:0 auto;text-align:center;padding:48px 28px 8px}
.page-intro p{font-size:16px;color:var(--ink-soft);line-height:1.7}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:.3em;text-transform:uppercase;border:1px solid var(--ink-soft);border-radius:999px;color:var(--ink);background:transparent;cursor:pointer;transition:all .25s ease}
.btn:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.btn.solid{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.btn.solid:hover{background:transparent;color:var(--ink);border-color:var(--ink-soft)}
.btn .arrow{font-family:serif;line-height:1}

/* Hero (home) */
.hero{position:relative;min-height:72vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:96px 24px 80px;overflow:hidden;border-bottom:1px solid rgba(245,239,226,.18)}
.hero-photo{position:absolute;inset:0;z-index:0;background:#000}
.hero-photo image-slot{position:absolute;inset:0;width:100%;height:100%}
.hero-photo::before{content:"";position:absolute;inset:0;z-index:1;background-image:url('logo-napoleon.jpg');background-repeat:no-repeat;background-position:center;background-size:auto 38%;filter:invert(1) brightness(2) contrast(.5);opacity:.12;pointer-events:none}
.hero-photo::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(ellipse at center, rgba(0,0,0,.55) 0%, rgba(0,0,0,.78) 70%, rgba(0,0,0,.9) 100%),linear-gradient(180deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.45) 40%, rgba(0,0,0,.55) 70%, rgba(0,0,0,.9) 100%)}
.hero-inner{position:relative;z-index:2;max-width:780px;margin:0 auto}
.hero-est{display:inline-flex;align-items:center;gap:14px;font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:#fff;font-weight:500;margin-bottom:28px;text-shadow:0 2px 12px rgba(0,0,0,.9), 0 1px 4px rgba(0,0,0,.7)}
.hero-est::before,.hero-est::after{content:"";width:24px;height:1px;background:#fff;opacity:.65}
.hero-title{font-family:var(--serif);font-size:clamp(36px,5.2vw,72px);font-weight:500;line-height:1.1;letter-spacing:-.01em;max-width:18ch;margin:0 auto 18px;color:var(--ink);text-shadow:0 2px 24px rgba(0,0,0,.85), 0 1px 4px rgba(0,0,0,.6)}
.hero-title em{font-style:italic;color:var(--ink-soft);font-weight:400}
.hero-script{font-family:var(--script);font-size:clamp(36px,4.4vw,56px);color:var(--ink);margin:2px auto 32px;line-height:1.1;font-weight:400;text-shadow:0 2px 20px rgba(0,0,0,.85), 0 1px 3px rgba(0,0,0,.6)}
.hero-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:3;font-size:9px;letter-spacing:.45em;text-transform:uppercase;color:var(--ink-soft);display:flex;flex-direction:column;align-items:center;gap:10px;pointer-events:none}
.hero-scroll::after{content:"";width:1px;height:36px;background:currentColor;opacity:.5;animation:scrollPulse 2.4s ease-in-out infinite;transform-origin:top}
@keyframes scrollPulse{0%,100%{transform:scaleY(.3);opacity:.3}50%{transform:scaleY(1);opacity:.8}}

/* Page hero (smaller, for inner pages) */
.page-hero{position:relative;padding:96px 24px 72px;text-align:center;border-bottom:1px solid var(--line-soft);overflow:hidden;background:var(--bg)}
.page-hero::before{content:"";position:absolute;inset:0;background-image:url('logo-napoleon.jpg');background-repeat:no-repeat;background-position:center;background-size:auto 80%;filter:invert(1) brightness(2) contrast(.5);opacity:.04;pointer-events:none}
.page-hero-inner{position:relative;z-index:1;max-width:780px;margin:0 auto}
.page-hero .label{display:inline-flex;align-items:center;gap:14px;margin-bottom:24px}
.page-hero .label::before,.page-hero .label::after{content:"";width:28px;height:1px;background:currentColor;opacity:.5}
.page-hero h1{font-family:var(--serif);font-size:clamp(40px,5.2vw,72px);font-weight:500;line-height:1.05;letter-spacing:-.01em;margin-bottom:14px}
.page-hero h1 em{font-style:italic;color:var(--ink-soft);font-weight:400}
.page-hero .sub{font-family:var(--script);font-size:clamp(28px,3.4vw,42px);color:var(--ink-soft);line-height:1;margin:8px 0 28px}
.page-hero p{max-width:54ch;margin:18px auto 0;color:var(--ink-soft)}

/* Servicios pills */
.servicios{padding:36px 28px;text-align:center;border-bottom:1px solid var(--line-soft)}
.servicios .label{display:block;margin-bottom:24px}
.servicios-list{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;max-width:780px;margin:0 auto}
.servicios-list span{padding:10px 22px;border:1px solid var(--line);border-radius:999px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);font-weight:400}

/* Sections */
section.s{padding:72px 28px;border-bottom:1px solid var(--line-soft);position:relative}
section.s:last-of-type{border-bottom:none}
.s-head{text-align:center;margin-bottom:44px}
.s-head .label{display:block;margin-bottom:20px}
.s-head h2.title{margin-bottom:14px}
.s-head p{max-width:46ch;margin:18px auto 0;color:var(--ink-soft)}
.s-head .ornament{margin-top:24px}
@media (max-width:720px){section.s{padding:56px 20px}.s-head{margin-bottom:32px}}

/* Sucursales */
.sucursales{display:grid;grid-template-columns:1fr 1fr;gap:32px;max-width:1120px;margin:0 auto}
.suc{background:var(--bg-2);border:1px solid var(--line);border-radius:24px;padding:48px 36px;text-align:center;display:flex;flex-direction:column;align-items:center}
.suc-motif{width:64px;height:64px;border:1px solid var(--ink-soft);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink);margin-bottom:24px}
.suc-title{font-family:var(--serif);font-size:30px;font-weight:500;margin-bottom:6px;letter-spacing:-.01em}
.suc-sub{font-family:var(--script);font-size:28px;color:var(--ink-soft);margin-bottom:20px;line-height:1}
.suc-photo{width:100%;aspect-ratio:4/3;background:#000;border:1px solid rgba(245,239,226,.22);border-radius:14px;margin-bottom:28px;overflow:hidden;position:relative}
.suc-photo::before{content:"";position:absolute;inset:0;background-image:url('logo-napoleon.jpg');background-repeat:no-repeat;background-position:center;background-size:55% auto;filter:invert(1) brightness(2) contrast(.5);opacity:.18;pointer-events:none;z-index:1}
.suc-photo image-slot{position:absolute;inset:0;width:100%;height:100%;z-index:2}
.suc-section{width:100%;margin-bottom:24px}
.suc-section h5{font-family:var(--sans);font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:var(--muted);font-weight:400;margin-bottom:16px}
.pill{width:100%;background:var(--bg-3);border:1px solid var(--line);border-radius:999px;padding:14px 24px;font-family:var(--sans);font-size:13px;letter-spacing:.18em;text-align:center;color:var(--ink);font-weight:400;margin-bottom:10px}
.pill .when{display:block;font-size:9px;letter-spacing:.32em;color:var(--muted);text-transform:uppercase;margin-bottom:6px;font-weight:500}
.suc-contact{display:flex;flex-direction:column;gap:8px;margin:8px 0 28px;font-size:13px;color:var(--ink-soft);letter-spacing:.04em}
.suc-contact .icon{width:14px;height:14px;display:inline-block;vertical-align:middle;margin-right:8px;opacity:.7}
.suc-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
@media (max-width:880px){.sucursales{grid-template-columns:1fr;gap:24px}.suc{padding:36px 24px}}

/* Home preview cards (smaller sucursal teasers) */
.suc-preview{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:1120px;margin:0 auto}
.suc-card{background:var(--bg-2);border:1px solid var(--line);border-radius:20px;overflow:hidden;display:flex;flex-direction:column;transition:all .3s}
.suc-card:hover{border-color:var(--ink-soft);transform:translateY(-2px)}
.suc-card .ph{aspect-ratio:16/10;background:#000;position:relative;border-bottom:1px solid rgba(245,239,226,.18)}
.suc-card .ph::before{content:"";position:absolute;inset:0;background-image:url('logo-napoleon.jpg');background-repeat:no-repeat;background-position:center;background-size:45% auto;filter:invert(1) brightness(2) contrast(.5);opacity:.16;pointer-events:none;z-index:1}
.suc-card .ph image-slot{position:absolute;inset:0;width:100%;height:100%;z-index:2}
.suc-card .body{padding:36px 32px;text-align:center;flex:1;display:flex;flex-direction:column}
.suc-card .label{display:inline-flex;align-items:center;gap:10px;margin-bottom:14px;justify-content:center}
.suc-card h3{font-family:var(--serif);font-size:28px;font-weight:500;margin-bottom:4px;letter-spacing:-.01em}
.suc-card .scr{font-family:var(--script);font-size:24px;color:var(--ink-soft);line-height:1;margin-bottom:18px}
.suc-card p{font-size:14.5px;margin-bottom:24px}
.suc-card .actions{margin-top:auto;display:flex;justify-content:center;gap:10px;flex-wrap:wrap}
@media (max-width:880px){.suc-preview{grid-template-columns:1fr}}

/* Cross-section CTAs (home links to other pages) */
.cross-links{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cross-link{background:var(--bg-2);border:1px solid var(--line);border-radius:20px;padding:28px 24px;text-align:center;transition:all .3s;display:flex;flex-direction:column;align-items:center;gap:10px}
.cross-link:hover{border-color:var(--ink-soft);background:var(--bg-3)}
.cross-link .icon{width:36px;height:36px;border:1px solid var(--ink-soft);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink);margin-bottom:8px}
.cross-link h4{font-family:var(--serif);font-size:22px;font-weight:500;letter-spacing:-.01em}
.cross-link p{font-size:13px;color:var(--muted);margin:0;line-height:1.5}
.cross-link .arr{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-soft);margin-top:8px}
@media (max-width:880px){.cross-links{grid-template-columns:1fr 1fr;gap:12px}}
@media (max-width:560px){.cross-links{grid-template-columns:1fr}}

/* Carta */
.carta-grid{max-width:880px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:56px}
.carta-cat h3{font-family:var(--serif);font-size:28px;font-weight:500;font-style:italic;text-align:center;margin-bottom:8px;color:var(--ink);letter-spacing:-.005em}
.carta-cat .cat-sub{text-align:center;font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:var(--muted);margin-bottom:32px}
.dish{display:flex;align-items:baseline;gap:16px;padding:18px 0;border-bottom:1px solid var(--line-soft);flex-wrap:wrap}
.dish:last-child{border-bottom:none}
.dish .name{font-family:var(--serif);font-size:19px;font-weight:500;color:var(--ink);flex-shrink:0;letter-spacing:-.005em}
.dish .dots{flex:1;border-bottom:1px dotted var(--line);transform:translateY(-4px);min-width:30px}
.dish .price{font-family:var(--serif);font-size:18px;font-style:italic;color:var(--ink-soft);white-space:nowrap}
.dish .desc{flex-basis:100%;font-size:13px;color:var(--muted);margin-top:6px;line-height:1.55}
.carta-note{margin-top:48px;text-align:center;font-family:var(--serif);font-style:italic;font-size:16px;color:var(--ink-soft)}

/* Eventos */
.eventos{max-width:780px;margin:0 auto;text-align:center}
.eventos-types{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin:32px 0 40px}
.eventos-types span{padding:8px 18px;border:1px solid var(--line);border-radius:999px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft)}
.cotiza-card{background:var(--bg-2);border:1px solid var(--line);border-radius:20px;padding:48px 40px;margin-top:32px;text-align:left}
.cotiza-card h4{font-family:var(--serif);font-size:26px;font-style:italic;font-weight:500;text-align:center;margin-bottom:8px;letter-spacing:-.005em}
.cotiza-card .sub{text-align:center;font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:var(--muted);margin-bottom:32px}
.cotiza-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px 32px;margin-bottom:32px;counter-reset:item}
.cotiza-list li{font-size:13.5px;padding:8px 0;color:var(--ink-soft);font-weight:300;border-bottom:1px solid var(--line-soft);display:flex;align-items:baseline;gap:14px}
.cotiza-list li::before{content:counter(item, decimal-leading-zero);counter-increment:item;font-size:10px;color:var(--muted);letter-spacing:.1em;font-weight:400;min-width:22px}
.cotiza-actions{text-align:center;padding-top:24px;border-top:1px solid var(--line-soft);display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.cotiza-note{text-align:center;font-size:11px;color:var(--muted);letter-spacing:.18em;text-transform:uppercase;margin-top:18px}
@media (max-width:600px){.cotiza-list{grid-template-columns:1fr}.cotiza-card{padding:32px 24px}}

/* Historia */
.historia{max-width:720px;margin:0 auto;text-align:center}
.historia .body p{margin-bottom:18px;font-size:16px;color:var(--ink-soft)}
.historia .pull{font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(20px,2.4vw,28px);line-height:1.4;color:var(--ink);letter-spacing:-.005em;margin:40px auto;padding:32px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);max-width:26ch}
.timeline{list-style:none;margin-top:48px;text-align:left;border-top:1px solid var(--line)}
.timeline li{display:grid;grid-template-columns:110px 1fr;gap:32px;padding:28px 0;border-bottom:1px solid var(--line-soft)}
.timeline .y{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--ink-soft)}
.timeline h5{font-family:var(--serif);font-size:18px;font-weight:400;margin-bottom:4px;color:var(--ink)}
.timeline p{font-size:13.5px;color:var(--muted);margin:0;line-height:1.55}
@media (max-width:600px){.timeline li{grid-template-columns:70px 1fr;gap:16px}}

/* Galería */
.gal{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;max-width:1120px;margin:0 auto}
.gal .g{aspect-ratio:1/1;background:#000;border:1px solid rgba(245,239,226,.22);border-radius:8px;overflow:hidden;position:relative}
.gal .g::before{content:"";position:absolute;inset:0;background-image:url('logo-napoleon.jpg');background-repeat:no-repeat;background-position:center;background-size:65% auto;filter:invert(1) brightness(2) contrast(.5);opacity:.15;pointer-events:none;z-index:1}
.gal .g image-slot{position:absolute;inset:0;width:100%;height:100%;z-index:2}
.gal-cta{text-align:center;margin-top:40px}
@media (max-width:720px){.gal{grid-template-columns:repeat(2,1fr)}}

/* Reseñas */
.resenas{max-width:1000px;margin:0 auto}
.stars{color:var(--ink);letter-spacing:4px;font-size:18px}
.rating-line{display:inline-flex;align-items:baseline;gap:16px;margin-top:16px;font-family:var(--serif)}
.rating-line .n{font-size:48px;font-weight:500;letter-spacing:-.01em}
.rating-line .info{font-family:var(--sans);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);text-align:left;font-weight:400}
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review{background:var(--bg-2);border:1px solid var(--line);border-radius:14px;padding:32px 28px;display:flex;flex-direction:column;gap:16px}
.review .stars{font-size:13px;letter-spacing:3px}
.review .quote{font-family:var(--serif);font-style:italic;font-size:17px;line-height:1.5;color:var(--ink);font-weight:400}
.review .who{margin-top:auto;padding-top:14px;border-top:1px solid var(--line-soft);font-size:12px;color:var(--ink-soft);letter-spacing:.04em}
.review .when{display:block;font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-top:4px}
@media (max-width:800px){.reviews{grid-template-columns:1fr}}

/* Mapas */
.mapas{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:1120px;margin:0 auto}
.mapa{background:var(--bg-2);border:1px solid var(--line);border-radius:18px;overflow:hidden}
.mapa .frame{aspect-ratio:4/3;background:#000;position:relative;overflow:hidden;border-bottom:1px solid rgba(245,239,226,.18)}
.mapa iframe{width:100%;height:100%;border:0;filter:invert(.94) hue-rotate(180deg) saturate(.3) contrast(.9)}
.mapa .info{padding:28px 32px}
.mapa .info h4{font-family:var(--serif);font-size:22px;font-weight:500;font-style:italic;margin-bottom:6px;letter-spacing:-.005em}
.mapa .info .addr{font-size:13.5px;color:var(--ink-soft);margin-bottom:10px;font-weight:300}
.mapa .info .hrs{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.mapa .links{display:flex;gap:18px}
.mapa .links a{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--ink-soft);padding-bottom:2px}
@media (max-width:880px){.mapas{grid-template-columns:1fr}}

/* Contacto */
.contacto{max-width:880px;margin:0 auto;text-align:center}
.contacto-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px}
.ccard{padding:32px 24px;border:1px solid var(--line);border-radius:18px;background:var(--bg-2);display:flex;flex-direction:column;gap:8px;text-align:center;transition:all .25s}
.ccard:hover{border-color:var(--ink-soft);background:var(--bg-3)}
.ccard .l{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}
.ccard .v{font-family:var(--serif);font-size:18px;font-weight:500;color:var(--ink);letter-spacing:-.005em}
.ccard small{font-size:12px;color:var(--ink-soft);font-weight:300}
@media (max-width:720px){.contacto-cards{grid-template-columns:1fr}}

/* Footer */
footer{padding:32px 28px;border-top:1px solid var(--line-soft)}
.foot-row{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.foot-brand{display:flex;align-items:center;gap:18px}
.foot-brand img{height:30px;width:auto;filter:invert(1) brightness(1.05)}
.foot-brand .tag{font-family:var(--script);font-size:22px;color:var(--ink-soft);line-height:1}
footer .links{display:flex;gap:28px;flex-wrap:wrap}
footer .links a{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-soft)}
footer .links a:hover{color:var(--ink)}
footer .copy{font-size:9px;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);text-align:center;margin-top:18px;padding-top:18px;border-top:1px solid var(--line-soft)}
@media (max-width:720px){.foot-row{flex-direction:column;text-align:center}}

image-slot{--placeholder-fg:rgba(245,239,226,.45);--placeholder-bg:transparent;--placeholder-font-size:11px;--placeholder-letter-spacing:.18em}

/* ===================================================================
   LANGUAGE TOGGLE (ES / EN)
   =================================================================== */
.lang-toggle{display:inline-flex;align-items:center;gap:0;border:1px solid rgba(245,239,226,.18);border-radius:999px;padding:3px;background:transparent;height:30px;margin-left:6px;transition:border-color .2s ease}
.lang-toggle:hover{border-color:rgba(245,239,226,.4)}
.lang-toggle .lang-opt{background:transparent;border:none;color:var(--muted);font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.22em;padding:0 10px;height:22px;border-radius:999px;cursor:pointer;transition:all .2s ease;line-height:1;display:inline-flex;align-items:center;justify-content:center}
.lang-toggle .lang-opt:hover{color:var(--ink)}
.lang-toggle .lang-opt.active{background:var(--ink);color:var(--bg)}
.lang-toggle .lang-sep{display:none}
.lang-toggle.m-lang{margin-left:0;margin-right:8px;height:38px;border-color:var(--line)}
.lang-toggle.m-lang .lang-opt{font-size:11px;padding:0 13px;height:30px}
@media (max-width:980px){
  nav.top .lang-toggle{display:none}
}

/* ===================================================================
   MOBILE NAV (hamburger + fullscreen overlay)
   =================================================================== */
.m-burger{display:none;background:transparent;border:1px solid var(--line);color:var(--ink);width:42px;height:42px;border-radius:999px;cursor:pointer;padding:0;flex-direction:column;justify-content:center;align-items:center;gap:4px;justify-self:end}
.m-burger span{display:block;width:16px;height:1px;background:currentColor;transition:transform .25s ease, opacity .2s ease}
.m-burger.open span:nth-child(1){transform:translateY(5px) rotate(45deg)}
.m-burger.open span:nth-child(2){opacity:0}
.m-burger.open span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}

.m-overlay{position:fixed;inset:0;z-index:200;background:#0a0a0a;display:flex;flex-direction:column;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .35s ease, visibility 0s linear .35s;overflow-y:auto}
.m-overlay.open{opacity:1;visibility:visible;pointer-events:auto;transition:opacity .35s ease, visibility 0s linear 0s}

.m-overlay-head{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--line-soft);position:sticky;top:0;background:rgba(10,10,10,.96);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);z-index:2}
.m-overlay-head .m-brand{display:flex;align-items:center;gap:12px}
.m-overlay-head .m-brand img{height:34px;width:auto;filter:invert(1) brightness(1.1)}
.m-overlay-head .m-script{font-family:var(--script);font-size:20px;color:var(--ink-soft);line-height:1;display:none}
@media (min-width:420px){.m-overlay-head .m-script{display:inline}}
.m-close{background:transparent;border:1px solid var(--line);color:var(--ink);width:42px;height:42px;border-radius:999px;cursor:pointer;display:flex;align-items:center;justify-content:center}

.m-overlay-body{flex:1;padding:24px 22px 16px;display:flex;flex-direction:column;gap:32px}
.m-section .m-section-label{font-size:9px;letter-spacing:.42em;text-transform:uppercase;color:var(--muted);font-weight:500;margin-bottom:14px;display:inline-flex;align-items:center;gap:12px}
.m-section .m-section-label::before{content:"";width:18px;height:1px;background:currentColor;opacity:.6}

.m-links{display:flex;flex-direction:column;border-top:1px solid var(--line-soft)}
.m-link{display:flex;justify-content:space-between;align-items:center;padding:18px 4px;border-bottom:1px solid var(--line-soft);font-family:var(--serif);font-size:22px;font-weight:500;letter-spacing:-.005em;color:var(--ink);text-decoration:none;transition:padding .2s ease, color .2s ease}
.m-link:hover, .m-link:active{padding-left:10px;color:#fff}
.m-link.active{font-style:italic;color:var(--ink-soft)}
.m-link .m-arr{font-family:serif;font-size:18px;color:var(--ink-soft);transition:transform .2s ease}
.m-link:hover .m-arr{transform:translateX(4px)}

.m-sucs{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:16px;padding:8px;background:var(--bg-2)}
.m-sucs .m-group{font-size:9px;letter-spacing:.4em;text-transform:uppercase;color:var(--muted);font-weight:500;padding:14px 12px 8px}
.m-sucs .m-group:first-child{padding-top:8px}
.m-sucs .m-sep{height:1px;background:var(--line-soft);margin:6px 12px}
.m-suc-link{display:flex;align-items:center;gap:14px;padding:12px 12px;border-radius:10px;text-decoration:none;color:var(--ink);transition:background .2s ease}
.m-suc-link:hover, .m-suc-link:active{background:var(--bg-3)}
.m-suc-link .m-num{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--muted);min-width:24px}
.m-suc-text{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}
.m-suc-title{font-family:var(--sans);font-size:14px;color:var(--ink);font-weight:500;letter-spacing:.01em;line-height:1.2}
.m-suc-sub{font-size:9px;letter-spacing:.32em;text-transform:uppercase;color:var(--muted);font-weight:500}
.m-suc-link .m-arr{font-family:serif;font-size:14px;color:var(--ink-soft)}

.m-overlay-foot{padding:16px 22px 28px;border-top:1px solid var(--line-soft);background:var(--bg-2);position:sticky;bottom:0}
.m-cta{display:flex;justify-content:space-between;align-items:center;background:var(--ink);color:var(--bg);padding:18px 24px;border-radius:999px;text-decoration:none;font-family:var(--sans);font-size:13px;letter-spacing:.32em;text-transform:uppercase;font-weight:600}
.m-cta .m-arr{font-family:serif;font-size:18px}
.m-foot-meta{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:16px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.m-foot-meta a{color:var(--ink-soft)}
.m-foot-meta span{opacity:.4}

@media (max-width:980px){
  .m-burger{display:flex}
  nav.top .row{grid-template-columns:1fr auto auto !important;gap:14px;padding:12px 18px}
  nav.top .nav-brand{justify-self:start}
  nav.top .nav-brand img{height:36px}
  nav.top .nav-l, nav.top .nav-r{display:none}
}
@media (min-width:981px){
  .m-burger{display:none !important}
  .m-overlay{display:none}
}

/* ===================================================================
   GLOBAL MOBILE TIGHTEN-UP
   =================================================================== */
@media (max-width:720px){
  section.s{padding:48px 18px}
  .wrap, .narrow{padding:0 18px}
  h2.title{font-size:30px}
  .page-hero{padding:64px 20px 56px}
  .page-hero h1{font-size:38px}
  .page-hero .sub{font-size:26px}
  .page-hero p{font-size:15px}

  /* Hero (home) */
  .hero{min-height:84vh;padding:80px 20px 64px}
  .hero-est{margin-bottom:18px;font-size:10px;letter-spacing:.3em}
  .hero-est::before, .hero-est::after{width:14px}
  .hero-title{font-size:42px;margin-bottom:10px}
  .hero-script{font-size:38px;margin:0 auto 26px}
  .hero-actions{flex-direction:column;align-items:stretch;max-width:280px;margin:0 auto;gap:10px}
  .hero-actions .btn{justify-content:center;padding:16px 20px}
  .hero-scroll{display:none}

  /* Servicios pills */
  .servicios{padding:28px 18px}
  .servicios .label{margin-bottom:18px}
  .servicios-list{gap:6px}
  .servicios-list span{padding:8px 14px;font-size:10px;letter-spacing:.18em}

  /* Section heads */
  .s-head{margin-bottom:28px}
  .s-head p{font-size:14.5px}
  .ornament .ln{width:42px}

  /* Sucursales (home preview + page) */
  .suc-card .body{padding:26px 22px}
  .suc-card h3{font-size:24px}
  .suc-card .scr{font-size:22px;margin-bottom:14px}
  .suc-card p{font-size:14px;margin-bottom:20px}

  /* Suc-grid (8 cards) */
  .sucs-grid{gap:14px}
  .suc-mini .body{padding:20px 20px 22px}
  .suc-mini h3{font-size:20px}
  .suc-mini .where{font-size:20px}
  .suc-mini p{font-size:13px}
  .suc-mini .meta{font-size:9.5px;letter-spacing:.18em;flex-wrap:wrap;gap:6px}

  /* Preferidos */
  .pref-card .body{padding:20px 22px}
  .pref-card h4{font-size:20px}
  .pref-card .price{font-size:16px}
  .pref-card .top{flex-wrap:wrap;gap:4px}

  /* Voice strip */
  .voice-strip .text{padding:32px 24px}
  .voice-strip .text h3{font-size:28px}
  .voice-strip .text .scr{font-size:24px;margin:4px 0 14px}
  .voice-strip .text p{margin-bottom:18px}
  .cap, .cap.script{font-size:15px;padding:5px 10px}

  /* Reservar split */
  .reservar-split{gap:32px}
  .reservar-split .left h2{font-size:46px}
  .reservar-split .left p{font-size:14.5px;margin-bottom:22px}
  .reservar-split .left .actions{flex-direction:column;align-items:stretch}
  .reservar-split .left .actions .btn{justify-content:center}
  .info-grid{grid-template-columns:1fr;gap:0}
  .info-grid > .row{display:block;padding:18px 0;border-bottom:1px solid var(--line-soft)}
  .info-grid > .row:last-child{border-bottom:none}
  .info-grid .k{padding-top:0;margin-bottom:8px;font-size:9px;letter-spacing:.32em}
  .info-grid .v{padding:0;border-bottom:none}
  .info-grid .v strong{font-size:19px}
  .info-grid .v small{font-size:12.5px}

  /* Photo strip */
  .photo-strip{gap:6px}

  /* Cross links */
  .cross-link{padding:22px 18px}
  .cross-link h4{font-size:18px}
  .cross-link p{font-size:12.5px}

  /* Carta */
  .carta-tabs{padding:6px;flex-wrap:wrap;justify-content:center}
  .carta-tabs a{flex:1 0 auto;text-align:center}
  .menu-block-head h2{font-size:34px}
  .menu-block-head .where{font-size:22px}
  .menu-block-head p{font-size:14px}
  .menu-block-head .badge{font-size:8px;letter-spacing:.28em;padding:6px 14px}
  .dish{padding:14px 0;gap:10px}
  .dish .name{font-size:17px}
  .dish .price{font-size:16px}
  .dish .desc{font-size:12.5px}
  .menu-placeholder{padding:40px 22px}
  .menu-placeholder h4{font-size:22px}
  .menu-placeholder p{font-size:13.5px}
  .menu-placeholder .pdf-slot{padding:14px 18px;font-size:10px;letter-spacing:.18em;gap:10px;flex-wrap:wrap;justify-content:center;text-align:center}
  .menu-placeholder .pdf-slot::before{width:26px;height:34px}

  /* Eventos */
  .eventos-types{gap:6px}
  .eventos-types span{padding:7px 14px;font-size:10px;letter-spacing:.18em}
  .cotiza-card{padding:32px 22px}
  .cotiza-card h4{font-size:22px}
  .cotiza-list li{font-size:13px}
  .cotiza-actions{flex-direction:column;align-items:stretch}
  .cotiza-actions .btn{justify-content:center}

  /* Historia */
  .historia .pull{font-size:20px;padding:24px 0;margin:32px auto}
  .timeline li{padding:22px 0}
  .timeline .y{font-size:18px}
  .timeline h5{font-size:16px}
  .timeline p{font-size:13px}

  /* Contacto */
  .video-card .text{padding:32px 22px}
  .video-card .text h3{font-size:24px}
  .video-card .text .scr{font-size:22px}
  .video-card .text .actions{flex-direction:column;align-items:stretch}
  .video-card .text .actions .btn{justify-content:center}
  .video-card .play{width:64px;height:64px}
  .video-card .video-side{min-height:220px}

  .matriz-card{padding:32px 22px}
  .matriz-card h3{font-size:26px}
  .matriz-card .addr{font-size:28px}
  .matriz-card .extra{font-size:13px}
  .matriz-card .actions{flex-direction:column;align-items:stretch}
  .matriz-card .actions .btn{justify-content:center}
  .matriz-card::before{background-position:right -100px center;background-size:auto 70%;opacity:.03}

  .contacto-cards{gap:10px}
  .ccard{padding:24px 18px;text-align:center}
  .ccard .v{font-size:17px}
  .ccard small{font-size:11.5px}

  .mapa .info{padding:22px 22px}
  .mapa .info h4{font-size:20px}
  .mapa .info .addr{font-size:13px}
  .mapa .info .hrs{font-size:10px;letter-spacing:.16em}
  .mapa .links{gap:14px;flex-wrap:wrap}
  .mapa .links a{font-size:9.5px;letter-spacing:.22em}

  .reviews{gap:14px}
  .review{padding:24px 22px}
  .review .quote{font-size:15px;line-height:1.55}

  /* Gallery filters */
  .gal-filters{gap:6px;margin-bottom:28px}
  .gal-filters span{padding:7px 14px;font-size:9.5px;letter-spacing:.22em}

  /* Footer */
  footer{padding:28px 20px 24px}
  footer .links{justify-content:center;gap:14px 22px}
  footer .links a{font-size:9.5px;letter-spacing:.22em}
  .foot-brand img{height:26px}
  .foot-brand .tag{font-size:20px}
  footer .copy{font-size:8.5px;letter-spacing:.18em}

  /* Page intro */
  .page-intro{padding:32px 20px 0}
  .page-intro p{font-size:15px}
}

@media (max-width:480px){
  .hero-title{font-size:36px}
  .hero-script{font-size:32px}
  .page-hero h1{font-size:32px}
  .page-hero .sub{font-size:22px}
  h2.title{font-size:26px}
  .reservar-split .left h2{font-size:38px}
  .menu-block-head h2{font-size:28px}
  .matriz-card .addr{font-size:24px}
  .video-card .text h3{font-size:22px}

  /* Mosaico en móvil */
  .galeria-grid{display:block;columns:2;column-gap:6px;max-width:100%}
  .gp{display:block;break-inside:avoid;margin-bottom:6px;border-radius:6px;aspect-ratio:unset!important;grid-column:unset!important;grid-row:unset!important;overflow:hidden}
  .gp img{position:static!important;width:100%!important;height:auto!important;object-fit:unset!important;display:block!important;border-radius:0}
  .gp .cap{display:none}
  .gp.big,.gp.wide,.gp.tall{aspect-ratio:unset}
  .gp.empty::after{font-size:8px;letter-spacing:.22em}
}

/* ====== Real photos (replacing image-slots) ====== */
.ph img, .suc-photo img, .hero-photo img, .gal .g img, .mapa .frame img, .eventos-img img, .full-photo img, .strip-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:2}
/* hide logo watermark when a real photo is present */
.ph:has(img)::before, .suc-photo:has(img)::before, .hero-photo:has(img)::before, .gal .g:has(img)::before{display:none}
/* Hero carousel crossfade */
.hero-photo .hc-slide{opacity:0;transition:opacity 2.9s ease-in-out}
.hero-photo .hc-slide.active{opacity:1}
@media (prefers-reduced-motion: reduce){.hero-photo .hc-slide{transition:none}}

/* Photo overlay caption (Instagram-story style) */
.cap{position:absolute;z-index:3;font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(16px,1.6vw,22px);line-height:1.3;color:#1a1a1a;background:rgba(245,228,170,.92);padding:6px 14px;letter-spacing:-.01em;border-left:2px solid #c9a347}
.cap.script{font-family:var(--script);font-style:normal;font-weight:400;font-size:clamp(22px,2.4vw,32px);padding:4px 14px}
.cap.white{background:rgba(255,255,255,.94);color:#1a1a1a;border-color:#1a1a1a}
.cap.tl{top:24px;left:24px}
.cap.bl{bottom:24px;left:24px}
.cap.br{bottom:24px;right:24px}
.cap.tr{top:24px;right:24px}
.cap.bc{bottom:24px;left:50%;transform:translateX(-50%);text-align:center}

/* Brand voice strip (between sections) */
.voice-strip{display:grid;grid-template-columns:1.2fr 1fr;gap:0;max-width:1280px;margin:0 auto;background:var(--bg-2);border:1px solid var(--line);border-radius:24px;overflow:hidden;align-items:stretch}
.voice-strip .photo{position:relative;min-height:380px;background:#000;overflow:hidden}
.voice-strip .photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.voice-strip .text{padding:48px 48px;display:flex;flex-direction:column;justify-content:center}
.voice-strip .text .label{display:inline-flex;align-items:center;gap:14px;margin-bottom:18px}
.voice-strip .text .label::before{content:"";width:24px;height:1px;background:currentColor;opacity:.5}
.voice-strip .text h3{font-family:var(--serif);font-size:clamp(28px,3.6vw,46px);font-weight:500;line-height:1.1;letter-spacing:-.015em;margin-bottom:14px}
.voice-strip .text h3 em{font-style:italic;color:var(--ink-soft);font-weight:400}
.voice-strip .text .scr{font-family:var(--script);font-size:clamp(26px,3vw,40px);color:var(--ink-soft);line-height:1.1;margin:6px 0 22px}
.voice-strip .text p{max-width:44ch;margin-bottom:24px}
@media (max-width:880px){.voice-strip{grid-template-columns:1fr}.voice-strip .photo{min-height:320px;aspect-ratio:4/3}.voice-strip .text{padding:40px 28px}}

/* Photo strip (small horizontal photos) */
.photo-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;max-width:1280px;margin:0 auto}
.photo-strip .pic{aspect-ratio:1/1;background:#000;border-radius:8px;overflow:hidden;position:relative;border:1px solid var(--line)}
.photo-strip .pic img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.photo-strip .pic:hover img{transform:scale(1.05)}
@media (max-width:720px){.photo-strip{grid-template-columns:repeat(3,1fr)}.photo-strip .pic:nth-child(n+4){display:none}}

/* ====== Home: Preferidos del Chef ====== */
.preferidos{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1180px;margin:0 auto}
.pref-card{background:var(--bg-2);border:1px solid var(--line);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:all .3s}
.pref-card:hover{border-color:var(--ink-soft);transform:translateY(-2px)}
.pref-card .ph{aspect-ratio:4/3;background:#000;position:relative;border-bottom:1px solid rgba(245,239,226,.18)}
.pref-card .ph::before{content:"";position:absolute;inset:0;background-image:url('logo-napoleon.jpg');background-repeat:no-repeat;background-position:center;background-size:55% auto;filter:invert(1) brightness(2) contrast(.5);opacity:.16;pointer-events:none;z-index:1}
.pref-card .ph image-slot{position:absolute;inset:0;width:100%;height:100%;z-index:2}
.pref-card .body{padding:24px 26px;display:flex;flex-direction:column;gap:8px;flex:1}
.pref-card .top{display:flex;justify-content:space-between;align-items:baseline;gap:14px}
.pref-card h4{font-family:var(--serif);font-size:22px;font-weight:500;letter-spacing:-.01em;line-height:1.2}
.pref-card .price{font-family:var(--serif);font-size:17px;font-style:italic;color:var(--ink-soft);white-space:nowrap}
.pref-card .desc{font-size:13px;color:var(--muted);line-height:1.5;margin:2px 0 4px}
.pref-card .tag{margin-top:auto;padding-top:12px;border-top:1px solid var(--line-soft);font-size:9px;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-soft)}
@media (max-width:900px){.preferidos{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.preferidos{grid-template-columns:1fr}}

/* ====== Home: Reservá tu mesa (split layout) ====== */
.reservar-split{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;max-width:1180px;margin:0 auto;align-items:center}
.reservar-split .left .label{display:inline-flex;align-items:center;gap:14px;margin-bottom:24px}
.reservar-split .left .label::before{content:"";width:24px;height:1px;background:currentColor;opacity:.5}
.reservar-split .left h2{font-family:var(--serif);font-size:clamp(40px,5.6vw,76px);font-weight:500;line-height:1.02;letter-spacing:-.015em;margin-bottom:22px}
.reservar-split .left h2 em{font-style:italic;color:var(--ink-soft);font-weight:400;display:block}
.reservar-split .left p{max-width:42ch;margin-bottom:28px}
.reservar-split .left .actions{display:flex;gap:12px;flex-wrap:wrap}
.info-grid{display:grid;grid-template-columns:120px 1fr;gap:24px 24px;align-items:start}
.info-grid > .row{display:contents}
.info-grid .k{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);padding-top:6px;font-weight:500}
.info-grid .v{padding:0 0 24px;border-bottom:1px solid var(--line-soft)}
.info-grid .v strong{display:block;font-family:var(--serif);font-size:21px;font-weight:500;letter-spacing:-.005em;line-height:1.2;margin-bottom:4px;color:var(--ink)}
.info-grid .v small{display:block;font-size:13px;color:var(--ink-soft);margin-top:2px;font-weight:300;line-height:1.5}
.info-grid > div:nth-last-child(-n+2) .v{border-bottom:none;padding-bottom:0}
@media (max-width:880px){.reservar-split{grid-template-columns:1fr;gap:40px}.info-grid{grid-template-columns:90px 1fr;gap:18px 18px}}
