@font-face {
  font-family: "Hurme Geometric Sans";
  src: url("fonts/HurmeGeometricSans4-Light.woff2") format("woff2");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Hurme Geometric Sans";
  src: url("fonts/HurmeGeometricSans4-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Hurme Geometric Sans";
  src: url("fonts/HurmeGeometricSans4-SemiBold.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Hurme Geometric Sans";
  src: url("fonts/HurmeGeometricSans4-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --ivory: #f5efe6;
  --ivory-2: #fbf7f0;
  --champagne: #efe3d2;
  --ink: #211812;
  --muted: #75685f;
  --marsala: #5c1d24;
  --marsala-deep: #351116;
  --gold: #c9a35a;
  --gold-soft: #e9d6aa;
  --copper: #a66a3f;
  --line: rgba(201, 163, 90, .32);
  --glass: rgba(255, 252, 246, .72);
  --shadow: 0 28px 90px rgba(53, 17, 22, .16);
  --radius-xl: 34px;
  --radius-lg: 24px;
  --radius-md: 16px;
  --max: 1180px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: "Hurme Geometric Sans", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at 15% 10%, rgba(201, 163, 90, .16), transparent 31%),
    radial-gradient(circle at 90% 7%, rgba(92, 29, 36, .13), transparent 28%),
    linear-gradient(135deg, var(--ivory), var(--ivory-2) 44%, #efe1d1);
  line-height: 1.6;
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(115deg, transparent 0 22%, rgba(255, 255, 255, .28) 31%, transparent 45%),
    repeating-linear-gradient(90deg, rgba(255,255,255,.10) 0 1px, transparent 1px 110px);
  opacity: .55;
  z-index: -1;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

.skip-link {
  position: absolute;
  left: 18px;
  top: -60px;
  z-index: 999;
  padding: 12px 16px;
  border-radius: 999px;
  background: var(--marsala);
  color: var(--ivory);
  transition: top .2s ease;
}

.skip-link:focus { top: 18px; }

.site-header {
  position: fixed;
  top: 18px;
  left: 50%;
  transform: translateX(-50%);
  width: min(calc(100% - 32px), var(--max));
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 12px 14px 12px 20px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(251, 247, 240, .78);
  backdrop-filter: blur(20px);
  box-shadow: 0 16px 48px rgba(33, 24, 18, .08);
}

.brand img { width: 178px; height: auto; }
.nav { display: flex; align-items: center; gap: 6px; }

.nav a {
  padding: 10px 14px;
  border-radius: 999px;
  color: var(--muted);
  font-size: .78rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  transition: color .2s ease, background .2s ease;
}

.nav a:hover, .nav a:focus-visible { color: var(--marsala); background: rgba(201, 163, 90, .12); }


/* V19 — seletor de idioma PT / EN / ES */
.header-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-left: auto;
}

.language-switch {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 4px;
  border: 1px solid rgba(201, 163, 90, .34);
  border-radius: 999px;
  background: rgba(251, 247, 240, .68);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.72);
}

.language-switch a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  height: 30px;
  padding: 0 9px;
  border-radius: 999px;
  color: var(--muted);
  font-size: .68rem;
  letter-spacing: .12em;
  font-weight: 700;
  text-transform: uppercase;
  transition: background .2s ease, color .2s ease, box-shadow .2s ease;
}

.language-switch a:hover,
.language-switch a:focus-visible {
  color: var(--marsala);
  background: rgba(201, 163, 90, .12);
}

.language-switch a.is-active {
  color: var(--ivory-2);
  background: linear-gradient(135deg, var(--marsala), var(--marsala-deep));
  box-shadow: 0 8px 20px rgba(92, 29, 36, .16);
}

@media (max-width: 980px) {
  .header-actions {
    margin-left: 0;
  }
}

@media (max-width: 640px) {
  .site-header {
    gap: 8px;
    padding: 10px 10px 10px 14px;
  }

  .language-switch {
    padding: 3px;
  }

  .language-switch a {
    min-width: 28px;
    height: 26px;
    padding: 0 7px;
    font-size: .62rem;
    letter-spacing: .08em;
  }

  .menu-button strong {
    display: none;
  }
}

.menu-button {
  display: none;
  border: 0;
  background: transparent;
  align-items: center;
  gap: 6px;
  color: var(--marsala);
  font: inherit;
  cursor: pointer;
}

.menu-button span { width: 18px; height: 1px; background: var(--marsala); display: block; }
.menu-button strong { margin-left: 4px; font-size: .75rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 600; }

.section { width: min(calc(100% - 38px), var(--max)); margin-inline: auto; }

.hero {
  min-height: 100vh;
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(360px, .98fr);
  gap: clamp(34px, 5vw, 76px);
  align-items: center;
  padding: 150px 0 92px;
}

.eyebrow, .section-label {
  margin: 0 0 18px;
  color: var(--copper);
  font-size: .76rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  font-weight: 600;
}

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

h1 {
  margin-bottom: 22px;
  font-size: clamp(3.45rem, 8.6vw, 8.2rem);
  line-height: .9;
  letter-spacing: -.08em;
  font-weight: 300;
}

h2 {
  margin-bottom: 22px;
  font-size: clamp(2.1rem, 4.8vw, 4.7rem);
  line-height: .98;
  letter-spacing: -.055em;
  font-weight: 300;
}

h3 { font-size: 1.25rem; line-height: 1.2; letter-spacing: -.02em; }

.slogan {
  max-width: 690px;
  margin-bottom: 22px;
  font-size: clamp(1.26rem, 2.1vw, 1.72rem);
  line-height: 1.34;
  color: var(--marsala);
  font-weight: 300;
}

.lead { max-width: 650px; margin-bottom: 34px; color: var(--muted); font-size: 1.05rem; }
.hero__actions { display: flex; flex-wrap: wrap; gap: 14px; }

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 14px 20px;
  border-radius: 999px;
  border: 1px solid var(--line);
  font-size: .78rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 600;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.button:hover, .button:focus-visible { transform: translateY(-2px); box-shadow: 0 18px 44px rgba(92, 29, 36, .18); }
.button--primary { color: var(--ivory-2); background: linear-gradient(135deg, var(--marsala), var(--marsala-deep)); border-color: rgba(201, 163, 90, .46); }
.button--ghost { background: rgba(251, 247, 240, .6); color: var(--marsala); }

.hero__visual { position: relative; min-height: 680px; }
.hero__visual::before {
  content: "";
  position: absolute;
  inset: 11% 9% 8% 0;
  border: 1px solid var(--line);
  border-radius: 999px 999px 40px 40px;
  background: linear-gradient(160deg, rgba(201, 163, 90, .20), rgba(255, 255, 255, .08));
  box-shadow: var(--shadow);
}

.visual-card {
  position: absolute;
  margin: 0;
  overflow: hidden;
  border-radius: 999px 999px 30px 30px;
  border: 1px solid rgba(201, 163, 90, .45);
  box-shadow: 0 28px 70px rgba(53, 17, 22, .2);
  background: var(--glass);
}

.visual-card img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.95) contrast(.98); }
.visual-card--one { inset: 0 14% auto 7%; height: 420px; }
.visual-card--two { right: 0; bottom: 54px; width: 44%; height: 315px; border-radius: 26px; }
.visual-card--three { left: 0; bottom: 0; width: 47%; height: 360px; border-radius: 28px; }

