/* ============================================================
   DESIGN TOKENS — Amanda Lislie
   Paleta: marfim / areia + tinta quente + acento BORDÔ (vinho)
   ============================================================ */
:root{
  --ivory:#F7F2EA;      /* fundo base, off-white quente */
  --sand:#EFE6D8;       /* seções suaves / preenchimento de cards */
  --sand-2:#E7DBC9;     /* variação mais profunda */
  --ink:#211C1A;        /* texto quase-preto quente */
  --muted:#6E645C;      /* texto secundário */
  --wine:#8C2F3A;       /* ACENTO — usar com parcimônia */
  --wine-deep:#6E2530;
  --blush:#E8D5D0;      /* preenchimento quente suave / hover */
  --line:rgba(33,28,26,.12);
  --shadow:0 18px 50px -24px rgba(33,28,26,.45);
  --shadow-sm:0 8px 24px -16px rgba(33,28,26,.5);
  --maxw:1180px;
  --radius:14px;
  --display:"Bodoni Moda", "Times New Roman", serif;
  --body:"Hanken Grotesk", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  background:var(--ivory);
  color:var(--ink);
  font-family:var(--body);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2px solid var(--wine);outline-offset:3px;border-radius:4px}

.container{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,5vw,40px)}
.section{padding-block:clamp(72px,11vw,128px)}
section[id]{scroll-margin-top:96px}
/* --- transição entre seções: painéis arredondados que sobem um sobre o outro --- */
.section,.footer{position:relative;margin-top:-48px;border-top-left-radius:48px;border-top-right-radius:48px;
  box-shadow:0 -28px 56px -44px rgba(33,28,26,.55)}
.marcas,.portfolio,.depoimentos{background:var(--ivory)}

/* ---------- Tipografia utilitária ---------- */
.eyebrow{
  font-family:var(--body);
  font-size:.74rem;
  font-weight:600;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--wine);
  margin:0 0 18px;
}
.display{
  font-family:var(--display);
  font-weight:600;
  line-height:1.04;
  letter-spacing:-.01em;
  margin:0;
}
h2.display{font-size:clamp(2.1rem,5.2vw,3.4rem)}
.lead{font-size:clamp(1.05rem,2.2vw,1.22rem);color:var(--muted);max-width:54ch}

/* assinatura: traço bordô desenhado sob os títulos */
.stroke{display:block;width:128px;height:14px;margin-top:14px;color:var(--wine)}
.stroke path{fill:none;stroke:currentColor;stroke-width:5;stroke-linecap:round}

