:root{
  --bg:#0d1117;
  --bg-soft:#f8f4ea;
  --surface:#121823;
  --surface-2:#19202c;
  --panel:#ffffff;
  --panel-soft:rgba(255,255,255,.84);
  --text:#10151b;
  --text-soft:#59626e;
  --text-on-dark:#f6f7fb;
  --line:rgba(16,21,27,.08);
  --line-dark:rgba(255,255,255,.10);
  --accent:#f1b500;
  --accent-2:#ffd659;
  --accent-soft:#fff3c1;
  --accent-glow:rgba(241,181,0,.26);
  --success:#2d8f54;
  --container:min(1220px,calc(100% - 2rem));
  --radius-sm:18px;
  --radius-md:28px;
  --radius-lg:40px;
  --shadow-soft:0 18px 48px rgba(0,0,0,.12);
  --shadow-panel:0 16px 40px rgba(16,21,27,.09);
  --shadow-strong:0 34px 88px rgba(0,0,0,.26);
  --font-sans:"Poppins",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --ease:cubic-bezier(.2,.8,.2,1);
  --header-height:92px;
}
*,
*::before,
*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-width:320px;
  font-family:var(--font-sans);
  color:var(--text);
  background:
    radial-gradient(circle at 8% 0%, rgba(241,181,0,.09), transparent 28%),
    radial-gradient(circle at 92% 8%, rgba(255,255,255,.65), transparent 18%),
    linear-gradient(180deg,#fbfaf7 0%, #f3eee2 100%);
  line-height:1.72;
  text-rendering:optimizeLegibility;
}
::selection{background:var(--accent);color:#111}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
input,select,textarea{
  width:100%;
  border:1px solid rgba(16,21,27,.12);
  background:#fff;
  color:var(--text);
  border-radius:16px;
  padding:1rem 1rem;
  outline:none;
  transition:border-color .22s ease, box-shadow .22s ease, transform .22s ease;
}
input:focus,select:focus,textarea:focus{
  border-color:rgba(241,181,0,.75);
  box-shadow:0 0 0 4px rgba(241,181,0,.14);
}
textarea{resize:vertical;min-height:160px}
.container{width:var(--container);margin-inline:auto}
.skip-link{
  position:absolute;left:-999px;top:0;background:#fff;color:#000;padding:.85rem 1rem;z-index:1000
}
.skip-link:focus{left:1rem;top:1rem;border-radius:12px;box-shadow:var(--shadow-soft)}

.topbar{
  position:relative;
  background:#090c12;
  color:var(--text-on-dark);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.topbar::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, rgba(241,181,0,.16), transparent 26%, transparent 74%, rgba(241,181,0,.08));
  pointer-events:none;
}
.topbar-inner{
  min-height:44px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  position:relative;
  z-index:1;
}
.topbar-links,.topbar-note{
  display:flex;align-items:center;gap:1rem;flex-wrap:wrap;
}
.topbar-links a,.topbar-note{font-size:.86rem;color:#eef1f8}
.topbar a:hover{color:var(--accent-2)}
.topbar svg{width:14px;height:14px;fill:currentColor;flex:0 0 auto}
.topbar-links span,.topbar-note{display:inline-flex;align-items:center;gap:.4rem}

.site-header{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(18px) saturate(170%);
  background:rgba(250,248,242,.78);
  border-bottom:1px solid rgba(16,21,27,.06);
  transition:background .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.site-header.is-scrolled{
  background:rgba(250,248,242,.94);
  box-shadow:0 16px 36px rgba(0,0,0,.07);
  border-color:rgba(16,21,27,.09)
}
.header-row{
  min-height:var(--header-height);
  display:flex;align-items:center;justify-content:space-between;gap:1.1rem
}
.brand{display:flex;align-items:center}
.brand img{width:min(236px,46vw);height:auto}
.nav-shell{display:flex;align-items:center;gap:1rem;flex:1;justify-content:flex-end}
.main-nav ul{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:.2rem}
.main-nav a,.submenu-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  border:0;background:none;padding:.9rem 1rem;border-radius:999px;color:var(--text);
  font-weight:600;letter-spacing:.01em;
  transition:background .22s ease, color .22s ease, box-shadow .22s ease, transform .22s ease;
}
.main-nav a:hover,.main-nav a.active,.submenu-toggle:hover,.submenu-toggle:focus-visible{
  background:#fff;box-shadow:0 12px 26px rgba(0,0,0,.06)
}
.has-submenu{position:relative}
.submenu{
  position:absolute;left:0;top:calc(100% + .75rem);
  min-width:260px;padding:.65rem;background:#fff;
  border:1px solid rgba(16,21,27,.09);border-radius:24px;box-shadow:0 24px 60px rgba(0,0,0,.14);
  display:grid;gap:.2rem;opacity:0;visibility:hidden;transform:translateY(8px);
  transition:.22s var(--ease)
}
.has-submenu:hover .submenu,.has-submenu:focus-within .submenu,.has-submenu.open .submenu{opacity:1;visibility:visible;transform:none}
.submenu a{justify-content:flex-start;border-radius:16px}
.header-actions{display:flex;gap:.7rem}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  border-radius:999px;border:1px solid transparent;
  padding:1rem 1.4rem;
  font-weight:600;
  line-height:1;
  transition:transform .26s var(--ease), box-shadow .26s var(--ease), border-color .26s var(--ease), background .26s var(--ease), color .26s var(--ease);
}
.btn:hover,.btn:focus-visible{transform:translateY(-2px)}
.btn-small{padding:.86rem 1.05rem;font-size:.94rem}
.btn-primary{
  color:#11151a;
  background:linear-gradient(180deg,var(--accent-2),var(--accent));
  box-shadow:0 18px 34px rgba(241,181,0,.24), inset 0 1px 0 rgba(255,255,255,.55);
}
.btn-primary:hover,.btn-primary:focus-visible{box-shadow:0 24px 42px rgba(241,181,0,.3)}
.btn-dark{
  color:#fff;background:linear-gradient(180deg,#1d2430,#0e1319);
  box-shadow:0 18px 34px rgba(15,20,28,.2)
}
.btn-ghost{
  color:var(--text);
  background:rgba(255,255,255,.82);
  border-color:rgba(16,21,27,.1)
}
.text-link{
  display:inline-flex;align-items:center;gap:.55rem;
  margin-top:1.1rem;
  font-weight:700;color:#0f141a
}
.text-link::after{
  content:"";width:1.05rem;height:1.05rem;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12.3 4.3l1.4 1.4-5.3 5.3H20v2H8.4l5.3 5.3-1.4 1.4L4.6 12z'/%3E%3C/svg%3E") center/contain no-repeat;
  background:currentColor;
  transform:scaleX(-1);
  transition:transform .2s ease;
}
.text-link:hover::after{transform:translateX(4px) scaleX(-1)}

.menu-toggle{
  display:none;align-items:center;justify-content:center;width:54px;height:54px;
  border:1px solid rgba(16,21,27,.1);border-radius:18px;background:#fff;color:#111;
  box-shadow:0 12px 24px rgba(0,0,0,.05)
}
.menu-toggle span,.menu-toggle span::before,.menu-toggle span::after{
  display:block;content:"";width:22px;height:2px;border-radius:999px;background:currentColor;transition:.26s var(--ease)
}
.menu-toggle span::before{transform:translateY(-7px)}
.menu-toggle span::after{transform:translateY(5px)}
.menu-toggle[aria-expanded="true"] span{background:transparent}
.menu-toggle[aria-expanded="true"] span::before{transform:rotate(45deg)}
.menu-toggle[aria-expanded="true"] span::after{transform:rotate(-45deg)}

