:root{
  --bg: oklch(98.2% 0.006 330);
  --bg-2: oklch(96% 0.010 330);
  --ink: oklch(21% 0.055 330);
  --ink-soft: oklch(43% 0.030 330);
  --line: oklch(89% 0.018 330);
  --purple: oklch(41% 0.150 331);
  --magenta: oklch(56% 0.215 342);
  --pink: oklch(70% 0.205 352);
  --green: oklch(72% 0.185 150);
  --deep: oklch(19% 0.055 328);
  --deep-2: oklch(24% 0.070 330);
  --cream-on-deep: oklch(94% 0.012 330);

  --step--1: clamp(.82rem,.79rem + .15vw,.9rem);
  --step-0: clamp(1rem,.96rem + .2vw,1.12rem);
  --step-1: clamp(1.2rem,1.1rem + .5vw,1.5rem);
  --step-2: clamp(1.6rem,1.3rem + 1.4vw,2.4rem);
  --step-3: clamp(2.2rem,1.6rem + 3vw,4rem);
  --step-4: clamp(2.9rem,1.7rem + 6vw,6.8rem);

  --sp-4:2rem; --sp-5:3rem; --sp-6:4.5rem; --sp-7:7rem;
  --edge: clamp(1.15rem, 5vw, 5rem);
  --maxw: 1360px;
  --display: 'Archivo', system-ui, sans-serif;
  --sans: 'Hanken Grotesk', system-ui, sans-serif;
}
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans); font-size:var(--step-0); line-height:1.6;
  color:var(--ink); background:var(--bg); -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
h1,h2,h3,h4{ font-family:var(--display); font-weight:800; line-height:.98; letter-spacing:-.02em; }
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
::selection{ background:var(--magenta); color:#fff; }

/* justificar textos de corpo */
.hero-sub,.lead,.about-note,.svc-main p,.stat .d,.quote blockquote,.contact .lead,.foot-top p{ text-align:justify; text-justify:inter-word; hyphens:none; }

body::after{
  content:''; position:fixed; inset:0; z-index:9999; pointer-events:none; opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--edge); }
