
:root{
  --bg:#f3f5f7;
  --panel:#ffffff;
  --line:#cfd6dd;
  --line-strong:#aab4bf;
  --text:#1f2937;
  --muted:#667085;
  --blue:#134a8e;
  --blue-2:#e8f0fb;
  --head:#eef3f7;
  --subhead:#dfe7ee;
  --sticky:#f8fafc;
  --accent:#163d73;
  --shadow:0 10px 30px rgba(17,24,39,.08);
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family:Arial, Helvetica, sans-serif;
  background:var(--bg);
  color:var(--text);
}
button,input,select{
  font:inherit;
}
.hidden{display:none!important}
.app-shell{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:32px;
}
.card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:var(--shadow);
}
.login{
  width:min(980px,100%);
  display:grid;
  grid-template-columns:1.2fr .9fr;
  gap:24px;
}
.login .intro{
  padding:34px;
}
.login .form{
  padding:28px;
}
.badge{
  display:inline-block;
  background:var(--blue-2);
  color:var(--accent);
  border:1px solid #c7d7f0;
  border-radius:999px;
  padding:8px 12px;
  font-size:13px;
  font-weight:700;
}
h1,h2,h3,p{margin:0}
.intro h1{font-size:40px; line-height:1.1; margin:16px 0}
.intro p{color:var(--muted); font-size:18px; line-height:1.5}
.demo-box{
  margin-top:22px;
  padding:16px;
  background:#f8fafc;
  border:1px dashed var(--line-strong);
  border-radius:14px;
}
.field{margin-top:14px}
label{display:block; margin-bottom:6px; font-size:14px; color:#344054; font-weight:700}
input{
  width:100%;
  border:1px solid var(--line);
  border-radius:12px;
  padding:12px 14px;
  background:#fff;
}
.btn{
  border:0;
  cursor:pointer;
  border-radius:12px;
  padding:12px 16px;
  font-weight:700;
}
.btn-primary{background:var(--accent); color:#fff}
.btn-secondary{background:#eef2f6; color:#21304d}
.dashboard-wrap{
  min-height:100vh;
  padding:24px;
}
.topbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  margin-bottom:18px;
}
.topbar .left h1{font-size:30px}
.topbar .left p{margin-top:6px; color:var(--muted)}
.actions{display:flex; gap:10px; align-items:center}
.grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(240px,1fr));
  gap:20px;
}
.tile{
  padding:24px;
  min-height:180px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.tile h3{font-size:26px;overflow-wrap:anywhere;word-break:break-word}
.tile p{color:var(--muted); line-height:1.45;overflow-wrap:anywhere;word-break:break-word}
.tile > div{min-width:0}
.grid-dashboard > .tile{min-width:0}
.page{
  min-height:100vh;
  padding:18px;
}
.page-header{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:14px;
}
.page-header h2{font-size:28px}
.page-header p{color:var(--muted); margin-top:6px}
.toolbar{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.select{
  border:1px solid var(--line);
  border-radius:10px;
  padding:10px 12px;
  background:white;
}
.table-card{padding:12px}
.table-wrap{
  overflow:auto;
  border:1px solid var(--line);
  border-radius:14px;
  max-height:76vh;
  background:white;
}
.sheet{
  border-collapse:separate;
  border-spacing:0;
  min-width:max-content;
  width:max-content;
}
.sheet th,.sheet td{
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:6px 8px;
  text-align:center;
  white-space:nowrap;
  font-size:13px;
  min-width:44px;
  height:34px;
}
.sheet tr:first-child th,.sheet tr:first-child td{border-top:1px solid var(--line)}
.sheet th:first-child,.sheet td:first-child{border-left:1px solid var(--line)}
.sheet .head1{background:var(--head); font-weight:700}
.sheet .head2{background:var(--subhead); font-weight:700}
.sheet .left{ text-align:left }
.sheet .title-cell{
  background:#f7fafc;
  font-weight:700;
}
.sheet .muted{color:var(--muted)}
.sticky-top{
  position:sticky;
  top:0;
  z-index:5;
}
.sticky-top-2{
  position:sticky;
  top:34px;
  z-index:5;
}
.sticky-top-3{
  position:sticky;
  top:68px;
  z-index:5;
}
.sticky-col-1{position:sticky; left:0; z-index:4; background:var(--sticky)}
.sticky-col-2{position:sticky; left:92px; z-index:4; background:var(--sticky)}
.sticky-col-3{position:sticky; left:230px; z-index:4; background:var(--sticky)}
.sticky-col-4{position:sticky; left:368px; z-index:4; background:var(--sticky)}
.sticky-col-1.head1,.sticky-col-2.head1,.sticky-col-3.head1,.sticky-col-4.head1,
.sticky-col-1.head2,.sticky-col-2.head2,.sticky-col-3.head2,.sticky-col-4.head2,
.sticky-col-1.sticky-top,.sticky-col-2.sticky-top,.sticky-col-3.sticky-top,.sticky-col-4.sticky-top,
.sticky-col-1.sticky-top-2,.sticky-col-2.sticky-top-2,.sticky-col-3.sticky-top-2,.sticky-col-4.sticky-top-2,
.sticky-col-1.sticky-top-3,.sticky-col-2.sticky-top-3,.sticky-col-3.sticky-top-3,.sticky-col-4.sticky-top-3{
  z-index:8;
}
.col-schicht{min-width:92px}
.col-name{min-width:138px}
.col-role{min-width:74px}
.code-x{background:transparent; color:inherit; font-weight:inherit}
.code-kr{background:transparent; color:inherit; font-weight:inherit}
.code-vdu,.code-pda,.code-tkl,.code-aba{background:#ecfdf3; color:#166534; font-weight:700}
.code-a{background:#fee2e2; color:#991b1b; font-weight:700}
.month-row:nth-child(even) td{background:#fbfdff}
.legend{
  display:flex; gap:8px; flex-wrap:wrap; margin-bottom:12px;
}
.legend span{
  border:1px solid var(--line);
  background:white;
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  font-weight:700;
}
.note{
  margin-top:10px;
  color:var(--muted);
  font-size:13px;
}
@media (max-width: 900px){
  .login{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
}


.note{
  margin-top:10px;
  color:var(--muted);
  font-size:13px;
}

.sheet--shift .col-schicht{
  width:92px;
  min-width:92px;
  max-width:92px;
}
.sheet--shift .col-name{
  width:138px;
  min-width:138px;
  max-width:138px;
}
.sheet--vacation .col-name{
  width:138px;
  min-width:138px;
  max-width:138px;
}

.sheet--shift .sticky-col-1{left:0}
.sheet--shift .sticky-col-2{left:92px}
.sheet--shift .sticky-col-3{left:230px}

.sheet--vacation .sticky-col-1{left:0}
.sheet--vacation .sticky-col-2{left:138px}
.sheet--vacation .sticky-col-3{left:276px}

.sheet .sticky-col-1,
.sheet .sticky-col-2,
.sheet .sticky-col-3,
.sheet .sticky-col-4{
  background:var(--sticky);
  background-clip:padding-box;
}

.sheet td.sticky-col-1,
.sheet td.sticky-col-2,
.sheet td.sticky-col-3,
.sheet td.sticky-col-4,
.sheet th.sticky-col-1,
.sheet th.sticky-col-2,
.sheet th.sticky-col-3,
.sheet th.sticky-col-4{
  box-shadow:1px 0 0 0 var(--line);
}

.sheet tr:nth-child(even) td.sticky-col-1,
.sheet tr:nth-child(even) td.sticky-col-2,
.sheet tr:nth-child(even) td.sticky-col-3{
  background:#fbfdff;
}

.sheet .sticky-top.sticky-col-1,
.sheet .sticky-top.sticky-col-2,
.sheet .sticky-top.sticky-col-3,
.sheet .sticky-top-2.sticky-col-1,
.sheet .sticky-top-2.sticky-col-2,
.sheet .sticky-top-2.sticky-col-3,
.sheet .sticky-top-3.sticky-col-1,
.sheet .sticky-top-3.sticky-col-2,
.sheet .sticky-top-3.sticky-col-3{
  box-shadow:1px 0 0 0 var(--line), 0 1px 0 0 var(--line);
}

.day-col--weekend{
}
.day-col--holiday{
}

.day-header--holiday{
}
.day-header--sunday{
}
.day-header--saturday{
}
.day-col--weekend.is-selected-cell,
.day-col--holiday.is-selected-cell,
.day-col--weekend.is-active-cell,
.day-col--holiday.is-active-cell{
  background-blend-mode:multiply;
}
.separator-row td.day-col--weekend,
.position-separator-row td.day-col--weekend{
}
.separator-row td.day-col--holiday,
.position-separator-row td.day-col--holiday{
}


.separator-row td{
  height:18px;
  min-height:18px;
  background:#ffffff !important;
  border-bottom:1px solid var(--line-strong);
}
.separator-row td.day-col--weekend,
.separator-row td.day-col--holiday{
  border-bottom:1px solid var(--line-strong);
}
.separator-row .sticky-col-1,
.separator-row .sticky-col-2,
.separator-row .sticky-col-3{
  background:#ffffff !important;
  box-shadow:1px 0 0 0 var(--line);
}


.shift-label-row td{
  background:#eef4fb !important;
  font-weight:700;
  border-top:2px solid var(--line-strong);
  border-bottom:1px solid var(--line-strong);
}
.shift-label-row td.day-col--weekend,
.shift-label-row td.day-col--holiday{
  border-top:2px solid var(--line-strong);
  border-bottom:1px solid var(--line-strong);
}
.shift-label-row .sticky-col-1,
.shift-label-row .sticky-col-2,
.shift-label-row .sticky-col-3{
  background:#e7eef8 !important;
}
.shift-label-row .shift-number{
  color:#1f3b63;
}

.position-separator-row td{
  background:#fafafa !important;
  height:14px;
  min-height:14px;
  background:#ffffff !important;
  border-bottom:0 !important;
}
.position-separator-row td.day-col--weekend,
.position-separator-row td.day-col--holiday{
  border-bottom:0 !important;
}
.position-separator-row .sticky-col-1,
.position-separator-row .sticky-col-2,
.position-separator-row .sticky-col-3{
  background:#ffffff !important;
  box-shadow:1px 0 0 0 var(--line);
}

.separator-row td.day-col--weekend,
.separator-row td.day-col--holiday,
.position-separator-row td.day-col--weekend,
.position-separator-row td.day-col--holiday{
  background-color:inherit;
}

.day-col--weekend.separator-override,
.day-col--holiday.separator-override{
  background-color:inherit;
}


.grid-dashboard{
  grid-template-columns:repeat(3,minmax(240px,1fr));
}
.admin-card{
  padding:18px;
}
.admin-tabs{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:18px;
}
.admin-tab{
  border:1px solid var(--line);
  background:#f8fafc;
  color:#21304d;
  border-radius:12px;
  padding:10px 14px;
  font-weight:700;
  cursor:pointer;
}
.admin-tab.active{
  background:var(--accent);
  color:#fff;
  border-color:var(--accent);
}
.admin-layout{
  display:grid;
  grid-template-columns:420px minmax(0,1fr);
  gap:18px;
}
.admin-panel{
  padding:18px;
}
.admin-panel h3, .admin-simple-list h3{
  font-size:22px;
  margin-bottom:6px;
}
.admin-text{
  color:var(--muted);
  margin-bottom:12px;
}
.two-cols{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.qual-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.qual-check{
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#f9fbfc;
  margin:0;
}
.qual-check input{
  width:auto;
  margin:0;
}
.admin-form-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:16px;
}
.admin-table{
  width:100%;
  border-collapse:collapse;
}
.admin-table th,
.admin-table td{
  border:1px solid var(--line);
  padding:10px 12px;
  text-align:left;
  vertical-align:top;
  font-size:14px;
}
.admin-table th{
  background:var(--head);
}
.admin-table-wrap{
  max-height:62vh;
}
.role-pill{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  font-weight:700;
  background:#edf4ff;
  color:#163d73;
  border:1px solid #cbdcf6;
}
.btn-small{
  padding:8px 10px;
  font-size:12px;
  border-radius:10px;
}
.btn-danger{
  background:#fee2e2;
  color:#991b1b;
}
.admin-actions-cell{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.admin-simple-list{
  display:grid;
  gap:12px;
}
.simple-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
  padding:14px 16px;
}
.muted-row{
  margin-top:4px;
  color:var(--muted);
  font-size:13px;
}
.simple-badges{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.mini-badge{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#f8fafc;
  font-size:12px;
  font-weight:700;
}
@media (max-width: 1100px){
  .admin-layout{
    grid-template-columns:1fr;
  }
  .grid-dashboard{
    grid-template-columns:1fr;
  }
}


/* Leerzeilen zwischen Positionen exakt wie normale Mitarbeiterzeilen */
.position-separator-row td{
  height:34px !important;
  min-height:34px !important;
  background:#ffffff !important;
  border-bottom:1px solid var(--line) !important;
}
.position-separator-row .sticky-col-1,
.position-separator-row .sticky-col-2,
.position-separator-row .sticky-col-3{
  background:#ffffff !important;
  box-shadow:1px 0 0 0 var(--line);
}

/* Alle Zellen klickbar */
.sheet td,
.sheet th{
  cursor:pointer;
}
.sheet td:hover,
.sheet th:hover{
  background:#eef6ff;
}

/* Stärkere Excel-artige Markierung */
.sheet .is-active-row td,
.sheet .is-active-row th{
  box-shadow: inset 0 0 0 9999px var(--active-row-fill);
}
.sheet .is-active-col{
  box-shadow: inset 0 0 0 9999px var(--active-col-fill);
}
.sheet .is-active-cell{
  background:var(--active-cell-fill) !important;
  outline:var(--active-cell-outline-width) solid var(--active-cell-border);
  outline-offset:calc(-1 * var(--active-cell-outline-width));
  box-shadow: inset 0 0 0 var(--active-cell-inner-width) #ffffff, 0 0 0 1px var(--active-cell-border);
}
.sheet .is-active-cell.is-active-col{
  background:var(--active-cell-fill) !important;
}
.sheet .is-active-row .is-active-col{
  box-shadow: inset 0 0 0 9999px var(--active-cross-fill);
}

/* Sticky-Zellen stabil über dem Rest */
.sheet td.sticky-col-1.is-active-cell,
.sheet td.sticky-col-2.is-active-cell,
.sheet td.sticky-col-3.is-active-cell,
.sheet th.sticky-col-1.is-active-cell,
.sheet th.sticky-col-2.is-active-cell,
.sheet th.sticky-col-3.is-active-cell{
  z-index:12 !important;
}
.sheet td.sticky-col-1.is-active-col,
.sheet td.sticky-col-2.is-active-col,
.sheet td.sticky-col-3.is-active-col,
.sheet th.sticky-col-1.is-active-col,
.sheet th.sticky-col-2.is-active-col,
.sheet th.sticky-col-3.is-active-col{
  z-index:11 !important;
}


.admin-search{
  margin-bottom:14px;
}


.profile-card{
  padding:20px;
}
.profile-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.profile-actions{
  margin-top:18px;
  display:flex;
  gap:10px;
}
@media (max-width: 800px){
  .profile-grid{
    grid-template-columns:1fr;
  }
}


.qualification-filter-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  margin-top:8px;
}
.filter-toolbar{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:10px;
}
.filter-check{
  background:#fff;
}
.filter-hint{
  margin-top:10px;
  color:var(--muted);
  font-size:13px;
}
@media (max-width: 1000px){
  .qualification-filter-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (max-width: 600px){
  .qualification-filter-grid{
    grid-template-columns:1fr;
  }
}


.filter-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.filter-hint-top{
  margin-top:8px;
}
.qualification-filter-panel{
  display:none;
  margin-top:10px;
}
.qualification-filter-panel.open{
  display:block;
}


.qual-compact-list{
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
  background:#fff;
}
.qual-compact-head,
.qual-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) 80px 110px;
  gap:10px;
  align-items:center;
  padding:10px 12px;
}
.qual-compact-head{
  background:var(--head);
  font-size:12px;
  font-weight:700;
  color:#344054;
}
.qual-row{
  border-top:1px solid var(--line);
}
.qual-row:nth-child(even){
  background:#fbfdff;
}
.qual-name{
  font-weight:600;
}
.qual-mini-check{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:32px;
}
.qual-mini-check input{
  width:auto;
  margin:0;
}
.qual-mini-check.disabled{
  color:var(--muted);
}
.qual-dash{
  color:var(--muted);
  font-weight:700;
}
@media (max-width: 800px){
  .qual-compact-head,
  .qual-row{
    grid-template-columns:minmax(0,1fr) 70px 90px;
  }
}


.month-edit-cell.is-editable{
  cursor:text;
  background:#fffef0;
}
.month-edit-cell.is-editable:focus{
  outline:2px solid var(--accent);
  outline-offset:-2px;
  background:#ffffff;
}

.excel-toolbar{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin-bottom:12px;
  padding:10px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#f8fafc;
}
.formula-input{
  min-width:220px;
  max-width:320px;
  border:1px solid var(--line);
  border-radius:10px;
  padding:10px 12px;
}
.color-palette{
  display:flex;
  gap:6px;
  align-items:center;
}
.color-btn{
  width:28px;
  height:28px;
  border-radius:8px;
  border:2px solid #cbd5e1;
  cursor:pointer;
}
.color-btn.active{outline:2px solid #163d73; outline-offset:1px}
.month-edit-cell.is-editable{cursor:cell}
.month-edit-cell.is-selected-cell{
  box-shadow: inset 0 0 0 var(--selected-cell-outline-width) var(--selected-cell-border);
  background:var(--selected-cell-fill);
  position:relative;
}
.btn[disabled]{opacity:.45; cursor:not-allowed}


.excel-toolbar{position:relative}
.shiftplan-context-menu{
  position:fixed;
  z-index:50;
  min-width:160px;
  background:#fff;
  border:1px solid var(--line-strong);
  border-radius:12px;
  box-shadow:0 12px 30px rgba(17,24,39,.18);
  padding:6px;
}
.shiftplan-context-menu button{
  width:100%;
  border:0;
  background:transparent;
  text-align:left;
  padding:10px 12px;
  border-radius:8px;
  cursor:pointer;
}
.shiftplan-context-menu button:hover{background:#eef2f6}
.month-edit-cell.is-editable{position:relative; user-select:none}
.month-edit-cell.has-fill-handle::after{
  content:'';
  position:absolute;
  width:8px;
  height:8px;
  right:1px;
  bottom:1px;
  border-radius:50%;
  background:#163d73;
  border:1px solid #ffffff;
  box-shadow:0 0 0 1px #163d73;
}
.month-edit-cell.has-fill-handle{cursor:crosshair}
.month-edit-cell.is-selected-cell{
  box-shadow: inset 0 0 0 var(--selected-cell-outline-width) var(--selected-cell-border);
  background:var(--selected-cell-fill);
}
.month-edit-cell.is-active-cell{
  box-shadow: inset 0 0 0 var(--active-cell-outline-width) var(--active-cell-border);
  background:var(--active-cell-fill);
}


/* Leichte optische Trennung zwischen den Positionsblöcken */
.employee-data-row + .position-separator-row td{
  border-top:1px solid #e5e7eb !important;
}


.legend{
  display:flex;
  flex-wrap:wrap;
  gap:10px 18px;
  align-items:center;
}

.legend-item{
  display:inline-flex;
  align-items:center;
  gap:8px;
  white-space:nowrap;
}

.legend-box{
  width:14px;
  height:14px;
  display:inline-block;
  border:1px solid rgba(0,0,0,0.2);
  border-radius:2px;
  vertical-align:middle;
  flex:0 0 auto;
}

.legend-box--flextag{
  background-color:var(--legend-flex-fill, rgba(244, 67, 54, 0.22));
}

.legend-box--schulung{
  background-color:var(--legend-training-fill, rgba(33, 150, 243, 0.28));
}


/* Legenden-Kästchen: globale .legend span-Regel darf diese kleinen Boxen nicht weiß machen */
.legend .legend-box{
  width:14px;
  height:14px;
  display:inline-block;
  padding:0 !important;
  margin:0;
  border:1px solid rgba(0,0,0,0.2);
  border-radius:2px;
  vertical-align:middle;
  flex:0 0 auto;
  background:white;
}

.legend .legend-box--flextag{
  background:var(--legend-flex-fill, rgba(244, 67, 54, 0.22)) !important;
  background-image:none !important;
}

.legend .legend-box--schulung{
  background:var(--legend-training-fill, rgba(33, 150, 243, 0.28)) !important;
  background-image:none !important;
}


/* Schicht 1-5 / Azubi: keine Sa/So/Feiertag-Kachelung, Originalfarbe behalten */
.shift-label-row td.day-col--weekend,
.shift-label-row td.day-col--holiday{
  background: #eef4fb !important;
  background-image: none !important;
}

.shift-label-row .sticky-col-1,
.shift-label-row .sticky-col-2,
.shift-label-row .sticky-col-3{
  background:#e7eef8 !important;
}


/* Mitarbeiter hinzufügen: Qualifikationen aufklappbar */
.qual-collapse{
  border:1px solid var(--line);
  border-radius:12px;
  background:var(--card);
  overflow:hidden;
}

.qual-collapse summary{
  cursor:pointer;
  list-style:none;
  padding:12px 14px;
  font-weight:600;
  display:flex;
  align-items:center;
  justify-content:space-between;
  user-select:none;
}

.qual-collapse summary::-webkit-details-marker{
  display:none;
}

.qual-collapse summary::after{
  content:'▾';
  font-size:14px;
  opacity:0.8;
  transition:transform 0.15s ease;
}

.qual-collapse[open] summary::after{
  transform:rotate(180deg);
}

.qual-collapse .qual-compact-list{
  border-top:1px solid var(--line);
  margin-top:0;
}


/* Urlaubsübersicht: Tage, die es im Monat nicht gibt (z. B. 30. Februar), schwarz markieren */
.sheet--vacation td.vacation-invalid-day{
  background:#000 !important;
  color:#fff !important;
  background-image:none !important;
}


.color-settings-inputs{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}

.color-settings-table input[type="number"]{
  width:88px;
}

.color-rule-preview{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:72px;
  height:32px;
  padding:0 10px;
  border-radius:10px;
  border:1px solid rgba(0,0,0,0.14);
  font-weight:700;
}

.color-settings-inputs--stacked{display:flex; flex-direction:column; gap:6px; align-items:flex-start}
.color-settings-input-row{display:flex; align-items:center; gap:8px}
.color-settings-range-wrap{display:flex; align-items:center; gap:8px; min-width:130px}
.color-settings-range-wrap input[type=range]{width:90px}
.mini-label{font-size:12px; color:var(--muted)}


.admin-table--mitarbeiter thead th,
.admin-table--protokoll thead th{
  position:sticky;
  top:0;
  z-index:2;
  background:var(--head);
}

.grid-two-columns{
  display:grid;
  grid-template-columns: minmax(320px, 1fr) minmax(360px, 1.2fr);
  gap:20px;
}

.form-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:16px;
}

.field--full{
  grid-column: 1 / -1;
}

.field textarea,
.field select[multiple]{
  width:100%;
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px 14px;
  background:#fff;
  font:inherit;
}

.message-list{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.message-card{
  padding:16px 18px;
}

.message-card--unread{
  border-color: rgba(33, 150, 243, 0.35);
  box-shadow: 0 0 0 1px rgba(33, 150, 243, 0.18) inset;
}

.message-meta{
  display:flex;
  justify-content:space-between;
  gap:12px;
  margin-bottom:8px;
}

.status-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:102px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  background:#eef2f7;
  color:#334155;
}

.status-pill--open{
  background:#fff4d6;
  color:#8a5a00;
}

.status-pill--approved{
  background:#dcfce7;
  color:#166534;
}

.status-pill--rejected{
  background:#fee2e2;
  color:#991b1b;
}

.button-group{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

@media (max-width: 960px){
  .grid-two-columns,
  .form-grid{
    grid-template-columns: 1fr;
  }
}


.header-icon-btn{
  position:relative;
  width:42px;
  height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}

.header-icon-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 20px rgba(15, 23, 42, 0.08);
  border-color:#cbd5e1;
}

.header-icon-btn__icon{
  font-size:18px;
  line-height:1;
}

.header-icon-btn__badge{
  position:absolute;
  top:-7px;
  right:-7px;
  min-width:20px;
  height:20px;
  padding:0 6px;
  border-radius:999px;
  background:#dc2626;
  color:#fff;
  font-size:11px;
  font-weight:700;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 10px rgba(220, 38, 38, 0.35);
}

.message-card{
  overflow:hidden;
}

.message-card-toggle{
  width:100%;
  border:0;
  background:transparent;
  padding:0;
  text-align:left;
  cursor:pointer;
  font:inherit;
}

.message-card-toggle:focus-visible{
  outline:2px solid var(--primary-color, #2563eb);
  outline-offset:4px;
}

.message-list-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.message-unread-hint{
  display:inline-flex;
  align-items:center;
  padding:2px 8px;
  border-radius:999px;
  background:#fee2e2;
  color:#b91c1c;
  font-size:12px;
  font-weight:700;
}
.message-card--open{
  border-color:var(--primary-color, #2563eb);
  box-shadow:0 0 0 1px rgba(37,99,235,.2);
}

.message-card-content{
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid var(--line);
}

.message-detail-meta + .message-detail-meta{
  margin-top:4px;
}

.message-detail-body{
  margin-top:12px;
  white-space:pre-wrap;
  user-select:text;
  cursor:text;
}

.message-detail-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
}

.vacation-thread-card{
  overflow:hidden;
}

.vacation-thread-history{
  display:grid;
  gap:10px;
}

.vacation-thread-entry{
  padding:10px 12px;
  border-left:3px solid var(--primary-color, #2563eb);
  background:rgba(37, 99, 235, 0.06);
  border-radius:10px;
}

.vacation-thread-entry__meta{
  margin-bottom:6px;
  font-size:12px;
  font-weight:700;
  color:var(--muted, #6b7280);
}


.multi-select{
  min-height: 160px;
}

.multi-select option{
  padding: 6px 8px;
}


.table-wrap-limited{
  max-height: 420px;
  overflow-y: auto;
}

.table-wrap-limited thead th{
  position: sticky;
  top: 0;
  z-index: 2;
  background: #24304a;
  color: #f5f7fb;
}

.vacation-list-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:12px;
  flex-wrap:wrap;
}

.vacation-list-filter{
  width:220px;
  max-width:100%;
}


.vacation-top-grid{
  align-items: stretch;
}

.vacation-top-grid > .card{
  height: 100%;
}

.vacation-my-requests-card{
  display: flex;
  flex-direction: column;
}

.vacation-my-requests-wrap{
  flex: 1 1 auto;
  min-height: 460px;
}

.table-wrap-limited{
  max-height: 460px;
  overflow-y: auto;
}

.table-wrap-limited thead th{
  position: sticky;
  top: 0;
  z-index: 2;
  background: #24304a;
  color: #f5f7fb;
}

.vacation-open-requests-grid{
  margin-bottom: 0;
}

@media (max-width: 980px){
  .vacation-my-requests-wrap,
  .table-wrap-limited{
    min-height: 320px;
    max-height: 320px;
  }
}

.jump-target-cell{
  outline: 3px solid #ffd54f !important;
  outline-offset: -3px;
  box-shadow: inset 0 0 0 9999px rgba(255, 213, 79, 0.22);
}

.vacation-history-content{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.vacation-history-line{
  margin-top:4px;
}

.vacation-history-value{
  white-space:pre-wrap;
  line-height:1.45;
}


.training-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));
  gap:16px;
}

.training-card{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.training-table td,
.training-table th{
  vertical-align:top;
}


.message-card-header-row{
  display:flex;
  align-items:flex-start;
  gap:12px;
}

.message-card-header-row .message-card-toggle{
  flex:1 1 auto;
}

.message-select-box{
  display:inline-flex;
  align-items:center;
  gap:8px;
  white-space:nowrap;
  font-size:13px;
  color:var(--muted, #6b7280);
  padding-top:2px;
}

.message-select-checkbox{
  width:16px;
  height:16px;
  cursor:pointer;
}

.message-card--selected{
  border-color: rgba(37, 99, 235, 0.45);
  box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.12) inset;
}


.message-view-btn--with-badge{
  position:relative;
  padding-right:42px;
}

.message-view-btn__badge{
  position:absolute;
  top:50%;
  right:10px;
  transform:translateY(-50%);
  min-width:20px;
  height:20px;
  padding:0 6px;
  border-radius:999px;
  background:#dc2626;
  color:#fff;
  font-size:11px;
  font-weight:700;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 10px rgba(220, 38, 38, 0.35);
  pointer-events:none;
}


.suggestions-layout{
  align-items:start;
  gap:20px;
}

#suggestionComposeCard,
.suggestion-filter-card,
.suggestion-card,
.suggestion-stat{
  border:1px solid rgba(148, 163, 184, 0.18);
  box-shadow:0 14px 34px rgba(15, 23, 42, 0.07);
}

#suggestionComposeCard,
.suggestion-filter-card{
  background:linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

#suggestionComposeCard{
  position:sticky;
  top:18px;
}

.suggestion-compose-head{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  margin-bottom:16px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(226, 232, 240, 0.9);
}

.suggestion-stats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(170px, 1fr));
  gap:16px;
  margin-bottom:22px;
}

.suggestion-stat{
  display:flex;
  flex-direction:column;
  gap:8px;
  background:linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
}

.suggestion-stat strong{
  font-size:34px;
  line-height:1;
}

.suggestion-stat__label{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:#64748b;
  font-weight:700;
}

.suggestion-filter-card{
  margin-bottom:16px;
}

.suggestion-list{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.suggestion-card{
  background:linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.suggestion-card--open{
  border-color:rgba(59, 130, 246, 0.38);
  box-shadow:0 18px 38px rgba(59, 130, 246, 0.10);
}

.suggestion-card__top{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  flex-wrap:wrap;
}

.suggestion-card__meta{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:10px;
}

.suggestion-card__title{
  margin:0;
  font-size:22px;
  line-height:1.25;
}

.suggestion-card__info{
  margin:8px 0 0;
  color:#64748b;
}

.suggestion-card__facts{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:10px;
  color:#475569;
  font-size:13px;
}

.suggestion-card__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.suggestion-card__preview{
  margin:14px 0 0;
  color:#334155;
  white-space:pre-wrap;
  padding-top:14px;
  border-top:1px solid rgba(226, 232, 240, 0.85);
}

.suggestion-card__details{
  margin-top:18px;
  display:flex;
  flex-direction:column;
  gap:16px;
}

.suggestion-detail-grid{
  display:grid;
  grid-template-columns:minmax(0, 1fr);
  gap:16px;
}

.suggestion-subcard{
  border:1px solid rgba(148, 163, 184, 0.18);
  background:#f8fafc;
}

.suggestion-copy{
  white-space:pre-wrap;
  line-height:1.6;
  color:#0f172a;
}

.suggestion-comments{
  display:flex;
  flex-direction:column;
  gap:12px;
  max-height:380px;
  overflow:auto;
  padding-right:6px;
}

.suggestion-comment{
  padding:12px 14px;
  border-radius:14px;
  background:#fff;
  border:1px solid rgba(148, 163, 184, 0.2);
}

.suggestion-comment--official{
  border-color:rgba(59, 130, 246, 0.28);
  box-shadow:0 0 0 1px rgba(59, 130, 246, 0.08) inset;
}

.suggestion-comment__head{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-bottom:8px;
}

.suggestion-admin-panel{
  border:1px dashed rgba(15, 23, 42, 0.14);
  background:linear-gradient(180deg, rgba(248, 250, 252, 1) 0%, rgba(241, 245, 249, 1) 100%);
}

.suggestion-admin-panel__actions{
  justify-content:flex-end;
}

.suggestion-status,
.suggestion-tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  font-weight:700;
  line-height:1;
}

.suggestion-status--open{ background:#fee2e2; color:#b91c1c; }
.suggestion-status--planned{ background:#ede9fe; color:#6d28d9; }
.suggestion-status--progress{ background:#fef3c7; color:#b45309; }
.suggestion-status--done{ background:#dcfce7; color:#15803d; }
.suggestion-status--rejected{ background:#e2e8f0; color:#475569; }

.suggestion-tag--neutral{ background:#e2e8f0; color:#334155; }
.suggestion-tag--bug{ background:#fee2e2; color:#b91c1c; }
.suggestion-tag--improvement{ background:#dbeafe; color:#1d4ed8; }
.suggestion-tag--feature{ background:#ede9fe; color:#7c3aed; }
.suggestion-tag--ui{ background:#fce7f3; color:#be185d; }
.suggestion-tag--low{ background:#ecfccb; color:#3f6212; }
.suggestion-tag--medium{ background:#fef3c7; color:#92400e; }
.suggestion-tag--high{ background:#ffedd5; color:#c2410c; }

@media (min-width: 1080px){
  .suggestion-detail-grid{
    grid-template-columns:minmax(0, 1.05fr) minmax(0, 0.95fr);
  }
}

@media (max-width: 768px){
  .suggestion-card__top{
    flex-direction:column;
  }
  .suggestion-card__actions{
    width:100%;
  }
  .suggestion-card__actions .btn{
    flex:1;
  }
}

.suggestion-filter-card .toolbar{align-items:center;}
.suggestion-filter-card input,
.suggestion-filter-card select{background:#fff;}

@media (max-width: 1079px){
  #suggestionComposeCard{position:static;}
}


/* Verbesserungen / Änderungswünsche – moderneres Layout */
.page:has(.suggestion-stats-grid){
  gap:22px;
}

.suggestions-layout{
  grid-template-columns:minmax(340px, 420px) minmax(0, 1fr);
  gap:24px;
}

.suggestion-compose-card,
.suggestion-filter-card,
.suggestion-card,
.suggestion-stat{
  border:1px solid rgba(148, 163, 184, 0.18);
  box-shadow:0 18px 42px rgba(15, 23, 42, 0.08);
}

#suggestionComposeCard,
.suggestion-filter-card{
  background:linear-gradient(180deg, #ffffff 0%, #f6faff 100%);
}

#suggestionComposeCard{
  border-radius:24px;
  padding:24px;
  top:22px;
}

.suggestion-compose-head{
  margin-bottom:20px;
  padding-bottom:18px;
  border-bottom:1px solid rgba(226,232,240,0.9);
}

.suggestion-compose-head h3,
.suggestion-filter-card h3{
  margin:10px 0 0;
  font-size:26px;
  line-height:1.15;
}

.suggestion-stats-grid{
  gap:18px;
  margin-bottom:8px;
}

.suggestion-stat{
  position:relative;
  overflow:hidden;
  border-radius:22px;
  padding:22px 24px;
  background:linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.suggestion-stat::before{
  content:'';
  position:absolute;
  inset:0 auto 0 0;
  width:5px;
  border-radius:999px;
  background:linear-gradient(180deg, #2563eb 0%, #60a5fa 100%);
  opacity:.9;
}

.suggestion-stat strong{
  font-size:40px;
  font-weight:800;
  color:#0f172a;
}

.suggestion-stat small{
  color:#64748b;
  font-size:13px;
}

.suggestion-filter-card{
  border-radius:22px;
  padding:20px;
  margin-bottom:18px;
}

.suggestion-filter-card__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:16px;
}

.suggestion-filter-card__count{
  white-space:nowrap;
  padding-top:6px;
}

.suggestion-filter-toolbar{
  align-items:stretch !important;
}

.suggestion-filter-toolbar__controls{
  display:grid !important;
  grid-template-columns:minmax(240px, 1.7fr) repeat(4, minmax(150px, 1fr));
  width:100%;
  gap:12px !important;
}

.suggestion-filter-card input,
.suggestion-filter-card select,
#suggestionComposeCard input,
#suggestionComposeCard select,
#suggestionComposeCard textarea,
.suggestion-admin-panel select,
.suggestion-card textarea{
  border-radius:14px;
  border:1px solid rgba(148, 163, 184, 0.28);
  background:#fff;
  box-shadow:0 1px 2px rgba(15, 23, 42, 0.03) inset;
}

.suggestion-card{
  border-radius:22px;
  padding:20px 22px;
  background:linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.suggestion-card--open{
  border-color:rgba(59, 130, 246, 0.32);
  box-shadow:0 20px 48px rgba(37, 99, 235, 0.12);
}

.suggestion-card__top{
  gap:20px;
}

.suggestion-card__title{
  margin:0;
  font-size:32px;
  line-height:1.08;
  letter-spacing:-0.02em;
  color:#0f172a;
}

.suggestion-card__info{
  margin:10px 0 0;
  color:#64748b;
  font-size:14px;
}

.suggestion-card__actions .btn{
  min-width:140px;
  border-radius:14px;
}

.suggestion-card__preview{
  margin-top:16px;
  padding-top:16px;
  color:#334155;
  font-size:16px;
  line-height:1.65;
}

.suggestion-card__details{
  margin-top:20px;
  padding-top:18px;
  border-top:1px solid rgba(226,232,240,0.9);
}

.suggestion-subcard,
.suggestion-admin-panel{
  border-radius:18px;
  padding:18px;
}

.suggestion-subcard{
  background:linear-gradient(180deg, #f8fbff 0%, #f8fafc 100%);
}

.suggestion-subcard h4,
.suggestion-admin-panel h4{
  margin:0 0 14px;
  font-size:18px;
}

.suggestion-comment{
  border-radius:16px;
  padding:14px 16px;
  background:#fff;
  box-shadow:0 6px 18px rgba(15, 23, 42, 0.04);
}

.suggestion-comment--official{
  background:linear-gradient(180deg, #eff6ff 0%, #ffffff 100%);
}

.suggestion-admin-panel{
  border:1px dashed rgba(59, 130, 246, 0.28);
  background:linear-gradient(180deg, rgba(239, 246, 255, 0.95) 0%, rgba(248, 250, 252, 1) 100%);
}

.suggestion-admin-panel__actions{
  margin-top:8px;
}

.suggestion-status,
.suggestion-tag{
  padding:7px 12px;
  border-radius:999px;
  font-size:12px;
  letter-spacing:0.01em;
}

@media (max-width: 1280px){
  .suggestions-layout{
    grid-template-columns:minmax(300px, 380px) minmax(0, 1fr);
  }
  .suggestion-filter-toolbar__controls{
    grid-template-columns:minmax(220px, 1fr) repeat(2, minmax(150px, 1fr));
  }
}

@media (max-width: 1079px){
  .suggestions-layout{
    grid-template-columns:minmax(0, 1fr);
  }
  #suggestionComposeCard{position:static;}
}

@media (max-width: 760px){
  .suggestion-filter-card__head{
    flex-direction:column;
  }
  .suggestion-filter-toolbar__controls{
    grid-template-columns:minmax(0, 1fr);
  }
  .suggestion-card{
    padding:18px;
  }
  .suggestion-card__title{
    font-size:26px;
  }
  .suggestion-card__actions{
    width:100%;
  }
  .suggestion-card__actions .btn{
    flex:1;
    min-width:0;
  }
}


.burger-menu-wrap{
  position:relative;
  display:inline-flex;
  align-items:center;
  flex:0 0 auto;
}

.burger-toggle{
  min-width:44px;
  padding-left:12px;
  padding-right:12px;
  font-size:20px;
  line-height:1;
}

.burger-dropdown{
  position:absolute;
  top:calc(100% + 8px);
  right:0;
  min-width:260px;
  width:max-content;
  max-width:min(320px, calc(100vw - 24px));
  padding:10px;
  border-radius:18px;
  background:rgba(15,23,42,0.98);
  color:#fff;
  box-shadow:0 16px 40px rgba(15,23,42,0.28);
  border:1px solid rgba(255,255,255,0.08);
  display:none;
  z-index:1200;
  overflow-x:hidden;
}

.burger-menu-wrap.is-open .burger-dropdown{
  display:block;
}

.burger-link{
  width:100%;
  border:none;
  background:transparent;
  color:#fff;
  text-align:left;
  padding:11px 12px;
  border-radius:12px;
  cursor:pointer;
  font-size:14px;
  display:block;
}

.burger-link:hover{
  background:rgba(255,255,255,0.08);
}

.burger-link.active{
  background:rgba(59,130,246,0.22);
}

.burger-divider{
  height:1px;
  background:rgba(255,255,255,0.10);
  margin:8px 4px;
}

.burger-link-danger{
  color:#fecaca;
}




.icon-btn{
  min-width:44px;
  height:44px;
  border:none;
  border-radius:12px;
  background:rgba(15,23,42,0.08);
  color:inherit;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  transition:transform .15s ease, background .15s ease;
}

.icon-btn:hover{
  transform:translateY(-1px);
  background:rgba(15,23,42,0.14);
}

.settings-btn{
  flex:0 0 auto;
}


.burger-footer-actions{
  display:flex;
  align-items:center;
  gap:8px;
}

.burger-footer-actions .burger-link-danger{
  flex:1 1 auto;
}

.burger-icon-link{
  width:44px;
  min-width:44px;
  height:44px;
  border:none;
  border-radius:12px;
  background:transparent;
  color:#fff;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
}

.burger-icon-link:hover{
  background:rgba(255,255,255,0.08);
}


@media (max-width: 700px){
  .burger-menu-wrap{
    position:relative;
  }

  .burger-dropdown{
    position:fixed;
    top:64px;
    right:12px;
    left:12px;
    width:auto;
    min-width:0;
    max-width:none;
    max-height:calc(100vh - 76px);
    overflow-y:auto;
    border-radius:16px;
  }

  .burger-footer-actions{
    position:sticky;
    bottom:0;
    background:rgba(15,23,42,0.98);
    padding-top:8px;
  }
}


.admin-position-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));
  gap:16px;
  margin-top:8px;
}


.position-order-input{
  width:100%;
  min-width:80px;
}



.admin-section-kicker{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:rgba(37,99,235,.10);color:#1d4ed8;font-size:12px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;margin-bottom:12px}
.admin-vacation-types-page{display:flex;flex-direction:column;gap:18px}
.admin-vacation-hero{display:flex;justify-content:space-between;align-items:stretch;gap:18px;padding:22px;border-radius:24px;background:linear-gradient(135deg, rgba(37,99,235,.10), rgba(14,165,233,.07));border:1px solid rgba(148,163,184,.18)}
.admin-vacation-hero h3{margin:6px 0 8px 0;font-size:28px}
.admin-vacation-hero__badge{min-width:140px;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:18px;border-radius:22px;background:#fff;border:1px solid rgba(148,163,184,.18);box-shadow:0 10px 30px rgba(15,23,42,.06)}
.admin-vacation-hero__badge strong{font-size:34px;line-height:1;font-weight:800}
.admin-vacation-hero__badge span{margin-top:6px;color:#64748b;font-size:13px}
.admin-vacation-grid{display:grid;grid-template-columns:minmax(320px, 420px) minmax(0,1fr);gap:18px}
.admin-vacation-panel{border-radius:24px;box-shadow:0 18px 40px rgba(15,23,42,.06)}
.admin-vacation-panel--form{position:sticky;top:18px;align-self:start}
.admin-vacation-create-grid,.admin-vacation-type-row__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.admin-vacation-create-preview{margin-top:16px}
.admin-vacation-preview-card{padding:16px;border-radius:20px;background:#f8fafc;border:1px solid rgba(148,163,184,.16)}
.admin-vacation-preview-card__label{display:block;font-size:12px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.03em;margin-bottom:10px}
.admin-vacation-preview-badges{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.admin-vacation-badge{display:inline-flex;align-items:center;justify-content:center;min-width:72px;padding:10px 14px;border-radius:14px;font-weight:800;font-size:14px;box-shadow:inset 0 0 0 1px rgba(15,23,42,.06)}
.admin-vacation-badge--privacy{background:#eef2ff;color:#4338ca}
.admin-vacation-list-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:16px}
.admin-vacation-mini-legend{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#64748b;text-align:right}
.admin-vacation-type-list{display:flex;flex-direction:column;gap:14px}
.admin-vacation-type-row{padding:18px;border-radius:22px;background:#fff;border:1px solid rgba(148,163,184,.16);box-shadow:0 8px 24px rgba(15,23,42,.05)}
.admin-vacation-type-row__top{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:16px}
.admin-vacation-type-row__top h4{margin:0 0 6px 0;font-size:18px}
.admin-vacation-type-row__top p{margin:0;color:#64748b}
@media (max-width: 1100px){.admin-vacation-grid{grid-template-columns:1fr}.admin-vacation-panel--form{position:static}.admin-vacation-list-head,.admin-vacation-hero{flex-direction:column}.admin-vacation-mini-legend{text-align:left}}
@media (max-width: 720px){.admin-vacation-create-grid,.admin-vacation-type-row__grid{grid-template-columns:1fr}.admin-vacation-hero h3{font-size:24px}}


.admin-vacation-hero__meta{display:flex;gap:12px;align-items:stretch;flex-wrap:wrap}
.admin-vacation-hero__badge--small{min-width:120px;padding:14px 16px}
.admin-vacation-panel-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}
.admin-vacation-panel-head h3{margin:4px 0 6px 0}
.admin-vacation-panel-kicker{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;background:#eef2ff;color:#4338ca;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.admin-vacation-preview-card__header{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:10px;flex-wrap:wrap}
.admin-vacation-preview-card__hint{font-size:12px;color:#64748b}
.admin-vacation-list-head--stacked{flex-direction:column;align-items:stretch}
.admin-vacation-toolbar{display:flex;justify-content:space-between;gap:16px;align-items:flex-end;flex-wrap:wrap}
.admin-vacation-search-field{min-width:260px;max-width:360px;width:100%}
.admin-vacation-search-field input{width:100%}
.admin-vacation-mini-legend--boxed{padding:12px 14px;border-radius:16px;background:#f8fafc;border:1px solid rgba(148,163,184,.16);text-align:left;min-width:280px}
.admin-vacation-type-list-meta{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:14px;color:#64748b;font-size:13px;flex-wrap:wrap}
.admin-vacation-type-row{position:relative;overflow:hidden;padding-left:22px}
.admin-vacation-type-row__accent{position:absolute;left:0;top:0;bottom:0;width:6px;border-radius:22px 0 0 22px}
.admin-vacation-type-row__titlewrap{display:flex;gap:12px;align-items:flex-start}
.admin-vacation-preview-badges--right{justify-content:flex-end}
.admin-vacation-type-row__grid--dense{grid-template-columns:minmax(220px,1.4fr) repeat(4,minmax(120px,1fr));align-items:end}
.admin-vacation-type-row .field--wide{grid-column:auto}
.admin-form-actions--split{display:flex;justify-content:space-between;gap:14px;align-items:center;flex-wrap:wrap;margin-top:16px}
.admin-vacation-inline-note{font-size:12px;color:#64748b;background:#f8fafc;border:1px solid rgba(148,163,184,.14);padding:8px 10px;border-radius:12px}
.admin-vacation-row-actions{display:flex;gap:10px;flex-wrap:wrap}
.admin-vacation-empty{padding:28px;border:1px dashed rgba(148,163,184,.3);border-radius:20px;background:#f8fafc;color:#64748b;text-align:center}
@media (max-width: 1100px){.admin-vacation-toolbar,.admin-vacation-panel-head{flex-direction:column;align-items:stretch}.admin-vacation-search-field{max-width:none}.admin-vacation-mini-legend--boxed{min-width:0}.admin-vacation-type-row__grid--dense{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 720px){.admin-vacation-hero__meta{width:100%}.admin-vacation-hero__badge,.admin-vacation-hero__badge--small{min-width:0;flex:1}.admin-vacation-type-row{padding-left:18px}.admin-vacation-type-row__top{flex-direction:column}.admin-vacation-preview-badges--right{justify-content:flex-start}.admin-vacation-type-row__grid--dense{grid-template-columns:1fr}.admin-form-actions--split{align-items:stretch}.admin-vacation-row-actions{width:100%}.admin-vacation-row-actions .btn{flex:1}}

.admin-vacation-hero--letters{
  background:linear-gradient(135deg, rgba(59,130,246,.12), rgba(99,102,241,.08), rgba(16,185,129,.08));
}
.admin-vacation-grid--equal{grid-template-columns:repeat(2,minmax(0,1fr));}
.admin-vacation-grid--topspace{margin-top:18px;}
.admin-linked-colors-panel{margin-top:18px;overflow:hidden;}
.admin-linked-colors-legend{display:flex;flex-wrap:wrap;gap:8px 14px;color:#64748b;font-size:13px;justify-content:flex-end;}
.admin-linked-color-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px;}
.admin-linked-color-card{padding:18px;border-radius:22px;background:linear-gradient(180deg,#ffffff 0%, #f8fbff 100%);border:1px solid rgba(148,163,184,.18);box-shadow:0 14px 32px rgba(15,23,42,.06);}
.admin-linked-color-card__head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:14px;}
.admin-linked-color-card__title{font-size:18px;font-weight:800;color:#0f172a;}
.admin-linked-color-card__subtitle{margin-top:4px;color:#64748b;font-size:13px;}
.admin-linked-color-card__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}
.admin-vacation-create-grid--wide{grid-template-columns:repeat(2,minmax(0,1fr));}
.admin-vacation-preview-card--double{background:linear-gradient(180deg,#f8fbff 0%,#ffffff 100%);border:1px solid rgba(148,163,184,.16);}
.admin-vacation-type-row--modern{background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);box-shadow:0 12px 28px rgba(15,23,42,.06);}
.admin-vacation-type-row__grid--modern{grid-template-columns:minmax(220px,1.4fr) repeat(6,minmax(120px,1fr));align-items:end;}
.admin-vacation-panel-head--tight{margin-bottom:18px;}
.admin-letter-color-page .admin-vacation-row-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.admin-letter-color-page .color-rule-preview{min-width:68px;justify-content:center;}
@media (max-width: 1200px){
  .admin-vacation-type-row__grid--modern{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width: 1100px){
  .admin-vacation-grid--equal{grid-template-columns:1fr;}
  .admin-linked-colors-legend{justify-content:flex-start;}
}
@media (max-width: 720px){
  .admin-linked-color-card__head{flex-direction:column;}
  .admin-linked-color-card__grid,.admin-vacation-create-grid--wide{grid-template-columns:1fr;}
  .admin-vacation-type-row__grid--modern{grid-template-columns:1fr;}
}

.admin-vacation-hero--clean{background:linear-gradient(135deg, rgba(255,255,255,.96), rgba(248,250,252,.96));border-color:rgba(148,163,184,.2);box-shadow:0 18px 40px rgba(15,23,42,.05)}
.admin-letter-modern-page{display:flex;flex-direction:column;gap:18px}
.admin-letter-layout{display:grid;grid-template-columns:minmax(320px,420px) minmax(0,1fr);gap:18px;align-items:start}
.admin-letter-create-panel,.admin-letter-list-panel,.admin-letter-editor-panel{border-radius:24px;box-shadow:0 16px 36px rgba(15,23,42,.06)}
.admin-letter-create-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;align-items:end}
.admin-letter-create-grid .admin-letter-checkbox{grid-column:1/-1;justify-content:flex-start}
.admin-letter-create-panel .admin-form-actions{margin-top:16px}
.admin-letter-checkbox{display:inline-flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid rgba(148,163,184,.22);border-radius:16px;background:#f8fafc;min-height:48px;font-weight:700;color:#334155}
.admin-letter-checkbox input{margin:0}
.admin-letter-privacy-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px}
.admin-letter-preview-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}
.admin-letter-preview-row--editor{margin-top:18px}
.admin-letter-preview-box{display:flex;flex-direction:column;gap:8px;padding:14px 16px;border-radius:18px;background:#f8fafc;border:1px solid rgba(148,163,184,.18);min-width:180px}
.admin-letter-preview-caption{font-size:12px;color:#64748b}
.admin-letter-chip-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.admin-letter-chip{appearance:none;border:1px solid rgba(148,163,184,.18);background:linear-gradient(180deg,#fff,#fbfdff);border-radius:20px;padding:14px 14px 12px;text-align:left;display:flex;flex-direction:column;gap:12px;cursor:pointer;transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;box-shadow:0 8px 20px rgba(15,23,42,.05)}
.admin-letter-chip:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(15,23,42,.07);border-color:rgba(59,130,246,.28)}
.admin-letter-chip.active{border-color:#2563eb;box-shadow:0 0 0 2px rgba(37,99,235,.12), 0 14px 28px rgba(15,23,42,.08)}
.admin-letter-chip__top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.admin-letter-chip__top strong{font-size:15px;color:#0f172a}
.admin-letter-chip__top span{font-size:12px;color:#64748b}
.admin-letter-chip__badges{display:flex;gap:8px;flex-wrap:wrap}
.admin-letter-chip-badge{display:inline-flex;align-items:center;justify-content:center;min-width:52px;height:38px;padding:0 12px;border-radius:14px;border:1px solid rgba(148,163,184,.16);font-weight:800;letter-spacing:.02em;box-shadow:inset 0 0 0 1px rgba(255,255,255,.25)}
.admin-letter-chip-badge--privacy{outline:2px dashed rgba(148,163,184,.2);outline-offset:0}
.admin-letter-editor-grid{display:grid;grid-template-columns:minmax(220px,1.4fr) repeat(4,minmax(120px,1fr));gap:14px;align-items:end}
.admin-letter-empty{padding:18px;border:1px dashed rgba(148,163,184,.32);border-radius:20px;background:#f8fafc;color:#64748b;text-align:center}
.admin-letter-empty--large{padding:28px;font-weight:600}
@media (max-width: 1180px){
  .admin-letter-layout{grid-template-columns:1fr}
  .admin-letter-editor-grid,.admin-letter-create-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 760px){
  .admin-letter-editor-grid,.admin-letter-create-grid,.admin-letter-privacy-fields{grid-template-columns:1fr}
  .admin-letter-chip-grid{grid-template-columns:1fr}
  .admin-letter-preview-box{width:100%}
}


/* v32 Datenschutz-Hub */
.admin-letter-hub-page{display:flex;flex-direction:column;gap:18px;}
.admin-letter-overview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;}
.admin-letter-overview-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.78);border:1px solid rgba(148,163,184,.18);box-shadow:0 10px 24px rgba(15,23,42,.06);}
.admin-letter-overview-card__meta{display:flex;flex-direction:column;gap:2px;min-width:0;}
.admin-letter-overview-card__meta strong,.admin-letter-overview-card__meta span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.admin-vacation-type-list--hub{display:flex;flex-direction:column;gap:14px;}
.admin-hub-row{display:grid;grid-template-columns:minmax(0,1fr) 240px;gap:16px;padding:18px;border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(248,250,252,.92));border:1px solid rgba(148,163,184,.22);box-shadow:0 16px 36px rgba(15,23,42,.06);}
.admin-hub-row__main{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;align-items:end;}
.admin-hub-row__side{display:flex;flex-direction:column;gap:10px;justify-content:center;}
.admin-letter-layout--stacked{display:flex;flex-direction:column;gap:18px;}
.admin-letter-create-grid--compact{grid-template-columns:1.2fr .9fr repeat(4,minmax(0,1fr));align-items:end;}
.admin-letter-context-list{display:flex;flex-direction:column;gap:12px;}
.admin-letter-context-row{display:grid;grid-template-columns:1.2fr repeat(2,minmax(120px,.8fr)) 150px 170px;gap:12px;align-items:end;padding:16px;border-radius:18px;background:rgba(255,255,255,.78);border:1px solid rgba(148,163,184,.18);}
.admin-letter-context-row__code input{text-transform:uppercase;}
.admin-letter-preview-box--inline{min-height:auto;align-items:flex-start;justify-content:center;}
.admin-vacation-row-actions--stacked{display:flex;flex-direction:column;gap:10px;}
.admin-letter-preview-row--hub{justify-content:space-between;align-items:center;flex-wrap:wrap;}
.admin-letter-checkbox--compact{align-self:end;margin-bottom:10px;}
@media (max-width: 1200px){
  .admin-hub-row{grid-template-columns:1fr;}
  .admin-hub-row__main{grid-template-columns:repeat(2,minmax(0,1fr));}
  .admin-letter-create-grid--compact{grid-template-columns:repeat(2,minmax(0,1fr));}
  .admin-letter-context-row{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width: 760px){
  .admin-hub-row__main,.admin-letter-create-grid--compact,.admin-letter-context-row{grid-template-columns:1fr;}
  .admin-hub-row__side{align-items:flex-start;}
}


.admin-privacy-color-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px;margin-top:10px}
.admin-privacy-color-tile{border:1px solid rgba(90,110,140,.16);border-radius:16px;padding:12px;background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(246,249,255,.92));display:grid;gap:10px}
.admin-privacy-color-tile__head{display:flex;align-items:flex-start;gap:10px}
.admin-privacy-color-tile__meta{display:grid;gap:4px;min-width:0}
.admin-privacy-color-tile__meta strong{font-size:15px}
.admin-privacy-color-tile__meta span{font-size:12px;color:#667085;line-height:1.35}
.admin-privacy-color-tile__controls{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;align-items:end}
.field--compact{display:grid;gap:6px}
.field--compact span{font-size:12px;color:#667085;font-weight:600}
.btn-small{padding:10px 12px;font-size:13px}
.admin-custom-letter-create-row,.admin-custom-letter-row{display:grid;grid-template-columns:minmax(100px,120px) minmax(150px,190px) repeat(4,minmax(110px,1fr)) auto auto;gap:10px;align-items:end}
.admin-custom-letter-create-row{padding:12px 0 14px;border-bottom:1px solid rgba(90,110,140,.12);margin-bottom:14px}
.admin-custom-letter-create-row__preview,.admin-custom-letter-row__preview{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.admin-custom-letter-list{display:grid;gap:10px}
.admin-custom-letter-row{padding:12px;border:1px solid rgba(90,110,140,.14);border-radius:16px;background:#fff}
.admin-custom-letter-row__code,.admin-custom-letter-create-row__code{min-width:0}
@media (max-width: 1180px){
  .admin-custom-letter-create-row,.admin-custom-letter-row{grid-template-columns:repeat(2,minmax(0,1fr))}
  .admin-privacy-color-tile__controls{grid-template-columns:repeat(2,minmax(0,1fr))}
}

.admin-letter-hub-page--compact{display:grid;gap:16px}
.admin-privacy-color-grid--compact,.admin-custom-letter-list--compact{display:grid;gap:10px}
.admin-privacy-color-tile--compact,.admin-custom-letter-row--compact,.admin-custom-letter-create-row--compact{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;align-items:end}
.admin-privacy-color-tile--compact .admin-privacy-color-tile__head{grid-column:1/-1;display:flex;align-items:center;gap:10px}
.admin-privacy-color-tile__controls--compact{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;align-items:end}
.admin-letter-checkbox--inline{align-self:end;min-height:42px;display:flex;align-items:center}
.admin-custom-letter-row--compact .admin-custom-letter-row__preview,.admin-custom-letter-create-row--compact .admin-custom-letter-create-row__preview{display:flex;gap:8px;align-items:center;align-self:end;flex-wrap:wrap}
.admin-custom-letter-row--compact .admin-vacation-row-actions,.admin-custom-letter-create-row--compact .admin-vacation-row-actions{align-self:end}


.admin-privacy-box-sections{display:grid;gap:16px}
.admin-privacy-box-section{display:grid;gap:10px}
.admin-privacy-box-section__title{font-size:13px;font-weight:700;color:#44526a}
.admin-privacy-box-grid{display:flex;flex-wrap:wrap;gap:10px}
.admin-privacy-box-card{display:grid;gap:8px;justify-items:center;padding:10px;border:1px solid rgba(90,110,140,.14);border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(246,249,255,.94));min-width:74px}
.admin-privacy-box-preview{display:flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 10px;border-radius:12px;font-weight:800;font-size:14px;letter-spacing:.02em;box-shadow:inset 0 0 0 1px rgba(0,0,0,.04)}
.admin-privacy-box-pickers{display:flex;gap:6px}
.privacy-box-color-input{width:24px;height:24px;padding:0;border:none;background:transparent;cursor:pointer}
.privacy-box-color-input::-webkit-color-swatch-wrapper{padding:0}
.privacy-box-color-input::-webkit-color-swatch{border:none;border-radius:8px}
.privacy-box-color-input::-moz-color-swatch{border:none;border-radius:8px}

.admin-privacy-box-headline{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px;}
.admin-privacy-box-legend{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:12px;color:#667085;}
.admin-privacy-box-legend span{display:inline-flex;align-items:center;gap:6px;}
.admin-privacy-box-legend-dot{width:10px;height:10px;border-radius:999px;display:inline-block;border:1px solid rgba(15,23,42,.12);}
.admin-privacy-box-legend-dot--text{background:#21304d;}
.admin-privacy-box-legend-dot--bg{background:#ffffff;}
.admin-privacy-box-pickers{position:relative;}
.admin-privacy-box-pickers .privacy-box-color-input:first-child{box-shadow:0 0 0 2px rgba(33,48,77,.08);}
.admin-privacy-box-pickers .privacy-box-color-input:last-child{box-shadow:0 0 0 2px rgba(148,163,184,.18);}

.admin-privacy-box-pickers{display:flex;gap:8px;align-items:flex-start;justify-content:center;width:100%;}
.admin-privacy-box-picker-col{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:4px;min-width:34px;}
.admin-privacy-box-picker-label{font-size:10px;line-height:1;text-align:center;color:#667085;white-space:nowrap;}
.admin-vacation-types-page--compact{display:block;}
.admin-vacation-panel--compact{display:grid;gap:14px;}
.admin-vacation-list-head--compact{display:flex;justify-content:space-between;align-items:end;gap:14px;flex-wrap:wrap;}
.admin-vacation-search-field--compact{min-width:220px;max-width:280px;}
.admin-vacation-create-grid--compact{display:grid;grid-template-columns:minmax(220px,1fr) minmax(140px,180px) auto;gap:10px;align-items:end;}
.admin-vacation-type-list--compact{display:grid;gap:10px;}
.admin-vacation-type-row--compact{display:grid;grid-template-columns:minmax(220px,1fr) minmax(140px,180px) auto;gap:10px;align-items:end;padding:12px;border:1px solid rgba(90,110,140,.14);border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(246,249,255,.94));}
.admin-vacation-row-actions--compact{justify-content:flex-end;}
.admin-form-actions--compact{align-self:end;}
.admin-vacation-type-list-meta--compact{padding-top:0;}
@media (max-width: 780px){.admin-vacation-create-grid--compact,.admin-vacation-type-row--compact{grid-template-columns:1fr;}}


.shiftplan-custom-color{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  min-height:40px;
}
.shiftplan-custom-color span{
  font-size:12px;
  color:var(--muted);
  font-weight:600;
}
.shiftplan-custom-color input[type="color"]{
  width:34px;
  height:34px;
  padding:0;
  border:none;
  background:transparent;
  cursor:pointer;
}


.vacation-year-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:16px;align-items:start}
.vacation-year-main-card{min-width:0}
.vacation-year-table-wrap{max-height:calc(100vh - 220px);overflow:auto}
.vacation-year-sheet{table-layout:fixed;border-collapse:collapse;width:max-content;min-width:100%}
.vacation-year-sheet th,.vacation-year-sheet td{min-width:28px;width:28px;height:28px;padding:0;text-align:center;font-size:12px;border:1px solid #111}
.vacation-year-sheet .sticky-col-1{position:sticky;left:0;z-index:4;background:#fff;min-width:54px;width:54px}
.vacation-year-sheet .sticky-col-2{position:sticky;left:54px;z-index:4;background:#fff;min-width:130px;width:130px;text-align:left;padding:0 8px}
.vacation-year-sheet .sticky-col-3{position:sticky;left:184px;z-index:4;background:#fff;min-width:100px;width:100px;text-align:center;padding:0 8px}
.vacation-year-sheet .sticky-col-right{position:sticky;right:0;z-index:4;background:#fff;min-width:54px;width:54px}
.vacation-year-month-cell{font-weight:700;background:#f8fafc}
.vacation-year-month-subhead{background:#f8fafc;font-weight:700}
.vacation-year-day-head{position:sticky;top:0;z-index:3;background:#fff;font-weight:600}
.vacation-year-month-header-row th{border-top:2px solid var(--line-strong, #000)}
.vacation-year-month-group:last-child tr:last-child td,.vacation-year-month-group:last-child tr:last-child th{border-bottom:2px solid var(--line-strong, #000)}
.vacation-year-cell{background:#fff}
.vacation-year-cell-blocked{background:#000 !important;color:#000}
.vacation-year-cell-editable{cursor:text}
.vacation-year-cell-editable[contenteditable="plaintext-only"]:focus,.vacation-year-cell-editable.is-active{outline:2px solid var(--accent,#2563eb);outline-offset:-2px;background:#eef6ff}
.vacation-year-employee-label{background:#fff;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vacation-year-rhythm-row th{font-size:11px;font-weight:700;background:#f8fafc}
.vacation-year-rhythm-head{color:#334155}
.vacation-year-empty{padding:12px;background:#fff;text-align:left}
.vacation-year-side-card{display:flex;flex-direction:column;gap:12px}
.vacation-year-side-header h3{margin:0}
.vacation-year-summary-wrap{overflow:auto}
.vacation-year-summary-grid{border-collapse:collapse}
.vacation-year-summary-grid td,.vacation-year-summary-grid th{white-space:nowrap;text-align:center;padding:6px 8px;border:1px solid var(--line)}
.vacation-year-summary-grid thead th,.vacation-year-summary-grid tfoot th{font-weight:700}
.vacation-year-summary-grid td:first-child,.vacation-year-summary-grid th:first-child{text-align:left}
.vacation-year-summary-name{font-weight:600}
.vacation-year-summary-input{min-width:54px;width:54px;text-align:center;padding:4px 6px}
@media (max-width: 1200px){.vacation-year-layout{grid-template-columns:1fr}.vacation-year-side-card{order:-1}}

.vacation-year-weekday-row th{font-size:11px;font-weight:600;opacity:.8}

.vacation-year-cell--sunday{background:rgba(239,68,68,.08)}
.vacation-year-day-head--sunday,.vacation-year-weekday-head--sunday{background:rgba(239,68,68,.08)}
.vacation-year-cell--holiday{background:rgba(220,38,38,.18)}
.vacation-year-day-head--holiday,.vacation-year-weekday-head--holiday{background:rgba(220,38,38,.18)}
.vacation-year-cell.vacation-year-cell--code-colored{
  background:var(--tomi-code-bg) !important;
  background-image:none !important;
  background-blend-mode:normal !important;
  color:var(--tomi-code-color) !important;
  border-color:var(--tomi-code-border) !important;
}
.vacation-year-cell-editable.vacation-year-cell--code-colored:focus,.vacation-year-cell-editable.vacation-year-cell--code-colored.is-active{
  background:var(--tomi-code-bg) !important;
  background-image:none !important;
  background-blend-mode:normal !important;
  color:var(--tomi-code-color) !important;
  border-color:var(--tomi-code-border) !important;
}
.grid-dashboard{
  grid-template-columns:repeat(3,minmax(240px,1fr));
}
.admin-card{
  padding:18px;
}
.admin-tabs{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:18px;
}
.admin-tab{
  border:1px solid var(--line);
  background:#f8fafc;
  color:#21304d;
  border-radius:12px;
  padding:10px 14px;
  font-weight:700;
  cursor:pointer;
}
.admin-tab.active{
  background:var(--accent);
  color:#fff;
  border-color:var(--accent);
}
.admin-layout{
  display:grid;
  grid-template-columns:420px minmax(0,1fr);
  gap:18px;
}
.admin-panel{
  padding:18px;
}
.admin-panel h3, .admin-simple-list h3{
  font-size:22px;
  margin-bottom:6px;
}
.admin-text{
  color:var(--muted);
  margin-bottom:12px;
}
.two-cols{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.qual-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.qual-check{
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#f9fbfc;
  margin:0;
}
.qual-check input{
  width:auto;
  margin:0;
}
.admin-form-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:16px;
}
.admin-table{
  width:100%;
  border-collapse:collapse;
}
.admin-table th,
.admin-table td{
  border:1px solid var(--line);
  padding:10px 12px;
  text-align:left;
  vertical-align:top;
  font-size:14px;
}
.admin-table th{
  background:var(--head);
}
.admin-table-wrap{
  max-height:62vh;
}
.role-pill{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  font-weight:700;
  background:#edf4ff;
  color:#163d73;
  border:1px solid #cbdcf6;
}
.btn-small{
  padding:8px 10px;
  font-size:12px;
  border-radius:10px;
}
.btn-danger{
  background:#fee2e2;
  color:#991b1b;
}
.admin-actions-cell{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.admin-simple-list{
  display:grid;
  gap:12px;
}
.simple-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
  padding:14px 16px;
}
.muted-row{
  margin-top:4px;
  color:var(--muted);
  font-size:13px;
}
.simple-badges{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.mini-badge{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#f8fafc;
  font-size:12px;
  font-weight:700;
}
@media (max-width: 1100px){
  .admin-layout{
    grid-template-columns:1fr;
  }
  .grid-dashboard{
    grid-template-columns:1fr;
  }
}


/* Leerzeilen zwischen Positionen exakt wie normale Mitarbeiterzeilen */
.position-separator-row td{
  height:34px !important;
  min-height:34px !important;
  background:#ffffff !important;
  border-bottom:1px solid var(--line) !important;
}
.position-separator-row .sticky-col-1,
.position-separator-row .sticky-col-2,
.position-separator-row .sticky-col-3{
  background:#ffffff !important;
  box-shadow:1px 0 0 0 var(--line);
}

/* Alle Zellen klickbar */
.sheet td,
.sheet th{
  cursor:pointer;
}
.sheet td:hover,
.sheet th:hover{
  background:#eef6ff;
}

/* Stärkere Excel-artige Markierung */
.sheet .is-active-row td,
.sheet .is-active-row th{
  box-shadow: inset 0 0 0 9999px var(--active-row-fill);
}
.sheet .is-active-col{
  box-shadow: inset 0 0 0 9999px var(--active-col-fill);
}
.sheet .is-active-cell{
  background:var(--active-cell-fill) !important;
  outline:var(--active-cell-outline-width) solid var(--active-cell-border);
  outline-offset:calc(-1 * var(--active-cell-outline-width));
  box-shadow: inset 0 0 0 var(--active-cell-inner-width) #ffffff, 0 0 0 1px var(--active-cell-border);
}
.sheet .is-active-cell.is-active-col{
  background:var(--active-cell-fill) !important;
}
.sheet .is-active-row .is-active-col{
  box-shadow: inset 0 0 0 9999px var(--active-cross-fill);
}

/* Sticky-Zellen stabil über dem Rest */
.sheet td.sticky-col-1.is-active-cell,
.sheet td.sticky-col-2.is-active-cell,
.sheet td.sticky-col-3.is-active-cell,
.sheet th.sticky-col-1.is-active-cell,
.sheet th.sticky-col-2.is-active-cell,
.sheet th.sticky-col-3.is-active-cell{
  z-index:12 !important;
}
.sheet td.sticky-col-1.is-active-col,
.sheet td.sticky-col-2.is-active-col,
.sheet td.sticky-col-3.is-active-col,
.sheet th.sticky-col-1.is-active-col,
.sheet th.sticky-col-2.is-active-col,
.sheet th.sticky-col-3.is-active-col{
  z-index:11 !important;
}


.admin-search{
  margin-bottom:14px;
}


.profile-card{
  padding:20px;
}
.profile-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.profile-actions{
  margin-top:18px;
  display:flex;
  gap:10px;
}
@media (max-width: 800px){
  .profile-grid{
    grid-template-columns:1fr;
  }
}


.qualification-filter-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  margin-top:8px;
}
.filter-toolbar{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:10px;
}
.filter-check{
  background:#fff;
}
.filter-hint{
  margin-top:10px;
  color:var(--muted);
  font-size:13px;
}
@media (max-width: 1000px){
  .qualification-filter-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (max-width: 600px){
  .qualification-filter-grid{
    grid-template-columns:1fr;
  }
}


.filter-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.filter-hint-top{
  margin-top:8px;
}
.qualification-filter-panel{
  display:none;
  margin-top:10px;
}
.qualification-filter-panel.open{
  display:block;
}


.qual-compact-list{
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
  background:#fff;
}
.qual-compact-head,
.qual-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) 80px 110px;
  gap:10px;
  align-items:center;
  padding:10px 12px;
}
.qual-compact-head{
  background:var(--head);
  font-size:12px;
  font-weight:700;
  color:#344054;
}
.qual-row{
  border-top:1px solid var(--line);
}
.qual-row:nth-child(even){
  background:#fbfdff;
}
.qual-name{
  font-weight:600;
}
.qual-mini-check{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:32px;
}
.qual-mini-check input{
  width:auto;
  margin:0;
}
.qual-mini-check.disabled{
  color:var(--muted);
}
.qual-dash{
  color:var(--muted);
  font-weight:700;
}
@media (max-width: 800px){
  .qual-compact-head,
  .qual-row{
    grid-template-columns:minmax(0,1fr) 70px 90px;
  }
}


.month-edit-cell.is-editable{
  cursor:text;
  background:#fffef0;
}
.month-edit-cell.is-editable:focus{
  outline:2px solid var(--accent);
  outline-offset:-2px;
  background:#ffffff;
}

.excel-toolbar{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin-bottom:12px;
  padding:10px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#f8fafc;
}
.formula-input{
  min-width:220px;
  max-width:320px;
  border:1px solid var(--line);
  border-radius:10px;
  padding:10px 12px;
}
.color-palette{
  display:flex;
  gap:6px;
  align-items:center;
}
.color-btn{
  width:28px;
  height:28px;
  border-radius:8px;
  border:2px solid #cbd5e1;
  cursor:pointer;
}
.color-btn.active{outline:2px solid #163d73; outline-offset:1px}
.month-edit-cell.is-editable{cursor:cell}
.month-edit-cell.is-selected-cell{
  box-shadow: inset 0 0 0 var(--selected-cell-outline-width) var(--selected-cell-border);
  background:var(--selected-cell-fill);
  position:relative;
}
.btn[disabled]{opacity:.45; cursor:not-allowed}


.excel-toolbar{position:relative}
.shiftplan-context-menu{
  position:fixed;
  z-index:50;
  min-width:160px;
  background:#fff;
  border:1px solid var(--line-strong);
  border-radius:12px;
  box-shadow:0 12px 30px rgba(17,24,39,.18);
  padding:6px;
}
.shiftplan-context-menu button{
  width:100%;
  border:0;
  background:transparent;
  text-align:left;
  padding:10px 12px;
  border-radius:8px;
  cursor:pointer;
}
.shiftplan-context-menu button:hover{background:#eef2f6}
.month-edit-cell.is-editable{position:relative; user-select:none}
.month-edit-cell.has-fill-handle::after{
  content:'';
  position:absolute;
  width:8px;
  height:8px;
  right:1px;
  bottom:1px;
  border-radius:50%;
  background:#163d73;
  border:1px solid #ffffff;
  box-shadow:0 0 0 1px #163d73;
}
.month-edit-cell.has-fill-handle{cursor:crosshair}
.month-edit-cell.is-selected-cell{
  box-shadow: inset 0 0 0 var(--selected-cell-outline-width) var(--selected-cell-border);
  background:var(--selected-cell-fill);
}
.month-edit-cell.is-active-cell{
  box-shadow: inset 0 0 0 var(--active-cell-outline-width) var(--active-cell-border);
  background:var(--active-cell-fill);
}


/* Leichte optische Trennung zwischen den Positionsblöcken */
.employee-data-row + .position-separator-row td{
  border-top:1px solid #e5e7eb !important;
}


.legend{
  display:flex;
  flex-wrap:wrap;
  gap:10px 18px;
  align-items:center;
}

.legend-item{
  display:inline-flex;
  align-items:center;
  gap:8px;
  white-space:nowrap;
}

.legend-box{
  width:14px;
  height:14px;
  display:inline-block;
  border:1px solid rgba(0,0,0,0.2);
  border-radius:2px;
  vertical-align:middle;
  flex:0 0 auto;
}

.legend-box--flextag{
  background-color:var(--legend-flex-fill, rgba(244, 67, 54, 0.22));
}

.legend-box--schulung{
  background-color:var(--legend-training-fill, rgba(33, 150, 243, 0.28));
}


/* Legenden-Kästchen: globale .legend span-Regel darf diese kleinen Boxen nicht weiß machen */
.legend .legend-box{
  width:14px;
  height:14px;
  display:inline-block;
  padding:0 !important;
  margin:0;
  border:1px solid rgba(0,0,0,0.2);
  border-radius:2px;
  vertical-align:middle;
  flex:0 0 auto;
  background:white;
}

.legend .legend-box--flextag{
  background:var(--legend-flex-fill, rgba(244, 67, 54, 0.22)) !important;
  background-image:none !important;
}

.legend .legend-box--schulung{
  background:var(--legend-training-fill, rgba(33, 150, 243, 0.28)) !important;
  background-image:none !important;
}


/* Schicht 1-5 / Azubi: keine Sa/So/Feiertag-Kachelung, Originalfarbe behalten */
.shift-label-row td.day-col--weekend,
.shift-label-row td.day-col--holiday{
  background: #eef4fb !important;
  background-image: none !important;
}

.shift-label-row .sticky-col-1,
.shift-label-row .sticky-col-2,
.shift-label-row .sticky-col-3{
  background:#e7eef8 !important;
}


/* Mitarbeiter hinzufügen: Qualifikationen aufklappbar */
.qual-collapse{
  border:1px solid var(--line);
  border-radius:12px;
  background:var(--card);
  overflow:hidden;
}

.qual-collapse summary{
  cursor:pointer;
  list-style:none;
  padding:12px 14px;
  font-weight:600;
  display:flex;
  align-items:center;
  justify-content:space-between;
  user-select:none;
}

.qual-collapse summary::-webkit-details-marker{
  display:none;
}

.qual-collapse summary::after{
  content:'▾';
  font-size:14px;
  opacity:0.8;
  transition:transform 0.15s ease;
}

.qual-collapse[open] summary::after{
  transform:rotate(180deg);
}

.qual-collapse .qual-compact-list{
  border-top:1px solid var(--line);
  margin-top:0;
}


/* Urlaubsübersicht: Tage, die es im Monat nicht gibt (z. B. 30. Februar), schwarz markieren */
.sheet--vacation td.vacation-invalid-day{
  background:#000 !important;
  color:#fff !important;
  background-image:none !important;
}


.color-settings-inputs{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}

.color-settings-table input[type="number"]{
  width:88px;
}

.color-rule-preview{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:72px;
  height:32px;
  padding:0 10px;
  border-radius:10px;
  border:1px solid rgba(0,0,0,0.14);
  font-weight:700;
}

.color-settings-inputs--stacked{display:flex; flex-direction:column; gap:6px; align-items:flex-start}
.color-settings-input-row{display:flex; align-items:center; gap:8px}
.color-settings-range-wrap{display:flex; align-items:center; gap:8px; min-width:130px}
.color-settings-range-wrap input[type=range]{width:90px}
.mini-label{font-size:12px; color:var(--muted)}


.admin-table--mitarbeiter thead th,
.admin-table--protokoll thead th{
  position:sticky;
  top:0;
  z-index:2;
  background:var(--head);
}

.grid-two-columns{
  display:grid;
  grid-template-columns: minmax(320px, 1fr) minmax(360px, 1.2fr);
  gap:20px;
}

.form-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:16px;
}

.field--full{
  grid-column: 1 / -1;
}

.field textarea,
.field select[multiple]{
  width:100%;
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px 14px;
  background:#fff;
  font:inherit;
}

.message-list{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.message-card{
  padding:16px 18px;
}

.message-card--unread{
  border-color: rgba(33, 150, 243, 0.35);
  box-shadow: 0 0 0 1px rgba(33, 150, 243, 0.18) inset;
}

.message-meta{
  display:flex;
  justify-content:space-between;
  gap:12px;
  margin-bottom:8px;
}

.status-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:102px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  background:#eef2f7;
  color:#334155;
}

.status-pill--open{
  background:#fff4d6;
  color:#8a5a00;
}

.status-pill--approved{
  background:#dcfce7;
  color:#166534;
}

.status-pill--rejected{
  background:#fee2e2;
  color:#991b1b;
}

.button-group{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

@media (max-width: 960px){
  .grid-two-columns,
  .form-grid{
    grid-template-columns: 1fr;
  }
}


.header-icon-btn{
  position:relative;
  width:42px;
  height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}

.header-icon-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 20px rgba(15, 23, 42, 0.08);
  border-color:#cbd5e1;
}

.header-icon-btn__icon{
  font-size:18px;
  line-height:1;
}

.header-icon-btn__badge{
  position:absolute;
  top:-7px;
  right:-7px;
  min-width:20px;
  height:20px;
  padding:0 6px;
  border-radius:999px;
  background:#dc2626;
  color:#fff;
  font-size:11px;
  font-weight:700;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 10px rgba(220, 38, 38, 0.35);
}

.message-card{
  overflow:hidden;
}

.message-card-toggle{
  width:100%;
  border:0;
  background:transparent;
  padding:0;
  text-align:left;
  cursor:pointer;
  font:inherit;
}

.message-card-toggle:focus-visible{
  outline:2px solid var(--primary-color, #2563eb);
  outline-offset:4px;
}

.message-list-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.message-unread-hint{
  display:inline-flex;
  align-items:center;
  padding:2px 8px;
  border-radius:999px;
  background:#fee2e2;
  color:#b91c1c;
  font-size:12px;
  font-weight:700;
}
.message-card--open{
  border-color:var(--primary-color, #2563eb);
  box-shadow:0 0 0 1px rgba(37,99,235,.2);
}

.message-card-content{
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid var(--line);
}

.message-detail-meta + .message-detail-meta{
  margin-top:4px;
}

.message-detail-body{
  margin-top:12px;
  white-space:pre-wrap;
  user-select:text;
  cursor:text;
}

.message-detail-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
}

.vacation-thread-card{
  overflow:hidden;
}

.vacation-thread-history{
  display:grid;
  gap:10px;
}

.vacation-thread-entry{
  padding:10px 12px;
  border-left:3px solid var(--primary-color, #2563eb);
  background:rgba(37, 99, 235, 0.06);
  border-radius:10px;
}

.vacation-thread-entry__meta{
  margin-bottom:6px;
  font-size:12px;
  font-weight:700;
  color:var(--muted, #6b7280);
}


.multi-select{
  min-height: 160px;
}

.multi-select option{
  padding: 6px 8px;
}


.table-wrap-limited{
  max-height: 420px;
  overflow-y: auto;
}

.table-wrap-limited thead th{
  position: sticky;
  top: 0;
  z-index: 2;
  background: #24304a;
  color: #f5f7fb;
}

.vacation-list-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:12px;
  flex-wrap:wrap;
}

.vacation-list-filter{
  width:220px;
  max-width:100%;
}


.vacation-top-grid{
  align-items: stretch;
}

.vacation-top-grid > .card{
  height: 100%;
}

.vacation-my-requests-card{
  display: flex;
  flex-direction: column;
}

.vacation-my-requests-wrap{
  flex: 1 1 auto;
  min-height: 460px;
}

.table-wrap-limited{
  max-height: 460px;
  overflow-y: auto;
}

.table-wrap-limited thead th{
  position: sticky;
  top: 0;
  z-index: 2;
  background: #24304a;
  color: #f5f7fb;
}

.vacation-open-requests-grid{
  margin-bottom: 0;
}

@media (max-width: 980px){
  .vacation-my-requests-wrap,
  .table-wrap-limited{
    min-height: 320px;
    max-height: 320px;
  }
}

.jump-target-cell{
  outline: 3px solid #ffd54f !important;
  outline-offset: -3px;
  box-shadow: inset 0 0 0 9999px rgba(255, 213, 79, 0.22);
}

.vacation-history-content{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.vacation-history-line{
  margin-top:4px;
}

.vacation-history-value{
  white-space:pre-wrap;
  line-height:1.45;
}


.training-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));
  gap:16px;
}

.training-card{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.training-table td,
.training-table th{
  vertical-align:top;
}


.message-card-header-row{
  display:flex;
  align-items:flex-start;
  gap:12px;
}

.message-card-header-row .message-card-toggle{
  flex:1 1 auto;
}

.message-select-box{
  display:inline-flex;
  align-items:center;
  gap:8px;
  white-space:nowrap;
  font-size:13px;
  color:var(--muted, #6b7280);
  padding-top:2px;
}

.message-select-checkbox{
  width:16px;
  height:16px;
  cursor:pointer;
}

.message-card--selected{
  border-color: rgba(37, 99, 235, 0.45);
  box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.12) inset;
}


.message-view-btn--with-badge{
  position:relative;
  padding-right:42px;
}

.message-view-btn__badge{
  position:absolute;
  top:50%;
  right:10px;
  transform:translateY(-50%);
  min-width:20px;
  height:20px;
  padding:0 6px;
  border-radius:999px;
  background:#dc2626;
  color:#fff;
  font-size:11px;
  font-weight:700;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 10px rgba(220, 38, 38, 0.35);
  pointer-events:none;
}


.suggestions-layout{
  align-items:start;
  gap:20px;
}

#suggestionComposeCard,
.suggestion-filter-card,
.suggestion-card,
.suggestion-stat{
  border:1px solid rgba(148, 163, 184, 0.18);
  box-shadow:0 14px 34px rgba(15, 23, 42, 0.07);
}

#suggestionComposeCard,
.suggestion-filter-card{
  background:linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

#suggestionComposeCard{
  position:sticky;
  top:18px;
}

.suggestion-compose-head{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  margin-bottom:16px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(226, 232, 240, 0.9);
}

.suggestion-stats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(170px, 1fr));
  gap:16px;
  margin-bottom:22px;
}

.suggestion-stat{
  display:flex;
  flex-direction:column;
  gap:8px;
  background:linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
}

.suggestion-stat strong{
  font-size:34px;
  line-height:1;
}

.suggestion-stat__label{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:#64748b;
  font-weight:700;
}

.suggestion-filter-card{
  margin-bottom:16px;
}

.suggestion-list{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.suggestion-card{
  background:linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.suggestion-card--open{
  border-color:rgba(59, 130, 246, 0.38);
  box-shadow:0 18px 38px rgba(59, 130, 246, 0.10);
}

.suggestion-card__top{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  flex-wrap:wrap;
}

.suggestion-card__meta{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:10px;
}

.suggestion-card__title{
  margin:0;
  font-size:22px;
  line-height:1.25;
}

.suggestion-card__info{
  margin:8px 0 0;
  color:#64748b;
}

.suggestion-card__facts{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:10px;
  color:#475569;
  font-size:13px;
}

.suggestion-card__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.suggestion-card__preview{
  margin:14px 0 0;
  color:#334155;
  white-space:pre-wrap;
  padding-top:14px;
  border-top:1px solid rgba(226, 232, 240, 0.85);
}

.suggestion-card__details{
  margin-top:18px;
  display:flex;
  flex-direction:column;
  gap:16px;
}

.suggestion-detail-grid{
  display:grid;
  grid-template-columns:minmax(0, 1fr);
  gap:16px;
}

.suggestion-subcard{
  border:1px solid rgba(148, 163, 184, 0.18);
  background:#f8fafc;
}

.suggestion-copy{
  white-space:pre-wrap;
  line-height:1.6;
  color:#0f172a;
}

.suggestion-comments{
  display:flex;
  flex-direction:column;
  gap:12px;
  max-height:380px;
  overflow:auto;
  padding-right:6px;
}

.suggestion-comment{
  padding:12px 14px;
  border-radius:14px;
  background:#fff;
  border:1px solid rgba(148, 163, 184, 0.2);
}

.suggestion-comment--official{
  border-color:rgba(59, 130, 246, 0.28);
  box-shadow:0 0 0 1px rgba(59, 130, 246, 0.08) inset;
}

.suggestion-comment__head{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-bottom:8px;
}

.suggestion-admin-panel{
  border:1px dashed rgba(15, 23, 42, 0.14);
  background:linear-gradient(180deg, rgba(248, 250, 252, 1) 0%, rgba(241, 245, 249, 1) 100%);
}

.suggestion-admin-panel__actions{
  justify-content:flex-end;
}

.suggestion-status,
.suggestion-tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  font-weight:700;
  line-height:1;
}

.suggestion-status--open{ background:#fee2e2; color:#b91c1c; }
.suggestion-status--planned{ background:#ede9fe; color:#6d28d9; }
.suggestion-status--progress{ background:#fef3c7; color:#b45309; }
.suggestion-status--done{ background:#dcfce7; color:#15803d; }
.suggestion-status--rejected{ background:#e2e8f0; color:#475569; }

.suggestion-tag--neutral{ background:#e2e8f0; color:#334155; }
.suggestion-tag--bug{ background:#fee2e2; color:#b91c1c; }
.suggestion-tag--improvement{ background:#dbeafe; color:#1d4ed8; }
.suggestion-tag--feature{ background:#ede9fe; color:#7c3aed; }
.suggestion-tag--ui{ background:#fce7f3; color:#be185d; }
.suggestion-tag--low{ background:#ecfccb; color:#3f6212; }
.suggestion-tag--medium{ background:#fef3c7; color:#92400e; }
.suggestion-tag--high{ background:#ffedd5; color:#c2410c; }

@media (min-width: 1080px){
  .suggestion-detail-grid{
    grid-template-columns:minmax(0, 1.05fr) minmax(0, 0.95fr);
  }
}

@media (max-width: 768px){
  .suggestion-card__top{
    flex-direction:column;
  }
  .suggestion-card__actions{
    width:100%;
  }
  .suggestion-card__actions .btn{
    flex:1;
  }
}

.suggestion-filter-card .toolbar{align-items:center;}
.suggestion-filter-card input,
.suggestion-filter-card select{background:#fff;}

@media (max-width: 1079px){
  #suggestionComposeCard{position:static;}
}


/* Verbesserungen / Änderungswünsche – moderneres Layout */
.page:has(.suggestion-stats-grid){
  gap:22px;
}

.suggestions-layout{
  grid-template-columns:minmax(340px, 420px) minmax(0, 1fr);
  gap:24px;
}

.suggestion-compose-card,
.suggestion-filter-card,
.suggestion-card,
.suggestion-stat{
  border:1px solid rgba(148, 163, 184, 0.18);
  box-shadow:0 18px 42px rgba(15, 23, 42, 0.08);
}

#suggestionComposeCard,
.suggestion-filter-card{
  background:linear-gradient(180deg, #ffffff 0%, #f6faff 100%);
}

#suggestionComposeCard{
  border-radius:24px;
  padding:24px;
  top:22px;
}

.suggestion-compose-head{
  margin-bottom:20px;
  padding-bottom:18px;
  border-bottom:1px solid rgba(226,232,240,0.9);
}

.suggestion-compose-head h3,
.suggestion-filter-card h3{
  margin:10px 0 0;
  font-size:26px;
  line-height:1.15;
}

.suggestion-stats-grid{
  gap:18px;
  margin-bottom:8px;
}

.suggestion-stat{
  position:relative;
  overflow:hidden;
  border-radius:22px;
  padding:22px 24px;
  background:linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.suggestion-stat::before{
  content:'';
  position:absolute;
  inset:0 auto 0 0;
  width:5px;
  border-radius:999px;
  background:linear-gradient(180deg, #2563eb 0%, #60a5fa 100%);
  opacity:.9;
}

.suggestion-stat strong{
  font-size:40px;
  font-weight:800;
  color:#0f172a;
}

.suggestion-stat small{
  color:#64748b;
  font-size:13px;
}

.suggestion-filter-card{
  border-radius:22px;
  padding:20px;
  margin-bottom:18px;
}

.suggestion-filter-card__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:16px;
}

.suggestion-filter-card__count{
  white-space:nowrap;
  padding-top:6px;
}

.suggestion-filter-toolbar{
  align-items:stretch !important;
}

.suggestion-filter-toolbar__controls{
  display:grid !important;
  grid-template-columns:minmax(240px, 1.7fr) repeat(4, minmax(150px, 1fr));
  width:100%;
  gap:12px !important;
}

.suggestion-filter-card input,
.suggestion-filter-card select,
#suggestionComposeCard input,
#suggestionComposeCard select,
#suggestionComposeCard textarea,
.suggestion-admin-panel select,
.suggestion-card textarea{
  border-radius:14px;
  border:1px solid rgba(148, 163, 184, 0.28);
  background:#fff;
  box-shadow:0 1px 2px rgba(15, 23, 42, 0.03) inset;
}

.suggestion-card{
  border-radius:22px;
  padding:20px 22px;
  background:linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.suggestion-card--open{
  border-color:rgba(59, 130, 246, 0.32);
  box-shadow:0 20px 48px rgba(37, 99, 235, 0.12);
}

.suggestion-card__top{
  gap:20px;
}

.suggestion-card__title{
  margin:0;
  font-size:32px;
  line-height:1.08;
  letter-spacing:-0.02em;
  color:#0f172a;
}

.suggestion-card__info{
  margin:10px 0 0;
  color:#64748b;
  font-size:14px;
}

.suggestion-card__actions .btn{
  min-width:140px;
  border-radius:14px;
}

.suggestion-card__preview{
  margin-top:16px;
  padding-top:16px;
  color:#334155;
  font-size:16px;
  line-height:1.65;
}

.suggestion-card__details{
  margin-top:20px;
  padding-top:18px;
  border-top:1px solid rgba(226,232,240,0.9);
}

.suggestion-subcard,
.suggestion-admin-panel{
  border-radius:18px;
  padding:18px;
}

.suggestion-subcard{
  background:linear-gradient(180deg, #f8fbff 0%, #f8fafc 100%);
}

.suggestion-subcard h4,
.suggestion-admin-panel h4{
  margin:0 0 14px;
  font-size:18px;
}

.suggestion-comment{
  border-radius:16px;
  padding:14px 16px;
  background:#fff;
  box-shadow:0 6px 18px rgba(15, 23, 42, 0.04);
}

.suggestion-comment--official{
  background:linear-gradient(180deg, #eff6ff 0%, #ffffff 100%);
}

.suggestion-admin-panel{
  border:1px dashed rgba(59, 130, 246, 0.28);
  background:linear-gradient(180deg, rgba(239, 246, 255, 0.95) 0%, rgba(248, 250, 252, 1) 100%);
}

.suggestion-admin-panel__actions{
  margin-top:8px;
}

.suggestion-status,
.suggestion-tag{
  padding:7px 12px;
  border-radius:999px;
  font-size:12px;
  letter-spacing:0.01em;
}

@media (max-width: 1280px){
  .suggestions-layout{
    grid-template-columns:minmax(300px, 380px) minmax(0, 1fr);
  }
  .suggestion-filter-toolbar__controls{
    grid-template-columns:minmax(220px, 1fr) repeat(2, minmax(150px, 1fr));
  }
}

@media (max-width: 1079px){
  .suggestions-layout{
    grid-template-columns:minmax(0, 1fr);
  }
  #suggestionComposeCard{position:static;}
}

@media (max-width: 760px){
  .suggestion-filter-card__head{
    flex-direction:column;
  }
  .suggestion-filter-toolbar__controls{
    grid-template-columns:minmax(0, 1fr);
  }
  .suggestion-card{
    padding:18px;
  }
  .suggestion-card__title{
    font-size:26px;
  }
  .suggestion-card__actions{
    width:100%;
  }
  .suggestion-card__actions .btn{
    flex:1;
    min-width:0;
  }
}


.burger-menu-wrap{
  position:relative;
  display:inline-flex;
  align-items:center;
  flex:0 0 auto;
}

.burger-toggle{
  min-width:44px;
  padding-left:12px;
  padding-right:12px;
  font-size:20px;
  line-height:1;
}

.burger-dropdown{
  position:absolute;
  top:calc(100% + 8px);
  right:0;
  min-width:260px;
  width:max-content;
  max-width:min(320px, calc(100vw - 24px));
  padding:10px;
  border-radius:18px;
  background:rgba(15,23,42,0.98);
  color:#fff;
  box-shadow:0 16px 40px rgba(15,23,42,0.28);
  border:1px solid rgba(255,255,255,0.08);
  display:none;
  z-index:1200;
  overflow-x:hidden;
}

.burger-menu-wrap.is-open .burger-dropdown{
  display:block;
}

.burger-link{
  width:100%;
  border:none;
  background:transparent;
  color:#fff;
  text-align:left;
  padding:11px 12px;
  border-radius:12px;
  cursor:pointer;
  font-size:14px;
  display:block;
}

.burger-link:hover{
  background:rgba(255,255,255,0.08);
}

.burger-link.active{
  background:rgba(59,130,246,0.22);
}

.burger-divider{
  height:1px;
  background:rgba(255,255,255,0.10);
  margin:8px 4px;
}

.burger-link-danger{
  color:#fecaca;
}




.icon-btn{
  min-width:44px;
  height:44px;
  border:none;
  border-radius:12px;
  background:rgba(15,23,42,0.08);
  color:inherit;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  transition:transform .15s ease, background .15s ease;
}

.icon-btn:hover{
  transform:translateY(-1px);
  background:rgba(15,23,42,0.14);
}

.settings-btn{
  flex:0 0 auto;
}


.burger-footer-actions{
  display:flex;
  align-items:center;
  gap:8px;
}

.burger-footer-actions .burger-link-danger{
  flex:1 1 auto;
}

.burger-icon-link{
  width:44px;
  min-width:44px;
  height:44px;
  border:none;
  border-radius:12px;
  background:transparent;
  color:#fff;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
}

.burger-icon-link:hover{
  background:rgba(255,255,255,0.08);
}


@media (max-width: 700px){
  .burger-menu-wrap{
    position:relative;
  }

  .burger-dropdown{
    position:fixed;
    top:64px;
    right:12px;
    left:12px;
    width:auto;
    min-width:0;
    max-width:none;
    max-height:calc(100vh - 76px);
    overflow-y:auto;
    border-radius:16px;
  }

  .burger-footer-actions{
    position:sticky;
    bottom:0;
    background:rgba(15,23,42,0.98);
    padding-top:8px;
  }
}


.admin-position-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));
  gap:16px;
  margin-top:8px;
}


.position-order-input{
  width:100%;
  min-width:80px;
}



.admin-section-kicker{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:rgba(37,99,235,.10);color:#1d4ed8;font-size:12px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;margin-bottom:12px}
.admin-vacation-types-page{display:flex;flex-direction:column;gap:18px}
.admin-vacation-hero{display:flex;justify-content:space-between;align-items:stretch;gap:18px;padding:22px;border-radius:24px;background:linear-gradient(135deg, rgba(37,99,235,.10), rgba(14,165,233,.07));border:1px solid rgba(148,163,184,.18)}
.admin-vacation-hero h3{margin:6px 0 8px 0;font-size:28px}
.admin-vacation-hero__badge{min-width:140px;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:18px;border-radius:22px;background:#fff;border:1px solid rgba(148,163,184,.18);box-shadow:0 10px 30px rgba(15,23,42,.06)}
.admin-vacation-hero__badge strong{font-size:34px;line-height:1;font-weight:800}
.admin-vacation-hero__badge span{margin-top:6px;color:#64748b;font-size:13px}
.admin-vacation-grid{display:grid;grid-template-columns:minmax(320px, 420px) minmax(0,1fr);gap:18px}
.admin-vacation-panel{border-radius:24px;box-shadow:0 18px 40px rgba(15,23,42,.06)}
.admin-vacation-panel--form{position:sticky;top:18px;align-self:start}
.admin-vacation-create-grid,.admin-vacation-type-row__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.admin-vacation-create-preview{margin-top:16px}
.admin-vacation-preview-card{padding:16px;border-radius:20px;background:#f8fafc;border:1px solid rgba(148,163,184,.16)}
.admin-vacation-preview-card__label{display:block;font-size:12px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.03em;margin-bottom:10px}
.admin-vacation-preview-badges{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.admin-vacation-badge{display:inline-flex;align-items:center;justify-content:center;min-width:72px;padding:10px 14px;border-radius:14px;font-weight:800;font-size:14px;box-shadow:inset 0 0 0 1px rgba(15,23,42,.06)}
.admin-vacation-badge--privacy{background:#eef2ff;color:#4338ca}
.admin-vacation-list-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:16px}
.admin-vacation-mini-legend{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#64748b;text-align:right}
.admin-vacation-type-list{display:flex;flex-direction:column;gap:14px}
.admin-vacation-type-row{padding:18px;border-radius:22px;background:#fff;border:1px solid rgba(148,163,184,.16);box-shadow:0 8px 24px rgba(15,23,42,.05)}
.admin-vacation-type-row__top{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:16px}
.admin-vacation-type-row__top h4{margin:0 0 6px 0;font-size:18px}
.admin-vacation-type-row__top p{margin:0;color:#64748b}
@media (max-width: 1100px){.admin-vacation-grid{grid-template-columns:1fr}.admin-vacation-panel--form{position:static}.admin-vacation-list-head,.admin-vacation-hero{flex-direction:column}.admin-vacation-mini-legend{text-align:left}}
@media (max-width: 720px){.admin-vacation-create-grid,.admin-vacation-type-row__grid{grid-template-columns:1fr}.admin-vacation-hero h3{font-size:24px}}


.admin-vacation-hero__meta{display:flex;gap:12px;align-items:stretch;flex-wrap:wrap}
.admin-vacation-hero__badge--small{min-width:120px;padding:14px 16px}
.admin-vacation-panel-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}
.admin-vacation-panel-head h3{margin:4px 0 6px 0}
.admin-vacation-panel-kicker{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;background:#eef2ff;color:#4338ca;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.admin-vacation-preview-card__header{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:10px;flex-wrap:wrap}
.admin-vacation-preview-card__hint{font-size:12px;color:#64748b}
.admin-vacation-list-head--stacked{flex-direction:column;align-items:stretch}
.admin-vacation-toolbar{display:flex;justify-content:space-between;gap:16px;align-items:flex-end;flex-wrap:wrap}
.admin-vacation-search-field{min-width:260px;max-width:360px;width:100%}
.admin-vacation-search-field input{width:100%}
.admin-vacation-mini-legend--boxed{padding:12px 14px;border-radius:16px;background:#f8fafc;border:1px solid rgba(148,163,184,.16);text-align:left;min-width:280px}
.admin-vacation-type-list-meta{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:14px;color:#64748b;font-size:13px;flex-wrap:wrap}
.admin-vacation-type-row{position:relative;overflow:hidden;padding-left:22px}
.admin-vacation-type-row__accent{position:absolute;left:0;top:0;bottom:0;width:6px;border-radius:22px 0 0 22px}
.admin-vacation-type-row__titlewrap{display:flex;gap:12px;align-items:flex-start}
.admin-vacation-preview-badges--right{justify-content:flex-end}
.admin-vacation-type-row__grid--dense{grid-template-columns:minmax(220px,1.4fr) repeat(4,minmax(120px,1fr));align-items:end}
.admin-vacation-type-row .field--wide{grid-column:auto}
.admin-form-actions--split{display:flex;justify-content:space-between;gap:14px;align-items:center;flex-wrap:wrap;margin-top:16px}
.admin-vacation-inline-note{font-size:12px;color:#64748b;background:#f8fafc;border:1px solid rgba(148,163,184,.14);padding:8px 10px;border-radius:12px}
.admin-vacation-row-actions{display:flex;gap:10px;flex-wrap:wrap}
.admin-vacation-empty{padding:28px;border:1px dashed rgba(148,163,184,.3);border-radius:20px;background:#f8fafc;color:#64748b;text-align:center}
@media (max-width: 1100px){.admin-vacation-toolbar,.admin-vacation-panel-head{flex-direction:column;align-items:stretch}.admin-vacation-search-field{max-width:none}.admin-vacation-mini-legend--boxed{min-width:0}.admin-vacation-type-row__grid--dense{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 720px){.admin-vacation-hero__meta{width:100%}.admin-vacation-hero__badge,.admin-vacation-hero__badge--small{min-width:0;flex:1}.admin-vacation-type-row{padding-left:18px}.admin-vacation-type-row__top{flex-direction:column}.admin-vacation-preview-badges--right{justify-content:flex-start}.admin-vacation-type-row__grid--dense{grid-template-columns:1fr}.admin-form-actions--split{align-items:stretch}.admin-vacation-row-actions{width:100%}.admin-vacation-row-actions .btn{flex:1}}

.admin-vacation-hero--letters{
  background:linear-gradient(135deg, rgba(59,130,246,.12), rgba(99,102,241,.08), rgba(16,185,129,.08));
}
.admin-vacation-grid--equal{grid-template-columns:repeat(2,minmax(0,1fr));}
.admin-vacation-grid--topspace{margin-top:18px;}
.admin-linked-colors-panel{margin-top:18px;overflow:hidden;}
.admin-linked-colors-legend{display:flex;flex-wrap:wrap;gap:8px 14px;color:#64748b;font-size:13px;justify-content:flex-end;}
.admin-linked-color-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px;}
.admin-linked-color-card{padding:18px;border-radius:22px;background:linear-gradient(180deg,#ffffff 0%, #f8fbff 100%);border:1px solid rgba(148,163,184,.18);box-shadow:0 14px 32px rgba(15,23,42,.06);}
.admin-linked-color-card__head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:14px;}
.admin-linked-color-card__title{font-size:18px;font-weight:800;color:#0f172a;}
.admin-linked-color-card__subtitle{margin-top:4px;color:#64748b;font-size:13px;}
.admin-linked-color-card__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}
.admin-vacation-create-grid--wide{grid-template-columns:repeat(2,minmax(0,1fr));}
.admin-vacation-preview-card--double{background:linear-gradient(180deg,#f8fbff 0%,#ffffff 100%);border:1px solid rgba(148,163,184,.16);}
.admin-vacation-type-row--modern{background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);box-shadow:0 12px 28px rgba(15,23,42,.06);}
.admin-vacation-type-row__grid--modern{grid-template-columns:minmax(220px,1.4fr) repeat(6,minmax(120px,1fr));align-items:end;}
.admin-vacation-panel-head--tight{margin-bottom:18px;}
.admin-letter-color-page .admin-vacation-row-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.admin-letter-color-page .color-rule-preview{min-width:68px;justify-content:center;}
@media (max-width: 1200px){
  .admin-vacation-type-row__grid--modern{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width: 1100px){
  .admin-vacation-grid--equal{grid-template-columns:1fr;}
  .admin-linked-colors-legend{justify-content:flex-start;}
}
@media (max-width: 720px){
  .admin-linked-color-card__head{flex-direction:column;}
  .admin-linked-color-card__grid,.admin-vacation-create-grid--wide{grid-template-columns:1fr;}
  .admin-vacation-type-row__grid--modern{grid-template-columns:1fr;}
}

.admin-vacation-hero--clean{background:linear-gradient(135deg, rgba(255,255,255,.96), rgba(248,250,252,.96));border-color:rgba(148,163,184,.2);box-shadow:0 18px 40px rgba(15,23,42,.05)}
.admin-letter-modern-page{display:flex;flex-direction:column;gap:18px}
.admin-letter-layout{display:grid;grid-template-columns:minmax(320px,420px) minmax(0,1fr);gap:18px;align-items:start}
.admin-letter-create-panel,.admin-letter-list-panel,.admin-letter-editor-panel{border-radius:24px;box-shadow:0 16px 36px rgba(15,23,42,.06)}
.admin-letter-create-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;align-items:end}
.admin-letter-create-grid .admin-letter-checkbox{grid-column:1/-1;justify-content:flex-start}
.admin-letter-create-panel .admin-form-actions{margin-top:16px}
.admin-letter-checkbox{display:inline-flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid rgba(148,163,184,.22);border-radius:16px;background:#f8fafc;min-height:48px;font-weight:700;color:#334155}
.admin-letter-checkbox input{margin:0}
.admin-letter-privacy-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px}
.admin-letter-preview-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}
.admin-letter-preview-row--editor{margin-top:18px}
.admin-letter-preview-box{display:flex;flex-direction:column;gap:8px;padding:14px 16px;border-radius:18px;background:#f8fafc;border:1px solid rgba(148,163,184,.18);min-width:180px}
.admin-letter-preview-caption{font-size:12px;color:#64748b}
.admin-letter-chip-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.admin-letter-chip{appearance:none;border:1px solid rgba(148,163,184,.18);background:linear-gradient(180deg,#fff,#fbfdff);border-radius:20px;padding:14px 14px 12px;text-align:left;display:flex;flex-direction:column;gap:12px;cursor:pointer;transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;box-shadow:0 8px 20px rgba(15,23,42,.05)}
.admin-letter-chip:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(15,23,42,.07);border-color:rgba(59,130,246,.28)}
.admin-letter-chip.active{border-color:#2563eb;box-shadow:0 0 0 2px rgba(37,99,235,.12), 0 14px 28px rgba(15,23,42,.08)}
.admin-letter-chip__top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.admin-letter-chip__top strong{font-size:15px;color:#0f172a}
.admin-letter-chip__top span{font-size:12px;color:#64748b}
.admin-letter-chip__badges{display:flex;gap:8px;flex-wrap:wrap}
.admin-letter-chip-badge{display:inline-flex;align-items:center;justify-content:center;min-width:52px;height:38px;padding:0 12px;border-radius:14px;border:1px solid rgba(148,163,184,.16);font-weight:800;letter-spacing:.02em;box-shadow:inset 0 0 0 1px rgba(255,255,255,.25)}
.admin-letter-chip-badge--privacy{outline:2px dashed rgba(148,163,184,.2);outline-offset:0}
.admin-letter-editor-grid{display:grid;grid-template-columns:minmax(220px,1.4fr) repeat(4,minmax(120px,1fr));gap:14px;align-items:end}
.admin-letter-empty{padding:18px;border:1px dashed rgba(148,163,184,.32);border-radius:20px;background:#f8fafc;color:#64748b;text-align:center}
.admin-letter-empty--large{padding:28px;font-weight:600}
@media (max-width: 1180px){
  .admin-letter-layout{grid-template-columns:1fr}
  .admin-letter-editor-grid,.admin-letter-create-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 760px){
  .admin-letter-editor-grid,.admin-letter-create-grid,.admin-letter-privacy-fields{grid-template-columns:1fr}
  .admin-letter-chip-grid{grid-template-columns:1fr}
  .admin-letter-preview-box{width:100%}
}


/* v32 Datenschutz-Hub */
.admin-letter-hub-page{display:flex;flex-direction:column;gap:18px;}
.admin-letter-overview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;}
.admin-letter-overview-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.78);border:1px solid rgba(148,163,184,.18);box-shadow:0 10px 24px rgba(15,23,42,.06);}
.admin-letter-overview-card__meta{display:flex;flex-direction:column;gap:2px;min-width:0;}
.admin-letter-overview-card__meta strong,.admin-letter-overview-card__meta span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.admin-vacation-type-list--hub{display:flex;flex-direction:column;gap:14px;}
.admin-hub-row{display:grid;grid-template-columns:minmax(0,1fr) 240px;gap:16px;padding:18px;border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(248,250,252,.92));border:1px solid rgba(148,163,184,.22);box-shadow:0 16px 36px rgba(15,23,42,.06);}
.admin-hub-row__main{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;align-items:end;}
.admin-hub-row__side{display:flex;flex-direction:column;gap:10px;justify-content:center;}
.admin-letter-layout--stacked{display:flex;flex-direction:column;gap:18px;}
.admin-letter-create-grid--compact{grid-template-columns:1.2fr .9fr repeat(4,minmax(0,1fr));align-items:end;}
.admin-letter-context-list{display:flex;flex-direction:column;gap:12px;}
.admin-letter-context-row{display:grid;grid-template-columns:1.2fr repeat(2,minmax(120px,.8fr)) 150px 170px;gap:12px;align-items:end;padding:16px;border-radius:18px;background:rgba(255,255,255,.78);border:1px solid rgba(148,163,184,.18);}
.admin-letter-context-row__code input{text-transform:uppercase;}
.admin-letter-preview-box--inline{min-height:auto;align-items:flex-start;justify-content:center;}
.admin-vacation-row-actions--stacked{display:flex;flex-direction:column;gap:10px;}
.admin-letter-preview-row--hub{justify-content:space-between;align-items:center;flex-wrap:wrap;}
.admin-letter-checkbox--compact{align-self:end;margin-bottom:10px;}
@media (max-width: 1200px){
  .admin-hub-row{grid-template-columns:1fr;}
  .admin-hub-row__main{grid-template-columns:repeat(2,minmax(0,1fr));}
  .admin-letter-create-grid--compact{grid-template-columns:repeat(2,minmax(0,1fr));}
  .admin-letter-context-row{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width: 760px){
  .admin-hub-row__main,.admin-letter-create-grid--compact,.admin-letter-context-row{grid-template-columns:1fr;}
  .admin-hub-row__side{align-items:flex-start;}
}


.admin-privacy-color-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px;margin-top:10px}
.admin-privacy-color-tile{border:1px solid rgba(90,110,140,.16);border-radius:16px;padding:12px;background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(246,249,255,.92));display:grid;gap:10px}
.admin-privacy-color-tile__head{display:flex;align-items:flex-start;gap:10px}
.admin-privacy-color-tile__meta{display:grid;gap:4px;min-width:0}
.admin-privacy-color-tile__meta strong{font-size:15px}
.admin-privacy-color-tile__meta span{font-size:12px;color:#667085;line-height:1.35}
.admin-privacy-color-tile__controls{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;align-items:end}
.field--compact{display:grid;gap:6px}
.field--compact span{font-size:12px;color:#667085;font-weight:600}
.btn-small{padding:10px 12px;font-size:13px}
.admin-custom-letter-create-row,.admin-custom-letter-row{display:grid;grid-template-columns:minmax(100px,120px) minmax(150px,190px) repeat(4,minmax(110px,1fr)) auto auto;gap:10px;align-items:end}
.admin-custom-letter-create-row{padding:12px 0 14px;border-bottom:1px solid rgba(90,110,140,.12);margin-bottom:14px}
.admin-custom-letter-create-row__preview,.admin-custom-letter-row__preview{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.admin-custom-letter-list{display:grid;gap:10px}
.admin-custom-letter-row{padding:12px;border:1px solid rgba(90,110,140,.14);border-radius:16px;background:#fff}
.admin-custom-letter-row__code,.admin-custom-letter-create-row__code{min-width:0}
@media (max-width: 1180px){
  .admin-custom-letter-create-row,.admin-custom-letter-row{grid-template-columns:repeat(2,minmax(0,1fr))}
  .admin-privacy-color-tile__controls{grid-template-columns:repeat(2,minmax(0,1fr))}
}

.admin-letter-hub-page--compact{display:grid;gap:16px}
.admin-privacy-color-grid--compact,.admin-custom-letter-list--compact{display:grid;gap:10px}
.admin-privacy-color-tile--compact,.admin-custom-letter-row--compact,.admin-custom-letter-create-row--compact{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;align-items:end}
.admin-privacy-color-tile--compact .admin-privacy-color-tile__head{grid-column:1/-1;display:flex;align-items:center;gap:10px}
.admin-privacy-color-tile__controls--compact{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;align-items:end}
.admin-letter-checkbox--inline{align-self:end;min-height:42px;display:flex;align-items:center}
.admin-custom-letter-row--compact .admin-custom-letter-row__preview,.admin-custom-letter-create-row--compact .admin-custom-letter-create-row__preview{display:flex;gap:8px;align-items:center;align-self:end;flex-wrap:wrap}
.admin-custom-letter-row--compact .admin-vacation-row-actions,.admin-custom-letter-create-row--compact .admin-vacation-row-actions{align-self:end}


.admin-privacy-box-sections{display:grid;gap:16px}
.admin-privacy-box-section{display:grid;gap:10px}
.admin-privacy-box-section__title{font-size:13px;font-weight:700;color:#44526a}
.admin-privacy-box-grid{display:flex;flex-wrap:wrap;gap:10px}
.admin-privacy-box-card{display:grid;gap:8px;justify-items:center;padding:10px;border:1px solid rgba(90,110,140,.14);border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(246,249,255,.94));min-width:74px}
.admin-privacy-box-preview{display:flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 10px;border-radius:12px;font-weight:800;font-size:14px;letter-spacing:.02em;box-shadow:inset 0 0 0 1px rgba(0,0,0,.04)}
.admin-privacy-box-pickers{display:flex;gap:6px}
.privacy-box-color-input{width:24px;height:24px;padding:0;border:none;background:transparent;cursor:pointer}
.privacy-box-color-input::-webkit-color-swatch-wrapper{padding:0}
.privacy-box-color-input::-webkit-color-swatch{border:none;border-radius:8px}
.privacy-box-color-input::-moz-color-swatch{border:none;border-radius:8px}

.admin-privacy-box-headline{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px;}
.admin-privacy-box-legend{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:12px;color:#667085;}
.admin-privacy-box-legend span{display:inline-flex;align-items:center;gap:6px;}
.admin-privacy-box-legend-dot{width:10px;height:10px;border-radius:999px;display:inline-block;border:1px solid rgba(15,23,42,.12);}
.admin-privacy-box-legend-dot--text{background:#21304d;}
.admin-privacy-box-legend-dot--bg{background:#ffffff;}
.admin-privacy-box-pickers{position:relative;}
.admin-privacy-box-pickers .privacy-box-color-input:first-child{box-shadow:0 0 0 2px rgba(33,48,77,.08);}
.admin-privacy-box-pickers .privacy-box-color-input:last-child{box-shadow:0 0 0 2px rgba(148,163,184,.18);}

.admin-privacy-box-pickers{display:flex;gap:8px;align-items:flex-start;justify-content:center;width:100%;}
.admin-privacy-box-picker-col{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:4px;min-width:34px;}
.admin-privacy-box-picker-label{font-size:10px;line-height:1;text-align:center;color:#667085;white-space:nowrap;}
.admin-vacation-types-page--compact{display:block;}
.admin-vacation-panel--compact{display:grid;gap:14px;}
.admin-vacation-list-head--compact{display:flex;justify-content:space-between;align-items:end;gap:14px;flex-wrap:wrap;}
.admin-vacation-search-field--compact{min-width:220px;max-width:280px;}
.admin-vacation-create-grid--compact{display:grid;grid-template-columns:minmax(220px,1fr) minmax(140px,180px) auto;gap:10px;align-items:end;}
.admin-vacation-type-list--compact{display:grid;gap:10px;}
.admin-vacation-type-row--compact{display:grid;grid-template-columns:minmax(220px,1fr) minmax(140px,180px) auto;gap:10px;align-items:end;padding:12px;border:1px solid rgba(90,110,140,.14);border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(246,249,255,.94));}
.admin-vacation-row-actions--compact{justify-content:flex-end;}
.admin-form-actions--compact{align-self:end;}
.admin-vacation-type-list-meta--compact{padding-top:0;}
@media (max-width: 780px){.admin-vacation-create-grid--compact,.admin-vacation-type-row--compact{grid-template-columns:1fr;}}


.shiftplan-custom-color{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  min-height:40px;
}
.shiftplan-custom-color span{
  font-size:12px;
  color:var(--muted);
  font-weight:600;
}
.shiftplan-custom-color input[type="color"]{
  width:34px;
  height:34px;
  padding:0;
  border:none;
  background:transparent;
  cursor:pointer;
}


.vacation-year-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:16px;align-items:start}
.vacation-year-main-card{min-width:0}
.vacation-year-table-wrap{max-height:calc(100vh - 220px);overflow:auto}
.vacation-year-sheet{table-layout:fixed;border-collapse:collapse;width:max-content;min-width:100%}
.vacation-year-sheet th,.vacation-year-sheet td{min-width:28px;width:28px;height:28px;padding:0;text-align:center;font-size:12px}
.vacation-year-sheet .sticky-col-1{position:sticky;left:0;z-index:4;background:#fff;min-width:64px;width:64px}
.vacation-year-sheet .sticky-col-2{position:sticky;left:64px;z-index:4;background:#fff;min-width:56px;width:56px}
.vacation-year-sheet .sticky-col-right{position:sticky;right:0;z-index:4;background:#fff;min-width:48px;width:48px}
.vacation-year-month-cell{font-weight:700;background:#f8fafc}
.vacation-year-month-subhead{background:#f8fafc;font-weight:700}
.vacation-year-day-head{position:sticky;top:0;z-index:3;background:#fff;font-weight:600}
.vacation-year-month-header-row th{border-top:2px solid var(--line-strong, #000)}
.vacation-year-month-group:last-child tr:last-child td,.vacation-year-month-group:last-child tr:last-child th{border-bottom:2px solid var(--line-strong, #000)}
.vacation-year-cell{background:#fff}
.vacation-year-employee-label{background:#fff;font-weight:700}
.vacation-year-rhythm-row th{font-size:11px;font-weight:700;background:#f8fafc}
.vacation-year-rhythm-head{color:#334155}
.vacation-year-empty{padding:12px;background:#fff;text-align:left}
.vacation-year-side-card{display:flex;flex-direction:column;gap:12px}
.vacation-year-side-header h3{margin:10px 0 8px}
.vacation-year-side-header p{margin:0;color:var(--muted)}
.vacation-year-code-chip{display:inline-flex;align-items:center;justify-content:center;min-width:44px;padding:2px 6px;border-radius:8px;background:#eef2ff;font-weight:700}
.vacation-year-legend-table td,.vacation-year-legend-table th{white-space:nowrap}
@media (max-width: 1200px){.vacation-year-layout{grid-template-columns:1fr}.vacation-year-side-card{order:-1}}


.vacation-year-weekday-row th{font-size:11px;font-weight:600;opacity:.8}
.grid-dashboard{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));}


/* Vacation year planning color overrides */
.vacation-year-day-head--holiday,
.vacation-year-weekday-head--holiday{
  background:#ff1f1f !important;
  color:#fff !important;
}
.vacation-year-rhythm-head--4{
  background:#92d050 !important;
  color:#111 !important;
  font-weight:700;
}
.vacation-year-rhythm-head--5{
  background:#ffd966 !important;
  color:#111 !important;
  font-weight:700;
}
.vacation-year-entry--u{
  background:rgb(155,194,230) !important;
  color:#111 !important;
}
.vacation-year-entry--su{
  background:rgb(155,194,230) !important;
  color:#111 !important;
}
.vacation-year-entry--f{
  background:rgb(191,191,191) !important;
  color:#111 !important;
}
.vacation-year-entry--tz{
  background:rgb(112,48,160) !important;
  color:#fff !important;
}
.vacation-year-cell--holiday.vacation-year-entry--u,
.vacation-year-cell--holiday.vacation-year-entry--su,
.vacation-year-cell--holiday.vacation-year-entry--f,
.vacation-year-cell--holiday.vacation-year-entry--tz{
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.18);
}


.vacation-year-month-separator-row > *{border:0 !important;padding:0 !important;height:8px;min-height:8px;background:transparent !important;color:transparent !important;line-height:0;font-size:0}
.vacation-year-month-separator-cell{border-left:1px solid var(--line, #d1d5db) !important;border-right:1px solid var(--line, #d1d5db) !important}
.vacation-year-month-separator-side{background:transparent !important}
.vacation-year-cell--auto4{background:#92d050 !important;color:#111 !important;font-weight:700}
.vacation-year-cell--auto5{background:#ffd966 !important;color:#111 !important;font-weight:700}


/* Vacation year planning interaction + nicer summary */
.vacation-year-toolbar{position:sticky;top:0;z-index:5;background:var(--card,#fff);border-bottom:1px solid var(--line,#d1d5db)}
.vacation-year-cell-editable{cursor:cell;user-select:none}
.vacation-year-cell-editable.is-selected{box-shadow:inset 0 0 0 2px rgba(37,99,235,.55)}
.vacation-year-cell-editable.is-selection-anchor{box-shadow:inset 0 0 0 2px var(--accent,#2563eb)}
.vacation-year-cell-editable.is-selected.is-selection-anchor{box-shadow:inset 0 0 0 2px var(--accent,#2563eb), inset 0 0 0 999px rgba(37,99,235,.08)}
.vacation-year-summary-card{border:1px solid var(--line,#d1d5db);box-shadow:0 10px 24px rgba(15,23,42,.06)}
.vacation-year-summary-grid{width:100%;border-collapse:separate;border-spacing:0;overflow:hidden;border-radius:14px;background:#fff}
.vacation-year-summary-grid thead th{position:sticky;top:0;background:#f8fafc;font-weight:800;border-bottom:1px solid var(--line,#d1d5db)}
.vacation-year-summary-grid th,.vacation-year-summary-grid td{padding:10px 12px;border-right:1px solid var(--line,#d1d5db);border-bottom:1px solid var(--line,#d1d5db);text-align:center}
.vacation-year-summary-grid tr > *:last-child{border-right:0}
.vacation-year-summary-grid tbody tr:last-child > *{border-bottom:0}
.vacation-year-summary-grid tbody tr:nth-child(even) > *{background:#fbfdff}
.vacation-year-summary-grid tbody tr:hover > *{background:#f8fbff}
.vacation-year-summary-grid thead th:first-child,.vacation-year-summary-grid tbody th{position:sticky;left:0;background:inherit;text-align:left}
.vacation-year-summary-grid thead th:first-child{z-index:2;background:#f8fafc}
.vacation-year-summary-grid tbody th{font-weight:700;min-width:190px}
.vacation-year-summary-value{font-variant-numeric:tabular-nums;font-weight:700}



.vacation-year-summary-head{
  color:#0f172a !important;
  background:#f8fafc !important;
  font-weight:800 !important;
  letter-spacing:0 !important;
}
.vacation-year-summary-head span{
  display:inline-block;
  color:#0f172a !important;
  opacity:1 !important;
  visibility:visible !important;
}
.vacation-year-summary-head-row th{
  color:#0f172a !important;
}

/* Final sunday visual fix: keep working edit/summary logic, only restore subtle Sunday styling */
.vacation-year-day-head--sunday,
.vacation-year-weekday-head--sunday{
  background:#fdeaea !important;
  color:#8f1d1d !important;
}
.vacation-year-cell--sunday{
  background:#fff6f6 !important;
}
.vacation-year-cell--sunday.vacation-year-cell--auto4{
  background:#92d050 !important;
}
.vacation-year-cell--sunday.vacation-year-cell--auto5{
  background:#ffd966 !important;
}
.vacation-year-cell--sunday.vacation-year-entry--u{
  background:rgb(155,194,230) !important;
}
.vacation-year-cell--sunday.vacation-year-entry--su{
  background:rgb(155,194,230) !important;
}
.vacation-year-cell--sunday.vacation-year-entry--f{
  background:rgb(191,191,191) !important;
}
.vacation-year-cell--sunday.vacation-year-entry--tz{
  background:rgb(112,48,160) !important;
  color:#fff !important;
}



.vacation-year-employee-label--info{
  background:#f8fafc !important;
  color:#334155 !important;
  font-weight:800 !important;
  letter-spacing:.04em;
}
.vacation-year-cell--info{
  background-clip:padding-box;
}


.vacation-year-archived-note{padding:10px 12px;margin:0 0 10px;border:1px solid rgba(255,255,255,.08);border-radius:10px;background:rgba(255,193,7,.10);font-size:13px;}


.vacation-year-design-note{margin-top:8px;font-size:12px;color:var(--muted,#6b7280);}
.vacation-year-page--design-horchi .vacation-year-design-note strong,.vacation-year-page--design-tomi .vacation-year-design-note strong{color:inherit;}


/* Tomi design vacation year layout */
.vacation-year-page--design-tomi .vacation-year-sheet .sticky-col-2,
.vacation-year-page--design-tomi .vacation-year-month-subhead,
.vacation-year-page--design-tomi .vacation-year-employee-label,
.vacation-year-page--design-tomi .vacation-year-employee-label--info,
.vacation-year-page--design-tomi .vacation-year-info-row > .sticky-col-2,
.vacation-year-page--design-tomi .vacation-year-month-separator-row > .sticky-col-2{
  display:none;
}
.vacation-year-page--design-tomi .vacation-year-sheet .sticky-col-1{min-width:72px;width:72px}
.vacation-year-page--design-tomi .vacation-year-sheet .vacation-year-day-head,
.vacation-year-page--design-tomi .vacation-year-sheet .vacation-year-weekday-head,
.vacation-year-page--design-tomi .vacation-year-sheet .vacation-year-rhythm-head,
.vacation-year-page--design-tomi .vacation-year-sheet .vacation-year-cell{min-width:30px;width:30px}
.tomi-vacation-side-stack{display:flex;flex-direction:column;gap:18px}
.tomi-vacation-side-user-color-card{display:flex;flex-direction:column;gap:8px;padding:10px 12px;border:1px solid #e5e7eb;background:#fff;border-radius:10px}
.tomi-vacation-side-user-color-label{font-size:13px;font-weight:800;color:#111827}
.tomi-vacation-side-user-color-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.tomi-vacation-side-user-color-controls input[type="color"]{width:42px;height:32px;padding:0;border:1px solid #d1d5db;background:#fff;cursor:pointer}
.tomi-vacation-side-user-color-hint{font-size:12px;color:#6b7280}
.tomi-vacation-side-block{background:#fff}
.tomi-vacation-side-block-head{display:flex;justify-content:flex-start;align-items:center;font-weight:800;font-size:14px;margin:0 0 6px;color:#111827}
.tomi-vacation-side-table{width:100%;border-collapse:separate;border-spacing:0 6px}
.tomi-vacation-side-table td{border:0;padding:0;vertical-align:middle;background:transparent}
.tomi-vacation-side-row td{font-size:14px}
.tomi-vacation-side-name{display:flex;align-items:center;gap:8px;font-weight:700;color:#111;white-space:nowrap}
.tomi-vacation-side-count{width:32px;text-align:right;font-weight:800;color:#374151;padding-left:10px!important}
.tomi-vacation-side-code{display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:18px;padding:0 4px;border:1px solid #111;color:#111;font-size:11px;font-weight:800;line-height:1;border-radius:0;cursor:pointer;appearance:none;background:transparent;font-family:inherit;user-select:all}.tomi-vacation-side-code:active{transform:translateY(1px)}.tomi-vacation-side-code.is-copied{box-shadow:0 0 0 2px rgba(17,24,39,.18) inset}.vacation-year-cell--tomi{font-weight:700}

/* Tomi Design: 5er-Rhythmus in beige rgb(250,191,143) */
.vacation-year-page--design-tomi .vacation-year-rhythm-head--5,
.vacation-year-page--design-tomi .vacation-year-cell--auto5,
.vacation-year-page--design-tomi .vacation-year-cell--sunday.vacation-year-cell--auto5,
.vacation-year-page--design-tomi .vacation-year-cell--holiday.vacation-year-cell--auto5{
  background: rgb(250, 191, 143) !important;
  background-image: none !important;
  background-blend-mode: normal !important;
  color: #111 !important;
}

.tomi-vacation-side-count[data-count-metric]{min-width:40px;}


.tomi-vacation-edit-palette{display:grid;gap:10px;padding:12px 14px;border-bottom:1px solid var(--line,#d1d5db);background:var(--card,#fff);position:sticky;top:52px;z-index:4}
.tomi-vacation-edit-palette-group{display:grid;gap:6px}
.tomi-vacation-edit-palette-title{font-size:12px;font-weight:700;color:var(--muted,#6b7280);text-transform:uppercase;letter-spacing:.04em}
.tomi-vacation-edit-palette-buttons{display:flex;flex-wrap:wrap;gap:6px}
.tomi-vacation-edit-palette-code{min-width:38px;height:24px;padding:0 8px;font-size:12px}


.vacation-year-employee-stack{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:2px;line-height:1.15}
.vacation-year-employee-rhythm{font-size:11px;font-weight:800;color:#475569;text-transform:uppercase;letter-spacing:.04em}
.vacation-year-employee-name{font-size:12px;font-weight:700;color:inherit}
.vacation-year-employee-label--shiftleader{padding-top:6px !important;padding-bottom:6px !important;vertical-align:middle}
.vacation-year-shiftleader-row > th,
.vacation-year-shiftleader-row > td{border:1px solid var(--line,#d1d5db) !important}
.vacation-year-shiftleader-row > th:first-child{border-left:3px solid #111 !important}
.vacation-year-shiftleader-row > td:last-child{border-right:3px solid #111 !important}
.vacation-year-shiftleader-row--group-head > th,
.vacation-year-shiftleader-row--group-head > td{border-top:3px solid #111 !important}
.vacation-year-shiftleader-row--group-last > th,
.vacation-year-shiftleader-row--group-last > td{border-bottom:3px solid #111 !important}
.vacation-year-shiftleader-shift-cell{font-weight:800;background:#f8fafc !important;text-transform:uppercase;letter-spacing:.04em}
.vacation-year-shiftleader-rhythm-title-cell{font-weight:800;background:#eef6ff !important;text-align:center !important}
.vacation-year-shiftleader-rhythm-day-cell{background:#f8fafc !important;color:#334155 !important;font-weight:700;text-align:center}
.vacation-year-shiftleader-name-cell{background:#fff !important;font-weight:700}



/* Keep vacation year planning header aligned like the other pages */
.vacation-year-page{
  min-height:100vh;
  padding:18px;
}
.vacation-year-page > .page-header{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin:0 0 14px;
  position:relative;
  inset:auto;
  width:100%;
}
.vacation-year-page > .page-header > div:first-child{
  margin:0;
}
.vacation-year-page > .page-header .toolbar{
  margin-left:auto;
}
.vacation-year-page .vacation-year-layout{
  margin-top:0;
}


.vacation-status-stack{
  display:inline-flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
  vertical-align:middle;
}

.status-pill--subtle{
  min-width:auto;
  justify-content:flex-start;
  padding:5px 9px;
  font-size:11px;
  line-height:1.2;
}

.status-pill--feedback-sent{
  background:#dbeafe;
  color:#1d4ed8;
}

.status-pill--feedback-received{
  background:#ede9fe;
  color:#6d28d9;
}

.status-pill--feedback-waiting{
  background:#ffedd5;
  color:#c2410c;
}


/* Anwesenheitsliste */
.attendance-page{
  --attendance-header-height:0px;
  --attendance-header-left:18px;
  --attendance-header-width:calc(100% - 36px);
  min-height:100vh;
  padding:18px;
  padding-top:calc(var(--attendance-header-height) + 18px);
}
.attendance-page > .page-header{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin:0;
  padding:18px 0 14px;
  position:fixed;
  top:0;
  left:var(--attendance-header-left);
  width:var(--attendance-header-width);
  z-index:200;
  background:var(--bg);
  border-bottom:1px solid var(--line);
}
.attendance-page > .page-header > div:first-child{
  margin:0;
  min-width:0;
}
.attendance-page > .page-header .toolbar{
  margin-left:auto;
}
.attendance-print-card{padding:16px}
.attendance-print-sheet{background:#fff;color:#111;max-width:1120px;margin:0 auto}
.attendance-sheet-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}
.attendance-sheet-header h3{margin:8px 0 6px 0;font-size:24px}
.attendance-sheet-header p{margin:0;color:#475569}
.attendance-sheet-meta{display:flex;flex-direction:column;gap:6px;text-align:right;color:#475569;font-size:12px}
.attendance-sections{display:flex;flex-direction:column;gap:14px}
.attendance-section{break-inside:avoid;page-break-inside:avoid;border:1px solid #d7dee9;border-radius:14px;overflow:hidden}
.attendance-section__title{padding:10px 12px;background:#f8fafc;font-weight:700;border-bottom:1px solid #d7dee9}
.attendance-table{width:100%;border-collapse:collapse;table-layout:fixed}
.attendance-table th,.attendance-table td{border:1px solid #d7dee9;padding:6px 8px;font-size:12px;line-height:1.2;text-align:center;vertical-align:middle}
.attendance-table th{background:#f8fafc}
.attendance-col-category{width:82px;font-weight:700;background:#f8fafc}
.attendance-col-category--spacer{background:#fff}
.attendance-col-slot{width:46px;font-weight:600}
.attendance-day-head span{display:block;font-size:11px;color:#64748b;font-weight:500;margin-top:2px}
.attendance-category-row td{background:#f8fafc;font-weight:700}
.attendance-category-row .attendance-col-slot{background:#f8fafc}
.attendance-shift-number-cell{font-weight:700;color:#1e293b}
.attendance-shift-number-cell--empty{color:transparent}
.attendance-day-cell.is-filled{font-weight:700}
.attendance-day-cell.is-missing{background:rgb(255, 255, 0) !important}
.attendance-table--matrix .attendance-day-cell{height:28px}
@media print{
  @page{size:A4 landscape;margin:10mm}
  body{background:#fff !important}
  .no-print,.attendance-page > :not(.attendance-print-card), .header-icon-btn, .burger-menu-wrap{display:none !important}
  .attendance-page{padding:0 !important;padding-top:0 !important;margin:0 !important;background:#fff !important}
  .attendance-page > .page-header{
    position:static !important;
    left:auto !important;
    width:100% !important;
    margin:0 0 12px !important;
    padding:0 0 12px !important;
    border-bottom:none !important;
    background:#fff !important;
  }
  .attendance-print-card{box-shadow:none !important;border:none !important;padding:0 !important;margin:0 !important}
  .attendance-print-sheet{max-width:none !important}
  .attendance-table th,.attendance-table td{font-size:10px;padding:4px 6px}
  .attendance-col-category{width:70px}
  .attendance-col-slot{width:38px}
  .attendance-table--matrix .attendance-day-cell{height:22px}
}


/* =========================
   ANWESENHEIT GELB (EXCEL STYLE)
========================= */
.warn-yellow {
  background-color: rgb(255, 255, 0) !important;
}

/* =========================
   PRINT FIX (FARBEN ERHALTEN)
========================= */
@media print {

  .warn-yellow {
    background-color: rgb(255, 255, 0) !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  html, body, * {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }
}


.btn-compact{
  padding:7px 10px;
  min-height:36px;
}

.select--compact{
  min-height:36px;
  padding:7px 10px;
  font-size:13px;
}

.shiftplan-map-month-select{
  min-width:110px;
}

.shiftplan-map-edit-btn,
.vacation-year-map-edit-btn{
  min-width:38px;
  padding-inline:10px;
  font-size:16px;
  line-height:1;
}

.shiftplan-mobile-tools{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  margin:0 0 10px;
}
.shiftplan-mobile-tools__label{
  font-weight:700;
  color:var(--muted);
}
.shiftplan-mobile-tools__hint{
  font-size:12px;
  color:var(--muted);
}
.table-wrap--shiftplan{
  overflow:auto;
  -webkit-overflow-scrolling:touch;
  touch-action:pan-x pan-y;
}
.table-wrap--shiftplan .sheet--shift{
  zoom:var(--shiftplan-zoom, 1);
}
@supports not (zoom: 1){
  .table-wrap--shiftplan .sheet--shift{
    transform:scale(var(--shiftplan-zoom, 1));
    transform-origin:top left;
  }
}

@media (max-width: 768px){
  .page{
    padding:12px;
  }
  .page-header{
    align-items:flex-start;
    gap:10px;
  }
  .page-header h2{
    font-size:24px;
  }
  .page-header p{
    font-size:13px;
    margin-top:4px;
  }
  .toolbar{
    width:100%;
    gap:8px;
    align-items:stretch;
  }
  .toolbar > *{
    flex:0 0 auto;
  }
  .toolbar .select,
  .toolbar .btn,
  .toolbar label.btn{
    padding:8px 10px;
    min-height:38px;
    font-size:13px;
  }
  .table-card{
    padding:10px;
  }
  .legend span{
    font-size:11px;
    padding:5px 8px;
  }
  .shiftplan-mobile-tools{
    gap:6px;
  }
  .shiftplan-mobile-tools__hint{
    flex:1 1 100%;
  }
}


/* Mobile UX improvement for shiftplan */
.page-header--shiftplan{
  position:static;
  top:auto;
  z-index:auto;
  background:transparent;
  padding-bottom:0;
}

@media (max-width: 900px){
  .page-header--shiftplan{
    margin:0 0 10px;
    padding:0;
    box-shadow:none;
  }
  .page-header--shiftplan h2{
    font-size:24px;
  }
  .page-header--shiftplan p{
    font-size:13px;
    margin-top:4px;
  }
  .toolbar--shiftplan{
    width:100%;
    gap:6px;
    align-items:stretch;
  }
  .toolbar--shiftplan .select,
  .toolbar--shiftplan .btn,
  .toolbar--shiftplan label.btn{
    padding:8px 10px;
    min-height:38px;
  }
  .shiftplan-table-card .legend{
    gap:6px;
    margin-bottom:8px;
  }
  .shiftplan-table-card .legend span{
    font-size:11px;
    padding:5px 8px;
  }
  .shiftplan-mobile-tools{
    position:static;
    margin:0 0 8px;
    padding:0;
    gap:6px;
  }
  .shiftplan-mobile-tools__open{
    order:-1;
  }
  .shiftplan-mobile-tools__hint{
    flex:1 1 100%;
  }
  .shiftplan-mobile-tools .btn{
    min-height:38px;
    padding:8px 10px;
  }
  .table-wrap--shiftplan{
    max-height:76vh;
    overflow-x:auto;
    overflow-y:auto;
    overscroll-behavior:contain;
    -webkit-overflow-scrolling:touch;
  }
  .table-wrap--shiftplan thead{
    position:sticky;
    top:0;
    z-index:22;
  }
  .table-wrap--shiftplan thead th.sticky-top,
  .table-wrap--shiftplan thead th.sticky-top-2,
  .table-wrap--shiftplan .sticky-top,
  .table-wrap--shiftplan .sticky-top-2,
  .table-wrap--shiftplan .sticky-top-3{
    position:sticky;
    z-index:22;
    box-shadow:0 1px 0 rgba(209,213,219,.95);
  }
  .table-wrap--shiftplan thead th.sticky-top{
    top:0;
    background:var(--head);
  }
  .table-wrap--shiftplan thead th.sticky-top-2{
    top:34px;
    background:var(--subhead);
  }
  .table-wrap--shiftplan .sticky-top.sticky-col-1,
  .table-wrap--shiftplan .sticky-top.sticky-col-2,
  .table-wrap--shiftplan .sticky-top.sticky-col-3,
  .table-wrap--shiftplan .sticky-top-2.sticky-col-1,
  .table-wrap--shiftplan .sticky-top-2.sticky-col-2,
  .table-wrap--shiftplan .sticky-top-2.sticky-col-3,
  .table-wrap--shiftplan .sticky-top-3.sticky-col-1,
  .table-wrap--shiftplan .sticky-top-3.sticky-col-2,
  .table-wrap--shiftplan .sticky-top-3.sticky-col-3{
    z-index:24;
  }
  .sheet--shift{
    transform-origin:top left;
  }
}

@media (max-width: 520px){
  .page-header--shiftplan .badge{
    padding:6px 10px;
    font-size:12px;
  }
  .page-header--shiftplan h2{
    font-size:22px;
  }
  .page-header--shiftplan p{
    display:none;
  }
  .toolbar--shiftplan{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .toolbar--shiftplan > *{
    min-width:0;
  }
  .toolbar--shiftplan .burger-menu-wrap{
    grid-column:1 / -1;
  }
  .toolbar--shiftplan .burger-toggle{
    width:100%;
  }
  .shiftplan-mobile-tools{
    gap:5px;
  }
  .shiftplan-mobile-tools .btn{
    min-height:36px;
  }
}


.table-wrap--shiftplan{
  --shift-sticky-1-width:52px;
  --shift-sticky-2-width:58px;
  --shift-sticky-3-width:72px;
}

.table-wrap--shiftplan.is-mobile-sticky-auto .sheet--shift .sticky-col-1.col-schicht,
.table-wrap--shiftplan.is-mobile-sticky-auto .sheet--shift .title-cell.sticky-col-1,
.table-wrap--shiftplan.is-mobile-sticky-auto .sheet--shift .head2.sticky-col-1{
  width:var(--shift-sticky-1-width) !important;
  min-width:var(--shift-sticky-1-width) !important;
  max-width:var(--shift-sticky-1-width) !important;
}
.table-wrap--shiftplan.is-mobile-sticky-auto .sheet--shift .sticky-col-2,
.table-wrap--shiftplan.is-mobile-sticky-auto .sheet--shift .title-cell.sticky-col-2,
.table-wrap--shiftplan.is-mobile-sticky-auto .sheet--shift .head2.sticky-col-2{
  left:var(--shift-sticky-1-width) !important;
  width:var(--shift-sticky-2-width) !important;
  min-width:var(--shift-sticky-2-width) !important;
  max-width:var(--shift-sticky-2-width) !important;
}
.table-wrap--shiftplan.is-mobile-sticky-auto .sheet--shift .sticky-col-3,
.table-wrap--shiftplan.is-mobile-sticky-auto .sheet--shift .title-cell.sticky-col-3,
.table-wrap--shiftplan.is-mobile-sticky-auto .sheet--shift .head2.sticky-col-3{
  left:calc(var(--shift-sticky-1-width) + var(--shift-sticky-2-width)) !important;
  width:var(--shift-sticky-3-width) !important;
  min-width:var(--shift-sticky-3-width) !important;
  max-width:var(--shift-sticky-3-width) !important;
}


.shiftplan-map-shell{
  position:relative;
}

body.is-shiftplan-mobile-like .table-wrap--shiftplan{
  max-height:76vh;
  overflow-x:auto;
  overflow-y:auto;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
}
body.is-shiftplan-mobile-like.is-shiftplan-map-open{
  overflow:hidden;
  overscroll-behavior:none;
}
body.is-shiftplan-mobile-like.is-shiftplan-map-open .page-header--shiftplan,
body.is-shiftplan-mobile-like.is-shiftplan-map-open .toolbar--shiftplan,
body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-table-card > .legend,
body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-table-card > .excel-toolbar,
body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-table-card > .admin-note,
body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-table-card > #shiftplanContextMenu,
body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-table-card > .shiftplan-mobile-tools{
  display:none !important;
}
body.is-shiftplan-mobile-like .shiftplan-table-card.is-map-open{
  position:fixed;
  inset:0;
  z-index:2200;
  margin:0;
  border-radius:0;
  padding:0;
  background:#fff;
  display:flex;
  flex-direction:column;
  max-width:none;
  width:100vw;
  height:100dvh;
}
body.is-shiftplan-mobile-like .shiftplan-map-shell.is-open{
  display:flex;
  flex-direction:column;
  min-height:100dvh;
  height:100dvh;
}
body.is-shiftplan-mobile-like .shiftplan-map-shell.is-open .shiftplan-map-controls{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  border-bottom:1px solid var(--line,#d1d5db);
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(8px);
}
body.is-shiftplan-mobile-like .shiftplan-map-shell.is-open > .table-wrap--shiftplan{
  flex:1 1 auto;
  max-height:none;
  height:auto;
  padding:10px 10px 24px;
}

.shiftplan-map-controls{
  display:none;
}

.shiftplan-map-editbar{
  display:none;
}
body.is-shiftplan-map-open .shiftplan-map-editbar,
body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-map-editbar,
.shiftplan-map-shell.is-open .shiftplan-map-editbar{
  display:flex;
  gap:8px;
  align-items:center;
  padding:8px 10px;
  border-bottom:1px solid var(--line,#d1d5db);
  background:rgba(255,255,255,.96);
}
.shiftplan-map-editbar .formula-input--map{
  flex:1 1 auto;
  min-width:0;
}
.shiftplan-map-editbar .btn{
  flex:0 0 auto;
}
@media (max-width: 560px){
  .shiftplan-map-editbar{
    padding:8px;
    gap:6px;
    flex-wrap:wrap;
  }
  .shiftplan-map-editbar .formula-input--map{
    width:100%;
  }
}

@media (max-width: 900px), screen and (orientation: landscape){
  body.is-shiftplan-map-open,
  body.is-shiftplan-mobile-like.is-shiftplan-map-open{
    overflow:hidden;
    overscroll-behavior:none;
  }
  body.is-shiftplan-map-open .page-header--shiftplan,
  body.is-shiftplan-mobile-like.is-shiftplan-map-open .page-header--shiftplan,
  body.is-shiftplan-map-open .toolbar--shiftplan,
  body.is-shiftplan-mobile-like.is-shiftplan-map-open .toolbar--shiftplan,
  body.is-shiftplan-map-open .shiftplan-table-card > .legend,
  body.is-shiftplan-map-open .shiftplan-table-card > .excel-toolbar,
  body.is-shiftplan-map-open .shiftplan-table-card > .admin-note,
  body.is-shiftplan-map-open .shiftplan-table-card > #shiftplanContextMenu,
  body.is-shiftplan-map-open .shiftplan-table-card > .shiftplan-mobile-tools{
    display:none !important;
  }
  .shiftplan-table-card.is-map-open > .legend,
  .shiftplan-table-card.is-map-open > .excel-toolbar,
  .shiftplan-table-card.is-map-open > .admin-note,
  .shiftplan-table-card.is-map-open > #shiftplanContextMenu,
  .shiftplan-table-card.is-map-open > .shiftplan-mobile-tools{
    display:none !important;
  }
  body.is-shiftplan-map-open .shiftplan-table-card,
  body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-table-card,
  .shiftplan-table-card.is-map-open{
    position:fixed;
    inset:0;
    z-index:2200;
    margin:0;
    border-radius:0;
    padding:0;
    background:#fff;
    display:flex;
    flex-direction:column;
    max-width:none;
    width:100vw;
    height:100dvh;
  }
  body.is-shiftplan-map-open .shiftplan-map-shell,
  body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-map-shell,
  .shiftplan-map-shell.is-open{
    display:flex;
    flex-direction:column;
    min-height:100dvh;
    height:100dvh;
  }
  body.is-shiftplan-map-open .shiftplan-map-controls,
  body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-map-controls,
  .shiftplan-map-shell.is-open .shiftplan-map-controls{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    padding:10px 12px;
    border-bottom:1px solid var(--line,#d1d5db);
    background:rgba(255,255,255,.96);
    backdrop-filter:blur(8px);
  }
  body.is-shiftplan-map-open .shiftplan-map-controls__left,
  body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-map-controls__left,
  .shiftplan-map-shell.is-open .shiftplan-map-controls__left{
    display:flex;
    flex-direction:column;
    gap:2px;
    min-width:0;
  }
  body.is-shiftplan-map-open .shiftplan-map-controls__left strong,
  body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-map-controls__left strong,
  .shiftplan-map-shell.is-open .shiftplan-map-controls__left strong{
    font-size:15px;
    line-height:1.1;
  }
  body.is-shiftplan-map-open .shiftplan-map-controls__left span,
  body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-map-controls__left span,
  .shiftplan-map-shell.is-open .shiftplan-map-controls__left span{
    font-size:12px;
    color:var(--muted);
  }
  body.is-shiftplan-map-open .shiftplan-map-controls__right,
  body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-map-controls__right,
  .shiftplan-map-shell.is-open .shiftplan-map-controls__right{
    display:flex;
    align-items:center;
    gap:6px;
    flex-wrap:wrap;
    justify-content:flex-end;
  }
  body.is-shiftplan-map-open .shiftplan-map-controls .btn,
  body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-map-controls .btn,
  .shiftplan-map-shell.is-open .shiftplan-map-controls .btn{
    min-height:38px;
  }
  body.is-shiftplan-map-open .shiftplan-map-shell > .table-wrap--shiftplan,
  body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-map-shell > .table-wrap--shiftplan,
  .shiftplan-map-shell.is-open > .table-wrap--shiftplan{
    flex:1 1 auto;
    max-height:none;
    height:auto;
    padding:10px 10px 24px;
  }
}

@media (max-width: 560px){
  body.is-shiftplan-map-open .shiftplan-map-controls,
  body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-map-controls,
  .shiftplan-map-shell.is-open .shiftplan-map-controls{
    padding:8px;
    align-items:flex-start;
  }
  body.is-shiftplan-map-open .shiftplan-map-controls__right,
  body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-map-controls__right,
  .shiftplan-map-shell.is-open .shiftplan-map-controls__right{
    gap:4px;
  }
  body.is-shiftplan-map-open .shiftplan-map-controls .btn,
  body.is-shiftplan-mobile-like.is-shiftplan-map-open .shiftplan-map-controls .btn,
  .shiftplan-map-shell.is-open .shiftplan-map-controls .btn{
    min-height:34px;
    padding:7px 9px;
  }
}

/* Mobile page zoom disabled, table keeps custom zoom */
html, body{
  touch-action:pan-x pan-y;
}
body.is-shiftplan-map-open .table-wrap--shiftplan{
  touch-action:pan-x pan-y;
}




/* Vacation year mobile map view */
.vacation-year-mobile-tools{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:0 0 10px;}
.vacation-year-mobile-tools__label{font-weight:700;color:var(--muted);}
.vacation-year-mobile-tools__hint{font-size:12px;color:var(--muted);}
.vacation-year-table-wrap--zoom{overflow:auto;-webkit-overflow-scrolling:touch;touch-action:pan-x pan-y;}
.vacation-year-table-wrap--zoom .vacation-year-sheet{zoom:var(--vacation-year-zoom, 1);}
@supports not (zoom: 1){.vacation-year-table-wrap--zoom .vacation-year-sheet{transform:scale(var(--vacation-year-zoom, 1));transform-origin:top left;}}
.vacation-year-map-shell{position:relative;}
.vacation-year-map-controls,.vacation-year-map-editbar{display:none;}
body.is-vacation-year-map-open .vacation-year-table-wrap--zoom{touch-action:pan-x pan-y;}
@media (max-width: 900px), screen and (orientation: landscape){
  .vacation-year-mobile-tools{gap:6px;}
  .vacation-year-mobile-tools__hint{flex:1 1 100%;}
  .vacation-year-mobile-tools .btn{min-height:38px;padding:8px 10px;}
  body.is-vacation-year-map-open{overflow:hidden;overscroll-behavior:none;}
  body.is-vacation-year-map-open .vacation-year-page > .page-header,
  body.is-vacation-year-map-open .vacation-year-side-card,
  body.is-vacation-year-map-open .vacation-year-main-card > .excel-toolbar,
  body.is-vacation-year-map-open .vacation-year-main-card > .vacation-year-archived-note,
  body.is-vacation-year-map-open .vacation-year-main-card > .vacation-year-mobile-tools{display:none !important;}
  body.is-vacation-year-map-open .vacation-year-layout{display:block;}
  body.is-vacation-year-map-open .vacation-year-main-card,.vacation-year-main-card.is-map-open{position:fixed;inset:0;z-index:2200;margin:0;border-radius:0;padding:0;background:#fff;display:flex;flex-direction:column;max-width:none;width:100vw;height:100dvh;}
  body.is-vacation-year-map-open .vacation-year-map-shell,.vacation-year-map-shell.is-open{display:flex;flex-direction:column;min-height:100dvh;height:100dvh;min-height:0;}
  body.is-vacation-year-map-open .vacation-year-map-controls,.vacation-year-map-shell.is-open .vacation-year-map-controls{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-bottom:1px solid var(--line,#d1d5db);background:rgba(255,255,255,.96);backdrop-filter:blur(8px);flex:0 0 auto;}
  .vacation-year-map-controls__left{display:flex;flex-direction:column;gap:2px;min-width:0;}
  .vacation-year-map-controls__left strong{font-size:15px;line-height:1.1;}
  .vacation-year-map-controls__left span{font-size:12px;color:var(--muted);}
  .vacation-year-map-controls__right{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-end;}
  .vacation-year-map-controls .btn{min-height:38px;}
  body.is-vacation-year-map-open .vacation-year-map-editbar,.vacation-year-map-shell.is-open .vacation-year-map-editbar{display:flex;gap:8px;align-items:center;padding:8px 10px;border-bottom:1px solid var(--line,#d1d5db);background:rgba(255,255,255,.96);flex-wrap:wrap;flex:0 0 auto;}
  .vacation-year-map-editbar .formula-input--map{flex:1 1 100%;min-width:0;}
  .vacation-year-map-close-inline{margin-left:auto;white-space:nowrap;}
  body.is-vacation-year-map-open .vacation-year-map-shell > .vacation-year-table-wrap--zoom,.vacation-year-map-shell.is-open > .vacation-year-table-wrap--zoom{flex:1 1 auto;min-height:0;max-height:none;height:auto;overflow:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:10px 10px 72px;}
  body.is-vacation-year-map-open .vacation-year-map-shell > .vacation-year-table-wrap--zoom .vacation-year-sheet,.vacation-year-map-shell.is-open > .vacation-year-table-wrap--zoom .vacation-year-sheet{margin-right:56px;}
}
@media (max-width: 560px){
  .vacation-year-map-controls,.vacation-year-map-shell.is-open .vacation-year-map-controls{padding:8px;align-items:flex-start;}
  .vacation-year-map-controls__right,.vacation-year-map-shell.is-open .vacation-year-map-controls__right{gap:4px;}
  .vacation-year-map-controls .btn,.vacation-year-map-shell.is-open .vacation-year-map-controls .btn{min-height:34px;padding:7px 9px;}
  .vacation-year-map-editbar{padding:8px;gap:6px;flex-wrap:wrap;}
  .vacation-year-map-editbar .formula-input--map{width:100%;}
}


/* Dashboard sauberer strukturieren */
.dashboard-wrap--clean{
  max-width:1440px;
  margin:0 auto;
}
.topbar--dashboard{
  margin-bottom:20px;
}
.dashboard-hero{
  padding:20px 22px;
  margin-bottom:20px;
  background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
}
.dashboard-hero h2{
  margin:12px 0 8px;
  font-size:24px;
}
.dashboard-hero p{
  margin:0;
  color:var(--muted);
}
.dashboard-sections{
  display:grid;
  gap:22px;
}
.dashboard-section{
  display:grid;
  gap:14px;
}
.dashboard-section__head{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.dashboard-section__head h2{
  margin:0;
  font-size:22px;
}
.dashboard-section__head p{
  margin:0;
  color:var(--muted);
}
.dashboard-grid-planung{
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
}
.dashboard-grid-kommunikation,
.dashboard-grid-konto{
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
}
.dashboard-tile{
  min-height:unset;
  gap:18px;
}
.dashboard-tile__body{
  min-width:0;
}
.dashboard-tile h3{
  margin:14px 0 0;
  font-size:23px;
}
.dashboard-tile p{
  margin:12px 0 0;
}
.dashboard-tile .btn{
  align-self:flex-start;
}
@media (max-width: 900px){
  .dashboard-wrap--clean{
    padding:18px 14px 28px;
  }
  .dashboard-hero{
    padding:18px;
  }
  .dashboard-section__head h2{
    font-size:20px;
  }
  .dashboard-tile h3{
    font-size:21px;
  }
}

/* App installieren - eingebettete SPA-Ansicht */
.install-page,
.install-page.install-page-embedded{
  max-width:980px;
  margin:0 auto;
  padding:24px 16px 56px;
}
.install-app-page-shell .topbar{
  margin-bottom:16px;
}
.install-hero{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  flex-wrap:wrap;
  margin-bottom:20px;
}
.install-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:16px;
}
.install-card{
  background:#fff;
  border:1px solid #dbe3f0;
  border-radius:16px;
  padding:20px;
  box-shadow:0 6px 18px rgba(23,43,77,.06);
}
.install-card-head{
  display:flex;
  align-items:flex-start;
  gap:12px;
  margin-bottom:12px;
}
.install-platform-icon{
  width:44px;
  height:44px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:24px;
  line-height:1;
  flex:0 0 44px;
  border:1px solid #dbe3f0;
  background:#f8fbff;
}
.install-platform-icon.android-icon{
  background:#edf8ef;
  border-color:#cdebd5;
}
.install-platform-icon.apple-icon{
  background:#f4f4f6;
  border-color:#dfdfe4;
}
.install-card h2{
  margin:0 0 10px;
}
.install-card ol{
  margin:0;
  padding-left:20px;
}
.install-card li + li{
  margin-top:10px;
}
.install-note{
  margin-top:16px;
  background:#f8fbff;
  border:1px solid #dbeafe;
  border-radius:14px;
  padding:14px 16px;
}
.install-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.install-badge{
  display:inline-block;
  background:#eef4ff;
  color:#294f9b;
  border-radius:999px;
  padding:6px 10px;
  font-size:.9rem;
  font-weight:600;
  margin-bottom:10px;
}
@media (max-width:640px){
  .install-page,
  .install-page.install-page-embedded{
    padding:16px 12px 36px;
  }
}
