/* Architecture landing page — imports shared design guide, then page-specific overrides */
@import '../css/designguide.css';

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --gold:#C9A96E;--gold-dim:rgba(201,169,110,.12);--gold-border:rgba(201,169,110,.3);
  --bg:#0F0F0F;--bg2:#141414;--text:#E8E6E0;--text2:#A0A0A0;--muted:#4A4A4A;--border:#1E1E1E;
  --serif:'Cormorant Garamond',Georgia,serif;--sans:'Inter',system-ui,sans-serif;
  --accent:var(--gold);--accent-dim:var(--gold-dim);--accent-border:var(--gold-border);
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--sans);overflow-x:hidden;cursor:none}

/* Cursor */
#cur,#cur-f{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;border-radius:50%;transform:translate(-50%,-50%)}
#cur{width:7px;height:7px;background:var(--gold)}
#cur-f{width:38px;height:38px;border:1px solid var(--gold-border);z-index:9998;transition:width .25s,height .25s}

/* Nav */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  padding:26px 52px;
  display:flex;align-items:center;justify-content:space-between;
  transition:background .5s,border-color .5s;
  border-bottom:1px solid transparent;
}
nav.scrolled{background:rgba(15,15,15,.96);backdrop-filter:blur(20px);border-color:var(--border)}
.nav-logo{font-family:var(--serif);font-size:1.55rem;font-weight:400;color:var(--text);text-decoration:none;letter-spacing:.18em;transition:color .2s}
.nav-logo em{color:var(--gold);font-style:normal}
.nav-center{display:flex;gap:36px}
.nav-center a{color:var(--text2);text-decoration:none;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;transition:color .2s;position:relative}
.nav-center a.here{color:var(--gold)}
.nav-center a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s}
.nav-center a:hover::after,.nav-center a.here::after{width:100%}
.nav-right{display:flex;align-items:center;gap:8px;color:var(--text2);text-decoration:none;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;transition:color .2s}
.nav-right:hover{color:var(--gold)}
.nav-arr{transition:transform .3s}
.nav-right:hover .nav-arr{transform:translateX(-4px)}

/* Hero */
.hero{
  position:relative;height:100svh;min-height:640px;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 52px 80px;overflow:hidden;
}
.h-grid{
  position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(201,169,110,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(201,169,110,.035) 1px,transparent 1px);
  background-size:90px 90px;
}
.h-ring{
  position:absolute;top:12%;right:8%;width:340px;height:340px;
  border:1px solid rgba(201,169,110,.07);border-radius:50%;pointer-events:none;
}
.h-ring::before,.h-ring::after{content:'';position:absolute;border:1px solid rgba(201,169,110,.05);border-radius:50%}
.h-ring::before{inset:28px}
.h-ring::after{inset:70px}
.h-corner{
  position:absolute;top:40px;left:52px;pointer-events:none;
  color:rgba(201,169,110,.25);font-size:.6rem;letter-spacing:.2em;font-family:var(--sans);
}
.h-corner::before{
  content:'';position:absolute;left:0;bottom:-12px;
  width:32px;height:1px;background:rgba(201,169,110,.3);
}

.hero-body{position:relative;z-index:2;max-width:1000px}
.h-eye{
  display:flex;align-items:center;gap:18px;
  font-size:.65rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);
  margin-bottom:28px;overflow:hidden;
}
.h-eye-line{width:44px;height:1px;background:var(--gold);flex-shrink:0}

.h-title{
  font-family:var(--serif);
  font-size:clamp(4.5rem,13vw,10rem);
  font-weight:300;line-height:.88;letter-spacing:-.02em;
  overflow:hidden;
}
.h-title .ww{display:block;overflow:hidden}
.h-title .ww span{display:inline-block}

.h-sub{
  font-size:clamp(.85rem,1.4vw,1rem);color:var(--text2);font-weight:300;
  margin-top:30px;max-width:480px;line-height:1.75;letter-spacing:.03em;
}
.h-stats{display:flex;gap:52px;margin-top:52px}
.h-stat-n{font-family:var(--serif);font-size:2.6rem;font-weight:300;color:var(--gold);line-height:1}
.h-stat-l{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:5px}

