/* ============================================
   QUICK RESPONSE TRANSPORTATION
   Handcrafted Design System — v2
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700&family=Playfair+Display:ital,wght@0,700;0,800;0,900;1,700;1,800&family=Space+Grotesk:wght@400;500;600;700&display=swap');

:root {
  /* — Warm, distinctive palette — */
  --ink:          #0E1117;
  --charcoal:     #171B23;
  --slate:        #1E232E;
  --slate-light:  #262D3A;
  --ocean:        #2563EB;
  --ocean-muted:  #1D4ED8;
  --sky:          #38BDF8;
  --mint:         #34D399;
  --mint-dark:    #059669;
  --amber:        #F59E0B;
  --amber-light:  #FCD34D;
  --coral:        #F87171;
  --cream:        #FAF8F5;
  --warm-white:   #F5F1EC;
  --sand:         #E8E0D4;
  --stone:        #C4B9A9;
  --bark:         #8B7E6A;
  --text-primary: #1A1A1A;
  --text-body:    #4A4A4A;
  --text-muted:   #8A8A8A;

  /* Typography */
  --font-display: 'Playfair Display', Georgia, serif;
  --font-heading: 'Space Grotesk', sans-serif;
  --font-body:    'DM Sans', sans-serif;

  /* Spacing */
  --gap-xs: 0.25rem; --gap-sm: 0.5rem; --gap-md: 1rem; --gap-lg: 1.5rem;
  --gap-xl: 2rem; --gap-2xl: 3rem; --gap-3xl: 4.5rem; --gap-4xl: 7rem;

  --max-w: 1180px;
  --nav-h: 72px;
  --radius: 16px;
  --radius-sm: 10px;
  --radius-xs: 6px;
}

/* ── Reset ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:var(--nav-h);-webkit-font-smoothing:antialiased}
body{font-family:var(--font-body);font-size:16px;line-height:1.75;color:var(--text-body);background:var(--cream);overflow-x:hidden}
img{max-width:100%;display:block}a{text-decoration:none;color:inherit}
ul{list-style:none}button{cursor:pointer;border:none;font-family:inherit;background:none}
input,textarea,select{font-family:inherit}

/* ── Container ── */
.wrap{max-width:var(--max-w);margin:0 auto;padding:0 var(--gap-xl)}

/* ── Section base ── */
.sec{padding:var(--gap-4xl) 0;position:relative}

/* ── Organic section dividers ── */
.divider-wave{position:relative}
.divider-wave::after{
  content:'';position:absolute;bottom:-2px;left:0;right:0;height:80px;
  background:var(--cream);
  clip-path:ellipse(55% 100% at 50% 100%);
  z-index:2;
}
.divider-wave-top::before{
  content:'';position:absolute;top:-2px;left:0;right:0;height:80px;
  background:var(--cream);
  clip-path:ellipse(55% 100% at 50% 0%);
  z-index:2;
}

/* ── Label tag ── */
.tag{
  display:inline-block;font-family:var(--font-heading);font-size:0.72rem;
  font-weight:600;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--ocean);padding:6px 16px;
  background:rgba(37,99,235,0.07);border:1px solid rgba(37,99,235,0.15);
  border-radius:100px;margin-bottom:var(--gap-lg);
}

.tag.dark{
  color:var(--sky);background:rgba(56,189,248,0.08);
  border-color:rgba(56,189,248,0.2);
}

/* ── Headings ── */
.hdg{
  font-family:var(--font-display);font-weight:800;
  color:var(--text-primary);line-height:1.15;
  margin-bottom:var(--gap-md);
}
.hdg-xl{font-size:clamp(2.6rem,5.5vw,4.2rem)}
.hdg-lg{font-size:clamp(2rem,4vw,2.8rem)}

.hdg em{
  font-style:italic;
  background:linear-gradient(135deg,var(--ocean),var(--mint));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}

