/* ============================================================
   PRIMEWAYS HOME IMPROVEMENTS — concept homepage
   Brand: royal/action blue + safety-yellow accent, charcoal
   neutrals. Headings: Montserrat (bold, uppercase, italic display).
   Body: Open Sans.
   ============================================================ */
:root{
  --blue-900:#1A2A55; --blue-700:#2A3F7E; --blue-600:#304080; --blue-500:#1F4FA3; --blue-400:#2E68C8;
  --blue-100:#DCE8F8; --blue-50:#EEF4FC;
  --ink-900:#0F0F0F; --ink-800:#1F1F1F; --ink-700:#2E2E2E; --ink-600:#4A4A4A; --ink-500:#6B6B6B;
  --ink-400:#8C8C8C; --ink-300:#B5B5B5; --ink-200:#DADADA; --ink-100:#F3F3F3; --ink-50:#F8F8F8;
  --accent:#F5B301; --accent-600:#D99500; --star:#F5B301; --success:#1E7A45;
  --fontH:'Montserrat',system-ui,sans-serif; --fontB:'Open Sans',system-ui,sans-serif;
  --maxw:1180px;
  --gutter:clamp(20px,5vw,56px);
  --radius-sm:5px; --radius:10px; --radius-lg:16px;
  --shadow-sm:0 1px 2px rgba(15,18,40,.06),0 6px 16px rgba(15,18,40,.08);
  --shadow-md:0 1px 2px rgba(15,18,40,.06),0 14px 34px rgba(15,18,40,.12);
  --overlay-brand:linear-gradient(120deg,rgba(26,42,85,.92) 0%,rgba(31,79,163,.72) 48%,rgba(15,15,15,.35) 100%);
  --header-h:76px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;scroll-padding-top:var(--header-h);}
body{font-family:var(--fontB);color:var(--ink-800);background:#fff;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--blue-100);color:var(--ink-900);}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter);}

/* ---------- type ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--fontH);font-weight:700;
  font-size:.8125rem;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-500);}
.eyebrow::before{content:"";width:26px;height:3px;background:var(--accent);flex:none;}
.eyebrow-dark{color:var(--accent);}

h1,h2,h3,h4{font-family:var(--fontH);text-transform:uppercase;line-height:1.04;letter-spacing:-.01em;color:var(--ink-900);}
.display{font-weight:800;font-style:italic;font-size:clamp(2.4rem,6vw,3.5rem);line-height:.97;letter-spacing:-.015em;color:#fff;text-wrap:balance;}
h2{font-weight:800;font-size:clamp(1.7rem,3.6vw,2.4rem);text-wrap:balance;}
h3{font-weight:800;font-size:clamp(1.35rem,2.4vw,1.75rem);letter-spacing:0;}
h4{font-size:.78rem;letter-spacing:.12em;}
.on-dark{color:#fff;}
.lead{font-family:var(--fontB);font-size:clamp(1rem,1.2vw,1.0625rem);line-height:1.6;color:var(--ink-500);text-wrap:pretty;}
.lead-dark{color:rgba(255,255,255,.85);}
.muted{font-family:var(--fontB);font-size:clamp(1rem,1.2vw,1.0625rem);line-height:1.6;color:var(--ink-500);}

.head{display:flex;flex-direction:column;gap:12px;max-width:600px;}
.head.center{align-items:center;text-align:center;margin-inline:auto;}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--fontH);font-weight:700;
  font-size:.875rem;letter-spacing:.06em;text-transform:uppercase;line-height:1;padding:13px 22px;border-radius:var(--radius-sm);
  border:2px solid transparent;cursor:pointer;white-space:nowrap;transition:transform .2s ease,background .2s ease,box-shadow .2s ease,border-color .2s ease;}
.btn-sm{padding:9px 15px;font-size:.78rem;}
.btn-lg{padding:16px 28px;font-size:.95rem;}
.btn-block{width:100%;}
.btn .arr{transition:transform .2s ease;}
.btn:hover .arr{transform:translateX(4px);}
.btn-accent{background:var(--accent);color:var(--ink-900);border-color:var(--accent);}
.btn-accent:hover{background:var(--accent-600);border-color:var(--accent-600);transform:translateY(-2px);box-shadow:0 12px 26px rgba(245,179,1,.32);}
.btn-primary{background:var(--blue-500);color:#fff;border-color:var(--blue-500);}
.btn-primary:hover{background:var(--blue-400);border-color:var(--blue-400);transform:translateY(-2px);}
.btn-outline{background:transparent;color:var(--blue-500);border-color:var(--blue-500);}
.btn-outline:hover{background:var(--blue-500);color:#fff;}
.btn-outline-w{background:transparent;color:#fff;border-color:rgba(255,255,255,.55);}
.btn-outline-w:hover{border-color:#fff;background:rgba(255,255,255,.1);transform:translateY(-2px);}

.ico-spark{width:16px;height:16px;flex:none;background:currentColor;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3l1.9 5.8L19.5 10l-5.6 1.2L12 17l-1.9-5.8L4.5 10l5.6-1.2zM19 3v4M21 5h-4M5 17v3M6.5 18.5h-3'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3l1.9 5.8L19.5 10l-5.6 1.2L12 17l-1.9-5.8L4.5 10l5.6-1.2zM19 3v4M21 5h-4M5 17v3M6.5 18.5h-3'/%3E%3C/svg%3E") center/contain no-repeat;}

/* ---------- tags ---------- */
.tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--fontH);font-weight:700;font-size:.72rem;
  letter-spacing:.06em;text-transform:uppercase;padding:6px 11px;border-radius:var(--radius-sm);line-height:1;width:fit-content;}
