/*
Theme Name: Santos e Passos v2
Theme URI: https://santosepassos.com
Author: Santos e Passos
Description: Santos e Passos — Arquitetura e Design de Interiores. End-to-end bilingual website.
Version: 3.1.0
License: GNU General Public License v2 or later
Text Domain: santos-passos
*/

*{box-sizing:border-box;margin:0;padding:0}
:root{
  --cr:#F9F5EA;--dk:#3D3D39;--br:#5C3D1E;--bl:#A07850;--gr:#8A8680;--wh:#fff;
  --bd:rgba(0,0,0,0.08);
  --fd:'Cormorant Garamond',Georgia,serif;
  --fb:'DM Sans',sans-serif;
  --fm:'DM Mono',monospace;
  -webkit-font-smoothing:antialiased;
}
html{scroll-behavior:smooth}
body{background:var(--cr);font-family:var(--fb);font-size:16px;color:var(--dk)}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
h1,h2,h3{font-family:var(--fd);font-weight:300;line-height:1.1}

/* ── NAV ── */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:100;height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(20px,5vw,60px);transition:background .3s,box-shadow .3s}
.site-nav.scrolled{background:rgba(249,245,234,.95);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--bd)}
.nav-logo{display:flex;align-items:center;gap:10px;cursor:pointer;text-decoration:none}
.nav-logo img{height:38px;width:auto}
.nav-logo-text{font-family:var(--fd);font-size:17px;font-weight:500;color:var(--br);letter-spacing:.03em;white-space:nowrap}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a,.nav-links button{font-size:13px;padding:6px 12px;border-radius:100px;cursor:pointer;color:var(--dk);background:transparent;border:none;font-family:var(--fb);transition:all .15s;text-decoration:none;display:inline-block}
.nav-links a:hover,.nav-links button:hover{background:rgba(0,0,0,.06)}
.nav-links a.current,.nav-links a.current-menu-item{background:rgba(0,0,0,.08);font-weight:500}
.lang-toggle{display:flex;margin-left:10px;border:0.5px solid rgba(0,0,0,.18);border-radius:100px;overflow:hidden}
.lang-toggle a{padding:5px 10px;font-size:11px;font-family:var(--fm);letter-spacing:.04em;cursor:pointer;color:var(--gr);background:transparent;border:none;text-decoration:none;transition:all .15s}
.lang-toggle a.lang-active{background:var(--dk);color:var(--wh)}

/* ── HERO ── */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;padding:clamp(40px,6vw,80px) clamp(20px,5vw,60px)}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(61,61,57,.82) 0%,rgba(61,61,57,.05) 60%,transparent 100%)}
.hero-content{position:relative;z-index:1;max-width:800px}
.hero-eye{font-family:var(--fm);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:16px}
.hero-h1{font-size:clamp(48px,7vw,90px);font-weight:300;font-style:italic;color:var(--wh);line-height:1.0;margin-bottom:28px}
.hero-h1 em{font-style:normal;font-weight:500}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}

/* ── BUTTONS ── */
.btn{padding:12px 24px;border-radius:100px;font-size:13px;font-weight:500;cursor:pointer;border:none;font-family:var(--fb);transition:all .2s;display:inline-block;text-decoration:none}
.btn-w{background:var(--wh);color:var(--dk)}.btn-w:hover{background:var(--cr);transform:translateY(-2px)}
.btn-o{background:transparent;color:var(--wh);border:1px solid rgba(255,255,255,.4)}.btn-o:hover{background:rgba(255,255,255,.1);transform:translateY(-2px)}
.btn-dk{background:var(--dk);color:var(--wh)}.btn-dk:hover{background:var(--br);transform:translateY(-2px)}

