*{box-sizing:border-box;margin:0;padding:0}body{color:#1a1a1a;background:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app{max-width:1400px;margin:0 auto;padding:0 20px}.header{border-bottom:2px solid #111;padding:24px 0 8px}.header h1{font-size:24px;font-weight:700}.header .subtitle{color:#666;font-size:14px}.tabs{gap:4px;padding:16px 0;display:flex}.tabs button{cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:6px;padding:8px 20px;font-size:14px;transition:all .15s}.tabs button:hover{background:#f0f0f0}.tabs button.active{color:#fff;background:#111;border-color:#111}.tabs button:disabled{opacity:.4;cursor:not-allowed}.content{padding:16px 0}.schedule-toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.schedule-toolbar input{border:1px solid #ddd;border-radius:6px;padding:8px 12px;font-size:14px}.schedule-toolbar button,.btn{cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .15s}.btn-primary{color:#fff;background:#111}.btn-primary:hover{background:#333}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-success{color:#fff;background:#16a34a}.btn-success:hover{background:#15803d}.btn-outline{color:#333;background:#fff;border:1px solid #ddd}.btn-outline:hover{background:#f5f5f5}.schedule-grid{background:#fff;border:1px solid #ddd;border-radius:8px;grid-template-columns:80px repeat(7,1fr);font-size:12px;display:grid;overflow:hidden}.schedule-grid .header-cell{color:#fff;text-align:center;background:#111;padding:10px 4px;font-size:13px;font-weight:600}.schedule-grid .time-cell{text-align:right;color:#666;background:#fafafa;border-bottom:1px solid #eee;padding:6px 8px;font-size:12px;font-weight:500}.schedule-grid .slot{border-bottom:1px solid #eee;border-left:1px solid #eee;min-height:32px;padding:2px;position:relative}.schedule-grid .slot .shift-badge{white-space:nowrap;border-radius:3px;margin:1px;padding:1px 5px;font-size:10px;font-weight:500;display:inline-block}.shift-color-0{color:#1e40af;background:#dbeafe}.shift-color-1{color:#166534;background:#dcfce7}.shift-color-2{color:#92400e;background:#fef3c7}.shift-color-3{color:#9d174d;background:#fce7f3}.shift-color-4{color:#3730a3;background:#e0e7ff}.shift-color-5{color:#6b21a8;background:#f3e8ff}.shift-color-6{color:#9a3412;background:#ffedd5}.shift-color-7{color:#155e75;background:#cffafe}.shift-color-8{color:#3f6212;background:#ecfccb}.shift-color-9{color:#9f1239;background:#fecdd3}.shift-color-10{color:#334155;background:#e2e8f0}.shift-color-11{color:#065f46;background:#d1fae5}.shift-color-12{color:#854d0e;background:#fef9c3}.shift-color-13{color:#5b21b6;background:#ede9fe}.shift-color-14{color:#991b1b;background:#fee2e2}.demand-indicator{color:#999;font-size:9px;position:absolute;top:1px;right:2px}.demand-met{color:#16a34a}.demand-unmet{color:#dc2626;font-weight:700}.employee-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:12px;display:grid}.employee-card{background:#fff;border:1px solid #ddd;border-radius:8px;padding:16px}.employee-card h3{margin-bottom:8px;font-size:16px}.employee-card .meta{color:#666;margin-bottom:8px;font-size:13px}.employee-card .meta span{margin-right:12px;display:inline-block}.badge{border-radius:12px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.badge-ft{color:#1e40af;background:#dbeafe}.badge-pt{color:#92400e;background:#fef3c7}.avail-mini{gap:2px;margin-top:8px;display:flex}.avail-mini .day-col{text-align:center;flex:1}.avail-mini .day-label{color:#999;margin-bottom:2px;font-size:10px;font-weight:600}.avail-mini .hour-block{border-radius:1px;height:4px;margin:1px 0}.hour-available{background:#86efac}.hour-preferred{background:#22c55e}.hour-unavailable{background:#f1f1f1}.report-cards{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:24px;display:grid}.report-card{text-align:center;background:#fff;border:1px solid #ddd;border-radius:8px;padding:20px}.report-card .label{color:#666;margin-bottom:4px;font-size:12px}.report-card .value{font-size:28px;font-weight:700}.report-card .value.good{color:#16a34a}.report-card .value.warn{color:#f59e0b}.report-card .value.bad{color:#dc2626}.hours-chart{background:#fff;border:1px solid #ddd;border-radius:8px;padding:20px}.hours-chart h3{margin-bottom:12px;font-size:16px}.bar-row{align-items:center;gap:8px;margin-bottom:6px;display:flex}.bar-label{text-align:right;flex-shrink:0;width:70px;font-size:12px}.bar-track{background:#f1f1f1;border-radius:4px;flex:1;height:20px;position:relative}.bar-fill{background:#3b82f6;border-radius:4px;height:100%;transition:width .3s}.bar-value{flex-shrink:0;width:40px;font-size:12px;font-weight:600}.validation-box{border-radius:8px;margin-top:12px;padding:12px;font-size:13px}.validation-box.valid{background:#f0fdf4;border:1px solid #86efac}.validation-box.invalid{background:#fef2f2;border:1px solid #fca5a5}.validation-box ul{margin-top:8px;padding-left:20px}.validation-box li{margin-bottom:4px}.violation{color:#dc2626}.warning{color:#f59e0b}.loading{text-align:center;color:#666;padding:40px;font-size:16px}.status-badge{border-radius:12px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-block}.status-draft{color:#92400e;background:#fef3c7}.status-confirmed{color:#166534;background:#dcfce7}