.tag .ico-spark{width:13px;height:13px;}
.tag-accent{background:var(--accent);color:var(--ink-900);}
.tag-brand{background:var(--blue-50);color:var(--blue-600);}
.tag-neutral{background:var(--ink-100);color:var(--ink-700);}

/* ---------- stars ---------- */
.stars{display:inline-flex;gap:1px;color:var(--star);}
.stars svg{width:16px;height:16px;}

/* ---------- icon spans (mask-based) ---------- */
[data-icon]{display:inline-block;width:1em;height:1em;background:currentColor;vertical-align:-.125em;flex:none;}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--header-h);
  background:transparent;border-bottom:1px solid transparent;transition:background .3s ease,border-color .3s ease,box-shadow .3s ease;}
.header-inner{max-width:1280px;margin:0 auto;height:100%;display:flex;align-items:center;gap:28px;padding-inline:var(--gutter);}
.logo{display:flex;align-items:center;flex:none;}
.logo img{height:30px;width:auto;}
.logo-dark{display:none;} .logo-light{display:block;}
.site-header.scrolled{background:#fff;border-bottom-color:var(--ink-200);box-shadow:0 2px 14px rgba(15,18,40,.06);}
.site-header.scrolled .logo-dark{display:block;} .site-header.scrolled .logo-light{display:none;}

.primary-nav{display:flex;gap:24px;margin-left:10px;}
.primary-nav a{font-family:var(--fontH);font-weight:700;font-size:.84rem;letter-spacing:.04em;text-transform:uppercase;
  color:rgba(255,255,255,.85);padding-bottom:4px;border-bottom:3px solid transparent;transition:color .2s ease,border-color .2s ease;}
.primary-nav a:hover,.primary-nav a.is-active{color:#fff;border-bottom-color:var(--accent);}
.site-header.scrolled .primary-nav a{color:var(--ink-700);}
.site-header.scrolled .primary-nav a:hover,.site-header.scrolled .primary-nav a.is-active{color:var(--blue-500);}

.header-actions{margin-left:auto;display:flex;align-items:center;gap:16px;}
.header-phone{display:inline-flex;align-items:center;gap:8px;font-family:var(--fontH);font-weight:800;font-size:1rem;color:#fff;}
.header-phone svg{width:17px;height:17px;fill:none;stroke:var(--accent);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.site-header.scrolled .header-phone{color:var(--ink-900);}
.menu-toggle{display:none;background:transparent;border:none;cursor:pointer;padding:6px;color:#fff;}
.menu-toggle svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;}
.site-header.scrolled .menu-toggle{color:var(--ink-900);}

/* mobile menu */
.mobile-menu{position:fixed;top:var(--header-h);left:0;right:0;z-index:99;background:#fff;border-bottom:1px solid var(--ink-200);
  display:flex;flex-direction:column;gap:4px;padding:14px var(--gutter) 22px;box-shadow:0 18px 40px rgba(15,18,40,.16);
  transform:translateY(-130%);transition:transform .35s cubic-bezier(.4,0,.2,1);}
.mobile-menu.open{transform:translateY(0);}
/* paving mode: GSAP drives a diagonal clip-path wipe, so suppress the slide */
.mobile-menu.paving{transition:none;}
.mobile-menu a{font-family:var(--fontH);font-weight:700;font-size:1rem;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-800);padding:13px 4px;border-bottom:1px solid var(--ink-100);}
.mobile-menu .btn{margin-top:14px;padding:15px;}
.mobile-menu-phone{text-align:center;color:var(--blue-500)!important;border-bottom:none!important;}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:clamp(560px,92vh,760px);display:flex;align-items:center;overflow:hidden;}
.hero-bg{position:absolute;inset:-12% 0;background:url("https://images.unsplash.com/photo-1605276374104-dee2a0ed3cd6?w=1600&q=72&auto=format&fit=crop") center/cover no-repeat;will-change:transform;}
.hero-overlay{position:absolute;inset:0;background:var(--overlay-brand);}
.hero-inner{position:relative;z-index:2;width:100%;padding-top:var(--header-h);}
.hero-copy{max-width:640px;display:flex;flex-direction:column;gap:22px;}
.hero-copy .lead{max-width:500px;}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap;}
.hero-rating{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding-top:4px;}
.hero-rating .stars svg{width:18px;height:18px;}
.hero-rating-text{font-family:var(--fontB);font-size:.875rem;color:rgba(255,255,255,.85);}
.hero-divider{width:1px;height:22px;background:rgba(255,255,255,.25);}
.hero-phone{display:inline-flex;align-items:center;gap:8px;font-family:var(--fontH);font-weight:800;font-size:1.0625rem;color:#fff;}
.hero-phone svg{width:17px;height:17px;fill:none;stroke:var(--accent);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.scroll-hint{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:3;display:inline-flex;flex-direction:column;align-items:center;gap:6px;
  font-family:var(--fontH);font-weight:700;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.65);}
.scroll-hint svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;animation:bob 1.8s ease-in-out infinite;}
@keyframes bob{0%,100%{transform:translateY(0);}50%{transform:translateY(5px);}}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust-strip{background:var(--ink-50);border-bottom:1px solid var(--ink-200);}
.trust-inner{display:flex;flex-wrap:wrap;gap:18px 28px;justify-content:center;align-items:center;padding-block:20px;}
.trust-item{display:flex;align-items:center;gap:9px;font-family:var(--fontH);font-weight:700;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-700);}
.trust-item .ti-icon{width:18px;height:18px;background:var(--accent);}