/* Scroll indicator */
.scroll-ind{
  position:absolute;right:52px;bottom:52px;
  display:flex;flex-direction:column;align-items:center;gap:14px;
  color:var(--muted);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;
}
.scroll-bar{width:1px;height:56px;background:var(--muted);overflow:hidden;position:relative}
.scroll-bar::after{
  content:'';position:absolute;top:0;left:0;width:100%;height:100%;
  background:var(--gold);animation:sb 2s ease-in-out infinite;
}
@keyframes sb{0%{transform:translateY(-100%)}50%{transform:translateY(0)}100%{transform:translateY(100%)}}

/* Projects */
.proj-sec{padding:72px 52px 120px}
.proj-head{
  display:flex;justify-content:space-between;align-items:baseline;
  padding-top:24px;margin-bottom:56px;
  border-top:1px solid var(--border);
}
.proj-label{font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--text2)}
.proj-total{font-family:var(--serif);font-size:1rem;color:var(--muted)}

.g{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.card{
  position:relative;overflow:hidden;display:block;text-decoration:none;
  aspect-ratio:4/5;background:var(--bg2);
  clip-path:inset(0);
}
.card:first-child{grid-row:span 2;aspect-ratio:unset}

.card-img{
  width:100%;height:100%;object-fit:cover;display:block;
  transform-origin:center;
  transition:transform .9s cubic-bezier(.25,.46,.45,.94),filter .9s;
  filter:brightness(.9);
}
.card:hover .card-img{transform:scale(1.07);filter:brightness(.75)}

.card-ov{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.88) 0%,rgba(0,0,0,.25) 45%,transparent 75%);
  transition:opacity .5s;
}
.card:hover .card-ov{opacity:1}

.card-num{
  position:absolute;top:22px;left:22px;
  font-family:var(--serif);font-size:.75rem;font-weight:300;
  color:rgba(201,169,110,.7);letter-spacing:.12em;
  transition:color .3s;
}
.card:hover .card-num{color:var(--gold)}

.card-rule{
  position:absolute;top:22px;right:22px;
  width:0;height:1px;background:var(--gold);
  transition:width .5s cubic-bezier(.16,1,.3,1);
}
.card:hover .card-rule{width:36px}

.card-bot{
  position:absolute;bottom:0;left:0;right:0;padding:22px 24px 20px;
}
.card-tit{
  font-family:var(--serif);
  font-size:clamp(1.35rem,2.2vw,1.9rem);
  font-weight:400;color:#fff;line-height:1.08;letter-spacing:.01em;
}
.card-cta{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:14px;
  font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);
  transform:translateY(14px);opacity:0;
  transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .4s;
}
.card-cta::after{content:'→';font-size:.9em}
.card:hover .card-cta{transform:none;opacity:1}

/* ─────────────────────────────────────────
   Shared section header
───────────────────────────────────────── */
.sec-header{
  text-align:center;max-width:640px;margin:0 auto 64px;
}
.sec-label{
  display:block;font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--accent);margin-bottom:14px;
}
.sec-title{
  font-family:var(--serif);
  font-size:clamp(2rem,4vw,3.2rem);
  font-weight:300;color:var(--text);line-height:1.1;margin-bottom:18px;
}
.sec-desc{
  font-size:clamp(.83rem,1.2vw,.95rem);color:var(--text2);
  line-height:1.78;font-weight:300;
}

/* ─────────────────────────────────────────
   Process
───────────────────────────────────────── */
.process-sec{padding:100px 52px;background:var(--bg2)}
.process-steps{
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:2px;max-width:1240px;margin:0 auto;
}
.step{
  padding:40px 28px;border:1px solid var(--border);
  background:var(--bg);transition:border-color .3s;
}
.step:hover{border-color:rgba(201,169,110,.3)}
.step-num{
  font-family:var(--serif);font-size:2.4rem;font-weight:300;
  color:var(--gold);opacity:.5;margin-bottom:20px;
}
.step-title{
  font-family:var(--serif);font-size:1.1rem;font-weight:400;
  color:var(--text);margin-bottom:12px;
}
.step-desc{
  font-size:.78rem;color:var(--text2);line-height:1.72;font-weight:300;
}

