:root{
  --bg:#0f121a;
  --bg-2:#121725;
  --panel:#171c2a;
  --panel-2:#1c2232;
  --ink:#f7f7f2;
  --muted:#b8c0cf;
  --line:rgba(255,255,255,.11);
  --lime:#a9ee38;
  --pink:#ff3d8d;
  --cyan:#54d9e8;
  --orange:#ff815c;
  --purple:#9a6dff;
  --shadow:0 28px 70px rgba(0,0,0,.34);
  --radius:24px;
  --shell:min(1440px,calc(100% - 40px));
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg)}
body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;line-height:1.55;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
img{display:block;max-width:100%}
button{color:inherit}
.shell{width:var(--shell);margin-inline:auto}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:fixed;top:12px;left:12px;z-index:9999;background:#fff;color:#000;padding:10px 14px;border-radius:10px;transform:translateY(-160%)}
.skip-link:focus{transform:translateY(0)}
:focus-visible{outline:3px solid var(--cyan);outline-offset:3px}
.is-development-only{display:none!important}

/* header */
.site-header{position:sticky;top:0;z-index:100;background:rgba(10,13,20,.88);backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.08)}
.header-inner{min-height:76px;display:flex;align-items:center;justify-content:space-between;gap:28px}
.brand{display:inline-flex;align-items:center;gap:10px;min-width:max-content}
.brand img{width:46px;height:46px;filter:drop-shadow(0 8px 16px rgba(0,0,0,.28))}
.brand-words{display:flex;align-items:center;gap:9px}
.brand-words strong{font-family:"Arial Black",Impact,sans-serif;font-size:.92rem;line-height:.85;letter-spacing:.02em;text-transform:uppercase}
.brand-words span{font-size:.67rem;font-weight:900;letter-spacing:.13em;color:#18210f;background:var(--lime);padding:5px 7px;border-radius:6px}
.site-nav{display:flex;align-items:center;gap:30px;color:#ecedf3;font-weight:650}
.site-nav a{position:relative;font-size:.96rem;opacity:.9}
.site-nav a:not(.nav-cta)::after{content:"";position:absolute;left:0;right:100%;bottom:-8px;height:2px;background:var(--lime);transition:right .2s ease}
.site-nav a:hover::after{right:0}
.nav-cta{background:var(--pink);padding:13px 20px;border-radius:999px;box-shadow:0 10px 30px rgba(255,61,141,.2)}
.nav-cta:hover{transform:translateY(-1px);filter:brightness(1.05)}
.menu-toggle{display:none;border:0;background:transparent;padding:8px}
.menu-toggle span:not(.sr-only){display:block;width:26px;height:2px;background:#fff;margin:5px 0;border-radius:2px}

/* hero */
.hero{position:relative;padding:40px 0 30px;background:
 radial-gradient(circle at 70% 30%,rgba(84,217,232,.09),transparent 32%),
 radial-gradient(circle at 20% 5%,rgba(255,61,141,.06),transparent 24%),
 linear-gradient(180deg,#0d1119,#101520 72%,#111724);overflow:hidden}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:linear-gradient(90deg,transparent,var(--cyan),var(--pink),transparent);opacity:.35}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,44fr) minmax(0,56fr);gap:clamp(40px,4.4vw,62px);align-items:start}
.hero-copy{min-width:0;padding-left:42px}
.hero-kicker{margin:0 0 10px;color:#dce2ec;font-size:.78rem;letter-spacing:.17em;text-transform:uppercase;font-weight:850}
.hero-copy h1{margin:0;font-family:"Arial Black",Impact,sans-serif;font-size:clamp(3.55rem,5.75vw,6.62rem);line-height:.84;letter-spacing:-.045em;text-shadow:0 18px 50px rgba(0,0,0,.34)}
.hero-tagline{margin:13px 0 0;color:var(--lime);font-family:"Segoe Print",cursive;font-weight:900;font-size:clamp(1.18rem,1.9vw,1.66rem);line-height:1.12}
.hero-lead{max-width:590px;margin:16px 0 0;color:#d3d8e3;font-size:1.02rem;line-height:1.48}
.hero-actions{display:grid;grid-template-columns:1fr;gap:11px;width:min(82%,440px);margin-top:0}
.button{display:inline-flex;align-items:center;justify-content:center;gap:12px;min-height:48px;padding:0 20px;border:1px solid transparent;border-radius:12px;font-weight:850;transition:.2s ease;cursor:pointer}
.button:hover{transform:translateY(-2px)}
.button-lime{background:var(--lime);color:#12180b;box-shadow:0 14px 34px rgba(169,238,56,.22)}
.button-outline{border-color:rgba(169,238,56,.85);color:var(--lime);background:rgba(255,255,255,.02)}
.microcopy{margin:9px 0 0;color:#9da7b6;font-size:.8rem}
.hero-visual{position:relative;min-width:0;isolation:isolate}
.hero-video-title{margin:0 0 9px;color:var(--cyan);font-size:.76rem;font-weight:950;letter-spacing:.15em;text-transform:uppercase}
.hero-video-frame{position:relative;overflow:hidden;aspect-ratio:16/9;border-radius:24px;border:1px solid rgba(255,255,255,.14);background:#151b27;box-shadow:var(--shadow)}
.hero-video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.hero-video-source{margin:8px 0 0;color:#9da7b6;font-size:.78rem;line-height:1.35}
.hero-info-panel{margin:16px 0 0}
.hero-cta-panel{margin-top:12px}
.game-info-bar{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:0;padding:0}
.game-info-bar div{display:flex;min-width:0;min-height:54px;align-items:center;justify-content:flex-start;gap:10px;padding:9px 13px;border:1px solid rgba(255,255,255,.1);border-radius:14px;background:rgba(21,26,37,.82)}
.game-info-bar dt{flex:0 0 auto;color:var(--cyan);font-size:.64rem;font-weight:950;letter-spacing:.11em;text-transform:uppercase}
.game-info-bar dd{min-width:0;margin:0;color:#f5f6f1;font-size:.95rem;font-weight:850;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.game-price-note{margin:7px 0 0;color:#aeb7c6;font-size:.76rem;line-height:1.35}
.hero-paint{position:absolute;z-index:1;pointer-events:none;filter:drop-shadow(0 12px 35px rgba(0,0,0,.2))}
.hero-paint-one{right:34%;bottom:-70px;width:210px;height:96px;background:url('../images/paint-splash.svg') center/contain no-repeat;transform:rotate(-8deg);opacity:.72}
.hero-paint-two{left:-70px;top:80px;width:260px;height:180px;background:radial-gradient(circle at 60% 55%,rgba(255,61,141,.28),transparent 58%);filter:blur(20px)}

/* portal */
.portal{background:#111724;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.08);padding:18px 0}
.portal-grid{display:grid;grid-template-columns:190px repeat(4,1fr);gap:16px;align-items:stretch}
.portal-heading{display:flex;align-items:center}
.portal-heading p{margin:0;font-family:"Segoe Print",cursive;font-size:1.45rem;line-height:1.15;color:#f2f3f5}
.portal-heading strong{color:var(--lime);font-size:1.1em}
.portal-card{min-height:88px;display:grid;grid-template-columns:54px 1fr 34px;gap:14px;align-items:center;padding:14px 16px;border:1px solid rgba(255,255,255,.07);border-radius:15px;overflow:hidden;position:relative;transition:.2s ease}
.portal-card::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.06),transparent 52%);pointer-events:none}
.portal-card:hover{transform:translateY(-3px);border-color:rgba(255,255,255,.18)}
.portal-teal{background:linear-gradient(135deg,#12343e,#102631)}
.portal-purple{background:linear-gradient(135deg,#30204b,#241b39)}
.portal-green{background:linear-gradient(135deg,#2a3b1f,#202c1b)}
.portal-orange{background:linear-gradient(135deg,#4c2b20,#342019)}
.portal-icon{width:50px;height:50px;display:grid;place-items:center;border-radius:50%;background:rgba(255,255,255,.11);font-weight:950;font-size:1.5rem;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}
.portal-card small{display:block;color:#cdd4df;font-size:.76rem;line-height:1.15;margin-bottom:4px}
.portal-card strong{display:block;font-size:1rem;line-height:1.12}
.portal-arrow{width:31px;height:31px;display:grid;place-items:center;border-radius:50%;background:#0d1119;border:1px solid rgba(255,255,255,.1);font-size:1.6rem}

/* intro */
.start-playing{padding:52px 0 38px;background:linear-gradient(180deg,#111724,#10141e)}
.compact-start-heading{max-width:780px}
.section-label{margin:0 0 10px;color:var(--cyan);font-size:.74rem;font-weight:900;letter-spacing:.17em;text-transform:uppercase}
.start-playing h2,.section-heading h2,.practice-copy h2,.player-help h2,.faq-heading h2{margin:0;font-size:clamp(2rem,3vw,3.7rem);line-height:1;letter-spacing:-.04em}
.text-link{display:inline-flex;gap:8px;align-items:center;color:var(--lime);font-weight:850;margin-top:8px}
.start-playing .section-heading{margin-bottom:18px}
.start-playing .text-link{margin-top:14px;font-size:.9rem}
.steps-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;margin:0;border:1px solid rgba(255,255,255,.1);border-radius:18px;background:linear-gradient(135deg,rgba(25,31,45,.86),rgba(15,20,31,.9));box-shadow:0 18px 42px rgba(0,0,0,.18);overflow:hidden}
.step-card{position:relative;min-width:0;min-height:132px;padding:20px 22px 18px;background:transparent;border:0;box-shadow:none;overflow:visible}
.step-card:not(:last-child){border-right:1px solid rgba(255,255,255,.1)}
.step-card:not(:last-child)::after{content:"→";position:absolute;right:-10px;top:50%;z-index:2;width:20px;height:20px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.12);border-radius:50%;background:#10151f;color:var(--step-accent);font-size:.9rem;font-weight:950;line-height:1;transform:translateY(-50%)}
.step-card::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--step-accent);opacity:.85}
.step-card-top{position:relative;z-index:1;display:flex;align-items:center;gap:14px;min-height:46px}
.step-number{display:inline-flex;align-items:center;color:var(--step-accent);font-size:.74rem;font-weight:950;letter-spacing:.14em}
.step-icon{width:46px;height:46px;flex:0 0 46px;filter:drop-shadow(0 9px 14px rgba(0,0,0,.2))}
.step-icon .icon-fill{fill:rgba(169,238,56,.12);stroke:var(--step-accent);stroke-width:3.4;stroke-linejoin:round}
.step-icon .icon-line{fill:none;stroke:#f7f7f2;stroke-width:3.4;stroke-linecap:round;stroke-linejoin:round}
.step-icon .icon-accent{stroke:var(--step-accent)}
.step-card-room .icon-fill{fill:rgba(84,217,232,.12)}
.step-card-seek .icon-fill{fill:rgba(255,61,141,.1)}
.step-card-seek .icon-person-head{fill:rgba(247,247,242,.16);stroke:#f7f7f2;stroke-width:3.4}
.icon-dot{stroke:#10151f;stroke-width:3}
.icon-dot-one{fill:var(--lime)}.icon-dot-two{fill:var(--pink)}.icon-dot-three{fill:var(--cyan)}
.step-card h3{position:relative;z-index:1;margin:11px 0 6px;font-size:1.02rem;line-height:1.12;white-space:nowrap}
.step-card p{position:relative;z-index:1;max-width:100%;margin:0;color:#c6cedb;font-size:.88rem;line-height:1.38;overflow-wrap:break-word}

/* hiding guide */
.main-playground{padding:66px 0 70px;background:
 radial-gradient(circle at 8% 25%,rgba(84,217,232,.07),transparent 26%),
 radial-gradient(circle at 90% 36%,rgba(255,61,141,.06),transparent 28%),
 #0e131d}
.hiding-guide{display:grid;gap:28px;min-width:0;max-width:100%}
.section-heading{margin-bottom:24px}
.section-heading>p:last-child{max-width:760px;color:var(--muted);margin:13px 0 0}
.spots-heading h2{font-family:"Segoe Print",cursive;font-size:2rem;letter-spacing:-.04em}
.hiding-guide-intro{display:grid;grid-template-columns:minmax(0,2fr) minmax(280px,1fr);gap:34px;align-items:start;min-width:0;max-width:100%}
.guide-intro-main{min-width:0}
.hiding-guide-intro h2{max-width:760px;margin:0;font-size:clamp(2.15rem,3.75vw,4.38rem);line-height:.9;letter-spacing:-.05em}
.guide-subtitle{max-width:720px;margin:14px 0 0;color:#d8dfeb;font-size:1.06rem;line-height:1.45}
.guide-mechanic{display:grid;gap:8px;min-width:0;max-width:100%;padding:18px 20px;border:1px solid rgba(169,238,56,.34);border-radius:16px;background:linear-gradient(135deg,rgba(169,238,56,.1),rgba(84,217,232,.06));box-shadow:0 18px 46px rgba(0,0,0,.16)}
.guide-mechanic strong{color:var(--lime);font-size:1rem}.guide-mechanic span{color:#d5deea;font-size:.9rem;line-height:1.35}
.guide-intro-copy{display:grid;gap:12px;margin-top:18px;color:#c8d1df}
.guide-intro-copy p{margin:0;line-height:1.55}
.guide-tips{display:grid;gap:26px;min-width:0;max-width:100%}
.guide-tip{position:relative;display:grid;grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);grid-template-areas:"copy stage" "demo demo" "summary summary" "more more";gap:18px 24px;align-items:start;min-width:0;max-width:100%;padding:24px;border:1px solid rgba(255,255,255,.1);border-radius:22px;background:
 radial-gradient(circle at 14% 10%,color-mix(in srgb,var(--tip-accent) 16%,transparent),transparent 30%),
 linear-gradient(135deg,rgba(24,30,44,.92),rgba(15,20,31,.96));box-shadow:0 24px 58px rgba(0,0,0,.22);overflow:hidden}
.guide-tip.is-reversed{grid-template-columns:minmax(0,1.08fr) minmax(0,.92fr);grid-template-areas:"stage copy" "demo demo" "summary summary" "more more"}
.guide-tip::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:var(--tip-accent)}
.tip-copy,.tip-stage{position:relative;z-index:1;min-width:0;max-width:100%}
.tip-copy{grid-area:copy}.tip-stage{grid-area:stage}
.guide-tip>.demo-shell,.guide-tip>.tip-summary,.guide-tip>.tip-more-link{position:relative;z-index:1;min-width:0;max-width:100%}
.guide-tip>.demo-shell{grid-area:demo}.guide-tip>.tip-summary{grid-area:summary}.guide-tip>.tip-more-link{grid-area:more}
.tip-label,.demo-label{margin:0 0 10px;color:var(--tip-accent);font-size:.7rem;font-weight:950;letter-spacing:.16em;text-transform:uppercase}
.tip-copy h3{margin:0;font-size:clamp(1.65rem,2.35vw,2.55rem);line-height:1;letter-spacing:-.04em}
.tip-subheading{margin:10px 0 14px;color:#f4f7ef;font-weight:900}.tip-copy>p:not(.tip-label):not(.tip-subheading){margin:0;color:#d5deea;line-height:1.55}
.tip-summary{padding:15px 16px;border:1px solid rgba(255,255,255,.1);border-radius:16px;background:rgba(11,15,24,.52)}
.tip-summary p{margin:0;color:#c4cedd;font-size:.92rem;line-height:1.48}.tip-more-link{width:fit-content;max-width:100%;margin-top:-6px;font-size:.86rem;color:var(--tip-accent);white-space:normal;overflow-wrap:anywhere}
.example-title{margin:0 0 10px;color:#fff;font-size:1rem;font-weight:950}
.guide-media{display:grid;place-items:center;align-content:center;gap:7px;width:100%;max-width:100%;max-height:460px;padding:20px;border:1px dashed color-mix(in srgb,var(--tip-accent) 58%,rgba(255,255,255,.25));border-radius:18px;background:
 linear-gradient(135deg,rgba(255,255,255,.04),rgba(255,255,255,.015)),
 repeating-linear-gradient(135deg,rgba(255,255,255,.045) 0 1px,transparent 1px 14px);text-align:center}
.guide-media--landscape{min-height:230px;aspect-ratio:16/10}
.guide-media--portrait{width:min(100%,340px);min-height:320px;aspect-ratio:3/4;margin-inline:auto;background:
 radial-gradient(circle at 50% 20%,color-mix(in srgb,var(--tip-accent) 14%,transparent),transparent 34%),
 linear-gradient(135deg,rgba(255,255,255,.04),rgba(255,255,255,.015)),
 repeating-linear-gradient(135deg,rgba(255,255,255,.045) 0 1px,transparent 1px 14px)}
.guide-media img{width:100%;height:100%;object-fit:contain}
.image-placeholder strong{color:#f4f7ef}.image-placeholder span{color:#aeb8c7;font-size:.86rem}
.spot-check{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:12px}
.spot-check span{color:#e8edf4;font-weight:850}.guide-reveal-toggle{min-height:42px;padding-inline:16px}
.demo-shell{max-width:100%;padding:16px;border:1px dashed rgba(255,255,255,.18);border-radius:17px;background:rgba(10,14,22,.58)}
.demo-shell h4{margin:0;font-size:1.02rem}.demo-shell p:not(.demo-label){margin:6px 0 12px;color:#c6d0de;font-size:.9rem;line-height:1.45}
.demo-placeholder{display:grid;gap:5px;min-height:104px;place-items:center;padding:16px;border-radius:14px;background:rgba(255,255,255,.035);box-shadow:inset 0 0 0 1px rgba(255,255,255,.07);text-align:center}
.demo-placeholder strong{color:#eef2f7}.demo-placeholder span{color:#9fa9b8;font-size:.84rem}
.seeker-tips{display:grid;gap:18px;padding:22px;border:1px solid rgba(255,255,255,.1);border-radius:20px;background:linear-gradient(135deg,#141b29,#101520)}
.seeker-heading{display:grid;gap:8px}.seeker-heading h3{margin:0;font-size:clamp(1.6rem,2.4vw,2.55rem);line-height:1;letter-spacing:-.04em}.seeker-heading p{max-width:760px;margin:0;color:#c9d2df}
.seeker-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.seeker-grid article{padding:16px;border:1px solid rgba(255,255,255,.1);border-radius:16px;background:rgba(255,255,255,.035)}.seeker-grid span{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:9px;background:var(--cyan);color:#082028;font-weight:950}.seeker-grid h4{margin:12px 0 7px;font-size:1rem}.seeker-grid p{margin:0;color:#c6d0de;font-size:.9rem;line-height:1.45}.seeker-tips .text-link{margin:0;color:var(--cyan);font-size:.9rem}
.guide-cta{display:grid;gap:16px;padding:22px;border:1px solid rgba(169,238,56,.24);border-radius:22px;background:
 radial-gradient(circle at 92% 10%,rgba(169,238,56,.13),transparent 26%),
 linear-gradient(135deg,#142033,#111721)}
.guide-cta h3{margin:0;font-size:clamp(1.65rem,2.5vw,2.8rem);line-height:1;letter-spacing:-.04em}.guide-cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.guide-cta-grid article{display:grid;align-content:start;gap:10px;padding:18px;border:1px solid rgba(255,255,255,.1);border-radius:16px;background:rgba(255,255,255,.035)}.guide-cta-grid h4{margin:0;font-size:1.05rem}.guide-cta-grid p{margin:0;color:#cbd4e0;line-height:1.45}.guide-cta-grid .button{width:max-content;min-width:190px}.guide-cta-grid small{color:#9fa9b8;font-size:.78rem}

/* spots */
.spots-showcase{padding:6px 0 76px;background:#0e131d}
.spots-column{padding-left:8px}
.spots-heading{display:flex;justify-content:space-between;gap:20px;align-items:end}
.spots-heading .section-label{margin-bottom:5px}
.pink-link{color:var(--pink);font-size:.83rem;margin:0 0 4px}
.spots-mosaic{display:grid;grid-template-columns:1.15fr .8fr 1.15fr;grid-template-rows:repeat(2,190px);grid-auto-rows:190px;gap:10px;min-width:0;max-width:100%}
.spot-card{position:relative;min-width:0;max-width:100%;padding:0;border:0;border-radius:16px;overflow:hidden;background:#171c28;color:#fff;cursor:pointer;text-align:left;box-shadow:0 16px 35px rgba(0,0,0,.22)}
.spot-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(7,9,14,.85));pointer-events:none}
.spot-card img{width:100%;height:100%;object-fit:contain;background:#0b1018;transition:transform .3s ease}
.spot-card:hover img{transform:scale(1.04)}
.spot-card>span{position:absolute;z-index:2;left:13px;right:13px;bottom:12px;min-width:0;max-width:calc(100% - 26px)}
.spot-card strong{display:block;font-size:.9rem;line-height:1.05}
.spot-card small{display:block;margin-top:5px;color:var(--cyan);font-size:.68rem;font-weight:800}
.spot-card:nth-child(1) small,.spot-card:nth-child(4) small{color:var(--pink)}
.spot-card:nth-child(3) small{color:var(--lime)}
.spot-large{grid-column:1;grid-row:1/3}
.spots-mosaic .spot-card:nth-child(2){grid-column:2;grid-row:1}
.spots-mosaic .spot-card:nth-child(3){grid-column:3;grid-row:1}
.spots-mosaic .spot-card:nth-child(4){grid-column:2;grid-row:2}
.spots-mosaic .spot-card:nth-child(5){grid-column:3;grid-row:2}
.spots-showcase-cta{display:flex;justify-content:center;margin-top:22px}

/* full gallery */
.gallery-page{background:#0e131d;color:var(--ink)}
.gallery-hero{position:relative;padding:58px 0 30px;background:
 radial-gradient(circle at 18% 8%,rgba(84,217,232,.12),transparent 28%),
 radial-gradient(circle at 84% 24%,rgba(255,61,141,.08),transparent 30%),
 linear-gradient(180deg,#101520,#0e131d)}
.gallery-hero h1{max-width:1100px;margin:0;font-family:"Arial Black",Impact,sans-serif;font-size:clamp(2.45rem,4.85vw,5.2rem);line-height:.82;letter-spacing:-.04em}
.spots-page-title span{display:block;white-space:nowrap}
.gallery-subtitle{max-width:760px;margin:16px 0 0;color:#f1f5f8;font-size:clamp(1.12rem,1.9vw,1.45rem);font-weight:850;line-height:1.25}
.gallery-intro{max-width:840px;margin:14px 0 0;color:#c9d2df;font-size:1rem;line-height:1.55}
.gallery-note{display:inline-flex;margin:18px 0 0;padding:9px 12px;border:1px solid rgba(84,217,232,.28);border-radius:12px;background:rgba(84,217,232,.08);color:#cbd8e5;font-size:.84rem}
.gallery-section{padding:30px 0 76px;background:#0e131d}
.gallery-toolbar{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:18px}
.gallery-count{margin:0;color:#aeb8c7;font-size:.9rem}
.gallery-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.gallery-card{display:grid;gap:0;min-width:0;padding:0;border:1px solid rgba(255,255,255,.11);border-radius:16px;background:#141a26;color:#fff;text-align:left;overflow:hidden;box-shadow:0 16px 38px rgba(0,0,0,.24);cursor:pointer;transition:transform .2s ease,border-color .2s ease}
.gallery-card:hover{transform:translateY(-2px);border-color:rgba(84,217,232,.45)}
.gallery-card:focus-visible{outline:3px solid var(--cyan);outline-offset:4px}
.gallery-thumb{display:grid;place-items:center;aspect-ratio:4/3;max-height:360px;background:#080d14}
.gallery-thumb img{width:100%;height:100%;object-fit:contain;object-position:center}
.gallery-card-copy{display:grid;gap:5px;padding:13px 14px 15px}
.gallery-card-copy strong{font-size:1rem;line-height:1.1}
.gallery-card-copy small{color:var(--cyan);font-size:.72rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.gallery-actions{display:flex;justify-content:center;margin-top:24px}
.gallery-actions[hidden]{display:none}
body.is-dialog-locked{overflow:hidden}
.gallery-dialog{width:min(1120px,calc(100% - 28px));max-height:92vh;padding:0;border:1px solid rgba(255,255,255,.16);border-radius:22px;background:#111723;color:#fff;box-shadow:0 40px 100px rgba(0,0,0,.55)}
.gallery-dialog::backdrop{background:rgba(5,8,13,.86);backdrop-filter:blur(8px)}
.gallery-dialog-close{position:absolute;right:14px;top:14px;z-index:2;width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:rgba(12,15,23,.86);font-size:1.5rem;cursor:pointer}
.gallery-dialog-image{display:grid;place-items:center;min-height:220px;background:#080d14}
.gallery-dialog-image img{width:100%;max-height:70vh;object-fit:contain;object-position:center}
.gallery-dialog-controls{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:18px 20px}
.gallery-dialog-controls small{color:var(--cyan);font-weight:900;letter-spacing:.15em}
.gallery-dialog-controls h2{margin:3px 0 0;font-size:1.45rem}

/* practice */
.practice-feature{padding:0 0 58px;background:#0e131d}
.practice-card{position:relative;display:grid;grid-template-columns:.86fr 1.14fr;gap:30px;align-items:center;min-height:360px;padding:34px 36px;border:1px solid rgba(84,217,232,.72);border-radius:26px;background:
 radial-gradient(circle at 14% 25%,rgba(84,217,232,.19),transparent 30%),
 radial-gradient(circle at 84% 80%,rgba(255,61,141,.13),transparent 32%),
 linear-gradient(135deg,#102a3b,#131c2c 55%,#111721);overflow:hidden;box-shadow:0 25px 70px rgba(0,0,0,.28)}
.practice-card::before{content:"";position:absolute;left:-50px;bottom:-90px;width:260px;height:180px;background:url('../images/paint-splash.svg') center/contain no-repeat;transform:rotate(16deg);opacity:.85}
.practice-paint{display:none}
.practice-copy{position:relative;z-index:2}
.tool-label{display:inline-block;margin:0 0 13px;background:var(--cyan);color:#092029;border-radius:6px;padding:5px 8px;font-size:.68rem;font-weight:950;letter-spacing:.14em}
.practice-copy p{color:#d8e0eb;max-width:570px}
.practice-copy ul{display:flex;flex-wrap:wrap;gap:18px;margin:18px 0 22px;padding:0;list-style:none;color:#eef3f6;font-size:.86rem}
.practice-copy li::before{content:"✓";color:var(--lime);font-weight:900;margin-right:7px}
.practice-meta{font-size:.78rem!important;color:#a7b1c1!important}.practice-meta span{margin:0 8px;color:var(--lime)}
.practice-disclaimer{margin-top:-8px!important;font-size:.78rem!important;color:#9da7b6!important}
.practice-visual{position:relative;z-index:2;border-radius:18px;overflow:hidden;border:1px solid rgba(84,217,232,.34);background:#080d14;box-shadow:0 25px 55px rgba(0,0,0,.28)}
.color-practice-preview-card{display:block;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}
.color-practice-preview-card:hover{transform:translateY(-2px);border-color:rgba(84,217,232,.72);box-shadow:0 29px 60px rgba(0,0,0,.32)}
.color-practice-preview-card:focus-visible{outline:3px solid var(--cyan);outline-offset:5px}
.practice-visual img{display:block;width:100%;height:auto;user-select:none}
.color-practice-preview-button{position:absolute;left:50%;bottom:18%;display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;padding:0 22px;border-radius:12px;background:var(--lime);color:#12180b;font-weight:850;line-height:1;white-space:nowrap;box-shadow:0 14px 34px rgba(169,238,56,.24);transform:translateX(-50%)}

/* help */
.player-help{padding:0 0 72px;background:#0e131d}
.compact-heading{display:flex;align-items:end;gap:16px;margin-bottom:15px}
.compact-heading .section-label{margin:0 0 3px}.compact-heading h2{font-size:2rem}
.help-grid{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid rgba(255,255,255,.12);border-radius:22px;background:#141925;overflow:hidden}
.help-card{display:grid;grid-template-columns:56px 1fr;gap:13px;align-items:start;padding:21px 22px;border-right:1px solid rgba(255,255,255,.1);transition:.2s ease}
.help-card:last-child{border-right:0}
.help-card:hover{background:#1a2030}
.help-icon{width:50px;height:50px;display:grid;place-items:center;border-radius:50%;background:#262d3b;color:#f8f8f4;font-weight:900;border:1px solid rgba(255,255,255,.12)}
.help-card strong{display:block;color:#fff;font-size:.95rem}.help-card small{display:block;margin-top:5px;color:#c1c7d2;line-height:1.35}.help-card em{display:block;margin-top:8px;color:var(--lime);font-style:normal;font-weight:800;font-size:.78rem}

/* faq footer */
.faq-section{padding:76px 0;background:linear-gradient(180deg,#111724,#0c1017)}
.faq-grid{display:grid;grid-template-columns:.65fr 1.35fr;gap:70px}
.faq-heading p:last-child{color:var(--muted);max-width:430px}
.faq-list{display:grid;gap:10px}
details{background:#151b27;border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:0 18px}
summary{cursor:pointer;list-style:none;padding:18px 34px 18px 0;font-weight:800;position:relative}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";position:absolute;right:0;top:14px;font-size:1.45rem;color:var(--lime)}
details[open] summary::after{content:"–"}
details p{margin:0;padding:0 0 18px;color:#c0c7d2}
.site-footer{background:#090c12;border-top:1px solid rgba(255,255,255,.08);padding:30px 0 24px}
.footer-top{display:flex;justify-content:space-between;gap:30px;align-items:center}
.footer-top nav{display:flex;flex-wrap:wrap;gap:24px;color:#c4cbd5;font-weight:700}
.footer-bottom{display:flex;justify-content:space-between;gap:30px;margin-top:24px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08);color:#80899a;font-size:.78rem}
.footer-bottom p:first-child{max-width:860px}

/* lightbox */
.spot-dialog{width:min(1040px,calc(100% - 30px));max-height:92vh;padding:0;border:1px solid rgba(255,255,255,.16);border-radius:22px;background:#111723;color:#fff;box-shadow:0 40px 100px rgba(0,0,0,.55)}
.spot-dialog::backdrop{background:rgba(5,8,13,.86);backdrop-filter:blur(8px)}
.dialog-close{position:absolute;right:14px;top:14px;z-index:2;width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:rgba(12,15,23,.82);font-size:1.5rem;cursor:pointer}
.dialog-image-wrap{background:#090d14}.dialog-image-wrap img{width:100%;max-height:70vh;object-fit:contain}
.dialog-controls{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:18px 20px}
.dialog-controls small{color:var(--cyan);font-weight:900;letter-spacing:.15em}.dialog-controls h2{margin:3px 0 0;font-size:1.45rem}

/* responsive */
@media (max-width:1220px){
  .hero{padding-top:36px}.hero-grid{grid-template-columns:minmax(0,470px) minmax(0,1fr);gap:42px}.hero-copy{padding-left:10px}.hero-copy h1{font-size:clamp(3.3rem,6.1vw,5.55rem)}
  .portal-grid{grid-template-columns:160px repeat(2,1fr)}.portal-heading{grid-row:span 2}
  .spots-column{padding-left:0}.spots-mosaic{grid-template-rows:repeat(2,180px);grid-auto-rows:180px}.guide-tip,.guide-tip.is-reversed{grid-template-columns:1fr;grid-template-areas:"copy" "stage" "demo" "summary" "more";gap:18px}.guide-tip>.demo-shell,.guide-tip>.tip-summary,.guide-tip>.tip-more-link{grid-column:auto}
}
@media (max-width:1040px){
  :root{--shell:min(760px,calc(100% - 28px))}
  .site-nav{position:absolute;top:76px;left:14px;right:14px;display:none;flex-direction:column;align-items:stretch;gap:6px;padding:15px;border:1px solid rgba(255,255,255,.11);border-radius:16px;background:#111724;box-shadow:var(--shadow)}
  .site-nav.is-open{display:flex}.site-nav a{padding:12px}.nav-cta{text-align:center}.menu-toggle{display:block}
  .hero{padding-top:34px}.hero-grid{grid-template-columns:1fr;gap:28px}.hero-copy{padding:0;text-align:center}.hero-lead{margin-inline:auto}.hero-actions{width:min(100%,440px);margin-inline:auto;justify-content:center}.game-info-bar{grid-template-columns:1fr 1fr}.hero-paint-one{right:40%;bottom:-28px}
  .portal-grid{grid-template-columns:1fr 1fr}.portal-heading{grid-column:1/-1;grid-row:auto}.portal-heading p br{display:none}
  .steps-grid{grid-template-columns:minmax(0,1fr);gap:0}.step-card:not(:last-child){border-right:0;border-bottom:1px solid rgba(255,255,255,.1)}.step-card:not(:last-child)::after{right:auto;left:50%;top:auto;bottom:-10px;content:"↓";transform:translateX(-50%)}.faq-grid{grid-template-columns:minmax(0,1fr);gap:16px}.hiding-guide-intro,.seeker-grid,.guide-cta-grid{grid-template-columns:1fr}
  .practice-card{grid-template-columns:1fr}.help-grid{grid-template-columns:1fr 1fr}.help-card:nth-child(2){border-right:0}.help-card:nth-child(-n+2){border-bottom:1px solid rgba(255,255,255,.1)}
  .gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .footer-top,.footer-bottom{align-items:flex-start;flex-direction:column}
}
@media (max-width:640px){
  :root{--shell:calc(100% - 34px)}
  .header-inner{min-height:68px}.brand img{width:39px;height:39px}.brand-words strong{font-size:.78rem}.site-nav{top:68px}
  .hero{min-height:auto;padding:30px 0 22px}.hero-grid{max-width:310px;width:100%;margin-inline:auto;gap:24px}.hero-copy,.hero-visual,.hero-video-frame{max-width:100%;width:100%}.hero-kicker{font-size:.67rem;margin-bottom:8px}.hero-copy h1{font-size:clamp(2.34rem,11.4vw,2.72rem);line-height:.9}.hero-tagline{margin-top:10px;font-size:1rem}.hero-lead{max-width:100%;margin-top:13px;font-size:.94rem;line-height:1.44}.hero-info-panel{margin-top:14px}.hero-cta-panel{margin-top:10px}.hero-actions{display:grid;width:100%}.button{width:100%;min-height:48px}.microcopy{margin-top:8px}.hero-visual{margin-top:0}.hero-video-frame{border-radius:20px}.hero-video-source{font-size:.72rem}.game-info-bar{grid-template-columns:1fr 1fr;gap:8px}.game-info-bar div{min-height:54px;gap:7px;padding:8px 9px}.game-info-bar dt{font-size:.59rem;letter-spacing:.09em}.game-info-bar dd{font-size:.78rem}.game-price-note{margin-top:6px;font-size:.74rem}.hero-paint-one{width:170px;right:6%;bottom:-62px;opacity:.54}
  .portal-grid{grid-template-columns:1fr}.portal-heading p{font-size:1.2rem}.portal-card{min-height:78px}
  .start-playing{padding:42px 0 34px}.steps-grid{width:100%;max-width:100%;overflow:visible}.step-card{width:100%;max-width:100%;min-height:auto;padding:18px}.step-card-top{justify-content:flex-start;gap:12px;min-height:44px}.step-icon{width:42px;height:42px;flex:0 0 42px}.step-card h3{white-space:normal}.step-card p{max-width:none;font-size:.82rem;line-height:1.42;overflow-wrap:break-word;word-break:normal}
  .main-playground{padding:50px 0}.hiding-guide{gap:22px}.hiding-guide-intro{gap:20px}.hiding-guide-intro h2{max-width:11em;font-size:clamp(1.8rem,7.2vw,2.75rem);overflow-wrap:break-word}.guide-subtitle,.guide-intro-copy p,.tip-copy>p:not(.tip-label):not(.tip-subheading),.seeker-heading p{overflow-wrap:break-word}.guide-intro-copy{gap:12px;margin-top:15px}.guide-tip{padding:18px}.guide-media{max-height:none}.guide-media--landscape{min-height:185px}.guide-media--portrait{width:100%;min-height:260px;max-height:520px}.spot-check{align-items:flex-start;flex-direction:column}.spot-check .button{width:100%}.demo-placeholder{min-height:92px}.guide-cta-grid .button{width:100%}
  .spots-mosaic{grid-template-columns:1fr;grid-template-rows:none;grid-auto-rows:190px}.spot-large,.spots-mosaic .spot-card:nth-child(n){grid-column:auto;grid-row:auto}.spots-heading{align-items:flex-start;flex-direction:column}.pink-link{margin-top:-12px}
  .gallery-hero{padding:44px 0 24px}.gallery-hero h1{font-size:clamp(2.25rem,10vw,3.35rem);line-height:.9}.spots-page-title span{white-space:normal}.gallery-grid{grid-template-columns:1fr}.gallery-thumb{max-height:300px}.gallery-toolbar{align-items:flex-start;flex-direction:column}.gallery-dialog-controls{align-items:stretch;flex-direction:column}.gallery-dialog-controls .button{width:100%}.gallery-dialog-image img{max-height:62vh}
  .practice-feature{padding-bottom:52px}.practice-card{padding:25px 19px}.practice-copy ul{display:grid;gap:7px}.color-practice-preview-button{bottom:15%;min-height:44px;padding-inline:16px;font-size:.88rem}
  .help-grid{grid-template-columns:1fr}.help-card{border-right:0;border-bottom:1px solid rgba(255,255,255,.1)!important}.help-card:last-child{border-bottom:0!important}
  .faq-section{padding:56px 0}.footer-top nav{display:grid;grid-template-columns:1fr 1fr}.dialog-controls{align-items:stretch;flex-direction:column}.dialog-controls .button{width:100%}
}
@media (max-width:520px){
  .game-info-bar{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
