/* Locals — multi-scene "arrival" journey (AURA pattern, Locals brand) */
:root{
  --bg:#0F0E0C; --charcoal:#111111; --warm-white:#FAF7F2;
  --accent:#FF3B30; --accent-2:#C6FF00; --lavender:#C6B8FF; --peach:#FFD7C2;
  --line:#E7E2D8; --ink2:#7A7770; --blue:#1F90FF; --bubble:#E9E4DB;
  --font:"Neue Montreal","Hanken Grotesk",-apple-system,system-ui,sans-serif;
  --font-head:"Neue Montreal","Hanken Grotesk",-apple-system,system-ui,sans-serif;
  --font-serif:"Playfair Display",Georgia,"Times New Roman",serif;
  --sys:-apple-system,BlinkMacSystemFont,"SF Pro Text",system-ui,sans-serif;
  --ease:cubic-bezier(0.22,1,0.36,1);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
/* overflow-x:hidden must live on html, not body. When body sets overflow-x:hidden alone,
   CSS auto-promotes its overflow-y to auto, which makes body the scroll container instead
   of html. That breaks Lenis (which scrolls window/html) and the ScrollTrigger journey pin. */
html{background:var(--bg);overflow-x:hidden}
body{font-family:var(--font);color:#fff;-webkit-font-smoothing:antialiased}
img,video{display:block}
a{color:inherit;text-decoration:none}

/* ---------- fixed video stage (stacked scene videos) ---------- */
#stage{position:fixed;inset:0;z-index:0;background:#0c0b0a;overflow:hidden}
.scene-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;will-change:opacity;
  filter:saturate(1.05);transition:opacity 1.15s ease}
.scene-vid.on{opacity:1}
#stage-tint{position:absolute;inset:0;z-index:5;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 35%,rgba(12,11,10,0) 30%,rgba(12,11,10,.55) 100%),
  linear-gradient(180deg,rgba(12,11,10,.45),rgba(12,11,10,.1) 38%,rgba(12,11,10,.62))}
/* floating brand commas (the signature glyph, as vector) */
#commas{position:absolute;inset:0;z-index:6;pointer-events:none}
.cm{position:absolute;transform:translate(-50%,-50%);width:clamp(46px,7vw,104px);height:auto;
  will-change:transform;animation:cmFloat 7s var(--ease) infinite}
.cm path{fill:currentColor}
.cm--red{color:var(--accent);filter:drop-shadow(0 0 22px rgba(255,59,48,.6))}
.cm--lime{color:var(--accent-2);filter:drop-shadow(0 0 22px rgba(198,255,0,.5));animation-delay:-2.3s}
.cm--lav{color:var(--lavender);filter:drop-shadow(0 0 22px rgba(198,184,255,.6));animation-delay:-4.6s}
@keyframes cmFloat{0%,100%{transform:translate(-50%,-50%)}50%{transform:translate(-50%,calc(-50% - 16px))}}
@media (prefers-reduced-motion:reduce){.cm{animation:none}}

/* ---------- preloader ---------- */
#pre{position:fixed;inset:0;z-index:200;background:var(--bg);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:22px;transition:opacity .7s var(--ease),visibility .7s}
#pre.done{opacity:0;visibility:hidden}
#pre .word{font-family:var(--font-head);font-weight:700;font-size:clamp(40px,7vw,84px);letter-spacing:-.04em;color:#fff}
#pre .word .c{color:var(--accent)}
#pre .bar{width:160px;height:3px;border-radius:3px;background:rgba(255,255,255,.16);overflow:hidden}
#pre .bar i{display:block;height:100%;width:0;background:#fff;transition:width .3s linear}

/* ---------- nav ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:60;display:flex;align-items:center;height:74px;
  padding:0 clamp(22px,5vw,48px);background:linear-gradient(180deg,rgba(12,11,10,.5),transparent)}
.nav__logo{font-family:var(--font-head);font-weight:700;font-size:25px;letter-spacing:-.03em;color:#fff}
.nav__logo .c{color:var(--accent)}
/* wordmark comma — the brand glyph (round bubble-tail signal mark) inline after "Locals" */
.wmc{display:inline-block;width:.4em;height:.48em;margin-left:.04em;vertical-align:-.17em}
.wmc path{fill:var(--accent)}
#pre .word .wmc{width:.36em;height:.432em;vertical-align:-.15em}
.nav__links{margin-left:auto;display:flex;align-items:center;gap:26px}
.nav__links a{font-size:15px;font-weight:500;opacity:.85;transition:opacity .15s}
.nav__links a:hover{opacity:1}

