:root{--bg:#f3f7fb;--surface:#fff;--surface-soft:#f8fbff;--border:#dce7f2;--text:#12304d;--muted:#68819d;--primary:#0c4f8f;--primary-2:#1267b8;--primary-soft:#e9f3fd;--sidebar:#0a3767;--sidebar-2:#0d4a89;--danger:#d94b4b;--success:#17956c;--radius:16px;--shadow:0 10px 30px #0d3a6714}*{box-sizing:border-box}html,body{background:var(--bg);color:var(--text);margin:0;padding:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}body{min-height:100vh}.page-shell{grid-template-columns:270px 1fr;min-height:100vh;display:grid}.sidebar{background:linear-gradient(180deg, var(--sidebar), var(--sidebar-2));color:#fff;padding:22px 18px}.sidebar-brand{align-items:center;gap:14px;margin-bottom:28px;display:flex}.sidebar-brand-text h1{margin:0;font-size:18px;line-height:1.1}.sidebar-brand-text p{color:#ffffffbf;margin:4px 0 0;font-size:12px}.nav-group{flex-direction:column;gap:8px;display:flex}.nav-item{color:#ffffffeb;border-radius:12px;align-items:center;gap:10px;padding:12px 14px;transition:background .2s;display:flex}.nav-item:hover{background:#ffffff1a}.nav-item.active{background:#ffffff29;font-weight:700}.main-area{flex-direction:column;min-width:0;display:flex}.topbar{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe0;justify-content:space-between;align-items:center;height:74px;padding:0 24px;display:flex}.topbar-title h2{margin:0;font-size:22px}.topbar-title p{color:var(--muted);margin:4px 0 0;font-size:13px}.topbar-right{align-items:center;gap:12px;display:flex}.user-chip{background:var(--surface);border:1px solid var(--border);color:var(--muted);border-radius:999px;padding:10px 14px;font-size:13px}.logout-btn{background:var(--primary);color:#fff;border:none;border-radius:12px;padding:10px 14px;font-weight:600}.content{padding:24px}.section-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}.section-title{margin:0 0 18px;font-size:20px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.card-row{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;display:grid}.kpi-card{border:1px solid var(--border);box-shadow:var(--shadow);background:linear-gradient(#fff,#f8fbff);border-radius:18px;padding:18px}.kpi-card p{color:var(--muted);margin:0;font-size:13px}.kpi-card h3{margin:10px 0 0;font-size:28px}.field{flex-direction:column;gap:8px;display:flex}.label{color:var(--muted);font-size:13px;font-weight:600}.input,.select,.textarea{border:1px solid var(--border);background:#fff;border-radius:12px;outline:none;width:100%;padding:12px 14px}.input:focus,.select:focus,.textarea:focus{border-color:#7baee4;box-shadow:0 0 0 4px #1267b814}.textarea{resize:vertical;min-height:110px}.table-wrap{border:1px solid var(--border);border-radius:14px;overflow-x:auto}.table{border-collapse:collapse;background:#fff;width:100%}.table th,.table td{border-bottom:1px solid var(--border);text-align:left;padding:12px}.table th{background:var(--surface-soft);color:var(--muted);font-size:13px}.summary-box{background:var(--primary-soft);border:1px solid #cfe0f2;border-radius:14px;padding:16px}.actions{gap:12px;margin-top:18px;display:flex}.btn{border:none;border-radius:12px;padding:12px 18px;font-weight:600}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--primary-2));color:#fff}.btn-secondary{color:var(--primary);background:#fff;border:1px solid #cfe0f2}.login-wrap{background:radial-gradient(circle at 100% 0,#1267b81f,#0000 22%),linear-gradient(#eff6fc,#e7f1fb);place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{border:1px solid var(--border);background:#fffffff5;border-radius:24px;width:100%;max-width:460px;padding:28px;box-shadow:0 18px 56px #0a376724}.login-head{align-items:center;gap:14px;margin-bottom:22px;display:flex}.login-head h1{margin:0;font-size:22px}.login-head p{color:var(--muted);margin:4px 0 0;font-size:13px}.login-actions{gap:12px;margin-top:18px;display:flex}.logo-image{object-fit:contain;background:#fff;border-radius:14px;flex-shrink:0;width:54px;height:54px;padding:6px;box-shadow:0 8px 24px #00000014}.empty-box{border:1px dashed var(--border);color:var(--muted);background:#fff;border-radius:16px;padding:18px}@media (max-width:1080px){.page-shell{grid-template-columns:88px 1fr}.sidebar-brand-text,.nav-item span{display:none}.card-row,.grid-3{grid-template-columns:1fr 1fr}}@media (max-width:720px){.page-shell{grid-template-columns:1fr}.sidebar{display:none}.topbar{padding:0 16px}.content{padding:16px}.card-row,.grid-2,.grid-3{grid-template-columns:1fr}}.gantt-container{background:#fff;border:1px solid #d8e4f0;border-radius:12px;width:100%;padding:12px;overflow-x:auto}.gantt .grid-background,.gantt .grid-row{fill:#fff}.gantt .grid-row:nth-child(2n){fill:#f8fbff}.gantt .row-line,.gantt .tick{stroke:#e3edf7}.gantt .today-highlight{fill:#0b5cab14}.gantt .bar{fill:#4a90e2}.gantt .bar-progress{fill:#2f6fb2}.gantt .bar-label{fill:#fff;font-size:12px;font-weight:600}.gantt .lower-text,.gantt .upper-text{fill:#40566e;font-size:11px}.gantt .arrow{stroke:#7b93ad}.gantt .details-container{background:#fff;border:1px solid #d8e4f0;border-radius:10px;box-shadow:0 10px 30px #0d3a6714}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}
