/* ============================================================
   Notariat Waizenkirchen — PHASE 2 · Design-System v3
   Richtung: modern-lebendig (Referenz: sk-strafrecht.de)
   Blau-Akzent (CI) + Navy/Slate + Hell · Sans-Serif · Scroll-Motion
   Diagonale Sektionen · Floating-Buttons · animierte Schritte
   Getrennt von der Phase-1-style.css.
   ============================================================ */

/* --- Fonts: lokal, DSGVO-konform ----------------------------- */
@font-face { font-family:"General Sans"; font-weight:400; font-style:normal; font-display:swap; src:url("/fonts/general-sans-400.woff2") format("woff2"); }
@font-face { font-family:"General Sans"; font-weight:500; font-style:normal; font-display:swap; src:url("/fonts/general-sans-500.woff2") format("woff2"); }
@font-face { font-family:"General Sans"; font-weight:600; font-style:normal; font-display:swap; src:url("/fonts/general-sans-600.woff2") format("woff2"); }
@font-face { font-family:"General Sans"; font-weight:700; font-style:normal; font-display:swap; src:url("/fonts/general-sans-700.woff2") format("woff2"); }

/* --- Design-Tokens ------------------------------------------- */
:root {
  /* Flächen — hell, kühl */
  --paper:    #FFFFFF;
  --paper-2:  #EEF2F4;   /* helle, kühle Grau-Fläche */
  --paper-3:  #DCE4E9;   /* tiefere Grau-Blau-Fläche (Diagonal-Sektionen) */
  --white:    #FFFFFF;

  /* Tinte — dunkles Slate-Navy (Text & Headlines) */
  --ink:      #2A3540;
  --ink-2:    #4E5C68;
  --muted:    #7E8C97;

  /* Akzent — Blau (Corporate Identity, exakt aus dem PNH-Logo gemessen: #0062AE) */
  --accent:      #0062AE;
  --accent-2:    #00508F;   /* Hover (dunkler) */
  --accent-soft: #E4EFF8;   /* zarte Blau-Tönung */

  /* Linien */
  --line:     #DCE2E6;
  --line-2:   #C7D0D6;

  /* Fonts */
  --font-sans:    "General Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-display: "General Sans", system-ui, -apple-system, "Segoe UI", sans-serif;

  /* Fluid type scale */
  --step--2: clamp(0.72rem, 0.69rem + 0.12vw, 0.78rem);
  --step--1: clamp(0.85rem, 0.82rem + 0.16vw, 0.95rem);
  --step-0:  clamp(1.0rem, 0.96rem + 0.22vw, 1.13rem);
  --step-1:  clamp(1.2rem, 1.1rem + 0.5vw, 1.5rem);
  --step-2:  clamp(1.5rem, 1.25rem + 1.1vw, 2.2rem);
  --step-3:  clamp(1.9rem, 1.45rem + 2.0vw, 3.1rem);
  --step-4:  clamp(2.4rem, 1.7rem + 3.1vw, 4.4rem);
  --step-5:  clamp(2.9rem, 1.9rem + 4.4vw, 5.6rem);

  --space-1: 0.5rem;  --space-2: 1rem;   --space-3: 1.5rem;
  --space-4: 2.5rem;  --space-5: 4rem;   --space-6: 6.5rem;  --space-7: 9rem;

  --measure: 60ch;
  --radius-sm: 8px;  --radius-md: 16px;  --radius-lg: 26px;  --radius-pill: 999px;

  --shadow-sm: 0 4px 14px rgba(28,40,52,0.07);
  --shadow-md: 0 14px 40px rgba(28,40,52,0.12);
  --shadow-accent: 0 12px 30px rgba(0,98,174,0.30);

  --t-fast: 200ms cubic-bezier(0.2, 0.6, 0.2, 1);
  --t-med:  400ms cubic-bezier(0.2, 0.6, 0.2, 1);
  --t-slow: 800ms cubic-bezier(0.16, 1, 0.3, 1);
}