/* ─────────────────────────────────────────
   Testimonials
───────────────────────────────────────── */
.testimonials-sec{padding:100px 52px}
.testi-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2px;max-width:1240px;margin:0 auto;
}
.testi-card{
  padding:40px 32px;border:1px solid var(--border);background:var(--bg2);
  display:flex;flex-direction:column;gap:24px;
  transition:border-color .3s;
}
.testi-card:hover{border-color:rgba(201,169,110,.3)}
.testi-stars{color:var(--gold);font-size:.85rem;letter-spacing:3px}
.testi-text{
  font-family:var(--serif);font-size:1.05rem;font-weight:300;font-style:italic;
  color:var(--text);line-height:1.78;flex:1;
}
.testi-author{border-top:1px solid var(--border);padding-top:18px}
.testi-name{
  font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text);margin-bottom:5px;
}
.testi-project{font-size:.62rem;color:var(--text2);letter-spacing:.08em}

/* ─────────────────────────────────────────
   Team
───────────────────────────────────────── */
.team-sec{padding:100px 52px;background:var(--bg2)}
.team-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2px;max-width:1240px;margin:0 auto;
}
.team-card{
  padding:40px 32px;border:1px solid var(--border);background:var(--bg);
  display:flex;flex-direction:column;gap:20px;transition:border-color .3s;
}
.team-card:hover{border-color:rgba(201,169,110,.35)}
.team-initials{
  width:56px;height:56px;border-radius:50%;
  background:var(--gold-dim);border:1px solid var(--gold-border);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:1.1rem;font-weight:300;color:var(--gold);
}
.team-name{
  font-family:var(--serif);font-size:1.3rem;font-weight:400;
  color:var(--text);margin-bottom:4px;
}
.team-role{
  font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);margin-bottom:12px;
}
.team-bio{font-size:.78rem;color:var(--text2);line-height:1.72;font-weight:300}

/* ─────────────────────────────────────────
   Contact
───────────────────────────────────────── */
.contact-sec{padding:100px 52px;background:var(--bg)}
.contact-inner{
  display:grid;grid-template-columns:1fr 1.4fr;
  gap:80px;max-width:1100px;margin:0 auto;
  align-items:start;
}
.contact-title{
  font-family:var(--serif);
  font-size:clamp(1.9rem,3.5vw,3rem);
  font-weight:300;color:var(--text);line-height:1.1;
  margin:14px 0 16px;
}
.contact-sub{
  font-size:.85rem;color:var(--text2);line-height:1.72;
  margin-bottom:36px;font-weight:300;
}
.cta-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:0}
.btn-whatsapp{
  display:inline-flex;align-items:center;gap:9px;
  padding:13px 22px;background:#25D366;color:#fff;
  text-decoration:none;font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;
  border-radius:2px;transition:opacity .3s,transform .2s;font-family:var(--sans);
}
.btn-whatsapp:hover{opacity:.88;transform:translateY(-2px)}
.btn-phone{
  display:inline-flex;align-items:center;gap:9px;
  padding:13px 22px;border:1px solid var(--gold-border);color:var(--gold);
  text-decoration:none;font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;
  border-radius:2px;transition:background .3s,transform .2s;font-family:var(--sans);
}
.btn-phone:hover{background:var(--gold-dim);transform:translateY(-2px)}