.intro, .services, .ritual, .international, .agenda, .manifesto, .atelier, .signature, .natural, .characters, .editorial-rio { padding: 88px 0; }

.manifesto, .atelier, .signature, .agenda, .ritual, .intro__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .66fr);
  gap: clamp(28px, 5vw, 68px);
  align-items: center;
}

.manifesto__copy { max-width: 740px; }
.manifesto__copy p, .atelier__content p, .signature__content p, .intro__copy p, .ritual__content p, .international__box p, .agenda__content p, .agenda__card p, .service-card p, .footer p, .footer small, .natural .section-heading p { color: var(--muted); }

.manifesto__image, .atelier__media, .ritual__image { border: 1px solid var(--line); overflow: hidden; box-shadow: var(--shadow); background: rgba(255,255,255,.3); }
.manifesto__image { min-height: 620px; border-radius: 999px 999px 34px 34px; }
.manifesto__image img, .atelier__media img, .ritual__image img { width: 100%; height: 100%; object-fit: cover; }
.manifesto__image img { min-height: 620px; object-position: center center; }

.intro__grid, .agenda, .ritual { grid-template-columns: minmax(0, 1fr) minmax(320px, .55fr); }
.intro__note, .agenda__card, .international__box, .service-card { border: 1px solid var(--line); background: rgba(251, 247, 240, .62); backdrop-filter: blur(14px); box-shadow: 0 22px 70px rgba(33, 24, 18, .06); }
.intro__note { padding: 34px; border-radius: var(--radius-xl); }
.intro__note span, .service-card span { display: inline-block; margin-bottom: 26px; color: var(--gold); font-size: .72rem; letter-spacing: .18em; text-transform: uppercase; font-weight: 600; }
.intro__note a, .quiet-link { display: inline-block; margin-top: 14px; color: var(--marsala); border-bottom: 1px solid rgba(201, 163, 90, .55); font-size: .92rem; }

.section-heading { max-width: 760px; margin-bottom: 42px; }

.atelier { grid-template-columns: .62fr 1fr; }
.atelier__media { min-height: 640px; border-radius: 34px 34px 999px 999px; }
.atelier__media img { min-height: 640px; object-position: center center; }
.atelier__stats { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; margin-top: 34px; }
.atelier__stats span { min-height: 128px; padding: 22px; border: 1px solid var(--line); border-radius: 24px; background: rgba(251, 247, 240, .55); color: var(--muted); font-size: .76rem; letter-spacing: .12em; text-transform: uppercase; }
.atelier__stats strong { display: block; margin-bottom: 12px; color: var(--marsala); font-size: clamp(2.1rem, 4vw, 3.6rem); line-height: .9; letter-spacing: -.06em; font-weight: 300; text-transform: none; }

.service-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.service-card { min-height: 254px; padding: 30px; border-radius: var(--radius-lg); transition: transform .2s ease, border-color .2s ease, background .2s ease; }
.service-card:hover { transform: translateY(-4px); border-color: rgba(201, 163, 90, .62); background: rgba(255, 252, 246, .82); }

.signature { grid-template-columns: .58fr 1fr; }
.signature__grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.signature__grid figure, .natural-card, .character-strip figure, .rio-grid figure { position: relative; margin: 0; overflow: hidden; border: 1px solid var(--line); background: rgba(251, 247, 240, .62); box-shadow: 0 24px 70px rgba(53, 17, 22, .12); }
.signature__grid figure { height: 420px; border-radius: 28px; }
.signature__grid figure:nth-child(2) { margin-top: 44px; }
.signature__grid figure:nth-child(3) { margin-top: 88px; }
.signature__grid img, .natural-card img, .character-strip img, .rio-grid img { width: 100%; height: 100%; object-fit: cover; }
.signature__grid figcaption, .natural-card figcaption, .character-strip figcaption, .rio-grid figcaption { position: absolute; left: 18px; right: 18px; bottom: 18px; padding: 12px 14px; border: 1px solid rgba(201, 163, 90, .33); border-radius: 999px; background: rgba(251, 247, 240, .76); backdrop-filter: blur(16px); color: var(--marsala); font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 600; text-align: center; }

