@font-face{font-family:'Anton';src:url('fonts/Anton-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Pacifico';src:url('fonts/Pacifico-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Manrope';src:url('fonts/Manrope-Variable.woff2') format('woff2');font-weight:100 800;font-style:normal;font-display:swap}
@font-face{font-family:'Archivo';src:url('fonts/Archivo-Variable.woff2') format('woff2');font-weight:100 900;font-style:normal;font-display:swap}
/* ============ STACKED — SHARED STYLES ============ */
:root{
  --orange:#EC5A1A;
  --orange-hot:#F26E2E;
  --orange-deep:#C8430B;
  --blue:#B8DAD5;
  --blue-mid:#7FB8B0;
  --blue-deep:#3D7A77;
  --cream:#FBF5E9;
  --paper:#FFFBF1;
  --ink:#1B1411;
  --ink-soft:#3A2D26;
  --white:#FFFFFF;
  --tile:#C9E2DD;
  --tile-line:#A7CCC4;
  --shadow:0 18px 42px -22px rgba(27,20,17,.45);
  --r-sm:14px;
  --r-md:22px;
  --r-lg:36px;
  --r-xl:56px;
  --maxw:1280px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Manrope',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ============ TILE BG ============ */
.tile-bg{
  background-color:var(--blue);
  background-image:
    linear-gradient(to right, var(--tile-line) 1px, transparent 1px),
    linear-gradient(to bottom, var(--tile-line) 1px, transparent 1px);
  background-size:38px 38px;
}

/* ============ NAV ============ */
.nav{
  position:sticky;top:0;z-index:60;
  background:rgba(255,251,241,.85);
  backdrop-filter:saturate(160%) blur(12px);
  -webkit-backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid rgba(27,20,17,.06);
}
.nav-inner{
  max-width:var(--maxw);margin:0 auto;
  padding:14px 22px;display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:center;gap:14px;flex-shrink:0;min-width:0;text-decoration:none}
.brand .badge{
  width:60px;height:60px;border-radius:50%;
  display:block;
  box-shadow:0 8px 20px -10px rgba(127,184,176,.55);
  transition:transform .35s ease;
  object-fit:contain;
  background:transparent;
}
.brand:hover .badge{transform:rotate(-6deg) scale(1.04)}
/* legacy wordmark kept for accessibility / SEO; visually hidden because the new logo image already includes the wordmark */
.brand .wordmark{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.nav-links{display:flex;gap:6px;align-items:center}
.nav-links a{
  padding:10px 14px;border-radius:999px;font-weight:600;font-size:14.5px;color:var(--ink-soft);
  transition:background .2s ease,color .2s ease;
}
.nav-links a:hover{background:rgba(236,90,26,.08);color:var(--orange-deep)}
.nav-links a.active{background:rgba(236,90,26,.12);color:var(--orange-deep);font-weight:700}
.nav-cta{
  background:var(--orange);color:var(--white)!important;font-weight:800!important;
  padding:12px 20px!important;letter-spacing:.02em;
  box-shadow:0 12px 26px -12px rgba(236,90,26,.55);
}
.nav-cta:hover{background:var(--orange-deep)!important}
.nav-burger{width:42px;height:42px;border-radius:12px;background:var(--ink);color:var(--white);align-items:center;justify-content:center;display:none}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 26px;border-radius:999px;font-weight:800;letter-spacing:.01em;font-size:16px;
  transition:transform .2s ease, background .2s ease, color .2s ease, box-shadow .25s ease;
}
.btn-primary{background:var(--orange);color:var(--white);box-shadow:0 18px 34px -16px rgba(236,90,26,.65)}
.btn-primary:hover{background:var(--orange-deep);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border:2px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-cream{background:var(--cream);color:var(--ink)}
.btn-cream:hover{background:var(--white)}
.btn .arrow{width:18px;height:18px;display:inline-block;transition:transform .25s ease}
.btn:hover .arrow{transform:translateX(4px)}

/* ============ HERO (home) ============ */
.hero{
  position:relative;overflow:hidden;
  padding:62px 22px 100px;
  background:linear-gradient(180deg,#FFFBF1 0%,#FBF1DE 60%,#F6E6C9 100%);
}
.hero-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center;position:relative;z-index:2}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--white);border:1.5px solid rgba(27,20,17,.08);
  padding:8px 14px;border-radius:999px;font-weight:700;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);
}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 4px rgba(236,90,26,.18)}
.hero h1{
  font-family:'Anton',sans-serif;font-weight:400;
  font-size:clamp(46px,6.6vw,104px);line-height:.86;
  letter-spacing:-.01em;margin:18px 0 18px;text-transform:uppercase;
  color:var(--ink);
}
.hero h1 .pink{color:var(--orange);display:inline-block;transform:translateY(2px)}
.hero h1 .stroke{-webkit-text-stroke:2.5px var(--ink);color:transparent}
.hero .lede{
  font-size:clamp(17px,1.6vw,20px);line-height:1.5;max-width:530px;color:var(--ink-soft);
}
.hero-cta{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap}
.hero-meta{display:flex;gap:24px;margin-top:30px;flex-wrap:wrap}
.hero-meta .m{display:flex;align-items:center;gap:10px;color:var(--ink-soft);font-weight:600;font-size:14.5px}
.hero-meta .m svg{width:18px;height:18px;color:var(--orange)}