/* --- Base ---------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: var(--step-0);
  line-height: 1.65;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: 0 0 0.5em;
  /* lange Wörter umbrechen statt abschneiden; KEINE Silbentrennung global
     (sonst werden auch kurze Wörter wie „Be-reich" getrennt) */
  overflow-wrap: break-word;
}
h1 { font-size: var(--step-4); }
h2 { font-size: var(--step-3); }
h3 { font-size: var(--step-1); }
p { margin: 0 0 1em; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-2); }
::selection { background: var(--accent); color: #fff; }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; border-radius: 4px; }

/* --- Skip-Link ---------------------------------------------- */
.skip-link {
  position: absolute; left: 1rem; top: -100%; z-index: 1000;
  background: var(--ink); color: #fff; padding: 0.7rem 1.1rem;
  border-radius: var(--radius-sm); font-weight: 500; transition: top var(--t-fast);
}
.skip-link:focus { top: 1rem; }

/* --- Layout -------------------------------------------------- */
.container { width: 100%; max-width: 1200px; margin-inline: auto; padding-inline: clamp(1.25rem, 5vw, 3rem); }
.section { padding-block: clamp(3.5rem, 8vw, var(--space-7)); position: relative; }
.section--grey { background: var(--paper-2); }
.section--ink { background: var(--ink); color: #fff; }
.section--ink h1, .section--ink h2, .section--ink h3 { color: #fff; }

/* diagonale Kanten (sk-strafrecht-Look) */
.diag-top { clip-path: polygon(0 4vw, 100% 0, 100% 100%, 0 100%); margin-top: -4vw; padding-top: calc(clamp(3.5rem,8vw,var(--space-7)) + 4vw); }
.diag-bottom { clip-path: polygon(0 0, 100% 0, 100% calc(100% - 4vw), 0 100%); padding-bottom: calc(clamp(3.5rem,8vw,var(--space-7)) + 4vw); }

/* --- Section-Heading-Helfer ---------------------------------- */
.eyebrow {
  display: inline-flex; align-items: center; gap: 0.7rem;
  font-family: var(--font-sans); font-size: var(--step--2); font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent);
  margin: 0 0 1.1rem;
}
.eyebrow::before { content: ""; width: 1.8rem; height: 2px; background: var(--accent); flex: none; }
.eyebrow--plain::before { display: none; }
.section__head { max-width: 42rem; margin-bottom: clamp(2rem, 4vw, 3.5rem); }
.lead { font-size: var(--step-1); line-height: 1.55; color: var(--ink-2); max-width: 52ch; }
.measure { max-width: var(--measure); }
.muted { color: var(--muted); }
.accent-text { color: var(--accent); }

/* --- Buttons ------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; gap: 0.6rem;
  font-family: var(--font-sans); font-size: var(--step-0); font-weight: 600;
  line-height: 1; padding: 1.05rem 1.9rem;
  border: 2px solid var(--accent); border-radius: var(--radius-pill);
  background: var(--accent); color: #fff; cursor: pointer; white-space: nowrap;
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
}
.btn:hover { background: var(--accent-2); border-color: var(--accent-2); color: #fff; transform: translateY(-2px); box-shadow: var(--shadow-accent); }
.btn:active { transform: translateY(0); }
.btn__arrow { width: 1.05em; height: 1.05em; transition: transform var(--t-med); }
.btn:hover .btn__arrow { transform: translateX(4px); }
.btn--outline { background: transparent; color: var(--ink); border-color: var(--line-2); }
.btn--outline:hover { background: var(--ink); border-color: var(--ink); color: #fff; box-shadow: none; }
.btn--ghost-light { background: transparent; color: #fff; border-color: rgba(255,255,255,0.5); }
.btn--ghost-light:hover { background: #fff; color: var(--ink); border-color: #fff; box-shadow: none; }

.link-arrow {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-weight: 600; color: var(--accent); font-size: var(--step-0);
}
.link-arrow svg { width: 1em; height: 1em; transition: transform var(--t-med); }
.link-arrow:hover svg { transform: translateX(4px); }

/* --- Header / Nav -------------------------------------------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  transition: background var(--t-med), box-shadow var(--t-med);
  background: transparent;
}
.site-header.is-scrolled {
  background: rgba(255,255,255,0.88);
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
  box-shadow: 0 6px 20px rgba(42,53,64,0.06);
}
.site-header__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); min-height: 4.8rem; }
.brand { display: inline-flex; align-items: center; gap: 0.65rem; color: var(--accent); font-weight: 700; font-size: 1.2rem; letter-spacing: -0.01em; }
.brand__mark { width: 34px; height: 34px; flex: none; }
.brand small { display: block; font-size: 0.56rem; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); margin-top: 2px; }
.brand__logo { height: 38px; width: auto; display: block; }
.site-footer .brand__logo { height: 42px; }
@media (max-width: 520px) { .brand__logo { height: 32px; } }

.nav { display: flex; align-items: center; gap: clamp(1rem, 2vw, 2rem); }
.nav__list { display: flex; align-items: center; gap: clamp(0.9rem, 1.8vw, 1.9rem); list-style: none; margin: 0; padding: 0; }
.nav__link { font-size: var(--step--1); font-weight: 500; color: var(--ink); transition: color var(--t-fast); }
.nav__link:hover { color: var(--accent); }
.nav__cta { padding: 0.65rem 1.3rem; font-size: var(--step--1); }

.nav-toggle { display: none; width: 2.7rem; height: 2.7rem; border: 0; border-radius: 0; background: transparent; color: var(--ink); cursor: pointer; align-items: center; justify-content: center; }
.nav-toggle__bars { position: relative; width: 18px; height: 2px; background: currentColor; }
.nav-toggle__bars::before, .nav-toggle__bars::after { content: ""; position: absolute; left: 0; width: 18px; height: 2px; background: currentColor; }
.nav-toggle__bars::before { top: -6px; } .nav-toggle__bars::after { top: 6px; }

.nav-close { display: none; }   /* nur im Mobil-Panel sichtbar */

@media (max-width: 900px) {
  .nav-toggle { display: inline-flex; }
  /* WICHTIG: backdrop-filter macht den Header zum Containing-Block fuer das
     position:fixed-Panel -> Panel wird auf Headerhoehe geklemmt (durchsichtig/
     abgeschnitten + H-Scroll, sobald is-scrolled aktiv). Auf Mobil daher aus. */
  .site-header.is-scrolled { -webkit-backdrop-filter: none; backdrop-filter: none; background: rgba(255,255,255,0.96); }
  .nav { position: fixed; inset: 0 0 0 auto; width: min(86vw, 360px); flex-direction: column; align-items: stretch; justify-content: flex-start; gap: var(--space-3); background: var(--paper); border-left: 1px solid var(--line); padding: 6rem var(--space-3) var(--space-3); transform: translateX(100%); transition: transform var(--t-med); z-index: 99; }
  body.nav-open .nav { transform: translateX(0); }
  body.nav-open { overflow: hidden; }
  .nav-close { display: inline-flex; position: absolute; top: 1.15rem; right: 1.15rem;
    width: 2.7rem; height: 2.7rem; align-items: center; justify-content: center;
    border: 0; border-radius: 0; background: transparent;
    color: var(--ink); cursor: pointer; transition: color var(--t-fast); }
  .nav-close:hover { color: var(--accent); }
  .nav-close svg { width: 18px; height: 18px; }
  .nav__list { flex-direction: column; align-items: stretch; gap: 0; width: 100%; }
  .nav__link { display: block; width: 100%; color: var(--ink); padding: 1.15rem 0; font-size: var(--step-1); font-weight: 500; line-height: 1.2; border-bottom: 1px solid var(--line); }
  .nav__list li:first-child .nav__link { border-top: 1px solid var(--line); }
  .nav__link::after { display: none; }      /* Hover-Unterstrich nur am Desktop */
  /* Panel ist immer hell -> Links dunkel halten, auch wenn der Header "scrolled"
     ist (sonst greift .is-scrolled .nav__link {weiss} -> weiss-auf-weiss). */
  .site-header.is-scrolled .nav__link { color: var(--ink); }
  .site-header.is-scrolled .nav__link:hover,
  .site-header.is-scrolled .nav__link.is-active { color: var(--accent); }
  /* offenes Menue: Hamburger ausblenden, der X-Button im Panel uebernimmt */
  body.nav-open .nav-toggle { opacity: 0; pointer-events: none; }
  .nav__cta { margin-top: var(--space-3); justify-content: center; border-bottom: 0; }
  .nav-overlay { position: fixed; inset: 0; background: rgba(28,40,52,0.45); opacity: 0; pointer-events: none; transition: opacity var(--t-med); z-index: 98; }
  body.nav-open .nav-overlay { opacity: 1; pointer-events: auto; }
}

/* --- HERO ---------------------------------------------------- */
.hero { position: relative; background: var(--paper); overflow: hidden; }
.hero::before { content: ""; position: absolute; inset: 0; z-index: 0; background: radial-gradient(120% 80% at 88% 0%, var(--paper-2) 0%, transparent 60%); }
.hero__inner {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(2rem, 5vw, 4.5rem);
  align-items: center;
  padding-block: clamp(3rem, 7vh, 6rem) clamp(3rem, 6vh, 5rem);
  min-height: clamp(34rem, 82svh, 50rem);
}
@media (max-width: 920px) { .hero__inner { grid-template-columns: 1fr; gap: var(--space-4); padding-block: 2.5rem 3rem; } }
.hero__eyebrow { margin-bottom: 1.4rem; }
.hero__title { font-size: var(--step-5); font-weight: 600; line-height: 1.04; letter-spacing: -0.025em; margin: 0 0 1.5rem; max-width: 18ch; text-wrap: balance; }
.hero__title .accent-text { color: var(--accent); }
.hero__lead { margin: 0 0 2.2rem; max-width: 46ch; }
.hero__cta { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; }
.hero__meta-row { display: flex; flex-wrap: wrap; gap: clamp(1.5rem, 4vw, 2.8rem); margin-top: clamp(2rem, 4vw, 3rem); padding-top: var(--space-3); border-top: 1px solid var(--line); }
.hero__meta .k { display: block; font-size: var(--step--2); font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); margin-bottom: 0.3rem; }
.hero__meta .v { display: block; font-size: var(--step-0); font-weight: 500; color: var(--ink); }

/* Hero-Bild: duotone-gerahmt (Platzhalter = Kanzlei am Marktplatz) */
.hero__media { position: relative; }
.hero__frame {
  position: relative; border-radius: var(--radius-lg); overflow: hidden;
  aspect-ratio: 4/5; box-shadow: var(--shadow-md); background: var(--paper-3);
}
.hero__frame img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(0.35) contrast(1.04); }
.hero__frame::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(42,53,64,0.06) 0%, rgba(0,98,174,0.18) 100%); mix-blend-mode: multiply; }
@media (max-width: 920px) { .hero__frame { aspect-ratio: 16/11; } }
.hero__badge {
  position: absolute; right: -1.4rem; top: -1.4rem;
  width: clamp(7rem, 9vw, 9rem); height: clamp(7rem, 9vw, 9rem);
  display: grid; place-items: center; border-radius: 50%;
  background: var(--paper); box-shadow: var(--shadow-md);
}
.hero__badge .seal { width: 84%; height: 84%; color: var(--accent); opacity: 0.85; animation: sealspin 90s linear infinite; }
.hero__badge .seal-mark { position: absolute; inset: 0; display: grid; place-items: center; font-weight: 700; color: var(--accent); font-size: 1.4rem; }
@keyframes sealspin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .hero__badge .seal { animation: none; } }

