/* ============================================================
   BITS Perth — Main Stylesheet
   bitsperth.com.au | Professional IT Services in Perth
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800&family=Inter:wght@300;400;500;600&display=swap');

/* ─── CSS Variables ──────────────────────────────────────── */
:root {
  --clr-navy:        #0a1628;
  --clr-blue:        #1565c0;
  --clr-blue-mid:    #1976d2;
  --clr-blue-light:  #42a5f5;
  --clr-cyan:        #00acc1;
  --clr-white:       #ffffff;
  --clr-light:       #f4f7fb;
  --clr-gray:        #6b7280;
  --clr-dark:        #111827;
  --clr-border:      #e5e7eb;

  --gradient-hero:   linear-gradient(135deg, #0a1628 0%, #1565c0 100%);
  --gradient-card:   linear-gradient(135deg, #1565c0 0%, #00acc1 100%);

  --shadow-sm:  0 2px 8px rgba(0,0,0,.06);
  --shadow-md:  0 4px 20px rgba(0,0,0,.10);
  --shadow-lg:  0 8px 40px rgba(0,0,0,.15);
  --shadow-xl:  0 20px 60px rgba(0,0,0,.20);

  --radius-sm:  8px;
  --radius:     12px;
  --radius-lg:  20px;
  --radius-xl:  100px;

  --transition: .3s cubic-bezier(.4,0,.2,1);

  --font-heading: 'Poppins', sans-serif;
  --font-body:    'Inter', sans-serif;

  --header-h:  80px;
  --container: 1200px;
}

/* ─── Reset ─────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--clr-dark);background:var(--clr-white);line-height:1.6;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}

/* ─── Layout ─────────────────────────────────────────────── */
.container{width:min(var(--container),100% - 2rem);margin-inline:auto}
.section{padding:5rem 0}
.section-sm{padding:3rem 0}
.section-lg{padding:7rem 0}

/* ─── Typography ─────────────────────────────────────────── */
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.2}
h1{font-size:clamp(2.1rem,5vw,3.4rem)}
h2{font-size:clamp(1.7rem,3.5vw,2.4rem)}
h3{font-size:clamp(1.2rem,2.5vw,1.5rem)}
h4{font-size:1.1rem}
p{line-height:1.75;color:var(--clr-gray)}

.section-label{
  display:inline-block;
  background:rgba(21,101,192,.1);
  color:var(--clr-blue);
  font-family:var(--font-heading);
  font-weight:600;font-size:.78rem;
  letter-spacing:.1em;text-transform:uppercase;
  padding:.35rem 1rem;border-radius:var(--radius-xl);
  margin-bottom:1rem
}
.section-header{text-align:center;margin-bottom:3.5rem}
.section-header p{max-width:600px;margin:.75rem auto 0;font-size:1.05rem}

/* ─── Buttons ────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.8rem 2rem;border-radius:var(--radius-xl);
  font-family:var(--font-heading);font-weight:600;font-size:.95rem;
  cursor:pointer;border:none;transition:var(--transition);white-space:nowrap
}
.btn-primary{background:var(--clr-blue);color:var(--clr-white)}
.btn-primary:hover{background:var(--clr-navy);transform:translateY(-2px);box-shadow:0 8px 25px rgba(21,101,192,.4)}
.btn-outline{background:transparent;color:var(--clr-white);border:2px solid rgba(255,255,255,.6)}
.btn-outline:hover{background:var(--clr-white);color:var(--clr-blue);border-color:var(--clr-white)}
.btn-outline-blue{background:transparent;color:var(--clr-blue);border:2px solid var(--clr-blue)}
.btn-outline-blue:hover{background:var(--clr-blue);color:var(--clr-white)}
.btn-lg{padding:1rem 2.5rem;font-size:1rem}
.btn-sm{padding:.5rem 1.25rem;font-size:.85rem}

/* ─── Header / Nav ───────────────────────────────────────── */
.header{position:fixed;top:0;left:0;right:0;height:var(--header-h);z-index:1000;transition:var(--transition)}
.header.scrolled{background:var(--clr-navy);box-shadow:0 2px 20px rgba(0,0,0,.3)}
.header-transparent{background:transparent}
.nav{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);gap:1rem}
.nav-logo{display:flex;align-items:center;gap:.6rem}
.nav-logo img{height:46px;width:auto}
.logo-text{font-family:var(--font-heading);font-size:1.45rem;font-weight:800;color:var(--clr-white);letter-spacing:-.5px}
.logo-text span{color:var(--clr-cyan)}
.nav-menu{display:flex;align-items:center;gap:.2rem}
.nav-menu>li{position:relative}
.nav-menu>li>a{
  display:block;padding:.5rem .85rem;
  color:rgba(255,255,255,.85);
  font-family:var(--font-heading);font-weight:500;font-size:.88rem;
  border-radius:var(--radius-sm);transition:var(--transition)
}
.nav-menu>li>a:hover,.nav-menu>li>a.active{color:var(--clr-white);background:rgba(255,255,255,.1)}
.dropdown-menu{
  position:absolute;top:calc(100% + .5rem);left:0;
  background:var(--clr-white);border-radius:var(--radius);
  padding:.5rem;min-width:250px;
  box-shadow:var(--shadow-xl);
  opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:var(--transition);z-index:100
}
.dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-menu li a{
  display:flex;align-items:center;gap:.75rem;
  padding:.7rem 1rem;color:var(--clr-dark);
  font-family:var(--font-heading);font-size:.88rem;font-weight:500;
  border-radius:var(--radius-sm);transition:var(--transition)
}
.dropdown-menu li a:hover{background:var(--clr-light);color:var(--clr-blue)}
.dropdown-menu li a i{color:var(--clr-blue);width:16px}
.nav-cta{margin-left:.5rem}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem}
.hamburger span{display:block;width:24px;height:2px;background:var(--clr-white);border-radius:2px;transition:var(--transition)}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ─── Hero (full) ────────────────────────────────────────── */
.hero{
  min-height:100vh;background:var(--gradient-hero);
  display:flex;align-items:center;
  position:relative;overflow:hidden;
  padding-top:var(--header-h)
}
.hero::before,.hero-inner::before,.cta-banner::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")
}
.hero-blob{
  position:absolute;width:650px;height:650px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,172,193,.15) 0%,transparent 70%);
  right:-120px;top:-120px;animation:blob-float 7s ease-in-out infinite
}
@keyframes blob-float{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-30px,30px) scale(1.06)}}
.hero-content{position:relative;z-index:1;color:var(--clr-white);max-width:700px}
.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  color:var(--clr-white);padding:.4rem 1rem;border-radius:var(--radius-xl);
  font-size:.83rem;font-weight:500;margin-bottom:1.5rem;backdrop-filter:blur(10px)
}
.hero-badge i{color:var(--clr-cyan)}
.hero-content h1{color:var(--clr-white);margin-bottom:1.25rem}
.hero-content h1 span{color:var(--clr-cyan)}
.hero-content p{color:rgba(255,255,255,.8);font-size:1.1rem;margin-bottom:2rem;max-width:560px}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero-stats{
  display:flex;gap:2.5rem;margin-top:3rem;
  padding-top:2rem;border-top:1px solid rgba(255,255,255,.15);flex-wrap:wrap
}
.hero-stat .number{font-family:var(--font-heading);font-size:2rem;font-weight:800;color:var(--clr-white);line-height:1}
.hero-stat .number span{color:var(--clr-cyan)}
.hero-stat .label{color:rgba(255,255,255,.65);font-size:.82rem;margin-top:.25rem}

