/* ================================================================
   THE LANDSCAPE WORKSHOP — STYLESHEET v3
   Vibrant emerald + bold orange palette, chunky contemporary type
   ================================================================ */

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

:root {
  /* Core palette — lettuce green primary + yellow accent (EDP-style) */
  --blue:         #D2D300;       /* PRIMARY — lettuce/lime green */
  --blue-bright:  #E8E91A;
  --blue-dark:    #A8A900;
  --blue-darker:  #112337;       /* dark navy for dark sections */
  --blue-mid:     #B8B900;
  --blue-light:   #E8E91A;
  --blue-pale:    #FAFCE0;       /* very pale lime tint */
  --blue-ultra:   #FDFDF2;       /* almost white with lime hint */

  /* Yellow accent — kept from previous round */
  --yellow:       #E5C000;
  --yellow-bright:#FFD400;
  --yellow-dark:  #B89A00;
  --yellow-pale:  #FFF8D6;

  /* Aliased green vars — same as blue (the primary now IS green) */
  --green:        #D2D300;
  --green-bright: #E8E91A;
  --green-dark:   #A8A900;
  --green-darker: #112337;
  --green-pale:   #FAFCE0;
  --green-ultra:  #FDFDF2;
  --green-accent: #E8E91A;

  /* Legacy orange vars — mapped to yellow */
  --orange:       #E5C000;
  --orange-bright:#FFD400;
  --orange-dark:  #B89A00;
  --orange-pale:  #FFF8D6;

  /* Backgrounds + neutrals */
  --cream:        #FAFAFC;
  --cream-2:      #F2F3F5;
  --white:        #FFFFFF;
  --off-white:    #F9F9FB;
  --stone:        #F2F3F5;

  --ink:          #112337;       /* dark navy for body text */
  --ink-mid:      #585e6a;
  --ink-light:    #686e77;
  --ink-soft:     #9aa0aa;
  --border:       #D4D6DA;
  --border-light: #E6E7EB;

  --nav-h:        76px;
  --radius:       8px;
  --shadow-sm:    0 2px 8px rgba(17,35,55,.08);
  --shadow-md:    0 12px 36px rgba(17,35,55,.12);
  --shadow-lg:    0 24px 70px rgba(17,35,55,.18);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:'Inter',system-ui,sans-serif;font-size:17px;line-height:1.65;color:var(--ink);background:var(--cream);font-weight:400;font-feature-settings:"ss01","cv11"}
img{max-width:100%;height:auto;display:block}

/* TYPOGRAPHY — Sora (chunky modern geometric sans, EDP-style) + Inter body */
h1,h2,h3{font-family:'Sora','Inter',system-ui,sans-serif;line-height:1.08;color:var(--ink);letter-spacing:-.025em;font-weight:700}
h4,h5,h6{font-family:'Inter',sans-serif;line-height:1.25;color:var(--ink);font-weight:700}
h1{font-size:clamp(2.4rem,5.5vw,4.4rem);font-weight:800;letter-spacing:-.035em}
h2{font-size:clamp(1.85rem,3.6vw,3rem);font-weight:700;letter-spacing:-.03em}
h3{font-size:clamp(1.15rem,2vw,1.55rem);font-weight:700;letter-spacing:-.018em}
h4{font-size:.74rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--yellow-dark)}
h5{font-size:1rem;font-weight:700}
em,i{font-style:italic}

p{color:var(--ink-mid);margin-bottom:1em;font-weight:400}
p:last-child{margin-bottom:0}
a{color:var(--green-dark);text-decoration:none;transition:color .2s}
a:hover{color:var(--orange-dark)}
strong{font-weight:700;color:var(--ink)}

/* LAYOUT */
.container{max-width:1280px;margin:0 auto;padding:0 32px}
.container--narrow{max-width:880px;margin:0 auto;padding:0 32px}
.section{padding:110px 0}
.section-sm{padding:64px 0}
.section--blue-dark{background:var(--green-darker);color:var(--cream)}
.section--blue-dark h1,.section--blue-dark h2,.section--blue-dark h3{color:var(--cream)}
.section--blue{background:var(--green)}
.section--blue-pale{background:var(--green-ultra)}
.section--stone{background:var(--cream)}
.section--green-pale{background:var(--green-pale)}
.section--cream{background:var(--cream)}
.section--cream-2{background:var(--cream-2)}

/* SCROLL ANIMATIONS — with CSS fallback so content is visible even if JS fails */
@keyframes revealUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes revealLeft{from{opacity:0;transform:translateX(-24px)}to{opacity:1;transform:none}}
@keyframes revealRight{from{opacity:0;transform:translateX(24px)}to{opacity:1;transform:none}}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .55s ease,transform .55s ease;animation:revealUp .6s ease 1.5s forwards}
.reveal.visible{opacity:1;transform:none;animation:none}
.reveal-left{opacity:0;transform:translateX(-24px);transition:opacity .55s ease,transform .55s ease;animation:revealLeft .6s ease 1.5s forwards}
.reveal-left.visible{opacity:1;transform:none;animation:none}
.reveal-right{opacity:0;transform:translateX(24px);transition:opacity .55s ease,transform .55s ease;animation:revealRight .6s ease 1.5s forwards}
.reveal-right.visible{opacity:1;transform:none;animation:none}
.delay-1{transition-delay:.1s}
.delay-2{transition-delay:.2s}
.delay-3{transition-delay:.3s}
.delay-4{transition-delay:.4s}

/* BUTTONS — chunky pill */
.btn{display:inline-flex;align-items:center;gap:10px;padding:18px 36px;border-radius:9999px;font-family:'Inter',sans-serif;font-size:.95rem;font-weight:700;letter-spacing:.005em;cursor:pointer;border:none;transition:all .25s ease;text-decoration:none;white-space:nowrap}
.btn svg{width:16px;height:16px;flex-shrink:0}
/* Primary — lettuce green with dark text */
.btn-primary{background:var(--blue);color:var(--ink)}
.btn-primary:hover{background:var(--blue-bright);color:var(--ink);transform:translateY(-2px);box-shadow:0 12px 28px rgba(210,211,0,.45)}
/* "Get a quote" / "Email us for a quote" CTA — dark navy (matches footer) */
.btn-green{background:#112337;color:var(--white)}
.btn-green:hover{background:#1f3550;color:var(--white);transform:translateY(-2px);box-shadow:0 12px 28px rgba(17,35,55,.4)}
.btn-yellow{background:var(--yellow);color:var(--ink)}
.btn-yellow:hover{background:var(--yellow-bright);color:var(--ink);transform:translateY(-2px);box-shadow:0 12px 28px rgba(229,192,0,.45)}
.btn-outline{background:transparent;color:var(--white);border:2px solid rgba(255,255,255,.6)}
.btn-outline:hover{border-color:var(--white);color:var(--ink);background:var(--white)}
.btn-outline-blue{background:transparent;color:var(--ink);border:2px solid var(--blue-dark)}
.btn-outline-blue:hover{background:var(--blue);color:var(--ink);border-color:var(--blue)}
.btn-sm{padding:12px 24px;font-size:.84rem}

/* LABEL / EYEBROW */
.eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--yellow-pale);border:1px solid rgba(229,192,0,.4);color:var(--yellow-dark);font-size:.72rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:8px 16px;border-radius:9999px;margin-bottom:22px;font-family:'Inter',sans-serif}
.eyebrow--white{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.28);color:rgba(255,255,255,.95)}
.eyebrow--green{background:var(--green-pale);border-color:rgba(22,163,74,.3);color:var(--green-dark)}

