.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:root{--bg: #fef6ef;--bg-grad-top: #fff7ee;--bg-grad-bot: #fde3d4;--panel: #ffffff;--panel-soft: #fff8f3;--panel-border: rgba(180, 110, 100, .16);--text: #3a261f;--muted: #8a6f64;--accent: #ff7a86;--accent-hover: #ff9aa3;--accent-shadow: rgba(255, 122, 134, .28);--danger: #d35454;--card-bg: #ffffff;--card-shadow: 0 6px 24px rgba(214, 130, 130, .12);--meter-bg: #fde0d6;--meter-affection: #ff7a86;--meter-attraction: #d36aa8;--meter-jealousy: #7e6cc4}*{box-sizing:border-box}html,body,#app{margin:0;height:100%;color:var(--text);font-family:Inter,-apple-system,system-ui,sans-serif;overflow:hidden}body{background-color:var(--bg);background-image:var(--story-bg, none);background-size:cover;background-position:center;position:relative}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,247,238,.18) 0%,rgba(255,247,238,.22) 60%,rgba(253,200,180,.45) 100%);pointer-events:none;z-index:0}#app{position:relative;z-index:1}#stage{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block;background:transparent}#ui{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}#ui>*{pointer-events:auto}.browser{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(160deg,var(--bg-grad-top) 0%,var(--bg-grad-bot) 100%);display:flex;flex-direction:column;align-items:center;padding:32px 24px 80px;overflow-y:auto;-webkit-overflow-scrolling:touch}.browser h1{font-size:40px;font-weight:700;letter-spacing:-.01em;margin:24px 0 8px;color:var(--text);text-align:center}@media (max-width: 600px){.browser{padding:48px 12px 60px}.browser h1{font-size:28px;margin-top:12px}.browser .sub{font-size:13px;padding:0 12px;text-align:center}.story-filter-bar{margin-top:14px!important}.story-grid{grid-template-columns:1fr!important;gap:12px!important}.story-card-art{height:120px!important}.title-actions{flex-direction:column;gap:8px!important;padding:0 12px}.title-actions .big-button{flex:1!important;width:100%}}.browser .sub{color:var(--muted);margin-bottom:32px;font-size:14px}.scenario-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;width:min(100%,900px)}.scenario-card{background:var(--card-bg);border:1px solid var(--panel-border);border-radius:18px;padding:20px;cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s;box-shadow:var(--card-shadow)}.scenario-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 12px 28px var(--accent-shadow)}.scenario-card h3{margin:0 0 6px;font-size:17px}.scenario-card .meta{color:var(--muted);font-size:12px;margin-bottom:10px}.scenario-card .desc{font-size:13px;line-height:1.45;color:var(--text)}.dialogue{position:absolute;left:50%;bottom:24px;transform:translate(-50%);width:min(900px,calc(100% - 48px));background:var(--card-bg);border:1px solid var(--panel-border);border-radius:22px;padding:22px 24px;box-shadow:var(--card-shadow);display:flex;gap:20px;align-items:stretch;max-height:calc(100vh - 100px);max-height:calc(100dvh - 100px);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:var(--panel-border) transparent}.dialogue::-webkit-scrollbar{width:6px}.dialogue::-webkit-scrollbar-track{background:transparent}.dialogue::-webkit-scrollbar-thumb{background:var(--panel-border);border-radius:3px}.dialogue::-webkit-scrollbar-thumb:hover{background:var(--accent)}.mute-toggle{position:absolute;top:16px;left:16px;background:var(--card-bg);border:1px solid var(--panel-border);border-radius:999px;width:40px;height:40px;font-size:16px;cursor:pointer;z-index:12;box-shadow:0 4px 12px #b46e642e;transition:transform .1s,background .12s;pointer-events:auto}.mute-toggle:hover{background:#fff0ec;transform:translateY(-1px)}.dialogue.beat-enter{animation:dialogue-beat-enter .32s ease-out}@keyframes dialogue-beat-enter{0%{opacity:0;transform:translate(-50%,6px)}to{opacity:1;transform:translate(-50%)}}.dialogue .body.typing:after{content:"▍";display:inline-block;margin-left:1px;color:var(--accent);animation:caret-blink .85s steps(2,end) infinite;font-weight:400;opacity:.7}@keyframes caret-blink{to{opacity:0}}.dialogue .choices.hidden{opacity:0;pointer-events:none}.dialogue .choices{transition:opacity .18s ease-out}.dialogue.has-portrait .dialogue-body-col{flex:1;min-width:0}.dialogue:not(.has-portrait) .dialogue-body-col{width:100%}.portrait-wrap{flex:0 0 240px;align-self:flex-start}.portrait{position:relative;width:240px;height:360px;border-radius:10px;overflow:hidden;border:1px solid var(--panel-border);background:#0e1014;box-shadow:0 4px 18px #0006}.portrait .portrait-img{width:100%;height:100%;object-fit:contain;display:block}.portrait .portrait-svg,.portrait .silhouette{width:100%;height:100%;display:block}.portrait-wrap.enter{animation:portrait-fade-in .32s ease-out}@keyframes portrait-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.portrait .silhouette .emblem{transform-origin:50px 55px;animation:emblem-pulse 2.4s ease-in-out infinite}@keyframes emblem-pulse{0%,to{opacity:.95;transform:scale(1)}50%{opacity:.78;transform:scale(.96)}}@media (max-width: 720px){.dialogue{flex-direction:column}.portrait-wrap{flex:0 0 auto;align-self:center}.portrait{width:180px;height:270px}}.dialogue .speaker{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:6px}.dialogue .body{font-size:15px;line-height:1.55;margin-bottom:14px;white-space:pre-wrap}.dialogue .choices{display:flex;flex-direction:column;gap:8px}.dialogue button.choice{text-align:left;background:var(--panel-soft);border:1px solid var(--panel-border);color:var(--text);padding:12px 16px;border-radius:14px;font:inherit;cursor:pointer;transition:background .12s,border-color .12s,transform .08s}.dialogue button.choice:hover{background:#fff0ec;border-color:var(--accent);transform:translate(2px)}.dialogue button.choice.choice-end{background:#e8f8f1;border-color:#46b794;border-left:4px solid #46b794;color:#1d6b54;font-weight:600}.dialogue button.choice.choice-end:hover{background:#d6f2e6;border-color:#2fa580;transform:translate(2px)}.dialogue .freeform{display:flex;gap:8px;margin-top:10px}.dialogue .freeform input{flex:1;background:var(--panel-soft);border:1px solid var(--panel-border);color:var(--text);padding:10px 14px;border-radius:14px;font:inherit}.dialogue .freeform input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-shadow)}.dialogue .freeform button{background:var(--accent);color:#fff;border:none;padding:0 18px;border-radius:14px;font:inherit;font-weight:600;cursor:pointer}.dialogue .freeform button:hover{background:var(--accent-hover)}.topbar{position:absolute;top:16px;left:16px;right:16px;display:flex;justify-content:space-between;align-items:center;pointer-events:none}.topbar .title{background:var(--card-bg);border:1px solid var(--panel-border);padding:10px 16px;border-radius:999px;font-size:13px;pointer-events:auto;box-shadow:var(--card-shadow);font-weight:500;margin-left:calc(46px + env(safe-area-inset-left))}.topbar button{background:var(--card-bg);border:1px solid var(--panel-border);color:var(--text);padding:10px 16px;border-radius:999px;font:inherit;font-size:13px;font-weight:500;cursor:pointer;pointer-events:auto;box-shadow:var(--card-shadow);transition:background .12s,border-color .12s,color .12s}.topbar button.status,.topbar button.save{margin-right:8px}.topbar button.status:hover,.topbar button.save:hover{border-color:var(--accent);color:var(--accent)}.topbar button.exit:hover{border-color:var(--danger);color:var(--danger)}.results{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(160deg,var(--bg-grad-top) 0%,var(--bg-grad-bot) 100%);display:flex;align-items:center;justify-content:center;padding:40px}.results .panel{background:var(--card-bg);border:1px solid var(--panel-border);border-radius:22px;padding:32px;width:min(560px,100%);box-shadow:var(--card-shadow)}.results h2{margin:0 0 6px;font-size:24px}.results .ending-name{color:var(--accent);font-size:13px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px}.results .ending-text{font-size:14px;line-height:1.55;margin-bottom:20px;color:#c9cdd4}.results .scores{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:20px}.results .score-row{display:flex;justify-content:space-between;padding:8px 12px;background:rgba(255,255,255,.03);border-radius:6px;font-size:13px}.results .score-row span:last-child{color:var(--accent);font-weight:600}.results .leaderboard{margin-top:12px;border-top:1px solid var(--panel-border);padding-top:16px}.results .leaderboard h4{margin:0 0 8px;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.results .lb-row{display:grid;grid-template-columns:24px 1fr auto auto;gap:10px;font-size:13px;padding:4px 0}.results .lb-row .rank{color:var(--muted)}.results .lb-row .ending{color:var(--muted);font-size:11px}.results .lb-row .score{color:var(--accent);font-weight:600}.results .lb-row.me{color:var(--accent)}.results .actions{display:flex;gap:8px;margin-top:20px}.results button{flex:1;background:rgba(255,255,255,.04);border:1px solid var(--panel-border);color:var(--text);padding:10px;border-radius:8px;font:inherit;cursor:pointer}.results button.primary{background:var(--accent);color:#1a1208;border-color:var(--accent);font-weight:600}.results button:hover{border-color:var(--accent)}.npc-label{position:absolute;transform:translate(-50%,-100%);font-size:11px;font-weight:700;letter-spacing:.04em;color:#fff;background:rgba(58,38,31,.85);padding:4px 10px;border-radius:999px;pointer-events:none;white-space:nowrap;border:1.5px solid rgba(255,255,255,.6);text-shadow:0 1px 2px rgba(0,0,0,.7);box-shadow:0 2px 6px #00000059}.npc-label.active{color:#fff;background:var(--accent);border-color:#fff;box-shadow:0 2px 10px #ff7a8680}