.hero-art{position:relative;aspect-ratio:1/1;max-width:560px;justify-self:end;width:100%}
.hero-art .disc{
  position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, #FFB68A 0%, var(--orange) 60%, var(--orange-deep) 100%);
  box-shadow:0 50px 90px -30px rgba(236,90,26,.55), inset 0 -30px 60px rgba(0,0,0,.12);
}
.hero-art .photo{
  position:absolute;top:5%;left:5%;width:90%;height:90%;border-radius:50%;
  background-size:cover;background-position:center;
  box-shadow:inset 0 -30px 60px rgba(0,0,0,.15), 0 30px 60px -20px rgba(0,0,0,.35);
  animation:bob 6s ease-in-out infinite;
}
.hero-art .badge-stamp{
  position:absolute;top:-22px;right:-12px;width:140px;height:140px;border-radius:50%;
  background:var(--white);display:grid;place-items:center;color:var(--ink);
  font-family:'Archivo',sans-serif;font-weight:900;font-size:11px;letter-spacing:.18em;text-align:center;line-height:1.3;
  box-shadow:var(--shadow);transform:rotate(-12deg);
  border:2px solid var(--ink);z-index:3;
}
.hero-art .badge-stamp span{padding:0 18px;text-transform:uppercase}
.hero-art svg.stack{position:absolute;inset:0;width:100%;height:100%;animation:bob 6s ease-in-out infinite}
@keyframes bob{
  0%,100%{transform:translateY(-2%) rotate(-2deg)}
  50%{transform:translateY(2%) rotate(2deg)}
}

.sticker{position:absolute;border-radius:50%;display:grid;place-items:center;color:var(--white);font-family:'Archivo',sans-serif;font-weight:900;text-transform:uppercase;letter-spacing:.12em;font-size:11px;text-align:center;line-height:1.2;z-index:2}
.sticker.s1{width:118px;height:118px;background:var(--blue-mid);top:14%;left:-3%;transform:rotate(-14deg);color:var(--ink)}
.sticker.s2{width:96px;height:96px;background:var(--ink);bottom:8%;left:38%;transform:rotate(8deg)}
.sticker.s3{width:104px;height:104px;background:var(--orange);bottom:12%;right:-2%;transform:rotate(-4deg)}

/* ============ PAGE HERO (sub-pages) ============ */
.page-hero{
  position:relative;overflow:hidden;
  padding:80px 22px 60px;background:linear-gradient(180deg,#FFFBF1 0%,#FBF1DE 100%);
}
.page-hero .container{display:flex;flex-direction:column;gap:14px;align-items:flex-start;max-width:var(--maxw);margin:0 auto}
.page-hero h1{
  font-family:'Anton',sans-serif;font-weight:400;
  font-size:clamp(40px,5.4vw,78px);line-height:.88;letter-spacing:-.01em;
  text-transform:uppercase;margin:6px 0 4px;color:var(--ink);
}
.page-hero h1 .o{color:var(--orange)}
.page-hero p{max-width:640px;font-size:18px;line-height:1.55;color:var(--ink-soft);margin:6px 0 0}
.breadcrumb{font-family:'Archivo',sans-serif;font-weight:800;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);display:flex;gap:10px;align-items:center}
.breadcrumb a{color:var(--orange-deep)}
.breadcrumb span{opacity:.4}

