/* ---------- self-hosted fonts ---------- */
@font-face{font-family:"Pinyon Script";font-style:normal;font-weight:400;font-display:swap;src:url("fonts/pinyon-script-latin-400-normal.woff2") format("woff2")}
@font-face{font-family:"Cormorant Garamond";font-style:normal;font-weight:400;font-display:swap;src:url("fonts/cormorant-garamond-latin-400-normal.woff2") format("woff2")}
@font-face{font-family:"Cormorant Garamond";font-style:normal;font-weight:500;font-display:swap;src:url("fonts/cormorant-garamond-latin-500-normal.woff2") format("woff2")}
@font-face{font-family:"Cormorant Garamond";font-style:normal;font-weight:600;font-display:swap;src:url("fonts/cormorant-garamond-latin-600-normal.woff2") format("woff2")}
@font-face{font-family:"Jost";font-style:normal;font-weight:300;font-display:swap;src:url("fonts/jost-latin-300-normal.woff2") format("woff2")}
@font-face{font-family:"Jost";font-style:normal;font-weight:400;font-display:swap;src:url("fonts/jost-latin-400-normal.woff2") format("woff2")}
@font-face{font-family:"Jost";font-style:normal;font-weight:500;font-display:swap;src:url("fonts/jost-latin-500-normal.woff2") format("woff2")}
@font-face{font-family:"Jost";font-style:normal;font-weight:600;font-display:swap;src:url("fonts/jost-latin-600-normal.woff2") format("woff2")}

/* ============================================================
   LA DUQUESA — Restaurante Bar · Guamúchil
   Emerald noir · gold · cream — taken from the printed menu
   ============================================================ */
:root{
  --noir:#07120d;
  --emerald:#0c1d16;
  --emerald-2:#11271d;
  --cream:#f1e9d6;
  --cream-dim:rgba(241,233,214,.62);
  --gold:#c8a256;
  --gold-soft:#e8d2a0;
  --gold-line:rgba(200,162,86,.35);
  --shadow:0 30px 60px rgba(0,0,0,.55);
  --ease:cubic-bezier(.22,.9,.24,1);
  --vh:100dvh;
}
@supports not (height:100dvh){ :root{ --vh:100vh; } }

