/* Color Splash Painting — Editorial Magazine Direction
   Mockup 2 — premium Lowcountry home magazine
   Fonts: DM Serif Display (headlines) + Manrope (body)
   Colors: Orange #FF4800, Blue #14B3F2, Magenta #FF00BD, Dark #1F1F1F,
           Off-white #FBF8F4, White #FFFFFF
*/

/* -------- Reset -------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:'Manrope',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:#1F1F1F;background:#FBF8F4;line-height:1.6;font-size:16px;
  font-feature-settings:"kern","liga";text-rendering:optimizeLegibility}
img,svg,iframe{max-width:100%;display:block}
img{height:auto}
a{color:#1F1F1F;text-decoration:none;transition:color .2s ease, opacity .2s ease}
a:hover{color:#FF4800}
button{font-family:inherit;cursor:pointer;border:none;background:none}
h1,h2,h3,h4,h5,h6{margin:0;font-family:'DM Serif Display',Georgia,serif;font-weight:400;
  line-height:1.15;color:#1F1F1F;letter-spacing:-.01em}
p{margin:0 0 1em}

/* -------- Tokens -------- */
:root{
  --orange:#FF4800;
  --blue:#14B3F2;
  --magenta:#FF00BD;
  --dark:#1F1F1F;
  --cream:#FBF8F4;
  --cream-photo:#F5EFE4;
  --pink-tint:#FBEBF4;
  --blue-tint:#EAF6FB;
  --white:#FFFFFF;
  --hairline:rgba(31,31,31,.14);
  --muted:rgba(31,31,31,.62);
  --soft:rgba(31,31,31,.85);
  --serif:'DM Serif Display',Georgia,serif;
  --sans:'Manrope',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --shadow-card:0 4px 16px rgba(0,0,0,.06);
  --shadow-soft:0 2px 8px rgba(0,0,0,.04);
  --max:1200px;
  --max-narrow:880px;
  --max-reading:680px;
}

