/* ============================================================
   KSK FARMOS — style.css v3.5
   Calibrated spacing · Glass buttons · Scroll animations
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,500;0,600;0,700;1,500;1,600&family=Inter:wght@300;400;450;500;600&display=swap');

/* ── DESIGN TOKENS ─────────────────────────────────────────── */
:root {
  --white:#f6efe9;
  --off-white:#fdfaf7;
  --gray-50:#efe6de;
  --gray-100:#e3d8cd;
  --gray-200:#d4c8be;
  --gray-400:#9898b0;
  --gray-600:#5c5c78;
  --gray-800:#2a2a3a;
  --gray-900:#1a1a28;
  --black:#0d0d18;
  --violet:#6b3fa0;
  --violet-mid:#7c50b5;
  --violet-light:#9d76d4;
  --violet-pale:#f0eaf9;
  --violet-alpha:rgba(107,63,160,0.10);
  --text-primary:#0d0d18;
  --text-secondary:#3d3d55;
  --text-muted:#7a7a94;
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Inter',system-ui,-apple-system,sans-serif;
  --shadow-xs:0 1px 3px rgba(0,0,0,0.05);
  --shadow-sm:0 2px 8px rgba(0,0,0,0.06),0 1px 3px rgba(0,0,0,0.04);
  --shadow-md:0 8px 24px rgba(0,0,0,0.08),0 2px 8px rgba(0,0,0,0.04);
  --shadow-lg:0 24px 56px rgba(0,0,0,0.10),0 8px 20px rgba(0,0,0,0.05);
  --shadow-violet:0 8px 32px rgba(107,63,160,0.25);
  --r-sm:8px;--r-md:14px;--r-lg:20px;--r-xl:28px;--r-2xl:40px;--r-full:9999px;

  /* 8px spacing grid */
  --sp-1:8px;--sp-2:16px;--sp-3:24px;--sp-4:32px;
  --sp-5:40px;--sp-6:48px;--sp-7:56px;--sp-8:64px;
  --sp-10:80px;--sp-12:96px;--sp-16:128px;

  --header-h:72px;
  --max-w:1200px;
  --pad-x:clamp(20px,5vw,64px);
  --section-gap:clamp(64px,8vw,112px);

  --ease:cubic-bezier(0.25,0.46,0.45,0.94);
  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --ease-expo:cubic-bezier(0.22,1,0.36,1);
  --ease-spring:cubic-bezier(0.34,1.56,0.64,1);
  --t-fast:160ms;--t-base:280ms;--t-slow:520ms;
}

/* ── RESET ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip}
body{font-family:var(--sans);font-size:16px;line-height:1.65;color:var(--text-primary);background:var(--white);-webkit-font-smoothing:antialiased;overflow-x:clip}
img{display:block;max-width:100%;height:auto}
picture{display:block;width:100%;height:100%}
picture img{width:100%;height:100%;object-fit:cover}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{font-family:var(--sans)}

/* ── TYPOGRAPHY ─────────────────────────────────────────────── */
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.25;letter-spacing:-0.02em;color:var(--text-primary);margin-bottom:1.5rem;overflow-wrap:break-word;word-break:break-word}
h1{font-size:clamp(3.2rem, 6vw, 5.2rem);line-height:1.12}
h2{font-size:clamp(2rem,3.5vw,3.1rem)}
h3{font-size:clamp(1.25rem,2vw,1.6rem)}
h4{font-size:1.05rem;font-family:var(--sans);font-weight:600;letter-spacing:-0.01em;line-height:1.4;margin-bottom:1rem}
p{color:var(--text-secondary);line-height:1.75;margin-bottom:1.25rem}
.lead{font-size:1.15rem;color:var(--text-secondary);font-weight:400;line-height:1.8;max-width:650px;margin-bottom:2rem}
.text-sm{font-size:0.875rem}.text-xs{font-size:0.78rem}.text-muted{color:var(--text-muted)}.text-center{text-align:center}.text-white{color:white}
.section-tag{display:inline-block;font-family:var(--sans);font-size:0.70rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--violet);margin-bottom:1.75rem}
.service-group-label {
  font-family: var(--sans);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--violet);
  margin-top: 2.5rem;
  margin-bottom: 1.25rem;
}

/* ── LAYOUT ─────────────────────────────────────────────────── */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 var(--pad-x)}
.section{padding:var(--section-gap) 0}
.section-gray{background:var(--gray-50)}
.section-white{background:#ffffff}
.section-dark{background:var(--gray-900);color:white}
.section-dark h2,.section-dark h3,.section-dark h4{color:white}
.section-dark p{color:rgba(255,255,255,0.65)}
.section-violet{background:var(--violet);color:white}
.section-violet h2,.section-violet h3{color:white}
.section-violet p{color:rgba(255,255,255,0.82)}
.section-header{max-width:640px;margin-bottom:clamp(32px,5vw,56px)}
.section-header.centered{margin-left:auto;margin-right:auto;text-align:center}
.section-header h2{margin-bottom:var(--sp-4)}
.section-header p{font-size:1.05rem;max-width:540px;margin-top:var(--sp-2)}
.section-header.centered p{margin-left:auto;margin-right:auto}

/* ── GRIDS ──────────────────────────────────────────────────── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,88px);align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.5vw,28px)}
.flex-grid-3{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(16px,2.5vw,28px)}
.flex-grid-3 > *{flex:0 1 calc(33.333% - 20px);min-width:300px;max-width:380px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2vw,20px)}
.flex-center{display:flex;align-items:center;justify-content:center}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.mb-sm{margin-bottom:var(--sp-2)}.mb-md{margin-bottom:var(--sp-4)}.mb-lg{margin-bottom:var(--sp-6)}

/* ── STICKY MEDIA LAYOUT UTILS ────────────────────────────────── */
@media (min-width: 992px) {
  .media-left {
    align-items: start;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
  }
  .media-left > :first-child {
    order: 2;
  }
  .media-left > :last-child {
    order: 1;
  }
  .sticky-media > :last-child {
    position: sticky;
    top: 100px;
  }
}

/* ── PHOTO PLACEHOLDERS ─────────────────────────────────────── */
.photo-placeholder{width:100%;min-height:300px;background:var(--gray-50);border:1.5px dashed var(--gray-200);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;text-align:center;padding:var(--sp-4);color:var(--text-muted);font-size:0.85rem;line-height:1.5;object-fit:cover}
.photo-placeholder.ph-tall{min-height:480px}.photo-placeholder.ph-short{min-height:220px}.photo-placeholder.ph-square{min-height:0;aspect-ratio:1/1}
.ph-4-5{aspect-ratio:4/5;min-height:0}.ph-4-3{aspect-ratio:4/3;min-height:0}.ph-1-1{aspect-ratio:1/1;min-height:0}

/* ── CARDS ───────────────────────────────────────────────────── */
.card{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--r-lg);padding:var(--sp-5) var(--sp-4);transition:transform 0.35s ease,box-shadow 0.35s ease,border-color 0.35s ease}
.card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,0.08);border-color:transparent;transition:transform 0.35s ease,box-shadow 0.35s ease,border-color 0.35s ease}
.card-icon{width:48px;height:48px;background:var(--violet-pale);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-3);color:var(--violet);flex-shrink:0;transition:transform 0.35s ease, background 0.3s ease}
.card:hover .card-icon{transform:translateY(-2px);background:var(--violet);color:var(--white)}
.card-icon svg{width:22px;height:22px;stroke-width:1.5}
.card h3{font-size:1.15rem;margin-bottom:var(--sp-1);line-height:1.25}
.card p{font-size:0.9rem;line-height:1.72;color:var(--text-muted)}
.card-centered{text-align:center;display:flex;flex-direction:column;align-items:center}
.card-img{padding:0;overflow:hidden;border-radius:var(--r-2xl);background:var(--white);box-shadow:var(--shadow-md);transition:transform 0.35s ease,box-shadow 0.35s ease}
.card-img:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,0.08);transition:transform 0.35s ease,box-shadow 0.35s ease}
.card-img .card-photo{width:100%;aspect-ratio:4/3;overflow:hidden;background:var(--gray-100)}
.card-img .card-photo img{width:100%;height:100%;object-fit:cover}
.card-img .card-body{padding:var(--sp-4) var(--sp-4) var(--sp-5)}
.card-img .card-body h3{margin-bottom:var(--sp-1)}
.card-img .card-body p{margin-bottom:var(--sp-3)}

/* ── BUTTONS ─────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--sans);font-size:0.9rem;font-weight:500;letter-spacing:0.01em;
  border:none;cursor:pointer;text-decoration:none;border-radius:var(--r-full);
  padding:14px 28px;line-height:1;white-space:nowrap;
  transition:transform 0.35s ease,box-shadow 0.35s ease,background 0.35s ease,border-color 0.35s ease,color 0.35s ease;
  position:relative;overflow:hidden;
  -webkit-mask-image: -webkit-radial-gradient(white, black);
}
.btn:hover{transition:transform 0.35s ease,box-shadow 0.35s ease,background 0.35s ease,border-color 0.35s ease,color 0.35s ease}
/* shimmer sweep */
.btn::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 35%,rgba(255,255,255,0.22) 50%,transparent 65%);transform:translateX(-100%);pointer-events:none;transition:transform 0.55s ease}
.btn:hover::after{transform:translateX(100%)}

.btn svg{width:16px;height:16px;stroke-width:2;flex-shrink:0;transition:transform 0.35s ease}
.btn:hover svg{transform:translateX(3px)}



/* Primary — solid violet */
.btn-primary{background:var(--violet);color:white;box-shadow:0 1px 2px rgba(107,63,160,0.25),0 4px 14px rgba(107,63,160,0.28),inset 0 1px 0 rgba(255,255,255,0.18)}
.btn-primary:hover{transform:translateY(-2px);background:var(--violet-mid);box-shadow:0 8px 24px rgba(107,63,160,0.28),inset 0 1px 0 rgba(255,255,255,0.2)}

