﻿
:root{
  --blue:#2E75FF; --silver:#D9E2EF; --white:#FFFFFF; --bg:#0F172A;
  --card:rgba(255,255,255,0.08); --text:#E6EDF7; --muted:#A8B3C7; --danger:#E24A4A; --ok:#2ecc71;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial,sans-serif;background:linear-gradient(120deg,#0f172a,#1e293b);color:var(--text);min-height:100vh}
.watermark{position:fixed;inset:0;background:url('/logo.png') center center/1400px no-repeat;opacity:.08;pointer-events:none;z-index:0}
.page{max-width:1600px;margin:0 auto;padding:16px;position:relative;z-index:1}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-radius:16px;background:var(--card);backdrop-filter:blur(8px);box-shadow:0 10px 30px rgba(0,0,0,.3)}
.brand{display:flex;align-items:center;gap:8px;font-weight:800;letter-spacing:.3px}
.version-badge{font-weight:500;font-size:.75rem;opacity:.55;cursor:pointer;margin-left:6px;padding:2px 6px;border-radius:6px;transition:opacity .2s,background .2s}
.version-badge:hover{opacity:.9;background:rgba(255,255,255,.08)}
.logo-small{height:24px;width:auto;display:inline-block;opacity:.9}
.logo-top{height:22px;width:auto;vertical-align:middle;margin-right:8px;opacity:.95}
.tabs{display:flex;gap:8px;flex-wrap:wrap}
.tabs button{background:transparent;border:1px solid transparent;color:var(--text);padding:8px 12px;border-radius:999px;cursor:pointer;transition:all .25s cubic-bezier(0.4, 0, 0.2, 1);position:relative}
.tabs button::after{content:'';position:absolute;bottom:0;left:50%;width:0;height:2px;background:var(--blue);transform:translateX(-50%);transition:width .3s ease}
.tabs button.active::after,.tabs button:hover::after{width:80%}
.tabs button.active,.tabs button:hover{border-color:var(--silver);background:rgba(255,255,255,0.06);transform:translateY(-1px)}
.tabs button:active{transform:translateY(0)}
.user{display:flex;align-items:center;gap:12px}
.user .divider{width:1px;height:24px;background:rgba(255,255,255,.2)}
.userbox{display:flex;align-items:center;gap:8px}
.avatar{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--blue);color:white;font-weight:700;overflow:hidden}
.avatar.small{width:22px;height:22px}
.avatar.tiny{width:18px;height:18px;vertical-align:-2px;margin-right:4px}
.avatar img{width:100%;height:100%;object-fit:cover;display:block;border-radius:50%}

.content{margin-top:16px;display:grid;gap:16px}
.card{background:var(--card);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:16px;box-shadow:0 6px 20px rgba(0,0,0,.25);animation:cardFadeIn .4s ease-out;transition:transform .2s,box-shadow .2s;transform:translateZ(0)}
.card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.card h2{margin-top:0}
@keyframes cardFadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.grid-2{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:900px){.grid-2{grid-template-columns:1fr 1fr}}
.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;align-items:end}
.roomy-grid{gap:14px}
.stack{display:flex;flex-direction:column;gap:6px}
.table{width:100%;border-collapse:separate;border-spacing:0 10px;table-layout:auto}
.table th{font-weight:600;text-align:left;color:var(--muted);font-size:.9rem}
.table td{background:rgba(255,255,255,.03);padding:12px;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06)}
.table input,.table select{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:var(--text);padding:12px;border-radius:10px;line-height:1.4}
.table.personnel td{padding:16px 14px}
.roomy-table input,.roomy-table select{padding:12px}
.row-with-avatar{display:flex;align-items:center;gap:10px}
.actions-col{white-space:nowrap;display:flex;gap:6px}
.title-row{display:flex;align-items:center;gap:8px}

/* Personnel wider columns */
.wide-personnel td:nth-child(1){min-width:260px}
.wide-personnel td:nth-child(2){min-width:160px}
.wide-personnel td:nth-child(3){min-width:240px}
.wide-personnel td:nth-child(4){min-width:160px}