.ritual { grid-template-columns: .72fr 1fr; }
.ritual__image { border-radius: 999px 999px 34px 34px; min-height: 560px; }
.ritual__image img { min-height: 560px; object-position: center center; }
.check-list { display: grid; gap: 13px; margin: 26px 0 0; padding: 0; list-style: none; }
.check-list li { position: relative; padding-left: 28px; color: var(--muted); }
.check-list li::before { content: ""; position: absolute; left: 0; top: .72em; width: 12px; height: 1px; background: var(--gold); }

.natural-grid { display: grid; grid-template-columns: 1.08fr .92fr; grid-template-rows: repeat(2, minmax(260px, 1fr)); gap: 18px; }
.natural-card { min-height: 320px; border-radius: 32px; }
.natural-card--large { grid-row: 1 / span 2; min-height: 650px; border-radius: 999px 999px 34px 34px; }
.natural-card--large img { object-position: center center; }
.natural-card:nth-child(2) img { object-position: center 38%; }
.natural-card:nth-child(3) img { object-position: center 18%; }

.rio-grid { display: grid; grid-template-columns: 1.1fr .9fr .9fr; grid-auto-rows: 330px; gap: 18px; }
.rio-grid figure { border-radius: 30px; }
.rio-grid .rio-tall { grid-row: span 2; border-radius: 999px 999px 34px 34px; }
.rio-grid .rio-tall img { object-position: center center; }

.character-strip { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.character-strip figure { height: 420px; border-radius: 999px 999px 28px 28px; }
.character-strip figure:nth-child(even) { margin-top: 46px; }

.editorial { width: 100%; max-width: none; padding: 42px 0; overflow: hidden; border-block: 1px solid var(--line); background: linear-gradient(90deg, rgba(92,29,36,.07), rgba(201,163,90,.10), rgba(92,29,36,.07)); }
.marquee { display: flex; gap: clamp(28px, 5vw, 78px); justify-content: center; white-space: nowrap; color: rgba(53, 17, 22, .54); font-size: clamp(1.1rem, 2.4vw, 2.5rem); letter-spacing: -.04em; }
.marquee span::after { content: ""; display: inline-block; width: 7px; height: 7px; margin-left: clamp(28px, 5vw, 78px); border-radius: 50%; background: var(--gold); vertical-align: middle; }

.international__box { max-width: 860px; margin-inline: auto; padding: clamp(34px, 6vw, 70px); border-radius: var(--radius-xl); text-align: center; }
.international__box p { max-width: 680px; margin-inline: auto; }
.agenda__card { padding: 34px; border-radius: var(--radius-xl); }
.agenda__card p { padding-left: 18px; border-left: 1px solid var(--gold); }

.footer { width: min(calc(100% - 38px), var(--max)); margin: 40px auto 28px; padding: 34px; display: grid; grid-template-columns: 1fr auto; gap: 22px; align-items: end; border: 1px solid var(--line); border-radius: var(--radius-xl); background: rgba(251, 247, 240, .75); }
.footer img { width: 180px; margin-bottom: 18px; }
.footer p { max-width: 470px; margin-bottom: 0; }
.footer nav { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 14px; color: var(--marsala); font-size: .8rem; letter-spacing: .12em; text-transform: uppercase; }
.footer small { grid-column: 1 / -1; border-top: 1px solid var(--line); padding-top: 18px; }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .72s ease, transform .72s ease; }
.reveal.is-visible { opacity: 1; transform: translateY(0); }

@media (max-width: 980px) {
  .menu-button { display: inline-flex; }
  .nav { position: absolute; top: calc(100% + 12px); right: 0; width: min(320px, calc(100vw - 34px)); padding: 12px; display: none; flex-direction: column; align-items: stretch; border: 1px solid var(--line); border-radius: 22px; background: rgba(251, 247, 240, .96); box-shadow: var(--shadow); }
  .nav.is-open { display: flex; }
  .nav a { padding: 14px 16px; }
  .hero, .intro__grid, .agenda, .ritual, .manifesto, .atelier, .signature { grid-template-columns: 1fr; }
  .hero__visual { min-height: 520px; }
  .visual-card--one { height: 330px; }
  .visual-card--two { height: 250px; bottom: 34px; }
  .visual-card--three { height: 270px; }
  .service-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .atelier__stats { grid-template-columns: 1fr; }
  .signature__grid { grid-template-columns: 1fr; }
  .signature__grid figure, .signature__grid figure:nth-child(2), .signature__grid figure:nth-child(3) { margin-top: 0; height: 360px; }
  .natural-grid { grid-template-columns: 1fr; grid-template-rows: auto; }
  .natural-card--large { grid-row: auto; min-height: 520px; }
  .natural-card { min-height: 460px; }
  .rio-grid { grid-template-columns: 1fr 1fr; }
  .rio-grid .rio-tall { grid-row: auto; grid-column: 1 / -1; min-height: 520px; }
  .character-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .character-strip figure:nth-child(even) { margin-top: 0; }
}