.sub{
  font-size:1.1rem;color:var(--text-muted);
  max-width:520px;line-height:1.85;
}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;gap:var(--gap-sm);
  font-family:var(--font-heading);font-weight:600;font-size:0.9rem;
  padding:14px 30px;border-radius:100px;
  transition:all .35s cubic-bezier(.25,.46,.45,.94);
  position:relative;letter-spacing:.3px;
}

.btn-fill{
  background:var(--ocean);color:#fff;
  box-shadow:0 4px 20px rgba(37,99,235,.25),inset 0 1px 0 rgba(255,255,255,.15);
}
.btn-fill:hover{
  background:var(--ocean-muted);transform:translateY(-2px);
  box-shadow:0 8px 30px rgba(37,99,235,.35);
}

.btn-ghost{
  color:#fff;border:1.5px solid rgba(255,255,255,.3);
  backdrop-filter:blur(4px);
}
.btn-ghost:hover{
  border-color:#fff;background:rgba(255,255,255,.08);
  transform:translateY(-2px);
}

.btn-warm{
  background:var(--warm-white);color:var(--text-primary);
  border:1.5px solid var(--sand);
}
.btn-warm:hover{
  background:#fff;border-color:var(--stone);
  transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.06);
}

.btn svg{width:18px;height:18px;flex-shrink:0}

/* ============================================
   NAVIGATION
   ============================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:var(--nav-h);display:flex;align-items:center;
  transition:all .4s ease;
}
.nav.pinned{
  background:rgba(250,248,245,.92);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  box-shadow:0 1px 0 var(--sand);
}
.nav.pinned .nav-brand span,.nav.pinned .nav-menu a{color:var(--text-primary)}
.nav.pinned .nav-phone-link{color:var(--ocean) !important}

.nav-bar{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;max-width:var(--max-w);margin:0 auto;padding:0 var(--gap-xl);
}

.nav-brand{display:flex;align-items:center;gap:10px;z-index:101}
.nav-mark{
  width:38px;height:38px;border-radius:var(--radius-xs);
  background:linear-gradient(135deg,var(--ocean),var(--mint-dark));
  display:flex;align-items:center;justify-content:center;
}
.nav-mark svg{width:20px;height:20px;color:#fff}
.nav-brand span{
  font-family:var(--font-heading);font-weight:700;font-size:1.05rem;
  color:#fff;line-height:1.2;
}
.nav-brand small{
  display:block;font-size:.6rem;font-weight:500;
  letter-spacing:1.8px;text-transform:uppercase;
  opacity:.6;
}

.nav-menu{display:flex;align-items:center;gap:var(--gap-lg)}
.nav-menu a{
  font-size:.88rem;font-weight:500;color:rgba(255,255,255,.8);
  transition:color .2s;position:relative;
}
.nav-menu a::after{
  content:'';position:absolute;bottom:-3px;left:0;width:0;height:2px;
  background:var(--ocean);border-radius:2px;transition:width .3s ease;
}
.nav-menu a:hover{color:#fff}
.nav-menu a:hover::after{width:100%}

.nav-phone-link{
  font-weight:600;color:var(--amber-light)!important;
  display:flex;align-items:center;gap:6px;
}
.nav-phone-link::after{display:none!important}
.nav-phone-link svg{width:15px;height:15px}

.nav-cta{padding:10px 22px!important;font-size:.82rem!important}

/* Hamburger */
.hamburger{
  display:none;flex-direction:column;gap:5px;z-index:101;padding:4px;
}
.hamburger i{
  width:24px;height:2px;background:#fff;border-radius:3px;
  transition:all .3s ease;transform-origin:center;
}
.hamburger.on i:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.on i:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.on i:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav.pinned .hamburger i{background:var(--text-primary)}

/* ============================================
   HERO
   ============================================ */
.hero{
  min-height:100vh;display:flex;align-items:center;
  background:var(--ink);position:relative;overflow:hidden;
}

/* Subtle noise texture */
.hero::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.03'/%3E%3C/svg%3E");
  opacity:.5;z-index:1;pointer-events:none;
}

