/*
Theme Name: FMP Flooring
Theme URI: https://fmpflooring.com
Author: FMP Flooring
Description: Custom WordPress theme for FMP Flooring. Full ACF Free support, WPForms ready, complete theme settings, hero image upload with opacity/padding controls, editable header/footer, font controls.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GPLv2+
Text Domain: fmp-flooring
Tags: custom-logo, custom-menu, featured-images, theme-options, full-site-editing
*/

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  /* Logo Colors */
  --navy:#2d2b55;
  --navy-dark:#1e1c42;
  --navy-deep:#14133a;
  --teal:#3ecdc6;
  --teal-dark:#2db5ae;
  --teal-light:#5ef0e8;
  --beige:#d5d0c0;
  --beige-light:#e8e4d8;
  --amber:#f5b731;
  --amber-dark:#d9a029;
  --amber-light:#ffc94d;

  /* Derived */
  --white:#ffffff;
  --cream:#faf8f4;
  --surface:#f4f1eb;
  --text-dark:#1a1835;
  --text-body:#4a4865;
  --text-muted:#8a87a2;
  --text-light:#b0adc2;

  --shadow-sm:0 2px 12px rgba(45,43,85,0.06);
  --shadow-md:0 8px 30px rgba(45,43,85,0.1);
  --shadow-lg:0 20px 60px rgba(45,43,85,0.14);
  --shadow-teal:0 8px 30px rgba(62,205,198,0.25);
  --shadow-amber:0 8px 30px rgba(245,183,49,0.3);
  --radius:14px;
  --radius-sm:8px;
  --transition:all 0.4s cubic-bezier(0.25,0.46,0.45,0.94);
}

html{scroll-behavior:smooth}
body{font-family:'Montserrat',sans-serif;color:var(--text-dark);line-height:1.7;overflow-x:hidden;background:var(--cream)}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;display:block}
.container{max-width:1240px;margin:0 auto;padding:0 24px}

/* ============= PROMO BANNER ============= */
.promo-banner{
  background:linear-gradient(90deg,var(--amber),var(--amber-dark),var(--amber));
  background-size:200% 100%;
  animation:bannerShimmer 4s ease infinite;
  text-align:center;
  padding:11px 20px;
  position:relative;
  z-index:1001;
}
@keyframes bannerShimmer{
  0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}
}
.promo-banner p{
  font-size:13px;font-weight:600;color:var(--navy-deep);
  display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;
}
.promo-badge{
  background:var(--navy);color:var(--white);
  padding:3px 12px;border-radius:20px;
  font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1px;
}
.promo-banner strong{font-weight:800}

/* ============= NAVBAR ============= */
.navbar{
  background:var(--navy-deep);
  position:sticky;top:0;z-index:1000;
  border-bottom:1px solid rgba(62,205,198,0.08);
}
.navbar .container{display:flex;justify-content:space-between;align-items:center;height:74px}

.logo-wrapper{display:flex;align-items:center;gap:0}
.logo-wrapper img{height:52px;width:auto;object-fit:contain}

.nav-links{display:flex;gap:4px;align-items:center}
.nav-links a{
  color:rgba(255,255,255,0.7);font-size:12.5px;font-weight:600;
  padding:8px 15px;border-radius:6px;
  transition:var(--transition);text-transform:uppercase;letter-spacing:0.8px;
}
.nav-links a:hover,.nav-links a.active{color:var(--white);background:rgba(62,205,198,0.1)}
.nav-links a i{font-size:8px;margin-left:3px;opacity:0.5}

.nav-right{display:flex;align-items:center;gap:16px}
.nav-phone{
  color:var(--teal);font-size:13px;font-weight:700;
  display:flex;align-items:center;gap:7px;
}
.nav-phone i{font-size:12px}
.btn-nav{
  background:var(--teal);color:var(--navy-deep);
  padding:10px 24px;border-radius:var(--radius-sm);
  font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:0.8px;
  transition:var(--transition);border:none;cursor:pointer;
}
.btn-nav:hover{background:var(--teal-light);transform:translateY(-2px);box-shadow:var(--shadow-teal)}
.mobile-toggle{display:none;background:none;border:none;color:var(--teal);font-size:22px;cursor:pointer}

/* ============= HERO ============= */
.hero{
  background:var(--navy-deep);
  position:relative;overflow:hidden;
  min-height:680px;display:flex;align-items:center;
  padding:50px 0;
}
/* Decorative tile grid background */
.hero-tiles{
  position:absolute;inset:0;z-index:0;opacity:0.04;
  background:
    repeating-linear-gradient(0deg,transparent,transparent 79px,rgba(255,255,255,0.5) 79px,rgba(255,255,255,0.5) 80px),
    repeating-linear-gradient(90deg,transparent,transparent 79px,rgba(255,255,255,0.5) 79px,rgba(255,255,255,0.5) 80px);
}
/* Gradient orbs */
.hero-orb{position:absolute;border-radius:50%;filter:blur(120px);z-index:0}
.hero-orb-1{width:500px;height:500px;background:var(--teal);top:-180px;right:-80px;opacity:0.1}
.hero-orb-2{width:350px;height:350px;background:var(--amber);bottom:-120px;left:-60px;opacity:0.08}
.hero-orb-3{width:300px;height:300px;background:var(--navy);top:50%;left:40%;opacity:0.2}
/* Accent lines */
.hero-line{
  position:absolute;width:1px;height:100%;
  background:linear-gradient(180deg,transparent,rgba(62,205,198,0.12),transparent);
  z-index:1;
}
.hero-line-1{left:20%}.hero-line-2{left:50%}.hero-line-3{left:80%}

.hero .container{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr 440px;
  gap:60px;align-items:center;
}

/* Hero Left */
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(62,205,198,0.1);border:1px solid rgba(62,205,198,0.2);
  border-radius:30px;padding:7px 18px 7px 8px;
  font-size:11px;font-weight:700;color:var(--teal);
  text-transform:uppercase;letter-spacing:1px;
  margin-bottom:24px;animation:fadeUp .8s ease both;
}
.hero-badge .badge-dot{
  width:24px;height:24px;border-radius:50%;
  background:var(--teal);display:grid;place-items:center;
}
.hero-badge .badge-dot i{font-size:10px;color:var(--navy-deep)}
.hero h1{
  font-size:56px;font-weight:900;color:var(--white);
  line-height:1.08;margin-bottom:16px;
  animation:fadeUp .8s ease .1s both;
  letter-spacing:-1px;
}
.hero h1 .highlight{
  color:var(--teal);
  position:relative;
}
.hero h1 .highlight::after{
  content:'';position:absolute;bottom:2px;left:0;right:0;
  height:4px;background:var(--teal);border-radius:2px;opacity:0.4;
}
.hero h1 .highlight-amber{color:var(--amber)}
.hero-sub{
  font-size:16px;color:rgba(255,255,255,0.5);
  margin-bottom:30px;max-width:460px;line-height:1.8;font-weight:400;
  animation:fadeUp .8s ease .2s both;
}
.hero-stats{
  display:flex;gap:32px;animation:fadeUp .8s ease .3s both;
}
.hero-stat{display:flex;align-items:center;gap:10px}
.hero-stat-icon{
  width:42px;height:42px;border-radius:10px;
  display:grid;place-items:center;font-size:16px;
}
.hero-stat-icon.ic-teal{background:rgba(62,205,198,0.12);color:var(--teal)}
.hero-stat-icon.ic-amber{background:rgba(245,183,49,0.12);color:var(--amber)}
.hero-stat-icon.ic-beige{background:rgba(213,208,192,0.15);color:var(--beige)}
.hero-stat strong{font-size:20px;font-weight:800;color:var(--white);display:block;line-height:1.1}
.hero-stat span{font-size:11px;color:rgba(255,255,255,0.4);font-weight:500;text-transform:uppercase;letter-spacing:0.5px}

