/* ============================================
   ScarboroughPlumbers.com — Industrial Warmth
   Conversion-optimized local service directory
   ============================================ */

/* --- Design Tokens --- */
:root {
  /* Brand — deep navy anchored by warm copper */
  --navy-950: #070d18;
  --navy-900: #0c1829;
  --navy-800: #132440;
  --navy-700: #1a365d;
  --navy-600: #234980;
  --navy-500: #2e5ea3;

  /* Copper accent — references pipe material */
  --copper: #c27531;
  --copper-light: #e09555;
  --copper-bright: #f0a965;
  --copper-glow: rgba(194,117,49,.25);

  /* Semantic */
  --emergency: #e63946;
  --emergency-dark: #c5303c;
  --success: #2d936c;
  --success-light: #34d399;

  /* Neutrals (warm) */
  --white: #faf8f5;
  --white-pure: #ffffff;
  --gray-50: #f5f1eb;
  --gray-100: #ede8e0;
  --gray-200: #ddd6cc;
  --gray-300: #c4bbb0;
  --gray-400: #9e9588;
  --gray-500: #78706a;
  --gray-600: #5c5550;
  --gray-700: #403b37;
  --gray-800: #2a2622;
  --gray-900: #1a1715;

  /* Typography */
  --font-display: 'Bricolage Grotesque', 'Georgia', serif;
  --font-body: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* Fluid type scale */
  --text-xs: clamp(.75rem, .7rem + .25vw, .8125rem);
  --text-sm: clamp(.8125rem, .76rem + .3vw, .9375rem);
  --text-base: clamp(.9375rem, .88rem + .4vw, 1.0625rem);
  --text-lg: clamp(1.0625rem, .98rem + .5vw, 1.25rem);
  --text-xl: clamp(1.25rem, 1.1rem + .75vw, 1.5rem);
  --text-2xl: clamp(1.5rem, 1.25rem + 1.25vw, 2rem);
  --text-3xl: clamp(1.875rem, 1.5rem + 1.875vw, 2.75rem);
  --text-4xl: clamp(2.25rem, 1.6rem + 3.25vw, 3.75rem);
  --text-5xl: clamp(2.75rem, 1.8rem + 4.75vw, 5rem);

  /* Spacing */
  --sp-1: .25rem; --sp-2: .5rem; --sp-3: .75rem;
  --sp-4: 1rem;   --sp-5: 1.25rem; --sp-6: 1.5rem;
  --sp-8: 2rem;   --sp-10: 2.5rem; --sp-12: 3rem;
  --sp-16: 4rem;  --sp-20: 5rem;   --sp-24: 6rem;

  /* Radii */
  --r-sm: .25rem; --r-md: .5rem; --r-lg: .75rem;
  --r-xl: 1rem;   --r-2xl: 1.25rem; --r-full: 9999px;

  /* Shadows */
  --sh-sm: 0 1px 3px rgba(7,13,24,.06);
  --sh-md: 0 4px 12px rgba(7,13,24,.08);
  --sh-lg: 0 12px 32px rgba(7,13,24,.12);
  --sh-xl: 0 20px 48px rgba(7,13,24,.16);
  --sh-copper: 0 4px 20px rgba(194,117,49,.35);

  /* Transitions */
  --ease-out: cubic-bezier(.16,1,.3,1);
  --t-fast: 150ms var(--ease-out);
  --t-base: 250ms var(--ease-out);
  --t-slow: 400ms var(--ease-out);
  --t-slower: 600ms var(--ease-out);

  /* Layout */
  --max-w: 1220px;
  --gutter: clamp(1rem, 4vw, 2rem);
}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-size:var(--text-base);line-height:1.65;color:var(--gray-700);background:var(--white);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{font:inherit;cursor:pointer;border:none;background:none}

