/* =============================================
   YUNAR STUDIO v2 — style.css
   Reformulado com inspiração na Rapina Digital
   Paleta: preto + offwhite. Sem acento de cor.
   ============================================= */

:root {
  --black:    #080808;
  --black-2:  #0d0d0d;
  --black-3:  #131313;
  --black-4:  #1a1a1a;
  --black-5:  #222222;
  --grey:     #2e2e2e;
  --white:    #f0ece4;
  --white-2:  rgba(240,236,228,0.6);
  --white-3:  rgba(240,236,228,0.28);
  --white-4:  rgba(240,236,228,0.08);
  --white-5:  rgba(240,236,228,0.04);
  --border:   rgba(240,236,228,0.08);
  --border-2: rgba(240,236,228,0.14);

  --ff-display: 'Bebas Neue', sans-serif;
  --ff-body:    'Archivo', sans-serif;
  --ff-mono:    'Azeret Mono', monospace;

  --ease:      cubic-bezier(0.16,1,0.3,1);
  --t:         0.45s var(--ease);
  --t-fast:    0.2s ease;

  --radius:    6px;
  --radius-lg: 12px;
  --max-w:     1200px;
  --pad:       clamp(24px,5vw,64px);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%;}
body{
  background:var(--black);
  color:var(--white);
  font-family:var(--ff-body);
  line-height:1.65;
  overflow-x:hidden;
  cursor:none;
}
body.menu-open{overflow:hidden;}
img,svg{display:block;max-width:100%;}
a{text-decoration:none;color:inherit;}
ul,ol{list-style:none;}
button{border:none;background:none;cursor:none;font:inherit;}
details{border:none;}
summary{list-style:none;cursor:none;}
summary::-webkit-details-marker{display:none;}

/* SVG filters hidden */
.svg-filters{position:fixed;width:0;height:0;overflow:hidden;pointer-events:none;}

/* Grain */
.grain{
  position:fixed;inset:0;pointer-events:none;
  z-index:9998;opacity:.04;mix-blend-mode:overlay;
}

/* Container */
.container{
  width:100%;max-width:var(--max-w);
  margin:0 auto;padding:0 var(--pad);
}

/* =============================================
   CURSOR LÍQUIDO
   ============================================= */
.cursor-wrap{position:fixed;top:0;left:0;pointer-events:none;z-index:10000;}

