/* =========================================================
   America's Mountain City — Concept 02 "Perpetual Momentum"
   Cinematic · dark · kinetic   (all-Saans, bold sentence case)
   ========================================================= */
:root{
  --navy:#051d2f; --navy-2:#062842; --navy-3:#0a3454; --cream:#F6F1EC;
  --blue:#4CACD1; --blue-d:#147CB2; --amber:#F29F1F; --coral:#F58B88;
  --green:#1A854C; --rust:#D24B27; --peach:#FFDDA3;
  --sans:"Hanken Grotesk",Arial,sans-serif;
  --ease:cubic-bezier(.19,1,.22,1);
  --maxw:1280px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans); background:var(--navy); color:var(--cream);
  -webkit-font-smoothing:antialiased; overflow-x:hidden; line-height:1.5;
}
img{display:block;max-width:100%}
a{color:inherit}
.container{max-width:var(--maxw);margin:0 auto;padding:0 30px}
sup{font-size:.5em;vertical-align:super}

.grain{position:fixed;inset:0;pointer-events:none;z-index:9000;opacity:.06;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* custom cursor glow — disabled (using the normal system cursor) */
.cursor{display:none!important;position:fixed;top:0;left:0;width:380px;height:380px;border-radius:50%;pointer-events:none;z-index:50;
  transform:translate(-50%,-50%);transition:opacity .4s;mix-blend-mode:screen;
  background:radial-gradient(circle,rgba(76,172,209,.16),rgba(76,172,209,0) 65%)}
.cursor::after{content:"";position:absolute;top:50%;left:50%;width:8px;height:8px;border-radius:50%;
  transform:translate(-50%,-50%);background:var(--cream);box-shadow:0 0 0 1px rgba(255,255,255,.4)}
@media(hover:none){.cursor{display:none}}

.progress{position:fixed;top:0;left:0;width:100%;height:3px;z-index:9001}
.progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--blue),var(--amber));transform-origin:left}

