/* ============================================================
   BOUGATSAKI — Greek Bougatsa, handcrafted in Melbourne
   "Aegean editorial, animated" — v2
   Brand blue #0979BE · Brand yellow #FFA629
   Fonts: Fraunces (display) + Hanken Grotesk (text)
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --blue:        #0979BE;
  --blue-600:    #0A6CA8;
  --blue-700:    #08537F;
  --blue-ink:    #06304A;
  --blue-tint:   #E7F2FA;

  --yellow:      #FFA629;
  --yellow-600:  #F18E0B;
  --yellow-tint: #FFF1DC;

  --cream:       #FBF8F2;
  --cream-2:     #F4ECDF;
  --stone:       #E9E0D1;
  --stone-line:  #DfD4C2;

  --ink:         #1C2B33;
  --ink-soft:    #5C6A72;
  --white:       #ffffff;

  --font-display: "Fraunces", "Times New Roman", serif;
  --font-text:    "Hanken Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --face: url("assets/logos/face.png");  /* laurel-head silhouette, used as a mask */

  --maxw: 1240px;
  --gut: clamp(20px, 5vw, 64px);

  --r-sm: 12px; --r-md: 20px; --r-lg: 30px; --r-pill: 999px;

  --shadow-sm: 0 2px 10px rgba(6,48,74,.06);
  --shadow-md: 0 18px 50px -24px rgba(6,48,74,.28);
  --shadow-lg: 0 40px 90px -40px rgba(6,48,74,.42);

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  font-family:var(--font-text); color:var(--ink); background:var(--cream);
  line-height:1.6; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; background:none; border:none; }
ul{ list-style:none; }
::selection{ background:var(--yellow); color:var(--blue-ink); }

body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%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");
}

/* ---------- Preloader ---------- */
.preloader{
  position:fixed; inset:0; z-index:10000;
  background:radial-gradient(130% 130% at 50% 30%, var(--blue) 0%, var(--blue-700) 60%, var(--blue-ink) 100%);
  display:grid; place-items:center; transition:opacity .7s var(--ease), visibility .7s;
}
.preloader.done{ opacity:0; visibility:hidden; }
.pl-inner{ display:grid; justify-items:center; gap:22px; }
.pl-face{
  width:96px; height:96px; border-radius:22px;
  object-fit:contain; display:block;
  animation:plbob 2.4s var(--ease) infinite;
}
.pl-bar{ width:160px; height:3px; background:rgba(255,255,255,.25); border-radius:3px; overflow:hidden; }
.pl-bar i{ display:block; height:100%; width:40%; background:var(--yellow); border-radius:3px; animation:plload 1.3s var(--ease) infinite; }
.pl-word{ font-family:var(--font-text); font-weight:800; letter-spacing:.34em; font-size:.74rem; text-transform:uppercase; color:rgba(255,255,255,.7); }
@keyframes plbob{ 50%{ transform:translateY(-10px); } }
@keyframes plload{ 0%{ transform:translateX(-120%);} 100%{ transform:translateX(320%);} }

/* ---------- Typography ---------- */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:500; line-height:1.04; letter-spacing:-.015em; color:var(--blue-ink); }
.display{ font-size:clamp(2.7rem, 7.2vw, 6.1rem); font-weight:430; line-height:.98; letter-spacing:-.025em; }
.h2{ font-size:clamp(2rem, 4.4vw, 3.5rem); }
.h3{ font-size:clamp(1.4rem, 2.4vw, 2rem); }
.lede{ font-size:clamp(1.12rem, 1.7vw, 1.4rem); color:var(--ink-soft); line-height:1.5; }
em, .it{ font-style:italic; }
.gr{ font-style:italic; color:var(--blue); }

.eyebrow{ font-family:var(--font-text); font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:.22em; color:var(--blue); display:inline-flex; align-items:center; gap:.7em; }
.eyebrow::before{ content:""; width:7px; height:7px; background:var(--yellow); transform:rotate(45deg); display:inline-block; }
.eyebrow--center{ justify-content:center; }
.eyebrow--light{ color:var(--yellow); }
.eyebrow--light::before{ background:var(--yellow); }