/* ================================================================
   NAVIGATION — transparent over hero, solid on scroll
   ================================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:500;height:var(--nav-h);background:transparent;transition:background .35s ease,box-shadow .35s ease,backdrop-filter .35s ease}
.nav.scrolled{background:rgba(10,10,10,.85);backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(255,255,255,.06)}
/* Inner pages without hero — give nav a default solid background */
body.nav-solid .nav{background:rgba(10,10,10,.92);backdrop-filter:blur(14px)}
.nav__inner{height:100%;display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav__logo{display:flex;align-items:center;gap:0;text-decoration:none;flex-shrink:0}
.nav__logo-mark{display:none}
.nav__logo-text{font-family:'Inter',sans-serif;font-size:1.4rem;font-weight:800;color:var(--white);line-height:1;letter-spacing:-.05em}
.nav__logo-text small{display:none}
.nav__links{display:flex;align-items:center;gap:4px;list-style:none}
.nav__links > li > a{font-family:'Inter',sans-serif;font-size:.86rem;font-weight:600;color:rgba(255,255,255,.85);padding:10px 16px;border-radius:9999px;transition:all .2s;letter-spacing:.005em;position:relative}
.nav__links > li > a:hover{color:var(--white);background:rgba(255,255,255,.1)}
.nav__links > li > a.is-active{color:var(--ink);background:#D2D300}
.nav__links > li > a.is-active:hover{background:#E8E91A;color:var(--ink)}
.mobile-nav ul a.is-active{color:#D2D300;font-weight:700}
.nav__links .nav-cta{background:#112337!important;color:var(--white)!important;padding:12px 22px;border-radius:9999px;font-weight:700;margin-left:8px;border:1.5px solid rgba(255,255,255,.25)}
.nav__links .nav-cta:hover{background:#1f3550!important;transform:translateY(-1px);border-color:rgba(255,255,255,.4)}
.nav__hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px}
.nav__hamburger span{display:block;width:24px;height:2.5px;background:white;border-radius:2px;margin:5px 0;transition:.3s}

/* MOBILE MENU */
.mobile-nav{display:none;position:fixed;top:var(--nav-h);left:0;right:0;z-index:499;background:rgba(10,10,10,.96);backdrop-filter:blur(14px);border-top:1px solid rgba(255,255,255,.08);padding:24px 32px 32px}
.mobile-nav.open{display:block}
.mobile-nav ul{list-style:none}
.mobile-nav ul a{display:block;padding:14px 0;color:rgba(255,255,255,.9);font-size:1.05rem;font-weight:600;border-bottom:1px solid rgba(255,255,255,.08);font-family:'Inter',sans-serif}
.mobile-nav .btn{width:100%;justify-content:center;margin-top:20px}

/* ================================================================
   HERO
   ================================================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:var(--ink)}
.hero__bg{position:absolute;inset:0;background-image:url('../img/hero.jpg');background-size:cover;background-position:center 40%}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.55) 0%,rgba(10,10,10,.25) 35%,rgba(10,10,10,.55) 100%)}
.hero__shapes{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.hero__shapes::before{content:'';position:absolute;width:600px;height:600px;border:1px solid rgba(44,123,179,.15);border-radius:50%;right:-100px;top:-100px}
.hero__shapes::after{content:'';position:absolute;width:350px;height:350px;background:radial-gradient(circle,rgba(61,170,110,.08) 0%,transparent 70%);right:100px;bottom:100px}
.hero__inner{position:relative;z-index:2;width:100%;padding:calc(var(--nav-h) + 48px) 0 80px}
.hero__content{max-width:720px}
.hero h1{color:var(--white);margin-bottom:20px}
.hero h1 em{font-style:italic;color:var(--green-accent)}
.hero__sub{font-size:1.1rem;color:rgba(255,255,255,.72);margin-bottom:36px;max-width:600px;line-height:1.75}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px}
.hero__trust{display:flex;gap:28px;flex-wrap:wrap}
.hero__trust-item{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.6);font-size:.82rem}
.hero__trust-item svg{width:14px;height:14px;stroke:var(--green-accent);flex-shrink:0}

/* ================================================================
   STATS BAR
   ================================================================ */
.stats-bar{background:#112337;padding:0}
.stats-bar__inner{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;border-right:1px solid rgba(255,255,255,.08);text-align:center;min-height:124px}
.stat-item:last-child{border-right:none}
.stat-item__num{font-family:'Sora',sans-serif;font-size:2.4rem;font-weight:800;color:var(--white);line-height:1;letter-spacing:-.025em;display:flex;align-items:baseline;justify-content:center;min-height:38px}
.stat-item__num > span{font-size:inherit;color:inherit;font-weight:inherit}
.stat-item__num--cmli{color:#D2D300;letter-spacing:.02em}
.stat-item__label{font-size:.72rem;color:rgba(255,255,255,.55);margin-top:10px;letter-spacing:.05em;font-weight:600;text-transform:uppercase}

/* ================================================================
   INTRO / TWO-COL
   ================================================================ */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.two-col--reverse{direction:rtl}
.two-col--reverse > *{direction:ltr}
.two-col__image{position:relative;border-radius:var(--radius);overflow:hidden}
.two-col__image img{width:100%;height:480px;object-fit:cover;border-radius:var(--radius)}
.two-col__image-badge{position:absolute;bottom:24px;left:24px;background:var(--blue-darker);color:var(--white);padding:14px 18px;border-radius:var(--radius);box-shadow:var(--shadow-md)}
.two-col__image-badge strong{display:block;font-size:1.4rem;font-family:'Sora',sans-serif;color:var(--green-accent);line-height:1}
.two-col__image-badge span{font-size:.7rem;color:rgba(255,255,255,.55);letter-spacing:.06em;text-transform:uppercase}
.two-col__text h2{margin-bottom:16px}
.two-col__text p{margin-bottom:14px}
.check-list{list-style:none;margin:22px 0}
.check-list li{display:flex;align-items:flex-start;gap:10px;font-size:.9rem;color:var(--ink-mid);margin-bottom:10px}
.check-list li::before{content:'';width:18px;height:18px;flex-shrink:0;margin-top:2px;background:var(--blue-pale) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 6l3 3 5-5' stroke='%23A8A900' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/10px no-repeat;border:1.5px solid rgba(168,169,0,.45);border-radius:50%}

/* ================================================================
   SERVICE CARDS
   ================================================================ */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border-light);border:1px solid var(--border-light);border-radius:var(--radius);overflow:hidden}
.svc-card{background:var(--white);padding:36px 28px;transition:background .2s,box-shadow .2s;position:relative}
.svc-card:hover{background:var(--blue-ultra);box-shadow:inset 0 0 0 2px var(--blue)}
.svc-card__num{font-family:'Sora',sans-serif;font-size:2.2rem;font-weight:700;color:var(--blue-pale);line-height:1;margin-bottom:14px;transition:color .2s}
.svc-card:hover .svc-card__num{color:var(--blue-light)}
.svc-card h3{font-size:1.05rem;margin-bottom:10px;color:var(--blue-darker)}
.svc-card p{font-size:.875rem;margin-bottom:0}
.svc-card__price{display:inline-block;margin-top:16px;font-size:.82rem;font-weight:700;color:var(--green-dark);background:var(--green-pale);padding:4px 10px;border-radius:4px}
.svc-card__link{display:inline-flex;align-items:center;gap:5px;margin-top:16px;font-size:.82rem;font-weight:600;color:var(--blue)}
.svc-card__link svg{width:13px;height:13px;stroke:currentColor;fill:none;transition:transform .2s}
.svc-card:hover .svc-card__link svg{transform:translateX(3px)}

/* ================================================================
   PRICING MATRIX
   ================================================================ */
.pricing-matrix-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius);box-shadow:var(--shadow-md)}
.pricing-matrix{width:100%;border-collapse:collapse;min-width:680px;background:var(--white)}
.pricing-matrix th{background:var(--blue-darker);color:var(--white);padding:16px 20px;text-align:left;font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}
.pricing-matrix th:not(:first-child){text-align:center;min-width:160px}
.pricing-matrix th.col-highlight{background:var(--blue)}
.pricing-matrix td{padding:16px 20px;border-bottom:1px solid var(--border-light);font-size:.88rem;vertical-align:middle}
.pricing-matrix td:not(:first-child){text-align:center}
.pricing-matrix tr:last-child td{border-bottom:none}
.pricing-matrix tr:hover td{background:var(--blue-ultra)}
.pm-service{font-weight:600;color:var(--ink);font-size:.88rem}
.pm-desc{font-size:.75rem;color:var(--ink-light);margin-top:3px;font-weight:400}
.pm-price{font-weight:700;color:var(--blue-dark);font-size:.95rem}
.pm-price small{display:block;font-size:.68rem;font-weight:400;color:var(--ink-light);margin-top:1px}
.pm-price--highlight{color:var(--green-dark)}
.pm-na{color:var(--border);font-size:.8rem}
.matrix-col-label{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue-light);display:block}
.matrix-col-sub{font-size:.65rem;color:rgba(255,255,255,.55);font-weight:400;letter-spacing:0;text-transform:none}
.pricing-note{font-size:.78rem;color:var(--ink-light);margin-top:14px;text-align:center}

/* ================================================================
   PROCESS / INFOGRAPHIC
   ================================================================ */
.process-diagram{display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative;padding:40px 0 0}
.process-diagram::before{content:'';position:absolute;top:68px;left:calc(10% + 20px);right:calc(10% + 20px);height:2px;background:linear-gradient(90deg,var(--blue-pale),var(--blue),var(--green),var(--green-pale));border-radius:2px}
.process-step{display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 12px;position:relative;z-index:1}
.process-step__circle{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-family:'Sora',sans-serif;font-size:1.1rem;font-weight:700;color:var(--white);position:relative;cursor:pointer;transition:transform .25s,box-shadow .25s}
.process-step__circle:hover{transform:scale(1.1);box-shadow:0 8px 24px rgba(44,123,179,.3)}
.process-step__circle--blue{background:linear-gradient(135deg,var(--blue-dark),var(--blue))}
.process-step__circle--green{background:linear-gradient(135deg,var(--green-dark),var(--green))}
.process-step__line{position:absolute;top:50%;right:-50%;width:100%;height:2px;background:var(--border-light);z-index:-1}
.process-step h5{font-size:.85rem;font-weight:700;color:var(--blue-darker);margin-bottom:7px}
.process-step p{font-size:.74rem;color:var(--ink-light);line-height:1.5}
.process-step__tooltip{display:none;position:absolute;bottom:calc(100% + 14px);left:50%;transform:translateX(-50%);background:var(--blue-darker);color:var(--white);padding:12px 16px;border-radius:var(--radius);font-size:.75rem;width:210px;text-align:left;line-height:1.5;z-index:10;box-shadow:var(--shadow-md)}
.process-step__tooltip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:6px solid transparent;border-top-color:var(--blue-darker)}
.process-step:hover .process-step__tooltip{display:block}

/* ================================================================
   MAP
   ================================================================ */
.map-section{position:relative;overflow:hidden}
.map-container{width:100%;height:480px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--border-light)}
#project-map{width:100%;height:100%}
.map-legend{display:flex;gap:20px;margin-top:16px;flex-wrap:wrap}
.map-legend-item{display:flex;align-items:center;gap:7px;font-size:.78rem;color:var(--ink-light)}
.map-dot-legend{width:12px;height:12px;border-radius:50%;flex-shrink:0}

/* ================================================================
   QUOTE FORM
   ================================================================ */
.quote-grid{display:grid;grid-template-columns:1fr 440px;gap:72px;align-items:start}
.form-card{background:var(--white);border:1px solid var(--border-light);border-radius:var(--radius);padding:36px;box-shadow:var(--shadow-md)}
.form-card h3{font-size:1.2rem;margin-bottom:4px}
.form-card > p{font-size:.82rem;color:var(--ink-light);margin-bottom:24px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-group{margin-bottom:12px}
.form-group label{display:block;font-size:.74rem;font-weight:600;color:var(--ink-mid);margin-bottom:5px;letter-spacing:.02em}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 13px;border:1.5px solid var(--border-light);border-radius:5px;font-family:'Inter',sans-serif;font-size:.875rem;color:var(--ink);background:var(--white);transition:border-color .2s,box-shadow .2s;appearance:none;-webkit-appearance:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(44,123,179,.1)}
.form-group textarea{resize:vertical;min-height:90px}
.form-submit{width:100%;justify-content:center;margin-top:4px}
.form-note{font-size:.71rem;color:var(--ink-light);text-align:center;margin-top:10px}
.form-honeypot{display:none}

/* DETAIL ITEMS */
.detail-items{display:flex;flex-direction:column;gap:16px;margin-top:28px}
.detail-item{display:flex;gap:14px;align-items:flex-start}
.detail-icon{width:40px;height:40px;flex-shrink:0;background:var(--blue-pale);border-radius:var(--radius);display:flex;align-items:center;justify-content:center}
.detail-icon svg{width:18px;height:18px;stroke:var(--blue);fill:none}
.detail-text strong{display:block;font-size:.85rem;margin-bottom:2px;color:var(--ink)}
.detail-text span{font-size:.8rem;color:var(--ink-light)}

/* ================================================================
   LOCATIONS GRID
   ================================================================ */
.locations-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.loc-card{background:var(--white);border:1.5px solid var(--border-light);border-radius:12px;transition:all .25s ease;overflow:hidden}
.loc-card:hover{border-color:var(--blue);box-shadow:0 14px 36px rgba(17,35,55,.1);transform:translateY(-3px)}
.loc-card a{text-decoration:none;color:inherit;display:block;padding:24px 22px}
.loc-card h4{font-family:'Sora','Inter',sans-serif;font-size:1.15rem;font-weight:700;letter-spacing:-.015em;color:var(--ink);margin-bottom:14px;text-transform:none}
.loc-card__example-label{display:inline-block;font-family:'Inter',sans-serif;font-size:.62rem;font-weight:800;letter-spacing:.13em;text-transform:uppercase;color:var(--blue-dark);background:var(--blue-pale);padding:4px 10px;border-radius:9999px;margin-bottom:10px}
.loc-card__example{font-family:'Inter',sans-serif;font-size:.92rem;color:var(--ink-mid);line-height:1.5;margin:0;font-weight:500}
.loc-card--cta{background:#112337;border-color:#112337}
.loc-card--cta h4,.loc-card--cta .loc-card__example{color:var(--white)}
.loc-card--cta .loc-card__example-label{background:rgba(255,255,255,.12);color:var(--blue-bright)}
.loc-card--cta:hover{background:#1f3550;border-color:#1f3550}
@media(max-width:1100px){.locations-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:780px){.locations-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.locations-grid{grid-template-columns:1fr}}

/* ================================================================
   FAQ
   ================================================================ */
.faq-list{list-style:none;border:1px solid var(--border-light);border-radius:var(--radius);overflow:hidden}
.faq-item{border-bottom:1px solid var(--border-light)}
.faq-item:last-child{border-bottom:none}
.faq-q{width:100%;background:none;border:none;text-align:left;padding:20px 24px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;font-size:.92rem;font-weight:600;color:var(--ink);font-family:'Inter',sans-serif;transition:background .15s}
.faq-q:hover{background:var(--blue-ultra)}
.faq-q svg{width:18px;height:18px;stroke:var(--blue);flex-shrink:0;transition:transform .25s}
.faq-item.open .faq-q svg{transform:rotate(45deg)}
.faq-a{display:none;padding:0 24px 20px;font-size:.875rem;color:var(--ink-mid);line-height:1.75}
.faq-item.open .faq-a{display:block}

/* ================================================================
   BREADCRUMB
   ================================================================ */
.breadcrumb{display:flex;align-items:center;gap:6px;list-style:none;font-size:.75rem;color:rgba(255,255,255,.5);flex-wrap:wrap;margin-bottom:18px}
.breadcrumb li::after{content:'/';margin-left:6px;opacity:.4}
.breadcrumb li:last-child::after{display:none}
.breadcrumb a{color:rgba(255,255,255,.65)}
.breadcrumb a:hover{color:var(--white)}
.breadcrumb--dark li{color:var(--ink-light)}
.breadcrumb--dark li::after{color:var(--border)}
.breadcrumb--dark a{color:var(--blue)}

/* ================================================================
   OFFICES
   ================================================================ */
.offices-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.office-card{background:var(--white);border:1.5px solid var(--border-light);border-radius:var(--radius);padding:28px;transition:all .2s}
.office-card:hover{border-color:var(--blue);box-shadow:var(--shadow-sm)}
.office-card__region{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--green-dark);margin-bottom:8px}
.office-card h3{font-size:1.05rem;margin-bottom:12px;color:var(--blue-darker)}
.office-card address{font-style:normal;font-size:.85rem;color:var(--ink-mid);line-height:1.7}
.office-card a{color:var(--blue)}

/* ================================================================
   CREDENTIALS
   ================================================================ */
.creds-bar{background:var(--blue-dark);padding:28px 0;border-top:1px solid rgba(255,255,255,.06)}
.creds-bar__inner{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.creds-bar__text{font-size:.8rem;color:rgba(255,255,255,.4);font-style:italic}
.creds-bar__logos{display:flex;gap:24px;flex-wrap:wrap}
.cred-pill{display:flex;align-items:center;gap:7px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.65);font-size:.75rem;font-weight:500;padding:6px 12px;border-radius:20px}
.cred-pill svg{width:13px;height:13px;stroke:var(--green-accent);fill:none}

/* ================================================================
   PAGE HEADER (inner pages) — chunky, charcoal
   ================================================================ */
.page-header{background:var(--ink);padding:calc(var(--nav-h) + 80px) 0 80px;position:relative;overflow:hidden}
.page-header::after{content:'';position:absolute;right:-120px;top:-120px;width:520px;height:520px;border:1.5px solid rgba(255,255,255,.06);border-radius:50%;pointer-events:none}
.page-header::before{content:'';position:absolute;right:80px;bottom:-160px;width:320px;height:320px;background:radial-gradient(circle,rgba(249,115,22,.18) 0%,transparent 70%);border-radius:50%;pointer-events:none}
.page-header h4{color:var(--orange-bright);margin-bottom:14px}
.page-header h1{color:var(--white);margin-bottom:18px}
.page-header p{color:rgba(255,255,255,.75);max-width:620px;font-size:1.1rem;line-height:1.6}

/* ================================================================
   FOOTER
   ================================================================ */
.footer{background:var(--blue-darker);padding:60px 0 32px}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:48px;margin-bottom:48px}
.footer__brand p{font-size:.83rem;color:rgba(255,255,255,.4);margin-top:16px;max-width:270px;line-height:1.65}
.footer__col h4{color:rgba(255,255,255,.3);margin-bottom:14px}
.footer__col ul{list-style:none}
.footer__col ul li{margin-bottom:9px}
.footer__col ul a{font-size:.83rem;color:rgba(255,255,255,.5);transition:color .2s}
.footer__col ul a:hover{color:var(--green-accent)}
.footer__col address{font-style:normal}
.footer__col address p{font-size:.8rem;color:rgba(255,255,255,.42);margin-bottom:3px}
.footer__col address a{font-size:.8rem;color:rgba(255,255,255,.5)}
.footer__col address a:hover{color:var(--green-accent)}
.footer__bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer__bottom p{font-size:.75rem;color:rgba(255,255,255,.28);margin:0}

/* ================================================================
   LOCAL AREA PAGE
   ================================================================ */
.local-hero{background:linear-gradient(135deg,var(--blue-darker),var(--blue-dark));padding:calc(var(--nav-h) + 64px) 0 64px}
.local-area__grid{display:grid;grid-template-columns:1fr 360px;gap:56px;align-items:start}
.local-sidebar{background:var(--blue-pale);border:1px solid rgba(44,123,179,.15);border-radius:var(--radius);padding:28px}
.local-sidebar h3{font-size:1rem;margin-bottom:16px}
.local-sidebar ul{list-style:none}
.local-sidebar ul li{border-bottom:1px solid rgba(44,123,179,.1);padding:10px 0;font-size:.85rem}
.local-sidebar ul li:last-child{border-bottom:none}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media(max-width:1100px){
  .two-col{gap:48px}
  .services-grid{grid-template-columns:1fr 1fr}
  .footer__grid{grid-template-columns:1fr 1fr}
  .locations-grid{grid-template-columns:repeat(3,1fr)}
  .local-area__grid{grid-template-columns:1fr}
}
@media(max-width:900px){
  .nav__links{display:none}
  .nav__hamburger{display:block}
  .process-diagram{grid-template-columns:1fr 1fr;gap:32px}
  .process-diagram::before{display:none}
  .quote-grid{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  .two-col--reverse{direction:ltr}
  .two-col__image{display:none}
  .stats-bar__inner{grid-template-columns:1fr 1fr}
  .stat-item:nth-child(2){border-right:none}
  .offices-grid{grid-template-columns:1fr}
  .locations-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .services-grid{grid-template-columns:1fr}
  .process-diagram{grid-template-columns:1fr}
  .hero__actions{flex-direction:column}
  .footer__grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .locations-grid{grid-template-columns:1fr 1fr}
  .creds-bar__inner{flex-direction:column;text-align:center}
}

/* LOCATION PAGE SPECIFIC */
.loc-intro{font-size:1.05rem;color:var(--ink-mid);line-height:1.8;max-width:720px}

/* ================================================================
   FLIP CARDS — services page
   ================================================================ */
.flip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.flip-card{perspective:1500px;height:420px;cursor:pointer}
.flip-card__inner{position:relative;width:100%;height:100%;transition:transform .7s cubic-bezier(.4,.2,.2,1);transform-style:preserve-3d;border-radius:var(--radius);box-shadow:var(--shadow-md)}
.flip-card.flipped .flip-card__inner,.flip-card:hover .flip-card__inner{transform:rotateY(180deg)}
.flip-card__face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--radius);padding:36px 30px;display:flex;flex-direction:column;overflow:hidden}
.flip-card__front{background:var(--white);border:1px solid var(--border-light)}
.flip-card__back{background:#112337;color:var(--white);transform:rotateY(180deg)}
.flip-card__num{font-family:'Sora',sans-serif;font-size:2.6rem;font-weight:700;color:var(--blue-light);line-height:1;margin-bottom:14px;opacity:.5}
.flip-card__icon{width:54px;height:54px;border-radius:12px;background:var(--blue-pale);display:flex;align-items:center;justify-content:center;margin-bottom:18px;flex-shrink:0}
.flip-card__icon svg{width:26px;height:26px;stroke:var(--blue);fill:none;stroke-width:1.6}
.flip-card__front h3{font-size:1.2rem;color:var(--blue-darker);margin-bottom:10px;line-height:1.25}
.flip-card__front p{font-size:.86rem;color:var(--ink-mid);line-height:1.65;margin-bottom:16px}
.flip-card__price-tag{display:inline-flex;align-items:center;gap:6px;background:var(--green-pale);border:1px solid rgba(61,170,110,.25);color:var(--green-dark);font-size:.78rem;font-weight:700;padding:6px 12px;border-radius:20px;margin-top:auto;align-self:flex-start}
.flip-card__hint{position:absolute;bottom:18px;right:22px;font-size:.7rem;color:var(--ink-light);display:flex;align-items:center;gap:5px;letter-spacing:.04em;text-transform:uppercase;font-weight:600}
.flip-card__hint svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2}
.flip-card__back h3{font-size:1.05rem;color:var(--white);margin-bottom:14px;font-family:'Sora',sans-serif;font-weight:600}
.flip-card__back h4{color:var(--green-accent);font-size:.66rem;letter-spacing:.13em;margin:0 0 8px}
.flip-card__back ul{list-style:none;margin-bottom:14px}
.flip-card__back ul li{font-size:.78rem;color:rgba(255,255,255,.75);padding:4px 0 4px 16px;position:relative;line-height:1.55}
.flip-card__back ul li::before{content:'';position:absolute;left:0;top:11px;width:5px;height:5px;border-radius:50%;background:var(--green-accent)}
.flip-card__back .btn{margin-top:auto;align-self:flex-start;font-size:.78rem;padding:9px 18px}
.flip-card__back-scroll{flex:1;overflow-y:auto;margin-bottom:14px;padding-right:6px}
.flip-card__back-scroll::-webkit-scrollbar{width:4px}
.flip-card__back-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:2px}

