
/* =========================================================================
   مطعم الأصالة — FLAGSHIP Luxury Arabic Restaurant Template
   Single file · RTL · Dark-first · Vanilla JS only · Zero frameworks
   --------------------------------------------------------------------------
   TABLE OF CONTENTS
   1.  Design tokens .......... color · type · spacing · radius · shadow · motion
   2.  Reset & base
   3.  Primitives ............ container · section · eyebrow · divider · btn · glass
   4.  Reveal / motion utilities
   5.  Scroll progress + announcement bar
   6.  Header / Nav
   7.  Hero (cinematic)
   8.  Stats / Trust band
   9.  Signature dishes (3D tilt cards)
   10. Menu experience (tabs)
   11. Story (timeline)
   12. Chef section
   13. Testimonials
   14. Gallery (lightbox)
   15. Reservation
   16. Contact
   17. Footer
   18. Back-to-top · utilities
   19. Responsive
   20. Reduced motion / print
   ========================================================================= */

/* ============================ 1. DESIGN TOKENS ========================== */
:root{
  /* ---- Color · DARK (default) — brief palette: #0A0A0A / #121212 / #171717 + gold #D4AF37 ---- */
  --c-bg:        #0A0A0A;
  --c-bg-2:      #0E0D0C;
  --c-surface:   #121212;
  --c-surface-2: #171717;
  --c-surface-3: #1E1B16;
  --c-glass:     rgba(18, 18, 18, 0.55);
  --c-glass-2:   rgba(28, 25, 19, 0.66);
  --c-glass-brd: rgba(212, 175, 55, 0.22);

  --c-text:   #F4EEDF;
  --c-text-2: #C8BDA6;
  --c-text-3: #8B826E;

  --c-gold:        #D4AF37;
  --c-gold-bright: #EFD27A;
  --c-gold-deep:   #9C7A24;
  --c-emerald:     #3C7A60;   /* secondary, used sparingly */
  --c-pom:         #8E3B3B;   /* heat accent, used sparingly */

  --c-border:        rgba(212, 175, 55, 0.14);
  --c-border-strong: rgba(212, 175, 55, 0.40);
  --c-hairline:      rgba(244, 238, 223, 0.08);

  /* ---- Premium gradients & glows ---- */
  --grad-gold:      linear-gradient(135deg, #EFD27A 0%, #D4AF37 46%, #9C7A24 100%);
  --grad-gold-soft: linear-gradient(135deg, rgba(239,210,122,.20), rgba(156,122,36,.05));
  --grad-text:      linear-gradient(100deg, #F8EFCF 0%, #EAC85F 45%, #C99B2E 100%);
  --grad-sheen:     linear-gradient(115deg, transparent 0%, rgba(255,255,255,.22) 48%, rgba(255,255,255,.05) 52%, transparent 100%);
  --grad-page:      radial-gradient(1200px 820px at 84% -8%, rgba(212,175,55,.12), transparent 55%),
                    radial-gradient(1000px 720px at -4% 6%, rgba(60,122,96,.07), transparent 55%),
                    radial-gradient(900px 700px at 50% 118%, rgba(212,175,55,.06), transparent 60%);
  --glow-gold:      0 0 0 1px rgba(212,175,55,.20), 0 0 38px rgba(212,175,55,.22);
  --plate-glow:     rgba(212,175,55,.20);

  /* ---- Spacing · strict 8px system ---- */
  --sp-0:4px; --sp-1:8px; --sp-2:16px; --sp-3:24px; --sp-4:32px; --sp-5:40px;
  --sp-6:48px; --sp-8:64px; --sp-10:80px; --sp-12:96px; --sp-16:128px; --sp-20:160px;

  /* ---- Radius ---- */
  --r-sm:10px; --r-md:18px; --r-lg:28px; --r-xl:40px; --r-full:999px;

  /* ---- Shadow elevation ---- */
  --sh-low:   0 2px 10px rgba(0,0,0,.4);
  --sh-med:   0 16px 40px rgba(0,0,0,.5);
  --sh-high:  0 38px 90px rgba(0,0,0,.62);
  --sh-gold:  0 18px 56px rgba(212,175,55,.22);
  --sh-inset: inset 0 1px 0 rgba(255,255,255,.06);

  /* ---- Typography ---- */
  --ff-display: "Aref Ruqaa", "Amiri", "Times New Roman", serif;
  --ff-head:    "El Messiri", "Tajawal", system-ui, sans-serif;
  --ff-body:    "Tajawal", system-ui, "Segoe UI", "Geeza Pro", sans-serif;

  --fs-display: clamp(3.2rem, 8vw, 7rem);
  --fs-h1: clamp(2.5rem, 5.6vw, 4.6rem);
  --fs-h2: clamp(2.05rem, 4.2vw, 3.3rem);
  --fs-h3: clamp(1.5rem, 2.7vw, 2.1rem);
  --fs-h4: clamp(1.2rem, 1.9vw, 1.5rem);
  --fs-h5: 1.14rem;
  --fs-h6: 0.95rem;
  --fs-body: 1.06rem;
  --fs-sm: 0.9rem;
  --fs-xs: 0.76rem;

  --lh-tight: 1.14;
  --lh: 1.9;
  --ls-wide: .22em;

  /* ---- Motion ---- */
  --ts-fast: .18s;
  --ts:      .36s;
  --ts-slow: .8s;
  --ease:        cubic-bezier(.22,.61,.36,1);
  --ease-out:    cubic-bezier(.16,1,.3,1);
  --ease-bounce: cubic-bezier(.34,1.56,.64,1);

  /* ---- Layout ---- */
  --w-max: 1280px;
  --w-text: 720px;
  --pad-x: clamp(20px, 5vw, 72px);

  /* ---- z-index scale ---- */
  --z-base:1; --z-deco:2; --z-top:80; --z-header:100; --z-bar:105; --z-menu:200; --z-modal:300;
}

/* ---- LIGHT THEME OVERRIDES ---- */
[data-theme="light"]{
  --c-bg:        #F7F3EA;
  --c-bg-2:      #F1EBDD;
  --c-surface:   #FFFFFF;
  --c-surface-2: #FBF7EE;
  --c-surface-3: #F3ECDB;
  --c-glass:     rgba(255, 253, 247, 0.7);
  --c-glass-2:   rgba(255, 252, 244, 0.8);
  --c-glass-brd: rgba(156, 122, 36, 0.26);

  --c-text:   #211B12;
  --c-text-2: #5C5240;
  --c-text-3: #8A7F69;

  --c-gold:        #A9821E;
  --c-gold-bright: #C99B2E;
  --c-gold-deep:   #7A5E16;

  --c-border:        rgba(156, 122, 36, 0.22);
  --c-border-strong: rgba(156, 122, 36, 0.5);
  --c-hairline:      rgba(33, 27, 18, 0.1);

  --grad-text: linear-gradient(100deg, #8A6A18 0%, #B8901F 50%, #6E541A 100%);
  --grad-page: radial-gradient(1200px 820px at 84% -8%, rgba(169,130,30,.12), transparent 55%),
               radial-gradient(1000px 720px at -4% 6%, rgba(60,122,96,.06), transparent 55%);
  --grad-sheen: linear-gradient(115deg, transparent 0%, rgba(255,255,255,.5) 48%, rgba(255,255,255,.1) 52%, transparent 100%);
  --glow-gold: 0 0 0 1px rgba(156,122,36,.22), 0 0 30px rgba(156,122,36,.16);

  --sh-low:   0 2px 10px rgba(80,60,10,.08);
  --sh-med:   0 16px 40px rgba(80,60,10,.12);
  --sh-high:  0 38px 90px rgba(80,60,10,.18);
  --sh-gold:  0 18px 56px rgba(169,130,30,.20);
  --sh-inset: inset 0 1px 0 rgba(255,255,255,.6);

  --plate-glow: rgba(169,130,30,.18);
}

/* ============================ 2. RESET & BASE ========================== */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  font-family:var(--ff-body);
  font-size:var(--fs-body);
  line-height:var(--lh);
  color:var(--c-text);
  background:var(--c-bg);
  background-image:var(--grad-page);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  transition:background-color var(--ts), color var(--ts);
}

h1,h2,h3,h4,h5,h6{ font-family:var(--ff-head); font-weight:600; line-height:var(--lh-tight); }
a{ color:inherit; text-decoration:none; }
img,svg{ display:block; max-width:100%; }
button,input,select,textarea{ font:inherit; color:inherit; }
button{ cursor:pointer; background:none; border:none; }
ul{ list-style:none; }
:focus-visible{ outline:2px solid var(--c-gold); outline-offset:3px; border-radius:4px; }
::selection{ background:rgba(212,175,55,.3); color:var(--c-text); }

/* Custom scrollbar */
*{ scrollbar-width:thin; scrollbar-color:var(--c-gold-deep) transparent; }
*::-webkit-scrollbar{ width:10px; height:10px; }
*::-webkit-scrollbar-thumb{ background:var(--c-gold-deep); border-radius:99px; border:2px solid var(--c-bg); }

.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; }
.skip-link{ position:fixed; inset-inline-start:50%; top:-60px; transform:translateX(50%); background:var(--c-gold); color:#1a1206; padding:10px 20px; border-radius:0 0 var(--r-sm) var(--r-sm); font-weight:700; z-index:var(--z-modal); transition:top var(--ts); }
.skip-link:focus{ top:0; }

/* ===================== 3. PRIMITIVES =================================== */
.container{ width:100%; max-width:var(--w-max); margin-inline:auto; padding-inline:var(--pad-x); }

.section{ position:relative; padding-block:clamp(72px, 11vw, 152px); }
.section--tint{ background:linear-gradient(180deg, transparent, var(--c-bg-2) 12%, var(--c-bg-2) 88%, transparent); }
.section__deco{ position:absolute; inset:0; pointer-events:none; overflow:hidden; z-index:var(--z-base); }

/* Eyebrow label */
.eyebrow{
  display:inline-flex; align-items:center; gap:var(--sp-1);
  font-family:var(--ff-head); font-size:var(--fs-xs); font-weight:600;
  letter-spacing:var(--ls-wide); text-transform:uppercase;
  color:var(--c-gold-bright);
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--grad-gold); }
.eyebrow--center::after{ content:""; width:26px; height:1px; background:var(--grad-gold); }

/* Section heading block */
.section-head{ max-width:680px; margin-bottom:clamp(40px, 6vw, 72px); }
.section-head--center{ margin-inline:auto; text-align:center; }
.section-title{ font-family:var(--ff-display); font-size:var(--fs-h2); margin-block:var(--sp-2) var(--sp-2); line-height:1.18; }
.section-title em{ font-style:normal; background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; }
.section-sub{ color:var(--c-text-2); font-size:var(--fs-h5); font-weight:300; line-height:1.8; }

/* Ornamental divider — eight-point star between hairlines */
.divider{ display:flex; align-items:center; justify-content:center; gap:var(--sp-2); color:var(--c-gold); margin-block:var(--sp-3); }
.divider::before,.divider::after{ content:""; height:1px; width:min(120px, 22vw); background:linear-gradient(90deg, transparent, var(--c-border-strong)); }
.divider svg{ width:18px; height:18px; opacity:.85; }

/* Buttons */
.btn{
  --btn-pad: 15px 30px;
  position:relative; display:inline-flex; align-items:center; justify-content:center; gap:var(--sp-1);
  padding:var(--btn-pad); border-radius:var(--r-full);
  font-family:var(--ff-head); font-weight:600; font-size:var(--fs-sm); letter-spacing:.02em;
  cursor:pointer; overflow:hidden; isolation:isolate; white-space:nowrap;
  transition:transform var(--ts) var(--ease-out), box-shadow var(--ts), color var(--ts), border-color var(--ts);
  will-change:transform;
}
.btn svg{ width:18px; height:18px; }
.btn--primary{ color:#1a1206; background:var(--grad-gold); box-shadow:var(--sh-gold), var(--sh-inset); }
.btn--primary::after{ /* moving sheen */
  content:""; position:absolute; inset:0; z-index:-1; transform:translateX(-130%);
  background:var(--grad-sheen); transition:transform .7s var(--ease-out);
}
.btn--primary:hover{ box-shadow:0 22px 64px rgba(212,175,55,.34), var(--sh-inset); }
.btn--primary:hover::after{ transform:translateX(130%); }
.btn--ghost{ color:var(--c-text); background:transparent; border:1px solid var(--c-border-strong); }
.btn--ghost::before{ content:""; position:absolute; inset:0; z-index:-1; background:var(--grad-gold-soft); opacity:0; transition:opacity var(--ts); }
.btn--ghost:hover{ border-color:var(--c-gold); color:var(--c-gold-bright); }
.btn--ghost:hover::before{ opacity:1; }
.btn--block{ width:100%; }
.btn:active{ transform:scale(.97); }

/* Glass surface */
.glass{
  background:var(--c-glass); backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  border:1px solid var(--c-glass-brd); border-radius:var(--r-lg);
  box-shadow:var(--sh-med), var(--sh-inset);
}

/* Glow-border card frame (premium soft glowing border) */
.glow-frame{ position:relative; border-radius:var(--r-lg); }
.glow-frame::before{
  content:""; position:absolute; inset:0; padding:1px; border-radius:inherit;
  background:linear-gradient(140deg, var(--c-border-strong), transparent 40%, transparent 60%, var(--c-border-strong));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none;
  transition:opacity var(--ts); 
}

/* Pattern overlay — girih lattice (data-URI SVG) */
.pattern-bg{
  position:absolute; inset:0; opacity:.05; pointer-events:none; z-index:var(--z-base);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cg fill='none' stroke='%23D4AF37' stroke-width='1'%3E%3Cpath d='M40 0l40 40-40 40L0 40z'/%3E%3Cpath d='M40 16l24 24-24 24-24-24z'/%3E%3Ccircle cx='40' cy='40' r='6'/%3E%3C/g%3E%3C/svg%3E");
  background-size:80px 80px;
}

/* Film grain */
.grain{ position:fixed; inset:0; z-index:var(--z-deco); pointer-events:none; opacity:.04; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

/* ===================== 4. REVEAL / MOTION UTILITIES =================== */
[data-reveal]{ opacity:0; transform:translateY(34px); filter:blur(8px);
  transition:opacity var(--ts-slow) var(--ease-out), transform var(--ts-slow) var(--ease-out), filter var(--ts-slow) var(--ease-out);
  transition-delay:var(--reveal-delay, 0s); will-change:opacity, transform; }
[data-reveal="scale"]{ transform:scale(.92); }
[data-reveal="right"]{ transform:translateX(40px); }
[data-reveal="left"]{ transform:translateX(-40px); }
[data-reveal].is-in{ opacity:1; transform:none; filter:blur(0); }
@media (prefers-reduced-motion: reduce){
  [data-reveal]{ opacity:1 !important; transform:none !important; filter:none !important; }
}

/* Tilt cards (3D) */
.tilt{ transform-style:preserve-3d; transition:transform var(--ts) var(--ease-out); will-change:transform; }
.tilt__inner{ transform:translateZ(40px); }

/* ===================== 5. SCROLL PROGRESS + ANNOUNCE BAR ============== */
.progress{ position:fixed; inset-block-start:0; inset-inline:0; height:3px; z-index:var(--z-bar); transform-origin:right; transform:scaleX(0); background:var(--grad-gold); box-shadow:0 0 12px rgba(212,175,55,.6); }

.announce{ position:relative; z-index:var(--z-bar); background:linear-gradient(90deg, var(--c-surface-2), var(--c-surface)); border-bottom:1px solid var(--c-hairline); overflow:hidden; }
.announce__track{ display:flex; gap:var(--sp-8); align-items:center; white-space:nowrap; padding-block:9px; font-size:var(--fs-xs); letter-spacing:.12em; color:var(--c-text-2); animation:marquee 32s linear infinite; }
.announce__track span{ display:inline-flex; align-items:center; gap:var(--sp-2); }
.announce__track b{ color:var(--c-gold-bright); font-weight:600; }
.announce:hover .announce__track{ animation-play-state:paused; }
@keyframes marquee{ from{ transform:translateX(0); } to{ transform:translateX(50%); } }


/* ===================== 6. HEADER / NAV ================================ */
.header{ position:sticky; inset-block-start:0; z-index:var(--z-header); transition:background var(--ts), box-shadow var(--ts), border-color var(--ts), padding var(--ts); border-bottom:1px solid transparent; }
.header.is-stuck{ background:var(--c-glass); backdrop-filter:blur(22px) saturate(150%); -webkit-backdrop-filter:blur(22px) saturate(150%); border-bottom-color:var(--c-hairline); box-shadow:var(--sh-low); }
.nav{ display:flex; align-items:center; justify-content:space-between; gap:var(--sp-3); padding-block:18px; transition:padding var(--ts); }
.header.is-stuck .nav{ padding-block:12px; }

.brand{ display:inline-flex; align-items:center; gap:var(--sp-2); }
.brand__mark{ width:42px; height:42px; flex:none; filter:drop-shadow(0 4px 12px rgba(212,175,55,.3)); }
.brand__name{ display:flex; flex-direction:column; line-height:1.1; }
.brand__name b{ font-family:var(--ff-display); font-size:1.3rem; font-weight:700; letter-spacing:.01em; }
.brand__name span{ font-size:.62rem; letter-spacing:.42em; color:var(--c-text-3); text-transform:uppercase; }

.nav__list{ display:flex; align-items:center; gap:var(--sp-1); position:relative; }
.nav__link{ position:relative; padding:9px 15px; font-family:var(--ff-head); font-size:.96rem; font-weight:500; color:var(--c-text-2); border-radius:var(--r-full); transition:color var(--ts); }
.nav__link::after{ content:""; position:absolute; inset-block-end:2px; inset-inline:15px; height:2px; background:var(--grad-gold); border-radius:2px; transform:scaleX(0); transform-origin:center; transition:transform var(--ts) var(--ease-out); }
.nav__link:hover{ color:var(--c-text); }
.nav__link.is-active{ color:var(--c-gold-bright); }
.nav__link.is-active::after{ transform:scaleX(1); }

.nav__actions{ display:flex; align-items:center; gap:var(--sp-1); }
.icon-btn{ display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; border-radius:var(--r-full); border:1px solid var(--c-border); color:var(--c-text-2); transition:color var(--ts), border-color var(--ts), background var(--ts), transform var(--ts); }
.icon-btn:hover{ color:var(--c-gold-bright); border-color:var(--c-border-strong); background:var(--grad-gold-soft); transform:translateY(-2px); }
.icon-btn svg{ width:20px; height:20px; }
.theme-toggle .moon{ display:none; }
[data-theme="light"] .theme-toggle .sun{ display:none; }
[data-theme="light"] .theme-toggle .moon{ display:block; }
.nav__cta{ display:inline-flex; }
.burger{ display:none; }

@media (max-width:1024px){
  .nav__list, .nav__cta{ display:none; }
  .burger{ display:inline-flex; }
}

/* Mobile drawer */
.drawer{ position:fixed; inset:0; z-index:var(--z-menu); visibility:hidden; }
.drawer.is-open{ visibility:visible; }
.drawer__scrim{ position:absolute; inset:0; background:rgba(0,0,0,.6); backdrop-filter:blur(4px); opacity:0; transition:opacity var(--ts); }
.drawer.is-open .drawer__scrim{ opacity:1; }
.drawer__panel{ position:absolute; inset-block:0; inset-inline-end:0; width:min(360px, 86vw); background:var(--c-surface); border-inline-start:1px solid var(--c-border); box-shadow:var(--sh-high); padding:var(--sp-5) var(--sp-4); transform:translateX(100%); transition:transform var(--ts-slow) var(--ease-out); display:flex; flex-direction:column; gap:var(--sp-2); overflow-y:auto; }
[dir="rtl"] .drawer__panel{ transform:translateX(-100%); }
.drawer.is-open .drawer__panel{ transform:none; }
.drawer__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:var(--sp-3); }
.drawer__link{ padding:14px 16px; border-radius:var(--r-md); font-family:var(--ff-head); font-size:1.1rem; color:var(--c-text); border:1px solid transparent; transition:background var(--ts), border-color var(--ts), padding-inline-start var(--ts); }
.drawer__link:hover, .drawer__link.is-active{ background:var(--grad-gold-soft); border-color:var(--c-border); color:var(--c-gold-bright); padding-inline-start:24px; }
.drawer .btn{ margin-top:var(--sp-2); }

/* ===================== 7. HERO ======================================= */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; padding-block:clamp(96px,16vh,180px) var(--sp-10); overflow:hidden; }
.hero__bg{ position:absolute; inset:0; z-index:var(--z-base); pointer-events:none; }
.hero__glow{ position:absolute; border-radius:50%; filter:blur(80px); opacity:.55; will-change:transform; }
.hero__glow--1{ width:540px; height:540px; inset-block-start:-8%; inset-inline-end:-6%; background:radial-gradient(circle, rgba(212,175,55,.4), transparent 70%); }
.hero__glow--2{ width:460px; height:460px; inset-block-end:-12%; inset-inline-start:-8%; background:radial-gradient(circle, rgba(60,122,96,.28), transparent 70%); }
.hero__grid{ position:relative; z-index:var(--z-deco); display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(32px,6vw,80px); align-items:center; width:100%; }

.hero__eyebrow{ margin-bottom:var(--sp-3); }
.hero__title{ font-family:var(--ff-display); font-size:var(--fs-display); line-height:1.05; margin-bottom:var(--sp-3); }
.hero__title .ln{ display:block; overflow:visible; padding-bottom:.12em; }
.hero__title .ln > span{ display:block; transform:translateY(110%); animation:riseIn 1s var(--ease-out) forwards; }
.hero__title .ln:nth-child(2) > span{ animation-delay:.12s; }
.hero__title em{ font-style:normal; background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; }
@keyframes riseIn{ to{ transform:none; } }
.hero__lead{ max-width:46ch; font-size:var(--fs-h5); font-weight:300; color:var(--c-text-2); line-height:1.85; margin-bottom:var(--sp-5); opacity:0; animation:fadeUp .9s var(--ease-out) .5s forwards; }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(20px); } to{ opacity:1; transform:none; } }
.hero__cta{ display:flex; flex-wrap:wrap; gap:var(--sp-2); margin-bottom:var(--sp-6); opacity:0; animation:fadeUp .9s var(--ease-out) .66s forwards; }
.hero__meta{ display:flex; flex-wrap:wrap; gap:var(--sp-4); opacity:0; animation:fadeUp .9s var(--ease-out) .8s forwards; }
.hero__meta-item{ display:flex; flex-direction:column; gap:2px; }
.hero__meta-item b{ font-family:var(--ff-display); font-size:1.7rem; color:var(--c-gold-bright); line-height:1; }
.hero__meta-item span{ font-size:var(--fs-xs); letter-spacing:.12em; color:var(--c-text-3); }
.hero__meta-sep{ width:1px; align-self:stretch; background:var(--c-hairline); }