/* Organic gradient blobs */
.hero-blob{
  position:absolute;border-radius:50%;filter:blur(80px);
  opacity:.15;z-index:0;
}
.hero-blob.b1{width:600px;height:600px;background:var(--ocean);top:-200px;right:-100px}
.hero-blob.b2{width:400px;height:400px;background:var(--mint);bottom:-100px;left:-80px}
.hero-blob.b3{width:300px;height:300px;background:var(--amber);bottom:100px;right:20%}

.hero .wrap{position:relative;z-index:3;display:grid;grid-template-columns:1fr 420px;align-items:center;gap:var(--gap-3xl)}

.hero-intro{max-width:620px}

.hero-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 18px;border-radius:100px;
  background:rgba(37,99,235,.1);border:1px solid rgba(37,99,235,.2);
  font-size:.78rem;font-weight:600;color:var(--sky);
  margin-bottom:var(--gap-xl);letter-spacing:.3px;
}
.hero-pill .dot{
  width:7px;height:7px;border-radius:50%;background:var(--mint);
  animation:blink 2.5s ease-in-out infinite;
}

.hero h1{
  font-family:var(--font-display);font-size:clamp(2.6rem,5.2vw,4rem);
  font-weight:900;color:#fff;line-height:1.08;margin-bottom:var(--gap-lg);
}
.hero h1 em{
  font-style:italic;
  background:linear-gradient(135deg,var(--sky),var(--mint));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

.hero-desc{
  font-size:1.08rem;color:rgba(255,255,255,.55);line-height:1.85;
  margin-bottom:var(--gap-2xl);max-width:480px;
}

.hero-btns{display:flex;gap:var(--gap-md);flex-wrap:wrap;margin-bottom:var(--gap-3xl)}

/* Stats strip */
.hero-metrics{display:flex;gap:var(--gap-3xl)}
.metric{text-align:left}
.metric-val{
  font-family:var(--font-heading);font-size:2rem;font-weight:700;
  color:#fff;line-height:1;display:flex;align-items:baseline;gap:2px;
}
.metric-val .accent{color:var(--mint)}
.metric-lbl{
  font-size:.7rem;color:rgba(255,255,255,.35);margin-top:4px;
  text-transform:uppercase;letter-spacing:1.5px;font-weight:600;
}

/* Floating side card */
.hero-aside{position:relative}
.hero-card{
  background:rgba(255,255,255,.04);backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius);padding:var(--gap-xl);
  position:relative;
}
.hero-card::before{
  content:'';position:absolute;top:-1px;left:24px;right:24px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);
}

.hc-head{display:flex;align-items:center;gap:14px;margin-bottom:var(--gap-lg)}
.hc-icon{
  width:48px;height:48px;border-radius:var(--radius-sm);
  background:linear-gradient(135deg,var(--ocean),var(--mint-dark));
  display:flex;align-items:center;justify-content:center;
}
.hc-icon svg{width:22px;height:22px;color:#fff}
.hc-title{font-family:var(--font-heading);font-size:1rem;font-weight:700;color:#fff}
.hc-sub{font-size:.72rem;color:rgba(255,255,255,.4)}

.hc-rows{display:flex;flex-direction:column;gap:10px}
.hc-row{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;border-radius:var(--radius-xs);
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);
  transition:background .2s;
}
.hc-row:hover{background:rgba(255,255,255,.06)}
.hc-row-icon{
  width:32px;height:32px;border-radius:var(--radius-xs);
  background:rgba(52,211,153,.1);display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.hc-row-icon svg{width:16px;height:16px;color:var(--mint)}
.hc-row-text{font-size:.82rem;font-weight:500;color:rgba(255,255,255,.75);flex:1}
.hc-row-badge{
  font-size:.65rem;font-weight:600;padding:3px 10px;border-radius:100px;
  background:rgba(52,211,153,.12);color:var(--mint);letter-spacing:.5px;
}

/* Floating accent badge on card */
.hero-card-float{
  position:absolute;top:-14px;right:-10px;
  background:var(--amber);color:var(--ink);
  font-family:var(--font-heading);font-size:.7rem;font-weight:700;
  padding:6px 14px;border-radius:100px;
  box-shadow:0 4px 16px rgba(245,158,11,.3);
  letter-spacing:.5px;
}

/* ============================================
   SERVICES
   ============================================ */
.services{background:var(--cream)}

.services-header{
  display:grid;grid-template-columns:1fr 1fr;
  align-items:end;gap:var(--gap-xl);margin-bottom:var(--gap-3xl);
}

.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:var(--gap-lg);
}

.svc{
  background:#fff;border-radius:var(--radius);padding:var(--gap-2xl);
  border:1px solid rgba(0,0,0,.05);position:relative;
  transition:all .4s cubic-bezier(.25,.46,.45,.94);
  overflow:hidden;
}
.svc::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--ocean);transform:scaleX(0);transform-origin:left;
  transition:transform .4s ease;
}
.svc:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(0,0,0,.06);border-color:transparent}
.svc:hover::before{transform:scaleX(1)}

