/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Inter',sans-serif;background:#111;color:#e8e8e8;line-height:1.6;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ===== TOKENS ===== */
:root{
  --green-dark:#4A5240;
  --green-mid:#6B7A5A;
  --green-light:#8DB360;
  --white:#fff;
  --off-white:#F5F0E8;
  --bg:#111;
  --bg-dark:#0d0d0d;
  --card:#1a1a1a;
  --border:#2a2a2a;
  --radius:12px;
  --shadow:0 4px 32px rgba(0,0,0,.4);
  --transition:.3s ease;
}

/* ===== LAYOUT ===== */
.container{max-width:1240px;margin:0 auto;padding:0 2rem}
.section{padding:100px 0}
.bg-dark{background:var(--bg-dark)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.cards-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.center{text-align:center}
.mt-1{margin-top:1rem}
.mt-2{margin-top:2rem}

/* ===== NAVBAR ===== */
.navbar{position:fixed;top:0;left:0;width:100%;z-index:100;padding:1.25rem 0;transition:background var(--transition),box-shadow var(--transition)}
.navbar.scrolled{background:rgba(13,13,13,.97);box-shadow:0 2px 20px rgba(0,0,0,.5);padding:.9rem 0}
.nav-container{max-width:1240px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;font-weight:800;font-size:1.5rem;letter-spacing:-0.02em}
.logo-ok{color:var(--white)}
.logo-pw{color:var(--green-light)}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{font-size:.9rem;font-weight:500;color:rgba(255,255,255,.75);transition:color var(--transition);position:relative}
.nav-links a:hover,.nav-links a.active{color:#fff}
.nav-links a.active::after{content:'';position:absolute;bottom:-4px;left:0;width:100%;height:2px;background:var(--green-light);border-radius:2px}
.nav-cta{background:var(--green-light)!important;color:#1a1a1a!important;padding:.5rem 1.25rem!important;border-radius:6px;font-weight:600!important}
.nav-cta:hover{background:#9ec46e!important}
.nav-cta.active::after{display:none}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav-toggle span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:var(--transition)}

/* ===== HERO ===== */
.hero{position:relative;height:100vh;min-height:680px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.page-hero{position:relative;height:55vh;min-height:400px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.page-hero-sm{height:45vh;min-height:320px}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05);transition:transform 8s ease}
.hero-bg.loaded{transform:scale(1)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.75) 0%,rgba(74,82,64,.3) 100%)}
.hero-content{position:relative;z-index:2;text-align:center;max-width:860px;padding:0 2rem}
.hero-pre{font-size:.85rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--green-light);margin-bottom:1rem}
.hero h1{font-size:clamp(2.8rem,7vw,5.5rem);font-weight:800;line-height:1.05;letter-spacing:-0.03em;margin-bottom:1.5rem;color:#fff}
.hero h1 .green{color:var(--green-light)}
.hero-sub{font-size:1.15rem;color:rgba(255,255,255,.8);max-width:580px;margin:0 auto 2.5rem;line-height:1.7}
.hero-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;color:rgba(255,255,255,.4);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase}
.scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,rgba(141,179,96,.6),transparent)}

/* ===== ANIMATIONS ===== */
.animate-up{opacity:0;transform:translateY(30px);animation:animUp .8s ease forwards}
.delay-1{animation-delay:.2s}
.delay-2{animation-delay:.4s}
.delay-3{animation-delay:.6s}
@keyframes animUp{to{opacity:1;transform:translateY(0)}}

.fade-in{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}
.fade-in.delay-1{transition-delay:.15s}
.fade-in.delay-2{transition-delay:.3s}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 2rem;border-radius:8px;font-weight:600;font-size:.95rem;transition:all var(--transition);cursor:pointer;border:none}
.btn-primary{background:var(--green-light);color:#1a1a1a}
.btn-primary:hover{background:#9ec46e;transform:translateY(-2px)}
.btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.4)}
.btn-outline:hover{border-color:var(--green-light);color:var(--green-light)}
.btn-outline-light{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.3)}
.btn-outline-light:hover{border-color:var(--green-light);color:var(--green-light)}
.btn-sm{padding:.5rem 1.25rem;font-size:.85rem}
.btn-lg{padding:1rem 2.5rem;font-size:1.05rem}
.btn-full{width:100%;justify-content:center}

