:root{
  --bg:#080b14;
  --bg-soft:#0f1424;
  --surface:rgba(18,24,42,.82);
  --surface-strong:rgba(24,32,55,.94);
  --surface-light:rgba(255,255,255,.055);
  --text:#f7f8ff;
  --muted:#aeb7cf;
  --soft:#dce4ff;
  --line:rgba(255,255,255,.12);
  --line-strong:rgba(255,255,255,.2);
  --primary:#7c3aed;
  --primary-2:#06b6d4;
  --accent:#f59e0b;
  --danger:#fb7185;
  --success:#34d399;
  --shadow:0 30px 100px rgba(0,0,0,.45);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(900px 520px at 8% -8%,rgba(124,58,237,.36),transparent 66%),
    radial-gradient(760px 460px at 92% 0%,rgba(6,182,212,.26),transparent 64%),
    radial-gradient(620px 520px at 55% 102%,rgba(245,158,11,.11),transparent 68%),
    linear-gradient(180deg,#080b14 0%,#0c1020 52%,#101827 100%);
  min-height:100vh;
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;
  background:linear-gradient(rgba(255,255,255,.032) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.032) 1px,transparent 1px);
  background-size:54px 54px;
  mask-image:linear-gradient(to bottom,rgba(0,0,0,.5),transparent 72%);
}
a{color:inherit;text-decoration:none}.container{width:min(1180px,calc(100% - 32px));margin:0 auto}.nav{min-height:84px;display:flex;align-items:center;justify-content:space-between;gap:18px;position:relative;z-index:2}.logo{display:flex;align-items:center;gap:12px;font-weight:950;font-size:22px;letter-spacing:-.04em}.logo-mark{width:46px;height:46px;border-radius:16px;background:linear-gradient(135deg,#7c3aed,#06b6d4);display:grid;place-items:center;color:white;font-weight:1000;box-shadow:0 18px 44px rgba(124,58,237,.3)}.nav-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--line);border-radius:16px;padding:12px 18px;font-weight:850;background:rgba(255,255,255,.055);color:var(--text);cursor:pointer;min-height:46px;transition:transform .15s ease,filter .15s ease,border-color .15s ease,background .15s ease}.btn:hover{transform:translateY(-1px);border-color:var(--line-strong);background:rgba(255,255,255,.09)}.btn-primary{background:linear-gradient(135deg,#7c3aed,#2563eb 52%,#06b6d4);color:#fff;border-color:transparent;box-shadow:0 16px 34px rgba(37,99,235,.24)}.btn-primary:hover{filter:brightness(1.08)}.btn-danger{background:rgba(251,113,133,.13);border-color:rgba(251,113,133,.34);color:#ffe5eb}.btn-soft{background:rgba(255,255,255,.08)}.hero{position:relative;z-index:1;padding:76px 0 42px;display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center}.eyebrow{color:#9ee7ff;font-weight:950;letter-spacing:.15em;text-transform:uppercase;font-size:12px;margin-bottom:16px}.section-label{color:#9ee7ff;font-weight:950;letter-spacing:.14em;text-transform:uppercase;font-size:12px;margin-bottom:10px}.hero h1,h1{font-size:clamp(42px,6vw,76px);line-height:.94;margin:0 0 20px;letter-spacing:-.07em}.auth-title{font-size:38px;line-height:1.02;margin:0 0 10px;letter-spacing:-.045em}.lead{color:var(--muted);font-size:20px;line-height:1.68;max-width:760px}.muted{color:var(--muted);line-height:1.6}.card{background:linear-gradient(180deg,var(--surface-strong),var(--surface));border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);backdrop-filter:blur(18px)}.panel{padding:30px}.grid{display:grid;gap:18px}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}.trust-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:28px}.trust-item{padding:16px;border:1px solid var(--line);border-radius:20px;background:rgba(255,255,255,.045)}.trust-item strong{display:block;font-size:22px;margin-bottom:4px}.preview{position:relative;overflow:hidden;min-height:430px}.preview::before{content:"";position:absolute;inset:-1px;background:radial-gradient(420px 240px at 30% 10%,rgba(124,58,237,.28),transparent 70%),radial-gradient(420px 260px at 90% 20%,rgba(6,182,212,.22),transparent 70%)}.preview-inner{position:relative;margin:28px;padding:24px;border-radius:24px;background:rgba(8,11,20,.72);border:1px solid var(--line)}.preview-top{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:20px}.preview-title{font-size:24px;font-weight:950;letter-spacing:-.04em}.preview-sub{color:var(--muted);font-size:14px;margin-top:4px}.mini-stat{padding:10px 12px;border-radius:16px;background:rgba(52,211,153,.12);border:1px solid rgba(52,211,153,.22);font-weight:900;color:#c8ffe9}.shift-list{display:grid;gap:12px}.shift-row{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;padding:14px;border-radius:18px;background:rgba(255,255,255,.055);border:1px solid var(--line)}.time{font-weight:950;color:#b9efff}.shift-name strong{display:block}.shift-name span{font-size:13px;color:var(--muted)}.places{font-weight:900;color:#e9ddff}.features{padding:48px 0 70px}.section-head{max-width:760px;margin-bottom:24px}.section-head h2{font-size:clamp(32px,4vw,52px);line-height:1;margin:0 0 14px;letter-spacing:-.055em}.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.feature-card{padding:24px}.icon-box{width:46px;height:46px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(124,58,237,.8),rgba(6,182,212,.75));font-weight:1000;margin-bottom:16px}.feature-card h3{font-size:21px;margin:0 0 10px;letter-spacing:-.03em}.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.step{padding:24px;border-left:3px solid rgba(6,182,212,.55)}.step-num{font-size:13px;font-weight:950;color:#9ee7ff;letter-spacing:.12em;text-transform:uppercase}.cta{margin:28px 0 70px;padding:34px;display:flex;align-items:center;justify-content:space-between;gap:22px}.cta h2{font-size:36px;margin:0 0 8px;letter-spacing:-.045em}.form{display:grid;gap:15px}label{font-size:13px;color:var(--muted);font-weight:850}input,textarea,select{width:100%;margin-top:7px;border:1px solid var(--line);border-radius:16px;background:rgba(7,12,25,.72);color:var(--text);padding:14px 15px;font-size:16px;outline:none}input:focus,textarea:focus,select:focus{border-color:rgba(6,182,212,.8);box-shadow:0 0 0 4px rgba(6,182,212,.14)}.flash{padding:14px 16px;border-radius:16px;margin:16px 0;border:1px solid var(--line);background:rgba(255,255,255,.06)}.flash.erfolg{border-color:rgba(52,211,153,.38);background:rgba(52,211,153,.11)}.flash.fehler{border-color:rgba(251,113,133,.38);background:rgba(251,113,133,.11)}.auth-wrap{min-height:calc(100vh - 84px);display:grid;place-items:center;padding:28px 0 70px}.auth-card{width:min(540px,100%);padding:34px}.dashboard{padding:38px 0 78px}.dash-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:22px}.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.tile{padding:24px}.tile strong{font-size:38px;display:block;margin-top:8px}.table-wrap{overflow:auto}.table{width:100%;border-collapse:collapse;min-width:680px}.table th,.table td{text-align:left;padding:14px;border-bottom:1px solid var(--line)}.table th{color:#cdd8f5;font-size:13px;text-transform:uppercase;letter-spacing:.08em}.empty{padding:24px;border:1px dashed var(--line-strong);border-radius:22px;background:rgba(255,255,255,.035);color:var(--muted)}.footer{padding:34px 0 44px;color:var(--muted);font-size:14px}.small-link{color:#9ee7ff;font-weight:850}.badge{display:inline-flex;align-items:center;border-radius:12px;padding:6px 9px;background:rgba(255,255,255,.07);border:1px solid var(--line);font-size:12px;font-weight:900}.badge.ok{background:rgba(52,211,153,.12);border-color:rgba(52,211,153,.25);color:#c8ffe9}.badge.warn{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.25);color:#ffe6b5}.error-code{color:#ffd6df;font-weight:950;letter-spacing:.12em;text-transform:uppercase;font-size:12px;margin-bottom:10px}@media(max-width:900px){.hero{grid-template-columns:1fr;padding-top:38px}.feature-grid,.steps,.tiles,.trust-row{grid-template-columns:1fr}.dash-head,.cta{display:grid}.nav{align-items:flex-start;padding:16px 0}.hero h1,h1{font-size:clamp(38px,12vw,58px)}}@media(max-width:560px){.container{width:min(100% - 24px,1180px)}.nav-actions{width:100%}.nav-actions .btn{flex:1}.logo{width:100%}.preview-inner{margin:14px;padding:16px}.shift-row{grid-template-columns:1fr}.hero-actions .btn{width:100%}.auth-card{padding:24px}.cta{padding:24px}}


/* ===== Dienstplan-Verwaltung ===== */
.plain-label{background:transparent!important;border:0!important;border-radius:0!important;padding:0!important;display:block!important}
.manager-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.manage-tiles{grid-template-columns:repeat(3,1fr)}.copy-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:end}.copy-row input{margin-top:0}.form-grid{grid-template-columns:repeat(3,1fr);align-items:end}.form-grid .wide{grid-column:1/-1}.item-list{display:grid;gap:12px}.manage-item{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px;border:1px solid var(--line);border-radius:20px;background:rgba(255,255,255,.045)}.manage-item form{margin:0}.shift-admin-list{display:grid;gap:16px}.shift-admin-card{padding:18px;border:1px solid var(--line);border-radius:24px;background:rgba(255,255,255,.045)}.shift-admin-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.people-list{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}.person-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:rgba(124,58,237,.10);border-radius:999px;padding:8px 10px;color:var(--soft);margin:0}.person-chip button{border:0;background:rgba(255,255,255,.1);color:var(--text);border-radius:999px;width:24px;height:24px;cursor:pointer;font-weight:950}.person-chip.public{background:rgba(6,182,212,.10)}.inline-form{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;align-items:end}.inline-form input{margin-top:0}.email-hint{padding:14px 16px;border-radius:18px;background:rgba(6,182,212,.09);border:1px solid rgba(6,182,212,.22);color:#dff8ff;line-height:1.55;margin:16px 0}
@media(max-width:900px){.manager-grid,.manage-tiles{grid-template-columns:1fr}.form-grid,.inline-form,.copy-row{grid-template-columns:1fr}.manage-item,.shift-admin-head{display:grid}.copy-row .btn,.inline-form .btn{width:100%}}


/* ===== ShiftFlow Dienstplan Studio / Public Plan ===== */
.sf-shell{padding:28px 0 76px}.sf-topbar{position:sticky;top:0;z-index:20;background:rgba(8,11,20,.72);backdrop-filter:blur(20px);border-bottom:1px solid var(--line)}.sf-plan-header{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:78px}.sf-plan-brand{display:flex;align-items:center;gap:14px;min-width:0}.sf-plan-logo{width:48px;height:48px;border-radius:18px;background:linear-gradient(135deg,var(--primary),#2563eb 45%,var(--primary-2));display:grid;place-items:center;font-weight:1000;box-shadow:0 18px 44px rgba(37,99,235,.22)}.sf-plan-title{font-weight:950;font-size:18px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sf-plan-sub{color:var(--muted);font-size:13px;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sf-dashboard{display:grid;grid-template-columns:278px minmax(0,1fr);gap:20px;align-items:start}.sf-sidebar{position:sticky;top:98px;padding:14px;background:linear-gradient(180deg,rgba(24,32,55,.92),rgba(12,16,32,.92))}.sf-side-brand{display:flex;gap:12px;align-items:center;border-bottom:1px solid var(--line);padding:10px 8px 14px;margin-bottom:10px}.sf-side-icon{width:42px;height:42px;border-radius:16px;display:grid;place-items:center;background:rgba(124,58,237,.16);border:1px solid rgba(124,58,237,.24)}.sf-nav-btn{width:100%;min-height:48px;display:flex;align-items:center;gap:10px;padding:12px 13px;border-radius:17px;background:transparent;border:1px solid transparent;color:var(--soft);font-weight:900;text-align:left;cursor:pointer}.sf-nav-btn:hover{background:rgba(255,255,255,.06);border-color:var(--line)}.sf-nav-btn.active{background:linear-gradient(135deg,rgba(124,58,237,.82),rgba(37,99,235,.7) 52%,rgba(6,182,212,.62));color:white;box-shadow:0 18px 40px rgba(37,99,235,.18)}.sf-content{display:grid;gap:18px;min-width:0}.sf-hero-panel{padding:26px;background:radial-gradient(420px 220px at 15% 0%,rgba(124,58,237,.2),transparent 72%),linear-gradient(180deg,var(--surface-strong),var(--surface))}.sf-hero-actions{display:flex;gap:10px;flex-wrap:wrap}.sf-admin-tab{display:grid;gap:18px}.sf-admin-tab[hidden]{display:none!important}.sf-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.sf-stat{padding:20px;position:relative;overflow:hidden}.sf-stat span{display:block;color:var(--muted);font-size:13px;font-weight:850}.sf-stat strong{display:block;font-size:34px;margin-top:8px}.sf-stat::after{content:"";position:absolute;right:-28px;top:-28px;width:92px;height:92px;border-radius:999px;background:rgba(6,182,212,.08)}.sf-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.sf-table-shell{overflow:auto;border-radius:22px;border:1px solid var(--line);background:rgba(255,255,255,.035)}.sf-table{width:100%;border-collapse:collapse;min-width:820px}.sf-table th,.sf-table td{padding:14px;border-bottom:1px solid var(--line);text-align:left}.sf-table th{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:#cdd8f5;background:rgba(0,0,0,.18)}.sf-row-actions{display:flex;gap:8px;flex-wrap:wrap}.sf-inline-card{padding:18px;border-radius:22px;border:1px solid var(--line);background:rgba(255,255,255,.04)}.sf-form-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px;align-items:end}.sf-col-2{grid-column:span 2}.sf-col-3{grid-column:span 3}.sf-col-4{grid-column:span 4}.sf-col-5{grid-column:span 5}.sf-col-6{grid-column:span 6}.sf-col-12{grid-column:1/-1}.sf-card-list{display:grid;gap:12px}.sf-admin-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;padding:16px;border-radius:22px;border:1px solid var(--line);background:rgba(255,255,255,.045)}.sf-admin-card.is-hidden{border-color:rgba(245,158,11,.32);background:rgba(245,158,11,.06);opacity:.8}.sf-muted{color:var(--muted)}.sf-chip{display:inline-flex;align-items:center;gap:6px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.06);padding:6px 10px;font-size:12px;font-weight:900;color:var(--soft)}.sf-chip.ok{background:rgba(52,211,153,.11);border-color:rgba(52,211,153,.24);color:#c8ffe9}.sf-chip.warn{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.25);color:#ffe6b5}.sf-switch-form{display:inline}.sf-icon-pill{width:40px;height:40px;border-radius:15px;display:grid;place-items:center;background:rgba(255,255,255,.07);border:1px solid var(--line);flex:0 0 40px}.sf-public-body{min-height:100vh}.sf-public-header{position:sticky;top:0;z-index:20;background:rgba(8,11,20,.72);backdrop-filter:blur(20px);border-bottom:1px solid var(--line)}.sf-public-title{padding:28px 0 18px}.sf-public-title h1{font-size:clamp(34px,5vw,64px);margin:0 0 10px}.sf-filter-panel{padding:20px;margin-bottom:20px}.sf-filter-grid{display:grid;grid-template-columns:2fr auto auto;gap:12px;align-items:end}.sf-category-section{display:grid;gap:14px;margin-top:20px}.sf-category-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:8px 2px}.sf-category-title{display:flex;align-items:center;gap:12px}.sf-service-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.sf-service-card{padding:18px;display:grid;gap:14px}.sf-service-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.sf-date-pill{display:inline-flex;align-items:center;gap:9px;border-radius:999px;border:1px solid rgba(6,182,212,.24);background:rgba(6,182,212,.09);padding:8px 12px;font-weight:950;color:#dff8ff}.sf-service-name{font-size:20px;font-weight:950;letter-spacing:-.03em}.sf-service-time{color:var(--muted);font-weight:800}.sf-people{display:flex;flex-wrap:wrap;gap:8px;min-height:12px}.sf-person{display:inline-flex;align-items:center;gap:8px;border-radius:999px;border:1px solid var(--line);background:rgba(124,58,237,.1);padding:8px 10px;max-width:100%}.sf-avatar{width:24px;height:24px;border-radius:999px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(124,58,237,.6),rgba(6,182,212,.45));font-size:12px;font-weight:950;flex:0 0 24px}.sf-person span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sf-full{opacity:.82}.sf-modal{position:fixed;inset:0;z-index:80;display:none}.sf-modal.is-open{display:block}.sf-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.62);backdrop-filter:blur(8px)}.sf-modal-panel{position:relative;z-index:1;width:min(720px,calc(100% - 28px));max-height:calc(100vh - 28px);overflow:auto;margin:7vh auto 0;padding:26px}.sf-modal-wide{width:min(1040px,calc(100% - 28px))}.sf-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.sf-modal-close{border:1px solid var(--line);background:rgba(255,255,255,.07);color:var(--text);border-radius:14px;width:44px;height:44px;cursor:pointer;font-size:22px}.sf-service-info{white-space:pre-wrap;line-height:1.7}.sf-public-note{font-size:13px;line-height:1.55;color:#dff8ff;background:rgba(6,182,212,.08);border:1px solid rgba(6,182,212,.2);padding:13px;border-radius:18px}.sf-admin-public-note{font-size:13px;line-height:1.55;color:#dff8ff;background:rgba(6,182,212,.08);border:1px solid rgba(6,182,212,.22);padding:14px;border-radius:18px}.sf-clean-link{color:#9ee7ff;font-weight:900}.sf-danger-mini{border:0;background:rgba(251,113,133,.18);color:#ffd7df;border-radius:999px;width:26px;height:26px;cursor:pointer;font-weight:950}.sf-person-form{display:inline-flex;gap:8px;align-items:center}.sf-person-form span{max-width:260px;overflow:hidden;text-overflow:ellipsis}.sf-public-actions{display:flex;gap:10px;flex-wrap:wrap}.sf-banner{padding:14px 16px;border-radius:20px;border:1px solid rgba(6,182,212,.23);background:rgba(6,182,212,.08);margin-bottom:18px}.sf-banner.warnung{border-color:rgba(245,158,11,.35);background:rgba(245,158,11,.1)}.sf-banner.fehler{border-color:rgba(251,113,133,.35);background:rgba(251,113,133,.1)}.sf-banner.erfolg{border-color:rgba(52,211,153,.35);background:rgba(52,211,153,.1)}
@media(max-width:980px){.sf-dashboard{grid-template-columns:1fr}.sf-sidebar{position:static;display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.sf-side-brand{display:none}.sf-stats{grid-template-columns:repeat(2,1fr)}.sf-service-grid{grid-template-columns:1fr}.sf-filter-grid{grid-template-columns:1fr}.sf-plan-header{display:grid}.sf-form-grid{grid-template-columns:1fr}.sf-col-2,.sf-col-3,.sf-col-4,.sf-col-5,.sf-col-6,.sf-col-12{grid-column:1/-1}.sf-admin-card{grid-template-columns:1fr}.sf-row-actions .btn,.sf-admin-card .btn{width:100%}}
@media(max-width:640px){.sf-sidebar{grid-template-columns:repeat(2,1fr)}.sf-stats{grid-template-columns:1fr}.sf-public-actions .btn,.sf-hero-actions .btn{width:100%}.sf-modal-panel{margin:14px auto 0;padding:20px}.sf-service-top{display:grid}.sf-table{min-width:720px}}

/* ===== ShiftFlow Original-Dienstplan Feinschliff ===== */
.sf-side-icon svg,.sf-nav-btn svg,.sf-icon-pill svg,.btn svg{width:19px;height:19px;stroke-width:2.3px}.sf-icon-pill svg{width:21px;height:21px}.sf-nav-btn svg{flex:0 0 19px}.sf-icon-select{font-weight:850}.sf-people{gap:.5rem .75rem;align-items:flex-start}.sf-person{display:inline-flex;align-items:center;gap:0;border:0!important;background:transparent!important;border-radius:0!important;padding:0!important;color:var(--soft);font-weight:850;box-shadow:none!important}.sf-person::before{content:'•';color:#9ee7ff;margin-right:.45rem;font-weight:1000}.sf-person span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sf-avatar{display:none!important}.sf-person-form{gap:.45rem}.sf-person-form .sf-danger-mini{margin-left:.2rem}.sf-filter-original{padding:22px}.sf-filter-header{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px}.sf-filter-title{display:flex;align-items:center;gap:14px}.sf-filter-layout{display:grid;gap:18px}.sf-search-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:12px;align-items:end}.sf-search-label span,.sf-filter-label{display:block;color:#cdd8f5;font-size:12px;text-transform:uppercase;letter-spacing:.11em;font-weight:950;margin-bottom:7px}.sf-filter-groups{display:grid;grid-template-columns:1fr 1fr;gap:18px}.sf-chipbar{display:flex;flex-wrap:wrap;gap:8px}.btn-chip{border-radius:999px;padding:9px 13px;min-height:40px;font-size:13px;background:rgba(255,255,255,.055)}.btn-chip.btn-primary{background:linear-gradient(135deg,rgba(124,58,237,.88),rgba(37,99,235,.72) 54%,rgba(6,182,212,.64));border-color:transparent;color:#fff}.sf-service-card .sf-people:empty{display:none}@media(max-width:760px){.sf-search-row,.sf-filter-groups{grid-template-columns:1fr}.sf-search-row .btn{width:100%}.sf-chipbar{overflow:auto;flex-wrap:nowrap;padding-bottom:4px}.sf-chipbar .btn{white-space:nowrap}}


/* ===== Professioneller Icon-Dropdown für Kategorien ===== */
.sf-icon-dropdown{position:relative;width:100%}
.sf-icon-dropdown-trigger{
  width:100%;
  min-height:48px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid var(--line);
  background:rgba(5,10,26,.72);
  color:var(--text);
  cursor:pointer;
  font:inherit;
  font-weight:900;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.sf-icon-dropdown-trigger:hover{border-color:rgba(6,182,212,.38);background:rgba(9,17,40,.86)}
.sf-icon-dropdown-trigger:focus{outline:0;border-color:rgba(34,211,238,.7);box-shadow:0 0 0 4px rgba(6,182,212,.14)}
.sf-icon-dropdown-trigger>svg{width:18px;height:18px;opacity:.8;transition:transform .18s ease}
.sf-icon-dropdown.is-open .sf-icon-dropdown-trigger>svg{transform:rotate(180deg)}
.sf-icon-dropdown-current{display:flex;align-items:center;gap:10px;min-width:0}
.sf-icon-preview{
  width:30px;
  height:30px;
  display:grid;
  place-items:center;
  border-radius:11px;
  background:linear-gradient(135deg,rgba(124,58,237,.22),rgba(6,182,212,.16));
  border:1px solid rgba(148,163,184,.16);
  color:#dff8ff;
  flex:0 0 30px;
}
.sf-icon-preview svg{width:18px;height:18px;stroke-width:2.4px}
.sf-icon-dropdown-menu{
  position:static;
  z-index:auto;
  display:none;
  max-height:285px;
  overflow:auto;
  margin-top:10px;
  padding:8px;
  border-radius:18px;
  border:1px solid rgba(148,163,184,.18);
  background:linear-gradient(180deg,rgba(17,25,50,.98),rgba(8,13,30,.98));
  box-shadow:0 18px 48px rgba(0,0,0,.32), inset 0 1px 0 rgba(255,255,255,.04);
  backdrop-filter:blur(16px);
}
.sf-icon-dropdown.is-open .sf-icon-dropdown-menu{display:grid;gap:5px}
.sf-icon-option{
  width:100%;
  min-height:44px;
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  border:1px solid transparent;
  border-radius:14px;
  background:transparent;
  color:var(--text);
  cursor:pointer;
  text-align:left;
  font:inherit;
}
.sf-icon-option strong{font-size:14px;font-weight:900;line-height:1.1}
.sf-icon-option:hover{background:rgba(255,255,255,.06);border-color:rgba(148,163,184,.14)}
.sf-icon-option.is-selected{
  background:linear-gradient(135deg,rgba(124,58,237,.26),rgba(6,182,212,.16));
  border-color:rgba(34,211,238,.34);
}
.sf-icon-option.is-selected .sf-icon-preview{border-color:rgba(34,211,238,.45);background:rgba(6,182,212,.16);color:#fff}
@media(max-width:640px){.sf-icon-dropdown-menu{max-height:240px}}

/* ===== Icon-Dropdown Overlap-Fix v2 =====
   Das Dropdown bleibt im normalen Seitenfluss und drückt die darunterliegenden Kategorien nach unten. */
.sf-icon-dropdown{
  position:relative !important;
  width:100% !important;
  z-index:2;
}
.sf-icon-dropdown.is-open{
  z-index:20;
}
.sf-icon-dropdown .sf-icon-dropdown-menu{
  position:relative !important;
  inset:auto !important;
  top:auto !important;
  left:auto !important;
  right:auto !important;
  bottom:auto !important;
  transform:none !important;
  z-index:1 !important;
  width:100% !important;
  margin-top:10px !important;
  display:none !important;
  max-height:285px !important;
  overflow:auto !important;
}
.sf-icon-dropdown.is-open .sf-icon-dropdown-menu{
  display:grid !important;
  gap:5px !important;
}
.sf-form-grid:has(.sf-icon-dropdown.is-open){
  align-items:start;
}
.card.panel:has(.sf-icon-dropdown.is-open){
  overflow:visible;
}
.sf-card-list{
  position:relative;
  z-index:1;
}

/* ===== ShiftFlow Mobile-Pro-Fix v3: keine Verzerrung, keine Überläufe ===== */
@media (max-width: 820px){
  html, body{
    width:100%;
    max-width:100%;
    overflow-x:hidden !important;
  }
  body{
    -webkit-text-size-adjust:100%;
    text-size-adjust:100%;
  }
  body::before{background-size:38px 38px;}
  .container,
  main.container,
  header .container{
    width:100% !important;
    max-width:100% !important;
    margin-left:0 !important;
    margin-right:0 !important;
    padding-left:16px !important;
    padding-right:16px !important;
  }
  .card,
  .panel,
  .sf-hero-panel,
  .sf-filter-panel,
  .sf-service-card,
  .sf-sidebar,
  .sf-admin-card,
  .sf-stat,
  .auth-card,
  .tile{
    max-width:100% !important;
    overflow-wrap:anywhere;
  }
  .panel{padding:20px !important;}
  .btn{
    max-width:100%;
    min-height:48px;
    padding:12px 14px;
    white-space:normal;
    text-align:center;
    line-height:1.18;
  }
  input, textarea, select{
    max-width:100%;
    min-width:0;
    font-size:16px;
  }
  h1, h2, h3, p, .lead, .muted, .sf-muted, .sf-plan-title, .sf-plan-sub, .sf-service-name{
    overflow-wrap:anywhere;
    word-break:normal;
  }
  .lead{font-size:18px;line-height:1.45;}
  .sf-shell{padding-top:18px !important;padding-bottom:56px !important;}

  /* Header / Topbar */
  .nav,
  .sf-plan-header{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:12px !important;
    align-items:stretch !important;
    min-width:0 !important;
  }
  .sf-plan-brand,
  .logo{
    min-width:0;
    width:100%;
  }
  .sf-plan-brand > span:last-child,
  .logo > span:last-child{
    min-width:0;
  }
  .sf-plan-title,
  .sf-plan-sub{
    display:block;
    max-width:100%;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  .nav-actions,
  .sf-public-actions,
  .sf-hero-actions{
    display:grid !important;
    grid-template-columns:1fr !important;
    width:100% !important;
    gap:10px !important;
  }
  .nav-actions .btn,
  .sf-public-actions .btn,
  .sf-public-actions a.btn,
  .sf-hero-actions .btn,
  .hero-actions .btn{
    width:100% !important;
  }

  /* Dashboard-Navigation als saubere mobile Kacheln */
  .sf-dashboard{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:18px !important;
    width:100% !important;
  }
  .sf-sidebar{
    position:relative !important;
    top:auto !important;
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    gap:10px !important;
    padding:14px !important;
    border-radius:24px !important;
  }
  .sf-side-brand{
    grid-column:1 / -1;
    display:flex !important;
    min-width:0;
  }
  .sf-nav-btn{
    width:100% !important;
    min-width:0 !important;
    justify-content:center !important;
    text-align:center !important;
    padding:12px 8px !important;
    min-height:52px !important;
    font-size:14px !important;
    line-height:1.1 !important;
    white-space:normal !important;
  }
  .sf-nav-btn svg{flex:0 0 18px;}
  .sf-content{min-width:0;width:100%;}
  .sf-toolbar{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:18px !important;
    min-width:0 !important;
  }
  .sf-hero-panel{padding:24px 20px !important;}
  .sf-hero-panel h1,
  .sf-public-title h1{
    font-size:clamp(34px, 13vw, 50px) !important;
    line-height:.98 !important;
    letter-spacing:-.055em !important;
  }
  .sf-stats,
  .tiles,
  .feature-grid,
  .steps,
  .trust-row,
  .manager-grid,
  .manage-tiles{
    grid-template-columns:1fr !important;
  }

  /* Formulare */
  .sf-form-grid,
  .form-grid,
  .copy-row{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:14px !important;
  }
  .sf-col-2,.sf-col-3,.sf-col-4,.sf-col-5,.sf-col-6,.sf-col-12,
  .form-grid .wide{
    grid-column:1 / -1 !important;
  }
  .copy-row .btn,
  .sf-form-grid .btn,
  .form .btn{
    width:100% !important;
  }

  /* Listen/Karten */
  .sf-admin-card,
  .manage-item,
  .shift-admin-head,
  .sf-category-head,
  .sf-service-top{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:12px !important;
    align-items:start !important;
  }
  .sf-admin-card form,
  .manage-item form,
  .sf-admin-card .btn,
  .manage-item .btn,
  .sf-row-actions,
  .sf-row-actions .btn{
    width:100% !important;
  }
  .sf-row-actions{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:10px !important;
  }

  /* Öffentliche Planseite */
  .sf-public-title{
    padding:42px 0 22px !important;
  }
  .sf-filter-original,
  .sf-filter-panel{
    padding:20px 18px !important;
    margin-bottom:22px !important;
    overflow:hidden !important;
  }
  .sf-filter-header,
  .sf-filter-title{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:12px !important;
    align-items:start !important;
  }
  .sf-filter-title .sf-icon-pill{
    width:48px;
    height:48px;
  }
  .sf-search-row,
  .sf-filter-groups,
  .sf-filter-layout{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:16px !important;
  }
  .sf-search-row .btn{
    width:100% !important;
  }
  .sf-chipbar{
    display:flex !important;
    flex-wrap:wrap !important;
    overflow:visible !important;
    gap:10px !important;
    padding-bottom:0 !important;
    max-width:100% !important;
  }
  .sf-chipbar .btn,
  .sf-chipbar .btn-chip{
    flex:0 1 auto !important;
    max-width:100% !important;
    min-width:0 !important;
    white-space:normal !important;
    overflow-wrap:anywhere !important;
  }
  .sf-service-grid{
    grid-template-columns:1fr !important;
    gap:16px !important;
  }
  .sf-service-card{
    padding:18px !important;
  }
  .sf-date-pill,
  .sf-chip{
    max-width:100%;
    white-space:normal;
    overflow-wrap:anywhere;
  }
  .sf-service-card .btn-primary{
    width:100% !important;
  }
  .sf-people{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:6px !important;
  }
  .sf-person span{
    white-space:normal !important;
    overflow:visible !important;
    text-overflow:clip !important;
  }

  /* Tabellen: auf Mobil nicht den gesamten Screen sprengen */
  .table-wrap,
  .sf-table-wrap{
    width:100% !important;
    max-width:100% !important;
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch;
  }
  .table,
  .sf-table{
    min-width:0 !important;
    width:100% !important;
  }
  .table thead,
  .sf-table thead{
    display:none !important;
  }
  .table tr,
  .sf-table tr{
    display:block;
    border:1px solid var(--line);
    border-radius:18px;
    background:rgba(255,255,255,.035);
    margin:0 0 12px;
    padding:8px;
  }
  .table td,
  .sf-table td{
    display:block;
    border-bottom:0 !important;
    padding:8px !important;
    text-align:left !important;
  }

  /* Modals */
  .sf-modal-panel{
    width:calc(100vw - 24px) !important;
    max-width:calc(100vw - 24px) !important;
    margin:12px auto 0 !important;
    padding:20px !important;
    max-height:calc(100dvh - 24px) !important;
    overflow:auto !important;
  }
  .sf-modal-head{
    display:grid !important;
    grid-template-columns:1fr auto !important;
    gap:12px !important;
  }
}

@media (max-width: 430px){
  .container,
  main.container,
  header .container{
    padding-left:12px !important;
    padding-right:12px !important;
  }
  .panel,
  .sf-hero-panel,
  .sf-filter-panel,
  .sf-service-card,
  .auth-card{
    padding:18px !important;
    border-radius:22px !important;
  }
  .sf-sidebar{grid-template-columns:1fr !important;}
  .sf-nav-btn{justify-content:flex-start !important;text-align:left !important;padding-left:14px !important;}
  .sf-public-title h1,
  .sf-hero-panel h1{
    font-size:clamp(32px, 12vw, 44px) !important;
  }
  .lead{font-size:17px;}
  .btn{padding:11px 12px;}
  .sf-chipbar .btn-chip{font-size:14px;padding:10px 13px;}
}


/* ===== ShiftFlow echtes Logo + Footer ===== */
.logo{display:inline-flex;align-items:center;gap:0;width:auto!important;min-width:0;text-decoration:none}
.logo-mark{display:none!important}
.site-logo-img{display:block;height:56px;width:auto;max-width:240px;object-fit:contain}
.nav{align-items:center}
.sf-plan-logo{width:auto!important;height:auto!important;border-radius:0!important;background:transparent!important;box-shadow:none!important;border:0!important;display:inline-flex!important;place-items:initial!important;flex:0 0 auto!important;padding:0!important}
.sf-plan-logo-img{display:block;height:50px;width:auto;max-width:230px;object-fit:contain}
.sf-plan-brand{align-items:center}
.site-footer{margin-top:70px;padding:42px 0;border-top:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,rgba(8,11,20,.08),rgba(8,11,20,.34))}
.site-footer-inner{display:grid;place-items:center;text-align:center;gap:18px}
.site-footer-logo img{display:block;height:42px;width:auto;max-width:210px;object-fit:contain}
.site-footer-links{display:flex;justify-content:center;align-items:center;gap:18px;flex-wrap:wrap}
.site-footer-links a{color:var(--muted);font-weight:850;text-decoration:none}
.site-footer-links a:hover{color:var(--text)}
.site-footer-copy{color:rgba(203,213,245,.62);font-size:14px}
@media(max-width:900px){.site-logo-img{height:48px}.sf-plan-logo-img{height:44px}.sf-plan-brand{max-width:100%}}
@media(max-width:560px){.nav{align-items:center}.logo{width:auto!important}.site-logo-img{height:42px;max-width:180px}.sf-plan-logo-img{height:38px;max-width:170px}.site-footer{margin-top:44px;padding:32px 0}.site-footer-logo img{height:34px}.site-footer-links{gap:12px;font-size:14px}}


/* ===== Rechtliche Seiten / Kontakt ===== */
.legal-layout{display:grid;gap:22px;max-width:980px;margin:0 auto}.legal-hero{padding:32px}.legal-card{padding:28px}.legal-card h2{font-size:28px;margin:0 0 14px;letter-spacing:-.035em}.legal-card h3{font-size:20px;margin:24px 0 10px}.legal-card p,.legal-card li{color:var(--muted);line-height:1.75}.legal-card ul{margin:8px 0 18px;padding-left:22px}.legal-meta{display:grid;grid-template-columns:220px 1fr;gap:10px 18px;margin-top:18px}.legal-meta dt{color:#cdd8f5;font-weight:950}.legal-meta dd{margin:0;color:var(--muted)}.placeholder{display:inline-block;min-width:220px;border-bottom:1px dashed rgba(203,213,245,.45);color:#dbeafe}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.contact-box{padding:22px;border-radius:22px;background:rgba(255,255,255,.045);border:1px solid var(--line)}.contact-field{display:block;margin-top:8px;color:#dbeafe;font-weight:900}.legal-note{border-left:3px solid rgba(6,182,212,.65);padding:14px 16px;background:rgba(6,182,212,.08);border-radius:16px;color:#dff8ff!important}
@media(max-width:760px){.legal-hero,.legal-card{padding:22px}.legal-meta{grid-template-columns:1fr}.contact-grid{grid-template-columns:1fr}.placeholder{min-width:160px}.legal-card h2{font-size:24px}}