/* --- Typography --- */
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.15;color:var(--navy-800);letter-spacing:-.02em}
h1{font-size:var(--text-4xl);margin-bottom:var(--sp-6)}
h2{font-size:var(--text-3xl);margin-bottom:var(--sp-5)}
h3{font-size:var(--text-2xl);margin-bottom:var(--sp-4)}
h4{font-size:var(--text-xl);margin-bottom:var(--sp-3)}
p{margin-bottom:var(--sp-4);color:var(--gray-600)}

/* --- Layout --- */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding-inline:var(--gutter)}

/* --- Scroll Reveal --- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}
.reveal-delay-5{transition-delay:.5s}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-4) var(--sp-8);font-family:var(--font-body);font-size:var(--text-sm);font-weight:700;letter-spacing:.01em;border-radius:var(--r-lg);border:2px solid transparent;cursor:pointer;transition:all var(--t-base);white-space:nowrap;text-decoration:none;position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent 40%,rgba(255,255,255,.15) 50%,transparent 60%);transform:translateX(-100%);transition:transform .5s}
.btn:hover::after{transform:translateX(100%)}

.btn-primary{background:var(--copper);color:var(--white-pure);border-color:var(--copper);box-shadow:var(--sh-copper)}
.btn-primary:hover{background:var(--copper-light);border-color:var(--copper-light);transform:translateY(-2px);box-shadow:0 8px 28px rgba(194,117,49,.45)}

.btn-secondary{background:rgba(255,255,255,.1);color:var(--white);border-color:rgba(255,255,255,.25);backdrop-filter:blur(8px)}
.btn-secondary:hover{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.4)}

.btn-outline{background:transparent;color:var(--navy-700);border-color:var(--navy-700)}
.btn-outline:hover{background:var(--navy-700);color:var(--white-pure);transform:translateY(-2px)}

.btn-emergency{background:var(--emergency);color:var(--white-pure);border-color:var(--emergency);box-shadow:0 4px 20px rgba(230,57,70,.35)}
.btn-emergency:hover{background:var(--emergency-dark);border-color:var(--emergency-dark);transform:translateY(-2px)}

.btn-lg{padding:var(--sp-5) var(--sp-12);font-size:var(--text-base)}
.btn-sm{padding:var(--sp-2) var(--sp-5);font-size:var(--text-xs)}
.btn-icon{width:20px;height:20px;flex-shrink:0}

/* --- Emergency Banner --- */
.e-banner{background:linear-gradient(90deg,var(--emergency) 0%,var(--emergency-dark) 100%);color:var(--white-pure);padding:var(--sp-3) 0;position:relative;z-index:200;overflow:hidden}
.e-banner::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent,transparent 20px,rgba(255,255,255,.04) 20px,rgba(255,255,255,.04) 40px)}
.e-banner-inner{display:flex;align-items:center;justify-content:center;gap:var(--sp-3);flex-wrap:wrap;text-align:center}
.e-banner-pulse{width:8px;height:8px;background:var(--white-pure);border-radius:50%;animation:e-pulse 1.5s ease-in-out infinite;flex-shrink:0}
@keyframes e-pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(255,255,255,.6)}50%{opacity:.7;box-shadow:0 0 0 6px rgba(255,255,255,0)}}
.e-banner-text{font-weight:700;font-size:var(--text-xs);letter-spacing:.06em;text-transform:uppercase}
.e-banner-link{color:var(--white-pure);font-weight:800;text-decoration:underline;text-underline-offset:3px;font-size:var(--text-xs);transition:opacity var(--t-fast)}
.e-banner-link:hover{opacity:.85}

/* --- Header --- */
.header{background:var(--white-pure);border-bottom:1px solid var(--gray-100);position:sticky;top:0;z-index:150;transition:box-shadow var(--t-base)}
.header.scrolled{box-shadow:0 4px 20px rgba(7,13,24,.08)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:var(--sp-6)}