/* ============ MARQUEE ============ */
.marquee{background:var(--orange);color:var(--cream);border-top:3px solid var(--ink);border-bottom:3px solid var(--ink);overflow:hidden}
.marquee-track{
  display:flex;gap:50px;align-items:center;
  padding:18px 0;white-space:nowrap;
  animation:scroll 30s linear infinite;
  font-family:'Anton',sans-serif;font-size:34px;text-transform:uppercase;letter-spacing:.04em;
}
.marquee-track .star{display:inline-block;color:var(--ink);font-size:22px;transform:translateY(-3px)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============ SECTIONS ============ */
.section{padding:110px 22px;position:relative}
.container{max-width:var(--maxw);margin:0 auto;position:relative}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:44px;flex-wrap:wrap}
.section-head h2{
  font-family:'Anton',sans-serif;font-weight:400;
  font-size:clamp(33px,4.4vw,58px);line-height:.95;letter-spacing:-.005em;
  text-transform:uppercase;margin:8px 0 0;color:var(--ink);max-width:780px;
}
.section-head .kicker{
  font-family:'Archivo',sans-serif;font-weight:900;font-size:12.5px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--orange);
}
.section-head p{max-width:380px;color:var(--ink-soft);font-size:16px;line-height:1.55}

/* ============ 3 STEPS ============ */
.steps{background:var(--paper)}
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.step{position:relative;background:var(--cream);border-radius:var(--r-lg);padding:42px 32px 38px;text-align:center;border:2px solid var(--ink);overflow:hidden;transition:transform .35s ease,box-shadow .35s ease}
.step:hover{transform:translateY(-6px);box-shadow:0 32px 60px -28px rgba(27,20,17,.32)}
.step .circle{width:118px;height:118px;border-radius:50%;background:var(--orange);color:var(--white);display:grid;place-items:center;margin:0 auto 22px;box-shadow:0 16px 30px -14px rgba(236,90,26,.55);position:relative}
.step .circle svg{width:54px;height:54px}
.step .num{position:absolute;top:16px;left:16px;width:38px;height:38px;border-radius:50%;background:var(--ink);color:var(--cream);display:grid;place-items:center;font-family:'Anton',sans-serif;font-size:20px}
.step h3{font-family:'Anton',sans-serif;font-weight:400;font-size:34px;letter-spacing:-.005em;text-transform:uppercase;margin:0 0 10px;color:var(--ink)}
.step p{color:var(--ink-soft);font-size:15.5px;line-height:1.55;margin:0;max-width:280px;margin-left:auto;margin-right:auto}

