@font-face { font-family: 'Montserrat'; font-style: normal; font-weight: 200 700; font-display: swap; src: url('/assets/fonts/montserrat-latin.woff2') format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Montserrat'; font-style: normal; font-weight: 200 700; font-display: swap; src: url('/assets/fonts/montserrat-latin-ext.woff2') format('woff2'); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: 'Montserrat'; font-style: italic; font-weight: 300 400; font-display: swap; src: url('/assets/fonts/montserrat-italic-latin.woff2') format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Montserrat'; font-style: italic; font-weight: 300 400; font-display: swap; src: url('/assets/fonts/montserrat-italic-latin-ext.woff2') format('woff2'); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: 'Playfair Display'; font-style: italic; font-weight: 400; font-display: swap; src: url('/assets/fonts/playfair-italic-latin.woff2') format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: 'Playfair Display'; font-style: italic; font-weight: 400; font-display: swap; src: url('/assets/fonts/playfair-italic-latin-ext.woff2') format('woff2'); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
    /* =========================================================
       UNIQUE — SAVE THE DATE SP
       Identidade visual derivada da LP de Consulta (Unique).
       Paleta: dourado quente sobre near-black / creme.
       Tipografia: Montserrat (fonte oficial da marca).
       ========================================================= */

    :root {
      /* Brand — Luxury Gold */
      --brand:        #C5A572;
      --brand-alt:    #B8935A;
      --brand-darker: #8B7047;
      --brand-light:  #D4B987;
      --brand-glow:   rgba(197, 165, 114, 0.30);
      --accent:       #D4AF37;

      /* Neutral */
      --white:        #FFFFFF;
      --black:        #0A0A0A;
      --bg-cream:     #FAF8F5;
      --bg-alt:       #FDFBF7;
      --text-dark:    #2C2C2C;
      --text-darker:  #1A1A1A;
      --text-gray:    #6B6B6B;
      --text-gray-lt: #9E9E9E;
      --border:       #E8E5DF;
      --border-gold:  rgba(197, 165, 114, 0.22);

      /* Spacing */
      --sp-xs: clamp(0.5rem, 1vw, 0.75rem);
      --sp-sm: clamp(1rem, 2vw, 1.5rem);
      --sp-md: clamp(2rem, 4vw, 3rem);
      --sp-lg: clamp(3rem, 6vw, 5rem);
      --sp-xl: clamp(5rem, 10vw, 8rem);

      /* Easing */
      --ease: cubic-bezier(0.4, 0, 0.2, 1);
      --ease-bounce: cubic-bezier(0.68, -0.55, 0.265, 1.55);

      --container: 1400px;
    }

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

    html {
      scroll-behavior: smooth;
      scroll-padding-top: 80px;
      -webkit-text-size-adjust: 100%;
    }

    body {
      margin: 0;
      font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, Arial, sans-serif;
      font-size: clamp(0.9375rem, 1.05vw, 1.0625rem);
      line-height: 1.7;
      color: var(--text-dark);
      background: var(--bg-alt);
      -webkit-font-smoothing: antialiased;
      text-rendering: optimizeLegibility;
      overflow-x: hidden;
    }

    img { max-width: 100%; display: block; }
    button { font: inherit; cursor: pointer; border: 0; background: transparent; color: inherit; }
    a { color: inherit; text-decoration: none; }

    .cookie-banner a {
      color: hsl(38 45% 42%) !important;
      text-decoration: underline !important;
    }

    .cookie-banner a:hover { color: hsl(38 50% 48%) !important; }

    .cookie-banner__button {
      border: 2px solid hsl(0 0% 88%) !important;
      border-radius: 9999px !important;
      color: hsl(30 10% 15%) !important;
      font-weight: 600 !important;
      transition: transform .2s ease, background-color .2s ease, border-color .2s ease !important;
    }

    .cookie-banner__button:hover { transform: scale(1.05) !important; }

    .cookie-banner__button--accept {
      background: hsl(38 45% 42%) !important;
      border-color: hsl(38 45% 42%) !important;
      color: hsl(40 20% 97%) !important;
    }

    .cookie-banner__button--accept:hover {
      background: hsl(38 50% 48%) !important;
      border-color: hsl(38 50% 48%) !important;
    }

    .cookie-banner__button--manage { background: hsl(35 15% 92%) !important; }
    .cookie-banner__button--manage:hover { background: hsl(35 20% 90%) !important; }
    .cookie-banner__button--reject:hover { border-color: hsl(30 10% 15%) !important; }

    ::selection { background: var(--brand); color: var(--white); }

    .container {
      width: 100%;
      max-width: var(--container);
      margin: 0 auto;
      padding: 0 clamp(1.25rem, 5vw, 3rem);
    }

    /* =========================================================
       HEADER — transparente sobre hero, blur ao rolar
       ========================================================= */
    .site-header {
      position: fixed;
      inset: 0 0 auto 0;
      z-index: 60;
      padding: clamp(14px, 2vw, 22px) 0;
      background: transparent;
      transition: background .35s var(--ease), backdrop-filter .35s var(--ease), padding .35s var(--ease), border-color .35s var(--ease);
      border-bottom: 1px solid transparent;
    }
    .site-header.is-scrolled {
      background: rgba(10,10,10,0.72);
      backdrop-filter: saturate(160%) blur(14px);
      -webkit-backdrop-filter: saturate(160%) blur(14px);
      border-bottom-color: var(--border-gold);
      padding: 10px 0;
    }
    .site-header__inner {
      display: flex;
      align-items: center;
      justify-content: center;
    }
    .site-header__logo img {
      height: clamp(28px, 3.5vw, 40px);
      width: auto;
      filter: brightness(0) invert(1);
      transition: transform .4s var(--ease), opacity .4s var(--ease);
    }
    .site-header__logo:hover img { transform: scale(1.04); }

    /* =========================================================
       HERO
       ========================================================= */
    .hero {
      position: relative;
      min-height: 100vh;
      display: flex;
      align-items: center;
      justify-content: center;
      overflow: hidden;
      background: var(--black);
      color: var(--white);
      isolation: isolate;
    }

    .hero__bg {
      position: absolute;
      inset: 0;
      z-index: -2;
    }
    .hero__bg-slide {
      position: absolute;
      inset: 0;
      background-size: cover;
      background-position: center;
      opacity: 0;
      transform: scale(1.08);
      transition: opacity 1.6s var(--ease), transform 8s linear;
    }
    .hero__bg-slide.is-active {
      opacity: 1;
      transform: scale(1.0);
    }
    .hero__bg-slide:nth-child(1) { background-image: url('/assets/img-slide-hero-1.webp'); }
    .hero__bg-slide:nth-child(2) { background-image: url('/assets/img-slide-hero-2.webp'); }
    .hero__bg-slide:nth-child(3) { background-image: url('/assets/img-slide-hero-3.webp'); }

    .hero__bg-video {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      z-index: 1;
    }

    .hero__overlay {
      position: absolute;
      inset: 0;
      z-index: -1;
      background:
        linear-gradient(180deg, rgba(10,10,10,0.55) 0%, rgba(10,10,10,0.65) 45%, rgba(10,10,10,0.92) 100%),
        radial-gradient(ellipse at center, transparent 0%, rgba(10,10,10,0.45) 70%);
    }

    .hero__particles {
      position: absolute;
      inset: 0;
      z-index: -1;
      pointer-events: none;
      background:
        radial-gradient(1.5px 1.5px at 20% 30%, rgba(197,165,114,.35), transparent 60%),
        radial-gradient(1.5px 1.5px at 70% 60%, rgba(212,175,55,.28), transparent 60%),
        radial-gradient(1px 1px at 40% 80%, rgba(197,165,114,.32), transparent 60%),
        radial-gradient(1px 1px at 85% 20%, rgba(197,165,114,.25), transparent 60%);
      animation: particlesFloat 60s linear infinite;
    }
    @keyframes particlesFloat {
      0%   { transform: translate(0,0); }
      50%  { transform: translate(-20px, -10px); }
      100% { transform: translate(0,0); }
    }

    .hero__inner {
      position: relative;
      display: flex;
      flex-direction: column;
      align-items: center;
      text-align: center;
      gap: clamp(20px, 2.6vw, 32px);
      max-width: 920px;
      padding: clamp(120px, 14vh, 180px) 0 clamp(80px, 10vh, 120px);
    }

    .hero__badge {
      display: inline-flex;
      align-items: center;
      gap: clamp(14px, 1.8vw, 22px);
      max-width: 100%;
      opacity: 0;
      transform: translateY(-20px);
      animation: subtitleReveal 1.1s var(--ease) .15s forwards;
    }
    .hero__badge-line {
      width: clamp(28px, 4vw, 56px);
      height: 1px;
      background: linear-gradient(90deg, transparent, var(--brand) 60%, transparent);
    }
    .hero__pretitulo {
      margin: 0;
      font-family: 'Montserrat', sans-serif;
      font-style: normal;
      font-weight: 500;
      font-size: clamp(11px, 0.95vw, 13px);
      letter-spacing: 0.26em;
      text-transform: uppercase;
      color: var(--brand-light);
      max-width: 580px;
      line-height: 1.7;
    }

    .hero__titulo {
      margin: 0;
      font-family: 'Playfair Display', Georgia, serif;
      font-style: italic;
      font-weight: 400;
      font-size: clamp(48px, 8.5vw, 110px);
      line-height: 1.02;
      letter-spacing: 0.005em;
      color: var(--white);
      text-shadow: 0 4px 40px rgba(0,0,0,0.5);
      opacity: 0;
      transform: translateY(-40px);
      filter: blur(8px);
      animation: titleReveal 1.2s var(--ease) .4s forwards;
    }
    @keyframes titleReveal {
      to { opacity: 1; transform: translateY(0); filter: blur(0); }
    }
    @keyframes subtitleReveal {
      to { opacity: 1; transform: translateY(0); }
    }
    @keyframes ctaReveal {
      to { opacity: 1; transform: translateY(0) scale(1); }
    }

    .hero__divisor {
      width: 0;
      height: 1px;
      background: linear-gradient(90deg, transparent, var(--brand), transparent);
      animation: lineExpand 1.4s var(--ease) 1.1s forwards;
    }
    @keyframes lineExpand {
      to { width: clamp(80px, 12vw, 140px); }
    }

    .hero__subtitulo {
      margin: 0;
      font-family: 'Montserrat', sans-serif;
      font-style: normal;
      font-weight: 500;
      font-size: clamp(15px, 1.35vw, 19px);
      line-height: 1.75;
      letter-spacing: 0.015em;
      color: rgba(255,255,255,0.96);
      text-shadow: 0 2px 18px rgba(0,0,0,0.45);
      max-width: 680px;
      opacity: 0;
      transform: translateY(-30px);
      animation: subtitleReveal 1.1s var(--ease) .85s forwards;
    }

    .hero__cta-wrap {
      opacity: 0;
      transform: translateY(-20px) scale(0.95);
      animation: ctaReveal 1s var(--ease) 1.3s forwards;
    }

    /* =========================================================
       BOTÕES — Gradiente dourado com shimmer + glow
       ========================================================= */
    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 12px;
      padding: clamp(16px, 1.9vw, 22px) clamp(36px, 4.5vw, 56px);
      min-height: 56px;
      font-family: 'Montserrat', sans-serif;
      font-size: clamp(13px, 1.2vw, 16px);
      font-weight: 600;
      letter-spacing: 0.28em;
      text-transform: uppercase;
      color: var(--white);
      background: linear-gradient(135deg, var(--brand-darker) 0%, var(--brand) 50%, var(--brand-light) 100%);
      background-size: 200% 200%;
      border-radius: 999px;
      box-shadow:
        0 10px 30px rgba(139,112,71,0.32),
        0 0 0 1px rgba(255,255,255,0.08) inset;
      position: relative;
      overflow: hidden;
      cursor: pointer;
      transition: transform .35s var(--ease), box-shadow .35s var(--ease), background-position .8s var(--ease);
      animation: gradientShift 6s ease-in-out infinite;
    }
    .btn::before {
      content: "";
      position: absolute;
      top: 0;
      left: -100%;
      width: 50%;
      height: 100%;
      background: linear-gradient(90deg, transparent, rgba(255,255,255,0.35), transparent);
      transform: skewX(-20deg);
      transition: left .8s var(--ease);
    }
    .btn:hover { transform: translateY(-3px) scale(1.02); box-shadow: 0 18px 42px rgba(139,112,71,0.46), 0 0 0 1px rgba(255,255,255,0.15) inset; }
    .btn:hover::before { left: 120%; }
    .btn:active { transform: translateY(-1px) scale(1.01); }
    .btn:focus-visible { outline: 2px solid var(--brand-light); outline-offset: 4px; }
    .btn--full { width: 100%; }

    @keyframes gradientShift {
      0%, 100% { background-position: 0% 50%; }
      50%      { background-position: 100% 50%; }
    }

    /* Botão ghost (variação clara em fundos cremes) */
    .btn--ghost {
      background: transparent;
      color: var(--brand-darker);
      border: 1px solid var(--brand);
      box-shadow: none;
      animation: none;
    }
    .btn--ghost:hover {
      background: var(--brand);
      color: var(--white);
    }

    /* =========================================================
       REVEAL ON SCROLL — REMOVIDO (conteúdo já visível)
       ========================================================= */
    .reveal { opacity: 1; transform: none; filter: none; }
    .d1 { }
    .d2 { }
    .d3 { }
    .d4 { }
    .d5 { }

    /* =========================================================
       EYEBROW (section tag) — dourado fino
       ========================================================= */
    .section-tag {
      display: inline-flex;
      align-items: center;
      gap: 14px;
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.32em;
      text-transform: uppercase;
      color: var(--brand-darker);
      margin-bottom: var(--sp-sm);
    }
    .section-tag::before,
    .section-tag::after {
      content: "";
      width: 28px;
      height: 1px;
      background: var(--brand);
    }
    .section-tag--light { color: var(--brand-light); }
    .section-tag--light::before,
    .section-tag--light::after { background: var(--brand); }

    /* =========================================================
       SECTION 2 — CONTEXTO
       ========================================================= */
    .contexto {
      padding: var(--sp-xl) 0;
      background: var(--bg-cream);
      position: relative;
    }
    .contexto::before {
      content: "";
      position: absolute;
      top: 0; left: 50%;
      transform: translateX(-50%);
      width: 1px; height: 64px;
      background: linear-gradient(180deg, var(--brand), transparent);
    }

    /* =========================================================
       CONTEXTO — Composição editorial (Aman / T Magazine ref)
       Spine vertical dourado, título-pôster, drop cap, funnel
       ========================================================= */
    .contexto__intro {
      position: relative;
      max-width: 1100px;
      margin: 0 auto;
      padding: clamp(32px, 4vw, 64px) clamp(24px, 5vw, 64px) clamp(48px, 7vw, 100px);
    }
    /* Atmosfera dourada estática no topo (apenas ambienta) */
    .contexto__intro::before {
      content: "";
      position: absolute;
      top: 0;
      left: 50%;
      transform: translateX(-50%);
      width: 80%;
      max-width: 900px;
      height: 360px;
      background: radial-gradient(ellipse at top, rgba(197,165,114,0.07), transparent 70%);
      pointer-events: none;
      z-index: 0;
    }
    .contexto__intro > * { position: relative; z-index: 1; }
    .contexto__intro .section-tag {
      display: flex;
      justify-content: center;
      margin-bottom: clamp(56px, 8vw, 100px);
    }

    /* === Composição com spine arquitetural à esquerda === */
    .contexto__composicao {
      position: relative;
      padding-left: clamp(24px, 5vw, 80px);
    }
    .contexto__spine {
      position: absolute;
      top: 6px;
      bottom: 6px;
      left: 0;
      width: 1px;
      background: linear-gradient(180deg,
        transparent 0%,
        rgba(197,165,114,0.5) 12%,
        rgba(197,165,114,0.5) 88%,
        transparent 100%);
      pointer-events: none;
    }

    /* === Pilares (sem decoração — só espacejamento intencional) === */
    .contexto__pillar {
      position: relative;
    }
    /* Beat 1 — Título-pôster (escala grande, line-breaks manuais, uma palavra-âncora italic) */
    .contexto__pillar--titulo {
      max-width: 880px;
      margin: 0 0 clamp(72px, 9vw, 120px);
      text-align: left;
    }
    .contexto__titulo {
      margin: 0;
      font-family: 'Montserrat', sans-serif;
      font-weight: 500;
      font-style: normal;
      font-size: clamp(40px, 7vw, 84px);
      line-height: 1.04;
      letter-spacing: -0.022em;
      color: var(--text-darker);
    }
    .contexto__titulo em {
      font-family: 'Playfair Display', 'Montserrat', serif;
      font-style: italic;
      font-weight: 400;
      color: var(--brand);
    }
    /* Régua dourada animada abaixo do título */
    .contexto__rule {
      display: block;
      width: 0;
      height: 1px;
      margin-top: clamp(36px, 5vw, 64px);
      background: linear-gradient(to right, var(--brand) 0%, var(--brand) 65%, transparent 100%);
      width: clamp(160px, 26vw, 320px);
    }

    /* Beat 2 — Parágrafo único do corpo COM drop cap editorial */
    .contexto__pillar--corpo {
      max-width: 640px;
      margin: 0;
    }

    /* === Parágrafo === */
    .contexto__paragrafo {
      margin: 0;
      font-family: 'Montserrat', sans-serif;
      font-weight: 400;
      font-style: normal;
      font-size: clamp(18px, 2.2vw, 25px);
      line-height: 1.62;
      letter-spacing: -0.003em;
      color: var(--text-darker);
    }
    .contexto__paragrafo em {
      font-family: 'Playfair Display', 'Montserrat', serif;
      font-style: italic;
      font-weight: 400;
      color: var(--brand);
    }

    /* === Drop cap editorial (somente P1) === */
    .contexto__paragrafo--dropcap::first-letter {
      font-family: 'Playfair Display', 'Montserrat', serif;
      font-style: italic;
      font-weight: 400;
      color: var(--brand);
      font-size: 4.6em;
      line-height: 0.85;
      float: left;
      padding: 0.08em 0.12em 0 0;
      margin-right: 0.02em;
    }

    /* === Smoke reveal — REMOVIDO (conteúdo já visível) === */

    /* === Responsivo === */
    @media (max-width: 768px) {
      .contexto__composicao {
        padding-left: 0;
      }
      .contexto__spine { display: none; }
      .contexto__pillar--titulo,
      .contexto__pillar--p1,
      .contexto__pillar--p2 {
        max-width: 100%;
        margin-left: auto;
        margin-right: auto;
        text-align: center;
      }
      .contexto__rule { margin-left: auto; margin-right: auto; }
      .contexto__paragrafo--dropcap::first-letter {
        font-size: 3.8em;
      }
    }

    /* Galeria — marquee infinito horizontal (minimalista) */
    .galeria {
      margin: clamp(8px, 1.5vw, 24px) 0 clamp(56px, 8vw, 96px);
    }
    .galeria__marquee {
      position: relative;
      overflow: hidden;
      /* fade nas bordas — sensação cinematográfica, esconde o "salto" do loop */
      -webkit-mask-image: linear-gradient(to right,
        transparent 0,
        #000 8%,
        #000 92%,
        transparent 100%);
              mask-image: linear-gradient(to right,
        transparent 0,
        #000 8%,
        #000 92%,
        transparent 100%);
    }
    .galeria__marquee-track {
      display: flex;
      width: max-content;
      animation: galeriaMarquee 50s linear infinite;
      will-change: transform;
    }
    .galeria__marquee:hover .galeria__marquee-track,
    .galeria__marquee:focus-within .galeria__marquee-track {
      animation-play-state: paused;
    }
    @keyframes galeriaMarquee {
      from { transform: translate3d(0, 0, 0); }
      to   { transform: translate3d(-50%, 0, 0); }
    }
    .galeria__marquee-item {
      margin: 0;
      flex: 0 0 auto;
      height: clamp(280px, 28vw, 380px);
      aspect-ratio: 4 / 3;
      padding-right: clamp(8px, 1vw, 14px); /* "gap" via padding — math do loop fica exata */
      box-sizing: content-box;
    }
    .galeria__marquee-item-inner {
      position: relative;
      display: block;
      width: 100%;
      height: 100%;
      overflow: hidden;
      border-radius: 6px;
      border: 1px solid var(--border-gold);
      background: var(--bg-alt);
      box-shadow:
        inset 0 0 0 1px rgba(255, 244, 214, 0.18),
        0 10px 30px rgba(139, 112, 71, 0.12);
      padding: 0;
      margin: 0;
      cursor: pointer;
      font: inherit;
      color: inherit;
      appearance: none;
      transition: border-color .4s var(--ease), box-shadow .4s var(--ease);
    }
    .galeria__marquee-item-inner:hover,
    .galeria__marquee-item-inner:focus-visible {
      border-color: var(--brand);
      box-shadow:
        inset 0 0 0 1px rgba(255, 244, 214, 0.35),
        0 14px 36px rgba(139, 112, 71, 0.22);
      outline: none;
    }

    .galeria__marquee-item img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      transition: transform .6s var(--ease);
      transform-origin: center center;
    }
    .galeria__marquee-item-inner:hover img,
    .galeria__marquee-item-inner:focus-visible img {
      transform: scale(1.04);
    }

    .galeria__placeholder {
      width: 100%;
      height: 100%;
      display: flex;
      align-items: center;
      justify-content: center;
      background:
        linear-gradient(135deg, rgba(197,165,114,0.08) 0%, rgba(78,56,28,0.18) 100%),
        var(--bg-alt);
      color: rgba(197, 165, 114, 0.55);
    }
    .galeria__placeholder svg {
      width: 38%;
      height: 38%;
      max-width: 96px;
      max-height: 96px;
    }

    /* Lightbox */
    .lightbox {
      position: fixed;
      inset: 0;
      z-index: 1000;
      background: rgba(10, 8, 6, 0.92);
      display: flex;
      align-items: center;
      justify-content: center;
      padding: clamp(16px, 4vw, 48px);
      animation: lightboxFadeIn .25s ease-out;
      backdrop-filter: blur(6px);
    }
    @keyframes lightboxFadeIn {
      from { opacity: 0; }
      to   { opacity: 1; }
    }
    .lightbox__stage {
      position: relative;
      display: flex;
      align-items: center;
      justify-content: center;
      max-width: min(1100px, 92vw);
      max-height: 86vh;
    }
    .lightbox__content {
      position: relative;
      max-width: min(1100px, 92vw);
      max-height: 86vh;
      display: flex;
      align-items: center;
      justify-content: center;
      border-radius: 8px;
      overflow: hidden;
      border: 1px solid var(--border-gold);
      box-shadow: 0 24px 80px rgba(0,0,0,0.6);
      background: var(--bg-alt);
    }
    .lightbox__content img {
      display: block;
      max-width: 100%;
      max-height: 86vh;
      width: auto;
      height: auto;
      object-fit: contain;
    }
    .lightbox__placeholder {
      width: min(1100px, 92vw);
      height: min(620px, 70vh);
      display: flex;
      align-items: center;
      justify-content: center;
      color: rgba(197, 165, 114, 0.45);
    }
    .lightbox__placeholder svg {
      width: 30%;
      height: 30%;
      max-width: 140px;
      max-height: 140px;
    }
    .lightbox__close,
    .lightbox__nav {
      position: absolute;
      background: rgba(15, 12, 10, 0.55);
      color: var(--white);
      border: 1px solid rgba(255,255,255,0.22);
      border-radius: 999px;
      cursor: pointer;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding: 0;
      line-height: 0;
      backdrop-filter: blur(6px);
      -webkit-backdrop-filter: blur(6px);
      transition: background .25s var(--ease), border-color .25s var(--ease), color .25s var(--ease), transform .25s var(--ease), box-shadow .25s var(--ease);
      z-index: 2;
    }
    .lightbox__close svg,
    .lightbox__nav svg {
      display: block;
      width: 50%;
      height: 50%;
    }
    .lightbox__close:hover,
    .lightbox__close:focus-visible,
    .lightbox__nav:hover,
    .lightbox__nav:focus-visible {
      background: var(--brand);
      border-color: var(--brand);
      color: var(--black);
      box-shadow: 0 6px 22px rgba(0,0,0,0.35);
      outline: none;
    }
    .lightbox__close {
      position: fixed;
      top: clamp(16px, 3vw, 28px);
      right: clamp(16px, 3vw, 28px);
      width: 44px;
      height: 44px;
    }
    .lightbox__nav {
      top: 50%;
      transform: translateY(-50%);
      width: 52px;
      height: 52px;
    }
    .lightbox__nav:hover,
    .lightbox__nav:focus-visible { transform: translateY(-50%) scale(1.06); }
    .lightbox__nav:active { transform: translateY(-50%) scale(0.96); }
    .lightbox__nav--prev { left: clamp(12px, 2vw, 20px); }
    .lightbox__nav--next { right: clamp(12px, 2vw, 20px); }
    .lightbox__counter {
      position: absolute;
      bottom: clamp(18px, 3vw, 30px);
      left: 50%;
      transform: translateX(-50%);
      font-family: 'Montserrat', sans-serif;
      font-size: 13px;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: rgba(255,255,255,0.7);
    }
    @media (max-width: 600px) {
      .lightbox__nav { width: 42px; height: 42px; }
      .lightbox__close { width: 38px; height: 38px; }
      .lightbox__nav--prev { left: 8px; }
      .lightbox__nav--next { right: 8px; }
    }

    /* Convite — frase de invitation em Montserrat (fonte da marca) */
    .contexto__convite {
      max-width: 760px;
      margin: clamp(48px, 7vw, 80px) auto 0;
      text-align: center;
      font-family: 'Montserrat', sans-serif;
      font-style: normal;
      font-weight: 300;
      font-size: clamp(19px, 2vw, 26px);
      line-height: 1.62;
      letter-spacing: -0.003em;
      color: var(--text-darker);
    }
    /* Trecho-âncora com gradiente dourado escuro animado (contraste no fundo creme) */
    .contexto__convite .destaque {
      font-weight: 500;
      background: linear-gradient(
        100deg,
        #6F5530 0%,
        var(--brand-darker) 22%,
        var(--brand-alt) 40%,
        var(--brand-darker) 58%,
        var(--brand-alt) 75%,
        var(--brand-darker) 100%
      );
      background-size: 220% 100%;
      background-position: 100% 0;
      -webkit-background-clip: text;
              background-clip: text;
      -webkit-text-fill-color: transparent;
              color: transparent;
      animation: conviteShimmer 6s linear infinite;
    }
    @keyframes conviteShimmer {
      0%   { background-position: 200% 0; }
      100% { background-position: -200% 0; }
    }
    @media (prefers-reduced-motion: reduce) {
      .contexto__convite .destaque {
        animation: none;
        background-position: 50% 0;
      }
    }

    /* Detalhes — tipografia de convite (sem cards, sem ícones) */
    .detalhes {
      list-style: none;
      margin: clamp(40px, 6vw, 80px) auto clamp(56px, 8vw, 100px);
      padding: 0;
      max-width: 900px;
    }
    .detalhes__rule {
      display: block;
      width: 1px;
      height: clamp(48px, 7vw, 80px);
      margin: 0 auto clamp(48px, 7vw, 88px);
      background: var(--brand);
    }
    .detalhes__grid {
      display: grid;
      grid-template-columns: 1fr auto 1fr;
      align-items: center;
      gap: clamp(20px, 4vw, 64px);
    }
    .detalhes__item {
      display: flex;
      flex-direction: column;
      gap: clamp(12px, 1.6vw, 20px);
      text-align: center;
      padding: 0;
    }
    .detalhes__label {
      font-family: 'Playfair Display', Georgia, serif;
      font-style: italic;
      font-weight: 400;
      font-size: clamp(15px, 1.55vw, 19px);
      color: var(--brand);
      letter-spacing: 0.01em;
      line-height: 1;
    }
    .detalhes__valor {
      font-family: 'Montserrat', sans-serif;
      font-weight: 500;
      font-style: normal;
      font-size: clamp(26px, 3.4vw, 44px);
      letter-spacing: -0.014em;
      text-transform: none;
      color: var(--text-darker);
      line-height: 1.12;
    }
    .detalhes__spine {
      display: block;
      width: 1px;
      height: clamp(72px, 11vw, 130px);
      background: linear-gradient(180deg, transparent, rgba(197,165,114,0.5), transparent);
    }

    /* =========================================================
       SECTION 3 — FORMULÁRIO
       ========================================================= */
    .formulario {
      position: relative;
      padding: var(--sp-xl) 0;
      background: var(--black);
      color: var(--white);
      overflow: hidden;
      isolation: isolate;
    }
    .formulario::before {
      content: "";
      position: absolute;
      inset: -20% -10% auto -10%;
      height: 70%;
      background: radial-gradient(ellipse at center, rgba(197,165,114,0.16), transparent 65%);
      z-index: -1;
      pointer-events: none;
    }
    .formulario::after {
      content: "";
      position: absolute;
      bottom: 0; left: 50%;
      transform: translateX(-50%);
      width: 1px; height: 64px;
      background: linear-gradient(180deg, transparent, var(--brand));
    }

    .formulario__inner {
      max-width: 620px;
      margin: 0 auto;
      text-align: center;
    }
    .formulario__titulo {
      margin: 0 0 var(--sp-sm);
      font-family: 'Montserrat', sans-serif;
      font-style: normal;
      font-weight: 300;
      font-size: clamp(32px, 4.3vw, 50px);
      line-height: 1.18;
      letter-spacing: 0.01em;
    }
    .formulario__subtitulo {
      margin: 0 auto clamp(40px, 5vw, 56px);
      max-width: 560px;
      font-size: clamp(14px, 1.05vw, 16px);
      line-height: 1.75;
      color: rgba(255,255,255,0.72);
    }

    /* Form — tratamento RSVP card editorial (sem boxes, underline-only) */
    .form {
      display: flex;
      flex-direction: column;
      gap: clamp(24px, 3vw, 36px);
      text-align: left;
    }
    .form__group {
      display: flex;
      flex-direction: column;
      gap: clamp(24px, 3vw, 36px);
    }
    .form__group--companion { gap: clamp(16px, 2vw, 22px); }
    .form__group-question {
      margin: 0;
      text-align: center;
      font-family: 'Montserrat', sans-serif;
      font-weight: 500;
      font-size: clamp(13px, 1.15vw, 15px);
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--white);
      line-height: 1.5;
    }
    .form__companion-title {
      margin: clamp(4px, 0.8vw, 8px) 0 clamp(8px, 1.2vw, 14px);
      text-align: center;
      font-family: 'Montserrat', sans-serif;
      font-weight: 500;
      font-size: clamp(12px, 1.05vw, 14px);
      letter-spacing: 0.10em;
      text-transform: uppercase;
      color: var(--white);
      line-height: 1.5;
    }
    .form__choice {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: clamp(12px, 1.5vw, 18px);
      width: 100%;
    }
    .form__choice-option {
      position: relative;
      display: block;
      cursor: pointer;
    }
    .form__choice-option input[type="radio"] {
      position: absolute;
      opacity: 0;
      pointer-events: none;
      width: 0;
      height: 0;
    }
    .form__choice-pill {
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 14px 24px;
      font-family: 'Montserrat', sans-serif;
      font-weight: 500;
      font-size: clamp(13px, 1.1vw, 15px);
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: rgba(255,255,255,0.85);
      background: transparent;
      border: 1px solid rgba(255,255,255,0.28);
      border-radius: 2px;
      transition: all .3s var(--ease);
      user-select: none;
    }
    .form__choice-option:hover .form__choice-pill {
      border-color: rgba(197,165,114,0.6);
      color: var(--white);
    }
    .form__choice-option input[type="radio"]:checked + .form__choice-pill {
      color: var(--black);
      background: var(--brand);
      border-color: var(--brand);
      box-shadow: 0 0 24px var(--brand-glow);
    }
    .form__choice-option input[type="radio"]:focus-visible + .form__choice-pill {
      outline: 2px solid var(--brand-light);
      outline-offset: 2px;
    }
    .form__companion-fields {
      display: flex;
      flex-direction: column;
      gap: clamp(24px, 3vw, 36px);
      margin-top: clamp(8px, 1.5vw, 16px);
    }
    .form__companion-fields[hidden] { display: none; }
    .form__field { display: flex; flex-direction: column; gap: 8px; position: relative; }
    .form__label {
      font-family: 'Montserrat', sans-serif;
      font-style: normal;
      font-weight: 500;
      font-size: clamp(12px, 1.05vw, 14px);
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--brand-light);
    }
    .form__req {
      color: rgba(197,165,114,0.55);
      margin-left: 4px;
      font-family: 'Montserrat', sans-serif;
      font-style: normal;
    }
    .form__input {
      width: 100%;
      padding: 12px 0 10px;
      font-family: 'Montserrat', sans-serif;
      font-weight: 300;
      font-size: clamp(16px, 1.55vw, 20px);
      color: var(--white);
      background: transparent;
      border: 0;
      border-bottom: 1px solid rgba(255,255,255,0.18);
      border-radius: 0;
      transition: border-color .35s var(--ease);
    }
    .form__input:hover { border-bottom-color: rgba(255,255,255,0.4); }
    .form__input:focus {
      outline: none;
      border-bottom-color: var(--brand);
      background: transparent;
      box-shadow: none;
    }
    .form__input::placeholder { color: rgba(255,255,255,0.28); font-style: italic; }
    .form__input.is-invalid {
      border-bottom-color: #E27575;
      box-shadow: none;
    }
    .form__error {
      display: none;
      margin-top: 4px;
      font-size: 12px;
      font-style: italic;
      letter-spacing: 0;
      color: #E8A8A8;
    }
    .form__field.is-invalid .form__error { display: block; }

    .form__checkbox {
      display: flex;
      align-items: flex-start;
      gap: 14px;
      padding: 12px 0 8px;
    }
    .form__checkbox input[type="checkbox"] {
      width: 18px;
      height: 18px;
      margin-top: 3px;
      accent-color: var(--brand);
      flex-shrink: 0;
      cursor: pointer;
    }
    .form__checkbox label {
      font-size: 13px;
      line-height: 1.65;
      color: rgba(255,255,255,0.82);
      cursor: pointer;
    }
    .form__checkbox a {
      color: var(--brand-light);
      text-decoration: underline;
      text-underline-offset: 3px;
      text-decoration-color: rgba(212,185,135,0.45);
      transition: text-decoration-color .3s var(--ease);
    }
    .form__checkbox a:hover { text-decoration-color: var(--brand-light); }
    .form__checkbox.is-invalid label { color: #E8A8A8; }

    .form .btn { margin-top: 14px; }
    .form .btn[disabled],
    .form .btn.is-loading {
      cursor: wait;
      opacity: 0.85;
      animation: none;
    }
    .form .btn.is-loading::after {
      content: "";
      width: 16px;
      height: 16px;
      margin-left: 4px;
      border: 2px solid rgba(255,255,255,0.35);
      border-top-color: var(--white);
      border-radius: 50%;
      animation: btnSpin 0.7s linear infinite;
    }
    @keyframes btnSpin {
      to { transform: rotate(360deg); }
    }

    /* Estado de sucesso — substitui o formulário */
    .form__success {
      display: none;
      flex-direction: column;
      align-items: center;
      gap: 20px;
      padding: clamp(40px, 5vw, 64px) clamp(24px, 3vw, 40px);
      text-align: center;
      background:
        radial-gradient(ellipse at top, rgba(197,165,114,0.10), transparent 70%),
        rgba(255,255,255,0.02);
      border: 1px solid var(--border-gold);
      border-radius: 12px;
    }
    .form__success.is-visible { display: flex; }
    .form__success-icon {
      width: 72px;
      height: 72px;
      display: flex;
      align-items: center;
      justify-content: center;
      border: 1px solid var(--brand);
      border-radius: 50%;
      color: var(--brand-light);
      background: radial-gradient(circle at 35% 30%, rgba(212,185,135,0.18), transparent 70%);
      box-shadow: 0 0 0 8px rgba(197,165,114,0.06), 0 12px 30px rgba(0,0,0,0.3);
    }
    .form__success-icon svg { width: 30px; height: 30px; stroke: currentColor; fill: none; stroke-width: 1.4; stroke-linecap: round; stroke-linejoin: round; }
    .form__success-titulo {
      margin: 0;
      font-family: 'Playfair Display', Georgia, serif;
      font-style: italic;
      font-weight: 400;
      font-size: clamp(26px, 3vw, 34px);
      line-height: 1.2;
      color: var(--white);
    }
    .form__success-texto {
      margin: 0;
      max-width: 460px;
      font-size: clamp(14px, 1.05vw, 15.5px);
      line-height: 1.75;
      color: rgba(255,255,255,0.74);
    }

    /* Banner de erro de envio */
    .form__error-banner {
      display: none;
      margin-top: 6px;
      padding: 12px 16px;
      border: 1px solid rgba(226,117,117,0.4);
      border-radius: 8px;
      background: rgba(226,117,117,0.08);
      font-size: 13px;
      line-height: 1.55;
      color: #F2C5C5;
      text-align: left;
    }
    .form__error-banner.is-visible { display: block; }

    /* =========================================================
       FOOTER
       ========================================================= */
    .rodape {
      padding: clamp(64px, 9vw, 110px) 0 clamp(28px, 3.5vw, 40px);
      background: linear-gradient(180deg, #0A0A0A 0%, #050505 100%);
      color: rgba(255,255,255,0.7);
      text-align: center;
    }
    .rodape__inner {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: clamp(22px, 2.6vw, 32px);
    }
    .rodape__logo img {
      height: clamp(36px, 4.5vw, 56px);
      width: auto;
      opacity: 0.92;
      filter: brightness(0) invert(1);
    }
    .rodape__redes {
      margin: 0;
      font-size: 13px;
      line-height: 1.7;
      color: rgba(255,255,255,0.66);
      letter-spacing: 0.02em;
      text-align: center;
    }
    .rodape__redes-icons {
      display: flex;
      justify-content: center;
      gap: 14px;
      margin-top: 14px;
    }
    .rodape__social {
      width: 42px;
      height: 42px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border-radius: 50%;
      border: 1px solid rgba(255,255,255,0.14);
      transition: transform .3s var(--ease), border-color .3s var(--ease), background .3s var(--ease);
    }
    .rodape__social img {
      width: 18px;
      height: 18px;
      filter: brightness(0) invert(1);
      opacity: 0.85;
      transition: opacity .3s var(--ease);
    }
    .rodape__social:hover {
      transform: translateY(-3px);
      border-color: var(--brand);
      background: rgba(197,165,114,0.08);
    }
    .rodape__social:hover img { opacity: 1; }

    .rodape__divisor {
      width: 100%;
      max-width: 280px;
      height: 1px;
      background: linear-gradient(90deg, transparent, rgba(197,165,114,0.4), transparent);
    }
    .rodape__copy {
      margin: 0;
      font-size: 10px;
      letter-spacing: 0.28em;
      text-transform: uppercase;
      color: rgba(255,255,255,0.4);
    }

    /* =========================================================
       RESPONSIVO
       ========================================================= */
    @media (max-width: 900px) {
      .galeria__marquee-track { animation-duration: 40s; }
    }

    @media (max-width: 640px) {
      .detalhes__grid { grid-template-columns: 1fr; gap: clamp(32px, 6vw, 48px); }
      .detalhes__spine {
        width: clamp(80px, 18vw, 120px);
        height: 1px;
        background: linear-gradient(90deg, transparent, rgba(197,165,114,0.5), transparent);
      }
      .btn { padding: 16px 32px; letter-spacing: 0.22em; }
      .hero__inner { padding-top: clamp(100px, 14vh, 140px); padding-left: 20px; padding-right: 20px; }
      .galeria__marquee-track { animation-duration: 32s; }
      .galeria__marquee-item { height: clamp(220px, 50vw, 280px); }
      .galeria__marquee {
        -webkit-mask-image: linear-gradient(to right, transparent 0, #000 4%, #000 96%, transparent 100%);
                mask-image: linear-gradient(to right, transparent 0, #000 4%, #000 96%, transparent 100%);
      }
    }

    @media (prefers-reduced-motion: reduce) {
      html { scroll-behavior: auto; }
      *, *::before, *::after {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
      }
      .reveal { opacity: 1; transform: none; filter: none; }
      /* Marquee vira scroll horizontal manual */
      .galeria__marquee { overflow-x: auto; -webkit-overflow-scrolling: touch; }
      .galeria__marquee-track { animation: none; }
    }