/* Accent stripe variants */
.svc.v-mint::before{background:var(--mint)}
.svc.v-amber::before{background:var(--amber)}
.svc.v-coral::before{background:var(--coral)}

.svc-ico{
  width:52px;height:52px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:var(--gap-lg);
}
.svc-ico svg{width:24px;height:24px}

.svc-ico.c-blue{background:rgba(37,99,235,.07);color:var(--ocean)}
.svc-ico.c-mint{background:rgba(52,211,153,.08);color:var(--mint-dark)}
.svc-ico.c-amber{background:rgba(245,158,11,.08);color:var(--amber)}
.svc-ico.c-coral{background:rgba(248,113,113,.08);color:var(--coral)}

.svc h3{
  font-family:var(--font-heading);font-size:1.08rem;
  font-weight:700;color:var(--text-primary);margin-bottom:6px;
}
.svc p{font-size:.88rem;color:var(--text-muted);line-height:1.75}

/* ============================================
   HOW IT WORKS
   ============================================ */
.how{
  background:var(--charcoal);padding:var(--gap-4xl) 0;
  position:relative;overflow:hidden;
}

.how::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.025'/%3E%3C/svg%3E");
  pointer-events:none;
}

.how .hdg{color:#fff}
.how .sub{color:rgba(255,255,255,.45)}

.steps{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:var(--gap-xl);margin-top:var(--gap-3xl);position:relative;
}

/* Connector */
.steps::before{
  content:'';position:absolute;top:44px;
  left:calc(16.66% + 24px);right:calc(16.66% + 24px);
  height:1px;
  background:repeating-linear-gradient(90deg,rgba(255,255,255,.15) 0,rgba(255,255,255,.15) 8px,transparent 8px,transparent 16px);
}

.step{text-align:center}
.step-num{
  width:64px;height:64px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto var(--gap-lg);
  font-family:var(--font-heading);font-size:1.3rem;font-weight:700;
  position:relative;
}
.step-num::after{
  content:'';position:absolute;inset:-5px;border-radius:50%;
  border:1.5px dashed rgba(255,255,255,.1);
}

.step.s1 .step-num{background:var(--ocean);color:#fff;box-shadow:0 0 24px rgba(37,99,235,.3)}
.step.s2 .step-num{background:var(--mint-dark);color:#fff;box-shadow:0 0 24px rgba(52,211,153,.25)}
.step.s3 .step-num{background:var(--amber);color:var(--ink);box-shadow:0 0 24px rgba(245,158,11,.3)}

.step h3{
  font-family:var(--font-heading);font-size:1.1rem;font-weight:700;
  color:#fff;margin-bottom:6px;
}
.step p{font-size:.88rem;color:rgba(255,255,255,.45);max-width:260px;margin:0 auto;line-height:1.75}

/* ============================================
   WHY CHOOSE US
   ============================================ */
.why{background:var(--cream)}

.why-layout{
  display:grid;grid-template-columns:1fr 1fr;
  gap:var(--gap-3xl);align-items:center;margin-top:var(--gap-2xl);
}

.why-text .hdg{margin-bottom:var(--gap-md)}
.why-text>p{margin-bottom:var(--gap-2xl)}

.why-features{display:flex;flex-direction:column;gap:var(--gap-lg)}

.feat{
  display:flex;gap:var(--gap-lg);align-items:flex-start;
  padding:var(--gap-lg) var(--gap-xl);
  background:#fff;border-radius:var(--radius-sm);
  border:1px solid rgba(0,0,0,.04);
  transition:all .3s ease;
}
.feat:hover{
  border-color:rgba(37,99,235,.12);
  box-shadow:0 4px 16px rgba(0,0,0,.04);
  transform:translateX(4px);
}

.feat-ico{
  width:44px;height:44px;border-radius:var(--radius-xs);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.feat-ico svg{width:20px;height:20px}

.feat-ico.f-blue{background:rgba(37,99,235,.07);color:var(--ocean)}
.feat-ico.f-mint{background:rgba(52,211,153,.08);color:var(--mint-dark)}
.feat-ico.f-amber{background:rgba(245,158,11,.08);color:var(--amber)}
.feat-ico.f-coral{background:rgba(248,113,113,.08);color:var(--coral)}

.feat h4{
  font-family:var(--font-heading);font-size:.95rem;
  font-weight:700;color:var(--text-primary);margin-bottom:2px;
}
.feat p{font-size:.82rem;color:var(--text-muted);line-height:1.7}

/* Big stat panel on right */
.why-panel{
  background:var(--charcoal);border-radius:var(--radius);
  padding:var(--gap-3xl);position:relative;overflow:hidden;
}
.why-panel::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.03'/%3E%3C/svg%3E");
}
.why-panel>*{position:relative;z-index:1}
.why-panel-title{
  font-family:var(--font-display);font-size:1.6rem;font-weight:800;
  color:#fff;margin-bottom:var(--gap-2xl);line-height:1.3;
}

.why-stats{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap-xl)}
.why-stat{
  padding:var(--gap-lg);border-radius:var(--radius-sm);
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);
}
.why-stat-val{
  font-family:var(--font-heading);font-size:2rem;font-weight:700;
  color:#fff;line-height:1;margin-bottom:4px;
}
.why-stat-lbl{font-size:.72rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:1px;font-weight:600}

.why-badges{display:flex;flex-wrap:wrap;gap:var(--gap-sm);margin-top:var(--gap-xl)}
.why-badge{
  padding:6px 14px;border-radius:100px;font-size:.72rem;font-weight:600;
  letter-spacing:.5px;
}
.why-badge.b1{background:rgba(37,99,235,.15);color:var(--sky)}
.why-badge.b2{background:rgba(52,211,153,.12);color:var(--mint)}
.why-badge.b3{background:rgba(245,158,11,.12);color:var(--amber)}
.why-badge.b4{background:rgba(248,113,113,.12);color:var(--coral)}

/* ============================================
   SERVICE AREAS
   ============================================ */
.areas{
  background:var(--charcoal);position:relative;overflow:hidden;
  padding:var(--gap-4xl) 0;
}
.areas .hdg{color:#fff}
.areas .sub{color:rgba(255,255,255,.45)}

.areas-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:var(--gap-3xl);align-items:center;margin-top:var(--gap-2xl);
}

.areas-map-wrap{
  background:rgba(255,255,255,.03);border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.06);padding:var(--gap-xl);
  position:relative;
}
.areas-map-wrap svg{width:100%;height:auto;max-height:360px}