@media (max-width: 640px) {
  .site-header { top: 10px; width: calc(100% - 20px); }
  .brand img { width: 148px; }
  .section { width: min(calc(100% - 26px), var(--max)); }
  .hero { padding-top: 126px; padding-bottom: 60px; }
  h1 { font-size: clamp(3rem, 18vw, 4.8rem); }
  .hero__actions { display: grid; }
  .button { width: 100%; }
  .hero__visual { min-height: 460px; }
  .visual-card--one { inset: 0 7% auto 7%; height: 300px; }
  .visual-card--two { width: 48%; height: 220px; right: 0; }
  .visual-card--three { width: 50%; height: 240px; }
  .intro, .services, .ritual, .international, .agenda, .manifesto, .atelier, .signature, .natural, .characters, .editorial-rio { padding: 60px 0; }
  .service-grid { grid-template-columns: 1fr; }
  .service-card { min-height: auto; }
  .manifesto__image, .manifesto__image img, .atelier__media, .atelier__media img, .ritual__image, .ritual__image img { min-height: 430px; border-radius: 28px; }
  .signature__grid figure { height: 320px; }
  .natural-card, .natural-card--large { min-height: 420px; border-radius: 28px; }
  .rio-grid { grid-template-columns: 1fr; grid-auto-rows: 430px; }
  .rio-grid .rio-tall { min-height: 430px; border-radius: 28px; }
  .character-strip { grid-template-columns: 1fr; }
  .character-strip figure { height: 460px; border-radius: 28px; }
  .natural-card figcaption, .character-strip figcaption, .rio-grid figcaption, .signature__grid figcaption { left: 12px; right: 12px; bottom: 12px; border-radius: 18px; }
  .marquee { justify-content: flex-start; padding-left: 16px; }
  .footer { width: calc(100% - 26px); grid-template-columns: 1fr; align-items: start; }
  .footer nav { justify-content: flex-start; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: .001ms !important; }
  .reveal { opacity: 1; transform: none; }
}

/* V4 — ajuste cirúrgico de enquadramento das imagens
   Objetivo: preservar rostos/cabelos dentro dos blocos sem cortar personagens. */
.visual-card--one {
  inset: 0 12% auto 5%;
  height: 462px;
}

.visual-card--one img {
  object-position: center 8%;
}

.visual-card--two img {
  object-position: center 46%;
}

.visual-card--three img {
  object-position: 58% center;
}

.natural-card--large img {
  object-position: 58% center;
}

.natural-card:nth-child(2) img {
  object-position: center 44%;
}

.natural-card:nth-child(3) img {
  object-position: center 10%;
}

.rio-grid figure img {
  object-position: center center;
}

.rio-grid figure:nth-child(2) img {
  object-position: center 26%;
}

.rio-grid figure:nth-child(3) img {
  object-position: center 30%;
}

/* As personagens de corpo inteiro usam CONTAIN para não cortar cabeça, mãos ou pés. */
.character-strip figure {
  height: 500px;
  background:
    radial-gradient(circle at 50% 18%, rgba(255,255,255,.92), rgba(251,247,240,.62) 52%, rgba(233,214,170,.22));
}

.character-strip img {
  object-fit: contain;
  object-position: center bottom;
  padding: 26px 10px 58px;
}

.character-strip figure:first-child img {
  padding-inline: 22px;
}

.signature__grid figure:nth-child(1) img,
.signature__grid figure:nth-child(2) img,
.signature__grid figure:nth-child(3) img {
  object-position: center center;
}

@media (max-width: 980px) {
  .visual-card--one { height: 365px; }
  .character-strip figure { height: 500px; }
}

@media (max-width: 640px) {
  .visual-card--one {
    inset: 0 7% auto 7%;
    height: 320px;
  }

  .visual-card--one img {
    object-position: center 6%;
  }

  .character-strip figure { height: 520px; }
  .character-strip img { padding: 22px 8px 58px; }
}


/* V5 — ajustes cirúrgicos de imagem, cabelo em evidência e base futura Rio/São Paulo */
:root {
  --city-current: "Rio de Janeiro";
}

.slogan--single {
  max-width: 760px;
  text-wrap: balance;
}

.hero__visual {
  min-height: 720px;
}

.hero__visual::before {
  inset: 7% 5% 6% 3%;
  background: linear-gradient(160deg, rgba(255, 252, 246, .72), rgba(233, 214, 170, .16));
}

.visual-card--one {
  inset: 0 7% auto 4%;
  height: 510px;
  border-radius: 999px 999px 34px 34px;
}

.visual-card--one img {
  object-position: center 34%;
}

.visual-card--two {
  right: 2%;
  bottom: 46px;
  width: 39%;
  height: 360px;
}

.visual-card--three {
  left: 1%;
  bottom: 0;
  width: 43%;
  height: 390px;
}

.visual-card--two img,
.visual-card--three img {
  object-position: center center;
}

/* Resultado: imagens de biquíni/externas viram close de cabelo, sem foco em corpo */
.natural-grid {
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: auto;
  gap: 18px;
}

.natural-card,
.natural-card--large {
  min-height: 640px;
  grid-row: auto;
  border-radius: 999px 999px 34px 34px;
}

.natural-card img,
.natural-card--large img {
  object-fit: cover;
}

.natural-card--large img {
  object-position: 58% 38%;
}

.natural-card:nth-child(2) img {
  object-position: 58% 34%;
}

.natural-card:nth-child(3) img {
  object-position: 50% 28%;
}

/* Universo editorial: evita cabeça cortada e centraliza melhor */
.rio-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-auto-rows: 560px;
}

.rio-grid .rio-tall {
  grid-row: auto;
  border-radius: 30px;
}

.rio-grid figure img {
  object-position: center center;
}

.rio-grid figure:nth-child(4) img {
  object-position: center top;
}

/* Personagens: fundos harmonizados e figura inteira visível */
.character-strip figure {
  height: 520px;
  border-radius: 999px 999px 28px 28px;
  background: linear-gradient(180deg, rgba(251,247,240,.96), rgba(239,225,209,.66));
}

