/* ───────────────────────────────────────────────────────────────
   Jerrie — UK Fuel Price Finder
   v2 — tighter spacing, sticky nav, overlapping devices, carousel
   ─────────────────────────────────────────────────────────────── */

:root{
  --green        : #2F7D32;
  --green-dark   : #0A4B0D;
  --green-mid    : #1C7324;
  --green-text   : #3A8A3E;
  --lime         : #97C11E;
  --lime-bright  : #BAD91B;
  --yellow       : #F0C419;
  --mint         : #EFF5F2;
  --ink          : #2D3A2E;
  --white        : #FFFFFF;
  --rule         : rgba(10,75,13,.18);

  --container    : 1180px;
  --radius-lg    : 22px;
  --radius-pill  : 999px;

  --nav-h        : 78px;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; overflow-x:hidden; }
body{
  font-family:'Nunito', system-ui, -apple-system, sans-serif;
  font-weight:400;
  font-size:16px;
  line-height:1.55;
  color:var(--ink);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

.container{ width:min(var(--container), 92vw); margin-inline:auto; }
.narrow   { width:min(760px, 92vw); margin-inline:auto; }

/* ── Sticky nav ─────────────────────────────────────────────── */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:18px 0;
  transition:background .3s ease, backdrop-filter .3s ease, box-shadow .3s ease, padding .3s ease;
}
.nav .container{
  display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:20px;
}
.nav-brand{
  display:flex; align-items:center; gap:10px;
  color:var(--white); font-weight:800; font-size:20px;
  transition:color .3s ease;
}
.nav-brand img{ width:38px; height:38px; border-radius:9px; box-shadow:0 4px 12px rgba(0,0,0,.2); }

.nav-pill{
  justify-self:center;
  display:inline-flex; align-items:center;
  background:var(--green-dark);
  padding:6px; border-radius:var(--radius-pill);
  gap:2px;
  box-shadow:0 4px 14px rgba(0,0,0,.18);
}
.nav-pill a{
  font-weight:700; font-size:15px;
  color:var(--yellow);
  padding:9px 22px;
  border-radius:var(--radius-pill);
  transition:background .25s, color .25s;
  white-space:nowrap;
}
.nav-pill a:hover{ background:rgba(255,255,255,.08); }
.nav-pill a.active{ background:var(--white); color:var(--ink); }