.areas-list{display:flex;flex-direction:column;gap:10px}
.al-item{
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;border-radius:var(--radius-sm);
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);
  transition:all .3s ease;
}
.al-item:hover{
  background:rgba(255,255,255,.06);
  border-color:rgba(52,211,153,.2);transform:translateX(5px);
}
.al-ico{
  width:36px;height:36px;border-radius:var(--radius-xs);
  background:linear-gradient(135deg,rgba(37,99,235,.15),rgba(52,211,153,.15));
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.al-ico svg{width:16px;height:16px;color:var(--mint)}
.al-name{font-family:var(--font-heading);font-size:.92rem;font-weight:600;color:#fff}
.al-desc{font-size:.72rem;color:rgba(255,255,255,.4)}

/* ============================================
   TESTIMONIALS
   ============================================ */
.reviews{background:var(--cream)}

.reviews-slider{margin-top:var(--gap-2xl);position:relative;overflow:hidden}
.reviews-track{display:flex;transition:transform .5s cubic-bezier(.25,.46,.45,.94)}

.rev-slide{min-width:100%;padding:0 var(--gap-md)}
.rev-inner{
  background:#fff;border-radius:var(--radius);
  padding:var(--gap-3xl);border:1px solid rgba(0,0,0,.04);
  max-width:750px;margin:0 auto;position:relative;
}
.rev-inner::before{
  content:'\201C';position:absolute;top:16px;left:28px;
  font-family:var(--font-display);font-size:5rem;
  color:var(--ocean);opacity:.06;line-height:1;
}

.rev-stars{display:flex;gap:3px;margin-bottom:var(--gap-lg);color:var(--amber)}
.rev-stars svg{width:18px;height:18px}

.rev-quote{
  font-family:var(--font-body);font-size:1.08rem;line-height:1.9;
  color:var(--text-primary);font-style:italic;margin-bottom:var(--gap-xl);
}

.rev-who{display:flex;align-items:center;gap:14px}
.rev-avatar{
  width:46px;height:46px;border-radius:50%;
  background:linear-gradient(135deg,var(--ocean),var(--mint-dark));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-heading);font-size:1rem;font-weight:700;color:#fff;
}
.rev-name{
  font-family:var(--font-heading);font-weight:700;
  color:var(--text-primary);font-size:.92rem;
}
.rev-role{font-size:.75rem;color:var(--text-muted)}

/* Slider controls */
.sl-ctrl{
  display:flex;justify-content:center;align-items:center;
  gap:var(--gap-lg);margin-top:var(--gap-xl);
}
.sl-btn{
  width:42px;height:42px;border-radius:50%;background:#fff;
  border:1px solid var(--sand);display:flex;align-items:center;justify-content:center;
  transition:all .2s ease;
}
.sl-btn svg{width:16px;height:16px;color:var(--text-primary)}
.sl-btn:hover{background:var(--ocean);border-color:var(--ocean)}
.sl-btn:hover svg{color:#fff}

.sl-dots{display:flex;gap:7px}
.sl-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--sand);border:none;transition:all .2s;
}
.sl-dot.on{background:var(--ocean);transform:scale(1.3)}

