/* =====================================================
   Vitória Palavro - Site CSS
   Editorial monochrome minimalist (paridade React)
   ===================================================== */

:root{
  --bg: #0B0B0C;
  --fg: #F5F5F3;
  --fg-70: rgba(245,245,243,0.7);
  --fg-55: rgba(245,245,243,0.55);
  --fg-30: rgba(245,245,243,0.30);
  --fg-15: rgba(245,245,243,0.15);
  --fg-10: rgba(245,245,243,0.10);
  --accent: #C9694A;          /* terracota */
  --villa-green: #36534A;
  --card: #141416;
  --border: rgba(245,245,243,0.18);
  --max-w: 1440px;
  --gutter: clamp(20px, 4vw, 40px);
  --font-serif: 'Playfair Display', 'Inter Tight', serif;
  --font-sans: 'Inter Tight', 'Inter', system-ui, sans-serif;
  --font-body: 'Inter', system-ui, sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--fg);font-family:var(--font-body);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased}
img,svg,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}
input,textarea,select{font:inherit;color:inherit}

.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 var(--gutter)}

/* ICON SIZES */
.icon-3{width:14px;height:14px}.icon-4{width:16px;height:16px}.icon-5{width:20px;height:20px}.icon-6{width:24px;height:24px}.icon-7{width:28px;height:28px}

/* SECTION BASICS */
.section{padding:64px 0}
@media(min-width:768px){.section{padding:88px 0}}

.section-head{margin-bottom:48px}
@media(min-width:768px){.section-head{margin-bottom:64px}}
.section-head--split{display:grid;gap:32px;align-items:end}
@media(min-width:1024px){.section-head--split{grid-template-columns:2fr 1fr}}
.section-head__aside{color:var(--fg-70);font-size:.95rem;max-width:340px;justify-self:start}
@media(min-width:1024px){.section-head__aside{justify-self:end;text-align:right}}

.kicker{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin:0 0 24px}
.kicker--accent{color:var(--accent)}
.rule{height:1px;background:var(--fg-30);max-width:120px;margin-top:32px}
.rule--light{background:rgba(255,255,255,.4)}