/* Better contrast selects */
.select-light{background:#fff !important; color:#0f172a !important;}
.select-contrast{background:#fff !important; color:#0f172a !important; border-color:#cfd6e4 !important;}
.table.personnel select option{color:#0f172a}

/* Buttons & pills */
.btn{background:var(--blue);border:none;color:white;padding:8px 12px;border-radius:10px;cursor:pointer;transition:all .2s cubic-bezier(0.4, 0, 0.2, 1);position:relative;overflow:hidden;transform:translateZ(0)}
.btn::before{content:'';position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(255,255,255,.2);transform:translate(-50%,-50%);transition:width .4s,height .4s}
.btn:active::before{width:300px;height:300px}
.btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(46,117,255,.4)}
.btn:active{transform:translateY(0);box-shadow:0 2px 6px rgba(46,117,255,.3)}
.btn:disabled,.btn[disabled]{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}
.btn:disabled::before,.btn[disabled]::before{display:none}
.btn.ghost{background:transparent;border:1px solid rgba(255,255,255,.2);color:var(--text)}
.btn.ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.3);transform:translateY(-1px)}
.btn:disabled:hover,.btn[disabled]:hover,.btn.ghost:disabled:hover,.btn.ghost[disabled]:hover{transform:none;box-shadow:none}
.btn.small{padding:6px 10px;font-size:.9rem}
.btn.danger{background:var(--danger)}
.btn.danger:hover{box-shadow:0 4px 12px rgba(226,74,74,.4)}

/* Spezieller Button "Mich zuteilen" (lila) */
.btn.me-assign{
  background:rgba(109,40,217,.75);
  border:1px solid rgba(196,181,253,.9);
  color:#f9f5ff;
}
.btn.me-assign:hover{
  background:rgba(124,58,237,.9);
}

.pill{display:inline-block;padding:4px 8px;border-radius:999px;background:rgba(255,255,255,.08);margin:2px 4px 2px 0;transition:all .2s ease;cursor:default}
.pill.ok{background:rgba(46,204,113,.2)}
.pill.no{background:rgba(226,74,74,.2)}
.pill.expired{background:rgba(226,74,74,.25);border:1px solid rgba(226,74,74,.35)}
.pill.draggable{cursor:grab;user-select:none}
.pill.draggable:hover{transform:scale(1.05);box-shadow:0 2px 8px rgba(0,0,0,.2)}
.pill.dragging{opacity:.5;transform:scale(0.95);z-index:1000;pointer-events:none}

