/* Babimakeup — site de marketing. Tokens e estética herdados de brandkit.html */
:root{
  --ink:#1C1A18; --greige:#A2978B; --sand:#E7DDD3; --nude:#D8C7B8;
  --clay:#C0A091; --paper:#FAF7F2; --white:#FFFFFF; --muted:#6a6258;
  /* greige escurecido p/ texto sobre fundo claro (4.5:1 WCAG AA); --greige
     fica reservado a superfícies escuras, onde já tem contraste suficiente */
  --greige-text:#7C7060;
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Jost','Century Gothic',sans-serif;
  --maxw:1120px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);color:var(--ink);background:var(--paper);
  font-weight:300;line-height:1.7;-webkit-font-smoothing:antialiased;
  /* normaliza a fonte de fallback durante o swap (reduz CLS no hero) */
  font-size-adjust:from-font;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--paper);padding:10px 16px;z-index:200}
.skip:focus{left:8px;top:8px}

/* ---------- tipografia utilitária ---------- */
.eyebrow{font-size:15.6px;letter-spacing:6px;text-transform:uppercase;color:var(--greige-text);font-weight:400}
h1,h2,h3{font-family:var(--serif);font-weight:400;letter-spacing:.5px;line-height:1.1}
h2{font-size:clamp(44.2px,6.5vw,70.2px);margin:18px 0 20px}
.lead{font-size:clamp(19.5px,2.6vw,23.4px);color:var(--muted);max-width:62ch}
.rule{display:inline-flex;align-items:center;gap:18px}
.rule::before,.rule::after{content:"";width:46px;height:1px;background:currentColor}

/* ---------- header / nav ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(250,247,242,.86);
  backdrop-filter:saturate(120%) blur(8px);border-bottom:1px solid rgba(28,26,24,.08)}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{font-family:var(--serif);font-size:33.8px;letter-spacing:1px;display:flex;align-items:baseline;gap:10px}
.brand small{font-family:var(--sans);font-weight:300;font-size:13px;letter-spacing:6px;color:var(--greige-text)}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-size:15.6px;letter-spacing:2px;text-transform:uppercase;color:var(--ink);opacity:.8}
.nav-links a:hover{opacity:1}
.nav-cta{border:1px solid var(--ink);padding:9px 16px;border-radius:40px;font-size:14.3px !important;letter-spacing:2px}
.nav-cta:hover{background:var(--ink);color:var(--paper)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:40px;height:40px}
.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--ink);margin:5px auto;transition:.25s}

/* ---------- hero ---------- */
.hero{min-height:92vh;min-height:92svh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:90px 24px}
.hero .markline{font-size:14.3px;letter-spacing:8px;text-transform:uppercase;color:var(--greige-text);margin-bottom:46px}
.hero-title{margin:0;font-weight:400}
/* fallback casado (Times) antes do genérico + font-size-adjust:none p/ não duplicar ajuste */
.hero-babi{display:block;font-family:'Cormorant Garamond','Cormorant Garamond Fallback',Georgia,serif;
  font-size-adjust:none;font-size:clamp(124.8px,28.6vw,286px);line-height:.86;letter-spacing:2px}
.hero-makeup{display:block;font-family:var(--sans);font-weight:300;font-size:clamp(20.8px,3.9vw,33.8px);letter-spacing:18px;margin:14px 0 0 18px;color:var(--ink)}
.hero-loc{font-size:15.6px;letter-spacing:11px;color:var(--greige-text);margin-top:26px}
.hero-tag{font-family:var(--serif);font-style:italic;font-size:clamp(26px,3.9vw,39px);color:var(--ink);margin-top:46px}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;margin-top:40px}

/* ---------- botões ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-size:15.6px;letter-spacing:3px;text-transform:uppercase;
  padding:15px 26px;border-radius:42px;border:1px solid var(--ink);transition:.2s;cursor:pointer}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:#000}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

/* ---------- seções ---------- */
section{padding:clamp(70px,11vw,140px) 0}
section+section{border-top:1px solid rgba(28,26,24,.08)}

/* sobre */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:42px;margin-top:64px}
.value .num{font-family:var(--serif);font-size:33.8px;color:var(--greige-text)}
.value h3{font-size:33.8px;margin:6px 0 8px}
.value p{font-size:18.2px;color:var(--muted)}