/* ================================================================
   EXPANDABLE PROCESS DIAGRAM — services page
   ================================================================ */
.process-v2{display:flex;flex-direction:column;gap:14px;max-width:880px;margin:0 auto}
.process-v2__step{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);overflow:hidden;transition:all .3s}
.process-v2__step.open{background:rgba(255,255,255,.08);border-color:rgba(82,191,128,.4);box-shadow:0 8px 30px rgba(0,0,0,.2)}
.process-v2__head{width:100%;display:flex;align-items:center;gap:20px;padding:22px 26px;background:none;border:none;cursor:pointer;text-align:left;color:white;font-family:'Inter',sans-serif}
.process-v2__num{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Sora',sans-serif;font-size:1.05rem;font-weight:700;color:white;flex-shrink:0;background:linear-gradient(135deg,var(--blue),var(--blue-dark));transition:all .3s}
.process-v2__step.open .process-v2__num{background:linear-gradient(135deg,var(--green),var(--green-dark));box-shadow:0 0 0 4px rgba(61,170,110,.18)}
.process-v2__icon{width:38px;height:38px;background:rgba(255,255,255,.06);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.process-v2__icon svg{width:20px;height:20px;stroke:var(--green-accent);fill:none;stroke-width:1.6}
.process-v2__title{flex:1;display:flex;flex-direction:column;gap:3px}
.process-v2__title strong{font-family:'Sora',sans-serif;font-size:1.1rem;color:white;font-weight:600;letter-spacing:0}
.process-v2__title span{font-size:.78rem;color:rgba(255,255,255,.55)}
.process-v2__chevron{width:24px;height:24px;color:rgba(255,255,255,.4);transition:transform .3s,color .2s;flex-shrink:0}
.process-v2__step.open .process-v2__chevron{transform:rotate(180deg);color:var(--green-accent)}
.process-v2__body{max-height:0;overflow:hidden;transition:max-height .4s ease;padding:0 26px 0 94px}
.process-v2__step.open .process-v2__body{max-height:600px;padding-bottom:24px}
.process-v2__body ul{list-style:none}
.process-v2__body ul li{font-size:.85rem;color:rgba(255,255,255,.72);padding:6px 0 6px 18px;position:relative;line-height:1.65}
.process-v2__body ul li::before{content:'';position:absolute;left:0;top:14px;width:6px;height:6px;border-radius:50%;background:var(--green-accent)}

/* ================================================================
   FEATURE COMPARISON MATRIX — pricing page
   ================================================================ */
.feature-matrix{width:100%;border-collapse:collapse;background:var(--white);font-size:.85rem;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md)}
.feature-matrix thead th{background:var(--blue-darker);color:var(--white);padding:18px 14px;text-align:center;font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;border-bottom:2px solid var(--blue)}
.feature-matrix thead th:first-child{text-align:left;background:var(--blue-darker);min-width:280px}
.feature-matrix tbody td{padding:14px 14px;border-bottom:1px solid var(--border-light);text-align:center;color:var(--ink-mid);font-size:.82rem}
.feature-matrix tbody td:first-child{text-align:left;font-weight:500;color:var(--ink);background:var(--off-white);position:sticky;left:0;z-index:1}
.feature-matrix tbody tr:nth-child(even) td{background:var(--blue-ultra)}
.feature-matrix tbody tr:nth-child(even) td:first-child{background:var(--blue-pale)}
.feature-matrix tbody tr:hover td{background:rgba(44,123,179,.06)}
.feature-matrix tbody tr:hover td:first-child{background:rgba(44,123,179,.1)}
.fm-tick{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--green-pale);color:var(--green-dark)}
.fm-tick svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2.5}
.fm-na{color:var(--border);font-size:1rem;font-weight:300}
.fm-text{font-size:.74rem;color:var(--blue-dark);font-weight:600;line-height:1.35;display:block}
.matrix-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius)}
.matrix-wrap caption{caption-side:top;text-align:left;font-size:.78rem;color:var(--ink-light);margin-bottom:12px;font-style:italic}

