/* ===========================================================
   DON CLUB — cafe site
   Signature: the broken concentric "ring" monogram motif
   Palette derived from the brand mark (black / cream / ember-orange)
   =========================================================== */

/* ===== Self-hosted fonts — no internet dependency at load ===== */
@font-face{
  font-family:"Vazirmatn";font-style:normal;font-weight:100 900;font-display:swap;
  src:url("assets/fonts/vazirmatn-arabic.woff2") format("woff2");
  unicode-range:U+0600-06FF,U+0750-077F,U+0870-088E,U+0890-0891,U+0898-08E1,U+08E3-08FF,U+200C-200E,U+2010-2011,U+204F,U+2E41,U+FB50-FDFF,U+FE70-FE74,U+FE76-FEFC;
}
@font-face{
  font-family:"Vazirmatn";font-style:normal;font-weight:100 900;font-display:swap;
  src:url("assets/fonts/vazirmatn-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"Sora";font-style:normal;font-weight:100 800;font-display:swap;
  src:url("assets/fonts/sora-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}

:root{
  --ink:#16130f;        /* warm near-black */
  --ink-2:#211c17;
  --char:#232a30;       /* poster charcoal */
  --cream:#f4efe3;      /* warm paper */
  --cream-2:#ece4d4;
  --paper-line:#ddd2bd;
  --orange:#e1581f;     /* brand vermilion */
  --orange-soft:#ef7a44;
  --ember:#d6232b;      /* red ring / hours disc */
  --gold:#c99a5b;       /* coffee gold */
  --text:#2a241d;       /* body on cream */
  --muted:#7c7263;
  --on-dark:#f3ece0;
  --on-dark-mut:#b7ac9b;

  --maxw:1180px;
  --pad:clamp(18px,5vw,40px);
  --r:18px;             /* card radius */
  --r-sm:12px;
  --shadow:0 18px 50px -22px rgba(20,15,10,.55);
  --shadow-soft:0 10px 30px -18px rgba(20,15,10,.5);

  --fa:"Vazirmatn",system-ui,"Segoe UI",Tahoma,sans-serif;
  --en:"Sora",system-ui,sans-serif;

  --ease:cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  font-family:var(--fa);
  background:var(--cream);
  color:var(--text);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0;line-height:1.2;font-weight:800}

.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}

/* focus + skip */
:focus-visible{outline:3px solid var(--orange);outline-offset:3px;border-radius:6px}
.skip-link{
  position:fixed;top:-60px;inset-inline-start:16px;z-index:200;
  background:var(--ink);color:#fff;padding:10px 16px;border-radius:10px;
  transition:top .2s var(--ease);
}
.skip-link:focus{top:14px}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--orange);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--fa);font-weight:700;font-size:1rem;
  padding:.85em 1.6em;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .2s var(--ease),box-shadow .25s var(--ease),background .2s,color .2s,border-color .2s;
  background:var(--bg);color:var(--fg);
}
.btn--solid{box-shadow:0 12px 26px -12px rgba(225,88,31,.75)}
.btn--solid:hover{transform:translateY(-2px);box-shadow:0 18px 34px -14px rgba(225,88,31,.85)}
.btn--ghost{background:transparent;color:var(--on-dark);border-color:rgba(243,236,224,.4)}
.btn--ghost:hover{border-color:var(--on-dark);transform:translateY(-2px)}
.btn--ghost-dark{color:var(--text);border-color:rgba(42,36,29,.3)}
.btn--ghost-dark:hover{border-color:var(--text);background:rgba(42,36,29,.05)}
.btn--block{width:100%}

/* ---------- loader ---------- */
.loader{
  position:fixed;inset:0;z-index:300;display:grid;place-items:center;
  background:var(--ink);transition:opacity .6s var(--ease),visibility .6s;
}
.loader.is-done{opacity:0;visibility:hidden}
.loader__ring{transform:rotate(-90deg)}
.loader__track{fill:none;stroke:rgba(243,236,224,.12);stroke-width:4}
.loader__spin{
  fill:none;stroke:var(--orange);stroke-width:4;stroke-linecap:round;
  stroke-dasharray:80 184;animation:spin 1s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);transform-origin:center}}