/* --- Feature-Row (Akzent Line-Icons) ------------------------- */
.features { background: var(--paper-2); padding-block: clamp(3.5rem, 6vw, 5.5rem); }
.features__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1.75rem, 3vw, 3rem); }
@media (max-width: 820px) { .features__grid { grid-template-columns: 1fr 1fr; gap: 2.25rem; } }
@media (max-width: 460px) { .features__grid { grid-template-columns: 1fr; } }
.feature { text-align: left; }
.feature__icon { display: inline-flex; width: 2.9rem; height: 2.9rem; color: var(--accent); margin-bottom: 1.1rem; }
.feature__icon svg { width: 100%; height: 100%; display: block; }
.feature h3 { font-size: var(--step-1); color: var(--ink); margin: 0 0 0.4rem; }
.feature p { color: var(--ink-2); font-size: var(--step--1); margin: 0; line-height: 1.6; }

/* --- Leistungen-Grid ----------------------------------------- */
.services__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2vw, 1.5rem); }
@media (max-width: 860px) { .services__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .services__grid { grid-template-columns: 1fr; } }
.service-card {
  display: flex; flex-direction: column; gap: 0.8rem;
  padding: clamp(1.5rem, 2.5vw, 2rem); background: var(--paper);
  border: 1px solid var(--line); border-radius: var(--radius-md);
  transition: transform var(--t-med), box-shadow var(--t-med), border-color var(--t-med);
}
.service-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: transparent; }
.service-card__icon { width: 2.4rem; height: 2.4rem; color: var(--accent); }
.service-card__icon svg { width: 100%; height: 100%; }
.service-card h3 { font-size: var(--step-1); margin: 0; }
.service-card p { color: var(--ink-2); font-size: var(--step--1); margin: 0; line-height: 1.6; flex: 1; }
.service-card .link-arrow { font-size: var(--step--1); margin-top: 0.3rem; }