/* Logo */
.logo{display:flex;align-items:center;gap:var(--sp-3);text-decoration:none;flex-shrink:0}
.logo-mark{width:44px;height:44px;background:linear-gradient(135deg,var(--navy-800) 0%,var(--navy-700) 100%);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.logo-mark::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 40%,rgba(194,117,49,.25));border-radius:inherit}
.logo-mark svg{position:relative;z-index:1;color:var(--copper-light)}
.logo-text{display:flex;flex-direction:column;line-height:1.2}
.logo-name{font-family:var(--font-display);font-size:var(--text-lg);font-weight:800;color:var(--navy-800);letter-spacing:-.03em}
.logo-sub{font-size:var(--text-xs);color:var(--gray-400);font-weight:600;text-transform:uppercase;letter-spacing:.08em}

/* Desktop Nav */
.nav{display:none}
.nav-list{display:flex;gap:var(--sp-8);align-items:center}
.nav-link{font-size:var(--text-sm);font-weight:600;color:var(--gray-600);padding:var(--sp-2) 0;position:relative;transition:color var(--t-fast)}
.nav-link::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--copper);border-radius:2px;transition:width var(--t-base)}
.nav-link:hover{color:var(--navy-800)}
.nav-link:hover::after{width:100%}
.header-cta{display:none}

/* Mobile Menu Toggle */
.menu-toggle{display:flex;flex-direction:column;gap:5px;padding:var(--sp-2);width:40px;height:40px;justify-content:center;align-items:center;border-radius:var(--r-md);transition:background var(--t-fast)}
.menu-toggle:hover{background:var(--gray-50)}
.menu-toggle span{display:block;width:22px;height:2px;background:var(--navy-800);border-radius:2px;transition:all var(--t-base)}
.menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile Nav */
.mobile-nav{position:fixed;top:72px;left:0;right:0;bottom:0;background:var(--white-pure);z-index:140;padding:var(--sp-6);transform:translateX(100%);transition:transform .35s var(--ease-out);overflow-y:auto}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav-list{display:flex;flex-direction:column;gap:var(--sp-1)}
.mobile-nav-link{display:block;padding:var(--sp-4) var(--sp-4);font-size:var(--text-lg);font-weight:600;color:var(--gray-700);border-radius:var(--r-lg);transition:all var(--t-fast)}
.mobile-nav-link:hover{background:var(--gray-50);color:var(--navy-800)}
.mobile-nav-cta{margin-top:var(--sp-6);width:100%;text-align:center}

/* --- Hero --- */
.hero{background:var(--navy-900);color:var(--white);padding:var(--sp-16) 0 var(--sp-20);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 70% 20%,rgba(194,117,49,.12) 0%,transparent 60%),radial-gradient(ellipse 60% 50% at 10% 80%,rgba(46,94,163,.1) 0%,transparent 50%)}
.hero::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.015'%3E%3Cpath d='M20 0v2m0 36v2M0 20h2m36 0h2'/%3E%3C/g%3E%3C/svg%3E")}

.hero-inner{position:relative;z-index:1;display:grid;gap:var(--sp-10);align-items:center}
.hero-content{text-align:center}

.hero-badge{display:inline-flex;align-items:center;gap:var(--sp-2);background:rgba(194,117,49,.12);border:1px solid rgba(194,117,49,.25);padding:var(--sp-2) var(--sp-5);border-radius:var(--r-full);font-size:var(--text-xs);font-weight:600;color:var(--copper-bright);margin-bottom:var(--sp-8);letter-spacing:.02em}
.hero-badge-dot{width:6px;height:6px;background:var(--success-light);border-radius:50%;animation:e-pulse 2s infinite}

