:root{
  --bg:#07101f;
  --bg2:#101935;
  --card:rgba(18,26,48,.78);
  --card-solid:#131d36;
  --line:rgba(215,228,255,.14);
  --text:#eef3ff;
  --muted:#b7c4ea;
  --moon:#dce8ff;
  --lav:#cab9ff;
  --pink:#ffbfd7;
  --accent:#7fc8ff;
  --danger:#ff7b8b;
  --good:#74f0bf;
  --shadow:0 16px 40px rgba(0,0,0,.35);
  --radius:24px;
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text)}
body{position:relative;overflow-x:hidden}
body.dom-game-open{height:100dvh;max-height:100dvh;overflow:hidden}
body.viewer-open{overflow:hidden}
button{font:inherit;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
img,video{max-width:100%;display:block}
.hero>*,.topbar>*,.cards-layout>*,.vn-layout>*,.game-card{min-width:0}
h1,h2,h3,.game-title,.dialogue-text{overflow-wrap:anywhere}
.app-bg{
  position:fixed;inset:0;
  background:
    radial-gradient(circle at 20% 10%, rgba(151,178,255,.28), transparent 28%),
    radial-gradient(circle at 80% 0%, rgba(196,177,255,.18), transparent 22%),
    linear-gradient(180deg, rgba(8,15,33,.75), rgba(4,8,19,.96)),
    url('assets/main_bg.png') center/cover no-repeat;
  filter:saturate(1.1) brightness(.75);
  z-index:-2;
}
.app-bg::after{content:'';position:absolute;inset:0;background:rgba(6,9,18,.38);backdrop-filter:blur(6px)}
.screen{display:none;padding:clamp(14px,2vw,24px);max-width:1260px;margin:0 auto}
.screen.active{display:block}
.glass{background:var(--card);backdrop-filter:blur(16px);border:1px solid var(--line);box-shadow:var(--shadow)}
.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:20px;align-items:stretch;padding-top:10px}
.hero-media,.hero-copy{border-radius:var(--radius);overflow:hidden;position:relative}
.hero-media::after{content:'';position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,transparent 55%,rgba(5,9,20,.58))}
.hero-video{width:100%;height:100%;object-fit:cover;min-height:320px;max-height:540px;filter:saturate(1.05) contrast(1.05)}
.floating-chip{position:absolute;right:14px;bottom:14px}
.hero-copy{padding:clamp(18px,2vw,30px);display:flex;flex-direction:column;justify-content:center}
.eyebrow{margin:0 0 8px;color:#d1dcff;letter-spacing:.16em;text-transform:uppercase;font-size:.76rem}
h1,h2,h3,p{margin:0}
h1{font-size:clamp(2.2rem,5vw,4.3rem);line-height:.95;margin-bottom:12px}
h2{font-size:clamp(1.5rem,3.2vw,2.4rem)}
.lead{color:var(--muted);font-size:clamp(1rem,1.6vw,1.1rem);line-height:1.65;max-width:62ch}
.avatar-row{display:flex;gap:14px;flex-wrap:wrap;margin:24px 0}
.avatar-card{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:18px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);min-width:220px}
.avatar-card img{width:64px;height:64px;border-radius:50%;object-fit:cover;background:#090f20}
.avatar-card strong{display:block;font-size:1rem}
.avatar-card small{color:var(--muted)}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.primary-btn,.secondary-btn,.chip,.game-card,.action-btn,.option-btn,.small-btn,.menu-link{
  border:none;border-radius:16px;cursor:pointer;transition:.2s transform,.2s opacity,.2s background,.2s border-color;
}
.primary-btn,.secondary-btn,.chip,.small-btn,.menu-link{padding:13px 18px;color:var(--text)}
.primary-btn{background:linear-gradient(135deg, #e5edff, #c3b7ff);color:#11162b;font-weight:800}
.secondary-btn{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1)}
.chip{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12)}
.chip.danger{color:#ffd2da;border-color:rgba(255,130,148,.35)}
.primary-btn:hover,.secondary-btn:hover,.chip:hover,.game-card:hover,.action-btn:hover,.option-btn:hover,.small-btn:hover,.menu-link:hover{transform:translateY(-1px)}
.summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:18px 0 22px}
.stat-box{padding:18px;border-radius:22px;text-align:center}
.stat-box span{display:block;font-size:1.8rem;font-weight:800;margin-bottom:6px;color:var(--pink);text-shadow:0 0 20px rgba(255,122,166,.3)}
.stat-box small{color:#e4d9fa;line-height:1.4}
.memory-section{padding:clamp(16px,2.2vw,26px);border-radius:var(--radius);margin:0 0 24px}
.memory-headline{align-items:center}
.memory-note{max-width:30ch;color:var(--muted);line-height:1.5;text-align:right}
.memory-actions{display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.gallery-open-btn{padding:10px 15px;white-space:nowrap}
.memory-gallery{columns:3 280px;column-gap:12px}
.memory-photo{position:relative;isolation:isolate;display:inline-block;width:100%;margin:0 0 12px;overflow:hidden;border-radius:20px;background:#0a1122;border:1px solid rgba(255,255,255,.12);box-shadow:0 12px 28px rgba(0,0,0,.2);break-inside:avoid;cursor:zoom-in}
.memory-photo img{width:100%;height:auto;object-fit:contain;transition:transform .5s ease,filter .5s ease}
.memory-photo::before{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(135deg,rgba(180,202,255,.12),transparent 40%);pointer-events:none}
.memory-photo::after{content:'';position:absolute;inset:38% 0 0;z-index:1;background:linear-gradient(transparent,rgba(5,8,18,.92));pointer-events:none}
.memory-photo figcaption{position:absolute;left:16px;right:16px;bottom:14px;z-index:2;display:flex;flex-direction:column;gap:4px;color:#fff;font-weight:750;text-shadow:0 2px 12px #000}
.memory-photo figcaption small{color:#dbe5ff;font-size:.68rem;font-weight:650;letter-spacing:.13em;text-transform:uppercase}
.memory-photo:hover img{transform:scale(1.045);filter:saturate(1.1) contrast(1.03)}
.photo-viewer{position:fixed;inset:0;z-index:100;display:grid;grid-template-columns:minmax(54px,1fr) minmax(0,1100px) minmax(54px,1fr);align-items:center;gap:16px;padding:clamp(12px,3vw,32px);background:rgba(2,5,12,.94);backdrop-filter:blur(18px)}
.photo-viewer-content{grid-column:2;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;width:100%;height:100%;max-height:calc(100dvh - 48px);margin:0}
.photo-viewer-content img{width:100%;height:calc(100% - 62px);min-height:0;object-fit:contain;filter:drop-shadow(0 18px 38px rgba(0,0,0,.5))}
.photo-viewer-content figcaption{color:#fff;font-weight:750;text-align:center}
.photo-viewer-count{color:var(--muted);font-size:.82rem}
.photo-viewer-close,.photo-viewer-nav{position:absolute;z-index:2;display:grid;place-items:center;border:1px solid rgba(255,255,255,.16);background:rgba(16,25,46,.82);color:#fff;cursor:pointer;backdrop-filter:blur(10px)}
.photo-viewer-close{top:max(14px,env(safe-area-inset-top));right:16px;width:46px;height:46px;border-radius:50%;font-size:2rem;line-height:1}
.photo-viewer-nav{top:50%;width:52px;height:72px;border-radius:18px;transform:translateY(-50%);font-size:2.5rem}
.photo-viewer-prev{left:16px}.photo-viewer-next{right:16px}
.photo-viewer-close:hover,.photo-viewer-nav:hover{background:rgba(45,59,94,.95)}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:20px;margin-bottom:14px}
.game-select{margin-top:10px}
.game-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.game-card{padding:20px;background:linear-gradient(145deg, rgba(24,36,66,.96), rgba(11,17,34,.94));border:1px solid rgba(215,228,255,.13);color:var(--text);text-align:left;min-height:200px;position:relative;overflow:hidden;box-shadow:0 10px 28px rgba(0,0,0,.2)}
.game-card::before{content:'';position:absolute;inset:auto -20px -20px auto;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle, rgba(199,216,255,.16), transparent 70%)}
.game-card .num{display:inline-flex;width:44px;height:44px;border-radius:50%;align-items:center;justify-content:center;background:rgba(255,255,255,.08);margin-bottom:14px;color:var(--moon);font-weight:800}
.game-card h3{margin-bottom:6px;font-size:1.15rem}
.game-card p{color:var(--muted);line-height:1.5;font-size:.95rem;min-height:68px}
.game-meta{display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap;margin-top:12px;color:#cbd8fa;font-size:.85rem}
.badge{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;background:rgba(255,255,255,.08)}
.progress-dot{width:10px;height:10px;border-radius:50%;background:#58698f}
.progress-dot.done{background:var(--good);box-shadow:0 0 10px rgba(116,240,191,.5)}
.topbar{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:12px 14px;border-radius:22px;margin-bottom:14px}
.topbar-left{display:flex;align-items:center;gap:12px}
.topbar-left .chip{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:44px;line-height:1;white-space:nowrap;flex:0 0 auto;transform:translateZ(0);backface-visibility:hidden;-webkit-font-smoothing:antialiased}
.menu-arrow{display:inline-grid;place-items:center;width:18px;height:18px;line-height:18px;font-size:1.15rem;transform:translateY(-.5px)}
.topbar-left .chip:hover{transform:translateZ(0)}
.game-title{font-size:1.15rem;font-weight:800}
.game-subtitle{color:var(--muted)}
.hud-mini{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.pill{padding:7px 12px;border-radius:999px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);font-size:.88rem;color:#eaf1ff}
#playScreen.active{display:grid;height:100dvh;max-height:100dvh;grid-template-rows:auto minmax(0,1fr);overflow:hidden;padding-bottom:82px}
.stage-wrap{border-radius:28px;padding:12px;min-height:0;position:relative;overflow:hidden}
#gameCanvas,.dom-stage{width:100%;height:100%;min-height:300px;border-radius:20px;background:rgba(8,12,24,.88)}
#gameCanvas{display:block;touch-action:none}
.dom-stage{padding:18px;overflow:auto}
#playScreen.active.dom-mode{display:grid;height:100dvh;max-height:100dvh;min-height:0;grid-template-rows:auto minmax(0,1fr);overflow:hidden;padding-bottom:8px}
#playScreen.dom-mode .stage-wrap{height:100%;min-height:0;overflow:hidden}
#playScreen.dom-mode .dom-stage{height:100%;min-height:0;overflow:hidden}
.dom-fit-content{width:100%;max-width:100%;transform-origin:top center;will-change:transform}
.hidden{display:none!important}
.overlay-message{position:absolute;inset:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;background:rgba(6,10,20,.72);backdrop-filter:blur(8px);border-radius:22px;z-index:4;overflow:auto}
.damage-flash{position:absolute;inset:12px;z-index:3;display:flex;align-items:center;justify-content:center;border-radius:20px;pointer-events:none;opacity:0;color:#fff;font-size:clamp(1.1rem,4vw,2rem);font-weight:900;letter-spacing:.05em;text-align:center;text-shadow:0 3px 12px #38000d;background:radial-gradient(circle,rgba(255,35,68,.08) 15%,rgba(185,0,35,.7) 100%);border:3px solid rgba(255,93,118,.8)}
.damage-flash.hit{animation:damageFlash .5s ease-out}
.stage-wrap.damage-shake{animation:damageShake .34s ease-out}
@keyframes damageFlash{0%{opacity:0;transform:scale(.96)}18%{opacity:1;transform:scale(1)}55%{opacity:.75}100%{opacity:0}}
@keyframes damageShake{0%,100%{transform:translateX(0)}20%{transform:translateX(-7px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(3px)}}
.overlay-message h3{font-size:clamp(1.7rem,4vw,2.6rem);margin-bottom:10px}
.overlay-message p{max-width:44ch;color:var(--muted);line-height:1.6;margin-bottom:16px}
.mobile-controls{position:fixed;left:50%;bottom:max(10px,env(safe-area-inset-bottom));z-index:20;transform:translateX(-50%);display:flex;justify-content:center;align-items:center;gap:12px;width:max-content;max-width:calc(100vw - 20px);padding:8px 10px;border-radius:22px;background:rgba(7,16,31,.82);border:1px solid rgba(215,228,255,.14);box-shadow:0 12px 34px rgba(0,0,0,.38);backdrop-filter:blur(14px)}
.dpad{display:flex;gap:6px;padding:0;border:none;box-shadow:none;background:none}
.dpad button,.action-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);color:var(--text);touch-action:none;user-select:none}
.dpad button{width:46px;height:46px;padding:0;font-size:1rem;border-radius:14px}
.action-pad{display:flex;gap:12px;align-items:center}
.action-btn{padding:0 16px;min-width:96px;height:48px;border-radius:16px;font-weight:700}
.action-main{background:linear-gradient(135deg, rgba(230,238,255,.95), rgba(194,181,255,.95));color:#10162e}
.toast{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);background:#11182c;border:1px solid rgba(255,255,255,.08);color:var(--text);padding:12px 16px;border-radius:16px;box-shadow:var(--shadow);z-index:30;max-width:min(92vw,560px)}

/* DOM game panels */
.vn-layout{display:grid;grid-template-columns:.95fr 1.05fr;gap:18px;height:100%}
.vn-art{border-radius:22px;overflow:hidden;position:relative;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);min-height:280px}
.vn-art img,.vn-art video{width:100%;height:100%;object-fit:cover}
.vn-body{display:flex;flex-direction:column;gap:12px}
.dialogue-box{padding:18px;border-radius:22px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08)}
.name-tag{display:inline-block;margin-bottom:10px;padding:5px 10px;border-radius:999px;background:rgba(220,232,255,.12);color:var(--moon);font-size:.84rem}
.dialogue-text{color:#eff4ff;line-height:1.7;font-size:1.03rem}
.option-list{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.option-btn{padding:14px 16px;background:#17233f;color:var(--text);text-align:left;border:1px solid rgba(255,255,255,.08);border-radius:18px}
.small-note{color:var(--muted);font-size:.92rem;line-height:1.6}
.story-meter{display:flex;gap:10px;flex-wrap:wrap}

.memory-board{display:grid;gap:10px;max-width:860px;margin:0 auto}
.memory-card{aspect-ratio:1/1;position:relative;border:none;background:none;padding:0;cursor:pointer}
.memory-card-inner{position:absolute;inset:0;transform-style:preserve-3d;transition:.35s transform}
.memory-card.flipped .memory-card-inner,.memory-card.matched .memory-card-inner{transform:rotateY(180deg)}
.memory-face{position:absolute;inset:0;border-radius:18px;display:flex;align-items:center;justify-content:center;backface-visibility:hidden;font-size:2rem;font-weight:800}
.memory-front{background:linear-gradient(135deg,#dfe9ff,#c4b6ff);color:#12182e}
.memory-back{background:#14203a;border:1px solid rgba(255,255,255,.1);transform:rotateY(180deg);color:#fff}
.memory-head,.puzzle-head,.cards-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}

.puzzle-stage{text-align:center}
.puzzle-workspace{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:16px}
.puzzle-reference{width:190px;flex:0 0 190px;margin:0;padding:10px;border-radius:18px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.11)}
.puzzle-reference img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:12px}
.puzzle-reference figcaption{padding-top:8px;color:var(--muted);font-size:.85rem}
.sliding-board{position:relative;flex:0 1 auto;max-width:100%;aspect-ratio:1;margin:0 auto;border-radius:20px;overflow:hidden;border:2px solid rgba(255,255,255,.16);background:#0c1325;touch-action:manipulation}
.sliding-tile{position:absolute;border-radius:14px;box-shadow:0 8px 24px rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.13);background-image:url('assets/main_bg.png');background-size:100% 100%;cursor:pointer;transition:left .15s ease, top .15s ease, transform .15s ease}
.sliding-tile:hover{transform:scale(1.02)}

.cards-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:18px}
.cards-layout>*{min-width:0}
.battle-box,.hand-box,.status-box,.ending-box{padding:16px;border-radius:22px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08)}
.bars{display:grid;gap:10px}
.bar{height:14px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden;position:relative}
.bar > span{display:block;height:100%;background:linear-gradient(90deg,var(--danger),#ffb37a);border-radius:inherit}
.bar.mana > span{background:linear-gradient(90deg,var(--accent),#9ad6ff)}
.bar.good > span{background:linear-gradient(90deg,var(--good),#dafddf)}
.char-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:12px 0}
.char-pill{display:flex;align-items:center;gap:10px}
.char-pill img{width:56px;height:56px;border-radius:50%;object-fit:cover}
.enemy-pill img{border:2px solid rgba(255,91,116,.58);box-shadow:0 0 18px rgba(206,29,61,.3);filter:saturate(.78) contrast(1.18) brightness(.72)}
.card-hand{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.battle-card{padding:14px;border-radius:18px;background:#162341;border:1px solid rgba(255,255,255,.1);color:var(--text);text-align:left}
.battle-card h4{margin-bottom:6px}
.log-box{margin-top:12px;color:var(--muted);line-height:1.55;min-height:62px}

.ending-box{text-align:center;max-width:760px;margin:0 auto}
.ending-box img{width:130px;height:130px;margin:0 auto 14px;border-radius:50%}
.ending-box img.ending-memory{width:min(100%,360px);height:auto;max-height:390px;object-fit:cover;object-position:center 35%;border-radius:22px;box-shadow:0 16px 38px rgba(0,0,0,.35)}
.ending-story{margin:14px auto 10px;max-width:54ch;line-height:1.7}
.ending-score{margin:0 auto 18px;color:#e5dcff}
.ending-actions{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}

@media (max-width:1100px){
  .hero,.cards-layout,.vn-layout{grid-template-columns:1fr}
  .game-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:720px){
  .screen{padding:10px}
  .hero{gap:12px;padding-top:0}
  .hero-copy{padding:20px}
  h1{font-size:clamp(2.35rem,14vw,3.5rem)}
  .lead{line-height:1.5}
  .hero-actions>*{width:100%}
  .section-head{align-items:flex-start;flex-direction:column}
  .section-head .chip{width:100%}
  .summary-grid{grid-template-columns:repeat(2,1fr)}
  .memory-headline{align-items:flex-start}
  .memory-note{text-align:left}
  .memory-actions{width:100%;align-items:flex-start}
  .gallery-open-btn{width:100%}
  .memory-gallery{columns:2 150px;column-gap:8px}
  .memory-photo{margin-bottom:8px;border-radius:16px}
  .photo-viewer{display:flex;align-items:center;justify-content:center;padding:60px 8px 76px}
  .photo-viewer-content{height:100%;max-height:none}
  .photo-viewer-content img{height:calc(100% - 58px)}
  .photo-viewer-nav{top:auto;bottom:max(10px,env(safe-area-inset-bottom));width:calc(50% - 14px);height:52px;transform:none}
  .photo-viewer-prev{left:8px}.photo-viewer-next{right:8px}
  .game-grid{grid-template-columns:1fr}
  .game-card{min-height:0}
  .game-card p{min-height:0}
  .hero-video{min-height:240px;max-height:320px}
  #playScreen.active{padding-bottom:174px}
  #playScreen.active.dom-mode{display:grid;height:100dvh;max-height:100dvh;min-height:0;grid-template-rows:auto minmax(0,1fr);overflow:hidden;padding-bottom:6px}
  #playScreen.dom-mode .topbar{position:relative;top:auto;z-index:auto}
  #playScreen.dom-mode .stage-wrap{height:100%;min-height:0;overflow:hidden;padding:0;border:0;background:transparent;box-shadow:none;backdrop-filter:none}
  #playScreen.dom-mode .dom-stage{height:100%;min-height:0;overflow:hidden;padding:4px 0;border-radius:0;background:transparent}
  .stage-wrap{padding:6px;border-radius:20px}
  #gameCanvas,.dom-stage{height:100%;min-height:260px;border-radius:16px}
  .dom-stage{padding:12px}
  .topbar{align-items:flex-start;flex-direction:column}
  .topbar-left{width:100%;align-items:center}
  .topbar-left>div{min-width:0}
  .game-subtitle{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:65vw}
  .hud-mini{justify-content:flex-start}
  .mobile-controls{left:8px;right:8px;bottom:max(6px,env(safe-area-inset-bottom));transform:none;justify-content:space-between;width:auto;max-width:none;padding:7px}
  .dpad{display:grid;grid-template-columns:repeat(3,48px);grid-template-rows:repeat(3,48px);padding:0;gap:5px}
  .dpad [data-control="up"]{grid-column:2;grid-row:1}
  .dpad [data-control="left"]{grid-column:1;grid-row:2}
  .dpad [data-control="down"]{grid-column:2;grid-row:3}
  .dpad [data-control="right"]{grid-column:3;grid-row:2}
  .dpad button{width:auto;height:auto}
  .dpad button{border-radius:14px}
  .action-pad{justify-content:flex-end}
  .action-btn{min-width:82px;height:56px;padding:0 12px}
  .avatar-card{min-width:0;flex:1 1 100%;width:100%}
  .cards-layout{display:flex;flex-direction:column;gap:10px}
  .card-hand{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}
  .battle-card{padding:11px;border-radius:14px}
  .battle-card h4{font-size:.92rem}
  .battle-card p{font-size:.82rem}
  .char-row{flex-wrap:wrap}
  .battle-box,.hand-box,.status-box,.ending-box{padding:13px}
  .memory-board{gap:7px}
  .memory-face{border-radius:12px;font-size:1.5rem}
  .vn-layout{height:auto;gap:10px}
  .vn-art{height:clamp(130px,22dvh,190px);min-height:130px;max-height:190px}
  .vn-body{gap:8px}
  .dialogue-box{padding:13px;border-radius:16px}
  .dialogue-text{font-size:.94rem;line-height:1.5}
  .option-list{gap:7px;margin-top:2px}
  .option-btn{padding:12px 13px;border-radius:14px}
  .puzzle-workspace{flex-direction:column;gap:12px}
  .puzzle-reference{width:88px;max-width:88px;flex-basis:auto;padding:6px}
  .puzzle-reference figcaption{display:none}
}
@media (max-width:390px){
  .screen{padding:7px}
  .summary-grid{gap:8px}
  .stat-box{padding:13px 8px}
  .topbar{padding:9px;gap:9px}
  .topbar-left{gap:8px}
  .topbar-left .chip{padding:10px 11px;flex:0 0 auto}
  .game-subtitle{max-width:58vw}
  .mobile-controls{gap:4px}
  .dpad{grid-template-columns:repeat(3,40px);grid-template-rows:repeat(3,40px);gap:3px;padding:4px}
  .action-pad{gap:4px;min-width:0}
  .action-btn{min-width:62px;height:48px;padding:0 7px;font-size:.78rem;border-radius:15px}
  .pill{padding:6px 9px;font-size:.8rem}
  .overlay-message{inset:7px;padding:15px;border-radius:16px;justify-content:flex-start}
  .overlay-message>div{width:100%;flex-direction:column}
  .overlay-message button{width:100%}
  .memory-face{font-size:1.25rem}
  .memory-photo figcaption{left:10px;right:10px;bottom:9px;font-size:.82rem}
  .puzzle-head,.memory-head,.cards-head{align-items:flex-start}
  .cards-head{margin-bottom:10px}
  .cards-head h2{font-size:1.35rem}
  .char-pill img{width:44px;height:44px}
  .log-box{min-height:0;font-size:.86rem}
  .story-meter{gap:5px}
  .vn-art{height:130px;min-height:130px}
}
@media (max-width:340px){
  .summary-grid{grid-template-columns:1fr}
  .hero-copy{padding:16px}
  .stat-box span{font-size:1.45rem}
  .dpad{grid-template-columns:repeat(3,37px);grid-template-rows:repeat(3,37px)}
  .action-btn{min-width:58px;padding:0 5px;font-size:.74rem}
  .card-hand{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (max-width:420px){
  .memory-gallery{columns:1}
}
@media (max-height:520px) and (orientation:landscape){
  .topbar{margin-bottom:7px;padding:7px 10px;flex-direction:row}
  .hud-mini{max-height:54px;overflow:auto}
  #playScreen.active{padding-bottom:58px}
  #gameCanvas,.dom-stage{height:100%;min-height:220px}
  .mobile-controls{left:8px;right:8px;bottom:4px;pointer-events:none;background:rgba(7,16,31,.72)}
  .mobile-controls button{pointer-events:auto;background:rgba(17,26,48,.94)}
  .dpad{grid-template-columns:repeat(3,38px);grid-template-rows:repeat(3,38px);opacity:.9}
  .action-btn{height:48px;min-width:72px}
}
@media (hover:none){
  .primary-btn:hover,.secondary-btn:hover,.chip:hover,.game-card:hover,.action-btn:hover,.option-btn:hover,.small-btn:hover,.menu-link:hover{transform:none}
}
@media (prefers-reduced-motion:reduce){
  .damage-flash.hit,.stage-wrap.damage-shake{animation-duration:.16s}
}