/* ============ STACKS / MENU ============ */
.menu{background:var(--paper);padding-top:30px}
.menu-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stack-card{position:relative;border-radius:var(--r-lg);padding:24px 22px 26px;overflow:hidden;border:2px solid var(--ink);display:flex;flex-direction:column;gap:14px;min-height:380px;transition:transform .35s ease,box-shadow .35s ease}
.stack-card:hover{transform:translateY(-6px);box-shadow:0 32px 60px -28px rgba(27,20,17,.4)}
.stack-card .tag{align-self:flex-start;background:var(--ink);color:var(--cream);font-family:'Archivo',sans-serif;font-weight:800;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;padding:6px 12px;border-radius:999px}
.stack-card h3{font-family:'Anton',sans-serif;font-weight:400;font-size:42px;line-height:.92;text-transform:uppercase;letter-spacing:-.005em;margin:0;color:var(--ink)}
.stack-card p{color:var(--ink-soft);font-size:14.5px;line-height:1.5;margin:0;flex:1}
.stack-card .footer-row{display:flex;justify-content:space-between;align-items:center;margin-top:8px}
.stack-card .price{font-family:'Anton',sans-serif;font-size:28px;color:var(--ink)}
.stack-card .arrow-btn{width:46px;height:46px;border-radius:50%;background:var(--ink);color:var(--cream);display:grid;place-items:center;transition:transform .25s ease,background .25s ease}
.stack-card:hover .arrow-btn{background:var(--orange);transform:rotate(-25deg)}
.stack-card .photo{height:130px;border-radius:18px;background-size:cover;background-position:center;border:1.5px solid var(--ink);margin-bottom:4px}
.stack-1{background:#FFE2CC}
.stack-2{background:#F7D5BC}
.stack-3{background:var(--blue)}
.stack-4{background:#F9E5B2}
.stack-illu{position:absolute;right:-20px;bottom:-20px;width:170px;height:170px;opacity:.95}

/* ============ TOPPINGS ============ */
.toppings{background:var(--blue);position:relative;overflow:hidden}
.toppings::before{content:"";position:absolute;inset:0;background-image:linear-gradient(to right, rgba(255,255,255,.4) 1px, transparent 1px),linear-gradient(to bottom, rgba(255,255,255,.4) 1px, transparent 1px);background-size:40px 40px;opacity:.55;pointer-events:none}
.toppings .section-head h2,.toppings .section-head p{color:var(--ink)}
.toppings .section-head .kicker{color:var(--orange-deep)}
.toppings-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;position:relative;z-index:2}
.topping{background:var(--paper);border:2px solid var(--ink);border-radius:24px;padding:22px 14px 18px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px;transition:transform .25s ease,background .25s ease}
.topping:hover{transform:translateY(-4px) rotate(-1deg);background:var(--white)}
.topping .ic{width:54px;height:54px;border-radius:50%;background:var(--orange);display:grid;place-items:center;color:var(--white);font-size:26px}
.topping .ic.b{background:var(--blue-mid);color:var(--ink)}
.topping .ic.c{background:var(--ink);color:var(--cream)}
.topping .ic.d{background:#F9E5B2;color:var(--ink)}
.topping span{font-weight:700;font-size:14px;color:var(--ink);letter-spacing:.01em}

/* ============ POSTER ============ */
.poster{background:var(--orange);color:var(--cream);padding:120px 22px;position:relative;overflow:hidden;border-top:3px solid var(--ink);border-bottom:3px solid var(--ink)}
.poster::before{content:"";position:absolute;inset:0;background-image:linear-gradient(to right, rgba(0,0,0,.07) 1px, transparent 1px),linear-gradient(to bottom, rgba(0,0,0,.07) 1px, transparent 1px);background-size:40px 40px}
.poster-inner{max-width:var(--maxw);margin:0 auto;position:relative;z-index:2;display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:center}
.poster h2{font-family:'Anton',sans-serif;font-weight:400;font-size:clamp(50px,8vw,116px);line-height:.84;letter-spacing:-.012em;text-transform:uppercase;margin:0;color:var(--cream)}
.poster h2 .o{color:var(--ink);-webkit-text-stroke:0;display:block}
.poster .ink-line{display:block;color:var(--ink);-webkit-text-stroke:0}
.poster p{font-size:18px;line-height:1.55;max-width:380px;color:var(--cream);margin:0 0 20px}
.poster .badge-big{
  width:260px;height:260px;border-radius:50%;background:var(--cream);color:var(--ink);
  display:grid;place-items:center;text-align:center;
  font-family:'Archivo',sans-serif;font-weight:900;letter-spacing:.18em;
  border:2.5px solid var(--ink);justify-self:end;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.4);
  transform:rotate(-8deg);
  font-size:13px;text-transform:uppercase;
}
.poster .badge-big .stack-name{font-family:'Pacifico',cursive;font-weight:400;font-size:48px;letter-spacing:0;color:var(--orange);display:block;margin:6px 0;line-height:1;text-transform:none}

/* ============ STORY ============ */
.story{background:var(--paper)}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.story h2{font-family:'Anton',sans-serif;font-size:clamp(32px,4.2vw,54px);font-weight:400;line-height:.95;text-transform:uppercase;margin:8px 0 24px}
.story p{font-size:17px;line-height:1.65;color:var(--ink-soft);margin:0 0 16px;max-width:520px}
.story .stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:32px;max-width:520px}
.story .stat{background:var(--cream);border:2px solid var(--ink);border-radius:18px;padding:18px 16px;text-align:center}
.story .stat .v{font-family:'Anton',sans-serif;font-size:38px;color:var(--orange);line-height:1}
.story .stat .l{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-top:6px}
.story-card{position:relative;aspect-ratio:4/5;border-radius:var(--r-xl);background:linear-gradient(160deg,#FFCFAF 0%,#FFA770 50%,var(--orange) 100%);overflow:hidden;border:2px solid var(--ink);display:grid;place-items:center}
.story-card.with-photo{background-size:cover;background-position:center}
.story-card .label{position:absolute;top:24px;left:24px;background:var(--ink);color:var(--cream);font-family:'Archivo',sans-serif;font-weight:900;font-size:11px;letter-spacing:.18em;text-transform:uppercase;padding:8px 14px;border-radius:999px;z-index:2}
.story-card .since{position:absolute;bottom:24px;right:24px;font-family:'Pacifico',cursive;font-size:34px;color:var(--cream);transform:rotate(-6deg);z-index:2;text-shadow:0 4px 18px rgba(0,0,0,.3)}
.story-card svg{width:78%;height:78%}

/* ============ FIND US ============ */
.find{background:var(--cream);position:relative;overflow:hidden}
.find::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle, rgba(127,184,176,.16) 1px, transparent 1.5px);background-size:24px 24px;opacity:.6;pointer-events:none}
.find-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:36px;position:relative;z-index:2}
.locations{display:flex;flex-direction:column;gap:16px}
.loc{background:var(--paper);border:2px solid var(--ink);border-radius:var(--r-md);padding:24px 26px;display:grid;grid-template-columns:auto 1fr auto;gap:22px;align-items:center;transition:transform .25s ease,background .25s ease}
.loc:hover{transform:translateY(-3px);background:var(--white)}
.loc .pin{width:52px;height:52px;border-radius:50%;background:var(--orange);color:var(--white);display:grid;place-items:center}
.loc h3{font-family:'Anton',sans-serif;font-weight:400;font-size:26px;text-transform:uppercase;margin:0 0 4px}
.loc .addr{font-size:14px;color:var(--ink-soft);line-height:1.4;margin:0}
.loc .hrs{font-weight:700;font-size:13px;color:var(--orange);margin-top:6px;display:block;letter-spacing:.04em}
.loc .open{background:var(--blue);color:var(--ink);padding:6px 12px;border-radius:999px;font-weight:800;font-size:11px;letter-spacing:.16em;text-transform:uppercase;border:1.5px solid var(--ink)}
.loc.coming{opacity:.65}
.loc.coming .pin{background:var(--blue-mid);color:var(--ink)}
.loc.coming .open{background:transparent;border-style:dashed}