.hero-title{color:var(--white-pure);font-size:var(--text-5xl);margin-bottom:var(--sp-6);line-height:1.05}
.hero-title-accent{color:var(--copper-bright);display:block}
.hero-title-line{display:block;background:linear-gradient(90deg,var(--copper-light),var(--copper-bright));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

.hero-desc{font-size:var(--text-lg);color:rgba(255,255,255,.75);margin-bottom:var(--sp-8);max-width:560px;margin-inline:auto;line-height:1.7}

.hero-actions{display:flex;flex-direction:column;gap:var(--sp-4);align-items:center}

/* Hero card */
.hero-card{background:rgba(255,255,255,.06);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-2xl);padding:var(--sp-8);max-width:380px;margin-inline:auto}
.hero-card-label{font-size:var(--text-xs);font-weight:700;color:var(--copper-bright);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--sp-3)}
.hero-card-title{font-family:var(--font-display);font-size:var(--text-xl);color:var(--white-pure);margin-bottom:var(--sp-6);font-weight:700}
.hero-card-steps{display:flex;flex-direction:column;gap:var(--sp-4);margin-bottom:var(--sp-6)}
.hero-card-step{display:flex;align-items:center;gap:var(--sp-4)}
.hero-card-num{width:32px;height:32px;border-radius:50%;background:rgba(194,117,49,.15);border:1px solid rgba(194,117,49,.3);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:var(--text-sm);color:var(--copper-bright);flex-shrink:0}
.hero-card-step-text{font-size:var(--text-sm);color:rgba(255,255,255,.8)}

/* Trust strip below hero */
.hero-trust{display:flex;flex-wrap:wrap;gap:var(--sp-6);justify-content:center;margin-top:var(--sp-10);padding-top:var(--sp-8);border-top:1px solid rgba(255,255,255,.08)}
.hero-trust-item{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--text-xs);color:rgba(255,255,255,.65);font-weight:500}
.hero-trust-item svg{width:16px;height:16px;color:var(--success-light);flex-shrink:0}

/* --- Trust Bar --- */
.trust-bar{background:var(--white-pure);padding:var(--sp-6) 0;border-bottom:1px solid var(--gray-100);position:relative}
.trust-bar::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--copper),var(--copper-light),var(--copper))}
.trust-bar-inner{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-4)}
.trust-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3)}
.trust-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--gray-50),var(--gray-100));border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;color:var(--copper);flex-shrink:0}
.trust-label{font-weight:700;font-size:var(--text-sm);color:var(--navy-800)}
.trust-sub{font-size:var(--text-xs);color:var(--gray-400)}

/* --- Section Utilities --- */
.section{padding:var(--sp-20) 0}
.section-alt{background:var(--gray-50)}
.section-dark{background:var(--navy-900);color:var(--white)}
.section-header{text-align:center;max-width:640px;margin:0 auto var(--sp-12)}
.section-tag{display:inline-flex;align-items:center;gap:var(--sp-2);font-size:var(--text-xs);font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--copper);margin-bottom:var(--sp-4);padding:var(--sp-2) var(--sp-4);background:rgba(194,117,49,.08);border-radius:var(--r-full)}
.section-title{margin-bottom:var(--sp-4)}
.section-desc{font-size:var(--text-lg);color:var(--gray-500);max-width:520px;margin-inline:auto}

/* --- Services Grid --- */
.services-grid{display:grid;gap:var(--sp-6)}
.service-card{background:var(--white-pure);border:1px solid var(--gray-100);border-radius:var(--r-2xl);padding:var(--sp-8);transition:all var(--t-base);position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy-700),var(--navy-500));transform:scaleX(0);transform-origin:left;transition:transform var(--t-slow)}
.service-card:hover{border-color:var(--gray-200);box-shadow:var(--sh-lg);transform:translateY(-6px)}
.service-card:hover::before{transform:scaleX(1)}

