/* SilverHarlequin — jazz LP aesthetic · teal / glowing coral · v3 */
@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Inter:wght@400;500;600;700;800&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --sh-bg:#0a3a3a;
  --sh-bg-deep:#062828;
  --sh-surface:#0f4242;
  --sh-card:#134c4c;
  --sh-card-hi:#1a5d5d;
  --sh-accent:#ec5a26;
  --sh-accent-hi:#ff7038;
  --sh-coral:#f0764a;
  --sh-gold:#ecbf63;
  --sh-gold-deep:#d49b3c;
  --sh-cream:#f6eedb;
  --sh-text:#f6eedb;
  --sh-text-sec:#b3cfc7;
  --sh-text-muted:#6f9a94;
  --sh-hero-dark:#041a1a;
  --sh-border:rgba(236,191,99,.18);
  --sh-border-warm:rgba(236,90,38,.32);
  --sh-overlay:rgba(4,22,22,.95);
  --sh-radius:16px;
  --sh-radius-lg:24px;
  --sh-transition:.25s cubic-bezier(.4,0,.2,1);
  --sh-grad-warm:linear-gradient(135deg,#ec5a26 0%,#ecbf63 100%);
  --sh-grad-warm-rev:linear-gradient(135deg,#ecbf63 0%,#ec5a26 100%);
  --sh-grad-fire:linear-gradient(135deg,#ff7038 0%,#ec5a26 55%,#d49b3c 100%);
  --sh-shadow-card:0 22px 60px -14px rgba(0,0,0,.6);
}
html{scroll-behavior:smooth;background:var(--sh-bg)}
html.sh-noscroll{overflow:hidden}
body{
  font-family:'Inter',sans-serif;color:var(--sh-text);line-height:1.6;-webkit-font-smoothing:antialiased;
  background:
    radial-gradient(1100px 700px at 88% -8%,rgba(236,90,38,.22),transparent 58%),
    radial-gradient(900px 800px at 2% 6%,rgba(236,191,99,.1),transparent 55%),
    radial-gradient(1200px 900px at 50% 112%,rgba(26,93,93,.55),transparent 60%),
    var(--sh-bg);
  background-attachment:fixed;
}
body::before{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
a{color:var(--sh-accent);text-decoration:none;transition:color var(--sh-transition)}
a:hover{color:var(--sh-accent-hi)}
img{max-width:100%;display:block}
h1,h2,h3{font-family:'DM Serif Display',serif;font-weight:400;line-height:1.12}
.sh-grad-text{background:var(--sh-grad-fire);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}

/* Layout */
.sh-container{max-width:1200px;margin:0 auto;padding:0 32px;position:relative;z-index:1}
.sh-section{padding:104px 0;position:relative}
.sh-section--alt{background:linear-gradient(180deg,transparent,rgba(15,66,66,.6) 12%,rgba(15,66,66,.6) 88%,transparent)}

/* kicker label (album-style) */
.sh-kicker{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--sh-gold);margin-bottom:16px}
.sh-kicker::before,.sh-kicker::after{content:'';width:24px;height:1px;background:linear-gradient(90deg,transparent,var(--sh-gold))}
.sh-kicker::after{background:linear-gradient(90deg,var(--sh-gold),transparent)}

/* Header */
.sh-header{position:fixed;top:0;left:0;right:0;z-index:900;background:rgba(6,40,40,.7);backdrop-filter:blur(18px) saturate(150%);border-bottom:1px solid var(--sh-border);transition:background .3s,box-shadow .3s}
.sh-header__inner{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;max-width:1200px;margin:0 auto}
.sh-logo{display:flex;align-items:center;gap:12px;font-family:'DM Serif Display',serif;font-size:24px;color:var(--sh-text);text-decoration:none;letter-spacing:.3px}
.sh-logo__diamond{width:32px;height:32px;filter:drop-shadow(0 2px 10px rgba(236,90,38,.6))}
.sh-logo__diamond svg{width:100%;height:100%}
.sh-logo span{color:var(--sh-accent)}
.sh-nav{display:flex;gap:32px;align-items:center}
.sh-nav a:not(.sh-btn){position:relative;color:var(--sh-text-sec);font-size:14px;font-weight:500;letter-spacing:.3px;padding:4px 0;transition:color var(--sh-transition)}
.sh-nav a:not(.sh-btn)::after{content:'';position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--sh-grad-warm);transition:width var(--sh-transition);border-radius:2px}
.sh-nav a:not(.sh-btn):hover,.sh-nav a:not(.sh-btn).active{color:var(--sh-text)}
.sh-nav a:not(.sh-btn):hover::after,.sh-nav a:not(.sh-btn).active::after{width:100%}
.sh-nav .sh-btn--sm{color:#fff}
.sh-burger{display:none;background:none;border:none;color:var(--sh-text);cursor:pointer;padding:4px}
.sh-burger svg{width:26px;height:26px}

/* Hero */
.sh-hero{position:relative;min-height:700px;display:flex;align-items:center;padding:140px 0 100px;overflow:hidden;background:linear-gradient(160deg,var(--sh-hero-dark) 0%,var(--sh-bg-deep) 42%,var(--sh-bg) 100%)}
.sh-hero__pattern{position:absolute;inset:0;opacity:.09;background-image:url("data:image/svg+xml,%3Csvg width='70' height='70' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M35 0L70 35L35 70L0 35Z' fill='none' stroke='%23ecbf63' stroke-width='1'/%3E%3C/svg%3E");background-size:70px 70px;-webkit-mask-image:radial-gradient(ellipse 95% 85% at 50% 40%,#000 28%,transparent 76%);mask-image:radial-gradient(ellipse 95% 85% at 50% 40%,#000 28%,transparent 76%)}
.sh-hero::before{content:'';position:absolute;width:680px;height:680px;right:-160px;top:-200px;background:radial-gradient(circle,rgba(236,90,38,.42),transparent 62%);filter:blur(10px);animation:shOrb1 16s ease-in-out infinite;pointer-events:none}
.sh-hero::after{content:'';position:absolute;width:520px;height:520px;left:-160px;bottom:-200px;background:radial-gradient(circle,rgba(236,191,99,.24),transparent 64%);filter:blur(10px);animation:shOrb2 20s ease-in-out infinite;pointer-events:none}
@keyframes shOrb1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-50px,40px) scale(1.12)}}
@keyframes shOrb2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(60px,-40px) scale(1.18)}}
.sh-hero .sh-container{display:flex;align-items:center;gap:56px}
.sh-hero__content{position:relative;z-index:2;max-width:560px;flex:1 1 auto}
.sh-hero__visual{position:relative;flex:0 0 460px;z-index:2;max-width:460px}
.sh-hero__visual svg{width:100%;height:auto;filter:drop-shadow(0 30px 70px rgba(0,0,0,.55))}
.sh-spin-slow{animation:shSpin 22s linear infinite;transform-origin:center}
.sh-float-1{animation:shFloat1 6s ease-in-out infinite;transform-origin:center}
.sh-float-2{animation:shFloat2 7.5s ease-in-out infinite;transform-origin:center}
.sh-glow{animation:shGlow 4s ease-in-out infinite}
@keyframes shSpin{to{transform:rotate(360deg)}}
@keyframes shFloat1{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes shFloat2{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-9px) rotate(3deg)}}
@keyframes shGlow{0%,100%{opacity:.4}50%{opacity:.85}}