.c-dot{
  width:6px;height:6px;
  background:var(--white);border-radius:50%;
  position:absolute;transform:translate(-50%,-50%);
  transition:width .15s ease,height .15s ease;
  mix-blend-mode:difference;
}
.c-ring{
  width:38px;height:38px;
  border:1px solid rgba(240,236,228,.4);
  border-radius:50%;position:absolute;
  transform:translate(-50%,-50%);
  transition:width .3s var(--ease),height .3s var(--ease),
             border-radius .3s var(--ease),border-color .2s ease;
  filter:url(#liquid);
}
.c-label{
  position:absolute;transform:translate(-50%,20px);
  font-family:var(--ff-mono);font-size:9px;
  letter-spacing:.15em;color:var(--white);
  opacity:0;transition:opacity .2s ease;
  white-space:nowrap;mix-blend-mode:difference;
}

body.ch-hover .c-dot{width:3px;height:3px;}
body.ch-hover .c-ring{
  width:68px;height:68px;
  border-radius:30% 70% 60% 40%/40% 50% 60% 50%;
  border-color:rgba(240,236,228,.7);
}
body.ch-hover .c-label{opacity:1;}

/* =============================================
   SKIP LINK
   ============================================= */
.skip-link{
  position:absolute;top:-100px;left:16px;
  background:var(--white);color:var(--black);
  padding:8px 16px;font-family:var(--ff-mono);
  font-size:12px;border-radius:2px;z-index:99999;
  transition:top .2s ease;
}
.skip-link:focus{top:16px;}

/* =============================================
   NAV
   ============================================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:24px var(--pad);
  display:flex;align-items:center;justify-content:space-between;
  transition:padding .3s ease,background .3s ease,border-color .3s ease;
  animation:navDrop .7s var(--ease) .1s both;
}
.nav.stuck{
  background:rgba(8,8,8,.9);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  padding:16px var(--pad);
}

.nav-logo{display:flex;align-items:center;gap:10px;}
.nl-mark{
  width:34px;height:34px;
  border:1px solid var(--border-2);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;flex-shrink:0;
}
.logo-img-nav{width:100%;height:100%;object-fit:contain;padding:4px;}
.nl-name{
  font-family:var(--ff-mono);font-size:11px;
  letter-spacing:.2em;color:var(--white-2);
}

.nav-links{display:flex;align-items:center;gap:36px;}
.nl{
  font-family:var(--ff-mono);font-size:11px;
  letter-spacing:.1em;color:var(--white-2);
  transition:color var(--t-fast);position:relative;
}
.nl::after{
  content:'';position:absolute;bottom:-3px;left:0;
  width:0;height:1px;background:var(--white);
  transition:width .25s ease;
}
.nl:hover{color:var(--white);}
.nl:hover::after{width:100%;}
.nl--cta{
  color:var(--white);
  border:1px solid var(--border-2);
  padding:9px 20px;
}
.nl--cta::after{display:none;}
.nl--cta:hover{background:var(--white-4);border-color:rgba(240,236,228,.25);}

.burger{display:none;flex-direction:column;gap:5px;padding:4px;}
.burger span{display:block;width:22px;height:1px;background:var(--white);transition:transform .3s ease,opacity .3s ease;}
.burger.open span:nth-child(1){transform:translateY(6px) rotate(45deg);}
.burger.open span:nth-child(2){opacity:0;transform:scaleX(0);}

.mob-nav{
  position:fixed;inset:0;background:var(--black);z-index:999;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;
  transform:translateY(-100%);transition:transform var(--t);
}
.mob-nav.open{transform:translateY(0);}
.mn-link{
  font-family:var(--ff-display);
  font-size:clamp(2.8rem,9vw,5.5rem);
  letter-spacing:.04em;color:var(--white);
  transition:color var(--t-fast);
}
.mn-link:hover{color:var(--white-3);}
.mn-whats{
  font-family:var(--ff-mono)!important;
  font-size:1rem!important;
  color:var(--white-3)!important;
  letter-spacing:.12em;
  border-top:1px solid var(--border);
  padding-top:20px;margin-top:4px;
}

/* =============================================
   BUTTONS
   ============================================= */
.btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--white);color:var(--black);
  font-family:var(--ff-body);font-size:14px;
  font-weight:600;letter-spacing:.03em;
  padding:14px 28px;border-radius:var(--radius);
  transition:all var(--t-fast);white-space:nowrap;
}
.btn-primary:hover{
  background:rgba(240,236,228,.88);
  transform:translateY(-2px);
  box-shadow:0 12px 40px rgba(0,0,0,.4);
}
.btn-primary svg{flex-shrink:0;transition:transform .2s ease;}
.btn-primary:hover svg{transform:translateX(3px);}

.btn-ghost{
  display:inline-flex;align-items:center;
  font-family:var(--ff-mono);font-size:12px;
  letter-spacing:.08em;color:var(--white-2);
  transition:color var(--t-fast);
  padding:14px 0;position:relative;
}
.btn-ghost::after{
  content:'';position:absolute;bottom:10px;left:0;
  width:100%;height:1px;background:var(--border-2);
  transition:background var(--t-fast);
}
.btn-ghost:hover{color:var(--white);}
.btn-ghost:hover::after{background:var(--white);}

.btn-outline{
  display:inline-flex;align-items:center;
  font-family:var(--ff-mono);font-size:12px;
  letter-spacing:.08em;color:var(--white-2);
  border:1px solid var(--border-2);
  padding:12px 22px;border-radius:var(--radius);
  transition:all var(--t-fast);
}
.btn-outline:hover{color:var(--white);border-color:rgba(240,236,228,.3);background:var(--white-4);}

/* =============================================
   SHARED SECTION ELEMENTS
   ============================================= */
.sec-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.15em;color:var(--white-3);
  text-transform:uppercase;margin-bottom:20px;
}
.sec-tag::before{
  content:'';display:block;
  width:24px;height:1px;background:var(--white-3);
}