.service-card--emergency::before{background:linear-gradient(90deg,var(--emergency),#f87171)}

.service-icon-wrap{width:56px;height:56px;border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-5);background:linear-gradient(135deg,var(--gray-50),var(--gray-100));color:var(--navy-700);transition:all var(--t-base)}
.service-card:hover .service-icon-wrap{background:linear-gradient(135deg,var(--navy-700),var(--navy-800));color:var(--copper-light)}
.service-card--emergency .service-icon-wrap{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:var(--emergency)}

.service-title{font-size:var(--text-xl);margin-bottom:var(--sp-3);font-weight:700}
.service-desc{font-size:var(--text-sm);color:var(--gray-500);margin-bottom:var(--sp-5)}
.service-features{margin-bottom:var(--sp-6)}
.service-feature{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--text-sm);color:var(--gray-600);margin-bottom:var(--sp-2)}
.service-feature svg{width:16px;height:16px;color:var(--success);flex-shrink:0}

/* --- How It Works --- */
.steps-grid{display:grid;gap:var(--sp-8);counter-reset:step-counter}
.step{display:flex;gap:var(--sp-5);align-items:flex-start}
.step-num{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--navy-800),var(--navy-700));color:var(--copper-bright);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:var(--text-xl);font-weight:800;flex-shrink:0;box-shadow:0 4px 16px rgba(7,13,24,.15)}
.step-body{flex:1}
.step-title{font-size:var(--text-lg);margin-bottom:var(--sp-2);font-weight:700}
.step-desc{font-size:var(--text-sm);color:var(--gray-500);margin-bottom:0}
.steps-cta{text-align:center;margin-top:var(--sp-12)}
.steps-note{font-size:var(--text-xs);color:var(--gray-400);margin-top:var(--sp-4)}

/* --- Areas Grid --- */
.areas-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-4)}
.area-card{background:var(--white-pure);border:1px solid var(--gray-100);border-radius:var(--r-xl);padding:var(--sp-5) var(--sp-5);text-decoration:none;transition:all var(--t-base);display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3)}
.area-card:hover{border-color:var(--copper);box-shadow:var(--sh-md);transform:translateY(-3px)}
.area-card:hover .area-name{color:var(--copper)}
.area-name{font-family:var(--font-display);font-weight:700;font-size:var(--text-sm);color:var(--navy-800);transition:color var(--t-fast);margin-bottom:0}
.area-codes{font-size:var(--text-xs);color:var(--gray-400);margin-bottom:0}
.area-arrow{width:20px;height:20px;color:var(--gray-300);transition:all var(--t-fast);flex-shrink:0}
.area-card:hover .area-arrow{color:var(--copper);transform:translateX(3px)}
.area-card--cta{background:linear-gradient(135deg,var(--navy-800),var(--navy-700));border-color:transparent}
.area-card--cta .area-name{color:var(--white-pure)}
.area-card--cta .area-codes{color:rgba(255,255,255,.5)}
.area-card--cta .area-arrow{color:var(--copper-light)}
.area-card--cta:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}

/* --- Why Choose --- */
.why-grid{display:grid;gap:var(--sp-10)}
.why-list{list-style:none}
.why-item{display:flex;gap:var(--sp-4);align-items:flex-start;margin-bottom:var(--sp-5)}
.why-check{width:28px;height:28px;border-radius:50%;background:rgba(45,147,108,.1);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.why-check svg{width:14px;height:14px;color:var(--success)}
.why-text{font-size:var(--text-base);color:var(--gray-600);line-height:1.6}
.why-text strong{color:var(--navy-800);font-weight:700}

/* Stats grid */
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-4)}
.stat-card{background:var(--white-pure);border:1px solid var(--gray-100);border-radius:var(--r-xl);padding:var(--sp-6);text-align:center;transition:all var(--t-base)}
.stat-card:hover{border-color:var(--copper);box-shadow:var(--sh-md);transform:translateY(-3px)}
.stat-number{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:800;color:var(--copper);line-height:1;margin-bottom:var(--sp-2)}
.stat-label{font-size:var(--text-xs);color:var(--gray-400);font-weight:600;text-transform:uppercase;letter-spacing:.05em}

