*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background: 0 0% 100%;--foreground: 0 0% 3.9%;--card: 0 0% 100%;--card-foreground: 0 0% 3.9%;--popover: 0 0% 100%;--popover-foreground: 0 0% 3.9%;--primary: 0 0% 9%;--primary-foreground: 0 0% 98%;--secondary: 0 0% 96.1%;--secondary-foreground: 0 0% 9%;--muted: 0 0% 96.1%;--muted-foreground: 0 0% 45.1%;--accent: 0 0% 96.1%;--accent-foreground: 0 0% 9%;--destructive: 0 84.2% 60.2%;--destructive-foreground: 0 0% 98%;--border: 0 0% 89.8%;--input: 0 0% 89.8%;--ring: 0 0% 3.9%;--chart-1: 12 76% 61%;--chart-2: 173 58% 39%;--chart-3: 197 37% 24%;--chart-4: 43 74% 66%;--chart-5: 27 87% 67%;--radius: .5rem}*{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}body{background-color:hsl(var(--background));color:hsl(var(--foreground))}.visible{visibility:visible}.relative{position:relative}.grid{display:grid}.hidden{display:none}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}@keyframes enter{0%{opacity:var(--tw-enter-opacity, 1);transform:translate3d(var(--tw-enter-translate-x, 0),var(--tw-enter-translate-y, 0),0) scale3d(var(--tw-enter-scale, 1),var(--tw-enter-scale, 1),var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity, 1);transform:translate3d(var(--tw-exit-translate-x, 0),var(--tw-exit-translate-y, 0),0) scale3d(var(--tw-exit-scale, 1),var(--tw-exit-scale, 1),var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0))}}@font-face{font-family:KBH_Med;src:url(/fonts/KBH-Medium.otf) format("opentype");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:KBH;src:url(/fonts/KBH-Black.otf) format("opentype");font-style:normal;font-display:swap}@font-face{font-family:KBH_Tekst;src:url(/fonts/KBHTekst%202.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}*{margin:0;padding:0;box-sizing:border-box}:root{font-family:KBH,KBH_Med,KBH_Tekst;line-height:1.5;font-weight:400;color:#000c2e;background-color:#f4f3e8;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{overflow-x:hidden;overflow-y:auto}body{margin:0;min-width:320px;min-height:100vh;background-color:#f4f3e8;position:relative;overflow-x:hidden;overflow-y:auto}#root{width:100%;min-height:100vh;position:relative;overflow-x:hidden}.font-kbh-regular{font-family:KBH,sans-serif;font-weight:400}.font-kbh-medium{font-family:KBH,sans-serif;font-weight:500}.font-kbh-black{font-family:KBH,sans-serif;font-weight:900}h1,h2,h3,h4,h5,h6{font-family:KBH,sans-serif;font-weight:500}.header{text-align:center;margin-bottom:clamp(.75rem,2vh,1.5rem)}.logo{width:clamp(100px,15vh,160px);height:clamp(100px,15vh,160px);border-radius:50%;background:transparent;padding:6px;display:block;margin-left:auto;margin-right:auto}.main-title{font-size:clamp(1.5rem,3.5vw,2rem);color:#000c2e;margin:clamp(.5rem,1vh,.75rem) 0 0 0;font-family:KBH,KBH}@media(max-width:480px){.logo{width:clamp(80px,20vw,120px);height:clamp(80px,20vw,120px)}}.navigation{display:flex;gap:0;margin-top:clamp(.75rem,2vh,1.5rem);margin-bottom:clamp(.75rem,2vh,1.25rem);justify-content:center}.nav-tab{background:none;border:none;padding:clamp(.6rem,1.5vh,.75rem) clamp(1rem,3vw,1.5rem);font-size:clamp(.875rem,2vw,.95rem);color:#6b7280;cursor:pointer;position:relative;font-weight:500;transition:color .3s ease;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.nav-tab:hover,.nav-tab.active{color:#000c2e}.nav-tab.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background-color:#000c2e}.nav-tab:not(.active){color:#9ca3af}.app-footer{position:absolute;bottom:20px;left:0;right:0;width:100%;background-color:transparent;padding:0;pointer-events:none;display:flex;justify-content:center;align-items:center}.footer-text{font-family:KBH_Tekst,sans-serif;font-size:.75rem;color:#9ca3af;font-weight:400;opacity:.8}@media(max-width:768px){.app-footer{padding:.75rem 1rem}.footer-text{font-size:.625rem}}.login-page{position:relative;min-height:100vh;max-height:100vh;background-color:#f4f3e8;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:clamp(.5rem,2vh,2rem) clamp(1rem,3vw,2rem) 80px;font-family:KBH_Med,KBH;overflow-y:auto}.login-container{width:100%;max-width:min(500px,90vw);padding:0 1rem}.login-form{background:#fafafb;padding:clamp(1rem,3vh,2rem) clamp(1.25rem,3vw,1.75rem);border-radius:clamp(20px,5vw,40px);box-shadow:0 4px 12px #00000014;text-align:center;transition:transform .2s ease;transform:scale(1)}.login-form.scale-down{transform:scale(.98)}.login-title{font-size:clamp(1.35rem,2.5vw,1.6rem);font-weight:600;color:#000c2e;margin:0 0 clamp(.8rem,2vh,1.2rem) 0;letter-spacing:1px;font-family:KBH_Med,KBH}.form-group{margin-bottom:clamp(.8rem,2vh,1rem);text-align:left}.form-label{display:block;color:#000c2e;font-weight:500;margin-bottom:clamp(.25rem,.5vh,.35rem);font-size:clamp(.8rem,1.8vw,.9rem)}.form-input{width:100%;padding:clamp(.5rem,1.2vh,.65rem) clamp(.65rem,1.5vw,.75rem);border:1px solid #d1d5db;border-radius:10px;font-family:KBH_Tekst,KBH;font-size:clamp(.875rem,1.8vw,.95rem);transition:border-color .3s ease;box-sizing:border-box;background:#fff}.form-input:focus{outline:none;border-color:#000c2e;box-shadow:0 0 0 2px #1e3a8a1a}.login-button{width:100%;background-color:#000c2e;color:#fff;border:none;padding:clamp(.65rem,1.5vh,.8rem);font-size:clamp(.85rem,1.8vw,.95rem);font-weight:500;font-family:KBH_Med,KBH;border-radius:10px;cursor:pointer;transition:background-color .3s ease;margin-top:clamp(.5rem,1vh,.7rem);text-transform:uppercase;letter-spacing:.5px}.login-button:hover{background-color:#363e58}.login-button:active{background-color:#000c2e}.login-button:disabled{background-color:#9ca3af;cursor:not-allowed}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:clamp(.6rem,2vw,.75rem);border-radius:10px;margin-bottom:1rem;font-size:clamp(.825rem,2vw,.9rem);text-align:center}@media(max-width:480px){.login-container{padding:0 .5rem}.form-group{margin-bottom:1rem}}.form-input:disabled{background-color:#f9fafb;cursor:not-allowed}.app-header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:1rem;background-color:transparent;height:100px}.header-logo-section{display:flex;align-items:center;gap:2rem;flex-shrink:0}.header-logo-img{width:80px;height:80px;border-radius:0;background:transparent;padding:0}.institution-name-2{font-family:KBH_Tekst;font-size:1rem;color:#000c2e;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;gap:.5rem}.institution-icon{color:#000c2e;flex-shrink:0}.header-nav{display:flex;align-items:center;gap:.5rem;justify-content:center;grid-column:2}.nav-tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:none;border:none;border-radius:8px;font-family:KBH_Tekst,sans-serif;font-size:1rem;font-weight:500;color:transparent;cursor:pointer;transition:all .2s ease;position:relative}.nav-tab:hover,.nav-tab.active{color:#000c2e;background-color:transparent}.nav-tab.active:after{content:"";position:absolute;bottom:-1px;left:50%;transform:translate(-50%);width:calc(100% - 2rem);height:3px;background-color:#000c2e;border-radius:2px}.nav-icon{flex-shrink:0}.header-user{display:flex;align-items:center;gap:.75rem;justify-content:flex-end;grid-column:3;margin-right:.5rem;position:relative}.user-name{font-family:KBH_Tekst,sans-serif;font-size:1rem;color:#000c2e;font-weight:500}.user-avatar{width:35px;height:35px;border-radius:50%;background-color:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;border:2px solid #000c2e;position:relative}.user-avatar:hover{border-color:#717581}.user-avatar svg{color:#000c2e;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.user-avatar:hover{background-color:#000c2e1a}.user-menu{position:fixed;top:0;right:0;width:320px;height:100vh;background-color:#fafafb;box-shadow:-8px 0 32px #0000001f;z-index:1000;overflow-y:auto;transform:translate(100%);transition:transform .3s ease-in-out;display:flex;flex-direction:column}.user-menu.open{transform:translate(0)}.user-menu-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000080;z-index:999;opacity:0;visibility:hidden;transition:opacity .3s ease-in-out,visibility .3s ease-in-out}.user-menu-overlay.open{opacity:1;visibility:visible}.menu-header{padding:2rem 1.5rem;background-color:#fafafb;border-bottom:1px solid #FAFAFB;display:flex;justify-content:space-between;align-items:flex-start}.menu-user-info{display:flex;align-items:center;gap:1rem;flex:1}.menu-close-button{background:none;border:none;border-radius:6px;cursor:pointer;color:#6b7280;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.menu-close-button:hover{color:#000c2e}.menu-user-avatar{width:45px;height:45px;border-radius:50%;background-color:#fafafb;border:2px solid #000c2e;display:flex;align-items:center;justify-content:center;flex-shrink:0}.menu-user-avatar svg{color:#000c2e}.menu-user-details{flex:1;min-width:0}.menu-user-name{font-family:KBH_Med,sans-serif;font-weight:500;font-size:1.125rem;color:#000c2e;margin-bottom:.25rem}.menu-user-email{font-family:KBH_Tekst,sans-serif;font-size:.875rem;color:#6b7280}.menu-divider{height:1px;background-color:#e5e7eb}.menu-actions{padding:1rem}.menu-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:none;border:none;border-radius:8px;font-family:KBH_Tekst,sans-serif;font-size:.875rem;color:#374151;cursor:pointer;transition:background-color .2s ease;text-align:left}.menu-item:hover{background-color:#f3f4f6}.menu-item svg{color:#6b7280;flex-shrink:0}.menu-logout{margin-top:auto;padding-top:1rem}.logout-item{color:#000c2e!important}.logout-item:hover{background-color:#f3f4f6!important}.logout-item svg{color:#000c2e!important}@media(max-width:768px){.app-header{padding:1rem;height:auto;display:flex;flex-direction:column;gap:1rem}.header-nav{order:3;flex-basis:100%;justify-content:center;margin-top:.5rem}.nav-tab{padding:.5rem 1rem;font-size:.875rem}.user-name{display:none}.header-logo-img{width:40px;height:40px}.institution-name{font-size:.8rem;max-width:120px}.institution-name-2{font-size:.8rem;max-width:120px;gap:.25rem}.institution-icon{width:12px;height:12px}.user-menu{width:280px}.menu-header{padding:1.5rem 1rem}.menu-close-button{padding:.375rem}.menu-user-info{gap:.75rem}.menu-user-avatar{width:40px;height:40px}.menu-user-name{font-size:1rem}.menu-user-email{font-size:.75rem}}@media(max-width:480px){.nav-tab{flex-direction:column;gap:.25rem;padding:.5rem;min-width:80px}.nav-tab .nav-icon{width:16px;height:16px}.nav-tab span{font-size:.75rem}.user-menu{width:100vw}}.dashboard{position:relative;min-height:100vh;background-color:#f4f3e8;padding:2rem 1rem 80px;font-family:KBH_Tekst,Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.dashboard-content{max-width:800px;margin:0 auto;text-align:center}.welcome-section{margin-bottom:3rem}.welcome-section h2{color:#000c2e;font-size:2rem;margin-bottom:.5rem;font-family:KBH_Med,sans-serif}.welcome-section p{color:#6b7280;font-size:1.1rem}.dashboard-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:3rem}.action-button{background:#fff;border:2px solid #000c2e;color:#000c2e;padding:1.5rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;display:block;font-family:KBH_Med,sans-serif}.action-button:hover,.action-button.primary{background-color:#000c2e;color:#fff}.action-button.primary:hover{background-color:#001a4d}.logout-section{margin-top:2rem}.logout-button{background:#dc2626;color:#fff;border:none;padding:.8rem 2rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .3s ease}.logout-button:hover{background-color:#b91c1c}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem}.schedule-upload-page{position:relative;min-height:100vh;background-color:#f4f3e8;display:flex;flex-direction:column;padding-bottom:80px}.upload-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;max-width:800px;margin:0 auto;width:100%}.upload-title{font-family:KBH_Med,sans-serif;font-weight:500;font-size:2.5rem;color:#000c2e;text-align:center;margin-bottom:3rem;line-height:1.2}.upload-card{background-color:#fafafb;border-radius:40px;padding:3rem;box-shadow:0 4px 20px #000c2e14;width:100%;max-width:800px}.upload-drop-zone{border:2px dashed #D1D5DB;border-radius:22px;padding:4rem 2rem;text-align:center;transition:all .3s ease;background-color:#fafafa}.upload-drop-zone:hover{border-color:#000c2e;background-color:#f8f9fa}.upload-drop-zone.drag-over{border-color:#000c2e;background-color:#f0f4ff;border-style:solid}.upload-icon{margin-bottom:1.5rem;display:flex;justify-content:center;align-items:center}.upload-icon svg{opacity:.7}.upload-text{font-family:KBH_Tekst,sans-serif;font-size:1.125rem;color:#000c2e;margin-bottom:2rem;font-weight:400}.upload-separator{margin:2rem 0;position:relative;display:flex;align-items:center;justify-content:center;width:100%}.upload-separator:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background-color:#e5e7eb;z-index:1}.upload-separator span{background-color:#fafafa;padding:0 1rem;color:#6b7280;font-family:KBH_Tekst,sans-serif;font-size:.875rem;position:relative;z-index:2}.browse-button{background-color:#000c2e;color:#fff;border:none;border-radius:8px;padding:.875rem 2rem;font-family:KBH_Med,sans-serif;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:160px}.browse-button:hover:not(:disabled){background-color:#001a4d}.browse-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.file-preview{padding:2rem}.file-info{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding:1.5rem;background-color:#f8f9fa;border-radius:8px;border:1px solid #E5E7EB}.file-icon{flex-shrink:0;opacity:.7}.file-details{flex:1;min-width:0}.file-name{font-family:KBH_Tekst,sans-serif;font-size:1.125rem;font-weight:500;color:#000c2e;margin:0 0 .25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-meta{font-family:KBH_Tekst,sans-serif;font-size:.875rem;color:#6b7280;margin:0}.clear-file-button{background:none;border:none;font-size:1.25rem;color:#6b7280;cursor:pointer;padding:.5rem;border-radius:4px;transition:all .2s ease;flex-shrink:0}.clear-file-button:hover:not(:disabled){background-color:#f3f4f6;color:#374151}.clear-file-button:disabled{opacity:.5;cursor:not-allowed}.upload-actions{display:flex;justify-content:center;gap:1rem}.upload-button{background-color:#000c2e;color:#fff;border:none;border-radius:8px;padding:1rem 2rem;font-family:KBH_Med,sans-serif;font-size:1.125rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:180px}.upload-button:hover:not(:disabled){background-color:#001a4d;transform:translateY(-1px)}.upload-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.error-message{margin-top:1.5rem;padding:1rem;background-color:#fef2f2;border:1px solid #FECACA;border-radius:8px;color:#dc2626;font-family:KBH_Tekst,sans-serif;font-size:.875rem;text-align:center;max-width:600px}.success-message{margin-top:1.5rem;padding:1rem;background-color:#f0fdf4;border:1px solid #BBF7D0;border-radius:8px;color:#16a34a;font-family:KBH_Tekst,sans-serif;font-size:.875rem;text-align:center;max-width:600px}.upload-progress{margin-top:1.5rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.upload-progress p{font-family:KBH_Tekst,sans-serif;color:#000c2e;font-size:.875rem;margin:0}@media(max-width:768px){.upload-container{padding:1rem}.upload-title{font-size:2rem;margin-bottom:2rem}.upload-card{padding:2rem 1.5rem}.upload-drop-zone{padding:3rem 1.5rem}.upload-text{font-size:1rem}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.week-shift-modal{background-color:#f4f3e8;border-radius:40px;width:100%;max-width:80%;height:90vh;overflow:hidden;box-shadow:0 20px 40px #00000026}.modal-header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:1.5rem 2rem;background-color:#f4f3e8}.modal-title{display:flex;align-items:center;gap:.75rem;font-family:KBH_Med,sans-serif;font-size:1.25rem;color:#000c2e}.schedule-date-range{font-family:KBH_Tekst,sans-serif;font-size:.8rem;color:#9ca3af;font-weight:400;margin-left:.5rem}.calendar-icon{font-size:1.5rem}.week-navigation{display:flex;align-items:center;gap:1rem}.nav-button{background:none;border:none;padding:.5rem;border-radius:6px;cursor:pointer;color:#6b7280;transition:background-color .2s ease}.nav-button:hover:not(:disabled){color:#000c2e}.nav-button:disabled{opacity:.3}.week-info{text-align:center;height:-moz-fit-content;height:fit-content;min-height:auto}.week-range-display{display:flex;align-items:center;gap:.5rem}.week-range-item{display:flex;flex-direction:column;align-items:center}.week-range-week{font-family:KBH_Tekst,sans-serif;font-size:.75rem;color:#6b7280;font-weight:600}.week-range-day{font-family:KBH_Med,sans-serif;font-size:1rem;color:#000c2e}.week-range-separator{font-family:KBH_Med,sans-serif;font-size:1.125rem;color:#6b7280;padding:0 .25rem}.modal-controls{display:flex;align-items:center;justify-content:flex-end;gap:.75rem}.theme-toggle{background:none;border:none;padding:.5rem;cursor:pointer;display:flex;align-items:center;gap:.25rem;color:#6b7280;transition:background-color .2s ease}.theme-toggle:hover{background-color:#f3f4f6}.toggle-times-button{background:none;border:none;padding:.5rem;border-radius:6px;cursor:pointer;color:#9ca3af;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.toggle-times-button:hover{color:#000c2e;background-color:#f3f4f6}.toggle-times-button.active{color:#000c2e}.close-button{background:none;border:none;padding:.5rem;border-radius:6px;cursor:pointer;color:#6b7280;transition:background-color .2s ease}.close-button:hover{color:#000c2e}.timeline-scrollbar-container{padding:.75rem 2rem;background-color:#f4f3e8;border-bottom:1px solid #E5E7EB}.timeline-scrollbar{width:100%;height:1px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#9a9eab;border-radius:7px;outline:none;cursor:pointer}.timeline-scrollbar::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:50px;height:18px;background:#363e58;border-radius:9px;cursor:grab;-webkit-transition:background-color .2s ease;transition:background-color .2s ease}.timeline-scrollbar::-webkit-slider-thumb:active{cursor:grabbing;background:#2a3550}.timeline-scrollbar::-moz-range-thumb{width:80px;height:20px;background:#000c2e;border-radius:10px;border:none;cursor:grab;-moz-transition:background-color .2s ease;transition:background-color .2s ease}.timeline-scrollbar::-moz-range-thumb:hover{background:#1a2540}.timeline-scrollbar::-moz-range-thumb:active{cursor:grabbing;background:#2a3550}.modal-content{padding:1rem 2rem;margin-bottom:30px;overflow-y:auto;max-height:calc(90vh - 120px)}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center}@keyframes pulse-glow{0%,to{box-shadow:0 0 #0a2df2}50%{box-shadow:0 0 8px 2px #0a2df2}}.week-schedule-container{width:100%;background:#f4f3e8;overflow:hidden}.week-schedule-header{display:grid;grid-template-columns:100px repeat(7,1fr) 65px 50px;background-color:#f4f3e8}.user-column-header{font-family:KBH_Med,sans-serif;font-weight:600;color:#374151;font-size:.875rem;display:flex;align-items:center;justify-content:center}.day-column-header{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.day-column-header.week-start{border-left:2px dotted #686D82}.day-date{font-family:KBH_Tekst,sans-serif;font-size:.75rem;color:#6b7280;align-items:start;font-weight:600}.day-name{font-family:KBH_Tekst,sans-serif;font-size:.875rem;color:#000c2e;font-weight:600}.time-indicators-row{display:grid;grid-template-columns:100px repeat(7,1fr) 65px 50px;background-color:#f4f3e8}.user-column-spacer{min-height:1rem;border-right:1px solid #9A9EAB}.time-indicator-container{padding:4px 8px;text-align:center;position:relative;border-bottom:1px solid #9A9EAB}.time-indicator-Midnight{font-family:KBH_Tekst,sans-serif;font-size:.7rem;color:#6b7280;position:absolute;left:0;top:0;transform:translate(-50%);white-space:nowrap}.time-indicator-Noon{font-family:KBH_Tekst,sans-serif;font-size:.7rem;color:#6b7280;position:absolute;left:50%;top:0;transform:translate(-50%);white-space:nowrap}.total-column-spacer{min-height:1px;border-bottom:1px solid #9A9EAB;display:flex;align-items:center;justify-content:center;position:relative}.total-column-title{font-family:KBH_Tekst,sans-serif;font-size:.7rem;color:#6b7280;text-align:center}.average-column-spacer{min-height:1px;border-bottom:1px solid #9A9EAB;border-right:1px solid #9A9EAB;display:flex;align-items:center;justify-content:center;position:relative}.average-column-title{font-family:KBH_Tekst,sans-serif;font-size:.7rem;color:#6b7280;text-align:center}.total-column-header,.average-column-header{padding:0 5px;font-family:KBH_Med,sans-serif;font-weight:600;color:#374151;font-size:.875rem;display:flex;align-items:end;justify-content:center;text-align:center}.week-schedule-body{display:flex;flex-direction:column}.position-group:last-child{border-bottom:none}.position-header-row{background-color:#f4f3e8;border-bottom:1px solid #9A9EAB;cursor:pointer;transition:background-color .2s ease;height:25px;display:flex;align-items:center}.position-header-row:hover{background-color:#faf9ef;opacity:.9}.position-header-cell{padding:0 8px;display:flex;align-items:center;justify-content:flex-start;font-family:KBH_Med,sans-serif;font-weight:600;color:#000c2e;position:relative}.position-header-day-cell{flex:1;min-width:0}.position-header-total-cell{width:65px}.position-header-content{display:flex;align-items:center;gap:6px;justify-content:flex-start;width:100%}.position-title{font-size:.875rem;color:#000c2e;letter-spacing:.025em;min-width:180px;flex-shrink:0}.violation-counts-container{display:grid;grid-template-columns:55px auto;align-items:center;min-width:0}.violation-count{font-size:.8rem;font-weight:700;padding:2px 6px;border-radius:4px;display:inline-flex;align-items:center;gap:2px;white-space:nowrap}.violation-symbol{color:#dc2626}.violation-symbol.request-rule{color:#000c2e}.violation-symbol.request-rule svg{stroke-width:2.5px}.violation-number{color:#000c2e;font-family:KBH_Tekst,sans-serif}.position-difference-row{display:grid;grid-template-columns:100px repeat(7,1fr) 65px 50px;background-color:#fafafb;border-bottom:2px solid #9A9EAB}.total-difference-row{background-color:#cdced5;font-weight:700}.total-difference-label{padding:10px 5px;font-family:KBH_Med,sans-serif;font-size:.875rem;color:#000c2e;text-align:end;font-weight:600;background-color:#f4f3e8;border-right:1px solid #9A9EAB}.total-difference-cell{padding:5px;display:flex;align-items:center;justify-content:center;font-family:KBH_Tekst,sans-serif;font-size:.875rem;background-color:#fafafb;color:#374151;font-weight:600}.total-difference-cell.week-start{border-left:1px solid #9A9EAB}.total-difference-total{padding:5px 16px;display:flex;align-items:center;justify-content:center;font-family:KBH_Tekst,sans-serif;font-size:.875rem;color:#374151;background-color:#fafafb;font-weight:600;border-left:1px solid #CDCED5}.total-difference-average{padding:5px 16px;display:flex;align-items:center;justify-content:center;border-right:1px solid #9A9EAB;font-family:KBH_Tekst,sans-serif;font-size:.875rem;color:#374151;font-weight:600;background-color:#fafafb}.week-schedule-row{display:grid;grid-template-columns:100px repeat(7,1fr) 65px 50px;min-height:45px}.week-schedule-row .user-id-cell{padding:5px;font-family:KBH_Tekst,sans-serif;font-size:.875rem;color:#374151;display:flex;align-items:center;justify-content:end;text-align:right;border-right:1px solid #9A9EAB;font-weight:600}.day-cell{position:relative;border-right:1px solid #CDCED5;border-bottom:2px solid #CDCED5;background-color:#fff}.day-cell.week-start{border-left:1px solid #9A9EAB}.day-cell:hover{background-color:#fafafb}.shifts-container{position:relative;width:100%;height:100%}.hour-grid-line{position:absolute;top:0;bottom:0;width:0px;border-left:1px solid #CDCED5;background-color:transparent;pointer-events:none}.shift-block{position:absolute;top:50%;transform:translateY(-50%);height:24px;background-color:#363e58;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:2}.shift-block-PF{position:absolute;top:50%;transform:translateY(-50%);height:24px;background:repeating-linear-gradient(45deg,#d6d7e0,#d6d7e0 4px,#f3f4f6 4px 8px);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:2}.shift-block-A9{position:absolute;top:50%;transform:translateY(-50%);height:24px;background:#ff9450;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:2}.shift-block-A9:hover{background:#ff9450!important;transform:translateY(-50%) scale(1.05);box-shadow:0 2px 8px #4b55634d}.shift-block:hover{background-color:#374151;transform:translateY(-50%) scale(1.05);box-shadow:0 2px 8px #4b55634d}.shift-block.has-violation{background-color:#363e58;cursor:pointer}.shift-block.shift-highlighted{z-index:20}.shift-block.shift-dimmed{opacity:.4;transition:opacity .3s ease}.shift-block.shift-dimmed:hover{opacity:.4}.shift-block.shift-dimmed .violation-indicator{opacity:.5}.shift-block.shift-selected-for-move{z-index:15}.shift-block.shift-checking{animation:pulse-glow 2.1s cubic-bezier(.33,1,.68,1) infinite}.violation-indicator{color:#ff3535;font-size:12px;font-family:KBH_Med,sans-serif;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.violation-indicator.request-rule{color:#fff;font-size:14px}.violation-indicator.request-rule svg{stroke-width:2.5px}.shift-time-display{position:absolute;top:50%;transform:translateY(-50%);pointer-events:none;z-index:1;height:0}.shift-time-line{color:#4b5563;font-size:10px;font-family:KBH_tekst,sans-serif;white-space:nowrap;line-height:1;position:absolute;left:50%;transform:translate(-50%)}.shift-time-line:first-child{bottom:14px}.shift-time-line:last-child{top:14px}.move-shift-eligibility-indicator{position:absolute;top:1px;bottom:1px;border-radius:5px;opacity:.4;pointer-events:none;z-index:3;border:2px solid;box-sizing:border-box}.move-shift-eligibility-indicator.eligible{background-color:#22c55e33;border-color:#22c55e99}.move-shift-eligibility-indicator.not-eligible{background-color:#ef444433;border-color:#ef444499}.move-shift-eligibility-indicator.pf-shift{background-color:#0006;border-color:#000c;opacity:.6}.move-shift-eligibility-indicator.ad-shift{background-color:#22c55e33;border-color:#22c55e99}.move-shift-eligibility-indicator.current-user{background-color:#0a2df233;border-color:#0a2df299;opacity:.4}.move-shift-eligibility-indicator.clickable{pointer-events:auto!important;cursor:pointer;opacity:.5;transition:opacity .2s ease;z-index:5!important}.move-shift-eligibility-indicator.clickable:hover{opacity:.7}.shift-block-pending{border:2px solid #686D82;background-color:#686d82!important}.pending-move-controls{display:flex;gap:.5rem;align-items:center;margin-right:1rem}.moving-shift-loading{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;border-radius:6px;font-family:KBH_Tekst,sans-serif;font-size:.875rem;color:#374151;font-weight:600}.moving-shift-loading svg{width:24px;height:24px}.moving-shift-loading svg ellipse{fill:#000c2e;stroke:none}.cancel-move-button,.save-move-button{padding:.5rem 1rem;border-radius:6px;font-family:KBH_Tekst,sans-serif;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.cancel-move-button{color:#374151}.cancel-move-button:hover{color:#000c2e}.save-move-button{background-color:#000c2e;color:#fff}.save-move-button:hover{background-color:#1a2332}.total-cell{padding:5px;display:flex;align-items:center;justify-content:center;border-right:2px solid #CDCED5;border-left:1px solid #CDCED5;border-bottom:2px solid #CDCED5;font-family:KBH_Tekst,sans-serif;font-size:.875rem;background-color:#fafafb;color:#374151;font-weight:600}.average-cell{padding:5px;border-right:1px solid #9A9EAB;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5px;font-family:KBH_Tekst,sans-serif;font-size:.75rem;background-color:#f4f3e8;color:#374151;font-weight:600}.average-value{color:#374151;font-weight:600}.average-separator{width:95%;height:.5px;background-color:#374151;margin:1px 0}.contracted-value{color:#686d82;font-weight:600}.week-schedule-footer{background-color:#f8f9fa}.violations-panel{margin-top:50px;padding:12px;margin-bottom:40px}.violations-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.violations-title{font-family:KBH_Med,sans-serif;color:#000c2e}.violations-count{font-family:KBH_Tekst,sans-serif;color:#6b7280}.violations-list{display:flex;flex-direction:column;gap:12px}.violations-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center}.violations-loading .spinner{width:24px;height:24px;border:2px solid #E5E7EB;border-top:2px solid #000c2e;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:.75rem}.violations-loading svg{width:32px;height:32px;margin-bottom:.75rem}.violations-loading svg ellipse{fill:#000c2e;stroke:none}.violations-loading p{font-family:KBH_Tekst,sans-serif;color:#6b7280;font-size:.875rem;margin:0}.violation-card{background-color:#fff;border:1px solid #CDCED5;border-radius:20px;padding:12px 16px;display:flex;flex-direction:column;gap:8px;cursor:pointer;transition:all .2s ease;position:relative}.violation-card-header{position:absolute;top:10px;right:15px}.violation-card-icon{font-family:KBH_Med,sans-serif;color:#dc2626;font-size:1rem}.violation-card-icon.request-rule{color:#000c2e;font-size:1.1rem}.violation-card:hover{border:1px solid #9A9EAB;scale:1.01;box-shadow:0 2px 8px #0000001a}.violation-card-selected{background-color:#fafafb;border:1px solid #000c2e;scale:1.01;box-shadow:0 2px 8px #0003}.violation-card-row{display:flex;gap:8px;align-items:flex-start}.violation-card-label{font-family:KBH_Med,sans-serif;color:#6b7280;font-size:.875rem;min-width:100px;flex-shrink:0}.violation-card-value{font-family:KBH_Tekst,sans-serif;color:#000c2e;font-size:.875rem;flex:1}.week-difference-row{display:grid;grid-template-columns:100px repeat(7,1fr) 65px 50px;border-bottom:2px solid #9A9EAB}.difference-label{padding:10px 5px;font-family:KBH_Med,sans-serif;font-size:.875rem;color:#000c2e;text-align:end;font-weight:600;background-color:#f4f3e8;border-right:1px solid #9A9EAB}.difference-sub-label{padding:10px 5px;font-family:KBH_Tekst,sans-serif;font-size:.875rem;color:#6b7280;text-align:end;font-weight:600;background-color:#f4f3e8;border-right:1px solid #9A9EAB}.difference-cell{padding:5px;display:flex;align-items:center;justify-content:center;font-family:KBH_Tekst,sans-serif;font-size:.875rem;color:#374151;font-weight:600}.difference-cell.week-start{border-left:1px solid #9A9EAB}.difference-total{padding:5px 16px;display:flex;align-items:center;justify-content:center;border-right:2px solid #CDCED5;border-left:1px solid #CDCED5;font-family:KBH_Tekst,sans-serif;font-size:.875rem;color:#374151;font-weight:600}.difference-average{background-color:#f4f3e8;border-right:1px solid #9A9EAB}.position-header-average-cell{width:65px;border-right:1px solid #9A9EAB}.no-shifts{text-align:center;padding:3rem;color:#000c2e;font-family:KBH_Med,sans-serif;font-size:1.5rem;border-radius:8px}.staffin-rule-highlight{position:absolute;top:0;bottom:0;z-index:1;pointer-events:none;opacity:.1}.staffin-rule-highlight.negative{background-color:#dc262666}.staffin-rule-highlight.positive{background-color:#3b82f666}.staffin-rule-highlight.neutral{background-color:#9ca3af66}.schedule-rule-block{position:absolute;top:0;bottom:0;background-color:#dc267f4d;pointer-events:none;z-index:1}.schedule-request-block{position:absolute;top:50%;transform:translateY(-50%);height:24px;background:repeating-linear-gradient(45deg,#d6d7e0,#d6d7e0 4px,#f3f4f6 4px 8px);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;pointer-events:auto;transition:all .2s ease;z-index:2}.schedule-request-block:hover{transform:translateY(-50%) scale(1.05);box-shadow:0 2px 8px #4b55634d}.schedule-request-icon{color:#000c2e;display:flex;align-items:center;justify-content:center}.schedule-request-dimmed{opacity:.4;transition:opacity .3s ease}.schedule-request-dimmed:hover{opacity:.4}.staffin-rule-time-highlight{position:absolute;top:0;bottom:0;z-index:1;pointer-events:none;opacity:.05;transform:translateZ(0);will-change:transform}.staffin-rule-time-highlight.negative{background-color:#9ca3af80}.staffin-rule-time-highlight.positive{background-color:#3b82f680}.staffin-rule-time-highlight.neutral{background-color:#d72232;border-left:1px dotted #000c2e}.time-slot-indicator{position:absolute;top:0;bottom:0;z-index:0;pointer-events:none;border-left:1px solid rgba(154,158,171,.3);border-right:1px solid rgba(154,158,171,.3)}.time-slot-indicator.time-slot-dag,.time-slot-indicator.time-slot-aften{background-color:#f9fafb80;border-left-color:#9a9eab66;border-right-color:#9a9eab66}.time-slot-indicator.time-slot-nat{background-color:#e6e7e9;border-left-color:#9a9eab66;border-right-color:#9a9eab66}.difference-cell .time-slot-indicator.time-slot-nat-start,.total-difference-cell .time-slot-indicator.time-slot-nat-start{border-left:none}.difference-cell .time-slot-indicator.time-slot-nat-end,.total-difference-cell .time-slot-indicator.time-slot-nat-end{border-right:none}.difference-cell>span:not(.missing-count-in-highlight),.total-difference-cell>span:not(.missing-count-in-highlight){font-family:KBH_Med,sans-serif;font-weight:700;font-size:.875rem;color:#000c2e;text-shadow:0 0 2px rgba(255,255,255,.8)}.difference-cell .missing-count-in-highlight,.total-difference-cell .missing-count-in-highlight{position:absolute!important;z-index:3!important;top:50%!important;transform:translate(-50%,-50%)!important;pointer-events:none!important;color:#d72232!important;font-weight:700!important;font-size:.875rem!important;text-shadow:0 0 2px rgba(255,255,255,.8)!important;font-family:KBH_Med,sans-serif!important}.difference-slot-counts{position:absolute;inset:0;z-index:3;pointer-events:none}.difference-slot-count{position:absolute;top:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:2px;font-size:.75rem;color:#4b5563;font-family:KBH_Tekst,sans-serif;min-width:36px}.difference-slot-label{font-size:.6rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.03em}.difference-slot-count.has-violation .difference-slot-label{color:#d72232}.difference-slot-value{font-weight:700;color:#111827}.difference-slot-count.has-violation .difference-slot-value{color:#d72232}.difference-slot-separator{margin:0 4px;color:#6b7280;font-weight:600}.difference-slot-second{color:#6b7280;font-weight:600}@media(max-width:1024px){.week-shift-modal{max-width:95vw;margin:1rem}.modal-content{padding:1rem}.time-indicators-row,.week-schedule-header,.week-schedule-row,.week-difference-row,.position-header-row,.position-difference-row{grid-template-columns:80px repeat(7,1fr) 60px 60px}.user-column-header,.week-schedule-row .user-id-cell,.difference-label{font-size:.75rem;padding:.75rem .5rem}.day-name{font-size:.75rem}.time-indicator{font-size:.625rem}.shift-block{height:20px}}@media(max-width:768px){.modal-overlay{padding:1rem}.modal-title{scale:.5}.week-navigation{scale:.5;order:2}.modal-controls{order:3}.time-indicators-row,.week-schedule-header,.week-schedule-row,.week-difference-row,.position-header-row,.position-difference-row{grid-template-columns:60px repeat(7,1fr) 60px 60px}.week-schedule-row{min-height:50px}.shift-block{height:18px}.day-name{font-size:.625rem}.time-indicator{font-size:.5rem}}.calendar-view{background-color:#fafafb;border-radius:40px;padding:2rem;box-shadow:0 4px 12px #00000014;position:relative;overflow:visible;width:100%;max-width:100%}.calendar-header{margin-bottom:1.5rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}.calendar-title-section{display:flex;align-items:center;gap:.75rem}.calendar-header h2{font-family:KBH_Med,sans-serif;font-weight:500;font-size:1.5rem;color:#000c2e;margin:0}.calendar-date-range{font-family:KBH_Tekst,sans-serif;font-size:.8rem;color:#9ca3af;font-weight:400}.calendar-loading{display:flex;align-items:center;gap:.5rem;font-family:KBH_Tekst,sans-serif;font-size:.875rem;color:#6b7280}.calendar-loading svg{width:20px;height:20px}.calendar-loading svg ellipse{fill:#000c2e;stroke:none}.calendar-grid{display:grid;grid-template-columns:auto 1fr;gap:1rem}.week-numbers{display:flex;flex-direction:column;gap:.5rem;padding-top:3rem}.week-number{font-family:KBH_Tekst,sans-serif;font-size:.875rem;color:#6b7280;text-align:center;height:110px;display:flex;align-items:center;justify-content:center}.calendar-main{flex:1}.day-headers{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem}.day-header{font-family:KBH_Tekst,sans-serif;font-size:.875rem;font-weight:500;color:#000c2e;text-align:center;padding:.75rem 0}.calendar-days{display:flex;flex-direction:column;gap:.5rem}.calendar-week{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;padding:0;border:2px solid transparent;border-radius:20px;transition:all .2s ease}.calendar-week:hover{border-color:#cdced5;background-color:#000c2e05;scale:1.01;box-shadow:0 2px 8px #0000001a}.calendar-week.clickable{cursor:pointer}.calendar-week.clickable:hover{border-color:#cdced5;background-color:#1e40af0d;scale:1.02;box-shadow:0 4px 12px #1e40af33}.calendar-day{background-color:#fff;border-radius:20px;min-height:106px;padding:.75rem;position:relative;display:flex;align-items:flex-start;justify-content:flex-start;border:1px solid #E5E7EB;transition:all .2s ease}.calendar-day.other-month{opacity:.3;background-color:transparent}.calendar-day.today{border-color:#000c2e}.calendar-day.out-of-range{background-color:transparent;opacity:.2}.calendar-day.out-of-range .day-number{color:#9ca3af}.calendar-day.other-month.out-of-range{background-color:transparent;opacity:.2}.day-weekday{font-family:KBH_Tekst,sans-serif;font-size:.75rem;font-weight:500;color:#000c2e}.rule-conflict-indicator{position:absolute;top:2.5rem;right:1.1rem;color:#dc2626;font-size:1rem;font-weight:700}.request-conflict-indicator{position:absolute;top:2.9rem;right:3rem;color:#000c2e;display:flex;align-items:center;justify-content:center}.calendar-day.has-staffing-rule-violation{background-color:#d7223233;border:1px solid #E5E7EB}.calendar-day.has-staffing-rule-violation.today{background-color:#d722324d;border:1px solid #E5E7EB}@media(max-width:768px){.calendar-view{padding:1rem}.calendar-header{flex-direction:column;gap:1rem;align-items:stretch}.calendar-header h2{font-size:1.25rem;text-align:center}.month-navigation{justify-content:center}.calendar-grid{grid-template-columns:1fr;gap:.5rem}.week-numbers{display:none}.calendar-week{padding:0;gap:.25rem}.calendar-day{min-height:50px;padding:.5rem}.day-number{font-size:.875rem}.day-headers{gap:.25rem}.day-header{font-size:.75rem;padding:.5rem 0}.calendar-days{gap:.25rem}}.schedule-view-page{position:relative;min-height:100vh;background-color:#f4f3e8;font-family:KBH_Tekst,sans-serif;padding-bottom:50px}.schedule-view-container{max-width:1200px;margin:0 auto;padding:2rem 1rem}.schedule-header{display:flex;justify-content:flex-end;align-items:flex-end;margin-bottom:2rem;background-color:transparent;gap:2rem}.schedule-content{display:flex;flex-direction:column;gap:2rem}.schedule-file-info h3{font-family:KBH,sans-serif;font-weight:500;font-size:1.25rem;color:#000c2e;margin:0 0 .25rem}.schedule-file-info p{font-family:KBH_Tekst,sans-serif;color:#6b7280;margin:0;font-size:.875rem}.header-content h1{font-family:KBH,sans-serif;font-weight:500;font-size:2.5rem;color:#000c2e;margin:0 0 .5rem}.upload-new-button{display:flex;justify-content:flex-end;align-items:center;gap:.5rem;background-color:#000c2e;color:#fff;border:none;padding:.75rem 1rem;border-radius:10px;font-family:KBH_Tekst,sans-serif;font-size:.95rem;cursor:pointer;transition:background-color .2s ease;white-space:nowrap}.upload-new-button:hover{background-color:#1a2332}.error-message{background-color:#fef2f2;border:1px solid #FECACA;border-radius:8px;padding:1rem;margin-bottom:2rem}.error-message p{color:#dc2626;margin:0;font-family:KBH_Tekst,sans-serif}.no-schedules{text-align:center;padding:4rem 2rem;background-color:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.no-schedules-icon{color:#d1d5db;margin-bottom:1.5rem}.no-schedules h2{font-family:KBH,sans-serif;font-weight:500;font-size:1.5rem;color:#000c2e;margin:0 0 1rem}.no-schedules p{font-family:KBH_Tekst,sans-serif;color:#6b7280;margin:0 0 2rem;font-size:1.1rem}.upload-first-button{background-color:#000c2e;color:#fff;border:none;padding:.875rem 2rem;border-radius:8px;font-family:KBH_Tekst,sans-serif;font-size:1.1rem;font-weight:500;cursor:pointer;transition:background-color .2s ease}.upload-first-button:hover{background-color:#1a2332}.schedules-list{background-color:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.schedules-header{padding:1.5rem;background-color:transparent}.schedules-header h2{font-family:KBH,sans-serif;font-weight:500;font-size:1.5rem;color:#000c2e;margin:0 0 .25rem}.schedules-header p{font-family:KBH_Tekst,sans-serif;color:#6b7280;margin:0;font-size:.875rem}.schedules-grid{padding:1.5rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.schedule-card{border:1px solid #E5E7EB;border-radius:8px;padding:1.5rem;background-color:#fff;transition:box-shadow .2s ease,border-color .2s ease}.schedule-card:hover{box-shadow:0 4px 12px #0000001a;border-color:#000c2e}.schedule-card-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1rem}.schedule-icon{color:#000c2e;flex-shrink:0;margin-top:.125rem}.schedule-title{flex:1;min-width:0}.schedule-title h3{font-family:KBH,sans-serif;font-weight:500;font-size:1.125rem;color:#000c2e;margin:0 0 .25rem;word-break:break-word}.schedule-id{font-family:KBH_Tekst,sans-serif;font-size:.75rem;color:#6b7280;background-color:#f3f4f6;padding:.125rem .5rem;border-radius:4px;display:inline-block}.schedule-details{margin-bottom:1.5rem}.detail-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-family:KBH_Tekst,sans-serif;font-size:.875rem;color:#374151}.detail-row:last-child{margin-bottom:0}.detail-row svg{color:#6b7280;flex-shrink:0}.schedule-actions{display:flex;gap:.75rem}.view-button,.download-button{flex:1;padding:.5rem 1rem;border-radius:6px;font-family:KBH_Tekst,sans-serif;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid}.view-button{background-color:#000c2e;color:#fff;border-color:#000c2e}.view-button:hover{background-color:#1a2332;border-color:#1a2332}.download-button{background-color:#fff;color:#000c2e;border-color:#000c2e}.download-button:hover{background-color:#f9fafb}@media(max-width:768px){.schedule-view-container{padding:1rem}.schedule-header{flex-direction:column;align-items:stretch;gap:1rem}.header-content h1{font-size:2rem}.upload-new-button{justify-content:center}.schedule-info{flex-direction:column;align-items:stretch;gap:1rem}.schedule-file-info{flex-direction:column;align-items:flex-start;gap:.5rem}.schedule-file-info h3{font-size:1.125rem}}.institution-selection-page{position:relative;min-height:100vh;background-color:#f4f3e8;display:flex;flex-direction:column;align-items:center;padding:3rem 1rem 80px}.selection-container{flex:1;display:flex;flex-direction:column;align-items:center;padding:2rem;max-width:800px;margin:0 auto;width:100%}.selection-title{font-family:KBH_Med,sans-serif;font-weight:500;font-size:2.5rem;color:#000c2e;text-align:center;margin-bottom:1rem;line-height:1.2}.selection-subtitle{font-family:KBH_Tekst,sans-serif;font-size:1.125rem;color:#6b7280;text-align:center;margin-bottom:3rem;max-width:600px}.institutions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;width:100%;margin-bottom:3rem}.institution-card{background-color:#fff;border:2px solid #E5E7EB;border-radius:25px;padding:1.5rem;cursor:pointer;transition:all .3s ease;display:flex;justify-content:space-between;align-items:center;position:relative}.institution-card:hover{box-shadow:0 4px 12px #000c2e1a;transform:translateY(-2px)}.institution-card.selected{border-color:#000c2e;background-color:#f0f4ff;box-shadow:0 4px 12px #000c2e26}.institution-info{flex:1}.institution-name{font-family:KBH_Tekst,sans-serif;font-size:1rem;font-weight:500;color:#000c2e;margin:0 0 .5rem}.institution-municipality{font-family:KBH_Tekst,sans-serif;font-size:.875rem;color:#6b7280;margin:0}.selection-indicator{width:24px;height:24px;display:flex;align-items:center;justify-content:center}.checkmark{width:20px;height:20px;background-color:#000c2e;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.continue-section{display:flex;justify-content:center;width:100%}.continue-button{background-color:#000c2e;color:#fff;border:none;border-radius:8px;padding:1rem 2rem;font-family:KBH_Med,sans-serif;font-size:1.125rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:160px}.continue-button:hover:not(:disabled){background-color:#001a4d;transform:translateY(-1px)}.continue-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.loading-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem}.spinner{width:32px;height:32px;border:3px solid #E5E7EB;border-top:3px solid #000c2e;border-radius:50%;animation:spin 1s linear infinite}.error-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem;text-align:center}.error-container h2{font-family:KBH_Med,sans-serif;color:#dc2626;font-size:1.5rem;margin:0}.error-container p{font-family:KBH_Tekst,sans-serif;color:#6b7280;font-size:1rem;margin:0}.retry-button{background-color:#000c2e;color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-family:KBH_Med,sans-serif;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.retry-button:hover{background-color:#001a4d}@media(max-width:768px){.selection-container{padding:1rem}.selection-title{font-size:2rem;margin-bottom:.75rem}.selection-subtitle{font-size:1rem;margin-bottom:2rem}.institutions-grid{grid-template-columns:1fr;gap:1rem;margin-bottom:2rem}.institution-card{padding:1.25rem}.institution-name{font-size:1.125rem}}.vagtplansoenker-page{position:relative;min-height:100vh;background-color:#f4f3e8;display:flex;flex-direction:column;padding-bottom:80px}.vagtplansoenker-content{flex:1;padding:2rem 1rem;max-width:1200px;margin-left:auto;margin-right:auto;width:100%}.message-container{text-align:center}.message-container .add-request-button{margin-top:5rem;justify-content:center;display:inline-flex;align-items:center;width:auto;margin-left:auto;margin-right:auto}.no-wishes-message{font-family:KBH_Med,sans-serif;font-size:2rem;color:#000c2e;margin:0;line-height:1.6}.schedule-requests-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem}.sort-button,.add-request-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;font-family:KBH_Tekst,sans-serif;font-size:.95rem;border-radius:10px;color:#374151;cursor:pointer;transition:all .2s ease}.filter-menu{position:absolute;top:calc(100% + 6px);left:0;background:#fff;border-radius:10px;box-shadow:0 8px 20px #00000014;padding:.5rem;min-width:220px;z-index:10}.filter-menu-item{width:100%;text-align:left;background:transparent;border:none;padding:.5rem .75rem;border-radius:8px;font-family:KBH_Tekst,sans-serif;font-size:.95rem;color:#374151;cursor:pointer}.filter-menu-item:hover{background-color:#f3f4f6;border-color:none!important}.sort-button:hover,.add-request-button:hover{background-color:#fafafb}.sort-button:active,.add-request-button:active{transform:translateY(0)}.add-request-button{background-color:#000c2e;color:#fff}.add-request-button:hover{background-color:#2a3144;border-color:#2a3144}.schedule-requests-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;width:100%}.schedule-request-card{background:#fafafb;border-radius:25px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:transform .2s ease,box-shadow .2s ease}.schedule-request-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.schedule-request-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.schedule-request-delete{margin-left:auto;background:transparent;border:none;color:#6b7280;cursor:pointer;padding:.25rem;border-radius:8px;transition:color .2s ease,background-color .2s ease}.schedule-request-delete:hover{color:#b91c1c;background-color:#fee2e2}.schedule-request-icon{color:#000c2e;display:flex;align-items:center}.schedule-request-name{font-family:KBH_Med,sans-serif;font-size:1.25rem;color:#000c2e;margin:0}.schedule-request-card-body{display:flex;flex-direction:column;gap:.75rem}.schedule-request-user-date-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.schedule-request-user{font-family:KBH_Med,sans-serif;font-size:1rem;color:#000c2e}.schedule-request-date-time{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.schedule-request-date{font-family:KBH_Med,sans-serif;font-size:1rem;color:#374151}.schedule-request-description{font-family:KBH_Tekst,sans-serif;font-size:1rem;color:#374151;margin:0;line-height:1.4}.schedule-request-time{font-family:KBH_Med,sans-serif;font-size:.9rem;color:#6b7280}@media(max-width:768px){.vagtplansoenker-content{padding:1rem}.no-wishes-message{font-size:1.5rem}.schedule-requests-toolbar{flex-direction:column;align-items:stretch}.sort-button,.add-request-button{width:100%;justify-content:center}.filter-dropdown{width:100%}.filter-menu{width:100%;min-width:unset}.schedule-requests-grid{grid-template-columns:1fr;gap:1rem}.schedule-request-card{padding:1.25rem}}@media(max-width:480px){.schedule-request-name{font-size:1.1rem}.schedule-request-description{font-size:.9rem}}.create-request-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.create-request-modal{background:#fafafb;border-radius:40px;width:100%;max-width:800px;max-height:90vh;overflow:hidden;box-shadow:0 10px 40px #0003;display:flex;flex-direction:column}.create-request-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb;flex-shrink:0}.create-request-modal-title{font-family:KBH_Med,sans-serif;font-size:1.5rem;color:#000c2e;margin:0}.create-request-modal-close{background:none;border:none;cursor:pointer;color:#6b7280;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.create-request-modal-close:hover{color:#374151}.create-request-form{padding:1.5rem 1.75rem;display:flex;flex-direction:column;gap:1.5rem;overflow-y:auto;flex:1;scrollbar-width:thin;scrollbar-color:#d1d5db transparent}.create-request-form::-webkit-scrollbar{width:8px}.create-request-form::-webkit-scrollbar-track{background:transparent;border-radius:0 40px 40px 0}.create-request-form::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.create-request-form::-webkit-scrollbar-thumb:hover{background:#9ca3af}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-family:KBH_Med,sans-serif;font-size:.95rem;color:#374151;font-weight:500}.form-group input,.form-group textarea,.form-group select{font-family:KBH_Tekst,sans-serif;font-size:1rem;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;color:#374151;transition:border-color .2s ease}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#000c2e}.form-group textarea{resize:vertical;min-height:80px}.day-bubbles{display:flex;justify-content:space-between;gap:.5rem;padding:0 10%}.day-bubble{width:48px;height:48px;border-radius:50%;border:1px solid #d1d5db;font-family:KBH_Med,sans-serif;font-size:1.1rem;background:#fff;color:#374151;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0}.day-bubble:hover{background-color:#e5e7eb;transform:scale(1.05)}.day-bubble-selected{background-color:#000c2e;color:#fff}.day-bubble-selected:hover{background-color:#1a2540;transform:scale(1.05)}.frequency-section{margin-top:1rem;padding-left:1rem}.frequency-toggle-button{font-family:KBH_Tekst,sans-serif;font-size:.85rem;color:#374151;background:transparent;align-self:center;border:none;cursor:pointer;transition:opacity .45 ease;opacity:.7}.frequency-toggle-button:hover{opacity:.5}.frequency-expanded{display:flex;align-items:baseline;gap:5rem}.frequency-text{font-family:KBH_Tekst,sans-serif;font-size:.85rem;color:#374151;display:flex;align-items:baseline;flex-wrap:wrap;gap:.25rem}.frequency-dropdown{font-family:KBH_Tekst,sans-serif;font-size:.85rem!important;padding:.25rem .5rem!important;border:1px solid #d1d5db;border-radius:6px;color:#374151;background:#fff;cursor:pointer;transition:border-color .2s ease}.frequency-dropdown:focus{outline:none;border-color:#000c2e}.frequency-collapse-button{font-family:KBH_Tekst,sans-serif;font-size:.85rem;color:#374151;background:transparent;border:none;cursor:pointer;transition:color .2s ease;align-self:center;opacity:.7}.frequency-collapse-button:hover{color:#dc2626}.time-group{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.time-input-wrapper{display:flex;flex-direction:column;gap:.5rem}.form-error{padding:.75rem;background-color:#fee2e2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;font-family:KBH_Tekst,sans-serif;font-size:.9rem}.form-actions{display:flex;justify-content:flex-end;gap:1rem;padding-top:.5rem}.delete-button,.cancel-button,.submit-button{padding:.75rem 1.5rem;font-family:KBH_Med,sans-serif;font-size:.95rem;border-radius:10px;cursor:pointer;transition:all .2s ease;border:none}.delete-button{background-color:#f3f4f6;color:#374151;margin-right:auto}.delete-button:hover:not(:disabled){background-color:#dc2626;color:#fff}.cancel-button{background-color:#f3f4f6;color:#374151}.cancel-button:hover:not(:disabled){background-color:#e5e7eb}.submit-button{background-color:#000c2e;color:#fff}.submit-button:hover:not(:disabled){background-color:#1a2540}.delete-button:disabled,.cancel-button:disabled,.submit-button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.create-request-modal{max-width:100%;margin:1rem}.day-bubbles{gap:.25rem}.day-bubble{width:40px;height:40px;font-size:1rem}.time-group{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.delete-button,.cancel-button,.submit-button{width:100%}.delete-button{order:-1}}.bemanding-page{position:relative;min-height:100vh;background-color:#f4f3e8;font-family:KBH_Tekst,sans-serif;padding-bottom:50px}.bemanding-container{max-width:1400px;margin:0 auto;padding:2rem 1rem}.bemanding-content{padding:2rem;position:relative;overflow:visible;width:100%;max-width:100%}.bemanding-header{margin-bottom:3.5rem;display:flex;justify-content:space-between;align-items:center}.bemanding-header h2{font-family:KBH_Med,sans-serif;font-weight:500;font-size:1.5rem;color:#000c2e;margin:0}.error-message{background-color:#fef2f2;border:1px solid #FECACA;border-radius:8px;padding:1rem;margin-bottom:1.5rem;color:#dc2626;font-family:KBH_Tekst,sans-serif;font-size:.875rem}.filter-dropdown{position:relative}.filter-menu{position:absolute;top:calc(100% + 6px);left:0;background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 8px 20px #00000014;padding:.5rem;min-width:220px;z-index:10}.filter-menu-item{width:100%;text-align:left;background:transparent;border:none;outline:none;padding:.5rem .75rem;border-radius:8px;font-family:KBH_Tekst,sans-serif;font-size:.95rem;color:#374151;cursor:pointer}.filter-menu-item:hover{background-color:#f3f4f6;border:none;outline:none}.filter-menu-item:focus{border:none;outline:none}.sort-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;font-family:KBH_Tekst,sans-serif;font-size:.95rem;border-radius:10px;color:#374151;cursor:pointer;transition:all .2s ease;background:transparent;border:1px solid transparent}.sort-button:hover{background-color:#fafafb}.sort-button:active{transform:translateY(0)}.bemanding-grid{display:flex;flex-direction:column;gap:2rem;align-items:center}.grid-header{display:grid;grid-template-columns:200px repeat(4,1fr);gap:2rem;margin-bottom:.5rem}.time-slot-header{font-family:KBH_Tekst,sans-serif;font-size:1rem;font-weight:500;color:#000c2e;text-align:center;padding:.5rem}.grid-row{display:grid;grid-template-columns:200px repeat(4,1fr);gap:2rem;align-items:stretch;max-width:1200px;width:100%}.day-label{font-family:KBH_Tekst,sans-serif;font-size:1rem;font-weight:500;color:#000c2e;display:flex;justify-content:flex-end;align-items:top;padding:.75rem 2rem}.time-slot-cell{background-color:#fff;box-shadow:0 2px 8px #0000001a;border-radius:25px;padding:1rem 1rem 1.5rem;display:flex;flex-direction:column;gap:.5rem;min-height:100px;margin:.5rem rem;align-items:center}.save-cell{display:flex;align-items:center;justify-content:center}.day-save-button{font-family:KBH_Tekst,sans-serif;font-size:.875rem;color:#fff;background-color:#000c2e;border:none;border-radius:10px;padding:.5rem 1rem;cursor:pointer;transition:all .2s ease;font-weight:500}.day-save-button:hover:not(:disabled){background-color:#000c2e;transform:translateY(-1px)}.day-save-button:disabled{opacity:0;transform:none}.cell-divider{width:100px;height:.5px;background-color:#cdced5;margin-bottom:.75rem}.cell-label{font-family:KBH_Tekst,sans-serif;font-size:.875rem;font-weight:500;color:#000c2e;margin-bottom:.5rem;text-align:center}.input-wrapper{position:relative;width:100%;max-width:85%}.input-top-label{position:absolute;top:-8px;left:12px;background-color:#fff;padding:0 4px;font-family:KBH_Tekst,sans-serif;font-size:.7rem;color:#6b7280;font-weight:500;z-index:1}.cell-input{background-color:#fff;border:1px solid #6B7280;border-radius:8px;padding:.75rem;font-family:KBH_Tekst,sans-serif;font-size:1rem;color:#000c2e;outline:none;transition:border-color .2s ease;text-align:center;width:100%;height:60px}.cell-input:hover{border-color:#000c2e;box-shadow:0 2px 8px #0000001a}.cell-input::-webkit-outer-spin-button,.cell-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.cell-input[type=number]{-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.cell-input:focus{border-color:#000c2e;box-shadow:none}.cell-input.modified{border-color:#0a2df2;border-width:1px}.cell-input.modified:focus{border-color:#0a2df2;box-shadow:0 0 0 2px #0a2df21a}.input-wrapper:has(.cell-input.modified) .input-top-label{color:#0a2df2}.cell-input::-moz-placeholder{color:#d1d5db;font-size:1rem}.cell-input::placeholder{color:#d1d5db;font-size:1rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem}.spinner{width:32px;height:32px;border:3px solid #E5E7EB;border-top:3px solid #000c2e;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{font-family:KBH_Tekst,sans-serif;color:#000c2e;font-size:.875rem;margin:0}@media(max-width:1024px){.bemanding-container{max-width:100%;padding:1.5rem 1rem}.grid-header,.grid-row{grid-template-columns:120px repeat(4,1fr);gap:.75rem}.day-label{font-size:.9rem;padding:.75rem 0}.time-slot-header{font-size:.9rem}.time-slot-cell{padding:.875rem;min-height:140px}.cell-input{font-size:.8rem;padding:.625rem}}@media(max-width:768px){.bemanding-container{padding:1rem}.bemanding-content{padding:1.5rem;border-radius:24px}.bemanding-header{margin-bottom:1.5rem}.bemanding-header h2{font-size:1.25rem}.grid-header,.grid-row{grid-template-columns:80px repeat(4,1fr);gap:.5rem}.day-label{font-size:.8rem;padding:.5rem 0}.time-slot-header{font-size:.8rem;padding:.25rem}.time-slot-cell{padding:.75rem;min-height:120px}.cell-divider{width:30px;height:1.5px}.cell-label{font-size:.75rem}.cell-input{font-size:.75rem;padding:.5rem}}.app{min-height:100vh;background-color:#f4f3e8}
