/* ============================================================
   Café Hanin — Styles
   Theme derived from the brand logo: soft teal + warm ivory.
   Arabic-first · mobile-first · light mode.
   ============================================================ */

:root{
  /* Brand — sampled from the logo */
  --teal:        #4AAE9E;
  --teal-600:    #3A9588;
  --teal-700:    #2F7C71;
  --teal-800:    #235F57;
  --teal-ink:    #163F3A;
  --teal-soft:   #E7F2EF;
  --teal-mist:   #D6E9E4;

  /* Warm neutrals */
  --ivory:       #FBF8F1;
  --cream:       #F5EEE1;
  --sand:        #EFE6D4;
  --white:       #FFFFFF;
  --gold:        #C49A53;
  --gold-soft:   #E7D4AE;

  --ink:         #20302D;
  --muted:       #6C7E79;
  --line:        #E4E0D4;

  --shadow-sm: 0 2px 10px rgba(22,63,58,.06);
  --shadow-md: 0 14px 40px rgba(22,63,58,.10);
  --shadow-lg: 0 30px 80px rgba(22,63,58,.16);

  --r-sm: 12px;
  --r-md: 18px;
  --r-lg: 28px;
  --r-xl: 40px;

  --ff-body: "Tajawal", system-ui, sans-serif;
  --ff-head: "El Messiri", "Tajawal", sans-serif;
  --ff-calli: "Aref Ruqaa", "El Messiri", serif;
  --ff-latin: "Playfair Display", Georgia, serif;
  --ff-latin-caps: "Cinzel", "Playfair Display", serif;

  --max: 1180px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--ivory);
  line-height:1.75;
  overflow-x:hidden;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
