/* ============================================================
   CASA PARAÍSO — estilo editorial de luxo (fiel ao boraboraone.com)
   Comercial · minimalista · aspiracional · muito respiro
   ============================================================ */

@font-face{font-family:'Fraunces';src:url('../fonts/fraunces-latin-wght-normal.woff2') format('woff2');font-weight:100 900;font-style:normal;font-display:swap}
@font-face{font-family:'Work Sans';src:url('../fonts/work-sans-latin-wght-normal.woff2') format('woff2');font-weight:100 900;font-style:normal;font-display:swap}

:root{
  --bg:#FCFBF8;            /* off-white quente, quase branco */
  --bg-soft:#F3EFE7;       /* areia clara p/ seção alternada */
  --ink:#1C2B22;           /* verde-quase-preto: texto */
  --ink-soft:#5C6A61;      /* muted */
  --line:rgba(28,43,34,.14);
  --gold:#A9884E;          /* dourado sóbrio (acento de luxo) */
  --gold-soft:#C6A15B;
  --dark:#14201A;          /* footer / faixas escuras */
  --on-dark:#F3EFE7;
  --on-dark-soft:#B9C2B8;

  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Work Sans',system-ui,-apple-system,'Segoe UI',sans-serif;

  --wrap:1280px; --wrap-text:760px; --wrap-narrow:620px;
  --pad:clamp(20px,5vw,64px);
  --sec:clamp(5rem,4rem+7vw,10rem);      /* respiro vertical generoso */

  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);font-size:1.0625rem;line-height:1.7;font-weight:340;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.1;font-optical-sizing:auto}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

/* ---------- tipografia editorial ---------- */
.eyebrow{font-family:var(--sans);font-size:.75rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);display:inline-block;margin-bottom:1.6rem}
.eyebrow--light{color:var(--gold-soft)}
.page-title{font-family:var(--serif);font-weight:400;letter-spacing:.06em;text-transform:uppercase;font-size:clamp(2.4rem,1.2rem+5vw,5rem);line-height:1.02}
.h-lg{font-size:clamp(2rem,1.3rem+3vw,3.4rem);letter-spacing:-.01em}
.h-md{font-size:clamp(1.6rem,1.2rem+1.8vw,2.5rem);letter-spacing:-.005em}
.lead{font-size:clamp(1.15rem,1.05rem+.5vw,1.5rem);line-height:1.6;color:var(--ink);font-weight:340}
.text{font-size:1.0625rem;line-height:1.8;color:var(--ink-soft)}
.text-narrow{max-width:52ch}
em,.i{font-style:italic}

/* ---------- layout ---------- */
.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad)}
.wrap-text{max-width:var(--wrap-text);margin-inline:auto;padding-inline:var(--pad)}
.section{padding-block:var(--sec)}
.section--soft{background:var(--bg-soft)}
.section--dark{background:var(--dark);color:var(--on-dark)}
.section--dark .text{color:var(--on-dark-soft)}
.section--dark h1,.section--dark h2{color:var(--on-dark)}
.center{text-align:center}
.center .eyebrow{display:block}
.stack-sm>*+*{margin-top:1.2rem}
.stack>*+*{margin-top:1.8rem}
.divider{width:48px;height:1px;background:var(--gold);margin:2rem auto 0}
.center .divider{margin-inline:auto}

/* ---------- nav ---------- */
.bb-header{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .4s var(--ease),box-shadow .4s;padding:clamp(14px,2vw,26px) 0}
.bb-header__inner{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad);display:flex;align-items:center;justify-content:space-between;gap:2rem}
.bb-brand{display:flex;align-items:center;gap:.7rem;font-family:var(--serif);font-size:1.15rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink)}
.bb-brand__mark{display:grid;place-items:center;width:40px;height:40px;border:1px solid var(--gold);border-radius:50%;font-size:.85rem;letter-spacing:.05em;flex:none}
.bb-nav{display:none;gap:2.4rem}
@media(min-width:940px){.bb-nav{display:flex}}
.bb-nav a{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;color:var(--ink);padding:4px 0;position:relative;transition:color .3s}
.bb-nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--gold);transition:width .3s var(--ease)}
.bb-nav a:hover::after,.bb-nav a[aria-current="page"]::after{width:100%}
/* transparente sobre o hero */
.bb-header.nav--on-hero:not(.is-scrolled){color:var(--on-dark)}
.bb-header.nav--on-hero:not(.is-scrolled) .bb-brand,.bb-header.nav--on-hero:not(.is-scrolled) .bb-nav a{color:#fff}
.bb-header.nav--on-hero:not(.is-scrolled) .bb-brand__mark{border-color:rgba(255,255,255,.7)}
.bb-header.is-scrolled{background:rgba(252,251,248,.94);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line)}
.bb-burger{display:grid;place-items:center;width:44px;height:44px;background:none;border:none;cursor:pointer;color:inherit}
@media(min-width:940px){.bb-burger{display:none}}
.bb-burger span,.bb-burger span::before,.bb-burger span::after{content:"";display:block;width:24px;height:1.5px;background:currentColor;transition:.3s}
.bb-burger span{position:relative}
.bb-burger span::before{position:absolute;top:-7px}
.bb-burger span::after{position:absolute;top:7px}