/* ---------- Layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); position:relative; z-index:1; }
.section{ padding-block:clamp(64px, 11vw, 140px); position:relative; z-index:1; }
.section--tight{ padding-block:clamp(48px, 7vw, 88px); }
.section--ink{ background:var(--blue-ink); color:rgba(255,255,255,.82); }
.center{ text-align:center; }
.measure{ max-width:62ch; } .measure-sm{ max-width:46ch; }

.diamonds{ display:flex; gap:10px; align-items:center; justify-content:center; }
.diamonds span{ width:8px; height:8px; transform:rotate(45deg); background:var(--blue); }
.diamonds span:nth-child(2){ background:var(--yellow); }

/* face watermark (recoloured silhouette) */
.facemark{
  position:absolute; pointer-events:none; z-index:0; opacity:.06;
  background:var(--blue-ink);
  -webkit-mask:var(--face) center/contain no-repeat; mask:var(--face) center/contain no-repeat;
}
.facemark--yellow{ background:var(--yellow); }
.facemark--white{ background:#fff; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--blue); --fg:#fff; position:relative;
  display:inline-flex; align-items:center; gap:.6em;
  background:var(--bg); color:var(--fg);
  font-weight:650; font-size:.98rem; padding:.92em 1.5em; border-radius:var(--r-pill);
  transition:transform .35s var(--ease-out), box-shadow .35s var(--ease-out), background .25s; line-height:1;
}
.btn svg{ width:1.05em; height:1.05em; transition:transform .35s var(--ease-out); }
.btn:hover{ transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn:hover svg{ transform:translateX(3px); }
.btn--yellow{ --bg:var(--yellow); --fg:var(--blue-ink); }
.btn--yellow:hover{ background:var(--yellow-600); }
.btn--ghost{ --bg:transparent; --fg:var(--blue-ink); border:1.5px solid var(--stone-line); }
.btn--ghost:hover{ background:var(--white); border-color:var(--blue); }
.btn--light{ --bg:#fff; --fg:var(--blue-ink); }
.btn--on-blue{ --bg:var(--yellow); --fg:var(--blue-ink); }
.btn--lg{ padding:1.05em 1.8em; font-size:1.05rem; }

.textlink{ display:inline-flex; align-items:center; gap:.45em; font-weight:650; color:var(--blue); border-bottom:2px solid transparent; padding-bottom:2px; transition:border-color .25s; }
.textlink svg{ width:1em; height:1em; transition:transform .3s var(--ease-out); }
.textlink:hover{ border-color:var(--yellow); }
.textlink:hover svg{ transform:translateX(3px); }

/* ---------- Navbar (glass, original wordmark) ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:flex-start; gap:22px;
  padding:11px var(--gut);
  background:rgba(251,248,242,.7); backdrop-filter:saturate(180%) blur(18px); -webkit-backdrop-filter:saturate(180%) blur(18px);
  border-bottom:1px solid transparent; transition:border-color .3s, background .3s, padding .3s;
}
.nav.scrolled{ border-bottom-color:var(--stone-line); padding-block:9px; }
.brand{ display:flex; align-items:center; z-index:2; }
.brand-badge{ width:42px; height:42px; border-radius:12px; display:block; object-fit:contain; box-shadow:var(--shadow-sm); transition:transform .5s var(--ease-out); }
.brand:hover .brand-badge{ transform:rotate(-5deg) scale(1.05); }
.nav-links{ display:flex; align-items:center; gap:4px; margin-right:auto; }
.nav-links a{ font-weight:550; font-size:.97rem; color:var(--ink); padding:.5em .85em; border-radius:var(--r-pill); position:relative; transition:color .2s, background .2s; }
.nav-links a:hover{ color:var(--blue); background:rgba(9,121,190,.07); }
.nav-links a.active{ color:var(--blue); }
.nav-links a.active::after{ content:""; position:absolute; left:50%; bottom:4px; transform:translateX(-50%); width:5px; height:5px; background:var(--yellow); border-radius:50%; }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.nav-toggle{ display:none; width:42px; height:42px; border-radius:50%; align-items:center; justify-content:center; }
.nav-toggle span{ position:relative; width:19px; height:1.6px; background:var(--blue-ink); transition:.3s; }
.nav-toggle span::before,.nav-toggle span::after{ content:""; position:absolute; left:0; width:19px; height:1.6px; background:var(--blue-ink); transition:.3s var(--ease); }
.nav-toggle span::before{ top:-6px; } .nav-toggle span::after{ top:6px; }
body.menu-open .nav-toggle span{ background:transparent; }
body.menu-open .nav-toggle span::before{ top:0; transform:rotate(45deg); }
body.menu-open .nav-toggle span::after{ top:0; transform:rotate(-45deg); }

.mobile-menu{ position:fixed; inset:0 0 0 auto; width:min(86vw,380px); z-index:99; background:var(--cream); box-shadow:var(--shadow-lg); transform:translateX(100%); transition:transform .5s var(--ease-out); display:flex; flex-direction:column; padding:96px 32px 40px; gap:6px; }
body.menu-open .mobile-menu{ transform:translateX(0); }
.mobile-menu a{ font-family:var(--font-display); font-size:1.8rem; color:var(--blue-ink); padding:.35em 0; border-bottom:1px solid var(--stone-line); }
.mobile-menu a:last-of-type{ border:none; }
.mobile-menu .btn{ margin-top:18px; justify-content:center; }
.scrim{ position:fixed; inset:0; z-index:98; background:rgba(6,48,74,.34); opacity:0; visibility:hidden; transition:.4s; }
body.menu-open .scrim{ opacity:1; visibility:visible; }

/* ---------- Marquee ---------- */
.marquee{ background:var(--blue-ink); color:#fff; overflow:hidden; padding:16px 0; position:relative; z-index:1; }
.marquee--yellow{ background:var(--yellow); color:var(--blue-ink); }
.marquee-track{ display:flex; gap:0; width:max-content; animation:marq 32s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-track span{ font-family:var(--font-display); font-style:italic; font-size:1.5rem; padding:0 28px; white-space:nowrap; display:inline-flex; align-items:center; gap:28px; }
.marquee-track span::after{ content:""; width:9px; height:9px; background:var(--yellow); transform:rotate(45deg); flex:none; }
.marquee--yellow .marquee-track span::after{ background:var(--blue); }
@keyframes marq{ to{ transform:translateX(-50%);} }
@media (prefers-reduced-motion: reduce){ .marquee-track{ animation:none; } }

/* ---------- Hero ---------- */
.hero{ padding-top:clamp(122px,17vh,184px); padding-bottom:clamp(40px,6vw,80px); overflow:clip; position:relative; }
.hero .facemark{ width:min(620px,70vw); height:min(720px,82vw); right:-8%; top:2%; opacity:.05; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(28px,5vw,70px); align-items:center; position:relative; z-index:1; }
.hero h1{ margin:.32em 0 .5em; }
.hero .lede{ max-width:42ch; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:2em; }
.hero-trust{ display:flex; gap:26px; margin-top:2.6em; flex-wrap:wrap; }
.hero-trust b{ font-family:var(--font-display); font-size:1.7rem; color:var(--blue); display:block; line-height:1; }
.hero-trust span{ font-size:.82rem; color:var(--ink-soft); }

.hero-media{ position:relative; }
.hero-media .frame{ border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-lg); aspect-ratio:4/5; background:var(--stone); }
.hero-media .frame img{ width:100%; height:100%; object-fit:cover; }
.hero-tag{ position:absolute; left:-18px; bottom:34px; background:#fff; border-radius:var(--r-pill); padding:.7em 1.1em; box-shadow:var(--shadow-md); display:flex; align-items:center; gap:.6em; font-weight:650; font-size:.92rem; animation:tagfloat 7s var(--ease) infinite; }
.hero-tag .face-chip{ width:24px; height:27px; background:var(--blue); -webkit-mask:var(--face) center/contain no-repeat; mask:var(--face) center/contain no-repeat; }
.float-diamond{ position:absolute; width:18px; height:18px; background:var(--yellow); transform:rotate(45deg); opacity:.9; animation:floaty 6s var(--ease) infinite; }
@keyframes floaty{ 50%{ transform:translateY(-12px) rotate(45deg);} }
@keyframes tagfloat{ 50%{ transform:translateY(-3px);} }
@media (prefers-reduced-motion: reduce){ .hero-tag,.float-diamond{ animation:none; } }

/* ---------- Brand band ---------- */
.brandband{ background:radial-gradient(125% 150% at 50% -10%, var(--blue) 0%, var(--blue-700) 64%, var(--blue-ink) 100%); color:#fff; text-align:center; position:relative; overflow:hidden; }
.brandband::after{ content:""; position:absolute; inset:0; opacity:.5; pointer-events:none; background:radial-gradient(60% 60% at 50% 120%, rgba(255,166,41,.22), transparent 70%); }
.brandband .wordmark{ width:min(330px,72vw); margin:0 auto 26px; position:relative; z-index:1; }
.brandband p{ font-family:var(--font-display); font-size:clamp(1.5rem,3.3vw,2.5rem); line-height:1.25; color:#fff; max-width:18ch; margin-inline:auto; position:relative; z-index:1; }
.brandband .kicker{ font-family:var(--font-text); font-weight:700; letter-spacing:.28em; text-transform:uppercase; font-size:.74rem; color:var(--yellow); margin-top:24px; position:relative; z-index:1; }

/* ---------- Section headers ---------- */
.shead{ max-width:680px; margin-bottom:clamp(34px,5vw,60px); }
.shead.center{ margin-inline:auto; }
.shead .h2{ margin:.3em 0 .4em; }

/* ---------- Split feature ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5.5vw,84px); align-items:center; }
.split--rev .split-media{ order:2; }
.split-media{ border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-md); aspect-ratio:5/6; background:var(--stone); position:relative; }
.split-media img{ width:100%; height:100%; object-fit:cover; }
.split-body .h2{ margin:.35em 0 .55em; }
.split-body p + p{ margin-top:1em; }
.feature-list{ margin-top:1.6em; display:grid; gap:14px; }
.feature-list li{ display:flex; gap:13px; align-items:flex-start; }
.feature-list .dot{ flex:none; width:9px; height:9px; margin-top:.55em; background:var(--yellow); transform:rotate(45deg); }
.feature-list b{ color:var(--blue-ink); font-weight:700; }
.signature{ margin-top:24px; display:flex; align-items:center; gap:14px; }
.signature .sig-name{ font-family:var(--font-display); font-style:italic; font-size:1.5rem; color:var(--blue-ink); }
.signature .sig-role{ font-size:.82rem; color:var(--ink-soft); text-transform:uppercase; letter-spacing:.14em; font-weight:700; }

/* ---------- Flavor cards ---------- */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2vw,26px); }
.card{ background:var(--white); border-radius:var(--r-md); overflow:hidden; border:1px solid var(--stone-line); box-shadow:var(--shadow-sm); transition:transform .5s var(--ease-out), box-shadow .5s var(--ease-out); }
.card:hover{ transform:translateY(-7px); box-shadow:var(--shadow-md); }
.card-img{ aspect-ratio:4/3; overflow:hidden; background:var(--stone); }
.card-img img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease-out); }
.card:hover .card-img img{ transform:scale(1.06); }
.card-body{ padding:22px 22px 26px; }
.card-body h3{ font-size:1.32rem; margin-bottom:.3em; }
.card-body p{ font-size:.96rem; color:var(--ink-soft); }
.card-tag{ font-size:.72rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--yellow-600); }

/* ---------- Steps ---------- */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,44px); }
.step .n{ font-family:var(--font-display); font-size:3.2rem; color:var(--blue); line-height:1; display:block; }
.step .n::after{ content:""; display:block; width:34px; height:3px; background:var(--yellow); margin-top:14px; }
.step h3{ font-size:1.28rem; margin:18px 0 .4em; }
.step p{ color:var(--ink-soft); font-size:.98rem; }