.find-card{background:var(--ink);color:var(--cream);border-radius:var(--r-lg);padding:34px 30px;display:flex;flex-direction:column;gap:18px;position:relative;overflow:hidden}
.find-card h3{font-family:'Anton',sans-serif;font-weight:400;font-size:42px;text-transform:uppercase;margin:0;line-height:.95}
.find-card p{font-size:15px;line-height:1.55;color:rgba(251,245,233,.85);margin:0}
.find-card .pill-list{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.find-card .pill{background:rgba(255,255,255,.08);padding:12px 16px;border-radius:14px;font-size:14px;font-weight:600;display:flex;justify-content:space-between;align-items:center;transition:background .2s ease}
.find-card .pill:hover{background:rgba(255,255,255,.15)}
.find-card .pill b{color:var(--orange-hot);font-weight:800}
.find-card .deco{position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle, var(--orange) 0%, transparent 70%);opacity:.22;bottom:-120px;right:-100px;pointer-events:none}

/* ============ CLUB ============ */
.club{background:var(--blue);padding:90px 22px;position:relative;overflow:hidden;border-top:3px solid var(--ink)}
.club::before{content:"";position:absolute;inset:0;background-image:linear-gradient(to right, rgba(255,255,255,.45) 1px, transparent 1px),linear-gradient(to bottom, rgba(255,255,255,.45) 1px, transparent 1px);background-size:40px 40px;opacity:.4}
.club-inner{max-width:920px;margin:0 auto;text-align:center;position:relative;z-index:2}
.club h2{font-family:'Anton',sans-serif;font-weight:400;font-size:clamp(38px,5vw,68px);line-height:.92;text-transform:uppercase;margin:0 0 14px}
.club h2 .scrip{font-family:'Pacifico',cursive;color:var(--orange);font-size:.7em;display:inline-block;transform:translateY(-6px) rotate(-3deg);text-transform:none;letter-spacing:0}
.club p{color:var(--ink-soft);font-size:17px;margin:0 0 26px;max-width:560px;margin-left:auto;margin-right:auto;line-height:1.55}
.club form{display:flex;gap:10px;max-width:540px;margin:0 auto;background:var(--paper);padding:8px;border-radius:999px;border:2px solid var(--ink);box-shadow:0 22px 40px -22px rgba(27,20,17,.32)}
.club input{flex:1;border:none;background:transparent;padding:14px 18px;font-size:16px;font-family:inherit;color:var(--ink);outline:none}
.club input::placeholder{color:#7a6b62}
.club button{background:var(--orange);color:var(--white);padding:14px 22px;border-radius:999px;font-weight:800;font-size:15px;transition:background .2s ease}
.club button:hover{background:var(--orange-deep)}
.club .perks{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin-top:24px}
.club .perk{display:inline-flex;gap:8px;align-items:center;color:var(--ink);font-weight:700;font-size:13.5px;letter-spacing:.04em}
.club .perk svg{width:18px;height:18px;color:var(--orange-deep)}

/* ============ FOOTER ============ */
footer{background:var(--ink);color:var(--cream);padding:80px 22px 28px}
.foot-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px}
.foot-brand .badge{width:84px;height:84px;box-shadow:0 14px 30px -14px rgba(127,184,176,.5)}
.foot-brand p{color:rgba(251,245,233,.6);font-size:14px;line-height:1.6;max-width:300px;margin:18px 0 22px}
.foot-brand .socials{display:flex;gap:10px}
.foot-brand .socials a{width:42px;height:42px;border-radius:50%;background:rgba(251,245,233,.07);display:grid;place-items:center;transition:background .2s ease;color:var(--cream)}
.foot-brand .socials a:hover{background:var(--orange)}
.foot-col h5,.foot-col .foot-h{font-family:'Archivo',sans-serif;font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--orange-hot);margin:0 0 16px;font-weight:900}
.foot-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.foot-col a{color:rgba(251,245,233,.78);font-size:14.5px;transition:color .2s ease}
.foot-col a:hover{color:var(--orange-hot)}
.foot-bot{max-width:var(--maxw);margin:50px auto 0;padding-top:24px;border-top:1px solid rgba(251,245,233,.1);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:12.5px;color:rgba(251,245,233,.45)}

