*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0f0f;--surface:#1a1a1a;--surface2:#222;--border:#2a2a2a;--accent:#4f8ef7;--accent-dim:#1e3a6e;--green:#5cb85c;--green-dim:#1a2a1a;--yellow:#f0ad4e;--yellow-dim:#2a2000;--red:#d9534f;--red-dim:#2a0a0a;--text:#e8e8e8;--text-muted:#666;--radius:10px;--font:"Apple SD Gothic Neo","Malgun Gothic","Noto Sans KR",sans-serif}body{font-family:var(--font);background:var(--bg);color:var(--text)}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.app-layout{height:100dvh}.app-layout,.main-area{display:flex;overflow:hidden}.main-area{flex:1 1;min-width:0}.main-area,.sidebar{flex-direction:column}.sidebar{width:220px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex}.sidebar-logo{padding:18px 18px 16px;border-bottom:1px solid var(--border)}.sidebar-logo h1{font-size:17px;font-weight:700;letter-spacing:-.3px}.sidebar-logo span{font-size:11px;color:var(--text-muted);display:block;margin-top:2px}.sidebar-nav{padding:10px 8px;flex:1 1;overflow-y:auto}.nav-section{font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;padding:8px 10px 4px}.nav-link,.nav-section{color:var(--text-muted)}.nav-link{display:flex;align-items:center;gap:9px;width:100%;padding:8px 12px;border-radius:8px;border:none;background:transparent;font-size:13px;font-family:var(--font);cursor:pointer;text-align:left;text-decoration:none;transition:background .15s,color .15s}.nav-link:hover{background:var(--border);color:var(--text)}.nav-link.active{background:var(--accent-dim);color:var(--accent)}.nav-link .icon{font-size:15px;width:20px;text-align:center;flex-shrink:0}.sidebar-footer{padding:10px 18px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.logout-btn,.sidebar-footer{font-size:11px;color:var(--text-muted)}.logout-btn{background:none;border:none;cursor:pointer;padding:2px 0;font-family:var(--font)}.logout-btn:hover{color:var(--red)}.topbar{justify-content:space-between;padding:13px 22px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.topbar,.topbar-left{display:flex;align-items:center}.topbar-left{gap:10px}.topbar-title{font-size:15px;font-weight:600}.topbar-sub{font-size:12px;color:var(--text-muted)}.topbar-actions{display:flex;gap:8px}.content{flex:1 1;overflow-y:auto;padding:22px}.btn{padding:6px 14px;border-radius:7px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-size:12px;font-family:var(--font);cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn:hover{color:var(--accent)}.btn.primary,.btn:hover{border-color:var(--accent)}.btn.primary{background:var(--accent);color:#fff}.btn.primary:hover{background:#3a7ae0;border-color:#3a7ae0}.btn.danger{color:var(--red);border-color:var(--red)}.btn.danger:hover{background:var(--red-dim)}.btn:disabled{opacity:.45;cursor:not-allowed}.tag{display:inline-block;font-size:10px;padding:2px 8px;border-radius:10px;font-weight:500;white-space:nowrap}.tag.green{background:var(--green-dim);color:var(--green)}.tag.yellow{background:var(--yellow-dim);color:var(--yellow)}.tag.gray{background:var(--border);color:var(--text-muted)}.tag.blue{background:var(--accent-dim);color:var(--accent)}.tag.red{background:var(--red-dim);color:var(--red)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;margin-bottom:12px;transition:border-color .15s}.card:hover{border-color:#3a3a3a}.card-title{font-size:14px;font-weight:600;margin-bottom:4px}.card-sub{font-size:11px;color:var(--text-muted)}.form-group{margin-bottom:14px}.form-label{font-size:12px;color:var(--text-muted);margin-bottom:5px;display:block;font-weight:500}.form-input{width:100%;padding:9px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:7px;color:var(--text);font-size:13px;font-family:var(--font);outline:none;transition:border-color .15s}.form-input:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--text-muted)}textarea.form-input{resize:vertical;min-height:90px;line-height:1.6}select.form-input{cursor:pointer}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:12px;gap:12px}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;transition:border-color .15s;position:relative}.project-card:hover{border-color:var(--accent)}.pc-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.pc-name{font-size:14px;font-weight:600}.pc-desc{font-size:12px;color:var(--text-muted);line-height:1.5;margin-bottom:10px;min-height:18px}.pc-meta{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.pc-actions{display:none;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.project-card:hover .pc-actions{display:flex}.notes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:12px;gap:12px}.note-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;cursor:pointer;transition:border-color .15s}.note-card:hover{border-color:#3a3a3a}.nc-title{font-size:13px;font-weight:600;margin-bottom:6px}.nc-body{font-size:12px;color:var(--text-muted);line-height:1.6;white-space:pre-wrap;max-height:80px;overflow:hidden}.nc-footer{display:flex;justify-content:space-between;align-items:center;margin-top:10px;padding-top:8px;border-top:1px solid var(--border)}.nc-date{font-size:10px;color:var(--text-muted)}.nc-del{font-size:11px;color:var(--red);cursor:pointer;display:none}.note-card:hover .nc-del{display:block}.issue-item{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px}.issue-body{flex:1 1;min-width:0}.issue-title{font-size:13px;font-weight:500;margin-bottom:4px}.issue-title a{color:var(--text);text-decoration:none}.issue-title a:hover{color:var(--accent)}.issue-meta{font-size:11px;color:var(--text-muted);gap:10px;flex-wrap:wrap}.issue-meta,.modal-overlay{display:flex;align-items:center}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:100;justify-content:center}.modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:24px;width:540px;max-width:95vw;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-title{font-size:16px;font-weight:700}.modal-close{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;padding:2px 6px}.modal-close:hover{color:var(--text)}.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.empty{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty .icon{font-size:40px;margin-bottom:12px}.empty h3{font-size:15px;color:var(--text);margin-bottom:6px}.empty p{font-size:12px;line-height:1.6}.login-wrap{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-box{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:36px 40px;width:360px;max-width:95vw}.login-title{font-size:20px;font-weight:700;margin-bottom:4px}.login-sub{font-size:12px;color:var(--text-muted);margin-bottom:24px}.login-error{font-size:12px;color:var(--red);margin-bottom:12px}.toast{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 16px;font-size:13px;animation:fadeIn .15s ease}.toast.ok{border-left:3px solid var(--green)}.toast.err{border-left:3px solid var(--red)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}.settings-row:last-child{border-bottom:none}.settings-key{font-size:13px}.settings-desc{font-size:11px;color:var(--text-muted);margin-top:2px}