.kicker{font-size:12.5px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:var(--amber);margin-bottom:18px}
h2{font-weight:800;letter-spacing:-.022em;line-height:1.02;font-size:clamp(32px,5.2vw,76px)}
.lead{font-size:clamp(16px,1.7vw,21px);line-height:1.5;max-width:620px;color:#b9d2e0}

@media(max-width:860px){
  .huid--bl,.huid--br{display:none}
  .huid--tl,.huid--tr{font-size:10px}
}

/* ---------------- HERO ---------------- */
.hero{position:relative;height:100vh;min-height:640px;overflow:hidden}
.hero-video{position:absolute;inset:0;z-index:0}
.hero-video video{width:100%;height:100%;object-fit:cover}
.hero-scrim{position:absolute;inset:0;background:
  linear-gradient(to bottom,rgba(5,29,47,.55),rgba(5,29,47,.15) 30%,rgba(5,29,47,.35) 65%,rgba(5,29,47,.92)),
  radial-gradient(80% 60% at 50% 45%,transparent,rgba(5,29,47,.4))}
.hero-ui{position:absolute;inset:0;z-index:3;pointer-events:none}
.huid{position:absolute;font-size:11.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;opacity:.0;color:#cfe2ee}
.huid--tl{top:90px;left:30px}.huid--tr{top:90px;right:30px}.huid--bl{bottom:30px;left:30px}.huid--br{bottom:30px;right:30px}
.hero-content{position:absolute;inset:0;z-index:4;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:0 22px;will-change:transform}
.hero-eyebrow{overflow:hidden;margin-bottom:6px}
.hero-eyebrow span{display:block;font-size:clamp(13px,1.5vw,17px);font-weight:800;letter-spacing:.34em;text-transform:uppercase;
  color:var(--amber);transform:translateY(110%)}
.hero-title{font-weight:900;letter-spacing:-.035em;line-height:.84;font-size:clamp(54px,13vw,200px);text-transform:none}
.hero-title .line{display:block;overflow:hidden}
.hero-title .w{display:block;transform:translateY(110%);will-change:transform}
.hero-sub{margin-top:26px;font-size:clamp(15px,1.7vw,21px);font-weight:600;letter-spacing:.01em;opacity:0;color:#dceaf2}
.scrollcue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:4;display:flex;align-items:center;gap:12px;
  font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;opacity:.85;text-align:center;max-width:90vw}
@media(max-width:560px){.scrollcue{flex-direction:column;gap:8px;bottom:18px;max-width:78vw}}
.scrollcue i{width:30px;height:30px;border:1.5px solid rgba(246,241,236,.5);border-radius:50%;position:relative}
.scrollcue i::after{content:"";position:absolute;top:6px;left:50%;width:2px;height:8px;background:var(--cream);transform:translateX(-50%);
  animation:drop 1.6s var(--ease) infinite}
@keyframes drop{0%{opacity:0;transform:translate(-50%,-4px)}40%{opacity:1}100%{opacity:0;transform:translate(-50%,10px)}}

/* ---------------- MARQUEE ---------------- */
.marquee{background:var(--amber);color:var(--navy);overflow:hidden;padding:16px 0;border-top:2px solid var(--navy);border-bottom:2px solid var(--navy)}
.mq-track{display:flex;gap:40px;white-space:nowrap;width:max-content;animation:mq 22s linear infinite;align-items:center}
.mq-track span{font-size:clamp(22px,3vw,40px);font-weight:900;letter-spacing:-.01em;text-transform:uppercase}
.mq-track b{font-size:22px}
@keyframes mq{to{transform:translateX(-50%)}}

/* ---------------- MANIFESTO ---------------- */
.manifesto{padding:clamp(90px,14vh,180px) 0}
.m-line{max-width:24ch}
.m-line.big{font-size:clamp(26px,3.4vw,46px);font-weight:700;line-height:1.12;letter-spacing:-.015em;max-width:22ch;color:var(--cream)}
.m-line.accent{font-size:clamp(46px,9vw,140px);font-weight:900;line-height:.92;letter-spacing:-.03em;margin:30px 0 44px;
  max-width:14ch;color:var(--amber)}
.m-line.body{font-size:clamp(17px,1.7vw,22px);font-weight:500;line-height:1.5;max-width:42ch;color:#c2d2dd;margin-bottom:22px}
.m-word{display:inline-block;will-change:transform,opacity}

/* ---------------- STATS STRIP (zigzag + boxes + elevation) ---------------- */
.stats{background:var(--navy-2);padding:clamp(40px,7vh,72px) 0}
.statband{display:flex;flex-direction:column;gap:clamp(28px,5vh,52px)}
.zz{display:block;width:100%;height:40px}
.statgrid{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:clamp(14px,1.8vw,30px)}
.sbox{border:2px solid var(--amber);padding:13px 18px 16px;display:flex;flex-direction:column;gap:11px;min-width:124px}
.sbox-label{font-size:11px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--amber);white-space:nowrap}
.sbox-val{font-size:clamp(28px,3vw,40px);font-weight:800;color:var(--amber);line-height:1}
.speak{position:relative;width:clamp(150px,15vw,190px);height:clamp(150px,15vw,190px);
  display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:20px;flex:0 0 auto}
.speak-tri{position:absolute;inset:0;width:100%;height:100%}
.speak-label{position:relative;font-size:13px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);margin-bottom:8px}
.speak-val{position:relative;font-size:clamp(26px,2.7vw,36px);font-weight:800;color:var(--amber);line-height:1}
/* tablets + phones: triangle on top, boxes 2-up with wrapping labels */
@media(max-width:1024px){
  .statgrid{gap:16px;align-items:stretch}
  .sbox{min-width:0;flex:1 0 40%;padding:13px 16px 15px;justify-content:flex-start}
  .sbox-label{white-space:normal}
  .speak{order:-1;flex:1 1 100%}
}

/* ---------------- DUALITY (pinned) ---------------- */
.duality{position:relative;height:100vh;min-height:620px;overflow:hidden;background:#000}
.dz{position:absolute;inset:0}
.dz img{width:100%;height:100%;object-fit:cover}
.dz-b{clip-path:inset(0 0 0 50%);will-change:clip-path}
.dz-b img{object-position:center 78%}/* lift the subjects above the overlaid copy */
.dz-a::after,.dz-b::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(5,29,47,.85),transparent 60%)}
.dz-copy{position:absolute;z-index:5;left:50%;bottom:9vh;transform:translateX(-50%);width:min(900px,90vw);text-align:center}
.dz-copy h2{color:var(--cream);margin-bottom:16px}
.dz-copy .kicker{color:var(--peach)}
.dz-sub{max-width:60ch;margin:0 auto;font-size:clamp(15px,1.6vw,19px);color:#dceaf2;font-weight:600}
.dz-split{position:absolute;top:0;bottom:0;left:50%;width:2px;background:var(--cream);z-index:6;opacity:.5;will-change:left}

/* ---------------- SOUND + MONTAGE ---------------- */
.sound{padding:clamp(70px,10vh,120px) 0 90px;background:var(--navy)}
.sound-head{margin-bottom:36px}
.sound .kicker{color:var(--coral)}
.montage-strip{display:flex;gap:14px;padding:0 30px 40px;overflow-x:auto;scrollbar-width:none}
.montage-strip::-webkit-scrollbar{display:none}
.montage-strip .cell{flex:0 0 clamp(180px,22vw,300px);aspect-ratio:3/4;border-radius:14px;overflow:hidden;position:relative;background:var(--navy-3)}
.montage-strip .cell img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.montage-strip .cell:hover img{transform:scale(1.07)}
.player{max-width:720px}
.player-note{margin-top:12px;font-size:13px;color:#7fa0b3}

/* ---------------- MAP ---------------- */
.land{padding:clamp(70px,10vh,120px) 0 0}
.land-head{margin-bottom:36px;max-width:780px}
.map-shell{position:relative}
#map{height:min(80vh,720px);width:100%;background:#e8e7e1}
.leaflet-container{font-family:var(--sans);background:#e8e7e1}
.map-legend{position:absolute;z-index:600;left:24px;bottom:24px;background:rgba(5,29,47,.9);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:12px 13px;display:flex;flex-direction:column;gap:3px}
.map-legend .lg-hint{font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#9fbccd;margin:2px 0 5px 8px}
.map-legend .lg{display:flex;align-items:center;gap:9px;font-size:13px;font-weight:700;color:var(--cream);
  background:none;border:0;padding:6px 9px;border-radius:8px;cursor:pointer;text-align:left;
  transition:opacity .2s,background .2s}
.map-legend .lg:hover{background:rgba(255,255,255,.08)}
.map-legend .lg .dot{width:11px;height:11px;border-radius:50%;flex:0 0 auto}
.map-legend .lg--off{opacity:.42;text-decoration:line-through}
.map-legend .lg--off .dot{background:#7d8a93!important}
.amc-pin{display:grid;place-items:center;width:22px;height:22px;border-radius:50%;color:#fff;font-size:11px;font-weight:800;
  box-shadow:0 2px 8px rgba(0,0,0,.5);border:2px solid rgba(255,255,255,.9)}
.leaflet-popup-content-wrapper{border-radius:12px;background:var(--navy-2);color:var(--cream)}
.leaflet-popup-tip{background:var(--navy-2)}
.leaflet-popup-content{margin:12px 14px;font-family:var(--sans)}
.leaflet-popup-content b{font-size:15px;color:var(--blue)}
.leaflet-control-zoom a{background:var(--navy-2)!important;color:var(--cream)!important;border-color:rgba(255,255,255,.15)!important}

/* ---------------- LISTS (two-column grid) ---------------- */
.lists{padding:clamp(70px,10vh,120px) 0}
.lists-head{margin-bottom:24px}
.tabs{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:34px}
.tab{font-size:13.5px;font-weight:800;padding:11px 18px;border-radius:100px;border:1.5px solid rgba(255,255,255,.25);
  background:transparent;color:var(--cream);cursor:pointer;transition:all .3s var(--ease)}
.tab:hover{border-color:var(--cream)}
.tab.active{background:var(--blue);color:var(--navy);border-color:var(--blue)}
.list-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0 56px}
@media(max-width:760px){.list-grid{grid-template-columns:1fr}}
.list-item{display:flex;gap:18px;padding:20px 0;border-bottom:1px solid rgba(255,255,255,.12);cursor:default;
  transition:background .3s,padding-left .3s var(--ease)}
.list-item:hover{padding-left:10px;background:linear-gradient(90deg,rgba(76,172,209,.12),transparent)}
.list-item .idx{font-size:20px;font-weight:900;color:var(--accent,var(--blue));min-width:34px;letter-spacing:-.02em}
.list-item h4{font-size:21px;font-weight:800;margin-bottom:3px;letter-spacing:-.01em;color:var(--cream)}
.list-item p{font-size:14.5px;color:#9fbccd;line-height:1.4}

/* ---------------- YEAR ---------------- */
.year{padding:clamp(70px,10vh,120px) 0;background:var(--navy-2)}
.year-head{margin-bottom:34px}
.seasons{display:flex;gap:10px;margin-top:24px;flex-wrap:wrap}
.seasons .tab{display:inline-flex;align-items:center;gap:7px}
.seasons .tab svg{width:14px;height:14px;flex:0 0 auto}
.year-split{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:26px;align-items:stretch}
@media(max-width:840px){.year-split{grid-template-columns:1fr}}
.year-media{margin:0;border-radius:18px;overflow:hidden;position:relative;min-height:440px;background:var(--navy)}
.year-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.1s var(--ease)}
.year-media img.is-active{opacity:1}
.year-dots{position:absolute;left:16px;bottom:14px;z-index:2;display:flex;gap:7px}
.year-dots button{width:7px;height:7px;padding:0;border:0;border-radius:50%;background:rgba(255,255,255,.5);
  cursor:pointer;transition:background .3s,transform .3s;box-shadow:0 1px 3px rgba(0,0,0,.4)}
.year-dots button.on{background:#fff;transform:scale(1.3)}
@media(max-width:840px){.year-media{min-height:300px}}
.event-list{display:flex;flex-direction:column;gap:14px;max-height:560px;overflow-y:auto;padding-right:12px;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.28) transparent}
.event-list::-webkit-scrollbar{width:8px}
.event-list::-webkit-scrollbar-track{background:transparent}
.event-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.22);border-radius:4px}
.event{flex:0 0 auto;background:var(--navy);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:18px 22px;position:relative;
  overflow:hidden;transition:transform .4s var(--ease),border-color .4s}
.event:hover{transform:translateY(-4px);border-color:var(--blue)}
.event-top{display:flex;align-items:baseline;justify-content:space-between;gap:14px;margin-bottom:8px}
.event .cat{font-size:11.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--coral)}
.event .when{font-size:12.5px;font-weight:800;color:var(--blue);letter-spacing:.03em;white-space:nowrap}
.event h4{font-size:22px;font-weight:800;margin:0 0 5px;letter-spacing:-.01em;color:var(--cream)}
.event p{font-size:14.5px;color:#aecadb;margin:0;line-height:1.45}

/* ---------------- PLAN ---------------- */
.plan{padding:clamp(70px,10vh,120px) 0}
.plan-head{margin-bottom:40px;max-width:840px}
.plan-shell{display:grid;grid-template-columns:.8fr 1.2fr;gap:26px;align-items:start}
@media(max-width:860px){.plan-shell{grid-template-columns:1fr}}
.plan-nav{display:flex;flex-direction:column;gap:10px}
.plan-tab{text-align:left;background:var(--navy-2);border:1px solid rgba(255,255,255,.1);cursor:pointer;padding:20px 22px;border-radius:16px;
  transition:all .35s var(--ease);color:var(--cream)}
.plan-tab:hover{border-color:rgba(255,255,255,.4)}
.plan-tab.active{background:var(--blue);color:var(--navy);border-color:var(--blue)}
.plan-tab .pt-n{font-size:12px;opacity:.6;font-weight:800;letter-spacing:.1em}
.plan-tab .pt-t{font-size:24px;font-weight:800;display:block;margin-top:2px;letter-spacing:-.01em}
.plan-tab .pt-k{font-size:13px;font-weight:600;opacity:.85;display:block;margin-top:2px}
.plan-stage{position:relative;border-radius:20px;overflow:hidden;min-height:520px;background:#000}
.plan-stage .ps-img{position:absolute;inset:0}.plan-stage .ps-img img{width:100%;height:100%;object-fit:cover}
.plan-stage .ps-scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(5,29,47,.92),rgba(5,29,47,.2) 55%,transparent)}
.plan-stage .ps-body{position:relative;z-index:2;padding:clamp(26px,3vw,42px);height:100%;display:flex;flex-direction:column;justify-content:flex-end;min-height:520px}
.ps-body h3{font-size:clamp(28px,3vw,42px);font-weight:800;margin-bottom:20px;letter-spacing:-.02em}
.ps-steps{list-style:none;display:flex;flex-direction:column;gap:12px}
.ps-steps li{display:flex;gap:16px;align-items:baseline;opacity:0;transform:translateY(14px)}
.ps-steps .when{font-size:11.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);min-width:90px}
.ps-steps .what{font-size:16px;line-height:1.4;font-weight:600}