/* ============================================================
   SECTIONS
   ============================================================ */
.section{padding-block:clamp(48px,7vw,68px);}
.section-grey{background:var(--ink-50);}
.section-head.split{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:32px;flex-wrap:wrap;}

/* ---------- service cards ---------- */
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.service-card{background:#fff;border:1px solid var(--ink-200);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .25s ease,box-shadow .25s ease;}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);}
.card-media{position:relative;height:158px;overflow:hidden;}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.service-card:hover .card-media img{transform:scale(1.05);}
.card-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(15,15,15,.62));}
.card-caption{position:absolute;left:16px;bottom:12px;z-index:2;font-family:var(--fontH);font-weight:800;font-size:1.125rem;text-transform:uppercase;color:#fff;letter-spacing:-.01em;}
.badge{position:absolute;top:12px;left:12px;z-index:2;font-family:var(--fontH);font-weight:700;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-900);background:var(--accent);padding:5px 10px;border-radius:var(--radius-sm);}
.card-body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:12px;flex:1;}
.card-body p{font-size:.875rem;line-height:1.5;color:var(--ink-500);flex:1;}
.card-actions{display:flex;gap:8px;}

/* ============================================================
   VISUALISER PROMO
   ============================================================ */
.visualiser-promo{background:var(--ink-900);background-image:var(--overlay-brand);}
.visualiser-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.visualiser-copy{display:flex;flex-direction:column;gap:18px;}
.visualiser-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:14px;}
.visualiser-preview{position:relative;height:300px;border-radius:8px;overflow:hidden;}
.visualiser-preview img{width:100%;height:100%;object-fit:cover;transition:opacity .35s ease;}
.viz-label{position:absolute;top:14px;right:14px;font-family:var(--fontH);font-weight:800;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-900);background:var(--accent);padding:5px 11px;border-radius:4px;}
.viz-chips{display:flex;gap:8px;margin-top:12px;}
.viz-chip{flex:1;text-align:center;font-family:var(--fontH);font-weight:700;font-size:.7rem;padding:8px 0;border-radius:6px;text-transform:uppercase;
  color:rgba(255,255,255,.8);background:rgba(255,255,255,.08);border:none;cursor:pointer;transition:background .2s ease,color .2s ease;}