.character-strip img {
  object-fit: contain;
  object-position: center bottom;
  padding: 18px 12px 58px;
  background: transparent;
}

.footer p {
  max-width: 720px;
  text-wrap: balance;
}

@media (max-width: 980px) {
  .natural-grid,
  .rio-grid {
    grid-template-columns: 1fr;
  }

  .natural-card,
  .natural-card--large,
  .rio-grid figure,
  .rio-grid .rio-tall {
    min-height: 620px;
    height: auto;
  }

  .character-strip figure {
    height: 560px;
  }
}

@media (max-width: 640px) {
  .hero__visual {
    min-height: 560px;
  }

  .visual-card--one {
    height: 360px;
  }

  .visual-card--two,
  .visual-card--three {
    height: 260px;
  }

  .natural-card,
  .natural-card--large,
  .rio-grid figure,
  .rio-grid .rio-tall {
    min-height: 540px;
    border-radius: 28px;
  }

  .character-strip figure {
    height: 520px;
  }
}


/* V6 — cirurgia fina nos 4 blocos das personagens */
.characters {
  padding-top: 72px;
}

.character-strip {
  align-items: end;
  gap: 20px;
}

.character-strip figure {
  height: 610px;
  border-radius: 999px 999px 30px 30px;
  background:
    radial-gradient(circle at 50% 18%, rgba(255, 255, 255, .78), transparent 42%),
    linear-gradient(180deg, rgba(251,247,240,.98), rgba(239,225,209,.72));
  box-shadow: 0 24px 72px rgba(53, 17, 22, .10);
}

.character-strip figure::before {
  content: "";
  position: absolute;
  inset: 18px 18px 54px;
  border-radius: 999px 999px 26px 26px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.62), rgba(255,255,255,.18)),
    linear-gradient(135deg, rgba(201,163,90,.10), rgba(92,29,36,.035));
  border: 1px solid rgba(201, 163, 90, .20);
  pointer-events: none;
}

.character-strip img {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center bottom;
  padding: 30px 18px 78px;
  filter: saturate(1.03) contrast(1.02);
}

.character-strip figure:nth-child(1) img,
.character-strip figure:nth-child(2) img,
.character-strip figure:nth-child(3) img,
.character-strip figure:nth-child(4) img {
  transform: scale(1.08);
  transform-origin: center bottom;
}

.character-strip figcaption {
  z-index: 2;
  bottom: 18px;
  left: 22px;
  right: 22px;
  background: rgba(251, 247, 240, .88);
  color: var(--marsala);
  border-color: rgba(201, 163, 90, .42);
  box-shadow: 0 12px 30px rgba(53, 17, 22, .06);
}

.character-strip figure:hover {
  transform: translateY(-4px);
  border-color: rgba(201, 163, 90, .58);
}

.characters .section-heading {
  max-width: 820px;
}

.characters .section-heading h2 {
  text-wrap: balance;
}

@media (max-width: 980px) {
  .character-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .character-strip figure {
    height: 620px;
  }
}

@media (max-width: 640px) {
  .character-strip {
    grid-template-columns: 1fr;
  }

  .character-strip figure {
    height: 620px;
    border-radius: 34px;
  }

  .character-strip figure::before {
    border-radius: 28px;
  }

  .character-strip img {
    padding: 24px 14px 82px;
    transform: scale(1.04);
  }

  .character-strip figcaption {
    border-radius: 18px;
  }
}

/* V7 — cirurgia premium nos 4 cards das personagens
   Escopo: seção Personagens da marca. O restante do site permanece preservado. */
.characters {
  position: relative;
  padding-top: 82px;
  padding-bottom: 104px;
}

.characters::before {
  content: "";
  position: absolute;
  inset: 34px max(-4vw, -48px) 18px;
  z-index: -1;
  border-radius: 46px;
  background:
    radial-gradient(circle at 18% 8%, rgba(201, 163, 90, .14), transparent 30%),
    radial-gradient(circle at 86% 18%, rgba(92, 29, 36, .075), transparent 30%),
    linear-gradient(180deg, rgba(251, 247, 240, .58), rgba(239, 225, 209, .22));
  pointer-events: none;
}

.characters .section-heading {
  max-width: 840px;
  margin-bottom: 50px;
}

.character-strip {
  gap: clamp(18px, 2vw, 26px);
  align-items: stretch;
}

.character-strip figure {
  height: clamp(620px, 48vw, 700px);
  isolation: isolate;
  border-radius: 999px 999px 34px 34px;
  border: 1px solid rgba(201, 163, 90, .42);
  background:
    radial-gradient(circle at 50% 16%, rgba(255,255,255,.52), transparent 34%),
    linear-gradient(180deg, #fbf6ee 0%, #efe0cf 100%);
  box-shadow:
    0 34px 92px rgba(53, 17, 22, .16),
    inset 0 1px 0 rgba(255,255,255,.82),
    inset 0 -24px 54px rgba(92, 29, 36, .075);
}

.character-strip figure:nth-child(even) {
  margin-top: 0;
}

.character-strip figure::before {
  z-index: 0;
  inset: 14px 14px 64px;
  border-radius: 999px 999px 28px 28px;
  background:
    radial-gradient(circle at 50% 12%, rgba(255,255,255,.48), transparent 36%),
    radial-gradient(circle at 50% 72%, rgba(201,163,90,.18), transparent 46%),
    linear-gradient(135deg, rgba(92,29,36,.045), rgba(255,255,255,.13));
  border: 1px solid rgba(201, 163, 90, .24);
  box-shadow: inset 0 0 52px rgba(53, 17, 22, .045);
}

.character-strip figure::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  border-radius: inherit;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(53,17,22,.055) 0%, transparent 24%, transparent 58%, rgba(53,17,22,.22) 100%),
    radial-gradient(circle at 50% 46%, transparent 0 50%, rgba(92,29,36,.075) 100%);
  mix-blend-mode: multiply;
}

