/* The Bar - identidade visual e layout base */
:root {
        color-scheme: dark;
        --obsidian: #0a0a0a;
        --warm-black: #100c06;
        --carbon: #1a1612;
        --champagne: #e8d9b3;
        --gold: #c9a961;
        --antique: #a88e52;
        --muted: #a89876;
        --bronze: #8a7d62;
        --whisper: #5a5141;
        --line: rgba(201, 169, 97, 0.22);
        --line-strong: rgba(201, 169, 97, 0.42);
        --error: #d58f75;
        --font-serif: "Young Serif", "Playfair Display", "Bodoni Moda", Georgia, serif;
        --font-sans: "Inter", "Helvetica Neue", Arial, sans-serif;
        --container: min(1120px, calc(100vw - 40px));
        --wide: min(1360px, calc(100vw - 40px));
        --nav-height: 96px;
        --ease: cubic-bezier(0.4, 0, 0.2, 1);
      }

      * {
        box-sizing: border-box;
      }

      html {
        scroll-behavior: smooth;
        scrollbar-width: none;
        -ms-overflow-style: none;
      }

      html::-webkit-scrollbar,
      body::-webkit-scrollbar {
        width: 0;
        height: 0;
        display: none;
      }

      body {
        margin: 0;
        min-width: 320px;
        overflow-x: hidden;
        background: var(--obsidian);
        color: var(--muted);
        font-family: var(--font-sans);
        font-size: 16px;
        line-height: 1.8;
        text-rendering: optimizeLegibility;
        -webkit-font-smoothing: antialiased;
      }

      .floating-scrollbar {
        position: fixed;
        top: 14px;
        right: 7px;
        bottom: 14px;
        z-index: 260;
        width: 7px;
        opacity: 0;
        pointer-events: none;
        transition: opacity 220ms var(--ease);
      }

      .floating-scrollbar span {
        display: block;
        width: 3px;
        min-height: 34px;
        margin-left: auto;
        border-radius: 999px;
        background: linear-gradient(180deg, rgba(232, 217, 179, 0.96), rgba(201, 169, 97, 0.68));
        box-shadow: 0 0 16px rgba(201, 169, 97, 0.24);
        will-change: height, transform;
      }

      .floating-scrollbar.is-visible {
        opacity: 0.9;
      }

      .is-loading body,
      body.menu-open,
      body.lightbox-open {
        overflow: hidden;
      }

      img,
      svg {
        display: block;
      }

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

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

      button,
      input,
      select,
      textarea {
        font: inherit;
      }

      button {
        color: inherit;
      }

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

      .skip-link {
        position: fixed;
        top: 12px;
        left: 12px;
        z-index: 300;
        transform: translateY(-140%);
        border: 1px solid var(--gold);
        background: var(--obsidian);
        color: var(--champagne);
        padding: 10px 14px;
      }

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

      .site-loader {
        position: fixed;
        inset: 0;
        z-index: 500;
        display: none;
        place-items: center;
        overflow: hidden;
        background: #020100;
        opacity: 1;
        transform: scale(1);
        visibility: visible;
        transition:
          opacity 820ms cubic-bezier(0.19, 1, 0.22, 1),
          transform 980ms cubic-bezier(0.19, 1, 0.22, 1),
          filter 820ms cubic-bezier(0.19, 1, 0.22, 1),
          visibility 820ms cubic-bezier(0.19, 1, 0.22, 1);
      }

      .js .site-loader {
        display: grid;
      }

      .site-loader::before,
      .site-loader::after {
        content: "";
        position: absolute;
        left: 0;
        z-index: 3;
        width: 100%;
        height: clamp(44px, 9vh, 86px);
        background: linear-gradient(180deg, rgba(0, 0, 0, 0.88), rgba(0, 0, 0, 0));
        pointer-events: none;
      }

      .site-loader::before {
        top: 0;
        animation: loader-letterbox-top 2.1s cubic-bezier(0.19, 1, 0.22, 1) both;
      }

      .site-loader::after {
        bottom: 0;
        background: linear-gradient(0deg, rgba(0, 0, 0, 0.9), rgba(0, 0, 0, 0));
        animation: loader-letterbox-bottom 2.1s cubic-bezier(0.19, 1, 0.22, 1) both;
      }

      .site-loader.is-hidden {
        opacity: 0;
        filter: saturate(0.88) brightness(1.12);
        pointer-events: none;
        transform: scale(1.018);
        visibility: hidden;
      }

      .loader-video,
      .loader-scrim {
        position: absolute;
        inset: 0;
      }

      .loader-video {
        width: 100%;
        height: 100%;
        background: #020100;
        object-fit: cover;
        opacity: 0.96;
        filter: saturate(0.78) brightness(0.56) contrast(1.12);
        transform: scale(1.095);
        animation: loader-video-cinema 2.55s cubic-bezier(0.19, 1, 0.22, 1) both;
        will-change: opacity, transform, filter;
      }

      .site-loader:not(.is-video-active) .loader-video,
      .site-loader:not(.is-video-active) .loader-logo {
        opacity: 0;
        animation: none;
      }

      .loader-scrim {
        background:
          radial-gradient(circle at center, rgba(10, 10, 10, 0.16), rgba(10, 10, 10, 0.82) 68%),
          linear-gradient(90deg, rgba(0, 0, 0, 0.62), transparent 37%, transparent 63%, rgba(0, 0, 0, 0.62)),
          rgba(10, 10, 10, 0.24);
        animation: loader-scrim-cinema 2.45s cubic-bezier(0.19, 1, 0.22, 1) both;
        will-change: opacity;
      }

      .loader-logo {
        position: relative;
        z-index: 4;
        width: clamp(220px, 29vw, 398px);
        height: auto;
        opacity: 0;
        animation: loader-focus 2.45s cubic-bezier(0.19, 1, 0.22, 1) both;
        filter: blur(16px);
        will-change: opacity, transform, filter;
      }

      .site-loader.is-hidden .loader-video {
        animation: none;
        opacity: 0.74;
        filter: saturate(0.58) brightness(0.7) contrast(1.18);
        transform: scale(1.035);
        transition:
          opacity 820ms cubic-bezier(0.19, 1, 0.22, 1),
          transform 980ms cubic-bezier(0.19, 1, 0.22, 1),
          filter 820ms cubic-bezier(0.19, 1, 0.22, 1);
      }

      .site-loader.is-hidden .loader-logo {
        animation: none;
        opacity: 0;
        filter: blur(14px);
        transform: scale(1.035);
        transition:
          opacity 560ms cubic-bezier(0.19, 1, 0.22, 1),
          transform 760ms cubic-bezier(0.19, 1, 0.22, 1),
          filter 560ms cubic-bezier(0.19, 1, 0.22, 1);
      }

      @keyframes loader-focus {
        0% {
          filter: blur(18px);
          opacity: 0;
          transform: scale(0.94);
        }

        28% {
          filter: blur(0);
          opacity: 1;
          transform: scale(1);
        }

        76% {
          filter: blur(0);
          opacity: 0.96;
          transform: scale(1);
        }

        100% {
          filter: blur(4px);
          opacity: 0.5;
          transform: scale(0.975);
        }
      }

      @keyframes loader-video-cinema {
        0% {
          opacity: 0.98;
          filter: saturate(0.62) brightness(0.42) contrast(1.18);
          transform: scale(1.14);
        }

        46% {
          opacity: 1;
          filter: saturate(0.78) brightness(0.58) contrast(1.1);
        }

        100% {
          opacity: 0.96;
          filter: saturate(0.76) brightness(0.54) contrast(1.14);
          transform: scale(1.085);
        }
      }

      @keyframes loader-scrim-cinema {
        0% {
          opacity: 0.96;
        }

        48% {
          opacity: 0.76;
        }

        100% {
          opacity: 0.88;
        }
      }

      @keyframes loader-letterbox-top {
        0% {
          transform: translateY(-22px);
          opacity: 0;
        }

        100% {
          transform: translateY(0);
          opacity: 1;
        }
      }

      @keyframes loader-letterbox-bottom {
        0% {
          transform: translateY(22px);
          opacity: 0;
        }

        100% {
          transform: translateY(0);
          opacity: 1;
        }
      }

      .container {
        width: var(--container);
        margin: 0 auto;
      }

      .wide {
        width: var(--wide);
        margin: 0 auto;
      }

      .section {
        padding: clamp(88px, 11vw, 144px) 0;
      }

      .section.alt {
        background: var(--warm-black);
      }

      .services-section {
        position: relative;
        z-index: 1;
      }

      .services-section::before,
      .services-section::after {
        content: "";
        position: absolute;
        left: 50%;
        pointer-events: none;
      }

      .services-section::before {
        bottom: 0;
        z-index: 2;
        width: min(760px, calc(100% - 40px));
        height: 1px;
        background:
          linear-gradient(90deg, transparent 0%, rgba(201, 169, 97, 0.18) 12%, rgba(201, 169, 97, 0.72) 50%, rgba(201, 169, 97, 0.18) 88%, transparent 100%);
        transform: translateX(-50%);
      }

      .services-section::after {
        bottom: -5px;
        z-index: 3;
        width: 10px;
        height: 10px;
        border: 1px solid rgba(201, 169, 97, 0.82);
        background: var(--obsidian);
        box-shadow:
          -34px 5px 0 -4px rgba(201, 169, 97, 0.54),
          34px 5px 0 -4px rgba(201, 169, 97, 0.54),
          0 0 18px rgba(201, 169, 97, 0.22);
        transform: translateX(-50%) rotate(45deg);
      }

      .eyebrow {
        margin: 0 0 18px;
        color: var(--gold);
        font-size: 11px;
        font-weight: 500;
        letter-spacing: 4px;
        line-height: 1.5;
        text-transform: uppercase;
      }

      .services-section .eyebrow {
        display: inline-flex;
        max-width: 100%;
        align-items: center;
        gap: 14px;
        white-space: nowrap;
      }

      .services-section .eyebrow::after {
        content: "";
        flex: 0 0 clamp(64px, 8vw, 118px);
        min-width: 64px;
        height: 1px;
        background: linear-gradient(90deg, rgba(201, 169, 97, 0.82), rgba(201, 169, 97, 0.28), transparent);
      }

      .services-section #services-title,
      .services-section .section-head > p {
        margin-bottom: 0;
      }

      .serif {
        font-family: var(--font-serif);
        font-weight: 400;
      }

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

      @keyframes title-shine {
        0%, 15%   { background-position: -80% center; }
        75%, 100% { background-position: 260% center; }
      }

      h1,
      h2,
      h3 {
        font-family: var(--font-serif);
        font-weight: 400;
        background: linear-gradient(
          105deg,
          #c9a961  0%,
          #b5892e  18%,
          #d4aa45  38%,
          #aa7e28  55%,
          #d4aa45  72%,
          #f0d878  88%,
          #c9a961  100%
        );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        background-clip: text;
        color: transparent;
      }

      .hero h1 {
        background: linear-gradient(
          105deg,
          #c9a961  0%,
          #b5892e  12%,
          #d4aa45  24%,
          #aa7e28  34%,
          #c9a961  42%,
          #ecd06a  47%,
          #f5e08a  50%,
          #ecd06a  53%,
          #c9a961  58%,
          #aa7e28  70%,
          #d4aa45  82%,
          #f0d878  92%,
          #c9a961  100%
        );
        background-size: 300% 100%;
        background-position: -80% center;
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        background-clip: text;
        color: transparent;
        animation: title-shine 22s ease-in-out infinite;
      }

      h1 {
        margin-bottom: 24px;
        font-size: clamp(48px, 7vw, 84px);
        line-height: 1.05;
        letter-spacing: 0.5px;
      }

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

      h2 {
        margin-bottom: 22px;
        font-size: clamp(32px, 4vw, 48px);
        line-height: 1.15;
      }

      h3 {
        margin-bottom: 14px;
        font-size: clamp(20px, 2.1vw, 22px);
        line-height: 1.3;
      }

      p {
        margin-bottom: 20px;
      }

      .lead {
        max-width: 660px;
        color: var(--muted);
        font-size: clamp(17px, 2vw, 20px);
        line-height: 1.85;
      }

      .text-stack {
        max-width: 720px;
      }

      .ornament {
        display: flex;
        align-items: center;
        gap: 18px;
        width: min(260px, 80vw);
        margin: 38px auto;
        color: var(--gold);
        font-size: 13px;
        line-height: 1;
      }

      .ornament::before,
      .ornament::after {
        content: "";
        flex: 1;
        height: 1px;
        background: var(--line);
      }

      .btn-row {
        display: flex;
        flex-wrap: wrap;
        gap: 14px;
        align-items: center;
        margin-top: 34px;
      }

      .btn {
        display: inline-flex;
        position: relative;
        min-height: 44px;
        align-items: center;
        justify-content: center;
        gap: 9px;
        border: 1px solid var(--gold);
        border-radius: 2px;
        background: transparent;
        color: var(--champagne);
        cursor: pointer;
        font-size: 11px;
        font-weight: 500;
        isolation: isolate;
        letter-spacing: 3px;
        line-height: 1.2;
        overflow: hidden;
        padding: 12px 18px;
        text-transform: uppercase;
        transition:
          background-color 600ms var(--ease),
          border-color 600ms var(--ease),
          color 600ms var(--ease);
      }

      .btn-icon {
        display: block;
        flex: 0 0 21px;
        width: 21px;
        height: 21px;
        margin-left: -2px;
        overflow: visible;
      }

      @keyframes reserve-icon-ring {
        0%, 55%, 100% { transform: rotate(0deg) scale(1); }
        60%  { transform: rotate(-13deg) scale(1.08); }
        67%  { transform: rotate(11deg)  scale(1.06); }
        74%  { transform: rotate(-6deg)  scale(1.03); }
        80%  { transform: rotate(3deg)   scale(1.01); }
        86%  { transform: rotate(0deg)   scale(1); }
      }

      .reserve-date-icon {
        animation: reserve-icon-ring 4s ease-in-out infinite;
        transform-origin: center;
        overflow: visible;
      }

      @media (prefers-reduced-motion: reduce) {
        .reserve-date-icon { animation: none; }
      }

      .btn:hover {
        border-color: var(--champagne);
        background: rgba(201, 169, 97, 0.08);
      }

      .btn.filled {
        background: var(--gold);
        color: var(--obsidian);
      }

      .btn.filled::after {
        content: "";
        position: absolute;
        top: -68%;
        bottom: -68%;
        left: -72%;
        z-index: 0;
        width: 34%;
        background: linear-gradient(
          104deg,
          transparent 0%,
          rgba(255, 255, 255, 0.18) 47%,
          rgba(255, 246, 218, 0.2) 50%,
          rgba(255, 255, 255, 0.12) 53%,
          transparent 100%
        );
        mix-blend-mode: soft-light;
        opacity: 0;
        transform: skewX(-18deg) translateX(0);
        animation: cta-light-sweep 4.8s linear infinite;
        pointer-events: none;
      }

      .btn.filled:hover {
        background: var(--champagne);
        color: var(--obsidian);
      }

      @keyframes cta-light-sweep {
        0% {
          transform: skewX(-18deg) translateX(0);
          opacity: 0;
        }

        14%,
        78% {
          opacity: 0.26;
        }

        100% {
          transform: skewX(-18deg) translateX(520%);
          opacity: 0;
        }
      }

      .link-arrow {
        display: inline-flex;
        align-items: center;
        gap: 10px;
        color: var(--champagne);
        font-size: 12px;
        font-weight: 500;
        letter-spacing: 3px;
        text-transform: uppercase;
      }

      .link-arrow-icon {
        display: inline-block;
        flex: 0 0 20px;
        width: 20px;
        height: 12px;
        margin-left: 1px;
        background: url("../icons/arrow-long-right-gold.webp") center / contain no-repeat;
        transform-origin: center;
        transition: filter 400ms var(--ease);
        will-change: transform, opacity;
      }

      .js [data-reveal].is-visible .link-arrow-icon {
        animation:
          link-arrow-enter 640ms var(--ease) both,
          link-arrow-pulse 4s 640ms var(--ease) infinite;
      }

      .link-arrow:hover .link-arrow-icon {
        filter: drop-shadow(0 0 7px rgba(201, 169, 97, 0.3));
      }

      .service-card:hover .link-arrow-icon,
      .service-card:focus-visible .link-arrow-icon,
      .service-pane:hover .link-arrow-icon,
      .service-pane:focus-visible .link-arrow-icon {
        filter: drop-shadow(0 0 7px rgba(201, 169, 97, 0.3));
      }

      @keyframes link-arrow-enter {
        0% {
          opacity: 0;
          transform: translateX(-8px) scale(0.82);
        }

        58% {
          opacity: 1;
          transform: translateX(4px) scale(1.06);
        }

        100% {
          opacity: 1;
          transform: translateX(0) scale(1);
        }
      }

      @keyframes link-arrow-pulse {
        0%,
        76%,
        100% {
          opacity: 1;
          transform: translateX(0) scale(1);
        }

        84% {
          opacity: 1;
          transform: translateX(5px) scale(1.05);
        }

        91% {
          opacity: 1;
          transform: translateX(0) scale(1);
        }
      }

      .site-header {
        position: fixed;
        inset: 0 0 auto;
        z-index: 100;
        height: var(--nav-height);
        border-bottom: 0;
        background: transparent;
        backdrop-filter: none;
        transition:
          background-color 420ms var(--ease),
          backdrop-filter 420ms var(--ease),
          border-color 420ms var(--ease);
      }

      .site-header.is-scrolled {
        border-bottom: 0.5px solid var(--line);
        background: rgba(10, 10, 10, 0.72);
        backdrop-filter: blur(12px);
      }

      .nav {
        display: flex;
        width: var(--wide);
        height: 100%;
        align-items: center;
        justify-content: space-between;
        margin: 0 auto;
      }

      .brand {
        display: inline-flex;
        align-items: center;
        justify-content: flex-start;
        width: clamp(132px, 12vw, 176px);
        height: 78px;
        color: var(--champagne);
      }

      .brand-logo {
        display: block;
        width: 100%;
        height: 100%;
        object-fit: contain;
        object-position: left center;
      }

      .site-footer .brand {
        width: 210px;
        height: 154px;
      }

      .desktop-menu {
        display: flex;
        align-items: center;
        gap: clamp(18px, 2.5vw, 30px);
      }

      .desktop-menu a {
        color: var(--muted);
        font-size: 12px;
        font-weight: 500;
        letter-spacing: 2.2px;
        text-transform: uppercase;
        transition: color 400ms var(--ease);
      }

      .desktop-menu a:hover,
      .desktop-menu a.is-active {
        color: var(--champagne);
      }

      .nav-cta {
        padding: 12px 15px;
        min-height: 42px;
      }

      .menu-toggle {
        display: none;
        width: 46px;
        height: 46px;
        align-items: center;
        justify-content: center;
        border: 1px solid var(--line-strong);
        border-radius: 2px;
        background: transparent;
        cursor: pointer;
      }

      .menu-toggle span,
      .menu-toggle::before,
      .menu-toggle::after {
        content: "";
        display: block;
        width: 20px;
        height: 1px;
        background: var(--gold);
        transition: transform 300ms var(--ease), opacity 300ms var(--ease);
      }

      .menu-toggle {
        flex-direction: column;
        gap: 6px;
      }

      .menu-open .menu-toggle span {
        opacity: 0;
      }

      .menu-open .menu-toggle::before {
        transform: translateY(7px) rotate(45deg);
      }

      .menu-open .menu-toggle::after {
        transform: translateY(-7px) rotate(-45deg);
      }

      .mobile-overlay {
        position: fixed;
        inset: 0;
        z-index: 90;
        display: grid;
        align-content: center;
        justify-items: center;
        padding: 100px 28px 42px;
        background: rgba(10, 10, 10, 0.97);
        opacity: 0;
        pointer-events: none;
        transform: translateY(-8px);
        transition: opacity 400ms var(--ease), transform 400ms var(--ease);
      }

      .menu-open .mobile-overlay {
        opacity: 1;
        pointer-events: auto;
        transform: translateY(0);
      }

      .mobile-overlay nav {
        display: grid;
        width: min(420px, 100%);
        gap: 20px;
        text-align: center;
        justify-items: center;
      }

      .mobile-overlay a {
        color: var(--champagne);
        font-family: var(--font-serif);
        font-size: clamp(34px, 11vw, 52px);
        line-height: 1.1;
      }

      .mobile-overlay .btn {
        width: min(310px, 100%);
        margin-top: 18px;
        font-family: var(--font-sans);
        font-size: 11px;
      }

      .view[hidden] {
        display: none;
      }

      .hero {
        position: relative;
        display: grid;
        min-height: 92svh;
        align-items: center;
        text-align: center;
        overflow: hidden;
        padding: calc(var(--nav-height) + 68px) 0 72px;
        background:
          linear-gradient(180deg, rgba(10, 10, 10, 0.60), rgba(10, 10, 10, 0.72)),
          var(--hero-image) center / cover no-repeat,
          var(--obsidian);
      }

      .hero::before {
        content: "";
        position: absolute;
        inset: 0;
        z-index: 1;
        background: linear-gradient(180deg, rgba(10, 10, 10, 0.44), rgba(10, 10, 10, 0.76));
        pointer-events: none;
      }

      .hero::after {
        content: "";
        position: absolute;
        inset: auto 0 0;
        z-index: 3;
        height: 1px;
        background: var(--line);
      }

      .hero-video {
        position: absolute;
        inset: 0;
        z-index: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
        filter: saturate(0.82) brightness(0.84);
      }

      .hero-inner {
        position: relative;
        z-index: 2;
        display: grid;
        justify-items: center;
        width: var(--container);
        margin: 0 auto;
      }

      .hero .lead {
        width: 100%;
        max-width: 610px;
        margin-right: auto;
        margin-left: auto;
      }

      .hero .eyebrow {
        width: 100%;
      }

      .hero .btn-row {
        justify-content: center;
      }

      .scroll-cue {
        position: absolute;
        z-index: 2;
        right: max(28px, calc((100vw - 1120px) / 2));
        bottom: 34px;
        display: flex;
        align-items: center;
        gap: 14px;
        color: var(--bronze);
        font-size: 10px;
        letter-spacing: 2.5px;
        text-transform: uppercase;
      }

      .scroll-cue::before {
        content: "";
        display: block;
        width: 1px;
        height: 58px;
        background: var(--gold);
        transform-origin: top;
        animation: cue 1.8s var(--ease) infinite;
      }

      @keyframes cue {
        0%,
        100% {
          transform: scaleY(0.45);
          opacity: 0.45;
        }

        50% {
          transform: scaleY(1);
          opacity: 1;
        }
      }

      .section-divider-ribbons {
        --ribbon-zone: clamp(82px, 6vw, 106px);
        position: relative;
        z-index: 32;
        height: var(--ribbon-zone);
        margin: calc(var(--ribbon-zone) / -2) 0;
        overflow: hidden;
        pointer-events: none;
      }

      .divider-ribbon {
        position: absolute;
        left: 50%;
        top: 50%;
        width: max(132vw, 1180px);
        border: 1px solid rgba(232, 217, 179, 0.26);
        background:
          linear-gradient(90deg, #9f813d 0%, #c9a961 24%, #f0ddb0 50%, #c9a961 76%, #9f813d 100%);
        box-shadow:
          inset 0 1px 0 rgba(255, 246, 218, 0.12),
          inset 0 -1px 0 rgba(0, 0, 0, 0.38),
          0 18px 42px rgba(0, 0, 0, 0.36);
        color: var(--obsidian);
        overflow: hidden;
        white-space: nowrap;
      }

      .divider-ribbon-back {
        z-index: 1;
        height: 46px;
        background:
          linear-gradient(90deg, #846a32 0%, #ac8e49 24%, #d6bd7f 50%, #ac8e49 76%, #846a32 100%);
        transform: translate(-50%, -52%) rotate(1.6deg);
      }

      .divider-ribbon-front {
        z-index: 2;
        height: 50px;
        transform: translate(-50%, -48%) rotate(-1.15deg);
      }

      .divider-ribbon-track {
        display: flex;
        width: max-content;
        height: 100%;
        animation: ribbon-marquee 28s linear infinite;
      }

      .divider-ribbon-back .divider-ribbon-track {
        animation-name: ribbon-marquee-reverse;
        animation-duration: 34s;
      }

      .divider-ribbon-sequence {
        display: flex;
        flex: 0 0 auto;
        align-items: center;
        height: 100%;
      }

      .divider-ribbon-sequence span {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        padding: 0 clamp(12px, 1.35vw, 20px);
        color: currentColor;
        font-size: 11px;
        font-weight: 600;
        letter-spacing: 2.6px;
        line-height: 1;
        text-transform: uppercase;
      }

      .divider-ribbon-icon {
        flex: 0 0 18px;
        width: 18px;
        height: 18px;
        color: currentColor;
        fill: none;
        stroke: currentColor;
        stroke-width: 1.45;
        stroke-linecap: round;
        stroke-linejoin: round;
      }

      @keyframes ribbon-marquee {
        from {
          transform: translateX(0);
        }

        to {
          transform: translateX(-50%);
        }
      }

      @keyframes ribbon-marquee-reverse {
        from {
          transform: translateX(-50%);
        }

        to {
          transform: translateX(0);
        }
      }

      .memory-section {
        position: relative;
        isolation: isolate;
        overflow: hidden;
        padding: clamp(76px, 8vw, 112px) 0;
        background:
          linear-gradient(180deg, rgba(8, 6, 3, 0.78), rgba(8, 6, 3, 0.9)),
          linear-gradient(115deg, rgba(7, 5, 3, 0.9) 0%, rgba(16, 12, 7, 0.78) 48%, rgba(6, 10, 8, 0.88) 100%),
          url("../img/memory-texture.webp") center / cover no-repeat,
          var(--warm-black);
      }

      .memory-section::before,
      .memory-section::after {
        content: "";
        position: absolute;
        pointer-events: none;
      }

      .memory-section::before {
        inset: 0;
        z-index: 0;
        background:
          radial-gradient(circle at 50% 34%, rgba(201, 169, 97, 0.14), transparent 31%),
          radial-gradient(circle at 12% 82%, rgba(232, 217, 179, 0.07), transparent 26%),
          linear-gradient(90deg, rgba(201, 169, 97, 0.08), transparent 18%, transparent 82%, rgba(232, 217, 179, 0.06)),
          linear-gradient(180deg, rgba(10, 10, 10, 0.06), rgba(10, 10, 10, 0.44));
      }

      .memory-section::after {
        inset: auto 0 0;
        z-index: 1;
        height: 1px;
        background: linear-gradient(90deg, transparent, rgba(201, 169, 97, 0.42), transparent);
      }

      .memory-grain {
        position: absolute;
        inset: 0;
        z-index: 1;
        opacity: 0.2;
        background-image:
          repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.018) 0 1px, transparent 1px 4px),
          repeating-linear-gradient(90deg, rgba(201, 169, 97, 0.012) 0 1px, transparent 1px 6px);
        mix-blend-mode: soft-light;
        pointer-events: none;
      }

      .memory-layout {
        position: relative;
        z-index: 2;
        display: grid;
        place-items: center;
        text-align: center;
      }

      .memory-content {
        position: relative;
        width: min(900px, 100%);
        margin: 0 auto;
      }

      .memory-kicker {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 14px;
        margin: 0 auto 22px;
        color: var(--gold);
        font-size: 10px;
        font-weight: 500;
        letter-spacing: 4px;
        line-height: 1.25;
        text-transform: uppercase;
      }

      .memory-kicker::before {
        content: "";
        flex: 0 1 150px;
        height: 1px;
        background: linear-gradient(90deg, transparent, rgba(201, 169, 97, 0.54));
      }

      .memory-kicker::after {
        content: "";
        flex: 0 1 150px;
        height: 1px;
        background: linear-gradient(90deg, rgba(201, 169, 97, 0.58), transparent);
      }

      .memory-kicker span {
        color: var(--champagne);
        letter-spacing: 3px;
      }

      .memory-title {
        max-width: 680px;
        margin: 0 auto 20px;
        color: var(--champagne);
        font-family: var(--font-serif);
        font-size: clamp(32px, 3.8vw, 50px);
        font-style: italic;
        font-weight: 400;
        line-height: 1.12;
        text-wrap: balance;
      }

      .memory-title span {
        display: block;
        color: rgba(232, 217, 179, 0.9);
      }

      .memory-copy {
        max-width: 700px;
        margin: 0 auto;
        color: rgba(232, 217, 179, 0.72);
        font-size: clamp(14px, 1.25vw, 16px);
        line-height: 1.72;
      }

      .memory-journey {
        position: relative;
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: clamp(18px, 2.4vw, 30px);
        width: min(860px, 100%);
        margin: clamp(42px, 4.4vw, 56px) auto 0;
        padding-top: 28px;
        overflow: visible;
      }

      .memory-journey::before {
        content: "";
        position: absolute;
        top: 125px;
        left: 12%;
        right: 12%;
        z-index: 0;
        height: 1px;
        background:
          linear-gradient(90deg, transparent, rgba(201, 169, 97, 0.28), rgba(232, 217, 179, 0.42), rgba(201, 169, 97, 0.28), transparent);
      }

      .memory-journey article {
        position: relative;
        z-index: 1;
        min-height: 150px;
        padding: 40px 22px 24px;
        border: 1px solid rgba(201, 169, 97, 0.24);
        border-radius: 6px;
        background:
          radial-gradient(circle at 50% 0%, rgba(201, 169, 97, 0.12), transparent 42%),
          linear-gradient(180deg, rgba(20, 15, 9, 0.82), rgba(12, 9, 6, 0.72)),
          rgba(16, 12, 8, 0.78);
        box-shadow:
          inset 0 1px 0 rgba(255, 246, 218, 0.04),
          0 16px 38px rgba(0, 0, 0, 0.16);
      }

      .memory-journey article:nth-child(2) {
        transform: translateY(22px);
      }

      .memory-journey article::before {
        content: "";
        position: absolute;
        inset: 12px 14px auto;
        height: 1px;
        background: linear-gradient(90deg, transparent, rgba(201, 169, 97, 0.24), transparent);
      }

      .memory-journey article::after {
        content: "I";
        position: absolute;
        right: 12px;
        bottom: -12px;
        z-index: 0;
        color: rgba(201, 169, 97, 0.055);
        font-family: var(--font-serif);
        font-size: 76px;
        font-weight: 700;
        line-height: 1;
        pointer-events: none;
      }

      .memory-journey article:nth-child(2)::after {
        content: "II";
      }

      .memory-journey article:nth-child(3)::after {
        content: "III";
      }

      .memory-journey span {
        position: absolute;
        top: -28px;
        left: 50%;
        display: grid;
        width: 56px;
        height: 56px;
        place-items: center;
        margin: 0;
        border: 1px solid rgba(201, 169, 97, 0.42);
        border-radius: 50%;
        background:
          radial-gradient(circle, rgba(201, 169, 97, 0.18), rgba(12, 9, 6, 0.94) 68%);
        color: rgba(201, 169, 97, 0.72);
        font-family: var(--font-serif);
        font-size: 20px;
        line-height: 1;
        transform: translateX(-50%);
        box-shadow: 0 0 0 8px rgba(10, 8, 5, 0.58);
      }

      .memory-journey h3,
      .memory-journey p {
        position: relative;
        z-index: 1;
      }

      .memory-journey h3 {
        margin: 0 0 10px;
        color: var(--gold);
        font-family: var(--font-sans);
        font-size: 10px;
        font-weight: 500;
        letter-spacing: 3px;
        line-height: 1.35;
        text-transform: uppercase;
      }

      .memory-journey p {
        max-width: 230px;
        margin: 0 auto;
        color: rgba(232, 217, 179, 0.7);
        font-size: 13px;
        line-height: 1.55;
      }

      .quote-block {
        max-width: 880px;
        margin: 0 auto;
        text-align: center;
      }

      .manifesto-quote {
        color: var(--champagne);
        font-family: var(--font-serif);
        font-size: clamp(30px, 5vw, 58px);
        font-style: italic;
        line-height: 1.25;
      }

      .manifesto-copy {
        max-width: 760px;
        margin: 28px auto 0;
        color: var(--muted);
        font-size: clamp(17px, 2vw, 19px);
      }

      .section-head {
        display: grid;
        grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.75fr);
        gap: 48px;
        align-items: end;
        margin-bottom: 52px;
      }

      .section-head.center {
        display: block;
        max-width: 760px;
        margin-inline: auto;
        text-align: center;
      }

