
:root{
  --navy:#071426;
  --navy2:#0d2038;
  --ink:#101828;
  --muted:#667085;
  --line:rgba(16,24,40,.12);
  --soft:#f6f8fb;
  --blue:#174d9f;
  --sky:#0ea5e9;
  --green:#0f9f6e;
  --red:#c01048;
  --shadow:0 22px 70px rgba(15,23,42,.14);
  --soft-shadow:0 14px 42px rgba(15,23,42,.08);
  --radius:26px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Avenir Next","Helvetica Neue",Arial,sans-serif;color:var(--ink);background:#fff}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
img{max-width:100%;display:block}
.shell{width:min(var(--max),calc(100% - 40px));margin:0 auto}
.nav-wrap{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.96);backdrop-filter:blur(18px);border-bottom:1px solid rgba(16,24,40,.08)}
.nav{min-height:76px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:12px;font-weight:850;letter-spacing:-.035em;font-size:1.12rem;color:var(--ink)}
.mark{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,var(--navy),#174d9f);color:#fff;box-shadow:0 12px 28px rgba(7,20,38,.22)}
.nav-links{display:flex;align-items:center;gap:18px;color:#344054;font-size:.88rem;font-weight:700}
.nav-links a:hover{color:var(--blue)}
.nav-actions{display:flex;gap:10px;align-items:center}
.btn{border:0;border-radius:999px;padding:13px 18px;font-weight:760;font-size:.92rem;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;white-space:nowrap;transition:.18s ease}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--navy);color:#fff;box-shadow:0 14px 34px rgba(7,20,38,.24)}
.btn-outline{background:#fff;color:var(--navy);border:1px solid var(--line);box-shadow:0 8px 24px rgba(15,23,42,.04)}
.btn-blue{background:linear-gradient(135deg,#174d9f,var(--sky));color:#fff;box-shadow:0 14px 34px rgba(31,94,255,.20)}
.menu-btn{display:none;width:44px;height:44px;border-radius:14px;border:1px solid var(--line);background:#fff;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:4px}
.menu-btn span{width:18px;height:2px;background:var(--ink);display:block;border-radius:999px}
.mobile-menu{display:none;position:absolute;top:76px;left:20px;right:20px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:16px;box-shadow:var(--shadow);gap:10px}
.mobile-menu a{padding:12px;border-radius:14px;background:var(--soft);font-weight:720;color:var(--ink)}
body.menu-open .mobile-menu{display:grid}
.hero{min-height:calc(100vh - 76px);position:relative;overflow:hidden;background:var(--navy);display:grid;align-items:center}
.hero.compact{min-height:560px}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transform:scale(1.04);transition:opacity 900ms ease,transform 7s ease}
.hero-slide.active{opacity:1;transform:scale(1)}
.hero:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,20,38,.95),rgba(7,20,38,.76) 45%,rgba(7,20,38,.20)),linear-gradient(180deg,rgba(7,20,38,.08),rgba(7,20,38,.52));pointer-events:none}
.hero-inner{position:relative;z-index:2;padding:72px 0 86px;color:#fff;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero.compact .hero-inner{grid-template-columns:1fr;max-width:960px}
.eyebrow{display:inline-flex;align-items:center;gap:9px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.17);color:rgba(255,255,255,.88);font-size:.82rem;font-weight:780;margin-bottom:18px}
.dot{width:8px;height:8px;border-radius:50%;background:#35d399;box-shadow:0 0 0 6px rgba(53,211,153,.18)}
h1{font-size:clamp(3rem,6.8vw,6.75rem);line-height:.91;letter-spacing:-.078em;margin:0;max-width:980px;color:#fff}
.hero-copy{margin:24px 0 0;max-width:800px;color:rgba(255,255,255,.82);font-size:clamp(1.06rem,1.6vw,1.28rem);line-height:1.62}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.hero-pills{display:flex;flex-wrap:wrap;gap:9px;margin-top:28px}
.pill{display:inline-flex;align-items:center;gap:7px;padding:8px 11px;border-radius:999px;background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.84);font-size:.82rem;font-weight:740}
.pass-panel{justify-self:end;width:min(440px,100%);background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:32px;padding:18px;box-shadow:0 28px 90px rgba(0,0,0,.30);backdrop-filter:blur(18px)}
.pass-card{background:#fff;color:var(--ink);border-radius:25px;overflow:hidden;box-shadow:var(--shadow)}
.pass-img{height:218px;background-size:cover;background-position:center;position:relative}
.pass-img:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(0,0,0,.62))}
.pass-img-text{position:absolute;z-index:1;left:16px;right:16px;bottom:16px;color:#fff}
.pass-img-text span{display:block;text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;font-weight:850;color:rgba(255,255,255,.82)}
.pass-img-text strong{display:block;font-size:1.34rem;line-height:1.05;letter-spacing:-.04em}
.pass-body{padding:18px}
.pass-row{display:flex;justify-content:space-between;gap:12px;color:var(--muted);font-size:.9rem;font-weight:720}
.timer{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin:14px 0}
.timer-cell{background:#f2f4f7;border-radius:16px;padding:12px;text-align:center}
.timer-cell b{font-size:1.4rem;letter-spacing:-.04em;display:block;color:var(--ink)}
.timer-cell span{display:block;margin-top:2px;color:var(--muted);font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;font-weight:820}
.hero-dots{position:absolute;z-index:3;left:50%;bottom:24px;transform:translateX(-50%);display:flex;gap:8px}
.hero-dot{width:42px;height:4px;border:0;border-radius:99px;background:rgba(255,255,255,.34);cursor:pointer}
.hero-dot.active{background:#fff}
.section{padding:86px 0;background:#fff;color:var(--ink)}
.section-soft{background:var(--soft);color:var(--ink)}
.section-navy{background:linear-gradient(135deg,var(--navy),var(--navy2));color:#fff}
.section h2,.section-soft h2{color:var(--ink)}
.section-navy h2,.section-navy h3{color:#fff}
.section-head{max-width:850px;margin-bottom:34px}
.center{text-align:center;margin-left:auto;margin-right:auto}
.kicker{font-size:.76rem;text-transform:uppercase;letter-spacing:.14em;font-weight:850;color:#174d9f;margin-bottom:10px}
.section-navy .kicker{color:#93c5fd}
h2{font-size:clamp(2.1rem,4.2vw,4.25rem);line-height:.98;letter-spacing:-.065em;margin:0}
.copy{margin:18px 0 0;color:var(--muted);font-size:1.05rem;line-height:1.68}
.center .copy{margin-left:auto;margin-right:auto}
.section-navy .copy{color:rgba(255,255,255,.76)}
.grid{display:grid;gap:20px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid rgba(17,24,39,.10);border-radius:var(--radius);padding:26px;box-shadow:var(--soft-shadow);overflow:hidden;color:var(--ink)}
.section-navy .card{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.12);box-shadow:none;color:#fff}
.icon{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;margin-bottom:18px;background:#eef4ff;color:#174d9f;font-size:1.35rem}
.card h3{margin:0;font-size:1.18rem;line-height:1.2;letter-spacing:-.035em;color:var(--ink)}
.section-navy .card h3{color:#fff}
.card p{margin:10px 0 0;color:var(--muted);line-height:1.58}
.section-navy .card p{color:rgba(255,255,255,.74)}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.tag{font-size:.78rem;font-weight:740;padding:7px 10px;border-radius:999px;background:#f2f4f7;color:#344054;border:1px solid rgba(17,24,39,.06)}
.section-navy .tag{color:rgba(255,255,255,.82);background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12)}
.image-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:20px}
.image-stack{display:grid;gap:20px}
.image-card{min-height:430px;border-radius:30px;overflow:hidden;position:relative;box-shadow:var(--shadow);background:#ddd}
.image-stack .image-card{min-height:205px}
.image-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.image-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.02),rgba(0,0,0,.62))}
.image-copy{position:absolute;z-index:1;left:24px;right:24px;bottom:24px;color:#fff}
.image-copy h3{font-size:1.5rem;letter-spacing:-.045em;margin:0;color:#fff}
.image-copy p{color:rgba(255,255,255,.84);line-height:1.5;margin:8px 0 0}
.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.step{background:#fff;border:1px solid rgba(17,24,39,.10);border-radius:22px;padding:22px;box-shadow:0 14px 38px rgba(15,23,42,.06);color:var(--ink)}
.num{width:34px;height:34px;border-radius:12px;background:var(--navy);color:#fff;display:grid;place-items:center;font-weight:850;margin-bottom:14px}
.step h3{font-size:1.02rem;letter-spacing:-.03em;margin:0;color:var(--ink)}
.step p{color:var(--muted);line-height:1.52;margin:8px 0 0;font-size:.94rem}
.idea-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.idea{background:#fff;border:1px solid rgba(17,24,39,.10);border-radius:22px;padding:18px;box-shadow:0 10px 28px rgba(15,23,42,.05);color:var(--ink)}
.idea span{display:inline-flex;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;font-weight:850;color:#174d9f;background:#eef4ff;padding:6px 8px;border-radius:999px;margin-bottom:10px}
.idea h3{margin:0;font-size:1rem;letter-spacing:-.03em;color:var(--ink)}
.idea p{margin:8px 0 0;color:var(--muted);line-height:1.48;font-size:.92rem}
.category-list{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.category-chip{background:#fff;border:1px solid rgba(17,24,39,.10);border-radius:18px;padding:16px;box-shadow:0 10px 28px rgba(15,23,42,.05);font-weight:760;color:#344054}
.category-chip span{display:block;font-size:1.35rem;margin-bottom:6px}
.persona-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.persona{background:#fff;border:1px solid rgba(17,24,39,.10);border-radius:24px;padding:22px;box-shadow:var(--soft-shadow)}
.persona h3{margin:0;color:var(--ink);letter-spacing:-.035em}
.persona p{color:var(--muted);line-height:1.55}
.standard-card,.network-card,.fair-card,.landscape-card{background:#fff;border:1px solid rgba(17,24,39,.10);border-radius:26px;padding:24px;box-shadow:0 14px 42px rgba(15,23,42,.07)}
.standard-card h3,.network-card h3,.fair-card h3,.landscape-card h3{margin:0;color:var(--ink);letter-spacing:-.035em}
.standard-card p,.network-card p,.fair-card p,.landscape-card p{color:var(--muted);line-height:1.58}
.check-list,.no-list{list-style:none;margin:18px 0 0;padding:0;display:grid;gap:10px;color:#344054;font-weight:680;font-size:.94rem;line-height:1.45}
.check-list li,.no-list li{display:grid;grid-template-columns:24px 1fr;gap:8px;align-items:start}
.check-list li:before{content:"✓";width:22px;height:22px;border-radius:999px;background:#ecfdf3;color:#027a48;display:grid;place-items:center;font-weight:900;font-size:.78rem}
.no-list li:before{content:"×";width:22px;height:22px;border-radius:999px;background:#fff1f3;color:#c01048;display:grid;place-items:center;font-weight:900;font-size:.9rem}
.inperson-rule{background:#f8fafc;border:1px solid rgba(16,24,40,.08);border-radius:28px;padding:28px;margin-top:22px}
.inperson-rule h3{margin:0;color:var(--ink);font-size:1.35rem;letter-spacing:-.04em}
.inperson-rule p{color:var(--muted);line-height:1.6}
.promise-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:24px}
.promise-item{background:#f8fafc;border:1px solid rgba(16,24,40,.08);border-radius:20px;padding:18px;color:var(--ink)}
.promise-item b{display:block;color:var(--ink);letter-spacing:-.025em}
.promise-item span{display:block;margin-top:7px;color:var(--muted);line-height:1.45;font-size:.92rem}
.comparison-wrap{margin-top:30px;background:#fff;border:1px solid rgba(17,24,39,.10);border-radius:32px;box-shadow:0 20px 58px rgba(15,23,42,.10);overflow:hidden}
.comparison-top{padding:22px 24px;background:linear-gradient(180deg,#fff,#f8fafc);border-bottom:1px solid rgba(17,24,39,.08);display:flex;justify-content:space-between;gap:18px;align-items:flex-end}
.comparison-top h3{margin:0;font-size:1.28rem;letter-spacing:-.04em;color:var(--ink)}
.comparison-top p{margin:6px 0 0;color:#667085;line-height:1.5;max-width:720px}
.comparison-badge{display:inline-flex;align-items:center;border-radius:999px;background:#071426;color:#fff;padding:8px 12px;font-weight:800;font-size:.78rem;white-space:nowrap}
.compare-row{display:grid;grid-template-columns:.85fr 1.1fr 1.25fr;border-bottom:1px solid rgba(17,24,39,.08)}
.compare-row:last-child{border-bottom:0}
.compare-row>div{padding:20px 22px;display:flex;flex-direction:column;justify-content:center;line-height:1.45;color:#475467}
.compare-row>div+div{border-left:1px solid rgba(17,24,39,.07)}
.compare-head{background:#f8fafc}
.compare-head>div{color:#111827;font-weight:850;font-size:.78rem;text-transform:uppercase;letter-spacing:.09em}
.compare-row b{color:#111827;letter-spacing:-.02em}
.gn-win{color:#0f5132!important;font-weight:740}
.gn-win:before{content:"✓";display:inline-grid;place-items:center;width:22px;height:22px;margin-right:8px;border-radius:999px;color:#fff;background:#0f9f6e;font-size:.78rem}
.impact-v2{display:grid;grid-template-columns:.82fr 1.18fr;gap:24px;align-items:start}
.formula-stack{display:grid;gap:12px;margin-top:24px}
.formula-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);border-radius:22px;padding:18px}
.formula-card b{display:block;color:#fff;letter-spacing:-.025em}
.formula-card code{display:block;margin-top:8px;color:#dbeafe;line-height:1.5;white-space:normal;font-size:.9rem}
.calc{background:#fff!important;color:#111827!important;border:1px solid rgba(17,24,39,.10);border-radius:30px;padding:24px;box-shadow:0 24px 70px rgba(15,23,42,.16)}
.calc *{color:#111827!important}
.calc h3{font-size:1.42rem;letter-spacing:-.045em;margin:0;color:#111827!important}
.calc-intro{color:#667085!important;line-height:1.55;margin:8px 0 0}
.calc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:20px 0}
.field label{display:block;font-size:.76rem;font-weight:850;color:#475467!important;margin-bottom:7px}
.field input{width:100%;border:1px solid rgba(17,24,39,.14);border-radius:15px;padding:13px 14px;outline:0;background:#fff!important;color:#111827!important;-webkit-text-fill-color:#111827!important;caret-color:#111827!important;box-shadow:0 4px 14px rgba(15,23,42,.04)}
.results{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.result{background:linear-gradient(180deg,#ffffff,#f8fafc)!important;border:1px solid rgba(17,24,39,.10)!important;border-radius:20px;padding:18px;min-height:100px}
.result.primary{background:linear-gradient(135deg,#071426,#0d2038)!important;border-color:rgba(7,20,38,.30)!important}
.result.primary b,.result.primary span{color:#fff!important}
.result b{display:block;font-size:1.62rem;letter-spacing:-.055em;color:#111827!important}
.result span{display:block;margin-top:4px;color:#667085!important;font-size:.8rem;font-weight:760;line-height:1.3}
.calc-note{margin-top:14px;padding:14px 16px;border-radius:18px;background:#f8fafc;border:1px solid rgba(17,24,39,.08);color:#667085!important;line-height:1.55;font-size:.9rem}
.calc-note b{color:#111827!important}
.calc-equation{margin-top:14px;color:#475467!important;font-size:.9rem;line-height:1.55}
.cta{border-radius:36px;background:linear-gradient(135deg,var(--navy),var(--navy2));color:#fff;padding:48px;display:grid;grid-template-columns:1fr .75fr;gap:28px;align-items:center;box-shadow:0 30px 90px rgba(7,20,38,.22)}
.cta h2{color:#fff}
.cta p{color:rgba(255,255,255,.74);line-height:1.62;margin:14px 0 0}
.form{display:grid;gap:10px}
.form input,.form select,.form textarea{width:100%;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.10);color:#fff;border-radius:14px;padding:14px 15px;outline:0}
.form input::placeholder,.form textarea::placeholder{color:rgba(255,255,255,.58)}
.form select option{color:var(--ink)}
.form textarea{min-height:92px;resize:vertical}
.footer{padding:54px 0 46px;background:#fff;border-top:1px solid rgba(17,24,39,.08)}
.footer-grid{display:grid;grid-template-columns:1.3fr repeat(4,1fr);gap:28px}
.footer-brand p{color:var(--muted);line-height:1.58;margin:14px 0 0;max-width:350px}
.footer .arns-line{color:#344054;font-weight:760;margin-top:10px}
.footer .arns-line span{color:#667085;font-weight:650}
.footer-col h4{margin:0 0 12px;font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;color:#475467}
.footer-col a{display:block;margin:9px 0;color:var(--muted);font-weight:650;font-size:.92rem}
.footer-bottom{margin-top:34px;padding-top:20px;border-top:1px solid rgba(17,24,39,.08);display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;color:var(--muted);font-size:.88rem}
.toast{position:fixed;right:22px;bottom:22px;background:var(--ink);color:#fff;border-radius:16px;padding:14px 16px;box-shadow:0 18px 48px rgba(15,23,42,.3);transform:translateY(28px);opacity:0;transition:all .25s ease;z-index:999;max-width:min(380px,calc(100vw - 44px));font-weight:720;pointer-events:none}
.toast.show{transform:translateY(0);opacity:1}
@media(max-width:1040px){.nav-links,.nav-actions{display:none}.menu-btn{display:inline-flex}.hero-inner,.image-grid,.impact-v2,.cta{grid-template-columns:1fr}.pass-panel{justify-self:start}.grid-4,.grid-3,.grid-2,.how-grid,.idea-grid,.persona-grid,.category-list,.footer-grid,.promise-grid{grid-template-columns:1fr 1fr}.calc-grid,.results{grid-template-columns:1fr 1fr}.compare-row{grid-template-columns:1fr}.compare-row>div+div{border-left:0;border-top:1px solid rgba(17,24,39,.07)}.comparison-top{align-items:flex-start;flex-direction:column}}
@media(max-width:720px){.shell{width:min(1180px,calc(100% - 28px))}.hero{min-height:auto}.hero-inner{padding:58px 0 86px}h1{font-size:clamp(2.7rem,16vw,4.3rem)}.section{padding:60px 0}.grid-4,.grid-3,.grid-2,.how-grid,.idea-grid,.persona-grid,.category-list,.footer-grid,.promise-grid,.calc-grid,.results{grid-template-columns:1fr}.image-card{min-height:320px}.image-stack .image-card{min-height:300px}.cta{padding:24px;border-radius:28px}.pass-img{height:180px}}


/* --- clean URL + community passport update --- */
.civic-band{background:#fff;color:#101828;border-top:1px solid rgba(16,24,40,.08);border-bottom:1px solid rgba(16,24,40,.08)}
.civic-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:stretch}
.civic-card{background:#fff;border:1px solid rgba(16,24,40,.10);border-radius:28px;padding:28px;box-shadow:0 16px 46px rgba(15,23,42,.07)}
.civic-card h3{margin:0;color:#101828;letter-spacing:-.04em;font-size:1.28rem}.civic-card p{color:#667085;line-height:1.62;margin:10px 0 0}
.path-flow{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:26px}.path-step{background:#f8fafc;border:1px solid rgba(16,24,40,.08);border-radius:22px;padding:18px;color:#101828}.path-step b{display:block;color:#101828;letter-spacing:-.025em}.path-step span{display:block;margin-top:7px;color:#667085;line-height:1.45;font-size:.92rem}
.route-note{display:inline-flex;align-items:center;gap:8px;border-radius:999px;background:#ecfdf3;color:#027a48;padding:8px 12px;font-weight:800;font-size:.82rem}
@media(max-width:1040px){.civic-grid{grid-template-columns:1fr}.path-flow{grid-template-columns:1fr 1fr}}@media(max-width:720px){.path-flow{grid-template-columns:1fr}}


/* --- Final polish: consolidated nav + live guest pass visual --- */
.nav{
  min-height:72px;
  gap:18px;
}
.nav-links{
  gap:18px;
  font-size:.88rem;
  white-space:nowrap;
}
.nav-links a{
  line-height:1.08;
}
.nav-actions .btn{
  padding:12px 18px;
}
.nav-actions .btn-outline{
  display:none;
}
.brand{
  flex-shrink:0;
}
.mark{
  flex-shrink:0;
}
.pass-live{
  justify-self:end;
}
.guest-pass-ui{
  background:#fff;
  color:#101828;
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 28px 90px rgba(0,0,0,.32);
  border:1px solid rgba(255,255,255,.28);
}
.guest-pass-head{
  padding:20px;
  background:linear-gradient(135deg,#071426,#0d2038);
  color:#fff;
}
.guest-pass-head .mini-label{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.86);
  font-weight:820;
  font-size:.74rem;
  text-transform:uppercase;
  letter-spacing:.09em;
}
.guest-pass-head .mini-label:before{
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  background:#35d399;
  box-shadow:0 0 0 5px rgba(53,211,153,.16);
}
.guest-pass-head h3{
  margin:14px 0 0;
  color:#fff;
  font-size:1.62rem;
  letter-spacing:-.055em;
  line-height:1;
}
.guest-pass-head p{
  margin:8px 0 0;
  color:rgba(255,255,255,.74);
  line-height:1.45;
}
.pass-status-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  padding:14px;
  background:#fff;
}
.status-pill{
  border:1px solid rgba(16,24,40,.09);
  background:#f8fafc;
  border-radius:16px;
  padding:12px;
}
.status-pill span{
  display:block;
  color:#667085;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.66rem;
  font-weight:850;
}
.status-pill b{
  display:block;
  color:#101828;
  margin-top:4px;
  letter-spacing:-.025em;
}
.mini-map{
  position:relative;
  height:150px;
  margin:0 14px 14px;
  border-radius:22px;
  overflow:hidden;
  background:
    radial-gradient(circle at 50% 50%, rgba(23,77,159,.18) 0 18%, transparent 19%),
    radial-gradient(circle at 50% 50%, rgba(23,77,159,.10) 0 34%, transparent 35%),
    linear-gradient(135deg,#f8fafc,#eaf1fb);
  border:1px solid rgba(16,24,40,.09);
}
.mini-map:before,
.mini-map:after{
  content:"";
  position:absolute;
  inset:auto;
  background:rgba(16,24,40,.07);
}
.mini-map:before{
  width:120%;
  height:2px;
  top:50%;
  left:-10%;
  transform:rotate(-18deg);
}
.mini-map:after{
  width:2px;
  height:120%;
  left:53%;
  top:-10%;
  transform:rotate(23deg);
}
.map-pin{
  position:absolute;
  z-index:2;
  width:28px;
  height:28px;
  border-radius:999px 999px 999px 4px;
  transform:rotate(-45deg);
  background:#174d9f;
  box-shadow:0 8px 20px rgba(23,77,159,.24);
}
.map-pin:after{
  content:"";
  position:absolute;
  width:9px;
  height:9px;
  border-radius:999px;
  background:#fff;
  top:9px;
  left:9px;
}
.map-pin.home{
  left:48%;
  top:42%;
  background:#0f9f6e;
}
.map-pin.coffee{left:28%;top:28%}
.map-pin.shop{left:63%;top:22%}
.map-pin.spa{left:69%;top:60%}
.map-caption{
  position:absolute;
  z-index:3;
  left:12px;
  bottom:12px;
  display:inline-flex;
  border-radius:999px;
  background:rgba(255,255,255,.86);
  color:#101828;
  padding:8px 10px;
  font-size:.72rem;
  font-weight:820;
  box-shadow:0 8px 18px rgba(15,23,42,.10);
}
.eligible-list{
  display:grid;
  gap:8px;
  padding:0 14px 14px;
}
.eligible-row{
  display:grid;
  grid-template-columns:36px 1fr auto;
  gap:10px;
  align-items:center;
  border:1px solid rgba(16,24,40,.09);
  background:#fff;
  border-radius:17px;
  padding:10px;
}
.eligible-row .emoji{
  width:36px;
  height:36px;
  display:grid;
  place-items:center;
  border-radius:12px;
  background:#eef4ff;
}
.eligible-row strong{
  display:block;
  color:#101828;
  line-height:1.05;
  letter-spacing:-.025em;
}
.eligible-row small{
  display:block;
  margin-top:3px;
  color:#667085;
  font-weight:650;
}
.redeem-badge{
  padding:7px 9px;
  border-radius:999px;
  background:#ecfdf3;
  color:#027a48;
  font-weight:850;
  font-size:.70rem;
  white-space:nowrap;
}
.pass-bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px;
  border-top:1px solid rgba(16,24,40,.08);
  background:#f8fafc;
}
.pass-bottom span{
  color:#667085;
  font-size:.78rem;
  font-weight:760;
}
.pass-bottom b{
  color:#101828;
  letter-spacing:-.02em;
}
.hero .pass-panel .btn{
  width:100%;
}
.footer-brand .arns-line{
  color:#344054;
  font-weight:760;
}
.footer-brand .arns-line span{
  color:#667085;
  font-weight:650;
}
@media(max-width:1180px){
  .nav-links{gap:13px;font-size:.84rem}
  .brand{font-size:1.02rem}
  .nav-actions .btn-primary{padding:11px 15px}
}
@media(max-width:1040px){
  .pass-live{justify-self:start}
  .nav-links,.nav-actions{display:none}
}
@media(max-width:720px){
  .pass-status-grid{grid-template-columns:1fr}
  .eligible-row{grid-template-columns:34px 1fr}
  .redeem-badge{grid-column:2}
}


/* --- Final strategic layer: wristband logic, gamification, ambassadors, campaigns --- */
.access-principle{
  background:#fff;
  border-top:1px solid rgba(16,24,40,.08);
  border-bottom:1px solid rgba(16,24,40,.08);
}
.principle-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:24px;
  align-items:stretch;
}
.principle-card{
  background:#fff;
  border:1px solid rgba(16,24,40,.10);
  border-radius:30px;
  padding:30px;
  box-shadow:0 18px 52px rgba(15,23,42,.08);
}
.principle-card h3{
  margin:0;
  color:#101828;
  letter-spacing:-.045em;
  font-size:1.5rem;
}
.principle-card p{
  color:#667085;
  line-height:1.62;
  margin:12px 0 0;
}
.wristband-visual{
  min-height:300px;
  border-radius:30px;
  background:
    radial-gradient(circle at 20% 20%, rgba(14,165,233,.14), transparent 30%),
    radial-gradient(circle at 90% 70%, rgba(15,159,110,.16), transparent 32%),
    linear-gradient(135deg,#071426,#0d2038);
  color:#fff;
  padding:30px;
  position:relative;
  overflow:hidden;
  box-shadow:0 24px 70px rgba(7,20,38,.24);
}
.wristband-strip{
  position:absolute;
  left:50%;
  top:52%;
  width:82%;
  height:78px;
  transform:translate(-50%,-50%) rotate(-7deg);
  border-radius:999px;
  background:linear-gradient(90deg,#ffffff,#eef4ff);
  box-shadow:0 22px 50px rgba(0,0,0,.24);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#071426;
  font-weight:900;
  letter-spacing:-.04em;
  font-size:1.45rem;
}
.wristband-strip span{
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.wristband-meta{
  position:relative;
  z-index:2;
  display:flex;
  justify-content:space-between;
  gap:12px;
}
.wristband-meta .meta-chip{
  display:inline-flex;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  padding:8px 11px;
  color:rgba(255,255,255,.86);
  font-size:.78rem;
  font-weight:800;
}
.wristband-caption{
  position:absolute;
  left:30px;
  right:30px;
  bottom:26px;
  color:rgba(255,255,255,.78);
  line-height:1.52;
  z-index:2;
}
.playbook-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.playbook-card{
  background:#fff;
  border:1px solid rgba(16,24,40,.10);
  border-radius:24px;
  padding:22px;
  box-shadow:0 12px 34px rgba(15,23,42,.06);
}
.playbook-card .label{
  display:inline-flex;
  border-radius:999px;
  background:#eef4ff;
  color:#174d9f;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:850;
  padding:6px 9px;
  margin-bottom:12px;
}
.playbook-card h3{
  margin:0;
  color:#101828;
  letter-spacing:-.035em;
}
.playbook-card p{
  color:#667085;
  line-height:1.55;
  margin:9px 0 0;
}
.campaign-table{
  border:1px solid rgba(16,24,40,.10);
  border-radius:30px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 18px 52px rgba(15,23,42,.08);
}
.campaign-row{
  display:grid;
  grid-template-columns:.95fr 1.1fr 1.2fr;
  border-bottom:1px solid rgba(16,24,40,.08);
}
.campaign-row:last-child{border-bottom:0}
.campaign-row>div{
  padding:18px 20px;
  color:#475467;
  line-height:1.5;
}
.campaign-row>div+div{
  border-left:1px solid rgba(16,24,40,.07);
}
.campaign-head{
  background:#f8fafc;
  font-weight:850;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.78rem;
}
.campaign-head>div{color:#101828}
.campaign-row b{color:#101828}
.ambassador-callout{
  background:linear-gradient(135deg,#071426,#0d2038);
  color:#fff;
  border-radius:32px;
  padding:36px;
  box-shadow:0 26px 72px rgba(7,20,38,.22);
}
.ambassador-callout h3{
  margin:0;
  color:#fff;
  font-size:2rem;
  letter-spacing:-.055em;
}
.ambassador-callout p{
  color:rgba(255,255,255,.76);
  line-height:1.62;
}
.ambassador-points{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-top:22px;
}
.ambassador-point{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.13);
  border-radius:20px;
  padding:18px;
}
.ambassador-point b{
  display:block;
  color:#fff;
}
.ambassador-point span{
  color:rgba(255,255,255,.72);
  display:block;
  margin-top:6px;
  line-height:1.45;
  font-size:.92rem;
}
@media(max-width:1040px){
  .principle-grid{grid-template-columns:1fr}
  .playbook-grid{grid-template-columns:1fr 1fr}
  .campaign-row{grid-template-columns:1fr}
  .campaign-row>div+div{border-left:0;border-top:1px solid rgba(16,24,40,.07)}
  .ambassador-points{grid-template-columns:1fr}
}
@media(max-width:720px){
  .playbook-grid{grid-template-columns:1fr}
  .wristband-strip{font-size:1.05rem;height:62px}
}


/* --- Stay-active pass language, FAQ, sponsorship, and group pass updates --- */
.access-principle .principle-card h2,
.access-principle .principle-card h3,
.faq-card h3,
.sponsor-card h3,
.party-card h3 {
  color:#101828;
}
.faq-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
}
.faq-card{
  background:#fff;
  border:1px solid rgba(16,24,40,.10);
  border-radius:24px;
  padding:22px;
  box-shadow:0 12px 34px rgba(15,23,42,.06);
}
.faq-card h3{
  margin:0;
  letter-spacing:-.035em;
  font-size:1.12rem;
}
.faq-card p{
  color:#667085;
  line-height:1.58;
  margin:9px 0 0;
}
.sponsor-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.sponsor-card{
  background:#fff;
  border:1px solid rgba(16,24,40,.10);
  border-radius:22px;
  padding:20px;
  box-shadow:0 10px 28px rgba(15,23,42,.05);
}
.sponsor-card h3{
  margin:0;
  letter-spacing:-.035em;
}
.sponsor-card p{
  color:#667085;
  line-height:1.5;
  margin:8px 0 0;
}
.party-flow{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.party-card{
  background:#f8fafc;
  border:1px solid rgba(16,24,40,.08);
  border-radius:22px;
  padding:20px;
}
.party-card b{
  display:block;
  color:#101828;
  letter-spacing:-.025em;
}
.party-card span{
  display:block;
  color:#667085;
  line-height:1.45;
  margin-top:7px;
  font-size:.92rem;
}
.pass-state-strip{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-top:22px;
}
.pass-state{
  background:#fff;
  border:1px solid rgba(16,24,40,.10);
  border-radius:20px;
  padding:18px;
}
.pass-state span{
  display:inline-flex;
  font-size:.70rem;
  text-transform:uppercase;
  letter-spacing:.09em;
  font-weight:850;
  color:#174d9f;
  background:#eef4ff;
  border-radius:999px;
  padding:6px 8px;
}
.pass-state b{
  display:block;
  color:#101828;
  margin-top:10px;
  letter-spacing:-.03em;
}
.pass-state p{
  color:#667085;
  line-height:1.48;
  margin:7px 0 0;
  font-size:.94rem;
}
@media(max-width:1040px){
  .sponsor-grid,.party-flow,.pass-state-strip{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
  .faq-grid,.sponsor-grid,.party-flow,.pass-state-strip{grid-template-columns:1fr}
}


/* --- Final fix: polished stay-eligibility pass card and corrected access language --- */
.principle-grid{
  align-items:stretch;
  overflow:hidden;
}
.access-principle{
  overflow:hidden;
}
.principle-card{
  min-width:0;
}
.principle-card h2{
  overflow-wrap:normal;
  word-break:normal;
  hyphens:none;
  max-width:100%;
}
.stay-eligibility-card{
  background:#ffffff;
  border:1px solid rgba(16,24,40,.10);
  border-radius:30px;
  overflow:hidden;
  box-shadow:0 24px 70px rgba(15,23,42,.14);
  min-height:100%;
}
.stay-eligibility-header{
  background:linear-gradient(135deg,#071426,#0d2038);
  color:#fff;
  padding:24px;
}
.stay-eligibility-header .mini-label{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.88);
  font-weight:850;
  font-size:.72rem;
  letter-spacing:.09em;
  text-transform:uppercase;
}
.stay-eligibility-header .mini-label:before{
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  background:#35d399;
  box-shadow:0 0 0 5px rgba(53,211,153,.16);
}
.stay-eligibility-header h3{
  margin:14px 0 0;
  color:#fff;
  font-size:1.65rem;
  letter-spacing:-.055em;
  line-height:1;
}
.stay-eligibility-header p{
  margin:9px 0 0;
  color:rgba(255,255,255,.76);
  line-height:1.48;
}
.stay-status-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
  padding:14px;
  background:#fff;
}
.stay-status{
  background:#f8fafc;
  border:1px solid rgba(16,24,40,.08);
  border-radius:16px;
  padding:13px;
}
.stay-status span{
  display:block;
  color:#667085;
  font-size:.67rem;
  letter-spacing:.09em;
  font-weight:850;
  text-transform:uppercase;
}
.stay-status b{
  display:block;
  color:#101828;
  margin-top:4px;
  letter-spacing:-.025em;
}
.eligible-perk-list{
  display:grid;
  gap:9px;
  padding:0 14px 14px;
}
.eligible-perk{
  display:grid;
  grid-template-columns:38px 1fr auto;
  gap:10px;
  align-items:center;
  border:1px solid rgba(16,24,40,.09);
  border-radius:18px;
  padding:11px;
  background:#fff;
}
.eligible-perk .emoji{
  width:38px;
  height:38px;
  display:grid;
  place-items:center;
  border-radius:13px;
  background:#eef4ff;
  font-size:1.1rem;
}
.eligible-perk strong{
  display:block;
  color:#101828;
  letter-spacing:-.025em;
  line-height:1.05;
}
.eligible-perk small{
  display:block;
  color:#667085;
  font-weight:650;
  margin-top:3px;
}
.inperson-chip{
  display:inline-flex;
  white-space:nowrap;
  border-radius:999px;
  background:#ecfdf3;
  color:#027a48;
  padding:7px 9px;
  font-size:.68rem;
  font-weight:900;
  letter-spacing:.02em;
}
.stay-map-mini{
  position:relative;
  height:134px;
  margin:0 14px 14px;
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(16,24,40,.08);
  background:
    radial-gradient(circle at 47% 47%, rgba(15,159,110,.20) 0 14%, transparent 15%),
    radial-gradient(circle at 47% 47%, rgba(23,77,159,.13) 0 33%, transparent 34%),
    linear-gradient(135deg,#f8fafc,#eaf1fb);
}
.stay-map-mini:before{
  content:"";
  position:absolute;
  width:120%;
  height:2px;
  top:53%;
  left:-10%;
  background:rgba(16,24,40,.08);
  transform:rotate(-15deg);
}
.stay-map-mini:after{
  content:"";
  position:absolute;
  width:2px;
  height:120%;
  left:55%;
  top:-10%;
  background:rgba(16,24,40,.08);
  transform:rotate(22deg);
}
.pin-dot{
  position:absolute;
  z-index:2;
  width:18px;
  height:18px;
  border-radius:999px;
  background:#174d9f;
  border:3px solid #fff;
  box-shadow:0 8px 18px rgba(15,23,42,.18);
}
.pin-dot.home{
  background:#0f9f6e;
  left:48%;
  top:44%;
}
.pin-dot.a{left:28%;top:32%}
.pin-dot.b{left:66%;top:28%}
.pin-dot.c{left:70%;top:62%}
.map-label{
  position:absolute;
  z-index:3;
  left:12px;
  bottom:12px;
  display:inline-flex;
  border-radius:999px;
  background:rgba(255,255,255,.88);
  color:#101828;
  padding:8px 10px;
  box-shadow:0 8px 18px rgba(15,23,42,.10);
  font-size:.72rem;
  font-weight:850;
}
.stay-eligibility-footer{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  background:#f8fafc;
  border-top:1px solid rgba(16,24,40,.08);
  padding:14px;
}
.stay-eligibility-footer span{
  color:#667085;
  font-weight:760;
  font-size:.8rem;
}
.stay-eligibility-footer b{
  color:#101828;
  letter-spacing:-.02em;
}
.pass-visual,.pass-meta,.pass-strip,.pass-caption{
  all:unset;
}
@media(max-width:1040px){
  .principle-grid{grid-template-columns:1fr}
}
@media(max-width:720px){
  .stay-status-grid{grid-template-columns:1fr}
  .eligible-perk{grid-template-columns:38px 1fr}
  .inperson-chip{grid-column:2}
}


/* --- Homepage reward playbook section --- */
.playbook-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.playbook-card{
  background:#fff;
  border:1px solid rgba(16,24,40,.10);
  border-radius:24px;
  padding:22px;
  box-shadow:0 12px 34px rgba(15,23,42,.06);
}
.playbook-card .label{
  display:inline-flex;
  border-radius:999px;
  background:#eef4ff;
  color:#174d9f;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:850;
  padding:6px 9px;
  margin-bottom:12px;
}
.playbook-card h3{
  margin:0;
  color:#101828;
  letter-spacing:-.035em;
}
.playbook-card p{
  color:#667085;
  line-height:1.55;
  margin:9px 0 0;
}
@media(max-width:1040px){.playbook-grid{grid-template-columns:1fr 1fr}}
@media(max-width:720px){.playbook-grid{grid-template-columns:1fr}}


/* --- Final legal/email/logo/FAQ polish --- */
.mark.gn-logo{
  width:46px;
  min-width:46px;
  height:46px;
  border-radius:15px;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:1px;
  font-weight:950;
  letter-spacing:-.08em;
}
.mark.gn-logo .g-face,
.mark.gn-logo .n-letter{
  position:relative;
  z-index:2;
  color:#fff;
}
.mark.gn-logo .g-face{
  font-size:1.05rem;
}
.mark.gn-logo .n-letter{
  font-size:.96rem;
}
.mark.gn-logo:before{
  content:"";
  position:absolute;
  width:18px;
  height:9px;
  left:10px;
  bottom:10px;
  border-bottom:3px solid #35d399;
  border-radius:0 0 999px 999px;
}
.mark.gn-logo:after{
  content:"";
  position:absolute;
  width:4px;
  height:4px;
  left:17px;
  top:15px;
  border-radius:999px;
  background:#35d399;
  box-shadow:10px 0 0 #35d399;
}
.legal-hero{
  min-height:420px;
}
.legal-content{
  max-width:920px;
  margin:0 auto;
}
.legal-content h2{
  font-size:clamp(1.9rem,3vw,3rem);
  margin-top:34px;
}
.legal-content h3{
  color:#101828;
  margin:26px 0 8px;
  letter-spacing:-.03em;
}
.legal-content p,
.legal-content li{
  color:#667085;
  line-height:1.7;
}
.legal-content ul{
  padding-left:1.2rem;
}
.legal-card{
  background:#fff;
  border:1px solid rgba(16,24,40,.10);
  border-radius:28px;
  padding:30px;
  box-shadow:0 16px 46px rgba(15,23,42,.07);
}
.faq-grid.expanded{
  grid-template-columns:repeat(2,1fr);
}
.faq-card.emphasis{
  border-color:rgba(23,77,159,.22);
  background:linear-gradient(180deg,#fff,#f8fbff);
}
.mail-link{
  color:#174d9f;
  font-weight:850;
}
@media(max-width:720px){
  .faq-grid.expanded{grid-template-columns:1fr}
}