/* ─── Hero (inner pages) ─────────────────────────────────── */
.hero-inner{
  min-height:40vh;background:var(--gradient-hero);
  display:flex;align-items:center;
  padding:calc(var(--header-h) + 3rem) 0 4rem;
  position:relative;overflow:hidden;text-align:center
}
.hero-inner .hero-content{max-width:700px;margin:0 auto;text-align:center}
.hero-inner h1{color:var(--clr-white)}
.hero-inner p{color:rgba(255,255,255,.8);margin:.85rem auto;max-width:560px}
.breadcrumb{
  display:flex;align-items:center;gap:.5rem;
  justify-content:center;margin-top:1rem;
  font-size:.88rem;color:rgba(255,255,255,.6)
}
.breadcrumb a{color:rgba(255,255,255,.8)}
.breadcrumb a:hover{color:var(--clr-white)}
.breadcrumb .sep{color:rgba(255,255,255,.4)}

/* ─── Trust Bar ──────────────────────────────────────────── */
.trust-bar{background:var(--clr-light);padding:1.25rem 0;border-bottom:1px solid var(--clr-border)}
.trust-items{display:flex;align-items:center;justify-content:center;gap:2.5rem;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:.5rem;font-family:var(--font-heading);font-weight:600;font-size:.85rem;color:var(--clr-dark)}
.trust-item i{color:var(--clr-blue);font-size:1rem}