/* ── SECTIONS ── */
.dk-sec{background:var(--dk);padding:clamp(50px,8vw,100px) clamp(20px,5vw,60px)}
.light-sec{background:var(--cr);padding:clamp(50px,8vw,100px) clamp(20px,5vw,60px)}
.brown-sec{background:var(--br);padding:clamp(50px,8vw,80px) clamp(20px,5vw,60px);text-align:center}
.inner{max-width:1300px;margin:0 auto}
.sec-lbl{font-family:var(--fm);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--bl);margin-bottom:12px}
.sec-titw{font-size:clamp(32px,4vw,52px);font-weight:300;color:var(--wh);margin-bottom:20px}
.sec-titw em{font-style:italic;color:var(--bl)}
.sec-tit{font-size:clamp(32px,4vw,52px);font-weight:300;color:var(--dk);margin-bottom:20px}
.sec-tit em{font-style:italic}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:clamp(28px,4vw,48px);gap:16px;flex-wrap:wrap}

/* ── INTRO ── */
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}
.intro-body{font-size:15px;font-weight:300;color:rgba(255,255,255,.62);line-height:1.8;margin-bottom:24px}
.stats{display:flex;gap:clamp(24px,4vw,48px);border-top:1px solid rgba(255,255,255,.12);padding-top:24px;margin-top:8px}
.stat-n{font-family:var(--fd);font-size:clamp(32px,4vw,48px);font-weight:300;color:var(--wh);line-height:1}
.stat-l{font-family:var(--fm);font-size:11px;color:rgba(255,255,255,.3);letter-spacing:.08em;text-transform:uppercase;margin-top:4px}
.intro-img{border-radius:6px;overflow:hidden;height:clamp(280px,35vw,460px)}
.intro-img img{width:100%;height:100%;object-fit:cover}

/* ── SERVICES GRID ── */
.svc-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:12px}
.sc{position:relative;border-radius:8px;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;padding:24px;cursor:pointer;transition:transform .35s,box-shadow .35s;min-height:320px;text-decoration:none}
.sc:hover{transform:translateY(-5px);box-shadow:0 20px 50px rgba(0,0,0,.15)}
.sc:nth-child(1){grid-column:span 7;min-height:400px}
.sc:nth-child(2){grid-column:span 5}
.sc:nth-child(3){grid-column:span 4}
.sc:nth-child(4){grid-column:span 4}
.sc:nth-child(5){grid-column:span 4}
.sc-bg{position:absolute;inset:0}
.sc-bg img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.sc:hover .sc-bg img{transform:scale(1.04)}
.sc-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.72) 0%,transparent 60%)}
.sc-num{font-family:var(--fm);font-size:11px;color:rgba(255,255,255,.4);position:relative;z-index:1;margin-bottom:6px}
.sc-name{font-family:var(--fd);font-size:clamp(20px,2.5vw,34px);color:var(--wh);position:relative;z-index:1;line-height:1.2}

/* ── PROCESS ── */
.proc-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:start}
.proc-step{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.08);cursor:pointer}
.proc-step:first-child{border-top:1px solid rgba(255,255,255,.08)}
.proc-num{font-family:var(--fm);font-size:11px;color:rgba(255,255,255,.2);min-width:24px;padding-top:3px}
.proc-title{font-size:18px;font-family:var(--fd);font-weight:400;color:rgba(255,255,255,.35);transition:color .2s}
.proc-step.on .proc-title{color:var(--wh)}
.proc-desc{font-size:13px;font-weight:300;color:rgba(255,255,255,.45);line-height:1.7;margin-top:8px;display:none}
.proc-step.on .proc-desc{display:block}
.proc-img{position:sticky;top:80px;border-radius:6px;overflow:hidden;height:480px}
.proc-img img{width:100%;height:100%;object-fit:cover;transition:opacity .4s}

/* ── PORTFOLIO ── */
.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.port-item{border-radius:8px;overflow:hidden;cursor:pointer;transition:transform .3s;text-decoration:none;display:block}
.port-item:hover{transform:scale(1.02)}
.port-item img{width:100%;height:260px;object-fit:cover;display:block}
.port-item:first-child{grid-column:span 2}
.port-item:first-child img{height:340px}

/* ── QUOTE ── */
.q-mark{font-family:var(--fd);font-size:100px;line-height:.4;color:rgba(255,255,255,.15);margin-bottom:20px}
.q-text{font-family:var(--fd);font-size:clamp(22px,3vw,36px);font-weight:300;font-style:italic;color:var(--wh);line-height:1.4;margin-bottom:20px;max-width:700px;margin-left:auto;margin-right:auto}
.q-auth{font-family:var(--fm);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.4)}