.sec-header{margin-bottom:56px;}
.sec-title{
  font-family:var(--ff-display);
  font-size:clamp(2.4rem,4.5vw,5rem);
  letter-spacing:.03em;line-height:1.05;
  color:var(--white);
}
.sec-sub{
  margin-top:16px;
  font-size:15px;color:var(--white-2);line-height:1.7;
}

/* =============================================
   HERO
   ============================================= */
.hero{
  min-height:100vh;
  display:flex;align-items:center;
  padding:120px var(--pad) 80px;
  position:relative;overflow:hidden;
}

.hero-bg-grid{
  position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(240,236,228,.018) 1px,transparent 1px),
    linear-gradient(90deg,rgba(240,236,228,.018) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black,transparent);
}

.hero-content{
  max-width:var(--max-w);width:100%;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  gap:40px;align-items:center;
}

/* Left */
.hero-left{display:flex;flex-direction:column;gap:0;}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--ff-mono);font-size:11px;
  letter-spacing:.12em;color:var(--white-3);
  text-transform:uppercase;margin-bottom:32px;
}
.eyebrow-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--white);
  animation:dotPulse 2.5s ease infinite;
}
@keyframes dotPulse{
  0%,100%{opacity:1;transform:scale(1);}
  50%{opacity:.4;transform:scale(.6);}
}

.hero-title{
  font-family:var(--ff-display);
  letter-spacing:.02em;line-height:1;
  color:var(--white);margin-bottom:28px;
}
.ht-line{
  display:block;
  font-size:clamp(3.5rem,7.5vw,8.5rem);
}
.ht-line em{font-style:normal;}
.ht-sub{
  font-size:clamp(2.8rem,5.5vw,6rem);
  color:var(--white-2);
}
.ht-sub .stroke{
  -webkit-text-stroke:1.5px var(--white-2);
  color:transparent;
}

.hero-desc{
  font-size:16px;font-weight:300;
  color:var(--white-2);line-height:1.75;
  margin-bottom:40px;
}

.hero-actions{
  display:flex;align-items:center;gap:24px;
  flex-wrap:wrap;margin-bottom:56px;
}

.hero-stats{
  display:flex;align-items:center;gap:24px;
  padding-top:32px;border-top:1px solid var(--border);
}
.hstat{display:flex;align-items:baseline;gap:12px;}
.hstat-num{
  font-family:var(--ff-display);
  font-size:clamp(2.2rem,3.5vw,3.5rem);
  color:var(--white);line-height:1;
}
.hstat-label{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.08em;color:var(--white-3);
  line-height:1.4;
}
.hstat-div{
  width:1px;height:40px;
  background:var(--border);flex-shrink:0;
}

/* Right */
.hero-right{
  position:relative;display:flex;
  align-items:center;justify-content:center;
}

.hero-logo-big{
  width:clamp(280px,40vw,520px);
  aspect-ratio:1/1;
  pointer-events:all;cursor:grab;user-select:none;
}
.hero-logo-big.dragging{cursor:grabbing;animation:none!important;}
.logo-img-hero{
  width:100%;height:100%;object-fit:contain;
  pointer-events:none;will-change:transform;
  filter:drop-shadow(0 0 60px rgba(240,236,228,.05));
}

.hero-badge{
  position:absolute;bottom:-20px;right:-10px;
  display:inline-flex;align-items:center;gap:8px;
  background:var(--black-4);
  border:1px solid var(--border-2);
  border-radius:20px;padding:8px 16px;
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.08em;color:var(--white-2);
  white-space:nowrap;
}
.badge-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--white);flex-shrink:0;
  animation:dotPulse 2s ease infinite;
}

/* Scroll hint */
.hero-scroll-hint{
  position:absolute;left:20px;top:50%;
  transform:translateY(-50%);
  display:flex;flex-direction:column;align-items:center;gap:12px;
  z-index:1;
}
.hero-scroll-hint span{
  font-family:var(--ff-mono);font-size:9px;
  letter-spacing:.2em;color:var(--white-3);
  writing-mode:vertical-rl;
}
.scroll-track{width:1px;height:56px;background:var(--border);overflow:hidden;}
.scroll-thumb{
  width:100%;height:40%;background:var(--white-3);
  animation:scrollDown 2.2s ease infinite;
}
@keyframes scrollDown{
  0%{transform:translateY(-100%);}
  100%{transform:translateY(300%);}
}