/* ============================================
   CTA BANNER
   ============================================ */
.cta-strip{
  background:var(--ink);padding:var(--gap-3xl) 0;
  position:relative;overflow:hidden;
}
.cta-strip::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(37,99,235,.12),rgba(52,211,153,.08));
  z-index:0;
}
.cta-strip .wrap{position:relative;z-index:1;text-align:center}
.cta-strip h2{
  font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.2rem);
  font-weight:800;color:#fff;margin-bottom:var(--gap-sm);
}
.cta-strip p{color:rgba(255,255,255,.55);font-size:1rem;margin-bottom:var(--gap-xl);max-width:480px;margin-left:auto;margin-right:auto}
.cta-strip .cta-btns{display:flex;justify-content:center;gap:var(--gap-md);flex-wrap:wrap}

/* ============================================
   CONTACT / BOOKING
   ============================================ */
.contact{background:var(--cream)}
.contact-grid{
  display:grid;grid-template-columns:1fr 1.2fr;
  gap:var(--gap-3xl);margin-top:var(--gap-2xl);
}

.ct-info{display:flex;flex-direction:column;gap:var(--gap-xl)}
.ct-item{display:flex;gap:var(--gap-lg);align-items:flex-start}
.ct-ico{
  width:44px;height:44px;border-radius:var(--radius-sm);
  background:rgba(37,99,235,.07);display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.ct-ico svg{width:20px;height:20px;color:var(--ocean)}
.ct-item h4{font-family:var(--font-heading);font-weight:700;color:var(--text-primary);margin-bottom:2px;font-size:.92rem}
.ct-item p,.ct-item a{color:var(--text-muted);font-size:.88rem}
.ct-item a:hover{color:var(--ocean)}

.ct-hours{
  background:#fff;border-radius:var(--radius-sm);
  padding:var(--gap-xl);border:1px solid rgba(0,0,0,.04);
}
.ct-hours h4{
  font-family:var(--font-heading);font-weight:700;color:var(--text-primary);
  margin-bottom:var(--gap-md);font-size:.92rem;
  display:flex;align-items:center;gap:var(--gap-sm);
}
.ct-hours h4 svg{width:18px;height:18px;color:var(--ocean)}

.hrs-row{display:flex;justify-content:space-between;padding:6px 0;font-size:.88rem}
.hrs-row .day{color:var(--text-muted)}
.hrs-row .time{font-weight:600;color:var(--text-primary)}

/* Form */
.bk-card{
  background:#fff;border-radius:var(--radius);
  padding:var(--gap-2xl);border:1px solid rgba(0,0,0,.04);
}
.bk-card h3{
  font-family:var(--font-heading);font-size:1.25rem;
  font-weight:700;color:var(--text-primary);margin-bottom:4px;
}
.bk-card .form-desc{font-size:.88rem;color:var(--text-muted);margin-bottom:var(--gap-xl)}

.fg{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap-md)}
.fg-item{display:flex;flex-direction:column;gap:5px}
.fg-item.span{grid-column:1/-1}