.h-section{font-family:var(--font-serif);font-weight:400;font-size:clamp(34px,5.4vw,64px);line-height:1.05;letter-spacing:-.02em;margin:0;color:var(--fg)}
.h-section--white{color:#fff}
.ttl-accent{color:var(--accent);font-style:italic}
.italic{font-style:italic}
.big-statement{font-family:var(--font-serif);font-size:clamp(22px,2.6vw,32px);line-height:1.25;max-width:520px;margin:0;color:var(--fg)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;height:48px;padding:0 28px;font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;transition:background .25s,color .25s,border-color .25s}
.btn--light{background:#fff;color:#111}
.btn--light:hover{background:rgba(255,255,255,.9)}
.btn--ghost{border:1px solid var(--fg-30);color:var(--fg)}
.btn--ghost:hover{border-color:var(--fg);background:rgba(245,245,243,.05)}
.btn--accent{background:var(--accent);color:#fff}
.btn--accent:hover{background:rgba(201,105,74,.9)}
.btn--block{width:100%}
.btn--mt{margin-top:56px}

/* HEADER */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .3s,border-color .3s,backdrop-filter .3s;background:transparent}
.site-header[data-scrolled="true"]{background:rgba(11,11,12,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;height:72px;padding:0 var(--gutter);max-width:var(--max-w);margin:0 auto}
.brand__text{font-family:var(--font-serif);font-size:22px;font-weight:600;letter-spacing:-.01em;color:var(--fg)}
.brand__accent{color:var(--accent);font-style:italic}
.nav-desktop{display:none;gap:22px;align-items:center}
@media(min-width:1024px){.nav-desktop{display:flex}}
.nav-desktop a{font-size:10px;text-transform:uppercase;letter-spacing:.2em;color:var(--fg-70);transition:color .2s}
.nav-desktop a:hover{color:var(--fg)}
.nav-cta{background:var(--accent);color:#fff !important;padding:8px 14px}
.nav-cta:hover{background:rgba(201,105,74,.9);color:#fff !important}
.nav-toggle{display:inline-flex;width:32px;height:32px;align-items:center;justify-content:center;color:var(--fg)}
@media(min-width:1024px){.nav-toggle{display:none}}
.nav-mobile{display:flex;flex-direction:column;gap:18px;padding:8px var(--gutter) 32px;background:rgba(11,11,12,.95);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.nav-mobile[hidden]{display:none}
@media(min-width:1024px){.nav-mobile{display:none !important}}
.nav-mobile a{font-size:12px;text-transform:uppercase;letter-spacing:.18em;color:var(--fg-70)}
.nav-mobile__cta{background:var(--accent);color:#fff !important;padding:12px;text-align:center;margin-top:8px}

/* HERO */
.hero{position:relative;min-height:100vh;display:flex;padding-top:72px;overflow:hidden}
.hero__grid{display:grid;grid-template-columns:1fr;width:100%}
@media(min-width:1024px){.hero__grid{grid-template-columns:1fr 1fr}}
.hero__text{display:flex;flex-direction:column;justify-content:center;padding:64px var(--gutter);order:2}
@media(min-width:1024px){.hero__text{order:1;padding:80px clamp(40px,5vw,72px)}}
.hero__tag{display:inline-flex;align-items:center;gap:10px;padding:6px 12px;border:1px solid var(--border);background:rgba(20,20,22,.4);width:fit-content;font-size:10px;text-transform:uppercase;letter-spacing:.22em;color:var(--fg-70);margin-bottom:40px}
.hero__tag-dot{width:8px;height:8px;background:var(--accent);border-radius:50%;box-shadow:0 0 0 4px rgba(201,105,74,.25);animation:pulse 2s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 8px rgba(201,105,74,0)}}
.hero__title{font-family:var(--font-serif);font-weight:400;line-height:1.02;letter-spacing:-.02em;font-size:clamp(40px,6.2vw,72px);margin:0 0 32px}
.hero__title .line{display:block;overflow:hidden}
.hero__title .line>span{display:block;animation:slideUp .9s cubic-bezier(.33,1,.68,1) both}
.hero__title .line:nth-child(2)>span{animation-delay:.15s}
.hero__title .line:nth-child(3)>span{animation-delay:.3s}
.hero__title .line:nth-child(4)>span{animation-delay:.45s}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.hero__subtitle{color:var(--fg-70);font-size:clamp(15px,1.2vw,18px);line-height:1.55;max-width:430px;margin:0 0 40px}
.hero__cta{display:flex;gap:12px;margin-bottom:48px;flex-wrap:wrap}
.hero__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding-top:32px;border-top:1px solid var(--border);max-width:520px}
.stat__value{font-family:var(--font-serif);font-size:clamp(22px,2vw,30px);color:var(--fg);margin-bottom:4px}
.stat__label{font-size:10px;text-transform:uppercase;letter-spacing:.16em;color:var(--fg-55);line-height:1.3}
.stat--big .stat__value{font-size:clamp(34px,3.6vw,48px);margin-bottom:12px}
.hero__photo{position:relative;width:70%;max-width:520px;aspect-ratio:4/5;margin:24px auto 0;background-size:cover;background-position:center top;background-color:#1a1a1c;order:1;min-height:0}
@media(min-width:1024px){.hero__photo{width:100%;max-width:none;aspect-ratio:auto;margin:0;order:2;min-height:calc(100vh - 72px)}}

/* PROJETOS */
.filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:40px}
.pill{font-size:11px;text-transform:uppercase;letter-spacing:.18em;padding:8px 16px;border:1px solid var(--border);color:var(--fg-70);transition:all .2s}
.pill:hover{border-color:var(--fg);color:var(--fg)}
.pill.is-active{background:var(--fg);color:#111;border-color:var(--fg)}
.projects-grid{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:640px){.projects-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.projects-grid{grid-template-columns:repeat(6,1fr);grid-auto-rows:95px}}
.project-card{position:relative;overflow:hidden;background:var(--card);min-height:180px;display:block;grid-column:span 1;grid-row:span 2}
@media(min-width:1024px){.project-card{grid-column:span 2;grid-row:span 2;min-height:0}.project-card--big{grid-column:span 4;grid-row:span 3}}
.project-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.25,.1,.25,1)}
.project-card:hover img{transform:scale(1.04)}
.project-card__overlay{position:absolute;inset:0;padding:28px;display:flex;flex-direction:column;justify-content:flex-end;background:rgba(11,11,12,0);opacity:0;transform:translateY(12px);transition:all .5s}
.project-card:hover .project-card__overlay{background:rgba(11,11,12,.72);opacity:1;transform:translateY(0)}
.project-card__overlay h3{font-family:var(--font-serif);font-size:clamp(20px,1.6vw,26px);margin:0 0 16px;line-height:1.2}
.project-card__overlay .more{display:inline-flex;align-items:center;gap:8px;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--fg)}
.project-card.is-hidden{display:none}
.project-card--hidden{display:none}
.projects-more{display:flex;justify-content:center;margin-top:32px}
.pill--lg{font-size:12px;padding:14px 28px}

/* FPV */
.fpv{padding:0;border-top:1px solid var(--border)}
.fpv__grid{display:grid;grid-template-columns:1fr}
@media(min-width:1024px){.fpv__grid{grid-template-columns:1fr 1fr}}
.fpv__photo{min-height:50vh;background-size:cover;background-position:top;background-color:#1a1a1c}
@media(min-width:1024px){.fpv__photo{min-height:75vh}}
.fpv__content{padding:64px var(--gutter)}
@media(min-width:1024px){.fpv__content{padding:80px clamp(40px,5vw,72px)}}
.lead{color:var(--fg-70);font-size:clamp(15px,1.1vw,18px);line-height:1.6;max-width:420px;margin:0 0 32px}
.fpv__specs{display:grid;grid-template-columns:1fr;gap:1px;background:var(--border);margin-bottom:32px}
@media(min-width:640px){.fpv__specs{grid-template-columns:repeat(2,1fr)}}
.fpv__spec{background:var(--bg);padding:24px}
.fpv__spec h3{font-family:var(--font-serif);font-size:18px;margin:16px 0 8px;line-height:1.3}
.fpv__spec p{font-size:12px;color:var(--fg-55);line-height:1.55;margin:0}

/* SERVIÇOS */
.servicos{background:var(--villa-green)}
.servicos__grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--border)}
@media(min-width:768px){.servicos__grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.servicos__grid{grid-template-columns:repeat(4,1fr)}}
.servico{background:var(--villa-green);padding:40px;min-height:260px;display:flex;flex-direction:column;transition:background .3s}
.servico:hover{background:rgba(54,83,74,.82)}
.servico h3{font-family:var(--font-serif);font-size:24px;margin:40px 0 12px;color:var(--fg)}
.servico p{font-size:14px;color:var(--fg-70);line-height:1.6;margin:0}

/* SEGMENTOS */
.segmentos__grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--border);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
@media(min-width:768px){.segmentos__grid{grid-template-columns:repeat(3,1fr)}}
.segmento{background:var(--bg);padding:28px;min-height:380px;display:flex;flex-direction:column;transition:background .3s}
.segmento:hover{background:rgba(245,245,243,.03)}
.segmento__top{display:flex;justify-content:space-between;align-items:start;margin-bottom:32px}
.segmento__num{font-family:var(--font-serif);font-size:56px;color:var(--fg-15);line-height:1;transition:color .3s}
.segmento:hover .segmento__num{color:var(--accent)}
.segmento h3{font-family:var(--font-serif);font-size:26px;margin:0 0 12px;line-height:1.15}
.segmento__desc{font-size:14px;color:var(--fg-70);line-height:1.6;margin:24px 0 32px}
.segmento ul{list-style:none;padding:24px 0 0;margin:auto 0 0;border-top:1px solid var(--fg-10);display:flex;flex-direction:column;gap:8px}
.segmento li{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--fg-55);display:flex;align-items:center;gap:12px}
.dash{width:16px;height:1px;background:var(--fg-30);display:inline-block}
.segmentos__cta{margin-top:80px;display:flex;flex-direction:column;gap:24px;align-items:flex-start}
@media(min-width:768px){.segmentos__cta{flex-direction:row;justify-content:space-between;align-items:center}}