/* --- Ablauf / animierte Schritte ----------------------------- */
.process__grid { position: relative; display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.5rem, 4vw, 3.5rem); }
@media (max-width: 760px) { .process__grid { grid-template-columns: 1fr; gap: 2.5rem; } }
/* top wird per JS exakt auf die Kreismitte gesetzt (robust gegen CSS-Quirks) */
.process__line { position: absolute; left: 16.6%; right: 16.6%; top: 2.4rem; transform: translateY(-50%); height: 2px; z-index: 0; pointer-events: none; }
@media (max-width: 760px) { .process__line { display: none; } }
.process__line-fill { display: block; width: 100%; height: 100%; background: var(--accent); transform: scaleX(0); transform-origin: left center; transition: transform 100ms linear; }
@media (prefers-reduced-motion: reduce) { .process__line-fill { transform: scaleX(1); transition: none; } }
.step { position: relative; z-index: 1; text-align: center; }
.step__num {
  width: 4.8rem; height: 4.8rem; margin: 0 auto 1.4rem; border-radius: 50%;
  display: grid; place-items: center; background: var(--paper); border: 2px solid var(--accent);
  font-size: 1.9rem; font-weight: 700; color: var(--accent); box-shadow: var(--shadow-sm);
}
.section--grey .step__num { background: var(--paper-2); }
.step h3 { font-size: var(--step-1); margin: 0 0 0.5rem; }
.step p { color: var(--ink-2); font-size: var(--step--1); margin: 0 auto; max-width: 30ch; line-height: 1.6; }

/* --- Werte / Split ------------------------------------------- */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; }
@media (max-width: 860px) { .split { grid-template-columns: 1fr; gap: 2rem; } }
.value-list { list-style: none; margin: 1.5rem 0 0; padding: 0; display: grid; gap: 1.2rem; }
.value-list li { display: flex; gap: 1rem; align-items: flex-start; }
.value-list .vi { width: 1.6rem; height: 1.6rem; flex: none; color: var(--accent); margin-top: 0.15rem; }
.value-list .vi svg { width: 100%; height: 100%; }
.value-list h4 { margin: 0 0 0.2rem; font-size: var(--step-0); }
.value-list p { margin: 0; color: var(--ink-2); font-size: var(--step--1); }

/* --- Team-Teaser --------------------------------------------- */
.team-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(1rem, 2vw, 1.5rem); }
@media (max-width: 620px) { .team-grid { grid-template-columns: 1fr; } }
.person-card { display: flex; gap: 1.2rem; align-items: center; padding: 1.5rem; background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-md); }
.person-card__mono { width: 4.2rem; height: 4.2rem; flex: none; border-radius: 50%; display: grid; place-items: center; background: var(--accent-soft); color: var(--accent); font-weight: 700; font-size: 1.3rem; letter-spacing: 0.02em; }
.person-card h3 { font-size: var(--step-0); margin: 0 0 0.15rem; }
.person-card p { margin: 0; color: var(--muted); font-size: var(--step--1); }