/* ── FOOTER ── */
.site-footer{background:var(--dk);padding:clamp(50px,7vw,80px) clamp(20px,5vw,60px) 32px}
.footer-grid{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:28px}
.footer-logo img{height:36px;width:auto;filter:brightness(0) invert(1);opacity:.9;margin-bottom:10px}
.footer-tag{font-size:13px;font-weight:300;color:rgba(255,255,255,.3);line-height:1.6;max-width:240px}
.footer-col-title{font-family:var(--fm);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.22);margin-bottom:14px}
.footer-links{display:flex;flex-direction:column;gap:9px}
.footer-links a{font-size:13px;font-weight:300;color:rgba(255,255,255,.42);transition:color .2s;text-decoration:none}
.footer-links a:hover{color:var(--wh)}
.footer-bot{max-width:1300px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-copy{font-family:var(--fm);font-size:11px;color:rgba(255,255,255,.2)}

/* ── ABOUT ── */
.about-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:end;padding:clamp(80px,10vw,120px) clamp(20px,5vw,60px) clamp(40px,5vw,60px);max-width:1300px;margin:0 auto}
.pg-lbl{font-family:var(--fm);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--bl);margin-bottom:14px}
.pg-tit{font-size:clamp(42px,6vw,72px);font-weight:300;color:var(--dk);margin-bottom:20px}
.pg-tit em{font-style:italic;color:var(--br)}
.pg-body{font-size:16px;font-weight:300;color:var(--gr);line-height:1.8}
.about-img-hero{border-radius:6px;overflow:hidden}
.about-img-hero img{width:100%;height:460px;object-fit:cover}
.about-content{max-width:1300px;margin:0 auto;padding:0 clamp(20px,5vw,60px) clamp(50px,7vw,80px)}
.about-text{max-width:720px;font-size:17px;font-weight:300;line-height:1.85;color:var(--dk);margin-bottom:40px}
.about-text p+p{margin-top:20px}
.about-cta-text{font-family:var(--fd);font-size:clamp(22px,3vw,32px);font-style:italic;color:var(--br);margin-bottom:28px}
.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;max-width:1300px;margin:0 auto;padding:0 clamp(20px,5vw,60px) clamp(50px,7vw,80px)}
.photo-grid img{width:100%;height:240px;object-fit:cover;border-radius:6px;transition:transform .35s}
.photo-grid img:hover{transform:scale(1.02)}
.photo-grid img:first-child{grid-column:span 2;height:340px}

/* ── SERVICES PAGE ── */
.svc-hero{padding:clamp(80px,10vw,120px) clamp(20px,5vw,60px) 0;max-width:1300px;margin:0 auto}
.svc-page-tit{font-size:clamp(52px,8vw,100px);font-weight:300;line-height:1.0;margin-bottom:clamp(40px,5vw,60px);color:var(--dk)}
.svc-page-tit em{font-style:italic}
.svc-full{display:grid;grid-template-columns:1fr 1fr;gap:12px;max-width:1300px;margin:0 auto;padding:0 clamp(20px,5vw,60px) clamp(50px,7vw,80px)}
.sfc{position:relative;border-radius:8px;overflow:hidden;min-height:400px;display:flex;flex-direction:column;justify-content:flex-end;padding:32px;cursor:pointer;transition:transform .35s;text-decoration:none}
.sfc:hover{transform:translateY(-5px)}
.sfc:first-child{grid-column:1/-1;min-height:460px}
.sfc-bg{position:absolute;inset:0}
.sfc-bg img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.sfc:hover .sfc-bg img{transform:scale(1.04)}
.sfc-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,transparent 55%)}
.sfc-content{position:relative;z-index:1}
.sfc-num{font-family:var(--fm);font-size:11px;color:rgba(255,255,255,.4);margin-bottom:8px}
.sfc-title{font-family:var(--fd);font-size:clamp(28px,3.5vw,48px);color:var(--wh);font-weight:400;line-height:1.15;margin-bottom:10px}
.sfc-desc{font-size:14px;font-weight:300;color:rgba(255,255,255,.65);max-width:500px;line-height:1.65}