/* Outline */
.btn-outline{background:transparent;color:var(--text-primary);border:1.5px solid var(--gray-200);box-shadow:none;padding:12.5px 26px;transition:transform 0.35s ease,border-color 0.35s ease,color 0.35s ease,background 0.35s ease}
.btn-outline:hover{border-color:var(--violet);color:var(--violet);background:var(--violet-alpha);box-shadow:var(--shadow-sm);transform:translateY(-2px)}

/* Glass — frosted on light bg */
.btn-glass{
  background:transparent !important;
  color:var(--text-primary);
  border:1px solid rgba(255,255,255,0.95);
  box-shadow:0 1px 2px rgba(0,0,0,0.06),0 4px 14px rgba(0,0,0,0.06),inset 0 1px 0 rgba(255,255,255,1),inset 0 -1px 0 rgba(0,0,0,0.03);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translate3d(0, 0, 0);
  -webkit-transform: translate3d(0, 0, 0);
  -webkit-mask-image: none !important;
  mask-image: none !important;
  overflow: visible !important;
}
.btn-glass::after{
  display: none !important;
}
.btn-glass::before{
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:rgba(255,255,255,0.62);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  z-index:-1;
  transition:background 0.35s ease;
  will-change:transform,opacity;
  transform: translate3d(0, 0, 0);
  -webkit-transform: translate3d(0, 0, 0);
}
.btn-glass:hover{
  transform: translate3d(0, -2px, 0);
  -webkit-transform: translate3d(0, -2px, 0);
  box-shadow:0 6px 20px rgba(0,0,0,0.08),inset 0 1px 0 rgba(255,255,255,1);
}
.btn-glass:hover::before{
  background:rgba(255,255,255,0.88);
}

/* Glass Dark — frosted on violet/dark bg */
.btn-glass-dark{
  background:transparent !important;
  color:white;
  border:1px solid rgba(255,255,255,0.22);
  box-shadow:0 1px 2px rgba(0,0,0,0.18),0 4px 18px rgba(0,0,0,0.14),inset 0 1px 0 rgba(255,255,255,0.18),inset 0 -1px 0 rgba(0,0,0,0.08);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translate3d(0, 0, 0);
  -webkit-transform: translate3d(0, 0, 0);
  -webkit-mask-image: none !important;
  mask-image: none !important;
  overflow: visible !important;
}
.btn-glass-dark::after{
  display: none !important;
}
.btn-glass-dark::before{
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:rgba(255,255,255,0.12);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  z-index:-1;
  transition:background 0.35s ease,border-color 0.35s ease;
  will-change:transform,opacity;
  transform: translate3d(0, 0, 0);
  -webkit-transform: translate3d(0, 0, 0);
}
.btn-glass-dark:hover{
  transform: translate3d(0, -2px, 0);
  -webkit-transform: translate3d(0, -2px, 0);
  border-color:rgba(255,255,255,0.38);
  box-shadow:0 6px 20px rgba(0,0,0,0.2),inset 0 1px 0 rgba(255,255,255,0.22);
}
.btn-glass-dark:hover::before{
  background:rgba(255,255,255,0.20);
}

/* Sizes */
.btn-sm{padding:9px 20px;font-size:0.82rem}.btn-sm.btn-outline{padding:7.5px 18px}
.btn-lg{padding:17px 36px;font-size:0.96rem}.btn-xl{padding:19px 44px;font-size:1rem;letter-spacing:0.015em}

/* ── HEADER ──────────────────────────────────────────────────── */
.header{position:fixed;top:0;left:0;right:0;height:var(--header-h);z-index:100;background:transparent;border-bottom:1px solid transparent}
.header.scrolled{background:rgba(255,255,255,0.90);backdrop-filter:blur(24px) saturate(200%);-webkit-backdrop-filter:blur(24px) saturate(200%);border-bottom:1px solid rgba(0,0,0,0.06);box-shadow:0 1px 28px rgba(0,0,0,0.05)}
.header-inner{display:flex;align-items:center;height:100%;gap:clamp(16px,3vw,40px);padding:0 var(--pad-x);max-width:var(--max-w);margin:0 auto}
.logo{display:flex;align-items:center;gap:12px;flex-shrink:0}
.logo img{height:36px;width:auto}
.logo-text{font-family:var(--sans);font-weight:700;font-size:1.02rem;color:var(--text-primary);line-height:1.1}
.logo-text span{display:block;font-size:0.60rem;font-weight:500;text-transform:uppercase;letter-spacing:0.12em;color:var(--text-muted);margin-top:2px}
.nav{display:flex;align-items:center;gap:2px;margin-left:auto;margin-right:auto}
.nav-link{display:inline-flex;align-items:center;gap:4px;padding:9px 16px;font-size:0.9rem;font-weight:450;color:var(--text-primary);border-radius:var(--r-full);white-space:nowrap}
.nav-link:hover{color:var(--violet);background:rgba(107,63,160,0.06)}
.nav-link.active{color:var(--violet)}
.chevron{font-size:0.68em;opacity:0.55}
.nav-mega{position:relative}
.mega-panel{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(10px);min-width:300px;background:rgba(0,0,0,0.45) !important;backdrop-filter:blur(16px) saturate(130%) !important;-webkit-backdrop-filter:blur(16px) saturate(130%) !important;border:1.5px solid rgba(255,255,255,0.12) !important;border-radius:var(--r-lg);box-shadow:0 12px 40px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;padding:6px;opacity:0;visibility:hidden;pointer-events:none;transition:all 0.4s cubic-bezier(0.16, 1, 0.3, 1)}
.nav-mega:hover .mega-panel,.nav-mega.open .mega-panel{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.nav-mega .chevron{transition:transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1)}
.nav-mega:hover .chevron{transform:rotate(180deg)}
.mega-item{display:block;padding:13px 16px;border-radius:var(--r-md);transition:background 0.3s ease}
.mega-item:hover{background:rgba(255,255,255,0.1) !important}
.mega-item strong{display:block;font-size:0.9rem;font-weight:600;color:#ffffff !important;margin-bottom:2px}
.mega-item span{font-size:0.78rem;color:rgba(255,255,255,0.65) !important}
.header-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.lang-selector{position:relative}
.lang-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;font-size:0.82rem;font-weight:500;color:var(--text-primary);border-radius:var(--r-full);cursor:pointer;background:transparent;border:none;font-family:var(--sans);transition:background 0.3s ease}
.lang-btn:hover{background:rgba(107,63,160,0.06)}
.lang-btn svg{width:14px;height:14px;transition:transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1)}
.lang-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:rgba(0,0,0,0.45) !important;backdrop-filter:blur(16px) saturate(130%) !important;-webkit-backdrop-filter:blur(16px) saturate(130%) !important;border:1.5px solid rgba(255, 255, 255, 0.12) !important;border-radius:var(--r-md);box-shadow:0 12px 40px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;padding:6px;min-width:130px;display:flex;flex-direction:column;gap:2px;z-index:200;opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-8px);transition:opacity 0.25s ease,transform 0.25s ease}
.lang-selector.open .lang-dropdown{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0)}
.lang-dropdown a{display:block;padding:8px 12px;border-radius:var(--r-sm);font-size:0.82rem;color:rgba(255, 255, 255, 0.85) !important;transition:all 0.3s ease}
.lang-dropdown a:hover,.lang-dropdown a.active{background:rgba(255,255,255,0.1) !important;color:#cbb5f0 !important}
.mobile-toggle{display:none;flex-direction:column;gap:5px;width:36px;height:36px;cursor:pointer;align-items:center;justify-content:center;background:none;border:none}
.mobile-toggle span{width:22px;height:1.5px;background:var(--text-primary);border-radius:2px;transition:transform var(--t-base) var(--ease-out),opacity var(--t-base) var(--ease-out);transform-origin:center}
.mobile-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.mobile-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.mobile-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mobile-menu{position:fixed;inset:0;background:rgba(0,0,0,0.65) !important;backdrop-filter:blur(16px) saturate(130%) !important;-webkit-backdrop-filter:blur(16px) saturate(130%) !important;z-index:99;padding:calc(var(--header-h) + 60px) var(--pad-x) 40px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;opacity:0;visibility:hidden;transition:opacity 0.35s ease,visibility 0.35s ease}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu .nav-link{font-size:1.8rem;padding:14px 20px;font-family:var(--serif);font-weight:500;color:rgba(255,255,255,0.9);transition:color 0.3s ease, transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1)}
.mobile-menu .nav-link:hover,
.mobile-menu .nav-link.active{color:var(--violet-light);background:transparent}
.mobile-menu .btn{margin-top:20px;align-self:center}
.mobile-lang{margin-top:auto;padding-top:28px;border-top:1px solid var(--gray-100);display:grid;grid-template-columns:repeat(5,1fr);gap:6px}
.mobile-lang a{text-align:center;padding:9px;font-size:0.78rem;border-radius:var(--r-sm);background:var(--gray-50);color:var(--text-secondary)}
.mobile-lang a:hover{background:var(--violet-pale);color:var(--violet)}

/* ── HEADER OPEN MOBILE STYLES ───────────────────────────────── */
.header.menu-open,
.header.scrolled.menu-open,
.header.header-transparent-allowed.menu-open,
.header.header-transparent-allowed.scrolled.menu-open {
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-bottom: 1px solid transparent !important;
  box-shadow: none !important;
  transition: none !important;
}
.header.menu-open .logo-text,
.header.scrolled.menu-open .logo-text,
.header.header-transparent-allowed.menu-open .logo-text,
.header.header-transparent-allowed.scrolled.menu-open .logo-text {
  color: white !important;
}
.header.menu-open .logo-text span,
.header.scrolled.menu-open .logo-text span,
.header.header-transparent-allowed.menu-open .logo-text span,
.header.header-transparent-allowed.scrolled.menu-open .logo-text span {
  color: rgba(255, 255, 255, 0.6) !important;
}
.header.menu-open .logo img,
.header.scrolled.menu-open .logo img,
.header.header-transparent-allowed.menu-open .logo img,
.header.header-transparent-allowed.scrolled.menu-open .logo img {
  filter: invert(1) grayscale(1) brightness(10) !important;
  mix-blend-mode: screen !important;
}
.header.menu-open .mobile-toggle span,
.header.scrolled.menu-open .mobile-toggle span,
.header.header-transparent-allowed.menu-open .mobile-toggle span,
.header.header-transparent-allowed.scrolled.menu-open .mobile-toggle span {
  background: white !important;
}