/* --- Standort ------------------------------------------------ */
.osm { position: relative; min-height: clamp(300px, 30vw, 380px); border-radius: var(--radius-md); overflow: hidden; background: var(--paper-3); border: 1px solid var(--line); display: grid; place-items: center; padding: clamp(1rem, 2.5vw, 1.75rem); }
.osm__load { text-align: center; padding: clamp(1.5rem, 3vw, 2.5rem); max-width: 44ch; }
.osm__icon { display: block; width: 2.4rem; height: 2.4rem; color: var(--accent); margin: 0 auto 0.8rem; }
.osm__icon svg { width: 100%; height: 100%; display: block; }
.osm__title { font-size: var(--step-1); margin: 0 0 0.6rem; }
.osm__load p { color: var(--ink-2); font-size: var(--step--1); margin: 0 0 1.2rem; line-height: 1.55; }
.osm__load p a { color: var(--accent); text-decoration: underline; }
.osm__remember { display: inline-flex; align-items: center; gap: 0.5rem; margin-top: 0.9rem; font-size: var(--step--2); color: var(--muted); cursor: pointer; }
.osm__remember input { accent-color: var(--accent); width: 1rem; height: 1rem; }

/* --- Kontakt-CTA --------------------------------------------- */
.cta { background: var(--accent); color: #fff; text-align: center; }
.cta h2 { color: #fff; max-width: 20ch; margin-inline: auto; }
.cta p { color: rgba(255,255,255,0.9); max-width: 46ch; margin: 0 auto 2rem; }
.cta__actions { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; }

/* --- Footer -------------------------------------------------- */
.site-footer { background: var(--paper-3); color: var(--ink-2); border-top: 1px solid var(--line); padding-block: clamp(3rem, 6vw, var(--space-6)) var(--space-3); }
.site-footer a { color: var(--ink-2); }
.site-footer a:hover { color: var(--accent); }
.site-footer__cols { display: grid; gap: var(--space-4); grid-template-columns: 1.5fr repeat(3, 1fr); }
@media (max-width: 860px) { .site-footer__cols { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .site-footer__cols { grid-template-columns: 1fr; } }
.site-footer h4 { font-size: var(--step--2); font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); margin: 0 0 1rem; }
.site-footer ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.55rem; }
.site-footer__bar { margin-top: var(--space-5); padding-top: var(--space-3); border-top: 1px solid var(--line); display: flex; justify-content: space-between; gap: var(--space-2); flex-wrap: wrap; font-size: var(--step--1); color: var(--muted); }

/* --- Floating Kontakt-Dock + Seal-Badge ---------------------- */
.contact-dock { position: fixed; right: clamp(0.9rem, 2vw, 1.6rem); bottom: clamp(0.9rem, 2vw, 1.6rem); z-index: 90; display: grid; gap: 0.6rem; }
.contact-dock a { width: 3rem; height: 3rem; border-radius: 50%; background: var(--accent); color: #fff; display: grid; place-items: center; box-shadow: var(--shadow-accent); transition: background var(--t-fast), transform var(--t-fast); }
.contact-dock a:hover { background: var(--accent-2); color: #fff; transform: translateY(-3px); }
.contact-dock svg { width: 1.25rem; height: 1.25rem; }
@media (max-width: 520px) { .contact-dock a { width: 2.7rem; height: 2.7rem; } }

/* --- Motion: Reveals (nur bei aktivem JS verstecken → ohne JS sichtbar) --- */
.js [data-reveal] { opacity: 0; transform: translateY(20px); transition: opacity var(--t-slow), transform var(--t-slow); transition-delay: var(--reveal-delay, 0ms); }
.js [data-reveal].is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .js [data-reveal] { opacity: 1; transform: none; } .btn:hover { transform: none; } }

/* ============================================================
   PHASE 2 — Unterseiten-Komponenten (Leistungs-Detail, FAQ, etc.)
   ============================================================ */

/* --- Aktiver Navigationspunkt -------------------------------- */
.nav__link.is-active { color: var(--accent); }
.site-header.is-scrolled .nav__link.is-active { color: var(--accent); }

/* --- Subhero (Kopf der Unterseiten) -------------------------- */
.subhero { position: relative; background: var(--paper); overflow: hidden;
  padding-block: clamp(2.5rem, 6vw, 4.5rem) clamp(2.5rem, 5vw, 4rem); border-bottom: 1px solid var(--line); }
.subhero::before { content: ""; position: absolute; inset: 0; z-index: 0;
  background: radial-gradient(120% 80% at 92% 0%, var(--paper-2) 0%, transparent 55%); }
.subhero .container { position: relative; z-index: 1; }
.subhero__title { font-size: var(--step-4); max-width: 22ch; margin: 0 0 1rem; text-wrap: balance;
  /* nur hier Silbentrennung: lange Leistungs-Titel (Verlassenschaftsverfahren …) */
  -webkit-hyphens: auto; hyphens: auto; }
.subhero__lead { max-width: 62ch; }

/* --- Breadcrumb ---------------------------------------------- */
.breadcrumb { margin: 0 0 1.4rem; }
.breadcrumb ol { display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem;
  list-style: none; margin: 0; padding: 0; font-size: var(--step--1); }
.breadcrumb li { display: inline-flex; align-items: center; gap: 0.5rem; color: var(--muted); }
.breadcrumb li + li::before { content: "/"; color: var(--line-2); }
.breadcrumb a { color: var(--ink-2); }
.breadcrumb a:hover { color: var(--accent); }
.breadcrumb [aria-current="page"] { color: var(--ink); font-weight: 500; }

/* --- Leistungs-Detail-Layout --------------------------------- */
.leistung { display: grid; grid-template-columns: minmax(0,1.7fr) minmax(0,0.9fr);
  gap: clamp(2rem, 4vw, 4rem); align-items: start; }
@media (max-width: 900px) { .leistung { grid-template-columns: 1fr; } }
.leistung__main > * + * { margin-top: clamp(2rem, 4vw, 3rem); }
.leistung__main .block h2 { font-size: var(--step-2); margin: 0 0 1rem; }

/* Kernaussagen als Checkliste */
.checklist { list-style: none; margin: 0; padding: 0; display: grid; gap: 1rem; }
.checklist li { display: flex; gap: 0.9rem; align-items: flex-start; font-size: var(--step-0); color: var(--ink); }
.checklist__mark { flex: none; width: 1.6rem; height: 1.6rem; display: inline-flex; align-items: center;
  justify-content: center; border-radius: 50%; background: var(--accent-soft); color: var(--accent); margin-top: 0.15rem; }
.checklist__mark svg { width: 0.95rem; height: 0.95rem; }

/* Leistungsliste (2-spaltig) */
.svc-list { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 0.7rem 1.6rem; }
@media (max-width: 560px) { .svc-list { grid-template-columns: 1fr; } }
.svc-list li { position: relative; padding-left: 1.4rem; color: var(--ink-2); font-size: var(--step--1); line-height: 1.55; }
.svc-list li::before { content: ""; position: absolute; left: 0; top: 0.62em; width: 6px; height: 6px;
  border-radius: 50%; background: var(--accent); }

/* Nummerierte Schritte */
.step-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 1rem; }
.step-list li { display: flex; gap: 1rem; align-items: flex-start; color: var(--ink); font-size: var(--step-0); }
.step-list__num { flex: none; width: 2.2rem; height: 2.2rem; border-radius: 50%; display: grid; place-items: center;
  background: var(--paper-2); border: 1.5px solid var(--accent); color: var(--accent); font-weight: 700; font-size: 0.95rem; }

/* Hinweis-Box */
.note { border-left: 3px solid var(--accent); background: var(--accent-soft);
  border-radius: 0 var(--radius-md) var(--radius-md) 0; padding: 1.2rem 1.4rem; }
.note p { margin: 0; color: var(--ink); font-size: var(--step--1); line-height: 1.65; }
.note strong { color: var(--accent-2); }

/* --- FAQ-Accordion (<details>) ------------------------------- */
.faq-ac { border-top: 1px solid var(--line); }
.faq-ac__item { border-bottom: 1px solid var(--line); }
.faq-ac__item summary { display: flex; justify-content: space-between; align-items: center; gap: 1rem;
  cursor: pointer; list-style: none; padding: 1.15rem 0; font-weight: 600; font-size: var(--step-0); color: var(--ink); }
.faq-ac__item summary::-webkit-details-marker { display: none; }
.faq-ac__item summary:hover { color: var(--accent); }
.faq-ac__icon { flex: none; position: relative; width: 1.1rem; height: 1.1rem; }
.faq-ac__icon::before, .faq-ac__icon::after { content: ""; position: absolute; background: var(--accent); border-radius: 1px; }
.faq-ac__icon::before { left: 0; top: 50%; width: 100%; height: 2px; transform: translateY(-50%); }
.faq-ac__icon::after { top: 0; left: 50%; width: 2px; height: 100%; transform: translateX(-50%); transition: transform var(--t-fast); }
.faq-ac__item[open] .faq-ac__icon::after { transform: translateX(-50%) scaleY(0); }
.faq-ac__a { padding: 0 0 1.3rem; }
.faq-ac__a p { margin: 0; color: var(--ink-2); font-size: var(--step--1); line-height: 1.7; max-width: 72ch; }

/* --- Aside-Card (Detailseite) -------------------------------- */
.leistung__aside { position: sticky; top: 6rem; }
@media (max-width: 900px) { .leistung__aside { position: static; } }
.aside-card { background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--radius-lg);
  padding: clamp(1.5rem, 2.5vw, 2rem); }
