:root {
      --bg: #f8f6f1;
      --bg-soft: #ece7dc;
      --ink: #171717;
      --ink-2: #29251f;
      --muted: #746c61;
      --line: rgba(23, 23, 23, 0.12);
      --card: rgba(255, 253, 248, 0.78);
      --white: #ffffff;
      --gold: #b5965b;
      --olive: #677a58;
      --wine: #6f2f3f;
      --sea: #496b73;
      --shadow: 0 28px 80px rgba(23, 23, 23, 0.16);
      --ease: cubic-bezier(.2, .8, .2, 1);
    }

    * {
      box-sizing: border-box;
    }

    html {
      scroll-behavior: smooth;
    }

    body {
      margin: 0;
      font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
      color: var(--ink);
      background:
        radial-gradient(circle at 12% 10%, rgba(103, 122, 88, 0.14), transparent 28rem),
        radial-gradient(circle at 92% 5%, rgba(111, 47, 63, 0.11), transparent 25rem),
        linear-gradient(180deg, #fbfaf6 0%, var(--bg) 38%, #f3efe6 100%);
      line-height: 1.5;
      text-rendering: optimizeLegibility;
    }

    body::before {
      position: fixed;
      inset: 0;
      z-index: -1;
      pointer-events: none;
      content: "";
      opacity: 0.22;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
    }

    a {
      color: inherit;
      text-decoration: none;
    }

    img {
      max-width: 100%;
      height: auto;
    }

    :focus-visible {
      outline: 3px solid var(--gold);
      outline-offset: 4px;
    }

    .skip-link {
      position: fixed;
      left: 16px;
      top: 16px;
      z-index: 100;
      padding: 12px 16px;
      border-radius: 8px;
      background: var(--ink);
      color: var(--white);
      font-weight: 800;
      transform: translateY(-140%);
      transition: transform 0.2s var(--ease);
    }

    .skip-link:focus {
      transform: translateY(0);
    }

    .page {
      overflow: hidden;
    }

    .container {
      width: min(1180px, calc(100% - 40px));
      margin: 0 auto;
    }

    .nav {
      position: sticky;
      top: 0;
      z-index: 20;
      border-bottom: 1px solid rgba(23, 23, 23, 0.08);
      background: rgba(248, 246, 241, 0.76);
      backdrop-filter: blur(22px) saturate(160%);
      transition: box-shadow 0.35s var(--ease), background 0.35s var(--ease);
    }

    .nav.is-scrolled {
      background: rgba(248, 246, 241, 0.9);
      box-shadow: 0 18px 50px rgba(23, 23, 23, 0.08);
    }

    .nav-inner {
      min-height: 76px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
    }

    .logo {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      min-width: 0;
    }

    .logo-mark {
      width: 60px;
      height: 60px;
      flex: 0 0 auto;
      background: url("handled-mark-source.png") center/contain no-repeat;
      filter: contrast(1.08);
    }

    .logo-copy {
      display: flex;
      flex-direction: column;
      min-width: 0;
    }

    .logo-name {
      font-family: "Cormorant Garamond", Georgia, serif;
      font-size: 32px;
      font-weight: 700;
      line-height: 0.86;
      letter-spacing: 0;
    }

    .nav-links {
      display: flex;
      align-items: center;
      gap: 30px;
      color: var(--muted);
      font-size: 14px;
    }

    .nav-links a {
      position: relative;
      transition: color 0.25s var(--ease);
    }

    .nav-links a::after {
      position: absolute;
      left: 0;
      bottom: -8px;
      width: 100%;
      height: 1px;
      background: var(--ink);
      content: "";
      transform: scaleX(0);
      transform-origin: left;
      transition: transform 0.3s var(--ease);
    }

    .nav-links a:hover {
      color: var(--ink);
    }

    .nav-links a:hover::after {
      transform: scaleX(1);
    }

    .language-switcher {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      list-style: none;
      margin: 0;
      padding: 7px;
      border: 1px solid var(--line);
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.42);
      color: var(--muted);
      font-size: 10px;
      font-weight: 900;
      letter-spacing: 0.08em;
    }

    .language-switcher span {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-width: 26px;
      min-height: 24px;
      border-radius: 999px;
    }

    .language-switcher [aria-current="true"] {
      background: var(--ink);
      color: var(--white);
    }

    .language-switcher [aria-disabled="true"] {
      opacity: 0.45;
    }

    .button {
      position: relative;
      isolation: isolate;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 48px;
      padding: 0 24px;
      overflow: hidden;
      border: 1px solid rgba(23, 23, 23, 0.92);
      border-radius: 999px;
      background: var(--ink);
      color: var(--white);
      box-shadow: 0 14px 34px rgba(23, 23, 23, 0.14);
      font-size: 12px;
      font-weight: 800;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease), border-color 0.3s var(--ease);
    }

    .button::before {
      position: absolute;
      inset: 0;
      z-index: -1;
      background: linear-gradient(115deg, var(--ink), var(--sea), var(--wine));
      content: "";
      opacity: 0;
      transition: opacity 0.3s var(--ease);
    }

    .button:hover {
      border-color: transparent;
      box-shadow: 0 22px 48px rgba(23, 23, 23, 0.2);
      transform: translateY(-2px);
    }

    .button:hover::before {
      opacity: 1;
    }

    .button.secondary {
      background: rgba(255, 255, 255, 0.42);
      color: var(--ink);
      border-color: var(--line);
      box-shadow: none;
    }

    .button.secondary::before {
      background: var(--ink);
    }

    .button.secondary:hover {
      color: var(--white);
      border-color: var(--ink);
    }

    .hero {
      position: relative;
      min-height: calc(100vh - 76px);
      padding: 96px 0 58px;
      display: flex;
      align-items: flex-end;
      overflow: hidden;
      border-top: 0;
      background:
        linear-gradient(90deg, rgba(10, 11, 11, 0.72) 0%, rgba(10, 11, 11, 0.43) 45%, rgba(10, 11, 11, 0.06) 100%),
        linear-gradient(180deg, rgba(10, 11, 11, 0.12) 0%, rgba(10, 11, 11, 0.12) 52%, rgba(10, 11, 11, 0.58) 100%),
        url('handled-hero-coast.webp') center/cover;
      color: var(--white);
    }

    .hero::before {
      position: absolute;
      inset: 0;
      pointer-events: none;
      content: "";
      background: radial-gradient(circle at 18% 34%, rgba(255, 255, 255, 0.16), transparent 28rem);
    }

    .hero::after {
      position: absolute;
      inset: auto 0 0;
      height: 28%;
      pointer-events: none;
      content: "";
      background: linear-gradient(to top, rgba(10, 11, 11, 0.76), transparent);
    }

    .hero-grid {
      position: relative;
      z-index: 1;
      display: grid;
      grid-template-columns: minmax(0, 740px);
      gap: 34px;
      align-items: end;
    }

    .hero-copy {
      animation: heroIn 900ms var(--ease) both;
    }

    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      color: rgba(255, 255, 255, 0.82);
      font-size: 12px;
      font-weight: 800;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      margin-bottom: 22px;
    }

    .eyebrow::before {
      width: 34px;
      height: 1px;
      background: currentColor;
      content: "";
    }

    h1, h2, h3, p {
      margin-top: 0;
    }

    h1 {
      max-width: 900px;
      margin-bottom: 30px;
      font-family: Georgia, serif;
      font-size: clamp(54px, 7.6vw, 104px);
      line-height: 0.92;
      letter-spacing: -0.055em;
    }

    h1 span {
      display: inline-block;
      color: transparent;
      background: linear-gradient(115deg, #ffffff, #e8d6a3 48%, #98d4dc);
      -webkit-background-clip: text;
      background-clip: text;
    }

    .hero-text {
      max-width: 630px;
      margin-bottom: 34px;
      color: rgba(255, 255, 255, 0.78);
      font-size: clamp(19px, 2vw, 23px);
    }

    .hero-actions {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 16px;
    }

    .hero-note {
      max-width: 250px;
      color: rgba(255, 255, 255, 0.7);
      font-size: 14px;
    }

    .not-found {
      min-height: calc(100vh - 76px);
      display: flex;
      align-items: center;
      border-top: 0;
      background:
        linear-gradient(90deg, rgba(10, 11, 11, 0.74), rgba(10, 11, 11, 0.36)),
        url('handled-support-atmosphere.webp') center/cover;
      color: var(--white);
    }

    .not-found-inner {
      max-width: 760px;
      padding: 96px 0;
    }

    .not-found .hero-text {
      max-width: 620px;
    }

    .policy-hero {
      padding: 108px 0 72px;
      border-top: 0;
      background:
        linear-gradient(90deg, rgba(23, 23, 23, 0.66), rgba(23, 23, 23, 0.28)),
        url('handled-support-atmosphere.webp') center/cover;
      color: var(--white);
    }

    .policy-hero .eyebrow,
    .policy-hero .section-intro {
      color: rgba(255, 255, 255, 0.78);
    }

    .policy-section {
      background: var(--bg);
    }

    .policy-content {
      max-width: 780px;
    }

    .policy-content p,
    .policy-content li {
      color: var(--muted);
      font-size: 18px;
      line-height: 1.7;
    }

    .policy-content h2 {
      margin: 44px 0 16px;
      font-size: clamp(30px, 4vw, 42px);
      line-height: 1.05;
    }

    .policy-content ul {
      margin: 12px 0 26px;
      padding-left: 22px;
    }

    .policy-content a:not(.button) {
      color: var(--ink);
      font-weight: 800;
      text-decoration: underline;
      text-decoration-thickness: 1px;
      text-underline-offset: 4px;
    }

    .policy-back {
      margin-top: 42px;
    }

    .contact-hero {
      min-height: calc(100vh - 76px);
      display: flex;
      align-items: flex-end;
      border-top: 0;
      padding: 104px 0 68px;
      background:
        linear-gradient(90deg, rgba(10, 11, 11, 0.72) 0%, rgba(10, 11, 11, 0.38) 54%, rgba(10, 11, 11, 0.1) 100%),
        linear-gradient(180deg, rgba(10, 11, 11, 0.08), rgba(10, 11, 11, 0.64)),
        url('handled-contact-atmosphere.webp') center/cover;
      color: var(--white);
    }

    .contact-hero-inner {
      max-width: 760px;
    }

    .contact-hero .eyebrow,
    .contact-hero .hero-text {
      color: rgba(255, 255, 255, 0.78);
    }

    .contact-reassurance,
    .next-steps-section {
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.48), transparent);
    }

    .contact-form-section {
      background:
        linear-gradient(90deg, rgba(73, 107, 115, 0.1), transparent 52%),
        var(--bg);
    }

    .contact-method-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 18px;
    }

    .contact-method-card {
      padding: 34px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: var(--card);
      backdrop-filter: blur(18px);
    }

    .contact-method-card p {
      margin-bottom: 0;
      color: var(--muted);
      font-size: 20px;
    }

    .contact-method-card a {
      color: var(--ink);
      font-weight: 800;
      text-decoration: underline;
      text-decoration-thickness: 1px;
      text-underline-offset: 5px;
    }

    .about-hero {
      min-height: calc(100vh - 76px);
      display: flex;
      align-items: flex-end;
      padding: 118px 0 82px;
      background:
        linear-gradient(90deg, rgba(24, 28, 27, 0.8), rgba(24, 28, 27, 0.34) 52%, rgba(24, 28, 27, 0.22)),
        linear-gradient(180deg, rgba(24, 28, 27, 0.08), rgba(24, 28, 27, 0.48)),
        url('handled-about-atmosphere.webp') center/cover;
      color: var(--white);
    }

    .about-hero-inner {
      max-width: 820px;
    }

    .about-hero .eyebrow,
    .about-hero .hero-text,
    .about-hero-note {
      color: rgba(255, 255, 255, 0.78);
    }

    .about-hero-note {
      max-width: 680px;
      margin: 0 0 28px;
      font-size: clamp(18px, 2vw, 22px);
      line-height: 1.55;
    }

    .about-intro-section,
    .about-reason-section,
    .about-responsible-section,
    .about-philosophy-section {
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.48), transparent);
    }

    .about-context-section {
      background:
        linear-gradient(90deg, rgba(73, 107, 115, 0.09), transparent 58%),
        var(--stone);
    }

    .about-panel h2 {
      margin-bottom: 16px;
    }

    .about-panel p,
    .about-list li,
    .about-philosophy-copy p {
      color: var(--muted);
    }

    .about-list {
      display: grid;
      gap: 10px;
      margin: 18px 0 26px;
      padding-left: 20px;
      color: var(--muted);
    }

    .about-list li::marker {
      color: var(--gold);
    }

    .about-split-section {
      background: var(--bg);
    }

    .about-split-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 22px;
      align-items: start;
    }

    .about-panel {
      padding: 42px;
    }

    .about-statement {
      max-width: 980px;
      margin-top: 24px;
      font-family: "Cormorant Garamond", Georgia, serif;
      font-size: clamp(38px, 6vw, 76px);
      line-height: 0.98;
      letter-spacing: 0;
      color: var(--ink);
    }

    .about-statement p {
      margin: 0 0 18px;
    }

    .about-philosophy-copy {
      max-width: 720px;
      margin-top: 34px;
      font-size: 19px;
      line-height: 1.72;
    }

    .journeys-hero {
      min-height: calc(100vh - 76px);
      display: flex;
      align-items: flex-end;
      padding: 118px 0 82px;
      background:
        linear-gradient(90deg, rgba(18, 21, 20, 0.76), rgba(18, 21, 20, 0.34) 54%, rgba(18, 21, 20, 0.16)),
        linear-gradient(180deg, rgba(18, 21, 20, 0.08), rgba(18, 21, 20, 0.56)),
        url('handled-journeys-atmosphere.webp') center/cover;
      color: var(--white);
    }

    .journeys-hero-inner {
      max-width: 820px;
    }

    .journeys-hero .eyebrow,
    .journeys-hero .hero-text {
      color: rgba(255, 255, 255, 0.78);
    }

    .journey-experience-section,
    .journey-portugal-section {
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.5), transparent);
    }

    .journey-feature-grid {
      display: grid;
      grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.8fr);
      gap: 54px;
      align-items: center;
    }

    .journey-image-card {
      position: relative;
      overflow: hidden;
      min-height: 440px;
      margin: 0;
      border-radius: 8px;
      box-shadow: var(--shadow);
      background: var(--stone);
    }

    .journey-image-card img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

    .journey-card-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 18px;
    }

    .journey-benefit-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 18px;
    }

    .journey-card,
    .journey-benefit,
    .journey-support-panel {
      position: relative;
      overflow: hidden;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: var(--card);
      backdrop-filter: blur(18px);
      box-shadow: var(--shadow-soft);
      transition: transform 0.35s var(--ease), box-shadow 0.35s var(--ease), border-color 0.35s var(--ease), background 0.35s var(--ease);
    }

    .journey-card,
    .journey-benefit {
      min-height: 250px;
      padding: 30px;
    }

    .journey-card::before,
    .journey-benefit::before,
    .journey-support-panel::before {
      position: absolute;
      left: 0;
      right: 0;
      top: 0;
      height: 3px;
      background: linear-gradient(90deg, var(--olive), var(--gold), var(--sea));
      content: "";
      transform: scaleX(0);
      transform-origin: left;
      transition: transform 0.35s var(--ease);
    }

    .journey-card:hover,
    .journey-benefit:hover,
    .journey-support-panel:hover {
      border-color: rgba(23, 23, 23, 0.22);
      background: rgba(255, 255, 255, 0.82);
      box-shadow: 0 24px 58px rgba(23, 23, 23, 0.12);
      transform: translateY(-6px);
    }

    .journey-card:hover::before,
    .journey-benefit:hover::before,
    .journey-support-panel:hover::before {
      transform: scaleX(1);
    }

    .journey-card p,
    .journey-benefit p,
    .journey-support-panel p {
      color: var(--muted);
    }

    .journey-choice-section {
      background:
        linear-gradient(90deg, rgba(73, 107, 115, 0.09), transparent 58%),
        var(--stone);
    }

    .journey-support-panel {
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      gap: 34px;
      align-items: center;
      padding: 42px;
    }

    .support-landing-hero {
      min-height: calc(100vh - 76px);
      display: flex;
      align-items: flex-end;
      padding: 118px 0 82px;
      background:
        linear-gradient(90deg, rgba(18, 21, 20, 0.78), rgba(18, 21, 20, 0.38) 54%, rgba(18, 21, 20, 0.18)),
        linear-gradient(180deg, rgba(18, 21, 20, 0.1), rgba(18, 21, 20, 0.6)),
        url('handled-support-presence.webp') center/cover;
      color: var(--white);
    }

    .support-hero-inner {
      max-width: 820px;
    }

    .support-landing-hero .eyebrow,
    .support-landing-hero .hero-text {
      color: rgba(255, 255, 255, 0.78);
    }

    .faq-hero {
      min-height: calc(100vh - 76px);
      display: flex;
      align-items: flex-end;
      padding: 118px 0 82px;
      background:
        linear-gradient(90deg, rgba(18, 21, 20, 0.78), rgba(18, 21, 20, 0.36) 54%, rgba(18, 21, 20, 0.12)),
        linear-gradient(180deg, rgba(18, 21, 20, 0.08), rgba(18, 21, 20, 0.58)),
        url('handled-faq-guidance.webp') center/cover;
      color: var(--white);
    }

    .faq-hero-inner {
      max-width: 840px;
    }

    .faq-hero .eyebrow,
    .faq-hero .hero-text {
      color: rgba(255, 255, 255, 0.78);
    }

    .faq-section {
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.52), transparent);
    }

    .faq-layout {
      display: grid;
      grid-template-columns: minmax(220px, 0.36fr) minmax(0, 1fr);
      gap: 54px;
      align-items: start;
      padding: 54px 0;
      border-top: 1px solid var(--line);
    }

    .faq-layout:first-child {
      border-top: 0;
      padding-top: 0;
    }

    .faq-layout h2 {
      position: sticky;
      top: 108px;
      max-width: 360px;
      font-size: clamp(34px, 4vw, 52px);
      line-height: 1.02;
      overflow-wrap: anywhere;
    }

    .faq-list {
      display: grid;
      gap: 14px;
    }

    .faq-item {
      border: 1px solid var(--line);
      border-radius: 8px;
      background: var(--card);
      box-shadow: 0 18px 44px rgba(23, 23, 23, 0.07);
      backdrop-filter: blur(18px);
      transition: border-color 0.25s var(--ease), box-shadow 0.25s var(--ease), background 0.25s var(--ease);
    }

    .faq-item[open] {
      border-color: rgba(23, 23, 23, 0.22);
      background: rgba(255, 255, 255, 0.82);
      box-shadow: 0 24px 58px rgba(23, 23, 23, 0.1);
    }

    .faq-item summary {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
      min-height: 78px;
      padding: 22px 26px;
      cursor: pointer;
      color: var(--ink);
      font-size: 19px;
      font-weight: 800;
      list-style: none;
    }

    .faq-item summary::-webkit-details-marker {
      display: none;
    }

    .faq-item summary::after {
      flex: 0 0 auto;
      width: 28px;
      height: 28px;
      border: 1px solid var(--line);
      border-radius: 50%;
      color: var(--gold);
      content: "+";
      display: inline-flex;
      align-items: center;
      justify-content: center;
      font-family: Inter, sans-serif;
      font-size: 18px;
      font-weight: 800;
      transition: transform 0.25s var(--ease), background 0.25s var(--ease), color 0.25s var(--ease);
    }

    .faq-item[open] summary::after {
      background: var(--ink);
      color: var(--white);
      content: "–";
      transform: rotate(180deg);
    }

    .faq-answer {
      max-width: 760px;
      padding: 0 26px 26px;
      color: var(--muted);
      font-size: 18px;
      line-height: 1.68;
    }

    .faq-answer p {
      margin-bottom: 16px;
    }

    .faq-answer p:last-child {
      margin-bottom: 0;
    }

    .support-distance-section,
    .support-fragmentation-section {
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.5), transparent);
    }

    .support-difference-section {
      background:
        linear-gradient(90deg, rgba(73, 107, 115, 0.09), transparent 58%),
        var(--stone);
    }

    .support-card-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 18px;
    }

    .support-card {
      position: relative;
      overflow: hidden;
      min-height: 250px;
      padding: 30px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: var(--card);
      backdrop-filter: blur(18px);
      box-shadow: var(--shadow-soft);
      transition: transform 0.35s var(--ease), box-shadow 0.35s var(--ease), border-color 0.35s var(--ease), background 0.35s var(--ease);
    }

    .support-card::before {
      position: absolute;
      left: 0;
      right: 0;
      top: 0;
      height: 3px;
      background: linear-gradient(90deg, var(--olive), var(--gold), var(--sea));
      content: "";
      transform: scaleX(0);
      transform-origin: left;
      transition: transform 0.35s var(--ease);
    }

    .support-card:hover {
      border-color: rgba(23, 23, 23, 0.22);
      background: rgba(255, 255, 255, 0.82);
      box-shadow: 0 24px 58px rgba(23, 23, 23, 0.12);
      transform: translateY(-6px);
    }

    .support-card:hover::before {
      transform: scaleX(1);
    }

    .support-card p {
      color: var(--muted);
    }

    .page-hero {
      padding: 108px 0 82px;
      background:
        linear-gradient(90deg, rgba(23, 23, 23, 0.66), rgba(23, 23, 23, 0.28)),
        url('handled-hero-coast.webp') center/cover;
      color: var(--white);
      border-top: 0;
    }

    .page-hero.support-hero {
      background:
        linear-gradient(90deg, rgba(23, 23, 23, 0.68), rgba(23, 23, 23, 0.34)),
        url('handled-support-atmosphere.webp') center/cover;
    }

    .page-hero .eyebrow,
    .page-hero .section-intro {
      color: rgba(255, 255, 255, 0.78);
    }

    .page-hero h1 {
      max-width: 920px;
    }

    .page-body {
      background: var(--bg);
    }

    .lead-grid {
      display: grid;
      grid-template-columns: 0.9fr 1.1fr;
      gap: 44px;
      align-items: start;
    }

    .lead-copy {
      color: var(--muted);
      font-size: 20px;
      max-width: 760px;
    }

    .text-list {
      list-style: none;
      padding: 0;
      margin: 26px 0 0;
    }

    .text-list li {
      padding: 13px 0;
      border-bottom: 1px solid var(--line);
      color: var(--muted);
    }

    section {
      position: relative;
      padding: 96px 0;
      border-top: 1px solid var(--line);
    }

    .section-head {
      display: grid;
      grid-template-columns: 0.9fr 1.1fr;
      gap: 60px;
      align-items: end;
      margin-bottom: 52px;
    }

    h2 {
      margin-bottom: 0;
      font-family: Georgia, serif;
      font-size: clamp(40px, 5vw, 72px);
      line-height: 0.98;
      letter-spacing: -0.05em;
    }

    .section-intro {
      max-width: 620px;
      margin-bottom: 0;
      color: var(--muted);
      font-size: clamp(18px, 2vw, 21px);
    }

    .cards-4,
    .process-grid,
    .moments-grid,
    .mode-grid,
    .trust-grid {
      display: grid;
      gap: 18px;
    }

    .cards-4 {
      grid-template-columns: repeat(4, 1fr);
    }

    .process-grid,
    .moments-grid {
      grid-template-columns: repeat(3, 1fr);
    }

    .mode-grid,
    .trust-grid {
      grid-template-columns: repeat(2, 1fr);
    }

    .card,
    .process-card,
    .moment-card,
    .mode-card,
    .about-panel,
    .form-wrap,
    .next-box {
      position: relative;
      overflow: hidden;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: var(--card);
      backdrop-filter: blur(18px);
      transition: transform 0.35s var(--ease), box-shadow 0.35s var(--ease), border-color 0.35s var(--ease), background 0.35s var(--ease);
    }

    .card::before,
    .process-card::before,
    .moment-card::before,
    .mode-card::before,
    .about-panel::before {
      position: absolute;
      left: 0;
      right: 0;
      top: 0;
      height: 3px;
      background: linear-gradient(90deg, var(--olive), var(--gold), var(--wine));
      content: "";
      transform: scaleX(0);
      transform-origin: left;
      transition: transform 0.35s var(--ease);
    }

    .card:hover,
    .process-card:hover,
    .moment-card:hover,
    .mode-card:hover,
    .about-panel:hover {
      border-color: rgba(23, 23, 23, 0.22);
      background: rgba(255, 255, 255, 0.82);
      box-shadow: 0 24px 58px rgba(23, 23, 23, 0.12);
      transform: translateY(-6px);
    }

    .card:hover::before,
    .process-card:hover::before,
    .moment-card:hover::before,
    .mode-card:hover::before,
    .about-panel:hover::before {
      transform: scaleX(1);
    }

    .card {
      min-height: 292px;
      padding: 30px;
    }

    .process-card,
    .moment-card {
      min-height: 250px;
      padding: 30px;
    }

    .number {
      margin-bottom: 34px;
      color: var(--gold);
      font-size: 12px;
      font-weight: 900;
      letter-spacing: 0.12em;
    }

    h3 {
      margin-bottom: 18px;
      font-size: 24px;
      line-height: 1.1;
      letter-spacing: -0.025em;
    }

    .card p,
    .trust-item p,
    .process-card p,
    .moment-card p,
    .mode-card p {
      color: var(--muted);
      margin-bottom: 0;
    }

    .trust-item {
      position: relative;
      padding: 28px 0 18px 34px;
      border-top: 1px solid var(--line);
    }

    .trust-item::before {
      position: absolute;
      left: 0;
      top: 34px;
      width: 13px;
      height: 13px;
      border: 1px solid var(--gold);
      background: rgba(181, 150, 91, 0.12);
      content: "";
      transform: rotate(45deg);
    }

    .quote {
      position: relative;
      margin-top: 52px;
      padding: clamp(34px, 5vw, 58px);
      overflow: hidden;
      border-radius: 8px;
      background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.06), transparent 35%),
        linear-gradient(135deg, var(--ink), #263f43 58%, #512731);
      box-shadow: var(--shadow);
      color: var(--white);
      font-family: Georgia, serif;
      font-size: clamp(30px, 4vw, 52px);
      line-height: 1.08;
      letter-spacing: -0.04em;
    }

    .quote::after {
      position: absolute;
      right: 26px;
      bottom: 18px;
      color: rgba(255, 255, 255, 0.14);
      content: "Handled";
      font-family: Georgia, serif;
      font-size: clamp(70px, 12vw, 170px);
      letter-spacing: -0.08em;
      line-height: 0.8;
    }

    .moment-card h3 {
      margin-bottom: 12px;
      font-size: 21px;
      letter-spacing: -0.025em;
    }

    .modes {
      background:
        linear-gradient(rgba(23, 23, 23, 0.48), rgba(23, 23, 23, 0.58)),
        url('handled-support-atmosphere.webp') center/cover fixed;
      color: var(--white);
    }

    .modes .section-intro,
    .modes .mode-card p,
    .modes .mode-list {
      color: rgba(255, 255, 255, 0.72);
    }

    .modes .eyebrow,
    .modes .number {
      color: #e0c98f;
    }

    .mode-card {
      min-height: 420px;
      padding: 40px;
      background: rgba(18, 18, 18, 0.48);
      border-color: rgba(255, 255, 255, 0.2);
    }

    .mode-card:hover {
      background: rgba(18, 18, 18, 0.62);
      border-color: rgba(255, 255, 255, 0.36);
      box-shadow: 0 34px 70px rgba(0, 0, 0, 0.28);
    }

    .mode-card h3 {
      max-width: 460px;
      font-size: clamp(30px, 3vw, 40px);
    }

    .mode-list {
      list-style: none;
      padding: 0;
      margin: 34px 0;
    }

    .mode-list li {
      position: relative;
      padding: 11px 0 11px 28px;
      border-bottom: 1px solid rgba(255, 255, 255, 0.16);
    }

    .mode-list li::before {
      position: absolute;
      left: 0;
      top: 17px;
      width: 8px;
      height: 8px;
      border-radius: 50%;
      background: var(--gold);
      content: "";
    }

    .center-statement {
      max-width: 920px;
      margin: 62px auto 0;
      color: rgba(255, 255, 255, 0.92);
      text-align: center;
      font-family: Georgia, serif;
      font-size: clamp(31px, 4vw, 54px);
      line-height: 1.04;
      letter-spacing: -0.045em;
    }

    .proof {
      text-align: center;
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.44), transparent);
    }

    .proof p {
      max-width: 760px;
      margin: 18px auto 0;
      color: var(--muted);
      font-size: 20px;
    }

    .cta-band {
      overflow: hidden;
      background:
        radial-gradient(circle at 80% 30%, rgba(181, 150, 91, 0.22), transparent 26rem),
        linear-gradient(135deg, #151515, #23393c 58%, #522936);
      color: var(--white);
      padding: 86px 0;
    }

    .cta-inner {
      display: grid;
      grid-template-columns: 1fr auto;
      align-items: center;
      gap: 40px;
    }

    .cta-inner h2 {
      max-width: 740px;
    }

    .cta-inner p {
      margin: 20px 0 0;
      color: rgba(255, 255, 255, 0.72);
      font-size: 20px;
    }

    .cta-band .button {
      background: var(--white);
      color: var(--ink);
      border-color: var(--white);
    }

    .form-section {
      background:
        linear-gradient(90deg, rgba(73, 107, 115, 0.08), transparent 44%),
        var(--bg);
    }

    .form-section .eyebrow {
      color: var(--wine);
    }

    .form-grid {
      display: grid;
      grid-template-columns: 0.85fr 1.15fr;
      gap: 70px;
      align-items: start;
    }

    .form-wrap {
      padding: 38px;
      box-shadow: 0 22px 60px rgba(23, 23, 23, 0.08);
    }

    label {
      display: block;
      margin-bottom: 9px;
      font-size: 14px;
      font-weight: 800;
    }

    input,
    textarea {
      width: 100%;
      margin-bottom: 20px;
      padding: 16px 18px;
      border: 1px solid rgba(23, 23, 23, 0.13);
      border-radius: 8px;
      outline: none;
      background: rgba(255, 255, 255, 0.76);
      color: var(--ink);
      font: inherit;
      transition: border-color 0.25s var(--ease), box-shadow 0.25s var(--ease), background 0.25s var(--ease);
    }

    textarea {
      min-height: 130px;
      resize: vertical;
    }

    input:focus,
    textarea:focus {
      border-color: var(--sea);
      background: var(--white);
      box-shadow: 0 0 0 4px rgba(73, 107, 115, 0.12);
    }

    .small-note {
      margin: 14px 0 0;
      color: var(--muted);
      font-size: 14px;
    }

    .form-honeypot {
      position: absolute;
      left: -9999px;
      width: 1px;
      height: 1px;
      opacity: 0;
      pointer-events: none;
    }

    .form-status {
      min-height: 0;
      margin-top: 18px;
      padding: 14px 16px;
      border-radius: 8px;
      color: var(--muted);
      font-weight: 700;
      white-space: pre-line;
      opacity: 1;
      transform: translateY(0);
      transition: opacity 0.28s var(--ease), transform 0.28s var(--ease);
    }

    .form-status:empty {
      display: none;
    }

    .form-status.is-success {
      border: 1px solid rgba(103, 122, 88, 0.3);
      background: rgba(103, 122, 88, 0.12);
      color: #3f5135;
    }

    .form-status.is-error {
      border: 1px solid rgba(111, 47, 63, 0.32);
      background: rgba(111, 47, 63, 0.1);
      color: #6f2f3f;
    }

    .form-wrap.is-loading .button {
      cursor: wait;
      opacity: 0.78;
    }

    .form-wrap.is-submitted input,
    .form-wrap.is-submitted textarea {
      background: rgba(255, 255, 255, 0.52);
    }

    .next-box {
      margin-top: 32px;
      padding: 30px;
      background:
        linear-gradient(135deg, rgba(103, 122, 88, 0.12), transparent),
        rgba(255, 253, 248, 0.68);
    }

    .next-box h3 {
      margin-bottom: 14px;
    }

    footer {
      background: #151515;
      color: var(--white);
      padding: 54px 0;
    }

    .footer-grid {
      display: grid;
      grid-template-columns: 1fr auto;
      gap: 40px;
      align-items: end;
    }

    .footer-brand {
      margin-bottom: 12px;
      font-family: Georgia, serif;
      font-size: 34px;
      letter-spacing: -0.04em;
    }

    .footer-muted {
      color: rgba(255, 255, 255, 0.65);
      margin: 0;
    }

    .footer-links {
      display: flex;
      flex-wrap: wrap;
      gap: 9px;
      margin: 14px 0 0;
      color: rgba(255, 255, 255, 0.62);
      font-size: 14px;
    }

    .footer-links a {
      transition: color 0.2s var(--ease);
    }

    .footer-links a:hover {
      color: var(--white);
    }

    .footer-contacts {
      text-align: right;
      color: rgba(255, 255, 255, 0.8);
    }

    [data-reveal] {
      opacity: 0;
      transform: translateY(26px);
      transition: opacity 0.75s var(--ease), transform 0.75s var(--ease);
      transition-delay: var(--delay, 0ms);
    }

    [data-reveal].is-visible {
      opacity: 1;
      transform: translateY(0);
    }

    @keyframes heroIn {
      from {
        opacity: 0;
        transform: translateY(28px);
      }
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }

    @keyframes imageIn {
      from {
        opacity: 0;
        transform: translateY(30px) scale(0.985);
      }
      to {
        opacity: 1;
        transform: translateY(0) scale(1);
      }
    }

    @keyframes floatImage {
      0%, 100% {
        transform: translateY(0);
      }
      50% {
        transform: translateY(-10px);
      }
    }

    @keyframes sheen {
      0%, 48% {
        transform: translateX(-120%);
      }
      66%, 100% {
        transform: translateX(120%);
      }
    }

    @media (prefers-reduced-motion: reduce) {
      *,
      *::before,
      *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        scroll-behavior: auto !important;
        transition-duration: 0.01ms !important;
      }
    }

    @media (min-width: 1200px) {
      .container {
        width: min(1180px, calc(100% - 48px));
      }

      .hero {
        min-height: calc(100vh - 76px);
        padding: 104px 0 68px;
        background-position: center;
      }

      section {
        padding: 96px 0;
      }
    }

    @media (min-width: 1024px) and (max-width: 1199px) {
      .container {
        width: min(1060px, calc(100% - 44px));
      }

      .nav-links {
        gap: 22px;
      }

      .hero {
        min-height: 760px;
        padding: 92px 0 62px;
        background-position: 48% center;
      }

      .contact-hero {
        min-height: 700px;
        padding: 92px 0 62px;
        background-position: center;
      }

      .about-hero {
        min-height: 700px;
        padding: 92px 0 62px;
      }

      .journeys-hero {
        min-height: 700px;
        padding: 92px 0 62px;
      }

      .support-landing-hero {
        min-height: 700px;
        padding: 92px 0 62px;
      }

      .faq-hero {
        min-height: 700px;
        padding: 92px 0 62px;
      }

      h1 {
        font-size: clamp(64px, 8vw, 88px);
        max-width: 780px;
      }

      h2 {
        font-size: clamp(42px, 5vw, 62px);
      }

      section {
        padding: 84px 0;
      }

      .section-head {
        gap: 44px;
      }

      .cards-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr));
      }

      .card,
      .process-card,
      .moment-card {
        padding: 26px;
      }

      .form-grid {
        gap: 48px;
      }

      .journey-card-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
      }

      .support-card-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
      }

      .journey-benefit-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }

    @media (min-width: 768px) and (max-width: 1023px) {
      .container {
        width: min(100% - 40px, 900px);
      }

      .nav-inner {
        min-height: 72px;
      }

      .nav-links {
        display: none;
      }

      .nav .button {
        min-height: 46px;
        padding: 0 20px;
      }

      .language-switcher {
        margin-left: auto;
      }

      .hero {
        min-height: 720px;
        padding: 86px 0 58px;
        background-position: 42% center;
      }

      .contact-hero {
        min-height: 640px;
        padding: 82px 0 56px;
        background-position: center;
      }

      .about-hero {
        min-height: 640px;
        padding: 82px 0 56px;
      }

      .journeys-hero {
        min-height: 640px;
        padding: 82px 0 56px;
      }

      .support-landing-hero {
        min-height: 640px;
        padding: 82px 0 56px;
      }

      .faq-hero {
        min-height: 640px;
        padding: 82px 0 56px;
      }

      .hero-grid {
        grid-template-columns: minmax(0, 680px);
      }

      h1 {
        font-size: clamp(58px, 8.5vw, 76px);
        max-width: 720px;
      }

      .hero-text {
        max-width: 600px;
        font-size: 20px;
      }

      .hero-note {
        max-width: 330px;
      }

      section {
        padding: 72px 0;
      }

      .section-head,
      .lead-grid,
      .journey-feature-grid,
      .faq-layout,
      .form-grid,
      .cta-inner,
      .footer-grid {
        grid-template-columns: 1fr;
        gap: 32px;
      }

      .faq-layout {
        padding: 42px 0;
      }

      .faq-layout h2 {
        position: static;
      }

      h2 {
        font-size: clamp(38px, 6vw, 52px);
        max-width: 760px;
      }

      .section-intro {
        max-width: 720px;
        font-size: 19px;
      }

      .cards-4,
      .moments-grid,
      .mode-grid,
      .trust-grid,
      .contact-method-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .journey-card-grid,
      .support-card-grid,
      .journey-benefit-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .about-split-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .process-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .card,
      .process-card,
      .moment-card,
      .mode-card {
        min-height: auto;
        padding: 28px;
      }

      .about-panel {
        min-height: auto;
        padding: 30px;
      }

      .process-card {
        padding: 24px;
      }

      .mode-card {
        min-height: 360px;
      }

      .journey-image-card {
        min-height: 360px;
      }

      .journey-support-panel {
        grid-template-columns: 1fr;
        padding: 30px;
      }

      .number {
        margin-bottom: 24px;
      }

      .quote,
      .center-statement {
        font-size: clamp(32px, 5vw, 44px);
      }

      .modes {
        background-attachment: scroll;
        background-position: center;
      }

      .form-wrap {
        max-width: 760px;
        padding: 34px;
      }

      input,
      textarea {
        min-height: 54px;
      }

      .footer-contacts {
        text-align: left;
      }
    }

    @media (min-width: 320px) and (max-width: 767px) {
      html,
      body {
        max-width: 100%;
        overflow-x: hidden;
      }

      .container {
        width: min(100% - 28px, 680px);
      }

      .nav {
        background: rgba(248, 246, 241, 0.92);
      }

      .nav-inner {
        min-height: 68px;
        gap: 12px;
      }

      .logo {
        gap: 8px;
      }

      .logo-mark {
        width: 48px;
        height: 48px;
      }

      .logo-name {
        font-size: 27px;
      }

      .nav-links {
        display: none;
      }

      .nav .button {
        min-height: 42px;
        max-width: 168px;
        padding: 0 14px;
        font-size: 10px;
        letter-spacing: 0.055em;
        text-align: center;
        white-space: normal;
      }

      .language-switcher {
        display: none;
      }

      .hero {
        min-height: min(760px, calc(100svh - 68px));
        padding: 74px 0 46px;
        align-items: flex-end;
        background:
          linear-gradient(90deg, rgba(10, 11, 11, 0.74) 0%, rgba(10, 11, 11, 0.42) 62%, rgba(10, 11, 11, 0.18) 100%),
          linear-gradient(180deg, rgba(10, 11, 11, 0.16) 0%, rgba(10, 11, 11, 0.28) 52%, rgba(10, 11, 11, 0.72) 100%),
          url('handled-hero-coast.webp') 33% center/cover;
      }

      .contact-hero {
        min-height: min(680px, calc(100svh - 68px));
        padding: 74px 0 46px;
        background:
          linear-gradient(90deg, rgba(10, 11, 11, 0.74), rgba(10, 11, 11, 0.36)),
          linear-gradient(180deg, rgba(10, 11, 11, 0.12), rgba(10, 11, 11, 0.68)),
          url('handled-contact-atmosphere.webp') 46% center/cover;
      }

      .about-hero {
        min-height: min(680px, calc(100svh - 68px));
        padding: 74px 0 46px;
        background:
          linear-gradient(90deg, rgba(10, 11, 11, 0.72), rgba(10, 11, 11, 0.34)),
          linear-gradient(180deg, rgba(10, 11, 11, 0.12), rgba(10, 11, 11, 0.7)),
          url('handled-about-atmosphere.webp') 52% center/cover;
      }

      .journeys-hero {
        min-height: min(680px, calc(100svh - 68px));
        padding: 74px 0 46px;
        background:
          linear-gradient(90deg, rgba(10, 11, 11, 0.72), rgba(10, 11, 11, 0.34)),
          linear-gradient(180deg, rgba(10, 11, 11, 0.12), rgba(10, 11, 11, 0.7)),
          url('handled-journeys-atmosphere.webp') 48% center/cover;
      }

      .support-landing-hero {
        min-height: min(680px, calc(100svh - 68px));
        padding: 74px 0 46px;
        background:
          linear-gradient(90deg, rgba(10, 11, 11, 0.72), rgba(10, 11, 11, 0.34)),
          linear-gradient(180deg, rgba(10, 11, 11, 0.12), rgba(10, 11, 11, 0.7)),
          url('handled-support-presence.webp') 54% center/cover;
      }

      .faq-hero {
        min-height: min(680px, calc(100svh - 68px));
        padding: 74px 0 46px;
        background:
          linear-gradient(90deg, rgba(10, 11, 11, 0.72), rgba(10, 11, 11, 0.34)),
          linear-gradient(180deg, rgba(10, 11, 11, 0.12), rgba(10, 11, 11, 0.7)),
          url('handled-faq-guidance.webp') 42% center/cover;
      }

      .hero-grid {
        grid-template-columns: 1fr;
      }

      .eyebrow {
        margin-bottom: 18px;
        font-size: 11px;
        line-height: 1.35;
        letter-spacing: 0.1em;
      }

      .eyebrow::before {
        width: 24px;
      }

      h1 {
        max-width: 520px;
        margin-bottom: 24px;
        font-size: clamp(42px, 12.8vw, 52px);
        line-height: 0.98;
        letter-spacing: -0.045em;
      }

      .hero-text {
        max-width: 560px;
        margin-bottom: 26px;
        font-size: 17px;
        line-height: 1.55;
      }

      .hero-actions {
        align-items: stretch;
        gap: 14px;
      }

      .hero-actions .button {
        width: 100%;
      }

      .hero-note {
        max-width: none;
        font-size: 13px;
      }

      section {
        padding: 56px 0;
      }

      .section-head,
      .lead-grid,
      .journey-feature-grid,
      .faq-layout,
      .form-grid,
      .cta-inner,
      .footer-grid {
        grid-template-columns: 1fr;
        gap: 24px;
        margin-bottom: 34px;
      }

      h2 {
        font-size: clamp(34px, 10vw, 42px);
        line-height: 1.02;
        letter-spacing: -0.04em;
      }

      h3 {
        font-size: 22px;
      }

      .section-intro,
      .lead-copy,
      .proof p,
      .cta-inner p {
        max-width: none;
        font-size: 17px;
        line-height: 1.58;
      }

      .cards-4,
      .process-grid,
      .moments-grid,
      .mode-grid,
      .trust-grid,
      .contact-method-grid {
        grid-template-columns: 1fr;
        gap: 14px;
      }

      .journey-card-grid,
      .support-card-grid,
      .journey-benefit-grid {
        grid-template-columns: 1fr;
        gap: 14px;
      }

      .about-split-grid {
        grid-template-columns: 1fr;
        gap: 14px;
      }

      .card,
      .process-card,
      .moment-card,
      .mode-card,
      .contact-method-card,
      .journey-card,
      .support-card,
      .journey-benefit,
      .about-panel,
      .journey-support-panel,
      .form-wrap,
      .next-box,
      .quote {
        min-height: auto;
        padding: 24px;
      }

      .journey-image-card {
        min-height: 260px;
      }

      .faq-layout {
        padding: 36px 0;
      }

      .faq-layout h2 {
        position: static;
      }

      .faq-item summary {
        min-height: 68px;
        padding: 18px 20px;
        gap: 18px;
        font-size: 17px;
      }

      .faq-answer {
        padding: 0 20px 22px;
        font-size: 16px;
        line-height: 1.62;
      }

      .journey-support-panel {
        grid-template-columns: 1fr;
      }

      .about-statement {
        font-size: clamp(32px, 10vw, 46px);
      }

      .number {
        margin-bottom: 22px;
      }

      .trust-item {
        padding: 24px 0 14px 30px;
      }

      .trust-item::before {
        top: 31px;
      }

      .quote {
        margin-top: 34px;
        font-size: clamp(28px, 8vw, 36px);
        line-height: 1.12;
      }

      .quote::after {
        right: 18px;
        bottom: 12px;
        font-size: 72px;
      }

      .modes {
        background-attachment: scroll;
        background-position: 52% center;
      }

      .mode-card h3 {
        font-size: 29px;
      }

      .mode-list {
        margin: 26px 0;
      }

      .center-statement {
        margin-top: 42px;
        font-size: clamp(30px, 8.5vw, 38px);
        line-height: 1.08;
      }

      .cta-band {
        padding: 58px 0;
      }

      .cta-inner .button,
      .form-wrap .button {
        width: 100%;
      }

      label {
        margin-bottom: 8px;
        font-size: 14px;
      }

      input,
      textarea {
        min-height: 54px;
        margin-bottom: 18px;
        padding: 15px 16px;
        font-size: 16px;
      }

      textarea {
        min-height: 126px;
      }

      footer {
        padding: 42px 0;
      }

      .footer-grid {
        align-items: start;
        margin-bottom: 0;
      }

      .footer-contacts {
        text-align: left;
      }
    }