.viz-chip:hover{background:rgba(255,255,255,.16);}
.viz-chip.is-on{color:var(--ink-900);background:var(--accent);}

/* ============================================================
   TIMELINE
   ============================================================ */
.timeline{list-style:none;display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative;}
.timeline::before{content:"";position:absolute;top:28px;left:10%;right:10%;height:3px;background:var(--ink-200);}
.timeline-step{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;position:relative;padding-inline:12px;}
.ts-dot{width:56px;height:56px;border-radius:50%;background:var(--blue-500);display:flex;align-items:center;justify-content:center;border:4px solid var(--ink-50);box-shadow:var(--shadow-sm);position:relative;z-index:1;color:#fff;}
.section:not(.section-grey) .ts-dot{border-color:#fff;}
.ts-dot[data-icon]::before{content:"";display:block;width:24px;height:24px;background:currentColor;
  -webkit-mask:var(--m) center/contain no-repeat;mask:var(--m) center/contain no-repeat;}
.ts-dot-accent{background:var(--accent);color:var(--ink-900);}
.ts-title{font-family:var(--fontH);font-weight:800;font-size:.95rem;text-transform:uppercase;color:var(--ink-900);}
.ts-desc{font-size:.8rem;line-height:1.45;color:var(--ink-500);}

/* ============================================================
   PROJECTS
   ============================================================ */
.project-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.project-card{border:1px solid var(--ink-200);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .25s ease,box-shadow .25s ease;}
.project-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);}
.card-media.tall{height:200px;}
.card-media.tall::after{display:none;}
.project-body{padding:16px;display:flex;flex-direction:column;gap:6px;}
.project-row{display:flex;justify-content:space-between;align-items:center;gap:10px;}
.project-title{font-family:var(--fontH);font-weight:800;font-size:1rem;text-transform:uppercase;color:var(--ink-900);}
.project-loc{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--ink-500);}
.project-loc [data-icon]{color:var(--blue-500);width:14px;height:14px;}
.project-link{margin-top:4px;display:inline-flex;align-items:center;gap:6px;font-family:var(--fontH);font-weight:700;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;color:var(--blue-500);}

/* ============================================================
   REVIEWS
   ============================================================ */
.rating-badges{display:flex;gap:24px;align-items:center;}
.rating-badge{text-align:center;}
.rb-num{display:block;font-family:var(--fontH);font-weight:800;font-size:1.65rem;color:var(--ink-900);}
.rb-src{display:flex;align-items:center;justify-content:center;gap:5px;font-family:var(--fontH);font-weight:700;font-size:.72rem;text-transform:uppercase;color:var(--ink-500);}
.rb-src [data-icon]{color:var(--blue-500);width:13px;height:13px;}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.review-card{background:#fff;border:1px solid var(--ink-200);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px;}
.review-top{display:flex;align-items:center;justify-content:space-between;}
.review-src{width:28px;height:28px;border-radius:6px;background:var(--ink-100);color:var(--ink-600);padding:6px;}
.review-card p{font-size:.92rem;line-height:1.6;color:var(--ink-700);flex:1;}
.review-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;border-top:1px solid var(--ink-200);padding-top:12px;}
.rev-name{display:block;font-family:var(--fontH);font-weight:700;font-size:.85rem;color:var(--ink-900);}
.rev-loc{font-size:.75rem;color:var(--ink-500);}

/* ============================================================
   DOMESTIC / COMMERCIAL SPLIT
   ============================================================ */