/* ================================================================
   PRICING CARDS (top of pricing page)
   ================================================================ */
.price-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:48px}
.price-card{background:var(--white);border:1.5px solid var(--border-light);border-radius:var(--radius);padding:28px 24px;text-align:left;transition:all .25s;position:relative}
.price-card:hover{border-color:var(--blue);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.price-card--featured{border-color:var(--blue);background:linear-gradient(170deg,var(--white),var(--blue-ultra))}
.price-card__badge{position:absolute;top:-10px;right:18px;background:var(--green);color:white;font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 11px;border-radius:20px}
.price-card h3{font-size:1.05rem;color:var(--blue-darker);margin-bottom:8px;line-height:1.25}
.price-card__sub{font-size:.78rem;color:var(--ink-light);margin-bottom:18px;line-height:1.55}
.price-card__price{font-family:'Sora',sans-serif;font-size:2rem;font-weight:700;color:var(--blue-darker);line-height:1;margin-bottom:4px}
.price-card__price small{font-size:.65rem;color:var(--ink-light);font-weight:400;display:block;font-family:'Inter',sans-serif;letter-spacing:.05em;text-transform:uppercase;margin-bottom:8px}
.price-card__from{display:inline-block;font-size:.7rem;color:var(--ink-light);margin-bottom:18px;font-weight:500}

/* ================================================================
   CONTACT PAGE
   ================================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:56px;align-items:start}
.contact-info h3{font-size:1.1rem;margin-bottom:14px;color:var(--blue-darker)}
.contact-info > p{font-size:.92rem;margin-bottom:24px}

/* ================================================================
   FLIP CARDS — RESPONSIVE
   ================================================================ */
@media(max-width:1100px){
  .flip-grid{grid-template-columns:repeat(2,1fr)}
  .price-cards{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr;gap:36px}
}
@media(max-width:700px){
  .flip-grid{grid-template-columns:1fr}
  .flip-card{height:auto;min-height:380px}
  .price-cards{grid-template-columns:1fr}
  .process-v2__head{padding:18px 18px;gap:14px}
  .process-v2__icon{display:none}
  .process-v2__body{padding:0 18px 0 80px}
}

/* Disable hover-to-flip on touch devices */
@media(hover:none){
  .flip-card:hover .flip-card__inner{transform:none}
  .flip-card.flipped .flip-card__inner{transform:rotateY(180deg)}
}

/* ================================================================
   PILL BUTTONS — replace radius globally for the new look
   ================================================================ */
.btn{border-radius:9999px;padding:14px 30px;letter-spacing:.01em}
.btn-sm{padding:9px 22px}
.nav__links .nav-cta{border-radius:9999px}

/* ================================================================
   IMAGE-LED CATEGORY BOXES (Brindle Green / live site style)
   ================================================================ */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.cat-box{display:block;text-decoration:none;color:inherit;border-radius:14px;overflow:hidden;background:var(--white);box-shadow:0 10px 40px rgba(15,61,97,.12);transition:transform .35s ease,box-shadow .35s ease;position:relative}
.cat-box:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(15,61,97,.18)}
.cat-box__img{position:relative;height:280px;overflow:hidden;background:#1A5A8C}
.cat-box__img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease;transform:scale(1.04)}
.cat-box:hover .cat-box__img img{transform:scale(1.1)}
/* Landscape plan image — slightly more crop to hide drawing's black outline */
.cat-box__img--crop img{transform:scale(1.12)}
.cat-box:hover .cat-box__img--crop img{transform:scale(1.18)}
.cat-box__img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(15,61,97,.7) 100%)}
.cat-box__tag{position:absolute;top:18px;left:18px;background:rgba(255,255,255,.95);color:var(--green-dark);font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:6px 14px;border-radius:9999px;z-index:2}
.cat-box__title{position:absolute;bottom:18px;left:22px;right:22px;color:white;font-family:'Sora',sans-serif;font-size:1.35rem;font-weight:600;line-height:1.2;z-index:2;text-shadow:0 2px 12px rgba(0,0,0,.4)}
.cat-box__body{padding:24px 26px 28px}
.cat-box__body p{font-size:.88rem;color:var(--ink-mid);margin-bottom:16px;line-height:1.65}
.cat-box__link{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;font-weight:700;color:var(--blue);letter-spacing:.04em;text-transform:uppercase}
.cat-box__link svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .3s}
.cat-box:hover .cat-box__link svg{transform:translateX(4px)}