/* ─── Service Cards ──────────────────────────────────────── */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}
.service-card{
  background:var(--clr-white);border:1px solid var(--clr-border);
  border-radius:var(--radius-lg);padding:2rem;
  transition:var(--transition);position:relative;overflow:hidden
}
.service-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:var(--gradient-card);transform:scaleX(0);transition:var(--transition)
}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-xl);border-color:transparent}
.service-card:hover::before{transform:scaleX(1)}
.service-icon{
  width:64px;height:64px;
  background:linear-gradient(135deg,rgba(21,101,192,.1),rgba(0,172,193,.1));
  border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.25rem;font-size:1.6rem;color:var(--clr-blue);transition:var(--transition)
}
.service-card:hover .service-icon{background:var(--gradient-card);color:var(--clr-white)}
.service-card h3{margin-bottom:.75rem;color:var(--clr-dark)}
.service-card p{font-size:.93rem;margin-bottom:1.25rem}
.service-link{
  display:inline-flex;align-items:center;gap:.4rem;
  color:var(--clr-blue);font-family:var(--font-heading);font-weight:600;font-size:.88rem;transition:var(--transition)
}
.service-link:hover{gap:.7rem}

/* ─── Features / Why Us ──────────────────────────────────── */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.5rem}
.feature-item{text-align:center;padding:2rem 1.5rem}
.feature-icon{
  width:70px;height:70px;background:var(--gradient-card);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:1.75rem;color:var(--clr-white);margin:0 auto 1.25rem
}
.feature-item h4{margin-bottom:.5rem;color:var(--clr-dark)}

/* ─── Stats ──────────────────────────────────────────────── */
.stats-section{background:var(--gradient-hero);padding:5rem 0}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:2rem;text-align:center}
.stat-item .stat-number{font-family:var(--font-heading);font-size:3rem;font-weight:800;color:var(--clr-white);line-height:1}
.stat-item .stat-number span{color:var(--clr-cyan)}
.stat-item .stat-label{color:rgba(255,255,255,.7);font-size:.93rem;margin-top:.5rem}