.split-band{display:grid;grid-template-columns:1fr 1fr;}
.split-panel{position:relative;min-height:360px;display:flex;align-items:flex-end;overflow:hidden;}
.split-domestic{background:url("https://images.unsplash.com/photo-1605276374104-dee2a0ed3cd6?w=1100&q=72&auto=format&fit=crop") center/cover;}
.split-commercial{background:url("https://images.unsplash.com/photo-1497366754035-f200968a6e72?w=1100&q=72&auto=format&fit=crop") center/cover;}
.split-overlay{position:absolute;inset:0;background:var(--overlay-brand);}
.split-commercial .split-overlay{background:linear-gradient(120deg,rgba(15,15,15,.85),rgba(15,15,15,.45));}
.split-content{position:relative;z-index:2;padding:40px clamp(24px,4vw,48px);display:flex;flex-direction:column;gap:12px;}
.split-content h3{color:#fff;}
.split-content p{max-width:360px;font-size:.9rem;line-height:1.55;color:rgba(255,255,255,.85);}

/* ============================================================
   QUOTE BAND
   ============================================================ */
.quote-band{background:var(--blue-600);background-image:var(--overlay-brand);padding-block:clamp(40px,6vw,54px);}
.quote-inner{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;}
.quote-inner h2{margin-bottom:8px;}
.quote-actions{display:flex;gap:12px;flex-wrap:wrap;}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink-900);color:#fff;padding-block:56px 24px;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:40px;padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,.12);}
.footer-logo{height:32px;margin-bottom:16px;}
.footer-brand p{font-size:.875rem;line-height:1.6;color:rgba(255,255,255,.7);max-width:300px;margin-bottom:16px;}
.footer-social{display:flex;gap:10px;}
.footer-social a{width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.8);transition:border-color .2s ease,color .2s ease;}
.footer-social a:hover{border-color:var(--accent);color:var(--accent);}
.footer-social [data-icon]{width:17px;height:17px;}
.footer-col h4{font-family:var(--fontH);font-weight:700;color:var(--accent);text-transform:uppercase;margin-bottom:14px;}
.footer-col a,.footer-contact{display:flex;align-items:center;gap:9px;font-size:.875rem;color:rgba(255,255,255,.72);margin-bottom:11px;}
.footer-col a:hover{color:#fff;}
.footer-contact [data-icon]{color:var(--accent);width:15px;height:15px;}
.footer-base{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:22px;font-size:.78rem;color:rgba(255,255,255,.5);}
.concept-note{margin-top:18px;font-size:.78rem;line-height:1.5;color:rgba(255,255,255,.4);max-width:70ch;}

/* ============================================================
   REVEAL (GSAP sets initial state via JS; fallback visible)
   ============================================================ */
.js [data-reveal],.js [data-reveal-card],.js [data-hero]{opacity:0;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .primary-nav,.header-phone{display:none;}
  .menu-toggle{display:inline-flex;}
  .service-grid,.project-grid,.review-grid{grid-template-columns:repeat(2,1fr);}
  .visualiser-grid{grid-template-columns:1fr;gap:28px;}
  .timeline{grid-template-columns:1fr 1fr;gap:28px 12px;}
  .timeline::before{display:none;}
  .rating-badges{gap:18px;}
}
@media (max-width:680px){
  :root{--header-h:64px;}
  .hero{min-height:auto;padding-block:120px 56px;}
  .hero-rating{gap:12px;}
  .hero-divider{display:none;}
  .service-grid,.project-grid,.review-grid{grid-template-columns:1fr;}
  .section-head.split{flex-direction:column;align-items:flex-start;}
  .section-head.split .btn{width:100%;}
  .timeline{grid-template-columns:1fr;gap:24px;}
  .split-band{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px;}
  .footer-brand{grid-column:1 / -1;}
  .quote-inner{flex-direction:column;align-items:flex-start;}
  .quote-actions .btn{flex:1;}
}
@media (max-width:420px){
  .footer-grid{grid-template-columns:1fr;}
  .hero-cta .btn{width:100%;}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  .scroll-hint svg{animation:none;}
  .js [data-reveal],.js [data-reveal-card],.js [data-hero]{opacity:1;}
}
