:root {
  --font-family: "Sora", sans-serif;
  --font-size-base: 15.8px;
  --line-height-base: 1.79;

  --max-w: 840px;
  --space-x: 1.29rem;
  --space-y: 1.5rem;
  --gap: 0.91rem;
  --space-section-y: calc(var(--space-y) * 2.4);
  --space-section-x: var(--space-x);
  --space-block: calc(var(--gap) * 1.5);
  --space-card: calc(var(--space-y) * .75);
  --font-size-sm: calc(var(--font-size-base) * .875);
  --font-size-md: var(--font-size-base);
  --font-size-lg: calc(var(--font-size-base) * 1.125);
  --font-size-h3: calc(var(--font-size-base) * 1.35);
  --font-size-h2: calc(var(--font-size-base) * 2);
  --font-size-h1: calc(var(--font-size-base) * 2.65);
  --motion-distance: calc(var(--gap) * var(--random-number));

  --radius-xl: 0.7rem;
  --radius-lg: 0.58rem;
  --radius-md: 0.36rem;
  --radius-sm: 0.26rem;

  --shadow-sm: 0 1px 3px rgba(0,0,0,0.05);
  --shadow-md: 0 4px 14px rgba(0,0,0,0.06);
  --shadow-lg: 0 12px 18px rgba(0,0,0,0.08);

  --overlay: rgba(15, 23, 42, 0.6);
  --anim-duration: 340ms;
  --anim-ease: ease;
  --random-number: 2;

  --brand: #2563EB;
  --brand-contrast: #FFFFFF;
  --accent: #3B82F6;
  --accent-contrast: #FFFFFF;

  --neutral-0: #FFFFFF;
  --neutral-100: #F1F5F9;
  --neutral-300: #CBD5E1;
  --neutral-600: #64748B;
  --neutral-800: #1E293B;
  --neutral-900: #0F172A;

  --page-bg: #F8FAFC;
  --page-fg: #1E293B;
  --muted-bg: #F1F5F9;
  --muted-fg: #475569;
  --card-bg: #FFFFFF;
  --card-fg: #1E293B;
  --card-border: #E2E8F0;
  --inverse-bg: #1E3A5F;
  --inverse-fg: #F8FAFC;
  --primary-bg: #2563EB;
  --primary-fg: #FFFFFF;
  --primary-hover: #1D4ED8;
  --accent-bg: #3B82F6;
  --accent-fg: #FFFFFF;
  --accent-hover: #2563EB;
  --gradient-hero-bg: linear-gradient(135deg, #1E3A5F 0%, #2563EB 100%);
  --gradient-hero-fg: #FFFFFF;
  --gradient-accent-bg: linear-gradient(135deg, #2563EB 0%, #1D4ED8 100%);
  --gradient-accent-fg: #FFFFFF;

  --ring: #2563EB;

  --link: #2563EB;
  --link-hover: #3B82F6;

  --btn-ghost-bg: transparent;
  --btn-ghost-bg-hover: color-mix(in srgb, currentColor 10%, transparent);
  --input-placeholder: rgba(255,255,255,0.55);
}
body{margin:0;padding:0;font-family:var(--font-family);box-sizing: border-box;}
*{box-sizing:border-box;}
a{color:inherit;}
.btn-primary,.btn.btn-primary{background:var(--primary-bg)!important;color:var(--primary-fg)!important;border-color:var(--primary-bg)!important;}
.btn-primary:hover,.btn.btn-primary:hover{background:var(--primary-hover)!important;color:var(--primary-fg)!important;border-color:var(--primary-hover)!important;}
.btn-outline-primary{color:var(--primary-bg)!important;border-color:var(--primary-bg)!important;}
.btn-outline-primary:hover{background:var(--primary-bg)!important;color:var(--primary-fg)!important;}
.bg-primary{background:var(--primary-bg)!important;color:var(--primary-fg)!important;}
.text-primary{color:var(--primary-bg)!important;}
.border-primary{border-color:var(--primary-bg)!important;}
.bg-light{background:var(--page-bg)!important;color:var(--page-fg)!important;}
.bg-dark{background:var(--inverse-bg)!important;color:var(--inverse-fg)!important;}

/* ===== Header – Basis ===== */
.site-header {
  width: 100%;
  background-color: var(--page-bg, #ffffff);
  border-bottom: 1px solid var(--muted-bg, #e5e7eb);
  /* Kein fixed/sticky */
  position: relative;
  z-index: 100;
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: var(--max-w, 1200px);
  margin: 0 auto;
  padding: var(--space-y, 0.75rem) var(--space-x, 1.5rem);
  gap: var(--gap, 1rem);
  min-height: 3.75rem; /* angenehme Höhe */
}

/* ===== Logo ===== */
.logo-link {
  font-size: var(--font-size-h3, 1.5rem);
  font-weight: 600;
  color: var(--page-fg, #111827);
  text-decoration: none;
  letter-spacing: -0.02em;
  line-height: 1.2;
  white-space: nowrap;
  flex-shrink: 0;
}

.logo-link:hover {
  color: var(--link-hover, #2563eb);
}

/* ===== Navigation (Desktop) ===== */
.main-nav {
  display: flex;
  align-items: center;
}

.nav-list {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: var(--gap, 1.5rem);
}

.nav-link {
  font-size: var(--font-size-md, 1rem);
  color: var(--page-fg, #111827);
  text-decoration: none;
  padding: 0.25rem 0;
  border-bottom: 2px solid transparent;
  transition: border-color var(--anim-duration, 0.2s) var(--anim-ease, ease), color var(--anim-duration, 0.2s) var(--anim-ease, ease);
  white-space: nowrap;
}

.nav-link:hover,
.nav-link:focus-visible {
  color: var(--link-hover, #2563eb);
  border-bottom-color: var(--link-hover, #2563eb);
}

/* ===== CTA Button ===== */
.cta-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--primary-bg, #2563eb);
  color: var(--primary-fg, #ffffff);
  font-size: var(--font-size-sm, 0.875rem);
  font-weight: 500;
  padding: 0.5rem 1.25rem;
  border-radius: var(--radius-md, 8px);
  text-decoration: none;
  white-space: nowrap;
  transition: background-color var(--anim-duration, 0.2s) var(--anim-ease, ease), box-shadow var(--anim-duration, 0.2s) var(--anim-ease, ease);
  box-shadow: var(--shadow-sm, 0 1px 2px rgba(0,0,0,0.05));
  flex-shrink: 0;
}

.cta-button:hover {
  background-color: var(--primary-hover, #1d4ed8);
  box-shadow: var(--shadow-md, 0 4px 6px rgba(0,0,0,0.07));
}

/* ===== Burger Button (mobil) ===== */
.burger-button {
  display: none; /* nur mobil sichtbar */
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 2.5rem;
  height: 2.5rem;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0.25rem;
  gap: 4px;
  border-radius: var(--radius-sm, 4px);
  transition: background var(--anim-duration, 0.2s) ease;
  flex-shrink: 0;
}

.burger-button:hover {
  background-color: var(--muted-bg, #f3f4f6);
}

.burger-line {
  display: block;
  width: 1.25rem;
  height: 2px;
  background-color: var(--page-fg, #111827);
  border-radius: 2px;
  transition: transform var(--anim-duration, 0.3s) ease, opacity var(--anim-duration, 0.2s) ease;
}

/* Burger geöffnet (aria-expanded) */
.burger-button[aria-expanded="true"] .burger-line:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}
.burger-button[aria-expanded="true"] .burger-line:nth-child(2) {
  opacity: 0;
}
.burger-button[aria-expanded="true"] .burger-line:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}

/* ===== Mobile Navigation (max-width: 767px) ===== */
@media (max-width: 767px) {
  .burger-button {
    display: flex; /* Burger erscheint */
  }

  .main-nav {
    position: absolute;
    top: 100%; /* direkt unter dem Header */
    left: 0;
    right: 0;
    background-color: var(--page-bg, #ffffff);
    border-bottom: 1px solid var(--muted-bg, #e5e7eb);
    box-shadow: var(--shadow-md, 0 8px 16px rgba(0,0,0,0.06));
    padding: 0 var(--space-x, 1.5rem) var(--space-y, 0.75rem);
    max-height: 0;
    overflow: hidden;
    visibility: hidden;
    opacity: 0;
    transition: max-height 0.35s ease, opacity 0.25s ease, visibility 0.25s ease;
  }

  .main-nav.is-open {
    max-height: 400px; /* genug Platz für 3–4 Items */
    visibility: visible;
    opacity: 1;
  }

  .nav-list {
    flex-direction: column;
    gap: 0.5rem;
    padding: 0.5rem 0;
  }

  .nav-link {
    font-size: var(--font-size-md, 1rem);
    padding: 0.5rem 0;
    border-bottom: none;
    display: block;
  }

  .nav-link:hover {
    border-bottom: none;
  }

  /* CTA im mobilen Fall bleibt sichtbar, aber ggf. kleiner */
  .cta-button {
    font-size: var(--font-size-sm, 0.875rem);
    padding: 0.4rem 1rem;
  }
}

/* ===== Kleine Anpassungen für sehr enge Viewports ===== */
@media (max-width: 480px) {
  .header-inner {
    padding-left: var(--space-x, 1rem);
    padding-right: var(--space-x, 1rem);
    gap: 0.5rem;
  }

  .logo-link {
    font-size: var(--font-size-md, 1.25rem);
  }

  .cta-button {
    font-size: 0.75rem;
    padding: 0.35rem 0.75rem;
  }
}

footer {
    background-color: #f8f9fa;
    color: #333;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
    padding: 2.5rem 1.5rem 1rem;
    font-size: 0.95rem;
    line-height: 1.6;
  }
  .footer-container {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    max-width: 1200px;
    margin: 0 auto;
    justify-content: space-between;
  }
  .footer-column {
    flex: 1 1 220px;
    min-width: 180px;
  }
  .brand-column {
    flex: 1.5 1 260px;
  }
  .footer-logo {
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 1px;
    color: #1a1a2e;
    margin-bottom: 0.5rem;
  }
  .footer-tagline {
    color: #555;
    margin: 0.25rem 0 0;
  }
  .footer-nav {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-bottom: 1.2rem;
  }
  .footer-nav a {
    color: #1a1a2e;
    text-decoration: none;
    font-weight: 500;
    transition: color 0.2s;
  }
  .footer-nav a:hover {
    color: #0056b3;
    text-decoration: underline;
  }
  .footer-legal-links {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    margin-top: 0.5rem;
  }
  .footer-legal-links a {
    color: #555;
    text-decoration: none;
    font-size: 0.88rem;
    transition: color 0.2s;
  }
  .footer-legal-links a:hover {
    color: #0056b3;
    text-decoration: underline;
  }
  .footer-contact p {
    margin: 0.3rem 0;
  }
  .footer-contact a {
    color: #1a1a2e;
    text-decoration: none;
  }
  .footer-contact a:hover {
    text-decoration: underline;
    color: #0056b3;
  }
  .footer-disclaimer {
    font-size: 0.8rem;
    color: #777;
    margin-top: 1.2rem;
    line-height: 1.4;
    border-top: 1px solid #e0e0e0;
    padding-top: 0.8rem;
  }
  .footer-bottom {
    text-align: center;
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid #ddd;
    font-size: 0.85rem;
    color: #888;
  }
  @media (max-width: 768px) {
    .footer-container {
      flex-direction: column;
      gap: 1.5rem;
    }
    .footer-column {
      flex: 1 1 100%;
    }
    .footer-logo {
      font-size: 1.4rem;
    }
  }

.cookies {
    position: fixed;
    left: var(--space-x);
    right: var(--space-x);
    bottom: var(--space-y);
    z-index: 1200;
}

.cookies .stack {
    max-width: 860px;
    margin: 0 auto;
    background: var(--card-bg);
    color: var(--card-fg);
    border-radius: var(--radius-lg);
    padding: var(--space-y) var(--space-x);
    box-shadow: var(--shadow-lg);
}

.cookies .stack strong {
    display: block;
    margin-bottom: 6px;
}

.cookies .stack p {
    margin: 0;
}

.cookies .actions {
    margin-top: 12px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.cookies .actions a {
    text-decoration: none;
    border: 1px solid rgba(148, 163, 184, 0.5);
    border-radius: 999px;
    padding: 7px 12px;
    transition: background var(--anim-duration) var(--anim-ease), color var(--anim-duration) var(--anim-ease);
}

.cookies .actions a[data-choice='accept'] {
    background: var(--accent-fg);
    background: var(--accent-bg);
    border-color: transparent;
    color: var(--page-fg);
    font-weight: 700;
}

.cookies .actions a:hover {
    background: rgba(148, 163, 184, 0.2);
    color: var(--page-fg);
}

.hero {
    padding: clamp(3.9rem, 9vw, 7rem) var(--space-x);
    background: radial-gradient(circle at 20% 20%, color-mix(in srgb, currentColor 18%, transparent), transparent 25%), var(--gradient-hero-bg);
    color: var(--gradient-hero-fg);
}

.hero .wrap {
    max-width: 58rem;
    margin: 0 auto;
    text-align: center;
}

.hero .copy p {
    margin: 0;
    color: color-mix(in srgb, currentColor 75%, transparent);
    text-transform: uppercase;
    letter-spacing: .1em;
    font-size: .82rem;
}

.hero .copy h1 {
    margin: .6rem 0 0;
    font-size: clamp(2.5rem, 5vw, 4.6rem);
    line-height: 1;
}

.hero .copy span {
    display: block;
    margin-top: .9rem;
    color: color-mix(in srgb, currentColor 88%, transparent);
}

.hero .actions {
    margin-top: 1.2rem;
    display: flex;
    gap: .75rem;
    justify-content: center;
    flex-wrap: wrap;
}

.hero .btn {
    display: inline-flex;
    min-height: 2.85rem;
    align-items: center;
    justify-content: center;
    padding: 0 1rem;
    border-radius: 999px;
    text-decoration: none;
    background: color-mix(in srgb, currentColor 14%, transparent);
    border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
}

.hero .mod-primary {
    background: var(--card-bg);
    color: var(--card-fg);
}

.solutions{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}
.solutions .grid{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:1fr 1.25fr;gap:var(--gap);}
.solutions .cap-intro{padding:1.2rem;border-radius:var(--radius-xl);background:var(--card-bg);border:1px solid var(--card-border);color:var(--card-fg);}
.solutions .cap-intro h2{margin:0;font-size:clamp(1.8rem,3.2vw,2.5rem);}
.solutions .cap-intro p{margin:.55rem 0 1rem;}
.solutions .cap-intro a{display:inline-block;padding:.6rem .95rem;border-radius:var(--radius-md);background:var(--primary-bg);color:var(--primary-fg);text-decoration:none;}
.solutions .cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem;}
.solutions article{padding:1rem;border-radius:var(--radius-lg);background:linear-gradient(180deg,var(--card-bg),var(--muted-bg));border:1px solid var(--card-border);color:var(--card-fg);}
.solutions .index{margin:0 0 .35rem;font-weight:700;}
.solutions h3{margin:0 0 .35rem;}
.solutions article p{margin:0;}
@media (max-width:900px){.solutions .grid{grid-template-columns:1fr;}.solutions .cards{grid-template-columns:1fr;}}

.tpl-variant-next-step-colored-v5{background-image:linear-gradient(135deg,color-mix(in srgb,currentColor 6%,transparent),transparent 48%);}
.tpl-variant-next-step-colored-v5 .grid,.tpl-variant-next-step-colored-v5 .cards,.tpl-variant-next-step-colored-v5 .list,.tpl-variant-next-step-colored-v5 .stack{gap:calc(var(--gap,1rem) * 1.08);}
.tpl-variant-next-step-colored-v5 article:nth-child(even),.tpl-variant-next-step-colored-v5 .card:nth-child(even),.tpl-variant-next-step-colored-v5 .item:nth-child(even){transform:translateY(0.35rem);}
.followup{padding:clamp(3.6rem,8vw,6.2rem) var(--space-x);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);}

    .followup .wrap{max-width:58rem;margin:0 auto;text-align:center;}

    .followup .banner p{margin:0;}

    .followup .banner h2{margin:.5rem 0 0;font-size:clamp(2.1rem,4vw,3.1rem);}

    .followup .fan{margin-top:1.15rem;display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;}

    .followup .fan a{display:block;padding:.9rem 1rem;min-width:10rem;border-radius:var(--radius-lg);background:var(--accent-bg);border:1px solid color-mix(in srgb, currentColor 18%, transparent);color:var(--accent-fg);text-decoration:none;}

    .followup .fan span{display:block;margin-top:.3rem;}

    .followup .tail{margin-top:1rem;}

    .followup .wrap > a{display:inline-flex;margin-top:1rem;min-height:2.85rem;align-items:center;justify-content:center;padding:0 1rem;border-radius:999px;background:var(--card-bg);color:var(--card-fg);text-decoration:none;}

.why-choose{background:var(--muted-bg);color:var(--muted-fg);padding:clamp(40px,6vw,80px) clamp(16px,3vw,40px);}

    .why-choose .c{max-width:var(--max-w);margin:0 auto;}

    .why-choose .h{text-align:center;margin-bottom:clamp(32px,5vw,64px);}

    .why-choose h2{font-size:clamp(32px,5vw,48px);margin:0 0 1rem;position:relative;display:inline-block;}

    .why-choose h2::after{content:'';position:absolute;bottom:-8px;left:0;width:100%;height:4px;background:var(--primary-bg);border-radius:var(--radius-sm);transform-origin:left;color:var(--primary-fg);}

    .why-choose .subtitle{font-size:clamp(16px,2vw,20px);margin:0;}

    .why-choose .list{display:flex;flex-direction:column;gap:clamp(16px,2vw,24px);}

    .why-choose .item{display:flex;gap:clamp(16px,2vw,24px);background:var(--card-bg);padding:clamp(20px,3vw,32px);border-radius:var(--radius-lg);border:1px solid var(--card-border);box-shadow:var(--shadow-sm);align-items:flex-start;position:relative;overflow:hidden;transition:transform var(--anim-duration) var(--anim-ease);color:var(--card-fg);}

    .why-choose .wave{position:absolute;bottom:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--primary-bg),var(--accent-bg));transform:scaleX(.18);transform-origin:left;transition:transform var(--anim-duration) var(--anim-ease);color:var(--primary-fg);}

    .why-choose .item:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}

    .why-choose .item:hover .wave{transform:scaleX(1);}

    .why-choose .content{flex:1;}

    .why-choose .item h3{font-size:clamp(18px,2.2vw,24px);margin:0 0 0.75rem;position:relative;}

    .why-choose .item h3::before{content:'';position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:4px;height:0;background:var(--primary-bg);border-radius:var(--radius-sm);transition:height var(--anim-duration) var(--anim-ease);color:var(--primary-fg);}

    .why-choose .item:hover h3::before{height:100%;}

    .why-choose .item p{margin:0;line-height:var(--line-height-base);}

.recommendations {
  padding: calc(var(--space-y) * 2.9) var(--space-x);
  background: var(--gradient-hero-bg);
  color: var(--gradient-hero-fg);
}
.recommendations .shell {
  max-width: var(--max-w);
  margin: 0 auto;
  display: grid;
  gap: var(--gap);
}
.recommendations h2 {
  margin: 0;
  font-size: clamp(1.85rem, 3.6vw, 2.8rem);
  line-height: 1.1;
}
.recommendations .sub {
  margin: .35rem 0 0;
  opacity: .9;
}
.recommendations article,
.recommendations li {
  padding: .85rem;
  border-radius: var(--radius-sm);
  background: var(--accent-bg);
  border: 1px solid var(--btn-ghost-bg-hover);
  list-style: none;
  color: var(--accent-fg);
}
.recommendations p {
  margin: 0;
}
.recommendations a {
  text-decoration: none;
  color: inherit;
  font-weight: 700;
}
.recommendations .rail {
  display: flex;
  gap: .55rem;
  overflow: auto;
}
.recommendations .rail article {
  min-width: 240px;
}
@media (max-width: 860px) {
  .recommendations .split,
  .recommendations .media,
  .recommendations .grid,
  .recommendations .cards,
  .recommendations .bento,
  .recommendations .foot {
    grid-template-columns: 1fr;
  }
}

.notes{padding:clamp(18px,3vw,44px);background:var(--gradient-hero-bg);color:var(--gradient-hero-fg);}

    .notes .c{max-width:var(--max-w);margin:0 auto;}

    .notes .h{margin-bottom:clamp(14px,2.2vw,22px);}

    .notes .title{margin:0;font-size:clamp(24px,4.4vw,42px);letter-spacing:-.02em;line-height:1.1;}

    .notes .sub{margin:10px 0 0;max-width:70ch;color:color-mix(in srgb, currentColor 82%, transparent);}

    .notes .rail{position:relative;border-radius:var(--radius-xl);background:color-mix(in srgb, currentColor 8%, transparent);border:1px solid color-mix(in srgb, currentColor 16%, transparent);box-shadow:var(--shadow-lg);overflow:hidden;}

    .notes .beam{position:absolute;top:0;left:0;width:48%;height:100%;background:linear-gradient(90deg,transparent,color-mix(in srgb, currentColor 12%, transparent),transparent);transform:translateX(-120%);animation:c2Beam 6.2s linear infinite;pointer-events:none;}

    @keyframes c2Beam{
        0% {transform:translateX(-120%);}
        55%{transform:translateX(160%);}
        100%{transform:translateX(160%);}
    }

    .notes .list{display:grid;gap:10px;padding:12px;}

    .notes .row{display:grid;grid-template-columns:auto 1fr;gap:12px;padding:12px 14px;border-radius:var(--radius-lg);background:color-mix(in srgb, currentColor 14%, transparent);border:1px solid color-mix(in srgb, currentColor 12%, transparent);transition:transform var(--anim-duration) var(--anim-ease),background var(--anim-duration) var(--anim-ease);}

    .notes .row.is-hot{transform:translateY(-2px);background:color-mix(in srgb, currentColor 12%, transparent);}

    .notes .tag{align-self:start;padding:8px 10px;border-radius:999px;background:color-mix(in srgb, currentColor 10%, transparent);border:1px solid color-mix(in srgb, currentColor 16%, transparent);font-weight:800;white-space:nowrap;color:color-mix(in srgb, currentColor 92%, transparent);}

    .notes .q{font-weight:900;letter-spacing:-.01em;margin-bottom:6px;}

    .notes .a{color:color-mix(in srgb, currentColor 82%, transparent);line-height:var(--line-height-base);}

    @media (max-width: 720px){.notes .row{grid-template-columns:1fr;}

        .notes .tag{justify-self:start;}
    }

    @media (prefers-reduced-motion: reduce){.notes .beam{animation:none;}
    }

.featured-cairn{padding:calc(var(--space-y)*2.8) var(--space-x);background:var(--page-bg);color:var(--page-fg)}
.featured-cairn .cairn-wrap{max-width:var(--max-w);margin:0 auto}
.featured-cairn h2{margin:0 0 1.2rem;color:var(--page-fg);font-size:clamp(1.9rem,4vw,3.1rem);line-height:1.05}
.featured-cairn .cairn-list{display:flex;gap:.85rem;align-items:stretch;overflow:auto;padding-bottom:.25rem}
.featured-cairn .cairn-card{flex:0 0 min(24rem,82vw);background:var(--card-bg);color:var(--card-fg);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:1rem;box-shadow:var(--shadow-sm)}
.featured-cairn h3{margin:0;color:var(--card-fg);font-size:var(--font-size-h3);line-height:1.15}
.featured-cairn p{margin:.65rem 0 0;color:var(--card-fg);opacity:.82;line-height:1.45}

.solutions {
    padding: calc(var(--space-y) * 2.7) var(--space-x);
    background: var(--gradient-hero-bg);
    color: var(--gradient-hero-fg);
}

.solutions .shell {
    max-width: var(--max-w);
    margin: 0 auto;
    display: grid;
    gap: .95rem;
}

.solutions h2 {
    margin: 0;
    font-size: clamp(1.9rem, 3.8vw, 2.8rem);
}

.solutions .cap-intro {
    margin: 0;
    max-width: 54ch;
    opacity: .9;
}

.solutions .strip {
    display: flex;
    gap: var(--gap);
    overflow: auto;
    padding-bottom: .2rem;
}

.solutions article {
    min-width: 250px;
    padding: .95rem;
    border-radius: var(--radius-md);
    background: var(--btn-ghost-bg-hover);
}

.solutions strong {
    display: inline-block;
    padding: .2rem .45rem;
    border-radius: var(--radius-sm);
    background: var(--accent-bg);
    color: var(--accent-fg);
}

.solutions h3 {
    margin: .55rem 0 .3rem;
}

.solutions p {
    margin: 0;
    opacity: .92;
}

.faq{padding:calc(var(--space-y) * 2.5) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}

    .faq .shell{max-width:var(--max-w);margin:0 auto;display:grid;gap:var(--gap);}

    .faq .head p{margin:.35rem 0 0;}

    .faq .grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--gap);}

    .faq article{padding:1rem;border-radius:var(--radius-lg);border:1px solid var(--card-border);background:var(--card-bg);color:var(--card-fg);}

    .faq h3{margin:0 0 .5rem;font-size:1.05rem;}

    .faq p{margin:0;}

    @media (max-width: 800px){.faq .grid{grid-template-columns:1fr;}
    }

.assistance{padding:clamp(50px,7vw,90px) clamp(16px,4vw,36px);background:var(--muted-bg);color:var(--muted-fg);}

    .assistance .wrap{max-width:920px;margin:0 auto;}

    .assistance .head{margin-bottom:14px;}

    .assistance .head h2{margin:0;font-size:clamp(28px,4vw,40px);}

    .assistance .head p{margin:8px 0 0;}

    .assistance .table{border:1px solid var(--card-border);border-radius:var(--radius-lg);overflow:hidden;}

    .assistance .table article{display:grid;grid-template-columns:.8fr 1.2fr;gap:12px;padding:12px;border-bottom:1px solid var(--card-border);background:var(--muted-bg);color:var(--muted-fg);}

    .assistance .table article:last-child{border-bottom:0;}

    .assistance .table h3{margin:0;font-size:1rem;}

    .assistance .table p{margin:0;}

    @media (max-width: 700px){.assistance .table article{grid-template-columns:1fr;}
    }

.form-coppergate{padding:calc(var(--space-y)*3) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}
.form-coppergate .coppergate-wrap{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:.78fr 1.22fr;gap:var(--gap);align-items:start;}
.form-coppergate .coppergate-copy{border-left:4px solid var(--accent-bg);padding-left:1rem;}
.form-coppergate h2{margin:0;font-size:clamp(2rem,4vw,3.25rem);line-height:1.04;}.form-coppergate p{margin:.8rem 0 0;}.form-coppergate small{display:block;margin-top:1.2rem;color:var(--muted-fg);opacity:.7;}
.form-coppergate .coppergate-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem;background:var(--card-bg);color:var(--card-fg);border-radius:var(--radius-xl);padding:1rem;border:1px solid var(--card-border);}
.form-coppergate label{display:grid;gap:.3rem;}.form-coppergate span{font-size:.82rem;color:var(--muted-fg);}.form-coppergate input,.form-coppergate textarea{width:100%;border:1px solid var(--card-border);border-radius:var(--radius-md);padding:.75rem;font:inherit;color:var(--card-fg);background:var(--card-bg);}
.form-coppergate .coppergate-wide{grid-column:1/-1;}.form-coppergate textarea{min-height:9rem;resize:vertical;}.form-coppergate button{justify-self:start;border:0;border-radius:var(--radius-md);background:var(--primary-bg);color:var(--primary-fg);font:inherit;font-weight:700;padding:.82rem 1.1rem;cursor:pointer;}
@media (max-width:820px){.form-coppergate .coppergate-wrap,.form-coppergate .coppergate-form{grid-template-columns:1fr;}}

.reach{padding:calc(var(--space-y)*2.9) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}
.reach .stage{max-width:var(--max-w);margin:0 auto;padding:1.1rem;border-radius:var(--radius-xl);background:var(--card-bg);border:1px solid var(--card-border);color:var(--card-fg);}
.reach .head h2{margin:0;font-size:clamp(1.75rem,3.1vw,2.45rem);}
.reach .head p{margin:.4rem 0 .95rem;}
.reach .columns{display:grid;grid-template-columns:1.2fr .8fr;gap:.75rem;}
.reach .essentials{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem;}
.reach .essentials article{padding:.9rem;border-radius:var(--radius-md);background:var(--muted-bg);color:var(--muted-fg);}
.reach small{display:block;margin-bottom:.2rem;}
.reach a{text-decoration:none;font-weight:700;}
.reach .side{padding:.9rem;border-radius:var(--radius-md);border:1px solid var(--card-border);}
.reach .side p{margin:0 0 .55rem;}
.reach .side p:last-child{margin:0;}
.reach .tags{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.85rem;}
.reach .tags a{padding:.35rem .6rem;border-radius:99px;background:var(--muted-bg);border:1px solid var(--card-border);font-weight:600;color:var(--muted-fg);}
@media (max-width:860px){.reach .columns,.reach .essentials{grid-template-columns:1fr;}}

.privacy-notes{padding:calc(var(--space-y)*2.95) var(--space-x);background:var(--muted-bg);color:var(--muted-fg);}
.privacy-notes .wrap{max-width:var(--max-w);margin:0 auto;}
.privacy-notes h2{margin:0 0 .85rem;font-size:clamp(1.76rem,3.1vw,2.45rem);}
.privacy-notes .cols{display:grid;grid-template-columns:.95fr 1.05fr;gap:var(--gap);}
.privacy-notes .left{padding:1rem;border-radius:var(--radius-lg);border:1px solid var(--card-border);background:var(--card-bg);color:var(--card-fg);}
.privacy-notes .left h3{margin:0 0 .32rem;}
.privacy-notes .left p{margin:0;}
.privacy-notes .right{list-style:none;margin:0;padding:0;display:grid;gap:.5rem;}
.privacy-notes .right li{padding:.8rem;border-radius:var(--radius-md);background:var(--card-bg);border:1px solid var(--card-border);color:var(--card-fg);}
.privacy-notes .right h4{margin:0 0 .2rem;font-size:1rem;}
.privacy-notes .right p{margin:0;}
.privacy-notes .note{display:flex;gap:.7rem;margin-top:.75rem;padding:.8rem;border-radius:var(--radius-md);background:var(--muted-bg);color:var(--muted-fg);}
@media (max-width:860px){.privacy-notes .cols{grid-template-columns:1fr;}.privacy-notes .note{display:grid;}}

.terms{padding:clamp(56px,8vw,96px) clamp(16px,4vw,36px);background:var(--card-bg);color:var(--card-fg);}

    .terms .wrap{max-width:900px;margin:0 auto;}

    .terms .section-head{margin-bottom:16px;text-align:center;}

    .terms h2{margin:0;font-size:clamp(28px,4vw,40px);}

    .terms .section-head p{margin:10px auto 0;color:var(--neutral-600);max-width:70ch;}

    .terms ol{margin:0;padding-left:18px;display:grid;gap:10px;}

    .terms li{background:var(--muted-bg);border-radius:var(--radius-md);border:1px solid var(--card-border);padding:12px;color:var(--muted-fg);}

    .terms h3{margin:0;font-size:1rem;}

    .terms li p{margin:8px 0 0;color:var(--neutral-600);}

.done {
    padding: calc(var(--space-y)*2.9) var(--space-x);
    background: var(--gradient-hero-bg);
    color: var(--gradient-hero-fg);
  }
  .done .shell {
    max-width: var(--max-w);
    margin: 0 auto;
    display: grid;
    gap: var(--gap);
  }
  .done h2 {
    margin: 0;
    font-size: clamp(1.85rem, 3.6vw, 2.8rem);
    line-height: 1.1;
  }
  .done .sub {
    margin: .35rem 0 0;
    opacity: .9;
  }
  .done article,
  .done li {
    padding: .85rem;
    border-radius: var(--radius-sm);
    background: var(--accent-bg);
    border: 1px solid var(--btn-ghost-bg-hover);
    list-style: none;
    color: var(--accent-fg);
  }
  .done p {
    margin: 0;
  }
  .done a {
    text-decoration: none;
    color: inherit;
    font-weight: 700;
  }
  .done .pulse {
    margin-top: .8rem;
    padding: 1rem;
    border-radius: var(--radius-lg);
    background: var(--accent-bg);
    border: 1px solid var(--btn-ghost-bg-hover);
    animation: thank-u1Pulse 2.8s ease-in-out infinite;
    color: var(--accent-fg);
  }
  @keyframes thank-u1Pulse {
    0%,
    100% {
      transform: scale(1);
    }
    50% {
      transform: scale(1.01);
    }
  }
  @media (max-width:860px) {
    .done .split,
    .done .media,
    .done .grid,
    .done .cards,
    .done .bento,
    .done .foot {
      grid-template-columns: 1fr;
    }
  }

.error-page{padding:clamp(56px,10vw,112px) 20px;background:linear-gradient(150deg,var(--primary-bg),var(--accent-bg));color:var(--primary-fg);}

    .error-page .shell{max-width:700px;margin:0 auto;text-align:center;border-radius:var(--radius-xl);padding:clamp(28px,4vw,44px);background:rgba(15, 23, 42,.24);border:1px solid color-mix(in srgb, currentColor 24%, transparent);color:var(--neutral-0);}

    .error-page h1{margin:0;font-size:clamp(32px,6vw,56px);}

    .error-page p{margin:12px 0 0;opacity:.9;}

    .error-page a{display:inline-block;margin-top:18px;padding:10px 16px;border-radius:var(--radius-sm);background:var(--page-bg);color:var(--page-fg);text-decoration:none;}