/* Hero Lead Form */
.hero-form-wrap{animation:fadeUp .8s ease .2s both}
.lead-form{
  background:var(--white);border-radius:18px;
  padding:36px 30px;
  box-shadow:0 30px 80px rgba(14,13,58,0.35),0 0 0 1px rgba(62,205,198,0.08);
  position:relative;overflow:hidden;
}
/* Top gradient bar matching logo colors */
.lead-form::before{
  content:'';position:absolute;top:0;left:0;right:0;height:5px;
  background:linear-gradient(90deg,var(--navy),var(--teal),var(--beige),var(--amber));
}
.form-head{text-align:center;margin-bottom:22px}
.form-head .form-logo{
  width:56px;height:56px;
  background:linear-gradient(135deg,var(--navy),var(--navy-dark));
  border-radius:14px;margin:0 auto 14px;
  display:grid;place-items:center;
  box-shadow:0 6px 20px rgba(45,43,85,0.2);
}
.form-head .form-logo i{font-size:22px;color:var(--teal)}
.form-head h3{font-size:20px;font-weight:800;color:var(--navy);margin-bottom:3px;letter-spacing:-0.3px}
.form-head p{font-size:12.5px;color:var(--text-muted);font-weight:500}
.form-group{margin-bottom:13px}
.form-group label{
  display:block;font-size:11px;font-weight:700;
  color:var(--navy);margin-bottom:5px;
  text-transform:uppercase;letter-spacing:0.8px;
}
.form-group input,.form-group select{
  width:100%;padding:12px 15px;
  border:2px solid var(--beige);border-radius:var(--radius-sm);
  font-size:13.5px;font-family:'Montserrat',sans-serif;
  color:var(--text-dark);background:var(--cream);
  transition:var(--transition);outline:none;font-weight:500;
}
.form-group input:focus,.form-group select:focus{
  border-color:var(--teal);box-shadow:0 0 0 4px rgba(62,205,198,0.1);
}
.form-group input::placeholder{color:var(--text-light);font-weight:400}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}

.btn-submit{
  width:100%;padding:14px;
  background:var(--teal);color:var(--navy-deep);
  font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:1px;
  border:none;border-radius:var(--radius-sm);
  cursor:pointer;transition:var(--transition);
  margin-top:4px;position:relative;overflow:hidden;
  font-family:'Montserrat',sans-serif;
}
.btn-submit::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,transparent,rgba(255,255,255,0.2),transparent);
  transform:translateX(-100%);transition:transform 0.5s;
}
.btn-submit:hover::after{transform:translateX(100%)}
.btn-submit:hover{background:var(--teal-light);transform:translateY(-2px);box-shadow:var(--shadow-teal)}

.form-footer{display:flex;justify-content:center;gap:16px;margin-top:14px}
.form-footer span{
  font-size:10.5px;font-weight:600;color:var(--text-muted);
  display:flex;align-items:center;gap:4px;
}
.form-footer span i{color:var(--teal);font-size:10px}

/* Success state */
#formSuccess{
  display:none;background:var(--white);border-radius:18px;
  padding:50px 30px;box-shadow:0 30px 80px rgba(14,13,58,0.35);
  text-align:center;
}
.success-icon{
  width:72px;height:72px;border-radius:50%;
  background:linear-gradient(135deg,var(--teal),var(--teal-dark));
  display:grid;place-items:center;margin:0 auto 20px;
  animation:scalePop 0.5s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes scalePop{from{transform:scale(0)}to{transform:scale(1)}}
.success-icon i{font-size:30px;color:white}

@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

/* ============= PROOF BAR ============= */
.proof-bar{background:var(--white);border-bottom:1px solid rgba(45,43,85,0.06);position:relative;z-index:5}
.proof-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.proof-item{
  text-align:center;padding:34px 20px;
  border-right:1px solid rgba(45,43,85,0.06);
  transition:var(--transition);
}
.proof-item:last-child{border-right:none}
.proof-item:hover{background:var(--surface)}
.proof-icon{
  width:50px;height:50px;margin:0 auto 12px;border-radius:12px;
  display:grid;place-items:center;
}
.proof-icon.pi-1{background:rgba(62,205,198,0.1)}
.proof-icon.pi-1 i{color:var(--teal);font-size:20px}
.proof-icon.pi-2{background:rgba(245,183,49,0.1)}
.proof-icon.pi-2 i{color:var(--amber);font-size:20px}
.proof-icon.pi-3{background:rgba(45,43,85,0.08)}
.proof-icon.pi-3 i{color:var(--navy);font-size:20px}
.proof-icon.pi-4{background:rgba(213,208,192,0.3)}
.proof-icon.pi-4 i{color:var(--amber-dark);font-size:20px}
.proof-num{font-size:30px;font-weight:900;color:var(--navy);display:block;margin-bottom:2px;letter-spacing:-1px}
.proof-label{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px}

/* ============= SECTION SHARED ============= */
.stag{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:800;text-transform:uppercase;
  letter-spacing:2.5px;color:var(--teal);margin-bottom:12px;
}
.stag::before{content:'';width:28px;height:3px;background:var(--teal);border-radius:2px}
.stitle{font-size:40px;font-weight:900;color:var(--navy);line-height:1.12;margin-bottom:14px;letter-spacing:-1px}
.stitle.light{color:var(--white)}
.sdesc{font-size:14px;color:var(--text-body);max-width:520px;line-height:1.85;font-weight:400}
.sdesc.light{color:rgba(255,255,255,0.45)}

/* ============= ABOUT ============= */
.about{padding:100px 0;background:var(--cream)}
.about .container{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-visual{position:relative}
.about-img{
  width:100%;aspect-ratio:4/3.5;border-radius:18px;overflow:hidden;
  position:relative;
  background:linear-gradient(135deg,var(--beige),var(--beige-light));
  box-shadow:var(--shadow-lg);
}
/* Simulated room */
.about-img::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,#f0ece2 0%,#f0ece2 55%,var(--beige) 55%);
}
.about-img::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:45%;
  background:repeating-linear-gradient(90deg,#c4a265 0px,#c4a265 78px,#b89450 78px,#b89450 80px);
}
/* Colored accent blocks like the logo */
.about-accent-1{
  position:absolute;top:-16px;left:-16px;
  width:80px;height:80px;background:var(--teal);
  border-radius:12px;z-index:3;opacity:0.9;
}
.about-accent-2{
  position:absolute;bottom:-16px;right:-16px;
  width:60px;height:60px;background:var(--amber);
  border-radius:10px;z-index:3;opacity:0.9;
}
.about-badge{
  position:absolute;bottom:30px;left:-30px;
  background:var(--navy);color:var(--white);
  padding:20px 24px;border-radius:14px;
  box-shadow:0 10px 30px rgba(45,43,85,0.3);
  z-index:4;text-align:center;
}
.about-badge strong{font-size:36px;font-weight:900;display:block;line-height:1;color:var(--teal)}
.about-badge span{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,0.6)}

.about-features{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:28px 0}
.about-feat{display:flex;align-items:flex-start;gap:12px}
.af-icon{
  width:42px;height:42px;min-width:42px;border-radius:10px;
  display:grid;place-items:center;font-size:16px;
}
.af-icon.afi-1{background:rgba(62,205,198,0.1);color:var(--teal)}
.af-icon.afi-2{background:rgba(245,183,49,0.1);color:var(--amber)}
.af-icon.afi-3{background:rgba(45,43,85,0.08);color:var(--navy)}
.af-icon.afi-4{background:rgba(213,208,192,0.3);color:var(--amber-dark)}
.about-feat h4{font-size:13px;font-weight:800;color:var(--navy);margin-bottom:2px}
.about-feat p{font-size:11.5px;color:var(--text-muted);line-height:1.5;font-weight:500}

.btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 32px;background:var(--teal);color:var(--navy-deep);
  font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:0.8px;
  border-radius:var(--radius-sm);transition:var(--transition);
  font-family:'Montserrat',sans-serif;border:none;cursor:pointer;
}
.btn-primary:hover{background:var(--teal-light);transform:translateY(-3px);box-shadow:var(--shadow-teal)}