.aside-card__icon { display: inline-flex; width: 2.6rem; height: 2.6rem; color: var(--accent); margin-bottom: 0.8rem; }
.aside-card__icon svg { width: 100%; height: 100%; }
.aside-card__title { font-size: var(--step-1); margin: 0 0 0.5rem; }
.aside-card p { color: var(--ink-2); font-size: var(--step--1); }
.aside-card__btn { width: 100%; justify-content: center; margin-top: 0.8rem; }
.aside-card__related { margin-top: 1.5rem; padding-top: 1.3rem; border-top: 1px solid var(--line); }
.aside-card__related h3 { font-size: var(--step--2); letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--muted); margin: 0 0 0.8rem; }
.aside-card__related ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.6rem; }
.aside-card__related .link-arrow { font-size: var(--step--1); }

/* --- Platzhalter (offene TODOs in Recht) --------------------- */
.placeholder { display: inline-block; background: var(--accent-soft); color: var(--accent-2);
  border-radius: var(--radius-sm); padding: 0.1em 0.5em; font-size: 0.92em; }

/* --- Prose (Impressum / Datenschutz) ------------------------- */
.prose { max-width: 72ch; }
.prose h2 { font-size: var(--step-2); margin: 2.2rem 0 0.8rem; }
.prose h2:first-of-type { margin-top: 0; }
.prose h3 { font-size: var(--step-1); margin: 1.6rem 0 0.6rem; }
.prose p { color: var(--ink-2); margin: 0 0 1rem; }
.prose ul { color: var(--ink-2); margin: 0 0 1.2rem; padding-left: 1.3rem; }
.prose li { margin-bottom: 0.4rem; }
.prose a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }
.prose strong { color: var(--ink); }
.prose__meta { color: var(--muted); font-size: var(--step--1); margin-top: 2.5rem; }