/* Hide chat widget when mobile menu is open */
.mobile-menu.open ~ #ksk-chat,
.header.menu-open ~ #ksk-chat {
  display: none !important;
}


/* ── HERO ─────────────────────────────────────────────────────── */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;padding-top:var(--header-h);background:var(--white);overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.hero-bg::before{content:'';position:absolute;width:800px;height:800px;top:-280px;right:-220px;background:radial-gradient(circle,rgba(107,63,160,0.08) 0%,transparent 68%);border-radius:50%;filter:blur(48px)}
.hero-bg::after{content:'';position:absolute;width:560px;height:560px;bottom:-180px;left:-120px;background:radial-gradient(circle,rgba(157,118,212,0.07) 0%,transparent 68%);border-radius:50%;filter:blur(48px)}
.hero-inner{position:relative;z-index:1;width:100%;display:grid;grid-template-columns:1.1fr 0.9fr;gap:clamp(40px,5vw,80px);align-items:center;padding:clamp(56px,8vh,112px) 0}
@media (max-width: 992px) {
  .hero-inner.centered{grid-template-columns:1fr;text-align:center;justify-items:center;padding:clamp(64px,10vh,112px) 0}
  .hero-inner.centered .hero-content{max-width:720px}
  .hero-inner.centered .hero-subtitle{max-width:580px;margin-left:auto;margin-right:auto}
  .hero-inner.centered .hero-actions{justify-content:center}
}
.hero-overline{display:inline-flex;align-items:center;gap:10px;padding:7px 18px 7px 12px;background:var(--violet-pale);border-radius:var(--r-full);font-size:0.76rem;font-weight:500;color:var(--violet);margin-bottom:var(--sp-4);letter-spacing:0.025em}
.hero-overline::before{content:'';width:6px;height:6px;background:var(--violet);border-radius:50%;box-shadow:0 0 0 4px rgba(107,63,160,0.15);flex-shrink:0}
.hero-title{margin-bottom:var(--sp-3)}
.hero-title em{font-style:italic;color:var(--violet);font-weight:500}
.hero-subtitle{font-size:1.1rem;color:var(--text-secondary);line-height:1.8;margin-bottom:var(--sp-5);max-width:420px}
body, h1, h2, h3, h4, h5, h6, p, li, a, span, em, cite, .hero-title, .hero-subtitle, .hero-content h1, .hero-content p {
  word-break: normal !important;
  overflow-wrap: break-word !important;
  hyphens: none !important;
  -webkit-hyphens: none !important;
}
.hero-visual{position:relative}
.hero-photo{aspect-ratio:4/5;border-radius:var(--r-xl);overflow:hidden}
.hero-photo img,.hero-photo .photo-placeholder{width:100%;height:100%;object-fit:cover;border-radius:var(--r-xl);min-height:0}
.hero-visual:hover .hero-photo img{transform:scale(1.03)}
.hero-badge{position:absolute;bottom:clamp(20px,3vw,32px);left:clamp(-12px,-2vw,-20px);background:rgba(0, 0, 0, 0.45) !important;backdrop-filter:blur(16px) saturate(130%) !important;-webkit-backdrop-filter:blur(16px) saturate(130%) !important;border:1.5px solid rgba(255, 255, 255, 0.12) !important;border-radius:var(--r-md);padding:14px 20px;box-shadow:0 12px 40px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;display:flex;align-items:center;gap:14px;-webkit-backface-visibility: hidden;backface-visibility: hidden;transform: translate3d(0, 0, 0);-webkit-transform: translate3d(0, 0, 0);}
.hero-badge-icon{width:38px;height:38px;background:rgba(167, 139, 250, 0.15) !important;color:#cbb5f0 !important;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hero-badge-icon svg{width:18px;height:18px;stroke-width:1.5}
.hero-badge-text strong{display:block;font-size:0.88rem;font-weight:600;color:#ffffff !important;margin-bottom:1px}
.hero-badge-text span{font-size:0.74rem;color:rgba(255,255,255,0.65) !important}

/* ── HERO CUTOUT VARIANT (BeautyGlanz Style) ────────────────── */
.hero-cutout{position:relative;min-height:100svh;display:flex;align-items:center;padding-top:var(--header-h);background:var(--off-white);overflow:hidden}
.hero-cutout .hero-inner{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:clamp(56px,8vh,112px) 0;position:relative;z-index:2;min-height:calc(100vh - var(--header-h))}
.hero-cutout .hero-content {
  max-width: 650px;
  position: relative;
  z-index: 3;
}
@media (min-width: 993px) {
  .hero-cutout .hero-content {
    margin-left: -120px;
  }
  html[dir="rtl"] .hero-cutout .hero-content {
    margin-left: 0;
    margin-right: -120px;
  }
}
@media (max-width: 992px) {
  .hero-cutout .hero-inner.centered {
    align-items: center;
    text-align: center;
  }
  .hero-cutout .hero-inner.centered .hero-content {
    margin-left: auto;
    margin-right: auto;
  }
  .hero-cutout .hero-inner.centered .hero-subtitle {
    margin-left: auto;
    margin-right: auto;
  }
  .hero-cutout .hero-inner.centered .hero-actions {
    justify-content: center;
  }
}
.hero-cutout .hero-title{font-size:clamp(4.2rem, 9vw, 6.2rem);line-height:1.05;margin-bottom:var(--sp-4);font-family:var(--serif);color:var(--text-primary);letter-spacing:-0.03em}
.hero-cutout .hero-title em{font-style:italic;color:var(--violet);font-weight:500}
.hero-cutout .hero-subtitle{font-size:1.05rem;color:var(--text-secondary);line-height:1.8;margin-bottom:var(--sp-5);max-width:550px}
.hero-cutout .hero-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}

.hero-cutout .hero-photo-abs{position:absolute;z-index:1;pointer-events:none}
.hero-cutout .hero-photo-abs img{width:100%;height:auto;display:block;object-fit:contain;object-position:bottom right}

/* Hero 1 (Index) - smaller */
.hero-photo-1{right:0;bottom:0;width:45vw;max-width:600px}
/* Hero 2 (Leistungen) - mirrored and much smaller */
.hero-photo-2{right:5%;bottom:0;width:35vw;max-width:500px;transform:scaleX(-1)}
/* Hero 3 (Ueber Uns) - larger on desktop */
.hero-photo-3{right:0;bottom:0;width:60vw;max-width:850px}

@media (max-width: 992px) {
  /* ── SCROLL-OVER HERO EFFECT ──────────────────────────────── */
  /* Hero stays fixed while content scrolls over it */
  .hero-cutout {
    position: sticky !important;
    top: 0 !important;
    z-index: 1 !important;
    min-height: 100svh !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-end !important;
    align-items: stretch !important;
    overflow: hidden !important;
    background: transparent !important; /* Safari fix: don't put background on sticky element */
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  /* Pseudo-element for black background to prevent Safari safe-area bleed */
  .hero-cutout::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: #000;
    z-index: -1;
    pointer-events: none;
  }
  /* All sections after hero scroll over it */
  .hero-cutout ~ section,
  .hero-cutout ~ .section-edge-photo {
    position: relative !important;
    z-index: 2 !important;
  }
  /* Footer is outside <main>, needs explicit z-index */
  .footer {
    position: relative;
    z-index: 2;
  }
  /* Ensure all content sections have opaque backgrounds */
  .hero-cutout ~ .section { background-color: var(--white); }
  .hero-cutout ~ .section-gray { background-color: var(--gray-50) !important; }
  .hero-cutout ~ .section-white { background-color: #ffffff !important; }
  .hero-cutout ~ .section-dark { background-color: var(--gray-900) !important; }
  .hero-cutout ~ .section-violet { background-color: var(--violet) !important; }
  .hero-cutout ~ .section-compact { background-color: var(--gray-50); }
  .hero-cutout ~ .section-edge-photo { background-color: rgb(var(--bg-rgb, 246, 239, 233)) !important; }
  /* Depth shadow on first content section */
  .hero-cutout + section,
  .hero-cutout + .section-edge-photo {
    box-shadow: 0 -20px 40px rgba(0, 0, 0, 0.15) !important;
  }
  .hero-cutout .container {
    padding: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  .hero-cutout .hero-inner {
    display: block !important;
    min-height: 100svh !important;
    width: 100% !important;
    position: relative !important;
    z-index: 3 !important;
    padding: 0 !important;
  }
  .hero-cutout .hero-content {
    position: static !important;
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    color: #ffffff !important;
  }
  .hero-cutout .hero-title {
    position: absolute !important;
    top: 50% !important;
    left: 16px !important;
    right: 16px !important;
    transform: translateY(-50%) !important;
    height: 120px !important;
    margin: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    text-align: center !important;
    z-index: 5 !important;
    letter-spacing: -0.02em !important;
    color: #ffffff !important;
    text-shadow: 
      0 2px 4px rgba(0, 0, 0, 0.65), 
      0 0 10px rgba(255, 255, 255, 0.65), 
      0 0 20px rgba(255, 255, 255, 0.35),
      0 4px 15px rgba(0, 0, 0, 0.4) !important;
    line-height: 1.15 !important;
  }
  .hero-cutout .hero-title .ht-line {
    display: block !important;
    white-space: nowrap !important;
  }
  /* Legacy span/em support */
  .hero-cutout .hero-title > span:not(.ht-line),
  .hero-cutout .hero-title > em:not(.ht-line) {
    display: inline-block !important;
    white-space: nowrap !important;
  }
  .hero-cutout .hero-title em,
  .hero-cutout .hero-title .ht-line em,
  em.ht-line {
    color: #cbb5f0 !important;
    font-style: italic !important;
    font-weight: 600 !important;
    text-shadow: 
      0 2px 4px rgba(0, 0, 0, 0.5), 
      0 0 8px rgba(255, 255, 255, 0.55),
      0 0 16px rgba(157, 118, 212, 0.9), 
      0 0 35px rgba(157, 118, 212, 0.5),
      0 4px 15px rgba(0, 0, 0, 0.3) !important;
  }
  .hero-cutout .hero-subtitle {
    position: absolute !important;
    top: calc(50% + 68px) !important; /* 60px half height of title + 8px gap */
    left: 16px !important;
    right: 16px !important;
    height: 70px !important;
    margin: 0 auto !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    align-items: center !important;
    text-align: center !important;
    z-index: 5 !important;
    color: rgba(255, 255, 255, 0.92) !important;
    text-shadow: 
      0 2px 4px rgba(0, 0, 0, 0.65), 
      0 0 10px rgba(255, 255, 255, 0.65), 
      0 0 20px rgba(255, 255, 255, 0.35),
      0 4px 15px rgba(0, 0, 0, 0.4) !important;
    line-height: 1.45 !important;
  }
  .hero-cutout .hero-subtitle .sub-line {
    display: block !important;
    white-space: nowrap !important;
  }
  .hero-cutout .hero-actions {
    position: absolute !important;
    top: calc(50% + 154px) !important; /* 68px + 70px (subtitle height) + 16px gap */
    left: 16px !important;
    right: 16px !important;
    margin: 0 auto !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 8px !important;
    z-index: 5 !important;
    opacity: 1 !important;
    transform: none !important;
  }
  .hero-cutout .hero-actions .btn {
    width: 100% !important;
    max-width: 280px !important;
    padding: 12.5px 16px !important;
    font-size: 0.9rem !important;
    white-space: nowrap !important;
    justify-content: center !important;
  }
  .hero-cutout .btn-outline {
    color: #ffffff !important;
    border-color: rgba(255, 255, 255, 0.4) !important;
    background: transparent !important;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: translate3d(0, 0, 0);
    -webkit-transform: translate3d(0, 0, 0);
    -webkit-mask-image: none !important;
    mask-image: none !important;
    overflow: visible !important;
  }
  .hero-cutout .btn-outline::after {
    display: none !important;
  }
  .hero-cutout .btn-outline::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: rgba(255, 255, 255, 0.08) !important;
    backdrop-filter: blur(5px) !important;
    -webkit-backdrop-filter: blur(5px) !important;
    z-index: -1;
    transition: background 0.35s ease;
    will-change: transform, opacity;
    transform: translate3d(0, 0, 0);
    -webkit-transform: translate3d(0, 0, 0);
  }
  .hero-cutout .btn-outline:hover {
    border-color: #ffffff !important;
  }
  .hero-cutout .btn-outline:hover::before {
    background: rgba(255, 255, 255, 0.18) !important;
  }
  .hero-photo-1, .hero-photo-2, .hero-photo-3 {
    display: none !important;
  }
  @media (max-width: 360px) {
    .hero-cutout .hero-actions {
      flex-direction: column !important;
    }
    .hero-cutout .hero-actions .btn {
      width: 100% !important;
      max-width: 280px !important;
    }
  }
  .header {
    background: rgba(255, 255, 255, 0.90) !important;
    backdrop-filter: blur(24px) saturate(200%) !important;
    -webkit-backdrop-filter: blur(24px) saturate(200%) !important;
    border-bottom: 1px solid rgba(0,0,0,0.06) !important;
    box-shadow: 0 1px 28px rgba(0,0,0,0.05) !important;

  }

  .header.header-transparent-allowed {
    background: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border-bottom: 1px solid transparent !important;
    box-shadow: none !important;
  }
  .header.header-transparent-allowed .logo-text {
    color: #ffffff !important;
  }
  .header.header-transparent-allowed .logo-text span {
    color: rgba(255, 255, 255, 0.70) !important;
  }
  .header.header-transparent-allowed .mobile-toggle span {
    background: #ffffff !important;
  }

  .header.header-transparent-allowed.scrolled {
    background: rgba(255, 255, 255, 0.90) !important;
    backdrop-filter: blur(24px) saturate(200%) !important;
    -webkit-backdrop-filter: blur(24px) saturate(200%) !important;
    border-bottom: 1px solid rgba(0,0,0,0.06) !important;
    box-shadow: 0 1px 28px rgba(0,0,0,0.05) !important;
  }
  .header.header-transparent-allowed.scrolled .logo-text {
    color: var(--text-primary) !important;
  }
  .header.header-transparent-allowed.scrolled .logo-text span {
    color: var(--text-muted) !important;
  }
  .header.header-transparent-allowed.scrolled .mobile-toggle span {
    background: var(--text-primary) !important;
  }

  .header.menu-open,
  .header.scrolled.menu-open,
  .header.header-transparent-allowed.menu-open,
  .header.header-transparent-allowed.scrolled.menu-open {
    background: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border-bottom: 1px solid transparent !important;
    box-shadow: none !important;
    transition: none !important;
  }
  .header.menu-open .logo-text,
  .header.scrolled.menu-open .logo-text,
  .header.header-transparent-allowed.menu-open .logo-text,
  .header.header-transparent-allowed.scrolled.menu-open .logo-text {
    color: #ffffff !important;
  }
  .header.menu-open .logo-text span,
  .header.scrolled.menu-open .logo-text span,
  .header.header-transparent-allowed.menu-open .logo-text span,
  .header.header-transparent-allowed.scrolled.menu-open .logo-text span {
    color: rgba(255, 255, 255, 0.70) !important;
  }
  .header.menu-open .mobile-toggle span,
  .header.scrolled.menu-open .mobile-toggle span,
  .header.header-transparent-allowed.menu-open .mobile-toggle span,
  .header.header-transparent-allowed.scrolled.menu-open .mobile-toggle span {
    background: #ffffff !important;
  }
}



/* ── SUBPAGE HERO ────────────────────────────────────────────── */
.sub-hero{position:relative;background:var(--off-white);padding:calc(var(--header-h) + 56px) 0 0;overflow:hidden}
.sub-hero .hero-inner{padding-bottom:clamp(48px,7vh,96px)}
.hero-photo{position:relative;width:100%;aspect-ratio:4/5;border-radius:var(--r-2xl);overflow:hidden;box-shadow:var(--shadow-lg);background:var(--gray-100)}
.hero-photo img{width:100%;height:100%;object-fit:cover;display:block}
.hero-photo:hover img{transform:scale(1.05)}
.page-hero{background:var(--off-white);padding:calc(var(--header-h) + 72px) 0 72px;border-bottom:1px solid var(--gray-100)}
.page-hero h1{margin-bottom:var(--sp-2);max-width:700px}
.page-hero .lead{max-width:580px;margin-top:var(--sp-2)}

/* ── EDITORIAL ACCENT ────────────────────────────────────────── */
.editorial-accent {
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
}
.editorial-accent p {
  font-family: var(--serif);
  font-size: clamp(1.2rem, 3.2vw, 1.75rem);
  line-height: 1.5;
  color: var(--text-primary);
}

/* ── IMAGE BOX ───────────────────────────────────────────────── */
.image-box{position:relative;width:85%;margin:0 auto;aspect-ratio:4/5;border-radius:var(--r-2xl);overflow:hidden;box-shadow:var(--shadow-lg);background:var(--gray-100)}
.image-box img{width:100%;height:100%;object-fit:cover;display:block}
.image-box:hover img{transform:scale(1.05)}

.editorial-accent::before {
  content: '';
  display: block;
  width: 40px;
  height: 2px;
  background: var(--violet);
  margin: 0 auto 1.5rem auto;
}
.editorial-accent p {
  color: var(--text-secondary);
}
.editorial-accent strong {
  font-weight: 600;
  color: var(--text-primary);
}
.section-compact {
  padding: clamp(40px, 5vw, 64px) 0;
}

/* ── CHECK LIST ─────────────────────────────────────────────── */
.check-list {
  list-style: none;
  margin: 2rem 0;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.check-list li {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}
.check-icon {
  flex-shrink: 0;
  width: 8px;
  height: 8px;
  background: var(--violet);
  border-radius: 50%;
  margin-top: 10px;
}
.check-icon svg {
  display: none;
}
.check-list strong {
  display: block;
  font-weight: 600;
  font-size: 1.05rem;
  color: var(--text-primary);
  margin-bottom: 2px;
}
.check-list span {
  font-size: 0.95rem;
  color: var(--text-muted);
  line-height: 1.6;
}

/* ── QUOTE BLOCK ─────────────────────────────────────────────── */
.quote-block {
  padding: 0 0 0 1.5rem;
  background: transparent;
  border-left: 2px solid var(--violet);
  margin: 2.5rem 0;
}
.quote-block p {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.2rem;
  line-height: 1.6;
  color: var(--text-primary);
}
.quote-block cite {
  display: block;
  margin-top: 0.75rem;
  font-size: 0.75rem;
  font-family: var(--sans);
  color: var(--violet);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
}

/* ── PROCESS STEPS ───────────────────────────────────────────── */
.process-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.5vw,24px);position:relative}
.process-steps::before{content:'';position:absolute;top:38px;left:calc(16.66% + 16px);right:calc(16.66% + 16px);height:1px;background:var(--gray-100);z-index:0}
.process-step{padding:var(--sp-5) var(--sp-4);background:var(--white);border:1px solid var(--gray-100);border-radius:var(--r-lg);position:relative;z-index:1;transition:transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.5s ease, border-color 0.3s ease}
.process-step:hover{box-shadow:var(--shadow-lg);border-color:transparent;transform:translateY(-6px) scale(1.02)}
.process-num{font-family:var(--serif);font-size:2.8rem;font-weight:700;color:rgba(107, 63, 160, 0.22);line-height:1;margin-bottom:var(--sp-3);letter-spacing:-0.04em}
.process-step:hover .process-num{color:rgba(107, 63, 160, 0.45)}
.process-step h3{font-family:var(--sans);font-size:1.02rem;font-weight:600;margin-bottom:8px}
.process-step p{font-size:0.87rem;line-height:1.72;color:var(--text-muted)}

/* ── FAQ ACCORDION ───────────────────────────────────────────── */
.faq-list{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--gray-100);overflow:hidden}
.faq-item:first-child{border-top:1px solid var(--gray-100)}
.faq-question{width:100%;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);padding:var(--sp-4) 0;text-align:left;font-family:var(--serif);font-size:1.12rem;font-weight:500;color:var(--text-primary)}
.faq-question:hover{color:var(--violet)}
.faq-toggle{flex-shrink:0;width:32px;height:32px;border-radius:50%;background:var(--off-white);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:transform 0.35s ease,background 0.35s ease,color 0.35s ease}
.faq-toggle svg{width:14px;height:14px;stroke-width:2}
.faq-item.open .faq-toggle{background:var(--violet);color:white;transform:rotate(45deg)}
.faq-answer{max-height:0;opacity:0;overflow:hidden;transition:max-height 0.45s cubic-bezier(0.22, 1, 0.36, 1),opacity 0.45s cubic-bezier(0.22, 1, 0.36, 1)}
.faq-item.open .faq-answer{opacity:1}
.faq-answer-inner{padding:0 0 var(--sp-4);color:var(--text-secondary);line-height:1.78;font-size:0.93rem}
.faq-answer-inner .btn{margin-top:var(--sp-2)}
.faq-search-wrap{position:relative;margin-bottom:var(--sp-2)}
.faq-search-wrap svg{position:absolute;left:18px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--text-muted);stroke-width:1.5;pointer-events:none}
.faq-search{width:100%;padding:15px 20px 15px 50px;border:1.5px solid var(--gray-100);border-radius:var(--r-full);font-family:var(--sans);font-size:0.93rem;color:var(--text-primary);background:var(--off-white);margin-bottom:0}
.faq-search:focus{outline:none;background:var(--white);border-color:var(--violet);box-shadow:0 0 0 4px var(--violet-alpha)}
.faq-cats{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:var(--sp-5);justify-content:center}
.faq-cat{position:relative;overflow:hidden;padding:8px 18px;font-size:0.80rem;font-weight:500;color:var(--text-secondary);background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-full);cursor:pointer}
.faq-cat::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 35%,rgba(255,255,255,0.22) 50%,transparent 65%);transform:translateX(-100%);pointer-events:none}
.faq-cat:hover{background:var(--violet);color:white;border-color:var(--violet)}
.faq-cat.active{background:var(--violet);color:white;border-color:var(--violet)}

