/* ============================================================
   GP Construction & Landscaping — styles.css
   ============================================================ */

*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --green:#2ecc52;
  --green-dark:#1fa83e;
  --green-glow:rgba(46,204,82,0.18);
  --dark:#0b0f0c;
  --dark2:#111a13;
  --dark3:#182019;
  --card:#1a241c;
  --text:#e8f0e9;
  --muted:#7a9b7e;
  --white:#ffffff;
  --orange:#ff6b1a;
  --orange-soft:#ff8c4a;
}
html{scroll-behavior:smooth;}
body{font-family:'Barlow',sans-serif;background:var(--dark);color:var(--text);overflow-x:hidden;}

/* ─── CURSOR ─── */
.cursor{position:fixed;width:12px;height:12px;background:var(--green);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform 0.1s,width 0.2s,height 0.2s,opacity 0.2s;mix-blend-mode:screen;}
.cursor-ring{position:fixed;width:36px;height:36px;border:1.5px solid var(--green);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:transform 0.12s ease,width 0.2s,height 0.2s,opacity 0.2s;opacity:0.5;}

/* ─── NAVBAR ─── */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:0 5%;height:72px;background:rgba(11,15,12,0.85);backdrop-filter:blur(14px);border-bottom:1px solid rgba(46,204,82,0.1);transition:all 0.3s;}
nav.scrolled{height:60px;background:rgba(11,15,12,0.97);}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;}
.logo-svg{width:52px;height:52px;}
.logo-text{display:flex;flex-direction:column;line-height:1.1;}
.logo-text span:first-child{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:18px;color:var(--green);letter-spacing:1px;}
.logo-text span:last-child{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:11px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;}
.nav-links{display:flex;gap:36px;list-style:none;}
.nav-links a{color:var(--muted);text-decoration:none;font-size:14px;font-weight:500;letter-spacing:0.5px;transition:color 0.2s;position:relative;}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--green);transition:width 0.3s;}
.nav-links a:hover{color:var(--white);}
.nav-links a:hover::after{width:100%;}
.nav-cta{background:var(--green);color:var(--dark);font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:15px;letter-spacing:1px;padding:10px 24px;border-radius:4px;text-decoration:none;transition:all 0.2s;border:none;cursor:pointer;}
.nav-cta:hover{background:var(--green-light,#3aff60);transform:translateY(-1px);box-shadow:0 6px 20px rgba(46,204,82,0.35);}

/* ─── HERO ─── */
#home{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:var(--dark);}
.hero-bg{position:absolute;inset:0;background:linear-gradient(105deg,rgba(11,15,12,0.97) 40%,rgba(11,15,12,0.55) 100%),url('img/13.jpeg') center/cover no-repeat;z-index:0;}
.hero-particles{position:absolute;inset:0;overflow:hidden;z-index:1;}
.hero-content{position:relative;z-index:2;max-width:660px;padding:0 5%;padding-top:100px;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(46,204,82,0.12);border:1px solid rgba(46,204,82,0.3);border-radius:100px;padding:6px 16px;margin-bottom:28px;}
.hero-badge span{font-size:12px;font-weight:600;color:var(--green);letter-spacing:1.5px;text-transform:uppercase;}
.badge-dot{width:6px;height:6px;background:var(--green);border-radius:50%;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:0.5;transform:scale(1.4);}}
h1{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:clamp(52px,7vw,88px);line-height:0.95;color:var(--white);margin-bottom:24px;letter-spacing:-1px;}
h1 .accent{color:var(--green);display:block;}
.hero-sub{font-size:17px;color:var(--muted);line-height:1.7;max-width:480px;margin-bottom:36px;}
.hero-checks{display:flex;flex-direction:column;gap:12px;margin-bottom:44px;}
.check-item{display:flex;align-items:center;gap:12px;font-size:15px;color:var(--text);}
.check-icon{width:22px;height:22px;background:rgba(46,204,82,0.15);border:1px solid var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.check-icon svg{width:11px;height:11px;stroke:var(--green);fill:none;}
.hero-btns{display:flex;gap:16px;flex-wrap:wrap;}
.btn-primary{background:var(--green);color:var(--dark);font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:16px;letter-spacing:1px;padding:14px 32px;border-radius:4px;text-decoration:none;transition:all 0.25s;border:none;cursor:pointer;display:inline-block;}
.btn-primary:hover{background:#3aff60;transform:translateY(-2px);box-shadow:0 10px 30px rgba(46,204,82,0.4);}
.btn-secondary{background:transparent;color:var(--white);font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:16px;letter-spacing:1px;padding:14px 32px;border-radius:4px;border:1.5px solid rgba(255,255,255,0.2);text-decoration:none;transition:all 0.25s;cursor:pointer;display:inline-block;}
.btn-secondary:hover{border-color:var(--green);color:var(--green);}
.hero-stats{position:absolute;right:5%;bottom:80px;z-index:2;display:flex;gap:48px;}
.stat{text-align:center;}
.stat-num{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:42px;color:var(--green);line-height:1;}
.stat-label{font-size:12px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-top:4px;}
.hero-scroll{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;}
.hero-scroll span{font-size:11px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--green),transparent);animation:scrollAnim 2s ease-in-out infinite;}
@keyframes scrollAnim{0%{opacity:0;transform:scaleY(0);transform-origin:top;}50%{opacity:1;}100%{opacity:0;transform:scaleY(1);transform-origin:bottom;}}

/* ─── TRUST BAR ─── */
.trust-bar{background:var(--dark2);border-top:1px solid rgba(46,204,82,0.1);border-bottom:1px solid rgba(46,204,82,0.1);padding:20px 5%;display:flex;justify-content:center;gap:60px;flex-wrap:wrap;}
.trust-item{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:13px;font-weight:500;letter-spacing:0.5px;}
.trust-item svg{width:18px;height:18px;stroke:var(--green);fill:none;flex-shrink:0;}

/* ─── SECTIONS ─── */
section{padding:100px 5%;}
.section-label{display:inline-block;font-size:12px;font-weight:600;color:var(--green);letter-spacing:3px;text-transform:uppercase;margin-bottom:14px;}
.section-title{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:clamp(36px,4.5vw,58px);color:var(--white);line-height:1.05;margin-bottom:18px;}
.section-sub{font-size:16px;color:var(--muted);line-height:1.7;max-width:540px;}

/* ─── ABOUT ─── */
#about{background:var(--dark2);}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;margin-top:60px;}
.about-img{position:relative;border-radius:8px;overflow:hidden;}
.about-img img{width:100%;height:500px;object-fit:cover;display:block;filter:saturate(0.9);}
.about-img-badge{position:absolute;bottom:24px;left:24px;background:var(--green);color:var(--dark);padding:14px 20px;border-radius:6px;}
.about-img-badge .big{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:36px;line-height:1;}
.about-img-badge .small{font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;}
.about-points{display:flex;flex-direction:column;gap:28px;margin-top:36px;}
.about-point{display:flex;gap:18px;align-items:flex-start;}
.about-icon{width:46px;height:46px;background:rgba(46,204,82,0.1);border:1px solid rgba(46,204,82,0.25);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.about-icon svg{width:20px;height:20px;stroke:var(--green);fill:none;}
.about-point h4{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:18px;color:var(--white);margin-bottom:4px;}
.about-point p{font-size:14px;color:var(--muted);line-height:1.6;}

/* ─── SERVICES ─── */
#services{background:var(--dark);}
.services-tabs{display:flex;gap:0;margin-bottom:48px;border:1px solid rgba(46,204,82,0.2);border-radius:6px;overflow:hidden;width:fit-content;}
.tab-btn{background:transparent;color:var(--muted);border:none;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:16px;letter-spacing:1px;padding:13px 32px;cursor:pointer;transition:all 0.25s;}
.tab-btn.active{background:var(--green);color:var(--dark);}
.tab-btn:hover:not(.active){color:var(--white);background:rgba(46,204,82,0.08);}
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;}
.service-card{background:var(--card);border:1px solid rgba(46,204,82,0.1);border-radius:10px;overflow:hidden;cursor:pointer;transition:all 0.35s;position:relative;}
.service-card:hover{border-color:var(--green);transform:translateY(-6px);box-shadow:0 20px 50px rgba(0,0,0,0.5),0 0 0 1px rgba(46,204,82,0.2);}
.service-card-img{height:190px;overflow:hidden;position:relative;}
.service-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s;filter:saturate(0.8);}
.service-card:hover .service-card-img img{transform:scale(1.08);filter:saturate(1.1);}
.service-card-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(11,15,12,0.9));}
.service-card-body{padding:20px;}
.service-card-icon{width:40px;height:40px;background:rgba(46,204,82,0.12);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;}
.service-card-icon svg{width:20px;height:20px;stroke:var(--green);fill:none;}
.service-card h3{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:20px;color:var(--white);margin-bottom:8px;}
.service-card p{font-size:13px;color:var(--muted);line-height:1.6;}
.service-card-tag{position:absolute;top:14px;right:14px;background:rgba(46,204,82,0.85);color:var(--dark);font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;border-radius:3px;}

