/* ============================================================
   marketingRAUM — home.css
   Page-level styles for index.html
   ============================================================ */

    /* =====================================================
       PAGE-LEVEL STYLES — alles was diese Seite braucht
       ===================================================== */

    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

    :root {
      --forest:       #33443D;
      --forest-deep:  #1E2B26;
      --forest-light: #4A5E56;
      --sage:         #53685F;
      --mist:         #B9C7C1;
      --cream:        #F8F6F3;
      --sand:         #BAAE93;
      --sand-light:   #D4CBB5;
      --border-dark:  rgba(185,199,193,0.15);
      --border-light: rgba(51,68,61,0.12);
      --font-display: 'Cormorant Garamond', Georgia, serif;
      --font-body:    'Barlow', system-ui, sans-serif;
      --ease-out:     cubic-bezier(0.16, 1, 0.3, 1);
    }

    html { scroll-behavior: smooth; }

    body {
      font-family: var(--font-body);
      background: var(--cream);
      color: var(--forest);
      overflow-x: hidden;
      cursor: none;
    }

    img, video { display: block; max-width: 100%; }
    a { text-decoration: none; color: inherit; }
    ul { list-style: none; }
    button { cursor: none; background: none; border: none; font: inherit; }

    /* Reduced motion */
    @media (prefers-reduced-motion: reduce) {
      *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
      }
    }

    /* =====================================================
       CURSOR
       ===================================================== */

    .cursor {
      position: fixed;
      width: 40px;
      height: 40px;
      border-radius: 50%;
      pointer-events: none;
      z-index: 9999;
      transform: translate(-50%, -50%);
      transition: width 0.3s var(--ease-out),
                  height 0.3s var(--ease-out),
                  background 0.4s ease,
                  border-color 0.4s ease,
                  opacity 0.3s ease;
      mix-blend-mode: normal;
    }

    .cursor--light {
      background: transparent;
      border: 1.5px solid rgba(248,246,243,0.7);
    }
    .cursor--dark {
      background: transparent;
      border: 1.5px solid rgba(51,68,61,0.5);
    }
    .cursor--dot {
      width: 6px;
      height: 6px;
      border-radius: 50%;
      position: fixed;
      pointer-events: none;
      z-index: 10000;
      transform: translate(-50%,-50%);
      transition: background 0.4s ease;
    }
    .cursor--dot.light { background: var(--cream); }
    .cursor--dot.dark  { background: var(--forest); }

    .cursor.hovering {
      width: 64px;
      height: 64px;
    }
    .cursor.clicking {
      width: 28px;
      height: 28px;
    }

    @media (hover: none) {
      .cursor, .cursor--dot { display: none; }
      body { cursor: auto; }
      button { cursor: pointer; }
    }

    /* =====================================================
       NAVIGATION
       ===================================================== */

    .nav {
      position: fixed;
      top: 0; left: 0; right: 0;
      z-index: 100;
      padding: 1rem 3rem;
      display: flex;
      align-items: center;
      justify-content: space-between;
      /* Always transparent — text adapts */
      background: transparent;
      transition: padding 0.4s cubic-bezier(0.16,1,0.3,1),
                  background 0.5s ease;
      border-bottom: 1px solid transparent;
    }

    .nav.scrolled {
      padding: 0.75rem 3rem;
      background: rgba(248, 246, 243, 0.08);
      backdrop-filter: blur(20px) saturate(180%);
      -webkit-backdrop-filter: blur(20px) saturate(180%);
      border-bottom: 1px solid rgba(255,255,255,0.08);
    }

    .nav__logo {
      display: flex;
      align-items: center;
      flex-shrink: 0;
      transition: opacity 0.3s ease;
      overflow: visible;
    }
    .nav__logo:hover { opacity: 0.8; }
    .nav__logo-img {
      height: 44px !important;
      width: auto !important;
      max-width: none !important;
      max-height: none !important;
      min-height: unset !important;
      object-fit: unset !important;
      object-position: unset !important;
      filter: brightness(0) invert(1);
      display: block !important;
      flex-shrink: 0;
    }

    .nav__links {
      display: flex;
      gap: 2.5rem;
      align-items: center;
    }
    .nav__link {
      font-size: 0.75rem;
      font-weight: 400;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      /* mix-blend-mode makes text always visible on any background */
      color: #fff;
      mix-blend-mode: difference;
      transition: opacity 0.3s ease;
      position: relative;
    }
    .nav__link::after {
      content: '';
      position: absolute;
      bottom: -2px; left: 0;
      width: 0; height: 1px;
      background: currentColor;
      transition: width 0.3s var(--ease-out);
    }
    .nav__link:hover { opacity: 0.7; }
    .nav__link:hover::after { width: 100%; }

    .nav__cta {
      font-size: 0.7rem;
      font-weight: 500;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: #fff;
      mix-blend-mode: difference;
      border: 1px solid rgba(255,255,255,0.5);
      padding: 0.6rem 1.4rem;
      border-radius: 2px;
      transition: all 0.3s ease;
    }
    .nav__cta:hover {
      color: var(--cream);
      border-color: rgba(248,246,243,0.7);
      background: rgba(248,246,243,0.08);
    }
    .nav__cta:hover { opacity: 0.7; border-color: rgba(255,255,255,0.9); }

    /* ── CURTAIN MENU ──────────────────────────────────────── */
    .nav__burger { display:none; flex-direction:column; justify-content:center; gap:6px; padding:.5rem; width:40px; height:40px; cursor:none; background:none; border:none; position:relative; z-index:101; }
    .nav__burger span { display:block; width:100%; height:1px; background:#fff; transform-origin:center; transition:transform .5s cubic-bezier(.16,1,.3,1), opacity .3s ease, width .4s cubic-bezier(.16,1,.3,1), background .3s ease; }
    .nav.scrolled .nav__burger span { background:#33443D; }
    .nav__burger.is-open span { background:#fff !important; }
    .nav__burger.is-open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
    .nav__burger.is-open span:nth-child(2) { opacity:0; width:0; }
    .nav__burger.is-open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

    .curtain { position:fixed; inset:0; z-index:99; pointer-events:none; overflow:hidden; }
    .curtain.is-open { pointer-events:auto; }
    .curtain__panel { position:absolute; left:0; right:0; height:50%; background:#1E2B26; will-change:transform; transition:transform .7s cubic-bezier(.16,1,.3,1); }
    .curtain__panel--top    { top:0;    transform:translateY(-100%); }
    .curtain__panel--bottom { bottom:0; transform:translateY(100%); transition-delay:.04s; }
    .curtain.is-open  .curtain__panel--top,
    .curtain.is-open  .curtain__panel--bottom { transform:translateY(0); }
    .curtain.is-closing .curtain__panel--top    { transform:translateY(-100%); transition-delay:.12s; }
    .curtain.is-closing .curtain__panel--bottom { transform:translateY(100%);  transition-delay:.06s; }
    .curtain__nav { position:absolute; inset:0; z-index:1; display:flex; flex-direction:column; justify-content:center; padding:6rem 2rem 2rem; opacity:0; transition:opacity .35s ease; pointer-events:none; overflow-y:auto; -webkit-overflow-scrolling:touch; }
    .curtain.is-open    .curtain__nav { opacity:1; transition-delay:.55s; pointer-events:auto; }
    .curtain.is-closing .curtain__nav { opacity:0; transition-delay:0s; }
    .curtain__links { list-style:none; margin:0 0 2rem; }
    .curtain__links li { overflow:hidden; border-bottom:1px solid rgba(185,199,193,.12); }
    .curtain__links li:first-child { border-top:1px solid rgba(185,199,193,.12); }
    .curtain__link { font-family:'Cormorant Garamond',Georgia,serif; font-size:clamp(1.75rem,6vw,3.5rem); font-weight:300; color:#F8F6F3; line-height:1; padding:.65rem 0; display:flex; align-items:center; justify-content:space-between; gap:1rem; transition:color .25s ease, letter-spacing .4s cubic-bezier(.16,1,.3,1); }
    .curtain__link::after { content:'→'; font-family:'Barlow',sans-serif; font-size:1.1rem; color:rgba(185,199,193,.35); transition:color .25s ease, transform .4s cubic-bezier(.16,1,.3,1); flex-shrink:0; }
    .curtain__link:hover { color:#B9C7C1; letter-spacing:.04em; }
    .curtain__link:hover::after { color:rgba(185,199,193,.7); transform:translate(6px,-4px); }
    .curtain__link.is-active { color:#BAAE93; }
    .curtain__cta { display:inline-flex; align-items:center; font-size:1rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:#F8F6F3; border:1px solid rgba(185,199,193,.35); padding:.75rem 1.75rem; border-radius:2px; width:fit-content; transition:border-color .25s ease, background .25s ease; }
    .curtain__cta:hover { border-color:#B9C7C1; background:rgba(185,199,193,.08); }
    @media (max-width:900px) { .nav__burger { display:flex !important; } }
    @media (orientation:landscape) and (max-height:500px) {
      .curtain__nav { padding:4.5rem 2rem 1.5rem; justify-content:flex-start; }
      .curtain__link { font-size:clamp(1.4rem,5vh,2rem); padding:.45rem 0; }
      .curtain__links { margin-bottom:1.25rem; }
      .curtain__cta { padding:.55rem 1.25rem; font-size:.9rem; }
    }

    @media (max-width: 900px) {
      .nav__links, .nav__cta { display: none; }
      .nav__burger { display: flex; }
      .nav { padding: 1.25rem 1.5rem; }
      .nav.scrolled { padding: 1rem 1.5rem; }
    }

    /* =====================================================
       HERO
       ===================================================== */

    .hero {
      position: relative;
      width: 100%;
      height: 100svh;
      height: 100vh;
      min-height: 600px;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      overflow: hidden;
      /* Mesh gradient base */
      background-color: #33443D;
    }

    /* Animated mesh gradient — visible movement */
    .hero::before {
      content: '';
      position: absolute;
      inset: 0;
      z-index: 0;
      background:
        radial-gradient(ellipse 70% 60% at var(--x1, 20%) var(--y1, 30%), rgba(83,104,95,0.75) 0%, transparent 60%),
        radial-gradient(ellipse 55% 50% at var(--x2, 80%) var(--y2, 70%), rgba(30,48,40,0.9) 0%, transparent 55%),
        radial-gradient(ellipse 60% 55% at var(--x3, 50%) var(--y3, 50%), rgba(74,94,86,0.6) 0%, transparent 60%),
        radial-gradient(ellipse 40% 40% at var(--x4, 10%) var(--y4, 80%), rgba(51,68,61,0.8) 0%, transparent 50%),
        radial-gradient(ellipse 45% 45% at var(--x5, 90%) var(--y5, 15%), rgba(42,74,58,0.7) 0%, transparent 55%);
      animation: mesh1 12s ease-in-out infinite alternate,
                 mesh2 17s ease-in-out infinite alternate-reverse,
                 mesh3 22s ease-in-out infinite alternate;
      pointer-events: none;
    }

    /* Second layer — lighter accent blobs */
    .hero__mesh {
      position: absolute;
      inset: 0;
      z-index: 0;
      background:
        radial-gradient(ellipse 35% 35% at 30% 60%, rgba(185,199,193,0.08) 0%, transparent 60%),
        radial-gradient(ellipse 25% 25% at 70% 30%, rgba(186,174,147,0.07) 0%, transparent 55%);
      animation: mesh2 14s ease-in-out infinite alternate;
      pointer-events: none;
    }

    @keyframes mesh1 {
      0%   { transform: scale(1)    translate(0%,    0%);   }
      33%  { transform: scale(1.08) translate(-4%,   3%);   }
      66%  { transform: scale(1.04) translate(5%,   -4%);   }
      100% { transform: scale(1.10) translate(-3%,  -2%);   }
    }
    @keyframes mesh2 {
      0%   { transform: scale(1)    translate(0%,    0%);   }
      40%  { transform: scale(1.12) translate(5%,   -5%);   }
      80%  { transform: scale(1.06) translate(-6%,   3%);   }
      100% { transform: scale(1.09) translate(3%,    5%);   }
    }
    @keyframes mesh3 {
      0%   { transform: scale(1.05) translate(2%,   -2%);   }
      50%  { transform: scale(1)    translate(-3%,   4%);   }
      100% { transform: scale(1.07) translate(4%,   -3%);   }
    }
      25%  { transform: translate(-3%, 4%) scale(1.04); }
      50%  { transform: translate(4%, -3%) scale(1.02); }
      75%  { transform: translate(-2%, -4%) scale(1.05); }
      100% { transform: translate(3%, 2%) scale(1.03); }
    }

    /* Grain */
    .hero::after {
      content: '';
      position: absolute;
      inset: 0;
      opacity: 0.07;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.72' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");
      background-size: 200px;
      pointer-events: none;
    }

    .hero__content {
      position: relative;
      z-index: 2;
      text-align: center;
      padding: 0 2rem;
      width: 100%;
      max-width: 900px;
    }

    /* Eyebrow */
    .hero__eyebrow {
      font-family: var(--font-body);
      font-size: 0.7rem;
      font-weight: 500;
      letter-spacing: 0.28em;
      text-transform: uppercase;
      color: var(--mist);
      margin-bottom: 2.5rem;
      opacity: 0;
      animation: fade-up 0.8s var(--ease-out) 0.3s forwards;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 1rem;
    }
    .hero__eyebrow::before,
    .hero__eyebrow::after {
      content: '';
      width: 32px;
      height: 1px;
      background: var(--mist);
      opacity: 0.5;
    }

    /* Rotating headline */
    .hero__title {
      font-family: var(--font-display);
      font-size: clamp(2.8rem, 6.5vw, 6rem);
      font-weight: 300;
      line-height: 1;
      letter-spacing: -0.02em;
      position: relative;
      /* Enough room for descenders (g, y, p) + ascenders */
      height: 1.35em;
      overflow: hidden;
      width: 100%;
    }

    .hero__phrase {
      position: absolute;
      top: 0.1em; /* small top offset so ascenders don't clip */
      left: 0;
      right: 0;
      opacity: 1;
      white-space: nowrap;
      text-align: center;
    }

    /* Each word clips its own inner span — no flex needed */
    .hero__word {
      display: inline-block;
      overflow: hidden;
      vertical-align: bottom;
      /* extra bottom padding so descenders breathe */
      padding-bottom: 0.15em;
      margin-bottom: -0.15em;
    }

    .hero__word-inner {
      display: inline-block;
      transform: translateY(115%);
      transition: transform 0.9s cubic-bezier(0.16, 1, 0.3, 1);
      will-change: transform;
      font-weight: 300;
      color: var(--cream);
    }

    .hero__word-inner.italic {
      font-style: italic;
      color: var(--sand);
    }
    .hero__phrase em .word-inner {
      font-style: italic;
    }
    /* When phrase is animating in */
    .hero__phrase.animating-in .word-inner {
      transform: translateY(0%);
    }

    /* Scroll indicator */
    .hero__scroll {
      position: absolute;
      bottom: 2.5rem;
      left: 50%;
      transform: translateX(-50%);
      z-index: 2;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 0.5rem;
      opacity: 0;
      animation: fade-up 0.8s var(--ease-out) 1.8s forwards;
    }
    .hero__scroll-text {
      font-size: 0.7rem;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: rgba(248,246,243,0.4);
    }
    .hero__scroll-line {
      width: 1px;
      height: 40px;
      background: rgba(248,246,243,0.15);
      position: relative;
      overflow: hidden;
    }
    .hero__scroll-line::after {
      content: '';
      position: absolute;
      top: -100%;
      width: 100%;
      height: 100%;
      background: var(--mist);
      animation: scroll-drop 2s ease-in-out infinite 2s;
    }

    /* =====================================================
       VIDEO FULL — Block 1
       ===================================================== */

    .block-video-full {
      position: relative;
      width: 100%;
      height: 100vh; height: 100svh;
      overflow: hidden;
      background: #000;
    }
    .block-video-full video {
      width: 100%;
      height: 100%;
      object-fit: cover;
      opacity: 0.9;
    }

    /* =====================================================
       SPLIT BLOCK — Block 2 (links Bild, rechts Video)
       ===================================================== */

    .block-split {
      display: grid;
      grid-template-columns: 1fr 1fr;
      width: 100%;
      height: 100vh; height: 100svh;
    }
    .block-split__left,
    .block-split__right {
      position: relative;
      overflow: hidden;
    }
    .block-split__left img,
    .block-split__right video {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: transform 0.8s var(--ease-out);
    }
    .block-split__left:hover img,
    .block-split__right:hover video {
      transform: scale(1.03);
    }

    @media (max-width: 768px) {
      .block-split {
        grid-template-columns: 1fr;
        height: auto;
      }
      .block-split__left,
      .block-split__right {
        height: 60svh;
      }
    }

    /* =====================================================
       FULL IMAGE — Block 3
       ===================================================== */

    .block-image-full {
      position: relative;
      width: 100%;
      height: 100vh; height: 100svh;
      overflow: hidden;
      background: var(--forest-deep);
    }
    .block-image-full img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

    /* =====================================================
       HORIZONTAL SCROLL GALLERY — Block 4
       ===================================================== */

    /* Horizontal scroll wrapper — height set by JS based on item count */
    .block-hscroll {
      position: relative;
      /* height set inline: (n+1) * 100vh so scroll space = n full screens */
    }

    .block-hscroll__sticky {
      position: sticky;
      top: 0;
      height: 100vh; height: 100svh;
      width: 100%;
      overflow: hidden;
    }

    .block-hscroll__track {
      display: flex;
      height: 100%;
      width: 100%;
      will-change: transform;
      transition: transform 0s linear;
    }

    .block-hscroll__item {
      flex-shrink: 0;
      width: 100vw;
      height: 100vh; height: 100svh;
      position: relative;
      overflow: hidden;
    }

    .block-hscroll__item img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: transform 0.6s var(--ease-out);
    }

    /* Caption overlay */
    .block-hscroll__caption {
      position: absolute;
      bottom: 3rem;
      left: 3rem;
      z-index: 2;
      opacity: 0;
      transform: translateY(8px);
      transition: opacity 0.4s ease, transform 0.4s var(--ease-out);
    }
    .block-hscroll__item.active .block-hscroll__caption {
      opacity: 1;
      transform: none;
    }
    .block-hscroll__caption-tag {
      font-size: 0.7rem;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: var(--mist);
      margin-bottom: 0.4rem;
    }
    .block-hscroll__caption-title {
      font-family: var(--font-display);
      font-size: clamp(1.5rem, 3vw, 2.5rem);
      font-weight: 300;
      color: var(--cream);
    }

    /* Progress dots */
    .block-hscroll__dots {
      position: absolute;
      bottom: 3rem;
      right: 3rem;
      z-index: 10;
      display: flex;
      gap: 0.6rem;
      align-items: center;
    }
    .block-hscroll__dot {
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: rgba(248,246,243,0.3);
      transition: background 0.3s ease, width 0.3s var(--ease-out);
    }
    .block-hscroll__dot.active {
      background: var(--cream);
      width: 20px;
      border-radius: 3px;
    }

    /* Scroll hint */
    .block-hscroll__hint {
      position: absolute;
      top: 50%;
      right: 3rem;
      transform: translateY(-50%);
      z-index: 10;
      writing-mode: vertical-rl;
      font-size: 0.7rem;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: rgba(248,246,243,0.35);
      display: flex;
      align-items: center;
      gap: 0.75rem;
    }
    .block-hscroll__hint::after {
      content: '';
      width: 1px;
      height: 48px;
      background: rgba(248,246,243,0.2);
    }

    /* =====================================================
       PROZESS BLOCK
       ===================================================== */

    .block-prozess {
      background: var(--forest);
      padding: 8rem 3rem;
      position: relative;
      overflow: hidden;
    }
    .block-prozess::after {
      content: '';
      position: absolute;
      inset: 0;
      opacity: 0.03;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.72' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");
      background-size: 200px;
      pointer-events: none;
    }

    .block-prozess__inner {
      max-width: 1280px;
      margin: 0 auto;
      position: relative;
      z-index: 1;
    }

    .block-prozess__header {
      margin-bottom: 5rem;
    }

    .eyebrow {
      font-size: 0.7rem;
      font-weight: 500;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      display: flex;
      align-items: center;
      gap: 0.75rem;
      margin-bottom: 1.5rem;
    }
    .eyebrow::before {
      content: '';
      width: 28px;
      height: 1px;
      background: currentColor;
      flex-shrink: 0;
      opacity: 0.6;
    }
    .eyebrow--light { color: var(--mist); }
    .eyebrow--dark  { color: var(--sage); }

    .section-title {
      font-family: var(--font-display);
      font-weight: 300;
      letter-spacing: -0.02em;
      line-height: 1.05;
    }
    .section-title--light { color: var(--cream); }
    .section-title--dark  { color: var(--forest); }
    .section-title em { font-style: italic; }
    .section-title--light em { color: var(--sand); }
    .section-title--dark  em { color: var(--sage); }

    .block-prozess__steps {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 1px;
      background: var(--border-dark);
      border: 1px solid var(--border-dark);
    }

    .prozess-step {
      background: var(--forest);
      padding: 3rem 2rem;
      transition: background 0.3s ease;
    }
    .prozess-step:hover { background: var(--forest-light); }

    .prozess-step__num {
      font-family: var(--font-display);
      font-size: 4rem;
      font-weight: 300;
      color: var(--border-dark);
      line-height: 1;
      margin-bottom: 1.5rem;
      font-style: italic;
      transition: color 0.3s ease;
    }
    .prozess-step:hover .prozess-step__num { color: var(--sage); }

    .prozess-step__title {
      font-family: var(--font-display);
      font-size: 1.375rem;
      font-weight: 600;
      color: var(--cream);
      margin-bottom: 0.75rem;
    }
    .prozess-step__text {
      font-size: 1rem;
      color: rgba(185,199,193,0.7);
      line-height: 1.65;
      font-weight: 300;
    }

    @media (max-width: 900px) {
      .block-prozess__steps { grid-template-columns: repeat(2,1fr); }
    }
    @media (max-width: 600px) {
      .block-prozess__steps { grid-template-columns: 1fr; }
      .block-prozess { padding: 5rem 1.5rem; }
    }

    /* =====================================================
       TESTIMONIALS
       ===================================================== */

    .block-testimonials {
      background: var(--cream);
      padding: 8rem 3rem;
    }

    .block-testimonials__inner {
      max-width: 1280px;
      margin: 0 auto;
    }

    .block-testimonials__header {
      margin-bottom: 4rem;
      text-align: center;
    }

    .block-testimonials__grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1.5rem;
    }

    .testimonial-card {
      background: #fff;
      border: 1px solid var(--border-light);
      padding: 2.5rem;
      transition: transform 0.3s var(--ease-out), box-shadow 0.3s ease;
    }
    .testimonial-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 16px 48px rgba(51,68,61,0.1);
    }

    .testimonial-card {
      quotes: "\201E" "\201C" "\2018" "\2019";
    }
    .testimonial-card__quote {
      font-family: var(--font-display);
      font-size: 1.3rem;
      font-weight: 300;
      font-style: italic;
      color: var(--forest);
      line-height: 1.6;
      margin-bottom: 2rem;
    }
    .testimonial-card__quote::before { display: none; }

    .testimonial-card__author {
      display: flex;
      align-items: center;
      gap: 1rem;
    }
    .testimonial-card__avatar {
      width: 38px;
      height: 38px;
      border-radius: 50%;
      background: var(--mist);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.75rem;
      font-weight: 500;
      color: var(--forest);
      flex-shrink: 0;
    }
    .testimonial-card__name {
      font-size: 0.875rem;
      font-weight: 500;
      color: var(--forest);
    }
    .testimonial-card__role {
      font-size: 0.75rem;
      color: #404040;
      margin-top: 2px;
    }

    @media (max-width: 900px) {
      .block-testimonials__grid { grid-template-columns: 1fr; }
      .block-testimonials { padding: 5rem 1.5rem; }
    }

    /* =====================================================
       CTA — BEREIT?
       ===================================================== */

    .block-cta {
      background: var(--forest-deep);
      padding: 10rem 3rem;
      text-align: center;
      position: relative;
      overflow: hidden;
    }
    .block-cta::before {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(83,104,95,0.25) 0%, transparent 70%);
      pointer-events: none;
    }
    .block-cta::after {
      content: '';
      position: absolute;
      inset: 0;
      opacity: 0.04;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.72' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");
      background-size: 200px;
      pointer-events: none;
    }

    .block-cta__inner {
      position: relative;
      z-index: 1;
      max-width: 700px;
      margin: 0 auto;
    }

    .block-cta__title {
      font-family: var(--font-display);
      font-size: clamp(2.5rem, 6vw, 5rem);
      font-weight: 300;
      color: var(--cream);
      line-height: 1.05;
      letter-spacing: -0.02em;
      margin-top: 1.5rem;
      margin-bottom: 1.5rem;
    }
    .block-cta__title em {
      font-style: italic;
      color: var(--sand-light);
    }

    .block-cta__sub {
      font-size: 1.125rem;
      color: rgba(248,246,243,0.55);
      font-weight: 300;
      margin-bottom: 3rem;
      line-height: 1.6;
    }

    .block-cta__actions {
      display: flex;
      gap: 1rem;
      justify-content: center;
      flex-wrap: wrap;
    }

    .btn {
      display: inline-flex;
      align-items: center;
      gap: 0.5rem;
      font-family: var(--font-body);
      font-size: 0.7rem;
      font-weight: 500;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      padding: 1rem 2.5rem;
      border-radius: 2px;
      transition: all 0.3s ease;
      position: relative;
      overflow: hidden;
    }
    .btn--light {
      color: var(--forest);
      background: var(--cream);
      border: 1px solid var(--cream);
    }
    .btn--light:hover {
      background: var(--sand-light);
      border-color: var(--sand-light);
    }
    .btn--outline-light {
      color: rgba(248,246,243,0.7);
      background: transparent;
      border: 1px solid rgba(248,246,243,0.25);
    }
    .btn--outline-light:hover {
      color: var(--cream);
      border-color: rgba(248,246,243,0.6);
      background: rgba(248,246,243,0.06);
    }

    .block-cta__note {
      margin-top: 2rem;
      font-size: 0.7rem;
      letter-spacing: 0.06em;
      color: rgba(248,246,243,0.3);
    }

    /* =====================================================
       FOOTER
       ===================================================== */

    .footer {
      background: linear-gradient(160deg, #2d4238 0%, #33443D 45%, #2a3d34 100%);
      padding: 5rem 3rem 3rem;
      position: relative; overflow: hidden;
    }

    .footer__inner {
      max-width: 1280px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: 1.5fr 1fr 1fr 1fr;
      gap: 3rem;
      padding-bottom: 3rem;
      border-bottom: 1px solid var(--border-dark);
    }

    .footer__logo-link {
      display: inline-block;
      margin-bottom: 1.25rem;
      transition: opacity 0.3s ease;
    }
    .footer__logo-link:hover { opacity: 0.75; }
    .footer__logo-img {
      height: 32px;
      width: auto;
      /* White version on dark footer */
      filter: brightness(0) invert(1);
      opacity: 0.9;
    }

    .footer__tagline {
      font-size: 0.875rem;
      color: #FCFBF7;
      line-height: 1.65;
      font-weight: 300;
    }

    .footer__col-title {
      font-size: 0.7rem;
      font-weight: 500;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: var(--mist);
      margin-bottom: 1.5rem;
    }

    .footer__links {
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
    }
    .footer__link { font-size: 0.875rem; color: rgba(252,251,247,.7); font-weight: 300; display: inline-flex; align-items: center; position: relative; width: fit-content; transition: color .25s ease; }
    .footer__link::after { content: ''; position: absolute; bottom: -1px; left: 0; width: 0; height: 1px; background: var(--mist); transition: width .35s cubic-bezier(.16,1,.3,1); }
    .footer__link:hover { color: #FCFBF7; }
    .footer__link:hover::after { width: 100%; }

    .footer__bottom {
      max-width: 1280px;
      margin: 2rem auto 0;
      display: flex;
      justify-content: space-between;
      align-items: center;
      flex-wrap: wrap;
      gap: 1rem;
    }
    .footer__copy {
      font-size: 0.75rem;
      color: #FCFBF7;
      font-weight: 300;
    }
    .footer__legal {
      display: flex;
      gap: 1.5rem;
    }
    .footer__legal a {
      font-size: 0.75rem;
      color: #FCFBF7;
      transition: color 0.2s;
    }
    .footer__legal a:hover { color: var(--mist); }

    @media (max-width: 900px) {
      .footer__inner { grid-template-columns: 1fr 1fr; gap: 2rem; }
      .footer { padding: 3rem 1.5rem 2rem; }
    }
    @media (max-width: 600px) {
      .footer__inner { grid-template-columns: 1fr; }
      .footer__bottom { flex-direction: column; align-items: flex-start; }
    }

    /* =====================================================
       REVEAL ANIMATIONS
       ===================================================== */

    .reveal {
      opacity: 0;
      transform: translateY(28px);
      transition: opacity 0.9s var(--ease-out), transform 0.9s var(--ease-out);
    }
    .reveal.visible { opacity: 1; transform: none; }

    .reveal-stagger > * {
      opacity: 0;
      transform: translateY(20px);
      transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
    }
    .reveal-stagger.visible > *:nth-child(1) { opacity:1; transform:none; transition-delay: 0ms; }
    .reveal-stagger.visible > *:nth-child(2) { opacity:1; transform:none; transition-delay: 80ms; }
    .reveal-stagger.visible > *:nth-child(3) { opacity:1; transform:none; transition-delay: 160ms; }
    .reveal-stagger.visible > *:nth-child(4) { opacity:1; transform:none; transition-delay: 240ms; }

    /* =====================================================
       KEYFRAMES
       ===================================================== */

    @keyframes fade-up {
      from { opacity: 0; transform: translateY(20px); }
      to   { opacity: 1; transform: none; }
    }
    @keyframes scroll-drop {
      0%   { top: -100%; }
      100% { top: 100%; }
    }
  
    /* ── CURTAIN MENU ──────────────────────────────────── */
    .nav__burger { display:none; flex-direction:column; justify-content:center; gap:6px; padding:.5rem; width:40px; height:40px; cursor:pointer; background:none; border:none; position:relative; z-index:101; }
    .nav__burger span { display:block; width:100%; height:1px; background:#fff; transform-origin:center; transition:transform .5s cubic-bezier(.16,1,.3,1), opacity .3s ease, width .4s cubic-bezier(.16,1,.3,1), background .3s ease; }
    .nav.scrolled .nav__burger span { background:#33443D; }
    .nav__burger.is-open span { background:#fff !important; }
    .nav__burger.is-open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
    .nav__burger.is-open span:nth-child(2) { opacity:0; width:0; }
    .nav__burger.is-open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
    .curtain { position:fixed; inset:0; z-index:99; pointer-events:none; overflow:hidden; }
    .curtain.is-open { pointer-events:auto; }
    .curtain__panel { position:absolute; left:0; right:0; height:50%; background:#33443D; will-change:transform; transition:transform .7s cubic-bezier(.16,1,.3,1); }
    .curtain__panel--top    { top:0;    transform:translateY(-100%); }
    .curtain__panel--bottom { bottom:0; transform:translateY(100%); transition-delay:.04s; }
    .curtain.is-open  .curtain__panel--top,
    .curtain.is-open  .curtain__panel--bottom { transform:translateY(0); }
    .curtain.is-closing .curtain__panel--top    { transform:translateY(-100%); transition-delay:.12s; }
    .curtain.is-closing .curtain__panel--bottom { transform:translateY(100%);  transition-delay:.06s; }
    .curtain__nav { position:absolute; inset:0; z-index:1; display:flex; flex-direction:column; justify-content:center; padding:6rem 2rem 2rem; opacity:0; transition:opacity .35s ease; pointer-events:none; overflow-y:auto; -webkit-overflow-scrolling:touch; }
    .curtain.is-open    .curtain__nav { opacity:1; transition-delay:.55s; pointer-events:auto; }
    .curtain.is-closing .curtain__nav { opacity:0; transition-delay:0s; }
    .curtain__links { list-style:none; margin:0 0 2rem; }
    .curtain__links li { overflow:hidden; border-bottom:1px solid rgba(185,199,193,.12); }
    .curtain__links li:first-child { border-top:1px solid rgba(185,199,193,.12); }
    .curtain__link { font-family:'Cormorant Garamond',Georgia,serif; font-size:clamp(1.75rem,6vw,3.5rem); font-weight:300; color:#F8F6F3; line-height:1; padding:.65rem 0; display:flex; align-items:center; justify-content:space-between; gap:1rem; transition:color .25s ease, letter-spacing .4s cubic-bezier(.16,1,.3,1); }
    .curtain__link::after { content:'→'; font-family:'Barlow',sans-serif; font-size:1.1rem; color:rgba(185,199,193,.35); transition:color .25s ease, transform .4s cubic-bezier(.16,1,.3,1); flex-shrink:0; }
    .curtain__link:hover { color:#B9C7C1; letter-spacing:.04em; }
    .curtain__link:hover::after { color:rgba(185,199,193,.7); transform:translate(6px,-4px); }
    .curtain__link.is-active { color:#BAAE93; }
    .curtain__cta { display:inline-flex; align-items:center; font-size:1rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:#F8F6F3; border:1px solid rgba(185,199,193,.35); padding:.75rem 1.75rem; border-radius:2px; width:fit-content; transition:border-color .25s ease, background .25s ease; }
    .curtain__cta:hover { border-color:#B9C7C1; background:rgba(185,199,193,.08); }
    @media (max-width:900px) { .nav__burger { display:flex !important; } }
    @media (orientation:landscape) and (max-height:500px) {
      .curtain__nav { padding:4.5rem 2rem 1.5rem; justify-content:flex-start; }
      .curtain__link { font-size:clamp(1.4rem,5vh,2rem); padding:.45rem 0; }
      .curtain__links { margin-bottom:1.25rem; }
      .curtain__cta { padding:.55rem 1.25rem; font-size:.9rem; }
    }
  
    /* ── FULLSCREEN IMAGE SEQUENCE ──────────────────────────── */
    .img-spacer {
      position: relative;
      height: 100vh; height: 100svh;
      width: 100%;
    }
    #imgSpacer1 { z-index: 0; }
    #imgSpacer2 { z-index: 0; }

    .img-layer {
      position: fixed;
      top: 0; left: 0;
      width: 100%; height: 100vh; height: 100svh;
      overflow: hidden;
      pointer-events: none;
    }
    #imgLayer1 { z-index: 10; opacity: 0; }
    #imgLayer2 { z-index: 11; transform: translateY(100%); }

    .img-layer img {
      width: 100%; height: 100%;
      object-fit: cover; display: block;
    }

    /* All content after image sequence must be above fixed layers */
    .block-hscroll,
    .block-prozess,
    .block-testimonials,
    .block-cta,
    .block-video-full,
    .block-split {
      position: relative;
      z-index: 20;
    }