.breadcrumbs{padding-top:1rem}
.breadcrumbs ol{
  margin:0;padding:0;list-style:none;display:flex;gap:.65rem;flex-wrap:wrap;
  font-size:.93rem;color:#65707c
}
.breadcrumbs li:not(:last-child)::after{content:"/";margin-left:.65rem;color:#abb3bc}
.breadcrumbs a:hover{color:var(--text)}

.section{padding:5.5rem 0}
.section-dark{
  color:var(--text-on-dark);
  background:linear-gradient(180deg,#11171f,#0b1016);
}
.section-dark .section-title,
.section-dark .section-copy,
.section-dark h3,
.section-dark p{color:inherit}
.section-head{max-width:72ch;margin-bottom:1.75rem}
.section-title{
  margin:.55rem 0 .85rem;
  font-size:clamp(2rem,3.8vw,3.25rem);
  line-height:1.04;
  letter-spacing:-.045em;
  font-weight:700;
  color:#0d1218;
}
.lead,.section-copy{
  font-size:1.05rem;
  color:var(--text-soft);
  max-width:66ch;
}
.eyebrow,.tiny-label,.routing-label,.review-badge{
  display:inline-flex;align-items:center;gap:.45rem;
  text-transform:uppercase;letter-spacing:.19em;
  font-size:.76rem;font-weight:700;
}
.eyebrow{color:#a77a00}
.tiny-label{color:#d2d6dd}
.review-badge{color:#f0d682}
.hero-actions{display:flex;gap:.85rem;flex-wrap:wrap;margin-top:1.6rem}

.hero,.page-hero{position:relative;overflow:hidden}
.hero-home{padding:3rem 0 2.2rem}
.hero-backdrop{
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 76% 22%, rgba(241,181,0,.18), transparent 20%),
    radial-gradient(circle at 86% 6%, rgba(255,255,255,.44), transparent 15%),
    linear-gradient(135deg, rgba(255,255,255,.3), transparent 40%);
  pointer-events:none;
}
.hero-grid,.page-hero-grid,.split-grid,.statement-grid,.faq-grid,.compare-grid,.route-grid,.story-grid{
  display:grid;grid-template-columns:1.04fr .96fr;gap:1.5rem;align-items:center
}
.hero-copy h1,.page-hero h1{
  margin:.7rem 0 1rem;
  font-size:clamp(2.95rem,6vw,5.5rem);
  line-height:.94;
  letter-spacing:-.065em;
  font-weight:700;
  color:#0c1116;
  max-width:9.2ch;
}
.page-hero{padding:2.6rem 0 1rem}
.page-hero h1{font-size:clamp(2.45rem,5.2vw,4.6rem);max-width:10.5ch}
.page-thankyou .page-hero h1{max-width:11ch}
.hero-proof{
  display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem;margin-top:1.45rem
}
.proof-pill{
  padding:1rem 1rem;border-radius:24px;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(16,21,27,.08);
}
.proof-pill strong{display:block;font-size:1rem;line-height:1.1;color:#0f141a;font-weight:700}
.proof-pill span{display:block;margin-top:.25rem;font-size:.91rem;color:#5e6773}

.panel{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  border-radius:var(--radius-md);
  border:1px solid rgba(16,21,27,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.86));
  box-shadow:var(--shadow-panel);
}
.panel::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(241,181,0,.15), transparent 34%);
  opacity:0;transition:opacity .35s ease;pointer-events:none
}
.panel:hover::before{opacity:1}
.premium-dark{
  background:linear-gradient(180deg,#17202b 0%, #0d1217 100%);
  color:var(--text-on-dark);
  border-color:rgba(255,255,255,.09);
  box-shadow:var(--shadow-strong);
}
.premium-dark::before{background:radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(241,181,0,.18), transparent 34%)}

.hero-stage{
  min-height:560px;
  padding:1rem;
  background:linear-gradient(180deg,#0f151d,#0a0e13);
  border-color:rgba(255,255,255,.08);
  box-shadow:var(--shadow-strong);
}
.hero-float{
  position:absolute;
  max-width:270px;
  padding:1rem 1.05rem;
  border-radius:22px;
  background:rgba(18,24,35,.94);
  border:1px solid rgba(255,255,255,.08);
  color:#fff;
  box-shadow:0 18px 44px rgba(0,0,0,.28);
}
.hero-float strong{display:block;font-size:.98rem;line-height:1.42;font-weight:600}
.hero-float-top{right:1.35rem;top:1.35rem;animation:floatA 5.8s ease-in-out infinite}
.hero-float-bottom{left:1.35rem;bottom:1.35rem;animation:floatB 6.1s ease-in-out infinite}
@keyframes floatA{50%{transform:translateY(-8px)}}
@keyframes floatB{50%{transform:translateY(8px)}}

.media-placeholder{
  position:relative;
  min-height:330px;
  border-radius:30px;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(245,240,228,.92)),
    linear-gradient(145deg, rgba(241,181,0,.08), transparent 44%);
  border:1px solid rgba(16,21,27,.08);
}
.media-placeholder.is-tall{min-height:440px}
.media-placeholder.is-dark{
  background:
    linear-gradient(180deg, rgba(24,32,43,.96), rgba(12,16,22,.98)),
    linear-gradient(145deg, rgba(241,181,0,.08), transparent 44%);
  border-color:rgba(255,255,255,.08);
}
.media-accent{
  position:absolute;left:0;top:0;bottom:0;width:10px;
  background:linear-gradient(180deg,var(--accent-2),var(--accent));
}
.media-lines{
  position:absolute;inset:0;
  background:
    linear-gradient(135deg, rgba(241,181,0,.13), transparent 26%),
    repeating-linear-gradient(90deg, transparent 0 120px, rgba(16,21,27,.04) 120px 121px),
    repeating-linear-gradient(0deg, transparent 0 90px, rgba(16,21,27,.03) 90px 91px);
  opacity:.75;
}
.media-placeholder.is-dark .media-lines{
  background:
    linear-gradient(135deg, rgba(241,181,0,.18), transparent 26%),
    repeating-linear-gradient(90deg, transparent 0 120px, rgba(255,255,255,.06) 120px 121px),
    repeating-linear-gradient(0deg, transparent 0 90px, rgba(255,255,255,.05) 90px 91px);
}
.media-label{
  position:absolute;left:1.2rem;right:1.2rem;bottom:1.2rem;
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.82rem 1rem;
  border-radius:999px;
  background:rgba(255,255,255,.84);
  color:#0f141a;
  font-size:.92rem;
  font-weight:600;
  backdrop-filter:blur(10px);
}
.media-label::before{
  content:"";
  width:.72rem;height:.72rem;border-radius:50%;
  background:linear-gradient(180deg,var(--accent-2),var(--accent));
  box-shadow:0 0 0 6px rgba(241,181,0,.12);
}
.media-placeholder.is-dark .media-label{
  background:rgba(18,24,35,.84);
  color:#fff;
}

.ticker-band{
  border-block:1px solid rgba(16,21,27,.08);
  background:rgba(255,255,255,.5);
  overflow:hidden;
}
.ticker-track{
  display:flex;gap:3rem;min-width:max-content;
  padding:1rem 0;
  animation:ticker 28s linear infinite;
  font-weight:700;font-size:.95rem;color:#11161c
}
.ticker-track span{display:inline-flex;align-items:center;gap:.8rem}
.ticker-track span::before{
  content:"";
  width:8px;height:8px;border-radius:50%;
  background:var(--accent)
}
@keyframes ticker{to{transform:translateX(-50%)}}

.feature-grid,.service-grid,.steps-grid,.materials-grid,.route-cards,.review-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1rem
}
.service-grid{grid-template-columns:repeat(3,1fr)}
.compact-grid{margin-top:1rem}
.feature-card,.service-card,.step-card,.material-card,.route-card,.hero-side-card,.quote-panel,.compare-table,.quote-form,.review-card,.mini-point,.proof-pill,.cta-band-inner,.review-grid > *{
  padding:1.25rem 1.25rem 1.2rem;
}
.icon-badge{
  width:54px;height:54px;display:grid;place-items:center;
  border-radius:18px;
  background:linear-gradient(180deg,var(--accent-2),var(--accent));
  color:#0f141a;
  box-shadow:0 14px 28px rgba(241,181,0,.2), inset 0 1px 0 rgba(255,255,255,.45);
}
.icon-badge svg{width:24px;height:24px;fill:currentColor}
.feature-card h3,.service-card h3,.step-card h3,.material-card h3,.route-card h3,.review-card h3,.hero-side-card h3,.quote-panel h3,.mini-point strong{
  margin:1rem 0 .5rem;
  font-size:1.18rem;
  line-height:1.2;
  font-weight:650;
  color:inherit;
}
.feature-card p,.service-card p,.step-card p,.material-card p,.route-card p,.hero-side-card p,.quote-panel p,.mini-point span{
  margin:0;
  color:inherit;
  opacity:.92;
}
.service-card .icon-list{margin-top:1rem}
.service-card .text-link{margin-top:1rem}

.stack-list{display:grid;gap:1rem}
.stack-list > div{
  display:flex;align-items:flex-start;gap:.8rem;
  padding:.9rem 1rem;border-radius:22px;
  background:rgba(255,255,255,.65);
  border:1px solid rgba(16,21,27,.08)
}
.stack-list svg{width:20px;height:20px;fill:currentColor;flex:0 0 auto}
.story-grid{align-items:start}
.statement-side,.contact-side{display:grid;gap:1rem}

.steps-grid{grid-template-columns:repeat(4,1fr)}
.step-card{padding-top:1.35rem}
.step-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:50px;height:50px;border-radius:999px;
  background:#0f141a;color:#fff;font-size:.96rem;font-weight:700
}

.materials-grid{grid-template-columns:repeat(3,1fr)}
.icon-list{list-style:none;margin:0;padding:0;display:grid;gap:.85rem}
.icon-list li{
  display:flex;align-items:flex-start;gap:.75rem
}
.icon-list svg{width:18px;height:18px;fill:currentColor;flex:0 0 auto;margin-top:.17rem}
.large-list{margin-top:1.25rem}

.compare-grid{align-items:start}
.compare-table{
  padding:0;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.9));
}
.compare-row{
  display:grid;grid-template-columns:.78fr 1.1fr 1.1fr;gap:1rem;
  padding:1rem 1.2rem;border-top:1px solid rgba(16,21,27,.08)
}
.compare-row.head{
  border-top:0;
  background:#0f141a;
  color:#fff;
  font-weight:700;
}
.route-grid{align-items:start}
.route-cards.vertical{grid-template-columns:1fr}
.route-card p{margin:0}