/* equalizer eyebrow */
.sh-hero__eyebrow{display:inline-flex;align-items:center;gap:11px;font-size:12px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--sh-gold);margin-bottom:26px;padding:8px 18px 8px 14px;border:1px solid var(--sh-border);border-radius:100px;background:rgba(236,191,99,.07)}
.sh-eq{display:inline-flex;align-items:flex-end;gap:2px;height:14px}
.sh-eq span{width:3px;background:var(--sh-accent);border-radius:2px;animation:shEq 1s ease-in-out infinite}
.sh-eq span:nth-child(1){height:40%;animation-delay:0s}
.sh-eq span:nth-child(2){height:90%;animation-delay:.2s}
.sh-eq span:nth-child(3){height:60%;animation-delay:.4s}
.sh-eq span:nth-child(4){height:100%;animation-delay:.1s}
@keyframes shEq{0%,100%{transform:scaleY(.4)}50%{transform:scaleY(1)}}
.sh-hero h1{font-size:clamp(46px,6vw,76px);margin-bottom:24px;color:var(--sh-text);letter-spacing:-1px;line-height:1.02}
.sh-hero h1 em{font-style:italic;background:var(--sh-grad-fire);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.sh-hero__sub{font-size:19px;color:var(--sh-text-sec);margin-bottom:38px;max-width:460px}
.sh-hero__actions{display:flex;gap:14px;flex-wrap:wrap}

/* Buttons */
.sh-btn{position:relative;display:inline-flex;align-items:center;gap:9px;padding:15px 32px;border-radius:100px;font-family:'Inter',sans-serif;font-size:15px;font-weight:600;border:none;cursor:pointer;transition:all var(--sh-transition);text-decoration:none;overflow:hidden;isolation:isolate}
.sh-btn--primary{background:var(--sh-grad-fire);color:#fff;box-shadow:0 12px 32px -8px rgba(236,90,38,.65)}
.sh-btn--primary::after{content:'';position:absolute;inset:0;z-index:-1;background:var(--sh-grad-warm-rev);opacity:0;transition:opacity var(--sh-transition)}
.sh-btn--primary:hover{color:#fff;transform:translateY(-2px);box-shadow:0 18px 42px -8px rgba(236,90,38,.75)}
.sh-btn--primary:hover::after{opacity:1}
.sh-btn--outline{background:rgba(255,255,255,.04);color:var(--sh-text);border:1px solid var(--sh-border)}
.sh-btn--outline:hover{border-color:var(--sh-accent);color:var(--sh-text);background:rgba(236,90,38,.12);transform:translateY(-2px)}
.sh-btn--sm{padding:10px 22px;font-size:13px}
.sh-btn--gold{background:linear-gradient(135deg,var(--sh-gold),var(--sh-gold-deep));color:var(--sh-hero-dark);box-shadow:0 10px 32px -6px rgba(236,191,99,.45)}
.sh-btn--gold:hover{color:var(--sh-hero-dark);transform:translateY(-2px)}
.sh-btn__arrow{transition:transform var(--sh-transition)}
.sh-btn:hover .sh-btn__arrow{transform:translateX(4px)}

/* Stats */
.sh-stats{display:flex;gap:0;margin-top:56px}
.sh-stats>div{padding-right:40px;margin-right:40px;border-right:1px solid var(--sh-border)}
.sh-stats>div:last-child{border-right:none;padding-right:0;margin-right:0}
.sh-stat__val{font-family:'DM Serif Display',serif;font-size:42px;background:var(--sh-grad-fire);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;line-height:1}
.sh-stat__label{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--sh-text-muted);margin-top:8px}

/* Section heading */
.sh-heading{text-align:center;margin-bottom:60px}
.sh-heading .sh-kicker{margin-bottom:18px}
.sh-heading h2{font-size:clamp(34px,4.5vw,52px);margin-bottom:16px;letter-spacing:-.8px}
.sh-heading p{color:var(--sh-text-sec);font-size:16px;max-width:580px;margin:0 auto}

/* Game Cards — tracklist tiles */
.sh-games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(272px,1fr));gap:24px;counter-reset:sh-trk}
.sh-game-card{position:relative;counter-increment:sh-trk;background:linear-gradient(180deg,var(--sh-card),var(--sh-surface));border-radius:var(--sh-radius);overflow:hidden;border:1px solid var(--sh-border);transition:transform var(--sh-transition),box-shadow var(--sh-transition),border-color var(--sh-transition)}
.sh-game-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--sh-grad-fire);opacity:0;transition:opacity var(--sh-transition);z-index:4}
.sh-game-card:hover{border-color:var(--sh-border-warm);transform:translateY(-7px);box-shadow:var(--sh-shadow-card)}
.sh-game-card:hover::before{opacity:1}
.sh-game-card__thumb{position:relative;height:188px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.sh-game-card__thumb-bg{position:absolute;inset:0;transition:transform .55s ease}
.sh-game-card__thumb-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 42%,rgba(4,22,22,.6) 100%)}
.sh-game-card:hover .sh-game-card__thumb-bg{transform:scale(1.09)}
.sh-game-card__thumb::before{content:'';position:absolute;top:0;left:-75%;width:50%;height:100%;z-index:2;background:linear-gradient(100deg,transparent,rgba(255,255,255,.22),transparent);transform:skewX(-18deg);transition:left .6s ease}
.sh-game-card:hover .sh-game-card__thumb::before{left:130%}
/* tracklist number */
.sh-game-card__body::before{content:counter(sh-trk,decimal-leading-zero);position:absolute;top:14px;right:14px;z-index:3;font-family:'DM Serif Display',serif;font-size:20px;color:var(--sh-gold);text-shadow:0 2px 8px rgba(0,0,0,.6);opacity:.9}
.sh-game-card__art{position:relative;z-index:1;width:82px;height:82px;opacity:.95;filter:drop-shadow(0 6px 14px rgba(0,0,0,.45));transition:transform .55s ease}
.sh-game-card:hover .sh-game-card__art{transform:scale(1.12) translateY(-2px)}
.sh-game-card__art svg{width:100%;height:100%;fill:var(--sh-cream)}
.sh-game-card__badge{position:absolute;top:14px;left:14px;z-index:3;background:rgba(4,22,22,.62);backdrop-filter:blur(8px);color:var(--sh-gold);font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:5px 12px;border-radius:100px;border:1px solid var(--sh-border)}
.sh-game-card__body{padding:20px 22px 22px}
.sh-game-card__title{font-family:'DM Serif Display',serif;font-size:20px;margin-bottom:11px;color:var(--sh-text);padding-right:28px}
.sh-game-card__tags{display:flex;gap:6px;margin-bottom:18px;flex-wrap:wrap}
.sh-game-card__tag{font-size:11px;color:var(--sh-text-sec);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.04);padding:3px 10px;border-radius:100px}
.sh-game-card__play{position:relative;width:100%;padding:13px;border:none;border-radius:100px;background:var(--sh-grad-fire);color:#fff;font-family:'Inter',sans-serif;font-size:14px;font-weight:600;cursor:pointer;overflow:hidden;isolation:isolate;transition:transform var(--sh-transition),box-shadow var(--sh-transition)}
.sh-game-card__play::after{content:'';position:absolute;inset:0;z-index:-1;background:var(--sh-grad-warm-rev);opacity:0;transition:opacity var(--sh-transition)}
.sh-game-card__play:hover{box-shadow:0 10px 26px -6px rgba(236,90,38,.65)}
.sh-game-card__play:hover::after{opacity:1}

/* About / How it Works */
.sh-about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.sh-about-text h2{font-size:clamp(30px,4vw,44px);margin-bottom:20px;letter-spacing:-.6px}
.sh-about-text p{color:var(--sh-text-sec);margin-bottom:16px}
.sh-about-visual{position:relative;height:360px;background:linear-gradient(155deg,var(--sh-card),var(--sh-bg-deep));border-radius:var(--sh-radius-lg);overflow:hidden;display:flex;align-items:center;justify-content:center;border:1px solid var(--sh-border);box-shadow:var(--sh-shadow-card)}
.sh-about-visual__pattern{position:absolute;inset:0;opacity:.13;background-image:url("data:image/svg+xml,%3Csvg width='48' height='48' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M24 0L48 24L24 48L0 24Z' fill='none' stroke='%23ecbf63' stroke-width='1'/%3E%3C/svg%3E");background-size:48px 48px}
.sh-about-visual::after{content:'';position:absolute;width:300px;height:300px;background:radial-gradient(circle,rgba(236,90,38,.3),transparent 64%);filter:blur(8px)}
.sh-about-visual svg{position:relative;z-index:1;width:150px;height:150px;opacity:.6;filter:drop-shadow(0 8px 24px rgba(0,0,0,.4))}

.sh-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:48px;position:relative}
.sh-step{position:relative;text-align:center;padding:42px 26px 34px;background:linear-gradient(180deg,var(--sh-card),var(--sh-surface));border-radius:var(--sh-radius);border:1px solid var(--sh-border);transition:transform var(--sh-transition),border-color var(--sh-transition)}
.sh-step:hover{transform:translateY(-5px);border-color:var(--sh-border-warm)}
.sh-step__num{display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;margin-bottom:20px;font-family:'DM Serif Display',serif;font-size:26px;color:#fff;background:var(--sh-grad-fire);clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%);box-shadow:0 10px 26px -6px rgba(236,90,38,.6)}
.sh-step__title{font-family:'DM Serif Display',serif;font-size:20px;margin-bottom:11px}
.sh-step__desc{font-size:14px;color:var(--sh-text-sec)}

/* Features */
.sh-features{display:grid;grid-template-columns:repeat(auto-fill,minmax(252px,1fr));gap:24px}
.sh-feature{position:relative;padding:32px 26px;background:linear-gradient(180deg,var(--sh-card),var(--sh-surface));border-radius:var(--sh-radius);border:1px solid var(--sh-border);transition:transform var(--sh-transition),border-color var(--sh-transition),box-shadow var(--sh-transition)}
.sh-feature:hover{border-color:var(--sh-border-warm);transform:translateY(-5px);box-shadow:var(--sh-shadow-card)}
.sh-feature__icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;margin-bottom:20px;color:var(--sh-accent);background:rgba(236,90,38,.12);border:1px solid var(--sh-border-warm);border-radius:14px;transition:all var(--sh-transition)}
.sh-feature:hover .sh-feature__icon{background:var(--sh-grad-fire);color:#fff;border-color:transparent;box-shadow:0 10px 24px -6px rgba(236,90,38,.55)}
.sh-feature__icon svg{width:28px;height:28px}
.sh-feature h3{font-size:19px;margin-bottom:11px}
.sh-feature p{font-size:14px;color:var(--sh-text-sec)}

/* CTA band */
.sh-cta{position:relative;padding:96px 0;overflow:hidden;text-align:center;background:linear-gradient(145deg,var(--sh-bg-deep),var(--sh-surface))}
.sh-cta::before{content:'';position:absolute;inset:0;opacity:.1;background-image:url("data:image/svg+xml,%3Csvg width='58' height='58' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M29 0L58 29L29 58L0 29Z' fill='none' stroke='%23ec5a26' stroke-width='1'/%3E%3C/svg%3E");background-size:58px 58px}
.sh-cta::after{content:'';position:absolute;width:680px;height:340px;left:50%;top:-90px;transform:translateX(-50%);background:radial-gradient(ellipse,rgba(236,90,38,.3),transparent 64%);filter:blur(14px);pointer-events:none}
.sh-cta__inner{position:relative;z-index:1;max-width:640px;margin:0 auto}
.sh-cta h2{font-size:clamp(32px,4.5vw,50px);margin-bottom:16px;letter-spacing:-.6px}
.sh-cta p{font-size:18px;color:var(--sh-text-sec);margin-bottom:32px}

/* Disclaimer banner */
.sh-disclaimer{background:var(--sh-hero-dark);padding:36px 0;text-align:center;border-top:1px solid var(--sh-border)}
.sh-disclaimer p{font-size:13px;color:var(--sh-text-muted);max-width:740px;margin:0 auto}

/* Footer */
.sh-footer{background:var(--sh-hero-dark);padding:60px 0 28px;border-top:1px solid var(--sh-border);position:relative}
.sh-footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:52px;margin-bottom:40px}
.sh-footer__brand{display:flex;align-items:center;gap:11px;font-family:'DM Serif Display',serif;font-size:23px;margin-bottom:16px}
.sh-footer__brand svg{width:28px;height:28px}
.sh-footer__brand span{color:var(--sh-accent)}
.sh-footer__about{font-size:13px;color:var(--sh-text-muted);line-height:1.75}
.sh-footer h4{font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--sh-gold);margin-bottom:18px}
.sh-footer__links{list-style:none}
.sh-footer__links li{margin-bottom:10px}
.sh-footer__links a{font-size:13px;color:var(--sh-text-muted);transition:color var(--sh-transition)}
.sh-footer__links a:hover{color:var(--sh-accent)}
.sh-footer__helplines{font-size:12px;color:var(--sh-text-muted);line-height:1.95}
.sh-footer__helplines strong{color:var(--sh-text-sec)}
.sh-footer__bottom{border-top:1px solid var(--sh-border);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.sh-footer__copy{font-size:12px;color:var(--sh-text-muted)}
.sh-footer__badges{display:flex;gap:12px;align-items:center}
.sh-footer__badge{font-size:11px;font-weight:700;color:var(--sh-text-muted);background:rgba(255,255,255,.05);border:1px solid var(--sh-border);padding:5px 13px;border-radius:100px}

/* Legal pages */
.sh-legal{padding-top:130px;padding-bottom:70px;max-width:840px}
.sh-legal h1{font-size:clamp(34px,5vw,48px);margin-bottom:14px;letter-spacing:-.6px}
.sh-legal__updated{font-size:13px;color:var(--sh-text-muted);margin-bottom:40px}
.sh-legal h2{font-size:25px;margin-top:40px;margin-bottom:14px;color:var(--sh-gold)}
.sh-legal h3{font-size:19px;margin-top:28px;margin-bottom:10px}
.sh-legal p,.sh-legal li{font-size:15px;color:var(--sh-text-sec);margin-bottom:12px}
.sh-legal ul,.sh-legal ol{padding-left:24px;margin-bottom:16px}
.sh-legal a{color:var(--sh-accent)}

/* Game page */
.sh-game-page{padding-top:104px;padding-bottom:70px}
.sh-game-page__frame-wrap{position:relative;width:100%;max-width:1000px;margin:0 auto;aspect-ratio:16/9;background:var(--sh-hero-dark);border-radius:var(--sh-radius-lg);overflow:hidden;border:1px solid var(--sh-border);box-shadow:var(--sh-shadow-card)}
.sh-game-page__frame-wrap iframe{width:100%;height:100%;border:none}
.sh-game-page__spinner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:var(--sh-hero-dark);z-index:2;transition:opacity .3s}
.sh-game-page__spinner.loaded{opacity:0;pointer-events:none}
.sh-game-page__info{max-width:1000px;margin:28px auto 0;padding:26px 30px;background:linear-gradient(180deg,var(--sh-card),var(--sh-surface));border-radius:var(--sh-radius);border:1px solid var(--sh-border)}
.sh-game-page__info h1{font-size:32px;margin-bottom:10px}
.sh-game-page__meta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.sh-game-page__meta span{font-size:12px;color:var(--sh-gold);background:rgba(236,191,99,.08);border:1px solid var(--sh-border);padding:4px 13px;border-radius:100px}
.sh-game-page__desc{font-size:15px;color:var(--sh-text-sec)}
.sh-game-page__notice{font-size:12px;color:var(--sh-text-muted);margin-top:14px;padding-top:14px;border-top:1px solid var(--sh-border)}
.sh-game-page__others{max-width:1000px;margin:40px auto}
.sh-game-page__others h2{font-size:25px;margin-bottom:18px}
.sh-game-page__others-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.sh-game-page__other{display:block;padding:18px;background:linear-gradient(180deg,var(--sh-card),var(--sh-surface));border-radius:var(--sh-radius);border:1px solid var(--sh-border);text-decoration:none;transition:transform var(--sh-transition),border-color var(--sh-transition);cursor:pointer}
.sh-game-page__other:hover{border-color:var(--sh-border-warm);transform:translateY(-3px)}
.sh-game-page__other-name{font-family:'DM Serif Display',serif;font-size:16px;color:var(--sh-text);margin-bottom:4px}
.sh-game-page__other-type{font-size:12px;color:var(--sh-text-muted)}
.sh-game-page__btn-row{display:flex;gap:10px;max-width:1000px;margin:18px auto 0}