.faq-top-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:var(--sp-6)}

/* ── FORMS ───────────────────────────────────────────────────── */
.form-card{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--r-xl);padding:clamp(32px,5vw,52px);box-shadow:var(--shadow-md)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-2)}
.form-group{margin-bottom:var(--sp-3)}
.form-label{display:block;font-size:0.80rem;font-weight:500;color:var(--text-secondary);margin-bottom:7px;letter-spacing:0.01em}
.form-group input:not([type="checkbox"]):not([type="radio"]),.form-group select,.form-group textarea{width:100%;padding:13px 18px;border:1.5px solid var(--gray-100);border-radius:var(--r-md);font-family:var(--sans);font-size:0.93rem;color:var(--text-primary);background:var(--off-white);-webkit-appearance:none;appearance:none;transition:all 0.3s ease}
.form-group input:not([type="checkbox"]):not([type="radio"]):focus,.form-group select:focus,.form-group textarea:focus{outline:none;background:var(--white);border-color:var(--violet);box-shadow:0 0 0 4px rgba(107,63,160,0.10)}
.form-group textarea{resize:vertical;min-height:110px;line-height:1.65}
.form-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%239898b0' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;cursor:pointer}
.form-check{display:flex;align-items:flex-start;gap:12px;cursor:pointer}
.form-check input[type="checkbox"]{width:18px;height:18px;margin-top:4px;accent-color:var(--violet);cursor:pointer}
.form-check span{font-size:0.9rem;color:var(--text-secondary);line-height:1.6}