/* ─── HOW WE WORK ─── */
#process{background:var(--dark2);}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:60px;position:relative;}
.process-steps::before{content:'';position:absolute;top:36px;left:10%;right:10%;height:1px;background:linear-gradient(to right,transparent,var(--green),transparent);opacity:0.3;}
.step{text-align:center;position:relative;}
.step-num{width:72px;height:72px;border-radius:50%;background:var(--card);border:2px solid rgba(46,204,82,0.25);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:28px;color:var(--green);transition:all 0.3s;}
.step:hover .step-num{background:var(--green);color:var(--dark);border-color:var(--green);box-shadow:0 0 30px rgba(46,204,82,0.4);}
.step h4{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:18px;color:var(--white);margin-bottom:8px;}
.step p{font-size:13px;color:var(--muted);line-height:1.6;}

/* ─── PROJECTS ─── */
#projects{background:var(--dark);}
.projects-grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:260px 260px;gap:16px;margin-top:60px;}
.proj-card{border-radius:8px;overflow:hidden;position:relative;cursor:pointer;}
.proj-card img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s,filter 0.4s;filter:saturate(0.75);}
.proj-card:hover img{transform:scale(1.06);filter:saturate(1);}
.proj-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(11,15,12,0.9) 0%,transparent 60%);display:flex;flex-direction:column;justify-content:flex-end;padding:20px;opacity:0;transition:opacity 0.3s;}
.proj-card:hover .proj-card-overlay{opacity:1;}
.proj-card-overlay h4{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:20px;color:var(--white);}
.proj-card-overlay span{font-size:12px;color:var(--green);font-weight:600;letter-spacing:1px;text-transform:uppercase;}
.proj-card.big{grid-row:1/3;}