/* ---------- buttons / glass ---------- */
.btn{font-family:var(--font);font-weight:600;font-size:15px;border:none;border-radius:99px;padding:12px 22px;
  cursor:pointer;transition:transform .14s var(--ease),filter .14s,background .2s}
.btn:active{transform:scale(.96)}
.btn-light{background:#fff;color:var(--charcoal)} .btn-light:hover{filter:brightness(.93)}
.btn-big{font-size:17px;padding:15px 28px}
.glass{position:relative;background:rgba(255,255,255,.08);backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);border:1px solid rgba(255,255,255,.16);border-radius:22px;
  box-shadow:0 20px 60px rgba(0,0,0,.35)}
.glass-btn{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.28);color:#fff;border-radius:99px;
  padding:13px 24px;font-weight:600;font-size:16px;cursor:pointer;transition:transform .14s var(--ease),background .2s}
.glass-btn:active{transform:scale(.96)}
.glass-btn--primary{background:#fff;color:var(--charcoal);border-color:#fff}
.glass-chip{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  border-radius:99px;padding:8px 15px;font-size:13.5px;font-weight:500;color:#fff}
.dot-live{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:live 2.4s ease-in-out infinite}
@keyframes live{0%,100%{box-shadow:0 0 0 0 rgba(255,59,48,.5)}50%{box-shadow:0 0 0 6px rgba(255,59,48,0)}}

#page{position:relative;z-index:10}
.wrap{max-width:1180px;margin:0 auto;padding:0 clamp(22px,5vw,48px)}
.eyebrow{font-size:13px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.7)}

/* ---------- JOURNEY ---------- */
#journey{position:relative}
.journey__pin{position:sticky;top:0;height:100vh;overflow:hidden}
/* ----- opening hero overlay ----- */
#cap-layer{position:absolute;inset:0;z-index:8;pointer-events:none}
.hero-ovl{position:absolute;inset:0;display:flex;align-items:center;will-change:opacity,transform}
.hero-ovl .inner{max-width:1180px;margin:0 auto;padding:0 clamp(22px,5vw,48px);width:100%;pointer-events:auto}
.hero__title{font-family:var(--font-head);font-weight:700;font-size:clamp(52px,8.6vw,122px);
  line-height:.95;letter-spacing:-.035em;margin:22px 0 0;text-shadow:0 2px 30px rgba(0,0,0,.4)}
.hero__title .c{color:var(--accent)}
.hero__title .ser{font-family:var(--font-serif);font-style:italic;font-weight:500;letter-spacing:-.01em}
.hero__sub{font-size:clamp(18px,2.1vw,24px);line-height:1.5;color:rgba(255,255,255,.85);
  max-width:560px;margin:22px 0 34px;text-shadow:0 1px 16px rgba(0,0,0,.5)}
.hero__cta{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.cta-pill{display:inline-flex;align-items:center;gap:14px;background:#fff;color:var(--charcoal);border:none;
  border-radius:99px;padding:7px 28px 7px 7px;font-family:var(--font);font-weight:600;font-size:17px;
  cursor:pointer;transition:transform .14s var(--ease),filter .14s}
.cta-pill:hover{filter:brightness(.94)}
.cta-pill:active{transform:scale(.96)}
.cta-pill__ico{width:42px;height:42px;border-radius:50%;background:var(--accent-2);flex:none;
  display:flex;align-items:center;justify-content:center}

/* ----- single conversation thread ----- */
.thread-view{position:absolute;inset:0;z-index:7;overflow:hidden;pointer-events:none;
  -webkit-mask-image:linear-gradient(180deg,transparent 0,#000 16%,#000 80%,transparent 100%);
  mask-image:linear-gradient(180deg,transparent 0,#000 16%,#000 80%,transparent 100%)}
#thread{position:absolute;top:0;left:50%;width:min(580px,90vw);display:flex;flex-direction:column;gap:15px;
  will-change:transform}
.msg{display:flex;align-items:flex-end;gap:11px;will-change:opacity,transform}
.msg--me{justify-content:flex-end}
.msg--them{justify-content:flex-start}
.msg .av{width:38px;height:38px;border-radius:12px;background:var(--charcoal);color:#fff;flex:none;
  display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:700;
  font-size:16px;letter-spacing:-.04em;box-shadow:0 6px 18px rgba(0,0,0,.4)}
.msg .b{max-width:80%;padding:13px 19px;font-family:var(--sys);font-size:clamp(17px,1.9vw,22px);
  font-weight:500;line-height:1.32;border-radius:22px}
.msg--them .b{background:rgba(255,255,255,.96);color:var(--charcoal);border-bottom-left-radius:7px;
  box-shadow:0 12px 34px rgba(0,0,0,.3)}
.msg--me .b{background:var(--blue);color:#fff;border-bottom-right-radius:7px;box-shadow:0 10px 28px rgba(0,0,0,.28)}
/* iMessage tapback badge (emphasis) sits on the top-left corner of the bubble */
.msg .b{position:relative}
.tapback{position:absolute;top:-16px;left:-14px;display:flex;align-items:center;justify-content:center;
  min-width:34px;height:34px;padding:0 6px;border-radius:18px;background:#3a3a3c;font-size:15px;line-height:1;
  box-shadow:0 4px 12px rgba(0,0,0,.35);border:2px solid #0F0E0C}
.msg--them .tapback{left:auto;right:-14px}

/* ----- inline rich cards (Locals attachments in the thread) ----- */
.b--card{max-width:340px;width:min(340px,82%)}
.rc{border-radius:20px;overflow:hidden;background:#fff;box-shadow:0 16px 44px rgba(0,0,0,.34);font-family:var(--font)}
.rc__photo{height:168px;background-size:cover;background-position:center;position:relative}
.rc__heart{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;border:none;
  background:rgba(0,0,0,.32);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;cursor:pointer}
.rc__body{padding:15px 17px 17px;color:var(--charcoal)}
.rc__name{font-family:var(--font-head);font-weight:700;font-size:22px;letter-spacing:-.02em;line-height:1}
.rc__meta{font-size:14px;color:var(--ink2);margin-top:7px}
.rc__star{color:var(--charcoal);font-weight:600}
.rc__cuisine{font-size:13px;color:var(--ink2);margin-top:2px}
.rc__desc{font-size:15px;line-height:1.4;color:#3a382f;margin:12px 0 14px}
.rc__cta{width:100%;border:none;cursor:pointer;background:var(--charcoal);color:#fff;font-family:var(--font);
  font-weight:600;font-size:15px;border-radius:99px;padding:12px 0;transition:filter .14s}
.rc__cta:hover{filter:brightness(1.5)}

.itin{border-radius:20px;overflow:hidden;background:#fff;box-shadow:0 16px 44px rgba(0,0,0,.34);
  font-family:var(--font);color:var(--charcoal)}
.itin__head{padding:16px 18px;background:var(--charcoal);color:#fff}
.itin__title{font-family:var(--font-head);font-weight:700;font-size:16px;letter-spacing:.12em}
.itin__sub{font-size:12.5px;color:rgba(255,255,255,.65);margin-top:3px;letter-spacing:.02em}
.itin__rows{padding:6px 0}
.itin__row{display:flex;align-items:center;gap:10px;padding:9px 16px;border-bottom:1px solid var(--line)}
.itin__row:last-child{border-bottom:none}
.itin__ico{width:22px;text-align:center;font-size:16px;flex:none}
.itin__day{font-family:var(--font-head);font-weight:700;font-size:11px;color:var(--ink2);width:30px;flex:none;letter-spacing:.04em}
.itin__time{font-size:12.5px;color:var(--ink2);width:64px;flex:none;font-variant-numeric:tabular-nums}
.itin__place{font-weight:600;font-size:15px;flex:1;display:flex;align-items:center;gap:6px}
.itin__secret{font-size:13px}
.itin__foot{display:flex;gap:9px;padding:13px 16px;border-top:1px solid var(--line)}
.itin__send{flex:1;border:none;cursor:pointer;background:var(--accent-2);color:var(--charcoal);font-family:var(--font);
  font-weight:600;font-size:14.5px;border-radius:99px;padding:11px 0;transition:filter .14s}
.itin__send:hover{filter:brightness(.96)}
.itin__save{border:1px solid var(--line);cursor:pointer;background:#fff;color:var(--charcoal);font-family:var(--font);
  font-weight:600;font-size:14.5px;border-radius:99px;padding:11px 20px;transition:background .14s}
.itin__save:hover{background:var(--warm-white)}

.scroll-hint{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;
  align-items:center;gap:8px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5);z-index:6}
.scroll-hint .m{width:22px;height:34px;border:1.5px solid rgba(255,255,255,.45);border-radius:12px;position:relative}
.scroll-hint .m::after{content:"";position:absolute;top:6px;left:50%;transform:translateX(-50%);width:3px;height:6px;
  border-radius:2px;background:#fff;animation:wheel 1.6s var(--ease) infinite}
@keyframes wheel{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}100%{opacity:0;transform:translate(-50%,10px)}}

/* ---------- YOUR TURN (live composer CTA) ---------- */
#contact{min-height:74vh;display:flex;align-items:center;justify-content:center;padding:40px 0 56px;position:relative;z-index:11}
.yt{width:min(560px,92vw);text-align:center;display:flex;flex-direction:column;align-items:center}
.yt__hint{font-family:var(--font-serif);font-style:italic;font-size:clamp(34px,5vw,60px);color:#fff;letter-spacing:-.01em;margin-bottom:30px;text-shadow:0 2px 30px rgba(0,0,0,.4)}
.yt__hint .c{color:var(--accent);font-style:normal}
.composer{display:flex;align-items:center;gap:12px;width:100%;max-width:480px;
  background:rgba(255,255,255,.1);backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);
  border:1px solid rgba(255,255,255,.28);border-radius:99px;padding:9px 9px 9px 22px;
  box-shadow:0 18px 50px rgba(0,0,0,.4);transition:transform .16s var(--ease),border-color .2s,background .2s}
.composer:hover{border-color:rgba(255,255,255,.5);background:rgba(255,255,255,.14)}
.composer:active{transform:scale(.985)}
.composer__field{flex:1;display:flex;align-items:center;justify-content:flex-start;gap:1px;min-height:30px;
  font-family:var(--sys);font-size:clamp(16px,1.9vw,19px);color:rgba(255,255,255,.92);text-align:left;overflow:hidden;white-space:nowrap}
.composer__type{font-weight:500}
.composer__caret{display:inline-block;width:2px;height:1.05em;background:var(--accent);margin-left:2px;border-radius:1px;
  animation:caretBlink 1.1s steps(1) infinite}
@keyframes caretBlink{0%,50%{opacity:1}51%,100%{opacity:0}}
.composer__send{width:38px;height:38px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;
  background:var(--blue);color:#fff;box-shadow:0 4px 14px rgba(31,144,255,.5)}
.composer:hover .composer__send{filter:brightness(1.08)}
.yt__sub{font-family:var(--sys);font-size:15px;color:rgba(255,255,255,.6);margin-top:20px}
@media (prefers-reduced-motion:reduce){.composer__caret{animation:none}}

/* ---------- FOOTER (links only) ---------- */
.footer{position:relative;z-index:11;background:linear-gradient(180deg,rgba(20,18,16,0),var(--bg) 60%,var(--bg));padding:5vh clamp(22px,5vw,48px) 5vh;overflow:hidden}
.footer__inner{position:relative}
.footer__bar{position:relative;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.footer__bar .fl{display:flex;gap:22px}
.footer__bar .fl span{font-size:14px;color:rgba(255,255,255,.55)}

@media (max-width:880px){
  .specs__grid{grid-template-columns:1fr;gap:30px}
  .nav__links a:not(.btn){display:none}
  #thread{width:min(560px,92vw)}
}