/* ================================================================
   HERO QUICK-QUOTE FORM (overlaid on hero photo)
   ================================================================ */
.hero__layout{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center;width:100%}
.hero-form{background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border-radius:14px;padding:32px 30px;box-shadow:0 30px 80px rgba(0,0,0,.35);max-width:420px;margin-left:auto}
.hero-form h3{font-family:'Sora','Inter',sans-serif;font-size:1.35rem;font-weight:700;letter-spacing:-.02em;color:var(--ink);margin-bottom:6px;line-height:1.15}
.hero-form__sub{font-size:.84rem;color:var(--ink-light);margin-bottom:20px;line-height:1.55}
.hero-form .form-group{margin-bottom:12px}
.hero-form label{display:block;font-family:'Inter',sans-serif;font-size:.7rem;font-weight:700;color:var(--ink-mid);margin-bottom:5px;letter-spacing:.04em;text-transform:uppercase}
.hero-form input,.hero-form textarea{width:100%;padding:12px 14px;border:1.5px solid var(--border-light);border-radius:8px;font-family:'Inter',sans-serif;font-size:.92rem;color:var(--ink);background:var(--white);transition:border-color .2s,box-shadow .2s}
.hero-form input:focus,.hero-form textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(210,211,0,.18)}
.hero-form textarea{resize:vertical;min-height:74px}
.hero-form__submit{width:100%;justify-content:center;margin-top:6px;padding:15px 24px}
.hero-form__note{font-size:.7rem;color:var(--ink-light);text-align:center;margin-top:10px}
.hero-form__honeypot{display:none}
@media(max-width:1100px){
  .hero__layout{grid-template-columns:1fr;gap:36px}
  .hero-form{margin-left:0;margin-right:auto;max-width:480px}
}

/* ================================================================
   HERO v2 — bigger, photo-led
   ================================================================ */
.hero{min-height:88vh}
.hero__bg{background-position:center}
.hero__overlay{background:linear-gradient(110deg,rgba(15,61,97,.78) 0%,rgba(15,61,97,.45) 55%,rgba(15,61,97,.15) 100%)}
.hero__inner{padding:calc(var(--nav-h) + 80px) 0 100px}
.hero h1{font-size:clamp(2.4rem,5.5vw,4rem);line-height:1.1;letter-spacing:-.01em}
.hero__sub{font-size:1.18rem;line-height:1.7;max-width:640px}
.hero__tagline{display:block;font-family:'Inter',sans-serif;font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--green-accent);margin-bottom:18px}