/* =============================================
   PARA QUEM
   ============================================= */
.paraquem{
  padding:120px 0;
  background:var(--black-2);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}

.pq-header{
  text-align:center;margin-bottom:64px;
}
.pq-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.15em;color:var(--white-3);
  text-transform:uppercase;
  border:1px solid var(--border);
  padding:6px 16px;border-radius:20px;
  margin-bottom:24px;
}
.pq-title{
  font-family:var(--ff-display);
  font-size:clamp(2.2rem,4vw,4.5rem);
  letter-spacing:.03em;line-height:1.08;
  color:var(--white);margin-bottom:16px;
}
.pq-sub{
  font-size:15px;color:var(--white-2);
  max-width:480px;margin:0 auto;line-height:1.7;
}

.pq-cards{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:var(--radius-lg);
  overflow:hidden;
}
.pq-card{
  background:var(--black-3);
  padding:40px 32px;
  position:relative;
  transition:background var(--t-fast);
}
.pq-card::before{
  content:'';position:absolute;
  top:0;left:0;right:0;height:2px;
  background:var(--white-4);
  transition:background var(--t-fast);
}
.pq-card:hover{background:var(--black-4);}
.pq-card:hover::before{background:rgba(240,236,228,.2);}

.pqc-icon{
  width:44px;height:44px;
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--white-2);margin-bottom:20px;
  transition:border-color var(--t-fast),color var(--t-fast);
}
.pq-card:hover .pqc-icon{border-color:var(--border-2);color:var(--white);}

.pq-card h3{
  font-family:var(--ff-body);font-size:15px;
  font-weight:600;color:var(--white);
  margin-bottom:10px;line-height:1.3;
}
.pq-card p{
  font-size:13px;color:var(--white-2);
  line-height:1.65;font-weight:300;
}

/* =============================================
   SOBRE
   ============================================= */
.sobre{
  padding:120px 0;
  background:var(--black);
  position:relative;overflow:hidden;
  border-bottom:1px solid var(--border);
}

.sobre-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:start;
}

.sobre-title{
  font-family:var(--ff-display);
  font-size:clamp(3rem,6vw,7rem);
  line-height:.95;letter-spacing:.02em;
  color:var(--white);
  margin-bottom:32px;
  display:flex;flex-direction:column;
}
.sobre-title .italic{
  font-family:var(--ff-body);
  font-style:italic;font-weight:900;
  font-size:clamp(2.5rem,5vw,6rem);
}

.sobre-skills{
  display:flex;flex-wrap:wrap;gap:8px;
}
.sobre-skills span{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.1em;color:var(--white-3);
  border:1px solid var(--border);
  padding:6px 14px;border-radius:2px;
  transition:border-color var(--t-fast),color var(--t-fast);
}
.sobre-skills span:hover{border-color:var(--border-2);color:var(--white-2);}

.sobre-lead{
  font-family:var(--ff-display);
  font-size:clamp(1.6rem,2.5vw,2.2rem);
  letter-spacing:.02em;line-height:1.2;
  color:var(--white);margin-bottom:24px;
}
.sobre-body{
  font-size:15px;color:var(--white-2);
  line-height:1.8;font-weight:300;
  margin-bottom:16px;
}
.sobre-right .btn-outline{margin-top:24px;}

.sobre-deco{
  position:absolute;right:-2%;top:50%;
  transform:translateY(-50%);
  font-family:var(--ff-display);
  font-size:clamp(14rem,28vw,34rem);
  line-height:1;color:transparent;
  -webkit-text-stroke:1px rgba(240,236,228,.04);
  pointer-events:none;user-select:none;
}

/* =============================================
   SERVIÇOS
   ============================================= */
.servicos{
  padding:120px 0;
  background:var(--black-2);
  border-bottom:1px solid var(--border);
}

.sec-header .sec-tag{margin-bottom:16px;}

.srv-list{border-top:1px solid var(--border);}

.srv-item{
  display:grid;
  grid-template-columns:80px 1fr auto 48px;
  align-items:center;gap:40px;
  padding:36px 0;
  border-bottom:1px solid var(--border);
  position:relative;overflow:hidden;
  transition:background var(--t-fast),padding-left var(--t-fast);
}
.srv-item::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:0;
  background:var(--white-4);transition:width .4s var(--ease);
}
.srv-item:hover::before{width:100%;}
.srv-item:hover{padding-left:20px;}