/* --- Team-Bio ------------------------------------------------ */
.bio-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.25rem, 3vw, 2rem); }
@media (max-width: 760px) { .bio-grid { grid-template-columns: 1fr; } }
.bio { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-lg);
  padding: clamp(1.5rem, 3vw, 2.2rem); }
.bio__head { display: flex; align-items: center; gap: 1.1rem; margin-bottom: 1.3rem; }
.bio__mono { flex: none; width: 4.6rem; height: 4.6rem; border-radius: 50%; display: grid; place-items: center;
  background: var(--accent-soft); color: var(--accent); font-weight: 700; font-size: 1.5rem; }
.bio__name { font-size: var(--step-1); margin: 0; }
.bio__role { margin: 0.1rem 0 0; color: var(--accent); font-weight: 600; font-size: var(--step--1); }
.bio__intro { color: var(--ink-2); }
.bio__cv { list-style: none; margin: 1.2rem 0 0; padding: 1.2rem 0 0; border-top: 1px solid var(--line);
  display: grid; gap: 0.7rem; }
.bio__cv li { position: relative; padding-left: 1.3rem; color: var(--ink-2); font-size: var(--step--1); line-height: 1.5; }
.bio__cv li::before { content: ""; position: absolute; left: 0; top: 0.55em; width: 6px; height: 6px;
  border-radius: 50%; background: var(--accent); }
.bio__placeholder { color: var(--muted); font-style: italic; background: var(--paper-2);
  border-radius: var(--radius-sm); padding: 0.9rem 1.1rem; margin-top: 0.5rem; }

/* --- Kontakt-Layout + Aside ---------------------------------- */
.contact-layout { display: grid; grid-template-columns: minmax(0,1.4fr) minmax(0,1fr);
  gap: clamp(2rem, 4vw, 3.5rem); align-items: start; }
@media (max-width: 920px) { .contact-layout { grid-template-columns: 1fr; } }
.contact-aside { display: grid; gap: 1.5rem; }
.contact-aside__card { background: var(--paper-2); border: 1px solid var(--line);
  border-radius: var(--radius-lg); padding: clamp(1.5rem, 2.5vw, 2rem); }
.contact-aside__card h2 { font-size: var(--step-1); margin: 0 0 1.2rem; }
.contact-dl { margin: 0; display: grid; gap: 1.1rem; }
.contact-dl > div { display: grid; gap: 0.2rem; }
.contact-dl dt { font-size: var(--step--2); font-weight: 600; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--muted); }
.contact-dl dd { margin: 0; color: var(--ink); font-size: var(--step--1); line-height: 1.5; }
.contact-dl a { color: var(--accent); }

/* --- Formular ------------------------------------------------ */
.form__hp { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }
.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
@media (max-width: 560px) { .form__row { grid-template-columns: 1fr; } }
.field { margin-bottom: 1.3rem; border: 0; padding: 0; min-width: 0; }
.field__label { display: block; font-size: var(--step--1); font-weight: 600; color: var(--ink); margin-bottom: 0.45rem; }
.field__opt { font-weight: 400; color: var(--muted); }
.req { color: var(--accent); }
.field__input { width: 100%; padding: 0.8rem 1rem; font: inherit; color: var(--ink); background: var(--paper);
  border: 1px solid var(--line-2); border-radius: var(--radius-sm);
  transition: border-color var(--t-fast), box-shadow var(--t-fast); }
.field__input:focus-visible { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
textarea.field__input { resize: vertical; min-height: 8rem; }

.radio-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 0.6rem; }
@media (max-width: 560px) { .radio-cards { grid-template-columns: 1fr; } }
.radio-card { display: flex; align-items: center; gap: 0.6rem; padding: 0.75rem 0.9rem;
  border: 1px solid var(--line-2); border-radius: var(--radius-sm); cursor: pointer;
  font-size: var(--step--1); color: var(--ink-2); transition: border-color var(--t-fast), background var(--t-fast); }
.radio-card:hover { border-color: var(--accent); }
.radio-card input { accent-color: var(--accent); flex: none; }
.radio-card:has(input:checked) { border-color: var(--accent); background: var(--accent-soft); color: var(--ink); font-weight: 500; }

