*{box-sizing:border-box}
:root{--user-font-scale:1}
html{font-size:calc(16px * var(--user-font-scale))}
body{
  margin:0;
  font-family:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;
  color:#0f172a;
  background:radial-gradient(1200px 500px at 20% -20%,#dbeafe 0%,transparent 60%),linear-gradient(180deg,#f8fafc 0%,#eef2ff 100%);
}
.wrap{max-width:980px;margin:0 auto;padding:28px 16px}
h1{margin:0 0 10px;font-size:clamp(1.5rem,2.5vw,2rem)}
h2{margin:0 0 10px;font-size:1.2rem}
h3{margin:0 0 10px;font-size:1rem}
p{line-height:1.45}
.progress{height:10px;background:#dbeafe;border-radius:999px;overflow:hidden;margin-bottom:8px}
.progress span{display:block;height:100%;background:linear-gradient(90deg,#2563eb,#4f46e5);width:0;transition:width .25s ease}
.card{
  background:rgba(255,255,255,.9);
  border:1px solid rgba(148,163,184,.25);
  backdrop-filter:blur(6px);
  border-radius:18px;
  padding:18px;
  box-shadow:0 12px 35px rgba(15,23,42,.08);
  margin:12px 0;
  transition:transform .25s ease, box-shadow .25s ease, opacity .25s ease;
}
.card:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(15,23,42,.11)}
input,select,textarea,button{
  width:100%;
  padding:11px 12px;
  border-radius:12px;
  border:1px solid #cbd5e1;
  margin:6px 0;
  font:inherit;
}
input:focus,select:focus,textarea:focus{
  border-color:#2563eb;
  outline:none;
  box-shadow:0 0 0 3px rgba(37,99,235,.12);
}
button{
  border:none;
  color:#fff;
  background:linear-gradient(90deg,#2563eb,#4f46e5);
  cursor:pointer;
  font-weight:600;
  transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease;
}
button:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(37,99,235,.25)}
button:active{transform:translateY(0)}
button.ghost{background:#e2e8f0;color:#0f172a;box-shadow:none}
.actions{display:flex;gap:10px;flex-wrap:wrap}
.actions button{width:auto;min-width:120px}
.err{color:#b91c1c;font-weight:700}
.ok{color:#166534;font-weight:700}
.required{color:#dc2626;font-weight:700}
.cards{display:grid;gap:10px}
.cards button{background:#f8fafc;color:#0f172a;border:1px solid #cbd5e1;text-align:left}
.cards button.active{border-color:#1d4ed8;box-shadow:0 0 0 3px rgba(29,78,216,.15)}
.dashboard{
  display:grid;
  grid-template-columns:260px 1fr;
  gap:16px;
  padding:14px;
  border-radius:20px;
  background:linear-gradient(180deg,#f8fafc 0%,#eef2f7 100%);
  border:1px solid #e5ebf3;
  box-shadow:0 24px 50px rgba(2,6,23,.08);
}
.navMenu{
  position:sticky;
  top:16px;
  height:fit-content;
  background:linear-gradient(180deg,#050b22 0%,#10193a 100%);
  color:#e2e8f0;
  border:1px solid rgba(99,102,241,.25);
  box-shadow:0 16px 30px rgba(2,6,23,.35);
}
.navMenu h2,.navMenu p,.navMenu b{color:#f8fafc}
.menuBtn{
  margin-bottom:8px;
  background:rgba(148,163,184,.12);
  color:#dbe7ff;
  border:1px solid rgba(148,163,184,.24);
}
.menuBtn.active{
  background:linear-gradient(90deg,#2563eb,#4f46e5);
  color:#fff;
  border-color:transparent;
  box-shadow:0 10px 20px rgba(59,130,246,.35);
}
.navMenu .logoutLink{color:#c7d2fe}
.contentArea .tab{
  animation:fadeSlide .28s ease;
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:16px;
  box-shadow:0 10px 24px rgba(15,23,42,.06);
}
.customerRow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  padding:10px 12px;
  border:1px solid #dbe2f0;
  border-radius:12px;
  margin-bottom:8px;
  background:#fff;
}
.customerRowMain{flex:1;min-width:160px;text-decoration:none;color:#0f172a;font-weight:600}
.customerRowMain:hover{text-decoration:underline}
.customerRowMain span{color:#475569;font-weight:400;margin-left:6px}
.logoutLink{display:inline-block;margin-top:12px}
.tableWrap{overflow:auto}
table{width:100%;border-collapse:collapse}
th,td{padding:8px;border-bottom:1px solid #e2e8f0;text-align:left;vertical-align:top}
th{font-size:.85rem;color:#475569}
.heroCard{text-align:center;padding:48px 20px}
.heroLink{display:inline-block;margin-top:10px;padding:11px 16px;border-radius:12px;background:linear-gradient(90deg,#2563eb,#4f46e5);color:#fff;text-decoration:none}
.heroLink:hover{text-decoration:none;transform:translateY(-1px)}
.fade-in{animation:fadeSlide .4s ease}
@keyframes fadeSlide{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
code{background:#eff6ff;padding:3px 7px;border-radius:8px}
a{color:#1d4ed8;text-decoration:none}
a:hover{text-decoration:underline}
@media (max-width:900px){
  .dashboard{grid-template-columns:1fr}
  .navMenu{position:relative;top:0}
}

body.onboarding{
  background:#f8fafc;
  color:#1e293b;
}
.onboardingWrap{max-width:720px;margin:0 auto;padding:32px 16px 48px}
.onboardingHeader h1{margin:0 0 4px;font-size:1.35rem;font-weight:600;letter-spacing:-.02em}
.stepLabel{margin:0 0 12px;font-size:.9rem;color:#64748b}
.onboardingCard{
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:14px;
  padding:24px 22px;
  box-shadow:0 4px 20px rgba(15,23,42,.05);
}
.onboarding .lead{color:#475569;margin:0 0 16px;line-height:1.55;font-size:.95rem}
.onboarding h2{margin:0 0 8px;font-size:1.15rem;font-weight:600}
.onboarding h3{margin:16px 0 8px;font-size:1rem;font-weight:600}
.onboarding .hint{font-size:.85rem;color:#64748b;margin:4px 0 12px;line-height:1.45}
.onboarding .hint.hintTight{margin-top:-2px;margin-bottom:0}
.onboarding input[readonly],.onboarding .readonly{background:#f1f5f9;color:#475569;border-color:#e2e8f0}
.onboarding .payOptions{display:grid;gap:12px;margin-top:8px}
.onboarding .payCard{
  display:block;width:100%;text-align:left;padding:16px 18px;border-radius:12px;
  border:1px solid #cbd5e1;background:#fff;color:#0f172a;
  box-shadow:none;line-height:1.45;
}
.onboarding .payCard:hover{transform:none;box-shadow:0 2px 8px rgba(15,23,42,.08)}
.onboarding .payCard.active{border-color:#0f172a;background:#f8fafc;box-shadow:0 0 0 2px rgba(15,23,42,.12)}
.onboarding .payTitle{display:block;font-weight:600;font-size:1rem;margin-bottom:6px;color:#0f172a}
.onboarding .payText{display:block;font-size:.9rem;color:#334155;font-weight:400}
.onboarding .legalOne{display:block;margin-top:14px;line-height:1.5;font-size:.95rem}
.onboarding .legalOne a{font-weight:600}
.onboarding .sepaBlock{margin-top:14px;padding-top:14px;border-top:1px solid #e2e8f0}
.onboarding .fileList{margin:8px 0 0;padding-left:18px;color:#475569;font-size:.9rem}
.onboarding .legalChecks label{display:block;margin:12px 0;font-size:.9rem;line-height:1.45}
.summaryGrid{display:grid;grid-template-columns:minmax(130px,auto) 1fr;gap:10px 18px;margin:16px 0 8px;font-size:.92rem}
.summaryGrid dt{font-weight:600;color:#64748b;margin:0}
.summaryGrid dd{margin:0;color:#0f172a}
.backLink{display:inline-block;margin:0 0 8px;font-weight:600;color:#1e3a8a}
.fileListAdmin{list-style:none;padding:0;margin:8px 0 0}
.fileRow{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap;padding:8px 0;border-bottom:1px solid #e2e8f0}
.fileRowMain{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}
.fileMeta{font-size:.82rem;color:#64748b}
.fileTag{display:inline-block;margin-left:6px;font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:999px;background:#e0e7ff;color:#312e81;vertical-align:middle}
.fileRow:last-child{border-bottom:none}
.smallBtn{padding:6px 12px;font-size:.85rem;width:auto;min-width:0}
a.smallBtn{display:inline-flex;align-items:center;justify-content:center}
.nachFileRow{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;padding:6px 0;border-bottom:1px solid #e2e8f0}
.nachFileRow:last-child{border-bottom:none}
.nachFileRow span{word-break:break-all;font-size:.9rem}
input.readonly,textarea.readonly{background:#f8fafc;color:#334155;border-color:#e2e8f0;cursor:default}
.onboarding .hint a{font-weight:600}
.onboarding input.fieldHidden,
.onboarding .fieldHidden{display:none!important}
.legalLinks{margin-top:20px;font-size:.85rem;color:#64748b;text-align:center}
.onboarding .onboardingProgress{background:#e2e8f0}
.onboarding .onboardingProgress span{background:#334155}
.onboarding button{background:#0f172a}
.onboarding button:hover{box-shadow:0 6px 16px rgba(15,23,42,.15)}
.onboarding button.ghost{background:#fff;color:#0f172a;border:1px solid #cbd5e1}
.onboarding .fieldLabel{font-size:.88rem;font-weight:600;color:#334155;margin:14px 0 8px}
.onboarding .fieldLabel:first-of-type{margin-top:4px}
.onboarding .choiceGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:0 0 14px}
.onboarding .choiceGrid--2{grid-template-columns:repeat(2,1fr)}
@media (max-width:560px){
  .onboarding .choiceGrid{grid-template-columns:1fr}
}
.onboarding button.choiceTile{
  margin:0;padding:14px 12px;border-radius:12px;border:1px solid #cbd5e1;
  background:#fff!important;color:#0f172a!important;
  font:inherit;font-weight:600;font-size:.9rem;
  cursor:pointer;line-height:1.35;text-align:center;width:100%;
  transition:border-color .15s ease,box-shadow .15s ease,background .15s ease;
  box-shadow:none!important;
}
.onboarding button.choiceTile:hover{border-color:#94a3b8;background:#fafafa!important;transform:none}
.onboarding button.choiceTile.active{
  border-color:#4f46e5!important;
  background:linear-gradient(180deg,#eef2ff,#f8fafc)!important;
  box-shadow:0 0 0 2px rgba(79,70,229,.14)!important;
  color:#1e1b4b!important;
}
.onboarding .choiceTileDesc{display:block;font-weight:400;font-size:.78rem;color:#64748b;margin-top:4px;line-height:1.3}
.onboarding .obPageTitle{
  margin:0 0 10px;
  font-size:1.28rem;
  font-weight:600;
  letter-spacing:-.035em;
  color:#0f172a;
  line-height:1.25;
}
.onboarding .obPageLead{max-width:52ch;margin-bottom:20px!important}
.onboarding .obStep2{
  display:flex;
  flex-direction:column;
  gap:18px;
  margin-bottom:4px;
}
.onboarding .obStep2Actions{margin-top:10px}
.onboarding .obSectionRule{
  border:0;
  height:1px;
  margin:20px 0 16px;
  background:linear-gradient(90deg,transparent,rgba(148,163,184,.45) 15%,rgba(148,163,184,.45) 85%,transparent);
}
.onboarding .obSectionTitle{
  margin:0 0 14px;
  font-size:.92rem;
  font-weight:600;
  color:#1e293b;
  letter-spacing:-.02em;
}
.onboarding .obSectionMuted{font-weight:500;color:#94a3b8;font-size:.78rem}
.onboarding .onboardingFormPanel{
  margin:0;
  padding:22px 22px 10px;
  border-radius:16px;
  border:1px solid #e8ecf1;
  background:#fff;
  box-shadow:
    0 1px 2px rgba(15,23,42,.04),
    0 10px 28px rgba(15,23,42,.07);
}
.onboarding .panelSectionTitle{
  margin:0 0 18px;
  padding:0 0 12px;
  border-bottom:1px solid #f1f5f9;
  font-size:.72rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.09em;
  color:#64748b;
  display:flex;
  align-items:center;
  gap:10px;
}
.onboarding .panelSectionTitle::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background:#94a3b8;
  flex-shrink:0;
  box-shadow:0 0 0 2px rgba(148,163,184,.2);
}
.onboarding .ob-field{
  display:flex;
  flex-direction:column;
  gap:7px;
  margin-bottom:16px;
}
.onboarding .ob-field--hero input{
  font-size:1.05rem;
  font-weight:600;
  letter-spacing:-.02em;
  color:#0f172a;
  padding:13px 14px;
}
.onboarding .ob-field .ob-lbl{
  font-size:.8rem;
  font-weight:600;
  color:#475569;
  line-height:1.3;
  letter-spacing:.01em;
}
.onboarding .ob-field input,
.onboarding .ob-field textarea{
  margin:0;
  width:100%;
  border-color:#e2e8f0;
}
.onboarding .ob-field input:focus,
.onboarding .ob-field textarea:focus{border-color:#818cf8}
.onboarding .subGroupTitle{
  margin:2px 0 12px;
  font-size:.98rem;
  font-weight:600;
  color:#1e293b;
  letter-spacing:-.01em;
}
.onboarding .ob-addressGrid{
  display:grid;
  grid-template-columns:minmax(100px,28%) 1fr;
  gap:0 14px;
  align-items:start;
}
@media (max-width:520px){
  .onboarding .ob-addressGrid{grid-template-columns:1fr}
}
.onboarding .ob-addressGrid .ob-field{margin-bottom:16px}
.onboarding .obContactGrid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:0 14px;
}
.onboarding .obContactGrid .ob-field{margin-bottom:16px}
@media (max-width:760px){
  .onboarding .obContactGrid{grid-template-columns:1fr}
}
.onboarding .onboardingSubGroup{
  padding:0;
  margin:0 0 14px;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.onboarding .onboardingSubGroup:last-of-type{margin-bottom:10px}
.onboarding .onboardingSubGroup .lockedBlock{margin:0}
.onboarding .onboardingSubGroup .fieldLabel{margin-top:0;margin-bottom:8px}
.onboarding .onboardingSubGroup .subGroupTitle{margin-top:0}
.onboarding .lockedBlock{
  margin:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.onboarding .lockedBlockTitle{
  margin:2px 0 10px;
  font-size:.98rem;
  font-weight:600;
  color:#0f172a;
  line-height:1.35;
}
.onboarding .lockedMeta{
  display:grid;
  grid-template-columns:minmax(108px,30%) 1fr;
  gap:8px 14px;
  font-size:.9rem;
  margin:0;
  padding:0;
  border:0;
}
.onboarding .lockedMeta dt{
  color:#64748b;
  font-weight:600;
  font-size:.78rem;
  margin:0;
  padding-top:2px;
}
.onboarding .lockedMeta dd{
  margin:0;
  color:#0f172a;
  font-weight:500;
  word-break:break-word;
}
.onboarding .obCompanyPanel .ob-field input[disabled]{
  background:#f8fafc;
  border-color:#e2e8f0;
  color:#334155;
}

/* Streamlined onboarding layout */
body.onboarding{
  background:#f3f5f9;
}
.onboardingShell{
  max-width:1220px;
  margin:0 auto;
  padding:24px;
}
.onboardingMainCard{
  background:#fff;
  border:1px solid #e7ecf3;
  border-radius:14px;
  box-shadow:0 24px 60px rgba(15,23,42,.08);
  display:grid;
  grid-template-columns:1.55fr .85fr;
  overflow:hidden;
  min-height:760px;
}
.onboardingPane{
  padding:26px 30px;
}
.onboardingPaneContent{
  background:#fff;
}
.onboardingPaneRail{
  border-left:1px solid #edf1f6;
  background:linear-gradient(180deg,#fcfdff 0%,#f8fbff 100%);
}
.onboardingPaneRail h3{
  margin:2px 0 16px;
  font-size:.86rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:#94a3b8;
}
.onboardingRailList{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.railItem{
  display:flex;
  align-items:flex-start;
  gap:12px;
  opacity:.62;
}
.railNo{
  width:26px;
  height:26px;
  border-radius:50%;
  border:1px solid #d8e0ea;
  color:#94a3b8;
  font-size:.8rem;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  background:#fff;
}
.railTxt b{
  display:block;
  font-size:.9rem;
  color:#334155;
  margin:2px 0 3px;
}
.railTxt small{
  display:block;
  color:#94a3b8;
  font-size:.77rem;
  line-height:1.35;
}
.railItem.active{
  opacity:1;
}
.railItem.active .railNo{
  border-color:#3b82f6;
  color:#1d4ed8;
  box-shadow:0 0 0 3px rgba(59,130,246,.16);
}
.railItem.done{
  opacity:.9;
}
.railItem.done .railNo{
  background:#3b82f6;
  color:#fff;
  border-color:#3b82f6;
}
.onboardingWrap,
.onboardingHeader,
.onboardingCard{
  max-width:none;
}

/* Admin dashboard redesign */
body.admin-dashboard{
  background:
    radial-gradient(1000px 460px at 82% -16%,rgba(79,70,229,.26),transparent 64%),
    radial-gradient(940px 520px at -14% 12%,rgba(56,189,248,.2),transparent 58%),
    linear-gradient(180deg,#eef2ff 0%,#eaf0f8 100%);
  color:#0f172a;
}
body.admin-dashboard .wrap{
  max-width:1280px;
  padding:22px 16px 32px;
}
body.admin-dashboard .dashboard{
  display:grid;
  grid-template-columns:282px minmax(0,1fr);
  gap:18px;
  border-radius:26px;
  border:1px solid #dde5f0;
  background:rgba(245,249,255,.62);
  padding:16px;
  box-shadow:0 28px 70px rgba(15,23,42,.12);
}
body.admin-dashboard .navMenu{
  margin:0;
  min-height:calc(100vh - 90px);
  position:sticky;
  top:14px;
  display:flex;
  flex-direction:column;
  gap:18px;
  border-radius:22px;
  padding:20px 16px 16px;
  border:1px solid rgba(148,163,184,.28);
  background:
    radial-gradient(420px 180px at 100% 0%,rgba(79,70,229,.28),transparent 65%),
    linear-gradient(180deg,#070f2b 0%,#101a3d 100%);
  box-shadow:0 26px 45px rgba(2,6,23,.4);
}
body.admin-dashboard .navMenuHead h2{
  margin:4px 0 10px;
  font-size:1.2rem;
  letter-spacing:-.02em;
  color:#f8fafc;
}
body.admin-dashboard .navMenuHead p{
  margin:0;
  color:#c7d2fe;
  font-size:.9rem;
}
body.admin-dashboard .navMenuHead b{color:#eef2ff}
body.admin-dashboard .navOverline{
  display:inline-flex;
  margin:0;
  font-size:.72rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#a5b4fc;
  font-weight:700;
}
body.admin-dashboard .navMenuLinks{
  display:grid;
  gap:8px;
}
body.admin-dashboard .menuBtn{
  margin:0;
  padding:11px 12px;
  text-align:left;
  border-radius:12px;
  border:1px solid rgba(148,163,184,.28);
  background:rgba(148,163,184,.1);
  color:#dbeafe;
  font-weight:600;
}
body.admin-dashboard .menuBtn:hover{
  transform:none;
  box-shadow:0 8px 18px rgba(15,23,42,.28);
  border-color:rgba(191,219,254,.5);
}
body.admin-dashboard .menuBtn.active{
  background:linear-gradient(100deg,#2563eb,#4f46e5 72%);
  border-color:transparent;
  color:#fff;
  box-shadow:0 12px 25px rgba(37,99,235,.45);
}
body.admin-dashboard .logoutLink{
  margin-top:auto;
  color:#c7d2fe;
  border:1px solid rgba(148,163,184,.35);
  border-radius:12px;
  padding:10px 12px;
  text-align:center;
  background:rgba(15,23,42,.25);
}
body.admin-dashboard .logoutLink:hover{
  text-decoration:none;
  color:#fff;
}
body.admin-dashboard .contentArea{
  display:grid;
}
body.admin-dashboard .contentArea .tab{
  margin:0;
  border-radius:22px;
  border:1px solid #d9e3ef;
  background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);
  box-shadow:0 18px 40px rgba(15,23,42,.1);
  padding:24px;
}
body.admin-dashboard .contentArea .tab h1,
body.admin-dashboard .contentArea .tab h2{
  margin-bottom:8px;
  letter-spacing:-.02em;
}
body.admin-dashboard .contentArea .tab > p{
  margin-top:0;
  color:#475569;
}
body.admin-dashboard label{
  display:block;
  font-size:.88rem;
  color:#334155;
  font-weight:600;
  margin-bottom:8px;
}
body.admin-dashboard input,
body.admin-dashboard select,
body.admin-dashboard textarea{
  background:#f8fbff;
  border:1px solid #d8e1ec;
  border-radius:12px;
  color:#0f172a;
  font-size:.94rem;
}
body.admin-dashboard input:focus,
body.admin-dashboard select:focus,
body.admin-dashboard textarea:focus{
  border-color:#4f46e5;
  box-shadow:0 0 0 4px rgba(79,70,229,.13);
}
body.admin-dashboard .actions{
  margin-top:14px;
}
body.admin-dashboard .actions button{
  min-width:150px;
  border-radius:12px;
}
body.admin-dashboard .actions .ghost{
  background:#eef2ff;
  color:#1e293b;
  border:1px solid #cbd5e1;
}
body.admin-dashboard .actions a.ghost{padding:6px 12px}
.tableWrap .smallBtn.active{
  border-color:#4f46e5;
  box-shadow:0 0 0 2px rgba(79,70,229,.14);
}
.calendarSplit{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  border:1px solid #e2e8f0;
  border-radius:14px;
  padding:14px;
  background:#fff;
}
.calendarPane{padding-right:8px;border-right:1px solid #e2e8f0}
.slotPane{padding-left:8px}
.calendarToolbar{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  margin-bottom:10px;
}
.calendarWeekdays{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:8px;
  margin-bottom:8px;
  font-size:.78rem;
  color:#64748b;
  text-align:center;
}
.calendarGrid{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:8px;
}
.dayCell{
  appearance:none;
  border:1px solid #dbe5f1;
  border-radius:999px;
  background:#f8fbff !important;
  color:#1e293b;
  min-height:42px;
  font-weight:600;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:4px;
  width:100%;
  box-shadow:none !important;
  cursor:pointer;
  transition:all .16s ease;
}
.dayCell small{font-size:.68rem;color:#64748b}
.dayCell.has{background:#e8f0ff !important;border-color:#9ec2ff}
.dayCell.active{background:#ffffff !important;color:#1e293b;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.18) !important}
.dayCell.active small{color:#dbeafe}
.dayCell.empty{opacity:.35;cursor:default}
.dayCell.past{opacity:.45;cursor:not-allowed;background:#eef2f7 !important;border-color:#d8e1ec;color:#94a3b8}
.dayCell.past small{color:#94a3b8}
.slotList{display:grid;gap:10px}
.slotCard{
  appearance:none;
  display:block;
  border:2px solid #3b82f6;
  border-radius:14px;
  padding:10px 12px;
  background:#fff !important;
  font-weight:600;
  box-shadow:none !important;
  cursor:pointer;
  transition:all .16s ease;
}
.slotCard:hover{transform:translateY(-1px)}
.slotCard.active{background:#eff6ff !important;box-shadow:0 0 0 3px rgba(59,130,246,.15) !important}
.adminAppointmentsShell .slotPane h3{margin-top:0}
.adminAppointmentsShell .adminDayEditor{
  margin-top:10px;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.adminAppointmentsShell .adminDayEditor button{
  grid-column:1 / -1;
}
.adminAppointmentsShell .adminSlotCard{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.adminAppointmentsShell .adminSlotCard button{
  width:auto;
}
.adminAppointmentsShell .adminSlotCard.booked{
  border-color:#f59e0b;
  background:#fffbeb !important;
}
.dayCell.booked{
  border-color:#f59e0b;
}
.cookieBanner{
  position:fixed;
  left:14px;
  right:14px;
  bottom:14px;
  z-index:9999;
}
.cookieBannerInner{
  max-width:980px;
  margin:0 auto;
  background:#ffffff;
  color:#0f172a;
  border:1px solid #cbd5e1;
  border-radius:14px;
  padding:14px;
  box-shadow:0 12px 30px rgba(2,6,23,.2);
}
.cookieBannerInner h3{margin:0 0 8px;color:#0f172a}
.cookieBannerInner p{margin:0 0 8px}
.cookieBannerInner ul{margin:0 0 8px 18px;padding:0}
.cookieBannerInner li{margin-bottom:4px}
.cookieBannerInner .actions{margin-top:8px}
.cookieSettingsBtn{
  position:fixed;
  right:14px;
  bottom:14px;
  z-index:9998;
  width:auto;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid #cbd5e1;
  background:#ffffff !important;
  color:#0f172a !important;
  font-weight:600;
  box-shadow:0 8px 18px rgba(15,23,42,.14);
}
.cookieBannerInner .hint{color:#334155 !important}
.cookieBannerInner code{background:#eef2ff;color:#0f172a}
.cookieBannerInner button{background:#2563eb !important;color:#fff !important}
.cookieBannerInner button.ghost{
  background:#f1f5f9 !important;
  color:#0f172a !important;
  border:1px solid #cbd5e1 !important;
}
.cookieOptions{display:grid;gap:8px}
.cookieOption{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  border:1px solid rgba(148,163,184,.25);
  border-radius:10px;
  padding:8px 10px;
}
.cookieOption small{color:#475569}
.cookieList{
  margin:0 0 0 18px;
  padding:0;
  font-size:.85rem;
}
.cookieTable{
  width:100%;
  border-collapse:collapse;
  margin-top:8px;
  font-size:.82rem;
}
.cookieTable th,.cookieTable td{
  border:1px solid rgba(148,163,184,.35);
  padding:6px 8px;
  text-align:left;
  vertical-align:top;
}
.cookieTable th{
  background:#f1f5f9;
  color:#0f172a;
}
.fontSizeDock{
  position:fixed;
  left:12px;
  bottom:12px;
  z-index:9997;
  display:flex;
  gap:6px;
  padding:6px;
  border-radius:999px;
  background:#ffffff;
  border:1px solid #cbd5e1;
  box-shadow:0 8px 20px rgba(15,23,42,.16);
}
.fontSizeDock button{
  width:auto;
  min-width:36px;
  margin:0;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid #cbd5e1;
  background:#f8fafc !important;
  color:#0f172a !important;
  box-shadow:none !important;
}
.fontSizeDock button:hover{transform:none}
.nachreichung-page .onboardingWrap{
  max-width:760px;
}
.nachreichung-page .onboardingCard{
  border:1px solid #e2e8f0;
  border-radius:14px;
  box-shadow:0 8px 24px rgba(15,23,42,.08);
  padding:20px;
}
.railCta{
  margin-top:18px;
}
.railCta .hint{
  margin:0 0 8px;
}
.railCtaBtn{
  display:inline-flex;
  width:auto;
  text-decoration:none;
}
.railCtaBtnPrimary{
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:12px;
  border:1px solid transparent;
  background:linear-gradient(90deg,#2563eb,#4f46e5);
  color:#ffffff !important;
  font-weight:600;
  box-shadow:0 8px 18px rgba(37,99,235,.25);
}
.railCtaBtnPrimary:hover{
  text-decoration:none;
  transform:translateY(-1px);
}
body.onboarding .dayCell{
  background:#e5e7eb !important;
  border-color:#d1d5db;
  color:#334155;
}
body.onboarding .dayCell.has{
  background:#0b1b45 !important;
  border-color:#0b1b45;
  color:#f8fafc;
}
body.onboarding .dayCell.has small{color:#c7d2fe}
body.onboarding .dayCell.active{
  background:#f3f8ff !important;
  border-color:#3b82f6;
  color:#0f172a;
  box-shadow:0 0 0 3px rgba(59,130,246,.18) !important;
}
body.onboarding .dayCell.active small{color:#64748b}
@media (max-width:980px){
  .calendarSplit{grid-template-columns:1fr}
  .calendarPane{border-right:0;border-bottom:1px solid #e2e8f0;padding-right:0;padding-bottom:10px}
  .slotPane{padding-left:0}
}
body.admin-dashboard .customerRow{
  border-radius:14px;
  border:1px solid #dbe5f1;
  background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
  box-shadow:0 6px 14px rgba(15,23,42,.06);
  padding:12px 14px;
  margin-bottom:10px;
}
body.admin-dashboard .tableWrap{
  border:1px solid #dde6f2;
  border-radius:14px;
  overflow:auto;
}
body.admin-dashboard table{
  background:#fff;
}
body.admin-dashboard th{
  background:#f8fbff;
  color:#64748b;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.06em;
}
body.admin-dashboard th,
body.admin-dashboard td{
  padding:11px 12px;
  border-bottom:1px solid #edf2f7;
}
@media (max-width:980px){
  body.admin-dashboard .dashboard{
    grid-template-columns:1fr;
    padding:12px;
  }
  body.admin-dashboard .navMenu{
    min-height:unset;
    position:relative;
    top:0;
  }
}

/* Top-menu dashboard layout */
body.admin-dashboard .dashboard{
  grid-template-columns:1fr;
  gap:16px;
}
body.admin-dashboard .topbar{
  margin:0;
  display:grid;
  grid-template-columns:1fr auto auto;
  align-items:center;
  gap:16px;
  border-radius:22px;
  border:1px solid #d6e0ee;
  background:
    radial-gradient(560px 260px at 80% -8%,rgba(79,70,229,.32),transparent 64%),
    linear-gradient(180deg,#0a122f 0%,#0d183a 100%);
  box-shadow:0 24px 45px rgba(2,6,23,.38);
}
body.admin-dashboard .topbarBrand h1{
  margin:2px 0 8px;
  color:#f8fafc;
  font-size:1.35rem;
  letter-spacing:-.02em;
}
body.admin-dashboard .topbarBrand p{
  margin:0;
  color:#c7d2fe;
}
body.admin-dashboard .topbarBrand b{color:#eef2ff}
body.admin-dashboard .topbarNav{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:flex-end;
}
body.admin-dashboard .menuBtn,
body.admin-dashboard .menuLinkBtn{
  width:auto;
  min-width:0;
  margin:0;
  padding:9px 12px;
  border-radius:11px;
  border:1px solid rgba(148,163,184,.3);
  background:rgba(148,163,184,.12);
  color:#dbeafe;
  font-size:.88rem;
  font-weight:600;
  text-decoration:none;
  line-height:1.2;
}
body.admin-dashboard .menuBtn.active,
body.admin-dashboard .menuLinkBtn.active{
  background:linear-gradient(100deg,#2563eb,#4f46e5 70%);
  color:#fff;
  border-color:transparent;
  box-shadow:0 10px 22px rgba(37,99,235,.42);
}
body.admin-dashboard .adminContent .tab{
  border-radius:20px;
  border:1px solid #dce5f1;
  box-shadow:0 14px 30px rgba(15,23,42,.08);
}
body.admin-dashboard .adminContent .tab h1,
body.admin-dashboard .adminContent .tab h2{
  margin-bottom:6px;
}
body.admin-dashboard .adminContent .tab h3{
  margin:16px 0 6px;
  font-size:.95rem;
  color:#334155;
}

/* Customer detail dashboard */
body.admin-customer-page .detailShell{
  margin:0;
  border-radius:20px;
  border:1px solid #dce5f1;
  box-shadow:0 14px 30px rgba(15,23,42,.08);
}
body.admin-customer-page .detailToolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:12px;
}
body.admin-customer-page .detailGrid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
body.admin-customer-page .detailGrid--bottom{
  margin-top:14px;
}
body.admin-customer-page .detailCard{
  border:1px solid #dbe5f1;
  border-radius:14px;
  background:linear-gradient(180deg,#fff 0%,#f9fbff 100%);
  padding:14px;
}
body.admin-customer-page .detailCard h2{
  margin:0 0 10px;
  font-size:1.02rem;
}
body.admin-customer-page #msg{
  margin-top:12px;
}
@media (max-width:1100px){
  body.admin-dashboard .topbar{
    grid-template-columns:1fr;
    align-items:flex-start;
  }
  body.admin-dashboard .topbarNav{
    justify-content:flex-start;
  }
}
@media (max-width:880px){
  body.admin-customer-page .detailGrid{
    grid-template-columns:1fr;
  }
}
.onboardingHeader{
  margin-bottom:10px;
}
.onboardingHeader h1{
  font-size:1.45rem;
  margin-bottom:2px;
}
.stepLabel{
  margin-bottom:12px;
}
.onboardingProgress{
  height:7px;
  background:#e8eef6;
  margin-bottom:0;
}
.onboardingProgress span{
  background:linear-gradient(90deg,#2d7df6,#255fda);
}
.onboardingCard{
  border:0;
  box-shadow:none;
  padding:12px 0 0;
  background:transparent;
}
#app{
  min-height:560px;
}
.onboarding .actions{
  padding-top:6px;
}
.legalLinks{
  text-align:left;
  margin-top:14px;
}
@media (max-width:980px){
  .onboardingMainCard{
    grid-template-columns:1fr;
  }
  .onboardingPaneRail{
    border-left:0;
    border-top:1px solid #edf1f6;
  }
}
@media (max-width:700px){
  .wrap{padding:16px 12px}
  .card{padding:14px}
  h1{font-size:1.5rem}
  h2{font-size:1.2rem}
  h3{font-size:1.05rem}
  input,select,textarea,button{padding:12px}
  #app{min-height:auto}
  .topbarNav{gap:8px}
  .menuBtn,.menuLinkBtn{font-size:.92rem}
}
