:root{--black:#2A2A2A;--cream:#F1E8E0;--teal:#7C8C87;--terra:#A14D3A;--gold:#CFAF68;--mono:'Roboto Mono',monospace}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--mono);background:var(--cream);color:var(--black);overflow-x:hidden}
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--cream)}::-webkit-scrollbar-thumb{background:var(--black)}

nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:28px 56px;transition:background .4s,padding .4s;border-bottom:1px solid transparent}
nav.scrolled{background:rgba(241,232,224,.96);backdrop-filter:blur(10px);padding:18px 56px;border-bottom-color:rgba(42,42,42,.1)}
.nav-logo-wrap{display:flex;align-items:center;gap:14px}
.nav-symbol{height:32px;width:auto;border-radius:2px}
.nav-wordmark{height:16px;width:auto;transition:filter .4s}
nav:not(.scrolled) .nav-wordmark{filter:invert(1)}
.nav-links{display:flex;gap:36px;list-style:none}
.nav-links a{font-size:10px;letter-spacing:.18em;text-transform:lowercase;text-decoration:none;transition:color .3s}
nav:not(.scrolled) .nav-links a{color:rgba(241,232,224,.6)}
nav.scrolled .nav-links a{color:rgba(42,42,42,.5)}
nav:not(.scrolled) .nav-links a:hover{color:var(--cream)}
nav.scrolled .nav-links a:hover{color:var(--black)}
.nav-cta{font-size:10px;letter-spacing:.16em;text-transform:lowercase;text-decoration:none;padding:9px 20px;transition:background .3s,color .3s}
nav:not(.scrolled) .nav-cta{background:var(--gold);color:var(--black)}
nav.scrolled .nav-cta{background:var(--black);color:var(--cream)}
.nav-cta:hover{background:var(--terra);color:var(--cream)}

#hero{min-height:100vh;background:var(--black);display:grid;grid-template-rows:1fr auto;padding:0 56px 64px;position:relative;overflow:hidden}
.hero-m-bg{position:absolute;right:-60px;bottom:-80px;width:min(700px,70vw);opacity:.06;user-select:none;pointer-events:none}
.hero-content{align-self:center;padding-top:140px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.hero-eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:40px}
.hero-eyebrow-line{width:28px;height:1px;background:var(--teal)}
.hero-eyebrow span{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--teal)}
.hero-logo{display:block;height:clamp(100px, 50vw, 300px);width:auto;filter:invert(1);margin-bottom:10px}
.hero-headline{font-size:clamp(28px,4vw,52px);font-weight:300;line-height:1.2;letter-spacing:-.01em;color:var(--cream)}
.hero-headline em{font-style:normal;color:var(--gold);display:block}
.hero-right{display:flex;flex-direction:column;gap:48px}
.hero-sub{font-size:14px;font-weight:300;line-height:2;letter-spacing:.04em;color:rgba(241,232,224,.5);border-left:1px solid rgba(241,232,224,.12);padding-left:28px}
.hero-tags{display:flex;flex-direction:column;border-top:1px solid rgba(241,232,224,.08)}
.hero-tag{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid rgba(241,232,224,.08);font-size:10px;letter-spacing:.16em;text-transform:lowercase}
.hero-tag-name{color:rgba(241,232,224,.5)}
.hero-tag-dot{width:6px;height:6px;border-radius:50%}
.hero-tag:nth-child(1) .hero-tag-dot{background:var(--gold)}
.hero-tag:nth-child(2) .hero-tag-dot{background:var(--teal)}
.hero-tag:nth-child(3) .hero-tag-dot{background:var(--terra)}
.hero-bottom{display:flex;align-items:center;gap:16px}
.hero-scroll-line{width:48px;height:1px;background:rgba(241,232,224,.15);position:relative;overflow:hidden}
.hero-scroll-line::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:var(--gold);animation:slide 2.5s ease-in-out infinite}
@keyframes slide{0%{left:-100%}50%{left:0}100%{left:100%}}
.hero-scroll-label{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:rgba(241,232,224,.25)}

.section-label{display:flex;align-items:center;gap:12px;margin-bottom:64px}
.section-label-line{width:24px;height:1px}
.section-label span{font-size:9px;letter-spacing:.22em;text-transform:uppercase}

