: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)}.print-only{display:none}@media print{@page{size:A4 landscape;margin:8mm}.no-print{display:none!important}body{background:#fff}.schedule-page>:not(.print-only){display:none!important}.print-only{display:block}.print-schedule h1{margin-bottom:2mm;font-size:16px}.print-norm-row{margin-bottom:6mm;font-size:11px}.print-section{margin-bottom:10mm}.print-section h2{margin-bottom:2mm;font-size:13px}.print-table{border-collapse:collapse;table-layout:fixed;width:100%}.print-table th,.print-table td{text-align:center;border:1px solid #333;padding:1.5px;font-size:8px}.print-table th:first-child,.print-table td:first-child{text-align:left;width:90px}.print-signature-row{justify-content:space-between;margin-top:12mm;font-size:11px;display:flex}}.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}.team-member-row{border-bottom:1px solid var(--border);flex-direction:column;gap:8px;padding-bottom:10px;display:flex}.team-permissions{flex-direction:column;gap:4px;display:flex}.team-permission-toggle{align-items:center;gap:8px;font-size:13px;display:flex}.employee-cell-name-row{justify-content:space-between;align-items:center;gap:6px;display:flex}.employee-remove-button{color:var(--danger);background:0 0;border:none;padding:2px 4px;font-size:12px}.gender-select{margin-top:4px;padding:2px 4px;font-size:12px}.hours-match{text-align:center;background:#17a36b1f;font-weight:700}.hours-mismatch{text-align:center;background:#d23b3b1f;font-weight:700}.work-norm-row{gap:16px;display:flex}.owner-badge{background:var(--accent);color:var(--accent-ink);border-radius:999px;margin-left:8px;padding:2px 8px;font-size:12px;font-weight:700;display:inline-block}.admin-grant-row{align-items:center;gap:6px;display:flex}.admin-grant-row select{padding:4px 6px;font-size:12px}.trial-banner{border-radius:14px;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;font-size:13px;display:flex}.trial-banner.expired{color:var(--danger);background:#d23b3b1f}.trial-banner.active{color:var(--ink);background:#17a36b1a}.tier-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin:12px 0;display:grid}.tier-card{border:1px solid var(--border);text-align:left;background:var(--card-alt,#f6f8fb);cursor:pointer;border-radius:14px;padding:14px}.tier-card.selected{border-color:var(--accent);background:#17a36b14}.tier-card-name{margin-bottom:4px;font-weight:700}.tier-card-range{color:var(--muted);margin-bottom:8px;font-size:12px}.tier-card-price{font-size:18px;font-weight:700}.period-toggle{gap:8px;margin-bottom:10px;display:flex}.header-logo{vertical-align:middle;width:28px;height:28px;margin-right:8px}.splash-screen{background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:14px;min-height:100vh;display:flex}.splash-logo{width:84px;height:84px;animation:.9s ease-out splash-pop}.splash-title{color:var(--ink);opacity:0;font-size:22px;font-weight:700;animation:.6s ease-out .3s forwards splash-fade}@keyframes splash-pop{0%{opacity:0;transform:scale(.6)}60%{opacity:1;transform:scale(1.08)}to{opacity:1;transform:scale(1)}}@keyframes splash-fade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