*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overscroll-behavior:none}
body{
  background:
    radial-gradient(120% 90% at 50% -10%, #143124 0%, transparent 55%),
    radial-gradient(90% 70% at 50% 110%, #0f241b 0%, transparent 60%),
    var(--noir);
  color:var(--cream);
  font-family:"Jost",system-ui,sans-serif;
  font-weight:300;
  overflow:hidden;
  position:fixed; inset:0;            /* the deck owns all movement */
}
::selection{background:var(--gold);color:var(--noir)}
.script{font-family:"Pinyon Script",cursive;font-weight:400}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}

/* ---------- background canvas + grain ---------- */
#dust{position:fixed;inset:0;z-index:0;pointer-events:none}
.grain{position:fixed;inset:-50%;z-index:1;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='0.6'/%3E%3C/svg%3E");
  animation:grain 7s steps(8) infinite}
@keyframes grain{0%,100%{transform:translate(0,0)}25%{transform:translate(-2%,3%)}50%{transform:translate(3%,-2%)}75%{transform:translate(-3%,-3%)}}

/* ============================================================
   LOADER
   ============================================================ */
.loader{position:fixed;inset:0;z-index:100;display:grid;place-items:center;
  background:radial-gradient(110% 90% at 50% 30%, #102419 0%, var(--noir) 70%);
  transition:opacity .9s var(--ease), visibility .9s}
.loader.done{opacity:0;visibility:hidden}
.loader-inner{display:grid;justify-items:center;gap:18px;padding:24px;text-align:center}
.crown{width:96px;height:64px}
.crown-path,.crown-base{fill:none;stroke:var(--gold);stroke-width:2.4;stroke-linejoin:round;stroke-linecap:round;
  stroke-dasharray:320;stroke-dashoffset:320;animation:drawcrown 2.2s var(--ease) .15s forwards}
.crown-base{stroke-dasharray:100;stroke-dashoffset:100;animation-delay:1.4s;animation-duration:1s}
.crown-gem{fill:var(--gold-soft);opacity:0;animation:gem .8s var(--ease) forwards}
.crown-gem:nth-of-type(1){animation-delay:1.7s}.crown-gem:nth-of-type(2){animation-delay:1.9s}.crown-gem:nth-of-type(3){animation-delay:2.1s}
@keyframes drawcrown{to{stroke-dashoffset:0}}
@keyframes gem{from{opacity:0;transform:scale(.4);transform-origin:center}to{opacity:1;transform:scale(1)}}
.loader-name{display:flex;align-items:center;gap:.45em;font-family:"Cormorant Garamond",serif;
  font-size:clamp(1.7rem,6vw,2.6rem);letter-spacing:.42em;text-indent:.42em;color:var(--cream)}
.loader-name i{width:34px;height:1px;background:var(--gold-line)}
.loader-name span{opacity:0;animation:rise .9s var(--ease) forwards}
.loader-name span:nth-child(1){animation-delay:.30s}.loader-name span:nth-child(2){animation-delay:.38s}
.loader-name span:nth-child(3){animation-delay:.52s}.loader-name span:nth-child(4){animation-delay:.60s}
.loader-name span:nth-child(5){animation-delay:.68s}.loader-name span:nth-child(6){animation-delay:.76s}
.loader-name span:nth-child(7){animation-delay:.84s}.loader-name span:nth-child(8){animation-delay:.92s}
.loader-name span:nth-child(9){animation-delay:1.0s}.loader-name span:nth-child(10){animation-delay:1.08s}
.loader-sub{font-size:.72rem;letter-spacing:.38em;text-transform:uppercase;color:var(--gold);opacity:0;animation:rise 1s var(--ease) 1.3s forwards}
.loader-bar{width:min(240px,60vw);height:1px;background:rgba(241,233,214,.12);overflow:hidden;margin-top:6px}
.loader-fill{height:100%;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-soft));
  box-shadow:0 0 14px var(--gold);transition:width .25s linear}
@keyframes rise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   FIXED CHROME
   ============================================================ */
.topbar{position:fixed;top:0;left:0;right:0;z-index:40;display:flex;justify-content:space-between;align-items:center;
  padding:calc(14px + env(safe-area-inset-top)) 22px 14px;
  background:linear-gradient(180deg, rgba(7,18,13,.85), transparent)}
.brand{display:flex;align-items:center;gap:10px;font-family:"Cormorant Garamond",serif;font-size:1.05rem;letter-spacing:.18em;text-transform:uppercase}
.brand b{color:var(--gold);font-weight:500}
.brand-crown{width:26px;height:18px;stroke:var(--gold);fill:none;stroke-width:6}
.topbar-cta{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-soft);
  border:1px solid var(--gold-line);padding:9px 14px;border-radius:999px;transition:.3s;white-space:nowrap}
.topbar-cta:hover{background:var(--gold);color:var(--noir)}

.dots{position:fixed;right:16px;top:50%;transform:translateY(-50%);z-index:40;display:grid;gap:16px}
.dots button{position:relative;width:22px;height:22px;display:grid;place-items:center}
.dots i{width:6px;height:6px;border-radius:50%;background:rgba(241,233,214,.3);transition:.4s var(--ease);transform:rotate(45deg)}
.dots .active i{background:var(--gold);box-shadow:0 0 12px var(--gold);width:9px;height:9px}
.dots em{position:absolute;right:28px;top:50%;transform:translateY(-50%);font-style:normal;font-size:.62rem;
  letter-spacing:.26em;text-transform:uppercase;color:var(--gold-soft);opacity:0;pointer-events:none;transition:.3s;white-space:nowrap}
