.games-shell { background:#f7f4f0; }
.games-hero { display:grid; min-height:610px; grid-template-columns:1.08fr .92fr; align-items:center; gap:70px; padding:60px 92px 90px; }
.games-kicker { margin:0 0 14px; color:#d85e36; font-size:13px; font-weight:700; }.games-kicker span { color:var(--yellow); font-size:20px; }
.games-hero h1 { margin:0; font-size:clamp(46px,5vw,70px); font-weight:500; line-height:1.25; }.games-hero h1 strong { position:relative; font-family:"Noto Serif SC",serif; font-weight:700; }.games-hero h1 strong::after { position:absolute; right:0; bottom:-10px; left:0; height:7px; border-radius:50%; background:var(--blue); content:""; transform:rotate(-1deg); }
.games-hero-copy>p:not(.games-kicker){ max-width:610px; margin:34px 0 28px; color:#625d67; font-size:14px; line-height:1.9; }
.games-primary-button { display:inline-flex; min-height:46px; align-items:center; gap:9px; padding:0 20px; border-radius:999px; background:var(--coral); font-size:13px; font-weight:700; transition:.18s; }.games-primary-button:hover{background:var(--yellow);transform:translateY(-2px)}.games-primary-button svg{width:16px}
.games-hero-stage{position:relative;min-height:460px;perspective:900px;isolation:isolate}
.stage-hint{position:absolute;right:18%;bottom:0;margin:0;color:#8a837b;font-size:10px;font-weight:600}
.stage-card{position:absolute;display:grid;place-items:center;border-radius:18px;box-shadow:0 18px 36px rgba(25,21,33,.1);will-change:transform;transition:box-shadow .25s,filter .25s}
.stage-card:hover{z-index:4;box-shadow:0 25px 46px rgba(25,21,33,.16);filter:saturate(1.05)}
.stage-word{top:105px;left:-6px;width:270px;height:180px;transform-style:preserve-3d;animation:float-word 5.6s ease-in-out infinite;background:transparent;box-shadow:none}
.stage-word:hover{box-shadow:none;filter:none}.word-svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible;filter:drop-shadow(0 18px 14px rgba(25,21,33,.2));backface-visibility:hidden;transition:transform .55s cubic-bezier(.2,.8,.2,1)}.word-edge{fill:#267cae}.word-svg-small{fill:#fff;font-family:"DM Sans",sans-serif;font-size:10px;font-weight:700;letter-spacing:1px;opacity:.78}.word-svg-title{fill:#fff;font-family:"DM Sans",sans-serif;font-size:27px;font-weight:700}.word-svg-cn{font-family:"Noto Serif SC",serif;font-size:25px}
.stage-word .word-card-front{transform:rotateY(0)}.stage-word .word-card-back{transform:rotateY(180deg)}
.stage-word:hover .word-card-front{transform:rotateY(-180deg)}.stage-word:hover .word-card-back{transform:rotateY(0)}
.stage-dice{top:24px;right:12%;width:155px;height:165px;background:transparent;box-shadow:none;animation:float-dice 4.8s ease-in-out infinite}
.stage-dice:hover{box-shadow:none;filter:none}
.dice-svg{width:100%;height:100%;overflow:visible;filter:drop-shadow(0 18px 13px rgba(25,21,33,.16));transition:transform .7s cubic-bezier(.2,.8,.2,1)}
.dice-top{fill:#ffe45b}.dice-left{fill:#f6b73c}.dice-right{fill:#e58c28}.dice-pips{fill:#fffdf8}.stage-dice small,.stage-flask small{position:absolute;bottom:1px;font-size:8px;font-weight:700;opacity:.62}.stage-dice:hover .dice-svg{transform:rotate(24deg) translateY(-5px) scale(1.08)}
.stage-dice:hover .dice-pips-top{animation:pip-pop .38s ease both}.stage-dice:hover .dice-pips-left{animation:pip-pop .38s .08s ease both}.stage-dice:hover .dice-pips-right{animation:pip-pop .38s .16s ease both}
.stage-flask{right:0;bottom:20px;width:205px;height:240px;color:#554064;background:transparent;box-shadow:none;animation:float-flask 6.2s ease-in-out infinite}.stage-flask:hover{box-shadow:none;filter:none}
.flask-svg{width:100%;height:100%;overflow:visible;filter:drop-shadow(0 19px 14px rgba(80,45,95,.2));transition:transform .45s}.stage-flask:hover .flask-svg{transform:rotate(7deg) scale(1.045)}.stage-flask:hover .flask-liquid{animation:liquid-swish .65s ease both}
.stage-bubble{position:absolute;border-radius:50%;background:#ffd34e;box-shadow:0 4px 8px rgba(80,45,95,.16);opacity:0}.bubble-a{top:77px;left:72px;width:11px;height:11px}.bubble-b{top:55px;left:99px;width:17px;height:17px}.bubble-c{top:34px;left:129px;width:9px;height:9px}.stage-flask:hover .stage-bubble{animation:stage-bubble .7s ease-out both}.stage-flask:hover .bubble-b{animation-delay:.09s}.stage-flask:hover .bubble-c{animation-delay:.17s}
.stage-spark{position:absolute;color:var(--yellow);font-size:31px;animation:spark-pulse 3s ease-in-out infinite}.spark-a{top:50px;left:22%}.spark-b{right:40%;bottom:75px;animation-delay:1.3s}
.stage-orbit{position:absolute;z-index:-1;border:1px solid rgba(25,21,33,.1);border-radius:50%;transform:rotate(-12deg)}.orbit-a{inset:25px 5px 20px 0}.orbit-b{inset:85px 50px 65px 60px;border-color:rgba(85,194,230,.24);transform:rotate(18deg)}
@keyframes float-word{0%,100%{transform:translate3d(0,0,0) rotate(-5deg)}50%{transform:translate3d(0,-12px,0) rotate(-2deg)}}@keyframes float-dice{0%,100%{transform:translate3d(0,0,20px) rotate(-3deg)}50%{transform:translate3d(7px,-16px,30px) rotate(5deg)}}@keyframes float-flask{0%,100%{transform:translate3d(0,0,10px) rotate(-7deg)}50%{transform:translate3d(-5px,-10px,10px) rotate(-11deg)}}@keyframes stage-bubble{from{opacity:0;transform:translateY(18px) scale(.5)}to{opacity:1;transform:translateY(-12px) scale(1)}}@keyframes spark-pulse{0%,100%{opacity:.4;transform:rotate(0) scale(.85)}50%{opacity:1;transform:rotate(35deg) scale(1.1)}}@keyframes pip-pop{0%{opacity:.4;transform:scale(.6)}70%{opacity:1;transform:scale(1.25)}100%{opacity:1;transform:scale(1)}}@keyframes liquid-swish{0%,100%{transform:rotate(0);transform-origin:center}50%{transform:rotate(-5deg);transform-origin:center}}
.open-games{padding:105px 0 100px;background:var(--paper)}.games-section-heading{display:flex;align-items:end;justify-content:space-between;padding:0 86px}.games-section-heading p{margin:0 0 7px;font-size:12px;font-weight:600}.games-section-heading h2{margin:0;font-family:"Noto Serif SC",serif;font-size:clamp(40px,4vw,58px)}.games-section-heading>div:first-child>span{display:block;width:200px;height:7px;margin:7px 0 0 85px;border-radius:50%;background:var(--yellow);transform:rotate(-2deg)}.games-arrows{display:flex;gap:12px}.games-arrows button{display:grid;width:48px;height:48px;place-items:center;border:0;border-radius:50%;background:var(--yellow);cursor:pointer;transition:.18s}.games-arrows button:hover{background:var(--coral);transform:translateY(-2px)}.games-arrows svg{width:18px}
.games-carousel{overflow:hidden;margin-top:42px}.games-track{display:flex;gap:18px;width:max-content;padding:0 86px;will-change:transform}.game-card{width:340px;flex:0 0 340px;overflow:hidden;border:1px solid #ebe5dd;border-radius:18px;background:#f8f6f3;transition:background-color .2s,transform .2s,box-shadow .2s}.game-card:hover{transform:translateY(-6px);box-shadow:0 17px 30px rgba(25,21,33,.08)}.coral-game:hover{background:#f3e6e1}.blue-game:hover{background:#e8eff2}.yellow-game:hover{background:#f3efe2}.green-game:hover{background:#e6eee8}.violet-game:hover{background:#ece8f0}
.game-cover{position:relative;display:grid;height:235px;place-items:center;overflow:hidden;background:#d98876}.game-cover::before{position:absolute;right:-60px;bottom:-75px;width:230px;height:190px;border-radius:50%;background:rgba(80,45,44,.13);content:""}.game-code{position:absolute;z-index:2;top:16px;left:18px;color:rgba(255,255,255,.85);font-size:9px;font-weight:700}.game-cover>svg{z-index:1;width:72px;height:72px;color:#fff;transition:transform .3s}.game-card:hover .game-cover>svg{transform:rotate(7deg) scale(1.06)}.game-cover>small{position:absolute;right:17px;bottom:13px;color:rgba(255,255,255,.75);font-size:10px;font-weight:700}
.image-cover{height:auto;aspect-ratio:16/9}.image-cover::before{display:none}.game-cover-image{display:block;width:100%;height:100%;object-fit:cover;transition:transform .38s ease}.game-card:hover .game-cover-image{transform:scale(1.035)}.image-cover .game-code{padding:6px 9px;border-radius:999px;background:rgba(25,21,33,.72);color:#fff;box-shadow:0 4px 12px rgba(25,21,33,.18);letter-spacing:.04em}
.sentence-cover{background:#7eaec0}.sentence-cover>div{z-index:1;display:flex;gap:5px;transition:transform .3s}.sentence-cover b{padding:8px 10px;border-radius:7px;background:rgba(255,255,255,.92);font-size:11px}.game-card:hover .sentence-cover>div{transform:translateX(8px)}
.missing-cover{background:#67b9dc}.missing-cover>div{z-index:1;display:flex;align-items:center;gap:8px}.missing-cover b{display:grid;width:54px;height:70px;place-items:center;border-radius:9px;background:#fff;color:#4388aa;font-size:22px;transition:.28s}.missing-cover b:nth-child(2){background:#ffd064;color:#393344}.game-card:hover .missing-cover b:first-child{transform:translateY(-8px) rotate(-5deg)}.game-card:hover .missing-cover b:last-child{transform:translateY(8px) rotate(5deg)}
.message-cover{background:#62ad82}.message-cover>svg{width:78px;height:78px}.message-cover::after{position:absolute;top:42px;right:58px;width:18px;height:18px;border-radius:50%;background:#ffd064;box-shadow:-124px 75px 0 #ff8b67;content:""}
.yellow-game .game-cover{background:#cdbd79}.green-game .game-cover{background:#7da489}.violet-game .game-cover{background:#9985ad}.sound-cover>div{position:absolute;right:40px;bottom:38px;display:flex;align-items:end;gap:3px;height:35px}.sound-cover b{display:block;width:4px;height:30%;border-radius:4px;background:#fff;transition:height .2s}.sound-cover b:nth-child(2){height:70%}.sound-cover b:nth-child(3){height:45%}.sound-cover b:nth-child(4){height:100%}.game-card:hover .sound-cover b{animation:soundbar .5s ease infinite alternate}@keyframes soundbar{to{height:100%}}
.flip-mini{z-index:1;display:flex;gap:8px;perspective:500px}.flip-mini span{display:grid;width:75px;height:100px;place-items:center;border-radius:11px;background:#fff;color:#746083;font-size:25px;font-weight:700;transition:transform .45s}.game-card:hover .flip-mini span:last-child{transform:rotateY(180deg)}
.game-copy{min-height:235px;padding:25px 28px 27px}.game-copy p{margin:0 0 10px;font-size:10px;font-weight:600}.game-copy h3{margin:0 0 13px;font-family:"Noto Serif SC",serif;font-size:25px}.game-copy>span{display:block;min-height:55px;color:#625d67;font-size:12px;line-height:1.8}.game-copy a{display:inline-flex;align-items:center;gap:8px;margin-top:23px;padding-bottom:2px;border-bottom:1px solid var(--ink);font-size:11px;font-weight:600}.game-copy a svg{width:14px;transition:transform .2s}.game-card:hover .game-copy a svg{transform:translateX(4px)}
.unlock-lab{display:grid;grid-template-columns:.82fr 1.18fr;align-items:center;gap:75px;padding:115px 92px;background:#f7f4f0}.unlock-lab-copy h2{margin:0;font-size:clamp(40px,4.5vw,62px);font-weight:500;line-height:1.28}.unlock-lab-copy h2 strong{font-family:"Noto Serif SC",serif;font-weight:700}.unlock-lab-copy>p:not(.games-kicker){max-width:570px;margin:28px 0;color:#625d67;font-size:14px;line-height:1.9}
.incubator-card{display:grid;grid-template-columns:1.1fr .9fr;align-items:center;min-height:500px;padding:25px 34px 25px 20px;border-radius:24px;background:#fff;box-shadow:0 22px 55px rgba(25,21,33,.09)}.incubator-visual{position:relative;min-height:450px}.incubator-svg{width:100%;height:450px;overflow:visible;filter:drop-shadow(0 22px 15px rgba(25,21,33,.1))}.incubator-headphones{transform-origin:center;animation:headphone-float 4s ease-in-out infinite}.incubator-letters{font-family:"DM Sans",sans-serif;font-size:18px;font-weight:700;fill:#fff;transform-origin:center;animation:letters-orbit 7s ease-in-out infinite}.incubator-waves{opacity:.32;transform-origin:center;transition:opacity .25s,transform .45s}.incubator-card:hover .incubator-waves{opacity:1;transform:scale(1.12)}.incubator-card:hover .incubator-glass{animation:glass-glow 1.5s ease-in-out infinite alternate}
.incubator-spark{position:absolute;color:#ffd34e;font-size:27px;animation:spark-pulse 2.8s ease-in-out infinite}.incubator-spark-one{top:70px;left:11%}.incubator-spark-two{top:42px;right:12%;animation-delay:.8s}.incubator-spark-three{right:8%;bottom:75px;animation-delay:1.6s}
.incubator-info p{margin:0 0 9px;color:#7d756d;font-size:10px;font-weight:600}.incubator-info h3{margin:0 0 45px;font-family:"Noto Serif SC",serif;font-size:27px;line-height:1.4}.energy-labels{display:flex;align-items:end;justify-content:space-between;margin-bottom:9px}.energy-labels span{font-size:10px;font-weight:600}.energy-labels strong{font-size:18px}.energy-tube{height:15px;overflow:hidden;border:2px solid #554064;border-radius:10px;background:#f2eee8}.energy-tube span{display:block;width:0;height:100%;border-radius:8px;background:linear-gradient(90deg,#ffd34e,#ff8b67);transition:width 1.3s cubic-bezier(.2,.8,.2,1)}.unlock-lab.in-view .energy-tube span{width:72%}.incubator-info small{display:block;margin-top:10px;color:#7d756d;font-size:9px}
@keyframes headphone-float{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-9px) rotate(2deg)}}@keyframes letters-orbit{0%,100%{transform:rotate(-2deg)}50%{transform:rotate(4deg) translateY(-5px)}}@keyframes glass-glow{to{filter:saturate(1.25) drop-shadow(0 0 9px rgba(85,194,230,.42))}}
@media(max-width:900px){.games-hero{grid-template-columns:1fr;padding:42px 28px 65px}.games-hero-stage{min-height:390px}.games-section-heading{padding:0 28px}.games-track{padding:0 28px}.game-card{width:310px;flex-basis:310px}}
@media(max-width:1050px){.unlock-lab{grid-template-columns:1fr;padding:90px 28px}.incubator-card{max-width:750px}}
@media(max-width:650px){.incubator-card{grid-template-columns:1fr;padding:15px 20px 35px}.incubator-visual{min-height:370px}.incubator-svg{height:370px}.incubator-info h3{margin-bottom:28px}}
@media(max-width:560px){.games-hero{padding:30px 22px 60px}.games-hero h1{font-size:42px}.games-hero-stage{min-height:340px}.stage-word{width:200px;height:130px}.stage-flask{width:135px;height:155px}.games-section-heading{align-items:start;flex-direction:column;gap:25px;padding:0 22px}.games-track{padding:0 22px}.game-card{width:82vw;flex-basis:82vw}.unlock-lab{padding:72px 22px}.unlock-lab-copy h2{font-size:39px}}

/* Unified section heading rhythm */
.games-section-heading h2{font-size:clamp(32px,3.2vw,40px)}