/* --- FAQ --- */
.faq-list{max-width:780px;margin:0 auto}
.faq-item{background:var(--white-pure);border:1px solid var(--gray-100);border-radius:var(--r-xl);margin-bottom:var(--sp-4);overflow:hidden;transition:border-color var(--t-fast)}
.faq-item.active{border-color:var(--copper)}
.faq-question{padding:var(--sp-5) var(--sp-6);font-weight:700;font-size:var(--text-base);color:var(--navy-800);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:var(--sp-4);transition:color var(--t-fast);-webkit-user-select:none;user-select:none}
.faq-question:hover{color:var(--copper)}
.faq-chevron{width:20px;height:20px;color:var(--gray-300);transition:transform var(--t-base),color var(--t-fast);flex-shrink:0}
.faq-item.active .faq-chevron{transform:rotate(180deg);color:var(--copper)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s var(--ease-out),padding .4s var(--ease-out)}
.faq-answer-inner{padding:0 var(--sp-6) var(--sp-6);color:var(--gray-600);font-size:var(--text-sm);line-height:1.7}
.faq-answer-inner p{margin-bottom:var(--sp-3)}
.faq-answer-inner ol,.faq-answer-inner ul{margin-left:var(--sp-5);margin-bottom:var(--sp-3)}
.faq-answer-inner li{margin-bottom:var(--sp-2);color:var(--gray-600)}
.faq-answer-inner strong{color:var(--navy-800)}

/* --- CTA Section --- */
.cta-section{padding:var(--sp-20) 0;background:linear-gradient(135deg,var(--navy-950) 0%,var(--navy-800) 100%);color:var(--white);position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;top:-40%;right:-15%;width:500px;height:500px;background:radial-gradient(circle,rgba(194,117,49,.2) 0%,transparent 60%);border-radius:50%}
.cta-section::after{content:'';position:absolute;bottom:-30%;left:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(46,94,163,.12) 0%,transparent 60%);border-radius:50%}
.cta-inner{position:relative;z-index:1;text-align:center;max-width:640px;margin:0 auto}
.cta-title{color:var(--white-pure);margin-bottom:var(--sp-4)}
.cta-desc{font-size:var(--text-lg);color:rgba(255,255,255,.7);margin-bottom:var(--sp-8)}
.cta-buttons{display:flex;flex-direction:column;gap:var(--sp-4);align-items:center}

/* --- Footer --- */
.footer{background:var(--navy-950);color:var(--gray-400);padding:var(--sp-16) 0 var(--sp-8)}
.footer-grid{display:grid;gap:var(--sp-8);margin-bottom:var(--sp-12)}
.footer-brand{max-width:280px}
.footer-logo{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-4)}
.footer-logo-mark{width:36px;height:36px;background:var(--navy-700);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--copper-light)}
.footer-logo-text{font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;color:var(--white-pure)}
.footer-desc{font-size:var(--text-sm);line-height:1.7;color:var(--gray-500)}
.footer-heading{font-family:var(--font-body);font-size:var(--text-xs);font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--gray-300);margin-bottom:var(--sp-4)}
.footer-links{list-style:none}
.footer-link{display:block;padding:var(--sp-2) 0;font-size:var(--text-sm);color:var(--gray-500);transition:color var(--t-fast)}
.footer-link:hover{color:var(--copper-light)}
.footer-bottom{padding-top:var(--sp-8);border-top:1px solid rgba(255,255,255,.06)}
.footer-bottom-inner{display:flex;flex-direction:column;gap:var(--sp-4);text-align:center}
.footer-copyright{font-size:var(--text-xs);color:var(--gray-600)}
.footer-disclosure{font-size:var(--text-xs);color:var(--gray-600);line-height:1.7;max-width:600px;margin:0 auto}
.footer-disclosure strong{color:var(--gray-400)}