/* SOBRE */
.sobre__grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:start}
@media(min-width:1024px){.sobre__grid{grid-template-columns:5fr 7fr;gap:64px}}
.sobre__mosaic{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
.mosaic-cell{overflow:hidden}
.mosaic-cell--portrait{grid-column:span 2;aspect-ratio:3/4}
.mosaic-cell--land{grid-column:span 3;aspect-ratio:16/10}
.mosaic-cell img{width:100%;height:100%;object-fit:cover}
.sobre__caption{grid-column:1/-1;font-size:10px;text-transform:uppercase;letter-spacing:.22em;color:var(--fg-55);margin:16px 0 0}
.sobre__text{display:flex;flex-direction:column;gap:24px;max-width:560px}
.sobre__lead{font-family:var(--font-serif);font-size:clamp(22px,2vw,28px);line-height:1.3;margin:0}
.sobre__text p{color:var(--fg-70);line-height:1.65;margin:0}
.sobre__stats{margin-top:40px;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.sobre__stats .stat--big{background:var(--bg);padding:28px}
.sobre__text .btn{margin-top:40px;align-self:flex-start}

/* CLIENTES - MARQUEE */
.clientes__marquee{position:relative;overflow:hidden;border-top:1px solid var(--fg-10);border-bottom:1px solid var(--fg-10);padding:24px 0;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.clientes__track{display:flex;gap:64px;width:max-content;animation:clientes-scroll 40s linear infinite}
.clientes__marquee:hover .clientes__track{animation-play-state:paused}
.cliente{flex:0 0 auto;display:flex;align-items:center;justify-content:center;min-height:80px;padding:0 12px}
.cliente__name{font-family:var(--font-sans);font-weight:500;font-size:17px;color:rgba(245,245,243,.85);letter-spacing:-.01em;white-space:nowrap}
.cliente img{max-height:40px;width:auto;filter:grayscale(1) brightness(2);opacity:.85}
@keyframes clientes-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){.clientes__track{animation:none}}

/* DEPOIMENTOS */
.depoimentos{padding:64px 0 80px}
.depoimentos__scroller{display:flex;gap:1px;background:var(--border);border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;margin:0 calc(var(--gutter)*-1);padding:0 var(--gutter)}
.depoimentos__scroller::-webkit-scrollbar{display:none}
.depo{background:var(--bg);padding:36px;flex-shrink:0;width:85%;min-height:340px;display:flex;flex-direction:column;scroll-snap-align:start;transition:background .3s}
@media(min-width:640px){.depo{width:60%}}@media(min-width:768px){.depo{width:50%}}@media(min-width:1024px){.depo{width:33.333%}}
.depo:hover{background:rgba(245,245,243,.03)}
.depo__quote{color:var(--accent);margin-bottom:28px}
.depo__text{font-family:var(--font-serif);font-size:clamp(18px,1.4vw,22px);line-height:1.4;color:var(--fg);flex-grow:1;margin:0 0 32px}
.depo__author{border-top:1px solid var(--border);padding-top:20px}
.depo__name{font-family:var(--font-serif);font-size:16px;margin:0 0 6px}
.depo__meta{font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:var(--fg-55);margin:0}

/* FAQ */
.faq .section-head{margin-bottom:64px}
.accordion{border-top:1px solid var(--border)}
.acc-item{border-bottom:1px solid var(--border)}
.acc-toggle{display:flex;align-items:flex-start;gap:24px;width:100%;text-align:left;padding:28px 0;color:var(--fg)}
.acc-num{flex-shrink:0;width:32px;font-size:10px;text-transform:uppercase;letter-spacing:.22em;color:var(--fg-30);padding-top:8px;display:none}
@media(min-width:768px){.acc-num{display:inline-block}}
.acc-title{flex:1;font-family:var(--font-serif);font-size:clamp(20px,2.4vw,32px);line-height:1.15;margin:0;letter-spacing:-.01em;transition:color .2s}
.acc-toggle:hover .acc-title{color:var(--accent)}
.acc-icon{flex-shrink:0;width:44px;height:44px;border:1px solid var(--border);display:inline-flex;align-items:center;justify-content:center;transition:transform .35s}
.acc-item.is-open .acc-icon{transform:rotate(45deg)}
.acc-panel{overflow:hidden;max-height:0;transition:max-height .4s cubic-bezier(.22,1,.36,1)}
.acc-item.is-open .acc-panel{max-height:600px}
.acc-panel__inner{padding:0 0 32px;max-width:700px}
@media(min-width:768px){.acc-panel__inner{padding-left:56px;padding-right:80px}}
.acc-panel p{color:var(--fg-70);font-size:clamp(15px,1.1vw,18px);line-height:1.65;margin:0}

/* ORÇAMENTO */
.orcamento{background:#0d0d0d}
.orcamento__sub{color:var(--fg-55);font-size:15px;margin-top:16px}
.orcamento__grid{display:grid;grid-template-columns:1fr;gap:40px;margin-top:56px}
@media(min-width:1024px){.orcamento__grid{grid-template-columns:4fr 8fr;gap:64px}}
.orcamento__aside{display:flex;flex-direction:column;gap:24px}
@media(min-width:1024px){.orcamento__aside{position:sticky;top:110px;align-self:start}}
.chan{display:block;border-top:1px solid var(--border);padding-top:24px;transition:border-color .25s}
.chan:hover{border-top-color:var(--accent)}
.chan__label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.22em;color:var(--fg-55);margin-bottom:8px}
.chan__value{display:block;font-family:var(--font-serif);font-size:clamp(20px,1.6vw,26px);color:var(--fg);transition:color .25s;word-break:break-word}
.chan:hover .chan__value{color:var(--accent)}
.orc-form{display:flex;flex-direction:column;gap:20px}
.orc-row{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:640px){.orc-row{grid-template-columns:1fr 1fr}}
.orc-field label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.22em;color:rgba(255,255,255,.55);margin-bottom:12px;font-weight:500}
.orc-field input,.orc-field textarea{width:100%;background:transparent;border:1px solid rgba(255,255,255,.2);padding:14px 16px;color:#fff;border-radius:3px;font-size:14px;transition:border-color .2s}
.orc-field input:focus,.orc-field textarea:focus{outline:none;border-color:var(--accent)}
.orc-field textarea{resize:vertical;min-height:160px}
.orc-checks{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}
.orc-check{display:flex;align-items:center;gap:12px;padding:12px 16px;border:1px solid rgba(255,255,255,.2);border-radius:3px;cursor:pointer;font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:rgba(255,255,255,.75);transition:all .2s}
.orc-check:hover{border-color:rgba(255,255,255,.45)}
.orc-check input{width:16px;height:16px;accent-color:var(--accent)}
.orc-check:has(input:checked){border-color:var(--accent);color:#fff;background:rgba(201,105,74,.1)}
.orc-feedback{margin-top:16px;font-size:14px}
.orc-feedback.is-ok{color:#7CC892}
.orc-feedback.is-err{color:var(--accent)}

/* CONTATO */
.contato{background:var(--fg);color:var(--bg);padding:80px 0 96px}
.contato .kicker{color:var(--accent)}
.contato .h-section{color:var(--bg)}
.contato__grid{display:grid;grid-template-columns:1fr;gap:1px;background:rgba(11,11,12,.15);border-top:1px solid rgba(11,11,12,.15);border-bottom:1px solid rgba(11,11,12,.15)}
@media(min-width:768px){.contato__grid{grid-template-columns:repeat(2,1fr)}}
.contato__card{background:var(--fg);padding:40px;min-height:180px;display:flex;flex-direction:column;justify-content:flex-end;transition:background .25s}
.contato__card:hover{background:rgba(245,245,243,.85)}
.contato__card svg{color:var(--bg);margin-bottom:24px}
.contato__card .kicker{color:rgba(11,11,12,.55);margin-bottom:12px}
.contato__value{font-family:var(--font-serif);font-size:clamp(22px,1.8vw,28px);color:var(--bg);margin:0;word-break:break-word}
.contato__signature{display:grid;grid-template-columns:1fr;gap:24px;margin-top:40px}
@media(min-width:768px){.contato__signature{grid-template-columns:repeat(3,1fr)}}
.contato__signature .kicker{color:rgba(11,11,12,.45);margin-bottom:8px}
.contato__signature p,.contato__signature a{font-family:var(--font-serif);color:var(--bg);font-size:18px}

/* FOOTER */
.site-footer{background:var(--fg);color:var(--bg);border-top:1px solid rgba(11,11,12,.15)}
.site-footer__brand{padding:40px var(--gutter) 32px;max-width:var(--max-w);margin:0 auto}
.site-footer__wordmark{font-family:var(--font-serif);font-size:32px;line-height:1;letter-spacing:-.01em;color:rgba(11,11,12,.9);margin:0;user-select:none}
.site-footer__bar{display:flex;flex-direction:column;gap:16px;padding:32px var(--gutter);border-top:1px solid rgba(11,11,12,.15);max-width:var(--max-w);margin:0 auto}
@media(min-width:768px){.site-footer__bar{flex-direction:row;justify-content:space-between;align-items:center}}
.site-footer__copy,.site-footer__links a{font-size:11px;text-transform:uppercase;letter-spacing:.22em;color:rgba(11,11,12,.55)}
.site-footer__links{display:flex;gap:32px}
.site-footer__links a:hover{color:var(--accent)}
.site-footer__links a.muted{color:rgba(11,11,12,.3)}

/* WHATSAPP FLOAT */
.whatsapp-float{position:fixed;bottom:24px;right:24px;z-index:60;display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;background:#25D366;color:#fff;box-shadow:0 10px 30px rgba(0,0,0,.35);transition:transform .2s}
.whatsapp-float:hover{transform:scale(1.05)}
.whatsapp-float svg{width:28px;height:28px}
@media(min-width:768px){.whatsapp-float{bottom:32px;right:32px;width:64px;height:64px}.whatsapp-float svg{width:32px;height:32px}}

/* PROJETO DETAIL */
.projeto-detail{padding:120px 0 80px}
.back-link{display:inline-block;font-size:11px;text-transform:uppercase;letter-spacing:.22em;color:var(--fg-70);margin-bottom:32px}
.back-link:hover{color:var(--accent)}
.back-to-portfolio{display:inline-flex;align-items:center;gap:10px;padding:12px 20px;margin-bottom:40px;border:1px solid var(--fg-30,rgba(245,245,243,.3));border-radius:999px;font-size:12px;text-transform:uppercase;letter-spacing:.2em;color:var(--fg);background:transparent;transition:background .25s ease,color .25s ease,border-color .25s ease}
.back-to-portfolio:hover{background:var(--fg);color:var(--bg);border-color:var(--fg)}
.projeto-nav{border-top:1px solid var(--fg-30,rgba(245,245,243,.15));margin-top:80px;padding:48px 0}
.projeto-nav__inner{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.projeto-nav__item{display:flex;align-items:center;gap:16px;text-decoration:none;color:var(--fg);min-width:0}
.projeto-nav__item--next{justify-content:flex-end;text-align:right}
.projeto-nav__thumb{flex:0 0 auto;width:120px;height:80px;overflow:hidden;border-radius:4px;background:#111}
.projeto-nav__thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.projeto-nav__item:hover .projeto-nav__thumb img{transform:scale(1.06)}
.projeto-nav__meta{display:flex;flex-direction:column;gap:6px;min-width:0}
.projeto-nav__label{font-size:10px;text-transform:uppercase;letter-spacing:.22em;color:var(--fg-70,rgba(245,245,243,.7))}
.projeto-nav__name{font-family:var(--font-serif,inherit);font-size:18px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media (max-width:640px){.projeto-nav__thumb{width:84px;height:56px}.projeto-nav__name{font-size:14px}.projeto-nav__inner{gap:16px}}
.projeto-detail h2{font-family:var(--font-serif);font-size:24px;margin:48px 0 16px}
.projeto-detail__media{display:block;margin:32px 0}
.projeto-detail__media > * + *{margin-top:24px}
.media-item{
  display:block; background:#000; margin:0 auto;
  width:100%;
  max-height:calc(100vh - 160px);
  aspect-ratio:16/9;
  max-width:calc((100vh - 160px) * 16 / 9);
}
.media-item--portrait{
  aspect-ratio:9/16;
  max-width:calc((100vh - 160px) * 9 / 16);
}
.media-item > iframe,
.media-item > video,
.media-item > img{
  width:100%; height:100%; display:block; border:0;
  object-fit:contain; background:#000;
}

/* REVEAL ANIMATION */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.reveal.is-visible{opacity:1;transform:none}

@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero__title .line>span{animation:none}
}

/* FAILSAFE: se o JS não rodar (ex.: site.js 404, bloqueio de cache, erro),
   o conteúdo aparece em 1.5s para não deixar a página em branco */
@keyframes vp-reveal-failsafe { to { opacity:1; transform:none; } }
.reveal{ animation: vp-reveal-failsafe 0s linear 1.5s forwards; }
.reveal.is-visible{ animation: none; }