/* Choice state */
.btn.choice.ok.active{background:var(--ok) !important;color:#fff}
.btn.choice.no.active{background:var(--danger) !important;color:#fff}

/* Expired marker */
.expired{opacity:.85}

/* Lists */
.list{list-style:none;padding:0;margin:0}
.list li{display:flex;justify-content:space-between;align-items:center;padding:10px;border-bottom:1px dashed rgba(255,255,255,.1)}
.list .meta{color:var(--muted);font-size:.9rem}

/* Tabs */
.tab{display:none;opacity:0;transform:translateX(10px);transition:opacity .3s ease-out,transform .3s ease-out}
.tab.active{display:block;animation:tabFadeIn .3s ease-out forwards}
@keyframes tabFadeIn{from{opacity:0;transform:translateX(10px)}to{opacity:1;transform:translateX(0)}}

/* Badges */
.badge{margin-left:6px;font-size:12px}
.badge.hidden{display:none}

/* Logbox */
.logbox{white-space:pre-wrap;background:rgba(0,0,0,.25);border-radius:12px;padding:12px;max-height:60vh;overflow:auto}

/* Login card */
.login-bg{position:relative;min-height:100vh;overflow:hidden}
.login-card{position:fixed;inset:0;display:flex;flex-direction:column;gap:10px;align-items:center;justify-content:center}
.login-card form{display:flex;flex-direction:column;gap:8px;background:rgba(15,23,42,0.85);backdrop-filter:blur(6px);padding:20px;border-radius:16px;min-width:340px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.login-card h1{margin-bottom:8px}
.login-card label{font-size:.9rem;color:var(--muted)}
.login-card input[type="text"],.login-card input[type="password"]{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);padding:10px;border-radius:10px;color:var(--text)}
.login-card .remember{display:flex;align-items:center;gap:6px}
.login-card button{margin-top:6px}

/* SR-only */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Toasts */
.toast{position:fixed;right:16px;bottom:16px;background:rgba(255,255,255,.1);border-left:4px solid var(--blue);padding:12px 16px;border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.4);animation:toastSlideIn .3s cubic-bezier(0.68, -0.55, 0.265, 1.55);z-index:10000;backdrop-filter:blur(8px);transition:transform .2s,opacity .2s}
.toast.error{border-left-color:var(--danger)}
.toast.fade-out{animation:toastSlideOut .2s ease-in forwards}
.hidden{display:none}
@keyframes toastSlideIn{from{transform:translateX(120%) scale(0.8);opacity:0}to{transform:translateX(0) scale(1);opacity:1}}
@keyframes toastSlideOut{from{transform:translateX(0) scale(1);opacity:1}to{transform:translateX(120%) scale(0.8);opacity:0}}
@keyframes pop{from{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}

/* Fix: slots number input wider */
.table input[type=number]{ min-width: 80px; }
.select-contrast{ min-width: 140px; }

/* Dialog fÃ¼r Dienst-Absage & offene PlÃ¤tze */
body.modal-open{
  overflow:hidden;
}

.cancel-modal{
  background:var(--card);
  border-radius:16px;
  padding:20px;
  max-width:420px;
  width:90%;
  box-shadow:0 18px 45px rgba(0,0,0,0.55);
  border:1px solid rgba(255,255,255,0.18);
}

.cancel-modal h3{
  margin:0 0 8px;
  font-size:1.1rem;
}

.cancel-modal p{
  margin:0 0 16px;
  color:var(--muted);
  line-height:1.4;
}

.changelog-modal{background:var(--card);border-radius:16px;padding:20px;max-width:520px;width:95%;max-height:85vh;display:flex;flex-direction:column;border:1px solid rgba(255,255,255,.1)}
.changelog-modal h3{margin:0 0 12px;font-size:1.1rem}
.changelog-modal .changelog-body{overflow-y:auto;max-height:calc(85vh - 100px);padding-right:8px;font-size:.875rem;line-height:1.5}
.changelog-modal .changelog-body::-webkit-scrollbar{width:6px}
.changelog-modal .changelog-body::-webkit-scrollbar-track{background:transparent}
.changelog-modal .changelog-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:3px}
.changelog-modal .changelog-version{margin-bottom:1.25rem}
.changelog-modal .changelog-version:last-child{margin-bottom:0}
.changelog-modal .changelog-version h4{font-size:.95rem;margin:0 0 8px;color:var(--blue)}
.changelog-modal .changelog-section{margin-bottom:10px}
.changelog-modal .changelog-section-title{font-weight:600;color:var(--muted);font-size:.8rem;margin-bottom:4px}
.changelog-modal .changelog-section ul{margin:0;padding-left:1.2rem;color:var(--text)}
.changelog-modal .changelog-section li{margin-bottom:2px}
.changelog-modal .modal-actions{margin-top:12px;display:flex;justify-content:flex-end;gap:8px}
.cancel-modal .modal-actions{
  display:flex;
  justify-content:flex-end;
  gap:8px;
}

/* "Platz frei" als Badge (z.B. in Dienstverwaltung) */
.pill-empty,
.pill.empty{
  background:rgba(226,74,74,.2);
  border:1px dashed rgba(226,74,74,.8);
  color:#fecaca;
  min-width:32px;
  min-height:22px;
  display:inline-block;
  font-weight:600;
}

/* "Platz frei" als Button (z.B. in Zuteilungen) */
.btn.pill-empty,
.btn.ghost.pill-empty{
  background:rgba(226,74,74,.2);
  border:1px dashed rgba(226,74,74,.8);
  color:#fecaca;
}



/* Voll belegte Dienste in Dienstverwaltung & Zuteilungen */
.table tr.svc-full td{
  background:rgba(46,204,113,0.16);
}

/* Drag & Drop Styles */
.drag-over{background:rgba(46,117,255,.15) !important;border:2px dashed var(--blue) !important;border-radius:8px}
.drag-over::after{content:'ðŸ‘† Hier ablegen';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.2rem;opacity:.8;pointer-events:none}
.drop-zone{position:relative;min-height:40px;transition:all .2s ease}
.drop-zone.drag-over{background:rgba(46,117,255,.1);border:2px dashed var(--blue);border-radius:8px}

/* Loading Animation */
.loading{position:relative;pointer-events:none;opacity:.6}
.loading::after{content:'';position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid rgba(255,255,255,.3);border-top-color:var(--blue);border-radius:50%;animation:spin .6s linear infinite}
.btn.loading{min-width:72px;color:transparent !important}
.btn.loading>*{visibility:hidden}
.btn.loading::after{border-top-color:#fff}
.btn.ghost.loading::after{border-top-color:var(--blue)}
.table tr.is-updating{opacity:.7;pointer-events:none}
@keyframes spin{to{transform:rotate(360deg)}}

/* Smooth Scroll */
html{scroll-behavior:smooth}

/* List Item Animations */
.list li{animation:listItemFadeIn .3s ease-out;animation-fill-mode:both}
.list li:nth-child(1){animation-delay:.05s}
.list li:nth-child(2){animation-delay:.1s}
.list li:nth-child(3){animation-delay:.15s}
.list li:nth-child(4){animation-delay:.2s}
.list li:nth-child(5){animation-delay:.25s}
.list li:nth-child(n+6){animation-delay:.3s}
@keyframes listItemFadeIn{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}

/* Table Row Animations */
.table tbody tr{animation:tableRowFadeIn .4s ease-out;animation-fill-mode:both}
.table tbody tr:nth-child(1){animation-delay:.05s}
.table tbody tr:nth-child(2){animation-delay:.1s}
.table tbody tr:nth-child(3){animation-delay:.15s}
.table tbody tr:nth-child(4){animation-delay:.2s}
.table tbody tr:nth-child(5){animation-delay:.25s}
.table tbody tr:nth-child(n+6){animation-delay:.3s}
@keyframes tableRowFadeIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}

/* Avatar Hover Effect */
.avatar{transition:transform .2s ease,box-shadow .2s ease}
.avatar:hover{transform:scale(1.1);box-shadow:0 4px 12px rgba(46,117,255,.4)}

/* Input Focus Animation */
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue) !important;box-shadow:0 0 0 3px rgba(46,117,255,.2);transition:all .2s ease}