@media (prefers-reduced-motion:reduce){.loader__spin{animation:none;stroke-dasharray:120 144}}

/* ===========================================================
   NAV
   =========================================================== */
.nav{
  position:fixed;inset-block-start:0;inset-inline:0;z-index:120;
  transition:background .3s var(--ease),box-shadow .3s,backdrop-filter .3s;
}
.nav__inner{display:flex;align-items:center;gap:18px;height:74px}
.nav.is-stuck{
  background:rgba(22,19,15,.82);backdrop-filter:blur(14px);
  box-shadow:0 1px 0 rgba(243,236,224,.08),0 14px 40px -28px #000;
}

.brand{display:flex;align-items:center;gap:12px;color:var(--on-dark)}
.brand__chip{
  width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  background:var(--cream);box-shadow:0 4px 14px -6px rgba(0,0,0,.5);overflow:hidden;flex:none;
}
.brand__chip img{width:78%;height:78%;object-fit:contain}
.brand__chip--lg{width:72px;height:72px}
.brand__text{display:flex;flex-direction:column;line-height:1.15}
.brand__fa{font-weight:800;font-size:1.18rem;color:var(--on-dark)}
.brand__en{font-family:var(--en);font-size:.62rem;letter-spacing:.28em;color:var(--orange-soft)}

.nav__links{display:flex;gap:28px;margin-inline-start:auto;font-weight:600}
.nav__links a{color:var(--on-dark);position:relative;padding-block:6px;opacity:.9}
.nav__links a::after{
  content:"";position:absolute;inset-block-end:0;inset-inline-start:0;width:0;height:2px;
  background:var(--orange);transition:width .25s var(--ease);
}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after{width:100%}