/* Big animated tagline — letters fade up in sequence */
.hero__tagline--big{font-family:'Sora','Inter',sans-serif;font-size:clamp(1.25rem,2.4vw,1.95rem);font-weight:800;color:#D2D300;letter-spacing:-.012em;text-transform:none;margin-bottom:24px;line-height:1}
.hero__tagline--big span{display:inline-block;opacity:0;transform:translateY(14px);animation:taglineIn .55s cubic-bezier(.2,.7,.2,1) forwards}
.hero__tagline--big span:nth-child(1){animation-delay:.05s}
.hero__tagline--big span:nth-child(2){animation-delay:.1s}
.hero__tagline--big span:nth-child(3){animation-delay:.15s}
.hero__tagline--big span:nth-child(4){animation-delay:.22s}
.hero__tagline--big span:nth-child(5){animation-delay:.27s}
.hero__tagline--big span:nth-child(6){animation-delay:.32s}
.hero__tagline--big span:nth-child(7){animation-delay:.37s}
.hero__tagline--big span:nth-child(8){animation-delay:.42s}
.hero__tagline--big span:nth-child(9){animation-delay:.47s}
.hero__tagline--big span:nth-child(10){animation-delay:.52s}
.hero__tagline--big span:nth-child(11){animation-delay:.57s}
.hero__tagline--big span:nth-child(12){animation-delay:.62s}
.hero__tagline--big span:nth-child(13){animation-delay:.69s}
.hero__tagline--big span:nth-child(14){animation-delay:.74s}
.hero__tagline--big span:nth-child(15){animation-delay:.79s}
.hero__tagline--big span:nth-child(16){animation-delay:.84s}
.hero__tagline--big span:nth-child(17){animation-delay:.89s}
.hero__tagline--big span:nth-child(18){animation-delay:.94s}
.hero__tagline--big span:nth-child(19){animation-delay:.99s}
.hero__tagline--big span:nth-child(20){animation-delay:1.04s}
.hero__tagline--big span:nth-child(21){animation-delay:1.09s}
@keyframes taglineIn{to{opacity:1;transform:translateY(0)}}
@media(prefers-reduced-motion:reduce){
  .hero__tagline--big span{animation:none;opacity:1;transform:none}
}

/* ================================================================
   PROCESS DIAGRAM v3 — pixel-accurate to user's PNG
   Each .p9 IS its own rail segment; circle/text positioned around it
   ================================================================ */
.proc9{display:grid;grid-template-columns:repeat(9,1fr);max-width:1280px;margin:0 auto;padding:240px 24px}
.p9{position:relative;height:20px;background:currentColor}
.p9:first-child{border-radius:10px 0 0 10px}
.p9:last-child{border-radius:0 10px 10px 0}
.p9__circle{position:absolute;left:50%;transform:translateX(-50%);width:76px;height:76px;border-radius:50%;background:#EFEFEF;border:3.5px solid currentColor;display:flex;align-items:center;justify-content:center;z-index:2;transition:transform .3s ease}
.p9__circle:hover{transform:translateX(-50%) scale(1.1)}
.p9__circle svg{width:30px;height:30px;stroke:var(--ink);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.p9__stalk{position:absolute;left:50%;transform:translateX(-50%);width:3px;background:currentColor;z-index:1}
.p9__text{position:absolute;left:50%;transform:translateX(-50%);width:175px;text-align:left;z-index:0}
.p9__text strong{display:block;font-family:'Sora',sans-serif;font-weight:600;font-size:1rem;color:currentColor;line-height:1.2;margin-bottom:6px;letter-spacing:-.01em}
.p9__text p{font-family:'Inter',sans-serif;font-size:.72rem;line-height:1.55;color:var(--ink-mid);font-weight:400}

/* UP — text and circle above the rail */
.p9--up .p9__text{bottom:calc(100% + 178px)}
.p9--up .p9__circle{bottom:calc(100% + 88px)}
.p9--up .p9__stalk{bottom:100%;height:88px}

/* DOWN — text and circle below the rail */
.p9--down .p9__text{top:calc(100% + 178px)}
.p9--down .p9__circle{top:calc(100% + 88px)}
.p9--down .p9__stalk{top:100%;height:88px}

/* per-segment colour matching user's reference (teal -> green -> chartreuse) */
.p9:nth-child(1){color:#1A6E7A}
.p9:nth-child(2){color:#1FA1A8}
.p9:nth-child(3){color:#2DC0A4}
.p9:nth-child(4){color:#2FBA67}
.p9:nth-child(5){color:#52C04F}
.p9:nth-child(6){color:#7BC848}
.p9:nth-child(7){color:#A8D24A}
.p9:nth-child(8){color:#C8D750}
.p9:nth-child(9){color:#D9DB6A}

/* mobile: vertical timeline */
@media(max-width:1100px){
  .proc9{display:flex;flex-direction:column;gap:22px;padding:20px 24px}
  .p9{height:auto;background:transparent;display:flex;align-items:flex-start;gap:20px;padding-left:6px}
  .p9:first-child,.p9:last-child{border-radius:0}
  .p9__stalk{display:none}
  .p9__circle{position:relative;left:auto;top:auto;bottom:auto;transform:none;flex-shrink:0;width:62px;height:62px;border-width:3px}
  .p9__circle svg{width:26px;height:26px}
  .p9__circle:hover{transform:scale(1.06)}
  .p9__text{position:relative;left:auto;top:auto;bottom:auto;transform:none;width:auto;flex:1;padding-top:6px;text-align:left}
  .p9__text strong{font-size:1.1rem}
  .p9__text p{font-size:.86rem}
  .p9--up .p9__text,.p9--down .p9__text,.p9--up .p9__circle,.p9--down .p9__circle{position:relative;top:auto;bottom:auto}
}

/* ================================================================
   SECTION DIVIDER — wave between sections (depth)
   ================================================================ */
.wave-divider{position:relative;width:100%;height:80px;line-height:0;overflow:hidden}
.wave-divider svg{width:100%;height:100%;display:block}

/* ================================================================
   FULL-BLEED PHOTO BAND — between sections for visual rhythm
   ================================================================ */
.photo-band{position:relative;height:380px;overflow:hidden;background:#1A5A8C}
.photo-band img{width:100%;height:100%;object-fit:cover;display:block}
.photo-band__overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(15,61,97,.6) 0%,transparent 50%,rgba(15,61,97,.3) 100%);display:flex;align-items:flex-end;padding:48px 0}
.photo-band__inner{position:relative;color:white;max-width:680px}
.photo-band__inner h2{color:white;font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:14px;font-style:italic;font-weight:400}
.photo-band__inner p{color:rgba(255,255,255,.85);font-size:1.05rem}

/* ================================================================
   FEATURE MATRIX — bottom price row
   ================================================================ */
.feature-matrix tfoot td{background:var(--blue-darker)!important;color:white;padding:22px 14px;text-align:center;font-family:'Sora',sans-serif;font-size:1.2rem;font-weight:700;border-bottom:none}
.feature-matrix tfoot td:first-child{background:var(--blue-darker)!important;color:white;font-family:'Inter',sans-serif;font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;text-align:left}
.feature-matrix tfoot td small{display:block;font-family:'Inter',sans-serif;font-size:.62rem;font-weight:400;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-top:2px}

/* ================================================================
   IMAGE CARD VARIANT (services with photos)
   ================================================================ */
.svc-img-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.svc-img-card{position:relative;border-radius:14px;overflow:hidden;background:var(--white);box-shadow:0 10px 40px rgba(15,61,97,.12);transition:transform .35s ease,box-shadow .35s ease;text-decoration:none;color:inherit;display:flex;flex-direction:column}
.svc-img-card:hover{transform:translateY(-5px);box-shadow:0 24px 60px rgba(15,61,97,.2)}
.svc-img-card__img{position:relative;height:240px;overflow:hidden;background:linear-gradient(135deg,#112337,#A8A900)}
.svc-img-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.svc-img-card:hover .svc-img-card__img img{transform:scale(1.06)}
.svc-img-card__price{position:absolute;top:16px;right:16px;background:rgba(255,255,255,.95);color:var(--green-dark);font-size:.78rem;font-weight:800;padding:7px 14px;border-radius:9999px;z-index:2;backdrop-filter:blur(4px)}
.svc-img-card__body{padding:24px 26px 28px;flex:1;display:flex;flex-direction:column}
.svc-img-card__body h3{font-size:1.15rem;color:var(--blue-darker);margin-bottom:10px;font-family:'Sora',sans-serif;font-weight:600}
.svc-img-card__body p{font-size:.87rem;color:var(--ink-mid);margin-bottom:18px;line-height:1.65;flex:1}
.svc-img-card__link{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;font-weight:700;color:var(--blue);letter-spacing:.04em;text-transform:uppercase;align-self:flex-start}
.svc-img-card__link svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .3s}
.svc-img-card:hover .svc-img-card__link svg{transform:translateX(4px)}

@media(max-width:1000px){
  .cat-grid,.svc-img-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .cat-grid,.svc-img-grid{grid-template-columns:1fr}
}

/* ================================================================
   KIT-STYLE PRICING (pricing page)
   ================================================================ */
.kit-pricing{background:var(--blue-pale);padding:90px 0 110px;border-radius:0}
.kit-pricing__header{text-align:center;max-width:760px;margin:0 auto 60px}
.kit-pricing__header h2{font-size:clamp(2.2rem,4.5vw,3.6rem);font-weight:600;color:var(--ink);margin-bottom:18px;line-height:1.05}
.kit-pricing__header p{font-size:1.05rem;color:var(--ink-mid)}

.kit-cards{display:grid;grid-template-columns:1fr 1.18fr 1fr;gap:30px;max-width:1180px;margin:0 auto;align-items:center;position:relative}
.kit-cards--4{grid-template-columns:repeat(4,1fr);max-width:1280px;gap:20px}

/* Compact price strip — under Specialist landscape services */
.price-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-top:48px;max-width:1200px;margin-left:auto;margin-right:auto}
.price-strip__item{background:var(--white);border:1.5px solid var(--border-light);border-radius:12px;padding:18px 16px;text-align:center;display:flex;flex-direction:column;gap:6px;transition:all .25s ease}
.price-strip__item:hover{border-color:var(--blue);background:var(--blue-pale);transform:translateY(-2px)}
.price-strip__name{font-family:'Inter',sans-serif;font-size:.74rem;font-weight:700;color:var(--ink-mid);letter-spacing:.04em;text-transform:uppercase}
.price-strip__price{font-family:'Sora','Inter',sans-serif;font-size:1.05rem;font-weight:800;color:var(--ink);letter-spacing:-.01em}
@media(max-width:1100px){.price-strip{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.price-strip{grid-template-columns:repeat(2,1fr);gap:10px}.price-strip__item{padding:14px 12px}}
.kit-cards--4 .kit-card{padding:38px 26px 32px;min-height:480px}
.kit-cards--4 .kit-card__price{font-size:2.6rem}
.kit-cards--4 .kit-card__name{font-size:1.25rem}
@media(max-width:1100px){
  .kit-cards--4{grid-template-columns:repeat(2,1fr);max-width:760px}
}
.kit-card{background:var(--white);border-radius:14px;padding:42px 32px 36px;text-align:center;border:1.5px solid var(--border-light);transition:all .3s ease;display:flex;flex-direction:column;min-height:440px;position:relative}
.kit-card:hover{transform:translateY(-4px);box-shadow:0 24px 60px rgba(17,35,55,.12);border-color:var(--blue-pale)}
.kit-card--featured{border:2.5px solid var(--blue);box-shadow:0 24px 60px rgba(210,211,0,.25);transform:translateY(-12px);padding:54px 36px 44px;min-height:500px}
.kit-card--featured:hover{transform:translateY(-16px)}
.kit-card--featured .kit-card__price{font-size:3.4rem;line-height:1}
.kit-card--featured .kit-card__name{font-size:1.32rem}
@media(max-width:980px){
  .kit-cards{grid-template-columns:1fr 1.12fr 1fr;gap:22px}
}
.kit-card__badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--blue);color:var(--ink);font-family:'Inter',sans-serif;font-size:.66rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;padding:8px 18px;border-radius:9999px;box-shadow:0 6px 18px rgba(210,211,0,.4);white-space:nowrap}
.kit-card__icon{width:62px;height:62px;margin:0 auto 22px;display:flex;align-items:center;justify-content:center;background:var(--yellow-pale);border-radius:14px}
.kit-card--featured .kit-card__icon{background:var(--blue-pale)}
.kit-card__icon svg{width:32px;height:32px;stroke:var(--yellow-dark);fill:none;stroke-width:1.6}
.kit-card--featured .kit-card__icon svg{stroke:var(--blue)}
.kit-card__name{font-family:'Sora',sans-serif;font-size:1.45rem;font-weight:600;color:var(--ink);margin-bottom:14px;letter-spacing:-.015em;line-height:1.15}
.kit-card__starting{font-family:'Inter',sans-serif;font-size:.78rem;color:var(--ink-light);margin-bottom:6px;font-weight:500}
.kit-card__price{font-family:'Sora',sans-serif;font-size:3.2rem;font-weight:600;color:var(--ink);line-height:1;margin-bottom:6px;letter-spacing:-.025em}
.kit-card__price small{font-size:1rem;font-weight:500;color:var(--ink-light);font-family:'Inter',sans-serif;display:inline-block;margin-left:4px;vertical-align:middle}
.kit-card__per{font-family:'Inter',sans-serif;font-size:.85rem;color:var(--ink-light);margin-bottom:18px;font-weight:500}
.kit-card__desc{font-family:'Inter',sans-serif;font-size:.8rem;color:var(--ink-mid);line-height:1.55;margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--border-light);text-align:left}
.kit-card__features{list-style:none;text-align:left;margin-bottom:30px;flex:1}
.kit-card__features li{font-size:.88rem;color:var(--ink-mid);padding:9px 0 9px 26px;position:relative;line-height:1.5}
.kit-card__features li::before{content:'';position:absolute;left:0;top:13px;width:14px;height:14px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23A8A900' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l5 5 9-11'/%3E%3C/svg%3E") center/14px no-repeat}
.kit-card__cta{display:block;width:100%;padding:16px 24px;background:var(--ink);color:var(--white);border-radius:10px;font-family:'Inter',sans-serif;font-size:.92rem;font-weight:700;text-decoration:none;text-align:center;border:none;cursor:pointer;transition:all .25s ease;letter-spacing:.005em}
.kit-card__cta:hover{background:var(--blue);color:var(--ink);transform:translateY(-2px);box-shadow:0 10px 24px rgba(210,211,0,.45)}
.kit-card--featured .kit-card__cta{background:var(--blue);color:var(--ink)}
.kit-card--featured .kit-card__cta:hover{background:var(--blue-bright);color:var(--ink);box-shadow:0 10px 24px rgba(210,211,0,.5)}

/* ================================================================
   KIT-STYLE COMPARISON MATRIX (with section headers)
   ================================================================ */
.kit-matrix-wrap{max-width:1200px;margin:90px auto 0;background:var(--white);border-radius:14px;overflow:hidden;border:1px solid var(--border-light)}
.kit-matrix{width:100%;border-collapse:collapse;font-family:'Inter',sans-serif}
.kit-matrix thead th{background:var(--white);border-bottom:2px solid var(--border-light);padding:24px 16px;text-align:center;font-family:'Inter',sans-serif;font-size:.78rem;font-weight:800;color:var(--ink);letter-spacing:.06em;text-transform:uppercase}
.kit-matrix thead th:first-child{text-align:left;font-size:.74rem;color:var(--ink-light);font-weight:700;min-width:300px}
.kit-matrix thead th.kit-matrix__featured{color:var(--blue);background:var(--blue-pale);position:relative}
.kit-matrix tbody tr:not(.kit-matrix__section) td{padding:14px 16px;text-align:center;border-bottom:1px solid var(--border-light);font-size:.86rem;color:var(--ink-mid)}
.kit-matrix tbody tr:not(.kit-matrix__section) td:first-child{text-align:left;font-weight:500;color:var(--ink)}
.kit-matrix tbody td.kit-matrix__featured{background:rgba(32,76,229,.04)}
.kit-matrix tbody tr:hover td:not(.kit-matrix__featured){background:var(--off-white)}
.kit-matrix tbody tr:hover td.kit-matrix__featured{background:rgba(32,76,229,.08)}
.kit-matrix__section td{background:var(--blue-pale);padding:14px 16px;border-bottom:1px solid var(--border-light);font-size:.68rem;font-weight:800;color:var(--blue-dark);letter-spacing:.16em;text-transform:uppercase}
.kit-tick{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--blue-pale);color:var(--blue)}
.kit-tick svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2.5}
.kit-na{color:var(--border);font-size:1.1rem;font-weight:300}
.kit-text{font-size:.74rem;color:var(--blue);font-weight:600;line-height:1.4;display:block}
.kit-pricerow td{background:var(--ink)!important;color:var(--white);padding:24px 16px!important;font-family:'Sora',sans-serif;font-size:1.5rem;font-weight:600;text-align:center;border-bottom:none!important}
.kit-pricerow td:first-child{text-align:left!important;font-family:'Inter',sans-serif!important;font-size:.74rem!important;font-weight:800!important;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.65)!important}
.kit-pricerow td small{display:block;font-family:'Inter',sans-serif;font-size:.62rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-top:4px}

@media(max-width:1000px){
  .kit-cards{grid-template-columns:1fr;max-width:480px}
  .kit-card--featured{transform:none;margin:14px 0}
  .kit-card--featured:hover{transform:translateY(-4px)}
  .kit-matrix-wrap{overflow-x:auto}
  .kit-matrix{min-width:720px}
}

/* ================================================================
   TRUSTED-BY STRIP — homepage social proof
   ================================================================ */
.trusted{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:center;max-width:1200px;margin:0 auto}
.trusted__head h2{font-family:'Sora','Inter',sans-serif;font-size:clamp(1.6rem,3vw,2.4rem);font-weight:700;letter-spacing:-.025em;margin-bottom:14px;line-height:1.1}
.trusted__head p{font-size:.95rem;line-height:1.65;color:var(--ink-mid)}
.trusted__pills{display:flex;flex-wrap:wrap;gap:10px}
.trusted__pill{display:inline-flex;align-items:center;background:var(--white);border:1.5px solid var(--border-light);color:var(--ink);font-family:'Inter',sans-serif;font-size:.84rem;font-weight:600;padding:11px 18px;border-radius:9999px;transition:all .25s ease}
.trusted__pill:hover{border-color:var(--blue);background:var(--blue-pale);color:var(--blue-dark)}
@media(max-width:900px){
  .trusted{grid-template-columns:1fr;gap:32px}
}

/* ================================================================
   USP GRID (Why TLW section)
   ================================================================ */
.usp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px}
.usp{padding:8px 0}
.usp__icon{width:56px;height:56px;border-radius:14px;background:var(--blue-pale);color:var(--blue);display:flex;align-items:center;justify-content:center;margin-bottom:22px;transition:all .3s}
.usp:hover .usp__icon{background:var(--yellow);color:var(--ink);transform:translateY(-3px)}
.usp__icon svg{width:26px;height:26px}
.usp h3{font-family:'Sora',sans-serif;font-size:1.25rem;font-weight:600;color:var(--ink);margin-bottom:12px;line-height:1.2;letter-spacing:-.012em}
.usp p{font-size:.95rem;line-height:1.65;color:var(--ink-mid)}
@media(max-width:1000px){.usp-grid{grid-template-columns:repeat(2,1fr);gap:32px}}
@media(max-width:680px){.usp-grid{grid-template-columns:1fr;gap:28px}}

/* ================================================================
   DEVELOPMENT TYPE PILLS
   ================================================================ */
.dev-grid{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:960px;margin:0 auto}
.dev-pill{background:var(--white);border:1.5px solid var(--border-light);color:var(--ink);font-family:'Inter',sans-serif;font-size:.88rem;font-weight:600;padding:14px 22px;border-radius:9999px;transition:all .25s ease;cursor:default}
.dev-pill:hover{border-color:var(--blue);background:var(--blue-pale);color:var(--blue-dark);transform:translateY(-2px);box-shadow:var(--shadow-sm)}

/* ================================================================
   CASE STUDIES — soft-shape photo cards with overlapping green title
   ================================================================ */
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:56px 36px;max-width:1280px;margin:0 auto}
.case-card{position:relative;display:flex;flex-direction:column;background:transparent;border:none;color:inherit}

/* Photo block — soft asymmetric shape (different from the docx reference) */
.case-card__media{position:relative;display:block;text-decoration:none;color:inherit;margin-bottom:30px}
.case-card__media img{display:block;width:100%;aspect-ratio:5/3;object-fit:cover;background:#1A6E7A;border-radius:120px 24px 120px 24px;transition:transform .6s ease,box-shadow .3s ease;box-shadow:0 14px 40px rgba(17,35,55,.10)}
.case-card:hover .case-card__media img{transform:translateY(-3px);box-shadow:0 22px 55px rgba(17,35,55,.16)}

/* Lime green title bar overlapping the bottom-left of the photo */
.case-card__cat{position:absolute;left:24px;right:24px;bottom:-22px;display:block;background:var(--blue);color:var(--ink);font-family:'Sora','Inter',sans-serif;font-size:1rem;font-weight:700;letter-spacing:-.005em;text-transform:none;padding:14px 22px;text-align:left;line-height:1.25;pointer-events:none;box-shadow:0 6px 22px rgba(17,35,55,.12)}

.case-card__body{padding:18px 6px 0;display:flex;flex-direction:column;flex:1}
.case-card__body p{font-family:'Inter',sans-serif;font-size:.92rem;line-height:1.6;color:var(--ink-mid);margin:0 0 22px}

.case-card__btn{display:inline-flex;align-items:center;gap:10px;align-self:flex-start;margin-top:auto;background:transparent;border:1.5px solid var(--ink);color:var(--ink);font-family:'Inter',sans-serif;font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;text-decoration:none;padding:11px 22px;border-radius:9999px;transition:all .25s ease}
.case-card__btn svg{width:14px;height:14px}
.case-card__btn:hover{background:var(--blue);border-color:var(--blue);color:var(--ink);transform:translateX(2px)}

@media(max-width:980px){.case-grid{grid-template-columns:repeat(2,1fr);gap:48px 28px}.case-card__media img{border-radius:90px 20px 90px 20px}}
@media(max-width:620px){.case-grid{grid-template-columns:1fr;gap:44px 0}.case-card__media img{border-radius:80px 18px 80px 18px}}

/* ================================================================
   RESOURCE GRID — resources index page
   ================================================================ */
.resource-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:1200px;margin:0 auto}
.resource-card{display:flex;flex-direction:column;background:var(--white);border:1.5px solid var(--border-light);border-radius:14px;text-decoration:none;color:inherit;transition:all .25s ease;overflow:hidden}
.resource-card:hover{border-color:var(--blue);transform:translateY(-4px);box-shadow:0 18px 50px rgba(17,35,55,.1)}
.resource-card__img{position:relative;width:100%;aspect-ratio:5/3;overflow:hidden;background:#1A6E7A}
.resource-card__img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s ease}
.resource-card:hover .resource-card__img img{transform:scale(1.06)}
.resource-card > .resource-card__tag,.resource-card > h3,.resource-card > p,.resource-card > .resource-card__link{margin-left:28px;margin-right:28px}
.resource-card > .resource-card__tag{margin-top:24px}
.resource-card > .resource-card__link{margin-bottom:28px}
.resource-card__tag{display:inline-block;font-family:'Inter',sans-serif;font-size:.66rem;font-weight:800;letter-spacing:.13em;text-transform:uppercase;color:var(--blue-dark);background:var(--blue-pale);padding:5px 11px;border-radius:9999px;margin-bottom:18px;align-self:flex-start}
.resource-card h3{font-family:'Sora','Inter',sans-serif;font-size:1.05rem;font-weight:700;color:var(--ink);line-height:1.3;letter-spacing:-.012em;margin-bottom:14px}
.resource-card p{font-size:.88rem;color:var(--ink-mid);line-height:1.6;margin-bottom:18px;flex:1}
.resource-card__link{font-family:'Inter',sans-serif;font-size:.78rem;font-weight:800;color:var(--blue-dark);letter-spacing:.04em;text-transform:uppercase;align-self:flex-start}
.resource-card:hover .resource-card__link{color:var(--ink)}
@media(max-width:1000px){.resource-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.resource-grid{grid-template-columns:1fr}}

/* ================================================================
   ARTICLE HERO IMAGE (above article body, below page header)
   ================================================================ */
.article-hero{padding:0;margin-top:-1px}
.article-hero .container{max-width:1200px;padding:0}
.article-hero img{width:100%;height:auto;display:block;aspect-ratio:16/7;object-fit:cover;border-radius:0 0 16px 16px;box-shadow:0 24px 60px rgba(17,35,55,.18)}
@media(max-width:1100px){.article-hero img{border-radius:0;aspect-ratio:16/8}}

/* ================================================================
   ARTICLE BODY — individual blog post pages
   ================================================================ */
.article-body{padding:80px 32px}
.article-body p{font-size:1.05rem;line-height:1.85;color:var(--ink-mid);margin-bottom:1.4em}
.article-body h2{font-family:'Sora','Inter',sans-serif;font-size:1.85rem;font-weight:700;color:var(--ink);margin:48px 0 18px;letter-spacing:-.025em;line-height:1.15}
.article-body h3{font-family:'Sora','Inter',sans-serif;font-size:1.3rem;font-weight:700;color:var(--ink);margin:32px 0 14px;letter-spacing:-.015em;line-height:1.2}
.article-body ul,.article-body ol{margin:0 0 1.4em;padding-left:24px}
.article-body ul li,.article-body ol li{font-size:1.05rem;line-height:1.75;color:var(--ink-mid);margin-bottom:8px;padding-left:6px}
.article-body ul li::marker{color:var(--blue)}
.article-body ol li::marker{color:var(--blue);font-weight:700}
.article-body strong{color:var(--ink);font-weight:700}
.article-body em{font-style:italic}
.article-body blockquote{border-left:4px solid var(--blue);padding:18px 28px;margin:32px 0;background:var(--blue-pale);border-radius:0 8px 8px 0}
.article-body blockquote p{font-size:1.1rem;font-style:italic;color:var(--ink);margin:0;line-height:1.6}
.article-body a{color:var(--blue-dark);font-weight:600;border-bottom:1.5px solid currentColor}
.article-body a:hover{color:var(--ink)}
.article-cta{margin-top:64px;padding:36px 32px;background:var(--blue-pale);border-radius:14px;border:1.5px solid rgba(210,211,0,.35)}
.article-cta h3{font-family:'Sora','Inter',sans-serif;font-size:1.35rem;font-weight:700;color:var(--ink);margin-bottom:10px;letter-spacing:-.02em}
.article-cta p{font-size:.95rem;color:var(--ink-mid);line-height:1.65;margin:0}

/* ================================================================
   PARTNER CARD — partners page
   ================================================================ */
.partner-card{display:grid;grid-template-columns:280px 1fr;gap:56px;max-width:1100px;margin:0 auto;background:var(--white);border:1.5px solid var(--border-light);border-radius:18px;padding:48px;box-shadow:0 14px 50px rgba(17,35,55,.08)}
.partner-card__logo{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--blue-pale);border-radius:14px;padding:36px 24px;text-align:center}
.partner-logo-mark{font-family:'Sora','Inter',sans-serif;font-size:3.4rem;font-weight:800;color:var(--ink);letter-spacing:-.06em;line-height:1;margin-bottom:12px}
.partner-card__tagline{font-family:'Inter',sans-serif;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue-dark);font-style:italic}
.partner-card__body h2{font-family:'Sora','Inter',sans-serif;font-size:2.2rem;font-weight:700;letter-spacing:-.025em;color:var(--ink);margin-bottom:14px;line-height:1.1}
.partner-card__lede{font-size:1.05rem;color:var(--ink-mid);line-height:1.65;margin-bottom:24px}
.partner-card__body h3{font-family:'Inter',sans-serif;font-size:.74rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-dark);margin:28px 0 14px}
.partner-card__body .check-list li{font-size:.92rem}
.partner-card__cta{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}
@media(max-width:880px){
  .partner-card{grid-template-columns:1fr;gap:32px;padding:32px}
  .partner-card__logo{padding:32px 24px}
  .partner-logo-mark{font-size:2.8rem}
}

/* ================================================================
   PLACES GRID — services page recent-work (EDP "Bowmans Cross" style)
   Compact card: arched photo + lime label band + body + pill CTA
   ================================================================ */
.places-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:48px;max-width:880px;margin:0 auto}
.place-card{display:flex;flex-direction:column;max-width:340px;margin:0 auto;width:100%}
.place-card__img{position:relative;width:100%;aspect-ratio:5/3;overflow:hidden;background:#1A6E7A;border-radius:9999px 9999px 14px 14px}
.place-card__img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s ease}
.place-card:hover .place-card__img img{transform:scale(1.05)}
.place-card__img .photo-ph{position:absolute;inset:0}
.place-card__title{display:block;background:#D2D300;color:var(--ink);font-family:'Sora','Inter',sans-serif;font-size:1.05rem;font-weight:700;letter-spacing:-.01em;padding:14px 22px;margin:14px 0 0}
.place-card__body{font-size:.88rem;color:var(--ink-mid);line-height:1.6;padding:18px 22px 0}
.place-card__cta{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--ink);font-family:'Inter',sans-serif;font-size:.7rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;padding:10px 20px;border:1.5px solid var(--ink);border-radius:9999px;margin:20px 22px 0;text-decoration:none;align-self:flex-start;transition:all .25s ease}
.place-card__cta:hover{background:var(--ink);color:var(--white)}
.place-card__cta svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.5;transition:transform .25s}
.place-card__cta:hover svg{transform:translateX(3px)}
@media(max-width:760px){
  .places-grid{grid-template-columns:1fr;gap:40px;max-width:340px}
}