/* serviços */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:60px;
  background:rgba(28,26,24,.10);border:1px solid rgba(28,26,24,.10)}
.service{background:var(--paper);padding:40px 28px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px}
.service img{width:62px;height:62px;border-radius:50%;border:1px solid rgba(28,26,24,.12)}
.service h3{font-size:31.2px}
.service p{font-size:16.9px;color:var(--muted)}

/* portfólio */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:60px}
.gallery button{border:0;padding:0;background:none;cursor:zoom-in;overflow:hidden;aspect-ratio:1;border:1px solid rgba(28,26,24,.06)}
.gallery picture{display:block;width:100%;height:100%}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gallery button:hover img{transform:scale(1.04)}
.gallery .note{grid-column:1/-1;text-align:center;color:var(--muted);font-size:16.9px;margin-top:6px}
/* deterrente de download — não impede captura real (DevTools/print sempre
   conseguem); a proteção de autoria é a marca d'água embutida. Aqui: sem
   arrastar/salvar a imagem, sem seleção, sem long-press "Salvar" no iOS.
   contextmenu/dragstart são bloqueados em main.js (escopo só nas mídias). */
.gallery img,.lightbox img,.reel-item video{
  -webkit-user-drag:none;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}

/* reels (vídeo de bastidores, vertical 9:16) */
.reels{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:60px}
.reel-item{position:relative;overflow:hidden;background:var(--sand);border:1px solid rgba(28,26,24,.06)}
/* height:auto anula o hint do atributo height="1920" do <video>, senão a altura
   fixa 1920 ignora o aspect-ratio e a caixa fica gigante (1922px). */
.reel-item video{display:block;width:100%;height:auto;aspect-ratio:9/16;object-fit:cover}
.reel-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:30px 14px 12px;color:var(--white);font-size:14.3px;letter-spacing:.3px;background:linear-gradient(to top,rgba(28,26,24,.72),transparent)}

/* depoimentos */
.quotes{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:56px}
.quote{background:var(--white);border:1px solid rgba(28,26,24,.10);padding:40px 36px}
.quote p{font-family:var(--serif);font-style:italic;font-size:31.2px;line-height:1.4}
.quote cite{display:block;margin-top:20px;font-style:normal;font-size:15.6px;letter-spacing:3px;text-transform:uppercase;color:var(--greige-text)}