/* mobile drawer */
.bb-drawer{position:fixed;inset:0;z-index:100;visibility:hidden}
.bb-drawer[data-open]{visibility:visible}
.bb-drawer__scrim{position:absolute;inset:0;background:rgba(20,32,26,.6);opacity:0;transition:.3s}
.bb-drawer[data-open] .bb-drawer__scrim{opacity:1}
.bb-drawer__panel{position:absolute;top:0;right:0;height:100%;width:min(82vw,320px);background:var(--bg);padding:5rem 2rem 2rem;display:flex;flex-direction:column;gap:.4rem;transform:translateX(100%);transition:transform .4s var(--ease)}
.bb-drawer[data-open] .bb-drawer__panel{transform:none}
.bb-drawer__close{position:absolute;top:1.2rem;right:1.4rem;width:44px;height:44px;border:none;background:none;font-size:1.8rem;cursor:pointer;color:var(--ink);line-height:1}
.bb-drawer a{font-family:var(--serif);font-size:1.3rem;padding:.7rem 0;border-bottom:1px solid var(--line)}

/* ---------- hero (home) ---------- */
.bb-hero{position:relative;min-height:100svh;display:grid;place-items:center;text-align:center;color:#fff;isolation:isolate}
.bb-hero__media{position:absolute;inset:0;z-index:-2;overflow:hidden}
.bb-hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 45%}
.bb-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(20,32,26,.34),rgba(20,32,26,.18) 40%,rgba(20,32,26,.52))}
.bb-hero__inner{padding:var(--pad);max-width:900px}
.bb-hero__name{font-family:var(--serif);font-weight:400;letter-spacing:.14em;text-transform:uppercase;font-size:clamp(2.6rem,1.4rem+6vw,6rem);line-height:1.04;color:#fff;text-shadow:0 2px 28px rgba(20,32,26,.5);text-wrap:balance}
.bb-hero__sub{font-size:clamp(1rem,.9rem+.6vw,1.35rem);letter-spacing:.02em;color:rgba(255,255,255,.92);margin-top:1.4rem;font-weight:340}
.bb-hero__eyebrow{color:#fff;opacity:.9;letter-spacing:.28em}
.bb-scroll{position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);z-index:1;color:#fff;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;opacity:.85;display:flex;flex-direction:column;align-items:center;gap:.6rem}
.bb-scroll::after{content:"";width:1px;height:44px;background:rgba(255,255,255,.7);animation:scrollpulse 2s var(--ease) infinite}
@keyframes scrollpulse{0%,100%{transform:scaleY(.5);opacity:.4;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}

/* ---------- page hero (páginas internas) ---------- */
.bb-page-hero{position:relative;min-height:66svh;display:grid;place-items:center;text-align:center;color:#fff;isolation:isolate}
.bb-page-hero__media{position:absolute;inset:0;z-index:-2;overflow:hidden}
.bb-page-hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 45%}
.bb-page-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:rgba(20,32,26,.4)}
.bb-page-hero .page-title{color:#fff;text-shadow:0 2px 24px rgba(20,32,26,.5)}
.bb-page-hero .eyebrow{color:rgba(255,255,255,.9)}

/* ---------- blocos editoriais ---------- */
.editorial{max-width:var(--wrap-text);margin-inline:auto;padding-inline:var(--pad);text-align:center}
.editorial .lead{margin-top:1.4rem}

.split{display:grid;gap:clamp(2rem,4vw,4.5rem);align-items:center}
@media(min-width:880px){.split{grid-template-columns:1fr 1fr}.split .split__img{order:0}.split--reverse .split__img{order:-1}}
.split__img{overflow:hidden;order:-1}
.split__img img{width:100%;height:100%;max-height:78vh;object-fit:cover;aspect-ratio:4/5}
.split__body{max-width:34rem}
@media(min-width:880px){.split--reverse .split__body{margin-left:auto}}

.feature-list{columns:1;margin-top:2rem}
@media(min-width:620px){.feature-list{columns:2;column-gap:3rem}}
.feature-list li{break-inside:avoid;padding:.9rem 0;border-bottom:1px solid var(--line);font-size:1.02rem;color:var(--ink);display:flex;gap:.8rem;align-items:baseline}
.feature-list li::before{content:"";flex:none;width:5px;height:5px;border-radius:50%;background:var(--gold);transform:translateY(-3px)}

.stat-row{display:flex;flex-wrap:wrap;justify-content:center;gap:2.4rem clamp(2rem,6vw,5rem);margin-top:1rem}
.stat b{display:block;font-family:var(--serif);font-size:clamp(2.4rem,1.6rem+2.5vw,3.6rem);font-weight:400;line-height:1}
.stat span{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft)}
.section--dark .stat span{color:var(--on-dark-soft)}

/* galeria full-bleed */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem}
@media(min-width:760px){.gallery{grid-template-columns:repeat(3,1fr);gap:1rem}.gallery--2{grid-template-columns:repeat(2,1fr)}}
.gallery img{width:100%;aspect-ratio:4/3;object-fit:cover}
.gallery--tall img{aspect-ratio:3/4}
.figure-wide{margin-top:3rem}
.figure-wide img{width:100%;max-height:82vh;object-fit:cover}

/* aclamação (prova social editorial, impessoal) */
.acclaim{text-align:center}
.acclaim__score{font-family:var(--serif);font-size:clamp(3.2rem,2rem+5vw,5.5rem);font-weight:400;line-height:1}
.acclaim__score .s{color:var(--gold)}
.acclaim__meta{font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);margin-top:.6rem}
.section--dark .acclaim__meta{color:var(--on-dark-soft)}
.quotes{display:grid;gap:clamp(2rem,4vw,3.5rem);margin-top:4rem}
@media(min-width:760px){.quotes{grid-template-columns:repeat(3,1fr)}}
.quote{max-width:34ch;margin-inline:auto}
.quote p{font-family:var(--serif);font-size:1.25rem;line-height:1.5;font-style:italic}
.quote cite{display:block;margin-top:1rem;font-family:var(--sans);font-style:normal;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.section--dark .quote cite{color:var(--gold-soft)}

/* CTA / botões */
.btn{display:inline-block;font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;padding:1.1rem 2.4rem;border:1px solid currentColor;transition:.3s var(--ease);cursor:pointer}
.btn--solid{background:var(--gold);color:#fff;border-color:var(--gold)}
.btn--solid:hover{background:transparent;color:var(--gold)}
.section--dark .btn--solid:hover{color:#fff;border-color:#fff}
.btn--outline{background:transparent;color:var(--ink)}
.btn--outline:hover{background:var(--ink);color:var(--bg)}
.section--dark .btn--outline{color:#fff}
.section--dark .btn--outline:hover{background:#fff;color:var(--ink)}
.btn-row{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.4rem}
.center .btn-row{justify-content:center}
.linkline{display:inline-block;margin-top:2rem;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--gold);border-bottom:1px solid var(--gold);padding-bottom:3px;transition:.3s}
.linkline:hover{letter-spacing:.22em}

/* footer */
.bb-footer{background:var(--dark);color:var(--on-dark);padding-block:clamp(4rem,6vw,7rem)}
.bb-footer__top{text-align:center;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.1)}
.bb-footer__mark{display:inline-grid;place-items:center;width:56px;height:56px;border:1px solid var(--gold);border-radius:50%;font-family:var(--serif);letter-spacing:.05em;margin-bottom:1.2rem}
.bb-footer__name{font-family:var(--serif);letter-spacing:.16em;text-transform:uppercase;font-size:1.4rem}
.bb-footer__nav{display:flex;flex-wrap:wrap;justify-content:center;gap:1.4rem 2.4rem;margin-top:1.6rem}
.bb-footer__nav a{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--on-dark-soft);transition:color .3s}
.bb-footer__nav a:hover{color:#fff}
.bb-footer__grid{display:grid;gap:1.6rem;text-align:center;padding-top:3rem;font-size:.82rem;letter-spacing:.03em;color:var(--on-dark-soft)}
.bb-footer__grid a{color:var(--gold-soft)}
.bb-footer__legal{margin-top:2.4rem;font-size:.72rem;letter-spacing:.08em;color:rgba(185,194,184,.7)}

/* reveal */
.js .reveal-on [data-reveal]{opacity:0;transform:translateY(24px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal-on [data-reveal].is-visible{opacity:1;transform:none}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .js .reveal-on [data-reveal]{opacity:1;transform:none}
  .bb-scroll::after{animation:none}
}