/* ================================================================
   PHOTO PLACEHOLDER (drop a real JPG with the named filename)
   ================================================================ */
.photo-ph{position:relative;width:100%;height:100%;background:repeating-linear-gradient(45deg,#112337 0,#112337 18px,#1f3550 18px,#1f3550 36px);display:flex;flex-direction:column;align-items:center;justify-content:center;color:white;text-align:center;padding:24px;min-height:240px}
.photo-ph::before{content:'';position:absolute;inset:14px;border:1.5px dashed rgba(255,255,255,.35);border-radius:8px;pointer-events:none}
.photo-ph__num{font-family:'Inter',sans-serif;font-size:2.4rem;font-weight:800;line-height:1;margin-bottom:6px;letter-spacing:-.03em}
.photo-ph__label{font-size:.66rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.85);margin-bottom:14px;font-family:'Inter',sans-serif}
.photo-ph__file{font-family:'Inter',sans-serif;font-size:.72rem;background:rgba(0,0,0,.4);padding:7px 14px;border-radius:6px;color:rgba(255,255,255,.95);letter-spacing:.02em;font-weight:600}
.cat-box .photo-ph,.svc-img-card .photo-ph{position:absolute;inset:0}
.two-col__image .photo-ph{height:480px}
.hero__bg.photo-ph{position:absolute;inset:0;height:auto;min-height:auto}

/* ================================================================
   NAV DROPDOWN — Projects sub-categories
   ================================================================ */
.nav__links li.has-dropdown{position:relative}
.nav__dropdown{list-style:none;margin:0;padding:8px 0;position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);background:#112337;border-radius:14px;box-shadow:0 18px 40px rgba(0,0,0,.32);min-width:220px;opacity:0;visibility:hidden;transition:opacity .2s ease,transform .2s ease,visibility .2s;border:1.5px solid rgba(255,255,255,.08);z-index:1000}
.nav__links li.has-dropdown:hover .nav__dropdown,
.nav__links li.has-dropdown:focus-within .nav__dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav__dropdown li{display:block}
.nav__dropdown li a{display:block;padding:11px 22px;font-family:'Inter',sans-serif;font-size:.85rem;font-weight:600;color:rgba(255,255,255,.85);text-decoration:none;letter-spacing:.005em;transition:all .15s ease;border-radius:0}
.nav__dropdown li a:hover{background:rgba(210,211,0,.16);color:#D2D300}
/* small caret on the parent link */
.nav__links li.has-dropdown > a::after{content:" \25BE";font-size:.7em;opacity:.7;margin-left:2px}

/* mobile-nav dropdown — show inline as indented sub-list */
.mobile-nav li.has-dropdown > .nav__dropdown{position:static;background:transparent;box-shadow:none;border:none;opacity:1;visibility:visible;transform:none;padding:0 0 0 16px;min-width:0}
.mobile-nav li.has-dropdown > .nav__dropdown li a{padding:10px 0;font-size:.95rem;color:rgba(255,255,255,.7)}
.mobile-nav li.has-dropdown > a::after{content:""}

/* ================================================================
   LI CHARTERED MEMBER LOGO — creds bar
   ================================================================ */
.cred-pill--li{padding:0;border:none;background:transparent;display:inline-flex;align-items:center}
.cred-pill--li img{display:block;height:62px;width:auto;border-radius:6px}
@media(max-width:640px){.cred-pill--li img{height:52px}}

/* ================================================================
   FOOTER LI LOGO — Chartered Member badge in brand block
   ================================================================ */
.footer__li-logo{display:inline-block;margin-top:18px;line-height:0;border-radius:6px;overflow:hidden}
.footer__li-logo img{display:block;height:80px;width:auto;border-radius:6px;transition:transform .25s ease}
.footer__li-logo:hover img{transform:scale(1.04)}

/* ================================================================
   NAV LOGO IMAGE — replaces the TLW text mark
   ================================================================ */
.nav__logo{display:inline-flex;align-items:center;text-decoration:none}
.nav__logo-img{display:block;height:44px;width:auto;border-radius:6px;transition:transform .2s ease}
.nav__logo:hover .nav__logo-img{transform:scale(1.04)}
.footer__brand .nav__logo-img{height:54px;border-radius:6px}
@media(max-width:640px){.nav__logo-img{height:38px}}

