:root{--bg-night: #0a0b12;--panel-dark: #2a1716;--panel-red: #4b1f24;--panel-border: #120a0a;--gold: #c8a15c;--bronze: #6f4e33;--text-main: #f0e6d2;--text-muted: #b7a998;--gauge-red: #9e1f2f;--gauge-blue: #1f4f8f}*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at top,#1b2030,#06060a 60%);color:var(--text-main);font-family:Malgun Gothic,Apple SD Gothic Neo,serif}.game-wrap{min-height:100vh;display:flex;justify-content:center;padding:18px;background:linear-gradient(180deg,#111522,#09080a)}.game-shell{width:min(1440px,100%);border:8px solid var(--bronze);background:linear-gradient(160deg,#2f1d19,#3c171a);box-shadow:0 0 0 3px var(--gold),0 16px 40px #000000b3;display:grid;gap:10px;grid-template-columns:310px 1fr 340px;grid-template-rows:auto 1fr 180px;padding:10px}.game-title{grid-column:1 / -1;padding:10px 14px;letter-spacing:3px;font-size:30px;border:2px solid var(--gold);background:linear-gradient(180deg,#5a1f25,#381316);text-shadow:0 2px 0 #000}.shell-left,.shell-center,.shell-right{display:flex;flex-direction:column;gap:10px}.shell-bottom{grid-column:1 / -1}.ornate-panel{border:3px solid var(--panel-border);box-shadow:inset 0 0 0 2px var(--gold),inset 0 0 0 5px #40181b,0 8px 14px #0006;background:linear-gradient(180deg,#3b1c1e,#261314)}.ornate-panel__title{padding:6px 10px;font-weight:700;border-bottom:1px solid #6d4e29;background:linear-gradient(180deg,#5a2a1e,#46221a)}.ornate-panel__content{padding:8px}.retro-button{width:100%;margin-bottom:6px;border:2px solid #6d4e29;color:var(--text-main);background:linear-gradient(180deg,#6e212d,#46151d);padding:8px 10px;text-align:left;font-weight:700;letter-spacing:.4px;box-shadow:inset 0 1px #b77,inset 0 -2px #2a0e12}.retro-button:active{transform:translateY(1px);box-shadow:inset 0 2px 3px #1c090b}.retro-button:hover{filter:brightness(1.08)}.retro-button__ornament{margin-right:8px;color:var(--gold)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.calendar-cell{text-align:center;border:1px solid #5f3a2b;padding:2px;font-weight:700}.is-today{background:#8a2a34;color:#fff}.character-stage{position:relative;min-height:470px;border:3px solid #4a2f21;background:#13121a;overflow:hidden}.character-stage__bg{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#1d1a28,#2c1e1e 58%,#37251a)}.character-stage__window{position:absolute;right:8%;top:11%;width:160px;height:180px;border:4px solid #6f5338;background:linear-gradient(180deg,#1c2f4f,#081226);box-shadow:inset 0 0 35px #aac8ff33}.character-stage__desk{position:absolute;left:0;right:0;bottom:0;height:120px;background:linear-gradient(180deg,#4e3023,#2f1a13);border-top:3px solid #7a5337}.character-stage__avatar{position:absolute;left:50%;bottom:94px;transform:translate(-50%);width:210px;height:280px}.character-stage__halo{position:absolute;left:30px;top:5px;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle,#ffdfaa73,#ffdfaa00)}.character-stage__hair{position:absolute;left:52px;top:26px;width:106px;height:120px;background:linear-gradient(180deg,#44384e,#282231);border-radius:56px 56px 44px 44px;box-shadow:0 0 0 2px #7c6552}.character-stage__face{position:absolute;left:67px;top:60px;width:76px;height:92px;background:linear-gradient(180deg,#ffe7c9,#f2cfa5);border-radius:42px;box-shadow:inset 0 -6px #af6a5740}.character-stage__uniform{position:absolute;left:44px;bottom:0;width:122px;height:152px;background:linear-gradient(180deg,#334a74,#1f2a45);clip-path:polygon(12% 0,88% 0,100% 24%,92% 100%,8% 100%,0 24%);border:2px solid #8a6d4c}.character-stage__nameplate{position:absolute;left:18px;top:14px;padding:6px 10px;border:2px solid #8a6d4c;background:#251818d1;font-weight:700;letter-spacing:1px}.character-stage__status{position:absolute;left:16px;bottom:16px;padding:8px 10px;border:2px solid #6c4f32;background:#140e13cc;font-size:13px}.character-stage__status p{margin:0 0 4px}.character-stage__status p:last-child{margin-bottom:0}.dialogue-box{height:100%;border:3px solid #4d2d21;background:linear-gradient(180deg,#2f1717,#1f1111);display:grid;grid-template-columns:90px 1fr 44px;align-items:center;padding:10px;box-shadow:inset 0 0 0 2px #765f40}.dialogue-box__portrait{width:70px;height:70px;border:2px solid #8b6b45;display:flex;align-items:center;justify-content:center;font-size:30px}.dialogue-box__name{margin:0 0 4px;color:#ffdd9e}.stat-row{display:grid;grid-template-columns:90px 40px 1fr;align-items:center;gap:6px;margin-bottom:6px;font-size:13px}.stat-gauge{display:grid;grid-template-columns:repeat(10,1fr);gap:2px}.stat-gauge i{height:12px;border:1px solid #442427;background:#201315}.stat-gauge .on-red{background:linear-gradient(180deg,#cf4456,#852531)}.stat-gauge .on-blue{background:linear-gradient(180deg,#4b88db,#2b4f88)}.action-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.event-window__image{height:120px;border:2px solid #7d633f;background:radial-gradient(circle at 20% 20%,#6d3e3e,#2e1d30);margin-bottom:6px}@media (max-width: 1100px){.game-shell{grid-template-columns:1fr;grid-template-rows:auto;max-height:none}}.scene-shell{grid-template-columns:1fr;max-width:900px;min-height:640px}.scene-shell__content{display:flex;align-items:center;justify-content:center;padding:40px}.scene-shell__content .ornate-panel{width:min(560px,100%)}.scene-shell__text{margin:0 0 18px;font-size:18px;color:var(--text-muted)}.title-wrap{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:20px;background:radial-gradient(circle at top,#1d2231,#09090d 70%)}.title-scene{width:min(1200px,100%);min-height:720px;border:8px solid #634827;box-shadow:0 0 0 3px var(--gold),0 20px 50px #000000b3;background:linear-gradient(180deg,#191522,#1a1113 60%,#2f1f16);position:relative;overflow:hidden;padding:40px}.title-scene__sky{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 20%,rgba(125,165,255,.22),transparent 40%),radial-gradient(circle at 80% 16%,rgba(241,193,130,.18),transparent 35%)}.title-scene__room{position:absolute;top:38%;right:0;bottom:0;left:0;background:linear-gradient(180deg,#2f1e1d,#241413);border-top:3px solid #715136}.title-scene__window{position:absolute;right:9%;top:17%;width:220px;height:300px;border:5px solid #8f6a3f;background:linear-gradient(180deg,#1f355f,#0e1930);box-shadow:inset 0 0 40px #aecfff33}.title-scene__desk{position:absolute;left:8%;right:8%;bottom:16%;height:90px;border:3px solid #6d4f35;background:linear-gradient(180deg,#4e3223,#342015)}.title-scene__album{position:absolute;right:23%;bottom:18%;width:130px;height:84px;border:2px solid #9b7a50;background:linear-gradient(160deg,#7b2933,#4f1720);transform:rotate(-8deg)}.title-scene__standing{position:absolute;right:13%;bottom:26%;width:190px;height:340px;border:3px solid #7a6040;background:linear-gradient(180deg,#574e7180,#281f34c7);box-shadow:inset 0 0 40px #ffdca024}.title-header{position:relative;z-index:1;max-width:650px}.title-header h1{margin:8px 0 6px;font-size:72px;letter-spacing:5px;text-shadow:0 3px 0 #000,0 0 18px rgba(255,216,142,.25);color:#f6e6bf}.title-header__eyebrow{margin:0;letter-spacing:2px;color:#cfba8e;font-size:12px}.title-header__subtitle{margin:0;font-size:22px;color:#e9d3b0}.title-menu{position:absolute;left:40px;bottom:110px;width:min(360px,calc(100% - 80px));z-index:1}.title-menu .retro-button{font-size:18px;padding:11px 14px;margin-bottom:8px}.title-footer{position:absolute;left:40px;bottom:38px;margin:0;color:#cfb692;font-size:15px;letter-spacing:.4px;z-index:1}.title-message{position:absolute;right:40px;bottom:42px;margin:0;color:#ffd2a2;background:#3b1515cc;border:2px solid #95673f;padding:8px 12px;z-index:1}.game-title,.ornate-panel__title{text-shadow:0 2px 0 #000,0 0 12px rgba(255,214,150,.2)}.ornate-panel{background-image:linear-gradient(180deg,#3b1c1e,#261314),repeating-linear-gradient(45deg,#ffffff05 0,#ffffff05 2px,#00000005 2px,#00000005 4px)}.stat-gauge i{border-color:#6a373c;background:#180d0f}.stat-gauge .on-red{background:linear-gradient(180deg,#ef6175,#8d1f32);box-shadow:0 0 6px #ed5e7673}.stat-gauge .on-blue{background:linear-gradient(180deg,#74a8ff,#2b4f88);box-shadow:0 0 6px #74a8ff73}.dialogue-box{border-width:4px;box-shadow:inset 0 0 0 2px #8a6f48,0 -2px 18px #0006}.dialogue-box__content p:last-child{font-size:17px;line-height:1.4}.title-header h1{font-size:88px}.title-scene__standing{border-radius:14px}.title-standing__hair{position:absolute;left:50%;top:48px;transform:translate(-50%);width:110px;height:120px;border-radius:56px 56px 45px 45px;background:linear-gradient(180deg,#4a3f56,#292435);box-shadow:0 2px #13101b}.title-standing__face{position:absolute;left:50%;top:88px;transform:translate(-50%);width:74px;height:86px;border-radius:38px;background:linear-gradient(180deg,#f8dfbd,#e9c59b)}.title-standing__uniform{position:absolute;left:50%;bottom:20px;transform:translate(-50%);width:120px;height:160px;border-radius:18px 18px 12px 12px;background:linear-gradient(180deg,#3d4f81,#222c46);border:2px solid #8f7451}.title-message{max-width:300px}.prologue-wrap{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:24px;background:radial-gradient(circle at top,#1c2235,#0a0b11 65%)}.prologue-scene{width:min(1120px,100%);min-height:680px;border:8px solid #634827;box-shadow:0 0 0 3px var(--gold),0 20px 50px #000000b3;position:relative;overflow:hidden;background:#140f18}.prologue-scene__cg{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(160deg,#1c2d4ecc,#29131bb3),radial-gradient(circle at 20% 65%,rgba(255,226,169,.25),transparent 40%)}.prologue-scene__vignette{position:absolute;top:0;right:0;bottom:0;left:0;box-shadow:inset 0 0 140px #000c}.prologue-dialogue{position:absolute;left:30px;right:30px;bottom:28px;border:3px solid #7a5d3a;background:#1f0e10e6;padding:18px}.prologue-dialogue p{margin:0 0 10px;font-size:18px}.character-stage__hair-back,.character-stage__head,.character-stage__hair-front,.character-stage__eye,.character-stage__mouth,.character-stage__hood,.character-stage__arm{position:absolute}.character-stage__hair-back{left:50px;top:20px;width:112px;height:120px;border-radius:58px 58px 45px 45px;background:linear-gradient(180deg,#44384e,#241f2d)}.character-stage__head{left:64px;top:52px;width:84px;height:100px;border-radius:44px;background:linear-gradient(180deg,#ffe5c4,#efc79f)}.character-stage__hair-front{left:58px;top:34px;width:96px;height:60px;border-radius:48px 48px 18px 18px;background:linear-gradient(180deg,#3f344a,#241f2f)}.character-stage__eye{top:96px;width:8px;height:8px;border-radius:50%;background:#2a1a19}.character-stage__eye--left{left:88px}.character-stage__eye--right{left:116px}.character-stage__mouth{left:100px;top:122px;width:18px;height:8px;border-bottom:2px solid #9c5c5c;border-radius:0 0 10px 10px}.character-stage__hood{left:48px;bottom:122px;width:120px;height:70px;border-radius:30px 30px 14px 14px;background:linear-gradient(180deg,#5a6f99,#33456c)}.character-stage__arm{bottom:72px;width:30px;height:96px;border-radius:16px;background:linear-gradient(180deg,#334a74,#1f2a45)}.character-stage__arm--left{left:34px;transform:rotate(8deg)}.character-stage__arm--right{right:28px;transform:rotate(-8deg)}.event-window__image{height:150px;background:linear-gradient(155deg,#3b2340,#1e2f4d 45%,#5f3a2f);box-shadow:inset 0 0 45px #ffd99c33;position:relative}.event-window__image:after{content:"추억 장면";position:absolute;right:10px;bottom:8px;font-size:12px;color:#f4d7ae}.title-scene:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(120deg,#ffffff05 0,#ffffff05 2px,#00000005 2px,#00000005 4px);pointer-events:none}.title-character-slot{position:absolute;right:7%;top:14%;width:320px;height:500px;z-index:1}.title-character-slot__art,.character-stage__art{width:100%;height:100%}.character-artwork{border:3px solid #6e5034;box-shadow:0 0 0 2px #cfab6b,inset 0 0 0 2px #00000073,0 20px 30px #00000073;background:#17121c;overflow:hidden;position:relative}.character-artwork img{width:100%;height:100%;object-fit:cover;display:block}.character-artwork__fallback{position:relative;width:100%;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:18px;background:linear-gradient(145deg,#29181ef2,#161323f2)}.character-artwork__fallback--dongha{background:radial-gradient(circle at 15% 20%,rgba(255,210,130,.25),transparent 42%),linear-gradient(160deg,#2c2234,#22171d 60%,#342518)}.character-artwork__fallback--heeseon{background:radial-gradient(circle at 15% 20%,rgba(255,182,163,.2),transparent 42%),linear-gradient(160deg,#3a2330,#271722 60%,#2f2117)}.character-artwork__shine{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(130deg,rgba(255,255,255,.1),transparent 30%)}.character-artwork__ornament{position:absolute;top:12px;right:12px;bottom:12px;left:12px;border:1px solid rgba(239,206,143,.45)}.character-artwork__name{margin:0;font-weight:700;letter-spacing:2px;color:#f4ddb2}.character-artwork__label{margin:6px 0 0;color:#d4bf98;font-size:13px}.character-stage__art{position:absolute;left:50%;bottom:92px;transform:translate(-50%);width:240px;height:330px}.event-window__title{margin:6px 0 2px;color:#ffe3b1;font-weight:700}.event-window__meta{margin:0 0 6px;color:#cbb489;font-size:13px}.event-window__image{height:150px;border:2px solid #90714b;background:linear-gradient(170deg,#1f3155,#311e2f 55%,#674528);position:relative}.event-window__image:before{content:"";position:absolute;left:10%;top:15%;width:36%;height:55%;border:2px solid rgba(235,208,154,.5);background:#1a142259}.event-cg img{width:100%;max-height:320px;object-fit:cover;border:2px solid #8b6c45}.cg-fallback{height:300px;border:2px solid #8b6c45;position:relative;overflow:hidden}.cg-fallback--study{background:linear-gradient(160deg,#1f2f4f,#1f1b2f 52%,#4e3223)}.cg-fallback--pc{background:linear-gradient(160deg,#101723,#192c4f 50%,#2f1f4b)}.cg-fallback--sunset{background:linear-gradient(160deg,#5e2f3d,#854d3f 50%,#2a1a2f)}.cg-fallback--bakery{background:linear-gradient(160deg,#6d4a33,#9a6a3c 50%,#40251d)}.cg-fallback__light{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 18%,rgba(255,238,180,.26),transparent 40%)}.cg-fallback__prop{position:absolute;left:8%;right:8%;bottom:16%;height:24%;border:2px solid rgba(236,208,152,.5);background:#0a0c1459}.cg-fallback__caption{position:absolute;right:14px;bottom:10px;color:#f2dcb3;font-size:12px;letter-spacing:.8px}.title-header h1{text-shadow:0 3px 0 #000,0 0 30px rgba(255,226,160,.45),0 0 80px rgba(177,90,48,.4)}.retro-button:hover{filter:brightness(1.12);transform:translate(2px)}.retro-button:active{transform:translate(1px,1px)}