/* contato */
.contact{text-align:center}
.contact .lead{margin:0 auto 36px}
.contact-links{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* footer */
footer{background:var(--ink);color:var(--sand);text-align:center;padding:90px 24px}
footer .babi{font-family:var(--serif);font-size:70.2px;color:var(--paper)}
footer .mk{font-size:16.9px;letter-spacing:14px;color:var(--greige);margin:4px 0 26px 14px}
footer .meta{font-size:14.3px;letter-spacing:3px;text-transform:uppercase;color:rgba(250,247,242,.6)}
footer a{color:var(--nude)}
/* links dentro de blocos de texto: sublinhado para distinguir sem depender de cor (WCAG 1.4.1) */
.meta a,.note a{text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}

/* ---------- lightbox (dialog nativo) ---------- */
.lightbox{position:fixed;inset:0;width:100%;height:100%;max-width:100%;max-height:100%;
  margin:0;border:0;padding:24px;background:rgba(28,26,24,.92);display:none;
  align-items:center;justify-content:center;z-index:300}
.lightbox[open]{display:flex}
.lightbox::backdrop{background:transparent}
.lightbox img{max-width:92vw;max-height:88vh;object-fit:contain;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lightbox button{position:absolute;background:none;border:0;color:var(--paper);cursor:pointer;font-size:39px;line-height:1}
.lb-close{top:18px;right:24px}
.lb-prev{left:18px;top:50%;transform:translateY(-50%);font-size:57.2px}
.lb-next{right:18px;top:50%;transform:translateY(-50%);font-size:57.2px}
/* trava o scroll do fundo enquanto o lightbox está aberto */
html:has(.lightbox[open]){overflow:hidden}

/* ---------- botão flutuante de WhatsApp ---------- */
.wa-fab{position:fixed;z-index:90;display:inline-flex;align-items:center;justify-content:center;
  width:56px;height:56px;border-radius:50%;background:var(--ink);color:var(--paper);
  right:max(20px,env(safe-area-inset-right));bottom:max(20px,env(safe-area-inset-bottom));
  /* halo claro além da sombra: delineia o FAB também sobre o rodapé tinta */
  box-shadow:0 8px 24px rgba(28,26,24,.28),0 0 0 1.5px rgba(255,255,255,.22);
  transition:transform .2s ease,background .2s ease}
.wa-fab svg{width:28px;height:28px;fill:currentColor}
.wa-fab:hover{background:#000;transform:translateY(-2px)}
.wa-fab:focus-visible{outline:3px solid var(--clay);outline-offset:3px}
@media(prefers-reduced-motion:reduce){.wa-fab{transition:none}.wa-fab:hover{transform:none}}

/* ---------- containment: pula layout/paint das seções pesadas fora da viewport
   (galeria de bastidores e reels). contain-intrinsic-size reserva altura p/ evitar
   pulo de scroll/CLS; 'auto' memoriza o tamanho real após o 1º render. ---------- */
#bastidores,#movimento{content-visibility:auto;contain-intrinsic-size:auto 1400px}

/* ---------- foco visível (teclado) ---------- */
:where(a,button):focus-visible{outline:2px solid var(--ink);outline-offset:3px;border-radius:2px}
.lightbox button:focus-visible,.btn-primary:focus-visible{outline-color:var(--paper)}
.gallery button:focus-visible{outline-offset:-2px}

/* ---------- páginas de serviço (PSEO) ---------- */
.crumbs{padding:22px 0 0;font-size:14.3px;letter-spacing:1px;color:var(--muted)}
.crumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.crumbs li::after{content:"›";margin-left:8px;color:var(--greige-text)}
.crumbs li:last-child::after{content:""}
.crumbs a:hover{color:var(--ink)}
.crumbs [aria-current="page"]{color:var(--ink)}
.subhero{padding:clamp(48px,7vw,90px) 0 0}
.subhero h1{font-size:clamp(46px,7vw,76px);margin:14px 0 0}
.subhero .lead{margin-top:18px}
.subhero .hero-cta{justify-content:flex-start;margin-top:34px}
.includes{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:14px 42px;margin-top:48px}
.includes li{position:relative;padding-left:30px;font-size:18.2px;color:var(--muted);line-height:1.5}
.includes li::before{content:"";position:absolute;left:0;top:.62em;width:14px;height:1px;background:var(--clay)}
.faq{margin-top:48px;display:grid;gap:8px}
.faq h3{font-size:26px;margin-top:24px}
.faq p{font-size:18.2px;color:var(--muted);max-width:72ch}
.svc-links{display:flex;flex-wrap:wrap;gap:12px;margin-top:40px}
.svc-links a{border:1px solid rgba(28,26,24,.18);border-radius:40px;padding:11px 20px;font-size:14.3px;
  letter-spacing:1px;text-transform:uppercase;color:var(--ink);transition:.2s}
.svc-links a:hover{background:var(--ink);color:var(--paper)}
.service a.service-link{margin-top:auto;font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--greige-text);border-bottom:1px solid transparent}
.service a.service-link:hover{color:var(--ink);border-bottom-color:var(--clay)}
@media(max-width:860px){ .includes{grid-template-columns:1fr;gap:12px} }

/* ---------- reveal (só esconde quando há JS; sem JS, tudo visível) ---------- */
.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.js .reveal.in{opacity:1;transform:none}

/* ---------- responsivo ---------- */
@media(max-width:860px){
  .nav-links{position:fixed;inset:64px 0 auto 0;background:var(--paper);flex-direction:column;gap:0;
    padding:8px 0;border-bottom:1px solid rgba(28,26,24,.10);transform:translateY(-120%);transition:transform .3s;height:auto}
  .nav-links.open{transform:none}
  .nav-links a{padding:16px 28px;width:100%;border-bottom:1px solid rgba(28,26,24,.06)}
  .nav-toggle{display:block}
  .values,.services,.quotes{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto !important}
  .js .reveal{opacity:1;transform:none;transition:none}
  .gallery button:hover img{transform:none}
}