/* ===== STATS BAR ===== */
.stats-bar{background:var(--green-dark);padding:2rem 0}
.stats-bar .container{display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap}
.stat{display:flex;flex-direction:column;align-items:center;padding:1rem 3rem;text-align:center}
.stat-num{font-size:2.2rem;font-weight:800;color:#fff;letter-spacing:-0.02em;line-height:1}
.stat-label{font-size:.8rem;color:rgba(255,255,255,.7);margin-top:.3rem;letter-spacing:.05em;text-transform:uppercase}
.stat-divider{width:1px;height:50px;background:rgba(255,255,255,.15)}

/* ===== SECTION HEADERS ===== */
.section-header{text-align:center;margin-bottom:3.5rem}
.section-pre{font-size:.8rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--green-light);margin-bottom:.75rem}
.section h2,.section-header h2{font-size:clamp(2rem,4vw,3rem);font-weight:800;letter-spacing:-0.03em;margin-bottom:1rem;color:#fff}
.section-sub{color:rgba(255,255,255,.55);font-size:1rem;max-width:560px;margin:0 auto}

/* ===== INTRO ===== */
.intro-text h2{font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:800;letter-spacing:-0.03em;margin-bottom:1.25rem;line-height:1.15}
.intro-text p{color:rgba(255,255,255,.65);margin-bottom:1rem;line-height:1.75}
.intro-img{position:relative}
.intro-img img{border-radius:var(--radius);width:100%;object-fit:cover;height:480px}
.intro-badge{position:absolute;bottom:-1.5rem;left:-1.5rem;background:var(--green-light);color:#1a1a1a;padding:1.25rem 1.5rem;border-radius:var(--radius);text-align:center}
.badge-num{display:block;font-size:2rem;font-weight:800;line-height:1}
.badge-text{display:block;font-size:.75rem;font-weight:600;opacity:.8}

/* ===== SERVICE CARDS (HOME) ===== */
.service-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;transition:transform var(--transition),border-color var(--transition)}
.service-card:hover{transform:translateY(-6px);border-color:var(--green-mid)}
.card-icon{width:52px;height:52px;background:rgba(141,179,96,.15);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
.card-icon svg{width:24px;height:24px;color:var(--green-light)}
.service-card h3{font-size:1.2rem;font-weight:700;margin-bottom:.75rem;color:#fff}
.service-card p{color:rgba(255,255,255,.55);font-size:.9rem;line-height:1.7;margin-bottom:1.25rem}
.card-link{font-size:.85rem;font-weight:600;color:var(--green-light);transition:gap var(--transition)}

/* ===== PORTFOLIO GRID (HOME) ===== */
.proj-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:1.5rem}
.proj-card{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer}
.proj-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;display:block}
.proj-card:hover img{transform:scale(1.05)}
.proj-card.large{grid-row:1/3}
.proj-card.large img{min-height:480px}
.proj-card img{min-height:220px}
.proj-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,transparent 50%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.5rem;opacity:0;transition:opacity var(--transition)}
.proj-card:hover .proj-overlay{opacity:1}
.proj-type{font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--green-light);margin-bottom:.4rem}
.proj-overlay h3{font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:.75rem}