/* ============= SERVICES ============= */
.services{padding:100px 0;background:var(--white)}
.services-head{text-align:center;margin-bottom:60px}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.scard{
  border-radius:18px;overflow:hidden;background:var(--cream);
  border:2px solid transparent;transition:var(--transition);position:relative;
}
.scard:hover{
  transform:translateY(-10px);box-shadow:var(--shadow-lg);
  border-color:var(--teal);
}
.scard-img{height:220px;position:relative;overflow:hidden}
.scard-img::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:50px;
  background:linear-gradient(transparent,var(--cream));
}
.si-carpet{background:linear-gradient(135deg,#8B4513,#A0522D,#CD853F)}
.si-carpet::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(45deg,rgba(255,255,255,0.04) 0px,rgba(255,255,255,0.04) 2px,transparent 2px,transparent 8px)}
.si-hardwood{background:linear-gradient(135deg,#654321,#8B6914,#D2B48C)}
.si-hardwood::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,rgba(255,255,255,0.02) 0px,rgba(255,255,255,0.02) 1px,transparent 1px,transparent 12px)}
.si-vinyl{background:linear-gradient(135deg,#888,#bbb,#999)}
.si-vinyl::before{content:'';position:absolute;inset:0;background:repeating-conic-gradient(#bbb 0% 25%,#ccc 0% 50%) 0 0/50px 50px;opacity:0.3}
/* Logo-color tag on each card */
.scard-tag{
  position:absolute;top:16px;left:16px;z-index:2;
  padding:5px 14px;border-radius:20px;
  font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:1px;
}
.scard-tag.st-teal{background:var(--teal);color:var(--navy-deep)}
.scard-tag.st-amber{background:var(--amber);color:var(--navy-deep)}
.scard-tag.st-navy{background:var(--navy);color:var(--white)}
.scard-body{padding:24px 26px 28px}
.scard-body h3{font-size:20px;font-weight:800;color:var(--navy);margin-bottom:8px}
.scard-body p{font-size:13px;color:var(--text-body);line-height:1.7;margin-bottom:14px;font-weight:400}
.scard-link{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:800;color:var(--teal);
  text-transform:uppercase;letter-spacing:0.5px;transition:var(--transition);
}
.scard-link:hover{gap:14px;color:var(--teal-dark)}
.scard-link i{font-size:10px}

/* ============= MID CTA ============= */
.mid-cta{
  background:var(--navy-deep);padding:70px 0;
  position:relative;overflow:hidden;
}
.mid-cta::before{
  content:'';position:absolute;width:400px;height:400px;
  background:var(--teal);border-radius:50%;filter:blur(150px);
  opacity:0.06;top:-150px;right:-50px;
}
.mid-cta .container{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.mid-cta h3{font-size:32px;font-weight:900;color:var(--white);margin-bottom:6px;letter-spacing:-0.5px}
.mid-cta p{font-size:13px;color:rgba(255,255,255,0.4);max-width:380px;font-weight:400}
.mid-cta-form{display:flex;gap:0}
.mid-cta-form input{
  padding:14px 20px;width:280px;
  border:2px solid rgba(62,205,198,0.2);background:rgba(255,255,255,0.05);
  color:var(--white);font-size:13px;font-family:'Montserrat',sans-serif;
  border-radius:var(--radius-sm) 0 0 var(--radius-sm);outline:none;
  transition:var(--transition);font-weight:500;
}
.mid-cta-form input::placeholder{color:rgba(255,255,255,0.25)}
.mid-cta-form input:focus{border-color:var(--teal)}
.mid-cta-form button{
  padding:14px 28px;background:var(--teal);color:var(--navy-deep);
  font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:0.8px;
  border:none;border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  cursor:pointer;transition:var(--transition);font-family:'Montserrat',sans-serif;
  white-space:nowrap;
}
.mid-cta-form button:hover{background:var(--teal-light);box-shadow:var(--shadow-teal)}

/* ============= PROCESS ============= */
.process{padding:100px 0;background:var(--cream)}
.process .container{display:grid;grid-template-columns:1fr 1fr;gap:70px}
.process-cards{display:flex;gap:20px;margin-top:28px}
.prc-card{
  flex:1;background:var(--white);border-radius:var(--radius);
  padding:28px 18px;text-align:center;
  border:2px solid transparent;transition:var(--transition);
}
.prc-card:hover{border-color:var(--teal);box-shadow:var(--shadow-sm)}
.prc-card i{font-size:28px;margin-bottom:10px;display:block}
.prc-card:nth-child(1) i{color:var(--teal)}
.prc-card:nth-child(2) i{color:var(--amber)}
.prc-card:nth-child(3) i{color:var(--navy)}
.prc-card span{font-size:11px;font-weight:800;color:var(--navy);text-transform:uppercase;letter-spacing:1px}

/* Accordion */
.acc-item{border-bottom:1px solid rgba(45,43,85,0.08)}
.acc-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 0;cursor:pointer;transition:var(--transition);
}
.acc-head:hover span{color:var(--teal)}
.acc-head span{font-size:13px;font-weight:700;color:var(--navy);transition:var(--transition)}
.acc-toggle{
  width:32px;height:32px;min-width:32px;border-radius:50%;
  background:var(--surface);border:2px solid rgba(45,43,85,0.08);
  display:grid;place-items:center;font-size:11px;color:var(--text-muted);
  transition:var(--transition);
}
.acc-item.active .acc-toggle{background:var(--teal);border-color:var(--teal);color:var(--navy-deep);transform:rotate(45deg)}
.acc-body{max-height:0;overflow:hidden;transition:max-height 0.4s ease}
.acc-body p{padding:0 0 18px;font-size:13px;color:var(--text-body);line-height:1.7;font-weight:400}
.acc-item.active .acc-body{max-height:200px}

/* ============= PORTFOLIO ============= */
.portfolio{padding:100px 0;background:var(--white)}
.port-head{text-align:center;margin-bottom:50px}
.port-tabs{display:flex;justify-content:center;gap:6px;margin-bottom:40px;flex-wrap:wrap}
.pt{
  padding:9px 22px;font-size:11px;font-weight:800;
  text-transform:uppercase;letter-spacing:1.2px;
  color:var(--text-muted);background:none;
  border:2px solid transparent;border-radius:30px;
  cursor:pointer;transition:var(--transition);
  font-family:'Montserrat',sans-serif;
}
.pt:hover{color:var(--navy);border-color:var(--beige)}
.pt.active{color:var(--navy-deep);border-color:var(--teal);background:rgba(62,205,198,0.06)}

.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pcard{
  border-radius:18px;overflow:hidden;position:relative;
  aspect-ratio:1;cursor:pointer;box-shadow:var(--shadow-sm);
}
.pcard-bg{width:100%;height:100%;transition:transform 0.6s ease}
.pcard:hover .pcard-bg{transform:scale(1.08)}
.pcard-bg-1{background:linear-gradient(135deg,#c4a265,#d4b896,#a08050)}
.pcard-bg-2{background:linear-gradient(135deg,#8B6914,#654321,#b08040)}
.pcard-bg-3{background:repeating-conic-gradient(#888 0% 25%,#999 0% 50%) 0 0/60px 60px}
.pcard-ov{
  position:absolute;bottom:0;left:0;right:0;padding:28px;
  background:linear-gradient(transparent,rgba(14,13,58,0.92));
  transform:translateY(20px);opacity:0;transition:var(--transition);
}
.pcard:hover .pcard-ov{transform:translateY(0);opacity:1}
.pcard-ov h4{font-size:18px;font-weight:800;color:var(--white);margin-bottom:4px}
.pcard-ov p{font-size:12px;color:rgba(255,255,255,0.5);margin-bottom:10px;font-weight:400}
.pcard-ov a{font-size:11px;font-weight:800;color:var(--teal);display:inline-flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:0.5px}

/* Portfolio CTA */
.port-cta{
  text-align:center;margin-top:50px;padding:44px;
  background:linear-gradient(135deg,rgba(62,205,198,0.05),rgba(245,183,49,0.05));
  border-radius:var(--radius);border:2px dashed var(--beige);
}
.port-cta h4{font-size:22px;font-weight:900;color:var(--navy);margin-bottom:4px}
.port-cta p{font-size:13px;color:var(--text-body);margin-bottom:18px;font-weight:400}

/* ============= TESTIMONIALS ============= */
.testimonials{padding:100px 0;background:var(--navy-deep);position:relative;overflow:hidden}
.testimonials::before{
  content:'';position:absolute;width:350px;height:350px;
  background:var(--amber);border-radius:50%;filter:blur(180px);
  opacity:0.04;bottom:-100px;right:-50px;
}
.test-head{text-align:center;margin-bottom:60px}
.test-head .stag{color:var(--teal-light)}
.test-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;max-width:920px;margin:0 auto}
.tcard{
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.06);
  border-radius:18px;padding:34px;transition:var(--transition);
}
.tcard:hover{background:rgba(255,255,255,0.07);border-color:rgba(62,205,198,0.15);transform:translateY(-4px)}
.tcard-stars{margin-bottom:16px;color:var(--amber);font-size:14px;letter-spacing:2px}
.tcard p{font-size:13.5px;color:rgba(255,255,255,0.55);line-height:1.85;font-style:italic;margin-bottom:22px;font-weight:400}
.tcard-author{display:flex;align-items:center;gap:14px;padding-top:18px;border-top:1px solid rgba(255,255,255,0.06)}
.tcard-av{
  width:46px;height:46px;border-radius:50%;
  display:grid;place-items:center;
}
.tcard-av.ta-1{background:rgba(62,205,198,0.15)}
.tcard-av.ta-1 i{color:var(--teal);font-size:18px}
.tcard-av.ta-2{background:rgba(245,183,49,0.15)}
.tcard-av.ta-2 i{color:var(--amber);font-size:18px}
.tcard-author h4{font-size:14px;font-weight:800;color:var(--teal)}
.tcard-author span{font-size:11px;color:rgba(255,255,255,0.3);font-weight:500}

/* ============= FINAL CTA ============= */
.final-cta{padding:100px 0;background:var(--cream);text-align:center}
.final-box{
  max-width:720px;margin:0 auto;background:var(--white);
  border-radius:22px;padding:60px 50px;box-shadow:var(--shadow-lg);
  position:relative;overflow:hidden;
}
.final-box::before{
  content:'';position:absolute;top:0;left:0;right:0;height:5px;
  background:linear-gradient(90deg,var(--navy),var(--teal),var(--amber),var(--beige));
}
.final-box h2{font-size:34px;font-weight:900;color:var(--navy);margin-bottom:8px;letter-spacing:-0.5px}
.final-box>p{font-size:13px;color:var(--text-body);margin-bottom:28px;max-width:420px;margin-left:auto;margin-right:auto;font-weight:400}
.final-form{display:grid;grid-template-columns:1fr 1fr;gap:12px;max-width:500px;margin:0 auto}
.final-form input{
  padding:14px 18px;border:2px solid var(--beige);border-radius:var(--radius-sm);
  font-size:13px;font-family:'Montserrat',sans-serif;color:var(--text-dark);
  background:var(--cream);outline:none;transition:var(--transition);font-weight:500;
}
.final-form input:focus{border-color:var(--teal);box-shadow:0 0 0 4px rgba(62,205,198,0.1)}
.final-form input::placeholder{color:var(--text-light)}
.final-form .full{grid-column:1/-1}
.btn-full{
  grid-column:1/-1;padding:15px;
  background:var(--teal);color:var(--navy-deep);
  font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:1px;
  border:none;border-radius:var(--radius-sm);cursor:pointer;
  transition:var(--transition);font-family:'Montserrat',sans-serif;
}
.btn-full:hover{background:var(--teal-light);transform:translateY(-2px);box-shadow:var(--shadow-teal)}
.final-trust{display:flex;justify-content:center;gap:20px;margin-top:16px}
.final-trust span{
  font-size:10.5px;font-weight:600;color:var(--text-muted);
  display:flex;align-items:center;gap:5px;
}
.final-trust span i{color:var(--teal);font-size:10px}

/* ============= FOOTER ============= */
.footer{background:var(--navy-deep);color:rgba(255,255,255,0.5);padding:60px 0 0}
.footer-grid{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;
  gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,0.06);
}
.footer-brand-logo{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.footer-brand-logo img{height:46px;width:auto}
.footer-brand p{font-size:12.5px;line-height:1.85;margin-bottom:20px;font-weight:400}
.footer-social{display:flex;gap:10px}
.footer-social a{
  width:38px;height:38px;border-radius:50%;
  border:1px solid rgba(255,255,255,0.1);
  display:grid;place-items:center;color:rgba(255,255,255,0.5);
  font-size:14px;transition:var(--transition);
}
.footer-social a:hover{border-color:var(--teal);color:var(--teal);background:rgba(62,205,198,0.08)}
.footer-col h4{
  color:var(--white);font-size:14px;font-weight:800;
  margin-bottom:20px;position:relative;padding-bottom:12px;
  text-transform:uppercase;letter-spacing:1px;
}
.footer-col h4::after{content:'';position:absolute;bottom:0;left:0;width:24px;height:3px;background:var(--teal);border-radius:2px}
.footer-col a{
  display:block;font-size:12.5px;padding:5px 0;
  color:rgba(255,255,255,0.4);transition:var(--transition);font-weight:500;
}
.footer-col a:hover{color:var(--teal);padding-left:6px}
.footer-col a i{margin-right:8px;color:var(--teal);font-size:12px}
.footer-bottom{
  padding:22px 0;display:flex;justify-content:space-between;
  font-size:11px;color:rgba(255,255,255,0.25);font-weight:500;
}
.footer-bottom a{color:rgba(255,255,255,0.25);transition:var(--transition)}
.footer-bottom a:hover{color:var(--teal)}

/* ============= FLOATING CTA ============= */
.float-cta{
  position:fixed;bottom:24px;right:24px;z-index:999;
  display:flex;flex-direction:column;align-items:flex-end;gap:10px;
}
.float-btn{
  width:58px;height:58px;border-radius:50%;
  background:var(--teal);color:var(--navy-deep);
  font-size:22px;display:grid;place-items:center;
  cursor:pointer;border:none;
  box-shadow:0 6px 24px rgba(62,205,198,0.4);
  transition:var(--transition);animation:float-pulse 2s ease infinite;
}
.float-btn:hover{transform:scale(1.1);background:var(--teal-light)}
@keyframes float-pulse{
  0%,100%{box-shadow:0 6px 24px rgba(62,205,198,0.4)}
  50%{box-shadow:0 6px 36px rgba(62,205,198,0.6)}
}
.float-label{
  background:var(--navy);color:var(--white);padding:8px 16px;
  border-radius:8px;font-size:11px;font-weight:700;
  box-shadow:0 4px 20px rgba(0,0,0,0.2);white-space:nowrap;
  opacity:0;transform:translateX(10px);transition:var(--transition);pointer-events:none;
}
.float-cta:hover .float-label{opacity:1;transform:translateX(0)}

/* ============= SCROLL REVEAL ============= */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.7s ease,transform 0.7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.rd1{transition-delay:.1s}.rd2{transition-delay:.2s}.rd3{transition-delay:.3s}

/* ============= RESPONSIVE ============= */
@media(max-width:1024px){
  .hero .container{grid-template-columns:1fr;text-align:center;gap:40px}
  .hero-sub{margin:0 auto 30px}
  .hero-stats{justify-content:center}
  .hero-form-wrap{max-width:440px;margin:0 auto}
  .about .container,.process .container{grid-template-columns:1fr;gap:50px}
  .services-grid,.port-grid,.test-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .mid-cta .container{flex-direction:column;text-align:center}
  .mid-cta p{margin:0 auto}
  .nav-links{display:none}.mobile-toggle{display:block}
}
@media(max-width:640px){
  .hero h1{font-size:36px}
  .stitle{font-size:30px}
  .proof-grid{grid-template-columns:1fr 1fr}
  .services-grid,.port-grid,.test-grid{grid-template-columns:1fr}
  .form-row,.final-form{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .promo-banner p{font-size:11px}
  .hero-stats{flex-direction:column;gap:14px;align-items:center}
  .mid-cta-form{flex-direction:column;width:100%}
  .mid-cta-form input{border-radius:var(--radius-sm);width:100%}
  .mid-cta-form button{border-radius:var(--radius-sm)}
  .about-badge{position:relative;bottom:auto;left:auto;margin-top:20px;display:inline-block}
  .process-cards{flex-direction:column}
}

/* ============= CLIENTS LOGO SLIDER ============= */
.clients{padding:80px 0;background:var(--white);overflow:hidden;position:relative}
.clients::before,.clients::after{
  content:'';position:absolute;top:0;bottom:0;width:120px;z-index:3;pointer-events:none;
}
.clients::before{left:0;background:linear-gradient(90deg,var(--white),transparent)}
.clients::after{right:0;background:linear-gradient(-90deg,var(--white),transparent)}
.clients-head{text-align:center;margin-bottom:44px}
.clients-track-wrapper{overflow:hidden;position:relative}
.clients-track{
  display:flex;gap:60px;align-items:center;
  animation:scrollLogos 25s linear infinite;
  width:max-content;
}
.clients-track:hover{animation-play-state:paused}
@keyframes scrollLogos{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.client-logo{
  flex-shrink:0;height:48px;min-width:140px;
  display:flex;align-items:center;justify-content:center;
  padding:14px 28px;
  background:var(--cream);
  border:2px solid var(--surface);
  border-radius:12px;
  transition:var(--transition);
  cursor:default;
  user-select:none;
}
.client-logo:hover{
  border-color:var(--teal);
  box-shadow:var(--shadow-sm);
  transform:translateY(-3px);
}
.client-logo-inner{
  display:flex;align-items:center;gap:10px;
  font-weight:800;font-size:15px;color:var(--navy);
  letter-spacing:0.5px;white-space:nowrap;
}
.client-logo-inner .cl-icon{
  width:34px;height:34px;border-radius:8px;
  display:grid;place-items:center;font-size:15px;
}
.cl-1{background:rgba(62,205,198,0.12);color:var(--teal)}
.cl-2{background:rgba(245,183,49,0.12);color:var(--amber)}
.cl-3{background:rgba(45,43,85,0.1);color:var(--navy)}
.cl-4{background:rgba(213,208,192,0.3);color:var(--amber-dark)}
.cl-5{background:rgba(62,205,198,0.12);color:var(--teal-dark)}
.cl-6{background:rgba(245,183,49,0.12);color:var(--amber-dark)}
.cl-7{background:rgba(45,43,85,0.1);color:var(--navy)}
.cl-8{background:rgba(62,205,198,0.15);color:var(--teal)}

/* Trusted count badge */
.clients-badge{
  text-align:center;margin-top:36px;
  display:flex;justify-content:center;gap:40px;flex-wrap:wrap;
}
.clients-badge-item{
  display:flex;align-items:center;gap:10px;
}
.clients-badge-item .cb-num{
  font-size:28px;font-weight:900;color:var(--navy);letter-spacing:-1px;
}
.clients-badge-item .cb-label{
  font-size:11px;font-weight:700;color:var(--text-muted);
  text-transform:uppercase;letter-spacing:1px;line-height:1.3;
}

/* ============= FAQ SECTION ============= */
.faq{padding:100px 0;background:var(--cream)}
.faq .container{max-width:900px}
.faq-head{text-align:center;margin-bottom:50px}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.faq-item{
  background:var(--white);
  border-radius:14px;
  border:2px solid transparent;
  overflow:hidden;
  transition:var(--transition);
}
.faq-item:hover{border-color:rgba(62,205,198,0.15)}
.faq-item.active{border-color:var(--teal);box-shadow:var(--shadow-sm)}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;
  padding:20px 24px;cursor:pointer;transition:var(--transition);gap:14px;
}
.faq-q:hover{background:rgba(62,205,198,0.02)}
.faq-q span{font-size:13.5px;font-weight:700;color:var(--navy);line-height:1.4;flex:1}
.faq-q-icon{
  width:34px;height:34px;min-width:34px;border-radius:50%;
  background:var(--surface);display:grid;place-items:center;
  font-size:13px;color:var(--text-muted);transition:var(--transition);
}
.faq-item.active .faq-q-icon{
  background:var(--teal);color:var(--navy-deep);transform:rotate(45deg);
}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height 0.4s ease,padding 0.4s ease;
}
.faq-a-inner{
  padding:0 24px 20px;
  font-size:13px;color:var(--text-body);line-height:1.85;font-weight:400;
}
.faq-item.active .faq-a{max-height:300px}

.faq-bottom{
  text-align:center;margin-top:40px;
  padding:30px;background:var(--white);border-radius:14px;
  border:2px dashed var(--beige);
}
.faq-bottom p{font-size:13px;color:var(--text-body);margin-bottom:14px;font-weight:500}
.faq-bottom a{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:800;color:var(--teal);
  text-transform:uppercase;letter-spacing:0.5px;transition:var(--transition);
}
.faq-bottom a:hover{color:var(--teal-dark);gap:12px}

/* ============= BLOG SECTION ============= */
.blogs{padding:100px 0;background:var(--white)}
.blogs-head{text-align:center;margin-bottom:50px}
.blogs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.blog-card{
  border-radius:18px;overflow:hidden;
  background:var(--cream);
  border:2px solid transparent;
  transition:var(--transition);
}
.blog-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-lg);
  border-color:var(--teal);
}
.blog-thumb{
  height:210px;position:relative;overflow:hidden;
}
.blog-thumb::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:50px;
  background:linear-gradient(transparent,var(--cream));
}
/* Blog image patterns */
.bt-1{
  background:linear-gradient(135deg,var(--navy),var(--navy-dark));
  position:relative;
}
.bt-1::before{
  content:'';position:absolute;inset:0;
  background:
    repeating-linear-gradient(0deg,transparent,transparent 19px,rgba(62,205,198,0.08) 19px,rgba(62,205,198,0.08) 20px),
    repeating-linear-gradient(90deg,transparent,transparent 19px,rgba(62,205,198,0.08) 19px,rgba(62,205,198,0.08) 20px);
}
.bt-2{
  background:linear-gradient(135deg,#8B6914,#D2B48C,#654321);
  position:relative;
}
.bt-2::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(90deg,rgba(255,255,255,0.04) 0px,rgba(255,255,255,0.04) 1px,transparent 1px,transparent 40px);
}
.bt-3{
  background:linear-gradient(135deg,var(--teal-dark),var(--teal),var(--teal-light));
  position:relative;
}
.bt-3::before{
  content:'';position:absolute;inset:0;
  background:repeating-conic-gradient(rgba(255,255,255,0.06) 0% 25%,transparent 0% 50%) 0 0/40px 40px;
}
/* Date tag */
.blog-date-tag{
  position:absolute;top:16px;left:16px;z-index:2;
  background:var(--white);
  border-radius:10px;padding:8px 12px;
  text-align:center;
  box-shadow:0 4px 12px rgba(0,0,0,0.1);
}
.blog-date-tag .bdt-day{
  font-size:20px;font-weight:900;color:var(--navy);
  display:block;line-height:1;
}
.blog-date-tag .bdt-month{
  font-size:9px;font-weight:800;color:var(--teal);
  text-transform:uppercase;letter-spacing:1.5px;
}
/* Category chip */
.blog-cat{
  position:absolute;top:16px;right:16px;z-index:2;
  padding:5px 14px;border-radius:20px;
  font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:1px;
}
.bc-teal{background:var(--teal);color:var(--navy-deep)}
.bc-amber{background:var(--amber);color:var(--navy-deep)}
.bc-navy{background:var(--navy);color:var(--white)}

.blog-body{padding:24px 26px 28px}
.blog-body h3{
  font-size:17px;font-weight:800;color:var(--navy);
  margin-bottom:8px;line-height:1.35;
  transition:var(--transition);
}
.blog-card:hover .blog-body h3{color:var(--teal)}
.blog-body p{
  font-size:12.5px;color:var(--text-body);line-height:1.75;
  margin-bottom:16px;font-weight:400;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.blog-meta{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:14px;border-top:1px solid var(--beige);
}
.blog-author{display:flex;align-items:center;gap:8px}
.blog-author-av{
  width:30px;height:30px;border-radius:50%;
  background:rgba(62,205,198,0.1);
  display:grid;place-items:center;
}
.blog-author-av i{font-size:12px;color:var(--teal)}
.blog-author span{font-size:11px;font-weight:700;color:var(--navy)}
.blog-read{
  font-size:11px;font-weight:700;color:var(--text-muted);
  display:flex;align-items:center;gap:4px;
}
.blog-read i{font-size:10px}

.blog-link{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:800;color:var(--teal);
  text-transform:uppercase;letter-spacing:0.5px;transition:var(--transition);
}
.blog-link:hover{gap:14px;color:var(--teal-dark)}
.blog-link i{font-size:10px}

.blogs-all{text-align:center;margin-top:44px}

/* ============= RESPONSIVE ADDITIONS ============= */
@media(max-width:1024px){
  .faq-grid{grid-template-columns:1fr}
  .blogs-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .blogs-grid{grid-template-columns:1fr}
  .clients-badge{flex-direction:column;align-items:center;gap:16px}
}

/* ═══ HERO BACKGROUND IMAGE SUPPORT ═══ */
.hero--has-bg{background-size:cover;background-position:center;background-repeat:no-repeat}
.hero__overlay{position:absolute;inset:0;z-index:1}
.hero .container{position:relative;z-index:2}
.page-hero--has-bg{background-size:cover;background-position:center;background-repeat:no-repeat}
.page-hero__overlay{position:absolute;inset:0;z-index:1}
.page-hero .container{position:relative;z-index:2}

/* ═══ WORDPRESS OVERRIDES ═══ */
body.admin-bar .navbar{top:32px}
@media(max-width:782px){body.admin-bar .navbar{top:46px}}

/* WPForms in lead form */
.lead-form .wpforms-container{margin:0}
.lead-form .wpforms-form .wpforms-field{margin-bottom:13px;padding:0}
.lead-form .wpforms-form .wpforms-field-label{font-size:11px!important;font-weight:700!important;color:var(--navy)!important;text-transform:uppercase!important;letter-spacing:.8px!important;margin-bottom:5px!important}
.lead-form .wpforms-form input[type="text"],.lead-form .wpforms-form input[type="email"],.lead-form .wpforms-form input[type="tel"],.lead-form .wpforms-form select,.lead-form .wpforms-form textarea{width:100%!important;padding:12px 15px!important;border:2px solid var(--beige)!important;border-radius:var(--radius-sm)!important;font-size:13.5px!important;font-family:'Montserrat',sans-serif!important;color:var(--text-dark)!important;background:var(--cream)!important;transition:var(--transition)!important}
.lead-form .wpforms-form input:focus,.lead-form .wpforms-form select:focus{border-color:var(--teal)!important;box-shadow:0 0 0 4px rgba(62,205,198,.1)!important}
.lead-form .wpforms-form .wpforms-submit-container{padding:0!important;margin-top:4px!important}
.lead-form .wpforms-form button[type="submit"]{width:100%!important;padding:14px!important;background:var(--teal)!important;color:var(--navy-deep)!important;font-size:13px!important;font-weight:800!important;text-transform:uppercase!important;letter-spacing:1px!important;border:none!important;border-radius:var(--radius-sm)!important;font-family:'Montserrat',sans-serif!important}
.lead-form .wpforms-form button[type="submit"]:hover{background:var(--teal-light)!important;transform:translateY(-2px)!important;box-shadow:var(--shadow-teal)!important}

/* Nav WP classes */
.nav-links .current-menu-item>a,.nav-links .current_page_item>a{color:var(--white);background:rgba(62,205,198,.1)}
.nav-links li{position:relative;display:inline-block}
.nav-links li a{color:rgba(255,255,255,.7);font-size:12.5px;font-weight:600;padding:8px 15px;border-radius:6px;transition:var(--transition);text-transform:uppercase;letter-spacing:.8px;display:flex;align-items:center;gap:5px}
.nav-links li a:hover{color:var(--white);background:rgba(62,205,198,.1)}
.nav-links .sub-menu{position:absolute;top:100%;left:0;min-width:220px;background:var(--navy-deep);border:1px solid rgba(62,205,198,.1);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(8px);transition:var(--transition);z-index:100;padding:8px 0}
.nav-links li:hover>.sub-menu,.nav-links li:focus-within>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-links .sub-menu li{display:block}
.nav-links .sub-menu li a{padding:10px 20px;font-size:12px;text-transform:none;letter-spacing:0;border-radius:0}
.nav-links .sub-menu li a:hover{background:rgba(62,205,198,.08);color:var(--teal)}

/* Page Hero */
.page-hero{background:var(--navy-deep);position:relative;overflow:hidden;padding:80px 0 70px;text-align:center}
.page-hero::before{content:'';position:absolute;inset:0;z-index:0;opacity:.04;background:repeating-linear-gradient(0deg,transparent,transparent 79px,rgba(255,255,255,.5) 79px,rgba(255,255,255,.5) 80px),repeating-linear-gradient(90deg,transparent,transparent 79px,rgba(255,255,255,.5) 79px,rgba(255,255,255,.5) 80px)}
.page-hero .container{position:relative;z-index:2}
.page-hero .stag{justify-content:center}
.page-hero h1{font-size:48px;font-weight:900;color:var(--white);margin-bottom:14px;letter-spacing:-1px}
.page-hero h1 .highlight{color:var(--teal);position:relative}
.page-hero h1 .highlight::after{content:'';position:absolute;bottom:2px;left:0;right:0;height:4px;background:var(--teal);border-radius:2px;opacity:.4}
.page-hero p{font-size:15px;color:rgba(255,255,255,.45);max-width:560px;margin:0 auto;line-height:1.85}
.page-hero .hero-orb{position:absolute;border-radius:50%;filter:blur(120px);z-index:0}
.page-hero .orb-1{width:400px;height:400px;background:var(--teal);top:-150px;right:-100px;opacity:.08}
.page-hero .orb-2{width:300px;height:300px;background:var(--amber);bottom:-120px;left:-80px;opacity:.06}
.breadcrumb{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:18px;font-size:12px;font-weight:600}
.breadcrumb a{color:var(--teal);transition:var(--transition)}.breadcrumb a:hover{color:var(--teal-light)}
.breadcrumb span{color:rgba(255,255,255,.3)}.breadcrumb .current{color:rgba(255,255,255,.5)}

/* About page */
.about-story{padding:100px 0;background:var(--cream)}
.about-story .container{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-story-img{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:4/3.5;background:linear-gradient(135deg,var(--beige),var(--beige-light));box-shadow:var(--shadow-lg)}
.about-story-img::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,#f0ece2 0%,#f0ece2 55%,var(--beige) 55%)}
.about-story-img::after{content:'';position:absolute;bottom:0;left:0;right:0;height:45%;background:repeating-linear-gradient(90deg,#c4a265 0px,#c4a265 78px,#b89450 78px,#b89450 80px)}
.about-story-img img{width:100%;height:100%;object-fit:cover;position:relative;z-index:1}
.story-accent-1{position:absolute;top:-16px;left:-16px;width:80px;height:80px;background:var(--teal);border-radius:12px;z-index:3;opacity:.9}
.story-accent-2{position:absolute;bottom:-16px;right:-16px;width:60px;height:60px;background:var(--amber);border-radius:10px;z-index:3;opacity:.9}
.story-badge{position:absolute;bottom:30px;left:-30px;background:var(--navy);color:var(--white);padding:20px 24px;border-radius:14px;box-shadow:0 10px 30px rgba(45,43,85,.3);z-index:4;text-align:center}
.story-badge strong{font-size:36px;font-weight:900;display:block;line-height:1;color:var(--teal)}
.story-badge span{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.6)}
.values-section{padding:100px 0;background:var(--white)}
.values-head{text-align:center;margin-bottom:60px}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.value-card{background:var(--cream);border-radius:18px;padding:36px 28px;border:2px solid transparent;transition:var(--transition);text-align:center}
.value-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--teal)}
.value-card-icon{width:64px;height:64px;border-radius:16px;margin:0 auto 18px;display:grid;place-items:center;font-size:24px}
.vci-teal{background:rgba(62,205,198,.1);color:var(--teal)}.vci-amber{background:rgba(245,183,49,.1);color:var(--amber)}.vci-navy{background:rgba(45,43,85,.08);color:var(--navy)}.vci-beige{background:rgba(213,208,192,.3);color:var(--amber-dark)}
.value-card h3{font-size:18px;font-weight:800;color:var(--navy);margin-bottom:8px}
.value-card p{font-size:13px;color:var(--text-body);line-height:1.7}
.team-section{padding:100px 0;background:var(--cream)}
.team-head{text-align:center;margin-bottom:60px}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.team-card{text-align:center;transition:var(--transition)}.team-card:hover{transform:translateY(-6px)}
.team-avatar{width:120px;height:120px;border-radius:50%;margin:0 auto 16px;display:grid;place-items:center;font-size:36px;overflow:hidden}
.team-avatar img{width:100%;height:100%;object-fit:cover}
.ta-navy{background:rgba(45,43,85,.1);color:var(--navy)}.ta-teal{background:rgba(62,205,198,.1);color:var(--teal)}.ta-amber{background:rgba(245,183,49,.1);color:var(--amber)}.ta-beige{background:rgba(213,208,192,.3);color:var(--amber-dark)}
.team-card h4{font-size:16px;font-weight:800;color:var(--navy);margin-bottom:2px}
.team-card span{font-size:12px;color:var(--teal);font-weight:700;text-transform:uppercase;letter-spacing:1px}
.team-card p{font-size:12px;color:var(--text-muted);margin-top:6px}
.page-cta-banner{background:var(--navy-deep);padding:80px 0;position:relative;overflow:hidden;text-align:center}
.page-cta-banner::before{content:'';position:absolute;width:400px;height:400px;background:var(--teal);border-radius:50%;filter:blur(150px);opacity:.06;top:-150px;right:-50px}
.page-cta-banner h2{font-size:36px;font-weight:900;color:var(--white);margin-bottom:10px}
.page-cta-banner p{font-size:14px;color:rgba(255,255,255,.4);max-width:480px;margin:0 auto 30px}

/* Contact page */
.contact-main{padding:100px 0;background:var(--cream)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:20px}
.contact-card{background:var(--white);border-radius:18px;padding:28px;display:flex;align-items:flex-start;gap:18px;border:2px solid transparent;transition:var(--transition)}
.contact-card:hover{border-color:var(--teal);box-shadow:var(--shadow-sm);transform:translateY(-4px)}
.contact-card-icon{width:52px;height:52px;min-width:52px;border-radius:14px;display:grid;place-items:center;font-size:20px}
.cci-teal{background:rgba(62,205,198,.1);color:var(--teal)}.cci-amber{background:rgba(245,183,49,.1);color:var(--amber)}.cci-navy{background:rgba(45,43,85,.08);color:var(--navy)}.cci-beige{background:rgba(213,208,192,.3);color:var(--amber-dark)}
.contact-card h4{font-size:15px;font-weight:800;color:var(--navy);margin-bottom:4px}
.contact-card p{font-size:13px;color:var(--text-body);line-height:1.65}
.contact-card a{color:var(--teal);font-weight:600;transition:var(--transition)}.contact-card a:hover{color:var(--teal-dark)}
.contact-form-card{background:var(--white);border-radius:18px;padding:40px 36px;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.contact-form-card::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--navy),var(--teal),var(--beige),var(--amber))}
.contact-form-card h3{font-size:22px;font-weight:800;color:var(--navy);margin-bottom:6px}
.contact-form-card>p{font-size:13px;color:var(--text-muted);margin-bottom:24px}
.contact-form .form-group{margin-bottom:14px}
.contact-form .form-group label{display:block;font-size:11px;font-weight:700;color:var(--navy);margin-bottom:5px;text-transform:uppercase;letter-spacing:.8px}
.contact-form .form-group input,.contact-form .form-group select,.contact-form .form-group textarea{width:100%;padding:12px 15px;border:2px solid var(--beige);border-radius:var(--radius-sm);font-size:13.5px;font-family:'Montserrat',sans-serif;color:var(--text-dark);background:var(--cream);transition:var(--transition);outline:none;font-weight:500}
.contact-form .form-group input:focus,.contact-form .form-group select:focus,.contact-form .form-group textarea:focus{border-color:var(--teal);box-shadow:0 0 0 4px rgba(62,205,198,.1)}
.contact-form .form-group textarea{min-height:120px;resize:vertical}
.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.contact-social{display:flex;gap:10px;margin-top:24px}
.contact-social a{width:42px;height:42px;border-radius:12px;border:2px solid var(--beige);display:grid;place-items:center;color:var(--text-muted);font-size:16px;transition:var(--transition)}
.contact-social a:hover{border-color:var(--teal);color:var(--teal);background:rgba(62,205,198,.06)}
.contact-map{margin-top:80px;border-radius:18px;overflow:hidden;height:400px;background:var(--surface);border:2px solid var(--beige);position:relative}
.contact-map iframe{width:100%;height:100%;border:0}
.contact-map-placeholder{width:100%;height:100%;display:grid;place-items:center;background:linear-gradient(135deg,rgba(45,43,85,.04),rgba(62,205,198,.04))}
.contact-map-placeholder i{font-size:48px;color:var(--beige);margin-bottom:12px;display:block}
.contact-map-placeholder span{font-size:13px;color:var(--text-muted);font-weight:600}
.hours-card{background:var(--navy);border-radius:18px;padding:28px;margin-top:20px}
.hours-card h4{font-size:14px;font-weight:800;color:var(--white);margin-bottom:14px;text-transform:uppercase;letter-spacing:1px}
.hours-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.hours-row:last-child{border-bottom:none}
.hours-row span:first-child{font-size:12.5px;color:rgba(255,255,255,.5)}.hours-row span:last-child{font-size:12.5px;color:var(--teal);font-weight:700}

/* WPForms in contact card */
.contact-form-card .wpforms-form input,.contact-form-card .wpforms-form select,.contact-form-card .wpforms-form textarea{width:100%!important;padding:12px 15px!important;border:2px solid var(--beige)!important;border-radius:var(--radius-sm)!important;font-size:13.5px!important;font-family:'Montserrat',sans-serif!important;color:var(--text-dark)!important;background:var(--cream)!important}
.contact-form-card .wpforms-form input:focus,.contact-form-card .wpforms-form select:focus,.contact-form-card .wpforms-form textarea:focus{border-color:var(--teal)!important;box-shadow:0 0 0 4px rgba(62,205,198,.1)!important}
.contact-form-card .wpforms-form button[type="submit"]{width:100%!important;padding:14px!important;background:var(--teal)!important;color:var(--navy-deep)!important;font-size:13px!important;font-weight:800!important;text-transform:uppercase!important;letter-spacing:1px!important;border:none!important;border-radius:var(--radius-sm)!important;font-family:'Montserrat',sans-serif!important}

.entry-content{color:var(--text-body);line-height:1.8}
.entry-content h2{font-size:28px;font-weight:900;color:var(--navy);margin:30px 0 14px}
.entry-content p{margin-bottom:16px}.entry-content a{color:var(--teal);font-weight:600}
.entry-content img{border-radius:var(--radius);margin:20px 0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
:focus-visible{outline:2px solid var(--teal);outline-offset:2px}

/* Responsive for pages */
@media(max-width:1024px){.about-story .container{grid-template-columns:1fr;gap:50px}.values-grid{grid-template-columns:1fr 1fr}.team-grid{grid-template-columns:repeat(2,1fr)}.contact-grid{grid-template-columns:1fr}}
@media(max-width:640px){.page-hero h1{font-size:32px}.values-grid,.team-grid{grid-template-columns:1fr}.contact-form .form-row{grid-template-columns:1fr}.story-badge{position:relative;bottom:auto;left:auto;margin-top:20px;display:inline-block}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}

/* ═══ GOOGLE REVIEWS SECTION ═══ */
.reviews-section{padding:100px 0;background:var(--white)}
.reviews-head{text-align:center;margin-bottom:50px}
.reviews-rating{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:28px}
.reviews-score{font-size:48px;font-weight:900;color:var(--navy);letter-spacing:-2px}
.reviews-stars{display:flex;gap:4px;font-size:20px;color:var(--amber)}
.reviews-count{font-size:13px;color:var(--text-muted);font-weight:600}
.reviews-shortcode{max-width:1000px;margin:0 auto}
.reviews-badge{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;background:var(--cream);border-radius:14px;border:2px solid var(--beige);margin-top:30px}
.reviews-badge img,.reviews-badge i{height:28px;width:28px;font-size:28px;color:var(--amber)}
.reviews-badge span{font-size:13px;font-weight:700;color:var(--navy)}

/* ═══ GOOGLE MAP SECTION (ALL PAGES) ═══ */
.map-section{padding:0;background:var(--cream)}
.map-section .container{max-width:100%;padding:0}
.map-wrap{height:420px;border-radius:0;overflow:hidden;position:relative}
.map-wrap iframe{width:100%;height:100%;border:0}
.map-info-bar{background:var(--navy-deep);padding:28px 0}
.map-info-inner{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.map-info-item{display:flex;align-items:center;gap:12px;color:rgba(255,255,255,.6);font-size:13px;font-weight:500}
.map-info-item i{color:var(--teal);font-size:16px}
.map-info-item a{color:var(--teal);font-weight:700;transition:var(--transition)}
.map-info-item a:hover{color:var(--teal-light)}

/* ═══ FLOORING PRODUCT PAGE ═══ */
.product-hero{background:var(--navy-deep);padding:80px 0;position:relative;overflow:hidden}
.product-hero .container{display:grid;grid-template-columns:1fr 400px;gap:50px;align-items:center}
.product-hero h1{font-size:44px;font-weight:900;color:var(--white);line-height:1.1;margin-bottom:14px}
.product-hero h1 .highlight{color:var(--teal)}
.product-hero .hero-sub{font-size:15px;color:rgba(255,255,255,.45);margin-bottom:24px;line-height:1.8}
.product-hero-badges{display:flex;gap:14px;flex-wrap:wrap}
.product-hero-badge{display:flex;align-items:center;gap:8px;padding:10px 18px;background:rgba(62,205,198,.08);border:1px solid rgba(62,205,198,.15);border-radius:10px;font-size:12px;font-weight:700;color:var(--teal)}
.product-hero-badge i{font-size:14px}

.product-grid-section{padding:80px 0;background:var(--cream)}
.product-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:40px;justify-content:center}
.product-filter{padding:8px 22px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);background:none;border:2px solid transparent;border-radius:30px;cursor:pointer;transition:var(--transition);font-family:'Montserrat',sans-serif}
.product-filter:hover{color:var(--navy);border-color:var(--beige)}
.product-filter.active{color:var(--navy-deep);border-color:var(--teal);background:rgba(62,205,198,.06)}

.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.product-card{background:var(--white);border-radius:18px;overflow:hidden;border:2px solid transparent;transition:var(--transition);position:relative}
.product-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--teal)}
.product-card-img{height:220px;background:var(--surface);position:relative;overflow:hidden}
.product-card-img img{width:100%;height:100%;object-fit:cover}
.product-card-badge{position:absolute;top:14px;left:14px;padding:5px 14px;border-radius:20px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:1px}
.pcb-sale{background:var(--amber);color:var(--navy-deep)}
.pcb-new{background:var(--teal);color:var(--navy-deep)}
.pcb-hot{background:#e74c3c;color:var(--white)}
.product-card-body{padding:24px}
.product-card-body h3{font-size:18px;font-weight:800;color:var(--navy);margin-bottom:6px}
.product-card-body .product-type{font-size:11px;color:var(--teal);font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;display:block}
.product-card-body p{font-size:13px;color:var(--text-body);line-height:1.65;margin-bottom:14px}
.product-price{display:flex;align-items:baseline;gap:8px;margin-bottom:16px}
.product-price .price-current{font-size:24px;font-weight:900;color:var(--teal)}
.product-price .price-was{font-size:14px;color:var(--text-muted);text-decoration:line-through}
.product-price .price-unit{font-size:11px;color:var(--text-muted);font-weight:600}
.product-card-cta{width:100%;padding:12px;background:var(--teal);color:var(--navy-deep);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);font-family:'Montserrat',sans-serif;display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none}
.product-card-cta:hover{background:var(--teal-light);transform:translateY(-2px);box-shadow:var(--shadow-teal)}

.product-urgency{text-align:center;padding:40px;background:linear-gradient(135deg,rgba(231,76,60,.05),rgba(245,183,49,.05));border:2px dashed var(--amber);border-radius:var(--radius);margin-top:50px}
.product-urgency h3{font-size:24px;font-weight:900;color:var(--navy);margin-bottom:6px}
.product-urgency p{font-size:13px;color:var(--text-body);margin-bottom:18px}

/* Responsive */
@media(max-width:1024px){.product-hero .container{grid-template-columns:1fr}.product-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.product-grid{grid-template-columns:1fr}.map-info-inner{flex-direction:column;text-align:center}.reviews-rating{flex-direction:column}}

/* ═══ MOBILE MENU — PROPER DRAWER ═══ */
.mobile-toggle{
  display:none;background:none;border:none;cursor:pointer;
  padding:8px;flex-direction:column;gap:5px;z-index:10;
  -webkit-tap-highlight-color:transparent;
}
.hamburger-line{
  display:block;width:24px;height:2.5px;
  background:var(--navy-deep);border-radius:2px;
  transition:all .3s ease;
}
.mobile-toggle.active .hamburger-line:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.mobile-toggle.active .hamburger-line:nth-child(2){opacity:0}
.mobile-toggle.active .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Overlay */
.mobile-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.5);
  z-index:9998;opacity:0;visibility:hidden;
  transition:all .3s ease;
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
}
.mobile-overlay.open{opacity:1;visibility:visible}

/* Drawer */
.mobile-drawer{
  position:fixed;top:0;right:-320px;width:300px;max-width:85vw;height:100vh;
  background:var(--white);z-index:9999;
  transition:right .35s cubic-bezier(.25,.46,.45,.94);
  display:flex;flex-direction:column;
  box-shadow:-10px 0 40px rgba(0,0,0,.15);
  overflow-y:auto;
}
.mobile-drawer.open{right:0}

.mobile-drawer-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;border-bottom:1px solid var(--surface);
}
.mobile-close{
  width:36px;height:36px;border-radius:8px;
  border:1px solid var(--surface);background:none;
  display:grid;place-items:center;cursor:pointer;
  font-size:16px;color:var(--text-muted);
  transition:all .3s ease;
}
.mobile-close:hover{background:var(--surface);color:var(--navy)}