/* ============ FLOATING ORDER CTA ============ */
.floating-cta{position:fixed;right:22px;bottom:22px;z-index:80;background:var(--orange);color:var(--white);padding:14px 20px;border-radius:999px;font-weight:800;box-shadow:0 20px 40px -18px rgba(236,90,26,.7);display:inline-flex;gap:10px;align-items:center;letter-spacing:.02em;font-size:14.5px;transition:transform .25s ease,background .25s ease}
.floating-cta:hover{background:var(--orange-deep);transform:translateY(-3px)}

/* ============ TABLES (allergens) ============ */
.allergen-table{width:100%;border-collapse:separate;border-spacing:0;background:var(--paper);border:2px solid var(--ink);border-radius:var(--r-md);overflow:hidden;font-size:14px}
.allergen-table thead{background:var(--ink);color:var(--cream)}
.allergen-table th{font-family:'Archivo',sans-serif;font-weight:800;letter-spacing:.08em;text-transform:uppercase;font-size:11.5px;padding:14px 10px;text-align:center}
.allergen-table th:first-child{text-align:left;padding-left:22px}
.allergen-table td{padding:14px 10px;text-align:center;border-top:1px solid rgba(27,20,17,.08)}
.allergen-table td:first-child{text-align:left;font-weight:700;padding-left:22px;color:var(--ink)}
.allergen-table tbody tr:hover{background:#FFFCEC}
.al-mark{display:inline-block;width:22px;height:22px;border-radius:50%;font-weight:900;font-size:12px;line-height:22px;color:var(--white)}
.al-mark.c{background:var(--orange)}
.al-mark.m{background:var(--blue-mid);color:var(--ink)}
.al-mark.n{background:transparent;color:rgba(27,20,17,.18);font-weight:700}
.legend{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:18px;font-size:13.5px;font-weight:600}
.legend-item{display:inline-flex;align-items:center;gap:8px}

/* ============ FORMS ============ */
.form-card{background:var(--paper);border:2px solid var(--ink);border-radius:var(--r-lg);padding:38px 36px;max-width:680px}
.form-card h3{font-family:'Anton',sans-serif;font-weight:400;font-size:42px;text-transform:uppercase;margin:0 0 6px;line-height:1}
.form-card .sub{color:var(--ink-soft);font-size:15px;margin:0 0 22px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form-field{display:flex;flex-direction:column;gap:6px}
.form-field.full{grid-column:1/-1}
.form-field label{font-family:'Archivo',sans-serif;font-weight:800;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.form-field input,.form-field textarea,.form-field select{
  background:var(--white);border:1.5px solid rgba(27,20,17,.18);border-radius:14px;
  padding:14px 16px;font-family:inherit;font-size:16px;color:var(--ink);outline:none;
  transition:border-color .2s ease,box-shadow .2s ease;
}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{border-color:var(--orange);box-shadow:0 0 0 4px rgba(236,90,26,.12)}
/* Southbank van feature (homepage) */
.sb-feature{display:grid;grid-template-columns:1.06fr .94fr;gap:42px;align-items:center}
.sb-feature .sb-media{margin:0;position:relative;border-radius:var(--r-lg);overflow:hidden;border:2px solid rgba(251,245,233,.16);box-shadow:0 44px 90px -34px rgba(0,0,0,.6)}
.sb-feature .sb-media img{display:block;width:100%;height:100%;object-fit:cover}
.sb-feature .sb-tag{position:absolute;left:16px;bottom:16px;background:var(--orange);color:var(--white);font-family:'Archivo',sans-serif;font-weight:800;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;padding:8px 14px;border-radius:999px}
@media (max-width:860px){.sb-feature{grid-template-columns:1fr;gap:24px}}
.btn.btn-ghost.btn-on-dark{border-color:rgba(251,245,233,.65);color:var(--cream);background:transparent}
.btn.btn-ghost.btn-on-dark:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.form-field textarea{resize:vertical;min-height:120px}
.form-submit{margin-top:8px}

/* ============ FAQ ============ */
.faq{display:flex;flex-direction:column;gap:12px;max-width:760px}
.faq details{background:var(--cream);border:2px solid var(--ink);border-radius:var(--r-md);padding:0;overflow:hidden}
.faq summary{padding:20px 24px;cursor:pointer;font-family:'Anton',sans-serif;font-size:22px;text-transform:uppercase;letter-spacing:-.005em;display:flex;justify-content:space-between;align-items:center;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:30px;color:var(--orange);font-family:'Manrope',sans-serif;transition:transform .25s ease}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 24px 22px;margin:0;color:var(--ink-soft);font-size:15.5px;line-height:1.6}

/* ============ CARD GRIDS (about/values/team) ============ */
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.value{background:var(--cream);border:2px solid var(--ink);border-radius:var(--r-lg);padding:28px 28px 30px;transition:transform .25s ease}
.value:hover{transform:translateY(-4px)}
.value .ic{width:60px;height:60px;border-radius:50%;background:var(--orange);color:var(--white);display:grid;place-items:center;margin-bottom:18px}
.value h3{font-family:'Anton',sans-serif;font-weight:400;font-size:28px;text-transform:uppercase;margin:0 0 8px;letter-spacing:-.005em}
.value p{color:var(--ink-soft);font-size:14.5px;line-height:1.55;margin:0}

/* careers cards */
.job-list{display:flex;flex-direction:column;gap:14px}
.job{background:var(--paper);border:2px solid var(--ink);border-radius:var(--r-md);padding:22px 26px;display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center;transition:transform .25s ease}
.job:hover{transform:translateY(-3px)}
.job h4{font-family:'Anton',sans-serif;font-weight:400;font-size:26px;text-transform:uppercase;margin:0 0 4px;line-height:1}
.job .meta{display:flex;gap:10px;flex-wrap:wrap;color:var(--ink-soft);font-size:13.5px;font-weight:600}
.job .meta span{display:inline-flex;gap:6px;align-items:center}
.job .meta span:not(:last-child)::after{content:"·";margin-left:10px;opacity:.4}

/* ============ FRANCHISE STATS ============ */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:30px 0 50px}
.kpi{background:var(--paper);border:2px solid var(--ink);border-radius:var(--r-md);padding:24px 22px;text-align:center}
.kpi .v{font-family:'Anton',sans-serif;font-size:54px;color:var(--orange);line-height:1}
.kpi .l{font-family:'Archivo',sans-serif;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:800;color:var(--ink-soft);margin-top:8px}

/* ============ MAP / LOCATION DETAIL ============ */
.map-block{position:relative;border:2px solid var(--ink);border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/9;background:var(--blue);display:grid;place-items:center}
.map-block::before{content:"";position:absolute;inset:0;background-image:linear-gradient(to right, rgba(255,255,255,.45) 1px, transparent 1px),linear-gradient(to bottom, rgba(255,255,255,.45) 1px, transparent 1px);background-size:40px 40px}
.map-pin{position:relative;z-index:2;width:120px;height:120px;border-radius:50%;background:var(--orange);color:var(--white);display:grid;place-items:center;box-shadow:0 20px 40px -16px rgba(236,90,26,.65);animation:pulse 2.6s ease-out infinite}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(236,90,26,.6),0 20px 40px -16px rgba(236,90,26,.65)}
  100%{box-shadow:0 0 0 40px rgba(236,90,26,0),0 20px 40px -16px rgba(236,90,26,.45)}
}