/* ===== TESTIMONIALS ===== */
.testi-card{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius);padding:2rem}
.stars{color:#f4c430;font-size:1rem;letter-spacing:2px;margin-bottom:1rem}
.testi-card p{color:rgba(255,255,255,.65);font-size:.9rem;line-height:1.75;margin-bottom:1.5rem;font-style:italic}
.testi-author{display:flex;align-items:center;gap:1rem}
.testi-avatar{width:42px;height:42px;border-radius:50%;background:var(--green-dark);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff;flex-shrink:0}
.testi-author strong{display:block;font-size:.9rem;color:#fff}
.testi-author span{font-size:.8rem;color:rgba(255,255,255,.4)}

/* ===== CTA BANNER ===== */
.cta-banner{background:linear-gradient(135deg,var(--green-dark) 0%,#2a3025 100%);padding:80px 0;text-align:center}
.cta-content h2{font-size:clamp(2rem,4vw,3rem);font-weight:800;color:#fff;margin-bottom:1rem}
.cta-content p{color:rgba(255,255,255,.7);font-size:1.05rem;margin-bottom:2rem}

/* ===== FOOTER ===== */
.footer{background:#0a0a0a;padding:70px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:3rem;padding-bottom:50px}
.footer-brand .nav-logo{margin-bottom:1rem;display:inline-flex}
.footer-brand p{color:rgba(255,255,255,.4);font-size:.85rem;line-height:1.7;max-width:280px;margin-bottom:1.5rem}
.social-links{display:flex;gap:.75rem}
.social-links a{width:36px;height:36px;border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);transition:all var(--transition)}
.social-links a:hover{border-color:var(--green-light);color:var(--green-light)}
.social-links svg{width:16px;height:16px}
.footer-col h4{font-size:.85rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff;margin-bottom:1.25rem}
.footer-col ul{display:flex;flex-direction:column;gap:.6rem}
.footer-col a{color:rgba(255,255,255,.4);font-size:.85rem;transition:color var(--transition)}
.footer-col a:hover{color:var(--green-light)}
.footer-contact li{color:rgba(255,255,255,.4);font-size:.85rem;line-height:1.6}
.footer-bottom{border-top:1px solid var(--border);padding:1.5rem 0;display:flex;justify-content:space-between;align-items:center}
.footer-bottom p{font-size:.8rem;color:rgba(255,255,255,.25)}

/* ===== SERVICES PAGE ===== */
.services-full-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.srv-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform var(--transition),border-color var(--transition)}
.srv-card:hover{transform:translateY(-4px);border-color:var(--green-mid)}
.srv-img img{width:100%;height:220px;object-fit:cover}
.srv-body{padding:1.75rem}
.srv-icon{width:44px;height:44px;background:rgba(141,179,96,.15);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.srv-icon svg{width:20px;height:20px;color:var(--green-light)}
.srv-body h3{font-size:1.2rem;font-weight:700;margin-bottom:.75rem;color:#fff}
.srv-body p{color:rgba(255,255,255,.55);font-size:.9rem;line-height:1.75;margin-bottom:1.25rem}
.srv-list{display:flex;flex-direction:column;gap:.4rem}
.srv-list li{font-size:.85rem;color:rgba(255,255,255,.5);padding-left:1rem;position:relative}
.srv-list li::before{content:'→';position:absolute;left:0;color:var(--green-light)}

/* ===== PROCESS ===== */
.process-steps{display:flex;align-items:flex-start;justify-content:center;gap:.5rem;flex-wrap:wrap}
.step{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem;flex:1;min-width:160px;max-width:200px;text-align:center}
.step-num{font-size:2.5rem;font-weight:800;color:var(--green-light);opacity:.5;line-height:1;margin-bottom:.75rem}
.step h4{font-size:1rem;font-weight:700;margin-bottom:.5rem;color:#fff}
.step p{font-size:.82rem;color:rgba(255,255,255,.45);line-height:1.6}
.step-arrow{font-size:1.5rem;color:var(--green-mid);align-self:center;padding:0 .25rem;margin-top:-20px}

/* ===== PORTFOLIO PAGE ===== */
.filter-bar{display:flex;gap:.75rem;margin-bottom:2.5rem;flex-wrap:wrap}
.filter-btn{background:transparent;border:1px solid var(--border);color:rgba(255,255,255,.5);padding:.5rem 1.25rem;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all var(--transition)}
.filter-btn.active,.filter-btn:hover{background:var(--green-light);border-color:var(--green-light);color:#1a1a1a}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.port-card{cursor:pointer;border-radius:var(--radius);overflow:hidden;background:var(--card);border:1px solid var(--border);transition:transform var(--transition)}
.port-card:hover{transform:translateY(-4px)}
.port-img-wrap{position:relative;overflow:hidden}
.port-img-wrap img{width:100%;height:260px;object-fit:cover;transition:transform .5s ease}
.port-card:hover .port-img-wrap img{transform:scale(1.07)}
.port-overlay{position:absolute;inset:0;background:rgba(74,82,64,.7);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition)}
.port-card:hover .port-overlay{opacity:1}
.port-icon{font-size:2rem;color:#fff;line-height:1}
.port-info{padding:1.25rem}
.port-badge{display:inline-block;font-size:.72rem;font-weight:600;padding:.25rem .75rem;border-radius:20px;margin-bottom:.5rem;letter-spacing:.05em}
.port-badge.luxury{background:rgba(212,175,55,.15);color:#d4af37}
.port-badge.residential{background:rgba(141,179,96,.15);color:var(--green-light)}
.port-badge.commercial{background:rgba(100,149,237,.15);color:#6495ed}
.port-badge.heritage{background:rgba(205,133,63,.15);color:#cd853f}
.port-info h3{font-size:1rem;font-weight:700;color:#fff;margin-bottom:.25rem}
.port-info p{font-size:.82rem;color:rgba(255,255,255,.4)}

/* ===== MODAL ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:1000;display:none;align-items:center;justify-content:center;padding:2rem}
.modal-overlay.active{display:flex}
.modal{background:#1a1a1a;border:1px solid var(--border);border-radius:16px;max-width:860px;width:100%;max-height:90vh;overflow-y:auto;display:grid;grid-template-columns:1fr 1fr}
.modal-close{position:absolute;top:1rem;right:1rem;background:rgba(0,0,0,.5);border:none;color:#fff;width:36px;height:36px;border-radius:50%;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10}
.modal-img-wrap{position:relative}
.modal-img-wrap img{width:100%;height:100%;min-height:380px;object-fit:cover;border-radius:16px 0 0 16px}
.modal-body{padding:2rem;display:flex;flex-direction:column;gap:.75rem}
.modal-loc{font-size:.85rem;color:rgba(255,255,255,.4)}
.modal-body h2{font-size:1.4rem;font-weight:800}
.modal-body p{font-size:.88rem;color:rgba(255,255,255,.6);line-height:1.75}
.modal-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem;margin-top:.5rem}
.stat-item{background:rgba(255,255,255,.05);border-radius:8px;padding:.75rem;text-align:center}
.stat-item strong{display:block;font-size:.72rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}
.stat-item span{font-size:.85rem;font-weight:700;color:#fff}

/* ===== CONTACT PAGE ===== */
.contact-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:3rem;align-items:start}
.contact-form-wrap h2{font-size:1.8rem;font-weight:800;margin-bottom:.5rem}
.contact-intro{color:rgba(255,255,255,.55);font-size:.9rem;margin-bottom:2rem}
.contact-form{display:flex;flex-direction:column;gap:1.25rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-group label{font-size:.82rem;font-weight:600;color:rgba(255,255,255,.65);letter-spacing:.02em}
.form-group input,.form-group select,.form-group textarea{background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:8px;color:#fff;padding:.8rem 1rem;font-size:.9rem;font-family:inherit;transition:border-color var(--transition);width:100%}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--green-light)}
.form-group select option{background:#1a1a1a}
.form-error{font-size:.78rem;color:#e05e5e;display:none}
.form-group.error input,.form-group.error select,.form-group.error textarea{border-color:#e05e5e}
.form-group.error .form-error{display:block}
.form-success{display:none;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;gap:1rem}
.success-icon{width:64px;height:64px;border-radius:50%;background:rgba(141,179,96,.2);display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:var(--green-light)}
.form-success h3{font-size:1.4rem;font-weight:800}
.form-success p{color:rgba(255,255,255,.55);font-size:.9rem}
.contact-info-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;margin-bottom:1.5rem}
.contact-info-card h3{font-size:1.15rem;font-weight:700;margin-bottom:1.5rem}
.contact-detail{display:flex;gap:1rem;margin-bottom:1.5rem;align-items:flex-start}
.cd-icon{width:40px;height:40px;border-radius:8px;background:rgba(141,179,96,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cd-icon svg{width:18px;height:18px;color:var(--green-light)}
.contact-detail strong{display:block;font-size:.85rem;color:#fff;margin-bottom:.2rem}
.contact-detail p,.contact-detail a{font-size:.85rem;color:rgba(255,255,255,.45);line-height:1.6}
.contact-detail a:hover{color:var(--green-light)}
.contact-map{margin-bottom:1.5rem;border-radius:var(--radius);overflow:hidden}
.contact-promise{background:rgba(141,179,96,.08);border:1px solid rgba(141,179,96,.2);border-radius:var(--radius);padding:1.5rem}
.contact-promise h4{font-size:.9rem;font-weight:700;margin-bottom:1rem;color:var(--green-light)}
.contact-promise ul{display:flex;flex-direction:column;gap:.5rem}
.contact-promise li{font-size:.85rem;color:rgba(255,255,255,.6)}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .grid-2,.services-full-grid,.contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .cards-grid-3{grid-template-columns:1fr 1fr}
  .process-steps{gap:.75rem}
  .step-arrow{display:none}
  .intro-img{display:none}
  .portfolio-grid{grid-template-columns:1fr 1fr}
  .modal{grid-template-columns:1fr}
  .modal-img-wrap img{border-radius:16px 16px 0 0;min-height:240px}
}
@media(max-width:768px){
  .section{padding:70px 0}
  .hero h1{font-size:2.6rem}
  .cards-grid-3{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:1fr}
  .proj-grid{grid-template-columns:1fr}
  .proj-card.large{grid-row:auto}
  .stats-bar .container{gap:0}
  .stat{padding:.75rem 1.5rem}
  .stat-divider{display:none}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:.5rem;text-align:center}
  .nav-links{display:none;position:fixed;inset:0;background:rgba(13,13,13,.97);flex-direction:column;align-items:center;justify-content:center;gap:2rem;z-index:99}
  .nav-links.open{display:flex}
  .nav-links a{font-size:1.4rem}
  .nav-toggle{display:flex;z-index:100}
  .modal{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .modal-stats{grid-template-columns:1fr}
  .process-steps{flex-direction:column;align-items:stretch}
  .step{max-width:100%}
}