.nav-cta{
  justify-self:end;
  display:inline-flex; align-items:center; gap:8px;
  background:var(--yellow); color:var(--green-dark);
  padding:11px 22px; border-radius:var(--radius-pill);
  font-weight:800; font-size:15px;
  box-shadow:0 4px 14px rgba(0,0,0,.18);
  transition:transform .2s, box-shadow .2s, background .2s;
}
.nav-cta:hover{ transform:translateY(-2px); box-shadow:0 8px 20px rgba(0,0,0,.25); background:#F5CE2A; }

/* Scrolled — compact white pill nav */
.nav.scrolled{
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  box-shadow:0 4px 20px rgba(10,75,13,.08);
  padding:12px 0;
}
.nav.scrolled .nav-brand{ color:var(--green-dark); }

/* ── Hero ───────────────────────────────────────────────────── */
.hero{
  position:relative;
  background:var(--green);
  color:var(--white);
  padding:130px 0 120px;
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:30px;
  align-items:center;
}
.hero-brand{ display:flex; align-items:center; gap:16px; margin-bottom:24px; }
.hero-brand img{ width:66px; height:66px; border-radius:15px; box-shadow:0 8px 22px rgba(0,0,0,.25); }
.hero-brand span{ font-size:36px; font-weight:700; letter-spacing:.2px; }

.hero h1{
  font-size: clamp(34px, 4.4vw, 56px);
  font-weight:800;
  line-height:1.08;
  letter-spacing:-.5px;
  margin-bottom:22px;
}
.hero h1 .y{ color:var(--yellow); }

.hero .sub{
  font-size: clamp(16px, 1.4vw, 19px);
  font-weight:400;
  opacity:.95;
  max-width:480px;
  margin-bottom:30px;
}
.hero-device{
  position:relative; z-index:3;
  display:flex; justify-content:center;
  filter: drop-shadow(0 40px 50px rgba(0,0,0,.3));
}
.hero-device img{ width:min(380px, 100%); margin-bottom:-180px; }

.store-row{ display:flex; gap:12px; flex-wrap:wrap; }
.store-btn{
  display:inline-flex; align-items:center; gap:9px;
  background:var(--white); color:#111;
  padding:10px 20px 10px 16px;
  border-radius:12px;
  font-weight:700; font-size:14px;
  box-shadow:0 4px 14px rgba(0,0,0,.15);
  transition:transform .2s ease, box-shadow .2s ease;
}
.store-btn svg{ width:18px; height:18px; flex:0 0 18px; }
.store-btn:hover{ transform:translateY(-3px); box-shadow:0 10px 22px rgba(0,0,0,.22); }

/* ── Wave dividers ──────────────────────────────────────────── */
.wave{
  position:absolute; left:0; right:0; bottom:-1px;
  width:100%; line-height:0; pointer-events:none; z-index:1;
}
.wave svg{ display:block; width:100%; height:auto; }

/* ── Reviews ────────────────────────────────────────────────── */
.reviews{ padding:80px 0 70px; background:var(--white); }
.reviews-grid{
  display:grid; grid-template-columns:repeat(2, 1fr); gap:22px;
}
.review{
  background:var(--mint);
  border-radius:var(--radius-lg);
  padding:22px 24px;
}
.review .stars{ color:var(--green); letter-spacing:2px; font-size:15px; margin-bottom:4px; }
.review .who{ color:var(--green-mid); font-weight:800; font-size:16px; margin-bottom:4px; }
.review .who em{ font-style:normal; }
.review p{ color:var(--green-text); font-style:italic; font-size:14.5px; line-height:1.5; }
.reviews-cta{ text-align:center; margin-top:30px; }
.reviews-cta a{ color:var(--green-mid); font-weight:800; font-size:15px; border-bottom:2px solid transparent; transition:border-color .2s; }
.reviews-cta a:hover{ border-color:var(--green-mid); }

/* ── CarPlay banner (wide landscape image, swoosh cuts) ─────── */
.carplay{
  position:relative; color:var(--white);
  overflow:hidden;
  margin:30px 0 0;
}
.carplay-photo{
  position:relative;
  width:100%;
  aspect-ratio: 1536 / 760;
  background:url('../img/screens/Carplay-new-v2.png') center 38% / cover no-repeat;
  -webkit-mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1536 760' preserveAspectRatio='none'><path fill='black' d='M0,120 C420,-40 960,180 1536,10 L1536,660 C1120,820 500,620 0,740 Z'/></svg>");
          mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1536 760' preserveAspectRatio='none'><path fill='black' d='M0,120 C420,-40 960,180 1536,10 L1536,660 C1120,820 500,620 0,740 Z'/></svg>");
  -webkit-mask-size:100% 100%; mask-size:100% 100%;
  -webkit-mask-repeat:no-repeat; mask-repeat:no-repeat;
}
.carplay-photo::before{
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(0,0,0,.55) 75%, rgba(0,0,0,.8) 100%);
  -webkit-mask-image: inherit; mask-image: inherit;
  -webkit-mask-size:100% 100%; mask-size:100% 100%;
}
.carplay-head{
  position:absolute; left:0; right:0; bottom:10%; z-index:2;
  text-align:center; padding:0 4vw;
}
.carplay-head h2{
  font-size: clamp(28px, 3.6vw, 46px);
  font-weight:800; line-height:1.15; letter-spacing:-.5px;
  text-shadow:0 4px 20px rgba(0,0,0,.5);
  color:#fff;
}
.carplay-head h2 .lime{ color:var(--lime-bright); }

/* ── Feature blocks (overlapping devices) ───────────────────── */
.feat-block{ position:relative; }
.feat-block.white{ background:var(--white); padding:30px 0 30px; }
.feat-block.lime { background:var(--lime); padding:40px 0 60px; }

.feat-grid{
  display:grid; grid-template-columns:.9fr 1.1fr; gap:50px; align-items:center;
}
.feat-grid.rev{ grid-template-columns:1.1fr .9fr; }
.feat-grid.rev .feat-device{ order:2; }

.feat-device{
  position:relative; z-index:4;
  filter:drop-shadow(0 30px 40px rgba(0,0,0,.25));
  align-self:center;
}
.feat-device img{ width:min(360px, 100%); margin-inline:auto; }
.feat-list{ padding:30px 0; }