.eyebrow{ font-family:var(--sans); font-weight:700; font-size:var(--step--1); letter-spacing:.22em; text-transform:uppercase; color:var(--purple); display:inline-flex; align-items:center; gap:.6rem; }
.eyebrow::before{ content:''; width:1.8rem; height:2px; background:var(--magenta); display:inline-block; }
.btn{ display:inline-flex; align-items:center; gap:.7rem; font-family:var(--sans); font-weight:700; font-size:var(--step-0); padding:1rem 1.6rem; border-radius:2px; transition:transform .35s cubic-bezier(.16,1,.3,1), background .25s; cursor:pointer; border:0; }
.btn svg{ width:1.15em; height:1.15em; flex:none; }
.btn--green{ background:var(--green); color:#fff; }
.btn--green:hover{ background:oklch(66% 0.19 150); }
.btn--green svg{ fill:#fff; }
.btn--ghost{ background:transparent; color:var(--ink); box-shadow:inset 0 0 0 1.5px var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:var(--bg); }
.btn:active{ transform:translateY(1px); }

.rv{ opacity:0; transform:translateY(26px); transition:opacity .9s cubic-bezier(.16,1,.3,1), transform .9s cubic-bezier(.16,1,.3,1); transition-delay:var(--d,0ms); }
.rv.in{ opacity:1; transform:none; }
@media(prefers-reduced-motion:reduce){ .rv{ opacity:1; transform:none; } }

/* ===== NAV ===== */
.nav{ position:fixed; inset:0 0 auto 0; z-index:100; transition:background .4s, box-shadow .4s, padding .4s; padding:1.2rem 0; }
.nav.stuck{ background:color-mix(in oklab, var(--bg) 85%, transparent); backdrop-filter:blur(14px) saturate(1.4); box-shadow:0 1px 0 var(--line); padding:.7rem 0; }
.nav-in{ display:flex; align-items:center; justify-content:space-between; gap:2rem; }
.nav-logo img{ height:52px; transition:height .4s; }
.nav.stuck .nav-logo img{ height:42px; }
.nav-links{ display:flex; align-items:center; gap:2.1rem; list-style:none; }
.nav-links a{ font-weight:600; font-size:var(--step--1); letter-spacing:.02em; text-transform:uppercase; position:relative; padding:.3rem 0; color:var(--ink-soft); transition:color .25s; }
.nav-links a::after{ content:''; position:absolute; left:0; bottom:-2px; height:2px; width:0; background:var(--magenta); transition:width .3s cubic-bezier(.16,1,.3,1); }
.nav-links a:hover{ color:var(--ink); } .nav-links a:hover::after{ width:100%; }
.nav-cta{ display:flex; align-items:center; gap:1rem; }
.nav-phone{ font-weight:700; color:var(--ink); font-size:var(--step--1); }
.burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:.4rem; }
.burger span{ width:26px; height:2px; background:var(--ink); }

/* ===== HERO (vídeo de fundo + overlay branco) ===== */
.hero{ position:relative; min-height:100dvh; display:flex; align-items:flex-end; overflow:hidden; padding-block:clamp(9rem,16vh,12rem) clamp(3rem,7vh,6rem); background:var(--bg-2); }
.hero-video{ position:absolute; inset:0; z-index:0; overflow:hidden; background:var(--bg-2); }
.hero-video iframe{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); pointer-events:none; border:0; }
.hero-video::after{ content:''; position:absolute; inset:0; background:linear-gradient(100deg, oklch(98% .006 330 /.94) 0%, oklch(98% .006 330 /.86) 46%, oklch(96% .02 340 /.66) 100%); }
.hero-in{ position:relative; z-index:2; width:100%; }
.hero h1{ font-size:var(--step-4); margin:1.4rem 0 0; text-transform:uppercase; max-width:16ch; }
.hero h1 .em{ color:var(--magenta); }
.hero-sub{ font-size:var(--step-1); color:var(--ink-soft); max-width:44ch; margin-top:1.8rem; line-height:1.45; }
.hero-sub b{ color:var(--ink); font-weight:700; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:1rem; margin-top:2.3rem; }
.hero-badge{ position:absolute; right:0; bottom:0; z-index:2; background:var(--deep); color:var(--cream-on-deep); padding:1.4rem 1.7rem; max-width:19rem; box-shadow:0 26px 55px -20px oklch(19% .055 328 /.55); }
.hero-badge .n{ font-family:var(--display); font-weight:900; font-size:var(--step-2); color:#fff; line-height:1; letter-spacing:-.02em; }
.hero-badge .n b{ color:var(--pink); font-weight:900; }
.hero-badge .l{ font-size:var(--step--1); color:oklch(82% .03 330); margin-top:.5rem; line-height:1.4; }
@media(max-width:720px){ .hero-badge{ position:static; margin-top:2.5rem; max-width:none; } }

/* ===== MARQUEE ===== */
.marquee{ border-block:1px solid var(--line); padding:1.15rem 0; overflow:hidden; white-space:nowrap; background:var(--bg); }
.marquee-track{ display:inline-flex; gap:2.5rem; animation:scroll 32s linear infinite; will-change:transform; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee span{ font-family:var(--display); font-weight:800; text-transform:uppercase; font-size:var(--step-1); color:var(--ink); display:inline-flex; align-items:center; gap:2.5rem; }
.marquee span::after{ content:'✳'; color:var(--magenta); font-size:.7em; }
@keyframes scroll{ to{ transform:translateX(-50%); } }

.sec-head{ display:grid; grid-template-columns:auto 1fr; gap:clamp(1.5rem,4vw,4rem); align-items:end; margin-bottom:var(--sp-6); }
.sec-head .idx{ font-family:var(--display); font-weight:900; font-size:var(--step-2); color:var(--line); line-height:.8; }
.sec-title{ font-size:var(--step-3); text-transform:uppercase; }
.sec-title .em{ color:var(--purple); }
.lead{ font-size:var(--step-1); color:var(--ink-soft); max-width:62ch; line-height:1.5; }
.lead b{ color:var(--ink); font-weight:700; }

.about{ padding-block:var(--sp-7); }
.about-grid{ display:grid; grid-template-columns:.85fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
.about-note{ margin-top:1.6rem; font-size:var(--step-0); color:var(--ink-soft); max-width:56ch; }

/* ===== SERVIÇOS (imagem no fundo da aba no hover) ===== */
.services{ padding-block:var(--sp-7); background:var(--bg-2); border-block:1px solid var(--line); }
.svc-list{ border-top:1px solid var(--line); }
.svc{ position:relative; overflow:hidden; display:grid; grid-template-columns:auto 1fr auto; gap:clamp(1rem,3vw,3rem); align-items:center; padding:clamp(2.4rem,4.5vw,3.6rem) clamp(1rem,2vw,2rem); border-bottom:1px solid var(--line); transition:padding-left .5s cubic-bezier(.16,1,.3,1); }
.svc-bg{ position:absolute; inset:0; z-index:0; opacity:0; transition:opacity .55s cubic-bezier(.16,1,.3,1); }
.svc-bg img{ width:100%; height:100%; object-fit:cover; filter:grayscale(1) contrast(1.05); transform:scale(1.06); transition:transform 1.2s cubic-bezier(.16,1,.3,1); }
.svc-bg::after{ content:''; position:absolute; inset:0; background:linear-gradient(95deg, oklch(18% .055 328 /.94), oklch(30% .13 332 /.82)); }
.svc > *:not(.svc-bg){ position:relative; z-index:1; }
.svc-num{ font-family:var(--display); font-weight:900; font-size:var(--step-1); color:var(--ink-soft); width:3ch; transition:color .3s; }
.svc-main{ min-width:0; }
.svc-main h3{ font-size:var(--step-2); text-transform:uppercase; transition:color .3s; }
.svc-main p{ color:var(--ink-soft); max-width:74ch; margin-top:.6rem; font-size:var(--step-0); transition:color .3s; }
.svc-go{ display:inline-flex; align-items:center; gap:.6rem; font-weight:700; text-transform:uppercase; font-size:var(--step--1); letter-spacing:.06em; color:var(--purple); white-space:nowrap; transition:color .3s; }
.svc-go svg{ width:1.4em;height:1.4em; transition:transform .35s cubic-bezier(.16,1,.3,1); }
@media(hover:hover){
  .svc:hover{ padding-left:clamp(1.6rem,3vw,3rem); }
  .svc:hover .svc-bg{ opacity:1; }
  .svc:hover .svc-bg img{ transform:scale(1); }
  .svc:hover .svc-num{ color:var(--pink); }
  .svc:hover .svc-main h3{ color:#fff; }
  .svc:hover .svc-main p{ color:oklch(88% .02 330); }
  .svc:hover .svc-go{ color:#fff; }
  .svc:hover .svc-go svg{ transform:translateX(5px); }
}
@media(max-width:720px){ .svc-bg{ opacity:1; } .svc-num{ color:var(--pink); } .svc-main h3{ color:#fff; } .svc-main p{ color:oklch(88% .02 330); } .svc{ grid-template-columns:auto 1fr; } .svc-go{ display:none; } }

/* ===== STATS / RESULTADOS ===== */
.stats{ background:var(--deep); color:var(--cream-on-deep); padding-block:var(--sp-7); position:relative; overflow:hidden; }
.stats::before{ content:''; position:absolute; width:60vw; height:60vw; right:-20vw; top:-24vw; background:radial-gradient(circle,var(--purple),transparent 62%); opacity:.5; }
.stats .wrap{ position:relative; }
.stats .eyebrow{ color:var(--pink); }
.stats .eyebrow::before{ background:var(--pink); }
.stats-h{ font-size:var(--step-3); color:#fff; text-transform:uppercase; max-width:20ch; margin:1.2rem 0 var(--sp-6); }
.stats-h .em{ color:var(--pink); }
.stat-row{ display:grid; grid-template-columns:1fr; border-top:1px solid oklch(100% 0 0 /.16); }
.stat{ padding:clamp(1.9rem,3.6vw,3.2rem) 0; border-bottom:1px solid oklch(100% 0 0 /.16); }
.stat .n{ font-family:var(--display); font-weight:900; font-size:clamp(2rem,7vw,6rem); color:#fff; line-height:.9; letter-spacing:-.03em; white-space:nowrap; }
.stat .n .u{ color:var(--pink); }
.stat .d{ color:oklch(85% .02 330); margin-top:1rem; max-width:64ch; font-size:var(--step-1); line-height:1.5; }

/* ===== DEPOIMENTOS ===== */
.quotes{ padding-block:var(--sp-7); }
.quote-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,3vw,3rem); }
.quote{ padding:clamp(1.8rem,3vw,2.8rem); border:1px solid var(--line); background:var(--bg); }
.quote .mk{ font-family:var(--display); font-weight:900; font-size:5rem; line-height:.7; color:var(--magenta); opacity:.3; }
.quote blockquote{ font-size:var(--step-1); line-height:1.45; color:var(--ink); margin:.4rem 0 1.8rem; }
.quote .who{ display:flex; align-items:center; gap:1rem; }
.quote .who img{ width:52px; height:52px; border-radius:50%; object-fit:cover; filter:grayscale(1); }
.quote .who .nm{ font-weight:800; font-family:var(--display); }
.quote .who .rl{ color:var(--ink-soft); font-size:var(--step--1); }

/* ===== CONTATO (sem formulário) ===== */
.contact{ background:var(--deep); color:var(--cream-on-deep); padding-block:var(--sp-7); position:relative; overflow:hidden; }
.contact::before{ content:''; position:absolute; width:52vw; height:52vw; left:-18vw; bottom:-24vw; background:radial-gradient(circle,var(--magenta),transparent 60%); opacity:.35; }
.contact .wrap{ position:relative; }
.contact-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2.5rem,6vw,6rem); align-items:center; }
.contact h2{ font-size:var(--step-3); color:#fff; text-transform:uppercase; margin-top:1rem; }
.contact h2 .em{ color:var(--pink); }
.contact .eyebrow{ color:var(--pink); } .contact .eyebrow::before{ background:var(--pink); }
.contact .lead{ color:oklch(84% .02 330); margin-top:1.4rem; max-width:46ch; }
.contact .btn{ margin-top:2.2rem; }
.contact-info{ display:grid; gap:1.4rem; }
.ci{ display:flex; gap:1.1rem; align-items:flex-start; }
.ci .ico{ width:48px;height:48px; flex:0 0 48px; border:1px solid oklch(100% 0 0 /.2); border-radius:3px; display:grid; place-items:center; color:var(--pink); }
.ci .ico svg{ width:22px;height:22px; }
.ci .lb{ font-size:var(--step--1); text-transform:uppercase; letter-spacing:.15em; color:oklch(72% .03 330); }
.ci .vl{ font-weight:700; color:#fff; font-size:var(--step-0); margin-top:.2rem; line-height:1.45; }

/* ===== FOOTER ===== */
.footer{ background:var(--deep-2); color:var(--cream-on-deep); padding-block:var(--sp-6) var(--sp-4); }
.foot-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.3fr; gap:2.5rem; padding-bottom:var(--sp-5); border-bottom:1px solid oklch(100% 0 0 /.12); }
.foot-logo img{ height:44px; filter:brightness(0) invert(1); opacity:.95; }
.foot-top p{ color:oklch(78% .02 330); margin-top:1.1rem; max-width:34ch; font-size:var(--step--1); }
.foot-col h4{ font-family:var(--sans); font-weight:800; font-size:var(--step--1); text-transform:uppercase; letter-spacing:.12em; color:#fff; margin-bottom:1.1rem; }
.foot-col a{ display:block; color:oklch(80% .02 330); padding:.35rem 0; font-size:var(--step-0); transition:color .2s; }
.foot-col a:hover{ color:var(--pink); }
.news{ display:flex; gap:.5rem; margin-top:1rem; }
.news input{ flex:1; min-width:0; background:oklch(100% 0 0 /.06); border:1px solid oklch(100% 0 0 /.16); color:#fff; padding:.7rem .9rem; border-radius:2px; font-family:var(--sans); }
.news input:focus{ outline:none; border-color:var(--pink); }
.news button{ background:var(--pink); color:var(--deep); border:0; padding:0 1.1rem; font-weight:800; cursor:pointer; border-radius:2px; text-transform:uppercase; font-size:var(--step--1); }
.foot-bot{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; padding-top:1.6rem; color:oklch(66% .02 330); font-size:var(--step--1); }
.foot-bot a{ color:oklch(66% .02 330); }
.foot-social{ display:flex; gap:.8rem; }
.foot-social a{ width:36px;height:36px; border:1px solid oklch(100% 0 0 /.16); border-radius:50%; display:grid; place-items:center; transition:.25s; }
.foot-social a:hover{ background:var(--pink); color:var(--deep); border-color:var(--pink); }
.foot-social svg{ width:16px;height:16px; }

.wa{ position:fixed; right:1.2rem; bottom:1.2rem; z-index:120; width:58px; height:58px; border-radius:50%; background:var(--green); color:#fff; display:grid; place-items:center; box-shadow:0 14px 34px -10px color-mix(in oklab,var(--green) 70%, transparent); transition:transform .3s; }
.wa:hover{ transform:scale(1.08); } .wa svg{ width:28px;height:28px; fill:#fff; }

@media(max-width:1000px){
  .about-grid,.quote-grid,.contact-grid{ grid-template-columns:1fr; }
  .foot-top{ grid-template-columns:1fr 1fr; gap:2rem; }
}
@media(max-width:720px){
  .nav-links,.nav-phone{ display:none; }
  .burger{ display:flex; }
  .nav-links.open{ display:flex; position:absolute; top:100%; left:0; right:0; flex-direction:column; background:var(--bg); padding:1.5rem var(--edge); gap:1.2rem; box-shadow:0 20px 40px -20px oklch(21% .055 330 /.4); border-top:1px solid var(--line); }
  .sec-head{ grid-template-columns:1fr; gap:.8rem; }
  .stat-row{ grid-template-columns:1fr; }
  .foot-top{ grid-template-columns:1fr; }
}

/* ===================== PÁGINAS INTERNAS ===================== */
.page-hero{ position:relative; padding:clamp(9rem,16vh,12rem) 0 clamp(3rem,6vh,5rem); background:var(--deep); color:var(--cream-on-deep); overflow:hidden; }
.page-hero::before{ content:''; position:absolute; width:55vw; height:55vw; right:-18vw; top:-22vw; background:radial-gradient(circle,var(--purple),transparent 62%); opacity:.5; }
.page-hero .wrap{ position:relative; }
.crumb{ display:flex; gap:.55rem; align-items:center; font-size:var(--step--1); text-transform:uppercase; letter-spacing:.16em; color:oklch(72% .04 340); font-weight:700; }
.crumb a{ color:var(--pink); } .crumb a:hover{ text-decoration:underline; } .crumb .sep{ color:oklch(55% .03 330); }
.page-hero h1{ font-size:clamp(2.3rem,1.4rem + 3.6vw,4.6rem); color:#fff; text-transform:uppercase; margin:1.3rem 0 0; max-width:20ch; line-height:.98; }
.page-hero h1 .em{ color:var(--pink); }
.page-hero .intro{ font-size:var(--step-1); color:oklch(86% .02 330); max-width:62ch; margin-top:1.6rem; line-height:1.55; text-align:justify; }
.page-hero .btn{ margin-top:2.3rem; }

.prose{ padding-block:var(--sp-7); }
.prose-wrap{ max-width:1120px; }
.prose p{ font-size:var(--step-1); color:var(--ink-soft); line-height:1.7; margin-bottom:1.4rem; max-width:74ch; text-align:justify; }
.prose p b{ color:var(--ink); font-weight:700; }

.feat-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(258px,1fr)); border-top:1px solid var(--line); border-left:1px solid var(--line); margin-top:var(--sp-4); }
.feat{ padding:clamp(1.7rem,3vw,2.5rem); border-bottom:1px solid var(--line); border-right:1px solid var(--line); background:var(--bg); transition:background .3s; }
.feat:hover{ background:var(--bg-2); }
.feat .fn{ font-family:var(--display); font-weight:900; font-size:var(--step-1); color:var(--pink); line-height:1; }
.feat h3{ font-size:var(--step-1); text-transform:uppercase; margin:.9rem 0 .55rem; }
.feat p{ color:var(--ink-soft); font-size:var(--step-0); line-height:1.6; text-align:justify; max-width:none; margin:0; }

.cta-band{ background:var(--deep-2); color:var(--cream-on-deep); padding-block:var(--sp-6); position:relative; overflow:hidden; }
.cta-band::before{ content:''; position:absolute; width:50vw;height:50vw; left:-16vw; bottom:-26vw; background:radial-gradient(circle,var(--magenta),transparent 60%); opacity:.35; }
.cta-band .wrap{ position:relative; display:flex; justify-content:space-between; align-items:center; gap:2rem; flex-wrap:wrap; }
.cta-band h2{ font-size:var(--step-2); color:#fff; text-transform:uppercase; max-width:22ch; }
.cta-band h2 .em{ color:var(--pink); }
@media(max-width:720px){ .cta-band .wrap{ flex-direction:column; align-items:flex-start; } }

/* thanks */
.thanks{ min-height:66vh; display:grid; place-items:center; text-align:center; padding-block:var(--sp-7); }
.thanks .ico{ width:84px;height:84px;border-radius:50%;background:var(--green);display:grid;place-items:center;margin:0 auto 2rem;color:#fff; }
.thanks .ico svg{ width:42px;height:42px; }
.thanks h1{ font-size:var(--step-3); text-transform:uppercase; color:var(--ink); }
.thanks p{ font-size:var(--step-1); color:var(--ink-soft); max-width:54ch; margin:1.4rem auto 2.4rem; }
/* form pages */
.formsec{ padding-block:var(--sp-7); }
.pform{ max-width:660px; margin-top:var(--sp-4); }
.pform .fg{ display:grid; gap:.5rem; margin-bottom:1.2rem; }
.pform .fg2{ display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
.pform label{ font-size:var(--step--1); font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-soft); }
.pform input,.pform textarea,.pform select{ width:100%; background:var(--bg-2); border:1px solid var(--line); color:var(--ink); padding:.9rem 1rem; font-family:var(--sans); font-size:var(--step-0); border-radius:2px; transition:border .2s; }
.pform input:focus,.pform textarea:focus,.pform select:focus{ outline:none; border-color:var(--purple); }
.pform textarea{ resize:vertical; min-height:120px; }
@media(max-width:600px){ .pform .fg2{ grid-template-columns:1fr; } }
/* portfolio + cases */
.port-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:1.5rem; margin-top:var(--sp-4); }
.port-card{ display:block; position:relative; overflow:hidden; aspect-ratio:4/3; background:var(--deep); }
.port-card img{ width:100%;height:100%;object-fit:cover; object-position:top; filter:grayscale(.4) contrast(1.05); transition:transform .9s cubic-bezier(.16,1,.3,1), filter .4s; }
.port-card:hover img{ transform:scale(1.05); filter:grayscale(0); }
.port-card .cap{ position:absolute; inset:auto 0 0 0; padding:1.4rem; background:linear-gradient(transparent, oklch(18% .05 328 /.94)); color:#fff; z-index:1; }
.port-card .cap h3{ font-size:var(--step-1); text-transform:uppercase; }
.port-card .cap span{ font-size:var(--step--1); color:var(--pink); font-weight:700; text-transform:uppercase; letter-spacing:.1em; }
.case-shot{ border:1px solid var(--line); background:var(--bg-2); padding:clamp(.6rem,1.5vw,1.2rem); max-width:1100px; margin-inline:auto; }
.case-shot img{ width:100%; display:block; }
/* logos + two-col */
.logos{ display:flex; flex-wrap:wrap; gap:2.5rem; align-items:center; margin-top:var(--sp-4); }
.logos img{ height:54px; width:auto; filter:grayscale(1) opacity(.55); transition:.3s; }
.logos img:hover{ filter:grayscale(0) opacity(1); }
.two-col{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.two-col .duo{ aspect-ratio:4/3; }
@media(max-width:820px){ .two-col{ grid-template-columns:1fr; } }
.back-link{ display:inline-flex; align-items:center; gap:.5rem; font-weight:700; text-transform:uppercase; font-size:var(--step--1); letter-spacing:.08em; color:var(--purple); margin-bottom:1.5rem; }
.back-link:hover{ color:var(--magenta); }

/* ===== DROPDOWN DE SERVIÇOS NO HEADER ===== */
.nav-links .has-drop{ position:relative; }
.nav-links .has-drop > a{ display:inline-flex; align-items:center; gap:.32rem; }
.nav-links .has-drop > a svg{ width:.7em; height:.7em; transition:transform .3s; }
.nav-links .has-drop:hover > a svg{ transform:rotate(180deg); }
.drop{ position:absolute; top:100%; left:50%; transform:translateX(-50%) translateY(10px); min-width:286px; background:var(--bg); border:1px solid var(--line); box-shadow:0 26px 55px -22px oklch(21% .055 330 /.4); padding:.55rem; opacity:0; visibility:hidden; transition:opacity .25s, transform .25s; z-index:120; }
.has-drop:hover .drop, .has-drop:focus-within .drop{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(6px); }
.drop a{ display:block; padding:.62rem .85rem; font-size:var(--step--1); text-transform:none; letter-spacing:.01em; color:var(--ink-soft); font-weight:600; border-radius:2px; }
.drop a::after{ display:none; }
.drop a:hover{ background:var(--bg-2); color:var(--purple); }
@media(max-width:720px){
  .drop{ position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; border:0; padding:.4rem 0 .4rem 1.1rem; min-width:0; background:transparent; }
  .drop a{ padding:.5rem 0; }
  .nav-links .has-drop > a svg{ display:none; }
}

/* ===== BLOG ===== */
.blog-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:1.5rem; margin-top:var(--sp-4); }
.blog-loading,.blog-empty{ color:var(--ink-soft); font-size:var(--step-1); padding:2rem 0; }
.blog-card{ display:flex; flex-direction:column; gap:.7rem; padding:1.8rem; border:1px solid var(--line); background:var(--bg); transition:border-color .3s, transform .5s cubic-bezier(.16,1,.3,1); }
.blog-card:hover{ border-color:var(--purple); transform:translateY(-4px); }
.bdate{ font-size:var(--step--1); text-transform:uppercase; letter-spacing:.1em; color:var(--pink); font-weight:700; }
.blog-card h3{ font-size:var(--step-1); text-transform:none; line-height:1.2; color:var(--ink); letter-spacing:-.01em; }
.blog-card p{ color:var(--ink-soft); font-size:var(--step-0); line-height:1.6; flex:1; margin:0; text-align:justify; }
.blink{ display:inline-flex; align-items:center; gap:.4rem; font-weight:700; text-transform:uppercase; font-size:var(--step--1); letter-spacing:.06em; color:var(--purple); }
.blink svg{ width:1.2em;height:1.2em; transition:transform .3s; } .blog-card:hover .blink svg{ transform:translateX(4px); }
/* post view */
.post-hero{ padding-bottom:clamp(2rem,4vh,3rem); }
.post-hero h1{ text-transform:none; letter-spacing:-.01em; max-width:22ch; }
.post-meta{ color:var(--pink); font-weight:700; margin-top:1.2rem; text-transform:uppercase; letter-spacing:.08em; font-size:var(--step--1); }
.post-img{ width:100%; border-radius:3px; margin:0 0 2rem; max-height:460px; object-fit:cover; }
.post-body{ font-size:var(--step-1); line-height:1.75; color:var(--ink-soft); max-width:74ch; }
.post-body h2,.post-body h3,.post-body h4{ font-family:var(--display); color:var(--ink); text-transform:none; margin:2.2rem 0 1rem; line-height:1.18; letter-spacing:-.01em; }
.post-body h2{ font-size:var(--step-2); } .post-body h3{ font-size:var(--step-1); }
.post-body p{ margin-bottom:1.3rem; }
.post-body strong,.post-body b{ color:var(--ink); }
.post-body a{ color:var(--purple); text-decoration:underline; text-underline-offset:3px; }
.post-body img{ max-width:100%; height:auto; border-radius:3px; margin:1.5rem 0; }
.post-body ul,.post-body ol{ margin:0 0 1.3rem 1.4rem; } .post-body li{ margin-bottom:.5rem; }
.post-body iframe,.post-body video,.post-body embed,.post-body object{ max-width:100%!important; width:100%!important; aspect-ratio:16/9; height:auto!important; margin:1.5rem 0; border:0; }
.post-body figure,.post-body .wp-block-embed,.post-body .wp-block-video{ max-width:100%!important; overflow:hidden; margin:1.5rem 0; }

/* ===== faixa de imagem de contexto (páginas internas) ===== */
.ctx-band{ position:relative; min-height:clamp(280px,38vh,420px); display:flex; align-items:center; overflow:hidden; border-block:1px solid var(--line); }
.ctx-band .duo{ position:absolute; inset:0; }
.ctx-band .duo img{ width:100%;height:100%;object-fit:cover; }
.ctx-band .ctx-cap{ position:relative; z-index:3; }
.ctx-band .ctx-cap span{ font-size:var(--step--1); text-transform:uppercase; letter-spacing:.2em; color:var(--pink); font-weight:700; }
.ctx-band .ctx-cap p{ font-family:var(--display); font-weight:900; text-transform:uppercase; color:#fff; font-size:clamp(1.8rem,1rem+3vw,3.2rem); max-width:22ch; line-height:1; margin-top:.9rem; }
/* página-hero com imagem de capa */
.page-hero.has-cover::before{ opacity:.32; mix-blend-mode:screen; }
/* portfolio card refeito */
.port-grid{ gap:1.8rem; }
.port-card{ display:block; background:var(--bg); border:1px solid var(--line); overflow:hidden; aspect-ratio:auto; transition:border-color .3s, transform .5s cubic-bezier(.16,1,.3,1), box-shadow .4s; }
.port-card:hover{ border-color:var(--purple); transform:translateY(-5px); box-shadow:0 24px 50px -26px oklch(21% .055 330 /.4); }
.port-card .pimg{ aspect-ratio:16/10; overflow:hidden; background:var(--deep); }
.port-card .pimg img{ width:100%;height:100%;object-fit:cover; object-position:top; transition:transform .9s cubic-bezier(.16,1,.3,1), filter .4s; filter:grayscale(.35); }
.port-card:hover .pimg img{ transform:scale(1.06); filter:grayscale(0); }
.port-card .pinfo{ padding:1.4rem 1.6rem; display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.port-card .pinfo span{ display:block; font-size:var(--step--1); color:var(--pink); font-weight:700; text-transform:uppercase; letter-spacing:.1em; margin-bottom:.35rem; }
.port-card .pinfo h3{ font-size:var(--step-1); text-transform:uppercase; line-height:1; }
.port-card .pinfo .go{ color:var(--purple); flex:none; width:26px;height:26px; }
.port-card .cap{ display:none; }
