/* Landscape 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{
  --grn:#7CB87A;--grn-dim:rgba(124,184,122,.1);--grn-border:rgba(124,184,122,.28);
  --gold:#C9A96E;
  --bg:#060E07;--bg2:#0C160D;--bg3:#101A11;
  --text:#E0E8E0;--text2:#8FA890;--muted:#3D5040;--border:#1A281B;
  --serif:'Cormorant Garamond',Georgia,serif;--sans:'Inter',system-ui,sans-serif;
  --accent:var(--grn);--accent-dim:var(--grn-dim);--accent-border:var(--grn-border);
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--sans);overflow-x:hidden;cursor:none}

#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(--grn)}
#cur-f{width:38px;height:38px;border:1px solid var(--grn-border);z-index:9998;transition:width .25s,height .25s}

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(6,14,7,.97);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}
.nav-logo em{color:var(--grn);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(--grn)}
.nav-center a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--grn);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(--grn)}
.nav-arr{transition:transform .3s}
.nav-right:hover .nav-arr{transform:translateX(-4px)}

.hero{
  position:relative;height:100svh;min-height:640px;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 52px 80px;overflow:hidden;
}
.h-mist{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 55% 55% at 75% 20%, rgba(124,184,122,.06) 0%, transparent 70%),
    radial-gradient(ellipse 40% 40% at 20% 70%, rgba(124,184,122,.04) 0%, transparent 70%);
}
.h-dots{
  position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle, rgba(124,184,122,.12) 1px, transparent 1px);
  background-size:44px 44px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%, black 0%, transparent 100%);
}
.h-leaf{
  position:absolute;top:8%;right:6%;width:380px;height:380px;pointer-events:none;
}
.h-leaf svg{width:100%;height:100%;opacity:.06}

.h-vert{
  position:absolute;right:52px;top:50%;transform:translateY(-50%) rotate(90deg);
  font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);
  transform-origin:center;white-space:nowrap;pointer-events:none;
}

.hero-body{position:relative;z-index:2;max-width:980px}
.h-eye{
  display:flex;align-items:center;gap:18px;
  font-size:.65rem;letter-spacing:.26em;text-transform:uppercase;color:var(--grn);
  margin-bottom:24px;
}
.h-eye-dot{width:6px;height:6px;border-radius:50%;background:var(--grn);flex-shrink:0}

.h-title{
  font-family:var(--serif);
  font-size:clamp(4rem,12vw,9.5rem);
  font-weight:300;line-height:.92;letter-spacing:-.015em;
}
.h-title .ww{display:block;overflow:hidden}
.h-title .ww span{display:inline-block}
.h-title .italic-line{font-style:italic;color:var(--grn)}

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

.scroll-ind{
  position:absolute;left:52px;bottom:48px;
  display:flex;align-items:center;gap:14px;
  color:var(--muted);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;
}
.scroll-bar{width:52px;height:1px;background:var(--muted);overflow:hidden;position:relative}
.scroll-bar::after{
  content:'';position:absolute;top:0;left:0;height:100%;width:100%;
  background:var(--grn);animation:sbH 2.2s ease-in-out infinite;
}
@keyframes sbH{0%{transform:translateX(-100%)}50%{transform:translateX(0)}100%{transform:translateX(100%)}}

.proj-sec{padding:72px 52px 120px}
.proj-head{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:52px;padding-bottom:20px;
  border-bottom: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);
  display:flex;align-items:center;gap:10px;
}
.proj-total::before{content:'';width:28px;height:1px;background:var(--muted)}

.g{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr;
  grid-template-rows:auto;
  gap:4px;
}
.card{
  position:relative;overflow:hidden;display:block;text-decoration:none;
  aspect-ratio:3/4;background:var(--bg2);
  border-radius:2px;
}
.card:first-child{grid-row:span 2;aspect-ratio:unset}
.card:nth-child(4){grid-column:span 2;aspect-ratio:16/9}

.card-img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .95s cubic-bezier(.25,.46,.45,.94),filter .8s;
  filter:brightness(.88) saturate(.9);
}
.card:hover .card-img{transform:scale(1.06);filter:brightness(.7) saturate(1.1)}

.card-ov{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(4,10,4,.9) 0%,rgba(4,10,4,.2) 50%,transparent 80%);
  transition:opacity .4s;
}

.card-tag{
  position:absolute;top:18px;left:18px;
  background:rgba(6,14,7,.7);border:1px solid var(--grn-border);
  color:var(--grn);font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;
  padding:4px 10px;border-radius:30px;backdrop-filter:blur(8px);
  transform:translateY(-6px);opacity:0;transition:transform .4s,opacity .4s;
}
.card:hover .card-tag{transform:none;opacity:1}

.card-num{
  position:absolute;top:18px;right:20px;
  font-family:var(--serif);font-size:.72rem;font-weight:300;
  color:rgba(124,184,122,.5);letter-spacing:.12em;
  transition:color .3s;
}
.card:hover .card-num{color:var(--grn)}

.card-bot{position:absolute;bottom:0;left:0;right:0;padding:20px 22px 18px}
.card-tit{
  font-family:var(--serif);
  font-size:clamp(1.3rem,2vw,1.8rem);
  font-weight:400;color:#fff;line-height:1.1;
  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(--grn);
  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}

.card::after{
  content:'';position:absolute;bottom:0;left:0;
  height:2px;width:0;background:var(--grn);
  transition:width .5s cubic-bezier(.16,1,.3,1);
}
.card:hover::after{width:100%}

/* ─────────────────────────────────────────
   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(124,184,122,.3)}
.step-num{
  font-family:var(--serif);font-size:2.4rem;font-weight:300;
  color:var(--grn);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(124,184,122,.3)}
.testi-stars{color:var(--grn);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(124,184,122,.35)}
.team-initials{
  width:56px;height:56px;border-radius:50%;
  background:var(--grn-dim);border:1px solid var(--grn-border);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:1.1rem;font-weight:300;color:var(--grn);
}
.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(--grn);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(--bg3)}
.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}
.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(--grn-border);color:var(--grn);
  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(--grn-dim);transform:translateY(-2px)}

.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(--grn-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='%233D5040' 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(--grn);color:#060E07;
  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}
.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(--grn)}
.faq-icon{
  font-size:1.3rem;font-weight:300;color:var(--grn);
  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(--grn)}
.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}
.foot-disc a:hover,.foot-disc a.here{color:var(--grn)}

/* ─────────────────────────────────────────
   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 56px}
  .proj-sec{padding:52px 24px 80px}
  .g{grid-template-columns:1fr 1fr;gap:3px}
  .card:first-child{grid-column:span 2;grid-row:span 1}
  .card:nth-child(4){grid-column:span 2}
  .h-stats{gap:28px}.h-leaf,.h-vert,.h-dots{display:none}
  footer{padding:28px 24px}
  .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,.card:nth-child(4){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}
}