/* Lead form */
.lead-form{display:flex;flex-direction:column;gap:20px}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-label{
  font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text2);
}
.form-input{
  background:var(--bg2);border:1px solid var(--border);color:var(--text);
  padding:12px 16px;font-size:.82rem;font-family:var(--sans);
  outline:none;transition:border-color .3s;border-radius:2px;width:100%;
}
.form-input:focus{border-color:var(--gold-border)}
.form-input::placeholder{color:var(--muted)}
.form-select{
  appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234A4A4A' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;
}
.form-select option{background:var(--bg2);color:var(--text)}
.form-textarea{resize:vertical;min-height:110px}
.btn-submit{
  display:inline-flex;align-items:center;gap:12px;
  padding:14px 28px;background:var(--gold);color:#0F0F0F;
  font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;
  font-family:var(--sans);border:none;cursor:pointer;border-radius:2px;
  align-self:flex-start;transition:opacity .3s,transform .2s;
}
.btn-submit:hover:not(:disabled){opacity:.88;transform:translateY(-2px)}
.btn-submit:disabled{opacity:.5;cursor:not-allowed}
.form-msg{
  font-size:.78rem;padding:10px 14px;border-radius:2px;
  display:none;line-height:1.5;
}
.form-msg.success{display:block;background:rgba(76,175,80,.1);color:#4CAF50;border:1px solid rgba(76,175,80,.25)}
.form-msg.error{display:block;background:rgba(255,107,107,.1);color:#FF6B6B;border:1px solid rgba(255,107,107,.25)}

/* ─────────────────────────────────────────
   FAQ
───────────────────────────────────────── */
.faq-sec{padding:100px 52px;background:var(--bg2)}
.faq-list{
  max-width:800px;margin:0 auto;
  border-top:1px solid var(--border);
}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{
  width:100%;display:flex;justify-content:space-between;align-items:center;
  padding:22px 0;background:none;border:none;
  color:var(--text);font-size:.88rem;font-family:var(--sans);
  font-weight:400;letter-spacing:.03em;text-align:left;
  cursor:pointer;gap:20px;transition:color .2s;
}
.faq-q:hover{color:var(--gold)}
.faq-icon{
  font-size:1.3rem;font-weight:300;color:var(--gold);
  flex-shrink:0;transition:transform .35s cubic-bezier(.16,1,.3,1);
  line-height:1;
}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.16,1,.3,1)}
.faq-item.open .faq-a{max-height:360px}
.faq-a p{
  padding-bottom:24px;font-size:.82rem;color:var(--text2);
  line-height:1.8;font-weight:300;
}

/* Footer */
footer{
  border-top:1px solid var(--border);
  padding:36px 52px;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:16px;
}
.foot-brand{font-family:var(--serif);font-size:1.05rem;color:var(--muted)}
.foot-nav{display:flex;gap:28px}
.foot-nav a{color:var(--muted);text-decoration:none;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;transition:color .2s}
.foot-nav a:hover{color:var(--gold)}
.foot-disc{display:flex;gap:20px}
.foot-disc a{
  color:var(--text2);text-decoration:none;font-size:.7rem;
  letter-spacing:.1em;text-transform:uppercase;transition:color .2s;
  display:inline-flex;align-items:center;gap:6px;
}
.foot-disc a:hover{color:var(--gold)}
.foot-disc a span{font-size:.65rem;opacity:.5}

/* ─────────────────────────────────────────
   Responsive
───────────────────────────────────────── */
@media(max-width:1100px){
  .process-steps{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:900px){
  nav{padding:20px 24px}
  .hero{padding:0 24px 60px}
  .proj-sec{padding:52px 24px 80px}
  .g{grid-template-columns:1fr 1fr;gap:2px}
  .card:first-child{grid-column:span 2;grid-row:span 1}
  .h-stats{gap:28px}
  footer{padding:28px 24px}
  .scroll-ind,.h-ring{display:none}
  .nav-center{gap:20px}
  .process-sec,.testimonials-sec,.team-sec,.contact-sec,.faq-sec{padding:72px 24px}
  .testi-grid,.team-grid{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr 1fr}
  .contact-inner{grid-template-columns:1fr;gap:48px}
}
@media(max-width:640px){
  .process-steps{grid-template-columns:1fr}
  .form-row-2{grid-template-columns:1fr}
  .cta-actions{flex-direction:column}
  .btn-whatsapp,.btn-phone{justify-content:center}
}
@media(max-width:540px){
  .g{grid-template-columns:1fr}
  .card:first-child{grid-column:1}
  .nav-center{display:none}
  nav{padding:18px 20px}
  .hero{padding:0 20px 52px}
  .proj-sec{padding:40px 20px 60px}
  footer{padding:24px 20px;flex-direction:column;text-align:center}
  .foot-nav,.foot-disc{justify-content:center;flex-wrap:wrap;gap:16px}
  .process-sec,.testimonials-sec,.team-sec,.contact-sec,.faq-sec{padding:60px 20px}
  .testi-card,.team-card,.step{padding:28px 20px}
}