/* ─── TESTIMONIALS ─── */
#reviews{background:var(--dark2);}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:60px;}
.review-card{background:var(--card);border:1px solid rgba(46,204,82,0.1);border-radius:10px;padding:28px;transition:border-color 0.3s;}
.review-card:hover{border-color:rgba(46,204,82,0.35);}
.stars{display:flex;gap:4px;margin-bottom:16px;}
.star{color:var(--orange);font-size:14px;}
.review-text{font-size:14px;color:var(--text);line-height:1.7;margin-bottom:20px;font-style:italic;}
.reviewer{display:flex;align-items:center;gap:12px;}
.reviewer-avatar{width:40px;height:40px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:16px;color:var(--dark);}
.reviewer-name{font-weight:600;font-size:14px;color:var(--white);}
.reviewer-loc{font-size:12px;color:var(--muted);}

/* ─── CONTACT ─── */
#contact{background:var(--dark);position:relative;overflow:hidden;}
#contact::before{content:'';position:absolute;top:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(46,204,82,0.06) 0%,transparent 70%);pointer-events:none;}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;margin-top:60px;}
.contact-info{display:flex;flex-direction:column;gap:28px;}
.contact-item{display:flex;gap:16px;align-items:flex-start;}
.contact-item-icon{width:48px;height:48px;background:rgba(46,204,82,0.1);border:1px solid rgba(46,204,82,0.25);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.contact-item-icon svg{width:22px;height:22px;stroke:var(--green);fill:none;}
.contact-item h4{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:16px;color:var(--white);margin-bottom:4px;letter-spacing:0.5px;}
.contact-item p,.contact-item a{font-size:15px;color:var(--muted);text-decoration:none;transition:color 0.2s;}
.contact-item a:hover{color:var(--green);}
.contact-cta-big{background:var(--green);border-radius:10px;padding:30px;margin-top:10px;}
.contact-cta-big p{font-size:13px;color:rgba(11,15,12,0.7);margin-bottom:6px;font-weight:600;letter-spacing:1px;text-transform:uppercase;}
.contact-cta-big a{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:36px;color:var(--dark);text-decoration:none;letter-spacing:1px;display:block;}
.contact-cta-big span{font-size:13px;color:rgba(11,15,12,0.6);}
.contact-form{display:flex;flex-direction:column;gap:16px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{display:flex;flex-direction:column;gap:6px;}
.form-group label{font-size:12px;font-weight:600;color:var(--muted);letter-spacing:1px;text-transform:uppercase;}
.form-group input,.form-group textarea,.form-group select{background:var(--dark2);border:1px solid rgba(46,204,82,0.15);border-radius:6px;color:var(--text);font-family:'Barlow',sans-serif;font-size:14px;padding:12px 16px;outline:none;transition:border-color 0.2s;}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--green);}
.form-group textarea{resize:vertical;min-height:100px;}
.form-group select option{background:var(--dark2);}
.btn-submit{background:var(--green);color:var(--dark);font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:17px;letter-spacing:1.5px;padding:15px;border-radius:6px;border:none;cursor:pointer;transition:all 0.25s;text-transform:uppercase;}
.btn-submit:hover{background:#3aff60;transform:translateY(-2px);box-shadow:0 10px 30px rgba(46,204,82,0.35);}
.form-status{font-size:13px;color:var(--muted);margin-top:4px;line-height:1.4;}
.form-status:empty{display:none;}
.form-status[data-status="success"]{color:var(--green);font-weight:600;}
.form-status[data-status="error"]{color:var(--orange);font-weight:600;}

/* ─── FOOTER ─── */
footer{background:var(--dark2);border-top:1px solid rgba(46,204,82,0.1);padding:40px 5%;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px;}
.footer-copy{font-size:13px;color:var(--muted);}
.footer-links{display:flex;gap:24px;}
.footer-links a{font-size:13px;color:var(--muted);text-decoration:none;transition:color 0.2s;}
.footer-links a:hover{color:var(--green);}

/* ─── FLOATING CTA ─── */
.float-cta{position:fixed;bottom:28px;right:28px;z-index:800;background:var(--orange);color:white;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:15px;letter-spacing:1px;padding:14px 24px;border-radius:50px;text-decoration:none;box-shadow:0 8px 30px rgba(255,107,26,0.45);animation:floatBounce 3s ease-in-out infinite;display:flex;align-items:center;gap:8px;transition:transform 0.2s,box-shadow 0.2s;}
.float-cta:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 14px 40px rgba(255,107,26,0.55);}
@keyframes floatBounce{0%,100%{transform:translateY(0);}50%{transform:translateY(-6px);}}
.float-cta svg{width:18px;height:18px;fill:white;}

