@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-primary:#f5f7fa;--bg-secondary:#fff;--bg-card:#fff;--bg-card-hover:#f0f4f8;--bg-input:#f8fafc;--bg-sidebar:#fff;--border-subtle:#e2e8f0;--border-default:#cbd5e1;--border-focus:#3b82f6;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-label:#334155;--accent-blue:#2563eb;--accent-blue-soft:#2563eb14;--accent-green:#059669;--accent-green-soft:#05966914;--accent-amber:#d97706;--accent-amber-soft:#d9770614;--accent-red:#dc2626;--accent-red-soft:#dc262614;--accent-purple:#7c3aed;--accent-purple-soft:#7c3aed14;--accent-teal:#0d9488;--accent-cyan:#0891b2;--accent-pink:#db2777;--gradient-hero:linear-gradient(135deg, #eff6ff 0%, #f5f7fa 100%);--gradient-card:linear-gradient(145deg, #fff 0%, #f8fafc 100%);--gradient-accent:linear-gradient(135deg, #2563eb 0%, #7c3aed 100%);--gradient-sidebar:linear-gradient(180deg, #1e293b 0%, #0f172a 100%);--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 10px 30px #0000001a;--shadow-glow-blue:0 0 0 3px #2563eb26;--shadow-glow-green:0 0 0 3px #05966926;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--transition-fast:.15s ease;--transition-default:.25s ease;--transition-slow:.4s ease;--sidebar-width:260px;--topbar-height:0px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:14px}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100vh;line-height:1.6;overflow:hidden}#root{height:100vh;display:flex}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-layout{width:100%;height:100vh;display:flex}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--gradient-sidebar);flex-direction:column;display:flex;overflow-y:auto}.sidebar-header{padding:var(--space-lg) var(--space-md);border-bottom:1px solid #ffffff14}.sidebar-client-name{color:#f1f5f9;letter-spacing:-.01em;align-items:center;gap:8px;font-size:1.15rem;font-weight:700;display:flex}.sidebar-flag{font-size:1.6rem;line-height:1}.sidebar-company{color:#cbd5e1;margin-top:3px;font-size:.82rem;font-weight:500}.sidebar-facility{color:#64748b;text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:4px;margin-top:6px;font-size:.68rem;display:flex}.sidebar-facility:before{content:"📍";font-size:.7rem}.sidebar-header h1{background:var(--gradient-accent);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;font-size:1rem;font-weight:700}.sidebar-header p{color:#64748b;margin-top:var(--space-xs);font-size:.75rem}.sidebar-section{padding:var(--space-md) 0}.sidebar-section-title{padding:0 var(--space-md) var(--space-sm);text-transform:uppercase;letter-spacing:.08em;color:#64748b;font-size:.65rem;font-weight:600}.sidebar-item{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);color:#94a3b8;cursor:pointer;transition:all var(--transition-fast);border-left:3px solid #0000;font-size:.85rem;text-decoration:none;display:flex}.sidebar-item:hover{color:#e2e8f0;background:#ffffff0d}.sidebar-item.active{color:#60a5fa;background:#3b82f626;border-left-color:#3b82f6;font-weight:500}.sidebar-item .icon{text-align:center;width:20px;font-size:1rem}.main-content{padding:var(--space-xl);background:var(--bg-primary);flex:1;overflow-y:auto}.page-header{margin-bottom:var(--space-xl);z-index:10;-webkit-backdrop-filter:blur(12px);padding:var(--space-md) 0;margin-top:calc(-1 * var(--space-xl));margin-left:calc(-1 * var(--space-xl));margin-right:calc(-1 * var(--space-xl));padding-left:var(--space-xl);padding-right:var(--space-xl);border-bottom:1px solid var(--border-subtle);background:#f5f7fad9;position:sticky;top:0}.page-header h2{letter-spacing:-.02em;color:var(--text-primary);font-size:1.5rem;font-weight:700}.page-header p{color:var(--text-secondary);margin-top:var(--space-xs);font-size:.9rem}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg);box-shadow:var(--shadow-sm);transition:border-color var(--transition-default), box-shadow var(--transition-default)}.card:hover{border-color:var(--border-default);box-shadow:var(--shadow-md)}.card-title{color:var(--text-primary);margin-bottom:var(--space-md);align-items:center;gap:var(--space-sm);font-size:1rem;font-weight:600;display:flex}.card-title .badge{border-radius:99px;padding:2px 8px;font-size:.65rem;font-weight:500}.badge-blue{background:var(--accent-blue-soft);color:var(--accent-blue)}.badge-green{background:var(--accent-green-soft);color:var(--accent-green)}.badge-amber{background:var(--accent-amber-soft);color:var(--accent-amber)}.badge-red{background:var(--accent-red-soft);color:var(--accent-red)}.badge-purple{background:var(--accent-purple-soft);color:var(--accent-purple)}.input-group{gap:var(--space-xs);flex-direction:column;display:flex}.input-group label{color:var(--text-label);font-size:.8rem;font-weight:500}.input-group .hint{color:var(--text-muted);font-size:.72rem}.input-row{gap:var(--space-md);margin-bottom:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid}input[type=number],input[type=text],input[type=date],select{background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);color:var(--text-primary);font-family:var(--font-mono);width:100%;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);font-size:.85rem}input:focus,select:focus{border-color:var(--accent-blue);box-shadow:var(--shadow-glow-blue);outline:none}input[type=number]{font-variant-numeric:tabular-nums}.data-table-wrap{border-radius:var(--radius-md);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm);overflow-x:auto}table.data-table{border-collapse:collapse;width:100%;font-size:.82rem}table.data-table thead th{background:var(--bg-primary);padding:var(--space-sm) var(--space-md);text-align:left;color:var(--text-label);border-bottom:2px solid var(--border-default);white-space:nowrap;z-index:1;font-weight:600;position:sticky;top:0}table.data-table tbody tr{border-bottom:1px solid var(--border-subtle);transition:background var(--transition-fast)}table.data-table tbody tr:hover{background:var(--bg-card-hover)}table.data-table tbody td{padding:var(--space-sm) var(--space-md);color:var(--text-secondary);font-family:var(--font-mono);font-size:.8rem}table.data-table tbody td.highlight{color:var(--accent-green);font-weight:600}table.data-table input{width:100%;min-width:60px;font-family:var(--font-mono);color:var(--text-primary);background:0 0;border:1px solid #0000;border-radius:4px;padding:4px 8px;font-size:.8rem}table.data-table input:focus{border-color:var(--accent-blue);background:var(--bg-input)}.computed-outputs{gap:var(--space-md);margin-top:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.computed-box{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-md);text-align:center;box-shadow:var(--shadow-sm)}.computed-box .value{font-size:1.5rem;font-weight:700;font-family:var(--font-mono);color:var(--accent-blue);margin-bottom:var(--space-xs)}.computed-box .value.warning{color:var(--accent-amber)}.computed-box .value.danger{color:var(--accent-red)}.computed-box .value.success{color:var(--accent-green)}.computed-box .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem}.btn{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);border:none;font-size:.82rem;font-weight:500;display:inline-flex}.btn-primary{background:var(--accent-blue);color:#fff}.btn-primary:hover{box-shadow:var(--shadow-glow-blue);background:#1d4ed8}.btn-secondary{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border-default)}.btn-secondary:hover{background:var(--bg-card-hover);color:var(--text-primary)}.btn-danger{background:var(--accent-red-soft);color:var(--accent-red)}.btn-danger:hover{background:var(--accent-red);color:#fff}.btn-sm{padding:4px 10px;font-size:.75rem}.alert{padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md);align-items:flex-start;gap:var(--space-sm);font-size:.82rem;display:flex}.alert-warning{background:var(--accent-amber-soft);color:#92400e;border:1px solid #d9770640}.alert-danger{background:var(--accent-red-soft);color:#991b1b;border:1px solid #dc262640}.alert-info{background:var(--accent-blue-soft);color:#1e40af;border:1px solid #2563eb40}.alert-success{background:var(--accent-green-soft);color:#065f46;border:1px solid #05966940}.chart-container{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg);box-shadow:var(--shadow-sm)}.chart-title{margin-bottom:var(--space-md);font-size:.9rem;font-weight:600}.gantt-row{align-items:center;margin-bottom:4px;display:flex}.gantt-label{width:70px;color:var(--text-secondary);flex-shrink:0;font-size:.72rem;font-weight:500}.gantt-track{background:var(--bg-primary);border-radius:4px;flex:1;height:24px;position:relative;overflow:hidden}.gantt-bar{opacity:.85;height:100%;transition:opacity var(--transition-fast);border-radius:3px;position:absolute}.gantt-bar:hover{opacity:1}.gantt-bar.germ{background:var(--accent-purple)}.gantt-bar.prop{background:var(--accent-cyan)}.gantt-bar.adapt{background:var(--accent-amber)}.gantt-bar.harvest{background:var(--accent-green)}.gantt-bar.clean{background:var(--accent-red)}.capacity-line{stroke:var(--accent-red);stroke-width:2px;stroke-dasharray:8 4}.dashboard-top{gap:var(--space-lg);margin-bottom:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}@media (width<=1200px){.dashboard-top{grid-template-columns:1fr}}.floor-plan-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.floor-plan-card h3{margin-bottom:var(--space-md);align-items:center;gap:var(--space-sm);font-size:.9rem;font-weight:600;display:flex}.floor-plan-svg{border-radius:var(--radius-md);border:1px solid var(--border-subtle);width:100%}.floor-plan-legend{gap:var(--space-md);margin-top:var(--space-md);flex-wrap:wrap;display:flex}.floor-plan-legend-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:.72rem;display:flex}.legend-dot{border-radius:3px;width:10px;height:10px}.kpi-grid{gap:var(--space-md);grid-template-columns:repeat(2,1fr);display:grid}@media (width>=1400px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}.kpi-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-default)}.kpi-card:hover{box-shadow:var(--shadow-md)}.kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;font-size:.72rem}.kpi-value{font-size:1.4rem;font-weight:700;font-family:var(--font-mono)}.kpi-sub{color:var(--text-muted);margin-top:2px;font-size:.72rem}.kpi-value.blue{color:var(--accent-blue)}.kpi-value.green{color:var(--accent-green)}.kpi-value.amber{color:var(--accent-amber)}.kpi-value.red{color:var(--accent-red)}.kpi-value.purple{color:var(--accent-purple)}.kpi-value.teal{color:var(--accent-teal)}.month-picker{align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);display:flex}.month-picker select{width:auto;min-width:180px}.month-picker-label{color:var(--text-label);font-size:.82rem;font-weight:500}.task-summary-grid{gap:var(--space-sm);grid-template-columns:repeat(auto-fit,minmax(120px,1fr));display:grid}.task-pill{background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);text-align:center}.task-pill-count{font-size:1.1rem;font-weight:700;font-family:var(--font-mono);color:var(--accent-blue)}.task-pill-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.68rem}.system-status-row{gap:var(--space-sm);margin-top:var(--space-md);grid-template-columns:repeat(12,1fr);display:grid}.system-chip{border-radius:var(--radius-sm);padding:var(--space-sm);text-align:center;color:#fff;border:2px solid #0000;font-size:.68rem;font-weight:600;position:relative}.system-chip .sys-id{font-size:.72rem;font-weight:700}.system-chip .sys-phase{opacity:.9;margin-top:2px;font-size:.6rem;font-weight:400}.chip-germ{background:#7c3aed}.chip-prop{background:#0891b2}.chip-adapt{background:#d97706}.chip-harvest{background:#059669}.chip-clean{background:#dc2626}.chip-idle{background:#94a3b8}@media (width<=900px){.sidebar{width:60px;min-width:60px}.sidebar-header h1,.sidebar-header p,.sidebar-client-name,.sidebar-company,.sidebar-facility,.sidebar-section-title,.sidebar-item span:not(.icon){display:none}.sidebar-item{padding:var(--space-sm);justify-content:center}.main-content{padding:var(--space-md)}.dashboard-top{grid-template-columns:1fr}}.login-page{background:linear-gradient(135deg,#0f172a 0%,#1e293b 40%,#0f172a 100%);justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(circle at 30%,#2563eb14 0%,#0000 50%),radial-gradient(circle at 70%,#7c3aed0f 0%,#0000 50%);width:200%;height:200%;animation:15s ease-in-out infinite alternate loginGlow;position:absolute;top:-50%;left:-50%}@keyframes loginGlow{0%{transform:translate(0)}to{transform:translate(-5%,3%)}}.login-card{background:#fffffff7;border-radius:20px;width:100%;max-width:420px;padding:48px 40px;position:relative;box-shadow:0 25px 60px #0000004d,0 0 0 1px #ffffff1a}.login-header{text-align:center;margin-bottom:32px}.login-flag{margin-bottom:12px;font-size:3rem}.login-header h1{color:#0f172a;letter-spacing:-.02em;margin-bottom:4px;font-size:1.3rem;font-weight:700}.login-header p{color:#64748b;font-size:.85rem}.login-facility{color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;margin-top:8px;font-size:.72rem}.login-form{flex-direction:column;gap:16px;display:flex}.login-form input[type=text],.login-form input[type=password]{color:#0f172a;font-size:.9rem;font-family:var(--font-sans);background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;padding:12px 16px;transition:border-color .2s,box-shadow .2s}.login-form input:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.login-form label{color:#334155;font-size:.8rem;font-weight:600}.login-error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;align-items:center;gap:6px;padding:10px 14px;font-size:.82rem;display:flex}.btn-login{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb 0%,#7c3aed 100%);border:none;border-radius:10px;justify-content:center;align-items:center;min-height:48px;margin-top:8px;padding:14px;font-size:.95rem;font-weight:600;transition:transform .15s,box-shadow .15s;display:flex}.btn-login:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #2563eb59}.btn-login:disabled{opacity:.5;cursor:not-allowed}.login-spinner{border:2.5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{text-align:center;color:#94a3b8;justify-content:center;align-items:center;gap:6px;margin-top:24px;font-size:.75rem;display:flex}.sidebar-logout{padding:var(--space-md);border-top:1px solid #ffffff0f;margin-top:auto}.btn-logout{color:#94a3b8;border-radius:var(--radius-sm);width:100%;padding:var(--space-sm) var(--space-md);font-size:.82rem;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);background:#ffffff0d;border:1px solid #ffffff14;align-items:center;gap:6px;display:flex}.btn-logout:hover{color:#fca5a5;background:#dc26261a;border-color:#dc26264d}