.fg-item label{
  font-size:.72rem;font-weight:600;color:var(--text-primary);
  text-transform:uppercase;letter-spacing:.5px;
}

.fg-item input,.fg-item select,.fg-item textarea{
  padding:11px 14px;border:1.5px solid var(--sand);
  border-radius:var(--radius-xs);font-size:.88rem;
  background:var(--cream);color:var(--text-primary);
  transition:all .2s ease;outline:none;
}
.fg-item input:focus,.fg-item select:focus,.fg-item textarea:focus{
  border-color:var(--ocean);box-shadow:0 0 0 3px rgba(37,99,235,.06);
  background:#fff;
}
.fg-item input.err,.fg-item select.err,.fg-item textarea.err{
  border-color:var(--coral);box-shadow:0 0 0 3px rgba(248,113,113,.06);
}
.fg-item .err-msg{font-size:.7rem;color:var(--coral);display:none}
.fg-item .err-msg.show{display:block}
.fg-item textarea{resize:vertical;min-height:90px}

.form-submit{margin-top:var(--gap-lg)}
.form-submit .btn{width:100%;padding:15px;font-size:.95rem}

.form-ok{display:none;text-align:center;padding:var(--gap-2xl)}
.form-ok.show{display:block}
.form-ok svg{width:48px;height:48px;color:var(--mint-dark);margin:0 auto var(--gap-md)}
.form-ok h3{font-family:var(--font-heading);font-weight:700;color:var(--text-primary);margin-bottom:var(--gap-sm)}
.form-ok p{color:var(--text-muted);font-size:.92rem}

/* ============================================
   FOOTER
   ============================================ */
.foot{
  background:var(--ink);color:rgba(255,255,255,.55);
  padding:var(--gap-4xl) 0 var(--gap-xl);
}

.foot-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;
  gap:var(--gap-3xl);margin-bottom:var(--gap-3xl);
}

