:root{--bg:#eef2f8;--card:#fff;--ink:#132238;--muted:#6b7587;--border:#d8dee8;--accent:#17a36b;--accent-ink:#fff;--danger:#d23b3b;color:var(--ink);background:var(--bg);font-family:system-ui,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}body{min-height:100vh;margin:0}#root{min-height:100vh}h1{margin:0;font-size:24px}h2{margin:0 0 4px;font-size:18px}p{margin:0}.muted{color:var(--muted);font-size:14px}.error-text{color:var(--danger);font-size:14px}button{font:inherit;border:1px solid var(--border);background:var(--card);color:var(--ink);cursor:pointer;border-radius:10px;padding:10px 16px}button[type=submit],.schedule-header button:first-of-type{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}button.danger{background:var(--danger);color:#fff;border-color:var(--danger)}input{font:inherit;border:1px solid var(--border);border-radius:10px;padding:10px 12px}label{color:var(--muted);flex-direction:column;flex:1;gap:4px;font-size:14px;display:flex}.card{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:20px}.centered{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{flex-direction:column;gap:12px;width:100%;max-width:360px;display:flex}.link-button{color:var(--accent);background:0 0;border:none;padding:4px 0;text-decoration:underline}.company-code{letter-spacing:2px;text-align:center;font-size:28px;font-weight:700}.schedule-page{flex-direction:column;gap:16px;width:fit-content;max-width:100%;margin:0 auto;padding:24px;display:flex}.schedule-header{justify-content:space-between;align-items:center;display:flex}.company-code-label{margin:2px 0 0;font-size:13px}.header-actions{gap:8px;display:flex}.week-nav{justify-content:space-between;align-items:center;gap:12px;display:flex}.month-label{font-weight:700}.add-employee-row{gap:8px;display:flex}.add-employee-row input{flex:1;max-width:280px}.publish-row{align-items:center;gap:10px;display:flex}.department-tabs{border-top:1px solid var(--border);flex-wrap:wrap;gap:8px;padding-top:12px;display:flex}.department-tab{border-radius:999px}.department-tab.active{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}@media print{@page{size:A4 landscape;margin:8mm}.no-print{display:none!important}body{background:#fff}.schedule-page{width:100%;max-width:none;padding:0}.week-nav{justify-content:center;margin-bottom:6mm}.month-label{font-size:16px}.month-grid-scroll{border:none;overflow:visible}.month-grid{table-layout:fixed;width:100%}.employee-cell,.employee-cell-header{min-width:0;position:static}.month-grid th,.month-grid td{padding:2px;font-size:9px}.shift-cell{min-width:0}}.error-card{border-color:var(--danger);flex-direction:column;gap:8px;display:flex}.month-grid-scroll{border:1px solid var(--border);border-radius:18px;overflow-x:auto}.month-grid{border-collapse:collapse;background:var(--card)}.month-grid th,.month-grid td{border:1px solid var(--border);vertical-align:top;text-align:left;padding:6px}.employee-cell,.employee-cell-header{background:var(--card);z-index:1;min-width:160px;position:sticky;left:0}.employee-cell{font-weight:600}.shift-cell{flex-direction:column;gap:4px;min-width:38px;display:flex}.shift-chip{border:1px solid var(--accent);text-align:center;background:#17a36b1a;border-radius:8px;justify-content:center;align-items:center;width:100%;padding:4px 5px;display:flex}.shift-chip-code{font-size:12px;font-weight:700}.shift-add{color:var(--accent);border-style:dashed;font-weight:700}.modal-overlay{background:#13223866;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-card{flex-direction:column;gap:10px;width:100%;max-width:380px;display:flex}.modal-card .row{gap:10px;display:flex}.template-list{flex-direction:column;gap:8px;max-height:320px;display:flex;overflow-y:auto}.template-row{text-align:left;align-items:center;gap:10px;display:flex}.requests-panel{max-width:480px}.request-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:10px;padding-bottom:8px;display:flex}