/* ─── TABS PANEL ─── */
.tab-panel{display:none;}
.tab-panel.active{display:grid;}

/* ─── ANIMATIONS ─── */
.reveal{opacity:0;transform:translateY(32px);transition:opacity 0.7s ease,transform 0.7s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}

/* ─── MODAL ─── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.85);z-index:2000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.3s;backdrop-filter:blur(4px);}
.modal-overlay.open{opacity:1;pointer-events:all;}
.modal-box{background:var(--dark2);border:1px solid rgba(46,204,82,0.2);border-radius:14px;padding:40px;max-width:540px;width:90%;transform:scale(0.9);transition:transform 0.3s;position:relative;}
.modal-overlay.open .modal-box{transform:scale(1);}
.modal-box h2{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:32px;color:var(--white);margin-bottom:6px;}
.modal-box p{color:var(--muted);font-size:14px;margin-bottom:24px;}
.modal-close{position:absolute;top:16px;right:20px;background:none;border:none;color:var(--muted);font-size:28px;cursor:pointer;transition:color 0.2s;}
.modal-close:hover{color:var(--white);}

/* ─── RESPONSIVE ─── */
@media(max-width:900px){
  .about-grid{grid-template-columns:1fr;}
  .projects-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;}
  .proj-card.big{grid-row:auto;}
  .reviews-grid{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .process-steps{grid-template-columns:1fr 1fr;}
  .hero-stats{position:static;margin-top:40px;justify-content:flex-start;}
}
@media(max-width:600px){
  .nav-links{display:none;}
  .process-steps{grid-template-columns:1fr;}
  .projects-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .trust-bar{gap:20px;}
  .hero-stats{gap:24px;}
}
