*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#0d1b2a;--bg2:#112030;--card:#1c3050;--border:#254060;--amber:#f5a623;--amber2:#ffc04d;--teal:#00c9a7;--coral:#ff6b5b;--sky:#4db8ff;--text:#eef2f7;--muted:#7a9ab8}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Barlow',sans-serif;font-weight:300;overflow-x:hidden}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:var(--amber);border-radius:2px}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:clamp(14px,1.6vw,22px) clamp(18px,4vw,64px);background:rgba(13,27,42,.96);backdrop-filter:blur(12px);border-bottom:1px solid rgba(245,166,35,.1)}
.logo{font-family:'Bebas Neue',sans-serif;font-size:clamp(.9rem,1.4vw,1.4rem);letter-spacing:.18em}
.logo span{color:var(--amber)}
.nav-links{display:flex;gap:22px}
.nav-links a{font-family:'Barlow Condensed',sans-serif;font-size:clamp(.6rem,.7vw,.8rem);font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .2s}
.nav-links a:hover{color:var(--amber)}
.nav-cta{background:var(--amber);color:#0d1b2a;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:clamp(.6rem,.7vw,.8rem);letter-spacing:.15em;text-transform:uppercase;padding:9px 20px;border:none;cursor:pointer;border-radius:3px}
.nav-cta:hover{background:var(--amber2)}

/* HERO */
.hero{min-height:100vh;display:flex;flex-direction:column;overflow:hidden;position:relative}
.hero-glow{position:absolute;inset:0;background:radial-gradient(ellipse 65% 50% at 50% 52%,rgba(245,166,35,.06) 0%,transparent 68%);pointer-events:none}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(245,166,35,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(245,166,35,.025) 1px,transparent 1px);background-size:70px 70px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 0%,transparent 100%);pointer-events:none}
.hero-copy{position:relative;z-index:2;padding:80px 48px 0;text-align:center;display:flex;flex-direction:column;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:9px;background:rgba(245,166,35,.09);border:1px solid rgba(245,166,35,.22);border-radius:100px;padding:6px 16px;font-family:'Barlow Condensed',sans-serif;font-size:.66rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--amber);margin-bottom:12px;animation:up .7s .1s both}
.eb-dot{width:5px;height:5px;border-radius:50%;background:var(--teal);animation:blink 2s infinite}
@keyframes blink{50%{opacity:.15}}
h1{font-family:'Bebas Neue',sans-serif;font-size:clamp(4rem,8.5vw,9.5rem);line-height:.9;letter-spacing:.025em;margin-bottom:14px;animation:up .7s .28s both}
h1 em{font-style:normal;color:var(--amber)}
h1 .hollow{-webkit-text-stroke:2px var(--teal);color:transparent}
.hero-p{font-size:clamp(.8rem,1.1vw,1.1rem);line-height:1.78;color:var(--muted);max-width:500px;margin:0 auto 36px;animation:up .7s .44s both}
.hero-btns{display:flex;gap:12px;animation:up .7s .58s both}
.btn-a{background:var(--amber);color:#0d1b2a;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.82rem;letter-spacing:.15em;text-transform:uppercase;padding:14px 32px;border:none;cursor:pointer;border-radius:3px;transition:transform .15s,box-shadow .15s}
.btn-a:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(245,166,35,.3)}
.btn-o{background:transparent;color:var(--text);font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:.82rem;letter-spacing:.15em;text-transform:uppercase;padding:13px 26px;border:1px solid rgba(238,242,247,.18);cursor:pointer;border-radius:3px;transition:border-color .2s}
.btn-o:hover{border-color:rgba(238,242,247,.45)}
@keyframes up{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* MAP */
.map-wrap{position:relative;z-index:2;margin-top:44px;animation:up 1s .72s both}
.map-stage{position:relative;max-width:1120px;margin:0 auto;padding:0 40px}
.scroll-hint{display:flex;flex-direction:column;align-items:center;gap:7px;padding:24px 0 44px;animation:fadeIn 1s 1.6s both}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.scroll-bar{width:1px;height:40px;background:linear-gradient(to bottom,var(--amber),transparent);animation:sbar 1.6s ease-in-out infinite}
@keyframes sbar{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
.scroll-txt{font-family:'Barlow Condensed',sans-serif;font-size:.55rem;letter-spacing:.25em;text-transform:uppercase;color:var(--muted)}

/* TICKER */
.ticker{background:var(--amber);overflow:hidden}
.ticker-inner{display:flex;animation:tickrun 30s linear infinite;white-space:nowrap}
@keyframes tickrun{to{transform:translateX(-50%)}}
.tk{font-family:'Bebas Neue',sans-serif;font-size:.86rem;letter-spacing:.18em;padding:10px 24px;color:#0d1b2a}
.tk-link{cursor:pointer;text-decoration:none;border-bottom:1.5px solid rgba(13,27,42,.3);transition:border-color .15s}
.tk-link:hover{border-bottom-color:#0d1b2a}
.tks{color:rgba(13,27,42,.3);padding:10px 2px;font-size:.4rem}

/* SHARED */
.wrap{max-width:1240px;margin:0 auto;padding:0 clamp(18px,4vw,64px)}
.sec{padding:90px 0}
.sec-eye{display:inline-flex;align-items:center;gap:9px;font-family:'Barlow Condensed',sans-serif;font-size:clamp(.55rem,.65vw,.75rem);font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--amber)}
.sec-eye::before{content:'';width:15px;height:1px;background:var(--amber)}
h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.3rem,3.8vw,4.5rem);line-height:.92;letter-spacing:.025em;margin-top:9px}
h2 em{font-style:normal;color:var(--amber)}
.rev{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.rev.in{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* CITY EXPLORER */
.city-ex{display:grid;grid-template-columns:250px 1fr;border:1px solid var(--border);border-radius:8px;overflow:hidden;margin-top:48px}
.ctabs{background:var(--bg2);border-right:1px solid var(--border)}
.ctab{display:flex;align-items:center;gap:11px;padding:16px 18px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .2s;position:relative}
.ctab::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--amber);transform:scaleY(0);transition:transform .2s}
.ctab.active,.ctab:hover{background:var(--card)}
.ctab.active::before{transform:scaleY(1)}
.ctab-nm{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:.9rem;letter-spacing:.04em}
.ctab-sub{font-size:.62rem;color:var(--muted);margin-top:1px}
.ctab-live{margin-left:auto;width:6px;height:6px;border-radius:50%;background:var(--teal);animation:blink 2s infinite;flex-shrink:0}
.cpanel{display:none;background:var(--card)}
.cpanel.active{display:block}
.cp-head{padding:24px 28px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start}
.cp-city{font-family:'Bebas Neue',sans-serif;font-size:2.4rem;letter-spacing:.04em;line-height:1;margin-bottom:3px}
.cp-state{font-family:'Barlow Condensed',sans-serif;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--amber)}
.cp-stats{display:flex;gap:22px}
.cpn{font-family:'Bebas Neue',sans-serif;font-size:1.9rem;line-height:1;color:var(--teal)}
.cpl{font-size:.55rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:2px}
.cp-grid{display:grid;grid-template-columns:1fr 1fr}
.cpb{padding:18px 26px;border-bottom:1px solid var(--border);border-right:1px solid var(--border)}
.cpb:nth-child(even){border-right:none}
.cpb.lr{border-bottom:none}
.cpb-title{font-family:'Barlow Condensed',sans-serif;font-size:.6rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.pi{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(37,64,96,.5)}
.pi:last-child{border-bottom:none;padding-bottom:0}
.piic{width:31px;height:31px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0}
.ia{background:rgba(245,166,35,.12)}.it{background:rgba(0,201,167,.12)}.ic{background:rgba(255,107,91,.12)}.is{background:rgba(77,184,255,.12)}
.pi-nm{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:clamp(.72rem,.85vw,.95rem)}
.pi-desc{font-size:.67rem;color:var(--muted);margin-top:1px}
.pi-badge{margin-left:auto;font-family:'Barlow Condensed',sans-serif;font-size:.54rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:2px 7px;border-radius:100px;flex-shrink:0}
.bd{background:rgba(0,201,167,.11);color:var(--teal);border:1px solid rgba(0,201,167,.2)}
.bp{background:rgba(245,166,35,.11);color:var(--amber);border:1px solid rgba(245,166,35,.2)}
.rdot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:5px}
.dr{background:var(--teal)}.dg{background:var(--amber)}.dm{background:var(--coral)}

