@import "https://fonts.googleapis.com/css2?family=Nanum+Gothic:wght@400;700;800&display=swap";
@import "https://fonts.googleapis.com/css2?family=Nanum+Gothic+Coding&display=swap";
:root{--color-primary:#6366f1;--color-primary-dark:#4f46e5;--color-primary-light:#818cf8;--color-secondary:#a855f7;--color-accent:#f59e0b;--color-success:#22c55e;--color-danger:#ef4444;--color-warning:#f59e0b;--bg-dark:#0f172a;--bg-darker:#020617;--bg-card:#fffffff2;--bg-glass:#ffffff1a;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-dark:#1e293b;--nav-height:56px}*{box-sizing:border-box;margin:0;padding:0}html,body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%;overflow:hidden;font-family:Nanum Gothic,NanumSquareRound,sans-serif!important}@media (max-width:1180px),(max-height:820px){html,body{-webkit-overflow-scrolling:touch;overflow:hidden auto}}*,button,input,textarea,select,span,p,h1,h2,h3,h4,h5,h6,div,a,label,li,td,th{font-family:Nanum Gothic,NanumSquareRound,sans-serif!important}body{background:var(--bg-dark);color:var(--text-primary)}.top-nav{height:var(--nav-height);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:9999;background:#0f172aeb;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:0 16px;display:flex;position:fixed;top:0;left:0;right:0}.nav-group{align-items:center;gap:8px;display:flex}.nav-btn{color:#e2e8f0;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;transition:all .2s;display:flex}.nav-btn:hover{background:#ffffff24;border-color:#fff3;transform:scale(1.05)}.nav-btn:active{transform:scale(.95)}.nav-title{color:#e2e8f0;text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:400px;font-size:14px;font-weight:700;overflow:hidden}.game-area{top:var(--nav-height);-webkit-overflow-scrolling:touch;position:fixed;bottom:0;left:0;right:0;overflow:hidden auto}.game-area.no-nav{top:0}.game-area-scroll{box-sizing:border-box;flex-direction:column;justify-content:center;align-items:center;min-height:100%;padding:clamp(16px,3vw,32px);display:flex}.dialogue-container{z-index:100;padding:0;position:absolute;bottom:0;left:0;right:0}.dialogue-integrated{max-width:1000px;margin:0 auto;padding:0 16px 16px;position:relative}.dialogue-character{z-index:50;flex-direction:column;align-items:center;display:flex;position:absolute;bottom:calc(100% - 60px);left:16px}.dialogue-character-right{left:auto;right:16px}.dialogue-character-img{object-fit:contain;filter:drop-shadow(0 8px 24px #00000080);width:220px;height:280px;transition:transform .3s;animation:3s ease-in-out infinite characterBreathe;transform:translateY(-20px)}.dialogue-character:hover .dialogue-character-img{transform:translateY(-28px)scale(1.03)}.dialogue-box{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;cursor:pointer;background:#0a0f1ed9;border:1px solid #ffffff1f;border-radius:20px;width:100%;min-height:120px;padding:24px 32px;transition:background .2s;position:relative;box-shadow:0 -4px 24px #0000004d}.dialogue-box:hover{background:#0a0f1ee6;border-color:#ffffff2e}.dialogue-character+.dialogue-box,.dialogue-box:first-child{padding-left:32px}.dialogue-speaker{background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));color:#fff;border-radius:20px;padding:4px 16px;font-size:13px;font-weight:700;position:absolute;top:-14px;left:24px;box-shadow:0 4px 12px #6366f166}.dialogue-text{color:#e2e8f0;letter-spacing:.01em;font-size:22px;font-weight:700;line-height:1.6}.dialogue-text .highlight{color:var(--color-primary-light);font-weight:700}.typing-cursor{color:var(--color-primary-light);animation:.8s infinite blink}.dialogue-next{color:var(--text-secondary);font-size:12px;animation:1.2s infinite blink;position:absolute;bottom:12px;right:20px}.character-container{z-index:90;align-items:flex-end;gap:16px;display:flex;position:absolute;bottom:160px;left:24px}.character-sprite{object-fit:contain;filter:drop-shadow(0 4px 12px #0006);width:140px;height:180px;transition:transform .3s}.character-name-tag{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;text-align:center;background:#0009;border-radius:8px;margin-top:4px;padding:4px 12px;font-size:12px;font-weight:700}.choices-container{flex-direction:column;gap:10px;margin-top:16px;display:flex}.choice-btn{color:#e2e8f0;cursor:pointer;text-align:left;opacity:0;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:14px;width:100%;padding:14px 20px;font-family:Nanum Gothic,sans-serif;font-size:15px;font-weight:600;transition:all .25s;animation:.4s forwards fadeInUp}.choice-btn:hover{border-color:var(--color-primary);background:#6366f133;transform:translate(8px);box-shadow:0 0 20px #6366f126}.stage-header{text-align:center;z-index:80;position:absolute;top:16px;left:50%;transform:translate(-50%)}.stage-title{color:#fff;text-shadow:0 2px 8px #0009;font-size:18px;font-weight:800}.stage-subtitle{color:#ffffffb3;margin-top:4px;font-size:13px}.minigame-area{z-index:85;width:90%;max-width:500px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.minigame-card{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);color:#fff;text-align:center;background:#0f1428eb;border:1px solid #ffffff1f;border-radius:24px;padding:28px;position:relative;overflow:hidden;box-shadow:0 20px 60px #00000080}.minigame-card .minigame-title{color:#e2e8f0;margin-bottom:20px;font-size:16px;font-weight:800}.minigame-card .minigame-success{color:#4ade80;margin-top:16px;font-size:15px;font-weight:800;animation:.4s fadeInUp}.minigame-card .minigame-fail{color:#f87171;margin-top:16px;font-size:15px;font-weight:800;animation:.4s shake}.char-card{border-radius:16px;justify-content:center;align-items:center;width:80px;height:100px;display:flex;overflow:hidden}.char-img{object-fit:contain;width:100%;height:100%}.intro-slide{object-fit:cover;opacity:0;width:100vw;height:100vh;transition:opacity 1s;position:absolute;inset:0}.intro-slide.active{opacity:1}.skip-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fffc;cursor:pointer;z-index:100;background:#00000080;border:1px solid #fff3;border-radius:24px;padding:10px 24px;font-family:Nanum Gothic,sans-serif;font-size:14px;font-weight:700;transition:all .2s;position:fixed;bottom:32px;right:32px}.skip-btn:hover{color:#fff;background:#000000b3}.start-screen{cursor:pointer;background-position:50%;background-size:cover;flex-direction:column;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:relative}.start-title{background:linear-gradient(135deg,#fde68a 0%,#fbbf24 50%,#f59e0b 100%);-webkit-text-fill-color:transparent;filter:drop-shadow(0 6px 20px #000000d9);text-align:center;letter-spacing:-1px;-webkit-background-clip:text;background-clip:text;font-size:96px;font-weight:900;line-height:1.2}.start-subtitle{color:#fef3c7;text-shadow:0 2px 12px #000000d9;margin-top:16px;font-size:22px;font-weight:700}.start-prompt{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fef3c7;text-align:center;text-shadow:0 2px 8px #000c;background:#0f172aa6;border:2px solid #fbbf24b3;border-radius:40px;margin:60px auto 0;padding:18px 56px;font-size:18px;font-weight:800;animation:2s infinite pulse-glow;display:inline-block}.auth-container{box-sizing:border-box;background-position:50%;background-size:cover;justify-content:center;align-items:center;min-height:100dvh;padding:24px 16px;display:flex;position:relative}.auth-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;position:absolute;inset:0}.auth-card{z-index:10;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0a0f1ee0;border:1px solid #ffffff1a;border-radius:24px;width:100%;max-width:440px;margin:0 16px;padding:40px;position:relative}.auth-title{text-align:center;background:linear-gradient(135deg,#00f5d4,#00bcd4);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:32px;font-size:28px;font-weight:800}.auth-label{color:#00f5d4;margin-top:20px;margin-bottom:8px;font-size:14px;font-weight:700;display:block}.auth-input{color:#fff;background:#ffffff14;border:1px solid #ffffff26;border-radius:12px;outline:none;width:100%;padding:14px 16px;font-family:Nanum Gothic,sans-serif;font-size:15px;transition:border-color .2s}.auth-input:focus{border-color:#00f5d4}.auth-input::placeholder{color:#ffffff4d}.auth-btn{color:#0f172a;cursor:pointer;background:linear-gradient(135deg,#00f5d4,#00bcd4);border:none;border-radius:12px;width:100%;margin-top:28px;padding:16px;font-family:Nanum Gothic,sans-serif;font-size:16px;font-weight:800;transition:all .2s}.auth-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00f5d44d}.auth-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.auth-link{color:#ffffff80;cursor:pointer;font-size:14px;text-decoration:none;transition:color .2s}.auth-link:hover{color:#00f5d4}.auth-error{color:var(--color-danger);text-align:center;margin-top:12px;font-size:13px;font-weight:700}.world-map{background-position:50%;background-size:cover;width:100%;height:100%;position:relative;overflow:hidden}.map-node{cursor:pointer;transition:all .3s;position:absolute}.map-node:hover{transform:scale(1.08)}.map-node.locked{filter:grayscale(.5);opacity:.7}.map-node-label{color:#fff;text-shadow:0 1px 4px #0006;white-space:nowrap;border-radius:20px;padding:8px 20px;font-size:14px;font-weight:800;box-shadow:0 4px 12px #0000004d}.vignette-red{background:radial-gradient(#0000 40%,#dc262666 100%)}.heart-display{top:calc(var(--nav-height) + 12px);z-index:999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffe6;border:1px solid #ec489933;border-radius:24px;align-items:center;gap:6px;padding:6px 16px;display:flex;position:fixed;right:16px;box-shadow:0 4px 12px #00000026}.mode-card{cursor:pointer;text-align:center;border:2px solid;border-radius:24px;padding:40px 32px;transition:all .3s}.mode-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px #00000026}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}@keyframes pulse-glow{0%,to{box-shadow:0 0 #fff0}50%{box-shadow:0 0 20px #fff3}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes characterBreathe{0%,to{transform:translateY(-20px)}50%{transform:translateY(-26px)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-20px)}60%{transform:translateY(-10px)}}@keyframes ping{0%{opacity:.5;transform:scale(1)}75%,to{opacity:0;transform:scale(2)}}@keyframes glowPulse{0%,to{box-shadow:0 0 8px #6366f14d}50%{box-shadow:0 0 24px #6366f199}}@keyframes cardFlipIn{0%{opacity:0;transform:perspective(600px)rotateY(90deg)}to{opacity:1;transform:perspective(600px)rotateY(0)}}@keyframes successScale{0%{opacity:0;transform:scale(.8)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@keyframes ribbonReveal{0%{opacity:0;transform:scale(.5)rotate(-10deg)}50%{opacity:1;transform:scale(1.15)rotate(5deg)}to{opacity:1;transform:scale(1)rotate(0)}}.animate-fade-in{animation:.6s forwards fadeIn}.animate-fade-in-up{animation:.6s forwards fadeInUp}.animate-shake{animation:.6s shake}.animate-float{animation:3s ease-in-out infinite float}.animate-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}.animate-glow-pulse{animation:2s ease-in-out infinite glowPulse}.animate-card-flip{animation:.5s forwards cardFlipIn}.animate-success-scale{animation:.5s forwards successScale}.animate-ribbon-reveal{animation:.8s forwards ribbonReveal}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.scene-grayscale{filter:grayscale()brightness(.7);transition:filter .8s}.landscape-prompt{background:var(--bg-darker);z-index:99999;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.portrait-notice{z-index:100000;color:#fef3c7;text-align:center;background:linear-gradient(135deg,#0f172a 0%,#1e1b4b 100%);justify-content:center;align-items:center;padding:40px 32px;display:none;position:fixed;inset:0}.portrait-notice-inner{max-width:520px}.portrait-notice-icon{justify-content:center;align-items:center;margin-bottom:28px;animation:2.4s ease-in-out infinite rotateHint;display:flex}.portrait-notice h2{color:#fde68a;letter-spacing:-.5px;margin-bottom:12px;font-size:26px;font-weight:900}.portrait-notice p{color:#fef3c7cc;font-size:16px;font-weight:700;line-height:1.6}@keyframes rotateHint{0%,20%{transform:rotate(0)}50%,70%{transform:rotate(-90deg)}to{transform:rotate(0)}}@media (orientation:portrait) and (max-width:1180px) and (hover:none) and (pointer:coarse){.portrait-notice{display:flex}body:has(.portrait-notice){overflow:hidden}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff40}@media (hover:none) and (pointer:coarse){.nav-btn,.choice-btn,.auth-btn,.map-node,button{touch-action:manipulation}}@media (max-width:1366px){.start-title{font-size:clamp(48px,9vw,88px)}.start-prompt{margin-top:48px;padding:16px 48px;font-size:17px}.dialogue-integrated{max-width:940px;padding:0 20px 16px}.dialogue-character-img{width:200px;height:250px}.dialogue-text{font-size:20px;line-height:1.55}.dialogue-box{min-height:112px;padding:22px 30px}.stage-title{font-size:17px}.choice-btn{padding:13px 20px;font-size:15px}}@media (max-width:1024px){:root{--nav-height:52px}.top-nav{padding:0 12px}.nav-btn{width:42px;height:42px;font-size:17px}.nav-title{max-width:240px;font-size:13px}.nav-group{gap:6px}.start-title{font-size:clamp(44px,8.5vw,72px)}.start-subtitle{font-size:18px}.start-prompt{margin-top:40px;padding:14px 40px;font-size:16px}.dialogue-integrated{max-width:100%;padding:0 16px 14px}.dialogue-character{bottom:calc(100% - 52px);left:12px}.dialogue-character-right{left:auto;right:12px}.dialogue-character-img{width:172px;height:214px}.dialogue-text{font-size:18px;line-height:1.55}.dialogue-box{border-radius:18px;min-height:100px;padding:20px 24px}.dialogue-character+.dialogue-box,.dialogue-box:first-child{padding-left:28px}.dialogue-speaker{padding:3px 14px;font-size:12px;top:-12px;left:20px}.stage-header{top:12px}.stage-title{font-size:16px}.stage-subtitle{font-size:12px}.minigame-area{width:92%;max-width:480px}.minigame-card{border-radius:20px;padding:22px 20px}.minigame-card .minigame-title{margin-bottom:16px;font-size:15px}.choice-btn{border-radius:12px;padding:14px 18px;font-size:15px}.auth-card{max-width:440px;padding:32px 24px}.auth-title{margin-bottom:26px;font-size:26px}.auth-input{padding:13px 14px;font-size:15px}.auth-btn{margin-top:24px;padding:15px;font-size:15px}.mode-card{padding:28px 22px}}@media (max-width:820px){.start-title{font-size:clamp(40px,9vw,60px)}.dialogue-character-img{width:148px;height:188px}.dialogue-text{font-size:17px}.dialogue-box{min-height:92px;padding:18px 22px}.dialogue-character{bottom:calc(100% - 48px)}.nav-title{max-width:180px;font-size:12px}}@media (max-width:640px){:root{--nav-height:48px}.start-title{font-size:clamp(36px,10vw,48px)}.dialogue-character-img{width:128px;height:164px}.dialogue-text{font-size:16px}.dialogue-box{padding:16px 20px!important}.character-sprite{width:96px;height:124px}.auth-card{padding:26px 18px}.nav-title{max-width:120px}}@media (max-height:820px) and (orientation:landscape){.dialogue-character-img{width:180px;height:224px}.dialogue-character{bottom:calc(100% - 50px)}.dialogue-box{min-height:96px;padding:18px 28px}.dialogue-text{font-size:18px;line-height:1.5}.stage-header{top:10px}.stage-title{font-size:15px}}@media (max-height:720px) and (orientation:landscape){.dialogue-character-img{width:156px;height:196px}.dialogue-text{font-size:17px}.dialogue-box{min-height:88px;padding:16px 24px}.start-title{font-size:clamp(40px,7vw,60px)}.start-prompt{margin-top:28px;padding:12px 36px;font-size:15px}}