/* --- Content Pages (sub-pages) --- */
.breadcrumb{padding:var(--sp-4) 0;background:var(--gray-50);border-bottom:1px solid var(--gray-100)}
.breadcrumb-list{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--text-xs);flex-wrap:wrap}
.breadcrumb-link{color:var(--gray-500);transition:color var(--t-fast)}
.breadcrumb-link:hover{color:var(--copper)}
.breadcrumb-sep{color:var(--gray-300)}
.breadcrumb-current{color:var(--gray-400)}

.page-hero{background:linear-gradient(135deg,var(--navy-950) 0%,var(--navy-800) 100%);color:var(--white);padding:var(--sp-12) 0;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;top:-50%;right:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(194,117,49,.15) 0%,transparent 60%);border-radius:50%}
.page-hero-inner{position:relative;z-index:1}
.page-tag{display:inline-block;font-size:var(--text-xs);font-weight:700;color:var(--copper-bright);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--sp-4)}
.page-title{color:var(--white-pure);margin-bottom:var(--sp-3)}
.page-subtitle{font-size:var(--text-lg);color:rgba(255,255,255,.7);margin-bottom:var(--sp-6);max-width:640px}

.content-section{padding:var(--sp-16) 0}
.content-grid{display:grid;gap:var(--sp-8)}
.content-main{min-width:0}
.content-sidebar{display:none}

.content-card{background:var(--white-pure);border:1px solid var(--gray-100);border-radius:var(--r-2xl);padding:var(--sp-8);margin-bottom:var(--sp-6)}
.content-card h2{font-size:var(--text-2xl)}
.content-card h3{font-size:var(--text-xl)}
.content-card p{margin-bottom:var(--sp-4)}
.content-card ul,.content-card ol{margin-left:var(--sp-6);margin-bottom:var(--sp-4)}
.content-card li{margin-bottom:var(--sp-2);color:var(--gray-600)}

.quick-cta{background:linear-gradient(135deg,var(--navy-800) 0%,var(--navy-700) 100%);border-radius:var(--r-2xl);padding:var(--sp-8);text-align:center;color:var(--white)}
.quick-cta-title{color:var(--white-pure);font-size:var(--text-xl);margin-bottom:var(--sp-3)}
.quick-cta-desc{color:rgba(255,255,255,.75);font-size:var(--text-sm);margin-bottom:var(--sp-5)}

/* --- Responsive --- */
@media(min-width:640px){
  .hero-actions{flex-direction:row}
  .trust-bar-inner{grid-template-columns:repeat(4,1fr)}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .areas-grid{grid-template-columns:repeat(3,1fr)}
  .cta-buttons{flex-direction:row;justify-content:center}
  .stats-grid{grid-template-columns:repeat(4,1fr)}
  .footer-bottom-inner{flex-direction:row;justify-content:space-between;text-align:left}
}

@media(min-width:768px){
  .nav{display:flex}
  .header-cta{display:inline-flex}
  .menu-toggle{display:none}
  .hero-inner{grid-template-columns:1.1fr .9fr;gap:var(--sp-12);text-align:left}
  .hero-content{text-align:left}
  .hero-desc{margin-inline:0}
  .hero-actions{justify-content:flex-start}
  .hero-trust{justify-content:flex-start}
  .steps-grid{grid-template-columns:repeat(3,1fr)}
  .step{flex-direction:column;text-align:center;align-items:center}
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}
  .why-grid{grid-template-columns:1fr 1fr;gap:var(--sp-12);align-items:start}
}

@media(min-width:1024px){
  .services-grid{grid-template-columns:repeat(3,1fr)}
  .areas-grid{grid-template-columns:repeat(4,1fr)}
  .content-grid{grid-template-columns:1fr 340px;gap:var(--sp-10)}
  .content-sidebar{display:block}
}

/* --- Print --- */
@media print{
  .header,.e-banner,.cta-section,.footer,.btn,.mobile-nav{display:none}
  body{font-size:12pt;color:#000}
  h1,h2,h3{page-break-after:avoid;color:#000}
}
