:root{font-family:Pretendard,Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#f1f5f9;background:#080f1e;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{-webkit-tap-highlight-color:transparent}html{background:#080f1e}body{margin:0;min-width:320px;min-height:100vh;background:#080f1e}button,input,textarea,select{font:inherit}button{cursor:pointer}button:active{transform:scale(.98)}img{display:block}@media(min-width:481px){body{display:flex;justify-content:center;align-items:flex-start}}#root{width:100%;min-height:100vh}.app-frame{width:100%;min-height:100vh;background:radial-gradient(circle at top right,rgba(56,189,248,.14),transparent 30%),#0f172a;color:#f1f5f9}main{width:min(100%,1180px);margin:0 auto;padding:20px 20px 48px}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid rgba(125,211,252,.85);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:56px;padding:8px max(20px,calc((100vw - 1180px)/2 + 20px));background:#0f172af0;border-bottom:1px solid #243044;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.brand{display:inline-flex;align-items:center;gap:10px;min-width:0;border:0;background:transparent;color:#f1f5f9;font:inherit;font-size:20px;font-weight:800}.brand-mark{display:inline-flex;width:32px;height:32px;align-items:center;justify-content:center;border:1px solid rgba(56,189,248,.7);border-radius:999px;background:#1e293b;color:#7dd3fc;font-size:12px;font-weight:800}.topbar-actions{display:inline-flex;gap:6px}.icon-button{border:1px solid #334155;border-radius:8px;background:#1e293b;color:#cbd5e1;padding:8px 10px;font-size:12px;font-weight:700}.icon-button.fit{align-self:flex-start}.icon-button.active{border-color:#38bdf894;background:#38bdf824;color:#7dd3fc}.stack,.case-layout,.chat-screen,.login-screen{display:flex;flex-direction:column;gap:16px}.login-screen{min-height:calc(100vh - 96px);justify-content:center;text-align:center;max-width:520px;margin:0 auto}.logo-orb{width:88px;height:88px;margin:0 auto 8px;border-radius:999px;display:grid;place-items:center;background:#1e293b;border:1px solid rgba(56,189,248,.6);box-shadow:0 0 32px #38bdf838;overflow:hidden}.logo-orb img{width:72px;height:72px;object-fit:cover}.eyebrow{margin:0;color:#64748b;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:11px;font-weight:800;letter-spacing:.16em}h1,h2,p{margin:0}h1{font-size:28px;line-height:1.2}h2{font-size:20px;line-height:1.25}.muted,.card-body{color:#94a3b8;font-size:13px;line-height:1.55}.hero-panel{display:flex;flex-direction:column;justify-content:flex-end;gap:10px;min-height:220px;padding:18px;border-radius:14px;background:linear-gradient(135deg,#0f172a47,#0d9488cc),#1e293b;border:1px solid #334155}.hero-panel p:not(.eyebrow){color:#f8fafcc7;font-size:14px}.briefing-panel{display:flex;min-height:220px;flex-direction:column;justify-content:flex-end;gap:10px;border:1px solid rgba(56,189,248,.28);border-radius:14px;background:linear-gradient(180deg,#0f172a1a,#0f172af0),radial-gradient(circle at top right,rgba(244,63,94,.18),transparent 30%),radial-gradient(circle at top left,rgba(56,189,248,.2),transparent 34%),#1e293b;padding:18px}.briefing-panel p:not(.eyebrow){color:#cbd5e1;font-size:14px;line-height:1.6}.hero-actions,.dev-login,.input-row{display:flex;gap:10px}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.dev-login{flex-direction:column}.oauth-buttons{display:grid;justify-items:center;gap:10px}.google-login-box{display:flex;justify-content:center;min-height:44px;width:min(360px,100%)}.kakao-login-button{width:min(360px,100%);min-height:44px;border:0;border-radius:6px;background:#fee500;color:#191919;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:0 16px;font-size:14px;font-weight:800}.kakao-login-button:disabled{opacity:.6}.kakao-mark{display:inline-grid;place-items:center;width:20px;height:20px;border-radius:999px;background:#191919;color:#fee500;font-size:12px;font-weight:900}.auth-notice{border:1px solid rgba(251,191,36,.34);border-radius:8px;background:#fbbf241a;color:#fde68a;padding:12px;font-size:13px;line-height:1.5}.button{min-height:48px;border:0;border-radius:8px;padding:12px 16px;font-size:14px;font-weight:800}.button:disabled{opacity:.45}.button.primary{background:#38bdf8;color:#082f49}.button.secondary{background:#38bdf824;color:#7dd3fc;border:1px solid rgba(56,189,248,.34)}.button.ghost{background:#1e293b;color:#cbd5e1;border:1px solid #334155}.button.compact{width:82px;min-height:48px;flex-shrink:0;padding-inline:12px}input,textarea,select{width:100%;box-sizing:border-box;border:1px solid #334155;border-radius:8px;background:#1e293b;color:#f1f5f9;padding:13px 14px;font:inherit;font-size:14px}input[type=range],input[type=checkbox]{width:auto}input[type=range]{width:100%;accent-color:#38bdf8}textarea{min-height:92px;resize:vertical}.select{min-height:48px}.screen-title{display:flex;flex-direction:column;gap:3px}.detail-actions,.section-header,.dialog-actions{display:flex;align-items:center;justify-content:space-between;gap:10px}.search-row{display:flex;gap:8px}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group>span{color:#64748b;font-size:11px;font-weight:900}.chip-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px}.chip,.question-chip{display:inline-flex;align-items:center;justify-content:center;min-height:32px;white-space:nowrap;border:1px solid #334155;border-radius:999px;background:#1e293b;color:#cbd5e1;padding:6px 10px;font-size:12px;font-weight:700}.chip.active{border-color:#38bdf899;background:#38bdf824;color:#7dd3fc}.chip:disabled{opacity:.55}.button-chip{border:1px solid #334155}.card-list{display:flex;flex-direction:column;gap:12px}.card-list.compact{gap:8px;margin-top:10px}.scenario-card,.suspect-card,.info-card{width:100%;box-sizing:border-box;border:1px solid #334155;border-radius:12px;background:#1e293b;color:#f1f5f9;padding:14px;text-align:left}.scenario-card,.suspect-card{display:grid;grid-template-columns:54px 1fr;gap:12px;align-items:center}.scenario-thumb,.evidence-thumb,.avatar,.state-icon{display:grid;place-items:center;overflow:hidden;background:#0f172a;border:1px solid #334155;color:#38bdf8;font-weight:900}.scenario-thumb{width:54px;height:54px;border-radius:8px}.scenario-hero,.evidence-hero{display:grid;place-items:center;min-height:190px;overflow:hidden;border:1px solid #334155;border-radius:14px;background:radial-gradient(circle at 20% 20%,rgba(56,189,248,.18),transparent 34%),linear-gradient(135deg,#1e293b,#0f172a);color:#38bdf8;font-size:18px;font-weight:900}.image-button{width:100%;padding:0;text-align:center}.image-button:disabled{cursor:default;opacity:1}.scenario-hero img,.evidence-hero img{width:100%;height:100%;min-height:190px;object-fit:cover}.scenario-thumb img,.evidence-thumb img,.avatar img,.scenario-thumb>span,.evidence-thumb>span,.avatar>span{width:100%;height:100%;object-fit:cover}.scenario-thumb>span,.evidence-thumb>span,.avatar>span{display:grid;place-items:center}.card-title{color:#f8fafc;font-size:15px;font-weight:800;line-height:1.25}.meta-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.meta-row span{border-radius:999px;background:#94a3b81f;color:#94a3b8;padding:4px 7px;font-size:11px;font-weight:700}.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.stat{border:1px solid #334155;border-radius:10px;background:#1e293b;padding:12px;min-width:0}.stat span{display:block;color:#64748b;font-size:11px;font-weight:800;margin-bottom:6px}.stat strong{display:block;color:#f8fafc;font-size:14px;word-break:keep-all}.profile-card{display:grid;grid-template-columns:72px 1fr;gap:14px;align-items:center;border:1px solid rgba(56,189,248,.28);border-radius:14px;background:#1e293b;padding:16px}.profile-avatar{display:grid;width:72px;height:72px;place-items:center;overflow:hidden;border:1px solid rgba(56,189,248,.5);border-radius:999px;background:#0f172a;color:#7dd3fc;font-size:20px;font-weight:900}.profile-avatar img{width:100%;height:100%;object-fit:cover}.menu-list,.records-list,.recommendation-list,.result-match-list,.review-list{display:flex;flex-direction:column;gap:10px}.menu-item{width:100%;border:1px solid #334155;border-radius:10px;background:#1e293b;color:#f1f5f9;padding:14px;text-align:left}.menu-item span{display:block;font-size:14px;font-weight:900}.menu-item small{display:block;margin-top:5px;color:#94a3b8;font-size:12px;line-height:1.45}.menu-item.danger span{color:#fb7185}.record-card{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;border:1px solid #334155;border-radius:12px;background:#1e293b;padding:14px}.detective-grade-card{display:grid;grid-template-columns:56px 1fr;gap:14px;align-items:center;border:1px solid rgba(56,189,248,.28);border-radius:14px;background:linear-gradient(135deg,rgba(56,189,248,.12),transparent 58%),#1e293b;padding:16px}.grade-mark{display:grid;width:56px;height:56px;place-items:center;border:1px solid rgba(56,189,248,.5);border-radius:12px;background:#38bdf81f;color:#7dd3fc;font-size:28px;font-weight:900}.detective-grade-card h2{font-size:18px}.record-card h2{margin-top:4px;font-size:17px}.record-score{min-width:72px;text-align:right}.record-score strong{display:block;color:#7dd3fc;font-size:22px;font-weight:900}.record-score span{display:block;margin-top:3px;color:#94a3b8;font-size:12px;font-weight:800}.record-score .chip{margin-top:8px}.review-empty,.review-list{margin-top:12px}.review-card{border:1px solid #334155;border-radius:10px;background:#0f172a;padding:12px}.review-card.spoiler{border-color:#fb718547}.review-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.review-head strong{display:block;color:#e2e8f0;font-size:13px}.review-head span{display:block;margin-top:3px;color:#64748b;font-size:11px}.review-head b{color:#7dd3fc;font-size:13px}.review-card p{margin-top:10px;color:#cbd5e1;font-size:13px;line-height:1.55}.spoiler-cover{width:100%;margin-top:10px;border:1px solid rgba(251,113,133,.34);border-radius:8px;background:#fb718514;color:#fda4af;padding:10px 12px;font-size:12px;font-weight:800;text-align:left}.hud{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.hud-stats{display:grid;grid-template-columns:74px 74px;gap:6px;flex-shrink:0}.hud-stats .stat{padding:8px}.tabbar{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;border:1px solid #334155;border-radius:10px;padding:4px;background:#1e293b}.tabbar button{border:0;border-radius:7px;background:transparent;color:#94a3b8;padding:9px 4px;font-size:12px;font-weight:800}.tabbar button.active{background:#38bdf829;color:#7dd3fc}.row{display:grid;grid-template-columns:44px 1fr;gap:12px}.location-grid,.hint-list{display:flex;flex-direction:column;gap:10px;margin-top:10px}.scene-map{position:relative;display:grid;width:100%;min-height:180px;place-items:center;overflow:hidden;border:1px solid #334155;border-radius:12px;background:linear-gradient(135deg,rgba(56,189,248,.08),transparent),#0f172a;color:#38bdf8;font-size:18px;font-weight:900;margin-top:10px;padding:0}.scene-map:disabled{cursor:default;opacity:1}.scene-map img{width:100%;height:100%;min-height:180px;object-fit:cover}.map-marker{position:absolute;display:grid;width:24px;height:24px;place-items:center;transform:translate(-50%,-50%);border:2px solid #0f172a;border-radius:999px;background:#f59e0b;color:#111827;font-size:11px;font-weight:900;box-shadow:0 6px 18px #00000047}.map-marker.active{width:30px;height:30px;background:#38bdf8}.location-card,.hint-card{display:grid;grid-template-columns:58px 1fr;gap:12px;align-items:center;border:1px solid #334155;border-radius:10px;background:#0f172a;padding:10px}.location-card{width:100%;color:#f1f5f9;text-align:left}.location-card.active{border-color:#38bdf894;background:#38bdf81a}.hint-card{grid-template-columns:1fr auto}.location-card img,.location-card>span,.location-placeholder{width:58px;height:58px;border-radius:8px}.location-card img{object-fit:cover}.location-card>span,.location-placeholder{display:grid;place-items:center;background:#1e293b;color:#38bdf8;font-size:12px;font-weight:900}.location-card strong,.hint-card strong{display:block;color:#e2e8f0;font-size:13px;font-weight:900}.location-card p,.hint-card p{margin-top:4px;color:#94a3b8;font-size:12px;line-height:1.45}.location-card span{display:inline-flex;margin-top:6px;color:#7dd3fc;font-size:11px;font-weight:900}.location-detail{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-top:12px;border-top:1px solid #334155;padding-top:12px}.evidence-thumb,.avatar{width:44px;height:44px;border-radius:10px}.avatar{border-radius:999px}.suspect-profile{display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 0;text-align:center}.suspect-profile .avatar{width:86px;height:86px;font-size:22px;box-shadow:0 0 28px #38bdf82e}.evidence-card.locked{opacity:.75}.evidence-card{min-height:104px;touch-action:manipulation}.evidence-card>.row{pointer-events:none}.guidance{display:flex;flex-direction:column;gap:9px;margin-top:12px;padding-top:12px;border-top:1px solid #334155}.mini-title,.field-label,.text-area span{color:#cbd5e1;font-size:12px;font-weight:900}.guidance ul{margin:0;padding-left:18px;color:#94a3b8;font-size:13px;line-height:1.55}.question-stack{display:flex;flex-direction:column;gap:8px}.question-chip{justify-content:flex-start;white-space:normal;text-align:left}.evidence-row{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;border:1px solid #334155;border-radius:8px;background:#0f172a;color:#f1f5f9;padding:10px 12px;text-align:left}.evidence-row.static{pointer-events:none}.evidence-row span{font-size:13px;font-weight:800}.evidence-row small{color:#64748b;font-size:11px}.log-list{display:flex;flex-direction:column;gap:10px;margin-top:10px}.log-item{border:1px solid #334155;border-radius:8px;background:#0f172a;padding:11px 12px}.log-item strong{display:block;color:#e2e8f0;font-size:13px;line-height:1.45}.log-item p{margin-top:8px;color:#94a3b8;font-size:13px;line-height:1.55}.log-item span{display:inline-flex;margin-top:8px;color:#7dd3fc;font-size:11px;font-weight:800}.chat-header{display:grid;grid-template-columns:auto 44px 1fr;align-items:center;gap:10px}.message-list{display:flex;min-height:320px;max-height:50vh;flex-direction:column;gap:8px;overflow-y:auto;padding:8px 0}.bubble{max-width:82%;border-radius:12px;padding:11px 12px;font-size:14px;line-height:1.55}.bubble.detective{align-self:flex-end;background:#38bdf82e;color:#e0f2fe;border:1px solid rgba(56,189,248,.34)}.bubble.suspect{align-self:flex-start;background:#1e293b;color:#e2e8f0;border:1px solid #334155}.bubble-kicker{display:block;margin-bottom:4px;color:#7dd3fc;font-size:10px;font-weight:900}.attached-evidence{display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid rgba(20,184,166,.35);border-radius:8px;background:#14b8a61f;color:#99f6e4;padding:10px 12px;font-size:12px;font-weight:800}.attached-evidence button{border:0;background:transparent;color:#99f6e4;font-weight:900}.input-row{align-items:stretch}.input-row textarea{min-height:52px}.input-row .button{width:84px;flex-shrink:0}.text-area{display:flex;flex-direction:column;gap:8px}.toggle-row{display:inline-flex;align-items:center;gap:8px;color:#cbd5e1;font-size:13px;font-weight:800}.submit-checklist{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.submit-check{display:flex;align-items:center;gap:8px;border:1px solid #334155;border-radius:8px;background:#1e293b;padding:9px 10px}.submit-check span{min-width:32px;color:#64748b;font-size:10px;font-weight:900}.submit-check strong{color:#94a3b8;font-size:12px}.submit-check.met{border-color:#38bdf861;background:#38bdf81a}.submit-check.met span,.submit-check.met strong{color:#7dd3fc}.evidence-picker{display:flex;flex-wrap:wrap;gap:8px}.evidence-picker .chip,.selected-summary .chip{min-height:40px;touch-action:manipulation}.selected-summary{display:flex;flex-wrap:wrap;gap:8px;border:1px solid rgba(56,189,248,.22);border-radius:10px;background:#38bdf814;padding:10px}.timeline{display:flex;flex-direction:column;gap:10px}.timeline-item{display:grid;grid-template-columns:54px 1fr;gap:12px;border:1px solid #334155;border-radius:12px;background:#1e293b;padding:12px}.timeline-item time{color:#38bdf8;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:12px;font-weight:900}.score-card{display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;gap:10px;border:1px solid rgba(56,189,248,.4);border-radius:14px;background:#38bdf81f;padding:20px}.score-card span{color:#7dd3fc;font-size:22px;font-weight:900}.score-card strong{color:#f8fafc;font-size:52px;line-height:1;text-align:right}.score-card small{color:#94a3b8;font-weight:800}.result-match-row{display:flex;justify-content:space-between;gap:12px;border:1px solid #334155;border-radius:8px;background:#0f172a;padding:10px 12px}.result-match-row span{color:#cbd5e1;font-size:13px;font-weight:800}.result-match-row strong{color:#94a3b8;font-size:13px;font-weight:900}.result-match-row.matched strong{color:#7dd3fc}.recommendation-card{display:grid;grid-template-columns:52px 1fr;gap:10px;align-items:center;border:1px solid #334155;border-radius:10px;background:#0f172a;padding:10px}.recommendation-card img,.recommendation-card>span{width:52px;height:52px;border-radius:8px}.recommendation-card img{object-fit:cover}.recommendation-card>span{display:grid;place-items:center;background:#1e293b;color:#38bdf8;font-size:12px;font-weight:900}.recommendation-card strong{color:#e2e8f0;font-size:13px}.recommendation-card p{margin-top:4px;color:#94a3b8;font-size:12px;line-height:1.45}.state-block{min-height:360px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;color:#94a3b8}.state-icon{width:48px;height:48px;border-radius:999px}.state-block h2{color:#f1f5f9}.error-text{color:#fb7185;font-size:13px;line-height:1.45}.modal-shell{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:grid;align-items:end}.modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:0;background:#020617c7}.review-dialog{position:relative;z-index:1;display:flex;width:100%;max-height:calc(100vh - 32px);box-sizing:border-box;flex-direction:column;gap:14px;overflow-y:auto;border:1px solid #334155;border-radius:18px 18px 0 0;background:#1e293b;padding:16px}.evidence-picker-dialog{position:relative;z-index:1;display:flex;width:100%;max-height:82vh;box-sizing:border-box;flex-direction:column;gap:14px;border:1px solid #334155;border-radius:18px 18px 0 0;background:#1e293b;padding:16px}.confirm-dialog{position:relative;z-index:1;display:flex;width:min(100%,448px);box-sizing:border-box;flex-direction:column;gap:14px;justify-self:center;align-self:center;border:1px solid #334155;border-radius:16px;background:#1e293b;padding:18px}.evidence-picker-dialog .state-block{min-height:160px}.picker-list{display:flex;min-height:0;flex-direction:column;gap:8px;overflow-y:auto;padding-bottom:8px}.picker-row{display:grid;grid-template-columns:44px 1fr;gap:10px;align-items:center;width:100%;border:1px solid #334155;border-radius:10px;background:#0f172a;color:#f1f5f9;padding:10px;text-align:left}.picker-row.active{border-color:#38bdf894;background:#38bdf81a}.picker-row strong{display:block;color:#e2e8f0;font-size:13px}.picker-row p{margin-top:4px;color:#94a3b8;font-size:12px;line-height:1.45}.modal-handle{width:42px;height:4px;align-self:center;border-radius:999px;background:#475569}.image-viewer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:16px}.image-viewer-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:0;background:#020617db}.image-viewer-panel{position:relative;z-index:1;display:flex;width:min(100%,448px);max-height:calc(100vh - 32px);flex-direction:column;gap:12px;border:1px solid #334155;border-radius:14px;background:#0f172a;padding:12px}.image-viewer-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px}.image-viewer-topbar h2{font-size:16px}.image-viewer-panel img{width:100%;max-height:calc(100vh - 148px);border-radius:10px;object-fit:contain;background:#020617}@media(min-width:760px){main{padding:28px 28px 56px}.login-screen{max-width:640px}.hero-actions,.dev-login{max-width:420px;margin-right:auto;margin-left:auto}.card-list:not(.compact),.records-list,.recommendation-list,.menu-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.scenario-hero,.evidence-hero,.scenario-hero img,.evidence-hero img{min-height:320px}.submit-checklist,.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:1040px){.card-list:not(.compact){grid-template-columns:repeat(3,minmax(0,1fr))}.case-layout{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.75fr);align-items:start}.chat-screen{min-height:calc(100vh - 140px)}}
