*,: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:Inter,system-ui,sans-serif;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}.collapse{visibility:collapse}.fixed{position:fixed}.relative{position:relative}.sticky{position:sticky}.ml-1{margin-left:.25rem}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.shrink-0{flex-shrink:0}.resize{resize:both}.items-center{align-items:center}.gap-1{gap:.25rem}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rounded{border-radius:.25rem}.border{border-width:1px}.border-l-2{border-left-width:2px}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.uppercase{text-transform:uppercase}.italic{font-style:italic}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.line-through{text-decoration-line:line-through}.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)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root{--edeka-yellow: #FFD700;--edeka-yellow-dark: #F5C400;--edeka-red: #E2001A;--edeka-dark: #1A1A1A;--edeka-gray: #3A3A3A;--edeka-light: #F7F7F7;--edeka-white: #FFFFFF;--edeka-border: #E0E0E0;--edeka-green: #2E7D32;--edeka-blue: #1565C0;--edeka-orange: #E65100;--shadow-sm: 0 2px 8px rgba(0,0,0,.1);--shadow-md: 0 4px 20px rgba(0,0,0,.13);--shadow-lg: 0 8px 40px rgba(0,0,0,.16);--radius: 10px;--radius-lg: 16px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Barlow,sans-serif;background:var(--edeka-light);color:var(--edeka-dark);min-height:100vh;-webkit-font-smoothing:antialiased}button,select,input,textarea{-webkit-tap-highlight-color:transparent}select,input,textarea{font-size:16px}.top-strip{height:4px;background:var(--edeka-yellow)}.header-top{background:var(--edeka-dark);display:flex;align-items:center;justify-content:space-between;padding:10px 24px;border-bottom:3px solid var(--edeka-yellow)}.logo{display:flex;align-items:center;gap:14px}.logo-badge{background:var(--edeka-yellow);color:var(--edeka-dark);font-family:Barlow Condensed,sans-serif;font-weight:800;font-size:22px;letter-spacing:1px;padding:4px 14px;border-radius:6px;line-height:1.2}.logo-text{color:var(--edeka-white);font-family:Barlow Condensed,sans-serif;font-size:17px;font-weight:600;letter-spacing:.5px;opacity:.85}.header-user{display:flex;align-items:center;gap:12px}.header-user-name{color:#fff9;font-size:13px;font-weight:500}.header-user-role{background:#ffd70033;color:var(--edeka-yellow);font-size:11px;font-weight:700;padding:2px 8px;border-radius:4px;text-transform:uppercase}.header-logout{background:none;border:none;color:#fff6;font-size:13px;font-weight:500;cursor:pointer;transition:color .15s;font-family:Barlow,sans-serif}.header-logout:hover{color:#fff}.header-nav-bar{background:#111;display:flex;align-items:center;justify-content:center;padding:6px 16px;position:sticky;top:0;z-index:1000;box-shadow:var(--shadow-md);overflow-x:auto;gap:2px}.nav-btn{background:none;border:none;color:#fff9;font-family:Barlow,sans-serif;font-size:14px;font-weight:500;padding:7px 14px;border-radius:6px;cursor:pointer;transition:all .15s;white-space:nowrap;text-decoration:none;display:inline-flex;align-items:center;gap:4px}.nav-btn.active,.nav-btn:hover{background:var(--edeka-yellow);color:var(--edeka-dark);font-weight:700}.bereich-bar{background:#111;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 24px;border-bottom:3px solid var(--edeka-yellow)}.bereich-label{color:#fff6;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-right:8px}.bereich-btn{display:flex;align-items:center;gap:8px;padding:8px 22px;border-radius:8px;border:2px solid transparent;font-family:Barlow Condensed,sans-serif;font-size:16px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;cursor:pointer;transition:all .18s;background:#ffffff12;color:#ffffff80}.bereich-btn:hover{background:#ffffff21;color:#fff}.bereich-btn.active-markt{background:var(--edeka-yellow);color:var(--edeka-dark);border-color:var(--edeka-yellow-dark);box-shadow:0 2px 12px #ffd70059}.bereich-btn.active-metzgerei{background:#c62828;color:#fff;border-color:#b71c1c;box-shadow:0 2px 12px #c6282859}.bereich-icon{font-size:18px}.app-page{padding:24px;max-width:1400px;margin:0 auto;width:100%}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:12px}.page-title{font-family:Barlow Condensed,sans-serif;font-size:30px;font-weight:800;color:var(--edeka-dark);letter-spacing:.5px;text-transform:uppercase}.page-title span{color:var(--edeka-red)}.year-nav-bar{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;background:#fff;border:1px solid var(--edeka-border);border-radius:var(--radius);padding:12px 20px;margin-bottom:16px;box-shadow:var(--shadow-sm)}.year-nav-label{font-family:Barlow Condensed,sans-serif;font-size:28px;font-weight:800;color:var(--edeka-dark);min-width:70px;text-align:center;background:var(--edeka-yellow);padding:2px 14px;border-radius:6px}.year-range-label{font-size:13px;font-weight:600;color:var(--edeka-dark);background:var(--edeka-light);border:1px solid var(--edeka-border);border-radius:6px;padding:4px 10px;white-space:nowrap}.year-legend{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-left:16px;padding-left:16px;border-left:2px solid var(--edeka-border)}.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--edeka-gray)}.legend-dot{width:14px;height:14px;border-radius:3px;flex-shrink:0}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:7px;border:none;font-family:Barlow,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.btn-primary{background:var(--edeka-yellow);color:var(--edeka-dark)}.btn-primary:hover{background:var(--edeka-yellow-dark);box-shadow:var(--shadow-sm)}.btn-danger{background:var(--edeka-red);color:#fff}.btn-danger:hover{opacity:.88}.btn-outline{background:#fff;color:var(--edeka-dark);border:2px solid var(--edeka-border)}.btn-outline:hover{border-color:var(--edeka-yellow);background:#fffde7}.btn-sm{padding:5px 11px;font-size:12px;border-radius:5px}.btn-dark{background:var(--edeka-dark);color:#fff}.btn-dark:hover{background:var(--edeka-gray)}.card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--edeka-border);overflow:hidden}.card-header{background:var(--edeka-dark);color:#fff;padding:14px 20px;font-family:Barlow Condensed,sans-serif;font-size:17px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;justify-content:space-between}.card-body{padding:20px}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:20px}.stat-card{background:#fff;border:1px solid var(--edeka-border);border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-sm)}.stat-icon{font-size:24px;flex-shrink:0}.stat-val{font-family:Barlow Condensed,sans-serif;font-size:26px;font-weight:800;color:var(--edeka-dark);line-height:1}.stat-label{font-size:12px;color:#888;font-weight:500;margin-top:2px}.form-grid{display:grid;gap:14px}.form-grid-2{grid-template-columns:1fr 1fr}.form-grid-3{grid-template-columns:1fr 1fr 1fr}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:12px;font-weight:600;color:var(--edeka-gray);text-transform:uppercase;letter-spacing:.4px}.form-input,.form-select,.form-textarea{padding:9px 12px;border:2px solid var(--edeka-border);border-radius:7px;font-family:Barlow,sans-serif;font-size:14px;background:#fff;transition:border-color .15s;color:var(--edeka-dark)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--edeka-yellow)}input[type=color]{height:42px;cursor:pointer;padding:4px 8px}.pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;gap:5px}.pill-yellow{background:var(--edeka-yellow);color:var(--edeka-dark)}.pill-red{background:var(--edeka-red);color:#fff}.pill-green{background:#e8f5e9;color:var(--edeka-green)}.pill-blue{background:#e3f2fd;color:var(--edeka-blue)}.staff-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.staff-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--edeka-border);overflow:hidden;transition:box-shadow .2s,transform .15s;cursor:pointer}.staff-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.staff-card-top{padding:18px 18px 14px;display:flex;align-items:center;gap:14px}.staff-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Barlow Condensed,sans-serif;font-size:20px;font-weight:800;color:#fff;flex-shrink:0}.staff-name{font-weight:700;font-size:15px;line-height:1.2}.staff-role{font-size:12px;color:#777;margin-top:2px}.staff-card-bottom{border-top:1px solid var(--edeka-border);padding:10px 18px;display:flex;justify-content:space-between;align-items:center;background:#fafafa}.staff-hours{font-size:12px;color:#666;font-weight:500}.schicht-list{display:flex;flex-direction:column;gap:10px}.schicht-item{background:#fff;border-radius:var(--radius);border:1px solid var(--edeka-border);padding:14px 18px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm);transition:box-shadow .15s}.schicht-item:hover{box-shadow:var(--shadow-md)}.schicht-color-bar{width:5px;height:44px;border-radius:4px;flex-shrink:0}.schicht-info{flex:1}.schicht-name{font-weight:700;font-size:15px}.schicht-time{font-size:13px;color:#666;margin-top:2px}.schicht-actions{display:flex;gap:7px;flex-shrink:0}.default-staff-pills{display:flex;flex-wrap:wrap;gap:5px;margin-top:7px}.default-staff-pill{background:#f5f5f5;border:1px solid #DDD;border-radius:20px;font-size:11px;font-weight:600;padding:2px 9px;color:var(--edeka-gray)}.plan-table-wrap{overflow-x:auto;margin-top:18px}.plan-table{width:100%;border-collapse:separate;border-spacing:0;min-width:800px}.plan-table th{background:var(--edeka-dark);color:#fff;font-family:Barlow Condensed,sans-serif;font-size:15px;font-weight:700;text-transform:uppercase;padding:12px 16px;text-align:left;letter-spacing:.5px}.plan-table th:first-child{border-radius:10px 0 0}.plan-table th:last-child{border-radius:0 10px 0 0}.plan-table th.today-header{background:var(--edeka-yellow);color:var(--edeka-dark)}.plan-table td{background:#fff;padding:8px 10px;vertical-align:top;border-bottom:1px solid #F0F0F0;border-right:1px solid #F0F0F0;min-width:130px;min-height:80px}.plan-table tr:last-child td{border-bottom:none}.schicht-label{font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:700;color:#fff;padding:4px 8px;border-radius:5px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;margin-bottom:5px;transition:opacity .15s}.schicht-label:hover{opacity:.85}.plan-assigned{display:flex;flex-direction:column;gap:3px;margin-top:4px}.plan-person{font-size:11px;background:#f5f5f5;border-radius:4px;padding:2px 7px;font-weight:600;color:#444;display:flex;align-items:center;justify-content:space-between;gap:4px}.plan-person .del-person{cursor:pointer;color:#bbb;font-size:13px;line-height:1;flex-shrink:0}.plan-person .del-person:hover{color:var(--edeka-red)}.plan-add-btn{font-size:11px;color:var(--edeka-yellow-dark);background:none;border:1.5px dashed var(--edeka-yellow-dark);border-radius:5px;padding:3px 8px;cursor:pointer;font-weight:600;width:100%;transition:all .12s;margin-top:3px;font-family:Barlow,sans-serif}.plan-add-btn:hover{background:#fffde7}.day-col-header{font-weight:700;font-size:14px}.day-col-date{font-size:11px;opacity:.7;font-weight:400}.mobile-plan{display:none}.mobile-day-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--edeka-border);margin-bottom:14px;overflow:hidden}.mobile-day-header{background:var(--edeka-dark);color:#fff;padding:12px 16px;font-family:Barlow Condensed,sans-serif;font-size:17px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.mobile-day-header.today{background:var(--edeka-yellow);color:var(--edeka-dark)}.mobile-day-body{padding:12px;display:flex;flex-direction:column;gap:8px}.mobile-schicht-block{border-radius:8px;overflow:hidden;border:1px solid #EEE}.mobile-schicht-title{color:#fff;font-weight:700;font-size:13px;padding:7px 12px;display:flex;justify-content:space-between;align-items:center}.mobile-schicht-persons{padding:8px 12px;background:#fafafa;display:flex;flex-wrap:wrap;gap:5px}.mobile-person-chip{background:#fff;border:1px solid #DDD;border-radius:20px;font-size:12px;font-weight:600;padding:3px 10px;color:#444}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:2000;display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{background:var(--edeka-dark);color:#fff;padding:16px 20px;font-family:Barlow Condensed,sans-serif;font-size:19px;font-weight:800;text-transform:uppercase;display:flex;align-items:center;justify-content:space-between;border-radius:var(--radius-lg) var(--radius-lg) 0 0;letter-spacing:.5px}.modal-header-red{background:#c62828}.modal-close{background:none;border:none;color:#fff9;font-size:22px;cursor:pointer;line-height:1;transition:color .15s}.modal-close:hover{color:#fff}.modal-body{padding:20px}.modal-footer{padding:14px 20px;border-top:1px solid var(--edeka-border);display:flex;justify-content:flex-end;gap:10px}.staff-chooser{display:flex;flex-wrap:wrap;gap:7px;max-height:200px;overflow-y:auto;padding:4px}.staff-choice{background:#f5f5f5;border:2px solid #EEE;border-radius:7px;padding:6px 12px;font-size:13px;font-weight:600;cursor:pointer;transition:all .12s;color:var(--edeka-dark)}.staff-choice:hover{border-color:var(--edeka-yellow);background:#fffde7}.staff-choice.selected{background:var(--edeka-yellow);border-color:var(--edeka-yellow-dark)}.shift-btn{flex:1;padding:10px;border-radius:8px;border:2px solid #E0E0E0;background:#fff;font-size:14px;font-weight:700;cursor:pointer;transition:all .15s;font-family:Barlow,sans-serif}.shift-btn-active-frueh{background:#e3f2fd!important;border-color:#1565c0!important;color:#1565c0!important}.shift-btn-active-spaet{background:#fff3e0!important;border-color:#e65100!important;color:#e65100!important}.shift-btn-active-beide{background:#fffde7!important;border-color:#f5c400!important;color:#1a1a1a!important}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.status-approved{background:#e8f5e9;color:#2e7d32}.status-pending{background:#fffde7;color:#f57f17}.status-rejected{background:#ffebee;color:#c62828}.urlaub-list{display:flex;flex-direction:column;gap:8px}.urlaub-entry{background:#fff;border-radius:var(--radius);border:1px solid var(--edeka-border);padding:14px 16px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow-sm);transition:box-shadow .15s}.urlaub-entry:hover{box-shadow:var(--shadow-md)}.urlaub-entry-top{display:flex;align-items:center;gap:12px}.urlaub-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Barlow Condensed,sans-serif;font-size:15px;font-weight:800;color:#fff;flex-shrink:0}.urlaub-info{flex:1;min-width:0}.urlaub-name{font-weight:700;font-size:14px}.urlaub-dates{font-size:12px;color:#777;margin-top:2px}.urlaub-note{font-size:12px;color:#999;font-style:italic;margin-top:2px}.urlaub-entry-bottom{display:flex;align-items:center;gap:8px;flex-wrap:wrap;border-top:1px solid #F0F0F0;padding-top:10px}.urlaub-actions{display:flex;gap:6px;align-items:center;margin-left:auto}.urlaub-tage-badge{background:var(--edeka-dark);color:var(--edeka-yellow);font-family:Barlow Condensed,sans-serif;font-size:15px;font-weight:800;padding:3px 10px;border-radius:6px;white-space:nowrap}.urlaub-calendar{overflow-x:auto}.urlaub-cal-table{width:100%;border-collapse:separate;border-spacing:0;min-width:900px;font-size:12px}.urlaub-cal-table th{background:var(--edeka-dark);color:#fff;padding:8px 6px;text-align:center;font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:700;letter-spacing:.3px;white-space:nowrap}.urlaub-cal-table th:first-child{border-radius:10px 0 0;text-align:left;padding-left:14px;min-width:150px;position:sticky;left:0;z-index:3}.urlaub-cal-table th:last-child{border-radius:0 10px 0 0}.urlaub-cal-table td{background:#fff;border-bottom:1px solid #F0F0F0;border-right:1px solid #F5F5F5;padding:0;height:32px;text-align:center;vertical-align:middle;position:relative}.urlaub-cal-table td:first-child{padding:6px 14px;text-align:left;background:#fafafa;border-right:2px solid #EEE;white-space:nowrap;position:sticky;left:0;z-index:2;box-shadow:2px 0 6px #00000012}.urlaub-cal-table td.weekend{background:#f9f9f9}.urlaub-block{display:flex;height:100%;width:100%;min-height:32px;align-items:center;justify-content:center}.urlaub-block.approved{background:#c8e6c9}.urlaub-block.pending{background:#fff9c4}.urlaub-block.rejected,.urlaub-block.sick{background:#ffcdd2}.urlaub-block.holiday{background:#7b1fa2}.month-header-row td:first-child{position:sticky;left:0;z-index:3;background:#f0f0f0!important;box-shadow:2px 0 6px #00000012}.month-header-row td{background:#f0f0f0!important;font-family:Barlow Condensed,sans-serif;font-weight:700;font-size:12px;color:#666;letter-spacing:.5px;text-transform:uppercase;padding:4px 2px!important;height:20px!important;border-bottom:1px solid #E0E0E0!important}.filter-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;align-items:center}.sep{height:1px;background:var(--edeka-border);margin:16px 0}.empty-state{text-align:center;padding:40px 20px;color:#aaa}.empty-state .empty-icon{font-size:48px;margin-bottom:12px}.empty-state p{font-size:15px;font-weight:500}.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999}.toast-msg{background:var(--edeka-dark);color:#fff;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:8px;animation:toastIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes toastIn{0%{transform:translateY(80px);opacity:0}to{transform:translateY(0);opacity:1}}.toast-dot{width:8px;height:8px;background:var(--edeka-yellow);border-radius:50%;flex-shrink:0}@media(max-width:750px){.header-top{padding:8px 14px}.nav-btn{font-size:12px;padding:6px 10px}.logo-text{display:none}.app-page{padding:14px}.page-title{font-size:22px}.form-grid-2,.form-grid-3{grid-template-columns:1fr}.plan-table-wrap{display:none}.mobile-plan{display:block}.stats-row{grid-template-columns:repeat(2,1fr);gap:8px}.stat-card{padding:10px 12px}.stat-val{font-size:20px}.staff-grid{grid-template-columns:1fr}.bereich-bar{padding:6px 14px}.bereich-btn{padding:6px 16px;font-size:14px}}@media(max-width:480px){.nav-btn{font-size:11px;padding:5px 8px}}@media print{.header-top,.header-nav-bar,.bereich-bar,.page-header .btn,.plan-add-btn,.del-person{display:none!important}.app-page{padding:0}.plan-table td,.plan-table th{border:1px solid #CCC!important}body{background:#fff}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--edeka-dark);display:flex;align-items:stretch;z-index:1000;box-shadow:0 -2px 12px #00000026;border-top:2px solid var(--edeka-yellow);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding:0 4px}.bottom-nav::-webkit-scrollbar{display:none}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 14px;min-width:64px;color:#ffffff80;text-decoration:none;font-family:Barlow,sans-serif;font-size:10px;font-weight:600;transition:all .15s;white-space:nowrap;flex-shrink:0}.bottom-nav-item.active{color:var(--edeka-yellow)}.bottom-nav-item:hover{color:#fff}.bottom-nav-icon{font-size:20px;line-height:1;margin-bottom:2px}.bottom-nav-label{font-size:10px;letter-spacing:.3px}.header-nav-bar{display:none}body{padding-bottom:64px}.slot-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:800;font-family:Barlow Condensed,sans-serif;padding:1px 6px;border-radius:3px;color:#fff;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.absence-banner{background:#fff3e0;border:1px solid #FFE0B2;border-radius:var(--radius);padding:10px 16px;margin-bottom:12px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}.absence-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700}.absence-chip-urlaub{background:#e8f5e9;color:#2e7d32}.absence-chip-krank{background:#ffebee;color:#c62828}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}@media(max-width:750px){.stats-row{grid-template-columns:repeat(2,1fr)}}.hover\:text-red-500:hover{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}