.character-strip img {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  padding: 0;
  background: transparent;
  transform: scale(1.01) !important;
  transform-origin: center center;
  filter: brightness(.965) contrast(1.17) saturate(1.12) sepia(.025);
}

.character-strip figure:nth-child(1) img { object-position: 50% center; }
.character-strip figure:nth-child(2) img { object-position: 50% center; }
.character-strip figure:nth-child(3) img { object-position: 50% center; }
.character-strip figure:nth-child(4) img { object-position: 51% center; }

.character-strip figcaption {
  z-index: 4;
  bottom: 20px;
  left: 24px;
  right: 24px;
  padding: 13px 15px 12px;
  border: 1px solid rgba(201, 163, 90, .56);
  background: rgba(251, 247, 240, .82);
  color: var(--marsala-deep);
  backdrop-filter: blur(18px) saturate(1.12);
  box-shadow:
    0 16px 38px rgba(53, 17, 22, .12),
    inset 0 1px 0 rgba(255,255,255,.72);
}

.character-strip figure:hover {
  transform: translateY(-6px);
  border-color: rgba(201, 163, 90, .68);
  box-shadow:
    0 40px 104px rgba(53, 17, 22, .20),
    inset 0 1px 0 rgba(255,255,255,.84),
    inset 0 -24px 54px rgba(92, 29, 36, .08);
}

@media (max-width: 980px) {
  .characters {
    padding-top: 72px;
    padding-bottom: 86px;
  }

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

  .character-strip figure {
    height: 680px;
  }
}

