@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--font-sans:"Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", monospace;--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--border-color:#e2e8f0;--primary-color:#6366f1;--primary-hover:#4f46e5;--primary-light:#6366f11a;--shift-1-bg:#3b82f61a;--shift-1-text:#1d4ed8;--shift-1-border:#3b82f633;--shift-2-bg:#f973161a;--shift-2-text:#c2410c;--shift-2-border:#f9731633;--shift-3-bg:#8b5cf61a;--shift-3-text:#6d28d9;--shift-3-border:#8b5cf633;--general-bg:#10b9811a;--general-text:#047857;--general-border:#10b98133;--weekoff-bg:#6b728014;--weekoff-text:#4b5563;--weekoff-border:#6b728026;--leave-bg:#ef44441a;--leave-text:#b91c1c;--leave-border:#ef444433;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000000d, 0 4px 6px -4px #0000000d;--card-radius:16px;--badge-radius:8px;transition:background-color .3s,border-color .3s}@media (prefers-color-scheme:dark){:root{--bg-primary:#090a0f;--bg-secondary:#121420;--bg-tertiary:#191c2c;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--border-color:#222536;--primary-color:#818cf8;--primary-hover:#6366f1;--primary-light:#818cf826;--shift-1-bg:#3b82f626;--shift-1-text:#60a5fa;--shift-1-border:#3b82f64d;--shift-2-bg:#f9731626;--shift-2-text:#fb923c;--shift-2-border:#f973164d;--shift-3-bg:#8b5cf626;--shift-3-text:#a78bfa;--shift-3-border:#8b5cf64d;--general-bg:#10b98126;--general-text:#34d399;--general-border:#10b9814d;--weekoff-bg:#6b728026;--weekoff-text:#9ca3af;--weekoff-border:#6b72804d;--leave-bg:#ef44442e;--leave-text:#f87171;--leave-border:#ef444459;--shadow-sm:0 1px 2px 0 #00000080;--shadow-md:0 4px 6px -1px #0006, 0 2px 4px -2px #0006;--shadow-lg:0 10px 15px -3px #0009, 0 4px 6px -4px #0009}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}#root{flex-direction:column;min-height:100vh;display:flex}.app-container{flex-direction:column;gap:2rem;width:100%;max-width:1400px;margin:0 auto;padding:2rem;display:flex}.app-header{border-bottom:1px solid var(--border-color);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.5rem;padding-bottom:1.5rem;display:flex}.header-title-container h1{letter-spacing:-.04em;background:linear-gradient(135deg, var(--text-primary), var(--primary-color));-webkit-text-fill-color:transparent;-webkit-background-clip:text;align-items:center;gap:.75rem;font-size:2.2rem;font-weight:700;display:flex}.header-badge{color:var(--primary-color);background-color:var(--primary-light);letter-spacing:.05em;text-transform:uppercase;border-radius:9999px;padding:.25rem .75rem;font-size:.85rem;font-weight:600}.header-subtitle{color:var(--text-secondary);margin-top:.25rem;font-size:.95rem}.header-actions{align-items:center;gap:1rem;display:flex}.btn{cursor:pointer;font-size:.9rem;font-weight:600;font-family:var(--font-sans);border:1px solid #0000;border-radius:10px;align-items:center;gap:.5rem;padding:.625rem 1.25rem;transition:all .2s;display:inline-flex}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #6366f133}.btn-secondary{background-color:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-color)}.btn-secondary:hover{background-color:var(--bg-tertiary);border-color:var(--text-muted)}.btn-icon-only{border-radius:10px;padding:.625rem}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;display:grid}.metric-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);flex-direction:column;gap:.5rem;padding:1.5rem;transition:transform .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.metric-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.metric-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.85rem;font-weight:600}.metric-value{color:var(--text-primary);font-size:2rem;font-weight:700}.metric-footer{color:var(--text-secondary);font-size:.8rem}.metric-icon-bg{opacity:.04;pointer-events:none;font-size:5rem;font-weight:800;position:absolute;bottom:-15px;right:-10px}.control-bar{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.5rem;padding:1.25rem;display:flex}.filter-group{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.search-input-wrapper{min-width:250px;position:relative}.search-input{border:1px solid var(--border-color);background-color:var(--bg-primary);width:100%;color:var(--text-primary);font-family:var(--font-sans);border-radius:8px;outline:none;padding:.6rem 1rem .6rem 2.5rem;font-size:.9rem;transition:border-color .2s}.search-input:focus{border-color:var(--primary-color)}.search-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:.85rem;transform:translateY(-50%)}.select-dropdown{border:1px solid var(--border-color);background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748b'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;background-size:1rem;border-radius:8px;outline:none;padding:.6rem 2rem .6rem 1rem;font-size:.9rem;transition:border-color .2s}.select-dropdown:focus{border-color:var(--primary-color)}.view-tabs{background-color:var(--bg-tertiary);border-radius:10px;padding:.25rem;display:flex}.tab-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.9rem;font-weight:600;transition:all .2s}.tab-btn.active{background-color:var(--bg-secondary);color:var(--text-primary);box-shadow:var(--shadow-sm)}.dashboard-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);flex-direction:column;gap:1.5rem;padding:1.5rem;display:flex}.card-header{justify-content:space-between;align-items:center;display:flex}.card-title{color:var(--text-primary);font-size:1.25rem;font-weight:700}.table-container{border:1px solid var(--border-color);background-color:var(--bg-secondary);border-radius:12px;max-height:70vh;overflow:auto}.schedule-table{border-collapse:collapse;text-align:left;width:100%;font-size:.9rem}.schedule-table th,.schedule-table td{border-bottom:1px solid var(--border-color);padding:.85rem 1rem}.schedule-table th{background-color:var(--bg-tertiary);color:var(--text-secondary);z-index:10;font-weight:600;position:sticky;top:0}.schedule-table tr:last-child td{border-bottom:none}.schedule-table tr:hover{background-color:var(--bg-primary)}.day-weekend{background-color:var(--bg-primary);font-weight:500}.shift-badge{border-radius:var(--badge-radius);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;padding:.35rem .75rem;font-size:.8rem;font-weight:600;transition:transform .1s;display:inline-flex}.shift-badge:hover{transform:scale(1.03)}.shift-badge-shift-1{background-color:var(--shift-1-bg);color:var(--shift-1-text);border-color:var(--shift-1-border)}.shift-badge-shift-2{background-color:var(--shift-2-bg);color:var(--shift-2-text);border-color:var(--shift-2-border)}.shift-badge-shift-3{background-color:var(--shift-3-bg);color:var(--shift-3-text);border-color:var(--shift-3-border)}.shift-badge-general{background-color:var(--general-bg);color:var(--general-text);border-color:var(--general-border)}.shift-badge-week-off{background-color:var(--weekoff-bg);color:var(--weekoff-text);border-color:var(--weekoff-border)}.shift-badge-leave{background-color:var(--leave-bg);color:var(--leave-text);border-color:var(--leave-border)}.timeline-container{flex-direction:column;gap:1.5rem;display:flex}.timeline-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;display:grid}.timeline-card{background-color:var(--bg-primary);border:1px solid var(--border-color);text-align:center;border-radius:12px;flex-direction:column;align-items:center;gap:.75rem;padding:1.25rem;transition:all .2s;display:flex}.timeline-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.timeline-card.weekend{opacity:.85;background-color:#6b728005}.timeline-date{color:var(--text-muted);font-size:.8rem;font-weight:500}.timeline-day{color:var(--text-primary);font-size:1rem;font-weight:700}.timeline-hours{color:var(--text-secondary);margin-top:.25rem;font-size:.75rem;font-weight:500}.stats-container{flex-direction:column;gap:2rem;display:flex}.stats-card-grid{grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:1.5rem;display:grid}.stats-person-card{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.stats-person-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding-bottom:.5rem;font-weight:600;display:flex}.stats-person-name{color:var(--text-primary);font-size:1.05rem}.stats-bars-container{flex-direction:column;gap:.75rem;display:flex}.stats-bar-item{flex-direction:column;gap:.25rem;display:flex}.stats-bar-label{color:var(--text-secondary);justify-content:space-between;font-size:.8rem;display:flex}.stats-progress-track{background-color:var(--bg-tertiary);border-radius:9999px;width:100%;height:8px;overflow:hidden}.stats-progress-fill{border-radius:9999px;height:100%;transition:width .3s}.fill-shift-1{background-color:var(--shift-1-text)}.fill-shift-2{background-color:var(--shift-2-text)}.fill-shift-3{background-color:var(--shift-3-text)}.fill-general{background-color:var(--general-text)}.fill-week-off{background-color:var(--weekoff-text)}.fill-leave{background-color:var(--leave-text)}.json-panel{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;gap:1rem;padding:1.25rem;display:flex}.json-pre{color:#34d399;font-family:var(--font-mono);background-color:#0b0c10;border:1px solid #34d3991a;border-radius:8px;max-height:400px;padding:1rem;font-size:.8rem;overflow-x:auto}.loading-overlay{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:5rem 0;display:flex}.spinner{border:4px solid var(--primary-light);border-top-color:var(--primary-color);border-radius:50%;width:48px;height:48px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.legend-container{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);flex-wrap:wrap;gap:1.5rem;padding:1.25rem;display:flex}.legend-title{color:var(--text-primary);width:100%;font-size:.9rem;font-weight:700}.legend-item{color:var(--text-secondary);align-items:center;gap:.75rem;font-size:.85rem;display:flex}.legend-color-box{border-radius:4px;width:16px;height:16px}@media (width<=768px){.app-header{flex-direction:column;align-items:flex-start}.control-bar{flex-direction:column;align-items:stretch}.view-tabs{justify-content:center}}.row-today{position:relative;background-color:var(--primary-light)!important;box-shadow:inset 4px 0 0 var(--primary-color)!important}.row-today td{font-weight:500}.today-badge{color:#fff;background-color:var(--primary-color);text-transform:uppercase;letter-spacing:.05em;vertical-align:middle;border-radius:4px;margin-left:.5rem;padding:.15rem .4rem;font-size:.65rem;font-weight:800;display:inline-block;box-shadow:0 2px 4px #6366f14d}.main-layout-grid{grid-template-columns:1fr 240px;align-items:start;gap:2rem;display:grid}.main-content-column{flex-direction:column;gap:2rem;min-width:0;display:flex}.sidebar-column{flex-direction:column;gap:1.5rem;display:flex;position:sticky;top:2rem}@media (width<=1024px){.main-layout-grid{grid-template-columns:1fr}}@media (width<=768px){.main-content-column{display:none!important}.sidebar-column{position:static!important}}.active-sidebar-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);flex-direction:column;gap:1.25rem;padding:1.15rem;display:flex}.active-sidebar-title{color:#10b981;border-bottom:1px solid var(--border-color);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:.5rem;padding-bottom:.75rem;font-size:1rem;font-weight:700;display:flex}.active-sidebar-list{flex-direction:column;gap:.75rem;display:flex}.active-sidebar-member{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;flex-direction:column;gap:.35rem;padding:.75rem 1rem;transition:all .2s;display:flex}.active-sidebar-member:hover{box-shadow:var(--shadow-sm);border-color:#10b981;transform:translate(3px)}.active-sidebar-name{color:var(--text-primary);font-size:.95rem;font-weight:600}.active-sidebar-shift-info{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.pulse-green-dot{background-color:#10b981;border-radius:50%;width:10px;height:10px;animation:1.5s infinite pulse-dot;box-shadow:0 0 #10b981b3}@keyframes pulse-dot{0%{transform:scale(.95);box-shadow:0 0 #10b981b3}70%{transform:scale(1);box-shadow:0 0 0 6px #10b98100}to{transform:scale(.95);box-shadow:0 0 #10b98100}}.available-tag{color:#10b981;text-transform:uppercase;letter-spacing:.05em;background-color:#10b98114;border:1px solid #10b98133;border-radius:4px;margin-top:2px;padding:.1rem .35rem;font-size:.65rem;font-weight:800;animation:2s ease-in-out infinite pulse-avail;display:inline-block}@keyframes pulse-avail{0%,to{opacity:1}50%{opacity:.75}}.schedule-table th:first-child,.schedule-table td:first-child,.schedule-table th:nth-child(2),.schedule-table td:nth-child(2){white-space:nowrap}.active-sidebar-member-link{color:inherit;text-decoration:none;display:block}