.foot-brand .fb-name{
  font-family:var(--font-heading);font-size:1.15rem;font-weight:700;
  color:#fff;margin-bottom:var(--gap-md);
  display:flex;align-items:center;gap:10px;
}
.foot-brand .fb-mark{
  width:32px;height:32px;border-radius:var(--radius-xs);
  background:linear-gradient(135deg,var(--ocean),var(--mint-dark));
  display:flex;align-items:center;justify-content:center;
}
.foot-brand .fb-mark svg{width:16px;height:16px;color:#fff}
.foot-brand p{font-size:.88rem;line-height:1.8;margin-bottom:var(--gap-lg)}

.foot-social{display:flex;gap:8px}
.foot-social a{
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.05);display:flex;
  align-items:center;justify-content:center;transition:all .2s;
}
.foot-social a svg{width:16px;height:16px;color:rgba(255,255,255,.5)}
.foot-social a:hover{background:var(--ocean)}
.foot-social a:hover svg{color:#fff}

.foot-col h4{
  font-family:var(--font-heading);font-size:.82rem;font-weight:700;
  color:#fff;margin-bottom:var(--gap-lg);
  text-transform:uppercase;letter-spacing:1.5px;
}
.foot-col li{margin-bottom:var(--gap-sm)}
.foot-col a{font-size:.85rem;transition:color .2s}
.foot-col a:hover{color:var(--mint)}

.foot-ct{display:flex;align-items:flex-start;gap:8px;margin-bottom:var(--gap-md);font-size:.85rem}
.foot-ct svg{width:16px;height:16px;flex-shrink:0;margin-top:3px;color:rgba(255,255,255,.3)}

.foot-bottom{
  border-top:1px solid rgba(255,255,255,.06);
  padding-top:var(--gap-xl);display:flex;
  justify-content:space-between;align-items:center;font-size:.75rem;
}
.foot-bottom-links{display:flex;gap:var(--gap-lg)}
.foot-bottom-links a:hover{color:var(--mint)}

/* ============================================
   ANIMATIONS
   ============================================ */
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

.reveal{opacity:0;transform:translateY(24px);transition:all .6s cubic-bezier(.25,.46,.45,.94)}
.reveal.vis{opacity:1;transform:translateY(0)}
.reveal.d1{transition-delay:80ms}
.reveal.d2{transition-delay:160ms}
.reveal.d3{transition-delay:240ms}
.reveal.d4{transition-delay:320ms}
.reveal.d5{transition-delay:400ms}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
  .hero .wrap{grid-template-columns:1fr}
  .hero-aside{display:none}
  .services-header{grid-template-columns:1fr}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .why-layout{grid-template-columns:1fr}
  .areas-grid{grid-template-columns:1fr;gap:var(--gap-2xl)}
  .contact-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:768px){
  .wrap{padding:0 var(--gap-md)}
  .sec{padding:var(--gap-3xl) 0}

  .nav-menu{
    position:fixed;top:0;left:0;right:0;bottom:0;
    background:rgba(14,17,23,.97);backdrop-filter:blur(20px);
    flex-direction:column;justify-content:center;gap:var(--gap-xl);
    transform:translateX(100%);transition:transform .35s ease;z-index:100;
  }
  .nav-menu.open{transform:translateX(0)}
  .nav-menu a{font-size:1.3rem;font-weight:600;color:rgba(255,255,255,.8)}
  .hamburger{display:flex}

  .hero{min-height:auto;padding:calc(var(--nav-h) + 2.5rem) 0 var(--gap-3xl)}
  .hero h1{font-size:clamp(2rem,7vw,2.7rem)}
  .hero-metrics{gap:var(--gap-xl)}
  .metric-val{font-size:1.5rem}

  .services-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr;gap:var(--gap-2xl)}
  .steps::before{display:none}
  .fg{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr;gap:var(--gap-2xl)}
  .foot-bottom{flex-direction:column;gap:var(--gap-md);text-align:center}
  .cta-strip .cta-btns{flex-direction:column;align-items:center}
}

@media(max-width:480px){
  .hero-btns{flex-direction:column}
  .hero-btns .btn{width:100%;justify-content:center}
  .hero-metrics{flex-direction:column;gap:var(--gap-lg)}
}
