: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}select{font:inherit;border:1px solid var(--border);background:var(--card);color:var(--ink);cursor:pointer;border-radius:10px;padding:9px 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{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.centered .site-footer{width:100%;margin-top:40px}.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)}.department-tab-group{align-items:center;gap:2px;display:inline-flex}.rename-button{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:4px 6px;font-size:13px}.rename-button:hover{color:var(--accent)}.inline-edit-row{align-items:center;gap:6px;display:inline-flex}.inline-edit-row input{padding:4px 8px;font-size:16px}.inline-edit-row button{padding:4px 8px}h1 .rename-button{vertical-align:middle;font-size:16px}.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}.oauth-row{gap:8px;margin-top:8px;display:flex}.oauth-row button{flex:1;font-size:13px}.selection-toolbar{align-items:center;gap:12px;display:flex}.selectable-cell{cursor:pointer;text-align:center;min-width:38px;height:100%}.selectable-cell:hover{background:#17a36b14}.selectable-cell.selected{background:#17a36b40;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;flex:1;align-items:center;gap:10px;display:flex}.template-row-wrap{align-items:center;gap:6px;display:flex}.template-delete-button{color:var(--danger);cursor:pointer;background:0 0;border:none;padding:4px 8px}.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}.site-footer{border-top:1px solid var(--border);background:var(--card);box-sizing:border-box;width:100vw;margin-top:32px;margin-left:-50vw;padding:28px 24px;position:relative;left:50%}.footer-columns{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:24px;max-width:1100px;margin:0 auto;display:grid}.footer-column{flex-direction:column;gap:6px;display:flex}.footer-column h3{margin-bottom:4px;font-size:14px}.footer-column a{color:var(--ink);font-size:13px;text-decoration:none}.footer-column a:hover{color:var(--accent);text-decoration:underline}.footer-column p{font-size:13px}.back-to-top{background:var(--accent);color:var(--accent-ink);border-color:var(--accent);border-radius:999px;padding:10px 16px;position:fixed;bottom:20px;right:20px;box-shadow:0 4px 12px #00000026}.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)}}