#sobre{display:grid;grid-template-columns:1fr 1fr;background:var(--cream)}
.sobre-left{padding:120px 64px 120px 56px;border-right:1px solid rgba(42,42,42,.08);position:relative;overflow:hidden}
.sobre-m-watermark{position:absolute;bottom:-40px;left:-20px;width:280px;opacity:.04;pointer-events:none}
.sobre-left .section-label-line{background:var(--teal)}
.sobre-left .section-label span{color:var(--teal)}
.sobre-heading{font-size:clamp(26px,3.5vw,44px);font-weight:300;line-height:1.2;letter-spacing:-.01em;margin-bottom:40px}
.sobre-heading strong{font-weight:500}
.sobre-body{font-size:12px;line-height:2;letter-spacing:.04em;color:rgba(42,42,42,.55);max-width:380px}
.sobre-right{padding:120px 56px 120px 64px;display:flex;flex-direction:column;gap:48px}
.sobre-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(42,42,42,.08)}
.stat-box{background:var(--cream);padding:36px 32px}
.stat-number{font-size:40px;font-weight:300;letter-spacing:-.02em;color:var(--black);line-height:1;margin-bottom:8px}
.stat-label{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--teal)}
.sobre-quote{font-size:11px;line-height:2;letter-spacing:.05em;color:rgba(42,42,42,.4);font-style:italic;padding-top:32px;border-top:1px solid rgba(42,42,42,.08)}

#servicos{background:var(--black);padding:120px 56px;position:relative;overflow:hidden}
.servicos-m{position:absolute;top:48px;right:56px;width:120px;opacity:.08;pointer-events:none}
#servicos .section-label-line{background:var(--gold)}
#servicos .section-label span{color:var(--gold)}
.servicos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(241,232,224,.06)}
.servico-card{background:var(--black);padding:52px 44px;transition:background .3s;position:relative}
.servico-card:hover{background:#303030}
.servico-accent{position:absolute;top:0;left:0;right:0;height:2px}
.servico-card:nth-child(1) .servico-accent{background:var(--gold)}
.servico-card:nth-child(2) .servico-accent{background:var(--teal)}
.servico-card:nth-child(3) .servico-accent{background:var(--terra)}
.servico-num{font-size:9px;letter-spacing:.2em;color:rgba(241,232,224,.18);margin-bottom:40px}
.servico-title{font-size:22px;font-weight:400;letter-spacing:.04em;color:var(--cream);margin-bottom:20px;text-transform:lowercase}
.servico-body{font-size:11px;line-height:1.9;letter-spacing:.04em;color:rgba(241,232,224,.4);margin-bottom:32px}
.servico-items{display:flex;flex-direction:column;gap:11px}
.servico-item{display:flex;align-items:center;gap:10px;font-size:10px;letter-spacing:.07em;color:rgba(241,232,224,.3)}
.servico-dot{width:4px;height:4px;border-radius:50%;flex-shrink:0}
.servico-card:nth-child(1) .servico-dot{background:var(--gold);opacity:.6}
.servico-card:nth-child(2) .servico-dot{background:var(--teal);opacity:.6}
.servico-card:nth-child(3) .servico-dot{background:var(--terra);opacity:.6}

#processo{background:var(--cream);padding:120px 56px}
#processo .section-label-line{background:var(--terra)}
#processo .section-label span{color:var(--terra)}
.processo-header{display:grid;grid-template-columns:1fr 1fr;gap:80px;margin-bottom:80px}
.processo-heading{font-size:clamp(24px,3.2vw,42px);font-weight:300;line-height:1.25;letter-spacing:-.01em}
.processo-sub{font-size:12px;line-height:2;letter-spacing:.04em;color:rgba(42,42,42,.55);padding-top:12px}
.processo-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(42,42,42,.08)}
.step{background:var(--cream);padding:44px 36px;position:relative}
.step-bar{position:absolute;top:0;left:0;right:0;height:2px}
.step:nth-child(1) .step-bar{background:var(--gold)}
.step:nth-child(2) .step-bar{background:var(--teal)}
.step:nth-child(3) .step-bar{background:var(--terra)}
.step:nth-child(4) .step-bar{background:var(--black)}
.step-num{font-size:9px;letter-spacing:.2em;color:rgba(42,42,42,.2);margin-bottom:28px}
.step-title{font-size:13px;font-weight:500;letter-spacing:.06em;color:var(--black);margin-bottom:14px;text-transform:lowercase}
.step-body{font-size:10px;line-height:1.9;letter-spacing:.04em;color:rgba(42,42,42,.5)}