/* Modal Animations */
.award-modal{animation:modalFadeIn .3s ease-out}
@keyframes modalFadeIn{from{opacity:0;backdrop-filter:blur(0px)}to{opacity:1;backdrop-filter:blur(8px)}}
.award-modal-content{animation:modalSlideIn .3s cubic-bezier(0.68, -0.55, 0.265, 1.55)}
@keyframes modalSlideIn{from{opacity:0;transform:scale(0.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}


/* Passwortfelder mit "anzeigen"-Schalter */
.password-field{
  position:relative;
  display:flex;
  align-items:center;
}

.password-field input[type="password"],
.password-field input[type="text"]{
  flex:1;
  padding-right:42px;
}

.password-toggle{
  position:absolute;
  right:10px;
  border:none;
  background:transparent;
  cursor:pointer;
  font-size:.8rem;
  color:var(--muted);
}

.password-toggle[data-visible="true"]{
  font-weight:600;
  color:var(--text);
}

.password-toggle:focus-visible{
  outline:2px solid var(--blue);
  border-radius:999px;
}


/* Dienste-Titelzeile: Input nicht zu schmal werden lassen,
   Badge darf in die nÃ¤chste Zeile umbrechen */
.title-row{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

.title-row input{
  flex:1 1 200px;
  min-width:180px;
}

.title-row .pill{
  flex:0 0 auto;
}


/* Dienstverwaltung: Mindestbreiten fÃ¼r Datum / Zeit / PlÃ¤tze / Bemerkung,
   damit die Inhalte auch bei vielen Bewerbungen noch lesbar bleiben */
.table input[data-f="date"]{
  min-width:90px;
}

.table input[data-f="time"]{
  min-width:70px;
}

.table input[data-f="slots"]{
  max-width:72px;
}

.table input[data-f="notes"]{
  min-width:140px;
}

/* ===== Mobile Optimierungen (max-width: 768px) ===== */
@media (max-width: 768px) {
  /* Seiten-Padding reduzieren */
  .page {
    padding: 8px;
  }

  /* Topbar fÃ¼r mobile optimieren */
  .topbar {
    flex-direction: column;
    gap: 12px;
    padding: 12px;
  }

  .brand {
    font-size: 0.9rem;
    width: 100%;
    justify-content: center;
  }

  .logo-small {
    height: 20px;
  }

  /* Navigation: Scrollbar horizontal statt Wrap */
  .tabs {
    display: flex;
    gap: 6px;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    width: 100%;
    padding-bottom: 4px;
  }

  .tabs::-webkit-scrollbar {
    height: 4px;
  }

  .tabs::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.2);
    border-radius: 2px;
  }

  .tabs button {
    padding: 8px 14px;
    font-size: 0.875rem;
    white-space: nowrap;
    flex-shrink: 0;
  }

  /* User-Bereich optimieren */
  .user {
    width: 100%;
    justify-content: space-between;
    padding-top: 8px;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
  }

  .userbox span:last-child {
    font-size: 0.875rem;
  }

  /* Content-Abstand reduzieren */
  .content {
    margin-top: 12px;
    gap: 12px;
  }

  /* Cards: Padding reduzieren */
  .card {
    padding: 12px;
  }

  .card h2 {
    font-size: 1.25rem;
    margin-bottom: 12px;
  }

  /* Grid-5 fÃ¼r Dienstverwaltung: 1 Spalte auf mobile */
  .grid-5 {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .grid-5 button {
    grid-column: 1;
  }

  /* Tabellen: Card-Layout nur fÃ¼r einfache Tabellen, nicht fÃ¼r Dienstverwaltung/Zuteilungen */
  .table:not(#servicesTable):not(#assignmentsTable) {
    display: block;
    width: 100%;
  }

  .table:not(#servicesTable):not(#assignmentsTable) thead {
    display: none; /* Header auf mobile ausblenden */
  }

  .table:not(#servicesTable):not(#assignmentsTable) tbody {
    display: block;
  }

  .table:not(#servicesTable):not(#assignmentsTable) tr {
    display: block;
    background: rgba(255, 255, 255, 0.03);
    border-radius: 12px;
    padding: 12px;
    margin-bottom: 12px;
    border: 1px solid rgba(255, 255, 255, 0.08);
  }

  .table:not(#servicesTable):not(#assignmentsTable) td {
    display: block;
    padding: 8px 0;
    border: none;
    background: transparent;
    width: 100%;
  }

  .table:not(#servicesTable):not(#assignmentsTable) td:not(:last-child) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    margin-bottom: 8px;
    padding-bottom: 12px;
  }

  .table:not(#servicesTable):not(#assignmentsTable) td:before {
    content: attr(data-label);
    display: block;
    font-weight: 600;
    color: var(--muted);
    font-size: 0.8rem;
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
  }

  .table:not(#servicesTable):not(#assignmentsTable) input,
  .table:not(#servicesTable):not(#assignmentsTable) select {
    width: 100%;
    min-width: 0;
    padding: 10px;
    font-size: 0.9rem;
  }

  /* Actions-Spalte speziell behandeln */
  .table:not(#servicesTable):not(#assignmentsTable) td.actions-col:before {
    content: "Aktionen";
  }

  /* Dienstverwaltung und Zuteilungen: Original-Layout beibehalten, nur kleiner */
  #servicesTable,
  #assignmentsTable {
    display: table;
    width: 100%;
    table-layout: auto;
  }

  #servicesTable thead,
  #assignmentsTable thead {
    display: table-header-group;
  }

  #servicesTable tbody,
  #assignmentsTable tbody {
    display: table-row-group;
  }

  #servicesTable tr,
  #assignmentsTable tr {
    display: table-row;
  }

  #servicesTable td,
  #assignmentsTable td {
    display: table-cell;
    vertical-align: top;
  }

  /* Input-Felder in Dienstverwaltung kompakter */
  #servicesTable input {
    padding: 6px 4px;
    font-size: 0.8rem;
    min-width: 0;
  }

  /* Titel-Input etwas breiter lassen */
  #servicesTable .title-row input {
    min-width: 100px;
  }

  /* Datum, Zeit, PlÃ¤tze, Bemerkung sehr kompakt */
  #servicesTable input[data-f="date"],
  #servicesTable input[data-f="time"] {
    min-width: 70px;
    max-width: 85px;
  }

  #servicesTable input[data-f="slots"] {
    min-width: 45px;
    max-width: 55px;
  }

  #servicesTable input[data-f="notes"] {
    min-width: 80px;
    max-width: 120px;
  }

  /* Tabellen einfach kleiner machen - Original-Layout beibehalten */
  .table {
    font-size: 0.85rem;
  }

  .table th {
    font-size: 0.8rem;
    padding: 8px 6px;
  }

  .table td {
    padding: 8px 6px;
    font-size: 0.85rem;
  }

  .table input,
  .table select {
    padding: 8px;
    font-size: 0.85rem;
  }

  .table .btn {
    padding: 6px 10px;
    font-size: 0.8rem;
  }

  .table .pill {
    font-size: 0.7rem;
    padding: 3px 6px;
    margin: 1px 2px 1px 0;
  }

  .table .avatar.tiny {
    width: 14px;
    height: 14px;
    font-size: 0.65rem;
  }

  /* Dienstverwaltung: Exakt wie Zuteilungen - keine speziellen Regeln */
  /* Die allgemeinen .table Regeln gelten auch fÃ¼r #servicesTable */

  /* Sortier- und Filterleiste kompakter */
  .meta[style*="display:flex"] {
    font-size: 0.85rem;
    gap: 6px;
  }

  .meta[style*="display:flex"] .btn.small {
    padding: 6px 10px;
    font-size: 0.75rem;
  }

  .meta[style*="display:flex"] select {
    padding: 6px 8px;
    font-size: 0.85rem;
  }

  /* Actions-Spalte auf mobile */
  .actions-col {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
  }

  .actions-col:before {
    content: "Aktionen";
    display: block;
    width: 100%;
    font-weight: 600;
    color: var(--muted);
    font-size: 0.8rem;
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
  }

  .actions-col .btn {
    flex: 1 1 auto;
    min-width: 80px;
  }

  /* Buttons grÃ¶ÃŸer fÃ¼r Touch */
  .btn {
    padding: 12px 16px;
    font-size: 0.95rem;
    min-height: 44px; /* MindestgrÃ¶ÃŸe fÃ¼r Touch-Targets */
  }

  .btn.small {
    padding: 10px 14px;
    min-height: 40px;
  }

  /* Input-Felder grÃ¶ÃŸer fÃ¼r Touch */
  input[type="text"],
  input[type="email"],
  input[type="password"],
  input[type="number"],
  input[type="date"],
  input[type="time"],
  select,
  textarea {
    padding: 12px;
    font-size: 16px; /* Verhindert Zoom auf iOS */
    min-height: 44px;
  }

  /* Formulare optimieren */
  .stack {
    gap: 8px;
  }

  .stack label {
    font-size: 0.875rem;
  }