/* -------- Accessibility helpers -------- */
.skip-link{position:absolute;left:-9999px;top:0;background:#1F1F1F;color:#fff;padding:12px 18px;z-index:9999;font-weight:600}
.skip-link:focus{left:12px;top:12px;color:#fff}
body.font-lg{font-size:18px}
body.font-xl{font-size:20px}
body.high-contrast{--muted:rgba(31,31,31,.85);--hairline:rgba(31,31,31,.5);--soft:#1F1F1F}
body.high-contrast .btn-secondary{border-color:#1F1F1F;color:#1F1F1F}
*:focus-visible{outline:2px solid #FF4800;outline-offset:2px;border-radius:2px}

/* -------- Layout -------- */
.container{max-width:var(--max);margin:0 auto;padding:0 24px}
.container-narrow{max-width:var(--max-narrow);margin:0 auto;padding:0 24px}
.container-reading{max-width:var(--max-reading);margin:0 auto;padding:0 24px}

/* -------- Kickers & rule -------- */
.kicker{display:inline-block;font-family:var(--sans);font-size:12px;font-weight:600;
  letter-spacing:.25em;text-transform:uppercase;color:var(--orange);margin:0}
.rule{width:80px;height:4px;background:var(--orange);margin:16px 0 32px;border:0;display:block}
.rule-thin{width:48px;height:2px;background:var(--orange);margin:12px 0 20px;border:0;display:block}

/* -------- Buttons -------- */
.btn{display:inline-block;padding:14px 28px;font-weight:600;font-family:var(--sans);
  font-size:15px;letter-spacing:.02em;border-radius:6px;transition:all .2s ease;line-height:1;cursor:pointer;border:none}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{background:#e03e00;color:#fff;transform:translateY(-1px)}
.btn-secondary{background:transparent;color:var(--dark);border:1px solid var(--dark)}
.btn-secondary:hover{background:var(--dark);color:#fff}
.btn-ghost{background:transparent;color:var(--dark);border:1px solid rgba(31,31,31,.25)}
.btn-ghost:hover{border-color:var(--dark)}
.btn-phone{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;font-weight:600;
  font-family:var(--sans);font-size:15px;border:1px solid var(--dark);border-radius:6px;color:var(--dark)}
.btn-phone:hover{background:var(--dark);color:#fff}
.btn-white{background:#fff;color:var(--dark);padding:14px 28px;border-radius:6px;font-weight:600}
.btn-white:hover{background:var(--cream);color:var(--dark)}
.btn-cream-outline{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.6);padding:14px 28px;border-radius:6px;font-weight:600}
.btn-cream-outline:hover{border-color:#fff;background:rgba(255,255,255,.08);color:#fff}

/* -------- Announcement bar -------- */
.announce{background:var(--dark);color:#fff;font-size:13px;padding:10px 24px;text-align:center;
  letter-spacing:.02em}
.announce a{color:#fff;border-bottom:1px solid rgba(255,255,255,.35)}
.announce a:hover{color:#fff;border-bottom-color:#fff}
.announce .pin{color:var(--orange);margin-right:6px;font-size:10px}

/* -------- Header / nav -------- */
.site-header{background:#fff;border-bottom:1px solid var(--hairline);position:sticky;top:0;z-index:50}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:18px 24px;max-width:1440px;margin:0 auto}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:22px;color:var(--dark)}
.logo-mark{width:28px;height:28px;border-radius:6px;background:var(--orange);position:relative;flex-shrink:0}
.logo-mark::after{content:"";position:absolute;width:10px;height:10px;border-radius:50%;background:var(--magenta);top:-3px;right:-3px}
.logo-text{font-weight:400;letter-spacing:-.01em}
.logo-text em{font-style:italic;color:var(--orange)}
.nav{display:flex;gap:28px;align-items:center}
.nav a{font-family:var(--sans);font-size:14px;font-weight:500;color:var(--dark)}
.nav a:hover{color:var(--orange)}
.nav a.active{color:var(--orange)}
.header-right{display:flex;align-items:center;gap:16px}
.a11y{display:flex;align-items:center;gap:6px;border-right:1px solid var(--hairline);padding-right:16px}
.a11y button{width:30px;height:30px;border-radius:50%;border:1px solid var(--hairline);background:#fff;
  font-size:12px;font-weight:700;color:var(--dark);display:inline-flex;align-items:center;justify-content:center}
.a11y button:hover{border-color:var(--dark)}
.a11y button.active{background:var(--dark);color:#fff;border-color:var(--dark)}
.header-phone{font-family:var(--sans);font-weight:600;font-size:14px}
.mobile-toggle{display:none;width:40px;height:40px;align-items:center;justify-content:center;border:1px solid var(--hairline);border-radius:6px}
.mobile-toggle span{width:18px;height:2px;background:var(--dark);position:relative;display:block}
.mobile-toggle span::before,.mobile-toggle span::after{content:"";position:absolute;width:18px;height:2px;background:var(--dark);left:0}
.mobile-toggle span::before{top:-6px}.mobile-toggle span::after{top:6px}

@media(max-width:960px){
  .nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;
    padding:20px 24px;gap:16px;border-bottom:1px solid var(--hairline);align-items:flex-start}
  .nav.open{display:flex}
  .a11y,.header-phone{display:none}
  .mobile-toggle{display:inline-flex}
}

/* -------- Hero (editorial) -------- */
.hero{background:#FBF8F4;padding:120px 24px 100px;position:relative;overflow:hidden}
.hero-inner{max-width:880px;margin:0 auto;text-align:left;position:relative;z-index:2}
.hero-kicker{font-size:12px;text-transform:uppercase;letter-spacing:.25em;color:#FF4800;
  font-weight:600;font-family:var(--sans)}
.hero-underline{height:4px;width:80px;background:#FF4800;margin:16px 0 32px}
.hero-headline{font-family:var(--serif);font-size:clamp(48px,7vw,88px);line-height:1.05;color:#1F1F1F;
  letter-spacing:-.02em;margin:0 0 32px;font-weight:400}
.hero-headline em{color:#FF4800;font-style:italic}
.hero-sub{font-family:var(--sans);font-size:clamp(17px,1.4vw,20px);line-height:1.6;
  color:rgba(31,31,31,.85);max-width:640px;margin:0}
.hero-stats{font-family:var(--sans);font-size:14px;color:rgba(31,31,31,.62);margin-top:32px;letter-spacing:.01em}
.hero-stats .stars{color:var(--orange);letter-spacing:1px}
.hero-ctas{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}
.hero-accent{position:absolute;top:40px;right:60px;width:56px;height:56px;opacity:.6;pointer-events:none;z-index:1}

/* Sub-page hero variant */
.hero.sub{padding:80px 24px 60px}
.hero.sub .hero-headline{font-size:clamp(40px,5vw,64px)}

/* -------- Trust strip -------- */
.trust-strip{background:#fff;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);padding:20px 24px}
.trust-strip-inner{max-width:var(--max);margin:0 auto;display:flex;flex-wrap:wrap;gap:12px 32px;
  justify-content:center;align-items:center;font-family:var(--sans);font-size:13px;color:var(--soft);font-weight:500}
.trust-strip-inner span{display:inline-flex;align-items:center;gap:8px}
.trust-strip-inner span::before{content:"";width:4px;height:4px;border-radius:50%;background:var(--orange)}

/* -------- Sections -------- */
.section{padding:100px 24px}
.section-sm{padding:72px 24px}
.section-cream{background:var(--cream)}
.section-white{background:#fff}
.section-blue-tint{background:var(--blue-tint)}
.section-pink-tint{background:var(--pink-tint)}
.section-dark{background:var(--dark);color:#fff}
.section-dark h1,.section-dark h2,.section-dark h3{color:#fff}
.section-inner{max-width:var(--max);margin:0 auto}
.section-header{max-width:var(--max-narrow);margin:0 auto 60px}
.section-header.center{text-align:center;margin-left:auto;margin-right:auto}
.section-header.center .rule{margin-left:auto;margin-right:auto}
.h-display{font-family:var(--serif);font-size:clamp(36px,4.4vw,56px);line-height:1.1;letter-spacing:-.02em}
.h-section{font-family:var(--serif);font-size:clamp(32px,3.8vw,48px);line-height:1.1;letter-spacing:-.02em}
.h-sub{font-family:var(--serif);font-size:clamp(24px,2.6vw,32px);line-height:1.2}
.lede{font-size:18px;line-height:1.65;color:var(--soft);max-width:620px}

/* -------- Two-col -------- */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.two-col.wide-right{grid-template-columns:1fr 1.15fr}
.two-col.wide-left{grid-template-columns:1.15fr 1fr}
@media(max-width:860px){.two-col{grid-template-columns:1fr;gap:40px}}

/* -------- Photo placeholder (cream, warm) -------- */
.photo{background:var(--cream-photo);border:1px solid var(--hairline);border-radius:10px;
  aspect-ratio:4/3;display:flex;align-items:flex-end;padding:20px;position:relative;overflow:hidden}
.photo.tall{aspect-ratio:3/4}
.photo.wide{aspect-ratio:16/9}
.photo.square{aspect-ratio:1/1}
.photo-label{font-family:var(--serif);font-style:italic;font-size:14px;color:rgba(31,31,31,.55);
  max-width:80%;line-height:1.4;letter-spacing:.01em}
.photo::before{content:"";position:absolute;inset:0;background-image:
  repeating-linear-gradient(135deg,transparent 0 14px,rgba(31,31,31,.025) 14px 15px);pointer-events:none}

/* -------- Card -------- */
.card{background:#fff;border:1px solid var(--hairline);border-radius:10px;padding:28px;
  box-shadow:var(--shadow-card);transition:transform .2s ease,box-shadow .2s ease}
.card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.08)}
.card-pad-sm{padding:20px}
.card-pad-lg{padding:40px}
.card h3{font-size:22px;margin-bottom:10px}

/* -------- Grids -------- */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.grid-6{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:960px){.grid-3,.grid-4,.grid-6{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid-2,.grid-3,.grid-4,.grid-6{grid-template-columns:1fr}}

/* -------- Start project form section -------- */
.start-project{padding:100px 24px;background:#fff}
.start-project-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:start}
@media(max-width:860px){.start-project-inner{grid-template-columns:1fr;gap:40px}}
.form-card{background:#fff;border:1px solid var(--hairline);border-radius:12px;padding:28px;box-shadow:var(--shadow-card)}
.form-card h3{font-size:22px;margin-bottom:6px}
.form-card-intro{font-size:14px;color:var(--muted);margin-bottom:18px}

/* -------- Services -------- */
.service-split{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:56px}
@media(max-width:860px){.service-split{grid-template-columns:1fr}}
.service-split .card{padding:36px}
.service-split h3{font-size:28px;margin-bottom:8px}
.service-split ul{list-style:none;padding:0;margin:18px 0 0}
.service-split ul li{padding:10px 0;border-top:1px solid var(--hairline);display:flex;justify-content:space-between;align-items:center;
  font-family:var(--sans);font-size:15px}
.service-split ul li::after{content:"→";color:var(--orange);font-weight:500}

/* Image-card service tiles */
.service-tile{background:#fff;border:1px solid var(--hairline);border-radius:10px;
  transition:all .2s ease;display:block;color:var(--dark);overflow:hidden;box-shadow:var(--shadow-card)}
.service-tile:hover{border-color:var(--orange);transform:translateY(-3px);color:var(--dark);box-shadow:0 10px 28px rgba(0,0,0,.09)}
.service-tile .tile-photo{aspect-ratio:4/3;background:var(--cream-photo);position:relative;overflow:hidden;display:flex;align-items:flex-end;padding:16px}
.service-tile .tile-photo::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,transparent 0 14px,rgba(31,31,31,.025) 14px 15px)}
.service-tile .tile-photo .photo-label{font-family:var(--serif);font-style:italic;font-size:13px;color:rgba(31,31,31,.55);position:relative;z-index:2;max-width:85%;line-height:1.4;margin-top:auto}
.service-tile .tile-tag{position:absolute;top:14px;left:14px;z-index:3;background:var(--orange);color:#fff;font-family:var(--sans);font-size:10px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;padding:5px 10px;border-radius:4px}
.service-tile .tile-tag.commercial{background:var(--magenta)}
.service-tile .tile-body{padding:22px 24px 26px}
.service-tile h4{font-family:var(--serif);font-size:24px;margin:0 0 8px;font-weight:400;line-height:1.2;letter-spacing:-.01em}
.service-tile p{font-size:14px;color:var(--muted);margin:0 0 14px;line-height:1.5}
.service-tile .learn{font-family:var(--sans);font-size:13px;font-weight:600;color:var(--orange);display:inline-flex;align-items:center;gap:6px;transition:gap .2s}
.service-tile:hover .learn{gap:10px}

/* -------- Brand flourishes (editorial but still Color Splash) -------- */
.gradient-rule{height:3px;background:linear-gradient(90deg,#FF4800,#FF00BD 55%,#14B3F2);border:0;border-radius:2px;margin:16px 0 28px;width:120px}
.gradient-underline{background:linear-gradient(90deg,#FF4800,#FF00BD);background-size:100% 8px;
  background-repeat:no-repeat;background-position:0 88%;padding:0 2px}
.splash-accent{position:absolute;width:52px;height:52px;opacity:.55;pointer-events:none;z-index:0}
.pullquote.with-gradient{border-left:none;position:relative;padding-left:26px}
.pullquote.with-gradient::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,#FF4800,#FF00BD,#14B3F2);border-radius:2px}
.bungee{font-family:'Bungee',var(--serif);letter-spacing:.02em}
.gradient-bar{height:2px;background:linear-gradient(90deg,#FF4800,#FF00BD 55%,#14B3F2);border:0;margin:0}
.stat-card{position:relative;overflow:hidden}
.stat-card .splash-accent{top:-8px;right:-8px}

/* -------- Why choose numerals -------- */
.numerals{display:flex;flex-direction:column;gap:28px}
.numeral{display:grid;grid-template-columns:72px 1fr;gap:20px;padding-bottom:24px;border-bottom:1px solid var(--hairline)}
.numeral:last-child{border-bottom:none}
.numeral .n{font-family:var(--serif);font-size:42px;color:var(--orange);font-style:italic;line-height:1}
.numeral h4{font-family:var(--serif);font-size:22px;margin:0 0 6px;font-weight:400}
.numeral p{font-size:14px;color:var(--muted);margin:0}

/* Video card w/ orange accent bar */
.video-card{background:#fff;border:1px solid var(--hairline);border-radius:12px;padding:14px;position:relative;box-shadow:var(--shadow-card)}
.video-card::before{content:"";position:absolute;top:-1px;left:-1px;bottom:-1px;width:5px;background:var(--orange);
  border-radius:12px 0 0 12px}

/* -------- Gallery tile -------- */
.gallery-tile{position:relative;overflow:hidden;border-radius:10px;background:var(--cream-photo);aspect-ratio:4/3;
  border:1px solid var(--hairline);display:flex;align-items:flex-end;padding:18px;transition:transform .2s ease}
.gallery-tile:hover{transform:translateY(-2px)}
.gallery-tile::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,transparent 0 14px,rgba(31,31,31,.025) 14px 15px)}
.gallery-tile .tag{position:relative;z-index:2;background:#fff;padding:6px 10px;border-radius:4px;font-size:11px;
  font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--dark);border:1px solid var(--hairline)}
.gallery-tile .caption{position:relative;z-index:2;margin-left:auto;font-family:var(--serif);font-style:italic;font-size:13px;color:rgba(31,31,31,.55)}

/* -------- Map + city cards -------- */
.areas-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:32px;align-items:start}
@media(max-width:860px){.areas-grid{grid-template-columns:1fr}}
.city-list{display:flex;flex-direction:column;gap:10px}
.city-card{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;padding:18px 22px;
  border:1px solid var(--hairline);border-radius:10px;background:#fff;transition:all .2s ease;color:var(--dark)}
.city-card:hover{border-color:var(--dark);transform:translateX(2px);color:var(--dark)}
.city-dot{width:14px;height:14px;border-radius:50%;background:var(--blue);flex-shrink:0}
.city-dot.orange{background:var(--orange)}
.city-dot.magenta{background:var(--magenta)}
.city-info h4{font-family:var(--serif);font-size:20px;margin:0;font-weight:400}
.city-info span{font-family:var(--sans);font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}
.city-arrow{color:var(--orange);font-size:20px}

/* -------- Reviews -------- */
.review-card{background:#fff;border:1px solid var(--hairline);border-radius:10px;padding:28px}
.review-card .stars{color:var(--orange);font-size:14px;letter-spacing:2px;margin-bottom:12px}
.review-card blockquote{font-family:var(--serif);font-size:17px;line-height:1.45;margin:0 0 16px;color:var(--dark);font-style:italic;font-weight:400;letter-spacing:-.01em}
.review-card .reviewer{font-family:var(--sans);font-size:13px;color:var(--muted);display:flex;justify-content:space-between;align-items:center}
.review-card .reviewer b{color:var(--dark);font-weight:600}

/* -------- Resources / guide cards -------- */
.resource-card{background:#fff;border:1px solid var(--hairline);border-radius:10px;padding:26px;display:flex;flex-direction:column;height:100%;
  color:var(--dark);transition:all .2s ease}
.resource-card:hover{border-color:var(--orange);transform:translateY(-2px);color:var(--dark)}
.resource-card .pillar{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--orange);margin-bottom:14px}
.resource-card h4{font-family:var(--serif);font-size:20px;margin:0 0 auto;font-weight:400;line-height:1.25}
.resource-card .read{font-family:var(--sans);font-size:13px;color:var(--muted);margin-top:16px;display:flex;justify-content:space-between;align-items:center}

/* -------- Social cards -------- */
.social-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:720px){.social-grid{grid-template-columns:1fr}}
.social-card{background:#fff;border:1px solid var(--hairline);border-radius:10px;padding:24px;display:flex;
  flex-direction:column;gap:14px;color:var(--dark);transition:all .2s ease}
.social-card:hover{border-color:var(--dark);transform:translateY(-2px);color:var(--dark)}
.social-card .handle{font-family:var(--serif);font-size:22px;font-weight:400}
.social-card .platform{font-family:var(--sans);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.social-card .arrow{color:var(--orange);font-size:18px;margin-top:auto}

/* -------- Financing strip -------- */
.financing-strip{background:#fff;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);padding:80px 24px;text-align:center}
.financing-strip h2{font-size:clamp(32px,4vw,52px);max-width:880px;margin:0 auto 20px;line-height:1.1}
.financing-strip .rule{margin:0 auto 24px}

/* -------- FAQ -------- */
.faq{max-width:var(--max-narrow);margin:0 auto}
.faq details{border-bottom:1px solid var(--hairline);padding:20px 0}
.faq details[open] summary{color:var(--orange)}
.faq summary{font-family:var(--serif);font-size:22px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px;font-weight:400}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:28px;color:var(--orange);font-family:var(--sans);font-weight:300;flex-shrink:0;transition:transform .2s}
.faq details[open] summary::after{content:"−"}
.faq .faq-body{padding:18px 0 4px;color:var(--soft);line-height:1.7;max-width:720px}

/* -------- Final CTA gradient strip (ONLY gradient) -------- */
.final-cta{background:linear-gradient(135deg,#FF4800 0%,#FF00BD 55%,#14B3F2 100%);padding:100px 24px;text-align:center;color:#fff}
.final-cta h2{color:#fff;font-size:clamp(40px,5.5vw,72px);max-width:900px;margin:0 auto 20px;line-height:1.05;letter-spacing:-.02em}
.final-cta p{color:rgba(255,255,255,.92);font-size:19px;max-width:640px;margin:0 auto 36px;line-height:1.55}
.final-cta .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* -------- Footer -------- */
.footer{background:var(--dark);color:#fff;padding:80px 24px 40px}
.footer a{color:rgba(255,255,255,.75)}
.footer a:hover{color:#fff}
.footer-top{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr;gap:48px;
  padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.12)}
@media(max-width:860px){.footer-top{grid-template-columns:1fr}}
.footer-brand h3{color:#fff;font-size:28px;margin-bottom:12px;font-weight:400}
.footer-brand p{color:rgba(255,255,255,.7);max-width:400px;margin-bottom:24px;line-height:1.6}
.footer-badges{display:flex;gap:12px;flex-wrap:wrap}
.footer-badge{border:1px solid rgba(255,255,255,.25);padding:8px 14px;border-radius:4px;font-size:12px;font-weight:500;color:rgba(255,255,255,.85);display:inline-flex;align-items:center;gap:8px;letter-spacing:.02em}
.footer-badge::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--orange)}
.footer-offices{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:560px){.footer-offices{grid-template-columns:1fr}}
.office h4{font-family:var(--sans);color:#fff;font-size:11px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:10px;font-weight:700}
.office p{color:rgba(255,255,255,.72);font-size:13px;line-height:1.6;margin-bottom:4px}
.office .phone{display:block;color:#fff;font-weight:600;font-size:15px;margin-top:6px}
.footer-mid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);gap:32px;padding:48px 0}
@media(max-width:960px){.footer-mid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:620px){.footer-mid{grid-template-columns:repeat(2,1fr)}}
.footer-col h5{font-family:var(--sans);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#fff;margin-bottom:16px;font-weight:700}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin-bottom:10px}
.footer-col a{font-size:13px;line-height:1.5}
.footer-bottom{max-width:var(--max);margin:0 auto;padding-top:32px;border-top:1px solid rgba(255,255,255,.12);
  display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;align-items:center}
.footer-bottom p{margin:0;color:rgba(255,255,255,.55);font-size:13px}
.footer-bottom .copy a{margin-left:12px;font-size:13px}
.socials{display:flex;gap:10px}
.social-icon{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.25);display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:14px}
.social-icon:hover{background:var(--orange);border-color:var(--orange);color:#fff}

/* -------- Breadcrumb -------- */
.breadcrumb{padding:20px 24px;background:#fff;border-bottom:1px solid var(--hairline);font-size:13px;color:var(--muted)}
.breadcrumb-inner{max-width:var(--max);margin:0 auto}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--orange)}
.breadcrumb .sep{margin:0 8px;color:rgba(31,31,31,.3)}

/* -------- Utility -------- */
.center{text-align:center}
.muted{color:var(--muted)}
.mb-0{margin-bottom:0}
.mt-auto{margin-top:auto}
.link-arrow{font-family:var(--sans);font-size:14px;font-weight:600;color:var(--orange);display:inline-flex;align-items:center;gap:8px;border-bottom:1px solid var(--orange);padding-bottom:2px}
.link-arrow:hover{color:var(--orange);gap:12px}

/* -------- Process steps -------- */
.process{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;margin-top:40px}
@media(max-width:960px){.process{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.process{grid-template-columns:1fr}}
.step{position:relative}
.step .step-n{font-family:var(--serif);font-size:44px;color:var(--orange);font-style:italic;line-height:1}
.step h4{font-family:var(--serif);font-size:22px;margin:10px 0 6px;font-weight:400}
.step p{font-size:14px;color:var(--muted);margin:0;line-height:1.55}

/* -------- Pull quote / testimonial -------- */
.pullquote{font-family:var(--serif);font-size:24px;line-height:1.35;color:var(--dark);font-style:italic;
  border-left:3px solid var(--orange);padding-left:24px;margin:24px 0}
.signature{font-family:var(--serif);font-style:italic;font-size:18px;margin-top:10px;color:var(--muted)}

/* -------- Included list (service pages) -------- */
.included{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:40px}
@media(max-width:720px){.included{grid-template-columns:1fr;gap:28px}}
.included ul{list-style:none;padding:0;margin:0}
.included ul li{padding:12px 0;border-top:1px solid var(--hairline);display:flex;gap:12px;align-items:flex-start;font-size:15px}
.included ul li::before{content:"✓";color:var(--orange);font-weight:700;flex-shrink:0}
.included h4{font-family:var(--serif);font-size:22px;margin-bottom:8px;font-weight:400}

/* -------- Blog/article page content -------- */
.article-body{max-width:var(--max-reading);margin:0 auto;padding:0 24px;font-size:17px;line-height:1.75;color:var(--dark)}
.article-body h2{font-family:var(--serif);font-size:32px;margin:56px 0 16px;font-weight:400;line-height:1.2}
.article-body h3{font-family:var(--serif);font-size:24px;margin:40px 0 12px;font-weight:400}
.article-body p{margin-bottom:20px}
.article-body ul,.article-body ol{margin:0 0 24px;padding-left:22px}
.article-body li{margin-bottom:8px}
.article-body blockquote{font-family:var(--serif);font-style:italic;font-size:22px;border-left:3px solid var(--orange);padding:8px 0 8px 24px;margin:32px 0;color:var(--dark);line-height:1.4}
.article-body a{color:var(--orange);border-bottom:1px solid var(--orange)}
.article-body a:hover{color:#e03e00}
.byline{font-family:var(--sans);font-size:13px;color:var(--muted);margin-bottom:40px;padding-bottom:20px;border-bottom:1px solid var(--hairline);max-width:var(--max-reading);margin-left:auto;margin-right:auto;padding-left:24px;padding-right:24px}
.toc{background:var(--cream);border:1px solid var(--hairline);border-radius:10px;padding:24px;margin:32px 0}
.toc h5{font-family:var(--sans);font-size:11px;letter-spacing:.2em;text-transform:uppercase;margin:0 0 12px;font-weight:700}
.toc ol{margin:0;padding-left:22px}
.toc li{margin-bottom:6px;font-size:14px}
.toc a{color:var(--dark);border:none}

/* -------- Category pills (blog/resources) -------- */
.pills{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:40px;justify-content:center}
.pill{display:inline-block;padding:8px 16px;border:1px solid var(--hairline);border-radius:999px;font-size:13px;font-weight:500;
  color:var(--dark);background:#fff;cursor:pointer;transition:all .2s ease}
.pill:hover,.pill.active{background:var(--dark);color:#fff;border-color:var(--dark)}

/* -------- Tweaks panel -------- */
.tweaks-panel{position:fixed;bottom:20px;right:20px;width:320px;background:#fff;border:1px solid var(--hairline);
  border-radius:10px;padding:18px;box-shadow:0 12px 32px rgba(0,0,0,.16);z-index:100;display:none;font-family:var(--sans)}
.tweaks-panel.open{display:block}
.tweaks-panel h5{font-family:var(--sans);font-size:11px;letter-spacing:.2em;text-transform:uppercase;margin:0 0 14px;font-weight:700}
.tweak-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--hairline);font-size:13px}
.tweak-row:last-child{border-bottom:none}
.tweak-row label{color:var(--muted);font-weight:500}
.tweak-row input[type=color]{width:40px;height:28px;border:1px solid var(--hairline);border-radius:4px;background:none;cursor:pointer}
.tweak-row select,.tweak-row input[type=range]{font-size:12px;padding:4px 8px;border:1px solid var(--hairline);border-radius:4px;background:#fff}
.tweak-row input[type=checkbox]{accent-color:var(--orange);width:16px;height:16px}

/* -------- Print -------- */
@media print{
  .site-header,.footer,.announce,.tweaks-panel,.mobile-toggle{display:none}
  .hero{padding:40px 24px}
}