/* ── CLIENTS ── */
.clients-hero{padding:clamp(80px,10vw,120px) clamp(20px,5vw,60px) clamp(40px,5vw,60px);max-width:1300px;margin:0 auto}
.masonry{max-width:1300px;margin:0 auto;padding:0 clamp(20px,5vw,60px) clamp(50px,7vw,80px);columns:3;column-gap:12px}
.masonry img{width:100%;border-radius:6px;margin-bottom:12px;break-inside:avoid;display:block;transition:transform .35s;cursor:pointer}
.masonry img:hover{transform:scale(1.02)}

/* ── CONTACT ── */
.contact-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(50px,7vw,100px);align-items:start;max-width:1300px;margin:0 auto;padding:clamp(80px,10vw,120px) clamp(20px,5vw,60px) clamp(60px,8vw,100px)}
.contact-tit{font-size:clamp(38px,5vw,60px);font-weight:300;color:var(--dk);margin-bottom:40px;line-height:1.1}
.contact-tit em{font-style:italic;color:var(--br)}
.c-detail{margin-bottom:24px}
.c-lbl{font-family:var(--fm);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--gr);margin-bottom:6px}
.c-val{font-size:16px;color:var(--dk);line-height:1.5}
.c-val a{color:var(--dk);transition:color .2s}.c-val a:hover{color:var(--br)}
.c-map{margin-top:28px;border-radius:8px;overflow:hidden}
.c-map iframe{display:block;border:none;border-radius:8px}
.form-tit{font-family:var(--fd);font-size:clamp(22px,3vw,32px);font-style:italic;color:var(--dk);margin-bottom:32px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.form-row.full{grid-template-columns:1fr}
.ff{display:flex;flex-direction:column;gap:6px}
.ff label{font-family:var(--fm);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gr)}
.ff input,.ff textarea{background:transparent;border:none;border-bottom:1px solid rgba(0,0,0,.12);padding:10px 0;font-size:15px;color:var(--dk);outline:none;font-family:var(--fb);transition:border-color .2s;width:100%}
.ff input:focus,.ff textarea:focus{border-bottom-color:var(--br)}
.ff textarea{resize:vertical;min-height:110px}
.form-submit{margin-top:20px}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .intro-grid,.proc-grid,.about-hero-grid,.contact-layout{grid-template-columns:1fr}
  .proc-img{display:none}
  .svc-grid{display:flex;flex-direction:column}
  .sc{min-height:260px!important}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  /* Hide nav links on mobile — shown via hamburger menu */
  .nav-links{display:none;flex-direction:column;align-items:flex-start;gap:0;position:fixed;top:60px;left:0;right:0;background:rgba(249,245,234,.98);backdrop-filter:blur(12px);padding:16px clamp(20px,5vw,60px) 24px;box-shadow:0 8px 24px rgba(0,0,0,.08);z-index:99}
  .nav-links.open{display:flex}
  .nav-links a,.nav-links button{display:block;width:100%;padding:12px 0;border-radius:0;border-bottom:1px solid rgba(0,0,0,.06);font-size:15px}
  .nav-links a:last-child{border-bottom:none}
  .lang-toggle{margin-left:0;margin-top:12px;align-self:flex-start}
  /* Hamburger button */
  .nav-hamburger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;cursor:pointer;background:transparent;border:none;padding:4px;margin-left:auto}
  .nav-hamburger span{display:block;height:1.5px;background:var(--dk);transition:all .25s;transform-origin:center}
  .nav-hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  .nav-hamburger.open span:nth-child(2){opacity:0}
  .nav-hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
  .svc-full{grid-template-columns:1fr}
  .sfc:first-child{grid-column:1}
  .port-grid,.photo-grid{grid-template-columns:1fr 1fr}
  .port-item:first-child,.photo-grid img:first-child{grid-column:1/-1}
  .masonry{columns:2}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .about-img-hero img{height:280px}
}
@media(min-width:769px){
  .nav-hamburger{display:none}
}