/* ── WIZARD ──────────────────────────────────────────────────── */
.wizard-steps{display:flex;align-items:center;gap:0;margin-bottom:var(--sp-4)}
.wizard-dot{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.85rem;font-weight:600;flex-shrink:0}
.wizard-dot.done{background:rgba(21,128,61,0.12);color:#15803d;border:1.5px solid #15803d}
.wizard-dot.active{background:var(--violet);color:white;border:none;box-shadow:0 4px 14px rgba(107,63,160,0.3)}
.wizard-dot.pending{background:var(--gray-100);color:var(--text-secondary);border:1.5px solid var(--gray-200)}
.wizard-line{flex:1;height:2px;background:var(--gray-200)}
.wizard-line.done{background:rgba(21,128,61,0.3)}
.wizard-panel{display:none}
.wizard-panel.active{display:block}


/* ── FOOTER ──────────────────────────────────────────────────── */
.footer{background:var(--gray-900);color:rgba(255,255,255,0.7);padding:var(--sp-12) 0 var(--sp-4)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1.2fr 1fr;gap:clamp(32px,5vw,56px);margin-bottom:var(--sp-10)}
.footer h4{color:white;font-size:0.72rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;margin-bottom:var(--sp-3)}
.footer-brand .logo-text{color:white}
.footer-brand .logo-text span{color:white}
.footer-brand p{color:rgba(255,255,255,0.50);font-size:0.88rem;line-height:1.75;margin-top:var(--sp-2);max-width:270px}
.footer-brand .logo img{filter:invert(1) grayscale(1) brightness(10);mix-blend-mode:screen}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-links a,.footer-contact a,.footer-contact p{color:rgba(255,255,255,0.50);font-size:0.86rem;line-height:1.6;margin:0}
.footer-links a:hover,.footer-contact a:hover{color:white}
.footer-contact{display:flex;flex-direction:column;gap:10px}
.footer-bottom{padding-top:var(--sp-4);border-top:1px solid rgba(255,255,255,0.08);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer-bottom span{font-size:0.80rem;color:rgba(255,255,255,0.35)}
.footer-social{display:flex;gap:20px;align-items:center;margin-top:6px}
.footer-social a{color:rgba(255,255,255,0.35);transition:color 0.3s ease,transform 0.3s ease;display:flex;align-items:center;justify-content:center}
.footer-social a:hover{color:#fff;transform:translateY(-2px)}
.footer-social i,.footer-social svg{width:20px;height:20px}
.footer-lang{display:flex;gap:4px;flex-wrap:wrap}
.footer-lang a{font-size:0.76rem;color:rgba(255,255,255,0.40);padding:4px 9px;border-radius:var(--r-sm)}
.footer-lang a:hover,.footer-lang a.active{color:white;background:rgba(255,255,255,0.08)}


/* ── LENIS SMOOTH SCROLL SUPPORT ─────────────────────────────── */
html.lenis { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-smooth [data-lenis-prevent] { overscroll-behavior: contain; }
.lenis.lenis-stopped { overflow: hidden; }

/* ── SCROLL REVEAL ───────────────────────────────────────────── */
/* ── SCROLL REVEAL ANIMATIONS ────────────────────────────────── */
.reveal, .reveal-left, .reveal-right, .reveal-scale {
  opacity: 0;
  transform: translateY(50px);
  transition: opacity 1.2s cubic-bezier(0.16, 1, 0.3, 1), transform 1.2s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal.visible, .reveal-left.visible, .reveal-right.visible, .reveal-scale.visible {
  opacity: 1;
  transform: translateY(0);
}

/* Hero elements specific reveal (appears from inside) */
.hero-content .reveal, .hero-content .reveal-scale {
  transform: scale(0.92);
}
.hero-content .reveal.visible, .hero-content .reveal-scale.visible {
  transform: scale(1);
}

/* Stagger Delays (Both legacy reveal-d and new stagger- classes) */
.reveal-d1{transition-delay:100ms}.reveal-d2{transition-delay:200ms}.reveal-d3{transition-delay:300ms}.reveal-d4{transition-delay:400ms}.reveal-d5{transition-delay:500ms}
.stagger-1{transition-delay:.15s}.stagger-2{transition-delay:.3s}.stagger-3{transition-delay:.45s}.stagger-4{transition-delay:.6s}
.stagger-5{transition-delay:.75s}.stagger-6{transition-delay:.9s}.stagger-7{transition-delay:1.05s}.stagger-8{transition-delay:1.2s}

/* ── UTILITIES ───────────────────────────────────────────────── */
.divider{width:56px;height:2px;background:var(--violet);margin:var(--sp-3) 0}
.divider.centered{margin:var(--sp-3) auto}
.link-arrow{display:inline-flex;align-items:center;gap:6px;color:var(--violet);font-weight:500;font-size:0.88rem;transition:all 0.3s ease}
.link-arrow:hover{gap:10px}
.link-arrow svg{width:15px;height:15px}

/* ── DUAL CTA ─────────────────────────────────────────────────── */
.dual-cta{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-md)}
.dual-cta-left{background:var(--violet);color:white;padding:clamp(36px,5vw,64px);display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px}
.dual-cta-left h2,.dual-cta-left h3{color:white}
.dual-cta-left p{color:rgba(255,255,255,0.72)}
.dual-cta-right{background:var(--off-white);padding:clamp(36px,5vw,64px);display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px}
.dual-cta-left .btn, .dual-cta-right .btn{margin-top:auto}

/* ── ANCHOR NAV ─────────────────────────────────────────────── */
.anchor-nav{position:sticky;top:var(--header-h);z-index:40;background:rgba(246, 239, 233, 0.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--gray-100);border-top:1px solid var(--gray-100);padding:14px 0;margin-top:var(--sp-2)}
.anchor-pills{display:flex;justify-content:center;gap:10px;max-width:var(--max-w);margin:0 auto;padding:0 var(--pad-x);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.anchor-pills::-webkit-scrollbar{display:none}
.anchor-pill{display:inline-flex;align-items:center;padding:10px 24px;font-size:0.85rem;font-weight:500;font-family:var(--sans);color:var(--text-secondary);background:var(--gray-50);border:1px solid var(--gray-100);border-radius:var(--r-full);cursor:pointer;white-space:nowrap;flex-shrink:0}
.anchor-pill:hover,.anchor-pill.active{background:var(--violet);color:white;border-color:var(--violet)}

/* ── VACANCY LIST ────────────────────────────────────────────── */
.vacancy-list{display:flex;flex-direction:column;gap:0}
.vacancy-item{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-3) 0;border-bottom:1px solid var(--gray-100)}
.vacancy-item:first-child{border-top:1px solid var(--gray-100)}
.vacancy-info{flex:1}
.vacancy-info h3{font-family:var(--sans);font-size:0.97rem;font-weight:600;margin-bottom:8px;color:var(--text-primary)}
.vacancy-tags{display:flex;gap:6px;flex-wrap:wrap}
.vacancy-tag{display:inline-block;padding:3px 11px;font-size:0.73rem;font-weight:500;color:var(--violet);background:var(--violet-pale);border:1px solid rgba(107,63,160,0.18);border-radius:var(--r-full)}

/* ── COMPONENT SPECIFICS ─────────────────────────────────────── */
.service-group-label{font-size:0.68rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--violet);margin-bottom:10px;margin-top:var(--sp-3)}
.service-group-label:first-child{margin-top:0}

.gallery-scroll{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,2vw,20px)}
.benefit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3.5vw,44px)}
.benefit-item h3{font-family:var(--sans);font-size:1.08rem;font-weight:600;margin-bottom:8px;color:var(--text-primary)}
.benefit-item p{font-size:0.88rem;color:var(--text-muted);line-height:1.72}
.leitbild-row{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.leitbild-item{padding:var(--sp-3) var(--sp-2);border:1px solid var(--gray-100);border-radius:var(--r-md)}
.leitbild-item:hover{border-color:transparent;box-shadow:var(--shadow-lg)}
.leitbild-item h3{font-family:var(--sans);font-size:0.9rem;font-weight:600;margin-bottom:6px}
.leitbild-item p{font-size:0.80rem;color:var(--text-muted);line-height:1.6}
.kosten-cols{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}
.kosten-list{display:flex;flex-direction:column;gap:var(--sp-4);max-width:900px;margin:0 auto}
.kosten-item{display:flex;align-items:flex-start;gap:var(--sp-4);padding:var(--sp-5);background:var(--white);border:1px solid var(--gray-100);border-radius:var(--r-xl)}
.kosten-item:hover{border-color:transparent;box-shadow:var(--shadow-lg)}
.kosten-item .kosten-icon{width:56px;height:56px;background:var(--violet-pale);color:var(--violet);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.kosten-item .kosten-icon svg{width:26px;height:26px;stroke-width:1.5}
.kosten-item h3{font-family:var(--sans);font-size:1.1rem;font-weight:600;margin-bottom:10px}
.kosten-item p{font-size:0.95rem;color:var(--text-secondary);line-height:1.75}
@media (max-width:768px){
  .kosten-item{flex-direction:column;gap:var(--sp-3);align-items:center;text-align:center}
  .kosten-item ul{display:inline-block;text-align:left;list-style-position:outside;margin:8px 0 0 0 !important;padding-left:1.2rem}
}
.fort-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.fort-grid.center{display:flex;flex-wrap:wrap;justify-content:center;gap:14px}
.fort-grid.center .fort-item{flex:0 1 calc(25% - 11px);min-width:250px}
@media(max-width:1024px){.fort-grid.center .fort-item{flex:0 1 calc(50% - 7px)}}
@media(max-width:768px){.fort-grid.center .fort-item{flex:0 1 100%}}
.fort-item{padding:var(--sp-3) var(--sp-2);border:1px solid var(--gray-100);border-radius:var(--r-md);background:var(--white)}
.fort-item:hover{border-color:var(--violet-pale);box-shadow:var(--shadow-lg)}
.fort-item h3{font-family:var(--sans);font-size:0.9rem;font-weight:600;margin-bottom:5px;color:var(--text-primary)}
.fort-item p{font-size:0.80rem;color:var(--text-muted);line-height:1.6}

/* ── FLOATING LANG (dropdown, opens UP) ─────────────────────── */
.lang-float{position:fixed;bottom:24px;left:24px;z-index:90}
.lang-float-btn{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:6px;padding:10px 18px;background:rgba(0, 0, 0, 0.45) !important;backdrop-filter:blur(16px) saturate(130%) !important;-webkit-backdrop-filter:blur(16px) saturate(130%) !important;border:1.5px solid rgba(255, 255, 255, 0.12) !important;border-radius:var(--r-full);box-shadow:none !important;font-family:var(--sans);font-size:0.82rem;font-weight:500;color:#ffffff !important;cursor:pointer}
.lang-float-btn::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 35%,rgba(255,255,255,0.22) 50%,transparent 65%);transform:translateX(-100%);pointer-events:none}
.lang-float-btn:hover{box-shadow:none !important;background:rgba(255, 255, 255, 0.1) !important;border-color:rgba(255, 255, 255, 0.25) !important}
.lang-float-btn svg{width:15px;height:15px;stroke-width:1.5;color:#cbb5f0 !important}
.lang-float-dropdown{position:absolute;bottom:calc(100% + 10px);left:0;background:rgba(0, 0, 0, 0.45) !important;backdrop-filter:blur(16px) saturate(130%) !important;-webkit-backdrop-filter:blur(16px) saturate(130%) !important;border:1.5px solid rgba(255, 255, 255, 0.12) !important;border-radius:var(--r-lg);box-shadow:0 12px 40px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;padding:6px;min-width:170px;display:none;flex-direction:column;gap:2px;z-index:200}
.lang-float-dropdown.open{display:flex}

.lang-float-dropdown a{display:block;padding:9px 14px;border-radius:var(--r-sm);font-size:0.84rem;color:rgba(255, 255, 255, 0.85) !important;white-space:nowrap}
.lang-float-dropdown a:hover,.lang-float-dropdown a.active{background:rgba(255, 255, 255, 0.1) !important;color:#cbb5f0 !important;font-weight:500}

/* ── CTA CARD (contained violet CTA) ────────────────────────── */
.cta-card-violet{background:var(--violet);color:white;border-radius:var(--r-xl);padding:clamp(40px,5vw,72px);max-width:var(--max-w);margin:0 auto;text-align:center}
.cta-card-violet h2,.cta-card-violet h3{color:white}
.cta-card-violet p{color:rgba(255,255,255,0.78);max-width:540px;margin:0 auto var(--sp-4)}

/* ── MAP EMBED ──────────────────────────────────────────────── */
.map-embed{width:100%;height:300px;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--gray-100)}
.map-embed iframe{width:100%;height:100%;border:0}

/* ── CONTACT CARDS (under form) ─────────────────────────────── */
.contact-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-3)}
.contact-card{position:relative;padding:var(--sp-4);background:var(--white);border:1px solid var(--gray-100);border-radius:var(--r-lg);text-align:center;cursor:pointer;transition:transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease}
.contact-card:hover{border-color:transparent;box-shadow:0 16px 40px rgba(0,0,0,0.08);transform:translateY(-4px);transition:transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease}
.contact-card .card-icon{margin:0 auto var(--sp-2)}
.contact-card h4{font-size:0.85rem;margin-bottom:8px}
.contact-card p,.contact-card a{font-size:0.85rem;color:var(--text-muted);line-height:1.6}
.contact-card a::after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;z-index:1}
.contact-card a:hover{color:var(--violet)}