/* ─── Testimonials ───────────────────────────────────────── */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}
.testimonial-card{
  background:var(--clr-white);border:1px solid var(--clr-border);
  border-radius:var(--radius-lg);padding:2rem;position:relative
}
.testimonial-card::before{
  content:'"';position:absolute;top:.75rem;right:1.5rem;
  font-size:5rem;font-family:Georgia,serif;
  color:var(--clr-blue);opacity:.1;line-height:1
}
.stars{color:#f59e0b;font-size:.95rem;margin-bottom:1rem;letter-spacing:2px}
.testimonial-text{font-style:italic;margin-bottom:1.5rem;font-size:.93rem;color:var(--clr-gray)}
.testimonial-author{display:flex;align-items:center;gap:.75rem}
.author-avatar{
  width:44px;height:44px;border-radius:50%;background:var(--gradient-card);
  display:flex;align-items:center;justify-content:center;
  color:var(--clr-white);font-family:var(--font-heading);font-weight:700;font-size:1rem
}
.author-info .name{font-family:var(--font-heading);font-weight:600;color:var(--clr-dark);font-size:.88rem}
.author-info .role{font-size:.78rem;color:var(--clr-gray)}

/* ─── FAQ ────────────────────────────────────────────────── */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border:1px solid var(--clr-border);border-radius:var(--radius);margin-bottom:.75rem;overflow:hidden;transition:var(--transition)}
.faq-item.active{border-color:var(--clr-blue);box-shadow:0 0 0 3px rgba(21,101,192,.1)}
.faq-question{
  width:100%;background:none;border:none;
  padding:1.2rem 1.5rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  text-align:left;cursor:pointer;
  font-family:var(--font-heading);font-weight:600;font-size:.95rem;
  color:var(--clr-dark);transition:var(--transition)
}
.faq-question:hover{color:var(--clr-blue)}
.faq-icon{
  width:28px;height:28px;border-radius:50%;background:var(--clr-light);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:var(--transition);color:var(--clr-blue)
}
.faq-item.active .faq-icon{background:var(--clr-blue);color:var(--clr-white);transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-answer-inner{padding:0 1.5rem 1.25rem;color:var(--clr-gray);font-size:.93rem;line-height:1.75}

/* ─── Forms ──────────────────────────────────────────────── */
.form-card{background:var(--clr-white);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:2.5rem;box-shadow:var(--shadow-md)}
.form-group{margin-bottom:1.25rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
label{display:block;font-family:var(--font-heading);font-weight:600;font-size:.83rem;color:var(--clr-dark);margin-bottom:.4rem}
input[type=text],input[type=email],input[type=tel],input[type=number],select,textarea{
  width:100%;padding:.8rem 1rem;
  border:2px solid var(--clr-border);border-radius:var(--radius-sm);
  font-family:var(--font-body);font-size:.93rem;
  color:var(--clr-dark);background:var(--clr-white);
  transition:var(--transition);outline:none;-webkit-appearance:none;appearance:none
}
input:focus,select:focus,textarea:focus{border-color:var(--clr-blue);box-shadow:0 0 0 3px rgba(21,101,192,.1)}
textarea{resize:vertical;min-height:120px}
.form-error{color:#ef4444;font-size:.78rem;margin-top:.25rem;display:none}
.form-success{
  background:#d1fae5;color:#065f46;border:1px solid #6ee7b7;
  border-radius:var(--radius);padding:1rem 1.25rem;
  margin-top:1rem;display:none;font-family:var(--font-heading);font-weight:500
}
.hp-field{display:none!important;visibility:hidden!important}

/* ─── CTA Banner ─────────────────────────────────────────── */
.cta-banner{background:var(--gradient-hero);padding:5rem 0;text-align:center;position:relative;overflow:hidden}
.cta-banner h2{color:var(--clr-white);position:relative;margin-bottom:1rem}
.cta-banner p{color:rgba(255,255,255,.8);position:relative;max-width:520px;margin:0 auto 2rem}
.cta-banner .btn-group{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative}

/* ─── Pricing ────────────────────────────────────────────── */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;align-items:start}
.pricing-card{
  background:var(--clr-white);border:2px solid var(--clr-border);
  border-radius:var(--radius-lg);padding:2.5rem;
  text-align:center;transition:var(--transition);position:relative
}
.pricing-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}
.pricing-card.featured{background:var(--gradient-hero);border-color:transparent;transform:scale(1.03)}
.pricing-card.featured:hover{transform:scale(1.03) translateY(-4px)}
.pricing-badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--clr-cyan);color:var(--clr-white);
  font-family:var(--font-heading);font-size:.73rem;font-weight:700;
  padding:.3rem 1rem;border-radius:var(--radius-xl);
  letter-spacing:.05em;text-transform:uppercase
}
.pricing-name{font-family:var(--font-heading);font-weight:700;font-size:1.15rem;color:var(--clr-dark);margin-bottom:.5rem}
.pricing-card.featured .pricing-name{color:var(--clr-white)}
.pricing-price{font-family:var(--font-heading);font-size:2.4rem;font-weight:800;color:var(--clr-blue);margin:1rem 0;line-height:1}
.pricing-card.featured .pricing-price{color:var(--clr-cyan)}
.pricing-price sup{font-size:1.1rem;vertical-align:top;margin-top:.5rem}
.pricing-price small{font-size:.9rem;font-weight:400;opacity:.7}
.pricing-desc{font-size:.88rem;margin-bottom:1.5rem}
.pricing-card.featured .pricing-desc{color:rgba(255,255,255,.75)}
.pricing-features{text-align:left;margin-bottom:2rem;border-top:1px solid var(--clr-border);padding-top:1.5rem}
.pricing-card.featured .pricing-features{border-color:rgba(255,255,255,.2)}
.pricing-features li{display:flex;align-items:flex-start;gap:.75rem;padding:.4rem 0;font-size:.88rem;color:var(--clr-gray)}
.pricing-card.featured .pricing-features li{color:rgba(255,255,255,.85)}
.pricing-features li i{color:var(--clr-cyan);margin-top:2px;flex-shrink:0}