/* ---------- Watch / phone video ---------- */
.watch{ position:relative; overflow:hidden; }
.phone{ position:relative; width:clamp(240px,30vw,320px); aspect-ratio:9/16; border-radius:38px; background:#000; padding:10px; box-shadow:var(--shadow-lg), 0 0 0 2px rgba(6,48,74,.12); margin-inline:auto; }
.phone video{ width:100%; height:100%; object-fit:contain; border-radius:28px; display:block; }
.phone::after{ content:""; position:absolute; top:0; left:50%; transform:translateX(-50%); width:42%; height:26px; background:#000; border-radius:0 0 16px 16px; z-index:2; }
.watch-grid{ display:grid; grid-template-columns:1fr auto; gap:clamp(30px,5vw,70px); align-items:center; }
.video-badge{ position:absolute; top:18px; right:-10px; background:var(--yellow); color:var(--blue-ink); font-weight:800; font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; padding:.5em .8em; border-radius:var(--r-pill); z-index:3; box-shadow:var(--shadow-sm); }

/* ---------- Teaser cards ---------- */
.teasers{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(16px,2vw,26px); }
.teaser{ position:relative; border-radius:var(--r-lg); overflow:hidden; min-height:340px; display:flex; align-items:flex-end; padding:34px; color:#fff; box-shadow:var(--shadow-md); }
.teaser img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; transition:transform .8s var(--ease-out); }
.teaser:hover img{ transform:scale(1.05); }
.teaser::after{ content:""; position:absolute; inset:0; z-index:1; background:linear-gradient(180deg, rgba(6,48,74,0) 30%, rgba(6,48,74,.82)); }
.teaser-body{ position:relative; z-index:2; }
.teaser-body h3{ color:#fff; font-size:1.7rem; margin-bottom:.2em; }
.teaser-body p{ color:rgba(255,255,255,.85); margin-bottom:1em; max-width:34ch; }

/* ---------- CTA band ---------- */
.cta-band{ background:var(--yellow); border-radius:var(--r-lg); padding:clamp(38px,6vw,72px); display:grid; grid-template-columns:1.4fr auto; gap:30px; align-items:center; position:relative; overflow:hidden; }
.cta-band::before{ content:""; position:absolute; right:-40px; top:-60px; width:260px; height:260px; background:radial-gradient(circle, rgba(255,255,255,.4), transparent 65%); }
.cta-band h2{ color:var(--blue-ink); }
.cta-band p{ color:#6a4a12; margin-top:.4em; max-width:46ch; }
.cta-band .btn{ white-space:nowrap; }

/* ---------- Footer ---------- */
.footer{ background:var(--blue-ink); color:rgba(255,255,255,.8); position:relative; z-index:1; padding-top:clamp(56px,8vw,90px); overflow:hidden; }
.footer .facemark{ width:520px; height:600px; right:-120px; bottom:-160px; opacity:.05; background:#fff; }
.footer a{ color:rgba(255,255,255,.8); transition:color .2s; }
.footer a:hover{ color:var(--yellow); }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:40px; padding-bottom:50px; border-bottom:1px solid rgba(255,255,255,.13); position:relative; z-index:1; }
.footer .wordmark{ width:190px; margin-bottom:20px; }
.footer h4{ color:#fff; font-family:var(--font-text); font-weight:700; font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; margin-bottom:18px; }
.footer ul{ display:grid; gap:11px; font-size:.96rem; }
.footer .muted{ font-size:.95rem; max-width:34ch; line-height:1.6; }
.socials{ display:flex; gap:12px; margin-top:18px; }
.socials a{ width:40px; height:40px; border-radius:50%; border:1px solid rgba(255,255,255,.2); display:flex; align-items:center; justify-content:center; transition:.25s; }
.socials a:hover{ background:var(--yellow); border-color:var(--yellow); color:var(--blue-ink); transform:translateY(-2px); }
.socials svg{ width:18px; height:18px; }
.footer-bottom{ display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; padding-block:26px; font-size:.85rem; color:rgba(255,255,255,.55); position:relative; z-index:1; }

/* ---------- Page hero ---------- */
.page-hero{ padding-top:clamp(124px,16vh,176px); padding-bottom:clamp(34px,5vw,58px); position:relative; overflow:clip; }
.page-hero .facemark{ width:min(440px,60vw); height:min(520px,70vw); right:-4%; top:8%; opacity:.05; }
.page-hero .display{ font-size:clamp(2.4rem,6vw,4.6rem); margin:.28em 0 .4em; }
.page-hero .lede{ max-width:56ch; }

/* ---------- Events (Find Us) ---------- */
.events{ display:grid; gap:16px; }
.event{ display:grid; grid-template-columns:auto 1fr auto; gap:clamp(18px,3vw,40px); align-items:center; background:var(--white); border:1px solid var(--stone-line); border-radius:var(--r-md); padding:24px clamp(20px,3vw,34px); box-shadow:var(--shadow-sm); transition:transform .4s var(--ease-out), box-shadow .4s var(--ease-out), border-color .3s; }
.event:hover{ transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--blue-tint); }
.event-date{ text-align:center; min-width:74px; padding-right:clamp(18px,3vw,34px); border-right:1px solid var(--stone-line); }
.event-date .d{ font-family:var(--font-display); font-size:2.5rem; line-height:.9; color:var(--blue); }
.event-date .m{ text-transform:uppercase; letter-spacing:.16em; font-size:.74rem; font-weight:700; color:var(--ink-soft); margin-top:6px; }
.event-main h3{ font-size:1.32rem; margin-bottom:5px; }
.event-meta{ display:flex; flex-wrap:wrap; gap:14px; color:var(--ink-soft); font-size:.94rem; }
.event-meta span{ display:inline-flex; align-items:center; gap:.4em; }
.event-meta svg{ width:1em; height:1em; color:var(--blue); }
.event-cta .btn{ font-size:.88rem; padding:.7em 1.15em; }
.event--recurring .event-date .d{ font-size:1.05rem; line-height:1.1; font-family:var(--font-text); font-weight:800; color:var(--blue); }
.events-empty{ text-align:center; padding:50px; color:var(--ink-soft); }

/* ---------- Calendar ---------- */
.cal-wrap{ display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:clamp(18px,3vw,32px); }
.cal{ background:var(--white); border:1px solid var(--stone-line); border-radius:var(--r-md); padding:clamp(18px,2.4vw,26px); box-shadow:var(--shadow-sm); }
.cal-head{ display:flex; align-items:baseline; justify-content:space-between; margin-bottom:16px; }
.cal-head .mo{ font-family:var(--font-display); font-size:1.5rem; color:var(--blue-ink); }
.cal-head .yr{ font-size:.82rem; color:var(--ink-soft); font-weight:700; letter-spacing:.12em; }
.cal-grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:3px; grid-auto-rows:minmax(42px,auto); }
.cal-grid .dow{ text-align:center; font-size:.66rem; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); padding-bottom:6px; }
.cal-cell{ display:flex; align-items:center; justify-content:center; font-size:.88rem; border-radius:8px; color:var(--ink); position:relative; }
.cal-cell.muted{ color:transparent; }
.cal-cell.today{ outline:2px solid var(--blue-tint); font-weight:700; }
.cal-cell.has-event{ background:var(--blue); color:#fff; font-weight:700; cursor:pointer; transition:transform .2s var(--ease-out), background .2s; flex-direction:column; justify-content:center; align-items:center; gap:2px; padding:5px 3px 6px; }
.cal-cell.has-event:hover{ transform:scale(1.05); background:var(--blue-700); }
.cal-day-num{ line-height:1; }
.cal-day-loc{ font-size:.48rem; font-weight:800; text-align:center; line-height:1.2; width:100%; padding:0 3px; opacity:.9; letter-spacing:.03em; text-transform:uppercase; word-break:break-word; hyphens:auto; }
.cal-cell.recurring{ background:var(--yellow-tint); color:var(--yellow-600); font-weight:700; }
.cal-legend{ display:flex; gap:22px; flex-wrap:wrap; justify-content:center; margin-top:26px; font-size:.85rem; color:var(--ink-soft); }
.cal-legend i{ display:inline-block; width:14px; height:14px; border-radius:5px; vertical-align:-2px; margin-right:7px; }
.cal-legend .e{ background:var(--blue); } .cal-legend .r{ background:var(--yellow-tint); border:1px solid var(--yellow); }

/* Calendar location panel */
.cal-location{ display:none; max-width:540px; margin:16px auto 0; background:var(--blue); color:#fff; border-radius:var(--r-md); padding:18px 22px; align-items:center; gap:16px; box-shadow:var(--shadow-md); }
.cal-location.visible{ display:flex; }
.cal-location-ico{ flex:none; width:38px; height:38px; background:rgba(255,255,255,.15); border-radius:50%; display:flex; align-items:center; justify-content:center; }
.cal-location-ico svg{ width:18px; height:18px; stroke:#fff; }
.cal-location-name{ font-weight:700; font-size:1.05rem; }
.cal-location-meta{ font-size:.88rem; opacity:.82; margin-top:3px; }
.cal-location-close{ margin-left:auto; flex:none; background:rgba(255,255,255,.15); border:none; color:#fff; width:28px; height:28px; border-radius:50%; font-size:.85rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background .2s; }
.cal-location-close:hover{ background:rgba(255,255,255,.3); }

/* status pill */
.pill{ display:inline-flex; align-items:center; gap:.5em; font-size:.74rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; padding:.4em .8em; border-radius:var(--r-pill); }
.pill--open{ background:#E6F6EC; color:#1B7A43; }
.pill--open .dotlive{ width:7px; height:7px; border-radius:50%; background:#2BA85B; box-shadow:0 0 0 0 rgba(43,168,91,.5); animation:pulse 2s infinite; }
@keyframes pulse{ 70%{ box-shadow:0 0 0 7px rgba(43,168,91,0);} 100%{ box-shadow:0 0 0 0 rgba(43,168,91,0);} }
.pill--soon{ background:var(--blue-tint); color:var(--blue-700); }

.mapframe{ border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-md); border:1px solid var(--stone-line); }
.mapframe iframe{ display:block; width:100%; height:100%; min-height:340px; border:0; }

/* ---------- Offer page ---------- */
.offer-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.2vw,28px); }
.offer-card{ background:var(--white); border:1px solid var(--stone-line); border-radius:var(--r-md); padding:30px; box-shadow:var(--shadow-sm); transition:transform .4s var(--ease-out), box-shadow .4s var(--ease-out); }
.offer-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.offer-ico{ width:54px; height:54px; border-radius:var(--r-sm); background:var(--blue-tint); display:flex; align-items:center; justify-content:center; margin-bottom:20px; color:var(--blue); }
.offer-ico svg{ width:26px; height:26px; }
.offer-card h3{ font-size:1.34rem; margin-bottom:.4em; }
.offer-card p{ color:var(--ink-soft); font-size:.97rem; }
.offer-card ul{ margin-top:16px; display:grid; gap:9px; }
.offer-card li{ display:flex; gap:10px; font-size:.94rem; }
.offer-card li::before{ content:""; flex:none; width:7px; height:7px; margin-top:.55em; background:var(--yellow); transform:rotate(45deg); }

.pricestrip{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--stone-line); border:1px solid var(--stone-line); border-radius:var(--r-md); overflow:hidden; }
.pricestrip > div{ background:var(--cream); padding:28px 24px; text-align:center; }
.pricestrip b{ font-family:var(--font-display); font-size:2.6rem; color:var(--blue); display:block; line-height:1; }
.pricestrip span{ font-size:.86rem; color:var(--ink-soft); display:block; margin-top:8px; }

/* ---------- Bougatsa Bar (dark, celebratory) ---------- */
.bar-hero{ background:linear-gradient(180deg, #15110d 0%, #221a12 100%); color:#fff; position:relative; overflow:hidden; }
.bar-hero .facemark{ width:480px; height:560px; left:-120px; top:-60px; opacity:.06; background:var(--yellow); }
.bar-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,70px); align-items:center; position:relative; z-index:1; }
.bar-hero h2{ color:#fff; }
.bar-hero .script{ font-family:var(--font-display); font-style:italic; color:var(--yellow); font-size:clamp(1.4rem,3vw,2rem); }
.bar-hero p{ color:rgba(255,255,255,.78); }
.bar-media{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.bar-media .m{ border-radius:var(--r-md); overflow:hidden; box-shadow:var(--shadow-lg); aspect-ratio:3/4; }
.bar-media .m:first-child{ margin-top:30px; }
.bar-media .m img{ width:100%; height:100%; object-fit:cover; }
.bar-media .m--video{ aspect-ratio:9/16; background:#000; }
.bar-media .m video{ width:100%; height:100%; object-fit:contain; display:block; }
.bar-feats{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:34px; }
.bar-feat{ background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:var(--r-md); padding:22px; }
.bar-feat .fi{ color:var(--yellow); width:28px; height:28px; margin-bottom:12px; }
.bar-feat h4{ color:#fff; font-family:var(--font-display); font-size:1.15rem; margin-bottom:.3em; }
.bar-feat p{ color:rgba(255,255,255,.7); font-size:.92rem; }

/* ---------- Contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(30px,5vw,70px); align-items:start; }
.contact-info .item{ display:flex; gap:16px; padding:18px 0; border-bottom:1px solid var(--stone-line); }
.contact-info .item:last-child{ border:none; }
.contact-ico{ flex:none; width:46px; height:46px; border-radius:50%; background:var(--blue-tint); color:var(--blue); display:flex; align-items:center; justify-content:center; }
.contact-ico svg{ width:20px; height:20px; }
.contact-info .item b{ display:block; font-size:.78rem; text-transform:uppercase; letter-spacing:.14em; color:var(--ink-soft); margin-bottom:3px; font-weight:700; }
.contact-info .item a, .contact-info .item p{ font-size:1.12rem; color:var(--blue-ink); }

.form{ background:var(--white); border:1px solid var(--stone-line); border-radius:var(--r-lg); padding:clamp(24px,3.5vw,40px); box-shadow:var(--shadow-md); }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field{ margin-bottom:16px; }
.field label{ display:block; font-size:.82rem; font-weight:600; color:var(--blue-ink); margin-bottom:7px; }
.field input, .field select, .field textarea{ width:100%; font:inherit; font-size:1rem; color:var(--ink); background:var(--cream); border:1.5px solid var(--stone-line); border-radius:var(--r-sm); padding:.8em 1em; transition:border-color .2s, box-shadow .2s, background .2s; }
.field textarea{ resize:vertical; min-height:130px; }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--blue); background:#fff; box-shadow:0 0 0 4px rgba(9,121,190,.12); }
.form .btn{ width:100%; justify-content:center; margin-top:6px; }
.form-note{ font-size:.84rem; color:var(--ink-soft); margin-top:14px; text-align:center; }
.form-status{ margin-top:14px; padding:14px 16px; border-radius:var(--r-sm); font-size:.95rem; display:none; }
.form-status.show{ display:block; }
.form-status.ok{ background:#E6F6EC; color:#1B7A43; }
.form-status.err{ background:#FCEBEA; color:#B23B32; }

.faq{ display:grid; gap:12px; max-width:760px; margin-inline:auto; }
.faq details{ background:var(--white); border:1px solid var(--stone-line); border-radius:var(--r-md); padding:6px 24px; box-shadow:var(--shadow-sm); }
.faq summary{ list-style:none; cursor:pointer; padding:18px 0; font-family:var(--font-display); font-size:1.2rem; color:var(--blue-ink); display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-family:var(--font-text); font-size:1.6rem; color:var(--blue); transition:transform .3s; line-height:1; }
.faq details[open] summary::after{ transform:rotate(45deg); }
.faq details p{ padding:0 0 20px; color:var(--ink-soft); }

/* ---------- Reveal ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease-out), transform .9s var(--ease-out); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; } .reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; } .reveal[data-d="4"]{ transition-delay:.32s; }
.reveal[data-d="5"]{ transition-delay:.40s; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* ---------- v3 additions ---------- */
.cards--4{ grid-template-columns:repeat(4,1fr); }
.misu-flavours{ display:flex; flex-wrap:wrap; gap:12px; margin:22px 0 6px; }
.misu-chip{ display:inline-flex; align-items:center; gap:.6em; background:#fff; border:1px solid var(--stone-line); border-radius:var(--r-pill); padding:.62em 1.15em; font-weight:650; color:var(--blue-ink); box-shadow:var(--shadow-sm); }
.misu-chip .d{ width:9px; height:9px; background:var(--yellow); transform:rotate(45deg); flex:none; }
.roots{ position:relative; overflow:hidden; text-align:center; color:#fff; background-color:var(--blue-ink); background-image:linear-gradient(rgba(6,48,74,.62), rgba(6,48,74,.74)), var(--serres, none); background-size:cover; background-position:center; }

/* ---------- Responsive ---------- */
@media (max-width: 980px){
  .footer-grid{ grid-template-columns:1fr 1fr; gap:34px; }
  .cards, .offer-grid, .steps, .bar-feats{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width: 860px){
  .nav-links, .nav-enquire{ display:none; }
  .nav-toggle{ display:flex; }
  .brand{ margin-right:auto; }
  .hero-grid{ grid-template-columns:1fr; gap:40px; }
  .hero-media{ max-width:460px; margin-inline:auto; width:100%; }
  .split, .watch-grid, .bar-grid{ grid-template-columns:1fr; gap:32px; }
  .split--rev .split-media{ order:0; }
  .split-media{ aspect-ratio:4/3; }
  .teasers, .contact-grid, .cta-band{ grid-template-columns:1fr; }
  .cta-band{ text-align:left; }
  .pricestrip{ grid-template-columns:repeat(2,1fr); }
  .event{ grid-template-columns:auto 1fr; }
  .event-cta{ grid-column:1 / -1; } .event-cta .btn{ width:100%; justify-content:center; }
  .phone{ width:clamp(220px,60vw,300px); }
  .bar-media{ max-width:460px; margin-inline:auto; }
}
@media (max-width: 560px){
  .cards, .offer-grid, .steps, .footer-grid, .bar-feats{ grid-template-columns:1fr; }
  .form-row{ grid-template-columns:1fr; }
  .hero-trust{ gap:18px; }
  .event-date{ min-width:58px; padding-right:16px; } .event-date .d{ font-size:2rem; }
  .marquee-track span{ font-size:1.2rem; }
}