/* ---------------- TIMELINE (horizontal clock) ---------------- */
.timeline{background:linear-gradient(180deg,var(--navy),#03131f);overflow:hidden;height:100vh;
  display:flex;flex-direction:column;padding:clamp(32px,5vh,64px) 0 clamp(20px,3vh,40px)}
.tl-intro{flex:0 0 auto;max-width:760px;margin-bottom:clamp(16px,2.6vh,32px)}
.tl-intro h2{font-size:clamp(28px,4vh,52px)}
.tl-intro p{color:#b9d2e0;font-size:clamp(15px,1.5vw,19px);margin-top:10px}
.tl-viewport{flex:1 1 auto;min-height:0;overflow:hidden;display:flex;align-items:center}
.tl-track{display:flex;align-items:center;will-change:transform}
.tl-stop{flex:0 0 78vw;max-width:760px;padding:0 4vw;border-left:1px solid rgba(255,255,255,.14);
  display:flex;flex-direction:column;justify-content:center}
@media(min-width:900px){.tl-stop{flex:0 0 52vw}}
.tl-stop .tl-num{font-size:clamp(48px,11vh,128px);font-weight:900;line-height:.8;letter-spacing:-.05em;color:#007db7}
.tl-stop .tl-meta{display:flex;justify-content:space-between;font-size:11.5px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  margin:clamp(12px,2.2vh,22px) 0 clamp(10px,1.6vh,16px);color:#9fbccd}
.tl-stop .tl-fig{border-radius:16px;overflow:hidden;height:clamp(170px,38vh,400px)}
.tl-stop .tl-fig img{width:100%;height:100%;object-fit:cover}
.tl-stop h3{font-size:clamp(20px,2.4vw,34px);font-weight:800;margin:clamp(12px,2vh,20px) 0 5px;letter-spacing:-.01em}
.tl-stop p{color:#b9d2e0;font-size:15px;max-width:34ch;font-weight:500}

/* ---------------- INSPO ---------------- */
.inspo{padding:clamp(70px,10vh,120px) 0}
.inspo-head{margin-bottom:34px}
.inspo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:900px){.inspo-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.inspo-grid{grid-template-columns:1fr}}
.blog{text-decoration:none;border-radius:16px;overflow:hidden;display:block;background:var(--navy-2);border:1px solid rgba(255,255,255,.1);
  transition:transform .45s var(--ease),border-color .45s;cursor:pointer}
.blog:hover{transform:translateY(-6px);border-color:var(--blue)}
.blog .bimg{aspect-ratio:4/3;overflow:hidden}
.blog .bimg img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.blog:hover .bimg img{transform:scale(1.08)}
.blog .bbody{padding:18px 18px 22px}
.blog .btag{font-size:11.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--coral)}
.blog h4{font-size:21px;font-weight:800;line-height:1.14;margin-top:8px;letter-spacing:-.01em}

/* ---------------- BOOK ---------------- */
.book{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden}
.book-bg{position:absolute;inset:0;z-index:0}
.book-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(5,29,47,.92),rgba(5,29,47,.45) 60%,rgba(5,29,47,.2))}
.book-bg img{width:100%;height:100%;object-fit:cover;will-change:transform}
.book-inner{position:relative;z-index:2;max-width:740px}
.book .kicker{color:var(--peach)}
.book h2{font-size:clamp(54px,10vw,150px);line-height:.86;margin-bottom:24px}
.book p{font-size:clamp(17px,1.8vw,22px);line-height:1.5;color:#dceaf2;max-width:46ch;margin-bottom:34px}
.bigcta{display:inline-flex;align-items:center;gap:12px;background:var(--amber);color:var(--navy);font-weight:900;font-size:18px;
  padding:18px 32px;border-radius:100px;text-decoration:none;transition:transform .3s;cursor:pointer}
.bigcta span{transition:transform .35s var(--ease)}
.bigcta:hover{transform:translateY(-3px)}.bigcta:hover span{transform:translateX(6px)}

/* ---------------- FOOTER ---------------- */
.foot{background:#03131f;padding:50px 0;border-top:1px solid rgba(255,255,255,.1)}
.foot-grid{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.foot-logo{height:22px}
.foot p{font-size:13px;color:#7fa0b3;max-width:60ch;flex:1;min-width:280px}
.foot a{font-weight:800;text-decoration:none;border-bottom:2px solid var(--amber);padding-bottom:2px}

/* ---------------- WEATHER WIDGET (subtle, hero bottom) ---------------- */
.wx{position:absolute;bottom:88px;left:50%;transform:translateX(-50%);z-index:6;display:flex;align-items:flex-start;gap:14px;
  color:var(--cream);opacity:0;text-shadow:0 1px 12px rgba(0,0,0,.6);
  transition:opacity .6s var(--ease),transform .5s var(--ease),visibility .6s}
.wx.is-ready{opacity:.76}
.wx:hover{opacity:1}
.wx.wx-hide{opacity:0;visibility:hidden;transform:translateX(-50%) translateY(8px);pointer-events:none}
.wx-loc{display:none}
.wx-days{display:flex;gap:14px}
.wx-cell{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:22px}
.wx-dow{font-size:8.5px;font-weight:700;letter-spacing:.05em;opacity:.72;text-transform:uppercase}
.wx-ico{width:16px;height:16px;color:currentColor;opacity:.9}
.wx-ico svg{width:100%;height:100%;display:block}
.wx-temp{font-size:9.5px;font-weight:600;display:flex;gap:3px;font-variant-numeric:tabular-nums}
.wx-temp b{font-weight:700}.wx-temp i{opacity:.5;font-style:normal}
@media(max-width:880px){.wx{bottom:74px;gap:9px}.wx-days{gap:9px}}
@media(max-width:560px){.wx{bottom:108px}}/* clear the taller stacked scroll cue */

/* ---------------- FLOATING JUKEBOX ---------------- */
.jb{position:fixed;right:24px;bottom:24px;z-index:8500;display:flex;flex-direction:column;align-items:flex-end;gap:12px;font-family:var(--sans)}
.jb-fab{display:inline-flex;align-items:center;gap:10px;background:var(--amber);color:var(--navy);border:none;
  padding:12px 18px;border-radius:100px;font-weight:800;font-size:13.5px;cursor:pointer;
  box-shadow:0 18px 44px -16px rgba(0,0,0,.7);transition:transform .3s var(--ease)}
.jb-fab:hover{transform:translateY(-2px)}
/* compact icon-only fab on phones so it doesn't cover the hero scroll cue */
@media(max-width:560px){.jb{right:16px;bottom:16px}.jb-fab{padding:14px;gap:0}.jb-fab-txt{display:none}}
.jb.open .jb-fab{display:none}
.jb-eq{display:inline-flex;align-items:flex-end;gap:2px;height:13px}
.jb-eq i{width:3px;border-radius:2px;height:40%;background:var(--navy);animation:eq 1s ease-in-out infinite}
.jb-eq i:nth-child(2){animation-delay:.25s}.jb-eq i:nth-child(3){animation-delay:.45s}.jb-eq i:nth-child(4){animation-delay:.12s}
@keyframes eq{0%,100%{height:25%}50%{height:100%}}
.jb-panel{width:min(360px,86vw);background:var(--navy-2);border:1px solid rgba(255,255,255,.12);border-radius:18px;overflow:hidden;
  box-shadow:0 40px 90px -34px rgba(0,0,0,.85);opacity:0;transform:translateY(16px) scale(.98);pointer-events:none;
  transition:opacity .35s var(--ease),transform .35s var(--ease)}
.jb.open .jb-panel{opacity:1;transform:none;pointer-events:auto}
.jb-head{display:flex;align-items:center;justify-content:space-between;padding:12px 10px 12px 16px}
.jb-title{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:13px;color:var(--cream)}
.jb-eq--head i{background:var(--blue)}
.jb-close{border:none;background:transparent;font-size:24px;line-height:1;cursor:pointer;color:var(--cream);width:32px;height:32px;border-radius:9px}
.jb-close:hover{background:rgba(255,255,255,.12)}
.jb-embed iframe{display:block;border:0}
@media(max-width:560px){.jb{right:12px;bottom:12px}}

/* ---------------- HERO WATCH CTA ---------------- */
.hero-watch{margin-top:26px;display:inline-flex;align-items:center;gap:10px;background:rgba(246,241,236,.1);
  border:1.5px solid rgba(246,241,236,.55);color:var(--cream);font-weight:800;font-size:15px;padding:12px 22px;
  border-radius:100px;cursor:pointer;backdrop-filter:blur(6px);transition:background .3s,transform .3s}
.hero-watch em{font-style:normal;opacity:.65;font-weight:600}
.hero-watch .hw-ico{display:grid;place-items:center;width:24px;height:24px;border-radius:50%;background:var(--amber);color:var(--navy)}
.hero-watch:hover{background:rgba(246,241,236,.2);transform:translateY(-2px)}

/* ---------------- FILM PLAYER ---------------- */
.film{padding:clamp(50px,7vh,96px) 0 clamp(56px,9vh,110px);background:var(--navy)}
.film-head{margin-bottom:30px;max-width:720px}
.film-stage{position:relative;max-width:1200px;margin:0 auto;aspect-ratio:16/9;border-radius:22px;overflow:hidden;
  background:#000;box-shadow:0 50px 110px -55px rgba(0,0,0,.9);border:1px solid rgba(255,255,255,.08)}
.film-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:#000}
.film-big{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  background:linear-gradient(to top,rgba(5,29,47,.55),rgba(5,29,47,.1));border:none;color:var(--cream);cursor:pointer;width:100%;height:100%;transition:opacity .4s}
.film-big-ico{width:80px;height:80px;border-radius:50%;background:var(--amber);color:var(--navy);display:grid;place-items:center;
  box-shadow:0 18px 44px -10px rgba(0,0,0,.6);transition:transform .3s}
.film-big-ico svg{width:38px;height:38px;margin-left:4px}
.film-big:hover .film-big-ico{transform:scale(1.08)}
.film-big-txt{font-size:22px;font-weight:800;letter-spacing:-.01em;text-shadow:0 2px 16px rgba(0,0,0,.5)}
.film-stage.is-active .film-big{opacity:0;pointer-events:none}
.film-bar{position:absolute;left:0;right:0;bottom:0;display:flex;align-items:center;gap:12px;padding:16px;color:var(--cream);
  background:linear-gradient(to top,rgba(5,29,47,.9),transparent);opacity:0;transition:opacity .35s;transform:translateY(6px)}
.film-stage:hover .film-bar,.film-stage.is-playing .film-bar{opacity:1;transform:none}
.fp-btn{width:34px;height:34px;flex:0 0 auto;border:none;background:transparent;color:var(--cream);cursor:pointer;padding:6px;border-radius:8px}
.fp-btn:hover{background:rgba(255,255,255,.16)}
.fp-btn svg{width:100%;height:100%;display:block}
.fp-progress{position:relative;flex:1;height:6px;border-radius:6px;background:rgba(255,255,255,.25);cursor:pointer;touch-action:none}
.fp-played{position:absolute;left:0;top:0;height:100%;border-radius:6px;background:var(--amber);width:0}
.fp-knob{position:absolute;top:50%;width:14px;height:14px;border-radius:50%;background:#fff;transform:translate(-50%,-50%);left:0;box-shadow:0 1px 4px rgba(0,0,0,.5);pointer-events:none}
.fp-time{font-size:12.5px;font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap;opacity:.92}
@media(max-width:560px){.film-big-txt{font-size:18px}.fp-time{display:none}}

/* ---------------- FLY-THROUGH GALLERY ---------------- */
.ft{position:relative;width:100%;height:100vh;overflow:hidden;perspective:1100px;perspective-origin:50% 50%}
.ft-scene{position:absolute;inset:0;transform-style:preserve-3d;will-change:transform}
.ft-item{position:absolute;left:50%;top:50%;margin:0;aspect-ratio:3/2;border-radius:14px;overflow:hidden;
  will-change:transform,opacity;box-shadow:0 44px 90px -34px rgba(0,0,0,.85);backface-visibility:hidden}
.ft-item img{width:100%;height:100%;object-fit:cover;display:block}
.ft.ft--grid{height:auto;perspective:none;display:flex;gap:14px;padding:0 30px;overflow-x:auto}
.ft--grid .ftg-cell{flex:0 0 clamp(200px,40vw,300px);aspect-ratio:3/4;border-radius:14px;overflow:hidden}
.ft--grid .ftg-cell img{width:100%;height:100%;object-fit:cover}

@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition:none!important}
  body{cursor:auto}.cursor{display:none}
  .hero-content{transform:none!important}
  .hero-title .w,.hero-eyebrow span{transform:none!important}
}
