/* ==========================================================================
   Northern Beaches Drafting, Design System
   Coastal-editorial, premium, conversion-focused.
   ========================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Lora:wght@500;600;700&display=swap');

:root{
  --navy:#263878;
  --navy-700:#1c2b5e;
  --navy-900:#141d3f;
  --sky:#07afe5;
  --sky-600:#0590c0;
  --sky-light:#5bcaee;
  --sky-50:#eaf7fd;
  --sand:#f5f6fa;
  --sand-2:#eef1f7;
  --ink:#1b2230;
  --grey:#5b6677;
  --line:#e6e9f1;
  --white:#ffffff;
  --amber:#ff9f1c;
  --radius:16px;
  --radius-sm:10px;
  --radius-lg:22px;
  --shadow:0 1px 2px rgba(20,29,63,.04), 0 14px 34px -12px rgba(20,29,63,.14);
  --shadow-lg:0 2px 6px rgba(20,29,63,.05), 0 34px 70px -22px rgba(20,29,63,.30);
  --max:1180px;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --font-display:'Lora','Hoefler Text',Georgia,'Times New Roman',serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--white);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--sky-600);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{font-family:var(--font-display);color:var(--navy);font-weight:600;line-height:1.08;letter-spacing:-.015em;font-optical-sizing:auto}
h4{font-family:var(--font);line-height:1.2;color:var(--navy);font-weight:700;letter-spacing:-.01em}
h1{font-size:clamp(2.4rem,5.4vw,4rem);margin-bottom:.45em}
h2{font-size:clamp(1.9rem,3.8vw,2.85rem);margin-bottom:.55em}
h3{font-size:1.32rem;letter-spacing:-.01em;margin-bottom:.45em}
p{margin-bottom:1rem}
.container{max-width:var(--max);margin:0 auto;padding:0 24px}
section{padding:clamp(60px,8vw,108px) 0}
.eyebrow{display:inline-flex;align-items:center;gap:9px;color:var(--sky-600);font-weight:700;text-transform:uppercase;letter-spacing:.18em;font-size:.76rem;margin-bottom:1rem}
.eyebrow::before{content:"";width:24px;height:1.5px;background:currentColor;opacity:.6}
.center .eyebrow::before{display:none}
.lead{font-size:1.2rem;color:var(--grey);max-width:62ch;line-height:1.6}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}
.bg-sand{background:var(--sand)}
.bg-navy{background:var(--navy);color:#dce6f2}
.bg-navy h2,.bg-navy h3{color:#fff}
.muted{color:var(--grey)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;justify-content:center;
  font-weight:700;font-size:1rem;line-height:1;
  padding:15px 26px;border-radius:999px;border:2px solid transparent;
  cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
  text-decoration:none;white-space:nowrap;
}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn-primary{background:var(--sky);color:#04222e}
.btn-primary:hover{background:var(--sky-600);color:#fff}
.btn-amber{background:var(--amber);color:#3a2400}
.btn-amber:hover{background:#f08c00;color:#fff}
.btn-ghost{background:transparent;border-color:rgba(255,255,255,.55);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.12);color:#fff}
.btn-outline{background:#fff;border-color:var(--line);color:var(--navy)}
.btn-outline:hover{border-color:var(--sky)}
.btn-lg{padding:18px 34px;font-size:1.08rem}
.btn-block{width:100%}

/* ---------- Top utility bar ---------- */
.topbar{background:var(--navy);color:#cfe0f0;font-size:.86rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:14px;padding-top:8px;padding-bottom:8px;flex-wrap:wrap}
.topbar a{color:#fff;font-weight:600}
.topbar .tb-right{display:flex;gap:18px;align-items:center;flex-wrap:wrap}

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:18px}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;color:var(--navy);font-size:1.12rem;letter-spacing:-.02em}
.brand:hover{text-decoration:none}
.brand .logo-mark{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--sky),var(--navy));display:grid;place-items:center;color:#fff;font-weight:800;font-size:1.05rem;flex:0 0 auto}
.brand small{display:block;font-size:.7rem;font-weight:600;color:var(--grey);letter-spacing:.05em}
.nav-links{display:flex;align-items:center;gap:6px;list-style:none}
.nav-links a{color:var(--navy);font-weight:600;padding:10px 13px;border-radius:8px;font-size:.97rem}
.nav-links a:hover{background:var(--sky-50);text-decoration:none}
.nav-links a.active{color:var(--sky-600)}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:26px;height:3px;background:var(--navy);border-radius:3px;margin:5px 0;transition:.25s}