.grid {
        display: grid;
        gap: 24px;
      }

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

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

      .service-card,
      .value-card,
      .pillar,
      .testimonial,
      .portfolio-card,
      .service-pane {
        border: 1px solid var(--line);
        border-radius: 6px;
        background-color: rgba(26, 22, 18, 0.42);
        transition: border-color 600ms var(--ease), background-color 600ms var(--ease);
      }

      .service-card,
      .value-card,
      .pillar,
      .service-pane {
        padding: clamp(24px, 3vw, 34px);
      }

      .pillar {
        position: relative;
        border: none;
      }

      .pillar::before {
        content: '';
        position: absolute;
        inset: 0;
        padding: 1px;
        border-radius: 6px;
        background: linear-gradient(to right, rgba(201, 169, 97, 0.65) 0%, rgba(201, 169, 97, 0) 80%);
        -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
        -webkit-mask-composite: xor;
        mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
        mask-composite: exclude;
        pointer-events: none;
      }

      .service-card:hover,
      .value-card:hover,
      .pillar:hover,
      .portfolio-card:hover,
      .service-pane:hover {
        border-color: var(--line-strong);
        background-color: rgba(26, 22, 18, 0.62);
      }

      .card-icon {
        width: 54px;
        height: 54px;
        margin-bottom: 26px;
        color: var(--gold);
      }

      .card-icon,
      .pillar-icon,
      .service-pane-icon {
        transform-origin: center;
        animation: icon-breathe 4s var(--ease) infinite;
      }

      .service-card:hover .card-icon,
      .pillar:hover .pillar-icon,
      .service-pane:hover .service-pane-icon {
        transform: translateY(-3px) scale(1.04);
      }

      .service-card p,
      .value-card p,
      .pillar p,
      .service-pane p {
        color: var(--muted);
      }

      .service-card {
        overflow: hidden;
        padding: 0;
        position: relative;
        background-color: rgb(12, 9, 7);
        color: inherit;
        cursor: pointer;
        text-decoration: none;
      }

      .card-media {
        position: relative;
        height: clamp(280px, 24vw, 340px);
        overflow: hidden;
      }

      .card-media img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center top;
        display: block;
      }

      .card-media::after {
        content: '';
        position: absolute;
        inset: 0;
        background: linear-gradient(
          to bottom,
          rgba(12, 9, 7, 0) 44%,
          rgba(12, 9, 7, 0.42) 76%,
          rgba(12, 9, 7, 1) 100%
        );
        pointer-events: none;
      }

      @keyframes card-shine {
        0%, 55%  { transform: translateX(-160%) skewX(-18deg); }
        100%     { transform: translateX(380%) skewX(-18deg); }
      }

      @keyframes services-mobile-card-cycle {
        0%,
        27%,
        100% {
          z-index: 3;
          opacity: 1;
          filter: brightness(1) saturate(1);
          transform: translateX(-50%) translateY(0) scale(1) rotateY(0deg);
        }

        33%,
        60% {
          z-index: 1;
          opacity: 0.6;
          filter: brightness(0.62) saturate(0.82);
          transform: translateX(calc(-50% + min(68vw, 270px))) translateY(24px) scale(0.82) rotateY(-10deg);
        }

        66%,
        93% {
          z-index: 1;
          opacity: 0.6;
          filter: brightness(0.62) saturate(0.82);
          transform: translateX(calc(-50% - min(68vw, 270px))) translateY(24px) scale(0.82) rotateY(10deg);
        }
      }

      .service-card::after {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        width: 70%;
        height: 100%;
        background: linear-gradient(
          to right,
          transparent 0%,
          rgba(255, 255, 255, 0.05) 28%,
          rgba(255, 253, 235, 0.145) 48%,
          rgba(255, 255, 255, 0.22) 50%,
          rgba(255, 253, 235, 0.145) 52%,
          rgba(255, 255, 255, 0.05) 72%,
          transparent 100%
        );
        animation: card-shine 16s ease-in-out infinite;
        filter: blur(0.8px);
        opacity: 0.48;
        pointer-events: none;
        z-index: 2;
      }

      .card-body {
        padding: clamp(24px, 3vw, 34px);
        position: relative;
        z-index: 1;
      }

      .roman {
        margin-bottom: 24px;
        color: var(--gold);
        font-family: var(--font-serif);
        font-size: clamp(46px, 6vw, 72px);
        line-height: 1;
      }

      .pillar-icon,
      .service-pane-icon {
        display: block;
        width: 58px;
        height: 58px;
        margin-bottom: 24px;
      }

      @keyframes icon-breathe {
        0%,
        82%,
        100% {
          opacity: 0.86;
          transform: translateY(0) scale(1);
        }

        8% {
          opacity: 1;
          transform: translateY(-3px) scale(1.04);
        }

        16% {
          opacity: 0.94;
          transform: translateY(0) scale(1);
        }
      }

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

      .portfolio-card {
        position: relative;
        overflow: hidden;
        min-height: 260px;
        cursor: pointer;
      }

      .portfolio-card img {
        width: 100%;
        height: 100%;
        min-height: 260px;
        object-fit: cover;
        filter: saturate(0.78) brightness(0.72);
        transform: scale(1.01);
        transition: transform 900ms var(--ease), filter 900ms var(--ease);
      }

      .portfolio-card:hover img {
        filter: saturate(0.9) brightness(0.48);
        transform: scale(1.05);
      }

      .portfolio-overlay {
        position: absolute;
        inset: auto 0 0;
        padding: 26px;
        background: linear-gradient(0deg, rgba(10, 10, 10, 0.9), rgba(10, 10, 10, 0));
        color: var(--champagne);
        transform: translateY(12px);
        opacity: 0;
        transition: opacity 500ms var(--ease), transform 500ms var(--ease);
      }

      .portfolio-card:hover .portfolio-overlay,
      .portfolio-card:focus-within .portfolio-overlay {
        transform: translateY(0);
        opacity: 1;
      }

      .portfolio-overlay strong {
        display: block;
        font-family: var(--font-serif);
        font-size: 24px;
        font-weight: 400;
        line-height: 1.2;
      }

      .portfolio-overlay span {
        color: var(--gold);
        font-size: 11px;
        letter-spacing: 2.8px;
        text-transform: uppercase;
      }

      @keyframes portfolio-album-marquee {
        from {
          transform: translateX(0);
        }

        to {
          transform: translateX(-50%);
        }
      }

      .portfolio-albums-section {
        overflow: hidden;
      }

      .portfolio-albums-section .section-head {
        margin-bottom: clamp(38px, 4vw, 56px);
      }

      .portfolio-album-viewport {
        position: relative;
        width: 100vw;
        margin: 0 calc(50% - 50vw);
        overflow: hidden;
      }

      .portfolio-album-viewport::before,
      .portfolio-album-viewport::after {
        content: "";
        position: absolute;
        top: -1px;
        bottom: -1px;
        z-index: 4;
        width: clamp(44px, 10vw, 160px);
        pointer-events: none;
      }

      .portfolio-album-viewport::before {
        left: 0;
        background:
          linear-gradient(90deg, var(--obsidian), rgba(10, 10, 10, 0.82) 32%, transparent);
      }

      .portfolio-album-viewport::after {
        right: 0;
        background:
          linear-gradient(270deg, var(--obsidian), rgba(10, 10, 10, 0.82) 32%, transparent);
      }

      .portfolio-album-track {
        display: flex;
        width: max-content;
        animation: portfolio-album-marquee 34s linear infinite;
      }

      .portfolio-album-sequence {
        display: flex;
        flex: 0 0 auto;
        gap: clamp(16px, 1.7vw, 26px);
        padding: 4px clamp(8px, 1vw, 14px) 22px;
      }

      .portfolio-albums-section .album-cover {
        position: relative;
        width: clamp(250px, 23vw, 360px);
        min-height: 0;
        aspect-ratio: 0.72;
        border-color: rgba(201, 169, 97, 0.34);
        border-radius: 8px;
        background:
          linear-gradient(180deg, rgba(28, 21, 13, 0.88), rgba(8, 6, 4, 0.96));
        box-shadow:
          inset 0 1px 0 rgba(255, 246, 218, 0.08),
          0 22px 54px rgba(0, 0, 0, 0.28);
        transform: translateZ(0);
      }

      .portfolio-albums-section .album-cover::before {
        content: "";
        position: absolute;
        inset: 10px;
        z-index: 2;
        border: 1px solid rgba(201, 169, 97, 0.18);
        border-radius: 5px;
        background:
          linear-gradient(135deg, rgba(240, 216, 120, 0.12), transparent 34%),
          linear-gradient(315deg, rgba(201, 169, 97, 0.1), transparent 38%);
        pointer-events: none;
      }

      .portfolio-albums-section .album-cover img {
        width: 100%;
        height: 100%;
        min-height: 0;
        object-fit: cover;
        filter: saturate(0.82) brightness(0.66);
        transform: scale(1.02);
        transition: transform 900ms var(--ease), filter 900ms var(--ease);
      }

      .portfolio-albums-section .album-cover:hover img,
      .portfolio-albums-section .album-cover:focus-visible img {
        filter: saturate(0.98) brightness(0.82);
        transform: scale(1.07);
      }

      .portfolio-albums-section .portfolio-overlay {
        inset: 0;
        z-index: 3;
        display: grid;
        align-content: end;
        justify-items: start;
        padding: 24px;
        background:
          linear-gradient(180deg, rgba(8, 6, 4, 0.12), transparent 34%),
          linear-gradient(0deg, rgba(8, 6, 4, 0.94), rgba(8, 6, 4, 0.05) 66%);
        opacity: 1;
        text-align: left;
        transform: none;
        pointer-events: none;
      }

      .portfolio-albums-section .portfolio-overlay strong {
        display: block;
        max-width: 11ch;
        color: var(--champagne);
        font-size: clamp(24px, 2.2vw, 36px);
        font-style: italic;
        line-height: 0.98;
        text-align: left;
        text-shadow: 0 8px 24px rgba(0, 0, 0, 0.62);
      }

      .portfolio-albums-section .portfolio-overlay > span:last-child {
        display: block;
        width: 100%;
        margin-top: 12px;
        text-align: left;
      }

      .album-hint {
        position: absolute;
        top: 22px;
        left: 22px;
        display: inline-flex;
        width: fit-content;
        max-width: calc(100% - 44px);
        align-items: center;
        justify-self: start;
        gap: 10px;
        color: rgba(232, 217, 179, 0.78);
        font-size: 9px;
        font-weight: 500;
        letter-spacing: 2.2px;
        line-height: 1.35;
        text-transform: uppercase;
      }

      .album-hint::before {
        content: "";
        width: 8px;
        height: 8px;
        border: 1px solid rgba(201, 169, 97, 0.72);
        transform: rotate(45deg);
      }

      .testimonial-shell {
        position: relative;
        max-width: 860px;
        margin: 0 auto;
      }

      .testimonial {
        display: none;
        padding: clamp(34px, 5vw, 58px);
        text-align: center;
      }

      .testimonial.is-active {
        display: block;
      }

      .testimonial blockquote {
        margin: 0;
        color: var(--champagne);
        font-family: var(--font-serif);
        font-size: clamp(24px, 3vw, 34px);
        font-style: italic;
        line-height: 1.5;
      }

      .testimonial cite {
        display: block;
        margin-top: 28px;
        color: var(--gold);
        font-style: normal;
        font-size: 11px;
        letter-spacing: 3px;
        text-transform: uppercase;
      }

      .testimonial-controls {
        display: flex;
        justify-content: center;
        gap: 12px;
        margin-top: 24px;
      }

      .google-reviews-section {
        position: relative;
        overflow: hidden;
        background:
          radial-gradient(circle at 50% 0%, rgba(201, 169, 97, 0.11), transparent 34%),
          linear-gradient(180deg, rgba(16, 12, 6, 0.96), rgba(6, 5, 4, 0.98));
      }

      .google-reviews-section::before {
        content: "";
        position: absolute;
        inset: 0;
        background:
          linear-gradient(90deg, rgba(201, 169, 97, 0.08), transparent 18%, transparent 82%, rgba(201, 169, 97, 0.08)),
          linear-gradient(135deg, transparent 0 48%, rgba(201, 169, 97, 0.04) 49%, transparent 50% 100%);
        background-size: auto, 38px 38px;
        opacity: 0.62;
        pointer-events: none;
      }

      .google-reviews-section .container {
        position: relative;
        z-index: 1;
      }

      .google-reviews-head {
        max-width: 760px;
        margin: 0 auto;
        text-align: center;
      }

      .google-reviews-title {
        margin-bottom: 18px;
        background: none;
        color: var(--champagne);
        -webkit-text-fill-color: currentColor;
      }

      .google-reviews-title span {
        color: var(--gold);
        -webkit-text-fill-color: var(--gold);
      }

      .google-rating {
        display: grid;
        justify-items: center;
        gap: 4px;
        margin-top: 14px;
      }

      .google-rating strong {
        display: block;
        background: linear-gradient(105deg, #f5e08a, #c9a961 54%, #8f6b2a);
        background-clip: text;
        color: transparent;
        font-family: var(--font-serif);
        font-size: clamp(58px, 7vw, 86px);
        line-height: 0.94;
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
      }

      .google-stars,
      .review-stars {
        display: inline-flex;
        color: var(--gold);
        font-size: 15px;
        letter-spacing: 5px;
        line-height: 1;
        text-shadow: 0 0 16px rgba(201, 169, 97, 0.16);
      }

      .google-rating p {
        margin: 8px 0 0;
        color: var(--bronze);
        font-size: 12px;
        letter-spacing: 2.4px;
        line-height: 1.5;
        text-transform: uppercase;
      }

      .google-review-carousel {
        --review-card-width: min(32vw, 360px);
        --review-side-shift: min(31vw, 384px);
        position: relative;
        margin-top: clamp(44px, 6vw, 64px);
        overflow: hidden;
        touch-action: pan-y;
      }

      .google-review-stage {
        position: relative;
        height: clamp(260px, 20vw, 286px);
        perspective: 1100px;
        isolation: isolate;
      }

      .google-review-card {
        position: absolute;
        top: 0;
        left: 50%;
        display: flex;
        width: var(--review-card-width);
        height: 100%;
        min-height: 0;
        flex-direction: column;
        overflow: hidden;
        border: 1px solid rgba(201, 169, 97, 0.18);
        border-radius: 6px;
        background:
          linear-gradient(112deg, rgba(255, 255, 255, 0.035), transparent 18%, transparent 78%, rgba(201, 169, 97, 0.055)),
          rgba(15, 13, 11, 0.84);
        box-shadow: 0 16px 54px rgba(0, 0, 0, 0.24);
        filter: brightness(0.64) saturate(0.86);
        opacity: 0;
        padding: clamp(22px, 2.4vw, 28px);
        pointer-events: none;
        transform: translateX(-50%) translateY(28px) scale(0.78);
        transform-origin: center;
        transition:
          opacity 680ms var(--ease),
          filter 760ms var(--ease),
          border-color 760ms var(--ease),
          background-color 760ms var(--ease),
          box-shadow 760ms var(--ease),
          transform 900ms cubic-bezier(0.22, 1, 0.36, 1);
        will-change: opacity, filter, transform;
      }

      .google-review-card.is-prev,
      .google-review-card.is-next {
        z-index: 1;
        filter: brightness(0.76) saturate(0.9);
        opacity: 0.78;
      }

      .google-review-card.is-prev {
        transform: translateX(calc(-50% - var(--review-side-shift) + var(--review-drag-soft, 0px))) translateY(18px) scale(0.9) rotateY(7deg);
      }

      .google-review-card.is-next {
        transform: translateX(calc(-50% + var(--review-side-shift) + var(--review-drag-soft, 0px))) translateY(18px) scale(0.9) rotateY(-7deg);
      }

      .google-review-card.is-active {
        z-index: 3;
        border-color: rgba(201, 169, 97, 0.62);
        background:
          linear-gradient(112deg, rgba(255, 255, 255, 0.06), transparent 18%, transparent 72%, rgba(201, 169, 97, 0.13)),
          rgba(18, 15, 11, 0.96);
        box-shadow:
          0 24px 84px rgba(0, 0, 0, 0.4),
          0 0 34px rgba(201, 169, 97, 0.13);
        filter: brightness(1.04) saturate(1.04);
        opacity: 1;
        pointer-events: auto;
        transform: translateX(calc(-50% + var(--review-drag, 0px))) translateY(0) scale(1);
      }

      .google-review-carousel.is-dragging .google-review-card {
        transition-duration: 0ms;
      }

      .google-review-card::before {
        content: "";
        position: absolute;
        inset: 0;
        border-radius: inherit;
        background:
          linear-gradient(90deg, rgba(201, 169, 97, 0.18), transparent 22%, transparent 78%, rgba(201, 169, 97, 0.12)),
          radial-gradient(circle at 50% 0%, rgba(248, 226, 151, 0.16), transparent 42%);
        opacity: 0;
        pointer-events: none;
        transition: opacity 520ms var(--ease);
      }

      .google-review-card::after {
        content: "";
        position: absolute;
        top: -40%;
        bottom: -40%;
        left: -54%;
        width: 36%;
        background: linear-gradient(104deg, transparent, rgba(255, 246, 218, 0.17) 48%, transparent 100%);
        opacity: 0;
        pointer-events: none;
        transform: skewX(-18deg);
      }

      .google-review-card.is-active::after {
        animation: google-review-center-sheen 3.5s ease-in-out infinite;
      }

      .google-review-card.is-active::before,
      .google-review-card:hover::before {
        opacity: 1;
      }

      .google-review-card:hover {
        border-color: rgba(201, 169, 97, 0.48);
        background-color: rgba(20, 17, 13, 0.92);
      }

      @keyframes google-review-center-sheen {
        0%, 48% {
          opacity: 0;
          transform: skewX(-18deg) translateX(0);
        }

        62% {
          opacity: 0.58;
        }

        100% {
          opacity: 0;
          transform: skewX(-18deg) translateX(520%);
        }
      }

      .google-review-top {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr) auto;
        gap: 14px;
        align-items: center;
        margin-bottom: 18px;
      }

      .review-avatar {
        display: inline-grid;
        width: 46px;
        height: 46px;
        place-items: center;
        border: 1px solid rgba(201, 169, 97, 0.48);
        border-radius: 50%;
        background:
          radial-gradient(circle at 32% 22%, rgba(248, 226, 151, 0.88), rgba(201, 169, 97, 0.84) 42%, rgba(86, 62, 24, 0.92));
        color: var(--obsidian);
        font-size: 14px;
        font-weight: 700;
        letter-spacing: 0;
      }

      .google-review-card h3 {
        margin: 0 0 2px;
        background: none;
        color: var(--champagne);
        font-family: var(--font-sans);
        font-size: 16px;
        font-weight: 600;
        line-height: 1.3;
        -webkit-text-fill-color: currentColor;
      }

      .google-review-card .google-review-top p {
        margin: 0;
        color: var(--bronze);
        font-size: 11px;
        letter-spacing: 0.4px;
        line-height: 1.45;
      }

      .google-mark {
        display: inline-grid;
        width: 24px;
        height: 24px;
        place-items: center;
        background: none;
        background-clip: text;
        color: var(--champagne);
        font-family: Arial, sans-serif;
        font-size: 21px;
        font-weight: 800;
        letter-spacing: 0;
        line-height: 1;
        -webkit-background-clip: text;
        -webkit-text-fill-color: currentColor;
      }

      .google-review-card > p {
        position: relative;
        margin: 14px 0 0;
        color: var(--muted);
        font-size: 14.5px;
        line-height: 1.62;
      }

      .google-reviews-action {
        display: flex;
        justify-content: center;
        margin-top: 20px;
      }

      .google-mark-inline {
        flex: 0 0 19px;
        width: 19px;
        height: 19px;
        font-size: 17px;
      }

      .icon-btn {
        display: inline-grid;
        width: 42px;
        height: 42px;
        place-items: center;
        border: 1px solid var(--line);
        border-radius: 50%;
        background: transparent;
        color: var(--gold);
        cursor: pointer;
        transition: border-color 500ms var(--ease), color 500ms var(--ease);
      }

      .icon-btn:hover {
        border-color: var(--gold);
        color: var(--champagne);
      }

      .cta-band {
        text-align: center;
      }

      .cta-band .lead {
        margin-inline: auto;
      }

      .page-hero {
        padding: calc(var(--nav-height) + 78px) 0 72px;
        background: var(--obsidian);
        border-bottom: 1px solid var(--line);
      }

      .page-hero.media {
        position: relative;
        min-height: 70svh;
        display: grid;
        align-items: end;
        overflow: hidden;
        background:
          linear-gradient(90deg, rgba(10, 10, 10, 0.9), rgba(10, 10, 10, 0.52)),
          var(--page-image) center / cover no-repeat,
          var(--obsidian);
      }

      .two-col {
        display: grid;
        grid-template-columns: minmax(0, 0.92fr) minmax(320px, 1fr);
        gap: clamp(38px, 6vw, 78px);
        align-items: center;
      }

      .editorial-image {
        overflow: hidden;
        border: 1px solid var(--line);
        border-radius: 6px;
        background: var(--carbon);
      }

      .editorial-image img {
        width: 100%;
        aspect-ratio: 4 / 5;
        object-fit: cover;
        filter: saturate(0.78) brightness(0.68);
      }

      .stats-row {
        display: grid;
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 1px;
        border: 1px solid var(--line);
        background: var(--line);
      }

      .stat {
        padding: clamp(24px, 4vw, 40px);
        background: var(--obsidian);
        text-align: center;
      }

      .stat strong {
        display: block;
        color: var(--champagne);
        font-family: var(--font-serif);
        font-size: clamp(34px, 5vw, 58px);
        font-weight: 400;
        line-height: 1.05;
      }

      .stat span {
        display: block;
        margin-top: 10px;
        color: var(--bronze);
        font-size: 11px;
        letter-spacing: 3px;
        text-transform: uppercase;
      }

      .service-hub {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 24px;
      }

      .service-pane {
        display: flex;
        min-height: 430px;
        flex-direction: column;
        color: inherit;
        cursor: pointer;
        text-decoration: none;
      }

      .service-pane .link-arrow {
        margin-top: auto;
      }

      .block-list {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 16px;
        margin: 38px 0 0;
        padding: 0;
        list-style: none;
      }

      .block-list li {
        border: 1px solid var(--line);
        border-radius: 6px;
        background: rgba(26, 22, 18, 0.4);
        color: var(--muted);
        padding: 20px;
      }

      .filter-bar {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        margin: 0 0 34px;
      }

      .filter-btn {
        border: 1px solid var(--line);
        border-radius: 999px;
        background: transparent;
        color: var(--muted);
        cursor: pointer;
        font-size: 11px;
        letter-spacing: 2.4px;
        padding: 10px 16px;
        text-transform: uppercase;
        transition: border-color 400ms var(--ease), color 400ms var(--ease);
      }

      .filter-btn:hover,
      .filter-btn.is-active {
        border-color: var(--gold);
        color: var(--champagne);
      }

      .faq-category {
        display: grid;
        grid-template-columns: minmax(180px, 0.35fr) minmax(0, 1fr);
        gap: 40px;
        border-top: 1px solid var(--line);
        padding: 42px 0;
      }

      .faq-category h2 {
        margin: 0;
        font-size: clamp(25px, 3vw, 34px);
      }

      .accordion {
        display: grid;
        gap: 12px;
      }

      .faq-item {
        border: 1px solid var(--line);
        border-radius: 6px;
        overflow: hidden;
        background: rgba(26, 22, 18, 0.34);
      }

      .faq-question {
        display: flex;
        width: 100%;
        min-height: 68px;
        align-items: center;
        justify-content: space-between;
        gap: 24px;
        border: 0;
        background: transparent;
        color: var(--champagne);
        cursor: pointer;
        padding: 20px 22px;
        text-align: left;
      }

      .faq-question span:first-child {
        font-family: var(--font-serif);
        font-size: 21px;
        line-height: 1.35;
      }

      .faq-question span:last-child {
        display: grid;
        flex: 0 0 28px;
        width: 28px;
        height: 28px;
        place-items: center;
        border: 1px solid var(--line);
        border-radius: 50%;
        color: var(--gold);
      }

      .faq-answer {
        display: none;
        padding: 0 22px 22px;
        color: var(--muted);
      }

      .faq-item.is-open .faq-answer {
        display: block;
      }

      .faq-item.is-open .faq-question span:last-child {
        border-color: var(--gold);
      }

      .form-grid {
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(290px, 0.42fr);
        gap: clamp(32px, 6vw, 72px);
        align-items: start;
      }

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

      .field {
        display: grid;
        gap: 8px;
      }

      .field.full {
        grid-column: 1 / -1;
      }

      label {
        color: var(--gold);
        font-size: 11px;
        letter-spacing: 2.5px;
        text-transform: uppercase;
      }

      input,
      select,
      textarea {
        width: 100%;
        border: 1px solid var(--line);
        border-radius: 4px;
        background: rgba(10, 10, 10, 0.45);
        color: var(--champagne);
        min-height: 50px;
        padding: 13px 14px;
        transition: border-color 300ms var(--ease), background-color 300ms var(--ease);
      }

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

      input:focus,
      select:focus,
      textarea:focus {
        border-color: var(--gold);
        background: rgba(10, 10, 10, 0.7);
      }

      .error {
        min-height: 18px;
        color: var(--error);
        font-size: 12px;
        line-height: 1.4;
      }

      .honeypot {
        position: absolute;
        left: -9999px;
      }

      .side-info {
        border-left: 1px solid var(--line);
        padding-left: 32px;
      }

      .side-info ul {
        display: grid;
        gap: 14px;
        margin: 0;
        padding: 0;
        list-style: none;
      }

      .side-info li {
        color: var(--muted);
      }

      .success-state {
        display: none;
        border: 1px solid var(--line-strong);
        border-radius: 6px;
        padding: 36px;
      }

      .success-state.is-visible {
        display: block;
      }

      .legal-content {
        max-width: 860px;
      }

      .legal-block {
        border-top: 1px solid var(--line);
        padding: 34px 0 10px;
      }

      .legal-block h2 {
        font-size: clamp(24px, 3vw, 32px);
      }

      .site-footer {
        border-top: 1px solid var(--line);
        background: var(--warm-black);
        padding: 72px 0 28px;
      }

      .footer-grid {
        display: grid;
        grid-template-columns: 1.1fr 0.7fr 1fr;
        gap: 52px;
      }

      .footer-title {
        margin-bottom: 18px;
        color: var(--champagne);
        font-family: var(--font-serif);
        font-size: 24px;
      }

      .footer-links {
        display: grid;
        gap: 10px;
        margin: 0;
        padding: 0;
        list-style: none;
      }

      .footer-links a,
      .footer-links button {
        border: 0;
        background: transparent;
        color: var(--muted);
        cursor: pointer;
        padding: 0;
        text-align: left;
        transition: color 300ms var(--ease);
      }

      .footer-links a:hover,
      .footer-links button:hover {
        color: var(--champagne);
      }

      .footer-bottom {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        gap: 16px;
        margin-top: 58px;
        border-top: 1px solid var(--line);
        padding-top: 24px;
        color: var(--whisper);
        font-size: 13px;
      }

      .footer-bottom nav {
        display: flex;
        flex-wrap: wrap;
        gap: 18px;
      }

      .whatsapp-float {
        position: fixed;
        right: 22px;
        bottom: 22px;
        z-index: 80;
        display: grid;
        width: 56px;
        height: 56px;
        place-items: center;
        border: 1px solid var(--gold);
        border-radius: 50%;
        background: rgba(10, 10, 10, 0.88);
        color: var(--gold);
        backdrop-filter: blur(10px);
      }

      .float-icon {
        width: 31px;
        height: 31px;
      }

      .whatsapp-float::before {
        content: "Reserve sua data";
        position: absolute;
        right: calc(100% + 12px);
        top: 50%;
        width: max-content;
        max-width: 180px;
        transform: translateY(-50%) translateX(8px);
        border: 1px solid var(--line);
        background: var(--obsidian);
        color: var(--champagne);
        font-size: 12px;
        opacity: 0;
        padding: 8px 10px;
        pointer-events: none;
        transition: opacity 300ms var(--ease), transform 300ms var(--ease);
      }

      .whatsapp-float:hover::before {
        opacity: 1;
        transform: translateY(-50%) translateX(0);
      }

      .cookie-banner {
        position: fixed;
        right: 0;
        bottom: 0;
        left: 0;
        z-index: 160;
        border-top: 0.5px solid var(--gold);
        background: rgba(10, 10, 10, 0.96);
        backdrop-filter: blur(12px);
        padding: 20px 0;
      }

      .cookie-banner[hidden] {
        display: none;
      }

      .cookie-inner {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 24px;
        align-items: center;
        width: var(--wide);
        margin: 0 auto;
      }

      .cookie-inner h2 {
        margin-bottom: 4px;
        font-size: 24px;
      }

      .cookie-inner p {
        margin: 0;
        color: var(--muted);
        font-size: 14px;
        line-height: 1.6;
      }

      .cookie-actions {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        justify-content: flex-end;
      }

      .cookie-options {
        display: none;
        grid-column: 1 / -1;
        border-top: 1px solid var(--line);
        padding-top: 16px;
      }

      .cookie-options.is-visible {
        display: grid;
        gap: 12px;
      }

      .toggle-row {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 20px;
        color: var(--muted);
      }

      .toggle-row input {
        width: 20px;
        min-height: 20px;
        accent-color: var(--gold);
      }

      .lightbox {
        position: fixed;
        inset: 0;
        z-index: 180;
        display: none;
        align-items: center;
        justify-content: center;
        padding: 24px;
        background: rgba(5, 4, 3, 0.78);
        backdrop-filter: blur(16px);
      }

      .lightbox.is-visible {
        display: flex;
      }

      @keyframes album-popup-enter {
        from {
          opacity: 0;
          transform: translateY(22px) scale(0.94);
        }

        to {
          opacity: 1;
          transform: translateY(0) scale(1);
        }
      }

      .lightbox-panel {
        position: relative;
        width: min(980px, 100%);
        border: 1px solid var(--line);
        border-radius: 8px;
        background:
          radial-gradient(circle at 50% 0%, rgba(201, 169, 97, 0.12), transparent 38%),
          rgba(12, 9, 6, 0.94);
        box-shadow: 0 32px 90px rgba(0, 0, 0, 0.56);
        overflow: hidden;
      }

      .lightbox.is-visible .lightbox-panel {
        animation: album-popup-enter 520ms var(--ease) both;
      }

      .lightbox-panel > img {
        width: 100%;
        height: auto;
        max-height: min(70svh, 720px);
        object-fit: cover;
        border-radius: 8px 8px 0 0;
      }

      .album-lightbox-stage img {
        width: 100%;
        height: 100%;
        max-height: none;
        object-fit: cover;
        border-radius: inherit;
      }

      .album-lightbox-stage {
        --album-drag: 0px;
        --album-drag-soft: 0px;
        position: relative;
        height: min(62svh, 620px);
        min-height: 360px;
        overflow: hidden;
        border-bottom: 1px solid rgba(201, 169, 97, 0.18);
        background:
          radial-gradient(circle at 50% 45%, rgba(201, 169, 97, 0.1), transparent 38%),
          rgba(8, 6, 4, 0.94);
        perspective: 900px;
        touch-action: pan-y;
      }

      .album-lightbox-slide {
        position: absolute;
        top: 26px;
        bottom: 26px;
        left: 50%;
        width: min(58vw, 420px);
        margin: 0;
        overflow: hidden;
        border: 1px solid rgba(201, 169, 97, 0.28);
        border-radius: 8px;
        opacity: 0;
        filter: brightness(0.56) saturate(0.78);
        transform: translateX(-50%) translateY(18px) scale(0.72);
        transition:
          transform 720ms cubic-bezier(0.22, 1, 0.36, 1),
          opacity 520ms var(--ease),
          filter 520ms var(--ease);
        will-change: transform, opacity, filter;
      }

      .album-lightbox-slide.is-active {
        z-index: 3;
        opacity: 1;
        filter: brightness(1) saturate(0.96);
        transform: translateX(calc(-50% + var(--album-drag))) translateY(0) scale(1);
      }

      .album-lightbox-slide.is-next {
        z-index: 1;
        opacity: 0.46;
        transform: translateX(calc(-50% + min(44vw, 360px) + var(--album-drag-soft))) translateY(24px) scale(0.78) rotateY(-10deg);
      }

      .album-lightbox-slide.is-prev {
        z-index: 1;
        opacity: 0.46;
        transform: translateX(calc(-50% - min(44vw, 360px) + var(--album-drag-soft))) translateY(24px) scale(0.78) rotateY(10deg);
      }

      .album-lightbox-stage.is-dragging .album-lightbox-slide {
        transition-duration: 0ms;
      }

      .album-lightbox-stage::before,
      .album-lightbox-stage::after {
        content: "";
        position: absolute;
        top: 0;
        bottom: 0;
        z-index: 4;
        width: min(16vw, 130px);
        pointer-events: none;
      }

      .album-lightbox-stage::before {
        left: 0;
        background: linear-gradient(90deg, rgba(8, 6, 4, 0.96), transparent);
      }

      .album-lightbox-stage::after {
        right: 0;
        background: linear-gradient(270deg, rgba(8, 6, 4, 0.96), transparent);
      }

      .album-lightbox-nav {
        position: absolute;
        top: calc(50% - 36px);
        z-index: 8;
        border-radius: 50%;
        background: rgba(8, 6, 4, 0.82);
        font-size: 30px;
        line-height: 1;
      }

      .album-lightbox-prev {
        left: 18px;
      }

      .album-lightbox-next {
        right: 18px;
      }

      .lightbox-copy {
        display: grid;
        gap: 8px;
        padding: 22px 26px 24px;
        text-align: center;
      }

      .lightbox-copy h2 {
        margin-bottom: 0;
        font-size: clamp(26px, 3vw, 36px);
        line-height: 1.08;
      }

      .lightbox-copy p {
        max-width: 620px;
        margin: 0 auto;
        color: var(--muted);
      }

      .lightbox-close {
        position: absolute;
        top: 14px;
        right: 14px;
        z-index: 10;
        background: rgba(10, 10, 10, 0.82);
      }

      .js [data-reveal] {
        opacity: 0;
        transform: translateY(20px);
        transition: opacity 700ms var(--ease), transform 700ms var(--ease);
      }

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

      @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;
        }

        .btn.filled::after {
          display: none;
        }

        .js [data-reveal].is-visible .link-arrow-icon {
          animation: none;
        }

        .divider-ribbon-track {
          animation: none;
          transform: translateX(0);
        }

        .portfolio-album-track {
          animation: none;
        }

        .portfolio-album-sequence[aria-hidden="true"] {
          display: none;
        }

        .js [data-reveal] {
          opacity: 1;
          transform: none;
        }

        .loader-logo {
          animation: none;
          filter: none;
          opacity: 1;
        }

        .floating-scrollbar {
          transition: none;
        }
      }

      /* ─── Small desktop (15" laptops, 981–1440 px) ─────────────────────── */
      @media (min-width: 981px) and (max-width: 1440px) {
        :root {
          --nav-height: clamp(72px, 6vw, 92px);
        }

        body {
          font-size: clamp(13px, 1vw, 15.5px);
        }

        h1 {
          font-size: clamp(36px, 5vw, 66px);
        }

        h2 {
          font-size: clamp(24px, 2.9vw, 40px);
        }

        h3 {
          font-size: clamp(15px, 1.5vw, 18px);
        }

        .lead {
          font-size: clamp(13.5px, 1.4vw, 17px);
        }

        .manifesto-quote {
          font-size: clamp(22px, 3.6vw, 44px);
        }

        .manifesto-copy {
          font-size: clamp(14px, 1.4vw, 17px);
        }

        .memory-section {
          padding: clamp(62px, 7vw, 92px) 0;
        }

        .memory-content {
          width: min(780px, 100%);
        }

        .memory-title {
          max-width: 620px;
          font-size: clamp(30px, 3.2vw, 42px);
        }

        .memory-copy {
          max-width: 620px;
          font-size: clamp(13.5px, 1.15vw, 15px);
        }

        .memory-journey {
          gap: clamp(14px, 1.8vw, 22px);
          width: min(760px, 100%);
          margin-top: clamp(36px, 3.8vw, 46px);
          padding-top: 26px;
        }

        .memory-journey::before {
          top: 118px;
          left: 10%;
          right: 10%;
        }

        .memory-journey article {
          min-height: 138px;
          padding: 38px 18px 20px;
        }

        .memory-journey article:nth-child(2) {
          transform: translateY(16px);
        }

        .memory-journey article::after {
          right: 10px;
          bottom: -9px;
          font-size: 62px;
        }

        .memory-journey span {
          top: -25px;
          width: 50px;
          height: 50px;
          font-size: 18px;
          box-shadow: 0 0 0 7px rgba(10, 8, 5, 0.58);
        }

        .memory-journey h3 {
          font-size: 9.5px;
          letter-spacing: 2.6px;
        }

        .memory-journey p {
          max-width: 210px;
          font-size: 12.5px;
        }

        .roman {
          font-size: clamp(34px, 4.2vw, 56px);
        }

        .stat strong {
          font-size: clamp(24px, 3.6vw, 44px);
        }

        .testimonial blockquote {
          font-size: clamp(17px, 2vw, 27px);
        }

        .eyebrow {
          font-size: 10px;
          letter-spacing: 3.5px;
        }

        .section {
          padding: clamp(56px, 7.5vw, 104px) 0;
        }

        .btn {
          min-height: 34px;
          padding: 7px 11px;
          font-size: 8.5px;
          letter-spacing: 2px;
        }

        .nav-cta {
          padding: 7px 10px;
          min-height: 32px;
        }

        .btn-icon {
          width: 18px;
          height: 18px;
          flex-basis: 18px;
        }

        .brand {
          width: clamp(100px, 9vw, 138px);
          height: clamp(48px, 4.2vw, 64px);
        }

        .desktop-menu a {
          font-size: 9.5px;
          letter-spacing: 1.4px;
        }

        .desktop-menu {
          gap: clamp(14px, 1.8vw, 24px);
        }

        .service-pane {
          min-height: clamp(280px, 24vw, 370px);
        }

        .service-card,
        .value-card,
        .pillar,
        .service-pane {
          padding: clamp(18px, 2vw, 26px);
        }

        .service-card {
          padding: 0;
        }

        .card-media {
          height: clamp(240px, 22vw, 310px);
        }

        .card-body {
          padding: clamp(18px, 2vw, 26px);
        }

        .card-icon {
          width: 44px;
          height: 44px;
          margin-bottom: 18px;
        }

        .pillar-icon,
        .service-pane-icon {
          width: 46px;
          height: 46px;
          margin-bottom: 18px;
        }

        .faq-question {
          min-height: 56px;
          padding: 16px 18px;
        }

        .faq-question span:first-child {
          font-size: 17px;
        }

        .footer-title {
          font-size: 20px;
        }

        .site-footer {
          padding: 52px 0 22px;
        }

        .footer-bottom {
          margin-top: 38px;
          font-size: 12px;
        }

        .section-head {
          gap: 36px;
          margin-bottom: 40px;
        }

        .faq-category {
          padding: 32px 0;
          gap: 28px;
        }

        .faq-category h2 {
          font-size: clamp(20px, 2.4vw, 28px);
        }

        .testimonial {
          padding: clamp(24px, 3.5vw, 44px);
        }

        .page-hero {
          padding: calc(var(--nav-height) + 54px) 0 52px;
        }

        .portfolio-card,
        .portfolio-card img {
          min-height: 220px;
        }

        .portfolio-albums-section .album-cover,
        .portfolio-albums-section .album-cover img {
          min-height: 0;
        }

        .hero {
          padding: calc(var(--nav-height) + 52px) 0 56px;
        }

        .lightbox-copy h2 {
          font-size: 24px;
        }

        .cookie-inner h2 {
          font-size: 20px;
        }

        .cookie-inner p {
          font-size: 13px;
        }
      }
      /* ─────────────────────────────────────────────────────────────────── */

      @media (max-width: 980px) {
        :root {
          --nav-height: 88px;
        }

        .desktop-menu,
        .nav-cta {
          display: none;
        }

        .menu-toggle {
          display: inline-flex;
        }

        .brand {
          width: 132px;
          height: 72px;
        }

        .section-head,
        .two-col,
        .form-grid,
        .faq-category {
          grid-template-columns: 1fr;
        }

        .services-section .section-head {
          gap: 22px;
          margin-bottom: 42px;
        }

        .grid.three,
        .grid.four,
        .service-hub,
        .stats-row {
          grid-template-columns: repeat(2, minmax(0, 1fr));
        }

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

        .google-review-carousel {
          --review-card-width: min(34vw, 330px);
          --review-side-shift: min(32vw, 320px);
        }

        .side-info {
          border-top: 1px solid var(--line);
          border-left: 0;
          padding-top: 32px;
          padding-left: 0;
        }

        .cookie-inner {
          grid-template-columns: 1fr;
        }

        .cookie-actions {
          justify-content: flex-start;
        }

        .memory-section {
          padding: 70px 0;
        }

        .section-divider-ribbons {
          --ribbon-zone: clamp(78px, 10vw, 96px);
        }

        .divider-ribbon {
          width: max(190vw, 980px);
        }

        .divider-ribbon-back {
          height: 42px;
          transform: translate(-50%, -52%) rotate(2deg);
        }

        .divider-ribbon-front {
          height: 46px;
          transform: translate(-50%, -48%) rotate(-1.6deg);
        }

        .divider-ribbon-sequence span {
          padding-inline: clamp(11px, 2vw, 18px);
          font-size: 10px;
          letter-spacing: 2px;
        }

        .divider-ribbon-icon {
          width: 16px;
          height: 16px;
          flex-basis: 16px;
        }

        .memory-layout {
          grid-template-columns: 1fr;
        }

        .memory-content {
          width: min(680px, 100%);
          margin: 0 auto;
          text-align: center;
        }

        .memory-kicker {
          justify-content: center;
        }

        .memory-kicker::before,
        .memory-kicker::after {
          max-width: 120px;
        }

        .memory-title {
          font-size: clamp(30px, 6vw, 38px);
        }

        .memory-copy {
          margin-inline: auto;
          font-size: 14px;
        }

        .memory-journey {
          gap: 16px;
          width: min(620px, 100%);
          margin-top: 36px;
          padding-top: 24px;
        }

        .memory-journey::before {
          top: 116px;
          left: 9%;
          right: 9%;
        }

        .memory-journey article {
          min-height: 136px;
          padding: 36px 15px 18px;
        }

        .memory-journey article:nth-child(2) {
          transform: translateY(14px);
        }

        .memory-journey span {
          top: -23px;
          width: 46px;
          height: 46px;
          font-size: 17px;
          box-shadow: 0 0 0 6px rgba(10, 8, 5, 0.58);
        }

        .memory-journey h3 {
          font-size: 9px;
          letter-spacing: 2.4px;
        }

        .memory-journey p {
          max-width: 185px;
          font-size: 12.5px;
        }

        @keyframes card-shine-mobile {
          0% {
            transform: translateX(-125%) skewX(-18deg);
            opacity: 0;
          }

          14%,
          68% {
            opacity: 0.5;
          }

          78%,
          100% {
            transform: translateX(245%) skewX(-18deg);
            opacity: 0;
          }
        }

        .service-card::after {
          width: 86%;
          animation: card-shine-mobile 8.5s ease-in-out infinite;
        }

        .card-media {
          height: clamp(240px, 42vw, 320px);
        }
      }

      @media (max-width: 640px) {
        :root {
          --container: min(100vw - 28px, 1120px);
          --wide: min(100vw - 28px, 1360px);
        }

        .loader-logo {
          transform: translateX(-8%);
        }

        h1 {
          font-size: clamp(31px, 8.8vw, 38px);
        }

        .hero .eyebrow {
          width: min(100%, 32ch);
          letter-spacing: 3px;
          text-wrap: balance;
        }

        .hero {
          min-height: 88svh;
          padding-bottom: 58px;
          background:
            linear-gradient(180deg, rgba(10, 10, 10, 0.7), rgba(10, 10, 10, 0.86)),
            var(--hero-image) 58% center / cover no-repeat,
            var(--obsidian);
        }

        .hero::before {
          background: linear-gradient(180deg, rgba(10, 10, 10, 0.62), rgba(10, 10, 10, 0.9));
        }

        .google-reviews-title {
          font-size: clamp(29px, 8vw, 38px);
        }

        .google-rating strong {
          font-size: clamp(54px, 16vw, 72px);
        }

        .google-rating p {
          max-width: 28ch;
          font-size: 10px;
          letter-spacing: 1.8px;
        }

        .google-review-carousel {
          --review-card-width: min(86vw, 350px);
          --review-side-shift: min(73vw, 285px);
          margin-top: 30px;
        }

        .google-review-stage {
          height: clamp(274px, 72vw, 296px);
        }

        .google-review-card {
          padding: 20px 18px;
        }

        .google-review-card.is-prev {
          opacity: 0.24;
          transform: translateX(calc(-50% - var(--review-side-shift) + var(--review-drag-soft, 0px))) translateY(14px) scale(0.86) rotateY(9deg);
        }

        .google-review-card.is-next {
          opacity: 0.24;
          transform: translateX(calc(-50% + var(--review-side-shift) + var(--review-drag-soft, 0px))) translateY(14px) scale(0.86) rotateY(-9deg);
        }

        .google-review-card > p {
          font-size: 13.5px;
          line-height: 1.58;
        }

        .google-review-top {
          margin-bottom: 16px;
        }

        .google-reviews-action {
          margin-top: 18px;
        }

        .memory-section {
          padding: 58px 0;
        }

        .section-divider-ribbons {
          --ribbon-zone: 78px;
        }

        .divider-ribbon {
          width: max(300vw, 920px);
        }

        .divider-ribbon-back {
          height: 39px;
          transform: translate(-50%, -53%) rotate(4.2deg);
        }

        .divider-ribbon-front {
          height: 43px;
          transform: translate(-50%, -47%) rotate(-3.6deg);
        }

        .divider-ribbon-track {
          animation-duration: 22s;
        }

        .divider-ribbon-back .divider-ribbon-track {
          animation-duration: 27s;
        }

        .divider-ribbon-sequence span {
          gap: 6px;
          padding-inline: 8px;
          font-size: 9px;
          letter-spacing: 1.2px;
        }

        .divider-ribbon-icon {
          width: 15px;
          height: 15px;
          flex-basis: 15px;
        }

        .memory-kicker {
          flex-wrap: wrap;
          gap: 10px;
          margin-bottom: 18px;
          font-size: 9px;
          letter-spacing: 2.6px;
        }

        .memory-kicker::before,
        .memory-kicker::after {
          flex-basis: 100%;
          max-width: none;
          margin-top: 4px;
        }

        .memory-kicker::before {
          order: -1;
          background: linear-gradient(90deg, transparent, rgba(201, 169, 97, 0.5), transparent);
        }

        .memory-kicker::after {
          order: 3;
          background: linear-gradient(90deg, transparent, rgba(201, 169, 97, 0.5), transparent);
        }

        .memory-title {
          max-width: 330px;
          margin-bottom: 18px;
          font-size: clamp(28px, 8.2vw, 34px);
          line-height: 1.15;
        }

        .memory-copy {
          max-width: 330px;
          font-size: 13.5px;
          line-height: 1.68;
        }

        .memory-journey {
          grid-template-columns: 1fr;
          gap: 14px;
          width: min(350px, 100%);
          margin-top: 30px;
          padding-top: 0;
          padding-left: 30px;
        }

        .memory-journey::before {
          top: 8px;
          bottom: 8px;
          left: 15px;
          right: auto;
          width: 1px;
          height: auto;
          background: linear-gradient(180deg, transparent, rgba(201, 169, 97, 0.52), transparent);
        }

        .memory-journey article {
          min-height: 0;
          padding: 18px 18px 18px 34px;
          text-align: left;
        }

        .memory-journey article:nth-child(2) {
          transform: none;
        }

        .memory-journey article::before {
          inset: 14px 14px auto 34px;
        }

        .memory-journey article::after {
          right: 10px;
          bottom: -7px;
          font-size: 54px;
        }

        .memory-journey span {
          top: 18px;
          left: -30px;
          width: 34px;
          height: 34px;
          font-size: 14px;
          transform: none;
          box-shadow: 0 0 0 6px rgba(10, 8, 5, 0.74);
        }

        .memory-journey h3 {
          margin-bottom: 8px;
          font-size: 9.5px;
          letter-spacing: 2.6px;
        }

        .memory-journey p {
          max-width: none;
          margin: 0;
          font-size: 13px;
          line-height: 1.58;
        }

        .btn-row,
        .cookie-actions {
          align-items: stretch;
          flex-direction: column;
        }

        .btn {
          width: 100%;
        }

        .scroll-cue {
          display: none;
        }

        .services-section .section-head {
          gap: 16px;
          margin-bottom: 34px;
        }

        .services-section .eyebrow {
          gap: 10px;
          margin-bottom: 12px;
          letter-spacing: 3.2px;
        }

        .services-section .eyebrow::after {
          flex: 0 0 70px;
          min-width: 70px;
          background: linear-gradient(90deg, rgba(201, 169, 97, 0.9), rgba(201, 169, 97, 0.28), transparent);
        }

        .grid.three,
        .service-hub,
        .stats-row,
        .portfolio-grid,
        .block-list,
        form,
        .footer-grid {
          grid-template-columns: 1fr;
        }

        /* Pillar cards: 2×2 grid on mobile */
        .grid.four {
          gap: 12px;
        }

        .pillar {
          padding: 16px 14px;
        }

        .pillar .pillar-icon {
          width: 36px;
          height: 36px;
          margin-bottom: 12px;
        }

        .pillar h3 {
          font-size: 16px;
          margin-bottom: 7px;
          line-height: 1.35;
        }

        .pillar p {
          font-size: 11px;
          line-height: 1.55;
          display: -webkit-box;
          -webkit-line-clamp: 3;
          -webkit-box-orient: vertical;
          overflow: hidden;
        }

        .service-pane {
          min-height: 0;
        }

        .service-card {
          padding: 0;
        }

        .card-media {
          height: clamp(240px, 70vw, 310px);
        }

        .card-body {
          padding: 20px 18px 24px;
        }

        .services-section {
          overflow: hidden;
        }

        .services-carousel {
          --service-carousel-card: min(78vw, 318px);
          --service-slide-side: min(68vw, 270px);
          --service-drag: 0px;
          --service-drag-soft: 0px;
          position: relative;
          display: block;
          width: 100vw;
          height: clamp(520px, 134vw, 610px);
          margin-right: calc(50% - 50vw);
          margin-left: calc(50% - 50vw);
          overflow: hidden;
          perspective: 900px;
          isolation: isolate;
          touch-action: pan-y;
        }

        .services-carousel::before,
        .services-carousel::after {
          content: "";
          position: absolute;
          top: 0;
          bottom: 0;
          z-index: 5;
          width: 38px;
          pointer-events: none;
        }

        .services-carousel::before {
          left: 0;
          background: linear-gradient(90deg, var(--obsidian), transparent);
        }

        .services-carousel::after {
          right: 0;
          background: linear-gradient(270deg, var(--obsidian), transparent);
        }

        .services-carousel .service-card {
          position: absolute;
          top: 0;
          left: 50%;
          display: flex;
          width: var(--service-carousel-card);
          height: calc(100% - 18px);
          flex-direction: column;
          padding: 0;
          transform-origin: center center;
          will-change: transform, opacity, filter;
          opacity: 0;
          filter: brightness(0.62) saturate(0.82);
          pointer-events: none;
          transform: translateX(-50%) translateY(36px) scale(0.76);
          transition:
            transform 720ms cubic-bezier(0.22, 1, 0.36, 1),
            opacity 520ms var(--ease),
            filter 520ms var(--ease);
        }

        .services-carousel .service-card:nth-child(2) {
          z-index: 1;
          opacity: 0.6;
          transform: translateX(calc(-50% + var(--service-slide-side))) translateY(24px) scale(0.82) rotateY(-10deg);
        }

        .services-carousel .service-card:nth-child(3) {
          z-index: 1;
          opacity: 0.6;
          transform: translateX(calc(-50% - var(--service-slide-side))) translateY(24px) scale(0.82) rotateY(10deg);
        }

        .services-carousel .service-card:first-child {
          z-index: 3;
          opacity: 1;
          filter: brightness(1) saturate(1);
          pointer-events: auto;
          transform: translateX(-50%) translateY(0) scale(1) rotateY(0deg);
        }

        .services-carousel .service-card.is-active,
        .js .services-carousel .service-card[data-reveal].is-active,
        .js .services-carousel .service-card[data-reveal].is-visible.is-active {
          z-index: 3;
          opacity: 1;
          filter: brightness(1) saturate(1);
          pointer-events: auto;
          transform: translateX(calc(-50% + var(--service-drag))) translateY(0) scale(1) rotateY(0deg);
        }

        .services-carousel .service-card.is-next,
        .js .services-carousel .service-card[data-reveal].is-next,
        .js .services-carousel .service-card[data-reveal].is-visible.is-next {
          z-index: 1;
          opacity: 0.6;
          filter: brightness(0.62) saturate(0.82);
          transform: translateX(calc(-50% + var(--service-slide-side) + var(--service-drag-soft))) translateY(24px) scale(0.82) rotateY(-10deg);
        }

        .services-carousel .service-card.is-prev,
        .js .services-carousel .service-card[data-reveal].is-prev,
        .js .services-carousel .service-card[data-reveal].is-visible.is-prev {
          z-index: 1;
          opacity: 0.6;
          filter: brightness(0.62) saturate(0.82);
          transform: translateX(calc(-50% - var(--service-slide-side) + var(--service-drag-soft))) translateY(24px) scale(0.82) rotateY(10deg);
        }

        .services-carousel.is-dragging .service-card {
          transition-duration: 0ms;
        }

        .services-carousel .service-card::after {
          animation: none;
          opacity: 0;
        }

        @keyframes service-card-mobile-shine {
          0% {
            opacity: 0;
            transform: translateX(-135%) skewX(-18deg);
          }

          18%,
          58% {
            opacity: 0.48;
          }

          100% {
            opacity: 0;
            transform: translateX(245%) skewX(-18deg);
          }
        }

        .services-carousel .service-card.is-active.is-shining::after {
          animation: service-card-mobile-shine 1250ms ease-out both;
        }

        .services-carousel .card-media {
          flex: 0 0 clamp(250px, 68vw, 300px);
          height: auto;
        }

        .services-carousel .card-body {
          display: flex;
          flex: 1;
          flex-direction: column;
          padding: 22px 20px 24px;
        }

        .services-carousel .link-arrow {
          margin-top: auto;
        }

        .portfolio-card,
        .portfolio-card img {
          min-height: 230px;
        }

        .portfolio-album-viewport {
          margin-top: 2px;
        }

        .portfolio-album-track {
          animation-duration: 26s;
        }

        .portfolio-album-sequence {
          gap: 14px;
          padding-bottom: 18px;
        }

        .portfolio-albums-section .album-cover {
          width: min(74vw, 292px);
          min-height: 0;
        }

        .portfolio-albums-section .album-cover img {
          min-height: 0;
        }

        .portfolio-albums-section .portfolio-overlay {
          padding: 20px;
        }

        .portfolio-albums-section .portfolio-overlay strong {
          font-size: 27px;
        }

        .album-hint {
          top: 18px;
          left: 18px;
          max-width: calc(100% - 36px);
          font-size: 8px;
          letter-spacing: 1.8px;
        }

        .lightbox {
          padding: 12px;
        }

        .lightbox-panel {
          width: 100%;
          max-height: calc(100svh - 24px);
        }

        .album-lightbox-stage {
          height: min(66svh, 560px);
          min-height: 390px;
        }

        .album-lightbox-slide {
          top: 22px;
          bottom: 22px;
          width: min(72vw, 300px);
        }

        .album-lightbox-nav {
          top: calc(50% - 36px);
          width: 38px;
          height: 38px;
          font-size: 24px;
        }

        .album-lightbox-prev {
          left: 10px;
        }

        .album-lightbox-next {
          right: 10px;
        }

        .lightbox-copy {
          padding: 18px 18px 20px;
        }

        .portfolio-overlay {
          opacity: 1;
          transform: none;
        }

        .footer-bottom,
        .footer-bottom nav {
          display: grid;
        }

        .whatsapp-float {
          right: 14px;
          bottom: 14px;
        }

        .whatsapp-float::before {
          display: none;
        }

        .floating-scrollbar {
          top: 8px;
          right: 4px;
          bottom: 8px;
          width: 5px;
        }

        .floating-scrollbar span {
          width: 2px;
        }
      }

      @media (max-width: 640px) and (prefers-reduced-motion: reduce) {
        .services-carousel {
          display: grid;
          width: auto;
          height: auto;
          margin-inline: 0;
          overflow: visible;
        }

        .services-carousel::before,
        .services-carousel::after {
          display: none;
        }

        .services-carousel .service-card {
          position: relative;
          top: auto;
          left: auto;
          width: auto;
          height: auto;
          opacity: 1;
          filter: none;
          transform: none;
          animation: none;
        }
      }