#contacto{background:var(--black);display:grid;grid-template-columns:1fr 1fr;position:relative;overflow:hidden}
.contacto-m-bg{position:absolute;left:-60px;bottom:-60px;width:min(500px,50vw);opacity:.05;pointer-events:none}
.contacto-left{padding:120px 64px 120px 56px;border-right:1px solid rgba(241,232,224,.06);position:relative;z-index:1}
#contacto .section-label-line{background:var(--teal)}
#contacto .section-label span{color:var(--teal)}
.contacto-heading{font-size:clamp(28px,4vw,56px);font-weight:300;line-height:1.15;letter-spacing:-.01em;color:var(--cream);margin-bottom:56px}
.contacto-links{display:flex;flex-direction:column;border-top:1px solid rgba(241,232,224,.07)}
.contacto-link{display:flex;align-items:center;justify-content:space-between;padding:22px 0;border-bottom:1px solid rgba(241,232,224,.07);text-decoration:none;transition:padding-left .3s}
.contacto-link:hover{padding-left:10px}
.contacto-link-label{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:rgba(241,232,224,.25);margin-bottom:4px}
.contacto-link-value{font-size:13px;letter-spacing:.05em;color:rgba(241,232,224,.65);transition:color .3s}
.contacto-link:hover .contacto-link-value{color:#F1E8E0}
.contacto-arrow{font-size:18px;color:rgba(241,232,224,.12);transition:color .3s,transform .3s}
.contacto-link:hover .contacto-arrow{color:var(--gold);transform:translateX(5px)}
.contacto-right{padding:120px 56px 120px 64px;display:flex;flex-direction:column;justify-content:space-between;position:relative;z-index:1}
.contacto-tagline{font-size:12px;line-height:2;letter-spacing:.05em;color:rgba(241,232,224,.3);max-width:320px}
.contacto-logo-stacked{height:100px;width:auto;opacity:.15;margin-top:auto;display:block;filter:invert(1) brightness(1.2)}

footer{background:#1d1d1d;padding:28px 56px;display:flex;align-items:center;justify-content:space-between}
.footer-left{display:flex;align-items:center;gap:14px}
.footer-symbol{height:24px;width:auto;border-radius:2px;opacity:.5}
.footer-copy{font-size:9px;letter-spacing:.14em;color:rgba(241,232,224,.2)}
.footer-links{display:flex;gap:32px}
.footer-links a{font-size:9px;letter-spacing:.14em;color:rgba(241,232,224,.2);text-decoration:none;transition:color .3s}
.footer-links a:hover{color:rgba(241,232,224,.5)}

.fade-up{opacity:0;transform:translateY(24px);transition:opacity .75s ease,transform .75s ease}
.fade-up.visible{opacity:1;transform:none}

@media(max-width:960px){
  nav,nav.scrolled{padding:18px 24px}
  #hero{padding:0 24px 48px}
  .hero-content{grid-template-columns:1fr;gap:40px;padding-top:120px}
  #sobre{grid-template-columns:1fr}
  .sobre-left{padding:80px 24px 48px;border-right:none;border-bottom:1px solid rgba(42,42,42,.08)}
  .sobre-right{padding:48px 24px 80px}
  .servicos-grid{grid-template-columns:1fr}
  #servicos{padding:80px 24px}
  .processo-header{grid-template-columns:1fr;gap:24px}
  .processo-steps{grid-template-columns:1fr 1fr}
  #processo{padding:80px 24px}
  #contacto{grid-template-columns:1fr}
  .contacto-left{padding:80px 24px 48px;border-right:none;border-bottom:1px solid rgba(241,232,224,.06)}
  .contacto-right{padding:48px 24px 80px}
  footer{padding:24px;flex-direction:column;gap:16px;text-align:center}
  .nav-links{display:none}
}
@media(max-width:600px){.processo-steps{grid-template-columns:1fr}}