/* ---------- Botões ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--body);font-weight:600;font-size:.95rem;
  padding:.85em 1.5em;border-radius:999px;cursor:pointer;border:1px solid transparent;
  transition:transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
  line-height:1;
}
.btn .arr{transition:transform .25s ease}
.btn:hover .arr{transform:translateX(4px)}
.btn-primary{background:var(--wine);color:#fff}
.btn-primary:hover{background:var(--wine-deep);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn-wa{background:#1f7a4d;color:#fff}
.btn-wa:hover{background:#19623e;transform:translateY(-2px)}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:sticky;top:0;z-index:50;
  background:color-mix(in srgb, var(--ivory) 86%, transparent);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid transparent;
  transition:border-color .3s ease, background .3s ease, padding .3s ease;
}
.nav.scrolled{border-color:var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-block:16px}
.brand{display:flex;align-items:baseline;gap:10px;letter-spacing:-.01em}
.brand b{font-family:var(--display);font-weight:600;font-size:1.32rem}
.brand span{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-size:.92rem;color:var(--muted);font-weight:500;position:relative;transition:color .2s ease}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1.5px;background:var(--wine);transition:width .25s ease}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:12px}
.burger{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--ink)}
.burger svg{width:26px;height:26px}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;overflow:hidden}
.hero-grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,6vw,76px);
  align-items:center;padding-block:clamp(46px,8vw,90px) clamp(58px,9vw,104px);
}
.kicker{display:flex;flex-direction:column;font-size:.76rem;font-weight:600;letter-spacing:.24em;
  text-transform:uppercase;color:var(--wine);margin:0 0 18px;width:max-content}
.kicker .stroke{width:118px;margin-top:6px}
.badge{
  display:inline-flex;align-items:center;gap:9px;
  font-size:.82rem;font-weight:600;color:var(--ink);
  background:var(--sand);border:1px solid var(--line);
  padding:.5em 1em;border-radius:999px;margin-bottom:22px;
}
.badge .dot{width:8px;height:8px;border-radius:50%;background:#2f9e63;box-shadow:0 0 0 4px rgba(47,158,99,.18)}
.hero-name{font-family:var(--display);font-weight:600;line-height:.92;letter-spacing:-.02em;
  font-size:clamp(3rem,8.6vw,5.6rem);margin:0 0 8px}
.hero-name .n2{display:block;font-style:italic;color:var(--wine);font-weight:500}
.hero .role{font-family:var(--display);font-style:italic;color:var(--ink);
  font-size:clamp(1.3rem,3.4vw,2rem);font-weight:500;margin:0 0 24px}
.hero p.impact{font-size:clamp(1.02rem,2.1vw,1.18rem);color:var(--muted);max-width:46ch;margin:0 0 32px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px}

/* foto da capa com pegada "scrapbook": clipe, fita washi, post-it e corações */
.hero-media{position:relative;justify-self:center;width:min(92%,400px);aspect-ratio:5/7;margin:6px auto}
.reel{position:absolute;width:74%;aspect-ratio:4/5;border-radius:12px;overflow:hidden;
  box-shadow:var(--shadow);border:7px solid #fff;background:#fff}
.reel img{width:100%;height:100%;object-fit:cover}
.reel-back{top:0;left:0;transform:rotate(-5deg);z-index:1}
.reel-front{bottom:0;right:0;transform:rotate(3.5deg);z-index:3}
.clip{position:absolute;z-index:4;top:-16px;left:14%;width:26px;height:70px;transform:rotate(-12deg);
  border:4px solid #b3aca0;border-top:none;border-radius:0 0 26px 26px;opacity:.85}
.tape{position:absolute;z-index:4;width:82px;height:24px;background:color-mix(in srgb,var(--blush) 76%,#fff);
  border:1px dashed rgba(140,47,58,.22);opacity:.92}
.tape-1{top:-8px;right:16%;transform:rotate(8deg)}
.tape-2{bottom:12%;left:-10px;transform:rotate(-7deg);z-index:4}
.sticky{position:absolute;z-index:5;right:-12px;top:6%;width:118px;transform:rotate(4deg);
  background:#F1E6C6;box-shadow:var(--shadow-sm);padding:13px 13px 15px;border-radius:2px}
.sticky b{display:block;font-family:var(--display);font-style:italic;font-size:1.0rem;color:var(--wine-deep);line-height:1.45}
.sticky small{font-family:var(--body);font-size:.62rem;letter-spacing:.04em;color:var(--muted);font-weight:600}
.doodle{position:absolute;z-index:4;color:var(--wine);opacity:.65;width:38px;height:38px}
.doodle.d1{top:2%;left:-20px;transform:rotate(-12deg)}
.doodle.d2{bottom:-8px;right:10%;transform:rotate(10deg);width:30px;height:30px}

/* placeholder de mídia (vídeo/foto) reutilizável */
.ph{
  position:absolute;inset:0;display:grid;place-content:center;gap:10px;text-align:center;
  background:
    radial-gradient(120% 90% at 30% 18%, var(--blush) 0%, transparent 55%),
    linear-gradient(150deg,var(--sand) 0%, var(--sand-2) 100%);
  color:var(--wine-deep);
}
.ph svg{width:46px;height:46px;opacity:.6;margin-inline:auto}
.ph small{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);opacity:.8}
.ph .play{width:58px;height:58px;border-radius:50%;background:rgba(255,255,255,.78);
  display:grid;place-content:center;box-shadow:var(--shadow-sm)}
.ph .play svg{width:22px;height:22px;opacity:.9;margin-left:3px;color:var(--wine)}

/* ============================================================
   SOBRE
   ============================================================ */
.sobre{background:var(--sand)}
/* índice com ícones (clicável) */
.quicknav{display:flex;justify-content:center;flex-wrap:wrap;margin:0 auto clamp(40px,6vw,62px);max-width:760px}
.quicknav a{flex:1 1 0;min-width:92px;display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:6px 8px;color:var(--ink);position:relative;text-align:center}
.quicknav a + a::before{content:"";position:absolute;left:0;top:16%;height:60%;width:1px;background:var(--line)}
.quicknav svg{width:25px;height:25px;color:var(--wine);transition:transform .2s ease}
.quicknav span{font-size:.84rem;font-weight:600;position:relative}
.quicknav span::after{content:"";position:absolute;left:50%;transform:translateX(-50%);bottom:-6px;width:0;height:2px;
  background:var(--wine);border-radius:2px;transition:width .25s ease}
.quicknav a:hover svg{transform:translateY(-3px)}
.quicknav a:hover span::after{width:92%}

.sobre-head{margin-bottom:clamp(34px,5vw,52px)}
.sobre-head .welcome{font-family:var(--display);font-style:italic;color:var(--wine);font-size:1.3rem;margin:14px 0 0}
.sobre-cols{display:grid;grid-template-columns:.95fr .66fr 1.05fr;gap:clamp(22px,4vw,46px);align-items:center}

/* polaroids */
.polaroids{position:relative;min-height:360px}
.polaroid{position:absolute;width:56%;background:#fff;padding:9px 9px 28px;border-radius:3px;box-shadow:var(--shadow-sm)}
.polaroid .pic{position:relative;aspect-ratio:4/5;border-radius:2px;overflow:hidden}
.polaroid .pic img{width:100%;height:100%;object-fit:cover}
.polaroid::before{content:"";position:absolute;top:-9px;left:50%;transform:translateX(-50%) rotate(-4deg);
  width:60px;height:21px;background:color-mix(in srgb,var(--blush) 76%,#fff);border:1px dashed rgba(140,47,58,.22)}
.polaroid:nth-child(1){top:0;left:0;transform:rotate(-5deg);z-index:1}
.polaroid:nth-child(2){top:14px;right:0;transform:rotate(4deg);z-index:2}
.polaroid:nth-child(3){bottom:0;left:22%;transform:rotate(-2deg);z-index:3}

/* lista com ícones + linha ondulada */
.bullets{position:relative;padding-left:8px}
.bullets .wave{position:absolute;left:-16px;top:4px;height:calc(100% - 8px);width:14px;color:var(--wine);opacity:.5}
.bullets ul{list-style:none;margin:0;padding:0;display:grid;gap:22px}
.bullets li{display:flex;flex-direction:column;gap:6px}
.bullets li svg{width:23px;height:23px;color:var(--wine)}
.bullets li b{font-weight:600;font-size:1rem;width:max-content;max-width:100%;border-bottom:2px solid var(--blush);padding-bottom:3px}

/* intro */
.intro .hi{font-family:var(--display);font-style:italic;font-size:1.5rem;color:var(--ink);margin:0 0 18px}
.intro .circled{position:relative;white-space:nowrap;color:var(--wine)}
.intro .circled::after{content:"";position:absolute;inset:-5px -11px;border:2px solid var(--wine);
  border-radius:50%;opacity:.5;transform:rotate(-3deg)}
.intro p{color:var(--muted);margin:0 0 14px;max-width:46ch}
.mark{background:linear-gradient(transparent 60%, var(--blush) 60%);padding:0 .12em}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:clamp(40px,5vw,56px);
  border-top:1px solid var(--line);padding-top:30px}
.stat .n{font-family:var(--display);font-weight:600;font-size:clamp(1.6rem,3.4vw,2.3rem);line-height:1;color:var(--ink)}
.stat .l{font-size:.78rem;color:var(--muted);margin-top:8px;line-height:1.35}

/* ============================================================
   MARCAS
   ============================================================ */
.marcas{text-align:center}
.marcas .stroke{margin-inline:auto}
.marcas-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:48px}
.brand-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 18px;font-family:var(--display);font-weight:500;font-size:1.15rem;
  display:grid;place-content:center;min-height:96px;
  transition:transform .25s ease, box-shadow .25s ease, color .25s ease;
}
.brand-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm);color:var(--wine)}

/* ============================================================
   DESTAQUES (reels horizontais)
   ============================================================ */
.destaques{background:var(--sand)}
.reel-row{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-top:48px}
.reel-card{position:relative;aspect-ratio:9/16;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .3s ease, box-shadow .3s ease;
  background:radial-gradient(120% 90% at 30% 18%, var(--blush) 0%, transparent 55%),linear-gradient(150deg,var(--sand) 0%, var(--sand-2) 100%)}
.reel-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.reel-card .ph .play{width:46px;height:46px}
.reel-card video{width:100%;height:100%;object-fit:cover}
.reel-card .poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.reel-card .preview{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;pointer-events:none}
.reel-card.previewing .play-badge{opacity:0;transition:opacity .25s ease}
.reel-card .play-badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;
  width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,.85);display:grid;place-content:center;box-shadow:var(--shadow-sm)}
