/* =========================================================
   Pete Gawtry Fitness — staging rebuild v2 (premium)
   Hand-coded, mobile-first, no framework.
   Barlow Condensed display + Inter body.
   ========================================================= */

:root{
  --bg:#070a10;
  --bg-2:#0b0e16;
  --surface:#12161f;
  --surface-2:#171c28;
  --surface-3:#1e2433;
  --line:#222838;
  --line-2:#2f3749;
  --ink:#f6f8fc;
  --ink-2:#c4ccdb;
  --mute:#828ca0;
  --accent:#3ab549;
  --accent-2:#2c9e3b;
  --accent-3:#54d166;
  --accent-soft:rgba(58,181,73,.12);
  --accent-glow:rgba(58,181,73,.38);
  --gold:#f5c518;
  --gold-2:#caa017;
  --radius:16px;
  --radius-lg:24px;
  --radius-sm:11px;
  --radius-pill:999px;
  --shadow:0 40px 90px -30px rgba(0,0,0,.7);
  --shadow-sm:0 14px 40px -18px rgba(0,0,0,.6);
  --shadow-card:0 18px 50px -28px rgba(0,0,0,.85);
  --max:1200px;
  --pad:clamp(20px,4vw,44px);
  --nav-h:66px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--ink);
  font:400 17px/1.62 'Inter','Helvetica Neue',system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  position:relative;
}
/* ambient page glows */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(60% 40% at 85% -5%,rgba(58,181,73,.10),transparent 60%),
    radial-gradient(50% 35% at 0% 12%,rgba(58,181,73,.06),transparent 55%);
}
img,svg,video{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;border:0;background:none;color:inherit;cursor:pointer}
ul{margin:0;padding:0;list-style:none}
::selection{background:var(--accent);color:#04230a}

.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.container--narrow{max-width:880px}
section{padding:clamp(60px,8.5vw,116px) 0;position:relative}
.section--tight{padding:clamp(40px,6vw,76px) 0}
hr.divider{border:0;height:1px;margin:0;background:linear-gradient(90deg,transparent,var(--line-2),transparent)}
.bg-2{background:var(--bg-2)}
.bg-surface{background:linear-gradient(180deg,var(--bg),var(--bg-2))}

/* ---------- Typography ---------- */
h1,h2,h3,h4{
  font-family:'Barlow Condensed','Oswald',sans-serif;
  font-weight:900;letter-spacing:.005em;line-height:1.0;
  margin:0 0 .4em;text-transform:uppercase;
}
h1{font-size:clamp(44px,8.5vw,92px);letter-spacing:-.01em}
h2{font-size:clamp(33px,5.6vw,60px)}
h3{font-size:clamp(21px,3.2vw,29px)}
h4{font-size:clamp(17px,2.2vw,21px)}
p{margin:0 0 1em}
.kicker,.eyebrow{
  display:inline-flex;align-items:center;gap:9px;font:800 12px/1 'Inter',sans-serif;
  letter-spacing:.2em;text-transform:uppercase;color:var(--accent-3);
  padding:9px 16px;border:1px solid color-mix(in srgb,var(--accent) 32%,transparent);
  background:var(--accent-soft);border-radius:var(--radius-pill);margin-bottom:20px;
}
.kicker::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent)}
.lede{font-size:clamp(17px,2vw,21px);color:var(--ink-2);max-width:64ch;margin:0 auto 24px;line-height:1.6}
.section-head{text-align:center;max-width:780px;margin:0 auto clamp(40px,5vw,62px)}
.section-head .lede{margin-bottom:0}
.muted{color:var(--mute)}.accent{color:var(--accent-3)}.gold{color:var(--gold)}
.center{text-align:center}
.text-grad{background:linear-gradient(120deg,var(--accent-3),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Icons ---------- */
.ico{width:24px;height:24px;flex:none;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.icon-chip{
  display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;
  border-radius:15px;background:linear-gradient(160deg,var(--accent-soft),rgba(58,181,73,.04));
  border:1px solid color-mix(in srgb,var(--accent) 28%,transparent);color:var(--accent-3);
  margin-bottom:18px;box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.icon-chip .ico{width:26px;height:26px}
.icon-chip--gold{background:linear-gradient(160deg,rgba(245,197,24,.14),rgba(245,197,24,.03));border-color:rgba(245,197,24,.32);color:var(--gold)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font:800 15px/1 'Inter',sans-serif;letter-spacing:.01em;
  padding:16px 28px;border-radius:var(--radius-pill);
  transition:transform .18s var(--ease),box-shadow .25s,background .25s,border-color .2s,color .2s;
  white-space:nowrap;position:relative;
}
.btn .ico{width:19px;height:19px;stroke-width:2.4}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn--primary{background:linear-gradient(135deg,var(--accent-3),var(--accent-2));color:#04230a;box-shadow:0 14px 34px -12px var(--accent-glow),inset 0 1px 0 rgba(255,255,255,.25)}
.btn--primary:hover{box-shadow:0 20px 44px -12px var(--accent-glow),inset 0 1px 0 rgba(255,255,255,.3)}
.btn--ghost{background:rgba(255,255,255,.02);color:var(--ink);border:1.5px solid var(--line-2)}
.btn--ghost:hover{border-color:var(--accent);color:var(--accent-3);background:var(--accent-soft)}
.btn--light{background:var(--ink);color:#070a10}
.btn--light:hover{background:#fff}
.btn--lg{padding:19px 36px;font-size:16px}
.btn--block{display:flex;width:100%;justify-content:center}
.btn-row{display:flex;flex-wrap:wrap;gap:14px}
.btn-row--center{justify-content:center}

/* ---------- Nav ---------- */
.nav{
  position:sticky;top:0;z-index:200;
  background:rgba(7,10,16,.72);
  backdrop-filter:saturate(150%) blur(14px);
  -webkit-backdrop-filter:saturate(150%) blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s;
}
.nav.is-stuck{border-bottom-color:var(--line);background:rgba(7,10,16,.9)}
.nav__inner{display:flex;align-items:center;gap:18px;padding:0 var(--pad);height:var(--nav-h);max-width:var(--max);margin:0 auto}
.nav__logo{display:flex;align-items:center;gap:11px;font:900 18px/1 'Barlow Condensed',sans-serif;letter-spacing:.1em;text-transform:uppercase}
.nav__logo img{height:34px;width:auto}
.nav__logo b{color:var(--accent-3)}
.nav__links{display:none;gap:24px;margin-left:auto;align-items:center}
.nav__links a{font:600 14.5px/1 'Inter',sans-serif;color:var(--ink-2);transition:color .18s;position:relative;padding:6px 0}
.nav__links a:hover,.nav__links a[aria-current]{color:var(--ink)}
.nav__links a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--accent);border-radius:2px;transition:right .25s var(--ease)}
.nav__links a:hover::after,.nav__links a[aria-current]::after{right:0}
.nav__cta{display:none;margin-left:6px}
.nav__toggle{margin-left:auto;display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;align-items:center;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.02)}
.nav__toggle span{width:21px;height:2px;background:var(--ink);border-radius:2px;transition:.25s var(--ease)}
body.menu-open .nav__toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.menu-open .nav__toggle span:nth-child(2){opacity:0}
body.menu-open .nav__toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.drawer{
  position:fixed;inset:var(--nav-h) 0 0;z-index:190;
  background:radial-gradient(80% 50% at 100% 0%,rgba(58,181,73,.10),transparent 60%),linear-gradient(180deg,var(--bg-2),var(--bg));
  padding:22px var(--pad) 40px;transform:translateX(100%);transition:transform .3s var(--ease);
  overflow-y:auto;display:flex;flex-direction:column;gap:4px;
}
body.menu-open .drawer{transform:translateX(0)}
body.menu-open{overflow:hidden}
.drawer a{
  display:flex;align-items:center;justify-content:space-between;
  font:800 23px/1 'Barlow Condensed',sans-serif;text-transform:uppercase;letter-spacing:.02em;
  padding:17px 4px;border-bottom:1px solid var(--line);color:var(--ink);transition:color .15s,padding .2s;
}
.drawer a:hover{color:var(--accent-3);padding-left:8px}
.drawer a span{color:var(--mute);font-size:14px;font-family:'Inter';font-weight:700;letter-spacing:.04em}
.drawer .btn{margin-top:24px}
.drawer__sub{font:700 11px/1 'Inter',sans-serif;letter-spacing:.2em;color:var(--mute);text-transform:uppercase;margin:24px 4px 6px}

@media (min-width:1100px){
  .nav__links{display:flex}.nav__cta{display:inline-flex}
  .nav__toggle{display:none}.drawer{display:none}
}

/* ---------- Hero (split) ---------- */
.hero{position:relative;overflow:hidden;background:var(--bg-2);isolation:isolate;border-bottom:1px solid var(--line)}
.hero::before{content:"";position:absolute;z-index:-1;width:680px;height:680px;right:-180px;top:-220px;
  background:radial-gradient(circle,var(--accent-glow),transparent 62%);filter:blur(16px);opacity:.55}
.hero__inner{max-width:var(--max);margin:0 auto;padding:clamp(48px,7vw,86px) var(--pad);
  display:grid;gap:clamp(28px,5vw,56px);grid-template-columns:1fr;align-items:center}
.hero__inner--center{text-align:center;justify-items:center}
.hero h1{margin-bottom:.28em}
.hero .lede{margin-left:0}
.hero__inner--center .lede{margin-left:auto}
.hero__copy{position:relative;z-index:2}
.hero__photo{position:relative;justify-self:center;max-width:440px;width:100%}
.hero__photo::before{content:"";position:absolute;inset:auto 0 -2% 0;height:78%;z-index:-1;
  border-radius:28px;background:
    radial-gradient(70% 70% at 50% 30%,rgba(58,181,73,.34),transparent 70%);filter:blur(8px)}
.hero__photo::after{content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%);
  width:84%;height:24px;border-radius:50%;background:rgba(0,0,0,.55);filter:blur(16px);z-index:-1}
.hero__photo img{width:100%;filter:drop-shadow(0 30px 50px rgba(0,0,0,.6))}
/* floating badges on hero photo */
.float-badge{position:absolute;display:flex;align-items:center;gap:10px;
  background:rgba(18,22,31,.86);border:1px solid var(--line-2);backdrop-filter:blur(8px);
  border-radius:14px;padding:11px 14px;box-shadow:var(--shadow-sm)}
.float-badge .ico{color:var(--accent-3);width:22px;height:22px}
.float-badge b{font:900 18px/1 'Barlow Condensed';display:block}
.float-badge span{font:600 11px/1.2 'Inter';color:var(--mute);text-transform:uppercase;letter-spacing:.08em}
.float-badge--tl{top:8%;left:-10px}
.float-badge--br{bottom:14%;right:-10px}
.float-badge--gold .ico{color:var(--gold)}
.hero-rating{display:inline-flex;align-items:center;gap:12px;margin-bottom:22px;
  background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:var(--radius-pill);padding:8px 16px 8px 10px}
.hero-rating .stars{color:var(--gold);letter-spacing:2px;font-size:14px}
.hero-rating small{color:var(--ink-2);font-size:13px;font-weight:600}
.hero-rating .avs{display:flex}
.hero-rating .avs img{width:30px;height:30px;border-radius:50%;border:2px solid var(--bg-2);object-fit:cover;margin-left:-10px}
.hero-rating .avs img:first-child{margin-left:0}
@media (min-width:880px){
  .hero__inner--split{grid-template-columns:1.15fr .85fr}
  .hero__inner--split .hero__copy{text-align:left}
  .hero__photo{justify-self:end;max-width:480px}
}

/* ribbon */
.ribbon{background:linear-gradient(90deg,var(--accent-2),var(--accent-3));color:#04230a;overflow:hidden;white-space:nowrap}
.ribbon__track{display:inline-flex;gap:0;padding:13px 0;font:800 13px/1 'Barlow Condensed',sans-serif;letter-spacing:.13em;text-transform:uppercase;animation:slide 30s linear infinite}
.ribbon__track span{display:inline-flex;gap:36px;padding-right:36px}
@keyframes slide{to{transform:translateX(-50%)}}

/* ---------- Stat strip ---------- */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border-block:1px solid var(--line)}
.stats .stat{background:var(--bg-2);padding:30px 16px;text-align:center;position:relative;transition:background .25s}
.stats .stat::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:0;height:2px;background:var(--accent);transition:width .3s var(--ease)}
.stats .stat:hover{background:var(--surface)}
.stats .stat:hover::before{width:46px}
.stat__n{font:900 clamp(34px,6vw,52px)/1 'Barlow Condensed',sans-serif;background:linear-gradient(120deg,#fde08a,#f5c518);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat__l{font-size:12.5px;color:var(--mute);text-transform:uppercase;letter-spacing:.14em;margin-top:8px;font-weight:600}
@media (min-width:760px){.stats{grid-template-columns:repeat(4,1fr)}}

/* ---------- Grids ---------- */
.grid{display:grid;gap:22px}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
.grid-4{grid-template-columns:1fr 1fr}
@media (min-width:680px){.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:1fr 1fr}}
@media (min-width:980px){.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}}

/* ---------- Cards ---------- */
.card{
  background:linear-gradient(165deg,var(--surface-2),var(--surface));
  border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px;height:100%;position:relative;overflow:hidden;
  transition:transform .25s var(--ease),border-color .25s,box-shadow .25s;
}
.card::after{content:"";position:absolute;top:0;left:24px;right:24px;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;transition:opacity .3s}
.card:hover{transform:translateY(-6px);border-color:var(--line-2);box-shadow:var(--shadow-card)}
.card:hover::after{opacity:1}
.card__icon{font-size:30px;margin-bottom:14px;display:block}
.card h3{margin-bottom:.45em}
.card p{color:var(--ink-2);margin-bottom:1em}
.card__link{display:inline-flex;align-items:center;gap:7px;font:800 14px/1 'Inter',sans-serif;color:var(--accent-3);letter-spacing:.01em;transition:gap .2s}
.card__link .ico{width:17px;height:17px}
.card__link:hover{gap:11px}
.card--media{padding:0;overflow:hidden}
.card--media img{aspect-ratio:16/10;object-fit:cover;width:100%;transition:transform .4s var(--ease)}
.card--media:hover img{transform:scale(1.05)}
.card--media .card__body{padding:24px}
.card--media .card__cat{font:700 11px/1 'Inter';letter-spacing:.16em;text-transform:uppercase;color:var(--accent-3);margin-bottom:8px;display:block}
.card--feature{background:linear-gradient(165deg,var(--surface-3),var(--surface))}

.tile{background:linear-gradient(165deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:var(--radius);padding:24px;transition:transform .2s,border-color .2s}
.tile:hover{transform:translateY(-3px);border-color:var(--line-2)}
.tile h4{color:var(--ink);margin-bottom:.3em}
.tile p{color:var(--mute);margin:0;font-size:15px}

/* split (image + text) */
.split{display:grid;gap:clamp(26px,5vw,60px);align-items:center;grid-template-columns:1fr}
@media (min-width:900px){.split{grid-template-columns:1fr 1fr}.split--reverse>.split__media{order:2}}
.split__media{position:relative}
.split__media img{border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow);border:1px solid var(--line-2)}
.split__media::before{content:"";position:absolute;inset:-14px -14px auto auto;width:64px;height:64px;border-top:2px solid var(--accent);border-right:2px solid var(--accent);border-radius:0 var(--radius-lg) 0 0;opacity:.6}
/* homepage photo swap 2026-06-22: arms-folded portrait now in hero, leaping cutout now in About split */
.hero__photo--framed img{border-radius:var(--radius-lg);border:1px solid var(--line-2)}
.split__media--cutout{display:flex;justify-content:center}
.split__media--cutout::before{display:none}
.split__media--cutout img{width:auto;max-width:100%;max-height:540px;border:0;box-shadow:none;border-radius:0;filter:drop-shadow(0 26px 44px rgba(0,0,0,.6))}
.split__body h2{margin-bottom:.4em}

/* ---------- Pricing ---------- */
.pricing{display:grid;gap:24px;grid-template-columns:1fr}
@media (min-width:860px){.pricing{grid-template-columns:repeat(3,1fr);align-items:center}}
.price{
  background:linear-gradient(170deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:34px 28px;position:relative;display:flex;flex-direction:column;gap:8px;transition:transform .25s var(--ease),border-color .25s;
}
.price:hover{transform:translateY(-5px);border-color:var(--line-2)}
.price--featured{border-color:transparent;background:linear-gradient(170deg,var(--surface-3),var(--surface));
  box-shadow:0 0 0 1.5px var(--accent),0 40px 90px -34px var(--accent-glow);}
@media (min-width:860px){.price--featured{transform:scale(1.05)}.price--featured:hover{transform:scale(1.05) translateY(-5px)}}
.price__tag{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--accent-3),var(--accent-2));color:#04230a;font:800 11px/1 'Inter',sans-serif;letter-spacing:.13em;text-transform:uppercase;padding:8px 16px;border-radius:var(--radius-pill);white-space:nowrap;box-shadow:0 8px 20px -8px var(--accent-glow)}
.price__name{font:800 13px/1 'Inter',sans-serif;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-3)}
.price__fig{font:900 clamp(50px,9vw,64px)/1 'Barlow Condensed',sans-serif;color:var(--ink);display:flex;align-items:baseline;gap:4px}
.price__fig small{font-size:24px;color:var(--mute);font-weight:700}
.price__per{color:var(--mute);font-size:14px;margin-bottom:4px}
.price__total{font:800 14px/1 'Inter',sans-serif;color:var(--accent-3)}
.price ul{display:flex;flex-direction:column;gap:12px;margin:20px 0 26px}
.price li{display:flex;gap:11px;align-items:flex-start;color:var(--ink-2);font-size:15px}
.price li .ico{width:19px;height:19px;color:var(--accent-3);margin-top:1px}
.price .btn{margin-top:auto}

/* ---------- Checklist tiles ---------- */
.checks{display:grid;gap:16px;grid-template-columns:1fr}
@media (min-width:680px){.checks{grid-template-columns:1fr 1fr}}
@media (min-width:980px){.checks{grid-template-columns:repeat(3,1fr)}}
.check{display:flex;gap:16px;align-items:flex-start;background:linear-gradient(165deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:var(--radius);padding:22px;transition:transform .2s,border-color .2s}
.check:hover{transform:translateY(-3px);border-color:var(--line-2)}
.check__i{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:var(--accent-soft);color:var(--accent-3);flex:none}
.check__i .ico{width:22px;height:22px}
.check h4{margin:0 0 .25em}
.check p{margin:0;color:var(--mute);font-size:14px}

/* ---------- Testimonials ---------- */
.reviews{display:grid;gap:22px;grid-template-columns:1fr}
@media (min-width:720px){.reviews{grid-template-columns:1fr 1fr}}
@media (min-width:1000px){.reviews{grid-template-columns:repeat(3,1fr)}}
.review{background:linear-gradient(165deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;display:flex;flex-direction:column;gap:15px;position:relative;transition:transform .2s,border-color .2s}
.review:hover{transform:translateY(-4px);border-color:var(--line-2)}
.review::before{content:"\201C";position:absolute;top:6px;right:22px;font:900 88px/1 'Barlow Condensed';color:var(--accent);opacity:.13}
.review__stars{color:var(--gold);letter-spacing:3px;font-size:15px}
.review p{color:var(--ink-2);margin:0;font-size:15.5px;line-height:1.62;position:relative;z-index:1}
.review__who{display:flex;align-items:center;gap:14px;margin-top:auto}
.review__who img{width:92px;height:92px;border-radius:50%;object-fit:cover;flex:none;border:2px solid var(--line-2)}
.review__photo{position:relative;z-index:1;width:100%;aspect-ratio:4/3;object-fit:cover;object-position:center 22%;border-radius:14px;border:1px solid var(--line-2);margin-bottom:4px;display:block}
.review__ini{width:92px;height:92px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;
  font:900 23px/1 'Barlow Condensed',sans-serif;letter-spacing:.04em;color:var(--accent-3);
  background:var(--accent-soft);border:2px solid color-mix(in srgb,var(--accent) 34%,transparent)}
.review__name{font-weight:700;font-size:15px}
.review__tag{font-size:12px;color:var(--mute);display:flex;align-items:center;gap:5px}
.review__tag .ico{width:13px;height:13px;color:var(--accent-3)}
.rating-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:12px 26px;margin-bottom:40px;color:var(--ink-2);font-weight:600}
.rating-bar span{display:inline-flex;align-items:center;gap:8px}
.rating-bar b{color:var(--gold);font-size:18px;font-family:'Barlow Condensed';font-weight:900}

/* ---------- Awards (medallion) ---------- */
.awards{display:grid;gap:18px;grid-template-columns:1fr 1fr}
@media (min-width:760px){.awards{grid-template-columns:repeat(3,1fr)}}
.award{background:linear-gradient(165deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px 18px;text-align:center;transition:transform .25s var(--ease),border-color .25s}
.award:hover{transform:translateY(-5px);border-color:rgba(245,197,24,.4)}
.award__medal{width:60px;height:60px;margin:0 auto 14px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 35% 30%,rgba(245,197,24,.25),rgba(245,197,24,.05));border:1px solid rgba(245,197,24,.4);color:var(--gold)}
.award__medal .ico{width:28px;height:28px}
.award h4{margin:0 0 4px;font-size:16px;color:var(--ink)}
.award span{font-size:12.5px;color:var(--mute)}

/* badge strip (real award imagery) */
.badge-strip{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(20px,5vw,52px);opacity:.92}
.badge-strip img{height:clamp(64px,11vw,92px);width:auto;filter:drop-shadow(0 10px 24px rgba(0,0,0,.5))}

/* ---------- FAQ ---------- */
.faq{max-width:840px;margin:0 auto;display:flex;flex-direction:column;gap:13px}
.faq details{background:linear-gradient(165deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:border-color .2s}
.faq details[open]{border-color:var(--line-2)}
.faq summary{list-style:none;cursor:pointer;padding:21px 24px;font:800 17px/1.35 'Inter',sans-serif;display:flex;justify-content:space-between;gap:16px;align-items:center;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"";width:13px;height:13px;flex:none;border-right:2.4px solid var(--accent-3);border-bottom:2.4px solid var(--accent-3);transform:rotate(45deg);transition:transform .25s var(--ease);margin-top:-4px}
.faq details[open] summary::after{transform:rotate(-135deg);margin-top:4px}
.faq .faq__a{padding:0 24px 22px;color:var(--ink-2);font-size:15.5px;line-height:1.68}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;border-radius:var(--radius-lg);
  background:linear-gradient(135deg,var(--accent-2),#176a26);text-align:center;border:1px solid rgba(255,255,255,.1)}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 120% at 80% 0%,rgba(255,255,255,.18),transparent 60%);pointer-events:none}
.cta-band .container{padding-block:clamp(46px,7vw,78px);position:relative}
.cta-band h2{color:#fff}
.cta-band p{color:rgba(255,255,255,.92);max-width:60ch;margin:0 auto 28px}

/* explore-more */
.explore{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.explore a{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-pill);padding:12px 22px;font-weight:700;font-size:14px;color:var(--ink-2);transition:.2s}
.explore a .ico{width:16px;height:16px;color:var(--accent-3)}
.explore a:hover{border-color:var(--accent);color:var(--ink);transform:translateY(-2px)}

/* ---------- Forms ---------- */
.form{display:grid;gap:17px}
.field label{display:block;font-weight:700;font-size:14px;margin-bottom:7px;color:var(--ink-2)}
.field input,.field textarea,.field select{
  width:100%;background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius-sm);
  padding:15px 16px;color:var(--ink);font:inherit;font-size:16px;transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.field textarea{min-height:150px;resize:vertical}

.contact-list{display:grid;gap:14px}
.contact-item{display:flex;gap:15px;background:linear-gradient(165deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:var(--radius);padding:20px;transition:border-color .2s}
.contact-item:hover{border-color:var(--line-2)}
.contact-item__i{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:var(--accent-soft);color:var(--accent-3);flex:none}
.contact-item__i .ico{width:22px;height:22px}
.contact-item h4{margin:0 0 3px;font-size:15px}
.contact-item p{margin:0;color:var(--ink-2);font-size:15px}
.contact-item a{color:var(--accent-3)}

/* ---------- Footer ---------- */
.footer{background:var(--bg-2);border-top:1px solid var(--line);padding:clamp(52px,7vw,76px) 0 30px;position:relative}
.footer::before{content:"";position:absolute;top:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.5}
.footer__grid{display:grid;gap:34px;grid-template-columns:1fr}
@media (min-width:760px){.footer__grid{grid-template-columns:1.5fr 1fr 1fr}}
.footer__brand .nav__logo{margin-bottom:14px}
.footer p{color:var(--mute);font-size:14.5px}
.footer h5{font:800 12px/1 'Inter';letter-spacing:.18em;text-transform:uppercase;color:var(--ink);margin:0 0 18px}
.footer__links{display:flex;flex-direction:column;gap:11px}
.footer__links a{color:var(--ink-2);font-size:14.5px;transition:color .15s,padding .2s}
.footer__links a:hover{color:var(--accent-3);padding-left:4px}
.footer__bottom{margin-top:44px;padding-top:24px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;color:var(--mute);font-size:13px}
.footer__social{display:flex;gap:10px}
.footer__social a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:11px;border:1px solid var(--line);color:var(--ink-2);transition:.2s}
.footer__social a:hover{border-color:var(--accent);color:var(--accent-3);transform:translateY(-2px)}
.footer__social .ico{width:18px;height:18px}

/* newsletter */
.newsletter{background:linear-gradient(165deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(30px,5vw,46px);text-align:center}
.newsletter form{display:flex;flex-wrap:wrap;gap:12px;max-width:480px;margin:18px auto 0}
.newsletter input{flex:1;min-width:200px}
.hp{position:absolute;left:-9999px}

/* utilities */
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.maxw-prose{max-width:70ch}.maxw-prose p{color:var(--ink-2)}
.pill-row{display:flex;flex-wrap:wrap;gap:11px;justify-content:center;margin-top:10px}
.pill{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-pill);padding:10px 18px;font-size:13.5px;color:var(--ink-2);font-weight:600}
.pill .ico{width:16px;height:16px;color:var(--accent-3)}
.prose h2{margin-top:1.4em}.prose h3{margin-top:1.2em;color:var(--ink)}
.prose ul{display:flex;flex-direction:column;gap:11px;margin:1em 0}
.prose ul li{position:relative;padding-left:30px;color:var(--ink-2)}
.prose ul li::before{content:"";position:absolute;left:4px;top:8px;width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent-glow)}

/* reveal-on-scroll */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}.ribbon__track{animation:none}.wa-fab{animation:none}}

/* ---------- A11y: visible focus + skip link ---------- */
:focus-visible{outline:2.5px solid var(--accent-3);outline-offset:3px;border-radius:4px}
.btn:focus-visible{outline-offset:4px}
section:focus{outline:none}
.skip-link{position:fixed;top:-60px;left:12px;z-index:400;background:var(--accent);color:#04230a;
  font:800 14px/1 'Inter',sans-serif;padding:12px 18px;border-radius:0 0 10px 10px;transition:top .2s var(--ease)}
.skip-link:focus{top:0}

/* ---------- Floating WhatsApp FAB ---------- */
.wa-fab{position:fixed;right:18px;bottom:18px;z-index:180;display:inline-flex;align-items:center;gap:0;
  width:58px;height:58px;border-radius:50%;background:#25d366;color:#fff;justify-content:center;
  box-shadow:0 12px 30px -8px rgba(37,211,102,.6),0 4px 12px rgba(0,0,0,.4);
  transition:width .28s var(--ease),border-radius .28s var(--ease),transform .2s;overflow:hidden;
  animation:wa-pop .5s var(--ease) .6s both}
.wa-fab svg{flex:none}
.wa-fab__tip{white-space:nowrap;font:800 14.5px/1 'Inter',sans-serif;max-width:0;opacity:0;transition:max-width .28s var(--ease),opacity .2s,margin .28s}
.wa-fab:hover,.wa-fab:focus-visible{width:202px;border-radius:var(--radius-pill);padding:0 22px;gap:11px}
.wa-fab:hover .wa-fab__tip,.wa-fab:focus-visible .wa-fab__tip{max-width:150px;opacity:1}
.wa-fab:active{transform:scale(.96)}
@keyframes wa-pop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
@media (max-width:600px){.wa-fab{right:14px;bottom:14px}}

/* ---------- Contact form status ---------- */
.form-status{padding:14px 18px;border-radius:var(--radius-sm);font-weight:600;font-size:15px;line-height:1.5}
.form-status--ok{background:var(--accent-soft);border:1px solid color-mix(in srgb,var(--accent) 40%,transparent);color:var(--accent-3)}
.form-status--err{background:rgba(220,80,80,.1);border:1px solid rgba(220,80,80,.4);color:#ff9b9b}

/* ===================== Premium polish pass — 2026-06-21 ===================== */
/* Gold award medallions (homepage "The Best in the UK") */
.award__medal{width:62px;height:62px;margin:0 auto 16px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 36% 30%,#fce98f,#f5c518 46%,#a9760a);
  box-shadow:0 8px 22px rgba(245,197,24,.26),inset 0 1px 2px rgba(255,255,255,.65);
  border:1px solid rgba(255,255,255,.28)}
.award__medal .ico{width:30px;height:30px;color:#231803}
.award{position:relative;overflow:hidden}
.award::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 70% at 50% -10%,rgba(245,197,24,.12),transparent 62%);opacity:0;transition:opacity .3s}
.award:hover::after{opacity:1}
.award:hover{transform:translateY(-6px)}

/* Tactile lift + depth on cards & review cards sitewide */
.card{transition:transform .28s var(--ease),border-color .28s,box-shadow .28s}
.card:hover{box-shadow:0 20px 44px rgba(0,0,0,.38)}
.review{transition:transform .28s var(--ease),border-color .28s,box-shadow .28s}
.review:hover{transform:translateY(-4px);border-color:var(--accent-glow);box-shadow:0 18px 40px rgba(0,0,0,.32)}

/* About SME award badge — soft gold halo so the dark seal lifts off the page */
img[src*="sme-award-2024"]{filter:drop-shadow(0 0 34px rgba(245,197,24,.20)) drop-shadow(0 18px 42px rgba(0,0,0,.55))!important}

/* Kicker labels — leading accent tick for a sharper editorial feel */
.kicker{position:relative}
/* Mobile hero declutter — hide floating badges over the photo (stats band repeats them) */
@media (max-width:600px){ .float-badge{display:none!important} .hero__photo img{filter:drop-shadow(0 16px 30px rgba(0,0,0,.55))} }

/* Load solid like the old site — never hide content behind scroll animation */
.reveal{opacity:1!important;transform:none!important}

/* ===== Awards & Recognition — badge row + clickable certificate lightbox ===== */
.badge-row{display:flex;flex-wrap:wrap;gap:30px;justify-content:center;align-items:flex-start;margin:0 auto 48px;max-width:780px}
.badge-row figure{margin:0;width:190px;text-align:center}
.badge-row img{width:100%;max-width:170px;filter:drop-shadow(0 12px 26px rgba(0,0,0,.5))}
.badge-row figcaption{margin-top:12px;font:700 11px/1.35 'Inter',sans-serif;letter-spacing:.06em;text-transform:uppercase;color:var(--mute)}
.cert-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:20px;max-width:1000px;margin:0 auto}
.cert-grid a{display:block;border-radius:12px;overflow:hidden;border:1px solid rgba(245,197,24,.22);box-shadow:0 16px 40px rgba(0,0,0,.42);background:#f4f6f8;transition:transform .25s,box-shadow .25s;cursor:zoom-in}
.cert-grid a:hover{transform:translateY(-5px);box-shadow:0 26px 60px rgba(0,0,0,.55)}
.cert-grid img{width:100%;display:block}
.cert-grid figcaption{padding:12px 15px;font:700 11px/1.45 'Inter',sans-serif;letter-spacing:.03em;text-transform:uppercase;color:var(--accent-3);background:var(--surface)}
.lb{position:fixed;inset:0;background:rgba(5,8,12,.93);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s;z-index:9999;padding:24px}
.lb:target{opacity:1;pointer-events:auto}
.lb img{max-width:94vw;max-height:88vh;border-radius:8px;box-shadow:0 30px 90px rgba(0,0,0,.7);position:relative}
.lb__bg{position:absolute;inset:0;cursor:zoom-out}
.lb__close{position:absolute;top:16px;right:26px;font:300 42px/1 system-ui,sans-serif;color:#fff;text-decoration:none;line-height:1}

/* Results gallery masonry — no empty cells */
.results-masonry{columns:1;column-gap:22px}
@media(min-width:640px){.results-masonry{columns:2}}
@media(min-width:1000px){.results-masonry{columns:3}}
.results-masonry .card{break-inside:avoid;margin:0 0 22px;display:inline-block;width:100%}