/* About page */
.sh-about-hero{padding-top:140px;padding-bottom:52px;text-align:center}
.sh-about-hero h1{font-size:clamp(40px,6vw,60px);margin-bottom:16px;letter-spacing:-1px}
.sh-about-hero p{font-size:18px;color:var(--sh-text-sec);max-width:600px;margin:0 auto}
.sh-values{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.sh-value{padding:32px;background:linear-gradient(180deg,var(--sh-card),var(--sh-surface));border-radius:var(--sh-radius);border:1px solid var(--sh-border);transition:transform var(--sh-transition),border-color var(--sh-transition)}
.sh-value:hover{transform:translateY(-5px);border-color:var(--sh-border-warm)}
.sh-value h3{font-size:20px;margin-bottom:11px}
.sh-value p{font-size:14px;color:var(--sh-text-sec)}

/* Contact */
.sh-contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px}
.sh-contact-info{padding:36px;background:linear-gradient(180deg,var(--sh-card),var(--sh-surface));border-radius:var(--sh-radius);border:1px solid var(--sh-border)}
.sh-contact-info h2{font-size:27px;margin-bottom:18px}
.sh-contact-info p{font-size:14px;color:var(--sh-text-sec);margin-bottom:12px}
.sh-contact-item{display:flex;gap:14px;align-items:flex-start;margin-bottom:20px}
.sh-contact-item__icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;color:var(--sh-accent);background:rgba(236,90,38,.12);border:1px solid var(--sh-border-warm);border-radius:11px;flex-shrink:0}
.sh-contact-item__icon svg{width:18px;height:18px}
.sh-contact-item__text{font-size:14px;color:var(--sh-text-sec);padding-top:9px}