/* SYNC */
.sync-sec{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.sync-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.sync-plat{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:24px}
.scard{background:var(--card);border:1px solid var(--border);border-radius:7px;padding:15px 14px;display:flex;align-items:center;gap:11px;cursor:pointer;transition:border-color .2s,transform .15s;position:relative}
.scard:hover{border-color:var(--amber);transform:translateY(-2px)}
.slogo{width:38px;height:38px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.l1{background:linear-gradient(135deg,#fc4c02,#f17a1f)}.l2{background:linear-gradient(135deg,#007dc5,#00a3e0)}.l3{background:linear-gradient(135deg,#e1251b,#ff5a52)}.l4{background:linear-gradient(135deg,#00a8e0,#0073bb)}.l5{background:linear-gradient(135deg,#2d7ae0,#1a5cb5)}.l6{background:linear-gradient(135deg,#6ab04c,#4a9030)}
.sname{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:clamp(.75rem,.9vw,1rem)}
.sdesc{font-size:.67rem;color:var(--muted);margin-top:1px}
.sstatus{margin-left:auto;font-family:'Barlow Condensed',sans-serif;font-size:.54rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:2px 7px;border-radius:100px;flex-shrink:0}
.sl{background:rgba(0,201,167,.1);color:var(--teal);border:1px solid rgba(0,201,167,.2)}
.sb2{background:rgba(245,166,35,.1);color:var(--amber);border:1px solid rgba(245,166,35,.2)}
.sync-vis{background:var(--card);border:1px solid var(--border);border-radius:11px;padding:32px;text-align:center;position:relative;overflow:hidden}
.sv-rw{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}
.sv-r{position:absolute;border-radius:50%;border:1px solid rgba(245,166,35,.06);animation:svR 4s ease-out infinite}
.sv-r:nth-child(1){width:90px;height:90px}.sv-r:nth-child(2){width:170px;height:170px;animation-delay:1.3s}.sv-r:nth-child(3){width:260px;height:260px;animation-delay:2.6s}
@keyframes svR{0%{opacity:.45;transform:scale(.85)}100%{opacity:0;transform:scale(1.1)}}
.sconn-btn{margin-left:auto;font-family:'Barlow Condensed',sans-serif;font-size:.58rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:4px 10px;border-radius:100px;border:1px solid rgba(245,166,35,.35);color:var(--amber);background:rgba(245,166,35,.08);white-space:nowrap;flex-shrink:0;transition:all .2s}
.scard:hover .sconn-btn{background:var(--amber);color:#0d1b2a;border-color:var(--amber)}
.scard.sc-connected .sconn-btn{background:rgba(0,201,167,.12);color:var(--teal);border-color:rgba(0,201,167,.3)}
.scard.sc-connected{border-color:rgba(0,201,167,.3)!important}
@keyframes scPulse{50%{opacity:.4}}

/* JERSEYS */
.jersey-sec{padding:90px 0 72px}
.jhead{display:flex;justify-content:space-between;align-items:flex-end;padding:0 48px;margin-bottom:46px}
.hs-out{overflow-x:auto}
.hs-track{display:flex;flex-direction:row;flex-wrap:nowrap;gap:0;width:100%;cursor:default}
.jcard{flex:1 1 0;min-width:220px;border-right:1px solid var(--border);display:flex;flex-direction:column}
.jcard:last-child{border-right:none}
.jcity{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;letter-spacing:.05em;line-height:1;margin-bottom:4px}
.jtag{font-family:'Barlow Condensed',sans-serif;font-style:italic;font-size:.75rem;color:var(--muted);margin-bottom:12px;line-height:1.5}
.prow{display:flex;align-items:center;gap:9px;margin-bottom:11px}
.pret{font-family:'Barlow Condensed',sans-serif;font-size:.75rem;text-decoration:line-through;color:var(--muted)}
.pmem{font-family:'Bebas Neue',sans-serif;font-size:1.85rem;color:var(--amber);line-height:1}
.ptag{background:rgba(0,201,167,.13);border:1px solid rgba(0,201,167,.26);border-radius:100px;padding:3px 8px;font-family:'Barlow Condensed',sans-serif;font-size:.54rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--teal)}
.jbtn{width:100%;background:var(--amber);color:#0d1b2a;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;padding:10px;border:none;cursor:pointer;border-radius:3px;transition:background .2s}
.jbtn:hover{background:var(--amber2)}
.hs-nav{display:flex;justify-content:center;gap:9px;margin-top:18px}
.jersey-3d-wrap{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;padding:14px 12px 10px}
.jersey-3d-wrap canvas{display:block;cursor:grab;filter:drop-shadow(0 16px 40px rgba(0,0,0,.7));transition:transform .2s}
.jersey-3d-wrap canvas:active{cursor:grabbing}
.j3d-hint{font-family:'Barlow Condensed',sans-serif;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-top:8px;text-align:center;animation:hintFade 3s 2s forwards}
.j-info-wrap{padding:16px 20px 22px;display:flex;flex-direction:column;align-items:center;text-align:center}
@keyframes hintFade{to{opacity:0}}

/* AFFILIATES */
.aff-sec{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.aff-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:13px;margin-top:44px}
.acard{background:var(--card);border:1px solid var(--border);border-radius:9px;padding:24px 20px;position:relative;overflow:hidden;transition:transform .2s}
.acard:hover{transform:translateY(-2px)}
.atag{position:absolute;top:13px;right:13px;font-family:'Barlow Condensed',sans-serif;font-size:.55rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 7px;border-radius:100px;background:rgba(245,166,35,.12);color:var(--amber);border:1px solid rgba(245,166,35,.22)}
.acat{font-family:'Barlow Condensed',sans-serif;font-size:.58rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.adot{width:5px;height:5px;border-radius:50%}
.abrand{font-family:'Bebas Neue',sans-serif;font-size:clamp(1.2rem,1.6vw,1.8rem);letter-spacing:.06em;margin-bottom:5px}
.adesc{font-size:.8rem;line-height:1.6;color:var(--muted);margin-bottom:12px}
.asaving{display:flex;align-items:baseline;gap:6px;margin-bottom:10px}
.apct{font-family:'Bebas Neue',sans-serif;font-size:clamp(1.8rem,2.5vw,3rem);color:var(--teal);line-height:1}
.aoff{font-family:'Barlow Condensed',sans-serif;font-size:.76rem;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}
.amembers{font-size:.68rem;color:var(--muted);margin-bottom:16px}
.portal-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:var(--teal);color:#0d1b2a;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.73rem;letter-spacing:.12em;text-transform:uppercase;padding:11px;border:none;cursor:pointer;border-radius:4px;transition:background .2s}
.portal-how{font-family:'Barlow Condensed',sans-serif;font-size:.58rem;letter-spacing:.07em;color:var(--muted);margin-top:8px}
.pe-box{background:rgba(0,201,167,.04);border:1px solid rgba(0,201,167,.14);border-radius:7px;padding:18px 22px;margin-bottom:26px}
.pe-title{font-family:'Barlow Condensed',sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--teal);margin-bottom:12px;display:flex;align-items:center;gap:7px}
.pe-steps{display:flex;gap:0}
.pe-step{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;padding:0 6px}
.pe-step:not(:last-child)::after{content:'→';position:absolute;right:-9px;top:11px;font-size:.75rem;color:var(--muted)}
.pe-n{width:26px;height:26px;border-radius:50%;background:rgba(0,201,167,.14);border:1px solid rgba(0,201,167,.28);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:.85rem;color:var(--teal);margin:0 auto 6px}
.pe-t{font-size:.67rem;color:var(--muted);line-height:1.4}
.join-banner{background:linear-gradient(130deg,rgba(245,166,35,.07),rgba(0,201,167,.05));border:1px solid rgba(245,166,35,.17);border-radius:9px;padding:22px 26px;display:flex;align-items:center;justify-content:space-between;gap:18px;margin-top:18px}
.jb-txt{font-family:'Barlow Condensed',sans-serif;font-size:.92rem;font-weight:500}
.jb-txt strong{color:var(--amber)}
.btn-teal{background:var(--teal);color:#0d1b2a;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;padding:11px 24px;border:none;cursor:pointer;border-radius:3px;transition:background .2s;white-space:nowrap}

/* INSURANCE */
.ins-grid{display:grid;grid-template-columns:1fr;max-width:560px;gap:52px;margin-top:48px}
.ins-card{background:var(--card);border:1px solid var(--border);border-radius:11px;padding:32px;position:relative;overflow:hidden}
.ins-card::before{content:'';position:absolute;top:-45px;right:-45px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(245,166,35,.07) 0%,transparent 70%)}
.ins-shield{font-size:2.6rem;margin-bottom:14px;display:block}
.ins-title{font-family:'Bebas Neue',sans-serif;font-size:1.8rem;letter-spacing:.05em;margin-bottom:9px}
.ins-list{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:24px}
.ins-list li{display:flex;align-items:flex-start;gap:9px;font-size:.84rem;line-height:1.55}
.ins-chk{width:17px;height:17px;border-radius:50%;background:rgba(0,201,167,.13);color:var(--teal);display:flex;align-items:center;justify-content:center;font-size:.52rem;flex-shrink:0;margin-top:1px}

/* PASSPORT */
.pass-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-top:48px}
.pb-book{background:linear-gradient(145deg,#162e4a,#0f2036);border:1px solid rgba(0,201,167,.17);border-radius:10px;padding:34px;position:relative;overflow:hidden;box-shadow:0 28px 72px rgba(0,0,0,.42)}
.pb-book::before{content:'';position:absolute;left:0;top:0;bottom:0;width:6px;background:linear-gradient(to bottom,var(--teal),rgba(0,201,167,.28));border-radius:10px 0 0 10px}
.pb-hdr{font-family:'Barlow Condensed',sans-serif;font-size:.58rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--teal);margin-bottom:20px;padding-left:13px}
.sg{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-bottom:24px}
.stamp{aspect-ratio:1;border-radius:7px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:transform .2s}
.stamp:hover{transform:scale(1.05)}
.stamp.on{background:rgba(0,201,167,.09);border:1px solid rgba(0,201,167,.23)}
.stamp.off{background:rgba(255,255,255,.02);border:1px dashed rgba(255,255,255,.09)}
.st-em{font-size:1.4rem}
.st-nm{font-family:'Barlow Condensed',sans-serif;font-size:.55rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.stamp.on .st-nm{color:var(--teal)}
.stamp.off .st-nm{color:rgba(255,255,255,.14)}
.ach-list{display:flex;flex-direction:column}
.ach-row{display:flex;align-items:center;gap:11px;padding:11px 0;border-bottom:1px solid rgba(37,64,96,.55)}
.ach-row:last-child{border-bottom:none}
.ach-ic{width:31px;height:31px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.88rem;flex-shrink:0}
.ach-nm{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:.85rem}
.ach-sb{font-size:.66rem;color:var(--muted);margin-top:1px}
.ach-pill{margin-left:auto;font-family:'Barlow Condensed',sans-serif;font-size:.53rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:2px 7px;border-radius:100px;flex-shrink:0}
.apy{background:rgba(0,201,167,.11);color:var(--teal);border:1px solid rgba(0,201,167,.2)}
.app{background:rgba(245,166,35,.1);color:var(--amber);border:1px solid rgba(245,166,35,.2)}

/* MEMBERSHIP */
.mem-sec{background:var(--bg2);border-top:1px solid var(--border)}
.mem-cards{display:grid;grid-template-columns:1fr 1.07fr;gap:13px;margin-top:44px}
.mcard{background:var(--card);border:1px solid var(--border);border-radius:11px;padding:36px 32px}
.mcard.feat{background:linear-gradient(148deg,#183858,#1a2e4a);border-color:var(--amber);position:relative;overflow:hidden}
.mcard.feat::before{content:'';position:absolute;top:-65px;right:-65px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(245,166,35,.08) 0%,transparent 70%)}
.mem-badge{position:absolute;top:-1px;right:22px;background:var(--amber);color:#0d1b2a;font-family:'Barlow Condensed',sans-serif;font-size:.56rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:4px 11px;border-radius:0 0 5px 5px}
.mem-lbl{font-family:'Barlow Condensed',sans-serif;font-size:.63rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.mem-pr-row{display:flex;align-items:baseline;gap:4px;margin-bottom:5px}
.mem-price{font-family:'Bebas Neue',sans-serif;font-size:5rem;line-height:.9;letter-spacing:.02em}
.mem-ps{font-size:.8rem;color:var(--muted)}
.mem-period{font-size:.74rem;color:var(--muted);margin-bottom:18px}
.mem-val{background:rgba(245,166,35,.05);border:1px solid rgba(245,166,35,.13);border-radius:5px;padding:10px 13px;margin-bottom:20px;font-size:.78rem;color:var(--muted);line-height:1.6}
.mem-val strong{color:var(--amber)}
.mem-perks{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:32px}
.mem-perks li{display:flex;align-items:flex-start;gap:9px;font-size:.84rem;line-height:1.5}
.pchk{width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.5rem;flex-shrink:0;margin-top:1px}
.pcy{background:rgba(0,201,167,.13);color:var(--teal)}
.pcn{background:rgba(255,255,255,.04);color:rgba(255,255,255,.17)}
.perk-no{opacity:.27}
.btn-teal-full{width:100%;background:var(--teal);color:#0d1b2a;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;padding:15px;border:none;cursor:pointer;border-radius:4px;transition:background .2s}
.btn-out-full{width:100%;background:transparent;color:var(--text);font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;padding:14px;border:1px solid var(--border);cursor:pointer;border-radius:4px;transition:border-color .2s}
.btn-out-full:hover{border-color:rgba(238,242,247,.36)}

/* CTA */
.cta-sec{position:relative;overflow:hidden;padding:130px 0;text-align:center}
.cta-sec::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(245,166,35,.08) 0%,transparent 70%)}
.cta-sec::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(245,166,35,.033) 1px,transparent 1px),linear-gradient(90deg,rgba(245,166,35,.033) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 0%,transparent 100%)}
.cta-inner{position:relative;z-index:2;max-width:640px;margin:0 auto;padding:0 40px}
.cta-sub{font-size:.94rem;line-height:1.76;color:var(--muted);margin:17px 0 38px}

footer{background:var(--bg);border-top:1px solid var(--border);padding:24px 48px;display:flex;justify-content:space-between;align-items:center}
.fc{font-size:.66rem;letter-spacing:.05em;color:var(--muted)}

/* CHAIN NAV */
.chain-bar{
  position:sticky;top:90px;z-index:90;
  background:rgba(10,18,28,.97);
  backdrop-filter:blur(12px);
  border-bottom:2px solid rgba(245,166,35,.15);
  display:flex;
  padding:6px 0;
}
.chain-tabs{display:flex;align-items:center;width:100%;gap:0}

.ctab-nav{
  flex:1;display:flex;align-items:center;justify-content:center;
  position:relative;
  /* Chain plate height */
  height:34px;
  margin:0 10px; /* gap between plates — this is where pins sit */
  padding:0 8px;
  cursor:pointer;outline:none;white-space:nowrap;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:clamp(.55rem,.75vw,.85rem);
  letter-spacing:.14em;text-transform:uppercase;
  color:rgba(210,200,165,.85);
  transition:color .15s,background .15s,border-color .15s;
  /* Plate shape: amber outline, rounded ends like a chain outer plate */
  background:rgba(245,166,35,.07);
  border:2px solid rgba(245,166,35,.35);
  border-radius:17px;
  /* Indent the long sides slightly to mimic chain plate waist */
  box-shadow:inset 0 4px 0 rgba(0,0,0,.25), inset 0 -4px 0 rgba(0,0,0,.25);
}

/* Left roller pin — sits in the gap before each plate */
.ctab-nav::before{
  content:'';
  position:absolute;
  left:-12px;top:50%;transform:translateY(-50%);
  width:14px;height:14px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%, #ffd966, #c07800);
  border:2px solid #8a5000;
  box-shadow:0 2px 4px rgba(0,0,0,.6), inset 0 1px 2px rgba(255,255,255,.2);
  z-index:3;
}

/* Right roller pin — sits after each plate */
.ctab-nav::after{
  content:'';
  position:absolute;
  right:-12px;top:50%;transform:translateY(-50%);
  width:14px;height:14px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%, #ffd966, #c07800);
  border:2px solid #8a5000;
  box-shadow:0 2px 4px rgba(0,0,0,.6), inset 0 1px 2px rgba(255,255,255,.2);
  z-index:3;
}

.ctab-nav:hover{
  color:#fff;
  background:rgba(245,166,35,.15);
  border-color:rgba(245,166,35,.7);
}

.ctab-nav.active{
  background:var(--amber);
  color:#0d1b2a;
  border-color:#c07800;
  font-weight:800;
  box-shadow:inset 0 4px 0 rgba(0,0,0,.2), inset 0 -4px 0 rgba(0,0,0,.2), 0 0 12px rgba(245,166,35,.3);
}
.ctab-nav.active::before,
.ctab-nav.active::after{
  background:radial-gradient(circle at 35% 35%, #c07800, #6b3800);
  border-color:#4a2800;
}
.tab-panels{position:relative}
.tab-panel{display:none}
.tab-panel.tab-active{display:block}

/* CITY MAP */
.city-map-wrap{padding:0;border-top:1px solid var(--border)}
.city-map{height:340px;width:100%;background:var(--bg)}
.leaflet-container{background:#0d1b2a!important}
.leaflet-popup-content-wrapper{background:#1c3050;border:1px solid #254060;border-radius:8px;color:#eef2f7;box-shadow:0 8px 32px rgba(0,0,0,.5)}
.leaflet-popup-tip{background:#1c3050}
.leaflet-popup-content{font-family:'Barlow Condensed',sans-serif;font-size:.85rem;line-height:1.5;margin:10px 14px}
.leaflet-popup-content strong{font-size:1rem;display:block;margin-bottom:3px;color:#f5a623}
.leaflet-popup-content span{color:#7a9ab8;font-size:.72rem;letter-spacing:.05em}
.leaflet-popup-close-button{color:#7a9ab8!important}
.nrn-pin{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;border:2px solid rgba(255,255,255,.2);box-shadow:0 3px 12px rgba(0,0,0,.5);cursor:pointer}


.rides-city-header{display:flex;align-items:center;gap:14px;margin-bottom:20px;padding-bottom:14px;border-bottom:2px solid rgba(245,166,35,.18);margin-top:52px}
.rides-city-header:first-child{margin-top:0}
.rides-city-emoji{font-size:2rem;line-height:1}
.rides-city-name{font-family:'Bebas Neue',sans-serif;font-size:2rem;letter-spacing:.06em;line-height:1;margin-bottom:3px}
.rides-city-sub{font-family:'Barlow Condensed',sans-serif;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--amber)}

/* RIDES */
.rides-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:52px 48px;max-width:1240px;margin:0 auto}
.ride-card{background:var(--card);border:1px solid var(--border);border-radius:9px;padding:20px;cursor:pointer;transition:transform .18s,border-color .18s;position:relative;overflow:hidden}
.ride-card:hover{transform:translateY(-3px);border-color:rgba(245,166,35,.3)}
.ride-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.ride-road::before{background:var(--teal)}.ride-gravel::before{background:var(--amber)}.ride-mtb::before{background:var(--coral)}
.ride-type{font-family:'Barlow Condensed',sans-serif;font-size:.56rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;margin-bottom:8px}
.ride-type-road{color:var(--teal)}.ride-type-gravel{color:var(--amber)}.ride-type-mtb{color:var(--coral)}
.ride-name{font-family:'Bebas Neue',sans-serif;font-size:1.3rem;letter-spacing:.04em;line-height:1;margin-bottom:4px}
.ride-meta{font-size:.72rem;color:var(--muted);margin-bottom:12px}
.ride-info{display:flex;gap:14px}
.ride-stat{text-align:center}
.ride-stat-n{font-family:'Bebas Neue',sans-serif;font-size:1.3rem;color:var(--text);line-height:1}
.ride-stat-l{font-size:.5rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.ride-rsvp{margin-top:12px;width:100%;background:rgba(0,201,167,.1);border:1px solid rgba(0,201,167,.25);color:var(--teal);font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;padding:8px;border-radius:4px;cursor:pointer;transition:all .18s}
.ride-rsvp:hover,.ride-rsvp.rsvpd{background:var(--teal);color:#0d1b2a}

/* ROUTES */
.routes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:52px 48px;max-width:1240px;margin:0 auto}
.route-card{background:var(--card);border:1px solid var(--border);border-radius:9px;overflow:hidden;cursor:pointer;transition:transform .18s,border-color .18s}
.route-card:hover{transform:translateY(-3px);border-color:rgba(77,184,255,.3)}
.route-map{height:110px;position:relative;overflow:hidden;background:var(--bg)}
.route-body{padding:16px}
.route-name{font-family:'Bebas Neue',sans-serif;font-size:1.2rem;letter-spacing:.04em;margin-bottom:3px}
.route-city{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);margin-bottom:10px}
.route-stats{display:flex;gap:16px;margin-bottom:12px}
.rstat{font-size:.72rem;color:var(--muted)}
.rstat strong{color:var(--text);font-family:'Barlow Condensed',sans-serif;font-size:.9rem}
.route-chips{display:flex;gap:5px}
.route-chip{font-size:.52rem;letter-spacing:.08em;text-transform:uppercase;padding:2px 7px;border-radius:100px;background:rgba(77,184,255,.1);color:var(--sky);border:1px solid rgba(77,184,255,.2)}
.route-save{margin-top:12px;width:100%;background:rgba(77,184,255,.08);border:1px solid rgba(77,184,255,.2);color:var(--sky);font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;padding:8px;border-radius:4px;cursor:pointer;transition:all .18s}
.route-save:hover,.route-save.saved{background:var(--sky);color:#0d1b2a}

/* RACES */
.races-list{max-width:900px;margin:0 auto;padding:52px 48px;display:flex;flex-direction:column;gap:13px}
.race-row{background:var(--card);border:1px solid var(--border);border-radius:9px;padding:22px 24px;display:flex;align-items:center;gap:20px;cursor:pointer;transition:border-color .18s,transform .15s}
.race-row:hover{border-color:rgba(245,166,35,.3);transform:translateX(3px)}
.race-date{text-align:center;min-width:52px}
.race-month{font-family:'Barlow Condensed',sans-serif;font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--amber)}
.race-day{font-family:'Bebas Neue',sans-serif;font-size:2rem;line-height:1;color:var(--text)}
.race-divider{width:1px;height:48px;background:var(--border);flex-shrink:0}
.race-info{flex:1}
.race-name{font-family:'Bebas Neue',sans-serif;font-size:1.3rem;letter-spacing:.04em;margin-bottom:2px}
.race-sub{font-size:.74rem;color:var(--muted)}
.race-tags{display:flex;gap:5px;margin-top:7px}
.race-tag{font-size:.52rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:2px 7px;border-radius:100px}
.rtg-r{background:rgba(0,201,167,.1);color:var(--teal);border:1px solid rgba(0,201,167,.2)}
.rtg-m{background:rgba(255,107,91,.1);color:var(--coral);border:1px solid rgba(255,107,91,.2)}
.race-dist{text-align:right;min-width:80px}
.race-mi{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;color:var(--text);line-height:1}
.race-mi-l{font-size:.52rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.race-reg{margin-top:10px;background:var(--amber);color:#0d1b2a;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;padding:7px 16px;border:none;border-radius:3px;cursor:pointer;white-space:nowrap;transition:background .15s}
.race-reg:hover{background:var(--amber2)}
.race-reg.registered{background:var(--teal);color:#0d1b2a}

/* PARTNERS */
.partners-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:52px 48px;max-width:1240px;margin:0 auto}
.partner-card{background:var(--card);border:1px solid var(--border);border-radius:9px;padding:22px 18px;text-align:center;cursor:pointer;transition:transform .18s,border-color .18s}
.partner-card:hover{transform:translateY(-3px);border-color:rgba(245,166,35,.3)}
.partner-logo{font-size:2.2rem;margin-bottom:10px;display:block}
.partner-name{font-family:'Bebas Neue',sans-serif;font-size:1.1rem;letter-spacing:.06em;margin-bottom:4px}
.partner-cat{font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.partner-disc{font-family:'Bebas Neue',sans-serif;font-size:1.8rem;color:var(--teal);line-height:1;margin-bottom:4px}
.partner-off{font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.partner-btn{width:100%;background:rgba(0,201,167,.1);border:1px solid rgba(0,201,167,.25);color:var(--teal);font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;padding:8px;border-radius:4px;cursor:pointer;transition:all .18s}
.partner-btn:hover{background:var(--teal);color:#0d1b2a}

/* STORE */
.store-hero{padding:52px 48px;max-width:1240px;margin:0 auto;text-align:center}
.store-coming{font-size:.84rem;color:var(--muted);margin-bottom:32px;line-height:1.7;max-width:520px;margin-left:auto;margin-right:auto}
.store-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:32px}
.store-cat{background:var(--card);border:1px solid var(--border);border-radius:9px;padding:24px 18px;cursor:pointer;transition:transform .18s,border-color .18s}
.store-cat:hover{transform:translateY(-3px);border-color:rgba(245,166,35,.3)}
.store-cat-ic{font-size:2rem;margin-bottom:10px;display:block}
.store-cat-name{font-family:'Bebas Neue',sans-serif;font-size:1.15rem;letter-spacing:.06em;margin-bottom:4px}
.store-cat-sub{font-size:.68rem;color:var(--muted);line-height:1.5}

/* OAUTH MODAL */
#sync-modal{position:fixed;inset:0;z-index:999;display:none;align-items:center;justify-content:center;padding:20px}
#sync-modal.open{display:flex}
#sync-modal-bg{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(4px)}
#sync-modal-box{position:relative;z-index:1;background:#0f1f32;border:1px solid #254060;border-radius:14px;width:100%;max-width:400px;overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,.7);animation:smIn .22s ease-out}
@keyframes smIn{from{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}
.sm-header{padding:22px 24px 18px;border-bottom:1px solid #1a2e44;display:flex;align-items:center;gap:14px}
.sm-logo{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.sm-titles{flex:1}
.sm-app{font-family:'Bebas Neue',sans-serif;font-size:1.35rem;letter-spacing:.05em;line-height:1;margin-bottom:2px}
.sm-sub{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.sm-close{width:28px;height:28px;border-radius:50%;background:#1a2e44;border:none;color:#7a9ab8;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,color .15s}
.sm-close:hover{background:var(--amber);color:#0d1b2a}
.sm-screen{padding:22px 24px;display:none}
.sm-screen.sm-active{display:block}
.sm-nrn-badge{display:flex;align-items:center;gap:9px;background:rgba(245,166,35,.07);border:1px solid rgba(245,166,35,.15);border-radius:8px;padding:11px 14px;margin-bottom:18px}
.sm-nrn-icon{width:32px;height:32px;border-radius:7px;background:rgba(245,166,35,.12);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.sm-nrn-txt{font-size:.75rem;color:var(--muted);line-height:1.5}
.sm-nrn-txt strong{color:var(--text)}
.sm-perms{margin-bottom:20px}
.sm-perms-title{font-family:'Barlow Condensed',sans-serif;font-size:.58rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.sm-perm{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:1px solid rgba(37,64,96,.5)}
.sm-perm:last-child{border-bottom:none}
.sm-perm-ic{width:28px;height:28px;border-radius:6px;background:rgba(0,201,167,.1);display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0;margin-top:1px}
.sm-perm-name{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:.82rem;line-height:1.2;margin-bottom:2px}
.sm-perm-desc{font-size:.65rem;color:var(--muted);line-height:1.4}
.sm-auth-btn{width:100%;padding:13px;border:none;cursor:pointer;border-radius:6px;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px;transition:all .2s}
.sm-auth-primary{color:#0d1b2a}
.sm-auth-secondary{background:transparent;border:1px solid #254060;color:var(--muted)}
.sm-auth-secondary:hover{border-color:rgba(255,255,255,.25);color:var(--text)}
.sm-fine{font-size:.6rem;color:var(--muted);text-align:center;line-height:1.6;margin-top:10px}
.sm-loading{text-align:center;padding:12px 0 8px}
.sm-spinner{width:40px;height:40px;border-radius:50%;border:3px solid rgba(255,255,255,.08);border-top-color:var(--teal);animation:spin .7s linear infinite;margin:0 auto 16px}
@keyframes spin{to{transform:rotate(360deg)}}
.sm-load-title{font-family:'Bebas Neue',sans-serif;font-size:1.2rem;letter-spacing:.06em;margin-bottom:6px}
.sm-load-steps{list-style:none;text-align:left;display:flex;flex-direction:column;gap:6px;margin:16px 0}
.sm-step{display:flex;align-items:center;gap:9px;font-size:.74rem;color:var(--muted);transition:color .3s}
.sm-step.done{color:var(--teal)}
.sm-step.active{color:var(--text)}
.sm-step-ic{width:18px;height:18px;border-radius:50%;border:1.5px solid #254060;display:flex;align-items:center;justify-content:center;font-size:.55rem;flex-shrink:0;transition:all .3s}
.sm-step.done .sm-step-ic{background:var(--teal);border-color:var(--teal);color:#0d1b2a}
.sm-step.active .sm-step-ic{border-color:var(--text);animation:scPulse .8s infinite}
.sm-success{text-align:center;padding:8px 0}
.sm-check{width:52px;height:52px;border-radius:50%;background:rgba(0,201,167,.13);border:2px solid rgba(0,201,167,.3);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:1.4rem}
.sm-conn-title{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;letter-spacing:.06em;margin-bottom:6px}
.sm-conn-sub{font-size:.76rem;color:var(--muted);line-height:1.6;margin-bottom:18px}
.sm-conn-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:20px}
.sm-stat{background:rgba(255,255,255,.04);border:1px solid #1a2e44;border-radius:7px;padding:10px 8px;text-align:center}
.sm-stat-n{font-family:'Bebas Neue',sans-serif;font-size:1.4rem;color:var(--teal);line-height:1}
.sm-stat-l{font-size:.52rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:2px}
.sm-disconnect{width:100%;background:none;border:1px solid rgba(255,107,91,.2);color:rgba(255,107,91,.7);font-family:'Barlow Condensed',sans-serif;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;padding:9px;border-radius:5px;cursor:pointer;transition:all .2s}
.sm-disconnect:hover{background:rgba(255,107,91,.08);color:var(--coral);border-color:var(--coral)}

/* MAP PANEL STYLES */
#nrn-map-svg.nrn-dragging{cursor:grabbing!important}
.nrn-state{fill:#17304a;stroke:#0d1b2a;stroke-width:0.7;cursor:pointer;transition:fill .15s}
.nrn-state:hover{fill:#1e3d5c}
.nrn-state.nrn-active-state{fill:#1c3d52;stroke:#00c9a7;stroke-width:1.2}
.nrn-pin-group{cursor:pointer}
@keyframes nrn-pulse{0%{r:13;opacity:.5}100%{r:28;opacity:0}}
.nrn-pulse{animation:nrn-pulse 2.5s ease-out infinite}
.nrn-pulse2{animation:nrn-pulse 2.5s ease-out 1.2s infinite}
.nrn-zc-btn{width:28px;height:28px;background:rgba(8,16,28,.88);border:1px solid #254060;border-radius:4px;color:#c8d8e8;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;font-family:'Barlow Condensed',sans-serif}
.nrn-zc-btn:hover{background:rgba(245,166,35,.15);border-color:#f5a623;color:#f5a623}
#nrn-back-btn.nrn-show{opacity:1!important;pointer-events:auto!important}
#nrn-back-btn:hover{border-color:#4a7090;color:#c8d8e8}
.nrn-close-x{position:absolute;width:26px;height:26px;border-radius:50%;background:#1a3050;border:1.5px solid #3a5570;color:#aac;font-size:12px;font-weight:700;display:none;align-items:center;justify-content:center;z-index:200;cursor:pointer;transition:background .15s,color .15s;font-family:'Barlow Condensed',sans-serif}
.nrn-close-x:hover{background:#f5a623;border-color:#f5a623;color:#0d1b2a}
#nrn-req-panel{position:absolute;background:rgba(8,16,28,.98);border:1px solid #254060;border-radius:8px;width:244px;z-index:50;pointer-events:auto;display:none;font-family:'Barlow Condensed',sans-serif;overflow:visible;box-shadow:0 12px 40px rgba(0,0,0,.6)}
.nrn-drag-grip{display:flex;flex-direction:column;gap:3px;opacity:.3;flex-shrink:0;padding:2px 0}
.nrn-drag-grip span{display:block;width:16px;height:1.5px;background:#c8d8e8;border-radius:1px}
.nrn-panel-head-inner{flex:1}
#nrn-city-tip{position:absolute;background:rgba(8,16,28,.97);border:1px solid #254060;border-left:3px solid #f5a623;border-radius:0 8px 8px 8px;padding:14px 13px;width:210px;z-index:50;pointer-events:auto;display:none;font-family:'Barlow Condensed',sans-serif}
.nrn-panel-head{padding:13px 14px 11px;border-bottom:1px solid #1a2e44;border-radius:8px 8px 0 0}
.nrn-panel-flag{font-size:.5rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:#00c9a7;margin-bottom:3px}
.nrn-panel-sname{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;letter-spacing:.05em;color:#eef2f7;line-height:1}
.nrn-screen{padding:13px 14px 14px}
.nrn-out{display:none}
.nrn-s1-prompt{font-size:.62rem;letter-spacing:.08em;color:#7a9ab8;margin-bottom:9px;line-height:1.5}
.nrn-city-input{width:100%;background:rgba(255,255,255,.05);border:1px solid #254060;border-radius:4px;padding:8px 10px;color:#eef2f7;font-family:'Barlow Condensed',sans-serif;font-size:.9rem;outline:none;margin-bottom:6px}
.nrn-city-input:focus{border-color:#00c9a7}
.nrn-city-input::placeholder{color:#3d5a72}
.nrn-dropdown{background:#0d1e30;border:1px solid #254060;border-radius:4px;max-height:180px;overflow-y:auto;margin-bottom:8px;display:none;position:relative;z-index:60}
.nrn-dropdown.nrn-open{display:block}
.nrn-drop-item{padding:8px 10px;font-size:.82rem;color:#c8d8e8;cursor:pointer;border-bottom:1px solid rgba(37,64,96,.4);transition:background .12s}
.nrn-drop-item:last-child{border-bottom:none}
.nrn-drop-item:hover,.nrn-drop-item.nrn-sel{background:rgba(0,201,167,.1);color:#00c9a7}
.nrn-drop-empty{padding:10px;font-size:.75rem;color:#4a6a88;text-align:center}
.nrn-vote-btn{width:100%;background:#f5a623;color:#0d1b2a;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;padding:9px;border:none;cursor:pointer;border-radius:4px;opacity:.38;pointer-events:none;transition:opacity .15s}
.nrn-vote-btn.nrn-ready{opacity:1;pointer-events:auto}
.nrn-vote-btn.nrn-ready:hover{background:#ffc04d}
.nrn-vote-count{font-size:.54rem;color:#3d5a72;margin-top:7px;text-align:center;min-height:14px}
.nrn-s2-badge{display:inline-block;background:rgba(245,166,35,.1);border:1px solid rgba(245,166,35,.22);border-radius:100px;padding:3px 10px;font-size:.58rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#f5a623;margin-bottom:8px}
.nrn-s2-confirm{font-family:'Bebas Neue',sans-serif;font-size:1.05rem;color:#eef2f7;line-height:1.2;margin-bottom:10px}
.nrn-divider{height:1px;background:#1a2e44;margin:10px 0}
.nrn-notify-row{display:flex;align-items:center;gap:10px;cursor:pointer;padding:2px 0 10px}
.nrn-nt-box{width:18px;height:18px;border-radius:4px;border:1.5px solid #254060;background:rgba(255,255,255,.04);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s}
.nrn-nt-box.nrn-on{background:#00c9a7;border-color:#00c9a7}
.nrn-nt-check{width:9px;height:6px;border-left:2px solid #0d1b2a;border-bottom:2px solid #0d1b2a;transform:rotate(-45deg) translate(1px,-1px);opacity:0;transition:opacity .12s}
.nrn-nt-box.nrn-on .nrn-nt-check{opacity:1}
.nrn-nt-label{font-size:.72rem;color:#c8d8e8;line-height:1.4}
.nrn-notify-fields{max-height:0;overflow:hidden;opacity:0;transition:max-height .25s,opacity .2s}
.nrn-notify-fields.nrn-open{max-height:130px;opacity:1}
.nrn-nf-input{width:100%;background:rgba(255,255,255,.05);border:1px solid #254060;border-radius:4px;padding:7px 10px;color:#eef2f7;font-family:'Barlow Condensed',sans-serif;font-size:.82rem;outline:none;margin-bottom:6px}
.nrn-nf-input:focus{border-color:#00c9a7}
.nrn-nf-input::placeholder{color:#3d5a72}
.nrn-nf-or{text-align:center;font-size:.55rem;letter-spacing:.14em;text-transform:uppercase;color:#3d5a72;margin:0 0 6px}
.nrn-done-btn{width:100%;background:#00c9a7;color:#0d1b2a;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;padding:9px;border:none;cursor:pointer;border-radius:4px}
.nrn-done-btn:hover{background:#00ddb8}
.nrn-skip-btn{width:100%;background:none;border:none;color:#3d5a72;font-family:'Barlow Condensed',sans-serif;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;padding:7px;cursor:pointer}
.nrn-skip-btn:hover{color:#7a9ab8}
.nrn-done-wrap{padding:18px 14px;text-align:center}
.nrn-done-circle{width:32px;height:32px;border-radius:50%;background:rgba(0,201,167,.15);border:1px solid rgba(0,201,167,.3);display:flex;align-items:center;justify-content:center;margin:0 auto 10px}
.nrn-done-tick{width:10px;height:7px;border-left:2px solid #00c9a7;border-bottom:2px solid #00c9a7;transform:rotate(-45deg) translate(1px,-1px)}
.nrn-done-title{font-family:'Bebas Neue',sans-serif;font-size:1.3rem;color:#eef2f7;margin-bottom:4px}
.nrn-done-sub{font-size:.65rem;color:#7a9ab8;line-height:1.6}
.nrn-t-city{font-family:'Bebas Neue',sans-serif;font-size:1.45rem;color:#eef2f7;line-height:1;margin-bottom:1px}
.nrn-t-sl{font-size:.55rem;letter-spacing:.22em;text-transform:uppercase;color:#f5a623;margin-bottom:9px}
.nrn-t-stats{display:grid;grid-template-columns:1fr 1fr;gap:5px;margin-bottom:9px}
.nrn-t-num{font-family:'Bebas Neue',sans-serif;font-size:1.55rem;line-height:1;color:#00c9a7}
.nrn-t-lbl{font-size:.48rem;letter-spacing:.12em;text-transform:uppercase;color:#7a9ab8;margin-top:1px}
.nrn-t-chips{display:flex;flex-wrap:wrap;gap:3px;margin-bottom:10px}
.nrn-chip{font-size:.52rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:2px 7px;border-radius:100px}
.nrn-cr{background:rgba(0,201,167,.13);color:#00c9a7;border:1px solid rgba(0,201,167,.28)}
.nrn-cg{background:rgba(245,166,35,.13);color:#f5a623;border:1px solid rgba(245,166,35,.28)}
.nrn-cm{background:rgba(255,107,91,.13);color:#ff6b5b;border:1px solid rgba(255,107,91,.28)}
.nrn-hub-btn{width:100%;background:#f5a623;color:#0d1b2a;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;padding:8px;border:none;cursor:pointer;border-radius:3px}
.nrn-hub-btn:hover{background:#ffc04d}
#nrn-hint{position:absolute;bottom:12px;left:14px;font-family:'Barlow Condensed',sans-serif;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:rgba(238,242,247,.28);pointer-events:none}

/* RESPONSIVE */
@media(max-width:900px){
  nav{padding:12px 18px}.nav-links{display:none}
  .wrap{padding:0 18px}
  .hero-copy,.jhead{padding-left:18px;padding-right:18px}
  .map-stage{padding:0!important}
  .city-ex,.sync-grid,.ins-grid,.pass-grid,.mem-cards{grid-template-columns:1fr}
  .cp-grid{grid-template-columns:1fr}
  .cpb:nth-child(even){border-right:none}
  .aff-grid,.sync-plat{grid-template-columns:1fr}
  footer{flex-direction:column;gap:9px;text-align:center}
  #nrn-map-wrap{border-radius:0!important;min-height:420px}
  .nrn-drag-grip{display:none!important}
  .nrn-zc-btn{width:36px!important;height:36px!important;font-size:18px!important}
  .nrn-close-x{display:none!important}
  #nrn-back-btn{font-size:.65rem!important;padding:6px 14px!important}
  #nrn-hint{font-size:8px!important}
  #nrn-req-panel{width:92vw!important;max-width:300px!important;max-height:82vh;overflow-y:auto!important;z-index:9999!important}
  .nrn-dropdown{max-height:130px!important}
  .nrn-city-input{font-size:16px!important;padding:11px!important}
  .nrn-vote-btn,.nrn-done-btn{padding:12px!important;font-size:.82rem!important}
  .nrn-panel-sname{font-size:1.6rem!important}
  #nrn-city-tip{width:92vw!important;max-width:260px!important;z-index:9999!important}
  .nrn-t-city{font-size:1.6rem!important}
  .nrn-t-num{font-size:1.6rem!important}
  .nrn-hub-btn{padding:12px!important;font-size:.82rem!important}
  .chain-bar{top:49px}
  .chain-tabs{overflow-x:auto;justify-content:flex-start;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .chain-tabs::-webkit-scrollbar{display:none}
  .ctab-nav{padding:0 14px;font-size:.68rem;letter-spacing:.12em}
  .rides-grid,.routes-grid,.partners-grid,.store-grid{grid-template-columns:1fr;padding:28px 18px}
  .races-list{padding:28px 18px}
  .partners-grid{grid-template-columns:1fr 1fr}
}