.dots button:hover em{opacity:1}

.counter{position:fixed;left:22px;bottom:calc(20px + env(safe-area-inset-bottom));z-index:40;display:flex;align-items:center;gap:10px;
  font-family:"Cormorant Garamond",serif;font-size:.95rem;letter-spacing:.2em;color:var(--cream-dim)}
.counter span:first-child{color:var(--gold)}
.counter i{width:30px;height:1px;background:var(--gold-line)}

.fab{position:fixed;right:18px;bottom:calc(18px + env(safe-area-inset-bottom));z-index:40;display:flex;align-items:center;gap:9px;
  background:linear-gradient(135deg,var(--gold),#a9823c);color:var(--noir);font-weight:500;font-size:.78rem;
  letter-spacing:.16em;text-transform:uppercase;padding:13px 18px;border-radius:999px;box-shadow:0 12px 30px rgba(200,162,86,.35);
  transition:transform .3s var(--ease)}
.fab:hover{transform:translateY(-3px)}
.fab svg{width:17px;height:17px;fill:var(--noir)}

/* ============================================================
   DECK + SLIDES
   ============================================================ */
.deck{position:fixed;inset:0;z-index:10;will-change:transform;
  transition:transform .95s cubic-bezier(.76,0,.18,1)}
.slide{height:var(--vh);width:100%;position:relative;display:grid;place-items:center;overflow:hidden}
.slide-body{position:relative;z-index:3;width:min(1100px,92vw);text-align:center;display:grid;justify-items:center;
  padding:84px 0 64px}
.slide-body.wide{width:min(1280px,94vw)}

/* entrance choreography */
.rise{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease) var(--d,0s),transform .9s var(--ease) var(--d,0s)}
.slide.on .rise{opacity:1;transform:translateY(0)}

.eyebrow{font-size:.68rem;letter-spacing:.42em;text-transform:uppercase;color:var(--gold)}
.title{margin-top:6px}
.title .script{font-size:clamp(3.2rem,9vw,5.4rem);color:var(--cream);line-height:1;
  text-shadow:0 0 50px rgba(200,162,86,.25)}

/* ---------- HERO ---------- */
.hero-frame{position:absolute;inset:clamp(14px,3vw,30px);border:1px solid var(--gold-line);z-index:2;pointer-events:none}
.hero-frame::before,.hero-frame::after{content:"";position:absolute;width:22px;height:22px;border:1px solid var(--gold)}
.hero-frame::before{top:-1px;left:-1px;border-right:0;border-bottom:0}
.hero-frame::after{bottom:-1px;right:-1px;border-left:0;border-top:0}
.hero-title{display:grid;justify-items:center;line-height:.9;margin:10px 0 4px}
.hero-title .script{font-size:clamp(3.4rem,11vw,7rem);color:var(--gold-soft);margin-bottom:-.28em;z-index:2;
  text-shadow:0 6px 30px rgba(0,0,0,.6)}