/* ── REVIEW SECTION ─────────────────────────────────────────── */
.review-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.5vw,28px)}
.review-card{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--r-lg);padding:var(--sp-5) var(--sp-4);transition:transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease}
.review-card:hover{border-color:transparent;box-shadow:0 16px 40px rgba(0,0,0,0.08);transform:translateY(-6px);transition:transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease}
.review-stars{display:flex;gap:2px;margin-bottom:var(--sp-2);color:#f59e0b;font-size:1.1rem;letter-spacing:2px}
.review-card p{font-size:0.9rem;color:var(--text-secondary);line-height:1.72;margin-bottom:var(--sp-3);font-style:italic}
.review-author{font-size:0.82rem;font-weight:600;color:var(--text-primary)}
.review-author span{display:block;font-weight:400;color:var(--text-muted);font-size:0.76rem;margin-top:2px}

/* ── STATS ROW (legacy, kept for compat) ─────────────────────── */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100);padding:var(--sp-5) 0}
.stat-item{text-align:center;padding:0 var(--sp-3);border-right:1px solid var(--gray-100)}
.stat-item:last-child{border-right:none}
.stat-num{font-family:var(--serif);font-size:clamp(2rem,3.5vw,2.8rem);font-weight:700;color:var(--text-primary);line-height:1;letter-spacing:-0.03em}
.stat-num .accent{color:var(--violet)}
.stat-label{display:block;margin-top:8px;font-size:0.76rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-muted);font-weight:500}

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media(max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,48px)}
  .process-steps{grid-template-columns:1fr}.process-steps::before{display:none}
  .dual-cta{grid-template-columns:1fr}
  .benefit-grid{grid-template-columns:repeat(2,1fr)}
  .leitbild-row{grid-template-columns:repeat(3,1fr)}
  .fort-grid{grid-template-columns:repeat(2,1fr)}
  .faq-top-cards{grid-template-columns:repeat(2,1fr)}
  .kosten-cols{grid-template-columns:1fr}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .stat-item:nth-child(2){border-right:none}
  .stat-item:nth-child(1),.stat-item:nth-child(2){border-bottom:1px solid var(--gray-100);padding-bottom:var(--sp-3);margin-bottom:var(--sp-3)}
  .contact-cards{grid-template-columns:repeat(2,1fr)}
  .review-cards{grid-template-columns:repeat(2,1fr)}
  .diagnosen-row{grid-template-columns:repeat(3,1fr)}
}