.radio-row { display: flex; flex-wrap: wrap; gap: 0.6rem; }
.radio-pill { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.5rem 1rem;
  border: 1px solid var(--line-2); border-radius: var(--radius-pill); cursor: pointer;
  font-size: var(--step--1); color: var(--ink-2); }
.radio-pill input { accent-color: var(--accent); }
.radio-pill:has(input:checked) { border-color: var(--accent); background: var(--accent-soft); color: var(--ink); }

.consent { display: flex; gap: 0.7rem; align-items: flex-start; font-size: var(--step--1); color: var(--ink-2);
  margin-bottom: 1.5rem; cursor: pointer; }
.consent input { accent-color: var(--accent); margin-top: 0.2rem; flex: none; width: 1.1rem; height: 1.1rem; }
.consent a { color: var(--accent); text-decoration: underline; }

.form__actions { display: flex; flex-wrap: wrap; align-items: center; gap: 1rem; }
.form__hint { margin: 1rem 0 0; font-size: var(--step--2); color: var(--muted); }
.form-status { margin: 0; font-size: var(--step--1); font-weight: 500; }
.form-status[data-state="error"] { color: var(--accent-2); }
.form-status[data-state="success"] { color: #2E7D52; }
.form-status[data-state="loading"] { color: var(--muted); }

/* --- FAQ-Seite ----------------------------------------------- */
.faq-page { max-width: 60rem; }
.faq-page__group + .faq-page__group { margin-top: clamp(2rem, 4vw, 3rem); }
.faq-page__title { font-size: var(--step-2); margin: 0 0 0.5rem; }

/* --- Danke --------------------------------------------------- */
.danke__inner { text-align: center; max-width: 46rem; margin-inline: auto; }
.danke__check { display: inline-grid; place-items: center; width: 4.5rem; height: 4.5rem; border-radius: 50%;
  background: var(--accent-soft); color: var(--accent); margin-bottom: 1.5rem; }
.danke__check svg { width: 2rem; height: 2rem; }

/* --- Bundesadler / Staatswappen ------------------------------ */
/* Emblem-Platte in der "staatliche Autoritaet"-Sektion */
.crest {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 1.5rem; text-align: center;
  padding: clamp(2rem, 5vw, 3.25rem);
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
}
.crest__img { width: min(58%, 290px); height: auto; display: block; }
.crest__cap { font-size: var(--step--1); line-height: 1.5; letter-spacing: 0.02em; color: var(--muted); max-width: 32ch; }
.crest__cap b { display: block; margin-bottom: 0.15rem; color: var(--ink-2); font-weight: 600; letter-spacing: 0.04em; }
@media (max-width: 860px) { .crest__img { width: min(48%, 220px); } }

/* Feature-Leiste (navy): Adler-Wasserzeichen, spiegelt den Footer */
.features { position: relative; overflow: hidden; }
.features .container { position: relative; z-index: 1; }
.features__crest {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  height: 86%; width: auto;            /* ganzer Adler, nach Sektionshoehe skaliert */
  opacity: 0.06;            /* Navy-Adler auf hellem Grau (kein Invert-Filter mehr) */
  pointer-events: none; user-select: none; z-index: 0;
}
@media (max-width: 820px) { .features__crest { height: auto; width: 72%; opacity: 0.06; } }

/* Footer-Wasserzeichen: Adler blass & weiss hinter den Inhalten */
.site-footer { position: relative; overflow: hidden; }
.site-footer .container { position: relative; z-index: 1; }
.site-footer__crest {
  position: absolute; right: clamp(-3.5rem, -3vw, -1.5rem); bottom: -12%;
  width: clamp(220px, 30vw, 400px); height: auto;
  opacity: 0.06;            /* Navy-Adler auf hellem Grau (kein Invert-Filter mehr) */
  pointer-events: none; user-select: none; z-index: 0;
}
@media (max-width: 620px) { .site-footer__crest { width: 260px; opacity: 0.055; right: -3rem; bottom: -6%; } }

/* --- Öffnungs- & Telefonzeiten (Karten) --------------------- */
.hours { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1rem, 2.5vw, 1.5rem); margin-top: clamp(2rem, 4vw, 2.75rem); }
.hours__card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-md);
  padding: clamp(1.4rem, 2.5vw, 1.9rem) clamp(1.5rem, 2.5vw, 2rem); }
.hours__title { display: flex; align-items: center; gap: 0.6rem; margin: 0 0 0.3rem; padding-bottom: 1rem;
  border-bottom: 1px solid var(--line); font-size: var(--step-1); font-weight: 600; color: var(--ink); }
.hours__title svg { width: 1.3rem; height: 1.3rem; flex: none; color: var(--accent); }
.hours__list { list-style: none; margin: 0; padding: 0; }
.hours__list li { padding: 0.9rem 0; border-top: 1px solid var(--line); }
.hours__list li:first-child { border-top: 0; }
.hours__day { display: block; margin-bottom: 0.3rem; font-size: var(--step--2); font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); }
.hours__time { display: block; font-size: var(--step-0); font-weight: 500; color: var(--ink);
  line-height: 1.5; font-variant-numeric: tabular-nums; }
.hours__note { margin: 1.1rem 0 0; color: var(--muted); font-size: var(--step--1); }
@media (max-width: 700px) { .hours { grid-template-columns: 1fr; } }
