:root{
  --ink:#1d1d1f;
  --muted:#6e6e73;
  --page:#f5f5f7;
  --surface:#fff;
  --surface-soft:#eef1f4;
  --surface-blue:#e8f3fb;
  --blue:#0878bd;
  --blue-dark:#0b3a55;
  --green:#2d7651;
  --green-soft:#e4f4ea;
  --yellow:#8a6500;
  --yellow-soft:#fff3c7;
  --red:#a62a2a;
  --red-soft:#fdeaea;
  --purple-soft:#eee9fb;
  --cyan-soft:#e2f4f7;
  --shadow:0 14px 36px rgba(24,39,51,.08);
  --shadow-small:0 6px 18px rgba(24,39,51,.07);
  --radius-xl:24px;
  --radius-lg:18px;
  --radius-md:13px;
  --radius-sm:9px;
}

*{box-sizing:border-box}
html{font-size:15px}
body{
  margin:0;
  color:var(--ink);
  background:var(--page);
  font-family:-apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",sans-serif;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
}
button,input,select{font:inherit}
button,a{-webkit-tap-highlight-color:transparent}
a{color:var(--blue)}
h1,h2,h3,p{margin-top:0}
h1{margin-bottom:8px;font-size:clamp(1.55rem,3vw,2.25rem);line-height:1.05;letter-spacing:-.045em}
h2{margin-bottom:12px;font-size:1.08rem;line-height:1.2;letter-spacing:-.02em}
.eyebrow{
  display:block;
  margin-bottom:7px;
  color:var(--blue);
  font-size:.7rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.button,button{
  border:0;
  border-radius:999px;
  padding:9px 14px;
  font-weight:750;
  cursor:pointer;
}
.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
}
.primary-button{background:var(--blue);color:#fff}
.primary-button:hover{background:#0068a5}
.secondary-button{background:rgba(255,255,255,.92);color:var(--blue-dark)}
.quiet-button{background:var(--surface-soft);color:var(--ink)}
.danger-button{background:var(--red);color:#fff}
.text-button{padding:0;border:0;background:transparent;color:inherit;text-decoration:underline;text-underline-offset:3px}
label>span:first-child{
  display:block;
  margin-bottom:5px;
  color:var(--muted);
  font-size:.69rem;
  font-weight:800;
  letter-spacing:.045em;
  text-transform:uppercase;
}
input,textarea,select{
  width:100%;
  border:0;
  border-radius:11px;
  outline:0;
  background:var(--surface-soft);
  color:var(--ink);
  padding:11px 12px;
}
input:focus,textarea:focus,select:focus{box-shadow:0 0 0 3px rgba(8,120,189,.2);background:#fff}
.form-message{margin:0 0 14px;padding:13px 15px;border-radius:var(--radius-md);font-size:.88rem}
.form-message ul{margin:7px 0 0;padding-left:20px}
.success-message{background:var(--green-soft);color:#205e3f}
.error-message{background:var(--red-soft);color:#8f2424}
.empty-state{padding:28px;border-radius:var(--radius-md);background:var(--surface-soft);color:var(--muted);text-align:center}
.fatal-error{margin:10px;padding:12px;border-radius:12px;background:var(--red-soft);color:var(--red);font-weight:750}

/* Bearbeitungsansicht */
.page{width:min(100%,1580px);margin:0 auto;padding:14px}
.app-header{
  padding:19px;
  border-radius:var(--radius-xl);
  background:linear-gradient(135deg,#0b3a55,#12688f);
  color:#fff;
  box-shadow:var(--shadow);
}
.app-header .eyebrow{color:#9dd8f4}
.app-header h1{margin:0;color:#fff;font-size:1.55rem}
.header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:20px}
.main-actions{display:flex;align-items:center;justify-content:flex-end;gap:7px;flex-wrap:wrap}
.main-actions form{margin:0}
.main-actions .quiet-button{background:rgba(255,255,255,.18);color:#fff}
.editor-badge{padding:8px 11px;border-radius:999px;background:rgba(255,255,255,.12);font-size:.72rem;font-weight:700}
.header-dashboard{display:grid;grid-template-columns:minmax(250px,1fr) minmax(0,4fr);gap:10px;margin-top:15px}
.metrics-panel,.people-panel{min-width:0;padding:12px;border-radius:var(--radius-lg);background:rgba(255,255,255,.1)}
.panel-title{color:rgba(255,255,255,.7);font-size:.67rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}
.dashboard{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-top:8px}
.kpi{padding:9px 10px;border-radius:12px;background:rgba(255,255,255,.12)}
.kpi strong{display:block;margin-bottom:2px;color:rgba(255,255,255,.68);font-size:.62rem;text-transform:uppercase}
.kpi span{font-size:1rem;font-weight:850}
.kpi.load-red{background:#fbdede;color:#7d2020}
.kpi.load-orange{background:#fee7cc;color:#7a4300}
.kpi.load-yellow{background:#fff0b5;color:#6e5200}
.kpi.load-green{background:#dff1e5;color:#215e40}
.kpi.load-red strong,.kpi.load-orange strong,.kpi.load-yellow strong,.kpi.load-green strong{color:inherit;opacity:.72}
.people-panel-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.helpers-stat{padding:4px 8px;border-radius:999px;background:rgba(255,255,255,.14);font-size:.68rem}
.helpers-stat span{font-weight:850}
.person-list{display:flex;align-items:flex-start;gap:9px;flex-wrap:wrap;margin-top:8px}
.person-group{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.person-group+.person-group{padding-left:9px;border-left:1px solid rgba(255,255,255,.24)}
.person-group-label{color:rgba(255,255,255,.66);font-size:.61rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.person-group-items{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.person-pagination{display:flex;align-items:center;gap:4px;color:rgba(255,255,255,.7);font-size:.65rem}
.person-page-button{width:22px;height:22px;padding:0;border-radius:50%;background:rgba(255,255,255,.15);color:#fff}
.person-page-button:disabled{opacity:.35;cursor:default}
.person-row{
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding:6px 8px;
  border-radius:999px;
  background:#fff;
  color:var(--ink);
  font-size:.69rem;
}
.person-row strong{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.person-count{padding:1px 5px;border-radius:999px;background:var(--surface-blue);color:var(--blue-dark);font-weight:850}
.person-info-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:18px;
  height:18px;
  padding:0;
  border-radius:50%;
  background:#dbe8ef;
  color:var(--blue-dark);
  font-family:Georgia,serif;
  font-size:.72rem;
  font-weight:800;
  font-style:italic;
}
.person-row.waiting-helper{background:#fff3c7}
.person-row.manual-waiting-helper{background:#edf0f3}
.person-row.active-highlight,.name-chip.person-highlight{
  background:var(--highlight-color);
  color:#fff;
  box-shadow:0 0 0 2px rgba(255,255,255,.8),0 3px 10px rgba(11,58,85,.28);
}
.person-row.active-highlight .person-count,.person-row.active-highlight .person-info-btn,.name-chip.person-highlight .person-info-btn{background:rgba(255,255,255,.9);color:var(--blue-dark)}
.name-chip.person-highlight>span{color:#fff;font-weight:800}
.conflict-box{display:none;align-items:center;justify-content:space-between;gap:10px;margin-top:12px;padding:10px 12px;border-radius:12px;background:var(--red-soft);color:#7f1d1d;font-weight:750}
.conflict-box.show{display:flex}
.conflict-box button{background:var(--red);color:#fff}

/* Schichtplantabelle */
.table-panel{margin-top:12px;border-radius:var(--radius-xl);overflow:hidden;background:var(--surface);box-shadow:var(--shadow)}
.table-wrap{overflow:auto;padding:6px;-webkit-overflow-scrolling:touch}
.schedule-table{
  width:100%;
  min-width:1280px;
  border-collapse:separate;
  border-spacing:5px;
  table-layout:fixed;
  background:#fff;
  font-size:.78rem;
}
.schedule-table th,.schedule-table td{min-width:160px;padding:0;vertical-align:top}
.schedule-table thead th{
  position:sticky;
  top:0;
  z-index:3;
  height:52px;
  padding:9px 10px;
  border-radius:12px;
  color:var(--blue-dark);
  text-align:left;
}
.role-column{
  position:sticky;
  left:0;
  z-index:5;
  width:238px;
  min-width:238px;
  max-width:238px;
  border-radius:12px;
  background:#edf2f5;
  box-shadow:5px 0 12px rgba(29,29,31,.05);
  color:var(--blue-dark);
}
.schedule-table thead .role-column{z-index:8;padding:12px}
.schedule-table tbody .role-column{padding:9px}
.phase-setup{background:var(--purple-soft)}
.phase-critical{background:var(--yellow-soft)}
.phase-cleanup{background:var(--cyan-soft)}
.phase-normal{background:#edf2f5}
.shift-time{display:block;color:#566b78;font-size:.66rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.shift-topic{display:block;margin-top:2px;color:var(--blue-dark);font-size:.86rem;font-weight:850}
.role-cell-layout{display:flex;flex-direction:column;gap:8px;min-width:0}
.role-title{
  display:block;
  width:100%;
  font-size:.84rem;
  font-weight:850;
  line-height:1.3;
  word-break:normal;
  overflow-wrap:normal;
  -webkit-hyphens:auto;
  hyphens:auto;
}
.role-meta-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.required-badge{flex:0 0 auto;padding:4px 8px;border-radius:999px;background:var(--blue-dark);color:#fff;font-size:.69rem;font-weight:800}
.role-tools{display:flex;align-items:center;gap:4px;padding:4px;border-radius:10px;background:#dde5ea}
.icon-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
  min-width:28px;
  padding:0;
  border-radius:8px;
  background:#fff;
  color:var(--blue-dark);
  font-size:.75rem;
}
.role-tools .icon-button{width:24px;height:24px;min-width:24px;border-radius:7px}
.cell-box{min-height:86px;padding:7px;border-radius:13px;background:rgba(255,255,255,.52)}
.cell-head{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:7px}
.cell-actions{display:flex;align-items:center;gap:4px}
.capacity{display:inline-flex;padding:3px 7px;border-radius:999px;font-size:.68rem;font-weight:850;white-space:nowrap}
.capacity.empty{background:var(--red-soft);color:var(--red)}
.capacity.partial{background:var(--yellow-soft);color:var(--yellow)}
.capacity.full{background:var(--green-soft);color:var(--green)}
.capacity.over{background:var(--surface-blue);color:var(--blue-dark)}
.capacity.inactive{background:#d5d7da;color:#666}
.add-btn,.slot-toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:22px;
  height:22px;
  min-width:22px;
  padding:0;
  border-radius:50%;
}
.add-btn{background:var(--blue);color:#fff;font-size:1rem}
.slot-toggle{background:#e1e3e6;color:#73767a;font-size:.86rem}
.slot-toggle:hover{background:#cfd2d5;color:#444}
.name-list{display:flex;flex-direction:column;gap:4px}
.name-chip{display:flex;align-items:center;justify-content:space-between;gap:5px;padding:5px 6px;border-radius:8px;background:#fff}
.name-chip>span{min-width:0;overflow-wrap:anywhere;font-size:.73rem}
.name-chip-actions{display:flex;align-items:center;gap:3px}
.delete-btn{width:18px;height:18px;min-width:18px;padding:0;border-radius:50%;background:#f6dede;color:var(--red);font-size:.75rem}
.empty-note{color:#8a8a8f;font-size:.72rem}
.empty-note.light{color:rgba(255,255,255,.7)}
.cell-box.shift-complete,.public-cell.shift-complete{background:var(--green-soft)}
.cell-box.is-disabled,.public-cell.is-disabled{
  min-height:68px;
  background:#dedfe1;
  background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.18) 0,rgba(255,255,255,.18) 8px,transparent 8px,transparent 16px);
}
.cell-box.is-disabled .name-list{display:none}
.name-chip.duplicate-assignment{background:var(--red-soft);box-shadow:inset 0 0 0 2px #d64a4a}
.name-chip.duplicate-assignment.person-highlight{background:var(--highlight-color);box-shadow:0 0 0 2px #fff,0 3px 10px rgba(11,58,85,.28)}
.cell-box.duplicate-cell-warning{background:var(--red-soft);box-shadow:inset 0 0 0 2px #d64a4a}
.table-footer-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;background:#f7f7f8}
.legend{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.legend span{padding:5px 8px;border-radius:999px;color:var(--blue-dark);font-size:.66rem;font-weight:750}
.disabled-legend{background:#dedfe1}
.duplicate-legend{background:var(--red-soft);color:var(--red)!important}
.app-footer{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;padding:10px 14px 16px;color:#a1a1a6;font-size:.67rem}
.backup-footer-status{padding:3px 7px;border-radius:999px;background:#eef0f2}
.backup-footer-status.is-ok{background:var(--green-soft);color:var(--green)}
.backup-footer-status.is-pending{background:var(--yellow-soft);color:var(--yellow)}
.backup-footer-status.is-stale{background:var(--red-soft);color:var(--red)}
#saveStatus.saving{color:#9a6a00}
#saveStatus.error,#saveStatus.conflict{color:var(--red)}

/* Dialoge und Kontaktinfo */
.modal{display:none;position:fixed;inset:0;z-index:100;align-items:center;justify-content:center;padding:18px;background:rgba(15,29,39,.42);backdrop-filter:blur(12px)}
.modal.show{display:flex}
.modal-card{width:min(440px,100%);max-height:86vh;overflow:auto;padding:21px;border-radius:22px;background:rgba(255,255,255,.96);box-shadow:0 28px 80px rgba(0,0,0,.22)}
.modal-card h2{margin-bottom:13px}
.modal-card label{display:block;margin-top:12px}
.modal-actions{display:flex;justify-content:flex-end;gap:7px;margin-top:16px}
.modal-warning{padding:11px 12px;border-radius:12px;background:var(--red-soft);color:#812323;font-size:.83rem}
.person-picker{position:relative}
.person-picker>input[type="search"]{
  padding-right:34px;
  background:#fff;
  box-shadow:inset 0 0 0 1px #d8dce0;
}
.person-picker>input[type="search"]:focus{box-shadow:0 0 0 3px rgba(8,120,189,.16),inset 0 0 0 1px var(--blue)}
.person-picker>input.has-selection{background:var(--green-soft);box-shadow:inset 0 0 0 1px rgba(45,118,81,.2)}
.person-suggestions{
  position:absolute;
  z-index:20;
  top:calc(100% + 6px);
  right:0;
  left:0;
  max-height:310px;
  overflow:auto;
  padding:5px;
  border:1px solid rgba(29,29,31,.1);
  border-radius:14px;
  background:rgba(255,255,255,.98);
  box-shadow:0 18px 45px rgba(24,39,51,.16);
}
.person-suggestion{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  width:100%;
  padding:10px;
  border-radius:10px;
  background:transparent;
  color:var(--ink);
  text-align:left;
}
.person-suggestion:hover,.person-suggestion.is-active{background:var(--surface-blue)}
.person-suggestion-copy{display:block;min-width:0;flex:1}
.person-suggestion-copy strong,.person-suggestion-copy small{display:block}
.person-suggestion-copy strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.82rem}
.person-suggestion-copy small{margin-top:2px;overflow:hidden;color:var(--muted);font-size:.68rem;text-overflow:ellipsis;white-space:nowrap}
.person-suggestion-meta{display:flex;align-items:flex-end;flex-direction:column;flex:0 0 auto}
.person-suggestion-meta small{color:var(--muted);font-size:.61rem}
.person-suggestion-meta strong{margin-top:2px;color:var(--blue-dark);font-size:.66rem}
.person-suggestion-meta.is-waiting strong{color:var(--green)}
.create-person-suggestion{justify-content:flex-start;margin-top:3px;border-top:1px solid #e6e8ea;border-radius:0 0 10px 10px}
.create-person-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--blue);color:#fff;font-weight:800}
.person-suggestion-empty{padding:13px;color:var(--muted);font-size:.75rem;text-align:center}
.person-picker-selection{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:7px;padding:8px 10px;border-radius:10px;background:var(--green-soft)}
.person-suggestions[hidden],.person-picker-selection[hidden]{display:none}
.person-picker-selection strong{font-size:.75rem}
.person-picker-selection span{color:var(--green);font-size:.66rem;font-weight:750;text-align:right}
.person-picker-help{margin:6px 0 0;color:var(--muted);font-size:.68rem}
.assignment-or{display:flex;align-items:center;gap:9px;margin:14px 0 8px;color:var(--muted);font-size:.68rem;font-weight:800;text-transform:uppercase}
.assignment-or::before,.assignment-or::after{content:"";height:1px;flex:1;background:#dfe3e6}
.assignment-name-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.modal-note{margin:10px 0 0;color:var(--muted);font-size:.73rem}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.modal-head h2{margin:0}
.log-card{width:min(900px,96vw)}
.log-card pre{max-height:65vh;margin:14px 0 0;padding:14px;overflow:auto;border-radius:12px;background:#edf0f2;color:#333;font-size:.78rem;white-space:pre-wrap}
.contact-card{width:min(520px,100%)}
.contact-status{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:16px 0;padding:9px 10px;border-radius:11px;background:var(--surface-blue);font-size:.76rem}
.contact-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.contact-field{padding:10px;border-radius:11px;background:var(--surface-soft)}
.contact-field>span{display:block;color:var(--muted);font-size:.64rem;font-weight:800;text-transform:uppercase}
.contact-field>a,.contact-field>strong{display:block;margin-top:3px;overflow-wrap:anywhere;font-size:.82rem}
.contact-tag-section{margin-top:12px}
.contact-tag-section>strong{display:block;margin-bottom:6px;color:var(--muted);font-size:.66rem;text-transform:uppercase}
.contact-tag-list,.tag-list{display:flex;gap:5px;flex-wrap:wrap}
.contact-tag-list span,.tag-list span{padding:4px 7px;border-radius:999px;background:var(--surface-blue);color:var(--blue-dark);font-size:.7rem;font-weight:700}
.contact-empty{padding:10px;border-radius:11px;background:var(--surface-soft);color:var(--muted);font-size:.8rem}
.contact-edit-link{display:block;margin-top:14px;font-size:.78rem;font-weight:750;text-align:center}

/* Öffentliche Vorschau */
.public-page-wrap{width:min(100%,1580px);margin:0 auto;padding:14px}
.public-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:20px;
  padding:21px;
  border-radius:var(--radius-xl);
  background:linear-gradient(135deg,#0b3a55,#12688f);
  color:#fff;
  box-shadow:var(--shadow);
}
.public-header .eyebrow{color:#9dd8f4}
.public-header h1{margin-bottom:7px;font-size:1.55rem}
.public-header p{margin:0;color:rgba(255,255,255,.72)}
.public-header-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.public-revision{padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.12);font-size:.7rem}
.public-plan-table .shift-time{font-size:.78rem;font-weight:850;letter-spacing:.025em}
.public-cell{display:flex;align-items:center;justify-content:center;flex-direction:column;min-height:84px;padding:10px;border-radius:13px;background:rgba(255,255,255,.58)}
.public-cell .capacity{justify-content:center;min-width:76px;padding:7px 12px;font-size:.9rem;line-height:1}
.public-cell .capacity.inactive{min-width:0;padding:4px 8px;font-size:.68rem}
.public-cell-label{display:block;margin-top:7px;color:var(--muted);font-size:.69rem;font-weight:700;text-align:center}
.public-registration-count{display:block;margin-top:6px;padding:4px 7px;border-radius:8px;background:var(--purple-soft);color:#51427a;font-size:.61rem;font-weight:800;line-height:1.25;text-align:center}
.public-registration-legend{display:flex;align-items:flex-start;gap:10px;margin:2px 11px 4px;padding:11px 13px;border-radius:12px;background:var(--purple-soft);color:#51427a;font-size:.72rem}
.public-registration-legend strong{flex:0 0 auto}
.public-registration-legend span{color:#655887}
.public-role-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.role-info-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:25px;
  height:25px;
  min-width:25px;
  padding:0;
  border:1px solid rgba(11,58,85,.12);
  border-radius:50%;
  background:rgba(255,255,255,.72);
  color:var(--blue-dark);
  font-family:Georgia,serif;
  font-size:.8rem;
  font-weight:800;
  font-style:italic;
}
.role-info-button:hover{background:#fff}
.role-info-button:focus-visible,.role-info-close:focus-visible{outline:3px solid rgba(8,120,189,.24);outline-offset:2px}
.role-info-card{width:min(520px,100%)}
.role-info-card .modal-head{align-items:flex-start}
.role-info-card #roleInfoDescription{margin:18px 0 2px;color:#424246;font-size:.9rem;line-height:1.65}
.role-info-close{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:32px;
  height:32px;
  min-width:32px;
  padding:0;
  border-radius:50%;
  background:var(--surface-soft);
  color:var(--muted);
  font-size:1.1rem;
}

/* Helferformular */
.helper-form-page{page:helper-form}
.helper-page,.admin-page,.legal-page{width:min(1080px,100%);margin:0 auto;padding:18px}
.helper-header{
  display:grid;
  grid-template-columns:minmax(0,2fr) minmax(260px,1fr);
  gap:12px;
  margin-bottom:12px;
}
.helper-header-intro,.contact-person,.surface-card,.submit-surface,.admin-section,.legal-card{
  border-radius:var(--radius-xl);
  background:var(--surface);
  box-shadow:var(--shadow-small);
}
.helper-header-intro{padding:24px}
.helper-header-intro p{max-width:720px;margin-bottom:16px;color:var(--muted)}
.helper-header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.helper-header-actions .quiet-button{box-shadow:inset 0 0 0 1px rgba(29,29,31,.07)}
.helper-header-intro .planning-note{
  max-width:680px;
  margin:10px 0 0;
  color:var(--muted);
  font-size:.7rem;
  line-height:1.5;
}
.planning-note strong{color:var(--ink)}
.contact-person{padding:21px;background:var(--surface-blue)}
.contact-person strong{display:block;margin-bottom:5px;font-size:1rem}
.contact-person a{font-weight:750}
.contact-person p{margin:13px 0 0;color:var(--muted);font-size:.82rem}
.surface-card{margin-bottom:11px;padding:20px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.choice-card{
  position:relative;
  display:flex;
  align-items:flex-start;
  gap:9px;
  min-height:48px;
  padding:11px;
  border-radius:13px;
  background:var(--surface-soft);
  cursor:pointer;
}
.choice-card input,.consent-choice>input{position:absolute;opacity:0;pointer-events:none}
.choice-mark{position:relative;width:18px;height:18px;min-width:18px;border-radius:6px;background:#fff;box-shadow:inset 0 0 0 2px #a7adb2}
input:checked+.choice-mark{background:var(--blue);box-shadow:none}
input:checked+.choice-mark::after{content:"";position:absolute;left:6px;top:3px;width:4px;height:8px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
.choice-card:has(input:checked){background:#deeff9}
.choice-card strong{font-size:.84rem}
.choice-copy{display:block;min-width:0}
.choice-description{display:block;margin-top:4px;color:var(--muted);font-size:.72rem;line-height:1.4}
.shift-choice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.shift-choice small{display:block;margin-top:2px;color:var(--muted);font-size:.7rem}
.section-intro{margin:-3px 0 12px;color:var(--muted);font-size:.84rem}
.setup-helper-note{
  margin:0 0 12px;
  padding:11px 13px;
  border:1px solid rgba(29,29,31,.08);
  border-radius:12px;
  background:var(--page);
  color:var(--muted);
  font-size:.82rem;
  box-shadow:none;
}
.setup-helper-note strong{color:var(--ink)}
.shift-choice--setup{background:var(--purple-soft);box-shadow:inset 0 0 0 1px #d9cff4}
.shift-choice--cleanup{background:var(--cyan-soft);box-shadow:inset 0 0 0 1px #c8e8ed}
.shift-choice--setup:has(input:checked){background:#ded3f7}
.shift-choice--cleanup:has(input:checked){background:#ccecf1}
.submit-surface{display:flex;align-items:center;gap:18px;padding:18px}
.consent-choice{position:relative;display:flex;align-items:flex-start;gap:10px;flex:1;cursor:pointer}
.consent-choice .choice-mark{margin-top:2px}
.consent-copy{color:var(--muted);font-size:.75rem;line-height:1.48}
.consent-copy>strong{display:block;margin-bottom:3px;color:var(--blue-dark);font-size:.8rem}
.submit-button{flex:0 0 auto}
.registration-success{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:14px;
  margin-bottom:12px;
  padding:20px;
  border:1px solid rgba(45,118,81,.13);
  border-radius:var(--radius-xl);
  background:var(--surface);
  box-shadow:var(--shadow-small);
}
.registration-success-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  border-radius:50%;
  background:var(--green-soft);
  color:var(--green);
  font-size:1.05rem;
  font-weight:900;
}
.registration-success .eyebrow{color:var(--green)}
.registration-success h2{margin-bottom:11px;font-size:1.05rem}
.registration-follow-up{
  display:flex;
  flex-direction:column;
  gap:3px;
  padding:11px 13px;
  border-radius:12px;
  background:var(--surface-soft);
  color:var(--muted);
  font-size:.8rem;
  line-height:1.5;
}
.registration-follow-up strong{color:var(--ink);font-size:.82rem}
.print-signature{display:none}
.honeypot{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}

/* Helferübersicht */
.admin-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  margin-bottom:12px;
  padding:22px;
  border-radius:var(--radius-xl);
  background:linear-gradient(135deg,#0b3a55,#12688f);
  color:#fff;
  box-shadow:var(--shadow);
}
.admin-header .eyebrow{color:#9dd8f4}
.admin-header h1{margin-bottom:7px}
.admin-header p{margin:0;color:rgba(255,255,255,.7)}
.admin-nav{display:flex;gap:7px;flex-wrap:wrap}
.admin-stats{width:100%;display:flex;gap:7px;flex-wrap:wrap}
.admin-stats span{padding:6px 9px;border-radius:999px;background:rgba(255,255,255,.12);font-size:.72rem}
.admin-stats .duplicate-stat{background:#fff0b5;color:#6e5200}
.admin-section{margin-bottom:12px;padding:18px}
.section-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.section-heading h2{margin-bottom:3px}
.section-heading p{margin:0;color:var(--muted);font-size:.8rem}
.section-count{min-width:32px;padding:5px 8px;border-radius:999px;background:var(--surface-blue);color:var(--blue-dark);font-weight:850;text-align:center}
.admin-pagination{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:13px}
.admin-pagination .button{padding:7px 11px;font-size:.72rem}
.admin-pagination span{color:var(--muted);font-size:.72rem;font-weight:750}
.registration-list,.manual-list,.duplicate-group-list{display:flex;flex-direction:column;gap:7px}
.duplicate-review-section{background:#fff7dc}
.duplicate-group-card{padding:13px;border-radius:var(--radius-md);background:#fff}
.duplicate-group-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.duplicate-group-heading h3{margin:4px 0 0;color:var(--blue-dark);font-size:1rem}
.duplicate-group-heading>span{color:var(--muted);font-size:.72rem}
.duplicate-badge{display:inline-flex;padding:3px 7px;border-radius:999px;background:var(--yellow-soft);color:var(--yellow);font-size:.62rem;font-weight:850;text-transform:uppercase}
.duplicate-person-list{display:flex;flex-direction:column;gap:5px;margin-top:10px}
.duplicate-person-row{display:grid;grid-template-columns:minmax(140px,1fr) auto minmax(180px,1.4fr) auto auto;align-items:center;gap:8px;padding:9px 10px;border-radius:10px;background:var(--surface-soft);font-size:.72rem}
.duplicate-person-row>span,.duplicate-person-row>small{color:var(--muted)}
.duplicate-actions{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;margin-top:10px}
.duplicate-actions form{margin:0}
.duplicate-merge-form{display:flex;align-items:flex-end;justify-content:flex-end;gap:7px;flex:1}
.duplicate-merge-form label{width:min(360px,100%)}
.duplicate-merge-form label span{font-size:.58rem}
.duplicate-merge-form select{padding:9px 10px;background:var(--surface-soft);font-size:.73rem}
.registration-card{border:0;border-radius:var(--radius-md);overflow:hidden;background:var(--surface-soft)}
.registration-summary{
  display:grid;
  grid-template-columns:auto minmax(165px,1fr) minmax(220px,1.3fr) auto auto;
  align-items:center;
  gap:10px;
  padding:11px;
  cursor:pointer;
  list-style:none;
}
.registration-summary::-webkit-details-marker{display:none}
.registration-card[open] .registration-summary{background:var(--surface-blue)}
.summary-arrow{width:24px;height:24px;border-radius:50%;background:#fff}
.summary-arrow::after{content:"›";display:block;color:var(--blue);font-size:1.2rem;font-weight:700;line-height:23px;text-align:center;transition:transform .15s ease}
.registration-card[open] .summary-arrow::after{transform:rotate(90deg)}
.registration-identity{min-width:0}
.registration-identity strong,.registration-identity small{display:block}
.registration-identity strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--blue-dark);font-size:.88rem}
.registration-identity small{margin-top:1px;color:var(--muted);font-size:.66rem}
.registration-quick-contact{min-width:0;display:flex;gap:3px 12px;flex-wrap:wrap;color:#4b5962;font-size:.72rem}
.registration-quick-contact>span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.assignment-pill{display:inline-flex;padding:4px 7px;border-radius:999px;background:var(--green-soft);color:var(--green);font-size:.72rem;font-weight:850}
.assignment-pill.zero{background:var(--yellow-soft);color:var(--yellow)}
.helper-delete-x{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:30px;
  height:30px;
  min-width:30px;
  padding:0;
  border-radius:50%;
  background:#f6dede;
  color:var(--red);
  font-size:1rem;
}
.registration-details{padding:14px;background:#fff}
.contact-list{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:0}
.contact-list div{padding:10px;border-radius:11px;background:var(--surface-soft)}
.contact-list dt{color:var(--muted);font-size:.65rem;font-weight:800;text-transform:uppercase}
.contact-list dd{margin:2px 0 0;overflow-wrap:anywhere;font-size:.8rem}
.registration-selections{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}
.selection-block{padding:11px;border-radius:11px;background:var(--surface-soft)}
.selection-block>strong{display:block;margin-bottom:6px;color:var(--muted);font-size:.66rem;text-transform:uppercase}
.selection-block p{margin:0;color:var(--muted);font-size:.74rem}
.time-tags span{background:var(--purple-soft);color:#51427a}
.contact-editor{display:grid;grid-template-columns:1fr 1fr 1.2fr 1fr auto;gap:8px;align-items:end;margin-top:8px;padding:11px;border-radius:11px;background:var(--surface-blue)}
.contact-editor label span{font-size:.62rem}
.contact-editor input{padding:9px 10px;background:#fff}
.assigned-shifts-panel{margin-top:8px;padding:11px;border:1px solid rgba(8,120,189,.11);border-radius:12px;background:var(--surface-blue)}
.assigned-shifts-panel>strong{display:block;margin-bottom:7px;color:var(--blue-dark);font-size:.68rem;letter-spacing:.035em;text-transform:uppercase}
.assigned-shifts-panel>p{margin:0;color:var(--muted);font-size:.75rem}
.assigned-shifts-list{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:0;padding:0;list-style:none}
.assigned-shifts-list li{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:8px 9px;border:1px solid rgba(29,29,31,.06);border-radius:10px;background:#fff}
.assigned-shifts-list li span{font-size:.75rem;font-weight:800}
.assigned-shifts-list li small{color:var(--muted);font-size:.68rem;text-align:right}
.contact-assigned-shifts{margin-top:12px}
.helper-print-roster{display:none}

/* Geschützter Systemcheck */
.systemcheck-overall{display:flex;align-items:flex-end;flex-direction:column;margin-left:auto;padding:10px 13px;border-radius:13px}
.systemcheck-overall span{font-size:.62rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}
.systemcheck-overall strong{font-size:.9rem}
.systemcheck-list{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.systemcheck-item{display:flex;align-items:flex-start;gap:10px;padding:12px;border:1px solid rgba(29,29,31,.07);border-radius:13px;background:var(--surface-soft)}
.systemcheck-item strong{font-size:.82rem}
.systemcheck-item p{margin:3px 0 0;color:var(--muted);font-size:.72rem}
.systemcheck-dot{width:10px;height:10px;min-width:10px;margin-top:4px;border-radius:50%}
.check-pass .systemcheck-dot{background:var(--green)}
.check-warn .systemcheck-dot{background:#d69b00}
.check-fail .systemcheck-dot{background:var(--red)}
.systemcheck-overall.check-pass{background:var(--green-soft);color:var(--green)}
.systemcheck-overall.check-warn{background:var(--yellow-soft);color:var(--yellow)}
.systemcheck-overall.check-fail{background:var(--red-soft);color:var(--red)}

/* Rechtliches, Login, Installation */
.legal-page-header{margin-bottom:12px;padding:23px;border-radius:var(--radius-xl);background:linear-gradient(135deg,#0b3a55,#12688f);color:#fff;box-shadow:var(--shadow)}
.legal-page-header .eyebrow{color:#9dd8f4}
.legal-page-header p{margin:0;color:rgba(255,255,255,.7)}
.legal-card{padding:24px}
.legal-card h2{margin:23px 0 8px}
.legal-card h2:first-child{margin-top:0}
.legal-card p{color:#424246;font-size:.88rem;line-height:1.6}
.privacy-version{margin-top:25px;padding-top:14px;color:var(--muted);font-size:.74rem}
.legal-back{text-align:center}
.legal-back a{text-decoration:none;font-weight:750}
.legal-links{display:flex;align-items:center;justify-content:center;gap:8px 13px;flex-wrap:wrap;width:min(100%,1580px);margin:4px auto 16px;padding:8px 14px;color:#9b9ba0;font-size:.68rem;text-align:center}
.legal-links a{color:#77777c;text-decoration:none;font-weight:700}
.legal-card .legal-development-note{margin-top:20px;padding-top:12px;border-top:1px solid rgba(29,29,31,.07);color:#8b8b90;font-size:.72rem}
.login-card,.install-card{width:min(430px,calc(100% - 28px));margin:10vh auto 22px;padding:25px;border-radius:var(--radius-xl);background:#fff;box-shadow:var(--shadow)}
.login-card p,.install-card p{color:var(--muted)}
.login-form,.install-form{display:flex;flex-direction:column;gap:9px}
.setup-required,.setup-success,.setup-delete-note{
  display:flex;
  flex-direction:column;
  gap:3px;
  margin-bottom:12px;
  padding:12px 14px;
  border-radius:var(--radius-md);
  background:var(--surface-soft);
  color:var(--muted);
  font-size:.8rem;
}
.setup-required strong,.setup-success strong,.setup-delete-note strong{color:var(--ink);font-size:.86rem}
.setup-start-button{width:100%}
.user-setup-card{width:min(680px,calc(100% - 28px));margin-top:5vh}
.password-tip{margin:-2px 0 5px;padding:10px 12px;border-radius:11px;background:var(--surface-soft);color:var(--muted);font-size:.76rem}
.user-password-list{display:flex;flex-direction:column;gap:9px}
.user-password-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:0;padding:12px;border:1px solid rgba(29,29,31,.08);border-radius:var(--radius-md)}
.user-password-row legend{padding:0 5px;color:var(--blue-dark);font-size:.79rem;font-weight:800}
.setup-success{background:var(--green-soft);color:var(--green)}
.setup-success strong{color:var(--green)}
.setup-delete-note{background:var(--yellow-soft);color:var(--yellow)}
.setup-delete-note strong{color:var(--yellow)}
.setup-delete-note code{overflow-wrap:anywhere;color:inherit;font-weight:800}

@media(max-width:900px){
  .header-top,.public-header{flex-direction:column}
  .main-actions,.public-header-actions{justify-content:flex-start}
  .header-dashboard{grid-template-columns:1fr}
  .helper-header{grid-template-columns:1fr}
  .shift-choice-grid{grid-template-columns:1fr 1fr}
  .duplicate-person-row{grid-template-columns:1fr 1fr}
  .duplicate-actions,.duplicate-merge-form{align-items:stretch;flex-direction:column}
  .duplicate-merge-form{width:100%}
  .duplicate-merge-form label{width:100%}
}

@media(max-width:620px){
  .page,.helper-page,.admin-page,.legal-page,.public-page-wrap{padding:8px}
  .app-header,.admin-header,.public-header,.helper-header-intro,.contact-person,.surface-card,.submit-surface,.admin-section,.legal-card{border-radius:18px}
  .main-actions{width:100%}
  .main-actions .button,.main-actions form{flex:1}
  .main-actions form button{width:100%}
  .dashboard{grid-template-columns:repeat(3,1fr)}
  .person-group+.person-group{width:100%;padding:7px 0 0;border-left:0;border-top:1px solid rgba(255,255,255,.2)}
  .form-grid,.choice-grid,.shift-choice-grid,.contact-list,.registration-selections,.contact-fields,.assignment-name-grid{grid-template-columns:1fr}
  .submit-surface{align-items:stretch;flex-direction:column}
  .submit-button{width:100%}
  .helper-header-actions{align-items:stretch;flex-direction:column}
  .helper-header-actions .button{width:100%}
  .registration-success{grid-template-columns:1fr}
  .registration-summary{grid-template-columns:auto minmax(0,1fr) auto auto}
  .registration-quick-contact{grid-column:2/-1;grid-row:2}
  .contact-editor{grid-template-columns:1fr}
  .duplicate-person-row{grid-template-columns:1fr}
  .public-registration-legend{flex-direction:column;gap:3px}
  .assigned-shifts-list{grid-template-columns:1fr}
  .user-password-row{grid-template-columns:1fr}
  .systemcheck-list{grid-template-columns:1fr}
  .systemcheck-overall{width:100%;align-items:flex-start;margin-left:0}
  .table-footer-actions{align-items:flex-start;flex-direction:column}
}

@page{size:A4 landscape;margin:8mm}
@page helper-form{size:A4 portrait;margin:8mm}
@page helper-roster{size:A4 portrait;margin:10mm}
@media print{
  body{background:#fff}
  .page,.public-page-wrap{width:100%;max-width:none;padding:0}
  .app-header,.public-header{padding:7px 0;border-radius:0;background:#fff;color:#000;box-shadow:none}
  .app-header h1,.public-header h1{color:#000;font-size:15px}
  .app-header .eyebrow,.public-header .eyebrow{color:#555}
  .main-actions,.header-dashboard,.conflict-box,.table-footer-actions,.app-footer,.legal-links,.public-header-actions,.person-info-btn,.role-info-button,.delete-btn,.slot-toggle,.add-btn,.role-tools{display:none}
  .table-panel{margin-top:5px;border-radius:0;box-shadow:none}
  .table-wrap{overflow:visible;padding:0}
  .schedule-table{min-width:0;border-spacing:2px;font-size:7.5px}
  .schedule-table th,.schedule-table td{position:static;min-width:0;padding:0}
  .schedule-table .role-column{position:static;width:38mm;min-width:38mm;max-width:38mm;box-shadow:none}
  .cell-box,.public-cell{min-height:0;padding:3px;border-radius:3px}
  .public-cell .capacity{min-width:0;padding:2px 4px;font-size:7.5px}
  .public-cell-label{margin-top:2px;font-size:6.5px}
  .public-plan-table .shift-time{font-size:7px}
  .name-chip{padding:1px 2px}
  .helper-page{width:100%;max-width:none;padding:0}
  .helper-header{grid-template-columns:2fr 1fr;gap:5px}
  .helper-header-intro,.contact-person,.surface-card,.submit-surface{padding:8px;border-radius:0;box-shadow:none}
  .helper-header-intro p,.contact-person p,.section-intro,.setup-helper-note,.consent-copy,.planning-note{font-size:7.5px}
  .print-button,.shift-preview-button,.submit-button{display:none}
  .registration-success{display:none}
  .surface-card{margin-bottom:4px}
  .choice-grid{grid-template-columns:1fr 1fr}
  .shift-choice-grid{grid-template-columns:repeat(3,1fr)}
  .choice-card{min-height:32px;padding:4px}
  .choice-description{font-size:7px;line-height:1.25}
  .form-grid input{padding:4px}
  .print-signature{
    display:grid;
    grid-template-columns:1fr 2fr;
    gap:12mm;
    margin-top:8mm;
    padding:0 4mm;
  }
  .print-signature div{height:10mm;border-bottom:1px solid #555}
  .print-signature span{display:block;color:#555;font-size:8px;font-weight:700;text-transform:uppercase}
  body.helper-admin-page .admin-page,
  body.helper-admin-page>.modal,
  body.helper-admin-page>.legal-links{display:none!important}
  body.helper-admin-page .helper-print-roster{
    display:block;
    page:helper-roster;
    color:#111;
    font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  }
  .helper-print-roster header{margin-bottom:7mm;border-bottom:1px solid #bbb;padding-bottom:4mm}
  .helper-print-roster header>span{font-size:8pt;font-weight:800;letter-spacing:.06em;text-transform:uppercase}
  .helper-print-roster h1{margin:1.5mm 0 1mm;font-size:18pt}
  .helper-print-roster header p{margin:0;color:#555;font-size:8.5pt}
  .helper-print-roster table{width:100%;border-collapse:collapse;font-size:8.5pt;table-layout:fixed}
  .helper-print-roster th,.helper-print-roster td{padding:2.5mm;border:1px solid #bbb;vertical-align:top;text-align:left;overflow-wrap:anywhere}
  .helper-print-roster th{background:#e9eef1;font-size:7.5pt;text-transform:uppercase}
  .helper-print-roster th:nth-child(1){width:20%}
  .helper-print-roster th:nth-child(2){width:24%}
  .helper-print-roster th:nth-child(3){width:18%}
  .helper-print-roster th:nth-child(4){width:38%}
  .helper-print-roster tr{break-inside:avoid}
  .helper-print-roster ul{margin:0;padding-left:4mm}
  .helper-print-roster li+li{margin-top:1mm}
  .helper-print-roster .print-unassigned{color:#777;font-style:italic}
  .helper-print-roster footer{margin-top:5mm;color:#666;font-size:7.5pt;text-align:center}
}