@media(max-width:768px){
  :root{--section-gap:clamp(52px,7vw,80px)}
  .nav,.header-right .btn-primary{display:none}
  .header-right{margin-left:auto}
  .mobile-toggle{display:flex}
  /* Hero mobile */
  .hero-inner{grid-template-columns:1fr;gap:0;align-items:flex-start;padding:clamp(40px,6vh,72px) 0 0}
  .hero-content{order:1}
  .hero-subtitle{max-width:100%}
  .hero-actions{flex-direction:column;align-items:stretch;gap:10px;position:relative;z-index:2;margin-bottom:var(--sp-4)}
  .hero-actions .btn{width:100%;justify-content:center}
  .hero-visual{order:2;margin-top:var(--sp-3);position:relative;z-index:0}
  .hero-photo{aspect-ratio:16/9;border-radius:var(--r-lg) var(--r-lg) 0 0}
  .hero-badge{left:var(--sp-2);bottom:var(--sp-2)}
  /* Sub-hero */
  .sub-hero .hero-inner{grid-template-columns:1fr;align-items:flex-start;padding-bottom:0}
  /* Grids */
  .grid-2{grid-template-columns:1fr;gap:clamp(24px,4vw,40px)}
  .grid-3{grid-template-columns:1fr}
  .benefit-grid{grid-template-columns:1fr}
  .leitbild-row{grid-template-columns:1fr}
  .fort-grid{grid-template-columns:1fr}
  .kosten-cols{grid-template-columns:1fr}
  /* Snap scroll for card grids */
  .grid-3.snap,.grid-4.snap{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:12px;padding-bottom:8px;scrollbar-width:none}
  .grid-3.snap::-webkit-scrollbar,.grid-4.snap::-webkit-scrollbar{display:none}
  .grid-3.snap > *,.grid-4.snap > *{flex:0 0 82%;scroll-snap-align:start}
  /* Forms */
  .form-row{grid-template-columns:1fr}
  .form-card{padding:var(--sp-4) var(--sp-3)}
  /* Footer */
  .footer-grid{grid-template-columns:1fr;gap:var(--sp-4)}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  /* Other */
  .dual-cta-left,.dual-cta-right{padding:var(--sp-5) var(--sp-4)}
  .cta-card-violet{padding:var(--sp-5) var(--sp-4)}
  .cta-card-violet .btn{padding:12px 24px;font-size:0.88rem}
  .vacancy-item{flex-direction:column;align-items:flex-start;gap:12px}
  .gallery-scroll{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:12px;padding-bottom:8px;scrollbar-width:none}
  .gallery-scroll::-webkit-scrollbar{display:none}
  .faq-top-cards{grid-template-columns:1fr}
  .lang-float{bottom:16px;left:16px}
  .stats-row{grid-template-columns:1fr}
  .stat-item{border-right:none;border-bottom:1px solid var(--gray-100);padding:var(--sp-3) 0}
  .stat-item:last-child{border-bottom:none}
  .contact-cards{grid-template-columns:1fr}
  .review-cards{grid-template-columns:1fr}
  .diagnosen-row{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:480px){
  :root{--section-gap:52px}
  h1{font-size:clamp(3rem, 12vw, 4.5rem);line-height:1.05;letter-spacing:-0.02em}
  h2{font-size:1.85rem}
  .hero{padding-top:var(--header-h)}
  .form-card{padding:var(--sp-3) var(--sp-2)}
  .hero-badge{display:none}
  .process-steps{gap:12px}
  .faq-cats{gap:6px}
  .btn-lg{padding:15px 28px;font-size:0.9rem}
}

/* ── RTL ─────────────────────────────────────────────────────── */
html[dir="rtl"] .check-icon{margin-right:0;margin-left:14px}
html[dir="rtl"] .quote-block{border-left:none;border-right:3px solid var(--violet);border-radius:var(--r-md) 0 0 var(--r-md)}

html[dir="rtl"] .hero-photo-1 {
  right: auto !important;
  left: 0 !important;
}
html[dir="rtl"] .hero-photo-2 {
  right: auto !important;
  left: 5% !important;
  transform: scaleX(1) !important;
}
html[dir="rtl"] .hero-photo-3 {
  right: auto !important;
  left: 0 !important;
}

/* ── COOKIE BANNER ───────────────────────────────────────────── */
.cookie-banner{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);width:calc(100% - 48px);max-width:600px;background:rgba(0, 0, 0, 0.45) !important;backdrop-filter:blur(16px) saturate(130%) !important;-webkit-backdrop-filter:blur(16px) saturate(130%) !important;border:1.5px solid rgba(255, 255, 255, 0.12) !important;padding:24px;border-radius:var(--r-xl);box-shadow:0 12px 40px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;z-index:9999;display:flex;flex-direction:column;gap:16px}
.cookie-banner.hidden{opacity:0;transform:translate(-50%, 40px);pointer-events:none}
.cookie-content h3{font-size:1.05rem;margin-bottom:6px;font-weight:600;color:#ffffff !important}
.cookie-content p{font-size:0.85rem;color:rgba(255, 255, 255, 0.8) !important;line-height:1.6}
.cookie-content a{color:#cbb5f0 !important;text-decoration:underline;font-weight:500}
.cookie-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:4px}
html[dir="rtl"] .cookie-actions{justify-content:flex-start}
.cookie-banner #cookieReject {
  background: rgba(255, 255, 255, 0.08) !important;
  color: #ffffff !important;
  border-color: rgba(255, 255, 255, 0.3) !important;
}
.cookie-banner #cookieReject:hover {
  background: rgba(255, 255, 255, 0.18) !important;
}
@media (max-width:500px) {
  .cookie-banner{bottom:16px;width:calc(100% - 32px);padding:20px}
  .cookie-actions{flex-direction:column}
  .cookie-actions .btn{width:100%}
}


/* ── HERO HOME ─────────────────────────────────────────────── */
.hero-home-photo-frame {
  position: absolute;
  right: 0;
  bottom: 0;
  top: auto;
  transform: none;
  width: 66vw;
  max-width: 1000px;
  aspect-ratio: 16 / 11;
  overflow: hidden;
  z-index: 1;
}

.hero-home-photo-inner {
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: relative;
}

.hero-home-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 45% center; /* crops the right edge to press the blonde girl to the screen edge */
  display: block;
  will-change: transform;
  transform-origin: center;
  transition: none !important;
  filter: brightness(1.05);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

@media (min-width: 993px) {
  .hero-home-photo {
    transform: scale(1.05);
  }
  .index-hero-frame .hero-home-photo {
    object-position: 45% 33%;
    transform: scale(1.12) translateX(5%);
  }
  .kontakt-hero-frame .hero-home-photo {
    object-position: 45% 20%;
  }
  .hero-bg-blur-pic {
    display: none !important;
  }
}

.hero-home-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: 
    /* fade from left */
    linear-gradient(to right, var(--off-white) 0%, var(--off-white) 8%, rgba(253, 250, 247, 0.8) 18%, rgba(253, 250, 247, 0) 35%),
    /* fade from top */
    linear-gradient(to bottom, var(--off-white) 0%, var(--off-white) 4%, rgba(253, 250, 247, 0.8) 12%, rgba(253, 250, 247, 0) 25%);
  pointer-events: none;
}

html[dir="rtl"] .hero-home-overlay {
  background: 
    /* fade from right */
    linear-gradient(to left, var(--off-white) 0%, var(--off-white) 8%, rgba(253, 250, 247, 0.8) 18%, rgba(253, 250, 247, 0) 35%),
    /* fade from top */
    linear-gradient(to bottom, var(--off-white) 0%, var(--off-white) 4%, rgba(253, 250, 247, 0.8) 12%, rgba(253, 250, 247, 0) 25%),
    /* fade from bottom */
    linear-gradient(to top, var(--off-white) 0%, rgba(253, 250, 247, 0) 8%);
}

html[dir="rtl"] .hero-home-photo-frame {
  right: auto;
  left: 0;
}

html[dir="rtl"] .hero-home-photo {
  object-position: 55% center;
}

@media (max-width: 992px) {
  .hero-home-photo-frame,
  .leistungen-hero-frame,
  .ueber-uns-hero-frame,
  .karriere-hero-frame,
  .faq-hero-frame,
  .kontakt-hero-frame {
    position: absolute !important;
    inset: 0 !important;
    width: 100vw !important;
    height: 100% !important;
    transform: none !important;
    left: 0 !important;
    right: 0 !important;
    top: 0 !important;
    bottom: 0 !important;
    aspect-ratio: auto !important;
    border-radius: 0 !important;
    border: none !important;
    box-shadow: none !important;
    margin: 0 !important;
    z-index: 1 !important;
  }
  .hero-home-photo-inner {
    width: 100% !important;
    height: 100% !important;
    border-radius: 0 !important;
    overflow: hidden !important;
  }
  .hero-home-photo-inner picture {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
  }
  .hero-home-photo {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center top !important;
  }
  .hero-home-overlay {
    position: absolute !important;
    inset: 0 !important;
    z-index: 2 !important;
    background: rgba(0, 0, 0, 0.35) !important;
    pointer-events: none !important;
  }
  .kontakt-hero-section .hero-inner {
    min-height: 100svh !important;
    padding-bottom: clamp(32px, 8vh, 72px) !important;
  }
  .index-hero-frame .hero-home-photo {
    object-position: center top !important;
  }
  .ueber-uns-hero-frame .hero-home-photo {
    object-position: center 20% !important;
  }
  .leistungen-hero-frame .hero-home-photo {
    object-position: center 20% !important;
  }
  .karriere-hero-frame .hero-home-photo {
    object-position: center 20% !important;
  }
  .faq-hero-frame .hero-home-photo {
    object-position: center 20% !important;
  }
  .kontakt-hero-frame .hero-home-photo {
    object-position: center 20% !important;
  }
}

.leistungen-hero-frame {
  transform: translateX(5vw);
}

.ueber-uns-hero-frame {
  width: 60vw;
  max-width: 900px;
  aspect-ratio: 16 / 13;
  transform: translateX(6vw);
}
.ueber-uns-hero-frame .hero-home-photo {
  object-position: center 10% !important;
}
@media (min-width: 993px) {
  .ueber-uns-hero-frame .hero-home-overlay {
    background: 
      linear-gradient(to right, var(--off-white) 0%, var(--off-white) 5%, rgba(253, 250, 247, 0.8) 12%, rgba(253, 250, 247, 0) 22%),
      linear-gradient(to bottom, var(--off-white) 0%, var(--off-white) 4%, rgba(253, 250, 247, 0.8) 12%, rgba(253, 250, 247, 0) 25%);
  }
}