@media (max-width: 640px) {
  .characters {
    padding-top: 60px;
    padding-bottom: 70px;
  }

  .characters::before {
    inset: 20px -10px 10px;
    border-radius: 30px;
  }

  .character-strip {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .character-strip figure {
    height: min(660px, 126vw);
    border-radius: 34px;
  }

  .character-strip figure::before {
    inset: 12px 12px 62px;
    border-radius: 28px;
  }

  .character-strip figure::after {
    border-radius: 34px;
  }

  .character-strip img {
    transform: scale(1.005) !important;
    object-position: center center;
  }

  .character-strip figcaption {
    left: 14px;
    right: 14px;
    bottom: 14px;
    border-radius: 18px;
  }
}

/* V8 — ajuste fino apenas na Valentina
   Objetivo: reduzir aspecto lavado no primeiro card, aumentar presença
   e manter a integração elegante no bloco. */
.character-strip figure:first-child {
  background:
    radial-gradient(circle at 50% 14%, rgba(255,255,255,.34), transparent 28%),
    linear-gradient(180deg, #f2e6da 0%, #ddc8b1 100%);
  border-color: rgba(191, 151, 92, .50);
  box-shadow:
    0 36px 96px rgba(53, 17, 22, .18),
    inset 0 1px 0 rgba(255,255,255,.72),
    inset 0 -28px 58px rgba(117, 86, 62, .10);
}

.character-strip figure:first-child::before {
  background:
    radial-gradient(circle at 50% 12%, rgba(255,255,255,.30), transparent 33%),
    radial-gradient(circle at 50% 72%, rgba(191,151,92,.20), transparent 48%),
    linear-gradient(180deg, rgba(255,255,255,.10), rgba(158,128,102,.18));
  border-color: rgba(191, 151, 92, .28);
  box-shadow: inset 0 0 62px rgba(86, 52, 38, .06);
}

.character-strip figure:first-child::after {
  background:
    linear-gradient(180deg, rgba(53,17,22,.02) 0%, transparent 18%, transparent 56%, rgba(53,17,22,.16) 100%),
    radial-gradient(circle at 50% 52%, transparent 0 50%, rgba(92,29,36,.055) 100%);
}

.character-strip figure:first-child img {
  object-position: 51% center;
  transform: scale(1.035) !important;
  filter: brightness(.89) contrast(1.26) saturate(1.02) sepia(.03);
}

/* V10 — microcirurgia final na seção Personagens
   Escopo preservado: somente Valentina e Helena nos cards da seção. */

/* Valentina: fundo do bloco volta para um ivory/champagne mais coerente
   e a personagem fica menos alta/pesada no primeiro card. */
.character-strip figure:first-child {
  background:
    radial-gradient(circle at 50% 15%, rgba(255,255,255,.40), transparent 30%),
    linear-gradient(180deg, #f5ebe0 0%, #e5d1be 100%);
  border-color: rgba(201, 163, 90, .46);
  box-shadow:
    0 34px 92px rgba(53, 17, 22, .15),
    inset 0 1px 0 rgba(255,255,255,.76),
    inset 0 -24px 54px rgba(92, 29, 36, .07);
}

.character-strip figure:first-child::before {
  background:
    radial-gradient(circle at 50% 12%, rgba(255,255,255,.38), transparent 34%),
    radial-gradient(circle at 50% 74%, rgba(201,163,90,.16), transparent 48%),
    linear-gradient(135deg, rgba(92,29,36,.035), rgba(255,255,255,.14));
  border-color: rgba(201, 163, 90, .24);
}

.character-strip figure:first-child::after {
  background:
    linear-gradient(180deg, rgba(53,17,22,.035) 0%, transparent 22%, transparent 60%, rgba(53,17,22,.17) 100%),
    radial-gradient(circle at 50% 50%, transparent 0 52%, rgba(92,29,36,.052) 100%);
}

.character-strip figure:first-child img {
  transform: scale(.975) !important;
  object-position: 50% 52%;
  filter: brightness(.925) contrast(1.20) saturate(1.04) sepia(.025);
}

/* Helena: imagem levemente ampliada para o fundo completar melhor o bloco,
   sem mexer nos demais cards. */
.character-strip figure:nth-child(2) {
  background:
    radial-gradient(circle at 50% 15%, rgba(255,255,255,.46), transparent 32%),
    linear-gradient(180deg, #f6eadf 0%, #e6d0bd 100%);
  border-color: rgba(201, 163, 90, .46);
}

.character-strip figure:nth-child(2)::before {
  background:
    radial-gradient(circle at 50% 12%, rgba(255,255,255,.36), transparent 34%),
    radial-gradient(circle at 50% 74%, rgba(201,163,90,.17), transparent 48%),
    linear-gradient(135deg, rgba(92,29,36,.036), rgba(255,255,255,.14));
}

.character-strip figure:nth-child(2) img {
  transform: scale(1.065) !important;
  object-position: 50% 51%;
  filter: brightness(.96) contrast(1.18) saturate(1.09) sepia(.025);
}

@media (max-width: 640px) {
  .character-strip figure:first-child img {
    transform: scale(.965) !important;
    object-position: 50% 52%;
  }

  .character-strip figure:nth-child(2) img {
    transform: scale(1.045) !important;
    object-position: 50% 51%;
  }
}

/* V12 — correção definitiva da Valentina
   Escopo: apenas o primeiro card da seção Personagens da marca.
   Remove a leitura de quadrado/fundo recortado e evita corte da cabeça. */
.character-strip figure:first-child {
  background:
    radial-gradient(circle at 50% 15%, rgba(255,255,255,.46), transparent 32%),
    linear-gradient(180deg, #f8efe5 0%, #e4cfbc 100%) !important;
  overflow: hidden !important;
}

.character-strip figure:first-child::before {
  background:
    radial-gradient(circle at 50% 12%, rgba(255,255,255,.34), transparent 34%),
    radial-gradient(circle at 50% 74%, rgba(201,163,90,.16), transparent 48%),
    linear-gradient(135deg, rgba(92,29,36,.03), rgba(255,255,255,.14)) !important;
}

.character-strip figure:first-child::after {
  background:
    linear-gradient(180deg, rgba(53,17,22,.025) 0%, transparent 22%, transparent 62%, rgba(53,17,22,.14) 100%),
    radial-gradient(circle at 50% 50%, transparent 0 53%, rgba(92,29,36,.045) 100%) !important;
}

.character-strip figure:first-child img {
  object-fit: cover !important;
  object-position: 50% 50% !important;
  transform: scale(.94) !important;
  transform-origin: center center !important;
  filter: brightness(.97) contrast(1.11) saturate(1.035) sepia(.018) !important;
}

@media (max-width: 640px) {
  .character-strip figure:first-child img {
    object-position: 50% 50% !important;
    transform: scale(.93) !important;
  }
}


/* V13 — Valentina final
   Nova imagem-base já com respiro superior.
   Regra de segurança: não cortar cabeça, cabelo nem pés. */
.character-strip figure:first-child img {
  object-fit: contain !important;
  object-position: center center !important;
  transform: scale(.98) !important;
  padding: 0 !important;
  filter: brightness(.975) contrast(1.08) saturate(1.03) sepia(.015) !important;
}

.character-strip figure:first-child {
  background:
    radial-gradient(circle at 50% 15%, rgba(255,255,255,.46), transparent 32%),
    linear-gradient(180deg, #f6eadf 0%, #e6d0bd 100%) !important;
}


/* V14 — Valentina final aplicada como card completo.
   A imagem já contém fundo/alcova, então deve preencher o card,
   sem contain, sem padding e sem redução que crie quadro dentro do quadro. */
.character-strip figure:first-child img {
  object-fit: cover !important;
  object-position: center center !important;
  transform: none !important;
  padding: 0 !important;
  width: 100% !important;
  height: 100% !important;
  filter: brightness(.985) contrast(1.08) saturate(1.03) sepia(.015) !important;
}

.character-strip figure:first-child {
  background:
    radial-gradient(circle at 50% 15%, rgba(255,255,255,.46), transparent 32%),
    linear-gradient(180deg, #f6eadf 0%, #e6d0bd 100%) !important;
}


/* V15 — Valentina final top-safe
   Usa a nova imagem com arco completo e ancora pelo topo para não cortar o bloco. */
.character-strip figure:first-child img {
  object-fit: cover !important;
  object-position: center top !important;
  transform: none !important;
  padding: 0 !important;
  width: 100% !important;
  height: 100% !important;
  filter: brightness(.99) contrast(1.07) saturate(1.03) sepia(.012) !important;
}

.character-strip figure:first-child {
  background:
    radial-gradient(circle at 50% 15%, rgba(255,255,255,.46), transparent 32%),
    linear-gradient(180deg, #f6eadf 0%, #e6d0bd 100%) !important;
}


/* V17 — Valentina maior e com topo preservado
   Usa a nova arte do card completo, sem encolher a personagem. */
.character-strip figure:first-child img {
  object-fit: cover !important;
  object-position: center top !important;
  transform: none !important;
  padding: 0 !important;
  width: 100% !important;
  height: 100% !important;
  filter: brightness(.992) contrast(1.075) saturate(1.03) sepia(.012) !important;
}

/* V17 FINAL — correção cirúrgica Valentina + tarjas de nomes
   Escopo: somente seção Personagens da marca.
   - Valentina usa imagem sem teto, preservando cabeça e proporção.
   - Tarjas dos nomes ficam uniformes nas 4 personagens, inclusive Ayla. */

.character-strip figure:first-child img {
  object-fit: cover !important;
  object-position: 50% 50% !important;
  transform: scale(1.005) !important;
  padding: 0 !important;
  filter: brightness(.985) contrast(1.08) saturate(1.03) sepia(.012) !important;
}

.character-strip figcaption {
  background: rgba(251, 247, 240, .92) !important;
  border: 1px solid rgba(201, 163, 90, .60) !important;
  color: var(--marsala-deep) !important;
  opacity: 1 !important;
  backdrop-filter: blur(18px) saturate(1.08) !important;
  -webkit-backdrop-filter: blur(18px) saturate(1.08) !important;
  box-shadow:
    0 16px 38px rgba(53, 17, 22, .12),
    inset 0 1px 0 rgba(255,255,255,.78) !important;
}

.character-strip figure:nth-child(4) figcaption {
  background: rgba(251, 247, 240, .92) !important;
  border-color: rgba(201, 163, 90, .60) !important;
  opacity: 1 !important;
}

@media (max-width: 640px) {
  .character-strip figure:first-child img {
    object-fit: cover !important;
    object-position: 50% 50% !important;
    transform: scale(1.005) !important;
  }
}

/* V18 — Personagens mobile-safe | Estúdio Boutique Dyego Lima
   Escopo: somente seção #personagens.
   Objetivo: usar as quatro novas imagens na mesma proporção, sem zoom forçado,
   sem corte de teto/cabeça/cabelo no mobile e sem pseudo-camada escurecendo a imagem. */
.characters-v18 {
  position: relative;
  padding-top: clamp(64px, 7vw, 96px) !important;
  padding-bottom: clamp(72px, 8vw, 112px) !important;
}

.characters-v18::before {
  inset: 34px max(-4vw, -48px) 18px !important;
  border-radius: 46px !important;
  background:
    radial-gradient(circle at 16% 8%, rgba(201, 163, 90, .12), transparent 30%),
    radial-gradient(circle at 88% 16%, rgba(92, 29, 36, .055), transparent 30%),
    linear-gradient(180deg, rgba(251, 247, 240, .66), rgba(239, 225, 209, .20)) !important;
}

.characters-v18 .section-heading {
  max-width: 860px !important;
  margin-bottom: clamp(34px, 5vw, 54px) !important;
}

.characters-v18 .character-strip--v18 {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: clamp(16px, 2vw, 24px) !important;
  align-items: start !important;
}

.characters-v18 .character-card {
  position: relative !important;
  margin: 0 !important;
  height: auto !important;
  min-height: 0 !important;
  aspect-ratio: 921 / 1536 !important;
  overflow: hidden !important;
  border-radius: 999px 999px 34px 34px !important;
  border: 1px solid rgba(201, 163, 90, .44) !important;
  background: #f5efe6 !important;
  box-shadow:
    0 30px 86px rgba(53, 17, 22, .14),
    inset 0 1px 0 rgba(255,255,255,.78) !important;
  isolation: isolate !important;
}

.characters-v18 .character-card:nth-child(even) {
  margin-top: 0 !important;
}

.characters-v18 .character-card::before,
.characters-v18 .character-card::after {
  display: none !important;
  content: none !important;
}

.characters-v18 .character-card img {
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  transform: none !important;
  transform-origin: center center !important;
  padding: 0 !important;
  filter: brightness(1) contrast(1.035) saturate(1.018) sepia(.006) !important;
  background: transparent !important;
}

.characters-v18 .character-card--ayla img,
.characters-v18 .character-card--bianca img,
.characters-v18 .character-card--helena img,
.characters-v18 .character-card--valentina img {
  object-position: 50% 50% !important;
}

.characters-v18 .character-card figcaption {
  position: absolute !important;
  z-index: 4 !important;
  left: 18px !important;
  right: 18px !important;
  bottom: 18px !important;
  padding: 12px 14px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(201, 163, 90, .60) !important;
  background: rgba(251, 247, 240, .92) !important;
  color: var(--marsala-deep) !important;
  opacity: 1 !important;
  backdrop-filter: blur(16px) saturate(1.08) !important;
  -webkit-backdrop-filter: blur(16px) saturate(1.08) !important;
  box-shadow:
    0 16px 36px rgba(53, 17, 22, .12),
    inset 0 1px 0 rgba(255,255,255,.82) !important;
  font-size: .72rem !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  text-align: center !important;
  font-weight: 600 !important;
}

.characters-v18 .character-card:hover {
  transform: translateY(-4px) !important;
  border-color: rgba(201, 163, 90, .66) !important;
}

@media (max-width: 980px) {
  .characters-v18 .character-strip--v18 {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 640px) {
  .characters-v18 {
    padding-top: 58px !important;
    padding-bottom: 72px !important;
  }

  .characters-v18::before {
    inset: 18px -10px 12px !important;
    border-radius: 30px !important;
  }

  .characters-v18 .character-strip--v18 {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }

  .characters-v18 .character-card {
    width: min(100%, 430px) !important;
    justify-self: center !important;
    border-radius: 34px !important;
    aspect-ratio: 921 / 1536 !important;
  }

  .characters-v18 .character-card img {
    object-fit: cover !important;
    object-position: center center !important;
    transform: none !important;
  }

  .characters-v18 .character-card figcaption {
    left: 14px !important;
    right: 14px !important;
    bottom: 14px !important;
    border-radius: 18px !important;
  }
}