/* Device protrudes into neighbouring sections via big negative margins */
.feat-block.white .feat-device{ margin-top:-220px; margin-bottom:-120px; }
.feat-block.lime  .feat-device{ margin-top:-140px; margin-bottom:-200px; }

.feat-list{ display:flex; flex-direction:column; }
.feat-item{
  display:grid; grid-template-columns:84px 1fr; gap:22px; align-items:center;
  padding:16px 0;
  border-bottom:1px solid var(--rule);
}
.feat-item:last-child{ border-bottom:none; }
.feat-item .pill{
  width:84px; height:54px; border-radius:27px;
  background:var(--green-dark);
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
.feat-item .pill img{ width:84px; height:54px; object-fit:cover; }
.feat-item h3{ color:var(--green-mid); font-weight:800; font-size:18px; margin-bottom:1px; }
.feat-item p { color:var(--green-text); font-size:15px; line-height:1.45; }

.feat-block.lime .feat-item{ border-color:rgba(10,75,13,.22); }
.feat-block.lime .feat-item h3{ color:var(--green-dark); }
.feat-block.lime .feat-item p { color:#21561F; }

/* ── Story / "What is Jerrie" ───────────────────────────────── */
.story{ position:relative; background:var(--white); padding:90px 0 100px; }
.story-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:50px; align-items:center; }
.story{ overflow:visible; }
.story .feat-device{ margin-top:-160px; margin-bottom:-140px; align-self:center; }
.story h2{ font-size:clamp(32px, 3.6vw, 44px); font-weight:800; color:var(--green-dark); margin-bottom:18px; letter-spacing:-.5px; }
.story p{ color:var(--ink); font-size:16px; margin-bottom:14px; max-width:560px; line-height:1.6; }
.story .btn-row{ margin-top:20px; }

/* Pill primary button */
.btn-primary{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--green-dark); color:#fff;
  padding:12px 24px; border-radius:var(--radius-pill);
  font-weight:800; font-size:15px;
  transition:transform .2s, background .2s, box-shadow .2s;
  box-shadow:0 6px 18px rgba(10,75,13,.25);
}
.btn-primary:hover{ background:var(--green); transform:translateY(-2px); box-shadow:0 10px 24px rgba(10,75,13,.32); }
.btn-primary.yellow{ background:var(--yellow); color:var(--green-dark); box-shadow:0 6px 18px rgba(240,196,25,.35); }
.btn-primary.yellow:hover{ background:#F5CE2A; }

/* ── Official Government Data ───────────────────────────────── */
.gov{ position:relative; background:var(--green); color:var(--white); padding:100px 0 120px; }
.gov-grid{ display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center; }
.gov h2{ font-size:clamp(30px, 3.4vw, 42px); font-weight:800; line-height:1.15; margin-bottom:18px; }
.gov p{ font-size:16px; max-width:480px; opacity:.96; margin-bottom:22px; }
.gov .feat-device{ margin-top:-120px; margin-bottom:-160px; align-self:center; }
.gov .btn-primary{ background:var(--yellow); color:var(--green-dark); box-shadow:0 6px 18px rgba(0,0,0,.22); }
.gov .btn-primary:hover{ background:#F5CE2A; }

/* ── Carousel ───────────────────────────────────────────────── */
.carousel-wrap{ position:relative; background:var(--white); padding:90px 0 100px; overflow:hidden; }
.carousel{
  position:relative;
  width:min(900px, 92vw);
  margin:0 auto;
}
.carousel-viewport{ overflow:hidden; border-radius:14px; }
.carousel-track{
  display:flex;
  transition:transform .6s cubic-bezier(.22,.61,.36,1);
  will-change:transform;
}
.carousel-slide{
  flex:0 0 100%;
  display:grid; grid-template-columns:.9fr 1.1fr; gap:50px; align-items:center;
  padding:10px 20px;
}
.carousel-slide .slide-img{ filter:drop-shadow(0 24px 36px rgba(0,0,0,.2)); }
.carousel-slide .slide-img img{ width:min(280px, 100%); margin-inline:auto; }
.carousel-slide .kicker{
  display:inline-flex; align-items:center; gap:8px;
  font-weight:800; font-size:12px; letter-spacing:1.5px; text-transform:uppercase;
  color:var(--green-mid); margin-bottom:10px;
}
.carousel-slide .kicker::before{ content:''; width:24px; height:2px; background:var(--lime); }
.carousel-slide h3{ font-size:28px; font-weight:800; color:var(--green-dark); margin-bottom:10px; letter-spacing:-.3px; }
.carousel-slide p { font-size:16px; color:var(--ink); max-width:460px; line-height:1.55; }

.car-arrow{
  position:absolute; top:50%; transform:translateY(-50%);
  width:48px; height:48px; border-radius:50%;
  background:var(--green-dark); color:#fff; border:none;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; z-index:3;
  transition:background .2s, transform .2s, box-shadow .2s;
  box-shadow:0 6px 16px rgba(10,75,13,.25);
}
.car-arrow:hover{ background:var(--green); box-shadow:0 10px 22px rgba(10,75,13,.35); }
.car-arrow.prev{ left:-20px; }
.car-arrow.next{ right:-20px; }
.car-arrow:hover.prev{ transform:translateY(-50%) translateX(-3px); }
.car-arrow:hover.next{ transform:translateY(-50%) translateX(3px); }

.car-dots{ display:flex; justify-content:center; gap:8px; margin-top:20px; }
.car-dots button{
  width:9px; height:9px; border-radius:50%;
  background:rgba(10,75,13,.22); border:none; cursor:pointer;
  transition:background .2s, transform .2s;
}
.car-dots button.active{ background:var(--green-dark); transform:scale(1.25); }

/* ── Full feature list (accordion) ──────────────────────────── */
.keylist{ position:relative; background:var(--lime); padding:90px 0 110px; }
.keylist h2{ font-size:clamp(30px, 3.4vw, 42px); font-weight:800; color:var(--green-dark); text-align:center; margin-bottom:10px; letter-spacing:-.5px; }
.keylist .lead{ text-align:center; color:#21561F; max-width:520px; margin:0 auto 34px; font-size:15.5px; }
.accordion{ width:min(640px, 92vw); margin:0 auto; }
.acc-item{
  background:var(--white); border-radius:14px; margin-bottom:10px;
  overflow:hidden; box-shadow:0 4px 14px rgba(10,75,13,.1);
}
.acc-head{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:14px 20px; cursor:pointer; user-select:none;
}
.acc-head h4{ font-weight:800; color:var(--green-dark); font-size:15.5px; }
.acc-head .chev{ transition:transform .25s ease; color:var(--green-mid); flex:0 0 18px; }
.acc-item.open .acc-head .chev{ transform:rotate(180deg); }
.acc-body{
  max-height:0; overflow:hidden;
  transition:max-height .35s ease;
}
.acc-body ul{ list-style:none; padding:2px 20px 18px; }
.acc-body li{
  padding:6px 0 6px 22px; position:relative;
  color:var(--ink); font-size:14.5px; line-height:1.45;
}
.acc-body li::before{
  content:''; position:absolute; left:0; top:11px;
  width:9px; height:9px; border-radius:2px;
  background:var(--lime); outline:2px solid var(--green-dark); outline-offset:-2px;
}

/* ── Quote ──────────────────────────────────────────────────── */
.quote{ position:relative; background:var(--white); padding:90px 0 40px; text-align:center; }
.quote .mark{ font-size:80px; line-height:.4; color:var(--lime); font-weight:800; }
.quote blockquote{
  font-size:clamp(18px, 1.7vw, 22px); font-weight:500; font-style:italic;
  color:var(--green-dark); max-width:720px; margin:20px auto 18px; line-height:1.55;
}
.quote cite{ font-style:normal; font-weight:800; color:var(--green-mid); font-size:14.5px; letter-spacing:.3px; }

/* ── Link cards (no green bg) ───────────────────────────────── */
.linkcards{ position:relative; background:var(--white); padding:20px 0 50px; }
.linkcards-grid{ display:grid; grid-template-columns:1fr 1fr; gap:20px; width:min(820px,92vw); margin:0 auto; }
.linkcard{
  background:var(--green-dark);
  color:#fff;
  border-radius:var(--radius-lg);
  padding:22px 26px;
  transition:transform .25s ease, background .25s ease, box-shadow .25s ease;
  box-shadow:0 6px 18px rgba(10,75,13,.2);
}
.linkcard:hover{ transform:translateY(-4px); background:var(--green); box-shadow:0 12px 26px rgba(10,75,13,.3); }
.linkcard h3{ font-size:18px; font-weight:800; margin-bottom:6px; display:flex; align-items:center; gap:8px; }
.linkcard h3 .y{ color:var(--yellow); }
.linkcard h3 .arrow{ transition:transform .25s ease; margin-left:auto; }
.linkcard:hover h3 .arrow{ transform:translateX(5px); }
.linkcard p{ font-size:14px; opacity:.9; line-height:1.5; }

/* ── Final CTA ──────────────────────────────────────────────── */
.cta{ position:relative; background:var(--white); padding:50px 0 120px; text-align:center; }
.cta h2{ font-size:clamp(28px, 3.2vw, 40px); font-weight:800; color:var(--green-dark); margin-bottom:10px; letter-spacing:-.5px; }
.cta p{ color:var(--green-text); font-size:15.5px; margin-bottom:24px; }
.cta .store-row{ justify-content:center; }
.cta .store-btn{ background:var(--green-dark); color:#fff; padding:11px 22px; font-size:14.5px; }
.cta .store-btn:hover{ background:var(--green); }

/* ── Footer (with subtle curve top) ─────────────────────────── */
.footer-wrap{ position:relative; background:var(--white); }
.foot-wave{ line-height:0; }
.foot-wave svg{ display:block; width:100%; height:auto; }
footer{
  background:#0A3A0C; color:rgba(255,255,255,.85);
  padding:40px 0 32px; font-size:14px;
}
.foot-grid{ display:flex; flex-wrap:wrap; gap:30px; align-items:center; justify-content:space-between; }
.foot-brand{ display:flex; align-items:center; gap:12px; font-weight:800; font-size:18px; color:#fff; }
.foot-brand img{ width:32px; height:32px; border-radius:8px; }
.foot-links{ display:flex; flex-wrap:wrap; gap:8px 22px; }
.foot-links a{ font-weight:700; font-size:13.5px; transition:color .2s; }
.foot-links a:hover{ color:var(--yellow); }
footer .legal{ margin-top:22px; padding-top:18px; border-top:1px solid rgba(255,255,255,.15); opacity:.7; font-size:12.5px; }

/* ── Sub-page hero (stats / press) ──────────────────────────── */
.subhero{
  position:relative; background:var(--green); color:var(--white);
  padding:130px 0 30px; overflow:hidden;
  min-height:580px;
}
.subhero-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:end; }
.subhero-grid > .reveal:first-child{ padding-bottom:170px; }
.subhero .phone-cut{
  position:relative; z-index:2;
  margin-bottom:-20px;
  filter:drop-shadow(0 24px 36px rgba(0,0,0,.3));
}
.subhero .phone-cut img{ width:min(360px,100%); margin:0 0 0 auto; }
.subhero .wave{ z-index:3; }       /* white swoosh clips phone bottom */
.subhero h1{ font-size:clamp(32px, 3.8vw, 46px); font-weight:800; line-height:1.1; margin-bottom:12px; letter-spacing:-.5px; }
.subhero p{ font-size:16.5px; max-width:540px; opacity:.95; line-height:1.55; }
.subhero .live-dot{
  display:inline-flex; align-items:center; gap:10px;
  font-weight:800; font-size:12px; letter-spacing:1.6px; text-transform:uppercase;
  color:var(--yellow); margin-bottom:14px;
}
.subhero .live-dot::before{
  content:''; width:8px; height:8px; border-radius:50%;
  background:var(--lime-bright); box-shadow:0 0 0 0 rgba(186,217,27,.7);
  animation:pulse 1.8s infinite;
}
@keyframes pulse{
  0%{ box-shadow:0 0 0 0 rgba(186,217,27,.7);} 70%{ box-shadow:0 0 0 12px rgba(186,217,27,0);} 100%{ box-shadow:0 0 0 0 rgba(186,217,27,0);}
}

/* ── Stats page ─────────────────────────────────────────────── */
.stats-wrap{ background:var(--white); padding:60px 0 100px; position:relative; }

.range-cards{ display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:30px; }
.range-card{
  border:1px solid var(--rule); border-radius:18px; padding:22px 24px;
  background:var(--white);
}
.range-card .label{ font-weight:800; letter-spacing:1.2px; font-size:12px; text-transform:uppercase; color:var(--green-mid); margin-bottom:8px; }
.range-card .range{ font-size:28px; font-weight:800; letter-spacing:-.5px; }
.range-card .lo{ color:var(--green-mid); }
.range-card .hi{ color:#D43B2A; }
.range-card .dash{ color:#888; font-weight:400; padding:0 6px; }
.range-card .avg{ margin-top:10px; font-size:14px; color:#5a6b5b; }
.range-card .avg b{ color:var(--ink); font-weight:800; }
.range-card .delta{ font-weight:800; font-size:12.5px; }
.delta.down{ color:var(--green-mid); } .delta.up{ color:#D43B2A; }

.stat-panel{
  border:1px solid var(--rule); border-radius:18px; padding:22px 24px; margin-bottom:20px;
}
.stat-panel h3{ font-weight:800; color:var(--green-dark); font-size:17px; margin-bottom:2px; }
.stat-panel .hint{ font-size:12.5px; color:#6a7a6b; margin-bottom:14px; }

/* Station type rows — left-aligned bars (all bars same max-width) */
.stat-row{
  display:grid;
  grid-template-columns: 190px 1fr 70px 72px;
  align-items:center;
  gap:18px;
  padding:10px 0;
  border-bottom:1px solid var(--rule);
}
.stat-row:last-child{ border-bottom:none; }
.stat-row .name{ font-weight:600; color:var(--ink); font-size:14.5px; }
.stat-row .name small{ color:#7d8c7e; font-weight:400; margin-left:4px; }
.stat-row .bar{ height:8px; background:var(--mint); border-radius:4px; overflow:hidden; }
.stat-row .bar i{ display:block; height:100%; background:var(--green); border-radius:4px; }
.stat-row .diff{ font-weight:800; font-size:13px; text-align:right; }
.stat-row .val{ font-weight:800; font-size:17px; white-space:nowrap; text-align:right; }

.trend-panel svg{ width:100%; height:auto; }
.trend-legend{ display:flex; gap:20px; margin-top:10px; font-size:13px; font-weight:700; }
.trend-legend span{ display:inline-flex; align-items:center; gap:8px; }
.trend-legend i{ width:16px; height:4px; border-radius:2px; }

/* Cheapest & most expensive two tables */
.price-tables{ display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:20px; }
.price-table{
  border:1px solid var(--rule); border-radius:18px; overflow:hidden;
}
.price-table header{
  padding:16px 20px 12px; border-bottom:1px solid var(--rule);
  background:var(--mint);
}
.price-table.expensive header{ background:#FBECEA; }
.price-table header .title{ font-weight:800; color:var(--green-dark); font-size:16px; display:flex; align-items:center; gap:8px; }
.price-table.expensive header .title{ color:#B02F21; }
.price-table header .sub{ font-size:12.5px; color:#6a7a6b; margin-top:2px; }
.price-table .prow{
  display:grid; grid-template-columns:1.4fr auto; gap:14px; align-items:center;
  padding:12px 20px;
  border-bottom:1px solid var(--rule);
}
.price-table .prow:last-child{ border-bottom:none; }
.price-table .prow .nm{ font-weight:700; font-size:14.5px; color:var(--ink); letter-spacing:.2px; }
.price-table .prow .nm small{ display:block; font-weight:400; color:#7d8c7e; font-size:12px; margin-top:1px; }
.price-table .prow .pr{ font-weight:800; font-size:17px; }
.price-table .prow .pr.good{ color:var(--green-mid); }
.price-table .prow .pr.bad { color:#D43B2A; }

.stats-dl{ background:var(--mint); border-radius:18px; padding:26px; text-align:center; margin-top:30px; }
.stats-dl p{ color:var(--green-text); margin-bottom:14px; font-size:15px; }
.stats-dl .store-row{ justify-content:center; }
.stats-dl .store-btn{ background:var(--green-dark); color:#fff; }

/* ── Press page ─────────────────────────────────────────────── */
.press-wrap{ background:var(--white); padding:60px 0 100px; position:relative; }
.press-grid{ display:grid; grid-template-columns:1.25fr .75fr; gap:44px; }
.press-grid h2{ font-size:24px; font-weight:800; color:var(--green-dark); margin:0 0 10px; }
.press-grid p{ font-size:15px; margin-bottom:14px; color:var(--ink); line-height:1.6; }
.fact-list{ list-style:none; margin:8px 0 24px; }
.fact-list li{
  display:flex; justify-content:space-between; gap:14px;
  padding:10px 0; border-bottom:1px solid var(--rule); font-size:14.5px;
}
.fact-list li b{ font-weight:800; color:var(--green-dark); }
.press-side .card{
  background:var(--mint); border-radius:18px; padding:22px; margin-bottom:16px;
}
.press-side .card h3{ font-size:16.5px; font-weight:800; color:var(--green-dark); margin-bottom:8px; }
.press-side .card p{ font-size:14px; margin-bottom:8px; }
.press-side .card a.btn{
  display:inline-block; margin-top:6px;
  background:var(--green-dark); color:#fff; font-weight:800;
  padding:10px 18px; border-radius:10px; font-size:13.5px;
  transition:background .2s, transform .2s;
}
.press-side .card a.btn:hover{ background:var(--green); transform:translateY(-2px); }
.asset-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-top:8px; }
.asset-grid a{
  background:var(--mint); border-radius:12px; padding:10px;
  display:flex; align-items:center; justify-content:center;
  aspect-ratio:1/1; transition:transform .2s;
}
.asset-grid a:hover{ transform:translateY(-3px); }
.asset-grid img{ max-height:100%; object-fit:contain; border-radius:6px; }

/* ── Scroll-reveal animation ────────────────────────────────── */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s ease, transform .7s ease; }
.reveal.left { transform:translateX(-30px); }
.reveal.right{ transform:translateX( 30px); }
.reveal.in{ opacity:1; transform:none; }
.stagger > *{ opacity:0; transform:translateY(22px); transition:opacity .6s ease, transform .6s ease; }
.stagger.in > *{ opacity:1; transform:none; }
.stagger.in > *:nth-child(1){ transition-delay:.04s;} .stagger.in > *:nth-child(2){ transition-delay:.10s;}
.stagger.in > *:nth-child(3){ transition-delay:.16s;} .stagger.in > *:nth-child(4){ transition-delay:.22s;}
.stagger.in > *:nth-child(5){ transition-delay:.28s;} .stagger.in > *:nth-child(6){ transition-delay:.34s;}

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 980px){
  .hero{ padding:110px 0 80px; }
  .hero-grid, .feat-grid, .feat-grid.rev, .story-grid, .gov-grid,
  .subhero-grid, .range-cards, .price-tables, .press-grid, .linkcards-grid,
  .carousel-slide{ grid-template-columns:1fr; gap:36px; }
  .feat-grid.rev .feat-device{ order:0; }
  .hero-device img{ width:min(300px,80%); margin-bottom:-100px; }
  .feat-block.white .feat-device,
  .feat-block.lime .feat-device,
  .story .feat-device,
  .gov .feat-device{ margin:0 auto; }
  .reviews-grid{ grid-template-columns:1fr; }
  .subhero .phone-cut{ transform:none; margin-top:20px; }
  .nav-cta{ display:none; }
  .nav-pill a{ padding:8px 16px; font-size:14px; }
  .nav .container{ grid-template-columns:auto 1fr; }
  .nav-pill{ justify-self:end; }
  .carplay-head{ bottom:6%; }
  .car-arrow.prev{ left:-4px; }
  .car-arrow.next{ right:-4px; }
  .reveal.left, .reveal.right{ transform:translateY(28px); }
  .asset-grid{ grid-template-columns:repeat(2,1fr); }
  .stat-row{ grid-template-columns:150px 1fr 60px 64px; gap:12px; }
}
@media (max-width: 560px){
  .hero-brand img{ width:56px; height:56px; border-radius:13px; }
  .hero-brand span{ font-size:30px; }
  .feat-item{ grid-template-columns:70px 1fr; gap:16px; }
  .feat-item .pill{ width:70px; height:46px; border-radius:23px; }
  .feat-item .pill img{ width:70px; height:46px; }
  .stat-row{ grid-template-columns:1fr auto; }
  .stat-row .bar, .stat-row .diff{ display:none; }
  .nav-brand span{ display:none; }
}