::selection{ background:var(--teal); color:#fff; }

h1,h2,h3{ font-family:var(--ff-head); line-height:1.2; font-weight:700; color:var(--teal-ink); }

/* soft textured background */
body::before{
  content:""; position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(900px 500px at 85% -5%, rgba(74,174,158,.10), transparent 60%),
    radial-gradient(700px 500px at 0% 100%, rgba(196,154,83,.08), transparent 55%),
    var(--ivory);
}

/* ---------- Loader ---------- */
.loader{
  position:fixed; inset:0; z-index:1000; display:grid; place-content:center; gap:18px;
  background:var(--teal); color:#fff; transition:opacity .7s var(--ease), visibility .7s;
}
.loader.is-done{ opacity:0; visibility:hidden; }
.loader__badge{ width:120px; height:150px; margin:0 auto; }
.loader__word{
  font-family:var(--ff-calli); font-size:34px; text-align:center; letter-spacing:1px;
  opacity:0; animation:fadeUp .8s .25s var(--ease) forwards;
}

/* ---------- Nav ---------- */
.nav{
  position:fixed; top:0; inset-inline:0; z-index:100;
  display:flex; align-items:center; gap:18px;
  padding:14px clamp(16px,4vw,40px);
  transition:background .35s var(--ease), box-shadow .35s var(--ease), padding .35s var(--ease);
}
.nav.is-stuck{
  background:rgba(251,248,241,.82); backdrop-filter:blur(14px) saturate(1.2);
  box-shadow:var(--shadow-sm); padding-top:10px; padding-bottom:10px;
}
.nav__brand{ display:flex; align-items:center; gap:10px; margin-inline-end:auto; }
.nav__mark{ width:34px; height:42px; display:inline-block; }
.nav__name{ font-family:var(--ff-calli); font-size:22px; color:var(--teal-ink); transition:color .3s; }
.nav__links{ display:flex; gap:26px; }
.nav__links a{ position:relative; font-weight:500; font-size:15px; color:var(--teal-ink); padding:4px 0; }
.nav__links a::after{
  content:""; position:absolute; inset-inline:0; bottom:-2px; height:2px;
  background:var(--teal); transform:scaleX(0); transform-origin:right; transition:transform .3s var(--ease);
}
.nav__links a:hover::after{ transform:scaleX(1); }
.nav__cta{
  background:var(--teal); color:#fff; padding:9px 20px; border-radius:999px;
  font-weight:700; font-size:14px; box-shadow:0 8px 20px rgba(74,174,158,.35);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.nav__cta:hover{ transform:translateY(-2px); box-shadow:0 12px 26px rgba(74,174,158,.45); }
.nav__burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px; }
.nav__burger span{ width:24px; height:2px; background:var(--teal-ink); border-radius:2px; transition:.3s var(--ease); }
.nav__burger.is-open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__burger.is-open span:nth-child(2){ opacity:0; }
.nav__burger.is-open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

.drawer{
  position:fixed; top:0; inset-inline-start:0; z-index:99; width:min(80vw,320px); height:100dvh;
  background:var(--white); box-shadow:var(--shadow-lg);
  display:flex; flex-direction:column; gap:6px; padding:90px 26px 30px;
  transform:translateX(-105%); transition:transform .4s var(--ease); visibility:hidden;
}
[dir=rtl] .drawer{ inset-inline-start:auto; inset-inline-end:0; transform:translateX(105%); }
.drawer.is-open{ transform:translateX(0); visibility:visible; }
.drawer a{ padding:14px 6px; font-family:var(--ff-head); font-size:19px; color:var(--teal-ink); border-bottom:1px solid var(--line); }
.drawer__call{ margin-top:auto; background:var(--teal-soft); border-radius:var(--r-sm); text-align:center; border:0 !important; color:var(--teal-700) !important; font-weight:700; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:14px 28px; border-radius:999px; font-family:var(--ff-head); font-weight:600; font-size:16px;
  cursor:pointer; border:1.5px solid transparent; transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s;
}
.btn--primary{ background:var(--teal); color:#fff; box-shadow:0 12px 28px rgba(74,174,158,.34); }
.btn--primary:hover{ transform:translateY(-3px); box-shadow:0 18px 40px rgba(74,174,158,.46); }
.btn--ghost{ background:transparent; color:var(--teal-700); border-color:var(--teal-mist); }
.btn--ghost:hover{ background:var(--teal-soft); transform:translateY(-3px); }
.btn--block{ width:100%; }

/* ---------- Shared ---------- */
.kicker{
  font-family:var(--ff-head); color:var(--gold); font-weight:600; letter-spacing:2px;
  font-size:14px; margin-bottom:10px; display:inline-flex; align-items:center; gap:8px;
}
.kicker::before{ content:""; width:26px; height:2px; background:var(--gold); display:inline-block; }
.section-head{ text-align:center; max-width:620px; margin:0 auto 38px; }
.section-head h2{ font-size:clamp(28px,5vw,42px); }
.section-head__sub{ color:var(--muted); margin-top:10px; }

section{ padding:clamp(64px,9vw,120px) clamp(18px,5vw,40px); }
.menu, .booking, .visit, .story{ max-width:var(--max); margin-inline:auto; }

/* ---------- HERO ---------- */
.hero{
  position:relative; min-height:100svh; display:grid; place-items:center; text-align:center;
  padding-top:120px; overflow:hidden;
}
.hero__glow{
  position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(60% 50% at 50% 28%, rgba(74,174,158,.16), transparent 70%),
    radial-gradient(40% 40% at 80% 80%, rgba(196,154,83,.10), transparent 70%);
}
.hero__beans{ position:absolute; inset:0; z-index:-1; pointer-events:none; }
.bean{ position:absolute; color:var(--teal); opacity:.16; animation:float linear infinite; }

.hero__inner{ max-width:780px; padding:0 6px; }
.hero__badge{ width:148px; height:186px; margin:0 auto 26px; opacity:0; }
.reveal-badge.in{ animation:badgeIn 1s var(--ease) forwards; }
.hero__eyebrow{ font-family:var(--ff-head); color:var(--teal-700); letter-spacing:3px; font-size:14px; margin-bottom:14px; }
.hero__title{ font-size:clamp(40px,9vw,74px); line-height:1.08; color:var(--teal-ink); }
.hero__title .line{ display:block; overflow:hidden; }
.hero__title .line span,
.hero__title .line{ display:block; }
.hero__title .line{ transform:translateY(110%); animation:lineUp .9s var(--ease) forwards; }
.hero__title .line:nth-child(1){ animation-delay:.35s; }
.hero__title .line:nth-child(2){ animation-delay:.5s; color:var(--teal); }
.hero__sub{ color:var(--muted); font-size:clamp(16px,2.4vw,19px); max-width:560px; margin:22px auto 30px; opacity:0; animation:fadeUp .9s .75s var(--ease) forwards; }
.hero__actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; opacity:0; animation:fadeUp .9s .9s var(--ease) forwards; }
.hero__scroll{ position:absolute; bottom:26px; inset-inline:0; margin:auto; width:26px; height:42px; border:2px solid var(--teal-mist); border-radius:14px; display:grid; place-items:start center; }
.hero__scroll span{ width:4px; height:8px; background:var(--teal); border-radius:2px; margin-top:7px; animation:scrollDot 1.6s infinite; }

/* ---------- Marquee ---------- */
.marquee{ background:var(--teal); color:#fff; padding:16px 0; overflow:hidden; white-space:nowrap; }
.marquee__track{ display:inline-flex; align-items:center; gap:26px; animation:marquee 26s linear infinite; }
.marquee__track span{ font-family:var(--ff-head); font-size:18px; font-weight:500; }
.marquee__track i{ color:var(--gold-soft); font-style:normal; }

/* ---------- STORY ---------- */
.story{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(28px,6vw,72px); align-items:center; }
.story__media{ display:grid; place-items:center; }
.story__card{
  position:relative; width:min(360px,80vw); aspect-ratio:4/5; border-radius:var(--r-xl);
  background:linear-gradient(150deg, var(--teal) 0%, var(--teal-700) 100%);
  display:grid; place-content:center; gap:14px; color:#fff; box-shadow:var(--shadow-lg); overflow:hidden;
}
.story__card::after{ content:""; position:absolute; inset:14px; border:1.5px solid rgba(255,255,255,.35); border-radius:calc(var(--r-xl) - 12px); }
.story__ring{ position:absolute; width:150%; aspect-ratio:1; border:1px dashed rgba(255,255,255,.25); border-radius:50%; top:-25%; inset-inline-end:-25%; animation:spin 40s linear infinite; }
.story__mark{ width:120px; height:150px; margin:0 auto; }
.story__est{ font-family:var(--ff-latin-caps); letter-spacing:4px; text-align:center; font-size:13px; opacity:.85; }
.story__text h2{ font-size:clamp(26px,4.5vw,40px); margin-bottom:16px; }
.story__text p{ color:var(--muted); margin-bottom:14px; }
.story__stats{ display:flex; gap:22px; flex-wrap:wrap; margin-top:26px; }
.story__stats div{ display:flex; flex-direction:column; }
.story__stats strong{ font-family:var(--ff-head); font-size:26px; color:var(--teal); }
.story__stats span{ font-size:13px; color:var(--muted); }

/* ---------- MENU ---------- */
.menu__bar{ position:sticky; top:64px; z-index:40; display:flex; flex-direction:column; gap:14px; padding:14px; margin-bottom:22px;
  background:rgba(251,248,241,.86); backdrop-filter:blur(12px); border-radius:var(--r-md); box-shadow:var(--shadow-sm); }
.menu__search{ position:relative; display:flex; align-items:center; }
.menu__search svg{ position:absolute; inset-inline-start:16px; width:20px; height:20px; fill:none; stroke:var(--muted); stroke-width:2; stroke-linecap:round; }
.menu__search input{
  width:100%; padding:14px 48px; border:1.5px solid var(--line); border-radius:999px; background:var(--white);
  font-family:var(--ff-body); font-size:16px; color:var(--ink); transition:border .25s, box-shadow .25s;
}
.menu__search input:focus{ outline:none; border-color:var(--teal); box-shadow:0 0 0 4px var(--teal-soft); }
.menu__tabs{ display:flex; gap:8px; justify-content:center; flex-wrap:wrap; }
.menu__tabs button{
  border:0; background:var(--cream); color:var(--teal-800); font-family:var(--ff-head); font-weight:600; font-size:15px;
  padding:9px 22px; border-radius:999px; cursor:pointer; transition:.25s var(--ease);
}
.menu__tabs button.is-active{ background:var(--teal); color:#fff; box-shadow:0 8px 18px rgba(74,174,158,.32); }

.menu__chips{ display:flex; gap:8px; overflow-x:auto; padding:2px 2px 12px; scrollbar-width:none; -webkit-overflow-scrolling:touch; }
.menu__chips::-webkit-scrollbar{ display:none; }
.menu__chips button{
  flex:0 0 auto; border:1.5px solid var(--line); background:var(--white); color:var(--teal-800);
  font-family:var(--ff-body); font-weight:500; font-size:14px; padding:7px 16px; border-radius:999px; cursor:pointer; transition:.2s;
}
.menu__chips button.is-active{ border-color:var(--teal); background:var(--teal-soft); color:var(--teal-700); }

.menu__grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(290px,1fr)); gap:18px; }
.cat{
  background:var(--white); border:1px solid var(--line); border-radius:var(--r-lg); padding:24px 22px;
  box-shadow:var(--shadow-sm); transition:transform .35s var(--ease), box-shadow .35s var(--ease);
  opacity:0; transform:translateY(22px);
}
.cat.in{ opacity:1; transform:none; }
.cat:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.cat__head{ display:flex; align-items:baseline; justify-content:space-between; gap:10px; margin-bottom:6px; }
.cat__name{ font-family:var(--ff-head); font-size:22px; color:var(--teal-ink); }
.cat__en{ font-family:var(--ff-latin); font-style:italic; color:var(--gold); font-size:14px; }
.cat__tag{ display:inline-block; font-size:12px; color:var(--teal-700); background:var(--teal-soft); padding:3px 12px; border-radius:999px; margin-bottom:16px; }
.cat__list{ list-style:none; }
.row{ display:flex; align-items:flex-end; gap:8px; padding:11px 0; border-bottom:1px dashed var(--line); }
.row:last-child{ border-bottom:0; }
.row__txt{ flex:1; min-width:0; }
.row__ar{ font-weight:500; font-size:16px; color:var(--ink); }
.row__en{ font-family:var(--ff-latin); font-style:italic; font-size:12.5px; color:var(--muted); }
.row__dots{ flex:1; border-bottom:1px dotted var(--line); transform:translateY(-5px); min-width:14px; }
.row__price{ font-family:var(--ff-head); font-weight:700; color:var(--teal); white-space:nowrap; font-size:16px; }
.row__price b{ font-size:12px; font-weight:600; color:var(--muted); margin-inline-start:2px; }
mark{ background:var(--gold-soft); color:var(--teal-ink); padding:0 2px; border-radius:3px; }

.menu__empty{ text-align:center; color:var(--muted); padding:40px 0; font-size:18px; }
.menu__note{ text-align:center; color:var(--muted); font-size:13px; margin-top:26px; }

/* ---------- BOOKING ---------- */
.booking{ display:grid; grid-template-columns:1fr 1.15fr; gap:clamp(28px,5vw,56px); align-items:start; }
.booking__intro h2{ font-size:clamp(26px,4.5vw,40px); margin-bottom:14px; }
.booking__intro p{ color:var(--muted); }
.booking__perks{ list-style:none; margin-top:24px; display:grid; gap:12px; }
.booking__perks li{ position:relative; padding-inline-start:30px; color:var(--teal-800); }
.booking__perks li::before{
  content:""; position:absolute; inset-inline-start:0; top:8px; width:16px; height:16px; border-radius:50%;
  background:var(--teal-soft); box-shadow:inset 0 0 0 2px var(--teal);
}
.booking__perks li::after{ content:"✓"; position:absolute; inset-inline-start:4px; top:4px; font-size:11px; color:var(--teal); font-weight:700; }

.booking__card{ background:var(--white); border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(20px,4vw,32px); box-shadow:var(--shadow-md); }
.field{ margin-bottom:22px; }
.field > label{ display:block; font-family:var(--ff-head); font-weight:600; color:var(--teal-ink); margin-bottom:10px; font-size:15px; }
.field input[type=text]{ width:100%; padding:13px 16px; border:1.5px solid var(--line); border-radius:var(--r-sm); font-family:var(--ff-body); font-size:16px; background:var(--ivory); transition:border .2s, box-shadow .2s; }
.field input[type=text]:focus{ outline:none; border-color:var(--teal); box-shadow:0 0 0 4px var(--teal-soft); background:#fff; }

.seg{ display:flex; gap:8px; background:var(--cream); padding:5px; border-radius:999px; }
.seg__btn{ flex:1; border:0; background:transparent; padding:10px 8px; border-radius:999px; font-family:var(--ff-head); font-weight:600; font-size:14px; color:var(--teal-800); cursor:pointer; transition:.25s var(--ease); }
.seg__btn.is-active{ background:var(--white); color:var(--teal-700); box-shadow:var(--shadow-sm); }

/* calendar */
.cal{ border:1.5px solid var(--line); border-radius:var(--r-md); padding:14px; background:var(--ivory); }
.cal__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.cal__title{ font-family:var(--ff-head); font-weight:700; color:var(--teal-ink); font-size:17px; }
.cal__nav{ width:34px; height:34px; border-radius:50%; border:1.5px solid var(--line); background:#fff; cursor:pointer; color:var(--teal-700); font-size:18px; transition:.2s; }
.cal__nav:hover{ background:var(--teal-soft); border-color:var(--teal-mist); }
.cal__nav:disabled{ opacity:.35; cursor:not-allowed; }
.cal__dow{ display:grid; grid-template-columns:repeat(7,1fr); gap:4px; margin-bottom:6px; }
.cal__dow span{ text-align:center; font-size:11px; color:var(--muted); font-weight:500; }
.cal__grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:4px; }
.cal__cell{ aspect-ratio:1; border:0; background:transparent; border-radius:10px; font-family:var(--ff-body); font-size:15px; color:var(--ink); cursor:pointer; transition:.18s var(--ease); position:relative; }
.cal__cell:hover:not(:disabled){ background:var(--teal-soft); }
.cal__cell:disabled{ color:var(--line); cursor:not-allowed; }
.cal__cell.is-today{ box-shadow:inset 0 0 0 1.5px var(--teal-mist); }
.cal__cell.is-selected{ background:var(--teal); color:#fff; box-shadow:0 8px 18px rgba(74,174,158,.4); transform:scale(1.04); }
.cal__cell.is-empty{ pointer-events:none; }

.slots{ display:grid; grid-template-columns:repeat(auto-fill,minmax(78px,1fr)); gap:8px; }
.slot{ border:1.5px solid var(--line); background:#fff; border-radius:var(--r-sm); padding:10px 6px; font-family:var(--ff-body); font-size:14px; color:var(--teal-800); cursor:pointer; transition:.2s var(--ease); }
.slot:hover{ border-color:var(--teal-mist); background:var(--teal-soft); }
.slot.is-active{ background:var(--teal); color:#fff; border-color:var(--teal); box-shadow:0 8px 16px rgba(74,174,158,.32); }

.stepper{ display:flex; align-items:center; gap:6px; background:var(--cream); border-radius:999px; padding:6px; width:fit-content; }
.stepper button{ width:44px; height:44px; border-radius:50%; border:0; background:#fff; color:var(--teal-700); font-size:22px; cursor:pointer; box-shadow:var(--shadow-sm); transition:.2s; }
.stepper button:hover{ background:var(--teal); color:#fff; }
.stepper__val{ display:flex; flex-direction:column; align-items:center; min-width:70px; }
.stepper__val strong{ font-family:var(--ff-head); font-size:22px; color:var(--teal-ink); line-height:1; }
.stepper__val span{ font-size:12px; color:var(--muted); }

.booking__summary{ background:var(--teal-soft); border-radius:var(--r-md); padding:14px 18px; margin-bottom:18px; color:var(--teal-800); font-size:14.5px; line-height:1.9; display:none; }
.booking__summary.show{ display:block; animation:fadeUp .4s var(--ease); }
.booking__summary b{ color:var(--teal-ink); }
.booking__hint{ text-align:center; color:var(--muted); font-size:12.5px; margin-top:12px; }

/* ---------- VISIT ---------- */
.visit{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(28px,5vw,56px); align-items:center; }
.visit__info h2{ font-size:clamp(26px,4.5vw,40px); margin-bottom:24px; }
.visit__row{ display:flex; gap:14px; align-items:flex-start; padding:16px 0; border-bottom:1px solid var(--line); }
.visit__row:last-of-type{ border-bottom:0; }
.visit__ico{ flex:0 0 46px; height:46px; border-radius:14px; background:var(--teal-soft); display:grid; place-items:center; }
.visit__ico svg{ width:24px; height:24px; fill:none; stroke:var(--teal-700); stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.visit__row strong{ display:block; font-family:var(--ff-head); color:var(--teal-ink); }
.visit__row span, .visit__row a{ color:var(--muted); }
.visit__row a{ color:var(--teal-700); font-weight:700; }
.visit__actions{ display:flex; gap:12px; margin-top:26px; flex-wrap:wrap; }

.visit__map{ position:relative; aspect-ratio:1/1; border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-lg);
  background:
    repeating-linear-gradient(0deg, rgba(74,174,158,.07) 0 1px, transparent 1px 46px),
    repeating-linear-gradient(90deg, rgba(74,174,158,.07) 0 1px, transparent 1px 46px),
    radial-gradient(120% 120% at 70% 30%, var(--teal-soft), var(--cream));
}
.visit__map::before{ content:""; position:absolute; width:60%; height:14px; background:var(--sand); top:46%; inset-inline-start:-5%; transform:rotate(-18deg); border-radius:8px; opacity:.7; }
.visit__map::after{ content:""; position:absolute; width:50%; height:10px; background:var(--gold-soft); top:62%; inset-inline-end:-2%; transform:rotate(8deg); border-radius:8px; opacity:.6; }
.visit__pin{ position:absolute; top:42%; inset-inline-start:50%; transform:translate(-50%,-50%); display:grid; place-items:center; }
[dir=rtl] .visit__pin{ transform:translate(50%,-50%); }
.visit__pin span{ width:74px; height:92px; filter:drop-shadow(0 14px 18px rgba(22,63,58,.3)); animation:bob 3s ease-in-out infinite; }

/* ---------- FOOTER ---------- */
.footer{ background:var(--teal-ink); color:#fff; padding:54px clamp(18px,5vw,40px) 30px; text-align:center; margin-top:40px; }
.footer__brand{ display:flex; flex-direction:column; align-items:center; gap:12px; }
.footer__mark{ width:64px; height:80px; }
.footer__brand p{ font-family:var(--ff-calli); font-size:22px; }
.footer__links{ display:flex; gap:22px; justify-content:center; flex-wrap:wrap; margin:24px 0; }
.footer__links a{ color:rgba(255,255,255,.82); font-weight:500; transition:color .2s; }
.footer__links a:hover{ color:#fff; }
.footer__copy{ color:rgba(255,255,255,.55); font-size:13px; border-top:1px solid rgba(255,255,255,.12); padding-top:20px; max-width:600px; margin:0 auto; }

/* ---------- Toast ---------- */
.toast{ position:fixed; bottom:26px; inset-inline:0; margin:auto; width:fit-content; max-width:90vw; z-index:200;
  background:var(--teal-ink); color:#fff; padding:14px 24px; border-radius:999px; box-shadow:var(--shadow-lg);
  font-weight:500; opacity:0; transform:translateY(20px); pointer-events:none; transition:.4s var(--ease); }
.toast.show{ opacity:1; transform:translateY(0); }

/* ---------- Reveal ---------- */
.reveal{ opacity:0; transform:translateY(30px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* ---------- Keyframes ---------- */
@keyframes fadeUp{ from{ opacity:0; transform:translateY(18px); } to{ opacity:1; transform:none; } }
@keyframes lineUp{ to{ transform:translateY(0); } }
@keyframes badgeIn{ 0%{ opacity:0; transform:translateY(20px) scale(.9); } 100%{ opacity:1; transform:none; } }
@keyframes marquee{ to{ transform:translateX(50%); } }
@keyframes spin{ to{ transform:rotate(360deg); } }
@keyframes bob{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-10px); } }
@keyframes scrollDot{ 0%{ opacity:0; transform:translateY(0); } 40%{ opacity:1; } 80%{ opacity:0; transform:translateY(12px); } 100%{ opacity:0; } }
@keyframes float{ from{ transform:translateY(0) rotate(0); } to{ transform:translateY(-120vh) rotate(360deg); } }

/* ---------- Responsive ---------- */
@media (max-width:920px){
  .story, .booking, .visit{ grid-template-columns:1fr; }
  .booking__intro{ text-align:center; }
  .booking__perks{ justify-items:center; }
  .visit__map{ order:-1; max-width:420px; margin-inline:auto; width:100%; }
  .story__media{ order:-1; }
}
@media (max-width:720px){
  .nav__links, .nav__cta{ display:none; }
  .nav__burger{ display:flex; }
  .menu__bar{ top:58px; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal, .cat, .hero__badge, .hero__sub, .hero__actions{ opacity:1 !important; transform:none !important; }
  .hero__title .line{ transform:none !important; }
}