.quote-form{
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.9));
}
.form-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1.3rem
}
.form-grid label{display:grid;gap:.42rem;font-weight:600;color:#24303a}
.form-grid label span{font-size:.93rem}
.form-grid .is-full{grid-column:1 / -1}
.form-head .section-title{margin-bottom:.7rem}
.form-actions{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  margin-top:1.2rem
}
.form-feedback{margin:0;font-size:.92rem;color:#5c6671;max-width:36ch}
.form-feedback.is-success{color:var(--success)}
.form-feedback.is-error{color:#a0342f}
.routing-inline{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  margin-top:1rem;padding:1rem 1.1rem;
  background:#fff8da;
  border:1px solid rgba(241,181,0,.22);
  border-radius:22px;
}
.routing-inline strong{display:block;font-size:1rem;line-height:1.2;font-weight:650}
.routing-inline p{margin:.25rem 0 0;color:#5d6672}
.branch-chip{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.75rem .95rem;border-radius:999px;
  background:#0f141a;color:#fff;font-size:.88rem;font-weight:700
}
.honeypot{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.consent-line{
  grid-template-columns:auto 1fr;align-items:start;gap:.8rem
}
.consent-line input{
  width:auto;margin-top:.25rem
}

.reviews-section .split-grid{align-items:start}
.review-grid{grid-template-columns:1.15fr 1fr 1fr}
.review-card{min-height:100%;color:#fff}
.review-card p,.review-card h3{color:#fff}
.review-top,.review-stars{display:flex;align-items:center;justify-content:space-between}
.review-stars{letter-spacing:.16em;font-weight:800;color:#ffd969}
.mini-point{
  display:grid;align-content:flex-start;
  min-height:100%;
}
.mini-point strong{font-size:1rem}
.mini-point span{display:block;margin-top:.25rem;color:var(--text-soft)}

.faq-grid{align-items:start}
.faq-list{display:grid;gap:.85rem}
.faq-item{padding:0}
.faq-question{
  width:100%;
  background:none;border:0;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1.2rem 1.3rem;text-align:left;
  font-weight:650;color:var(--text)
}
.faq-plus{
  position:relative;display:inline-block;width:18px;height:18px;flex:0 0 auto
}
.faq-plus::before,.faq-plus::after{
  content:"";position:absolute;left:50%;top:50%;width:18px;height:2px;border-radius:999px;background:#0f141a;transform:translate(-50%,-50%);transition:.22s ease
}
.faq-plus::after{transform:translate(-50%,-50%) rotate(90deg)}
.faq-item.is-open .faq-plus::after{transform:translate(-50%,-50%) rotate(0deg);opacity:0}
.faq-answer{
  display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s var(--ease)
}
.faq-answer p{overflow:hidden;margin:0;padding:0 1.3rem 0;color:var(--text-soft)}
.faq-item.is-open .faq-answer{grid-template-rows:1fr}
.faq-item.is-open .faq-answer p{padding-bottom:1.2rem}

.cta-band{padding:0 0 5rem}
.cta-band-inner{
  display:flex;align-items:center;justify-content:space-between;gap:1.2rem;
}
.cta-band .section-title,.cta-band .section-copy{color:#fff}
.cta-band-actions{display:flex;gap:.8rem;flex-wrap:wrap}

.site-footer{
  position:relative;overflow:hidden;
  color:var(--text-on-dark);
  background:linear-gradient(180deg,#10161e,#080b10);
}
.footer-glow{
  position:absolute;inset:auto auto -12rem -10rem;width:32rem;height:32rem;border-radius:50%;
  background:radial-gradient(circle, rgba(241,181,0,.22), transparent 60%);
  pointer-events:none
}
.footer-grid{
  position:relative;
  display:grid;grid-template-columns:1.3fr .8fr .8fr 1fr;
  gap:1.2rem;padding:4rem 0 2rem
}
.footer-grid h3{
  margin:0 0 .9rem;font-size:1rem;font-weight:650;
  letter-spacing:.06em;text-transform:uppercase;color:#f2d97a
}
.footer-grid p,.footer-grid li,.footer-grid a{color:#c6ccd6}
.footer-grid ul{list-style:none;margin:0;padding:0;display:grid;gap:.68rem}
.footer-brand p{max-width:34ch}
.footer-proof{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1rem}
.footer-proof span{display:inline-flex;align-items:center;gap:.5rem;color:#fff}
.footer-proof svg,.footer-contact svg{width:16px;height:16px;fill:currentColor;flex:0 0 auto}
.footer-contact li{display:flex;gap:.7rem}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding:1rem 0 2rem
}
.footer-bottom p{margin:0;color:#aeb4be;font-size:.9rem}

[data-reveal]{
  opacity:0;
  transform:translateY(28px) scale(.985);
  transition:opacity .7s var(--ease), transform .7s var(--ease)
}
[data-reveal].is-visible{opacity:1;transform:none}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important;scroll-behavior:auto !important}
  [data-reveal]{opacity:1 !important;transform:none !important}
  .ticker-track{animation:none}
}

@media (max-width:1120px){
  .service-grid,.feature-grid,.materials-grid,.review-grid{grid-template-columns:repeat(2,1fr)}
  .steps-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1.2fr 1fr 1fr}
  .footer-grid > :first-child{grid-column:1 / -1}
}
@media (max-width:920px){
  :root{--header-height:82px}
  .menu-toggle{display:inline-flex}
  .nav-shell{
    position:fixed;left:1rem;right:1rem;top:calc(var(--header-height) + 1rem);z-index:49;
    display:grid;gap:1rem;align-content:start;
    background:rgba(255,255,255,.97);padding:1rem;border-radius:28px;
    border:1px solid rgba(16,21,27,.08);box-shadow:0 28px 60px rgba(0,0,0,.16);
    transform:translateY(-14px);opacity:0;visibility:hidden;transition:.28s var(--ease)
  }
  .nav-shell.is-open{transform:none;opacity:1;visibility:visible}
  .main-nav ul{display:grid;gap:.25rem}
  .main-nav a,.submenu-toggle{justify-content:flex-start}
  .submenu{
    position:static;opacity:1;visibility:visible;transform:none;display:none;
    box-shadow:none;background:#faf7ee;border-radius:20px
  }
  .has-submenu.open .submenu{display:grid}
  .header-actions{display:grid;grid-template-columns:1fr 1fr}
  .hero-grid,.page-hero-grid,.split-grid,.statement-grid,.faq-grid,.compare-grid,.route-grid,.story-grid{grid-template-columns:1fr}
  .hero-stage{min-height:auto}
  .hero-copy h1,.page-hero h1{max-width:none}
  .hero-proof,.route-cards{grid-template-columns:1fr}
  .hero-float{position:relative;left:auto;right:auto;top:auto;bottom:auto;max-width:none;margin-top:1rem}
}
@media (max-width:640px){
  body{line-height:1.65}
  .topbar-inner{padding:.35rem 0}
  .topbar-note{display:none}
  .header-actions{grid-template-columns:1fr}
  .hero-home{padding-top:2rem}
  .hero-copy h1{font-size:clamp(2.55rem,12vw,4.1rem)}
  .page-hero h1{font-size:clamp(2.2rem,10vw,3.3rem)}
  .section{padding:4.2rem 0}
  .section-title{font-size:clamp(1.9rem,8.8vw,2.65rem)}
  .service-grid,.feature-grid,.steps-grid,.materials-grid,.review-grid{grid-template-columns:1fr}
  .media-placeholder{min-height:250px}
  .media-placeholder.is-tall{min-height:320px}
  .form-grid{grid-template-columns:1fr}
  .routing-inline,.form-actions,.cta-band-inner{align-items:flex-start;flex-direction:column}
  .footer-grid{grid-template-columns:1fr}
}

/* ---- Final launch polish overrides ---- */
:root{
  --radius-md:30px;
  --radius-lg:44px;
}

.scroll-progress{
  position:fixed;
  left:0;top:0;
  height:3px;
  width:0%;
  z-index:120;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  box-shadow:0 0 18px rgba(241,181,0,.4);
  transition:width .15s linear;
}

.section-alt{
  background:
    radial-gradient(circle at 85% 10%, rgba(241,181,0,.12), transparent 18%),
    linear-gradient(180deg, rgba(255,255,255,.68), rgba(255,255,255,.34));
}

.hero-burst{
  position:absolute;
  inset:auto -10rem -8rem auto;
  width:32rem;height:32rem;
  border-radius:50%;
  background:radial-gradient(circle, rgba(241,181,0,.22), rgba(241,181,0,.04) 40%, transparent 62%);
  filter:blur(2px);
  pointer-events:none;
}

.hero-copy h1,.page-hero h1,.section-title{
  font-weight:650;
}

.section-title{
  letter-spacing:-.05em;
}

.lead,.section-copy{
  color:#55606b;
}

.btn{
  position:relative;
  overflow:hidden;
}
.btn::after{
  content:"";
  position:absolute;
  inset:-20% auto -20% -60%;
  width:42%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent);
  transform:skewX(-22deg);
  transition:transform .55s var(--ease);
}
.btn:hover::after,
.btn:focus-visible::after{
  transform:translateX(260%) skewX(-22deg);
}

.glow-card::after,
.priority-card::after,
.quiz-option::after{
  content:"";
  position:absolute;
  inset:auto 1rem .8rem 1rem;
  height:2px;
  border-radius:999px;
  background:linear-gradient(90deg, transparent, rgba(241,181,0,.85), transparent);
  opacity:.45;
}

.panel.glow-card,
.priority-card,
.quiz-option{
  transition:transform .28s var(--ease), box-shadow .28s var(--ease), border-color .28s var(--ease), background .28s var(--ease);
}

.panel.glow-card:hover,
.priority-card:hover,
.quiz-option:hover{
  transform:translateY(-4px);
  box-shadow:0 28px 60px rgba(13,17,23,.13);
}

.service-card,
.feature-card,
.material-card,
.route-card,
.review-card,
.priority-card{
  position:relative;
}

.media-placeholder{
  background:
    linear-gradient(135deg, rgba(241,181,0,.08), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(244,238,223,.92));
}
.media-placeholder::after{
  content:"";
  position:absolute;
  inset:1rem;
  border-radius:26px;
  border:1px dashed rgba(16,21,27,.08);
}
.media-placeholder .media-label{
  font-size:.84rem;
  letter-spacing:.14em;
  color:#74808c;
}

.media-placeholder.is-dark{
  background:
    radial-gradient(circle at 72% 18%, rgba(241,181,0,.18), transparent 18%),
    linear-gradient(180deg,#141b24,#0d1118);
}
.media-placeholder.is-dark::after{
  border-color:rgba(255,255,255,.08);
}
.media-placeholder.is-dark .media-label{
  color:#d7dee8;
}

.hero-stage{
  min-height:100%;
}
.hero-stage .media-placeholder{
  min-height:520px;
}
.hero-float{
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(14px);
}
.hero-float strong{
  font-weight:600;
}

.stats-grid{
  gap:1rem;
}
.stat-panel{
  position:relative;
}
.stat-panel strong{
  font-size:1.06rem;
}
.stat-panel span{
  line-height:1.4;
}
.microcopy{
  margin-top:.8rem;
  font-size:.86rem;
  color:#6e7782;
}

.surface-quiz{
  position:relative;
  padding:1.2rem;
  display:grid;
  gap:1rem;
}
.quiz-progress{
  height:8px;
  border-radius:999px;
  background:rgba(16,21,27,.08);
  overflow:hidden;
}
.quiz-progress-bar{
  display:block;
  width:25%;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  transition:width .28s var(--ease);
}
.quiz-step{
  display:none;
}
.quiz-step.is-active{
  display:grid;
  gap:1rem;
}
.quiz-label{
  font-size:.82rem;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#9a7200;
}
.quiz-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:.9rem;
}
.quiz-option{
  position:relative;
  display:flex;
  align-items:center;
  min-height:90px;
  text-align:left;
  padding:1rem 1rem 1.5rem;
  border:1px solid rgba(16,21,27,.08);
  background:rgba(255,255,255,.92);
  border-radius:24px;
  font-weight:600;
  color:#11161c;
  box-shadow:var(--shadow-panel);
}
.quiz-option.is-selected{
  border-color:rgba(241,181,0,.55);
  box-shadow:0 24px 54px rgba(241,181,0,.16);
  background:linear-gradient(180deg, rgba(255,248,222,.98), rgba(255,255,255,.95));
}
.quiz-result{
  display:grid;
  gap:.9rem;
  padding:1rem 1rem 1.15rem;
  border-radius:24px;
  background:#fff8dd;
  border:1px solid rgba(241,181,0,.28);
}
.quiz-result h3{
  margin:0;
  font-size:1.38rem;
  line-height:1.08;
  font-weight:650;
}
.quiz-result p{
  margin:0;
  color:#4f5a66;
}
.quiz-result .icon-list{
  gap:.6rem;
}
.quiz-result .icon-list li{
  color:#24303a;
}
.quiz-result .hero-actions{
  margin-top:.1rem;
}

.priority-tool{
  padding:1.2rem;
  display:grid;
  gap:1rem;
}
.priority-chips{
  display:flex;
  flex-wrap:wrap;
  gap:.7rem;
}
.priority-chip{
  border:1px solid rgba(16,21,27,.08);
  background:#fff;
  border-radius:999px;
  padding:.85rem 1rem;
  font-weight:600;
  color:#11161c;
}
.priority-chip.is-active{
  background:linear-gradient(180deg,var(--accent-2),var(--accent));
  color:#11161c;
  box-shadow:0 14px 26px rgba(241,181,0,.22);
}
.priority-results{
  display:grid;
  gap:.85rem;
}
.priority-card{
  position:relative;
  padding:1rem 1rem 1.35rem;
  border-radius:24px;
  border:1px solid rgba(16,21,27,.08);
  background:rgba(255,255,255,.88);
  box-shadow:var(--shadow-panel);
  opacity:.66;
}
.priority-card.is-match{
  opacity:1;
  border-color:rgba(241,181,0,.38);
  background:linear-gradient(180deg, rgba(255,248,226,.96), rgba(255,255,255,.96));
  box-shadow:0 26px 52px rgba(241,181,0,.12);
}
.priority-card h3{
  margin:0 0 .4rem;
  font-size:1.08rem;
  font-weight:650;
}
.priority-card p{
  margin:0;
  color:#54606b;
}
.priority-actions{
  display:flex;
  justify-content:flex-start;
}

.prefill-banner{
  margin-bottom:1rem;
  padding:1.15rem 1.15rem 1.1rem;
  background:linear-gradient(180deg, rgba(255,248,223,.98), rgba(255,255,255,.92));
}
.prefill-banner h3{
  margin:.4rem 0 .35rem;
  font-size:1.26rem;
  line-height:1.1;
  font-weight:650;
}
.prefill-banner p{
  margin:0;
  color:#55616d;
}

.surface-pill-list > div{
  background:rgba(255,255,255,.8);
}

.review-grid{
  grid-template-columns:repeat(3,1fr);
}
.review-card{
  min-height:100%;
}
.review-card:not(.premium-dark) h3{
  color:#11161c;
}
.review-card:not(.premium-dark) p{
  color:#58636f;
}
.review-top{
  gap:1rem;
}
.review-top .review-stars{
  justify-content:flex-end;
}

.priority-card .text-link{
  margin-top:.8rem;
}

.routing-inline.panel{
  box-shadow:none;
}

@keyframes floatBob{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}
.hero-float-top{animation:floatBob 5.5s ease-in-out infinite}
.hero-float-bottom{animation:floatBob 6.6s ease-in-out infinite 1.1s}

[data-parallax]{
  will-change:transform;
}

.form-grid select,
.form-grid input,
.form-grid textarea{
  background:rgba(255,255,255,.98);
}

.section .compare-table .compare-row div:first-child{
  font-weight:650;
}

@media (max-width:920px){
  .quiz-grid{grid-template-columns:1fr}
  .review-grid{grid-template-columns:1fr}
}

@media (max-width:640px){
  .priority-chips{display:grid;grid-template-columns:1fr 1fr}
  .hero-stage .media-placeholder{min-height:360px}
  .quiz-option{min-height:78px}
}


/* --- Latest refinement pass --- */
.ticker-band{margin-top:1.2rem}

.tools-grid,.comparison-balance{grid-template-columns:1.02fr .98fr;align-items:start}

.stat-panel{display:grid;grid-template-columns:auto 1fr;gap:.85rem;align-items:center}
.stat-icon{display:grid;place-items:center;width:56px;height:56px;border-radius:18px;background:linear-gradient(180deg,#fff8df,#fff);border:1px solid rgba(241,181,0,.26);box-shadow:0 14px 32px rgba(241,181,0,.12)}
.stat-icon svg{width:28px;height:28px;display:block}
.stat-copy{display:grid;gap:.15rem}
.stat-panel--experience .stat-icon svg{fill:#11161c}
.stat-panel--google .stat-icon{background:#fff}
.stat-panel--checkatrade .stat-icon{background:linear-gradient(180deg,#fff3bb,#fff7df)}

.quiz-support-list,.comparison-points{margin-top:1.25rem}
.quiz-support-list li,.comparison-points li{gap:.8rem}
.quiz-support-list span,.comparison-points span{color:#35414d}
.tool-note{margin:1rem 0 0;color:#58636f;max-width:56ch}

.surface-quiz{padding:1rem 1rem 1.05rem;gap:.85rem}
.quiz-grid{gap:.75rem}
.quiz-option{min-height:78px;padding:.9rem .95rem 1.2rem;font-size:.98rem}
.quiz-result{padding:1rem 1rem 1.05rem}
.quiz-result .hero-actions{gap:.7rem}
.quiz-result h3{font-size:1.28rem}

.section-dark .feature-card{background:linear-gradient(180deg, rgba(255,251,236,.98), rgba(248,242,224,.94));border-color:rgba(241,181,0,.18);color:#10161d}
.section-dark .feature-card h3{color:#10161d !important}
.section-dark .feature-card p{color:#4f5b67 !important}
.section-dark .feature-card .icon-badge{box-shadow:0 12px 26px rgba(241,181,0,.22), inset 0 1px 0 rgba(255,255,255,.45)}

.reviews-section .split-grid{grid-template-columns:.88fr 1.12fr;align-items:start}
.review-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
.review-grid > :nth-child(3){grid-column:1 / -1}
.review-card{min-height:220px}
.review-top{display:flex;align-items:center;justify-content:space-between;gap:.9rem;flex-wrap:wrap}
.review-top .review-stars{min-width:auto}

.priority-tool{padding:1rem;gap:.9rem}
.priority-chips{gap:.55rem}
.priority-chip{padding:.72rem .9rem;font-size:.95rem}
.priority-card{padding:.95rem 1rem 1.15rem}
.priority-card h3{font-size:1.04rem}
.priority-card p{font-size:.96rem;line-height:1.55}

@media (max-width:1120px){
  .reviews-section .split-grid{grid-template-columns:1fr}
}

@media (max-width:920px){
  .tools-grid,.comparison-balance{grid-template-columns:1fr}
}

@media (max-width:640px){
  .stat-panel{grid-template-columns:1fr}
  .stat-icon{width:48px;height:48px}
  .review-grid{grid-template-columns:1fr}
  .review-grid > :nth-child(3){grid-column:auto}
}

/* --- Header and trust polish pass --- */
.topbar-links a,
.topbar-note{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
}
.topbar-links a{
  color:#f3f6fb;
  text-decoration:none;
}
.topbar-links a span,
.topbar-note span{
  line-height:1;
}
.topbar-links a svg,
.topbar-note svg{
  width:18px;
  height:18px;
  fill:var(--accent);
  flex:0 0 auto;
}
.topbar-note{
  color:#eef1f8;
}

.ticker-band{
  margin-top:1.9rem;
}

.hero-proof{
  gap:1rem;
  align-items:stretch;
}
.proof-pill.stat-panel{
  padding:1.05rem 1.05rem 1rem;
  border-radius:26px;
}
.stat-panel{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:flex-start;
  gap:.85rem;
}
.stat-panel .stat-brand{
  display:flex;
  align-items:center;
  gap:.72rem;
}
.stat-panel .stat-icon{
  width:54px;
  height:54px;
  border-radius:17px;
  box-shadow:0 16px 34px rgba(17,22,28,.08);
}
.stat-panel .stat-label{
  display:inline-block;
  margin:0;
  color:#6f7983;
  font-size:.76rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:700;
}
.proof-pill.stat-panel strong{
  margin:0;
  display:block;
  font-size:1.3rem;
  line-height:1.02;
  font-weight:700;
  color:#11161c;
}
.proof-pill.stat-panel strong span{
  display:inline;
  margin:0;
  color:inherit;
  font-size:inherit;
  line-height:inherit;
}
.proof-pill.stat-panel p{
  margin:0;
  color:#56616c;
  font-size:.94rem;
  line-height:1.55;
  max-width:26ch;
}
.stat-panel--experience .stat-icon{
  background:linear-gradient(180deg,#fff7dc,#fff1b7);
}
.stat-panel--experience .stat-icon svg{
  fill:#11161c;
}
.stat-panel--google .stat-icon{
  background:#ffffff;
  border:1px solid rgba(66,133,244,.14);
}
.stat-panel--checkatrade .stat-icon{
  background:linear-gradient(180deg,#e8f9ff,#f4fdff);
  border:1px solid rgba(16,166,215,.16);
}

.why-bonwycks-section .section-head{
  max-width:66rem;
}
.section-head--left{
  text-align:left;
  margin-bottom:0;
}
.why-grid{
  margin-top:1.35rem;
}

@media (max-width:920px){
  .topbar-links{
    gap:.8rem;
  }
  .topbar-links a span{
    font-size:.82rem;
  }
  .hero-proof{
    grid-template-columns:1fr;
  }
}
@media (max-width:640px){
  .topbar-inner{
    gap:.65rem;
  }
  .topbar-links{
    width:100%;
    justify-content:space-between;
  }
  .topbar-links a{
    gap:.45rem;
  }
  .topbar-links a svg{
    width:17px;
    height:17px;
  }
  .proof-pill.stat-panel{
    padding:1rem .95rem .95rem;
  }
  .stat-panel .stat-icon{
    width:50px;
    height:50px;
  }
  .proof-pill.stat-panel p{
    max-width:none;
  }
}


/* --- Homepage hero rebuild --- */
.hero-grid--refined{
  gap:2rem;
  align-items:stretch;
}
.hero-grid--refined .hero-copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.hero-grid--refined .lead{
  max-width:60ch;
}
.hero-trust-list{
  display:grid;
  gap:.9rem;
  margin-top:1.6rem;
}
.hero-trust-card{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:.95rem;
  align-items:flex-start;
  padding:1rem 1.05rem;
  border-radius:24px;
  border:1px solid rgba(16,21,27,.08);
  background:rgba(255,255,255,.88);
  box-shadow:0 14px 34px rgba(16,21,27,.07);
}
.hero-trust-icon{
  display:grid;
  place-items:center;
  width:46px;
  height:46px;
  border-radius:16px;
  background:linear-gradient(180deg,var(--accent),#d9a100);
  color:#fff;
  box-shadow:0 14px 30px rgba(241,181,0,.25);
}
.hero-trust-icon svg{
  width:22px;
  height:22px;
  fill:currentColor;
}
.hero-trust-card strong{
  display:block;
  margin:.05rem 0 .2rem;
  font-size:1rem;
  line-height:1.35;
  color:#11161c;
}
.hero-trust-card p{
  margin:0;
  font-size:.95rem;
  line-height:1.6;
  color:#56616d;
}
.hero-showcase{
  padding:1.15rem;
  display:grid;
  gap:1rem;
  min-height:100%;
  background:
    radial-gradient(circle at top right, rgba(241,181,0,.16), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,241,227,.96));
  border:1px solid rgba(16,21,27,.08);
  box-shadow:0 28px 56px rgba(16,21,27,.11);
}
.hero-showcase-head{
  display:grid;
  gap:.35rem;
  padding:.45rem .2rem 0;
}
.hero-showcase-kicker{
  display:inline-flex;
  align-items:center;
  width:fit-content;
  padding:.42rem .75rem;
  border-radius:999px;
  background:rgba(241,181,0,.14);
  color:#936a00;
  font-size:.76rem;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.hero-showcase-head h2{
  margin:0;
  font-size:clamp(1.9rem,3vw,2.6rem);
  line-height:1.04;
  letter-spacing:-.04em;
  color:#0f141a;
}
.hero-showcase-head p{
  margin:0;
  max-width:46ch;
  color:#56616d;
}
.hero-surface-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:.85rem;
}
.hero-surface-card{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:.55rem;
  min-height:170px;
  padding:1rem;
  border-radius:24px;
  background:#fff;
  border:1px solid rgba(16,21,27,.08);
  box-shadow:0 12px 28px rgba(16,21,27,.07);
}
.hero-surface-card span{
  display:block;
  font-size:.74rem;
  font-weight:700;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:#7a8490;
}
.hero-surface-card strong{
  display:block;
  font-size:1.14rem;
  line-height:1.18;
  color:#11161c;
}
.hero-surface-card p{
  margin:0;
  font-size:.93rem;
  line-height:1.58;
  color:#58636f;
}
.hero-surface-card--featured{
  background:linear-gradient(180deg, #f1b500 0%, #d79f00 100%);
  border-color:rgba(171,125,0,.35);
  box-shadow:0 20px 40px rgba(241,181,0,.24);
}
.hero-surface-card--featured span,
.hero-surface-card--featured strong,
.hero-surface-card--featured p{
  color:#fff;
}
.hero-summary-card{
  display:grid;
  gap:1rem;
  padding:1.15rem;
  border-radius:28px;
}
.hero-summary-copy{
  display:grid;
  gap:.3rem;
}
.hero-summary-copy strong{
  font-size:1.25rem;
  line-height:1.3;
}
.hero-summary-points{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:.8rem .95rem;
}
.hero-summary-points li{
  display:flex;
  gap:.65rem;
  align-items:flex-start;
  color:rgba(255,255,255,.9);
  line-height:1.55;
}
.hero-summary-points svg{
  width:18px;
  height:18px;
  fill:var(--accent-2);
  flex:0 0 auto;
  margin-top:.24rem;
}
.hero-summary-meta{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:.8rem;
}
.hero-summary-meta div{
  padding:.85rem .95rem;
  border-radius:18px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.08);
}
.hero-summary-meta span{
  display:block;
  margin-bottom:.15rem;
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(255,255,255,.64);
}
.hero-summary-meta strong{
  display:block;
  color:#fff;
  line-height:1.45;
}

.priority-chip.is-active{
  background:linear-gradient(180deg, #f1b500, #d79f00);
  color:#fff;
  border-color:rgba(171,125,0,.35);
  box-shadow:0 14px 26px rgba(241,181,0,.26);
}
.priority-card.is-match{
  opacity:1;
  border-color:rgba(171,125,0,.34);
  background:linear-gradient(180deg, #f1b500 0%, #d79f00 100%);
  box-shadow:0 26px 52px rgba(241,181,0,.22);
}
.priority-card.is-match h3,
.priority-card.is-match p,
.priority-card.is-match a,
.priority-card.is-match .text-link{
  color:#fff;
}
.priority-card.is-match::after{
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.86), transparent);
  opacity:.55;
}

@media (max-width:1120px){
  .hero-surface-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width:920px){
  .hero-grid--refined{
    grid-template-columns:1fr;
  }
  .hero-showcase{
    padding:1rem;
  }
}

@media (max-width:640px){
  .hero-trust-card{
    grid-template-columns:1fr;
  }
  .hero-trust-icon{
    width:42px;
    height:42px;
  }
  .hero-summary-points,
  .hero-summary-meta{
    grid-template-columns:1fr;
  }
  .hero-showcase-head h2{
    font-size:1.9rem;
  }
}


/* --- Bonwycks homepage gallery/reviews pass --- */
.main-nav ul{
  gap:1rem;
}
.main-nav a,
.submenu-toggle{
  position:relative;
  padding:.4rem 0;
  border-radius:0;
  background:none;
  box-shadow:none;
  white-space:nowrap;
  overflow:visible;
}
.main-nav a::after,
.submenu-toggle::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-.45rem;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(241,181,0,0), rgba(241,181,0,.95) 20%, rgba(255,214,89,.96) 80%, rgba(241,181,0,0));
  transform:scaleX(.15);
  transform-origin:left center;
  opacity:0;
  transition:transform .3s var(--ease), opacity .22s ease;
}
.main-nav a:hover,
.main-nav a:focus-visible,
.main-nav a.active,
.submenu-toggle:hover,
.submenu-toggle:focus-visible{
  background:none;
  box-shadow:none;
  color:#0c1116;
  transform:translateY(-1px);
}
.main-nav a:hover::after,
.main-nav a:focus-visible::after,
.main-nav a.active::after,
.submenu-toggle:hover::after,
.submenu-toggle:focus-visible::after,
.has-submenu.open .submenu-toggle::after{
  transform:scaleX(1);
  opacity:1;
}
.submenu{
  top:calc(100% + 1rem);
}
.submenu a{
  padding:.82rem .9rem;
}

.card-media{
  position:relative;
  margin:.95rem 0 .15rem;
  overflow:hidden;
  border-radius:22px;
  border:1px solid rgba(16,21,27,.08);
  background:#ebe5d8;
}
.card-media img{
  width:100%;
  aspect-ratio:1.55 / 1;
  object-fit:cover;
  transition:transform .45s var(--ease);
}
.service-card:hover .card-media img{
  transform:scale(1.04);
}
.card-media--service::after{
  content:"Dummy image";
  position:absolute;
  left:1rem;
  bottom:1rem;
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  padding:.48rem .7rem;
  border-radius:999px;
  background:rgba(13,17,23,.74);
  color:#fff;
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.google-reviews-carousel{
  padding:1.25rem;
}
.carousel-topbar,
.carousel-controls,
.google-review-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}
.carousel-topbar{
  margin-bottom:1rem;
  flex-wrap:wrap;
}
.carousel-brand{
  display:flex;
  align-items:center;
  gap:.9rem;
}
.google-mark{
  width:52px;
  height:52px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:#fff;
  color:#1f58f6;
  font-size:1.6rem;
  font-weight:700;
  box-shadow:0 16px 30px rgba(17,22,28,.08);
}
.carousel-brand strong{
  display:block;
  font-size:1.02rem;
  line-height:1.1;
}
.carousel-brand p,
.carousel-note{
  margin:0;
  color:#5b6671;
  font-size:.92rem;
}
.carousel-note{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  padding:.5rem .8rem;
  border-radius:999px;
  background:rgba(255,248,223,.9);
  border:1px solid rgba(241,181,0,.22);
}
.carousel-viewport{
  overflow:hidden;
  border-radius:26px;
}
.carousel-track{
  display:flex;
  transition:transform .45s var(--ease);
  will-change:transform;
}
.google-review-slide{
  flex:0 0 100%;
  padding:1.35rem 1.35rem 1.3rem;
  min-height:320px;
  display:grid;
  align-content:start;
  gap:1rem;
  background:
    radial-gradient(circle at 100% 0%, rgba(241,181,0,.12), transparent 22%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,242,226,.96));
}
.google-review-head{
  justify-content:flex-start;
}
.review-avatar{
  width:54px;
  height:54px;
  border-radius:18px;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  background:linear-gradient(180deg,var(--accent-2),var(--accent));
  color:#11161c;
  font-weight:700;
  box-shadow:0 14px 26px rgba(241,181,0,.18);
}
.google-review-head h3{
  margin:0 0 .15rem;
  font-size:1.12rem;
  line-height:1.15;
}
.google-review-head p,
.google-review-slide p{
  margin:0;
  color:#56616c;
}
.review-stars-row{
  letter-spacing:.24em;
  color:#f1b500;
  font-weight:800;
  font-size:1.06rem;
}
.google-review-slide p:last-child{
  font-size:1.02rem;
  line-height:1.74;
  color:#252f39;
}
.carousel-controls{
  margin-top:1rem;
}
.carousel-button{
  border:1px solid rgba(16,21,27,.08);
  background:#fff;
  color:#11161c;
  border-radius:999px;
  padding:.82rem 1rem;
  min-width:110px;
  font-weight:600;
  box-shadow:0 14px 28px rgba(17,22,28,.06);
  transition:transform .22s var(--ease), box-shadow .22s ease, border-color .22s ease;
}
.carousel-button:hover,
.carousel-button:focus-visible{
  transform:translateY(-2px);
  border-color:rgba(241,181,0,.28);
  box-shadow:0 20px 34px rgba(241,181,0,.14);
}
.carousel-dots{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.45rem;
  flex:1;
  flex-wrap:wrap;
}
.carousel-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  border:0;
  padding:0;
  background:rgba(16,21,27,.16);
  transition:transform .22s ease, background .22s ease, width .22s ease;
}
.carousel-dot.is-active{
  width:30px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
}

.gallery-section .section-head{
  margin-bottom:1.35rem;
}
.editorial-gallery{
  display:grid;
  grid-template-columns:1.15fr .85fr .85fr;
  gap:1rem;
}
.gallery-card{
  position:relative;
  min-height:260px;
  display:grid;
  overflow:hidden;
}
.gallery-card img,
.gallery-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .5s var(--ease);
}
.gallery-card:hover img,
.gallery-photo:hover img{
  transform:scale(1.04);
}
.gallery-card--feature{
  grid-row:span 2;
  min-height:100%;
}
.gallery-card-copy{
  position:absolute;
  left:1rem;
  right:1rem;
  bottom:1rem;
  z-index:1;
  display:grid;
  gap:.35rem;
  padding:1rem 1rem .95rem;
  border-radius:22px;
  background:linear-gradient(180deg, rgba(13,17,23,.08), rgba(13,17,23,.76));
  color:#fff;
  backdrop-filter:blur(10px);
}
.gallery-kicker{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#ffe8a1;
}
.gallery-card-copy h3,
.gallery-card-copy p{
  margin:0;
  color:inherit;
}
.gallery-card-copy h3{
  font-size:1.18rem;
  line-height:1.08;
}
.gallery-card-copy p{
  font-size:.95rem;
  line-height:1.55;
  color:rgba(255,255,255,.82);
}

.gallery-mosaic-grid{
  grid-template-columns:.84fr 1.16fr;
  align-items:start;
}
.gallery-benefits{
  margin-top:1.25rem;
}
.gallery-mosaic{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:1rem;
}
.gallery-photo{
  position:relative;
  overflow:hidden;
  min-height:220px;
  margin:0;
}
.gallery-photo--tall{
  grid-row:span 2;
  min-height:100%;
}
.gallery-photo--wide{
  min-height:280px;
}
.gallery-photo figcaption{
  position:absolute;
  left:1rem;
  bottom:1rem;
  margin:0;
  padding:.48rem .72rem;
  border-radius:999px;
  background:rgba(13,17,23,.72);
  color:#fff;
  font-size:.8rem;
  font-weight:600;
  letter-spacing:.06em;
}

@media (max-width:1100px){
  .editorial-gallery{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .gallery-card--feature{
    grid-column:1 / -1;
    grid-row:auto;
    min-height:340px;
  }
  .gallery-mosaic-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width:920px){
  .main-nav ul{
    gap:.25rem;
  }
  .main-nav a,
  .submenu-toggle{
    padding:.8rem 0;
  }
  .main-nav a::after,
  .submenu-toggle::after{
    bottom:.15rem;
  }
  .carousel-controls{
    flex-wrap:wrap;
  }
  .carousel-button{
    min-width:auto;
  }
}

@media (max-width:760px){
  .editorial-gallery,
  .gallery-mosaic{
    grid-template-columns:1fr;
  }
  .gallery-card,
  .gallery-card--feature,
  .gallery-photo,
  .gallery-photo--tall,
  .gallery-photo--wide{
    min-height:260px;
    grid-row:auto;
  }
  .google-reviews-carousel{
    padding:1rem;
  }
  .google-review-slide{
    min-height:unset;
    padding:1.1rem;
  }
}

@media (max-width:640px){
  .carousel-controls{
    justify-content:center;
  }
  .carousel-dots{
    order:3;
    width:100%;
  }
}



/* --- Driveways planner and review carousel upgrade --- */
.section-dark .compare-table{
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(246,241,230,.95));
  color:#24303a;
}
.section-dark .compare-row:not(.head),
.section-dark .compare-row:not(.head) div{
  color:#24303a;
}
.section-dark .compare-row:not(.head):nth-child(even){
  background:rgba(249,243,227,.72);
}
.section-dark .compare-row.head,
.section-dark .compare-row.head div{
  color:#fff;
}

.carousel-track{
  display:flex;
  transition:transform .45s var(--ease);
  will-change:transform;
}
.carousel-page{
  flex:0 0 100%;
  min-width:100%;
  display:grid;
  grid-template-columns:repeat(var(--visible-slides, 1), minmax(0, 1fr));
  gap:1rem;
}
.google-review-slide{
  min-height:320px;
  height:100%;
}

.driveway-planner{
  padding:1.1rem;
  display:grid;
  gap:1.1rem;
}
.planner-head{
  display:grid;
  gap:.55rem;
}
.planner-head h3{
  margin:.3rem 0 0;
  font-size:1.42rem;
}
.planner-head p{
  margin:0;
  color:#56616c;
  max-width:62ch;
}
.planner-groups{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:.9rem;
}
.planner-group{
  padding:1rem;
  border-radius:24px;
  border:1px solid rgba(16,21,27,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,242,226,.92));
  box-shadow:0 16px 30px rgba(17,22,28,.05);
  display:grid;
  gap:.8rem;
}
.planner-group-head{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:.8rem;
  align-items:start;
}
.planner-step{
  width:38px;
  height:38px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(180deg,#fff8de,#fff);
  border:1px solid rgba(241,181,0,.22);
  font-size:.82rem;
  font-weight:800;
  color:#11161c;
}
.planner-group h4{
  margin:0;
  font-size:1rem;
}
.planner-group p{
  margin:.2rem 0 0;
  color:#5a6470;
  font-size:.92rem;
}
.planner-options{
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
}
.planner-option{
  appearance:none;
  border:1px solid rgba(16,21,27,.09);
  border-radius:999px;
  background:#fff;
  color:#24303a;
  padding:.72rem .95rem;
  font:inherit;
  font-weight:600;
  line-height:1.35;
  box-shadow:0 12px 24px rgba(17,22,28,.04);
  transition:transform .22s var(--ease), box-shadow .22s ease, border-color .22s ease, background .22s ease, color .22s ease;
}
.planner-option:hover,
.planner-option:focus-visible{
  transform:translateY(-2px);
  border-color:rgba(241,181,0,.34);
  box-shadow:0 18px 30px rgba(241,181,0,.12);
  outline:none;
}
.planner-option.is-selected{
  background:linear-gradient(180deg, #11171f, #0d1118);
  color:#fff;
  border-color:rgba(17,23,31,.92);
  box-shadow:0 18px 34px rgba(13,17,24,.18);
}
.planner-results{
  display:grid;
  grid-template-columns:minmax(0, .94fr) minmax(0, 1.06fr);
  gap:1rem;
  align-items:start;
}
.planner-summary{
  padding:1.15rem;
  border-radius:28px;
  box-shadow:0 26px 58px rgba(13,17,24,.2);
}
.planner-summary h3{
  margin:.8rem 0 .7rem;
  font-size:1.55rem;
}
.planner-summary p{
  color:#d5dde6;
}
.planner-reasons,
.planner-notes .icon-list{
  gap:.8rem;
}
.planner-reasons span,
.planner-notes .icon-list span{
  color:inherit;
}
.planner-actions{
  display:flex;
  gap:.75rem;
  flex-wrap:wrap;
  margin-top:1.2rem;
}
.planner-side-grid{
  display:grid;
  gap:1rem;
}
.planner-scoreboard,
.planner-notes{
  padding:1rem;
  border-radius:26px;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,242,226,.92));
  border:1px solid rgba(16,21,27,.08);
}
.planner-score-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:.8rem;
  flex-wrap:wrap;
  margin-bottom:.95rem;
}
.planner-score-head strong{
  font-size:1rem;
}
.planner-score-head span{
  color:#5a6470;
  font-size:.92rem;
}
.planner-score-list{
  display:grid;
  gap:.75rem;
}
.planner-score-row{
  padding:.9rem .95rem;
  border-radius:22px;
  background:#fff;
  border:1px solid rgba(16,21,27,.07);
  box-shadow:0 12px 24px rgba(17,22,28,.04);
}
.planner-score-row.is-leading{
  border-color:rgba(241,181,0,.34);
  box-shadow:0 18px 34px rgba(241,181,0,.12);
}
.planner-score-row p{
  margin:.55rem 0 0;
  color:#5c6671;
  font-size:.92rem;
}
.planner-score-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}
.planner-score-top span{
  font-weight:800;
  color:#11161c;
}
.planner-score-bar{
  margin-top:.55rem;
  height:10px;
  border-radius:999px;
  background:rgba(17,22,28,.08);
  overflow:hidden;
}
.planner-score-bar span{
  display:block;
  height:100%;
  width:0;
  border-radius:999px;
  background:linear-gradient(90deg, #f1b500, #11171f);
  transition:width .35s ease;
}
.planner-notes{
  background:linear-gradient(180deg, rgba(17,23,31,.98), rgba(12,16,22,.96));
  color:#fff;
  box-shadow:0 24px 48px rgba(13,17,24,.18);
}
.planner-notes .planner-score-head span,
.planner-notes li span,
.planner-notes p{
  color:#d8e0e9;
}
.planner-notes svg,
.planner-reasons svg{
  fill:currentColor;
}

@media (max-width:1120px){
  .planner-groups,
  .planner-results{
    grid-template-columns:1fr;
  }
}

@media (max-width:720px){
  .carousel-page{grid-template-columns:1fr}
  .driveway-planner{padding:1rem}
  .planner-group{padding:.95rem}
  .planner-summary,
  .planner-scoreboard,
  .planner-notes{padding:.95rem}
}


/* --- Driveways planner layout tidy-up --- */
.driveway-tool-layout{
  display:grid;
  gap:1.15rem;
}
.driveway-tool-intro{
  max-width:72ch;
}
.driveway-tool-intro .comparison-points{
  max-width:68ch;
}
.driveway-planner{
  padding:1rem;
  gap:1rem;
}
.driveway-planner .panel{
  box-shadow:0 12px 26px rgba(17,22,28,.05);
}
.planner-head{
  grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);
  align-items:end;
  gap:.9rem 1.1rem;
}
.planner-head h3{
  font-size:1.28rem;
}
.planner-head p{
  font-size:.95rem;
  max-width:none;
}
.planner-groups{
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:.75rem;
}
.planner-group{
  padding:.82rem .85rem;
  border-radius:20px;
  gap:.65rem;
}
.planner-group-head{
  gap:.65rem;
}
.planner-step{
  width:32px;
  height:32px;
  border-radius:11px;
  font-size:.76rem;
}
.planner-group h4{
  font-size:.96rem;
}
.planner-group p{
  font-size:.86rem;
  line-height:1.45;
}
.planner-options{
  gap:.45rem;
}
.planner-option{
  padding:.56rem .8rem;
  font-size:.9rem;
  box-shadow:0 8px 18px rgba(17,22,28,.035);
}
.planner-results{
  grid-template-columns:minmax(0, 1.02fr) minmax(0, .98fr);
  gap:.85rem;
}
.planner-summary,
.planner-scoreboard,
.planner-notes{
  padding:.95rem;
  border-radius:22px;
}
.planner-summary h3{
  margin:.65rem 0 .55rem;
  font-size:1.34rem;
}
.planner-summary p,
.planner-score-head span,
.planner-score-row p,
.planner-notes li span,
.planner-notes p{
  font-size:.9rem;
}
.planner-reasons,
.planner-notes .icon-list,
.planner-score-list,
.planner-side-grid{
  gap:.7rem;
}
.planner-actions{
  gap:.65rem;
  margin-top:.95rem;
}
.planner-score-head{
  margin-bottom:.8rem;
}
.planner-score-row{
  padding:.8rem .82rem;
  border-radius:18px;
}
.planner-score-bar{
  height:8px;
}
@media (max-width:1120px){
  .planner-head,
  .planner-groups,
  .planner-results{
    grid-template-columns:1fr;
  }
}