.karriere-hero-frame {
  transform: translateX(5vw);
}

.faq-hero-frame {
  transform: translateX(5vw);
}

.kontakt-hero-frame {
  transform: translateX(5vw);
}



/* ── SECTION EDGE PHOTO ───────────────────────────────────────── */
.section-edge-photo {
  position: relative;
  overflow: hidden;
  --bg-rgb: 246, 239, 233; /* default theme white #f6efe9 */
  background: rgb(var(--bg-rgb));
}

.section-edge-photo.section-gray {
  --bg-rgb: 239, 230, 222; /* theme gray #efe6de */
}

.section-edge-photo.section-white {
  --bg-rgb: 255, 255, 255;
}

@media (min-width: 993px) {
  .section-edge-photo {
    display: flex;
    align-items: center;
    min-height: 580px;
    padding: var(--sp-6) 0;
  }
  
  .section-edge-photo .container {
    position: relative;
    z-index: 3;
    pointer-events: none;
  }

  .section-edge-photo .container > * {
    pointer-events: auto;
  }
  
  .section-edge-photo .edge-photo-frame {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 48vw;
    z-index: 1;
    overflow: visible !important;
  }
  
  .section-edge-photo.img-left .edge-photo-frame {
    left: 0;
  }
  
  .section-edge-photo.img-right .edge-photo-frame {
    right: 0;
  }
  
  .section-edge-photo .edge-photo-inner {
    width: 100%;
    height: 100%;
    overflow: hidden !important;
  }
  
  .section-edge-photo .edge-photo-inner img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    will-change: transform;
    transform-origin: center;
    transition: none !important;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
  }
  
  .section-edge-photo .edge-photo-overlay {
    position: absolute;
    top: 0;
    bottom: 0;
    z-index: 2;
    pointer-events: none;
  }
  
  /* Fade/Blur from center to outside */
  .section-edge-photo.img-left .edge-photo-overlay {
    background: linear-gradient(to left, rgb(var(--bg-rgb)) 0%, rgb(var(--bg-rgb)) 4%, rgba(var(--bg-rgb), 0.7) 12%, rgba(var(--bg-rgb), 0) 30%);
    left: 0 !important;
    right: -10px !important;
    width: auto !important;
  }
  
  .section-edge-photo.img-right .edge-photo-overlay {
    background: linear-gradient(to right, rgb(var(--bg-rgb)) 0%, rgb(var(--bg-rgb)) 4%, rgba(var(--bg-rgb), 0.7) 12%, rgba(var(--bg-rgb), 0) 30%);
    left: -10px !important;
    right: 0 !important;
    width: auto !important;
  }

  .section-edge-photo p {
    font-size: 1.12rem;
    line-height: 1.8;
    color: var(--text-secondary);
    max-width: 580px;
  }
}

@media (max-width: 992px) {
  .section-edge-photo {
    position: relative;
    padding: var(--section-gap) 0 calc(clamp(220px, 50svh, 450px) + 40px) 0;
    overflow: hidden;
  }
  .section-edge-photo .edge-photo-frame {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100vw;
    height: clamp(220px, 50svh, 450px);
    z-index: 1;
    border-radius: 0;
    box-shadow: none;
    margin: 0;
    transition: none !important;
    will-change: transform;
  }
  .section-edge-photo .edge-photo-inner {
    width: 100%;
    height: 100%;
    overflow: hidden;
  }
  .section-edge-photo .edge-photo-inner img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .section-edge-photo .edge-photo-inner img.crop-mobile {
    transform: scale(1.43) translateY(10%);
  }
  .section-edge-photo .edge-photo-overlay {
    display: block;
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    background: linear-gradient(to bottom, rgb(var(--bg-rgb)) 0%, rgb(var(--bg-rgb)) 4%, rgba(var(--bg-rgb), 0.7) 12%, rgba(var(--bg-rgb), 0) 30%);
  }
  .section-edge-photo .grid-2 {
    display: block;
    position: relative;
    z-index: 3;
  }
}
.pos-girl {
  object-position: 88% center !important;
}

.faq-answer-inner .check-list {
  margin: 0.5rem 0 1rem 0;
  gap: 0.8rem;
}

/* ── WIDE-SCREEN PROPORTIONAL SCALING ─────────────────────────
   Lock position and size of both text and photo relative to the viewport width (vw).
   No transform: scale() scaling, ensuring zero overlap and perfect alignment on any width.
   ──────────────────────────────────────────────────────────── */
@media (min-width: 993px) {
  .hero-cutout .container {
    position: static !important;
  }
  .hero-cutout .hero-inner {
    position: static !important;
    display: block !important;
    min-height: 100svh !important;
    width: 100% !important;
    padding: 0 !important;
  }
  .hero-cutout .hero-content {
    position: absolute !important;
    top: 50% !important;
    left: 8vw !important;
    transform: translateY(-50%) !important;
    width: 46vw !important;
    min-width: 500px !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    z-index: 3 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    text-align: left !important;
  }
  html[dir="rtl"] .hero-cutout .hero-content {
    left: auto !important;
    right: 8vw !important;
    align-items: flex-end !important;
    text-align: right !important;
  }
  
  .hero-cutout .hero-title {
    font-size: calc(1.5rem + 3.5vw) !important;
    line-height: 1.05 !important;
    margin-bottom: calc(1.2rem + 1vw) !important;
    text-align: left !important;
    width: 100% !important;
  }
  .hero-cutout .hero-title .ht-line,
  .hero-cutout .hero-title > span,
  .hero-cutout .hero-title > em {
    display: block !important;
    white-space: nowrap !important;
  }
  .hero-cutout .hero-title br {
    display: none !important;
  }
  html[dir="rtl"] .hero-cutout .hero-title {
    text-align: right !important;
  }
  
  .hero-cutout .hero-subtitle {
    font-size: calc(0.9rem + 0.6vw) !important;
    line-height: 1.7 !important;
    margin-bottom: calc(1.5rem + 1.2vw) !important;
    max-width: 32vw !important;
    min-width: 320px !important;
    text-align: left !important;
    width: 100% !important;
  }
  html[dir="rtl"] .hero-cutout .hero-subtitle {
    text-align: right !important;
  }
  
  .hero-cutout .hero-actions {
    display: flex !important;
    gap: 12px !important;
    flex-wrap: wrap !important;
    justify-content: flex-start !important;
    width: 100% !important;
  }
  .hero-cutout .hero-actions .btn {
    font-size: calc(0.85rem + 0.15vw) !important;
    padding: calc(10px + 0.2vw) calc(20px + 0.4vw) !important;
  }
  html[dir="rtl"] .hero-cutout .hero-actions {
    justify-content: flex-end !important;
  }

  .hero-home-photo-frame {
    top: 0;
    bottom: 0;
    height: 100%;
    aspect-ratio: auto;
    max-width: none;
    width: 58vw !important;
    transform: none !important;
    overflow: visible !important;
  }
  .index-hero-frame {
    width: 54vw !important;
  }
  .hero-home-photo-inner {
    width: 100%;
    height: 100%;
    overflow: hidden !important;
  }
  
  .ueber-uns-hero-frame {
    aspect-ratio: auto;
    max-width: none;
    width: 58vw !important;
    transform: none !important;
    overflow: visible !important;
  }
  
  .hero-home-overlay {
    position: absolute !important;
    top: 0 !important;
    bottom: 0 !important;
    left: -10px !important;
    right: 0 !important;
    width: auto !important;
    z-index: 2 !important;
  }
  html[dir="rtl"] .hero-home-overlay {
    left: 0 !important;
    right: -10px !important;
  }
}

/* ── SLIDER NAVIGATION ───────────────────────────────────────── */
.slider-container {
  position: relative;
  width: 100%;
}
.slider-nav {
  display: none;
}
@media (max-width: 992px) {
  .slider-nav {
    display: flex;
    justify-content: center;
    gap: 12px;
    margin-top: 20px;
  }
  .slider-arrow {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--white);
    border: 1px solid var(--gray-100);
    color: var(--violet);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: var(--shadow-sm);
    padding: 0;
  }
  .slider-arrow:active {
    background: var(--gray-50);
  }
  .slider-arrow svg {
    width: 20px;
    height: 20px;
    stroke-width: 2.2;
  }
}

/* ── KOOPERATIONEN MOBILE PHOTO FIX ─────────────────────────── */
@media (max-width: 992px) {
  .koop-edge-photo {
    padding-bottom: calc(140vw + 40px) !important;
  }
  .koop-edge-photo .edge-photo-frame {
    height: 140vw !important;
  }
  .koop-edge-photo .edge-photo-inner img {
    object-position: center top !important;
  }
}

/* ── PREVENT MOBILE ZOOM ON INPUT FOCUS ───────────────────────── */
@media (max-width: 992px) {
  .form-group input:not([type="checkbox"]):not([type="radio"]),
  .form-group select,
  .form-group textarea,
  .faq-search {
    font-size: 16px !important;
  }
}

/* ── FORM VALIDATION & ALERTS ────────────────────────────────── */
.form-alert {
  padding: 14px 18px;
  border-radius: var(--r-md);
  margin-bottom: var(--sp-4);
  font-size: 0.88rem;
  line-height: 1.5;
  display: flex;
  align-items: center;
  gap: 12px;
  animation: none;
}
@keyframes formAlertSlideIn {
  from { opacity: 0; transform: translateY(-8px); }
  to { opacity: 1; transform: translateY(0); }
}
.form-alert-error {
  background: #fdf2f2;
  color: #9b1c1c;
  border: 1px solid #fbd5d5;
}
.form-alert-warning {
  background: #fffbeb;
  color: #92400e;
  border: 1px solid #fde68a;
}
.form-alert-icon {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
}
.form-group input.is-invalid,
.form-group select.is-invalid,
.form-group textarea.is-invalid {
  border-color: #ef4444 !important;
  background: #fdf2f2 !important;
}