.srv-num{
  font-family:var(--ff-mono);font-size:11px;
  letter-spacing:.1em;color:var(--white-3);
  position:relative;z-index:1;
}
.srv-body{position:relative;z-index:1;}
.srv-body h3{
  font-family:var(--ff-display);
  font-size:clamp(1.6rem,2.8vw,2.6rem);
  letter-spacing:.04em;color:var(--white);
  margin-bottom:6px;
}
.srv-body p{
  font-size:13px;color:var(--white-2);
  font-weight:300;line-height:1.6;
  max-width:480px;
}
.srv-tags{
  display:flex;flex-wrap:wrap;gap:8px;
  justify-content:flex-end;position:relative;z-index:1;
}
.srv-tags span{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.08em;color:var(--white-3);
  border:1px solid var(--border);padding:4px 10px;
  border-radius:20px;transition:all var(--t-fast);
}
.srv-item:hover .srv-tags span{border-color:var(--border-2);color:var(--white-2);}
.srv-arrow{
  font-size:20px;color:var(--white-3);
  transition:transform .3s ease,color .2s ease;
  position:relative;z-index:1;
}
.srv-item:hover .srv-arrow{transform:rotate(-45deg) scale(1.2);color:var(--white);}

/* =============================================
   PORTFÓLIO — grid 2x2 limpo
   ============================================= */
.portfolio{
  padding:120px 0;
  background:var(--black);
  border-bottom:1px solid var(--border);
}

.pf-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:20px;
  margin-bottom:0;
}

.pf-item{
  display:flex;flex-direction:column;
  background:var(--black-3);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  transition:border-color var(--t-fast),transform .4s var(--ease),box-shadow .4s ease;
}
.pf-item:hover{
  border-color:var(--border-2);
  transform:translateY(-6px);
  box-shadow:0 32px 80px rgba(0,0,0,.6);
}

.pf-thumb{
  position:relative;overflow:hidden;
  aspect-ratio:16/10;
}

.pf-img{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;
  object-position:center top;
  transition:transform .6s var(--ease);
}
.pf-item:hover .pf-img{transform:scale(1.04);}

/* Placeholder fallback */
.pf-ph{
  position:absolute;inset:0;
  background:var(--black-4);
  display:flex;align-items:center;justify-content:center;
}
.pf-ph.dark{background:#0a0a0a;}
.pf-ph.mid{background:#111;}
.pph-corner{
  position:absolute;top:16px;left:18px;
  font-family:var(--ff-mono);font-size:11px;
  letter-spacing:.1em;color:var(--white-3);
}
.pph-circle{
  width:80px;height:80px;
  border:1px solid rgba(240,236,228,.1);border-radius:50%;
}
.pph-grid-vis{
  position:absolute;inset:20%;
  border:1px solid rgba(240,236,228,.06);
}
.pph-grid-vis::after{
  content:'';position:absolute;
  top:50%;left:0;right:0;height:1px;
  background:rgba(240,236,228,.06);
}

.pf-over{
  position:absolute;inset:0;
  background:rgba(8,8,8,.88);
  display:flex;flex-direction:column;
  justify-content:flex-end;padding:28px;
  opacity:0;
  transition:opacity .3s ease;
  backdrop-filter:blur(4px);
}
.pf-item:hover .pf-over{opacity:1;}

.pf-over-tag{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.12em;color:var(--white-3);
  text-transform:uppercase;display:block;margin-bottom:8px;
}
.pf-over h3{
  font-family:var(--ff-display);font-size:1.8rem;
  letter-spacing:.04em;color:var(--white);margin-bottom:6px;
}
.pf-over p{font-size:13px;color:var(--white-2);margin-bottom:16px;font-weight:300;}
.pf-over a{
  font-family:var(--ff-mono);font-size:11px;
  letter-spacing:.1em;color:var(--white);
  border-bottom:1px solid var(--border-2);
  padding-bottom:2px;width:fit-content;
  transition:border-color .2s ease;
}
.pf-over a:hover{border-color:var(--white);}

.pf-meta{
  padding:18px 24px;
  border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.pf-name{
  font-size:14px;font-weight:600;color:var(--white);
}
.pf-type{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.1em;color:var(--white-3);text-transform:uppercase;
}

.pf-cta{
  margin-top:56px;
  padding-top:40px;border-top:1px solid var(--border);
}
.pf-cta-link{
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--ff-display);
  font-size:clamp(1.8rem,3.5vw,3rem);
  letter-spacing:.04em;color:var(--white-2);
  transition:color .2s ease;
}
.pf-cta-link:hover{color:var(--white);}
.pfc-arrow{font-size:2rem;transition:transform .3s ease;}
.pf-cta-link:hover .pfc-arrow{transform:translate(8px,-8px);}

/* =============================================
   PROCESSO
   ============================================= */
.processo{
  padding:120px 0;
  background:var(--black-2);
  border-bottom:1px solid var(--border);
}

.proc-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--border);
}
.proc-item{
  padding:40px 32px 40px 0;
  border-right:1px solid var(--border);
}
.proc-item:last-child{border-right:none;}
.proc-n{
  font-family:var(--ff-display);
  font-size:5rem;line-height:1;
  color:rgba(240,236,228,.06);margin-bottom:16px;
}
.proc-item h3{
  font-family:var(--ff-display);
  font-size:1.8rem;letter-spacing:.04em;
  color:var(--white);margin-bottom:12px;
}
.proc-item p{
  font-size:13px;color:var(--white-2);
  line-height:1.7;font-weight:300;
}