/* Arch-framed centerpiece */
.arch{ position:relative; aspect-ratio:3/4; max-width:420px; margin-inline:auto; width:100%; opacity:0; animation:fadeUp 1.1s var(--ease-out) .4s forwards; }
.arch__plate{ position:absolute; inset:0; background:radial-gradient(circle at 50% 42%, var(--c-surface-3), var(--c-bg)); clip-path:url(#archClip); border:1px solid var(--c-border-strong); box-shadow:inset 0 0 80px rgba(0,0,0,.6); }
[data-theme="light"] .arch__plate{ background:radial-gradient(circle at 50% 42%, #E8DFC8, #D4C9A8); box-shadow:inset 0 0 60px rgba(120,90,20,.15); }
.arch__pattern{ position:absolute; inset:0; clip-path:url(#archClip); opacity:.16; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='104' viewBox='0 0 60 104'%3E%3Cg fill='none' stroke='%23D4AF37' stroke-width='1'%3E%3Cpath d='M30 2l28 16v36L30 70 2 54V18z'/%3E%3Cpath d='M30 20l14 8v18l-14 8-14-8V28z'/%3E%3C/g%3E%3C/svg%3E"); background-size:60px 104px; }
.arch__centerpiece{ position:absolute; inset-block:8%; inset-inline:0; margin-inline:auto; height:84%; filter:drop-shadow(0 20px 40px rgba(0,0,0,.5)); }
.arch__glow{ position:absolute; inset-block-start:30%; inset-inline:0; margin-inline:auto; width:60%; height:40%; background:radial-gradient(circle, var(--plate-glow), transparent 70%); filter:blur(30px); animation:pulse 4s ease-in-out infinite; }
@keyframes pulse{ 0%,100%{ opacity:.6; transform:scale(1); } 50%{ opacity:1; transform:scale(1.08); } }
.arch__frame{ position:absolute; inset:0; width:100%; height:100%; pointer-events:none; }
.arch__badge{ position:absolute; display:flex; flex-direction:column; align-items:center; justify-content:center; width:108px; height:108px; border-radius:50%; background:var(--c-glass-2); backdrop-filter:blur(10px); border:1px solid var(--c-border-strong); box-shadow:var(--sh-gold); animation:float 5s ease-in-out infinite; }
.arch__badge svg{ width:26px; height:26px; color:var(--c-gold); margin-bottom:4px; }
.arch__badge b{ font-family:var(--ff-display); font-size:1.5rem; color:var(--c-gold-bright); line-height:1; }
.arch__badge span{ font-size:.6rem; letter-spacing:.1em; color:var(--c-text-2); }
.arch__badge--1{ inset-block-start:6%; inset-inline-start:-6%; }
.arch__badge--2{ inset-block-end:8%; inset-inline-end:-8%; animation-delay:1.4s; }
@keyframes float{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-12px); } }

.scroll-hint{ position:absolute; inset-block-end:var(--sp-4); inset-inline-start:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:var(--sp-1); color:var(--c-text-3); font-size:var(--fs-xs); letter-spacing:.16em; opacity:0; animation:fadeUp 1s 1.2s forwards; }
.scroll-hint__mouse{ width:24px; height:38px; border:1.5px solid var(--c-border-strong); border-radius:12px; position:relative; }
.scroll-hint__mouse::after{ content:""; position:absolute; inset-block-start:7px; inset-inline-start:50%; transform:translateX(-50%); width:4px; height:7px; border-radius:2px; background:var(--c-gold); animation:wheel 1.8s ease-in-out infinite; }
@keyframes wheel{ 0%{ opacity:0; transform:translate(-50%,0); } 40%{ opacity:1; } 100%{ opacity:0; transform:translate(-50%,10px); } }

/* ===================== 8. STATS / TRUST BAND ========================= */
.stats{ position:relative; padding-block:clamp(48px,7vw,88px); border-block:1px solid var(--c-hairline); background:linear-gradient(180deg, var(--c-bg-2), var(--c-surface)); overflow:hidden; }
.stats__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:var(--sp-2); position:relative; z-index:var(--z-deco); }
.stat{ text-align:center; padding:var(--sp-3) var(--sp-2); position:relative; }
.stat:not(:last-child)::after{ content:""; position:absolute; inset-block:18%; inset-inline-end:0; width:1px; background:var(--c-hairline); }
.stat__num{ font-family:var(--ff-display); font-size:clamp(2.4rem,4.5vw,3.6rem); background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; line-height:1; }
.stat__num small{ font-size:.5em; -webkit-text-fill-color:var(--c-gold); }
.stat__label{ margin-top:var(--sp-1); font-size:var(--fs-sm); color:var(--c-text-2); letter-spacing:.04em; }

.awards{ margin-top:var(--sp-6); padding-top:var(--sp-5); border-top:1px solid var(--c-hairline); }
.awards__title{ text-align:center; font-size:var(--fs-xs); letter-spacing:.3em; color:var(--c-text-3); text-transform:uppercase; margin-bottom:var(--sp-3); }
.awards__row{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:clamp(24px,5vw,64px); }
.award{ display:inline-flex; align-items:center; gap:var(--sp-1); color:var(--c-text-2); font-family:var(--ff-head); font-size:.95rem; opacity:.78; transition:opacity var(--ts), color var(--ts); }
.award:hover{ opacity:1; color:var(--c-gold-bright); }
.award svg{ width:26px; height:26px; color:var(--c-gold); }

/* ===================== 9. SIGNATURE DISHES =========================== */
.dishes__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--sp-3); perspective:1400px; }
.dish{ position:relative; padding:var(--sp-4) var(--sp-3) var(--sp-3); border-radius:var(--r-lg); background:linear-gradient(180deg, var(--c-surface-2), var(--c-surface)); border:1px solid var(--c-border); overflow:hidden; }
.dish::before{ content:""; position:absolute; inset:0; border-radius:inherit; padding:1px; background:linear-gradient(140deg, var(--dish-a, var(--c-gold)), transparent 45%, transparent 55%, var(--dish-b, var(--c-gold-deep))); -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude; opacity:0; transition:opacity var(--ts); pointer-events:none; }
.dish:hover::before{ opacity:1; }
.dish__rank{ position:absolute; inset-block-start:var(--sp-3); inset-inline-start:var(--sp-3); font-family:var(--ff-display); font-size:1.1rem; color:var(--c-text-3); }
.dish__heat{ position:absolute; inset-block-start:var(--sp-3); inset-inline-end:var(--sp-3); display:inline-flex; align-items:center; gap:6px; font-size:var(--fs-xs); font-weight:600; color:var(--c-gold-bright); padding:5px 11px; border-radius:var(--r-full); background:var(--grad-gold-soft); border:1px solid var(--c-border); }
.dish__heat svg{ width:13px; height:13px; }
.dish__plate{ position:relative; width:170px; height:170px; margin:var(--sp-3) auto var(--sp-3); border-radius:50%; display:grid; place-items:center; background:radial-gradient(circle at 38% 32%, var(--dish-a,#3a2f17), var(--dish-b,#1a140a)); box-shadow:inset 0 0 0 6px rgba(255,255,255,.04), inset 0 0 0 7px var(--c-border-strong), 0 24px 50px rgba(0,0,0,.5); transition:transform var(--ts) var(--ease-out); }
.dish:hover .dish__plate{ transform:translateZ(30px) scale(1.04); }
.dish__plate::after{ content:""; position:absolute; inset:18px; border-radius:50%; border:1px dashed rgba(212,175,55,.35); }
.dish__plate svg{ width:74px; height:74px; }
.dish__glow{ position:absolute; inset:0; border-radius:50%; background:radial-gradient(circle, var(--plate-glow), transparent 70%); filter:blur(18px); opacity:0; transition:opacity var(--ts); }
.dish:hover .dish__glow{ opacity:1; }
.dish__name{ font-family:var(--ff-display); font-size:var(--fs-h4); text-align:center; }
.dish__desc{ text-align:center; color:var(--c-text-2); font-size:var(--fs-sm); line-height:1.7; margin-block:var(--sp-1) var(--sp-3); min-height:3.4em; }
.dish__foot{ display:flex; align-items:center; justify-content:space-between; padding-top:var(--sp-2); border-top:1px solid var(--c-hairline); }
.dish__price{ font-family:var(--ff-display); font-size:1.5rem; color:var(--c-gold-bright); }
.dish__price span{ font-family:var(--ff-body); font-size:.8rem; color:var(--c-text-3); }
.dish__rating{ display:inline-flex; align-items:center; gap:5px; font-size:var(--fs-sm); color:var(--c-text-2); }
.dish__rating svg{ width:15px; height:15px; color:var(--c-gold); }
.dish__add{ display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px; border-radius:var(--r-full); background:var(--grad-gold); color:#1a1206; box-shadow:var(--sh-gold); transition:transform var(--ts) var(--ease-bounce); }
.dish__add:hover{ transform:rotate(90deg) scale(1.08); }
.dish__add svg{ width:18px; height:18px; }

/* ===================== 10. MENU EXPERIENCE =========================== */
.menu__tabs{ display:flex; flex-wrap:wrap; gap:var(--sp-1); justify-content:center; margin-bottom:var(--sp-6); padding:6px; border-radius:var(--r-full); background:var(--c-surface); border:1px solid var(--c-border); width:fit-content; margin-inline:auto; max-width:100%; }
.menu__tab{ display:inline-flex; align-items:center; gap:8px; padding:11px 20px; border-radius:var(--r-full); font-family:var(--ff-head); font-weight:500; font-size:var(--fs-sm); color:var(--c-text-2); white-space:nowrap; transition:color var(--ts), background var(--ts); }
.menu__tab svg{ width:18px; height:18px; }
.menu__tab[aria-selected="true"]{ color:#1a1206; background:var(--grad-gold); box-shadow:var(--sh-gold); }
.menu__panels{ position:relative; max-width:880px; margin-inline:auto; }
.menu__panel{ display:none; animation:panelIn .5s var(--ease-out); }
.menu__panel.is-active{ display:block; }
@keyframes panelIn{ from{ opacity:0; transform:translateY(20px); filter:blur(6px); } to{ opacity:1; transform:none; filter:blur(0); } }
.menu__item{ display:grid; grid-template-columns:1fr auto; align-items:baseline; gap:var(--sp-2); padding:var(--sp-2) 0; border-bottom:1px solid var(--c-hairline); }
.menu__item:hover .menu__item-name{ color:var(--c-gold-bright); }
.menu__item-head{ display:flex; flex-direction:column; gap:4px; min-width:0; }
.menu__item-name{ font-family:var(--ff-head); font-size:var(--fs-h5); font-weight:600; transition:color var(--ts); display:inline-flex; align-items:center; gap:8px; }
.menu__tag{ font-size:.62rem; letter-spacing:.08em; padding:2px 8px; border-radius:var(--r-full); border:1px solid var(--c-border-strong); color:var(--c-gold-bright); }
.menu__item-desc{ font-size:var(--fs-sm); color:var(--c-text-3); line-height:1.6; }
.menu__leader{ flex:1; border-bottom:1px dotted var(--c-text-3); opacity:.4; align-self:center; margin-inline:8px; min-width:18px; }
.menu__price{ font-family:var(--ff-display); font-size:1.25rem; color:var(--c-gold-bright); white-space:nowrap; }
.menu__price span{ font-family:var(--ff-body); font-size:.72rem; color:var(--c-text-3); }
.menu__cta{ text-align:center; margin-top:var(--sp-6); }


/* ===================== 11. STORY (timeline) ========================== */
.story__grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(40px,6vw,80px); align-items:center; }
.story__visual{ position:relative; }
.story__arch{ position:relative; aspect-ratio:3/4; max-width:380px; margin-inline:auto; }
.story__seal{ position:absolute; inset-block-end:-4%; inset-inline-start:-4%; width:128px; height:128px; border-radius:50%; display:grid; place-items:center; text-align:center; background:var(--c-glass-2); backdrop-filter:blur(10px); border:1px solid var(--c-border-strong); box-shadow:var(--sh-gold); }
.story__seal b{ font-family:var(--ff-display); font-size:1.9rem; color:var(--c-gold-bright); line-height:1; }
.story__seal span{ font-size:.62rem; letter-spacing:.14em; color:var(--c-text-2); }
.timeline{ margin-top:var(--sp-5); border-inline-start:1px solid var(--c-border); padding-inline-start:var(--sp-3); display:flex; flex-direction:column; gap:var(--sp-4); }
.tl{ position:relative; }
.tl::before{ content:""; position:absolute; inset-inline-start:calc(-1*var(--sp-3) - 5px); inset-block-start:7px; width:10px; height:10px; border-radius:50%; background:var(--grad-gold); box-shadow:0 0 0 4px var(--c-bg-2), var(--glow-gold); }
.tl__year{ font-family:var(--ff-display); color:var(--c-gold-bright); font-size:1.15rem; }
.tl__title{ font-family:var(--ff-head); font-weight:600; font-size:var(--fs-h5); margin-block:2px 4px; }
.tl__text{ color:var(--c-text-2); font-size:var(--fs-sm); line-height:1.7; }

/* ===================== 12. CHEF SECTION ============================== */
.chef{ position:relative; overflow:hidden; }
.chef__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,88px); align-items:center; }
.chef__portrait{ position:relative; max-width:440px; margin-inline:auto; width:100%; }
.chef__frame{ position:relative; aspect-ratio:4/5; border-radius:var(--r-xl) var(--r-xl) var(--r-full) var(--r-full); overflow:hidden; background:radial-gradient(circle at 50% 24%, var(--c-surface-3), var(--c-bg)); border:1px solid var(--c-border-strong); box-shadow:var(--sh-high); }
.chef__frame .pattern-bg{ opacity:.08; }
.chef__illus{ position:absolute; inset:6%; margin:auto; width:88%; filter:drop-shadow(0 18px 36px rgba(0,0,0,.5)); }
.chef__sign{ position:absolute; inset-block-end:var(--sp-3); inset-inline:0; text-align:center; font-family:var(--ff-display); font-size:1.7rem; color:var(--c-gold-bright); opacity:.92; }
.chef__quote{ font-family:var(--ff-display); font-size:var(--fs-h3); line-height:1.5; margin-block:var(--sp-3) var(--sp-4); }
.chef__quote::before{ content:"”"; color:var(--c-gold); font-size:2.4em; line-height:0; vertical-align:-.4em; margin-inline-end:8px; }
.chef__name{ font-family:var(--ff-head); font-weight:700; font-size:var(--fs-h4); }
.chef__role{ color:var(--c-gold-bright); font-size:var(--fs-sm); letter-spacing:.08em; margin-bottom:var(--sp-3); }
.chef__creds{ display:flex; flex-wrap:wrap; gap:var(--sp-2); }
.cred{ display:inline-flex; align-items:center; gap:8px; padding:9px 15px; border-radius:var(--r-full); background:var(--c-surface-2); border:1px solid var(--c-border); font-size:var(--fs-sm); color:var(--c-text-2); }
.cred svg{ width:16px; height:16px; color:var(--c-gold); }

/* ===================== 13. TESTIMONIALS ============================== */
.tst__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--sp-3); }
.tst{ padding:var(--sp-4); border-radius:var(--r-lg); display:flex; flex-direction:column; gap:var(--sp-2); position:relative; }
.tst__mark{ position:absolute; inset-block-start:var(--sp-2); inset-inline-end:var(--sp-3); font-family:var(--ff-display); font-size:4rem; color:var(--c-border-strong); line-height:1; }
.tst__stars{ display:flex; gap:3px; color:var(--c-gold); }
.tst__stars svg{ width:17px; height:17px; }
.tst__text{ color:var(--c-text); font-size:1.02rem; line-height:1.8; flex:1; }
.tst__author{ display:flex; align-items:center; gap:var(--sp-2); padding-top:var(--sp-2); border-top:1px solid var(--c-hairline); }
.tst__avatar{ width:46px; height:46px; border-radius:50%; flex:none; display:grid; place-items:center; font-family:var(--ff-head); font-weight:700; color:#1a1206; background:var(--grad-gold); }
.tst__meta b{ display:block; font-family:var(--ff-head); font-weight:600; }
.tst__meta span{ font-size:var(--fs-sm); color:var(--c-text-3); }

/* ===================== 14. GALLERY =================================== */
.gallery__grid{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:var(--sp-2); }
.gal{ position:relative; border-radius:var(--r-md); overflow:hidden; border:1px solid var(--c-border); cursor:pointer; background:radial-gradient(circle at 40% 32%, var(--c-surface-3), var(--c-bg)); }
.gal--tall{ grid-row:span 2; }
.gal--wide{ grid-column:span 2; }
.gal__art{ position:absolute; inset:0; display:grid; place-items:center; }
.gal__art svg{ width:46%; height:46%; color:var(--c-gold); opacity:.7; transition:transform var(--ts-slow) var(--ease-out), opacity var(--ts); }
.gal__overlay{ position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end; padding:var(--sp-2); background:linear-gradient(0deg, rgba(8,8,8,.82), transparent 60%); opacity:0; transition:opacity var(--ts); }
.gal__overlay b{ font-family:var(--ff-display); font-size:1.15rem; color:var(--c-text); }
.gal__overlay span{ font-size:var(--fs-xs); color:var(--c-gold-bright); letter-spacing:.1em; }
.gal:hover .gal__overlay{ opacity:1; }
.gal:hover .gal__art svg{ transform:scale(1.12) rotate(-4deg); opacity:1; }
.gal::after{ content:""; position:absolute; inset:0; box-shadow:inset 0 0 0 0 var(--c-gold); transition:box-shadow var(--ts); border-radius:inherit; pointer-events:none; }
.gal:hover::after{ box-shadow:inset 0 0 0 2px var(--c-border-strong); }

/* Lightbox */
.lightbox{ position:fixed; inset:0; z-index:var(--z-modal); display:grid; place-items:center; padding:var(--sp-4); background:rgba(6,6,6,.9); backdrop-filter:blur(8px); visibility:hidden; opacity:0; transition:opacity var(--ts), visibility var(--ts); }
.lightbox.is-open{ visibility:visible; opacity:1; }
.lightbox__stage{ position:relative; width:min(560px,92vw); aspect-ratio:1; border-radius:var(--r-lg); background:radial-gradient(circle at 45% 35%, var(--c-surface-3), var(--c-bg)); border:1px solid var(--c-border-strong); box-shadow:var(--sh-high); display:grid; place-items:center; transform:scale(.92); transition:transform var(--ts) var(--ease-out); }
.lightbox.is-open .lightbox__stage{ transform:none; }
.lightbox__stage svg{ width:46%; height:46%; color:var(--c-gold); }
.lightbox__cap{ position:absolute; inset-block-end:var(--sp-3); inset-inline:0; text-align:center; font-family:var(--ff-display); font-size:1.4rem; color:var(--c-text); }
.lightbox__close,.lightbox__nav{ position:absolute; display:inline-flex; align-items:center; justify-content:center; width:48px; height:48px; border-radius:var(--r-full); background:var(--c-glass-2); border:1px solid var(--c-border-strong); color:var(--c-text); backdrop-filter:blur(8px); transition:background var(--ts), transform var(--ts); }
.lightbox__close{ inset-block-start:-60px; inset-inline-end:0; }
.lightbox__close:hover,.lightbox__nav:hover{ background:var(--grad-gold-soft); color:var(--c-gold-bright); }
.lightbox__nav{ inset-block-start:50%; transform:translateY(-50%); }
.lightbox__nav--prev{ inset-inline-end:-64px; }
.lightbox__nav--next{ inset-inline-start:-64px; }
.lightbox__close svg,.lightbox__nav svg{ width:22px; height:22px; }

/* ===================== 15. RESERVATION =============================== */
.reserve__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(32px,5vw,64px); align-items:stretch; }
.rsv-card{ padding:clamp(28px,4vw,48px); }
.rsv-form{ display:grid; grid-template-columns:1fr 1fr; gap:var(--sp-2) var(--sp-3); }
.field{ display:flex; flex-direction:column; gap:8px; }
.field--full{ grid-column:1/-1; }
.field label{ font-family:var(--ff-head); font-size:var(--fs-sm); font-weight:500; color:var(--c-text-2); }
.field input,.field select,.field textarea{ width:100%; padding:14px 16px; border-radius:var(--r-md); background:var(--c-surface); border:1px solid var(--c-border); color:var(--c-text); transition:border-color var(--ts), box-shadow var(--ts), background var(--ts); }
.field textarea{ resize:vertical; min-height:90px; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--c-gold); box-shadow:0 0 0 4px rgba(212,175,55,.12); }
.field input::placeholder,.field textarea::placeholder{ color:var(--c-text-3); }
.field select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23C8BDA6' stroke-width='2'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:left 16px center; }
.field__err{ font-size:var(--fs-xs); color:#e88; min-height:1em; opacity:0; transition:opacity var(--ts); }
.field.is-invalid input,.field.is-invalid select{ border-color:#c66; }
.field.is-invalid .field__err{ opacity:1; }
.rsv-success{ display:none; flex-direction:column; align-items:center; text-align:center; gap:var(--sp-2); padding:var(--sp-6) var(--sp-3); }
.rsv-success.is-shown{ display:flex; animation:panelIn .5s var(--ease-out); }
.rsv-success .check{ width:72px; height:72px; border-radius:50%; display:grid; place-items:center; background:var(--grad-gold-soft); border:1px solid var(--c-border-strong); color:var(--c-gold-bright); }
.rsv-success .check svg{ width:34px; height:34px; }
.rsv-aside{ display:flex; flex-direction:column; gap:var(--sp-2); justify-content:center; }
.info-row{ display:flex; align-items:flex-start; gap:var(--sp-2); padding:var(--sp-2); border-radius:var(--r-md); transition:background var(--ts); }
.info-row:hover{ background:var(--c-surface-2); }
.info-row__icon{ flex:none; width:46px; height:46px; border-radius:var(--r-md); display:grid; place-items:center; background:var(--grad-gold-soft); border:1px solid var(--c-border); color:var(--c-gold-bright); }
.info-row__icon svg{ width:22px; height:22px; }
.info-row b{ display:block; font-family:var(--ff-head); font-weight:600; margin-bottom:2px; }
.info-row span{ color:var(--c-text-2); font-size:var(--fs-sm); line-height:1.6; }

/* ===================== 16. CONTACT =================================== */
.contact__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,64px); align-items:stretch; }
.map-card{ position:relative; border-radius:var(--r-lg); overflow:hidden; min-height:340px; border:1px solid var(--c-border-strong); background:linear-gradient(135deg, var(--c-surface-2), var(--c-bg)); }
.map-card svg{ position:absolute; inset:0; width:100%; height:100%; }
.map-pin{ position:absolute; inset-block-start:46%; inset-inline-start:52%; transform:translate(-50%,-100%); display:flex; flex-direction:column; align-items:center; }
.map-pin__dot{ width:18px; height:18px; border-radius:50%; background:var(--grad-gold); box-shadow:var(--glow-gold); position:relative; }
.map-pin__dot::after{ content:""; position:absolute; inset:0; border-radius:50%; border:2px solid var(--c-gold); animation:ping 2s ease-out infinite; }
@keyframes ping{ 0%{ transform:scale(1); opacity:.8; } 100%{ transform:scale(3); opacity:0; } }
.map-pin__label{ margin-top:8px; padding:6px 14px; border-radius:var(--r-full); background:var(--c-glass-2); backdrop-filter:blur(8px); border:1px solid var(--c-border-strong); font-family:var(--ff-head); font-size:var(--fs-sm); white-space:nowrap; }
.contact__panel{ display:flex; flex-direction:column; gap:var(--sp-2); justify-content:center; }
.contact__hours{ margin-top:var(--sp-1); padding:var(--sp-3); border-radius:var(--r-md); background:var(--c-surface-2); border:1px solid var(--c-border); }
.contact__hours h4{ font-family:var(--ff-head); font-size:var(--fs-h5); margin-bottom:var(--sp-1); }
.contact__hours .row{ display:flex; justify-content:space-between; padding:7px 0; font-size:var(--fs-sm); color:var(--c-text-2); border-bottom:1px solid var(--c-hairline); }
.contact__hours .row:last-child{ border-bottom:none; }
.contact__hours .row b{ color:var(--c-gold-bright); font-weight:600; }