/* Game Modal */
.sh-game-modal{display:none;position:fixed;inset:0;z-index:1100;background:var(--sh-overlay);backdrop-filter:blur(10px);align-items:center;justify-content:center;padding:16px;animation:shFade .25s ease}
@keyframes shFade{from{opacity:0}to{opacity:1}}
.sh-game-modal.open{display:flex}
.sh-game-modal__box{position:relative;width:100%;max-width:1040px;aspect-ratio:16/9;background:#000;border-radius:var(--sh-radius-lg);overflow:hidden;box-shadow:0 0 0 1px rgba(236,191,99,.2),0 34px 90px -16px rgba(0,0,0,.85)}
.sh-game-modal__close{position:absolute;top:14px;right:14px;z-index:10;width:38px;height:38px;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.12);border-radius:50%;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s}
.sh-game-modal__close:hover{background:var(--sh-accent);transform:rotate(90deg)}
.sh-game-modal__fs{position:absolute;top:14px;right:60px;z-index:10;width:38px;height:38px;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.12);border-radius:50%;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.sh-game-modal__fs:hover{background:var(--sh-accent)}
.sh-game-modal__spinner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:5}
.sh-game-modal iframe{width:100%;height:100%;border:none;position:relative;z-index:6}

/* Spinner */
.sh-spinner{width:46px;height:46px;border:3px solid rgba(236,191,99,.22);border-top-color:var(--sh-accent);border-radius:50%;animation:sh-spin .8s linear infinite}
@keyframes sh-spin{to{transform:rotate(360deg)}}