/* =============================================
   CTA STRIP
   ============================================= */
.cta-strip{
  overflow:hidden;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background:var(--black-3);
}
.cta-strip-inner{
  display:flex;align-items:center;gap:60px;
  padding:28px 0;
  animation:marquee 16s linear infinite;
  width:max-content;
}
.cta-strip:hover .cta-strip-inner{animation-play-state:paused;}
.ctas-text{
  font-family:var(--ff-display);
  font-size:clamp(2rem,3.5vw,3.5rem);
  letter-spacing:.08em;color:var(--white-2);
  white-space:nowrap;
  transition:color .2s ease;
}
.ctas-sep{
  font-size:1.2rem;color:var(--white-3);
  flex-shrink:0;
}
.cta-strip-inner:hover .ctas-text{color:var(--white);}
@keyframes marquee{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}

/* =============================================
   FAQ
   ============================================= */
.faq{
  padding:120px 0;
  background:var(--black);
  border-bottom:1px solid var(--border);
}

.faq-list{display:flex;flex-direction:column;gap:0;}

.faq-item{
  border-bottom:1px solid var(--border);
  transition:background var(--t-fast);
}
.faq-item:first-child{border-top:1px solid var(--border);}
.faq-item[open]{background:var(--white-5);}

.faq-q{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:24px 0;
  font-family:var(--ff-body);font-size:16px;
  font-weight:600;color:var(--white);
  transition:color var(--t-fast);
  position:relative;
}
.faq-q::after{
  content:'+';
  font-family:var(--ff-mono);font-size:20px;
  color:var(--white-3);flex-shrink:0;
  transition:transform .3s ease,color .2s ease;
}
details[open] .faq-q::after{transform:rotate(45deg);color:var(--white);}
.faq-q:hover{color:var(--white-2);}

.faq-a{
  padding:0 0 24px;
}
.faq-a p{
  font-size:14px;color:var(--white-2);
  line-height:1.75;font-weight:300;
  max-width:680px;
}

/* =============================================
   CONTATO
   ============================================= */
.contato{
  padding:120px 0;
  background:var(--black-2);
  border-bottom:1px solid var(--border);
}

.contato-inner{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
}

.ct-title{
  font-family:var(--ff-display);
  font-size:clamp(4rem,8vw,9rem);
  line-height:.92;color:var(--white);
  margin:16px 0 0;
  display:flex;flex-direction:column;
}
.ct-title .italic{
  font-family:var(--ff-body);
  font-style:italic;font-weight:900;
  font-size:clamp(3.5rem,7vw,8rem);
}
.ct-sub{
  font-size:14px;color:var(--white-3);
  font-family:var(--ff-mono);font-size:12px;
  letter-spacing:.06em;margin-top:28px;line-height:1.7;
}

