:root{--bg:#0f1117;--surface:#181c27;--card:#1e2333;--border:#2a3045;--accent:#4e79a7;--accent2:#f28e2b;--green:#59a14f;--red:#e15759;--text:#e8eaf0;--muted:#7a8099;--radius:10px;--mono:"Space Mono", monospace;--sans:"DM Sans", sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{font-family:var(--sans);background:var(--bg);color:var(--text);min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.layout{height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:220px;padding:24px 0;display:flex}.main{flex:1;padding:28px;overflow-y:auto}.logo{font-family:var(--mono);letter-spacing:-.5px;color:var(--accent);border-bottom:1px solid var(--border);margin-bottom:12px;padding:0 20px 24px;font-size:1.1rem;font-weight:700}.logo span{color:var(--accent2)}.nav-item{cursor:pointer;color:var(--muted);border-left:3px solid #0000;align-items:center;gap:10px;padding:10px 20px;font-size:.875rem;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{color:var(--text);background:#4e79a714}.nav-item.active{color:var(--text);border-left-color:var(--accent);background:#4e79a726}.nav-item svg{width:16px;height:16px}.sidebar-footer{border-top:1px solid var(--border);color:var(--muted);margin-top:auto;padding:16px 20px;font-size:.75rem}.role-badge{letter-spacing:.5px;text-transform:uppercase;color:var(--accent);background:#4e79a733;border-radius:100px;padding:2px 8px;font-size:.65rem;font-weight:700;display:inline-block}.role-badge.admin{color:var(--accent2);background:#f18e2b33}.role-badge.viewer{color:var(--muted);background:#7a809933}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.card-sm{padding:14px 16px}.card-grid{gap:16px;display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.stat-value{font-family:var(--mono);margin:8px 0 4px;font-size:2rem;font-weight:700;line-height:1}.stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.stat-sub{color:var(--muted);margin-top:4px;font-size:.8rem}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-title{font-size:1.4rem;font-weight:600}.page-title span{color:var(--muted);margin-left:8px;font-size:1rem;font-weight:400}.btn{font-family:var(--sans);cursor:pointer;border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:.875rem;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#5e8fbf}.btn-secondary{background:var(--border);color:var(--text)}.btn-secondary:hover{background:#3a4565}.btn-danger{color:var(--red);background:#e1575926;border:1px solid #e157594d}.btn-danger:hover{background:#e1575940}.btn-sm{padding:5px 10px;font-size:.8rem}.btn-icon{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;padding:6px;transition:all .15s}.btn-icon:hover{background:var(--border);color:var(--text)}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:500}.form-input,.form-select{background:var(--bg);border:1px solid var(--border);color:var(--text);font-family:var(--sans);border-radius:6px;width:100%;padding:8px 12px;font-size:.875rem;transition:border-color .15s}.form-input:focus,.form-select:focus{border-color:var(--accent);outline:none}input[type=date],input[type=month]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#1a1f2e;background:#eef2ff;border-color:#c7d2fe}input[type=date]:hover,input[type=month]:hover{border-color:var(--accent);background:#e0e7ff}input[type=date]:focus,input[type=month]:focus{border-color:var(--accent);background:#e0e7ff;outline:none}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-actions{justify-content:flex-end;gap:10px;margin-top:8px;display:flex}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.875rem}th{text-align:left;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);padding:10px 14px;font-size:.7rem;font-weight:600}td{vertical-align:middle;border-bottom:1px solid #2a304580;padding:10px 14px}tr:hover td{background:#4e79a70a}.progress-bar{background:var(--border);border-radius:3px;height:6px;overflow:hidden}.progress-fill{border-radius:3px;height:100%;transition:width .4s}.badge{letter-spacing:.3px;border-radius:100px;padding:3px 10px;font-size:.7rem;font-weight:600;display:inline-block}.badge-todo{color:var(--muted);background:#7a809933}.badge-doing{color:var(--accent);background:#4e79a733}.badge-done{color:var(--green);background:#59a14f33}.badge-blocked{color:var(--red);background:#e1575933}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--card);border:1px solid var(--border);border-radius:12px;width:520px;max-width:95vw;max-height:90vh;padding:28px;overflow-y:auto}.modal-title{margin-bottom:20px;font-size:1.1rem;font-weight:600}.toast{z-index:200;border-radius:8px;padding:12px 18px;font-size:.875rem;font-weight:500;animation:.2s slideIn;position:fixed;bottom:24px;right:24px}.toast-success{background:var(--green);color:#fff}.toast-error{background:var(--red);color:#fff}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--card);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:20px;width:380px;padding:40px;display:flex}.login-logo{text-align:center;font-family:var(--mono);color:var(--accent);font-size:1.8rem;font-weight:700}.login-logo span{color:var(--accent2)}.login-subtitle{text-align:center;color:var(--muted);font-size:.875rem}.gantt-wrap{overflow-x:auto}.pdc-pilot-card{margin-bottom:16px}.pdc-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.pdc-load-bar{background:var(--border);border-radius:4px;height:8px;margin-bottom:10px;overflow:hidden}.pdc-load-fill{border-radius:4px;height:100%}.presence-table{overflow-x:auto}.presence-table table{font-size:.72rem}.presence-cell{text-align:center;border:1px solid var(--border);border-radius:3px;min-width:28px;max-width:28px;height:28px;font-size:.65rem;font-weight:700}.weekend{background:#2a304580}.divider{background:var(--border);height:1px;margin:20px 0}.empty-state{text-align:center;color:var(--muted);padding:48px;font-size:.9rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.text-muted{color:var(--muted)}.text-sm{font-size:.8rem}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-accent{color:var(--accent)}.font-mono{font-family:var(--mono)}.w-full{width:100%}