/* ---------- Hero ---------- */
.hero{position:relative;background:linear-gradient(160deg,#1c2b5e 0%,#263878 52%,#2f4aa0 100%);color:#fff;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(1100px 480px at 80% -10%,rgba(7,175,229,.40),transparent 60%);pointer-events:none}
/* hero with photo background */
.hero.has-photo{background:#1c2b5e}
.hero.has-photo .hero-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;opacity:.5}
.hero.has-photo::after{background:linear-gradient(110deg,rgba(28,43,94,.94) 0%,rgba(38,56,120,.80) 42%,rgba(28,43,94,.45) 100%)}
.hero .container{position:relative;z-index:2;display:grid;grid-template-columns:1.08fr .92fr;gap:56px;align-items:center;padding-top:clamp(64px,9vw,104px);padding-bottom:clamp(72px,9vw,104px)}
.hero h1{color:#fff;font-size:clamp(2.6rem,5.6vw,4.2rem);letter-spacing:-.02em}
.hero .lead{color:#cfe0f2;font-size:1.22rem}
.hero .eyebrow{color:#9fdcf5}
/* atmosphere: fine grain + soft vignette on dark surfaces */
.hero,.bg-navy,.cta-band,.page-hero,.cc-checklist{position:relative}
.hero::before,.bg-navy::before,.page-hero::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.5;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E")}
.bg-navy .container,.page-hero .container{position:relative;z-index:2}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin:22px 0 26px;padding:0;list-style:none}
.chip{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);color:#eaf4ff;padding:9px 17px 9px 10px;border-radius:999px;font-size:.9rem;font-weight:600;white-space:nowrap;backdrop-filter:blur(4px)}
.chip .tick{flex:0 0 auto;width:21px;height:21px;border-radius:50%;background:var(--sky);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:12px}
@media (min-width:981px){ .hero-badges{flex-wrap:nowrap} .chip{font-size:.86rem;padding:9px 15px 9px 9px} }
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:6px}
.hero-trust{margin-top:26px;display:flex;gap:22px;flex-wrap:wrap;color:#aecbe6;font-size:.9rem}
.hero-trust b{font-family:var(--font-display);font-weight:600;color:#fff;font-size:1.7rem;display:block;line-height:1;letter-spacing:-.01em}

/* ---------- Quote card (hero form) ---------- */
.quote-card{background:#fff;color:var(--ink);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:30px;border:1px solid rgba(255,255,255,.5)}
.quote-card h3{font-size:1.5rem;margin-bottom:5px;letter-spacing:-.015em}
.quote-card .sub{color:var(--grey);font-size:.92rem;margin-bottom:16px}
.form-row{margin-bottom:13px}
.form-row label{display:block;font-size:.82rem;font-weight:600;color:var(--navy);margin-bottom:5px}
.form-row input,.form-row select,.form-row textarea{
  width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:10px;
  font-size:1rem;font-family:inherit;color:var(--ink);background:#fff;transition:border .15s,box-shadow .15s;
}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 3px var(--sky-50)}
.form-row textarea{resize:vertical;min-height:90px}
.form-note{font-size:.78rem;color:var(--grey);margin-top:10px;text-align:center}
.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:13px}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow);transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease)}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:#d3dbec}
.card .ico{width:54px;height:54px;border-radius:13px;background:linear-gradient(150deg,var(--sky-50),#fff);border:1px solid var(--line);color:var(--sky-600);display:grid;place-items:center;margin-bottom:18px;transition:transform .35s var(--ease)}
.card:hover .ico{transform:translateY(-2px) scale(1.04)}
.card h3{margin-bottom:9px}
.card p{color:var(--grey);margin-bottom:0;font-size:.97rem}
.card .more{display:inline-block;margin-top:14px;font-weight:700;font-size:.92rem}

/* ---------- Steps ---------- */
.steps{counter-reset:step;display:grid;gap:22px;grid-template-columns:repeat(4,1fr)}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px}
.step::before{content:none}
.step h3{margin:10px 0 6px;font-size:1.08rem}
.step p{font-size:.92rem;color:var(--grey);margin:0}

/* ---------- Feature split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.tick-list{list-style:none;margin:18px 0 0}
.tick-list li{position:relative;padding-left:34px;margin-bottom:13px;color:var(--ink)}
.tick-list li::before{content:"";position:absolute;left:0;top:2px;width:22px;height:22px;border-radius:50%;background:var(--sky-50);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%230590c0' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}

/* ---------- Stats band ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat b{display:block;font-family:var(--font-display);font-size:clamp(2.6rem,4vw,3.2rem);color:#fff;line-height:1;font-weight:600;letter-spacing:-.02em}
@supports ((-webkit-background-clip:text) or (background-clip:text)){
  .bg-navy .stat b{background:linear-gradient(180deg,#fff 30%,var(--sky-light));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
}
.stat span{color:#bcd2ea;font-size:.95rem}

/* ---------- Pricing ---------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.price{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;display:flex;flex-direction:column}
.price.featured{border:2px solid var(--sky);box-shadow:var(--shadow-lg);position:relative}
.price.featured .tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--sky);color:#04222e;font-weight:700;font-size:.78rem;padding:5px 14px;border-radius:999px}
.price h3{font-size:1.2rem}
.price .amt{font-size:2.1rem;font-weight:800;color:var(--navy);margin:10px 0 2px}
.price .amt small{font-size:.95rem;color:var(--grey);font-weight:600}
.price ul{list-style:none;margin:16px 0 22px}
.price li{padding-left:26px;position:relative;margin-bottom:9px;font-size:.95rem;color:var(--ink)}
.price li::before{content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border-radius:50%;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2307aee5' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}
.price .btn{margin-top:auto}

/* ---------- Reviews ---------- */
.review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 30px 28px;box-shadow:var(--shadow);position:relative}
.review::before{content:"\201C";position:absolute;top:6px;right:24px;font-family:var(--font-display);font-size:5rem;line-height:1;color:var(--sky-50)}
.stars{display:inline-flex;gap:3px;color:#ffb703;margin-bottom:10px}
.stars .ic{width:18px;height:18px}
.review p{font-family:var(--font-display);font-weight:400;font-style:italic;color:var(--navy);font-size:1.18rem;line-height:1.5;position:relative;z-index:1}
.review .who{font-weight:700;color:var(--navy);font-style:normal;margin-top:10px;font-size:.95rem}
.review .who span{display:block;font-weight:500;color:var(--grey);font-size:.85rem}

/* ---------- Gallery ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.gal{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;background:var(--sky-50);box-shadow:var(--shadow)}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gal:hover img{transform:scale(1.06)}
.gal .cap{position:absolute;left:0;right:0;bottom:0;padding:30px 16px 14px;background:linear-gradient(transparent,rgba(10,37,64,.85));color:#fff;font-weight:600;font-size:.95rem}
.gal-placeholder{width:100%;height:100%;display:grid;place-items:center;color:var(--sky-600);background:repeating-linear-gradient(45deg,#eaf6fc,#eaf6fc 14px,#f4fbfe 14px,#f4fbfe 28px);font-weight:700;text-align:center;padding:12px;font-size:.9rem}

/* ---------- Areas ---------- */
.area-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.area-grid a{display:block;background:#fff;border:1px solid var(--line);border-radius:10px;padding:13px 16px;color:var(--navy);font-weight:600;font-size:.95rem;transition:.15s}
.area-grid a:hover{border-color:var(--sky);background:var(--sky-50);text-decoration:none;transform:translateY(-2px)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(125deg,#0a3a52 0%,var(--sky-600) 46%,var(--sky) 100%);color:#eafaff;text-align:center;border-radius:var(--radius-lg);padding:clamp(44px,6vw,68px) 28px;box-shadow:var(--shadow-lg)}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 300px at 50% -40%,rgba(255,255,255,.30),transparent 60%);pointer-events:none}
.cta-band > *{position:relative;z-index:1}
.cta-band h2{color:#fff}
.cta-band p{color:#d6f3ff}
.cta-band h2{color:#04222e}
.cta-band p{color:#053246;max-width:60ch;margin-left:auto;margin-right:auto}

/* ---------- FAQ ---------- */
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:6px 22px;margin-bottom:12px}
.faq summary{cursor:pointer;font-weight:700;color:var(--navy);padding:14px 0;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--sky);font-weight:400}
.faq details[open] summary::after{content:"\2212"}
.faq details p{color:var(--grey);padding-bottom:14px;margin:0}

/* ---------- Footer ---------- */
.site-footer{background:#071a30;color:#9fb6cf;padding-top:60px}
.site-footer h4{color:#fff;font-size:1rem;margin-bottom:14px;letter-spacing:.02em}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.4fr;gap:30px;font-size:.9rem}
.site-footer a{color:#c7d6e6}
.site-footer li{margin-bottom:8px}
.site-footer a[href^="mailto:"]{white-space:nowrap}
.site-footer .btn-primary{color:#04222e}
.site-footer ul{list-style:none}
.site-footer li{margin-bottom:9px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:46px;padding:22px 0;font-size:.85rem;color:#7e93a9;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---------- Page hero (interior) ---------- */
.page-hero{position:relative;overflow:hidden;background:linear-gradient(160deg,#1c2b5e,#2f4aa0);color:#fff;padding:54px 0}
.page-hero.has-photo{background:#1c2b5e}
.page-hero.has-photo .ph-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center}
.page-hero.has-photo::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(118deg,rgba(28,43,94,.92) 0%,rgba(38,56,120,.80) 52%,rgba(28,43,94,.60) 100%)}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{color:#fff;margin-bottom:10px}
.page-hero h1 .accent{color:var(--sky-light)}
.page-hero p{color:#cfe0f2;max-width:64ch;margin:0}
.breadcrumb{font-size:.85rem;color:#9fc1e2;margin-bottom:14px}
.breadcrumb a{color:#cfe6fb}

/* ---------- Sticky mobile call bar ---------- */
.mobile-cta{display:none}

/* ---------- Misc ---------- */
.section-head{max-width:760px;margin:0 auto 44px}
.prose p{color:var(--grey)}
.prose h2{margin:30px 0 12px}
.prose h3{margin:24px 0 8px}
.alert{background:var(--sky-50);border:1px solid #bfe7f6;border-radius:12px;padding:18px 20px;color:#0a4a63;font-size:.95rem}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width:980px){
  .hero .container{grid-template-columns:1fr;gap:34px;padding-top:48px;padding-bottom:54px}
  .split{grid-template-columns:1fr;gap:30px}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .price-grid{grid-template-columns:1fr;max-width:460px;margin:0 auto}
  .stats{grid-template-columns:repeat(2,1fr);gap:30px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .area-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  body{font-size:16px}
  section{padding:54px 0}
  .nav-links,.nav-cta .btn{display:none}
  .nav-toggle{display:block}
  .site-header.open .nav-links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:#fff;border-bottom:1px solid var(--line);padding:12px 18px;gap:2px;box-shadow:var(--shadow)}
  .site-header.open .nav-links a{padding:13px}
  .grid-2,.grid-3,.grid-4,.gallery-grid{grid-template-columns:1fr}
  .form-2col{grid-template-columns:1fr}
  .topbar .tb-left{display:none}
  .topbar .container{justify-content:center}
  .mobile-cta{display:grid;grid-template-columns:1fr 1fr;gap:0;position:fixed;bottom:0;left:0;right:0;z-index:60;box-shadow:0 -6px 20px rgba(0,0,0,.12)}
  .mobile-cta a{padding:15px;text-align:center;font-weight:700;color:#fff;font-size:1rem}
  .mobile-cta .call{background:var(--navy)}
  .mobile-cta .quote{background:var(--sky);color:#04222e}
  body{padding-bottom:56px}
  .footer-bottom{padding-bottom:70px}
  .footer-grid{grid-template-columns:1fr;gap:6px 0}
  .site-footer .footer-grid{font-size:.92rem}
  .site-footer p{font-size:.92rem}
  .site-footer h4{margin-top:14px}
  .site-footer a[href^="mailto:"]{font-size:.92rem}
  /* trim the hero on mobile */
  .hero-badges .chip:nth-child(3){display:none}
  .hero-trust > div:nth-child(3){display:none}
}
@media (max-width:560px){
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{width:100%}
  .locale img{height:clamp(180px,46vw,300px)}
}
@media (max-width:460px){
  .stats,.area-grid{grid-template-columns:1fr}
  .hero-trust{gap:16px}
  h1{font-size:1.85rem}
}

/* ==========================================================================
   Brand logo & real imagery (added with brand rollout)
   ========================================================================== */
.brand-logo{height:46px;width:auto;display:block}
.site-footer .brand-logo{height:48px}
@media (max-width:760px){ .brand-logo{height:40px} }

/* real photos replacing placeholder tiles */
.media{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:var(--sky-50)}
.media img{width:100%;height:100%;object-fit:cover;display:block}
.split .media{aspect-ratio:4/3}
.media{position:relative}
.media-loc{position:absolute;left:12px;bottom:12px;display:inline-flex;align-items:center;gap:6px;background:rgba(38,56,120,.82);color:#fff;font-weight:600;font-size:.82rem;padding:6px 11px;border-radius:999px;line-height:1.2}
.media-loc .ic{width:14px;height:14px;color:var(--sky)}
/* full-colour local landscape band (no overlay) */
.locale{position:relative;line-height:0;padding:0}
.locale img{width:100%;height:clamp(220px,36vw,440px);object-fit:cover;display:block}
.locale-tag{position:absolute;left:20px;bottom:20px;display:inline-flex;align-items:center;gap:7px;background:rgba(38,56,120,.85);color:#fff;font-weight:600;font-size:.92rem;padding:9px 15px;border-radius:999px;line-height:1.2}
.locale-tag .ic{width:16px;height:16px;color:var(--sky)}
.media-portrait{aspect-ratio:auto;max-width:380px;margin:0 auto;background:#fff}
.media-portrait img{height:auto;object-fit:contain}
.media-cap{text-align:center;margin:14px 0 0;color:var(--grey);font-size:.95rem}
.media-cap strong{color:var(--navy)}

/* gallery: real render + line-drawing tiles */
.gal img{width:100%;height:100%;object-fit:cover}
.gal.line{background:#fff}
.gal.line img{object-fit:contain;padding:10px}
.gal.line:hover img{transform:none}
.gal.line .cap{background:linear-gradient(transparent,rgba(38,56,120,.82))}

/* line-drawing feature band */
.lineband{background:var(--sand)}
.linegrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.linegrid .gal{aspect-ratio:16/11}
@media (max-width:760px){ .linegrid{grid-template-columns:1fr} }
.td-project{margin-bottom:34px}
.td-project:last-child{margin-bottom:0}
.td-title{font-size:1.1rem;color:var(--navy);margin-bottom:15px;padding-bottom:7px;border-bottom:2px solid var(--sky);display:inline-block}

/* DA -> CC process flow */
.cc-flow{display:flex;align-items:stretch;gap:6px;margin-top:8px}
.cc-step{flex:1 1 0;position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 18px 22px;text-align:center}
.cc-step .num{position:absolute;top:-15px;left:50%;transform:translateX(-50%);width:32px;height:32px;border-radius:50%;background:var(--navy);color:#fff;font-weight:800;font-size:.92rem;display:grid;place-items:center}
.cc-ico{width:62px;height:62px;margin:6px auto 16px;border-radius:14px;background:var(--sky-50);color:var(--sky-600);display:grid;place-items:center}
.cc-ico .ic{width:30px;height:30px}
.cc-step h3{font-size:.92rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:9px;color:var(--navy)}
.cc-step p{font-size:.9rem;color:var(--grey);margin:0;line-height:1.55}
.cc-arrow{flex:0 0 auto;display:flex;align-items:center;color:var(--sky);align-self:center}
.cc-arrow .ic{width:24px;height:24px;stroke-width:2.5}
/* certifier checklist */
.cc-checklist{margin-top:26px;background:var(--navy);color:#dce6f2;border-radius:var(--radius);padding:26px 28px}
.cc-checklist h3{color:#fff;font-size:1.1rem;margin-bottom:16px}
.cc-checks{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:11px 26px}
.cc-checks li{position:relative;padding-left:28px;font-size:.95rem;color:#e6eefb}
.cc-checks li .ic{position:absolute;left:0;top:1px;width:18px;height:18px;color:var(--sky-light)}
/* standards strip */
.cc-standards{margin-top:24px;background:var(--sand);border:1px solid var(--line);border-radius:var(--radius);padding:18px 24px;display:flex;align-items:center;gap:14px 28px;flex-wrap:wrap;justify-content:center}
.cc-standards .lbl{font-weight:700;color:var(--navy);font-size:.86rem;text-transform:uppercase;letter-spacing:.08em}
.cc-std{display:flex;align-items:center;gap:10px}
.cc-std .ic{width:24px;height:24px;color:var(--sky-600);flex:0 0 auto}
.cc-std b{color:var(--navy);display:block;line-height:1.1;font-size:1.05rem}
.cc-std span{color:var(--grey);font-size:.82rem}
@media (max-width:900px){
  .cc-flow{flex-wrap:wrap}
  .cc-step{flex:1 1 calc(50% - 20px)}
  .cc-arrow{display:none}
  .cc-checks{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:560px){
  .cc-step{flex:1 1 100%}
  .cc-checks{grid-template-columns:1fr}
  .cc-standards{justify-content:flex-start}
}

/* Inline brand icons (replace emoji) */
.ic{width:1.05em;height:1.05em;display:inline-block;vertical-align:-.16em;flex:0 0 auto;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ic-fill{fill:currentColor;stroke:none}
.topbar .ic,.site-footer .ic{color:var(--sky)}
.card .ico .ic{width:26px;height:26px}
.btn .ic,.mobile-cta .ic{width:1.15em;height:1.15em}
.contact-ico .ic{width:22px;height:22px;color:var(--sky-600)}

/* ==========================================================================
   Premium motion: hero load + scroll reveal + image hover
   ========================================================================== */
.media{overflow:hidden}
.split .media img,.gal img{transition:transform .7s var(--ease)}
.split:hover .media img{transform:scale(1.045)}
.nav-links a.active{position:relative}
.nav-links a.active::after{content:"";position:absolute;left:13px;right:13px;bottom:4px;height:2px;background:var(--sky);border-radius:2px}
@media (prefers-reduced-motion: no-preference){
  .hero-copy > *,.hero .quote-card{opacity:0;animation:fadeUp .8s var(--ease) forwards}
  .hero-copy > *:nth-child(1){animation-delay:.06s}
  .hero-copy > *:nth-child(2){animation-delay:.14s}
  .hero-copy > *:nth-child(3){animation-delay:.22s}
  .hero-copy > *:nth-child(4){animation-delay:.30s}
  .hero-copy > *:nth-child(5){animation-delay:.38s}
  .hero-copy > *:nth-child(6){animation-delay:.46s}
  .hero .quote-card{animation-delay:.34s}
  @keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
  .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
  .reveal.in{opacity:1;transform:none}
}
