*,:before,:after{box-sizing:border-box}html,body,#root{width:100%;min-height:100vh;min-height:100dvh;margin:0;padding:0}#root{flex-direction:column;display:flex}:root{--primary:#1a56db;--primary-hover:#1e40af;--primary-light:#dbeafe;--success:#059669;--success-light:#d1fae5;--danger:#dc2626;--danger-light:#fee2e2;--text:#111827;--text-secondary:#374151;--text-muted:#6b7280;--bg:#f8fafc;--card-bg:#fff;--border:#e2e8f0;--border-light:#f1f5f9;--shadow-sm:0 1px 2px #0000000a;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 6px #0000000f, 0 2px 4px #0000000a;--shadow-lg:0 10px 20px #00000014, 0 4px 8px #0000000a;--radius:clamp(8px, 2vw, 12px);--radius-sm:clamp(6px, 1.5vw, 8px);--radius-lg:clamp(12px, 3vw, 16px);--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--safe-left:env(safe-area-inset-left,0px);--safe-right:env(safe-area-inset-right,0px)}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:clamp(15px,1.8vw + .5rem,18px)}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;min-height:100dvh;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5}.app-shell{min-height:100vh;background:radial-gradient(circle at 0 0,#1a56db14,#0000 28%),linear-gradient(#f8fbff 0%,#f8fafc 100%);flex-direction:row;min-height:100dvh;display:flex}.app-sidebar{width:min(320px,28vw);min-height:100vh;min-height:100dvh;padding:clamp(1rem,4vw,1.5rem);padding-top:max(clamp(1rem, 4vw, 1.5rem), var(--safe-top));padding-left:max(clamp(1rem, 4vw, 1.5rem), var(--safe-left));padding-right:max(clamp(1rem, 4vw, 1.5rem), var(--safe-right));-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffe0;border-right:1px solid #1a56db1a;flex-direction:column;flex-shrink:0;gap:clamp(1rem,4vw,1.5rem);display:flex;position:sticky;top:0}.sidebar-brand{align-items:flex-start;gap:.875rem;min-width:0;display:flex}.brand-icon{background:#0a2a481f;border:1px solid #ffffff3d;border-radius:1rem;justify-content:center;align-items:center;width:3rem;height:3rem;padding:.2rem;display:inline-flex;box-shadow:inset 0 1px #ffffff42,0 10px 24px #0206171f}.brand-icon svg{width:100%;height:100%}.sidebar-brand-copy{min-width:0}.brand-text{color:var(--text);font-size:1.1rem;font-weight:700;display:block}.brand-subtitle{color:var(--text-muted);font-size:.875rem}.sidebar-nav{flex-direction:column;gap:.75rem;display:flex}.sidebar-link{color:var(--text-secondary);background:#ffffffd6;border:1px solid #94a3b833;border-radius:1rem;align-items:center;gap:.75rem;padding:.9rem 1rem;font-weight:600;text-decoration:none;transition:transform .15s,border-color .15s,box-shadow .15s,background .15s;display:flex}.sidebar-link:hover{box-shadow:var(--shadow-md);border-color:#1a56db3d;transform:translateY(-1px)}.sidebar-link.active{color:var(--primary);background:linear-gradient(135deg,#1a56db1f,#3b82f62e);border-color:#1a56db4d}.sidebar-link-icon{width:1.875rem;height:1.875rem;color:var(--primary);letter-spacing:.08em;text-transform:uppercase;background:#ffffffeb;border-radius:.75rem;justify-content:center;align-items:center;font-size:.75rem;font-weight:800;display:inline-flex}.sidebar-footer{background:#1a56db14;border:1px solid #1a56db1f;border-radius:1rem;flex-direction:column;gap:.9rem;margin-top:auto;padding:1rem 1.125rem;display:flex}.sidebar-footer-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.35rem;font-size:.75rem;font-weight:700}.sidebar-footer-value{color:var(--text);font-size:1rem;font-weight:600}.sidebar-footer-meta{color:var(--text-muted);margin-top:.25rem;font-size:.875rem}.sidebar-logout{color:#b91c1c;cursor:pointer;background:#ffffffeb;border:1px solid #dc262629;border-radius:.9rem;padding:.8rem .95rem;font-size:.9rem;font-weight:700;transition:background .15s,border-color .15s,transform .15s}.sidebar-logout:hover{background:#fef2f2eb;border-color:#dc262647;transform:translateY(-1px)}.mobile-top-bar,.mobile-bottom-nav{display:none}.app-layout{min-width:0;min-height:0;padding-bottom:var(--safe-bottom);flex-direction:column;flex:1;display:flex}.app-header{z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:clamp(1rem,4vw,1.5rem) clamp(1rem,4vw,2rem);padding-left:max(clamp(1rem, 4vw, 2rem), var(--safe-left));padding-right:max(clamp(1rem, 4vw, 2rem), var(--safe-right));background:#ffffffe6;border-bottom:1px solid #94a3b82e;justify-content:flex-start;align-items:center;gap:1rem;display:flex;position:sticky;top:0}.header-copy{max-width:44rem}.header-eyebrow{color:var(--primary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.45rem;font-size:.8rem;font-weight:700}.header-title{color:var(--text);font-size:clamp(1.2rem,3vw,1.7rem);line-height:1.2}.header-user{justify-content:flex-end;align-items:center;gap:clamp(.75rem,3vw,1rem);display:flex}.user-name{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:clamp(100px,30vw,200px);font-size:clamp(.875rem,3vw,1rem);font-weight:700;display:block;overflow:hidden}.user-meta{color:var(--text-muted);font-size:.8125rem}.btn-logout{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);background:linear-gradient(135deg,#fff 0%,#eef4ff 100%);border:1px solid #1a56db29;padding:clamp(.5rem,2vw,.75rem) clamp(.875rem,3vw,1.25rem);font-size:clamp(.875rem,3vw,1rem);font-weight:500;transition:all .15s}.btn-logout:hover{background:#fff;border-color:#1a56db4d}.btn-logout:active{transform:scale(.97)}.app-main{padding:clamp(1rem,4vw,2rem);padding-left:max(clamp(1rem, 4vw, 2rem), var(--safe-left));padding-right:max(clamp(1rem, 4vw, 2rem), var(--safe-right));flex:1;width:100%;min-width:0;margin:0;overflow-x:hidden}.app-footer{text-align:center;color:var(--text-muted);padding:clamp(.875rem,3vw,1.25rem);padding-bottom:max(clamp(.875rem, 3vw, 1.25rem), var(--safe-bottom));background:#ffffffd1;border-top:1px solid #94a3b829;font-size:clamp(.8125rem,2.5vw,.9375rem)}.loading-screen,.loading{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:clamp(2rem,8vw,4rem);display:flex}.time-off-placeholder-page{width:100%}.portal-time-off-page{flex-direction:column;gap:1rem;width:100%;display:flex}.time-off-placeholder-card{box-shadow:var(--shadow-md);background:linear-gradient(145deg,#fffffff5,#eff6ffe0);border:1px solid #94a3b829;border-radius:1.5rem;grid-template-columns:1fr;gap:1rem;padding:clamp(1.25rem,4vw,2rem);display:grid}.page-eyebrow{color:var(--primary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem;font-size:.78rem;font-weight:700}.time-off-placeholder-card h2{color:var(--text);margin-bottom:.75rem;font-size:clamp(1.5rem,4vw,2.2rem);line-height:1.15}.time-off-placeholder-card p{color:var(--text-secondary);max-width:46rem}.time-off-placeholder-actions{flex-wrap:wrap;gap:.75rem;margin-top:1rem;display:flex}.time-off-hero{box-shadow:var(--shadow-md);background:linear-gradient(145deg,#fffffff5,#dbeafedb);border:1px solid #94a3b829;border-radius:1.5rem;grid-template-columns:minmax(0,1.2fr) minmax(240px,.95fr);align-items:start;gap:.85rem;padding:clamp(1rem,3vw,1.35rem);display:grid}.time-off-hero-copy h2{margin-bottom:.35rem;font-size:clamp(1.2rem,3vw,1.65rem)}.time-off-hero-copy{flex-direction:column;gap:.2rem;display:flex}.time-off-hero-copy p{color:var(--text-secondary);max-width:32rem}.time-off-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem;display:grid}.time-off-summary-card{background:#ffffffdb;border:1px solid #94a3b829;border-radius:1rem;flex-direction:column;gap:.25rem;padding:.82rem .9rem;display:flex}.time-off-summary-card span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.8125rem;font-weight:700}.time-off-summary-card strong{font-size:1.4rem}.time-off-summary-card.status-pending strong{color:#b45309}.time-off-summary-card.status-approved strong{color:var(--success)}.time-off-summary-card.status-declined strong{color:var(--danger)}.time-off-summary-card.status-cancelled strong{color:var(--text-muted)}.portal-time-off-content{grid-template-columns:minmax(320px,.95fr) minmax(0,1.3fr);gap:1rem;display:grid}.portal-time-off-card{box-shadow:var(--shadow-sm);background:#fffffff0;border:1px solid #94a3b829;border-radius:1.5rem;padding:clamp(1.25rem,4vw,1.75rem)}.portal-section-kicker{color:var(--primary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.3rem;font-size:.74rem;font-weight:700}.portal-type-legend{margin-bottom:1rem}.portal-time-off-form{flex-direction:column;gap:1rem;display:flex}.portal-time-off-form label,.portal-time-off-cancel-panel label{color:var(--text);flex-direction:column;gap:.45rem;font-weight:600;display:flex}.portal-time-off-form select,.portal-time-off-form input,.portal-time-off-form textarea,.portal-time-off-cancel-panel textarea{width:100%;color:var(--text);font:inherit;background:#fff;border:1px solid #94a3b838;border-radius:.95rem;padding:.875rem 1rem}.portal-time-off-form textarea,.portal-time-off-cancel-panel textarea{resize:vertical;min-height:6rem}.portal-time-off-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;display:grid}.time-off-form-actions{flex-wrap:wrap;gap:.75rem;display:flex}.time-off-feedback.success-message{background:var(--success-light);color:var(--success);border-radius:1rem;margin-bottom:1rem;padding:.875rem 1rem;font-weight:600}.portal-time-off-list{flex-direction:column;gap:.9rem;display:flex}.time-off-cancelled-toggle{opacity:.7;align-self:center;margin-top:.25rem;font-size:.8rem}.time-off-cancelled-toggle:hover{opacity:1}.portal-time-off-entry{background:linear-gradient(145deg,#fffffffa,#f8fafceb);border:1px solid #94a3b829;border-left-width:3px;border-radius:1.15rem;flex-direction:column;gap:.4rem;padding:1rem 1rem 1rem .875rem;display:flex}.portal-time-off-entry.status-pending{border-left-color:#b453098c}.portal-time-off-entry.status-approved{border-left-color:#0596698c}.portal-time-off-entry.status-declined{border-left-color:#dc26268c}.portal-time-off-entry.status-cancelled{opacity:.72;border-left-color:#6b728047}.portal-time-off-entry-header{flex-direction:column;gap:.15rem;margin-bottom:.15rem;display:flex}.portal-time-off-entry-title-row{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.portal-time-off-entry-title-row h3{font-size:1.05rem}.time-off-status-pill,.time-off-type-pill{border:1px solid #94a3b829;border-radius:999px;justify-content:center;align-items:center;padding:.35rem .7rem;font-size:.8rem;font-weight:700;display:inline-flex}.time-off-status-pill.status-pending{color:#b45309;background:#f59e0b24}.time-off-status-pill.status-approved{color:var(--success);background:#0596691f}.time-off-status-pill.status-declined{color:var(--danger);background:#dc26261f}.time-off-status-pill.status-cancelled{color:var(--text-muted);background:#6b72801f}.time-off-type-legend{flex-wrap:wrap;gap:.5rem;display:flex}.portal-time-off-entry-range,.portal-time-off-entry-meta{color:var(--text-secondary)}.portal-time-off-entry-notes{color:var(--text)}.portal-time-off-entry-meta{font-size:.9rem}.portal-time-off-entry-actions{flex-wrap:wrap;gap:.6rem;margin-top:.75rem;display:flex}.portal-time-off-entry-actions>*{flex:8rem;min-width:0}.portal-time-off-entry-company{align-self:flex-start}.portal-time-off-cancel-panel{background:#f8fafce0;border:1px solid #94a3b829;border-radius:1rem;margin-top:1rem;padding:.95rem}.portal-link-button{border-radius:999px;justify-content:center;align-items:center;min-width:11rem;padding:.85rem 1.15rem;font-weight:700;text-decoration:none;transition:transform .15s,box-shadow .15s;display:inline-flex}.portal-link-button:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.portal-link-button.primary{color:#fff;background:linear-gradient(135deg,#1a56db 0%,#3b82f6 100%)}.portal-link-button.secondary{color:var(--text);background:#fff;border:1px solid #94a3b838}.login-container{min-height:100vh;min-height:100dvh;padding:clamp(1rem,4vw,2rem);padding-top:max(clamp(1rem, 4vw, 2rem), var(--safe-top));padding-bottom:max(clamp(1rem, 4vw, 2rem), var(--safe-bottom));background:linear-gradient(160deg,#1e40af 0%,#1a56db 50%,#3b82f6 100%);justify-content:center;align-items:center;display:flex}.login-card{background:var(--card-bg);border-radius:var(--radius-lg);width:100%;max-width:min(92vw,480px);box-shadow:var(--shadow-lg);padding:clamp(1.75rem,6vw,3rem) clamp(1.5rem,5vw,2.5rem)}.login-header{text-align:center;margin-bottom:clamp(1.5rem,5vw,2.5rem)}.login-header h1{color:var(--text);margin-bottom:clamp(.375rem,1.5vw,.625rem);font-size:clamp(1.5rem,6vw,2rem);font-weight:700}.login-header p{color:var(--text-secondary);font-size:clamp(.9375rem,3vw,1.0625rem)}.login-alt-link{text-align:center;color:var(--text-secondary);margin-top:clamp(1.25rem,4vw,1.75rem);font-size:clamp(.875rem,2.8vw,.9375rem)}.login-alt-link a{color:var(--primary);font-weight:500;text-decoration:none}.login-alt-link a:hover{text-decoration:underline}.form-group{margin-bottom:clamp(1.25rem,4vw,1.75rem)}.form-group label{color:var(--text);margin-bottom:clamp(.5rem,1.5vw,.75rem);font-size:clamp(.9375rem,3vw,1.0625rem);font-weight:600;display:block}.form-group input{border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);width:100%;color:var(--text);padding:clamp(.875rem,3vw,1.125rem) clamp(1rem,3vw,1.25rem);font-size:clamp(1rem,3.5vw,1.125rem);transition:all .15s}.form-group input::placeholder{color:var(--text-muted)}.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}.form-group input:disabled{background:var(--bg);color:var(--text-muted)}.phone-input{text-align:center;letter-spacing:.25em;font-weight:600;font-size:clamp(1.375rem,5vw,1.625rem)!important}.otp-input{text-align:center;letter-spacing:.5em;font-family:SF Mono,Menlo,Consolas,monospace;font-weight:700;font-size:clamp(1.625rem,6vw,2rem)!important}.otp-info{text-align:center;background:var(--primary-light);border-radius:var(--radius-sm);border:1px solid #1a56db26;margin-bottom:clamp(1.25rem,4vw,1.75rem);padding:clamp(1rem,3vw,1.25rem)}.otp-info p{color:var(--text-secondary);margin-bottom:.375rem;font-size:clamp(.9375rem,3vw,1rem)}.otp-info strong{color:var(--primary);font-size:clamp(1.0625rem,3.5vw,1.25rem)}.otp-actions{justify-content:center;gap:clamp(1.25rem,5vw,2rem);margin-top:clamp(1rem,4vw,1.5rem);display:flex}.btn-primary{background:var(--primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;width:100%;padding:clamp(.875rem,3.5vw,1.125rem);font-size:clamp(1rem,3.5vw,1.125rem);font-weight:600;transition:all .15s}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-link{color:var(--primary);cursor:pointer;background:0 0;border:none;padding:.625rem;font-size:clamp(.9375rem,3vw,1.0625rem);font-weight:500}.btn-link:hover{text-decoration:underline}.help-text{text-align:center;color:var(--text-muted);margin-top:clamp(1.25rem,4vw,1.75rem);font-size:clamp(.875rem,2.5vw,.9375rem);line-height:1.6}.error-message{background:var(--danger-light);color:var(--danger);border-radius:var(--radius-sm);text-align:center;margin-bottom:clamp(1rem,3vw,1.25rem);padding:clamp(.875rem,3vw,1rem) clamp(1rem,3vw,1.25rem);font-size:clamp(.9375rem,3vw,1rem);font-weight:500}.hours-page,.schedule-page{width:100%}.page-header{margin-bottom:clamp(1rem,3vw,1.5rem)}.page-header h1{color:var(--text);margin-bottom:.25rem;font-size:clamp(1.375rem,5vw,1.875rem);font-weight:700}.page-header p{color:var(--text-secondary);font-size:clamp(1rem,3.5vw,1.125rem)}.week-nav{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);justify-content:space-between;align-items:center;margin-bottom:clamp(1.25rem,4vw,1.75rem);padding:clamp(1rem,3vw,1.25rem) clamp(1.25rem,4vw,1.75rem);display:flex}.btn-nav{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;letter-spacing:.04em;width:clamp(44px,12vw,56px);height:clamp(44px,12vw,56px);color:var(--text-secondary);flex-shrink:0;justify-content:center;align-items:center;font-size:clamp(.75rem,2.7vw,.875rem);font-weight:700;transition:all .15s;display:flex}.btn-nav:hover:not(:disabled){background:var(--bg);border-color:var(--text-muted)}.btn-nav:active:not(:disabled){transform:scale(.95)}.btn-nav:disabled{opacity:.4;cursor:not-allowed}.week-label{text-align:center;color:var(--text);flex-direction:column;flex:1;align-items:center;gap:.5rem;min-width:0;font-size:clamp(1rem,3.5vw,1.25rem);font-weight:600;display:flex}.current-badge{background:var(--primary);color:#fff;text-transform:uppercase;letter-spacing:.025em;border-radius:999px;padding:.25rem clamp(.625rem,2vw,.75rem);font-size:clamp(.625rem,2vw,.75rem);font-weight:600}.week-total{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-hover) 100%);color:#fff;border-radius:var(--radius);box-shadow:var(--shadow-md);flex-wrap:wrap;justify-content:space-between;align-items:center;margin-bottom:clamp(1.25rem,4vw,1.5rem);padding:clamp(1.25rem,4vw,1.5rem) clamp(1.5rem,5vw,2rem);display:flex}.week-total span{opacity:.9;font-size:clamp(1rem,3.5vw,1.25rem)}.week-total strong{font-size:clamp(1.75rem,6vw,2.25rem);font-weight:700}.ot-breakdown{opacity:.9;justify-content:space-between;width:100%;margin-top:.5rem;font-size:clamp(.85rem,2.5vw,1rem);display:flex}.ot-breakdown .regular-label{opacity:.9}.ot-breakdown .ot-label{color:#fbbf24;font-weight:600}.days-list{flex-direction:column;gap:clamp(.75rem,2vw,1rem);display:flex}.day-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);width:100%;overflow:hidden}.day-header{background:var(--bg);border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:clamp(1rem,3vw,1.25rem) clamp(1.25rem,4vw,1.5rem);display:flex}.day-info{align-items:baseline;gap:clamp(.625rem,2.5vw,1rem);display:flex}.day-name{color:var(--text);font-size:clamp(1rem,3.5vw,1.25rem);font-weight:700}.day-date{color:var(--text-muted);font-size:clamp(.9375rem,3vw,1.0625rem)}.day-hours{color:var(--success);font-size:clamp(1rem,3.5vw,1.25rem);font-weight:700}.punches-list{padding:clamp(.875rem,3vw,1.125rem) clamp(1.25rem,4vw,1.5rem)}.punch-item{align-items:center;gap:clamp(.75rem,3vw,1rem);padding:clamp(.625rem,2vw,.75rem) 0;font-size:clamp(1rem,3.5vw,1.125rem);display:flex}.punch-item+.punch-item{border-top:1px solid var(--border-light)}.punch-icon{background:#6b728047;border-radius:999px;flex-shrink:0;width:.7rem;height:.7rem}.punch-item.clock_in .punch-icon{background:#059669e6}.punch-item.clock_out .punch-icon{background:#dc2626e6}.punch-event{text-transform:uppercase;width:clamp(2.5rem,8vw,3rem);font-size:clamp(.875rem,3vw,1rem);font-weight:600}.punch-item.clock_in .punch-event{color:var(--success)}.punch-item.clock_out .punch-event{color:var(--danger)}.punch-time{color:var(--text);font-size:clamp(1rem,3.5vw,1.125rem);font-weight:500}.punch-rounded{color:var(--text-muted);margin-left:auto;font-size:clamp(.875rem,3vw,1rem)}.no-punches{color:var(--text-muted);text-align:center;padding:clamp(1.25rem,4vw,1.5rem);font-size:clamp(1rem,3.5vw,1.125rem);font-style:italic}.schedule-name{color:var(--text-secondary);margin-bottom:.375rem;font-size:clamp(.9375rem,3vw,1.0625rem)}.schedule-grid{grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr));gap:clamp(.75rem,2vw,1rem);display:grid}.schedule-day{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:2px solid #0000;padding:clamp(1rem,3vw,1.25rem);transition:all .15s}.schedule-day.today{border-color:var(--primary);background:var(--primary-light)}.schedule-day.off{opacity:.5;background:var(--bg)}.day-label{align-items:center;gap:clamp(.5rem,2vw,.75rem);margin-bottom:clamp(.375rem,1.5vw,.5rem);display:flex}.day-label .day-name{color:var(--text);font-size:clamp(.9375rem,3vw,1.0625rem);font-weight:700}.today-badge{background:var(--primary);color:#fff;text-transform:uppercase;letter-spacing:.05em;border-radius:999px;padding:.1875rem clamp(.5rem,1.5vw,.625rem);font-size:clamp(.5625rem,1.5vw,.6875rem);font-weight:700}.shifts{flex-direction:column;gap:.375rem;display:flex}.shift{align-items:center;gap:clamp(.625rem,2vw,1rem);display:flex}.shift-times{color:var(--text);align-items:center;gap:.375rem;font-size:clamp(1rem,3vw,1.125rem);font-weight:600;display:flex}.shift-separator{color:var(--text-muted)}.shift-label{color:var(--text-muted);background:var(--bg);border-radius:4px;padding:.1875rem clamp(.5rem,1.5vw,.625rem);font-size:clamp(.8125rem,2.5vw,.9375rem)}.day-off{color:var(--text-muted);font-size:clamp(.9375rem,3vw,1rem);font-style:italic}.no-schedule{text-align:center;background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border-light);padding:clamp(2.5rem,8vw,4rem) clamp(1.25rem,4vw,2rem)}.no-schedule p:first-child{color:var(--text);margin-bottom:.5rem;font-size:clamp(1.0625rem,3.5vw,1.25rem);font-weight:600}.schedule-legend{text-align:center;margin-top:clamp(1.25rem,4vw,2rem)}.muted{color:var(--text-muted);font-size:clamp(.8125rem,2.5vw,.9375rem)}@media (min-width:768px){.app-sidebar{gap:1.25rem}.sidebar-nav{grid-template-columns:repeat(4,minmax(0,1fr))}.schedule-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.portal-time-off-list{gap:1rem}.days-list{grid-template-columns:repeat(2,1fr);display:grid}}@media (min-width:1024px){.app-main{padding:clamp(1.5rem,4vw,2.5rem);padding-left:max(clamp(1.5rem, 4vw, 2.5rem), var(--safe-left));padding-right:max(clamp(1.5rem, 4vw, 2.5rem), var(--safe-right))}.schedule-grid{grid-template-columns:repeat(7,1fr);gap:.75rem}.days-list{grid-template-columns:repeat(7,1fr)}}@media (max-width:767px){.app-sidebar,.app-header,.app-footer{display:none}.app-layout{padding-bottom:0}.mobile-top-bar{z-index:200;height:56px;padding:0 1rem;padding-top:var(--safe-top);-webkit-backdrop-filter:blur(16px);background:#fffffff5;border-bottom:1px solid #94a3b833;justify-content:space-between;align-items:center;gap:.5rem;display:flex;position:fixed;top:0;left:0;right:0}.mobile-brand{align-items:center;gap:.55rem;min-width:0;display:flex}.mobile-brand-name{color:var(--text);font-size:1.05rem;font-weight:700}.mobile-user-area{flex-shrink:0;align-items:center;gap:.55rem;min-width:0;display:flex}.mobile-user-name{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;max-width:100px;font-size:.875rem;font-weight:600;overflow:hidden}.mobile-logout-btn{color:#b91c1c;cursor:pointer;background:#fffffff2;border:1px solid #dc262638;border-radius:999px;flex-shrink:0;padding:.4rem .85rem;font-size:.82rem;font-weight:700;transition:background .15s}.mobile-logout-btn:hover{background:#fef2f2f2}.mobile-bottom-nav{z-index:200;-webkit-backdrop-filter:blur(16px);padding-bottom:var(--safe-bottom);background:#fffffff5;border-top:1px solid #94a3b833;display:flex;position:fixed;bottom:0;left:0;right:0}.mobile-nav-item{color:var(--text-muted);letter-spacing:.01em;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.28rem;padding:.6rem .25rem .7rem;font-size:.7rem;font-weight:600;text-decoration:none;transition:color .15s;display:flex}.mobile-nav-item.active{color:var(--primary)}.mobile-nav-icon{flex-shrink:0;width:1.55rem;height:1.55rem}.app-main{padding-top:calc(56px + var(--safe-top) + 1rem);padding-bottom:calc(64px + var(--safe-bottom) + .5rem);padding-left:max(1rem, var(--safe-left));padding-right:max(1rem, var(--safe-right))}.time-off-hero,.time-off-placeholder-card{flex-direction:column;grid-template-columns:1fr;align-items:flex-start}.portal-time-off-content,.portal-time-off-form-grid{grid-template-columns:1fr}.time-off-hero,.time-off-placeholder-card,.portal-time-off-card,.week-nav,.week-total,.day-card,.schedule-day,.no-schedule{border-radius:1.2rem}.time-off-hero,.time-off-placeholder-card,.portal-time-off-card{padding:1rem}.time-off-hero{box-shadow:none;background:0 0;border:none;border-radius:0;padding:0 0 .15rem;display:block}.time-off-hero-copy{display:none}.time-off-summary-grid{grid-template-columns:repeat(4,1fr);gap:.4rem}.time-off-summary-card{text-align:center;border-radius:.85rem;align-items:center;padding:.55rem .3rem}.time-off-summary-card span{font-size:.6rem}.time-off-summary-card strong{font-size:1rem}.portal-time-off-content{flex-direction:column;display:flex}.time-off-history-card{order:1}.time-off-form-card{order:2}.page-header h1{font-size:1.25rem}.page-header p{font-size:.96rem}.portal-type-legend{scrollbar-width:none;flex-wrap:nowrap;padding-bottom:.2rem;overflow-x:auto}.portal-type-legend::-webkit-scrollbar{display:none}.time-off-type-pill{white-space:nowrap}.portal-time-off-entry{padding:.95rem}.time-off-form-actions,.time-off-placeholder-actions,.otp-actions{flex-direction:column;align-items:stretch}.portal-time-off-entry-actions{flex-direction:row;gap:.5rem}.portal-time-off-entry-actions>*{flex:1;min-width:0;min-height:44px;padding:.65rem .5rem;font-size:.85rem}.time-off-form-actions .portal-link-button,.time-off-form-actions .btn-primary{width:100%}.portal-time-off-entry-header{gap:.55rem}.portal-time-off-entry-title-row h3{font-size:1rem}.portal-time-off-entry-range,.portal-time-off-entry-meta{font-size:.88rem}.portal-time-off-cancel-panel{margin-top:.85rem;padding:.85rem}.week-nav{flex-wrap:wrap;gap:.75rem;padding:1rem}.week-label{order:-1;width:100%}.week-total{padding:1rem 1.2rem}.day-header,.shift,.shift-times,.punch-item{flex-wrap:wrap}.day-header{align-items:flex-start;gap:.35rem}.punch-rounded{width:100%;margin-left:0}.login-card{padding:1.5rem 1.25rem}.portal-time-off-entry-header{flex-direction:column}}@media (orientation:landscape) and (max-height:500px){.login-container{align-items:flex-start;padding-top:clamp(1rem,3vh,2rem)}.login-header{margin-bottom:clamp(.75rem,2vh,1rem)}.form-group{margin-bottom:clamp(.625rem,2vh,1rem)}}@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
