:root {
  --bg: #060a14;
  --text: #fff4d8;
  --muted: #d7c6a5;
  --dim: #95856f;
  --cream: #ffe2aa;
  --gold: #ffb84d;
  --line: rgba(255, 226, 170, .16);
  --panel: rgba(9, 14, 27, .74);
  --panel-soft: rgba(255, 255, 255, .06);
  --shadow: 0 30px 120px rgba(0, 0, 0, .62);
  --hero-bg: url('../assets/bg.png');
  --world-bg: url('../assets/bg2.png');
  --hero-overlay: linear-gradient(90deg, rgba(4, 7, 15, .96) 0%, rgba(4, 7, 15, .83) 34%, rgba(4, 7, 15, .45) 62%, rgba(4, 7, 15, .82) 100%), linear-gradient(180deg, rgba(4, 7, 15, .28), rgba(4, 7, 15, .16) 45%, #060a14 100%);
  --world-overlay: rgba(6, 10, 20, .76);
}

body.day-theme {
  --bg: #f7e6c2;
  --text: #24170f;
  --muted: #4f3b2b;
  --dim: #725943;
  --cream: #3a2413;
  --gold: #c8741a;
  --line: rgba(82, 48, 20, .22);
  --panel: rgba(255, 245, 218, .84);
  --panel-soft: rgba(255, 255, 255, .55);
  --shadow: 0 30px 120px rgba(95, 64, 28, .18);
  --hero-bg: url('../assets/bg_day.png');
  --world-bg: url('../assets/bg2_day.png');
  --hero-overlay: linear-gradient(90deg, rgba(255, 246, 220, .86) 0%, rgba(255, 246, 220, .55) 34%, rgba(255, 246, 220, .14) 62%, rgba(255, 246, 220, .55) 100%), linear-gradient(180deg, rgba(255, 246, 220, .2), rgba(255, 246, 220, .1) 45%, #f7e6c2 100%);
  --world-overlay: rgba(255, 244, 214, .66);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-width: 320px;
  font-family: Inter, Arial, sans-serif;
  color: var(--text);
  background: var(--bg);
  overflow-x: hidden;
  transition: background .75s ease, color .75s ease;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font: inherit; }

.wrap { width: min(1180px, calc(100% - 40px)); margin: 0 auto; }

/* Intro */
.intro-loader {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: grid;
  place-items: center;
  background: radial-gradient(circle at center, rgba(255, 184, 77, .14), transparent 28%), #050813;
  animation: introOut 1.1s ease 1.55s forwards;
}
.intro-mark { display: grid; place-items: center; gap: 18px; color: #ffe2aa; text-transform: uppercase; letter-spacing: .12em; font-weight: 950; animation: introMark 1.4s ease forwards; }
.intro-mark img { width: 160px; filter: drop-shadow(0 0 42px rgba(255, 184, 77, .6)); }

/* Ambient layers */
.scroll-progress { position: fixed; top: 0; left: 0; z-index: 1000; width: 0%; height: 3px; background: linear-gradient(90deg, transparent, var(--gold), #ffe2aa); box-shadow: 0 0 18px rgba(255, 184, 77, .65); }
.cursor-light { position: fixed; left: 0; top: 0; z-index: 3; width: 420px; height: 420px; border-radius: 50%; pointer-events: none; opacity: .22; background: radial-gradient(circle, rgba(255, 184, 77, .24), transparent 62%); mix-blend-mode: screen; transform: translate(-50%, -50%); }
body.day-theme .cursor-light { opacity: .12; background: radial-gradient(circle, rgba(196, 111, 24, .22), transparent 62%); }
.ambient { position: fixed; inset: 0; pointer-events: none; }
.noise { z-index: -5; opacity: .075; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E"); }
.stars { z-index: -4; opacity: .45; background-image: radial-gradient(circle, rgba(255, 244, 216, .9) 1px, transparent 1.5px), radial-gradient(circle, rgba(255, 184, 77, .65) 1px, transparent 1.5px); background-size: 120px 120px, 190px 190px; background-position: 20px 30px, 80px 70px; animation: twinkle 4.5s ease-in-out infinite; }
body.day-theme .stars { opacity: .12; filter: blur(1px); }
.lantern-flicker { z-index: -2; opacity: .9; background: radial-gradient(circle at 18% 76%, rgba(255, 132, 38, .20), transparent 14%), radial-gradient(circle at 78% 54%, rgba(255, 160, 58, .16), transparent 17%), radial-gradient(circle at 87% 28%, rgba(255, 196, 92, .14), transparent 14%); mix-blend-mode: screen; animation: lanternPulse 3.4s ease-in-out infinite; }
body.day-theme .lantern-flicker { opacity: .12; }
.sun-rays { z-index: -1; opacity: 0; mix-blend-mode: screen; background: radial-gradient(circle at 20% 0%, rgba(255, 220, 120, .70), transparent 36%), radial-gradient(circle at 60% 10%, rgba(255, 200, 100, .45), transparent 40%), linear-gradient(110deg, transparent 0%, rgba(255, 210, 120, .34) 18%, transparent 38%, rgba(255, 210, 120, .26) 55%, transparent 75%); animation: sunRayMove 8s ease-in-out infinite; transition: opacity .6s ease; }
body.day-theme .sun-rays { opacity: .85; }
.day-dust { z-index: -1; opacity: 0; background-image: radial-gradient(rgba(140, 90, 40, .48) 1.2px, transparent 1.8px), radial-gradient(rgba(255, 220, 150, .55) 1.2px, transparent 1.8px); background-size: 110px 110px, 170px 170px; background-position: 10px 20px, 60px 50px; animation: dustFloat 12s linear infinite; transition: opacity .6s ease; }
body.day-theme .day-dust { opacity: .55; }
.fog { left: -20%; right: -20%; top: auto; bottom: -10%; height: 52vh; z-index: -3; opacity: .36; filter: blur(34px); background: radial-gradient(ellipse at 20% 65%, rgba(255, 255, 255, .2), transparent 42%), radial-gradient(ellipse at 65% 55%, rgba(255, 226, 170, .12), transparent 46%), linear-gradient(90deg, transparent, rgba(255, 255, 255, .11), transparent); animation: fogMove 18s ease-in-out infinite; }
.fog-two { bottom: 18%; height: 34vh; opacity: .20; animation-duration: 28s; animation-direction: reverse; }
body.day-theme .fog { opacity: .22; filter: blur(28px); }
.petals { position: fixed; inset: 0; z-index: 2; overflow: hidden; pointer-events: none; }
.petals span { position: absolute; top: -8vh; width: 8px; height: 12px; border-radius: 70% 30% 70% 30%; background: rgba(255, 184, 77, .34); animation: fall linear infinite; }
.petals span:nth-child(1){left:8%;animation-duration:14s}.petals span:nth-child(2){left:24%;animation-duration:18s;animation-delay:-4s}.petals span:nth-child(3){left:42%;animation-duration:16s;animation-delay:-8s}.petals span:nth-child(4){left:61%;animation-duration:20s;animation-delay:-3s}.petals span:nth-child(5){left:78%;animation-duration:15s;animation-delay:-6s}.petals span:nth-child(6){left:91%;animation-duration:19s;animation-delay:-10s}

/* Header */
.site-header { position: fixed; inset: 0 0 auto 0; z-index: 50; background: linear-gradient(180deg, rgba(3, 6, 14, .88), rgba(3, 6, 14, .24)); border-bottom: 1px solid rgba(255, 226, 170, .08); backdrop-filter: blur(16px); }
body.day-theme .site-header { background: linear-gradient(180deg, rgba(255, 244, 214, .92), rgba(255, 244, 214, .55)); backdrop-filter: blur(18px); }
.nav { width: min(1280px, calc(100% - 40px)); height: 78px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; gap: 20px; }
.brand { display: flex; align-items: center; gap: 13px; font-weight: 950; letter-spacing: .05em; text-transform: uppercase; }
.brand img { width: 52px; height: 52px; object-fit: cover; border-radius: 12px; filter: drop-shadow(0 0 20px rgba(255, 184, 77, .25)); }
.nav-actions { display: flex; align-items: center; gap: 22px; color: var(--muted); font-size: 14px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }
.nav-actions a:not(.button) { opacity: .82; transition: .25s ease; }
.nav-actions a:not(.button):hover { opacity: 1; color: var(--cream); }

.theme-toggle { position: relative; width: 86px; height: 38px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255, 255, 255, .08); color: var(--cream); cursor: pointer; transition: .45s; backdrop-filter: blur(12px); }
body.day-theme .theme-toggle { background: rgba(255, 246, 220, .72); color: #3a2413; }
.theme-toggle span { position: absolute; top: 50%; z-index: 2; transform: translateY(-50%); font-size: 16px; }
.theme-toggle .sun { left: 12px; }
.theme-toggle .moon { right: 12px; }
.theme-toggle i { position: absolute; top: 4px; left: 4px; width: 30px; height: 30px; border-radius: 50%; background: linear-gradient(135deg, #ffb84d, #ffe1a2); box-shadow: 0 0 22px rgba(255, 184, 77, .45); transition: .45s cubic-bezier(.2,.8,.2,1); }
body.day-theme .theme-toggle i { left: 50px; background: linear-gradient(135deg, #fff7d8, #e28b20); }

/* UI */
.button { position: relative; display: inline-flex; justify-content: center; align-items: center; min-height: 52px; padding: 0 26px; border: 1px solid rgba(255, 226, 170, .18); border-radius: 999px; background: linear-gradient(135deg, #ffb84d, #ffe0a0); color: #271606; font-weight: 950; letter-spacing: .02em; box-shadow: 0 18px 55px rgba(255, 184, 77, .28); overflow: hidden; transition: transform .25s ease, box-shadow .25s ease; }
.button::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, transparent, rgba(255,255,255,.55), transparent); transform: translateX(-130%); transition: .65s ease; }
.button:hover { transform: translateY(-3px) scale(1.025); box-shadow: 0 24px 70px rgba(255, 184, 77, .36); }
.button:hover::after { transform: translateX(130%); }
.button:active { transform: translateY(-1px) scale(.98); }
.button.secondary { background: rgba(255,255,255,.05); color: var(--cream); box-shadow: none; backdrop-filter: blur(12px); }
.button-small { min-height: 48px; }
body.day-theme .button { background: linear-gradient(135deg, #a85a18, #e09a3c); color: #fff8e8; box-shadow: 0 12px 40px rgba(168, 90, 24, .25); }
body.day-theme .button.secondary { background: rgba(255, 247, 220, .82); color: #2a1a10; border-color: rgba(104, 61, 24, .25); box-shadow: 0 12px 34px rgba(108, 70, 28, .12); }

/* Hero */
.hero { position: relative; min-height: 100vh; display: flex; align-items: center; overflow: hidden; padding: 128px 0 80px; }
.hero::after { content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 220px; background: linear-gradient(180deg, transparent, var(--bg)); pointer-events: none; }
.hero-bg { position: absolute; inset: 0; z-index: -2; background-image: var(--hero-bg); background-position: center; background-size: cover; background-repeat: no-repeat; background-attachment: fixed; transform: scale(1.04); animation: bgBreath 14s ease-in-out infinite; transition: background-image .75s ease, transform .2s linear; }
.hero-bg::after { content: ""; position: absolute; inset: 0; background: var(--hero-overlay); transition: background .75s ease; }
.hero-inner { position: relative; z-index: 1; width: min(1280px, calc(100% - 40px)); margin: 0 auto; display: grid; grid-template-columns: 1fr .82fr; gap: 54px; align-items: center; }
.hero-copy > * { opacity: 0; transform: translateY(24px); animation: stagedIn .85s ease forwards; }
.hero-copy > *:nth-child(1){animation-delay:1.7s}.hero-copy > *:nth-child(2){animation-delay:1.85s}.hero-copy > *:nth-child(3){animation-delay:2s}.hero-copy > *:nth-child(4){animation-delay:2.15s}.hero-copy > *:nth-child(5){animation-delay:2.3s}
.kicker { display: inline-flex; align-items: center; gap: 9px; padding: 9px 14px; border: 1px solid var(--line); border-radius: 999px; background: var(--panel-soft); color: var(--cream); font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: .1em; backdrop-filter: blur(12px); }
.kicker::before { content: "✦"; color: var(--gold); }
h1 { margin: 24px 0 20px; font-size: clamp(52px, 8vw, 118px); line-height: .84; letter-spacing: -.075em; text-transform: uppercase; text-wrap: balance; text-shadow: 0 18px 70px rgba(0,0,0,.55); }
body.day-theme h1 { text-shadow: 0 14px 55px rgba(92, 58, 21, .18); }
.accent { background: linear-gradient(135deg, #fff2c7, #ffb84d 44%, #ff8f8f); -webkit-background-clip: text; background-clip: text; color: transparent; }
body.day-theme .accent { background: linear-gradient(135deg, #2a1a10, #a95812 50%, #c2523b); -webkit-background-clip: text; background-clip: text; color: transparent; }
.lead { max-width: 680px; margin: 0; color: var(--muted); font-size: 20px; line-height: 1.75; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.platforms { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 28px; }
.pill { padding: 9px 12px; border: 1px solid var(--line); border-radius: 999px; background: rgba(0,0,0,.22); color: var(--muted); font-size: 13px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }
body.day-theme .pill { background: rgba(255, 247, 222, .85); color: #4a3322; }
.logo-panel { position: relative; min-height: 520px; display: grid; place-items: center; }
.logo-panel::before { content: ""; position: absolute; width: 540px; height: 540px; border-radius: 50%; background: radial-gradient(circle, rgba(255, 184, 77, .26), transparent 62%); animation: pulse 4.8s ease-in-out infinite; }
.logo-panel img { position: relative; width: min(92%, 560px); filter: drop-shadow(0 0 28px rgba(255, 184, 77, .45)) drop-shadow(0 36px 80px rgba(0,0,0,.7)); animation: float 5.2s ease-in-out infinite; }

/* Sections */
.section { position: relative; padding: 108px 0; }
.section-title { position: relative; display: grid; grid-template-columns: 1fr .8fr; gap: 44px; align-items: end; margin-bottom: 34px; }
.section-title::before { content: ""; position: absolute; top: -26px; left: 0; width: 86px; height: 2px; background: linear-gradient(90deg, var(--gold), transparent); box-shadow: 0 0 18px rgba(255,184,77,.35); }
.eyebrow { margin-bottom: 12px; color: var(--gold); font-size: 12px; font-weight: 950; text-transform: uppercase; letter-spacing: .14em; }
h2 { margin: 0; font-size: clamp(42px, 5.8vw, 82px); line-height: .88; letter-spacing: -.065em; text-transform: uppercase; }
.section-title p { margin: 0; color: var(--muted); font-size: 17px; line-height: 1.75; }
.game-banner { position: relative; width: min(1100px, 90%); margin: 0 auto; overflow: hidden; border: 1px solid var(--line); border-radius: 12px; box-shadow: var(--shadow); }
.game-banner::before { content: ""; position: absolute; inset: 0; z-index: 2; pointer-events: none; box-shadow: inset 0 0 90px rgba(0,0,0,.42); }
.game-banner img { width: 100%; height: auto; transition: transform 1.2s ease; }
.game-banner:hover img { transform: scale(1.025); }
.cinematic-text { max-width: 900px; margin: 60px auto 0; text-align: center; opacity: 0; transform: translateY(34px); transition: opacity 1s ease, transform 1s ease; }
.cinematic-text.visible { opacity: 1; transform: none; }
.cinematic-text h3 { margin: 0 0 20px; font-size: clamp(32px, 4vw, 56px); line-height: 1; letter-spacing: -.03em; }
.cinematic-text p { max-width: 700px; margin: 0 auto; color: var(--muted); font-size: 19px; line-height: 1.8; }
.highlight-word { position: relative; display: inline-block; color: var(--gold); text-shadow: 0 0 24px rgba(255,184,77,.35); }
.highlight-word::after { content: ""; position: absolute; left: 0; right: 0; bottom: .04em; z-index: -1; height: .18em; background: linear-gradient(90deg, transparent, rgba(255,184,77,.55), transparent); transform: scaleX(0); transform-origin: left; transition: transform 1.1s ease .35s; }
.cinematic-text.visible .highlight-word::after { transform: scaleX(1); }
.story-grid { display: grid; grid-template-columns: 1.08fr .92fr; gap: 24px; margin-top: 42px; }
.panel { position: relative; overflow: hidden; padding: 34px; border: 1px solid var(--line); background: var(--panel); box-shadow: var(--shadow); backdrop-filter: blur(18px); transition: background .75s ease, color .75s ease, transform .35s ease, border-color .35s ease; }
.panel::before { content: ""; position: absolute; inset: -1px; pointer-events: none; background: radial-gradient(circle at var(--mx,80%) var(--my,20%), rgba(255,184,77,.16), transparent 34%); opacity: 0; transition: .35s; }
.panel:hover { transform: translateY(-6px); border-color: rgba(255,184,77,.35); }
.panel:hover::before { opacity: 1; }
.panel h3 { position: relative; margin: 0 0 16px; font-size: 34px; line-height: 1; letter-spacing: -.03em; }
.panel p { position: relative; margin: 0 0 18px; color: var(--muted); font-size: 17px; line-height: 1.78; }
.tags { position: relative; display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px; }
.tag { padding: 10px 13px; border: 1px solid var(--line); background: rgba(255,184,77,.10); color: var(--cream); font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: .09em; transition: .25s; }
.tag:hover { transform: translateY(-2px); background: rgba(255,184,77,.18); }

/* World */
.world-section { overflow: hidden; }
.world-bg { position: absolute; inset: 0; background-image: var(--world-bg); background-position: center; background-size: cover; background-repeat: no-repeat; background-attachment: fixed; transition: background-image .75s ease; }
.world-bg::before { content: ""; position: absolute; inset: 0; background: var(--world-overlay); transition: background .75s ease; }
.world-section::after { content: ""; position: absolute; inset: -8% 0 auto 0; height: 180px; background: linear-gradient(180deg, var(--bg), transparent); pointer-events: none; }
.world-section > .wrap { position: relative; z-index: 1; }
.features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; border: 1px solid var(--line); background: var(--line); }
.feature { position: relative; overflow: hidden; min-height: 300px; padding: 36px; background: rgba(9,14,27,.92); transition: .35s; }
body.day-theme .feature { background: linear-gradient(180deg, rgba(255,250,232,.92), rgba(255,232,184,.78)); box-shadow: inset 0 1px 0 rgba(255,255,255,.45); }
.feature::after { content: ""; position: absolute; inset: auto -20% -40% -20%; height: 120px; opacity: 0; background: radial-gradient(ellipse, rgba(255,184,77,.18), transparent 65%); transition: .35s; }
.feature:hover { transform: translateY(-6px); }
.feature:hover::after { opacity: 1; }
.icon { margin-bottom: 30px; font-size: 36px; }
.feature h3 { margin: 0 0 14px; font-size: 28px; line-height: 1; letter-spacing: -.03em; }
.feature p { margin: 0; color: var(--muted); line-height: 1.7; }

/* Studio */
.studio-section { padding: 120px 0; background: linear-gradient(180deg, transparent, rgba(255,184,77,.045), transparent); }
.studio { display: grid; grid-template-columns: .85fr 1fr; gap: 60px; align-items: center; }
.studio-logo { position: relative; display: grid; place-items: center; min-height: 460px; }
.studio-logo::before { content: ""; position: absolute; width: 520px; height: 520px; border-radius: 50%; background: radial-gradient(circle, rgba(255,184,77,.20), transparent 62%); }
.studio-logo img { position: relative; width: min(95%, 520px); filter: drop-shadow(0 35px 80px rgba(0,0,0,.55)); animation: float 5.6s ease-in-out infinite; }
.studio-copy p { max-width: 620px; color: var(--muted); font-size: 19px; line-height: 1.8; }

/* CTA / footer */
.cta { position: relative; width: min(1180px, calc(100% - 40px)); margin: 0 auto 90px; overflow: hidden; padding: 86px 36px; border: 1px solid var(--line); background: var(--panel); box-shadow: var(--shadow); text-align: center; }
body.day-theme .cta { background: linear-gradient(180deg, rgba(255,250,232,.9), rgba(255,232,184,.72)); }
.cta::before { content: ""; position: absolute; inset: -45%; background: conic-gradient(from 0deg, transparent, rgba(255,184,77,.18), transparent, rgba(255,226,170,.12), transparent); animation: slowSpin 18s linear infinite; }
.cta > * { position: relative; z-index: 1; }
.cta p { max-width: 680px; margin: 18px auto 30px; color: var(--muted); font-size: 19px; line-height: 1.7; }
.footer { width: min(1180px, calc(100% - 40px)); margin: 0 auto; padding: 30px 0 46px; display: flex; justify-content: space-between; gap: 16px; color: var(--dim); border-top: 1px solid var(--line); }

/* Animations */
.reveal { opacity: 0; transform: translateY(34px); transition: opacity .9s ease, transform .9s ease; }
.reveal.visible { opacity: 1; transform: none; }
@keyframes fall { 0%{transform:translate3d(0,-10vh,0) rotate(0);opacity:0} 10%{opacity:1} 100%{transform:translate3d(90px,110vh,0) rotate(360deg);opacity:0} }
@keyframes fogMove { 0%,100%{transform:translate3d(-4%,0,0) scale(1)} 50%{transform:translate3d(7%,-16px,0) scale(1.06)} }
@keyframes twinkle { 0%,100%{opacity:.28;filter:brightness(.8)} 50%{opacity:.62;filter:brightness(1.35)} }
@keyframes lanternPulse { 0%,100%{opacity:.52;filter:brightness(.9)} 44%{opacity:.9;filter:brightness(1.32)} 52%{opacity:.66;filter:brightness(1.05)} 58%{opacity:.84;filter:brightness(1.22)} }
@keyframes sunRayMove { 0%,100%{transform:translateX(-2%) rotate(0deg);filter:brightness(1)} 50%{transform:translateX(3%) rotate(1deg);filter:brightness(1.12)} }
@keyframes dustFloat { from{background-position:10px 20px,60px 50px} to{background-position:120px 130px,230px 220px} }
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-14px)} }
@keyframes pulse { 0%,100%{opacity:.7;transform:scale(.95)} 50%{opacity:1;transform:scale(1.06)} }
@keyframes introMark { 0%{opacity:0;transform:translateY(18px) scale(.94)} 45%{opacity:1;transform:none} 100%{opacity:1;transform:scale(1.03)} }
@keyframes introOut { to{opacity:0;visibility:hidden;pointer-events:none} }
@keyframes stagedIn { to{opacity:1;transform:none} }
@keyframes bgBreath { 0%,100%{filter:saturate(1.05) contrast(1.02)} 50%{filter:saturate(1.16) contrast(1.08) brightness(1.04)} }
@keyframes slowSpin { to{transform:rotate(360deg)} }

/* Tablet */
@media (max-width: 1024px) {
  .hero-inner, .section-title, .studio { grid-template-columns: 1fr; }
  .hero-inner { gap: 30px; }
  .logo-panel { min-height: 360px; }
  .features { grid-template-columns: 1fr; gap: 12px; background: transparent; border: 0; }
  .feature { border: 1px solid var(--line); border-radius: 16px; }
}

/* Mobile — independent layout, not just shrinked desktop */
@media (max-width: 768px) {
  html, body { width: 100%; overflow-x: hidden; }
  body { font-size: 16px; }
  .intro-loader { display: none; }
  .cursor-light, .scroll-progress { display: none; }
  .noise { opacity: .045; }
  .stars { opacity: .16; }
  body.day-theme .stars { opacity: .06; }
  .lantern-flicker { opacity: .35; }
  .sun-rays, .day-dust { opacity: .08; background-attachment: scroll; }
  body.day-theme .sun-rays { opacity: .38; }
  body.day-theme .day-dust { opacity: .22; }
  .fog { height: 28vh; bottom: -10vh; opacity: .14; filter: blur(30px); }
  .fog-two { display: none; }
  .petals span { width: 6px; height: 9px; }
  .petals span:nth-child(n+4) { display: none; }

  .site-header { height: 64px; background: rgba(5, 8, 19, .86) !important; backdrop-filter: blur(18px); }
  body.day-theme .site-header { background: rgba(255,244,214,.88) !important; }
  .nav { width: calc(100% - 24px); height: 64px; gap: 10px; }
  .brand { gap: 8px; }
  .brand img { width: 42px; height: 42px; border-radius: 10px; }
  .brand span { display: block; max-width: 120px; font-size: 11px; line-height: 1.1; letter-spacing: .06em; }
  .nav-actions { gap: 8px; margin-left: auto; }
  .nav-actions a:not(.button), .nav-actions .button { display: none; }
  .theme-toggle { width: 62px; height: 32px; }
  .theme-toggle span { font-size: 13px; }
  .theme-toggle .sun { left: 10px; }
  .theme-toggle .moon { right: 10px; }
  .theme-toggle i { top: 3px; left: 4px; width: 24px; height: 24px; }
  body.day-theme .theme-toggle i { left: 32px; }

  .hero { display: block; min-height: auto; padding: 92px 0 54px; }
  .hero::after { display: none; }
  .hero-bg { background-attachment: scroll; background-position: center top; transform: none !important; animation: none; }
  .hero-bg::after { background: linear-gradient(180deg, rgba(4,7,15,.18) 0%, rgba(4,7,15,.76) 42%, var(--bg) 100%); }
  body.day-theme .hero-bg::after { background: linear-gradient(180deg, rgba(255,246,220,.15) 0%, rgba(255,246,220,.62) 46%, var(--bg) 100%); }
  .hero-inner { width: calc(100% - 28px); display: flex; flex-direction: column; align-items: stretch; gap: 26px; }
  .hero-copy { order: 2; }
  .hero-copy > * { opacity: 1; transform: none; animation: none; }
  .logo-panel { order: 1; min-height: 190px; }
  .logo-panel::before { width: 210px; height: 210px; }
  .logo-panel img { width: min(58vw, 220px); max-width: 220px; animation: none; }
  .kicker { padding: 8px 10px; font-size: 10px; letter-spacing: .08em; }
  h1 { margin: 18px 0 16px; font-size: clamp(38px, 13vw, 58px); line-height: .9; letter-spacing: -.055em; }
  .lead { max-width: 100%; font-size: 16px; line-height: 1.65; }
  .hero-actions { display: grid; grid-template-columns: 1fr; gap: 10px; margin-top: 24px; }
  .button { width: 100%; min-height: 50px; padding: 0 18px; font-size: 14px; }
  .platforms { gap: 8px; margin-top: 18px; }
  .pill { padding: 8px 10px; font-size: 10px; }

  .wrap { width: calc(100% - 28px); }
  .section, .studio-section { padding: 56px 0; }
  .section-title { display: block; margin-bottom: 24px; }
  .section-title::before { display: none; }
  .eyebrow { margin-bottom: 10px; font-size: 10px; letter-spacing: .14em; }
  h2 { margin-bottom: 14px; font-size: clamp(32px, 11vw, 48px); line-height: .95; letter-spacing: -.05em; }
  .section-title p { font-size: 15px; line-height: 1.65; }

  .game-banner { width: calc(100% - 28px); min-height: 0; border-radius: 12px; }
  .game-banner::before { display: none; }
  .game-banner img { width: 100%; height: auto; transform: none !important; }
  .cinematic-text { width: calc(100% - 28px); margin: 32px auto 0; text-align: left; opacity: 1; transform: none; }
  .cinematic-text h3 { font-size: clamp(28px, 9vw, 40px); line-height: 1.05; }
  .cinematic-text p { font-size: 16px; line-height: 1.7; }

  .story-grid, .studio { grid-template-columns: 1fr; gap: 14px; margin-top: 28px; }
  .panel { padding: 22px; border-radius: 16px; }
  .panel:hover, .feature:hover, .button:hover { transform: none; }
  .panel h3 { font-size: 25px; line-height: 1.08; }
  .panel p { font-size: 15px; line-height: 1.68; }
  .tags { gap: 8px; }
  .tag { padding: 8px 10px; font-size: 10px; }

  .world-bg { background-attachment: scroll; background-position: center; }
  .world-section::after { height: 90px; }
  .features { grid-template-columns: 1fr; gap: 12px; background: transparent; border: none; }
  .feature { min-height: auto; padding: 22px; border: 1px solid var(--line); border-radius: 16px; backdrop-filter: blur(12px); }
  .icon { margin-bottom: 16px; font-size: 28px; }
  .feature h3 { font-size: 23px; }
  .feature p { font-size: 15px; line-height: 1.65; }

  .studio-logo { min-height: 220px; }
  .studio-logo::before { width: 240px; height: 240px; }
  .studio-logo img { width: min(68vw, 260px); animation: none; }
  .studio-copy p { font-size: 16px; line-height: 1.7; }

  .cta { width: calc(100% - 28px); margin-bottom: 48px; padding: 44px 20px; border-radius: 16px; }
  .cta p { font-size: 16px; line-height: 1.65; }
  .footer { width: calc(100% - 28px); flex-direction: column; gap: 8px; padding: 24px 0 34px; font-size: 13px; }
}

@media (max-width: 420px) {
  .brand span { display: none; }
  .hero { padding-top: 82px; }
  h1 { font-size: clamp(34px, 14vw, 52px); }
  .lead, .panel p, .feature p, .section-title p, .cta p { font-size: 14.5px; }
  .logo-panel { min-height: 160px; }
  .logo-panel img { width: min(54vw, 190px); }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
  .reveal, .cinematic-text { opacity: 1; transform: none; }
}