/* Login-Card auf mobile */
  .login-card form {
    min-width: auto;
    width: 90%;
    max-width: 400px;
    padding: 20px 16px;
  }

  /* Modals auf mobile */
  .cancel-modal {
    width: 95%;
    padding: 16px;
    max-width: none;
  }

  .modal-actions {
    flex-direction: column;
  }

  .modal-actions .btn {
    width: 100%;
  }

  /* Title-Row optimieren */
  .title-row {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }

  .title-row input {
    min-width: 0;
    width: 100%;
  }

  /* Pills kleiner auf mobile */
  .pill {
    font-size: 0.8rem;
    padding: 4px 8px;
  }

  /* Toast-Position auf mobile */
  .toast {
    right: 8px;
    left: 8px;
    bottom: 8px;
    width: auto;
  }

  /* Personnel-Tabelle: Mindestbreiten entfernen */
  .wide-personnel td:nth-child(1),
  .wide-personnel td:nth-child(2),
  .wide-personnel td:nth-child(3),
  .wide-personnel td:nth-child(4) {
    min-width: 0;
  }

  /* Row with avatar optimieren */
  .row-with-avatar {
    flex-wrap: wrap;
    gap: 8px;
  }

  /* Grid-2 bleibt 1 Spalte auf mobile (bereits so definiert) */
  /* Aber gap reduzieren */
  .grid-2 {
    gap: 12px;
  }

  /* Password-Toggle grÃ¶ÃŸer */
  .password-toggle {
    font-size: 0.9rem;
    padding: 8px;
    min-width: 60px;
  }

  /* Logbox auf mobile */
  .logbox {
    max-height: 50vh;
    padding: 10px;
    font-size: 0.85rem;
  }

  /* Simulation-Banner auf mobile */
  div[style*="position: fixed"][style*="top: 0"] {
    flex-direction: column;
    gap: 8px;
    padding: 10px 12px;
    font-size: 0.875rem;
  }

  div[style*="position: fixed"][style*="top: 0"] button {
    width: 100%;
    padding: 10px;
  }
}

/* ===== Sehr kleine Smartphones (max-width: 480px) ===== */
@media (max-width: 480px) {
  .page {
    padding: 6px;
  }

  .topbar {
    padding: 10px;
  }

  .brand {
    font-size: 0.85rem;
  }

  .tabs button {
    padding: 6px 12px;
    font-size: 0.8rem;
  }

  .card {
    padding: 10px;
  }

  .card h2 {
    font-size: 1.1rem;
  }

  .btn {
    padding: 10px 14px;
    font-size: 0.9rem;
  }

  .table td {
    padding: 6px 0;
    font-size: 0.875rem;
  }
}