/* ─── Blog Cards ─────────────────────────────────────────── */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}
.blog-card{background:var(--clr-white);border:1px solid var(--clr-border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition)}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}
.blog-thumb{height:200px;background:var(--gradient-hero);position:relative;display:flex;align-items:center;justify-content:center}
.blog-thumb-icon{font-size:3rem;color:rgba(255,255,255,.25)}
.blog-category{
  position:absolute;bottom:.75rem;left:.75rem;
  background:var(--clr-blue);color:var(--clr-white);
  font-family:var(--font-heading);font-size:.73rem;font-weight:600;
  padding:.25rem .75rem;border-radius:var(--radius-xl)
}
.blog-body{padding:1.5rem}
.blog-meta{display:flex;align-items:center;gap:1rem;font-size:.78rem;color:var(--clr-gray);margin-bottom:.75rem}
.blog-meta i{color:var(--clr-blue)}
.blog-card h3{font-size:1rem;color:var(--clr-dark);margin-bottom:.5rem;line-height:1.4}
.blog-card p{font-size:.88rem;line-height:1.6}
.blog-card .read-more{display:inline-flex;align-items:center;gap:.4rem;color:var(--clr-blue);font-weight:600;font-size:.83rem;margin-top:1rem;font-family:var(--font-heading)}

/* ─── Contact ────────────────────────────────────────────── */
.contact-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:1.25rem;margin-bottom:4rem}
.contact-info-card{background:var(--clr-white);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:2rem;text-align:center;transition:var(--transition)}
.contact-info-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--clr-blue)}
.contact-info-icon{width:56px;height:56px;background:linear-gradient(135deg,rgba(21,101,192,.1),rgba(0,172,193,.1));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:var(--clr-blue);margin:0 auto 1rem}
.contact-info-card h4{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--clr-gray);margin-bottom:.5rem}
.contact-info-card a,.contact-info-card p{color:var(--clr-dark);font-weight:500;font-size:.93rem}
.contact-info-card a:hover{color:var(--clr-blue)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.map-container{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);background:var(--clr-light);height:380px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;border:1px solid var(--clr-border)}
.map-container i{font-size:3rem;color:var(--clr-blue)}
.map-container p{color:var(--clr-gray)}

/* ─── Process Steps ──────────────────────────────────────── */
.process-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem}
.step-item{text-align:center;padding:1.5rem}
.step-number{width:56px;height:56px;background:var(--gradient-card);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:1.2rem;font-weight:800;color:var(--clr-white);margin:0 auto 1rem}
.step-item h4{color:var(--clr-dark);margin-bottom:.5rem}

/* ─── Service Detail Cards ───────────────────────────────── */
.service-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}
.service-detail-card{background:var(--clr-light);border-radius:var(--radius);padding:1.75rem;display:flex;gap:1.25rem;align-items:flex-start;transition:var(--transition)}
.service-detail-card:hover{background:var(--clr-white);box-shadow:var(--shadow-md)}
.service-detail-icon{width:48px;height:48px;background:var(--clr-white);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:var(--clr-blue);flex-shrink:0;box-shadow:var(--shadow-sm)}
.service-detail-card h4{color:var(--clr-dark);margin-bottom:.4rem;font-size:.98rem}
.service-detail-card p{font-size:.86rem}

