:root {
  /* Paleta RBB & Nexus */
  --navy: #120f0d;
  --navy-mid: #22170f;
  --navy-soft: #2d1d12;
  --accent-blue: #c69c6c;
  --accent-green: #e5c79a;
  --accent-gold: #c69c6c;
  --accent-gold-dark: #a57f54;

  /* Superfícies (tema claro elegante, diferente do ValourPay) */
  --white-color: #ffffff;
  --white-background: #fffdf9;
  --surface-muted: #f8f3eb;
  --surface-alt: #efe4d4;
  --paragraph-color: #5d5145;

  /* Marca — CTAs e destaques */
  --primary-color: var(--accent-gold);
  --primary-text: var(--accent-gold);
  --btn-color: var(--accent-gold);
  --btn-hover: var(--accent-gold-dark);
  --btn-text-on-primary: #120f0d;

  /* Hero / slideshow — overlay escuro com dourado da marca */
  --background-color: var(--navy);
  --background-linear-color: linear-gradient(
    115deg,
    rgba(18, 15, 13, 0.96) 0%,
    rgba(34, 23, 15, 0.82) 48%,
    rgba(198, 156, 108, 0.28) 100%
  );
  --background-overlay: linear-gradient(
    120deg,
    rgba(18, 15, 13, 0.9) 0%,
    rgba(198, 156, 108, 0.22) 55%,
    transparent 100%
  );

  /* Seções */
  --background-gallery: linear-gradient(
    165deg,
    var(--navy) 0%,
    var(--navy-mid) 45%,
    #4a3822 100%
  );
  --background-contact: linear-gradient(
    165deg,
    #faf6ef 0%,
    #f6efe4 55%,
    #ede2d1 100%
  );
  --background-second: var(--surface-muted);

  /* Gradientes de acento (ícones, underlines) */
  --gradient-brand: linear-gradient(
    135deg,
    var(--accent-blue) 0%,
    var(--accent-green) 100%
  );
  --gradient-brand-soft: linear-gradient(
    90deg,
    rgba(198, 156, 108, 0.15) 0%,
    rgba(229, 199, 154, 0.16) 100%
  );

  --accent-highlight: var(--accent-blue);

  /* Navegação */
  --menu-header-color: rgba(255, 252, 247, 0.95);
  --menu-header-text: #2c231b;

  /* Elevação e forma */
  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-pill: 999px;
  --shadow-sm: 0 2px 10px rgba(18, 15, 13, 0.08);
  --shadow-md: 0 10px 32px rgba(18, 15, 13, 0.14);
  --shadow-glow-gold: 0 4px 24px rgba(198, 156, 108, 0.3);
  --shadow-lg: 0 22px 56px rgba(18, 15, 13, 0.16);
  --shadow-inner-vignette: inset 0 0 100px rgba(18, 15, 13, 0.35);
  --border-hairline: 1px solid rgba(18, 15, 13, 0.1);
  --border-accent-soft: 1px solid rgba(198, 156, 108, 0.24);
  --radius-lg: 20px;
  --section-py: clamp(3.5rem, 6vw, 5.5rem);
  --transition-smooth: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-spring: 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);

  /* Animações — curvas e durações unificadas */
  --ease-reveal: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-nav: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-hero: cubic-bezier(0.2, 0.85, 0.35, 1);
  --dur-reveal: 0.88s;
  --dur-hero: 0.92s;
  --dur-nav: 1s;

  /* Texto principal (títulos) — separado do navy usado em fundos da marca */
  --text-primary: #201811;

  /* Topbar */
  --nav-surface: rgba(255, 252, 247, 0.92);
  --nav-border: rgba(18, 15, 13, 0.09);
  --nav-link: rgba(36, 29, 24, 0.82);
  --nav-link-hover-bg: rgba(198, 156, 108, 0.18);
  --nav-link-hover-text: #1f1811;
  --nav-shadow: 0 4px 24px rgba(18, 15, 13, 0.1);
}

/* Tema escuro — mantém --navy / hero; ajusta superfícies e tipografia */
html[data-theme="dark"] {
  color-scheme: dark;
}

[data-theme="dark"] {
  --text-primary: #f2e7d5;
  --paragraph-color: #c9bba7;

  --white-background: #1c1713;
  --surface-muted: #120f0d;
  --surface-alt: #191411;

  --menu-header-text: #f2e7d5;

  --background-contact: linear-gradient(
    165deg,
    var(--surface-muted) 0%,
    var(--surface-alt) 52%,
    #16120f 100%
  );
  --background-second: var(--surface-alt);

  --border-hairline: 1px solid rgba(255, 255, 255, 0.08);
  --border-accent-soft: 1px solid rgba(198, 156, 108, 0.28);

  --shadow-sm: 0 2px 10px rgba(0, 0, 0, 0.35);
  --shadow-md: 0 10px 32px rgba(0, 0, 0, 0.45);
  --shadow-lg: 0 22px 56px rgba(0, 0, 0, 0.55);
  --shadow-glow-gold: 0 4px 24px rgba(198, 156, 108, 0.2);

  --gradient-brand-soft: linear-gradient(
    90deg,
    rgba(198, 156, 108, 0.22) 0%,
    rgba(229, 199, 154, 0.16) 100%
  );

  --nav-surface: rgba(19, 15, 13, 0.94);
  --nav-border: rgba(255, 255, 255, 0.08);
  --nav-link: rgba(242, 231, 213, 0.82);
  --nav-link-hover-bg: rgba(198, 156, 108, 0.16);
  --nav-link-hover-text: #fff5e6;
  --nav-shadow: 0 4px 28px rgba(0, 0, 0, 0.45);
}

/* Reveals de seção (scroll) */
@keyframes revealUpFade {
  from {
    opacity: 0;
    transform: translate3d(0, 48px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes revealFromLeft {
  from {
    opacity: 0;
    transform: translate3d(-52px, 0, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes revealFromRight {
  from {
    opacity: 0;
    transform: translate3d(52px, 0, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

/* Hero / slideshow — entrada mais legível */
@keyframes heroSlideInRight {
  from {
    opacity: 0;
    transform: translate3d(72px, 36px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes heroSlideInLeft {
  from {
    opacity: 0;
    transform: translate3d(-56px, 28px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