.hero-title .serif{font-family:"Cormorant Garamond",serif;font-weight:500;font-size:clamp(3rem,13vw,8.6rem);
  letter-spacing:.16em;text-indent:.16em;
  background:linear-gradient(180deg,#fdf6e3 20%,var(--gold-soft) 55%,var(--gold) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.hero-line{max-width:46ch;color:var(--cream-dim);font-size:clamp(.95rem,2.4vw,1.1rem);line-height:1.75;margin-top:18px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:26px}
.btn{font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;padding:15px 26px;border-radius:999px;transition:.35s var(--ease)}
.btn.gold{background:linear-gradient(135deg,var(--gold),#a9823c);color:var(--noir);font-weight:500;box-shadow:0 14px 34px rgba(200,162,86,.3)}
.btn.gold:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(200,162,86,.45)}
.btn.ghost{border:1px solid var(--gold-line);color:var(--gold-soft)}
.btn.ghost:hover{background:rgba(200,162,86,.12)}
.hero-hours{margin-top:22px;font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;color:var(--cream-dim)}
.swipe-hint{position:absolute;bottom:calc(18px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);z-index:3;
  display:grid;justify-items:center;gap:8px;font-size:.62rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold)}
.swipe-hint i{width:1px;height:34px;background:linear-gradient(180deg,var(--gold),transparent);animation:hint 1.8s var(--ease) infinite}
@keyframes hint{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- ESPECIALIDADES ---------- */
.cards{display:grid;grid-auto-flow:column;grid-auto-columns:min(300px,76vw);gap:18px;overflow-x:auto;
  width:100%;padding:26px 4vw 30px;scroll-snap-type:x mandatory;scrollbar-width:none;
  -webkit-overflow-scrolling:touch;mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.cards::-webkit-scrollbar{display:none}
.cards{cursor:grab}
.card{scroll-snap-align:center;background:linear-gradient(180deg,var(--emerald-2),var(--emerald));
  border:1px solid rgba(200,162,86,.22);border-radius:18px;overflow:hidden;display:grid;
  grid-template-rows:200px 1fr;text-align:left;box-shadow:var(--shadow);
  transition:transform .45s var(--ease),border-color .45s}
.card:hover{transform:translateY(-8px);border-color:var(--gold)}
.card figure{overflow:hidden;position:relative}
.card figure::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(12,29,22,.85))}
.card img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.02);transition:transform .8s var(--ease)}
.card:hover img{transform:scale(1.1)}
.deco-fig{display:grid;place-items:center;background:
  radial-gradient(80% 80% at 50% 30%, rgba(200,162,86,.18), transparent 70%), var(--emerald)}
.deco-fig .script{font-size:6.5rem;color:var(--gold);text-shadow:0 0 40px rgba(200,162,86,.5)}
.card-info{padding:18px 20px 22px;display:grid;gap:8px;align-content:start}
.card-cat{font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold)}
.card-info h3{font-family:"Cormorant Garamond",serif;font-weight:500;font-size:1.5rem;letter-spacing:.04em}
.card-info p{font-size:.83rem;line-height:1.6;color:var(--cream-dim)}
.price{font-family:"Cormorant Garamond",serif;font-size:1.2rem;color:var(--gold-soft);letter-spacing:.06em}
.cards-hint{font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--cream-dim)}

/* ---------- MENÚ ---------- */
.menu-layout{display:grid;grid-template-rows:auto 1fr;height:calc(var(--vh) - 80px);align-items:start;gap:4px;
  padding:68px 0 20px}
.menu-head{display:grid;justify-items:center;gap:6px;width:100%}
.chips{display:flex;gap:9px;overflow-x:auto;max-width:100%;padding:8px 14px;scrollbar-width:none;
  mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent)}
.chips::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cream-dim);
  border:1px solid rgba(241,233,214,.18);padding:9px 15px;border-radius:999px;transition:.3s;white-space:nowrap}