/* ===================== 17. FOOTER ==================================== */
.footer{ position:relative; border-top:1px solid var(--c-hairline); background:linear-gradient(180deg, var(--c-bg-2), var(--c-bg)); padding-block:clamp(56px,8vw,96px) var(--sp-4); }
.footer__grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.4fr; gap:var(--sp-5); margin-bottom:var(--sp-6); }
.footer__about p{ color:var(--c-text-2); font-size:var(--fs-sm); line-height:1.8; margin-block:var(--sp-2) var(--sp-3); max-width:34ch; }
.footer__social{ display:flex; gap:var(--sp-1); }
.footer h4{ font-family:var(--ff-head); font-size:var(--fs-h5); margin-bottom:var(--sp-3); }
.footer__links{ display:flex; flex-direction:column; gap:var(--sp-1); }
.footer__links a{ color:var(--c-text-2); font-size:var(--fs-sm); transition:color var(--ts), padding-inline-start var(--ts); width:fit-content; }
.footer__links a:hover{ color:var(--c-gold-bright); padding-inline-start:8px; }
.footer__news p{ color:var(--c-text-2); font-size:var(--fs-sm); margin-bottom:var(--sp-2); }
.news-form{ display:flex; gap:8px; }
.news-form input{ flex:1; padding:13px 15px; border-radius:var(--r-md); background:var(--c-surface); border:1px solid var(--c-border); color:var(--c-text); }
.news-form input:focus{ outline:none; border-color:var(--c-gold); }
.news-form button{ flex:none; width:50px; border-radius:var(--r-md); background:var(--grad-gold); color:#1a1206; display:grid; place-items:center; box-shadow:var(--sh-gold); transition:transform var(--ts); }
.news-form button:hover{ transform:translateY(-2px); }
.news-form button svg{ width:20px; height:20px; }
.news-msg{ font-size:var(--fs-xs); color:var(--c-emerald); margin-top:8px; min-height:1em; opacity:0; transition:opacity var(--ts); }
.news-msg.is-shown{ opacity:1; }
.footer__bottom{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:var(--sp-2); padding-top:var(--sp-4); border-top:1px solid var(--c-hairline); color:var(--c-text-3); font-size:var(--fs-sm); }
.footer__bottom a:hover{ color:var(--c-gold-bright); }

/* ===================== 18. BACK TO TOP =============================== */
.to-top{ position:fixed; inset-block-end:var(--sp-3); inset-inline-end:var(--sp-3); z-index:var(--z-top); width:50px; height:50px; border-radius:var(--r-full); background:var(--grad-gold); color:#1a1206; display:grid; place-items:center; box-shadow:var(--sh-gold); opacity:0; visibility:hidden; transform:translateY(16px); transition:opacity var(--ts), transform var(--ts), visibility var(--ts); }
.to-top.is-shown{ opacity:1; visibility:visible; transform:none; }
.to-top:hover{ transform:translateY(-3px); }
.to-top svg{ width:22px; height:22px; }

/* ===================== 19. RESPONSIVE =============================== */
@media (max-width:980px){
  .hero__grid{ grid-template-columns:1fr; text-align:center; }
  .hero__eyebrow,.hero .eyebrow{ justify-content:center; }
  .hero__lead{ margin-inline:auto; }
  .hero__cta,.hero__meta{ justify-content:center; }
  .arch{ order:-1; max-width:320px; }
  .stats__grid{ grid-template-columns:repeat(2,1fr); gap:var(--sp-3); }
  .stat:nth-child(2)::after{ display:none; }
  .dishes__grid{ grid-template-columns:1fr; max-width:440px; margin-inline:auto; }
  .story__grid,.chef__grid,.reserve__grid,.contact__grid{ grid-template-columns:1fr; }
  .chef__portrait,.story__visual{ order:-1; }
  .tst__grid{ grid-template-columns:1fr; max-width:480px; margin-inline:auto; }
  .gallery__grid{ grid-template-columns:repeat(2,1fr); }
  .gal--wide{ grid-column:span 2; }
  .footer__grid{ grid-template-columns:1fr 1fr; }
  .footer__about{ grid-column:1/-1; }
  .lightbox__nav--prev{ inset-inline-end:8px; } .lightbox__nav--next{ inset-inline-start:8px; }
}
@media (max-width:560px){
  .rsv-form{ grid-template-columns:1fr; }
  .menu__item{ grid-template-columns:1fr; }
  .menu__leader{ display:none; }
  .menu__price{ margin-top:4px; }
  .footer__grid{ grid-template-columns:1fr; }
  .gallery__grid{ grid-template-columns:1fr 1fr; grid-auto-rows:150px; }
  .hero__meta-sep{ display:none; }
}
@media (min-width:1600px){
  .gallery__grid{ grid-auto-rows:230px; }
}

/* ===================== 20. REDUCED MOTION / PRINT ==================== */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; }
  .hero__title .ln > span{ transform:none; }
  .arch,.hero__lead,.hero__cta,.hero__meta,.scroll-hint{ opacity:1 !important; animation:none !important; }
}
@media print{
  .header,.to-top,.scroll-hint,.announce,.progress,.drawer,.lightbox{ display:none !important; }
  body{ background:#fff; color:#000; }
}

/* ---- Content column wrappers (intentional rhythm for prose columns) ---- */
.hero__copy{ max-width:620px; }
.story__copy,.chef__copy{ max-width:560px; }
.story__copy .section-head,.chef__copy .section-head{ margin-bottom:var(--sp-3); }
.story__lead,.chef__lead{ color:var(--c-text-2); font-size:var(--fs-h5); font-weight:300; line-height:1.85; }



/* ---- Light mode hero fixes ---- */
[data-theme="light"] .hero__title,
[data-theme="light"] .hero__lead,
[data-theme="light"] .hero__eyebrow{ text-shadow: 0 1px 4px rgba(255,255,255,.4); }
[data-theme="light"] .hero__meta-item b{ color:var(--c-gold); }
[data-theme="light"] .arch__pattern{ opacity:.22; }
[data-theme="light"] .arch__centerpiece path,
[data-theme="light"] .arch__centerpiece circle{ stroke:var(--c-gold-deep); }

/* ---- Hide arch in light mode (looks bad on light bg) ---- */
[data-theme="light"] .arch{ opacity:0; pointer-events:none; }
[data-theme="light"] .hero__grid{ grid-template-columns:1fr; }
[data-theme="light"] .hero__copy{ max-width:720px; }
