:root{--surface:#f5f7f7;--ink:#243239;--ink-strong:#132229;--ink-soft:#33464f;--muted:#718087;--line:#dce5e7;--font-sans:"Pretendard", "Noto Sans KR", "Segoe UI", sans-serif;color:var(--ink);background:var(--surface);font-family:var(--font-sans);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{min-width:320px;min-height:100%}body{margin:0}button,textarea{font-family:inherit}.shell{min-height:100vh;color:var(--ink);background:linear-gradient(180deg, #dee6ebc7, #f7f9fa57 260px), var(--surface)}.auth-shell{min-height:100vh;color:var(--ink);background:radial-gradient(circle at 20% 20%,#40647529,#0000 34%),linear-gradient(135deg,#eef4f4,#f8faf8 52%,#e7efed);place-items:center;padding:24px;display:grid}.auth-card{border:1px solid var(--line);background:#ffffffe6;border-radius:18px;gap:14px;width:min(440px,100%);padding:30px;display:grid;box-shadow:0 24px 70px #1e364029}.auth-card .brand-mark{margin-bottom:4px}.auth-card h1{font-size:28px}.auth-card p{color:var(--muted);line-height:1.55}.auth-form{gap:10px;margin-top:6px;display:grid}.auth-form label{color:var(--ink-strong);font-size:13px;font-weight:800}.auth-form input{height:46px;color:var(--ink);font:inherit;background:#f8fbfb;border:1px solid #cddce0;border-radius:10px;padding:0 14px}.auth-form button,.logout-button{cursor:pointer;border:1px solid #0000;font-weight:800}.auth-form button{color:#fff;background:#274f60;border-radius:10px;height:46px}.auth-form button:disabled{cursor:not-allowed;opacity:.56}.auth-alert,.auth-error{border-radius:10px;padding:11px 12px;font-size:13px}.auth-alert{color:#895223;background:#fff8ec;border:1px solid #ecd1b2}.auth-error{color:#8f2d32;background:#fff0f1;border:1px solid #efc4c9}.logout-button{color:#274f60;background:#eef6f8;border-color:#bed6de;border-radius:999px;min-height:28px;padding:0 10px;font-size:12px}.topbar{border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fafcfce0;justify-content:space-between;align-items:center;gap:24px;min-height:76px;padding:14px 18px;display:flex}.brand,.status-strip,.status-strip span,.pane-tools,.runner-card div,.thread-actions,.thread-tabs,.message-meta,.tag-row,.attachment-strip,.composer-row,.section-title,.rule-list li,.deploy-panel .accordion-body button{align-items:center;display:flex}.brand{gap:12px;min-width:260px}.brand-mark{color:#f8fbfb;background:#26333a;border:1px solid #19252b;border-radius:8px;place-items:center;width:44px;height:44px;display:grid;box-shadow:0 10px 22px #1f2f372e}.eyebrow,.label{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin:0;font-size:11px;font-weight:700}h1,h2,h3,p{margin:0}h1{margin-top:3px;font-size:22px;font-weight:760}h2{color:var(--ink-strong);font-size:19px;font-weight:740}h3{color:var(--muted);font-size:12px;font-weight:760}.status-strip{flex-wrap:wrap;justify-content:flex-end;gap:8px}.status-strip span,.status-pill,.tag-row span,.attachment-strip em{min-height:28px;color:var(--ink-soft);border:1px solid var(--line);background:#fff;border-radius:999px;gap:6px;padding:0 9px;font-size:12px;font-weight:700}.status-strip .ok{color:#0f6b4d;background:#effaf5;border-color:#b7decf}.status-strip .syncing{color:#275c92;background:#edf6ff;border-color:#bbd7f1}.status-strip .danger{color:#895223;background:#fff8ec;border-color:#ecd1b2}.workspace{grid-template-columns:minmax(230px,280px) minmax(480px,1fr) minmax(320px,390px);height:calc(100vh - 77px);display:grid}.project-pane,.thread-pane,.context-pane{border-right:1px solid var(--line);min-height:0}.project-pane,.context-pane{background:#f5f8f9e0;overflow:auto}.project-pane{padding:14px}.pane-tools{gap:8px;margin-bottom:14px}.search-box{min-width:0;height:36px;color:var(--muted);border:1px solid var(--line);background:#fff;border-radius:7px;flex:1;align-items:center;gap:8px;padding:0 10px;font-size:13px;display:flex}button{font:inherit}.icon-button,.thread-actions button,.deploy-panel .accordion-body button,.send-button{border:1px solid var(--line);cursor:pointer}.icon-button{width:36px;height:36px;color:var(--ink-soft);background:#fff;border-radius:7px;place-items:center;display:grid}.project-list{gap:8px;display:grid}.project-item{width:100%;color:inherit;text-align:left;border:1px solid var(--line);cursor:pointer;background:#ffffffbd;border-radius:8px;grid-template-columns:1fr auto;align-items:center;gap:10px;padding:10px 11px;display:grid}.project-item.active{background:#fff;border-color:#6e8ea0;box-shadow:inset 3px 0 #315d6f,0 10px 26px #25404e14}.project-item strong{color:var(--ink-strong);font-size:15px;display:block}.project-item span,.project-item small,.runner-card p,.context-section p{color:var(--muted);font-size:12px;line-height:1.45}.project-item small{grid-column:1/-1}.status-pill{align-self:start;min-height:24px;font-size:11px;font-style:normal}.status-pill.running,.status-pill.implementing{color:#0d635d;background:#edf9f7;border-color:#b5deda}.status-pill.review,.status-pill.reviewing,.status-pill.spec{color:#5e5b0d;background:#fffbe6;border-color:#ebe3a1}.status-pill.planning,.status-pill.staging{color:#275c92;background:#edf6ff;border-color:#bbd7f1}.status-pill.blocked{color:#8f392d;background:#fff0ee;border-color:#efbeb8}.runner-card{background:#eef4f3;border:1px solid #d5e0df;border-radius:8px;gap:9px;margin-top:16px;padding:13px;display:grid}.runner-card div{color:var(--ink-strong);gap:8px;font-size:13px}.staff-card{border:1px solid var(--line);background:#fff;border-radius:8px;gap:10px;margin-top:12px;padding:12px;display:grid}.staff-title{color:var(--ink-strong);align-items:center;gap:8px;font-size:13px;display:flex}.staff-title strong{flex:1}.staff-title button{color:#315d6f;cursor:pointer;background:#edf4f6;border:1px solid #cfdfe4;border-radius:999px;place-items:center;width:26px;height:26px;display:grid}.staff-list{gap:7px;display:grid}.staff-list button{min-height:36px;color:var(--ink-soft);text-align:left;border:1px solid var(--line);cursor:pointer;background:#f8fbfb;border-radius:7px;grid-template-columns:minmax(54px,auto) 1fr auto;align-items:center;gap:7px;padding:7px 8px;display:grid}.staff-list button.active{color:#163240;background:#eaf3f6;border-color:#98b6c3}.staff-list button strong{color:#315d6f;text-align:center;text-overflow:ellipsis;white-space:nowrap;background:#edf4f6;border-radius:999px;padding:2px 7px;font-size:10px;overflow:hidden}.staff-list button span{text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.staff-list button em{color:var(--muted);font-size:10px;font-style:normal;font-weight:760}.thread-pane{background:#fbfcfc;grid-template-rows:auto 1fr auto;min-width:0;display:grid}.thread-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-start;gap:18px;padding:18px 18px 14px;display:flex}.thread-header h2{margin-top:3px;line-height:1.18}.thread-actions{flex-wrap:wrap;justify-content:flex-end;gap:7px}.room-description{max-width:620px;color:var(--muted);margin-top:5px;font-size:12px;line-height:1.45;display:block}.nametag-preview{color:#315d6f;background:#edf4f6;border-radius:999px;padding:2px 7px}.thread-actions button,.deploy-panel .accordion-body button,.send-button{min-height:34px;color:var(--ink-soft);background:#fff;border-radius:7px;align-items:center;gap:7px;padding:0 11px;font-size:13px;font-weight:760;display:inline-flex}.thread-actions .primary,.send-button{color:#fff;background:#315d6f;border-color:#315d6f}.thread-tabs{border-bottom:1px solid var(--line);gap:8px;padding:10px 18px;overflow-x:auto}.thread-tabs button{max-width:260px;min-height:32px;color:var(--ink-soft);border:1px solid var(--line);cursor:pointer;white-space:nowrap;background:#fff;border-radius:999px;align-items:center;gap:8px;padding:0 10px;display:flex}.thread-tabs button span{text-overflow:ellipsis;overflow:hidden}.thread-tabs button strong{color:#315d6f;background:#edf4f6;border-radius:999px;flex:none;padding:2px 7px;font-size:10px}.thread-tabs button.active{color:#163240;background:#eaf3f6;border-color:#98b6c3}.thread-tabs em{color:var(--muted);font-size:11px;font-style:normal}.room-context-menu{z-index:30;background:#fff;border:1px solid #b8cbd1;border-radius:9px;min-width:170px;padding:5px;display:grid;position:fixed;overflow:hidden;box-shadow:0 16px 38px #2a3d462e}.room-context-menu button{min-height:34px;color:var(--ink-soft);cursor:pointer;text-align:left;background:0 0;border:0;border-radius:6px;padding:0 10px;font-size:12px;font-weight:760}.room-context-menu button:hover{background:#edf4f6}.message-list{align-content:start;gap:14px;min-height:0;padding:18px;display:grid;overflow:auto}.message{grid-template-columns:36px minmax(0,1fr);gap:10px;display:grid}.avatar{color:#fff;background:#3a4a50;border-radius:8px;place-items:center;width:36px;height:36px;display:grid}.message.architect .avatar{background:#315d6f}.message.executor .avatar{background:#426052}.message.security .avatar{background:#7b4c45}.message.db .avatar{background:#4a5f7c}.message.qa .avatar{background:#6a6742}.message.system .avatar{background:#86533a}.message-body{border:1px solid var(--line);background:#fff;border-radius:8px;gap:12px;padding:13px;display:grid;box-shadow:0 8px 22px #1e2f360b}.message-meta{color:var(--muted);flex-wrap:wrap;gap:8px;font-size:12px}.message-meta strong{color:var(--ink-strong);font-size:14px}.message-meta em{color:#315d6f;font-style:normal;font-weight:800}.message-body section{gap:5px;display:grid}.message-body p{color:var(--ink-soft);font-size:14px;line-height:1.55}.tag-row{flex-wrap:wrap;gap:6px}.tag-row span,.attachment-strip em{color:#305362;background:#edf5f6;border-color:#c5dade;min-height:24px;font-size:11px;display:inline-flex}.attachment-preview-grid{grid-template-columns:repeat(auto-fit,minmax(118px,1fr));gap:8px;display:grid}.attachment-preview-grid figure{background:#f3f7f8;border:1px solid #d8e4e7;border-radius:7px;gap:6px;margin:0;padding:7px;display:grid}.attachment-preview-grid img{object-fit:cover;border-radius:5px;width:100%;height:92px}.attachment-preview-grid figcaption{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.composer{border-top:1px solid var(--line);background:#fafcfcf5;gap:8px;padding:12px 18px 16px;display:grid}.attachment-strip{min-height:26px;color:var(--muted);flex-wrap:wrap;gap:7px;font-size:12px}.attachment-strip span{align-items:center;gap:6px;display:inline-flex}.composer-row{gap:8px}textarea,input{color:var(--ink);font:inherit;background:#fff;border:1px solid #cad7db;border-radius:8px;flex:1;padding:11px 12px;font-size:14px;line-height:1.45}textarea{resize:vertical;min-height:44px;max-height:120px}input{width:100%;min-height:34px}textarea:focus,input:focus,button:focus-visible{outline-offset:2px;outline:2px solid #6b9cae}.upload{flex:none}.hidden-file-input{display:none}.context-pane{border-right:0;align-content:start;gap:10px;padding:14px;display:grid}.context-section{border:1px solid var(--line);background:#fff;border-radius:8px;gap:11px;padding:13px;display:grid}.context-section.accordion{gap:0;padding:0;display:block;overflow:visible}.accordion-summary{width:100%;color:inherit;cursor:pointer;text-align:left;-webkit-user-select:none;user-select:none;background:0 0;border:0;justify-content:space-between;align-items:center;gap:10px;padding:13px;display:flex}.accordion-summary:focus-visible{outline-offset:-3px;outline:2px solid #266f8352}.accordion-summary .section-title{align-items:flex-start;min-width:0}.accordion-summary .section-title>div{gap:3px;min-width:0;display:grid}.accordion-summary p{color:var(--muted);margin:0;font-size:11px;line-height:1.35}.accordion-chevron{color:#80949c;flex:none;transition:transform .16s}.accordion.open .accordion-chevron{transform:rotate(90deg)}.accordion-body{gap:11px;padding:0 13px 13px;display:grid}.panel-textarea{resize:vertical;width:100%;min-height:118px;max-height:none;font-size:12px}.panel-textarea.small{min-height:86px}.project-editor label{gap:5px;display:grid}.project-editor label span{color:var(--muted);font-size:11px;font-weight:760}.project-sync-card{border:1px solid #d5e0df;border-radius:7px;gap:4px;padding:10px;display:grid}.project-sync-card strong{color:var(--ink-strong);font-size:12px}.project-sync-card p{margin:0;font-size:12px}.project-sync-card.synced{background:#effaf5;border-color:#b7decf}.project-sync-card.syncing,.project-sync-card.idle{background:#edf6ff;border-color:#bbd7f1}.project-sync-card.error{background:#fff8ec;border-color:#ecd1b2}.role-editor{gap:10px}.role-tabs{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;display:grid}.role-tabs button{min-height:30px;color:var(--ink-soft);border:1px solid var(--line);cursor:pointer;background:#f8fbfb;border-radius:6px;padding:0 8px;font-size:12px;font-weight:760}.role-tabs button.active{color:#183542;background:#eaf3f6;border-color:#9ebbc6}.role-editor label{gap:6px;display:grid}.role-editor label span,.save-hint{color:var(--muted);font-size:11px;font-weight:740}.role-editor textarea{resize:vertical;min-height:116px;font-size:12px}.save-hint{align-items:center;gap:6px;display:flex}.section-title{gap:8px}.section-title h2{font-size:14px}.check-list,.rule-list,.risk-list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.check-list li,.risk-list li{color:var(--ink-soft);font-size:13px;line-height:1.45}.check-list li{grid-template-columns:16px 1fr;gap:8px;display:grid}.check-list span{border:2px solid #9ab2ba;border-radius:4px;width:12px;height:12px;margin-top:3px;display:inline-block}.rule-list li{color:var(--ink-soft);gap:5px;font-size:13px;line-height:1.35}.split{gap:12px}.split div{gap:5px;min-width:0;display:grid}.connection-panel .accordion-body{gap:12px}.connection-panel .accordion-body>div{gap:5px;min-width:0;display:grid}code{color:#304a56;text-overflow:ellipsis;white-space:nowrap;background:#edf4f6;border:1px solid #d2e1e5;border-radius:6px;padding:8px;font-family:JetBrains Mono,SFMono-Regular,Consolas,monospace;font-size:11px;display:block;overflow:hidden}.risk-list li{border-left:3px solid #e7b8a9;padding-left:10px}.github-panel .accordion-body>button,.runner-panel .accordion-body>button{min-height:34px;color:var(--ink-soft);border:1px solid var(--line);cursor:pointer;background:#fff;border-radius:7px;justify-content:center;align-items:center;gap:7px;font-size:13px;font-weight:760;display:inline-flex}.runner-panel .accordion-body>button:disabled{cursor:not-allowed;opacity:.46}.runner-panel .accordion-body>button.codex-run-button{color:#224250;background:#fff8ec;border-color:#e5c091}.runner-panel .accordion-body>button.codex-run-button:not(:disabled):hover{background:#fff1d9}.github-state{border-radius:7px;gap:6px;padding:10px;display:grid}.github-state.ok{background:#effaf5;border:1px solid #b7decf}.github-state.error{background:#fff0ee;border:1px solid #efbeb8}.github-state strong,.job-list strong{color:var(--ink-strong);font-size:13px}.github-state span,.github-state small,.job-list small{color:var(--muted);font-size:11px}.github-state a{color:#315d6f;align-items:center;gap:4px;font-size:12px;font-weight:760;text-decoration:none;display:inline-flex}.job-list{gap:8px;display:grid}.job-list article{border:1px solid var(--line);background:#f8fbfb;border-radius:7px;gap:6px;padding:9px;display:grid}.job-list article>div{justify-content:space-between;align-items:center;gap:8px;display:flex}.job-summary{color:var(--ink-soft);margin:0;font-size:12px;line-height:1.5}.job-artifacts{grid-template-columns:repeat(auto-fit,minmax(104px,1fr));gap:7px;display:grid}.job-artifacts a{color:#315d6f;background:#eef5f6;border:1px solid #d5e4e7;border-radius:7px;gap:5px;min-width:0;padding:6px;font-size:11px;font-weight:760;text-decoration:none;display:grid}.job-artifacts img{object-fit:cover;background:#fff;border-radius:5px;width:100%;height:84px}.job-artifacts span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.job-artifacts .file-artifact{grid-template-columns:auto minmax(0,1fr);align-items:center;min-height:42px}.job-raw-log{gap:7px;display:grid}.job-raw-log summary{color:#315d6f;cursor:pointer;font-size:11px;font-weight:800}.job-raw-log code{color:#2f5260;background:#eef5f6;border:1px solid #d5e4e7;border-radius:6px;padding:7px 8px;font-size:10px}.job-log{color:#3c5360;background:#eef5f6;border:1px solid #d5e4e7;border-radius:6px;gap:4px;max-height:145px;padding:8px;font-family:JetBrains Mono,SFMono-Regular,Consolas,monospace;font-size:10px;line-height:1.45;display:grid;overflow:auto}.job-log span{overflow-wrap:anywhere;white-space:pre-wrap}.job-status{text-transform:uppercase;border-radius:999px;padding:2px 7px;font-size:10px;font-style:normal;font-weight:800}.job-status.queued{color:#275c92;background:#edf6ff}.job-status.running{color:#5e5b0d;background:#fffbe6}.job-status.done{color:#0d635d;background:#edf9f7}.job-status.blocked,.job-status.failed{color:#8f392d;background:#fff0ee}.deploy-panel strong{color:var(--ink-strong);font-size:13px;line-height:1.45}.deploy-panel .accordion-body button{justify-content:center;width:100%}.deploy-panel .locked{color:#895223;background:#fff8ec;border-color:#ecd1b2}.text-button{width:100%;min-height:34px;color:var(--muted);cursor:pointer;background:0 0;border:1px dashed #bccace;border-radius:7px;margin-top:10px;font-size:12px;font-weight:740}.empty-state{min-height:100vh;color:var(--muted);place-items:center;display:grid}@media (width<=1180px){.workspace{grid-template-columns:240px minmax(420px,1fr)}.context-pane{display:none}}@media (width<=820px){.topbar{flex-direction:column;align-items:flex-start}.workspace{grid-template-columns:1fr;height:auto}.project-pane,.thread-pane{border-right:0}.project-pane{max-height:none}.project-list{grid-template-columns:repeat(2,minmax(0,1fr))}.thread-header{flex-direction:column}}@media (width<=560px){.project-list{grid-template-columns:1fr}.thread-actions,.composer-row{flex-direction:column;align-items:stretch}.thread-actions button,.send-button,.icon-button.upload{justify-content:center;width:100%}}
