@import"https://fonts.googleapis.com/css2?family=Crimson+Pro:wght@400;500;600;700&family=DM+Sans:wght@400;500;600;700&display=swap";:root{--primary: #3d5a99;--primary-hover: #4a6bb3;--primary-light: #e8edf6;--primary-dark: #2d4370;--accent: #c4922a;--accent-light: #faf3e0;--success: #2d6a4f;--success-light: #e8f5ee;--warning: #b8860b;--warning-light: #fef9e7;--danger: #9b2226;--danger-light: #fce8e8;--info: #1a5276;--info-light: #e8f0f8;--bg: #f3f5f8;--surface: #ffffff;--surface-alt: #edf0f5;--border: #cdd3de;--border-light: #dfe3ec;--text: #1a2333;--text-muted: #5c6a7f;--text-light: #8995a8;--sidebar-bg-from: #253352;--sidebar-bg-to: #2f4068;--sidebar-text: #c8d0e0;--sidebar-heading: #e8ecf4;--sidebar-muted: #7b8aa8;--sidebar-active: rgba(61, 90, 153, .5);--sidebar-hover: rgba(255, 255, 255, .07);--sidebar-border: rgba(255, 255, 255, .08);--font-display: "Crimson Pro", Georgia, serif;--font-body: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--shadow-sm: 0 1px 3px rgba(26, 35, 51, .07);--shadow-md: 0 4px 12px rgba(26, 35, 51, .09);--shadow-lg: 0 8px 24px rgba(26, 35, 51, .13);--radius: 8px;--radius-lg: 12px}@media(prefers-color-scheme:dark){:root{--bg: #121318;--surface: #1a1b22;--surface-alt: #22232c;--border: #2e303a;--border-light: #363842;--text: #e2e4e9;--text-muted: #9ca3af;--text-light: #6b7280;--primary-light: rgba(61, 90, 153, .2);--accent-light: rgba(196, 146, 42, .15);--success-light: rgba(45, 106, 79, .2);--warning-light: rgba(184, 134, 11, .15);--danger-light: rgba(155, 34, 38, .2);--info-light: rgba(26, 82, 118, .2);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .25);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .4)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);background:var(--bg);color:var(--text)}.app-layout{display:flex;min-height:100vh}.sidebar{width:260px;background:linear-gradient(180deg,var(--sidebar-bg-from) 0%,var(--sidebar-bg-to) 100%);color:var(--sidebar-text);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-header{padding:24px 20px;border-bottom:1px solid var(--sidebar-border)}.sidebar-header h1{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--sidebar-heading);letter-spacing:.3px;line-height:1.3}.sidebar-header p{font-size:11px;color:var(--sidebar-muted);margin-top:4px;letter-spacing:.5px;text-transform:uppercase}.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;color:#9aa8c2;transition:all .15s;margin-bottom:2px}.nav-item:hover{background:var(--sidebar-hover);color:#d0d8e8}.nav-item.active{background:var(--sidebar-active);color:var(--sidebar-heading)}.nav-badge{margin-left:auto;background:var(--primary);color:#fff;font-size:11px;padding:1px 7px;border-radius:10px;font-weight:600}.nav-divider{height:1px;background:#ffffff0f;margin:10px 14px}.sidebar-footer{padding:16px 20px;border-top:1px solid var(--sidebar-border);font-size:12px;color:#5c6e8e}.main-content{margin-left:260px;flex:1;min-height:100vh}.app-header{position:sticky;top:0;z-index:90;background:var(--surface);border-bottom:1px solid var(--border-light);padding:0 32px;display:flex;align-items:center;justify-content:flex-end;height:48px}.app-header .user-info{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text-muted)}.app-header .user-name{font-weight:600;color:var(--text)}.app-header .user-role{font-size:11px;color:var(--text-light)}.app-header .sign-out-btn{padding:5px 12px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text-muted);font-family:var(--font-body);font-size:12px;cursor:pointer;transition:all .15s}.app-header .sign-out-btn:hover{background:var(--danger-light);color:var(--danger);border-color:var(--danger)}.page-header{background:var(--surface);border-bottom:1px solid var(--border-light);padding:20px 32px;display:flex;align-items:center;justify-content:space-between}.page-header h2{font-family:var(--font-display);font-size:26px;font-weight:600;color:var(--text)}.page-body{padding:28px 32px}.card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.card-header{padding:16px 20px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}.card-header h3{font-family:var(--font-display);font-size:18px;font-weight:600}.card-body{padding:20px}.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:var(--radius);font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;border:none;white-space:nowrap}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:var(--surface-alt);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border-light)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#b02528}.btn-sm{padding:6px 12px;font-size:12px}.btn-ghost{background:transparent;color:var(--text-muted);padding:6px 10px}.btn-ghost:hover{background:var(--surface-alt);color:var(--text)}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-input,.form-select,.form-textarea{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-body);font-size:14px;color:var(--text);background:var(--surface);transition:border-color .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-textarea{resize:vertical;min-height:80px}.form-row{display:grid;gap:16px}.form-row-2{grid-template-columns:1fr 1fr}.form-row-3{grid-template-columns:1fr 1fr 1fr}.checkbox-group{display:flex;flex-wrap:wrap;gap:10px}.checkbox-label{display:flex;align-items:center;gap:6px;font-size:13px;cursor:pointer;padding:6px 12px;border:1px solid var(--border-light);border-radius:var(--radius);transition:all .15s}.checkbox-label:hover{border-color:var(--primary)}.checkbox-label.checked{background:var(--primary-light);border-color:var(--primary);color:var(--primary-dark)}.checkbox-label input{display:none}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.3px}.badge-planning{background:var(--info-light);color:var(--info)}.badge-awaiting{background:var(--warning-light);color:var(--warning)}.badge-approved{background:var(--accent-light);color:var(--accent)}.badge-progress{background:#e8f0ff;color:#2563eb}.badge-hold{background:#fef3cd;color:#856404}.badge-completed{background:var(--success-light);color:var(--success)}.badge-cancelled{background:var(--surface-alt);color:var(--text-light)}.data-table{width:100%;border-collapse:collapse}.data-table th{padding:10px 14px;text-align:left;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border-light);background:var(--surface-alt);-webkit-user-select:none;user-select:none}.data-table th[style*=cursor]:hover{color:var(--primary);background:var(--primary-light)}.data-table td{padding:12px 14px;border-bottom:1px solid var(--border-light);font-size:13px}.data-table tr:hover td{background:#3d5a9908}.data-table .clickable{cursor:pointer}.data-table .clickable:hover td{background:var(--primary-light)}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm)}.stat-card .stat-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:8px}.stat-card .stat-value{font-family:var(--font-display);font-size:28px;font-weight:700;color:var(--text)}.stat-card .stat-sub{font-size:12px;color:var(--text-light);margin-top:4px}.alert-bar{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius);margin-bottom:12px;font-size:13px;font-weight:500}.alert-warning{background:var(--warning-light);color:#7a6608;border-left:3px solid var(--warning)}.alert-danger{background:var(--danger-light);color:var(--danger);border-left:3px solid var(--danger)}.alert-info{background:var(--info-light);color:var(--info);border-left:3px solid var(--info)}.alert-success{background:var(--success-light);color:var(--success);border-left:3px solid var(--success)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a233380;z-index:200;display:flex;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:740px;animation:modalIn .2s ease}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}.modal-header h3{font-family:var(--font-display);font-size:20px;font-weight:600}.modal-body{padding:24px;max-height:65vh;overflow-y:auto}.modal-footer{padding:16px 24px;border-top:1px solid var(--border-light);display:flex;justify-content:flex-end;gap:10px}@keyframes modalIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.tabs{display:flex;gap:0;border-bottom:2px solid var(--border-light);margin-bottom:20px;flex-wrap:wrap}.tab{padding:10px 20px;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.tab:hover{color:var(--text)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.timeline{position:relative;padding-left:24px}.timeline:before{content:"";position:absolute;left:8px;top:4px;bottom:4px;width:2px;background:var(--border-light)}.timeline-item{position:relative;margin-bottom:16px;padding-left:16px}.timeline-dot{position:absolute;left:-20px;top:4px;width:12px;height:12px;border-radius:50%;border:2px solid var(--border)}.timeline-dot.done{background:var(--success);border-color:var(--success)}.timeline-dot.current{background:var(--primary);border-color:var(--primary)}.timeline-dot.upcoming{background:var(--surface);border-color:var(--border)}.timeline-dot.overdue{background:var(--danger);border-color:var(--danger)}.timeline-label{font-size:13px;font-weight:600;color:var(--text)}.timeline-date{font-size:12px;color:var(--text-muted);margin-top:2px}.progress-bar{height:8px;background:var(--surface-alt);border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;transition:width .3s}.empty-state{text-align:center;padding:48px 20px;color:var(--text-muted)}.empty-state h4{font-family:var(--font-display);font-size:18px;margin-bottom:8px;color:var(--text)}.tag{display:inline-flex;padding:2px 8px;background:var(--surface-alt);border-radius:4px;font-size:11px;font-weight:600;color:var(--text-muted);margin-right:4px;margin-bottom:4px}.divider{border:none;border-top:1px solid var(--border-light);margin:20px 0}.doc-list{display:flex;flex-direction:column;gap:6px}.doc-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface-alt);border-radius:var(--radius);font-size:13px}.doc-item .doc-name{flex:1;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doc-item .doc-meta{font-size:11px;color:var(--text-muted);white-space:nowrap}.file-ext-badge{display:inline-flex;padding:2px 6px;border-radius:3px;font-size:9px;font-weight:700;letter-spacing:.5px;color:#fff;flex-shrink:0}.file-ext-pdf{background:#c0392b}.file-ext-doc,.file-ext-docx{background:#2b6cb0}.file-ext-xls,.file-ext-xlsx,.file-ext-csv{background:#217a3e}.file-ext-jpg,.file-ext-jpeg,.file-ext-png,.file-ext-gif,.file-ext-heic,.file-ext-webp,.file-ext-bmp,.file-ext-tif,.file-ext-tiff{background:#9b59b6}.file-ext-ppt,.file-ext-pptx{background:#d4581c}.file-ext-txt,.file-ext-rtf{background:#7f8c8d}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:20px;text-align:center;cursor:pointer;transition:all .15s;background:var(--surface)}.upload-zone:hover,.upload-zone.dragging{border-color:var(--primary);background:var(--primary-light)}.winner-badge{background:var(--accent);color:#fff;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.config-list-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface-alt);border-radius:var(--radius);margin-bottom:6px;font-size:13px}.config-list-item .item-label{flex:1}.gantt-bar{position:relative;height:28px;border-radius:4px;display:flex;align-items:center;padding:0 8px;font-size:11px;font-weight:600;color:#fff;overflow:hidden;white-space:nowrap}.score-cell{text-align:center;font-weight:700;font-size:14px}.score-best{background:var(--success-light);color:var(--success)}.activity-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-light);font-size:13px}.activity-item:last-child{border-bottom:none}.activity-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:12px}@media(max-width:900px){.sidebar{width:60px}.sidebar-header h1,.sidebar-header p,.nav-item span,.sidebar-footer,.nav-divider{display:none}.nav-item{justify-content:center;padding:12px}.main-content{margin-left:60px}.stat-grid{grid-template-columns:repeat(2,1fr)}.form-row-2,.form-row-3{grid-template-columns:1fr}}