/* Age Gate */
.sh-age-gate{display:none;position:fixed;inset:0;z-index:2000;background:var(--sh-overlay);backdrop-filter:blur(12px);align-items:center;justify-content:center;padding:20px}
.sh-age-gate.open{display:flex}
.sh-age-gate__box{position:relative;background:linear-gradient(180deg,var(--sh-surface),var(--sh-bg-deep));border:1px solid var(--sh-border);border-radius:var(--sh-radius-lg);padding:48px 40px;max-width:450px;width:100%;text-align:center;box-shadow:0 34px 90px -16px rgba(0,0,0,.75);animation:shPop .35s cubic-bezier(.34,1.56,.64,1)}
@keyframes shPop{from{opacity:0;transform:scale(.94) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}
.sh-age-gate__box::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--sh-grad-fire);border-radius:var(--sh-radius-lg) var(--sh-radius-lg) 0 0}
.sh-age-gate__diamond{width:58px;height:58px;margin:0 auto 24px;filter:drop-shadow(0 6px 20px rgba(236,90,38,.55))}
.sh-age-gate__diamond svg{width:100%;height:100%}
.sh-age-gate h2{font-size:29px;margin-bottom:12px}
.sh-age-gate p{font-size:14px;color:var(--sh-text-sec);margin-bottom:28px}
.sh-age-gate__btns{display:flex;gap:12px;justify-content:center}
.sh-age-gate__deny{font-size:13px;color:var(--sh-text-muted);margin-top:18px}