.ct-right{display:flex;flex-direction:column;gap:12px;}

.ct-card{
  display:flex;align-items:center;gap:20px;
  padding:22px 24px;
  background:var(--black-3);
  border:1px solid var(--border);
  border-radius:var(--radius);
  transition:border-color var(--t-fast),background var(--t-fast);
}
.ct-card.static{pointer-events:none;}
.ct-card:not(.static):hover{border-color:var(--border-2);background:var(--black-4);}

.ctc-icon{
  width:44px;height:44px;
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--white-2);flex-shrink:0;
  transition:border-color var(--t-fast),color var(--t-fast);
}
.ct-card:hover .ctc-icon{border-color:var(--border-2);color:var(--white);}
.ctc-info{display:flex;flex-direction:column;gap:2px;flex:1;}
.ctc-label{
  font-family:var(--ff-mono);font-size:9px;
  letter-spacing:.15em;color:var(--white-3);text-transform:uppercase;
}
.ctc-val{font-size:15px;font-weight:500;color:var(--white);}
.ctc-arr{
  font-size:18px;color:var(--white-3);
  transition:transform .3s ease,color .2s ease;
}
.ct-card:hover .ctc-arr{transform:translate(4px,-4px);color:var(--white);}

/* =============================================
   FOOTER
   ============================================= */
.footer{
  padding:48px 0 40px;
  background:var(--black-3);
  border-top:1px solid var(--border);
}

.ft-top{
  display:flex;align-items:center;
  justify-content:space-between;margin-bottom:40px;
}
.ft-logo{display:flex;align-items:center;gap:12px;}
.ft-top nav{display:flex;gap:32px;}
.ft-top nav a{
  font-family:var(--ff-mono);font-size:11px;
  letter-spacing:.08em;color:var(--white-3);
  transition:color var(--t-fast);
}
.ft-top nav a:hover{color:var(--white-2);}
.ft-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:24px;border-top:1px solid var(--border);
}
.ft-bottom span{
  font-family:var(--ff-mono);font-size:10px;
  letter-spacing:.06em;color:var(--white-3);
}

/* WhatsApp FAB */
.mob-whats-fab{
  display:none;position:fixed;
  bottom:24px;right:24px;z-index:500;
  width:56px;height:56px;
  background:var(--white);border-radius:50%;
  align-items:center;justify-content:center;
  box-shadow:0 8px 32px rgba(0,0,0,.5);
  transition:transform .2s ease;
}
.mob-whats-fab:hover{transform:scale(1.08);}
.mob-whats-fab svg{width:26px;height:26px;color:var(--black);}

/* Nav animations */
@keyframes navDrop{
  from{transform:translateY(-100%);opacity:0;}
  to{transform:translateY(0);opacity:1;}
}
@keyframes pageIn{from{opacity:0;}to{opacity:1;}}
body{animation:pageIn .35s ease forwards;}

/* =============================================
   RESPONSIVE — 1100px
   ============================================= */
@media(max-width:1100px){
  .hero-content{grid-template-columns:1fr;}
  .hero-right{display:none;}
  .hero-stats{flex-wrap:wrap;gap:16px;}
  .pq-cards{grid-template-columns:repeat(2,1fr);}
  .sobre-grid{grid-template-columns:1fr;gap:48px;}
  .sobre-deco{display:none;}
  .srv-item{grid-template-columns:60px 1fr 48px;}
  .srv-tags{display:none;}
  .proc-grid{grid-template-columns:1fr 1fr;}
  .proc-item{border-right:none;border-bottom:1px solid var(--border);}
  .proc-item:nth-child(odd){border-right:1px solid var(--border);}
  .proc-item:last-child{border-bottom:none;}
  .contato-inner{grid-template-columns:1fr;gap:48px;}
  .hero-scroll-hint{display:none;}
}

/* ── Nav active state ── */
.nl-active {
  color: var(--white) !important;
}
.nl-active::after {
  width: 100% !important;
}

/* ── Body loaded — remove FOUC ── */
body:not(.loaded) .hero-content {
  opacity: 0;
}
body.loaded .hero-content {
  transition: opacity .4s ease;
  opacity: 1;
}