/* ============ RESPONSIVE ============ */
@media (max-width:980px){
  .hero-inner{grid-template-columns:1fr;gap:30px}
  .hero{padding:36px 22px 70px}
  .hero-art{max-width:420px;justify-self:center;margin-top:14px}
  .nav-links{display:none}
  .nav-burger{display:flex}
  .steps-grid{grid-template-columns:1fr;gap:14px}
  .menu-grid{grid-template-columns:repeat(2,1fr)}
  .toppings-grid{grid-template-columns:repeat(3,1fr)}
  .poster-inner{grid-template-columns:1fr;gap:30px}
  .poster .badge-big{justify-self:start}
  .story-grid{grid-template-columns:1fr;gap:36px}
  .find-grid{grid-template-columns:1fr}
  .foot-inner{grid-template-columns:1fr 1fr;gap:30px}
  .section{padding:78px 22px}
  .poster{padding:78px 22px}
  .form-row{grid-template-columns:1fr}
  .value-grid{grid-template-columns:1fr;gap:14px}
  .job{grid-template-columns:1fr;gap:14px}
  .kpi-row{grid-template-columns:repeat(2,1fr)}
  .allergen-table{font-size:12.5px}
  .allergen-table th,.allergen-table td{padding:10px 6px}
}
@media (max-width:540px){
  .menu-grid{grid-template-columns:1fr}
  .toppings-grid{grid-template-columns:repeat(2,1fr)}
  .foot-inner{grid-template-columns:1fr}
  .marquee-track{font-size:24px;gap:32px}
  .floating-cta{padding:12px 16px;font-size:13px}
  .loc{grid-template-columns:auto 1fr;gap:14px}
  .loc .open{grid-column:1/-1;justify-self:start}
  .hero-art .sticker.s1{width:84px;height:84px;font-size:9px}
  .hero-art .sticker.s2{width:72px;height:72px;font-size:9px}
  .hero-art .sticker.s3{width:78px;height:78px;font-size:9px}
  .hero-art .badge-stamp{width:100px;height:100px;font-size:9px}
  .form-card{padding:26px 22px}
  .story .stat-row{gap:10px}
  .story .stat{padding:14px 8px;border-radius:14px}
  .story .stat .v{font-size:29px}
  .story .stat .l{font-size:10px;letter-spacing:.06em;margin-top:4px}
}


/* Screen-reader-only utility */
.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}

/* ============ PHOTO STRIP / GALLERY ============ */
.gallery{background:var(--paper)}
.gallery.on-cream{background:var(--cream)}
.photo-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.photo-strip.three{grid-template-columns:repeat(3,1fr)}
.photo-strip .ph{aspect-ratio:4/3;border-radius:var(--r-lg);background-size:cover;background-position:center;border:2px solid var(--ink);box-shadow:0 18px 38px -22px rgba(27,20,17,.45);transition:transform .35s ease,box-shadow .35s ease}
.photo-strip .ph:hover{transform:translateY(-6px) rotate(-.6deg);box-shadow:0 30px 56px -26px rgba(27,20,17,.5)}
.photo-strip .ph.tall{aspect-ratio:3/4}
@media(max-width:860px){
  .photo-strip,.photo-strip.three{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:460px){
  .photo-strip,.photo-strip.three{grid-template-columns:1fr 1fr}
  .photo-strip .ph{border-radius:var(--r-md)}
}