.reel-card .play-badge svg{width:22px;height:22px;color:var(--wine);margin-left:3px}
.reel-card .cap{position:absolute;left:0;right:0;bottom:0;padding:30px 14px 12px;z-index:2;
  background:linear-gradient(transparent, rgba(33,28,26,.82));color:#fff;font-size:.82rem;font-weight:500}

/* ============================================================
   PORTFÓLIO POR NICHOS
   ============================================================ */
.filters{display:flex;flex-wrap:wrap;gap:10px;margin-top:34px}
.chip{
  font-family:var(--body);font-size:.86rem;font-weight:600;cursor:pointer;
  padding:.6em 1.15em;border-radius:999px;border:1px solid var(--line);
  background:transparent;color:var(--muted);transition:all .2s ease;
}
.chip:hover{border-color:var(--ink);color:var(--ink)}
.chip[aria-pressed="true"]{background:var(--ink);border-color:var(--ink);color:var(--ivory)}
.niche{margin-top:54px}
.niche-head{display:flex;align-items:baseline;gap:16px;margin-bottom:24px}
.niche-head .idx{font-family:var(--display);font-size:1rem;color:var(--wine)}
.niche-head h3{font-family:var(--display);font-weight:600;font-size:clamp(1.4rem,3vw,2rem);margin:0;letter-spacing:.01em}
.niche-head .sub{font-style:italic;color:var(--muted);font-family:var(--display);font-size:1.05rem}
.grid-reels{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.niche.is-hidden{display:none}

/* ============================================================
   PROCESSO
   ============================================================ */
.processo{background:var(--ink);color:var(--ivory)}
.processo .eyebrow{color:var(--blush)}
.processo h2{color:var(--ivory)}
.processo .stroke{color:var(--blush)}
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:22px;margin-top:52px}
.step .num{
  width:54px;height:54px;border-radius:50%;border:1px solid rgba(247,242,234,.35);
  display:grid;place-content:center;font-family:var(--display);font-size:1.4rem;margin-bottom:20px;
}
.step h4{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;margin:0 0 10px;color:var(--blush)}
.step p{color:rgba(247,242,234,.72);font-size:.95rem;margin:0}

/* ============================================================
   DEPOIMENTOS
   ============================================================ */
.depo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.depo{background:var(--sand);border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px}
.depo .q{font-family:var(--display);font-size:2.4rem;line-height:0;color:var(--wine);display:block;height:.6em}
.depo p{font-style:italic;color:var(--ink);margin:14px 0 22px}
.depo .who{font-weight:600;font-size:.95rem}
.depo .who span{display:block;font-weight:400;font-size:.82rem;color:var(--muted)}

/* ============================================================
   CONTATO
   ============================================================ */
.contato{background:var(--sand)}
.contato-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,72px);align-items:start}
.contato h2{font-size:clamp(2.4rem,6vw,4rem)}
.contact-list{margin-top:30px;display:grid;gap:14px}
.contact-list a{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:16px 20px;transition:transform .2s ease, box-shadow .2s ease}
.contact-list a:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.contact-list .ic{width:40px;height:40px;border-radius:50%;background:var(--blush);display:grid;place-content:center;flex:none;color:var(--wine-deep)}
.contact-list .ic svg{width:20px;height:20px}
.contact-list b{display:block;font-size:.95rem}
.contact-list small{color:var(--muted)}
.form{background:#fff;border:1px solid var(--line);border-radius:18px;padding:clamp(24px,4vw,38px);box-shadow:var(--shadow-sm)}
.form label{display:block;font-size:.82rem;font-weight:600;letter-spacing:.04em;margin:0 0 7px}
.field{width:100%;font-family:var(--body);font-size:1rem;color:var(--ink);
  background:var(--ivory);border:1px solid var(--line);border-radius:10px;padding:13px 15px;margin-bottom:18px}
.field:focus{outline:none;border-color:var(--wine)}
textarea.field{resize:vertical;min-height:110px}
.form .btn-wa{width:100%;justify-content:center}
.form .hint{font-size:.78rem;color:var(--muted);margin:12px 0 0;text-align:center}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--ink);color:rgba(247,242,234,.7)}
.footer-inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:24px;align-items:center;padding-block:40px}
.footer .brand b{color:var(--ivory)}
.footer .brand span{color:rgba(247,242,234,.55)}
.footer nav{display:flex;gap:22px;flex-wrap:wrap}
.footer nav a{font-size:.9rem;transition:color .2s ease}
.footer nav a:hover{color:var(--ivory)}
.footer .copy{font-size:.82rem;width:100%;border-top:1px solid rgba(247,242,234,.14);padding-top:22px}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lb{position:fixed;inset:0;z-index:100;display:none;place-content:center;
  background:rgba(20,16,15,.86);backdrop-filter:blur(4px);padding:24px}