.chip.active{color:var(--noir);background:var(--gold);border-color:var(--gold);font-weight:500;box-shadow:0 6px 20px rgba(200,162,86,.35)}
.menu-scroll{width:min(860px,94vw);justify-self:center;height:100%;overflow-y:auto;overscroll-behavior:contain;
  padding:8px 16px 50px;scrollbar-width:thin;scrollbar-color:var(--gold-line) transparent;
  mask-image:linear-gradient(180deg,transparent,#000 24px,#000 calc(100% - 40px),transparent)}
.menu-cat{padding:26px 0 6px}
.menu-cat h3{font-family:"Pinyon Script",cursive;font-weight:400;font-size:2.4rem;color:var(--gold-soft);text-align:center}
.menu-cat .cat-rule{display:flex;align-items:center;gap:12px;margin:8px 0 16px;color:var(--gold)}
.cat-rule::before,.cat-rule::after{content:"";flex:1;height:1px;background:var(--gold-line)}
.cat-rule span{font-size:.85rem;letter-spacing:.2em}
.mi{display:grid;grid-template-columns:1fr auto;gap:4px 18px;padding:13px 4px;border-bottom:1px solid rgba(241,233,214,.08);text-align:left}
.mi-name{font-family:"Cormorant Garamond",serif;font-size:1.18rem;letter-spacing:.04em;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.tag{font-family:"Jost";font-size:.55rem;letter-spacing:.22em;text-transform:uppercase;color:var(--noir);
  background:var(--gold);padding:3px 8px;border-radius:3px;font-weight:600}
.mi-price{font-family:"Cormorant Garamond",serif;font-size:1.12rem;color:var(--gold-soft);white-space:nowrap}
.mi-desc{grid-column:1/-1;font-size:.82rem;line-height:1.6;color:var(--cream-dim);max-width:62ch}

/* ---------- RESERVACIONES ---------- */
.phone-big{font-family:"Jost",system-ui,sans-serif;font-weight:300;font-size:clamp(2.4rem,9vw,5rem);letter-spacing:.14em;
  margin:14px 0 4px;background:linear-gradient(180deg,#fdf6e3,var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent;
  border-bottom:1px solid var(--gold-line);padding-bottom:8px;transition:.3s}
.phone-big:hover{border-color:var(--gold)}
.phone-sub{font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--cream-dim);margin-bottom:6px}
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:26px;width:min(880px,92vw);
  margin-top:38px;padding-top:30px;border-top:1px solid rgba(241,233,214,.1)}
.info-grid h4{font-size:.66rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.info-grid p{font-size:.92rem;line-height:1.7;color:var(--cream-dim)}
.link{display:inline-block;margin-top:8px;font-size:.8rem;letter-spacing:.14em;color:var(--gold-soft);border-bottom:1px solid var(--gold-line);padding-bottom:2px;transition:.3s}
.link:hover{color:var(--gold);border-color:var(--gold)}
.footnote{margin-top:36px;font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(241,233,214,.35)}

/* ============================================================
   RESPONSIVE + MOTION
   ============================================================ */
@media (max-width:640px){
  .topbar{padding:calc(12px + env(safe-area-inset-top)) 16px 12px}
  .topbar-cta{display:none}
  .dots{right:10px;gap:14px}
  .counter{display:none}
  .fab span{display:inline}
  .slide-body{padding:76px 0 56px}
  .card{grid-template-rows:176px 1fr}
  .menu-layout{height:calc(var(--vh) - 56px);padding-top:58px}
  .info-grid{gap:20px;text-align:center}
  .hero-frame{inset:10px}
  /* loader mobile fix */
  .loader-inner{gap:12px;padding:16px;transform:scale(.82)}
  .crown{width:72px;height:48px}
  .loader-name{font-size:clamp(1.3rem,5.5vw,1.8rem);gap:.35em;letter-spacing:.32em;text-indent:.32em}
  .loader-name i{width:22px}
  .loader-sub{font-size:.6rem;letter-spacing:.28em}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.2s !important}
  .rise{opacity:1;transform:none}
}

/* ---------- short screens (small phones / landscape) ---------- */
@media (max-height:720px){
  .slide-body{padding:70px 0 50px}
  .phone-big{font-size:clamp(2rem,8vw,3.6rem)}
  .info-grid{margin-top:24px;padding-top:18px;gap:16px}
  .info-grid p{font-size:.84rem;line-height:1.55}
  .footnote{margin-top:20px}
  .hero-line{margin-top:12px;font-size:.92rem}
  .hero-actions{margin-top:18px}
  .card{grid-template-rows:150px 1fr}
  .title .script{font-size:clamp(2.6rem,8vw,4rem)}
}
.footnote{padding:0 64px}