/* Cookie Banner */
.sh-cookie{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1050;background:rgba(15,66,66,.93);backdrop-filter:blur(14px);border-top:1px solid var(--sh-border);padding:18px 24px}
.sh-cookie.open{display:block;animation:shSlideUp .35s ease}
@keyframes shSlideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.sh-cookie__inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.sh-cookie p{font-size:13px;color:var(--sh-text-sec);flex:1}
.sh-cookie a{color:var(--sh-accent)}

/* Scroll reveal */
.sh-reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease}
.sh-reveal.visible{opacity:1;transform:translateY(0)}

/* Mobile nav */
.sh-mobile-nav{display:none;position:fixed;inset:0;z-index:950;background:var(--sh-overlay);backdrop-filter:blur(14px);padding-top:70px}
.sh-mobile-nav.open{display:flex;flex-direction:column;align-items:center;gap:24px;padding-top:110px}
.sh-mobile-nav a{font-size:20px;color:var(--sh-text);text-decoration:none;font-weight:500}
.sh-mobile-nav a:hover{color:var(--sh-accent)}

/* Responsive */
@media(max-width:920px){
  .sh-nav{display:none}
  .sh-burger{display:block}
  .sh-hero{min-height:auto;padding-top:120px;padding-bottom:70px}
  .sh-hero .sh-container{flex-direction:column;text-align:center;gap:44px}
  .sh-hero__content{max-width:100%}
  .sh-hero__sub{max-width:100%;margin-left:auto;margin-right:auto}
  .sh-hero__actions{justify-content:center}
  .sh-hero__eyebrow{margin-left:auto;margin-right:auto}
  .sh-hero__visual{flex:0 0 auto;max-width:360px;margin:0 auto}
  .sh-stats{gap:0;justify-content:center}
  .sh-stats>div{padding-right:26px;margin-right:26px}
  .sh-about-grid{grid-template-columns:1fr;gap:36px}
  .sh-steps{grid-template-columns:1fr}
  .sh-footer__grid{grid-template-columns:1fr;gap:36px}
  .sh-contact-grid{grid-template-columns:1fr}
  .sh-section{padding:80px 0}
  .sh-game-modal__box{aspect-ratio:auto;height:80vh}
  .sh-game-page__frame-wrap{aspect-ratio:auto;height:60vh}
}
@media(max-width:480px){
  .sh-container{padding:0 20px}
  .sh-hero__actions{flex-direction:column}
  .sh-hero__actions .sh-btn{justify-content:center}
  .sh-games-grid{grid-template-columns:1fr}
  .sh-stats{flex-wrap:wrap;gap:22px 0}
  .sh-stats>div{padding-right:22px;margin-right:22px}
}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  .sh-reveal{transition:none;opacity:1;transform:none}
  .sh-spinner,.sh-spin-slow,.sh-eq span{animation:none}
  .sh-hero::before,.sh-hero::after,.sh-float-1,.sh-float-2,.sh-glow{animation:none}
  *{transition-duration:0s!important}
}