.phone-pill{
  display:inline-flex;align-items:center;gap:8px;
  border:1.5px solid rgba(243,236,224,.35);color:var(--on-dark);
  padding:.5em 1em;border-radius:999px;font-weight:700;font-size:.92rem;
  transition:border-color .2s,background .2s,color .2s;
}
.phone-pill svg{color:var(--orange-soft)}
.phone-pill:hover{background:var(--orange);border-color:var(--orange);color:#fff}
.phone-pill:hover svg{color:#fff}

.nav__order{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--orange);color:#fff;font-weight:700;font-size:.92rem;
  padding:.55em 1.15em;border-radius:999px;
  box-shadow:0 10px 22px -12px rgba(225,88,31,.85);
  transition:transform .2s var(--ease),background .2s;
}
.nav__order:hover{background:var(--ember);transform:translateY(-2px)}
.drawer-order{color:var(--orange-soft);font-weight:800}

.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav__toggle span{width:24px;height:2px;background:var(--on-dark);transition:.25s var(--ease)}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav__drawer{
  position:fixed;inset-block-start:74px;inset-inline:0;z-index:115;
  background:rgba(22,19,15,.97);backdrop-filter:blur(14px);
  display:flex;flex-direction:column;padding:8px var(--pad) 22px;
  transform:translateY(-130%);transition:transform .35s var(--ease);
}
.nav__drawer.is-open{transform:translateY(0)}
.nav__drawer a{color:var(--on-dark);font-weight:600;padding:14px 4px;border-bottom:1px solid rgba(243,236,224,.08)}
.nav__drawer .drawer-call{color:var(--orange-soft);font-weight:800;border-bottom:0}

/* ===========================================================
   HERO
   =========================================================== */
.hero{
  position:relative;background:radial-gradient(120% 90% at 80% 0%,#2a2018 0%,var(--ink) 55%);
  color:var(--on-dark);overflow:hidden;padding-block:130px 70px;
}
.hero__rings{position:absolute;inset-block-start:-120px;inset-inline-start:-160px;width:680px;height:680px;pointer-events:none;opacity:.5}
.ring{position:absolute;inset:0;width:100%;height:100%}
.ring circle{fill:none;stroke:var(--orange);stroke-width:1.4}
.ring--outer circle{stroke:rgba(225,88,31,.5);stroke-dasharray:1500;stroke-dashoffset:1500;animation:draw 2.4s var(--ease) .2s forwards}
.ring--mid circle{stroke:rgba(214,35,43,.45);stroke-dasharray:1320;stroke-dashoffset:1320;animation:draw 2.4s var(--ease) .45s forwards}
.ring--dash circle{stroke:rgba(201,154,91,.5);stroke-dasharray:14 22}
.hero__rings .ring--dash{animation:rot 60s linear infinite}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes rot{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){
  .ring--outer circle,.ring--mid circle{animation:none;stroke-dashoffset:0}
  .hero__rings .ring--dash{animation:none}
}

.hero__inner{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}

.eyebrow{
  display:inline-block;font-family:var(--en);letter-spacing:.22em;text-transform:uppercase;
  font-size:.72rem;font-weight:600;color:var(--orange-soft);margin-bottom:18px;
}
.eyebrow--dark{color:var(--orange)}

.hero__title{display:flex;flex-direction:column;margin-bottom:18px}
.hero__title-sm{font-size:clamp(1.2rem,3.5vw,1.7rem);font-weight:500;color:var(--on-dark-mut)}
.hero__title-lg{
  font-size:clamp(3.4rem,11vw,6.6rem);font-weight:900;letter-spacing:-.01em;
  background:linear-gradient(180deg,#fff 0%,#ffd9c4 60%,var(--orange-soft) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;line-height:.95;
}
.hero__lead{font-size:clamp(1rem,2.4vw,1.2rem);color:var(--on-dark-mut);max-width:46ch;margin:0 0 26px}

.hero__cats{list-style:none;display:flex;flex-wrap:wrap;gap:10px;padding:0;margin:0 0 30px}
.hero__cats li{
  font-size:.86rem;font-weight:600;color:var(--on-dark);
  border:1px solid rgba(243,236,224,.22);border-radius:999px;padding:.4em 1em;
  background:rgba(243,236,224,.04);
}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px}

/* hero media */
.hero__media{position:relative;justify-self:center}
.hero__photo{
  position:relative;width:min(420px,80vw);aspect-ratio:1;border-radius:50%;
  overflow:hidden;border:2px solid rgba(201,154,91,.4);
  box-shadow:0 40px 80px -30px #000, inset 0 0 0 12px rgba(22,19,15,.25);
}
.hero__photo img{width:100%;height:100%;object-fit:cover}
.hero__photo::after{
  content:"";position:absolute;inset:-3px;border-radius:50%;
  border:2px dashed rgba(225,88,31,.55);animation:rot 80s linear infinite;
}
@media (prefers-reduced-motion:reduce){.hero__photo::after{animation:none}}

.hours-badge{
  position:absolute;inset-block-end:-6px;inset-inline-start:-14px;
  width:138px;height:138px;border-radius:50%;background:var(--ember);color:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  box-shadow:0 18px 40px -16px rgba(214,35,43,.8);transform:rotate(-6deg);
  border:3px solid rgba(255,255,255,.18);
}
.hours-badge__top{font-weight:800;font-size:.98rem;margin-bottom:4px}
.hours-badge__row{font-size:.82rem;opacity:.95}
.hours-badge__row b{font-weight:700}

.scroll-cue{position:absolute;inset-block-end:22px;inset-inline-start:50%;transform:translateX(50%);width:26px;height:42px;border:2px solid rgba(243,236,224,.4);border-radius:14px;display:grid;justify-items:center;padding-top:7px}
.scroll-cue span{width:4px;height:8px;border-radius:4px;background:var(--orange-soft);animation:cue 1.5s var(--ease) infinite}
@keyframes cue{0%{opacity:0;transform:translateY(-4px)}40%{opacity:1}100%{opacity:0;transform:translateY(10px)}}
@media (prefers-reduced-motion:reduce){.scroll-cue span{animation:none}}

/* ===========================================================
   CATEGORIES
   =========================================================== */
.cats{background:var(--cream);padding-block:clamp(48px,8vw,86px)}
.cats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.cat{text-align:center;padding:8px}
.cat__ring{
  width:84px;height:84px;border-radius:50%;display:grid;place-items:center;margin:0 auto 16px;
  color:var(--orange);background:#fff;
  border:2px solid var(--paper-line);position:relative;
  transition:transform .3s var(--ease),border-color .3s,color .3s;
}
.cat__ring::before{content:"";position:absolute;inset:-7px;border-radius:50%;border:1.5px dashed var(--gold);opacity:.6}
.cat__ring svg{width:38px;height:38px}
.cat:hover .cat__ring{transform:translateY(-4px);border-color:var(--orange);color:var(--ember)}
.cat h3{font-size:1.15rem;margin-bottom:6px}
.cat p{margin:0;color:var(--muted);font-size:.92rem}

/* ===========================================================
   SECTION HEADERS
   =========================================================== */
.section-head{text-align:center;max-width:640px;margin:0 auto clamp(30px,5vw,52px)}
.section-head--light .eyebrow{color:var(--orange-soft)}
.section-head--light .section-title{color:#fff}
.section-title{font-size:clamp(1.9rem,5vw,3rem);letter-spacing:-.01em}
.section-sub{color:var(--muted);margin:14px 0 0;font-size:1.02rem}

/* ===========================================================
   MENU
   =========================================================== */
.menu{background:var(--cream);padding-block:clamp(40px,6vw,70px) clamp(56px,9vw,100px);position:relative}
.menu .section-title{color:var(--ink)}

.filters{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:36px}
.filter{
  font-family:var(--fa);font-weight:600;font-size:.95rem;cursor:pointer;
  padding:.55em 1.25em;border-radius:999px;border:1.5px solid var(--paper-line);
  background:#fff;color:var(--text);transition:all .2s var(--ease);
}
.filter:hover{border-color:var(--orange);color:var(--orange)}
.filter.is-active{background:var(--ink);border-color:var(--ink);color:var(--cream)}

.menu__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:24px}

.card{
  background:#fff;border-radius:var(--r);overflow:hidden;position:relative;
  border:1px solid var(--paper-line);box-shadow:var(--shadow-soft);
  display:flex;flex-direction:column;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card__img{aspect-ratio:4/3;overflow:hidden;background:var(--cream-2)}
.card__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.card:hover .card__img img{transform:scale(1.06)}

.card__tag{
  position:absolute;inset-block-start:12px;inset-inline-start:12px;z-index:2;
  font-size:.72rem;font-weight:700;padding:.35em .8em;border-radius:999px;
  background:var(--ink);color:var(--cream);
}
.card__tag--signature{background:var(--ember);color:#fff;box-shadow:0 8px 18px -8px rgba(214,35,43,.8)}

.card__body{padding:16px 16px 18px;display:flex;flex-direction:column;gap:8px;flex:1}
.card__head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}
.card__head h3{font-size:1.12rem;color:var(--ink)}
.card__en{font-family:var(--en);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);white-space:nowrap}
.card p{margin:0;font-size:.9rem;color:var(--muted);flex:1}

.card__foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:6px}
.price{display:flex;align-items:baseline;gap:5px;color:var(--ink);font-weight:800}
.price__num{font-size:1.18rem}
.price__cur{font-size:.78rem;color:var(--muted);font-weight:600}

.add-btn{
  display:inline-flex;align-items:center;gap:6px;cursor:pointer;
  font-family:var(--fa);font-weight:700;font-size:.9rem;
  background:var(--orange);color:#fff;border:0;border-radius:999px;padding:.5em 1em;
  transition:transform .15s var(--ease),background .2s,box-shadow .2s;
  box-shadow:0 8px 18px -10px rgba(225,88,31,.8);
}
.add-btn svg{width:16px;height:16px}
.add-btn:hover{background:var(--ember);transform:translateY(-2px)}
.add-btn.is-added{background:var(--ink)}

/* in-card stepper (when item already in cart) */
.stepper{display:inline-flex;align-items:center;gap:0;border-radius:999px;background:var(--ink);color:#fff;padding:3px}
.stepper button{width:28px;height:28px;border:0;background:transparent;color:#fff;font-size:1.1rem;cursor:pointer;border-radius:50%;line-height:1;transition:background .15s}
.stepper button:hover{background:rgba(255,255,255,.15)}
.stepper span{min-width:26px;text-align:center;font-weight:800;font-size:.95rem}

.card--feature{grid-column:span 2}
.card--feature .card__img{aspect-ratio:16/10}

.menu__empty{text-align:center;color:var(--muted);padding:30px 0}
.menu__note{text-align:center;color:var(--muted);font-size:.9rem;margin-top:34px;max-width:60ch;margin-inline:auto}

/* ===========================================================
   STORY
   =========================================================== */
.story{background:var(--ink);color:var(--on-dark);padding-block:clamp(56px,9vw,110px)}
.story__inner{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(28px,5vw,64px);align-items:center}
.story__media{position:relative}
.story__media img{border-radius:var(--r);aspect-ratio:4/5;object-fit:cover;width:100%;box-shadow:var(--shadow)}
.story__seal{
  position:absolute;inset-block-end:-26px;inset-inline-end:-18px;
  width:96px;height:96px;border-radius:50%;background:var(--cream);
  display:grid;place-items:center;box-shadow:0 18px 40px -16px #000;border:4px solid var(--ink);
}
.story__seal img{width:64%;height:64%;object-fit:contain;border-radius:0;box-shadow:none;aspect-ratio:auto}
.story .section-title{color:#fff}
.story__copy p{color:var(--on-dark-mut);margin:16px 0}
.story__copy .btn{margin-top:14px}

/* ===========================================================
   GALLERY
   =========================================================== */
.gallery{background:var(--char);padding-block:clamp(56px,9vw,100px)}
.gallery__strip{
  display:grid;gap:14px;padding-inline:var(--pad);max-width:1320px;margin-inline:auto;
  grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;grid-auto-flow:dense;
}
.g-item{margin:0;overflow:hidden;border-radius:var(--r-sm);position:relative}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.g-item:hover img{transform:scale(1.08)}
.g-tall{grid-row:span 2}
.g-wide{grid-column:span 2}

/* ===========================================================
   VISIT
   =========================================================== */
.visit{background:var(--ink);color:var(--on-dark);padding-block:clamp(56px,9vw,100px)}
.visit__inner{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(28px,5vw,56px);align-items:stretch}
.visit .section-title{color:#fff}
.visit .eyebrow{color:var(--orange-soft)}

.info-row{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid rgba(243,236,224,.1)}
.info-row__ic{flex:none;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:rgba(225,88,31,.14);color:var(--orange-soft);border:1px solid rgba(225,88,31,.3)}
.info-row h3{font-size:1.05rem;color:#fff;margin-bottom:3px}
.info-row p{margin:0;color:var(--on-dark-mut)}
.info-row a{color:var(--on-dark)}
.info-row a:hover{color:var(--orange-soft)}
.muted{color:var(--on-dark-mut);font-weight:500;font-size:.9em}
.visit__actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px}

.visit__map{border-radius:var(--r);overflow:hidden;min-height:340px;border:1px solid rgba(243,236,224,.12);box-shadow:var(--shadow)}
.visit__map iframe{width:100%;height:100%;min-height:340px;border:0;filter:grayscale(.2) contrast(1.05)}

/* ===========================================================
   FOOTER
   =========================================================== */
.foot{background:#0f0d0a;color:var(--on-dark);padding-block:48px 0}
.foot__inner{display:grid;grid-template-columns:1.2fr 1fr 1.2fr;gap:30px;align-items:start;padding-bottom:34px}
.foot__brand{display:flex;flex-direction:column;gap:14px}
.foot__tag{color:var(--on-dark-mut);margin:0;max-width:28ch}
.foot__links{display:flex;flex-direction:column;gap:10px;font-weight:600}
.foot__links a{color:var(--on-dark-mut);transition:color .2s}
.foot__links a:hover{color:var(--orange-soft)}
.foot__addr{color:var(--on-dark-mut);margin:0;line-height:2}
.foot__addr a{color:var(--on-dark)}
.foot__bar{
  border-top:1px solid rgba(243,236,224,.1);padding:18px var(--pad);
  display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;
  font-size:.85rem;color:var(--on-dark-mut);max-width:var(--maxw);margin-inline:auto;width:100%;
}
.foot__bar span:last-child{font-family:var(--en);letter-spacing:.1em}

/* ===========================================================
   FLOATING ACTIONS
   =========================================================== */
.fab,.cart-fab{
  position:fixed;inset-block-end:22px;z-index:90;border:0;cursor:pointer;
  box-shadow:0 16px 36px -12px rgba(0,0,0,.5);transition:transform .2s var(--ease),box-shadow .2s;
}
.fab{
  inset-inline-end:22px;width:54px;height:54px;border-radius:50%;
  background:var(--ink);color:#fff;display:grid;place-items:center;
}
.fab:hover{transform:translateY(-3px)}
.cart-fab{
  inset-inline-start:22px;display:inline-flex;align-items:center;gap:10px;
  background:var(--orange);color:#fff;border-radius:999px;padding:12px 18px 12px 16px;font-family:var(--fa);font-weight:800;
}
.cart-fab:hover{transform:translateY(-3px)}
.cart-fab__count{
  background:#fff;color:var(--orange);min-width:24px;height:24px;border-radius:999px;
  display:grid;place-items:center;font-size:.85rem;padding-inline:6px;
}
.cart-fab__total{font-size:.92rem}
.cart-fab.bump{animation:bump .35s var(--ease)}
@keyframes bump{0%,100%{transform:scale(1)}40%{transform:scale(1.12)}}

/* ===========================================================
   CART DRAWER
   =========================================================== */
.cart{position:fixed;inset:0;z-index:200;visibility:hidden}
.cart.is-open{visibility:visible}
.cart__scrim{position:absolute;inset:0;background:rgba(15,13,10,.5);opacity:0;transition:opacity .3s}
.cart.is-open .cart__scrim{opacity:1}
.cart__panel{
  position:absolute;inset-block:0;inset-inline-start:0;width:min(420px,92vw);
  background:var(--cream);display:flex;flex-direction:column;
  transform:translateX(-105%);transition:transform .35s var(--ease);box-shadow:var(--shadow);
}
[dir="rtl"] .cart__panel{transform:translateX(-105%)}
.cart.is-open .cart__panel{transform:translateX(0)}
.cart__head{display:flex;align-items:center;justify-content:space-between;padding:20px var(--pad);border-bottom:1px solid var(--paper-line)}
.cart__head h2{font-size:1.3rem;color:var(--ink)}
.cart__x{background:none;border:0;font-size:2rem;line-height:1;cursor:pointer;color:var(--muted);width:40px;height:40px;border-radius:50%}
.cart__x:hover{background:rgba(0,0,0,.05);color:var(--ink)}

.cart__items{flex:1;overflow-y:auto;padding:8px var(--pad)}
.cart__empty{padding:40px var(--pad);text-align:center;color:var(--muted)}

.c-item{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--paper-line);align-items:center}
.c-item__img{width:62px;height:62px;border-radius:12px;object-fit:cover;flex:none}
.c-item__main{flex:1;min-width:0}
.c-item__name{font-weight:700;color:var(--ink);font-size:.98rem}
.c-item__price{color:var(--muted);font-size:.84rem}
.c-item__right{display:flex;flex-direction:column;align-items:flex-end;gap:6px}

.cart__foot{padding:18px var(--pad) calc(18px + env(safe-area-inset-bottom));border-top:1px solid var(--paper-line);background:#fff}
.cart__sum{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px;font-size:1.05rem}
.cart__sum strong{font-size:1.3rem;color:var(--ink)}
.cart__clear{display:block;width:100%;margin-top:10px;background:none;border:0;color:var(--muted);cursor:pointer;font-family:var(--fa);font-size:.88rem;text-decoration:underline}
.cart__clear:hover{color:var(--ember)}

/* ===========================================================
   ORDER MODAL
   =========================================================== */
.modal{position:fixed;inset:0;z-index:210;display:grid;place-items:center;padding:20px;visibility:hidden}
.modal.is-open{visibility:visible}
.modal__scrim{position:absolute;inset:0;background:rgba(15,13,10,.6);opacity:0;transition:opacity .3s}
.modal.is-open .modal__scrim{opacity:1}
.modal__box{
  position:relative;background:var(--cream);border-radius:22px;max-width:460px;width:100%;
  padding:34px clamp(20px,4vw,34px);box-shadow:var(--shadow);text-align:center;
  transform:translateY(16px) scale(.98);opacity:0;transition:transform .3s var(--ease),opacity .3s;
  max-height:92vh;overflow-y:auto;
}
.modal.is-open .modal__box{transform:none;opacity:1}
.modal__x{position:absolute;inset-block-start:12px;inset-inline-end:14px;background:none;border:0;font-size:1.8rem;color:var(--muted);cursor:pointer;line-height:1}
.modal__seal{margin:0 auto 10px}
.modal__box h2{font-size:1.5rem;color:var(--ink)}
.modal__lead{color:var(--muted);margin:10px 0 18px}
.order-summary{
  text-align:start;background:#fff;border:1px solid var(--paper-line);border-radius:14px;
  padding:16px;font-family:var(--fa);font-size:.9rem;line-height:2;white-space:pre-wrap;
  color:var(--text);max-height:230px;overflow-y:auto;margin:0 0 18px;
}
.modal__actions{display:flex;flex-direction:column;gap:10px}
.modal__hint{color:var(--orange);font-weight:700;margin:12px 0 0}

/* ===========================================================
   SCROLL REVEAL
   =========================================================== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width:980px){
  .nav__links{display:none}
  .nav__order{display:none}
  .nav__toggle{display:flex}
  .phone-pill{margin-inline-start:auto}
  .hero__inner{grid-template-columns:1fr;gap:40px;text-align:center}
  .hero__copy{display:flex;flex-direction:column;align-items:center}
  .hero__cats{justify-content:center}
  .hero__cta{justify-content:center}
  .story__inner,.visit__inner{grid-template-columns:1fr}
  .story__media{max-width:420px;margin-inline:auto}
  .visit__map{min-height:300px}
}
@media (max-width:760px){
  .cats__grid{grid-template-columns:repeat(2,1fr);gap:28px 16px}
  .gallery__strip{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .g-wide{grid-column:span 2}
  .foot__inner{grid-template-columns:1fr;gap:24px}
  .card--feature{grid-column:span 1}
  .card--feature .card__img{aspect-ratio:4/3}
}
@media (max-width:520px){
  .phone-pill span{display:none}
  .phone-pill{padding:.55em;border-radius:50%}
  .menu__grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .card__body{padding:12px}
  .card__head h3{font-size:1rem}
  .card__en{display:none}
  .card p{font-size:.82rem}
  .price__num{font-size:1.02rem}
  .add-btn{padding:.45em .7em}
  .hours-badge{width:118px;height:118px;inset-inline-start:-6px}
  .gallery__strip{gap:10px}
}
