.app-layout{display:flex;min-height:100vh;min-height:100dvh;max-width:1280px;margin:0 auto;width:100%}.sidebar{width:280px;min-height:100vh;min-height:100dvh;background:var(--surface-container-low);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:var(--z-sidebar);transition:transform var(--transition-normal),background var(--transition-normal)}.sidebar-header{padding:var(--spacing-6) var(--spacing-5);display:flex;align-items:center;justify-content:space-between}.sidebar-brand{display:flex;align-items:center;gap:var(--spacing-3)}.brand-icon{width:42px;height:42px;border-radius:var(--radius-md);background:var(--primary);color:var(--on-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.brand-text{display:flex;flex-direction:column}.brand-name{font-size:1rem;font-weight:700;color:var(--on-surface);letter-spacing:var(--tracking-tight);line-height:1.2}.brand-subtitle{font-size:.6875rem;color:var(--on-surface-variant);font-weight:400}.sidebar-close-btn{display:none;flex-shrink:0}.sidebar-site-filter{padding:0 var(--spacing-5);margin-bottom:var(--spacing-4);position:relative}.site-filter-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-3) var(--spacing-4);background:var(--surface-container);border:none;border-radius:var(--radius-md);color:var(--on-surface);font-family:var(--font-family);font-size:.8125rem;font-weight:500;cursor:pointer;transition:background var(--transition-fast)}.site-filter-btn:hover{background:var(--surface-container-high)}.site-filter-chevron{transition:transform var(--transition-fast)}.site-filter-chevron.rotated{transform:rotate(180deg)}.site-filter-dropdown{position:absolute;top:calc(100% + var(--spacing-2));left:var(--spacing-5);right:var(--spacing-5);padding:var(--spacing-2);z-index:var(--z-overlay);animation:fadeIn .2s ease}.site-filter-option{display:block;width:100%;text-align:left;padding:var(--spacing-3) var(--spacing-4);border:none;border-radius:var(--radius-sm);background:transparent;color:var(--on-surface);font-family:var(--font-family);font-size:.8125rem;cursor:pointer;transition:background var(--transition-fast)}.site-filter-option:hover{background:var(--surface-container-high)}.site-filter-option.active{background:var(--primary);color:var(--on-primary)}.sidebar-nav{flex:1;padding:var(--spacing-2) var(--spacing-3);display:flex;flex-direction:column;gap:var(--spacing-1);overflow-y:auto}.nav-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);color:var(--on-surface-variant);text-decoration:none;font-size:.9375rem;font-weight:500;transition:all var(--transition-fast);position:relative}.nav-item:hover{background:var(--surface-container);color:var(--on-surface)}.nav-item-active{background:var(--surface-container-lowest);color:var(--primary);box-shadow:var(--shadow-sm);font-weight:600}.nav-badge{margin-left:auto;background:var(--primary);color:var(--on-primary);font-size:.6875rem;font-weight:700;padding:2px 7px;border-radius:var(--radius-pill);min-width:20px;text-align:center}.sidebar-footer{padding:var(--spacing-4) var(--spacing-5);padding-bottom:max(var(--spacing-4),env(safe-area-inset-bottom));background:var(--surface-container);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-3)}.sidebar-user{display:flex;align-items:center;gap:var(--spacing-3);min-width:0}.user-avatar{width:36px;height:36px;border-radius:var(--radius-pill);background:var(--primary);color:var(--on-primary);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.user-info{display:flex;flex-direction:column;min-width:0}.user-name{font-size:.8125rem;font-weight:600;color:var(--on-surface);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.6875rem;color:var(--on-surface-variant)}.main-wrapper{flex:1;margin-left:280px;display:flex;flex-direction:column;min-height:100vh;transition:margin var(--transition-normal)}.top-header{position:sticky;top:0;z-index:var(--z-header);background:var(--surface);display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-6);min-height:60px;transition:background var(--transition-normal)}.header-spacer{flex:1}.mobile-menu-btn,.bottom-nav{display:none}.notif-wrapper,.notif-btn{position:relative}.notif-dot{position:absolute;top:8px;right:8px;width:9px;height:9px;border-radius:50%;background:var(--error);border:2px solid var(--surface)}.notif-dropdown{position:absolute;top:calc(100% + var(--spacing-3));right:0;width:380px;max-height:480px;overflow-y:auto;padding:var(--spacing-4);animation:slideUp .25s ease}.notif-header{padding-bottom:var(--spacing-3);margin-bottom:var(--spacing-3)}.notif-item{display:flex;gap:var(--spacing-3);padding:var(--spacing-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.notif-item:hover{background:var(--surface-container-high)}.notif-unread{background:var(--surface-container)}.notif-icon-badge{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.notif-icon-warning{background:var(--warning-container)}.notif-icon-success{background:var(--success-container)}.notif-icon-info{background:var(--info-container)}.notif-content{display:flex;flex-direction:column;gap:2px;min-width:0}.notif-title{font-size:.8125rem;font-weight:600;color:var(--on-surface)}.notif-message{font-size:.75rem;color:var(--on-surface-variant);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-time{font-size:.6875rem;color:var(--outline);margin-top:2px}.main-content{flex:1;padding:var(--spacing-6) var(--spacing-8);max-width:1280px;margin:0 auto;width:100%}.sidebar-overlay{display:none}@media(min-width:900px)and (max-width:1199px){.sidebar{width:240px}.main-wrapper{margin-left:240px}.main-content{padding:var(--spacing-5) var(--spacing-6)}}@media(max-width:899px){.sidebar{display:flex;transform:translate(-100%);box-shadow:var(--shadow-lg);width:280px}.sidebar.sidebar-open{transform:translate(0)}.sidebar-close-btn{display:flex}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:calc(var(--z-sidebar) - 1);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);animation:fadeIn .2s ease}.mobile-menu-btn{display:flex!important}.main-wrapper{margin-left:0}.hide-on-mobile{display:none!important}.top-header{padding:var(--spacing-2) var(--spacing-3)}.main-content{padding:var(--spacing-4) var(--spacing-4);padding-bottom:calc(72px + var(--spacing-4))}.notif-dropdown{width:min(380px,calc(100vw - var(--spacing-8)));right:calc(-1 * var(--spacing-2))}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--surface-container-low);border-top:1px solid var(--outline-variant);z-index:var(--z-header);padding-bottom:env(safe-area-inset-bottom,0px)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;text-decoration:none;color:var(--on-surface-variant);transition:color var(--transition-fast);padding:var(--spacing-2) 0;border-radius:0;-webkit-tap-highlight-color:transparent}.bottom-nav-item:hover,.bottom-nav-item-active{color:var(--primary)}.bottom-nav-item-active .bottom-nav-icon-wrap{background:#722f3726;border-radius:var(--radius-pill)}.dark .bottom-nav-item-active .bottom-nav-icon-wrap{background:#c48b9333}.bottom-nav-icon-wrap{position:relative;width:48px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-pill);transition:background var(--transition-fast)}.bottom-nav-label{font-size:.6875rem;font-weight:500;line-height:1;white-space:nowrap}.bottom-nav-badge{position:absolute;top:-2px;right:4px;background:var(--error);color:#fff;font-size:.5625rem;font-weight:700;min-width:16px;height:16px;border-radius:var(--radius-pill);display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--surface-container-low)}}@media(max-width:479px){.top-header{padding:var(--spacing-2) var(--spacing-2)}.main-content{padding:var(--spacing-3) var(--spacing-3);padding-bottom:calc(72px + var(--spacing-3))}.notif-dropdown{width:calc(100vw - var(--spacing-6));right:calc(-1 * var(--spacing-1))}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--surface);position:relative;overflow:hidden;padding:var(--spacing-6)}.login-bg-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 20% 50%,rgba(114,47,55,.06) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(74,37,0,.04) 0%,transparent 50%),radial-gradient(ellipse at 60% 80%,rgba(114,47,55,.03) 0%,transparent 50%)}.dark .login-bg-pattern{background:radial-gradient(ellipse at 20% 50%,rgba(196,139,147,.08) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(224,168,120,.05) 0%,transparent 50%)}.login-container{width:100%;max-width:420px;background:var(--surface-container-lowest);border-radius:var(--radius-xl);padding:var(--spacing-10) var(--spacing-8);box-shadow:var(--shadow-lg);position:relative;z-index:1}.login-brand{text-align:center;margin-bottom:var(--spacing-8)}.login-logo{width:64px;height:64px;border-radius:var(--radius-lg);background:var(--primary);color:var(--on-primary);display:inline-flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-4)}.login-title{font-size:1.5rem;font-weight:700;color:var(--primary);letter-spacing:var(--tracking-tight);margin-bottom:var(--spacing-1)}.login-subtitle{font-size:.875rem;color:var(--on-surface-variant)}.login-form{display:flex;flex-direction:column;gap:var(--spacing-5)}.password-wrapper{position:relative}.password-toggle{position:absolute;right:var(--spacing-3);top:50%;transform:translateY(-50%);background:none;border:none;color:var(--on-surface-variant);cursor:pointer;padding:var(--spacing-2);display:flex;align-items:center}.login-role-selector{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-3)}.login-submit{width:100%;margin-top:var(--spacing-2);position:relative}.login-loading{pointer-events:none;opacity:.7}.login-spinner{width:22px;height:22px;border:2.5px solid rgba(255,255,255,.3);border-top-color:var(--on-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-forgot{width:100%;justify-content:center}.login-footer{text-align:center;margin-top:var(--spacing-6)}@media(max-width:599px){.login-container{padding:var(--spacing-8) var(--spacing-5)}.login-role-selector{flex-direction:column;align-items:flex-start;gap:var(--spacing-2)}.login-role-selector .segmented-control{width:100%}}@media(max-width:479px){.login-page{padding:var(--spacing-4);align-items:flex-start;padding-top:var(--spacing-8)}.login-container{padding:var(--spacing-6) var(--spacing-4);border-radius:var(--radius-lg)}.login-brand{margin-bottom:var(--spacing-6)}.login-logo{width:56px;height:56px}.login-title{font-size:1.25rem}.login-form{gap:var(--spacing-4)}}.forgot-password-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--surface);position:relative;overflow:hidden;padding:var(--spacing-6)}.forgot-password-bg-pattern{position:absolute;top:0;right:0;width:600px;height:600px;background:radial-gradient(circle,var(--primary) 0%,transparent 70%);opacity:.05;border-radius:50%;pointer-events:none}.forgot-password-container{width:100%;max-width:480px;padding:var(--spacing-4);background:var(--surface);border-radius:var(--radius-lg);box-shadow:0 10px 40px #0000001a;position:relative;z-index:10}.forgot-password-brand{display:flex;flex-direction:column;align-items:center;margin-bottom:var(--spacing-6);text-align:center}.forgot-password-logo{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary) 0%,var(--tertiary) 100%);border-radius:var(--radius-full);color:#fff;margin-bottom:var(--spacing-3);box-shadow:0 4px 12px #722f3733}.forgot-password-title{font-size:28px;font-weight:700;color:var(--on-surface);margin:0;letter-spacing:-.5px}.forgot-password-subtitle{font-size:14px;color:var(--on-surface-variant);margin:var(--spacing-1) 0 0 0}.forgot-password-form{display:flex;flex-direction:column;gap:var(--spacing-4)}.forgot-password-submit{position:relative;margin-top:var(--spacing-2)}.forgot-password-submit:disabled{opacity:.6;cursor:not-allowed}.forgot-password-loading{color:transparent}.forgot-password-spinner{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.success-info{background:var(--primary-container);border-left:4px solid var(--primary);padding:var(--spacing-3);border-radius:var(--radius-md);margin-bottom:var(--spacing-4);width:100%;text-align:left}.success-info p{margin:0;font-size:13px}.forgot-password-footer{text-align:center;padding-top:var(--spacing-3);border-top:1px solid var(--outline-variant);margin-top:var(--spacing-4)}@media(max-width:600px){.forgot-password-page{padding:var(--spacing-4);align-items:flex-start;padding-top:var(--spacing-8)}.forgot-password-container{border-radius:var(--radius-md)}.forgot-password-bg-pattern{width:300px;height:300px}.form-header h2{font-size:1.125rem}.forgot-password-title{font-size:1.5rem}}@media(max-width:400px){.forgot-password-page{padding:var(--spacing-3);padding-top:var(--spacing-6)}}.reset-password-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--surface);position:relative;overflow:hidden;padding:var(--spacing-6)}.reset-password-bg-pattern{position:absolute;top:0;right:0;width:600px;height:600px;background:radial-gradient(circle,var(--primary) 0%,transparent 70%);opacity:.05;border-radius:50%;pointer-events:none}.reset-password-container{width:100%;max-width:480px;padding:var(--spacing-4);background:var(--surface);border-radius:var(--radius-lg);box-shadow:0 10px 40px #0000001a;position:relative;z-index:10}.reset-password-brand{display:flex;flex-direction:column;align-items:center;margin-bottom:var(--spacing-6);text-align:center}.reset-password-logo{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary) 0%,var(--tertiary) 100%);border-radius:var(--radius-full);color:#fff;margin-bottom:var(--spacing-3);box-shadow:0 4px 12px #722f3733}.reset-password-title{font-size:28px;font-weight:700;color:var(--on-surface);margin:0;letter-spacing:-.5px}.reset-password-subtitle{font-size:14px;color:var(--on-surface-variant);margin:var(--spacing-1) 0 0 0}.form-header{margin-bottom:var(--spacing-5);text-align:center}.form-header h2{font-size:20px;font-weight:600;color:var(--on-surface);margin:0 0 var(--spacing-2) 0}.form-header p{margin:0;font-size:14px;line-height:1.5}.back-button{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);margin-bottom:var(--spacing-4);background:transparent;border:1px solid var(--outline);border-radius:var(--radius-md);color:var(--primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.back-button:hover{background:var(--primary-container);border-color:var(--primary)}.back-button:active{transform:scale(.98)}.reset-password-form{display:flex;flex-direction:column;gap:var(--spacing-4)}.input-group label{font-size:14px;font-weight:500;color:var(--on-surface)}.input-field{padding:var(--spacing-3);border:1px solid var(--outline);border-radius:var(--radius-md);font-size:16px;color:var(--on-surface);background:var(--surface);transition:all .2s ease;font-family:inherit}.input-field:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #722f371a}.input-field:disabled{background:var(--surface-container-high);color:var(--on-surface-variant);cursor:not-allowed}.input-field::placeholder{color:var(--on-surface-variant)}.password-wrapper{position:relative;display:flex;align-items:center}.password-wrapper .input-field{width:100%;padding-right:44px}.password-toggle{position:absolute;right:var(--spacing-3);background:none;border:none;color:var(--on-surface-variant);cursor:pointer;padding:var(--spacing-2);display:flex;align-items:center;justify-content:center;transition:color .2s ease}.password-toggle:hover{color:var(--on-surface)}.password-toggle:active{transform:scale(.95)}.password-hint{font-size:12px;color:var(--on-surface-variant);margin:var(--spacing-1) 0 0 0}.reset-password-submit{position:relative;margin-top:var(--spacing-2)}.reset-password-submit:disabled{opacity:.6;cursor:not-allowed}.reset-password-loading{color:transparent}.reset-password-spinner{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}.success-message-container{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-4) 0}.success-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--success-container, #e8f5e9);border-radius:var(--radius-full);font-size:32px;color:var(--success, #2e7d32);margin-bottom:var(--spacing-4);animation:scale-in .4s ease}@keyframes scale-in{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.success-title{font-size:20px;font-weight:600;color:var(--on-surface);margin:0 0 var(--spacing-2) 0}.success-text{font-size:15px;color:var(--on-surface-variant);line-height:1.6;margin:0 0 var(--spacing-4) 0}.error-state-container{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-4) 0}.error-icon{font-size:48px;margin-bottom:var(--spacing-3)}.error-state-container h2{font-size:20px;font-weight:600;color:var(--on-surface);margin:0 0 var(--spacing-2) 0}.error-state-container p{font-size:15px;color:var(--on-surface-variant);margin:0 0 var(--spacing-4) 0}.reset-password-footer{text-align:center;padding-top:var(--spacing-3);border-top:1px solid var(--outline-variant);margin-top:var(--spacing-4)}.link-button{background:none;border:none;color:var(--primary);text-decoration:none;cursor:pointer;font-weight:500;padding:0;font-size:inherit;transition:opacity .2s ease}.link-button:hover{opacity:.8;text-decoration:underline}.link-button:active{opacity:.6}.error-message{border-radius:var(--radius-md);animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.animate-slide-up{animation:slide-up .4s ease}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:600px){.reset-password-page{padding:var(--spacing-4);align-items:flex-start;padding-top:var(--spacing-8)}.reset-password-container{border-radius:var(--radius-md)}.reset-password-bg-pattern{width:300px;height:300px}.form-header h2{font-size:1.125rem}.reset-password-title{font-size:1.5rem}}@media(max-width:400px){.reset-password-page{padding:var(--spacing-3);padding-top:var(--spacing-6)}}.shift-overview-page{display:flex;flex-direction:column;gap:var(--spacing-4);height:100%}.shift-overview-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-4);flex-wrap:wrap}.shift-overview-controls{display:flex;align-items:center;gap:var(--spacing-3);flex-wrap:wrap}.week-nav{display:flex;align-items:center;gap:var(--spacing-2);background:var(--surface-container);border-radius:var(--radius-lg);padding:var(--spacing-1) var(--spacing-2)}.week-label{min-width:240px;text-align:center;color:var(--on-surface);font-weight:500}.shift-overview-error{padding:var(--spacing-3);background:var(--error-container);color:var(--on-error-container);border-radius:var(--radius-md);font-size:.875rem}.shift-type-legend{display:flex;gap:var(--spacing-2);flex-wrap:wrap;align-items:center}.legend-chip{display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--surface-container);border-radius:var(--radius-full);font-size:.8rem;color:var(--on-surface)}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-dot--open{background:var(--outline);border:2px dashed var(--on-surface-variant)}.so-desktop-view{display:flex;flex-direction:column;flex:1}.shift-overview-grid-wrapper{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--outline-variant);background:var(--surface);flex:1}.shift-overview-grid{min-width:900px;display:flex;flex-direction:column}.so-header-row{display:flex;background:var(--surface-container);border-bottom:2px solid var(--outline-variant);position:sticky;top:0;z-index:10}.so-header-cell{padding:var(--spacing-3) var(--spacing-2);text-align:center;font-weight:600;font-size:.8rem;color:var(--on-surface);text-transform:uppercase;letter-spacing:.05em}.so-header-cell.so-today{background:var(--primary-container);color:var(--on-primary-container)}.so-employee-col{min-width:200px;width:200px;flex-shrink:0;text-align:left!important;padding-left:var(--spacing-4)!important;border-right:1px solid var(--outline-variant)}.so-day-col{flex:1;min-width:110px;border-right:1px solid var(--outline-variant)}.so-day-col:last-child{border-right:none}.so-day-name{font-size:.75rem;font-weight:700}.so-day-date{font-size:.8rem;font-weight:400;opacity:.8}.so-open-badge{margin-top:2px;font-size:.7rem;padding:1px 6px;background:var(--error-container);color:var(--on-error-container);border-radius:var(--radius-full);display:inline-block}.so-row{display:flex;border-bottom:1px solid var(--outline-variant);min-height:64px}.so-row:last-child{border-bottom:none}.so-row:hover{background:var(--surface-container-low)}.so-open-row{background:var(--surface-container-lowest, var(--surface-dim))}.so-open-row:hover{background:var(--surface-container)}.so-cell{padding:var(--spacing-2);display:flex;align-items:flex-start;flex-direction:column;gap:4px;border-right:1px solid var(--outline-variant)}.so-cell:last-child{border-right:none}.so-cell.so-today-cell{background:color-mix(in srgb,var(--primary) 5%,transparent)}.so-cell--empty{background:transparent}.so-employee-col.so-cell{flex-direction:row;align-items:center;gap:var(--spacing-2);min-width:200px;width:200px}.so-avatar{width:34px;height:34px;border-radius:50%;background:var(--primary-container);color:var(--on-primary-container);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.so-avatar--open{background:var(--surface-container-high);color:var(--on-surface-variant);border:2px dashed var(--outline);font-size:1rem}.so-emp-info{display:flex;flex-direction:column;gap:2px;min-width:0}.so-emp-name{font-size:.875rem;font-weight:500;color:var(--on-surface);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.so-emp-role{font-size:.75rem}.so-shift-chip{width:100%;padding:4px 6px;border-radius:var(--radius-sm);background:var(--surface-container);border-left:3px solid var(--primary);display:flex;flex-direction:column;gap:1px}.so-shift-chip--open{border-left-color:var(--outline);background:var(--surface-dim);opacity:.85;border-style:dashed;border-left-style:dashed}.so-shift-time{font-size:.75rem;font-weight:600;color:var(--on-surface);white-space:nowrap}.so-shift-type{font-size:.7rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.so-loading,.so-empty{padding:var(--spacing-8);text-align:center;color:var(--on-surface-variant);font-size:.875rem;grid-column:1 / -1}.so-mobile-view{display:none;flex-direction:column;gap:var(--spacing-3)}.so-day-card{background:var(--surface);border:1px solid var(--outline-variant);border-radius:var(--radius-lg);overflow:hidden}.so-day-card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-3) var(--spacing-4);background:var(--surface-container);border-bottom:1px solid var(--outline-variant)}.so-day-card-header.so-today-header{background:var(--primary-container)}.so-day-card-header.so-today-header .so-day-card-name,.so-day-card-header.so-today-header .so-day-card-date{color:var(--on-primary-container)}.so-day-card-name{font-size:.9rem;font-weight:700;color:var(--on-surface);text-transform:uppercase;letter-spacing:.05em}.so-day-card-date{font-size:.8rem;color:var(--on-surface-variant);margin-top:1px}.so-day-card-meta{display:flex;align-items:center;gap:var(--spacing-2)}.so-day-count{font-size:.75rem;padding:2px 8px;background:var(--primary);color:var(--on-primary);border-radius:var(--radius-full)}.so-day-open-badge{font-size:.75rem;padding:2px 8px;background:var(--error-container);color:var(--on-error-container);border-radius:var(--radius-full)}.so-day-card-body{display:flex;flex-direction:column}.so-mobile-shift-row{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-bottom:1px solid var(--outline-variant)}.so-mobile-shift-row:last-child{border-bottom:none}.so-mobile-shift-row--open{background:var(--surface-container-lowest, var(--surface-dim));opacity:.85}.so-mobile-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-container);color:var(--on-primary-container);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.so-mobile-avatar--open{background:var(--surface-container-high);color:var(--on-surface-variant);border:2px dashed var(--outline)}.so-mobile-shift-info{flex:1;min-width:0}.so-mobile-shift-name{font-size:.875rem;font-weight:500;color:var(--on-surface);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.so-mobile-shift-time{font-size:.8rem;color:var(--on-surface-variant);margin-top:1px}.so-mobile-shift-type-pill{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);background:var(--surface-container-high);white-space:nowrap;flex-shrink:0}.so-day-card-empty{padding:var(--spacing-4);text-align:center;color:var(--on-surface-variant);font-size:.8rem}.so-mobile-loading,.so-mobile-empty{padding:var(--spacing-8);text-align:center;color:var(--on-surface-variant);font-size:.875rem}@media(max-width:767px){.so-desktop-view{display:none}.so-mobile-view{display:flex}.shift-overview-header{flex-direction:column;gap:var(--spacing-3)}.shift-overview-controls{width:100%;justify-content:space-between}.week-label{min-width:0;flex:1;font-size:.85rem}.week-nav{flex:1}.shift-type-legend{gap:var(--spacing-1)}.legend-chip{font-size:.75rem;padding:3px 8px}}@media(min-width:768px)and (max-width:1024px){.week-label{min-width:180px;font-size:.9rem}.so-employee-col{min-width:160px;width:160px}.so-day-col{min-width:90px}}.dashboard{display:flex;flex-direction:column;gap:var(--spacing-6)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-4);flex-wrap:wrap}.page-header h1{color:var(--primary)}.dash-warning{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-5) var(--spacing-6);background:var(--tertiary-container, var(--warning-container));border-radius:var(--radius-xl)}.dash-warning-icon{width:44px;height:44px;border-radius:var(--radius-md);background:#4a250026;color:var(--tertiary, var(--warning));display:flex;align-items:center;justify-content:center;flex-shrink:0}.dark .dash-warning-icon{background:#e0a87826}.dash-warning-content{flex:1;display:flex;flex-direction:column;gap:2px}.dash-warning-title{font-size:.9375rem;font-weight:600;color:var(--on-tertiary-fixed, var(--warning))}.dash-warning-detail{font-size:.8125rem;color:var(--on-tertiary-fixed, var(--warning));opacity:.8}.dash-reminder{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-5) var(--spacing-6);background:var(--primary-container);color:var(--on-primary);border-radius:var(--radius-xl)}.dash-reminder>div{display:flex;flex-direction:column;gap:2px}.dash-kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--spacing-5)}.dash-kpi-card{display:flex;flex-direction:column;gap:var(--spacing-1)}.dash-kpi-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-2)}.dash-kpi-primary{background:#722f371a;color:var(--primary)}.dash-kpi-info{background:var(--info-container);color:var(--info)}.dash-kpi-tertiary{background:var(--tertiary-container);color:var(--tertiary)}.dash-kpi-secondary{background:var(--secondary-container);color:var(--secondary)}.dark .dash-kpi-primary{background:#c48b9326}.dash-kpi-body{display:flex;flex-direction:column;gap:2px}.dash-kpi-value{font-size:1.75rem;font-weight:700;letter-spacing:var(--tracking-tight);color:var(--on-surface);line-height:1.2}.dash-columns{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-5)}.dash-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-4)}.dash-shift-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.dash-shift-item{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);background:var(--surface-container-low);transition:background var(--transition-fast)}.dash-shift-item:hover{background:var(--surface-container)}.dash-shift-item.shift-open{background:var(--warning-container)}.dash-shift-time{display:flex;flex-direction:column;align-items:center;min-width:52px}.dash-shift-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.dash-request-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.dash-request-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);background:var(--surface-container-low);transition:background var(--transition-fast)}.dash-request-item:hover{background:var(--surface-container)}.dash-request-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.dash-request-actions{display:flex;gap:var(--spacing-1)}.empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-3);padding:var(--spacing-8);color:var(--on-surface-variant);text-align:center}.empty-icon{opacity:.3}@media(max-width:899px){.dash-columns{grid-template-columns:1fr}.dash-kpi-grid{grid-template-columns:repeat(2,1fr)}.dash-warning{flex-wrap:wrap}.dash-warning .btn{width:100%;justify-content:center}}@media(max-width:599px){.dash-kpi-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-3)}.dash-kpi-value{font-size:1.375rem}.dash-shift-item{gap:var(--spacing-2)}.dash-shift-time{min-width:44px}.dash-request-item{gap:var(--spacing-2)}.dash-request-actions{flex-shrink:0}.dash-section-header{flex-wrap:wrap;gap:var(--spacing-2)}}@media(max-width:399px){.dash-kpi-grid{grid-template-columns:1fr}.empty-state{padding:var(--spacing-5)}}.schedule-page{display:flex;flex-direction:column;gap:var(--spacing-5)}.schedule-actions{display:flex;gap:var(--spacing-2);flex-wrap:wrap}.schedule-controls{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-4);flex-wrap:wrap}.schedule-nav{display:flex;align-items:center;gap:var(--spacing-3)}.schedule-grid-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.schedule-grid{display:grid;grid-template-columns:180px repeat(7,1fr);min-width:900px;gap:0}.schedule-header-cell{padding:var(--spacing-3) var(--spacing-2);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-1);background:var(--surface-container);position:sticky;top:0;z-index:2}.schedule-header-cell.schedule-name-col{text-align:left;align-items:flex-start;padding-left:var(--spacing-4)}.schedule-today-header{background:var(--primary);color:var(--on-primary);border-radius:var(--radius-md) var(--radius-md) 0 0}.schedule-day-name{text-transform:uppercase}.schedule-day-num{font-size:1.25rem;font-weight:700;color:var(--on-surface);width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-pill)}.schedule-today-num{background:var(--on-primary);color:var(--primary)}.schedule-today-header .schedule-day-name{color:var(--on-primary)}.schedule-name-cell{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);background:var(--surface-container-low)}.schedule-name-col{position:sticky;left:0;z-index:1}.schedule-avatar{width:32px;height:32px;border-radius:var(--radius-pill);background:var(--primary);color:var(--on-primary);display:flex;align-items:center;justify-content:center;font-size:.6875rem;font-weight:700;flex-shrink:0}.schedule-avatar-open{background:var(--warning);color:var(--on-surface)}.schedule-emp-info{display:flex;flex-direction:column;min-width:0}.schedule-open-row{background:var(--warning-container)}.schedule-cell{padding:var(--spacing-2);min-height:64px;display:flex;flex-direction:column;gap:var(--spacing-1);background:var(--surface-container-lowest);transition:background var(--transition-fast)}.schedule-cell:hover{background:var(--surface-container)}.shift-card{padding:var(--spacing-2);border-radius:var(--radius-sm);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast);display:flex;flex-direction:column;gap:1px}.shift-card:hover{transform:scale(1.03);box-shadow:var(--shadow-sm)}.shift-card-normal{background:#722f371f;color:var(--primary)}.dark .shift-card-normal{background:#c48b9326}.shift-card-late{background:#5d5f5b1a;color:var(--secondary)}.shift-card-open{background:var(--warning-container);color:var(--warning);border:1px dashed var(--warning)}.shift-card-time{font-size:.6875rem;font-weight:600;letter-spacing:.02em}.shift-card-site{font-size:.625rem;opacity:.7}.schedule-desktop-only{display:block}.schedule-mobile-only{display:none}.schedule-day-tabs{display:flex;gap:var(--spacing-1);overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:var(--spacing-1);scrollbar-width:none}.schedule-day-tabs::-webkit-scrollbar{display:none}.schedule-day-tab{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--spacing-2) var(--spacing-3);border:none;border-radius:var(--radius-lg);background:var(--surface-container);color:var(--on-surface-variant);cursor:pointer;font-family:var(--font-family);transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;min-width:48px}.schedule-day-tab:hover{background:var(--surface-container-high);color:var(--on-surface)}.schedule-day-tab.active{background:var(--primary);color:var(--on-primary)}.schedule-day-tab.today:not(.active){background:var(--surface-container-high)}.schedule-day-tab.today:not(.active) .sdt-num{color:var(--primary);font-weight:700}.sdt-name{font-size:.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.sdt-num{font-size:1.125rem;font-weight:700;line-height:1.1}.schedule-mobile-day-label{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-3);padding:var(--spacing-1) 0}.schedule-mobile-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.schedule-mobile-item{display:flex;flex-direction:column;gap:var(--spacing-3);padding:var(--spacing-4)}.schedule-mobile-emp{display:flex;align-items:center;gap:var(--spacing-3)}.schedule-mobile-shifts{display:flex;flex-direction:column;gap:var(--spacing-2)}.schedule-mobile-shift{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);flex-wrap:wrap}.schedule-mobile-shift.shift-card-normal{background:#722f3714;color:var(--primary)}.dark .schedule-mobile-shift.shift-card-normal{background:#c48b931f}.schedule-mobile-shift.shift-card-late{background:#5d5f5b14;color:var(--secondary)}.schedule-mobile-shift.shift-card-open{background:var(--warning-container);color:var(--warning);border:1px dashed var(--warning)}.schedule-mobile-shift-time{display:flex;align-items:center;gap:var(--spacing-2)}.emp-schedule-tabs{display:flex;gap:var(--spacing-2);background:var(--surface-container-high);border-radius:var(--radius-xl);padding:var(--spacing-1)}.emp-schedule-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);border:none;border-radius:var(--radius-lg);background:transparent;color:var(--on-surface-variant);font-family:var(--font-family);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent}.emp-schedule-tab:hover{background:var(--surface-container-highest);color:var(--on-surface)}.emp-schedule-tab.active{background:var(--surface-container-lowest);color:var(--primary);box-shadow:var(--shadow-sm);font-weight:600}.planned-shifts{display:flex;flex-direction:column;gap:var(--spacing-5)}.planned-controls{display:flex;align-items:center;justify-content:center;gap:var(--spacing-4);flex-wrap:wrap;position:relative}.planned-controls .schedule-nav{position:absolute;left:0;right:0;display:flex;justify-content:space-between;pointer-events:none}.planned-controls .schedule-nav button{pointer-events:auto}.planned-controls>:not(.schedule-nav){position:relative;z-index:1}.planned-week-desktop{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--spacing-2)}.planned-week-mobile{display:none}.planned-week-col{display:flex;flex-direction:column;gap:var(--spacing-2);padding:var(--spacing-3);border-radius:var(--radius-lg);background:var(--surface-container-low);min-height:100px}.planned-week-col.today{background:#722f370f;outline:2px solid var(--primary);outline-offset:-2px}.dark .planned-week-col.today{background:#c48b9314}.planned-week-header{display:flex;flex-direction:column;align-items:center;gap:2px;padding-bottom:var(--spacing-2);border-bottom:1px solid var(--outline-variant)}.planned-week-num{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-pill);font-size:.9375rem;font-weight:700;color:var(--on-surface)}.planned-week-num.today-num{background:var(--primary);color:var(--on-primary)}.planned-week-shifts{display:flex;flex-direction:column;gap:var(--spacing-1)}.planned-free{font-size:.75rem;color:var(--outline);text-align:center;padding:var(--spacing-2) 0}.planned-shift-pill{display:inline-flex;align-items:center;gap:4px;padding:3px var(--spacing-2);border-radius:var(--radius-pill);font-size:.6875rem;font-weight:600;white-space:nowrap}.planned-shift-pill.normal{background:#722f371f;color:var(--primary)}.dark .planned-shift-pill.normal{background:#c48b9326}.planned-shift-pill.late{background:#5d5f5b1f;color:var(--secondary)}.planned-month{padding:var(--spacing-4)}.planned-month-header{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:var(--spacing-2);gap:2px}.planned-month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.planned-month-day{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--spacing-2) var(--spacing-1);border-radius:var(--radius-md);min-height:48px;background:var(--surface-container-lowest);transition:background var(--transition-fast)}.planned-month-day.today{background:#722f3714;outline:2px solid var(--primary);outline-offset:-2px}.planned-month-day.has-shift{background:var(--surface-container)}.planned-month-day-num{font-size:.8125rem;font-weight:500;color:var(--on-surface);line-height:1}.planned-month-day.today .planned-month-day-num{color:var(--primary);font-weight:700}.planned-month-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.planned-month-dot.normal{background:var(--primary)}.planned-month-dot.late{background:var(--secondary)}.planned-month-legend{display:flex;gap:var(--spacing-4);margin-top:var(--spacing-4);padding-top:var(--spacing-3);border-top:1px solid var(--outline-variant)}.planned-legend-item{display:flex;align-items:center;gap:var(--spacing-2);font-size:.8125rem;color:var(--on-surface-variant)}.planned-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.planned-list-item{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-4);flex-wrap:wrap}.planned-list-date{min-width:100px}.planned-list-info{flex:1;display:flex;align-items:center;gap:var(--spacing-3);flex-wrap:wrap;min-width:0}.avail-planner{display:flex;flex-direction:column;gap:var(--spacing-5)}.avail-month-nav{display:flex;align-items:center;justify-content:center;gap:var(--spacing-3);position:relative}.avail-month-nav button{position:absolute}.avail-month-nav button:first-child{left:0}.avail-month-nav button:last-child{right:0}.avail-month-nav>span{position:relative;z-index:1}.avail-legend-row{display:flex;gap:var(--spacing-4);flex-wrap:wrap;justify-content:center}.avail-legend-item{display:flex;align-items:center;gap:var(--spacing-2);font-size:.8125rem;color:var(--on-surface-variant)}.avail-dot{width:14px;height:14px;border-radius:var(--radius-sm);flex-shrink:0}.avail-green{background:var(--success)}.avail-red{background:var(--error)}.avail-blue{background:var(--info)}.avail-calendar{padding:var(--spacing-4)}.avail-cal-header{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:var(--spacing-2);gap:2px}.avail-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.avail-cal-empty{min-height:44px}.avail-cal-day{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:44px;border:none;border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-family);transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;position:relative;padding:var(--spacing-1)}.avail-cal-day:hover:not(:disabled){opacity:.85;transform:scale(1.05)}.avail-cal-day:disabled{opacity:.35;cursor:default}.avail-cal-day.avail-green{background:#2d6a4f33;color:var(--success)}.avail-cal-day.avail-red{background:#9b233533;color:var(--error)}.avail-cal-day.avail-blue{background:#3a6b9f33;color:var(--info)}.dark .avail-cal-day.avail-green{background:#68c98a33}.dark .avail-cal-day.avail-red{background:#e0809033}.dark .avail-cal-day.avail-blue{background:#7ab0e033}.avail-today{outline:2px solid var(--primary);outline-offset:-2px}.avail-past{opacity:.3!important}.avail-cal-day-num{font-size:.875rem;font-weight:600;line-height:1}.avail-state-btn{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-3);border:none;border-radius:var(--radius-pill);font-family:var(--font-family);font-size:.75rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-tap-highlight-color:transparent}.avail-state-btn.avail-green{background:#2d6a4f26;color:var(--success)}.avail-state-btn.avail-red{background:#9b233526;color:var(--error)}.avail-state-btn.avail-blue{background:#3a6b9f26;color:var(--info)}.avail-state-btn:hover{opacity:.8}.avail-state-btn-sm{font-size:.6875rem;padding:2px var(--spacing-2)}.avail-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--spacing-4);animation:fadeIn .2s ease}.avail-popup{width:100%;max-width:400px;max-height:80vh;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-3);animation:slideUp .25s ease}.avail-popup-shift{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-3);padding:var(--spacing-3) 0;border-bottom:1px solid var(--outline-variant)}.avail-popup-shift:last-of-type{border-bottom:none}.avail-popup-actions{display:flex;gap:var(--spacing-2);justify-content:flex-end;margin-top:var(--spacing-2)}.avail-weekday-section{display:flex;flex-direction:column}.avail-weekday-list{display:flex;flex-direction:column;gap:var(--spacing-1)}.avail-weekday-row{display:flex;flex-direction:column;gap:var(--spacing-2);padding:var(--spacing-3) 0;border-bottom:1px solid var(--outline-variant)}.avail-weekday-row:last-child{border-bottom:none}.avail-weekday-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-3)}.avail-weekday-shifts{display:flex;flex-direction:column;gap:var(--spacing-2);padding-left:var(--spacing-4)}.avail-weekday-shift{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);background:var(--surface-container-low)}.avail-hours-section{display:flex;flex-direction:column}.avail-hours-row{display:flex;gap:var(--spacing-4);flex-wrap:wrap}@media(max-width:899px){.schedule-grid{grid-template-columns:140px repeat(7,1fr)}.schedule-actions{width:100%;justify-content:flex-start}.schedule-controls{gap:var(--spacing-3)}.planned-week-desktop{grid-template-columns:repeat(7,1fr)}}@media(max-width:699px){.schedule-desktop-only{display:none!important}.schedule-mobile-only{display:flex;flex-direction:column;gap:var(--spacing-4)}.schedule-controls{flex-direction:column;align-items:flex-start;gap:var(--spacing-3)}.schedule-nav{width:100%;justify-content:space-between}.schedule-actions{flex-wrap:wrap;gap:var(--spacing-2)}.schedule-actions .btn{flex:1;min-width:90px;justify-content:center}.emp-schedule-tab{font-size:.8125rem;padding:var(--spacing-2) var(--spacing-3);gap:var(--spacing-1)}.planned-week-desktop{display:none}.planned-week-mobile,.planned-mobile-day{display:flex;flex-direction:column;gap:var(--spacing-3)}.planned-controls{flex-direction:column;align-items:flex-start;gap:var(--spacing-3)}.planned-controls .schedule-nav{width:100%;justify-content:space-between}.planned-month-day{min-height:40px;padding:var(--spacing-1)}.planned-month-day-num{font-size:.75rem}.planned-list-item{gap:var(--spacing-3)}.planned-list-date{min-width:80px}.avail-cal-day{min-height:38px}.avail-cal-day-num{font-size:.8125rem}.avail-weekday-shift{flex-wrap:wrap}.avail-hours-row{flex-direction:column;gap:var(--spacing-3)}}@media(max-width:479px){.emp-schedule-tab span{display:none}.emp-schedule-tab{gap:0}.schedule-day-tab{min-width:40px;padding:var(--spacing-2)}.sdt-num{font-size:1rem}.schedule-mobile-item{padding:var(--spacing-3)}.planned-month-day{min-height:34px}.planned-month-dot{width:6px;height:6px}.avail-cal-day{min-height:34px;border-radius:var(--radius-sm)}.avail-cal-day-num{font-size:.75rem}.avail-state-btn{font-size:.6875rem;padding:2px var(--spacing-2)}.avail-popup{max-width:100%}.avail-popup-shift{flex-wrap:wrap}}@media(max-width:399px){.emp-schedule-tabs{gap:var(--spacing-1)}.avail-legend-row{gap:var(--spacing-2)}.avail-legend-item{font-size:.75rem}}.sched-week-controls{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-3);flex-wrap:wrap}.sched-week-nav{display:flex;align-items:center;gap:var(--spacing-3);flex-wrap:wrap}.sched-nav-pills{display:flex;align-items:center;gap:var(--spacing-2);background:var(--surface-container);border-radius:var(--radius-lg);padding:var(--spacing-1) var(--spacing-2)}.sched-week-label{min-width:220px;text-align:center;color:var(--on-surface);font-weight:500}.sched-week-meta{display:flex;align-items:center;gap:var(--spacing-3)}.sched-desktop-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0;border:1px solid var(--outline-variant);border-radius:var(--radius-lg);background:var(--surface);overflow:hidden}.sched-day-col{display:flex;flex-direction:column;border-right:1px solid var(--outline-variant);min-width:0}.sched-day-col:last-child{border-right:none}.sched-today-col{background:color-mix(in srgb,var(--primary) 4%,transparent)}.sched-day-header{padding:var(--spacing-2) var(--spacing-2) var(--spacing-1);background:var(--surface-container);border-bottom:2px solid var(--outline-variant);text-align:center;display:flex;flex-direction:column;align-items:center;gap:2px}.sched-today-header{background:var(--primary-container)}.sched-today-header .sched-day-name,.sched-today-header .sched-day-date{color:var(--on-primary-container)}.sched-day-name{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--on-surface)}.sched-day-date{font-size:.8rem;color:var(--on-surface-variant)}.sched-open-badge{font-size:.65rem;padding:1px 6px;background:var(--error-container);color:var(--on-error-container);border-radius:var(--radius-full)}.sched-day-body{display:flex;flex-direction:column;gap:4px;padding:var(--spacing-2);min-height:60px}.sched-cell-loading,.sched-cell-empty{font-size:.8rem;color:var(--on-surface-variant);text-align:center;padding:var(--spacing-2) 0;opacity:.5}.sched-shift-card{padding:4px 6px;border-radius:var(--radius-sm);background:var(--surface-container);border-left:3px solid var(--primary);display:flex;flex-direction:column;gap:1px;overflow:hidden}.sched-shift-card--open{opacity:.75;border-left-style:dashed;background:var(--surface-container-low)}.sched-shift-time{font-size:.7rem;font-weight:700;color:var(--on-surface);white-space:nowrap}.sched-shift-emp{font-size:.7rem;color:var(--on-surface-variant);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sched-open-tag{color:var(--error);font-style:normal;font-weight:500}.sched-shift-type{font-size:.65rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sched-count-badge{font-size:.7rem;padding:1px 7px;background:var(--primary);color:var(--on-primary);border-radius:var(--radius-full)}.sched-mobile-days{display:none;flex-direction:column;gap:var(--spacing-3)}.sched-mobile-day-card{background:var(--surface);border:1px solid var(--outline-variant);border-radius:var(--radius-lg);overflow:hidden}.sched-mobile-day-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-3) var(--spacing-4);background:var(--surface-container);border-bottom:1px solid var(--outline-variant)}.sched-mobile-loading,.sched-mobile-empty{padding:var(--spacing-4);text-align:center;color:var(--on-surface-variant);font-size:.875rem}.sched-mobile-shift{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-bottom:1px solid var(--outline-variant);border-left:3px solid var(--primary)}.sched-mobile-shift:last-child{border-bottom:none}.sched-mobile-shift-left{display:flex;flex-direction:column;gap:2px;min-width:0}.sched-shift-type-pill{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0}@media(max-width:767px){.sched-desktop-grid{display:none}.sched-mobile-days{display:flex}.sched-week-controls{flex-direction:column;align-items:flex-start;gap:var(--spacing-3)}.sched-week-nav,.sched-week-meta{width:100%;justify-content:space-between}.sched-week-label{min-width:0;flex:1;font-size:.85rem}.sched-nav-pills{flex:1}}@media(min-width:768px)and (max-width:1100px){.sched-week-label{min-width:160px;font-size:.85rem}.sched-shift-time,.sched-shift-emp{font-size:.65rem}}.admin-schedule-container{max-width:1400px;margin:0 auto;padding:var(--spacing-5);display:flex;flex-direction:column;gap:var(--spacing-6)}.admin-schedule-header{background:var(--surface-container-lowest);padding:var(--spacing-7) var(--spacing-7);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.admin-schedule-header h1{margin:0 0 var(--spacing-2) 0;font-size:1.75rem;font-weight:700;color:var(--on-surface);letter-spacing:var(--tracking-tight)}.admin-schedule-header p{margin:0;color:var(--on-surface-variant);font-size:.875rem}.error-banner{display:flex;align-items:center;gap:var(--spacing-3);background:var(--error-container);border-left:4px solid var(--error);padding:var(--spacing-4) var(--spacing-5);border-radius:var(--radius-md);color:var(--on-error-container)}.error-banner svg{flex-shrink:0}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-5);color:var(--on-surface-variant)}.spinner{width:40px;height:40px;border:4px solid var(--surface-container-highest);border-top:4px solid var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.schedule-generator{background:var(--surface-container-lowest);border-radius:var(--radius-xl);padding:var(--spacing-7);box-shadow:var(--shadow-sm)}.week-navigation{display:flex;align-items:center;justify-content:center;gap:var(--spacing-5);margin-bottom:var(--spacing-7);padding-bottom:var(--spacing-5);border-bottom:1px solid var(--outline-variant)}.week-navigation .btn-icon{color:var(--primary)}.week-label{font-size:1rem;font-weight:600;color:var(--on-surface);min-width:200px;text-align:center}.availability-matrix{margin-bottom:var(--spacing-7);overflow-x:auto;-webkit-overflow-scrolling:touch}.matrix-header,.matrix-row{display:grid;grid-template-columns:200px repeat(7,1fr);gap:1px;background:var(--outline-variant);margin-bottom:1px}.matrix-cell{background:var(--surface-container-lowest);padding:var(--spacing-3);display:flex;align-items:center;justify-content:center;min-height:60px;font-size:.8125rem;color:var(--on-surface)}.header-cell{background:var(--primary);color:var(--on-primary);font-weight:600;padding:var(--spacing-4) var(--spacing-3)}.employee-cell{background:var(--surface-container-low);flex-direction:column;align-items:flex-start;justify-content:center;gap:var(--spacing-1);padding:var(--spacing-3)}.employee-name{font-weight:600;color:var(--on-surface)}.employee-hours{font-size:.75rem;color:var(--outline)}.day-name{font-size:.75rem;font-weight:600;color:var(--on-primary)}.day-date{font-size:.875rem;font-weight:700;color:var(--on-primary)}.availability-cell{display:flex;align-items:center;justify-content:center;position:relative}.availability-badge{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.875rem}.availability-legend{display:flex;gap:var(--spacing-7);margin-bottom:var(--spacing-7);padding:var(--spacing-5);background:var(--surface-container-low);border-radius:var(--radius-lg);flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:var(--spacing-3);font-size:.875rem;color:var(--on-surface)}.legend-color{width:20px;height:20px;border-radius:var(--radius-sm)}.action-buttons{display:flex;gap:var(--spacing-3);margin-bottom:var(--spacing-7);justify-content:center;flex-wrap:wrap}.info-box{background:var(--info-container);border-left:4px solid var(--info);padding:var(--spacing-5);border-radius:var(--radius-md);margin-top:var(--spacing-7)}.info-box h3{margin:0 0 var(--spacing-4) 0;color:var(--on-info-container);font-size:1rem;font-weight:600}.info-box ul{margin:0;padding-left:var(--spacing-5);list-style:none}.info-box li{margin-bottom:var(--spacing-3);color:var(--on-surface);font-size:.875rem;line-height:1.5;padding-left:var(--spacing-2)}.info-box li:last-child{margin-bottom:0}.schedule-preview{background:var(--surface-container-lowest);border-radius:var(--radius-xl);padding:var(--spacing-7);box-shadow:var(--shadow-sm)}.schedule-preview h2{margin:0 0 var(--spacing-7) 0;font-size:1.375rem;font-weight:700;color:var(--on-surface);letter-spacing:var(--tracking-tight)}.preview-table{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:var(--spacing-7)}.preview-table table{width:100%;border-collapse:collapse}.preview-table th{background:var(--primary);color:var(--on-primary);padding:var(--spacing-4);text-align:left;font-weight:600;font-size:.875rem}.preview-table td{padding:var(--spacing-3) var(--spacing-4);border-bottom:1px solid var(--outline-variant);font-size:.875rem;color:var(--on-surface)}.preview-table tr:hover td{background:var(--surface-container-low)}.preview-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-5);margin-bottom:var(--spacing-7);padding:var(--spacing-5);background:var(--surface-container-low);border-radius:var(--radius-lg)}.stat-item{display:flex;flex-direction:column;gap:var(--spacing-2)}.stat-label{font-size:.8125rem;color:var(--on-surface-variant);font-weight:600}.stat-value{font-size:1.5rem;font-weight:700;color:var(--primary);letter-spacing:var(--tracking-tight)}.preview-actions{display:flex;gap:var(--spacing-3);justify-content:center;flex-wrap:wrap;padding-top:var(--spacing-5);border-top:1px solid var(--outline-variant)}.override-hint{font-size:.75rem;color:var(--outline);text-align:center;margin-bottom:var(--spacing-4);font-style:italic}.matrix-mobile{display:none}@media(max-width:1024px){.matrix-header,.matrix-row{grid-template-columns:150px repeat(7,1fr)}.admin-schedule-container{padding:var(--spacing-4)}.schedule-generator{padding:var(--spacing-5)}}@media(max-width:768px){.availability-matrix{display:none}.matrix-mobile{display:flex;flex-direction:column;gap:var(--spacing-3);margin-bottom:var(--spacing-5)}.matrix-mobile-card{background:var(--surface-container-lowest);border-radius:var(--radius-lg);padding:var(--spacing-3);box-shadow:var(--shadow-sm)}.matrix-mobile-name{font-weight:600;color:var(--on-surface);font-size:.875rem;margin-bottom:var(--spacing-3);display:flex;align-items:center;gap:var(--spacing-2)}.matrix-mobile-hours{font-size:.6875rem;color:var(--outline);font-weight:400}.matrix-mobile-days{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--spacing-1)}.matrix-mobile-day{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2) var(--spacing-1);border-radius:var(--radius-sm);cursor:pointer;gap:2px;min-height:60px;background:var(--surface-container-low);transition:background var(--transition-fast)}.matrix-mobile-day:hover{background:var(--surface-container)}.matrix-mobile-day-label{font-size:.625rem;color:var(--on-surface-variant);font-weight:600;text-transform:uppercase}.matrix-mobile-day-num{font-size:.75rem;font-weight:700;color:var(--on-surface)}.availability-legend{flex-direction:column;gap:var(--spacing-3)}.action-buttons{flex-direction:column}.action-buttons .btn{width:100%;justify-content:center}.preview-stats{grid-template-columns:1fr}.preview-actions{flex-direction:column}.preview-actions .btn{width:100%;justify-content:center}.schedule-generator{padding:var(--spacing-4)}.admin-schedule-container{padding:var(--spacing-3);gap:var(--spacing-4)}.admin-schedule-header{padding:var(--spacing-5)}.admin-schedule-header h1{font-size:1.375rem}.schedule-preview{padding:var(--spacing-4)}.schedule-preview h2{font-size:1.125rem}}@media(max-width:480px){.week-navigation{gap:var(--spacing-2)}.week-label{font-size:.8125rem;min-width:0;flex:1;text-align:center}.matrix-mobile-days{grid-template-columns:repeat(7,1fr);gap:2px}.matrix-mobile-day{padding:var(--spacing-1);min-height:52px}.matrix-mobile-day-label{font-size:.5625rem}}.employees-page{display:flex;flex-direction:column;gap:var(--spacing-5)}.emp-filters{display:flex;gap:var(--spacing-4);flex-wrap:wrap;align-items:center}.emp-search{position:relative;flex:1;min-width:200px}.emp-search-icon{position:absolute;left:var(--spacing-4);top:50%;transform:translateY(-50%);color:var(--outline);pointer-events:none}.emp-search .input-field{padding-left:calc(var(--spacing-4) + 24px)}.emp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-5)}.emp-card{display:flex;flex-direction:column;gap:var(--spacing-3);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.emp-card:hover{transform:translateY(-2px)}.emp-card-header{display:flex;align-items:flex-start;justify-content:space-between}.emp-avatar-lg{width:52px;height:52px;border-radius:var(--radius-lg);background:var(--primary);color:var(--on-primary);display:flex;align-items:center;justify-content:center;font-size:1.125rem;font-weight:700}.emp-card-body{display:flex;flex-direction:column;gap:var(--spacing-2)}.emp-card-body .badge{align-self:flex-start}.emp-card-details{display:flex;flex-direction:column;gap:var(--spacing-2)}.emp-detail{display:flex;align-items:center;gap:var(--spacing-2);color:var(--on-surface-variant)}.emp-detail svg{flex-shrink:0}.emp-card-footer{margin-top:var(--spacing-2);padding-top:var(--spacing-3)}.emp-hours{display:flex;flex-direction:column;gap:2px}@media(max-width:699px){.emp-filters{flex-direction:column;align-items:stretch}.emp-search{min-width:0;width:100%}.emp-filters .segmented-control{width:100%;justify-content:stretch}.emp-filters .segmented-control button{flex:1}}@media(max-width:599px){.emp-grid{grid-template-columns:1fr}}@media(max-width:479px){.emp-card-body .badge{font-size:.6875rem}.emp-detail{font-size:.8125rem}}.emp-card-clickable{cursor:pointer;transition:box-shadow var(--transition-fast),transform var(--transition-fast)}.emp-card-clickable:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.emp-avail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.emp-avail-modal{width:100%;max-width:480px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-4)}.emp-avail-header{display:flex;align-items:center;justify-content:space-between}.emp-avail-hours-info{display:flex;gap:var(--spacing-4);padding:var(--spacing-3) var(--spacing-4);background:var(--surface-container-low);border-radius:var(--radius-md);color:var(--on-surface-variant)}.emp-avail-weekday-summary{padding-top:var(--spacing-2)}.avail-weekday-chip{padding:4px 10px;border-radius:var(--radius-full, 999px);font-size:.8125rem;font-weight:500}.avail-chip-available{background:var(--success-container, #d4edda);color:var(--on-success-container, #155724)}.avail-chip-blacklist{background:var(--error-container, #f8d7da);color:var(--on-error-container, #7b1d1d)}.avail-chip-wishday{background:var(--info-container);color:var(--on-info-container, var(--info))}.chat-page{display:flex;height:calc(100vh - 120px);border-radius:var(--radius-xl);overflow:hidden;background:var(--surface-container-lowest);box-shadow:var(--shadow-sm)}.chat-channels{width:280px;background:var(--surface-container-low);display:flex;flex-direction:column;flex-shrink:0}.chat-channels-header{padding:var(--spacing-5) var(--spacing-5) var(--spacing-3);display:flex;align-items:center;justify-content:space-between}.chat-channel-list{flex:1;overflow-y:auto;padding:0 var(--spacing-2)}.chat-channel-item{display:flex;align-items:center;gap:var(--spacing-3);width:100%;padding:var(--spacing-3) var(--spacing-3);border:none;border-radius:var(--radius-md);background:transparent;color:var(--on-surface-variant);cursor:pointer;text-align:left;font-family:var(--font-family);font-size:.9375rem;transition:all var(--transition-fast)}.chat-channel-item:hover{background:var(--surface-container);color:var(--on-surface)}.chat-channel-item.active{background:var(--surface-container-lowest);color:var(--primary);box-shadow:var(--shadow-sm)}.chat-channel-hash{flex-shrink:0;opacity:.5}.chat-channel-info{flex:1;display:flex;flex-direction:column;min-width:0}.chat-channel-name{font-weight:500}.chat-archive-folder{margin-top:var(--spacing-2);border-top:1px solid var(--outline-variant);padding-top:var(--spacing-2)}.chat-archive-header{display:flex;align-items:center;gap:var(--spacing-2);width:100%;padding:var(--spacing-2) var(--spacing-3);border:none;border-radius:var(--radius-md);background:transparent;color:var(--on-surface-variant);cursor:pointer;font-family:var(--font-family);font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;transition:background var(--transition-fast)}.chat-archive-header:hover{background:var(--surface-container)}.chat-channel-archived{opacity:.75}.chat-main{flex:1;display:flex;flex-direction:column;min-width:0}.chat-main-header{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-4) var(--spacing-5);background:var(--surface)}.chat-back-btn{display:none}.chat-messages{flex:1;overflow-y:auto;padding:var(--spacing-5);display:flex;flex-direction:column;gap:var(--spacing-4)}.chat-msg{display:flex;gap:var(--spacing-3);max-width:75%;animation:fadeIn .2s ease}.chat-msg-me{margin-left:auto;flex-direction:row-reverse}.chat-msg-avatar{width:32px;height:32px;border-radius:var(--radius-pill);background:var(--secondary-container);color:var(--on-secondary-container);display:flex;align-items:center;justify-content:center;font-size:.6875rem;font-weight:700;flex-shrink:0}.chat-msg-body{display:flex;flex-direction:column;gap:2px}.chat-msg-sender{font-size:.75rem;font-weight:600;color:var(--on-surface-variant)}.chat-msg-bubble{padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-lg);background:var(--surface-container);color:var(--on-surface);font-size:.9375rem;line-height:1.5;border-top-left-radius:var(--spacing-1)}.chat-msg-bubble-me{background:var(--primary);color:var(--on-primary);border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--spacing-1)}.chat-msg-time{font-size:.6875rem;color:var(--outline)}.chat-msg-me .chat-msg-time{text-align:right}.chat-archived-notice{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-4) var(--spacing-5);background:var(--surface-container-low);color:var(--on-surface-variant);font-size:.875rem;border-top:1px solid var(--outline-variant)}.chat-input-bar{display:flex;gap:var(--spacing-3);padding:var(--spacing-4) var(--spacing-5);background:var(--surface)}.chat-input{flex:1}.chat-send-btn{width:48px;padding:0;border-radius:var(--radius-md)}@media(max-width:899px){.chat-page{height:calc(100vh - 132px - 2rem);height:calc(100dvh - 132px - 2rem)}}@media(max-width:699px){.chat-channels{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;z-index:10;transform:translate(-100%);transition:transform var(--transition-normal);border-radius:0}.chat-channels-open{transform:translate(0)}.chat-back-btn{display:flex}.chat-page{position:relative;border-radius:var(--radius-lg);height:calc(100vh - 132px - 2rem);height:calc(100dvh - 132px - 2rem)}.chat-msg{max-width:90%}.chat-main-header{padding:var(--spacing-3) var(--spacing-3)}.chat-messages,.chat-input-bar{padding:var(--spacing-3)}}@media(max-width:479px){.chat-page{height:calc(100vh - 124px - 1.5rem);height:calc(100dvh - 124px - 1.5rem);border-radius:var(--radius-md)}.chat-msg-bubble{font-size:.875rem;padding:var(--spacing-2) var(--spacing-3)}.notif-dropdown{width:calc(100vw - 2rem)}}.settings-page{display:flex;flex-direction:column;gap:var(--spacing-6);max-width:800px}.settings-section{display:flex;flex-direction:column;gap:var(--spacing-5)}.settings-section-header{display:flex;gap:var(--spacing-3);align-items:flex-start}.settings-section-header>div{display:flex;flex-direction:column;gap:2px}.settings-section-header svg{margin-top:2px;flex-shrink:0}.settings-grid{display:flex;flex-direction:column;gap:var(--spacing-4)}.settings-item{display:flex;flex-direction:column;gap:var(--spacing-2)}.settings-item-row{flex-direction:row;align-items:center;justify-content:space-between;gap:var(--spacing-4);padding:var(--spacing-3) 0}.settings-item-row>div{display:flex;flex-direction:column;gap:2px}.settings-logo-upload{display:flex;align-items:center;gap:var(--spacing-4)}.settings-logo-preview{width:64px;height:64px;border-radius:var(--radius-lg);background:var(--primary);color:var(--on-primary);display:flex;align-items:center;justify-content:center}.settings-color-picker{display:flex;align-items:center;gap:var(--spacing-3);flex-wrap:wrap}.color-input{width:44px;height:44px;border-radius:var(--radius-md);border:none;cursor:pointer;padding:2px;background:var(--surface-container-high)}.color-input::-webkit-color-swatch-wrapper{padding:2px}.color-input::-webkit-color-swatch{border:none;border-radius:var(--radius-sm)}.settings-color-presets{display:flex;gap:var(--spacing-2)}.color-preset{width:28px;height:28px;border-radius:var(--radius-pill);border:3px solid transparent;cursor:pointer;transition:border-color var(--transition-fast),transform var(--transition-fast)}.color-preset:hover{transform:scale(1.15)}.color-preset-active{border-color:var(--on-surface)}.settings-sites-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.settings-site-item{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-4);padding:var(--spacing-4);border-radius:var(--radius-md);background:var(--surface-container-low);transition:background var(--transition-fast)}.settings-site-item:hover{background:var(--surface-container)}.settings-site-info{display:flex;flex-direction:column;gap:2px}@media(max-width:699px){.settings-page{max-width:100%}.settings-color-picker,.settings-site-item{flex-wrap:wrap;gap:var(--spacing-2)}.settings-site-item .btn{align-self:flex-start}}@media(max-width:599px){.settings-item-row{flex-direction:column;align-items:flex-start}.settings-item-row .segmented-control{width:100%}.settings-logo-upload,.settings-color-presets{flex-wrap:wrap}}@media(max-width:479px){.settings-section-header{flex-wrap:wrap}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{overflow-x:hidden;max-width:100%}:root{--primary: #a9151f;--primary-deep: #7a0f17;--primary-container: #d4525c;--primary-fixed-variant: #bb2a35;--on-primary: #faf9f6;--on-primary-container: #2a0f13;--secondary: #5d5f5b;--secondary-container: #e8e6e1;--on-secondary: #ffffff;--on-secondary-container: #1a1b19;--tertiary: #4a2500;--tertiary-container: #ffdcc2;--on-tertiary: #ffffff;--on-tertiary-fixed: #3a1d00;--background: #faf9f6;--surface: #faf9f6;--surface-container-lowest: #ffffff;--surface-container-low: #f5f3ee;--surface-container: #efede8;--surface-container-high: #e9e7e2;--surface-container-highest: #e3e1dc;--surface-variant: rgba(239, 237, 232, .7);--on-surface: #1c1b1a;--on-surface-variant: #534f4b;--outline: #857f7a;--outline-variant: rgba(133, 127, 122, .15);--success: #2d6a4f;--success-container: #d4edda;--warning: #b8860b;--warning-container: #fff3cd;--error: #9b2335;--error-container: #f8d7da;--info: #3a6b9f;--info-container: #d6e9f8;--surface-dim: var(--surface-container-low);--on-error-container: #7b1d1d;--on-success-container: #1b4332;--on-info-container: #1e3a5f;--on-warning-container: #7b5e00;--radius-full: 9999px;--shadow-ambient: 0 12px 40px rgba(83, 67, 67, .08);--shadow-sm: 0 2px 8px rgba(83, 67, 67, .06);--shadow-md: 0 6px 20px rgba(83, 67, 67, .08);--shadow-lg: 0 12px 40px rgba(83, 67, 67, .1);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--tracking-tight: -.02em;--tracking-normal: 0;--spacing-0: 0;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-7: 2rem;--spacing-8: 2.5rem;--spacing-9: 3rem;--spacing-10: 4rem;--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-pill: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--z-sidebar: 100;--z-header: 90;--z-overlay: 200;--z-modal: 300;--z-toast: 400}.dark,[data-theme=dark]{--primary: #e85d6a;--primary-deep: #c43d4d;--primary-container: #7a0f17;--primary-fixed-variant: #d94a58;--on-primary: #1a1a1a;--on-primary-container: #ffd6d9;--secondary: #c7c5c0;--secondary-container: #46483f;--on-secondary: #1a1a1a;--on-secondary-container: #e8e6e1;--tertiary: #e0a878;--tertiary-container: #5a3a1e;--on-tertiary: #1a1a1a;--on-tertiary-fixed: #ffd6b0;--background: #141313;--surface: #1a1918;--surface-container-lowest: #111010;--surface-container-low: #201f1e;--surface-container: #252423;--surface-container-high: #302f2e;--surface-container-highest: #3b3a39;--surface-variant: rgba(37, 36, 35, .85);--on-surface: #e8e5e0;--on-surface-variant: #c0bab5;--outline: #8e8883;--outline-variant: rgba(142, 136, 131, .2);--success: #68c98a;--success-container: #1a3a28;--warning: #e0b84a;--warning-container: #3a2e10;--error: #e08090;--error-container: #3a1520;--info: #7ab0e0;--info-container: #152a3a;--shadow-ambient: 0 12px 40px rgba(0, 0, 0, .3);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .2);--shadow-md: 0 6px 20px rgba(0, 0, 0, .25);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .35);--surface-dim: var(--surface-container);--on-error-container: #ffc5c5;--on-success-container: #95d5b2;--on-info-container: #a8d5f5;--on-warning-container: #ffe08a}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:var(--background);color:var(--on-surface);line-height:1.6;min-height:100vh;transition:background var(--transition-normal),color var(--transition-normal)}#root{min-height:100vh}.text-display-lg{font-size:2.5rem;font-weight:700;letter-spacing:var(--tracking-tight);line-height:1.15}.text-display-md{font-size:2rem;font-weight:700;letter-spacing:var(--tracking-tight);line-height:1.2}.text-headline-lg{font-size:1.75rem;font-weight:600;letter-spacing:var(--tracking-tight);line-height:1.25}.text-headline-md{font-size:1.5rem;font-weight:600;letter-spacing:var(--tracking-tight);line-height:1.3}.text-title-lg{font-size:1.25rem;font-weight:600;line-height:1.35}.text-title-md{font-size:1.125rem;font-weight:600;line-height:1.4}.text-body-lg{font-size:1rem;font-weight:400;line-height:1.6}.text-body-md{font-size:.9375rem;font-weight:400;line-height:1.55}.text-body-sm{font-size:.875rem;font-weight:400;line-height:1.5}.text-label-lg{font-size:.875rem;font-weight:500;letter-spacing:.01em;line-height:1.4}.text-label-md{font-size:.8125rem;font-weight:500;letter-spacing:.02em;line-height:1.3}.text-label-sm{font-size:.75rem;font-weight:500;letter-spacing:.03em;line-height:1.3}.text-primary{color:var(--primary)}.text-secondary{color:var(--secondary)}.text-on-surface-variant{color:var(--on-surface-variant)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-error{color:var(--error)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-6);border:none;border-radius:var(--radius-xl);font-family:var(--font-family);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;min-height:44px;text-decoration:none}.btn-primary{background:var(--primary);color:var(--on-primary)}.btn-primary:hover{background:var(--primary-deep);box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--surface-container-highest);color:var(--on-surface)}.btn-secondary:hover{background:var(--surface-container-high)}.btn-tertiary{background:transparent;color:var(--primary-fixed-variant);padding:var(--spacing-2) var(--spacing-4)}.btn-tertiary:hover{background:var(--surface-container)}.btn-sm{padding:var(--spacing-2) var(--spacing-4);font-size:.8125rem;min-height:36px}.btn-lg{padding:var(--spacing-4) var(--spacing-8);font-size:1.0625rem;min-height:52px}.btn-icon{width:44px;height:44px;padding:0;border-radius:var(--radius-md);background:transparent;color:var(--on-surface-variant);border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.btn-icon:hover{background:var(--surface-container-high)}.btn:disabled,.btn[disabled]{opacity:.5;cursor:not-allowed;pointer-events:none}.card{background:var(--surface-container-lowest);border-radius:var(--radius-xl);padding:var(--spacing-6);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-normal),background var(--transition-normal)}.card:hover{box-shadow:var(--shadow-md)}.card-flat{background:var(--surface-container-low);border-radius:var(--radius-lg);padding:var(--spacing-5)}.badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-pill);font-size:.75rem;font-weight:600;letter-spacing:.02em}.badge-primary{background:var(--primary-container);color:var(--on-primary)}.badge-success{background:var(--success-container);color:var(--success)}.badge-warning{background:var(--warning-container);color:var(--warning)}.badge-error{background:var(--error-container);color:var(--error)}.badge-info{background:var(--info-container);color:var(--info)}.input-field{width:100%;padding:var(--spacing-3) var(--spacing-4);border:none;border-radius:var(--radius-md);font-family:var(--font-family);font-size:.9375rem;background:var(--surface-container-high);color:var(--on-surface);transition:background var(--transition-fast),box-shadow var(--transition-fast);min-height:48px}.input-field:focus{outline:none;background:var(--surface-container-highest);box-shadow:0 0 0 3px #722f3726}.input-field::placeholder{color:var(--outline)}.input-group{display:flex;flex-direction:column;gap:var(--spacing-2)}.input-group label{font-size:.8125rem;font-weight:500;color:var(--on-surface-variant)}.segmented-control{display:inline-flex;background:var(--surface-container-high);border-radius:var(--radius-lg);padding:var(--spacing-1);gap:var(--spacing-1)}.segmented-control button{padding:var(--spacing-2) var(--spacing-5);border:none;border-radius:var(--radius-md);background:transparent;color:var(--on-surface-variant);font-family:var(--font-family);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);min-height:36px}.segmented-control button.active{background:var(--surface-container-lowest);color:var(--on-surface);box-shadow:var(--shadow-sm)}.progress-bar{width:100%;height:8px;background:var(--surface-container-highest);border-radius:var(--radius-pill);overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-container));border-radius:var(--radius-pill);transition:width var(--transition-slow)}.toggle-switch{position:relative;width:52px;height:32px;background:var(--surface-container-highest);border-radius:var(--radius-pill);cursor:pointer;transition:background var(--transition-fast);border:none;padding:0}.toggle-switch.active{background:var(--primary)}.toggle-switch:after{content:"";position:absolute;top:3px;left:3px;width:26px;height:26px;background:var(--surface-container-lowest);border-radius:50%;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}.toggle-switch.active:after{transform:translate(20px)}.glass-overlay{background:var(--surface-variant);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--surface-container-high) 25%,var(--surface-container-highest) 50%,var(--surface-container-high) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--outline-variant);border-radius:var(--radius-pill)}::-webkit-scrollbar-thumb:hover{background:var(--outline)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn .4s ease forwards}.animate-slide-up{animation:slideUp .5s cubic-bezier(.4,0,.2,1) forwards}@media(max-width:899px){.page-header{flex-wrap:wrap}}@media(max-width:599px){:root{--spacing-8: 1.5rem;--spacing-9: 2rem;--spacing-10: 2.5rem}.text-display-lg{font-size:1.75rem}.text-display-md{font-size:1.5rem}.text-headline-lg{font-size:1.375rem}.text-headline-md{font-size:1.25rem}.segmented-control{width:100%}.segmented-control button{flex:1;padding:var(--spacing-2) var(--spacing-2);font-size:.75rem}.card{padding:var(--spacing-4)}.btn{min-height:44px}}@media(max-width:479px){.text-headline-lg{font-size:1.25rem}.text-headline-md,.text-title-lg{font-size:1.125rem}.page-header{flex-direction:column;align-items:flex-start}}:focus-visible{outline:3px solid var(--primary);outline-offset:2px}.skip-link{position:absolute;top:-100px;left:var(--spacing-4);padding:var(--spacing-3) var(--spacing-5);background:var(--primary);color:var(--on-primary);border-radius:var(--radius-md);z-index:9999;font-weight:500;text-decoration:none}.skip-link:focus{top:var(--spacing-4)}