.mobile-drawer-nav{flex:1;padding:16px 0;overflow-y:auto}
.mobile-menu-list{list-style:none;margin:0;padding:0}
.mobile-menu-list li{border-bottom:1px solid var(--surface)}
.mobile-menu-list li a{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;font-size:14px;font-weight:600;
  color:var(--navy);transition:all .3s ease;
  text-decoration:none;
}
.mobile-menu-list li a:hover,.mobile-menu-list li.current-menu-item>a{
  color:var(--teal);background:rgba(62,205,198,.04);padding-left:28px;
}
.mobile-menu-list .sub-menu{
  list-style:none;margin:0;padding:0;
  background:var(--cream);
}
.mobile-menu-list .sub-menu li a{
  padding:12px 24px 12px 40px;font-size:13px;font-weight:500;
  color:var(--text-body);
}
.mobile-menu-list .sub-menu li a:hover{color:var(--teal)}

.mobile-drawer-footer{
  padding:20px 24px;border-top:1px solid var(--surface);
  display:flex;flex-direction:column;gap:10px;
}
.mobile-phone-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:12px;border:2px solid var(--teal);border-radius:var(--radius-sm);
  color:var(--teal);font-size:13px;font-weight:700;
  transition:all .3s ease;
}
.mobile-phone-btn:hover{background:rgba(62,205,198,.06)}