.lb.open{display:grid}
.lb-inner{position:relative;width:min(94vw, calc(88dvh * 9 / 16));aspect-ratio:9/16;border-radius:18px;overflow:hidden;box-shadow:var(--shadow);background:#000}
.lb-inner video{width:100%;height:100%;object-fit:contain;background:#000}
.lb-close{position:absolute;top:18px;right:18px;z-index:2;width:46px;height:46px;border-radius:50%;
  border:none;cursor:pointer;background:rgba(247,242,234,.92);display:grid;place-content:center;color:var(--ink)}
.lb-close svg{width:22px;height:22px}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ============================================================
   RESPONSIVO
   ============================================================ */
@media (max-width:960px){
  .nav-links,.nav-cta .btn-ghost{display:none}
  .burger{display:block}
  .nav.menu-open .nav-links{
    display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;
    background:var(--ivory);border-bottom:1px solid var(--line);padding:22px 24px;gap:18px;
  }
  .hero-grid,.sobre-cols,.contato-grid{grid-template-columns:1fr}
  .hero-media{order:-1;margin-bottom:18px}
  .sobre-cols{gap:36px}
  .polaroids{position:static;min-height:0;max-width:420px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .polaroid{position:static;width:auto}
  .polaroid:nth-child(1){transform:rotate(-3deg)}
  .polaroid:nth-child(2){transform:rotate(2deg)}
  .polaroid:nth-child(3){transform:rotate(-1deg);grid-column:1 / -1;width:62%;justify-self:center}
  .bullets{padding-left:0}
  .bullets .wave{display:none}
  .quicknav a{min-width:84px}
  .reel-row{grid-template-columns:repeat(3,1fr)}
  .marcas-grid,.steps{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr);gap:24px}
  .depo-grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  .grid-reels,.reel-row{grid-template-columns:repeat(2,1fr)}
  .marcas-grid{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:1fr 1fr}
}