/* ─── Two-col content ────────────────────────────────────── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.two-col-reverse{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.two-col-reverse>:first-child{order:2}
.two-col-reverse>:last-child{order:1}
.col-img{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xl)}
.col-img-placeholder{height:400px;background:var(--gradient-hero);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:5rem;color:rgba(255,255,255,.3)}
.col-content .section-label{display:inline-block}
.col-content h2{margin-bottom:1rem}
.col-content p{margin-bottom:1.5rem}
.check-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}
.check-list li{display:flex;align-items:flex-start;gap:.75rem;font-size:.93rem;color:var(--clr-gray)}
.check-list li i{color:var(--clr-cyan);margin-top:3px;flex-shrink:0}

/* ─── Footer ─────────────────────────────────────────────── */
.footer{background:var(--clr-navy);padding:5rem 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:3rem;padding-bottom:4rem;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand p{color:rgba(255,255,255,.6);font-size:.88rem;margin:1rem 0 1.5rem;line-height:1.7}
.social-links{display:flex;gap:.75rem}
.social-link{width:38px;height:38px;background:rgba(255,255,255,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);font-size:.95rem;transition:var(--transition)}
.social-link:hover{background:var(--clr-blue);color:var(--clr-white)}
.footer-links h4,.footer-contact h4{color:var(--clr-white);font-family:var(--font-heading);font-size:.93rem;margin-bottom:1.25rem}
.footer-links ul li{margin-bottom:.5rem}
.footer-links ul li a{color:rgba(255,255,255,.6);font-size:.88rem;transition:var(--transition)}
.footer-links ul li a:hover{color:var(--clr-cyan);padding-left:4px}
.footer-contact-item{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.85rem}
.footer-contact-item i{color:var(--clr-cyan);margin-top:3px;font-size:.88rem;flex-shrink:0}
.footer-contact-item a,.footer-contact-item span{color:rgba(255,255,255,.7);font-size:.88rem}
.footer-contact-item a:hover{color:var(--clr-cyan)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 0;flex-wrap:wrap;gap:1rem}
.footer-bottom p{color:rgba(255,255,255,.4);font-size:.83rem}
.footer-bottom-links{display:flex;gap:1.5rem}
.footer-bottom-links a{color:rgba(255,255,255,.4);font-size:.83rem}
.footer-bottom-links a:hover{color:var(--clr-white)}

/* ─── Floating WhatsApp ──────────────────────────────────── */
.float-chat{position:fixed;bottom:2rem;right:2rem;z-index:999;display:flex;flex-direction:column;align-items:flex-end;gap:.75rem}
.float-chat-btn{
  width:60px;height:60px;border-radius:50%;background:#25d366;
  color:var(--clr-white);display:flex;align-items:center;justify-content:center;
  font-size:1.75rem;box-shadow:0 4px 20px rgba(37,211,102,.4);
  cursor:pointer;text-decoration:none;transition:var(--transition);
  animation:pulse-green 2.5s infinite
}
.float-chat-btn:hover{transform:scale(1.1)}
@keyframes pulse-green{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.4)}50%{box-shadow:0 4px 30px rgba(37,211,102,.7)}}
.float-chat-label{
  background:var(--clr-white);color:var(--clr-dark);
  padding:.4rem .9rem;border-radius:var(--radius-xl);
  font-family:var(--font-heading);font-size:.78rem;font-weight:600;
  box-shadow:var(--shadow-md);opacity:0;transform:translateX(10px);transition:var(--transition)
}
.float-chat:hover .float-chat-label{opacity:1;transform:translateX(0)}

/* ─── Scroll Animations ──────────────────────────────────── */
.animate-on-scroll{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease}
.animate-on-scroll.animated{opacity:1;transform:translateY(0)}

/* ─── Utilities ──────────────────────────────────────────── */
.bg-light{background:var(--clr-light)}
.bg-white{background:var(--clr-white)}
.text-center{text-align:center}
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}
.mb-1{margin-bottom:1rem}.mb-2{margin-bottom:2rem}

/* ─── Responsive ─────────────────────────────────────────── */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .two-col,.two-col-reverse{grid-template-columns:1fr}
  .two-col-reverse>:first-child{order:0}
  .two-col-reverse>:last-child{order:0}
  .col-img-placeholder{height:280px}
}
@media(max-width:768px){
  :root{--header-h:68px}
  .nav-menu,.nav-cta{display:none}
  .nav-menu.open{
    display:flex;flex-direction:column;
    position:fixed;top:var(--header-h);left:0;right:0;bottom:0;
    background:var(--clr-navy);padding:1.5rem;gap:.25rem;
    overflow-y:auto;z-index:999
  }
  .nav-menu.open .mobile-cta{display:inline-flex!important;margin-top:1rem}
  .nav-menu>li>a{font-size:1.05rem;padding:.85rem 1rem}
  .dropdown-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;background:rgba(255,255,255,.05);margin-top:.25rem}
  .dropdown-menu li a{color:rgba(255,255,255,.7)}
  .dropdown-menu li a:hover{background:rgba(255,255,255,.1);color:var(--clr-white)}
  .hamburger{display:flex}
  .hero{min-height:90vh}
  .hero-stats{gap:1.5rem}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;text-align:center}
  .float-chat{bottom:1.5rem;right:1.5rem}
  .float-chat-btn{width:52px;height:52px;font-size:1.5rem}
  .trust-items{gap:1.25rem}
  .pricing-card.featured{transform:none}
  .pricing-card.featured:hover{transform:translateY(-4px)}
  .process-steps{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  h1{font-size:1.85rem}
  h2{font-size:1.55rem}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{width:100%;justify-content:center}
  .blog-grid,.testimonials-grid{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr}
  .section{padding:3.5rem 0}
}