/* Logo text for white header */
.logo-text{font-size:20px;font-weight:900;color:var(--navy)}

/* Fix desktop nav-links to hide on mobile */
@media(max-width:1024px){
  .nav-links{display:none!important}
  .mobile-toggle{display:flex}
  .nav-phone span{display:none}
  .nav-phone{width:40px;height:40px;border-radius:8px;border:1px solid var(--surface);display:grid;place-items:center;font-size:14px}
  .nav-phone i{margin:0}
  .btn-nav{padding:8px 16px;font-size:11px}
  .navbar .container{gap:10px}
}
@media(max-width:480px){
  .btn-nav{display:none}
}

/* Body scroll lock when menu open */
body.menu-open{overflow:hidden}

/* ═══ LIGHT HEADER SUPPORT ═══ */
/* When header bg is light, these ensure proper contrast */
.navbar{transition:background .3s ease,box-shadow .3s ease}
.navbar .container{display:flex;justify-content:space-between;align-items:center;gap:16px}
.nav-right{display:flex;align-items:center;gap:12px}
/* Hamburger adapts to nav color from customizer dynamic CSS */
.hamburger-line{background:var(--navy-deep)}
.nav-phone{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:700;transition:all .3s ease}
/* Nav links on desktop */
.nav-links{display:flex;gap:4px;align-items:center}
/* Ensure dropdown works above mobile drawer */
.nav-links .sub-menu{z-index:10000}

/* Scrolled state — add subtle shadow */
.navbar.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.08)}
