:root{
  --bg:#fff;
  --ink:#0b1220;
  --muted:rgba(11,18,32,.70);
  --line:rgba(11,18,32,.10);

  --y:#facc15;
  --y2:#fde047;

  --r-xl:22px;
  --r-lg:18px;
  --r-md:14px;

  --shadow:0 18px 50px rgba(11,18,32,.12);
  --shadow2:0 10px 28px rgba(11,18,32,.10);

  --container:1160px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial;
  background:var(--bg);
  color:var(--ink);
  overflow-x:hidden;
}

.container{width:min(92%,var(--container));margin:0 auto}

/* Header */
.header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:box-shadow .2s ease,border-color .2s ease;
}
.header.is-scrolled{box-shadow:0 10px 30px rgba(11,18,32,.06);border-bottom-color:var(--line)}
.header__inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0}

.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink);font-weight:950}
.brand__mark{
  width:38px;height:38px;border-radius:14px;
  background:radial-gradient(circle at 30% 30%,var(--y2),var(--y));
  box-shadow:0 14px 26px rgba(250,204,21,.25);
}
.brand__name{font-size:16px}

.nav{display:flex;align-items:center;gap:18px}
.nav a{color:rgba(11,18,32,.78);text-decoration:none;font-weight:850;font-size:14px}
.nav a:hover{color:var(--ink)}

.menuBtn{
  display:none;width:44px;height:44px;border-radius:14px;
  border:1px solid var(--line);background:rgba(255,255,255,.90);cursor:pointer;
}
.menuBtn span{display:block;height:2px;width:20px;background:rgba(11,18,32,.75);margin:5px auto;border-radius:2px}

/* Buttons */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:12px 16px;border-radius:999px;text-decoration:none;font-weight:950;font-size:14px;
  border:1px solid var(--line);
  transition:transform .15s ease,box-shadow .15s ease,background .2s ease,border-color .2s ease;
  user-select:none;
}
.btn:active{transform:translateY(1px) scale(.99)}
.btn--small{padding:10px 14px;font-size:13px}
.btn--wide{width:100%}

.btn--primary{
  color:#1a1404;
  background:linear-gradient(135deg,var(--y2),var(--y));
  border-color:rgba(250,204,21,.55);
  box-shadow:0 18px 45px rgba(250,204,21,.22),0 16px 45px rgba(11,18,32,.10);
}
.btn--primary:hover{transform:translateY(-1px);box-shadow:0 24px 60px rgba(250,204,21,.28),0 18px 55px rgba(11,18,32,.12)}
.btn--ghost{color:var(--ink);background:rgba(255,255,255,.94)}
.btn--ghost:hover{transform:translateY(-1px);box-shadow:var(--shadow2);border-color:rgba(11,18,32,.16)}

.btn__shine{
  position:absolute;inset:-2px;border-radius:999px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);
  transform:translateX(-120%);opacity:0;
}
.btn--primary:hover .btn__shine{opacity:1;animation:shine 1.1s ease}
@keyframes shine{0%{transform:translateX(-120%)}100%{transform:translateX(120%)}}

/* Hero */
.hero{position:relative;min-height:74vh;display:flex;align-items:center;padding:70px 0 40px}
.hero__bg{
  position:absolute;inset:0;
  background-image:url("https://images.unsplash.com/photo-1502005229762-cf1b2da7c5d6?auto=format&fit=crop&w=2400&q=80");
  background-size:cover;background-position:center;
  filter:saturate(1.05) contrast(1.02);
  transform:scale(1.02);
}
.hero__overlay{
  position:absolute;inset:0;
  background:
    radial-gradient(1200px 600px at 18% 30%, rgba(255,255,255,.94), rgba(255,255,255,.78) 45%, rgba(255,255,255,.62) 70%),
    linear-gradient(to bottom, rgba(255,255,255,.92), rgba(255,255,255,.82));
}
.hero__inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:center;
}
.pill{
  display:inline-flex;align-items:center;gap:10px;padding:9px 12px;border-radius:999px;
  background:rgba(255,255,255,.90);border:1px solid rgba(11,18,32,.10);
  color:rgba(11,18,32,.78);font-weight:900;font-size:13px;box-shadow:0 10px 26px rgba(11,18,32,.08);
}
.pill__spark{width:10px;height:10px;border-radius:999px;background:linear-gradient(135deg,var(--y2),var(--y));box-shadow:0 0 0 7px rgba(250,204,21,.18)}

.hero h1{margin:14px 0 10px;font-size:clamp(38px,4.2vw,60px);line-height:1.03;letter-spacing:-0.03em}
.hl{background:linear-gradient(135deg,var(--y2),var(--y));-webkit-background-clip:text;background-clip:text;color:transparent}
.lead{margin:0 0 18px;color:rgba(11,18,32,.72);font-size:16.5px;max-width:60ch}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}

.trustRow{
  margin-top:20px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;max-width:680px;
}
.trustItem{
  padding:12px;border-radius:16px;
  background:rgba(255,255,255,.90);
  border:1px solid rgba(11,18,32,.10);
  box-shadow:0 12px 32px rgba(11,18,32,.08);
}
.trustTop{font-weight:980}
.trustSub{margin-top:2px;color:rgba(11,18,32,.66);font-weight:800;font-size:12px}

.heroCard{
  width:min(520px,100%);
  padding:18px;border-radius:var(--r-xl);
  background:rgba(255,255,255,.92);
  border:1px solid rgba(11,18,32,.10);
  box-shadow:var(--shadow);
}
.heroCard__top{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.badge{
  font-weight:980;font-size:12px;padding:8px 10px;border-radius:999px;
  background:rgba(11,18,32,.05);border:1px solid rgba(11,18,32,.10);
}
.badge--yellow{background:rgba(250,204,21,.25);border-color:rgba(250,204,21,.45)}
.heroCard h3{margin:6px 0 6px;font-size:18px;letter-spacing:-.01em}
.heroCard p{margin:0 0 14px;color:rgba(11,18,32,.70);font-weight:700}

.heroEstimate{
  display:flex;align-items:flex-end;justify-content:space-between;gap:12px;
  padding:14px;border-radius:var(--r-xl);
  border:1px solid rgba(250,204,21,.45);
  background:linear-gradient(to bottom, rgba(250,204,21,.16), #fff);
}
.heroEstimate__label{font-weight:980}
.heroEstimate__sub{color:rgba(11,18,32,.66);font-weight:700;font-size:12.5px;margin-top:2px}
.heroEstimate__price{font-weight:980;font-size:40px;letter-spacing:-0.03em;line-height:1}
.heroEstimate__meta{margin:10px 0 12px;color:rgba(11,18,32,.72);font-weight:900;font-size:13px}
.micro{margin-top:10px;color:rgba(11,18,32,.58);font-weight:750;font-size:12.5px}

/* Sections */
.section{padding:78px 0}
.section--soft{
  background:linear-gradient(to bottom, rgba(11,18,32,.02), rgba(11,18,32,.03));
  border-top:1px solid rgba(11,18,32,.06);
  border-bottom:1px solid rgba(11,18,32,.06);
}
.sectionHead{text-align:center;max-width:72ch;margin:0 auto 26px}
.sectionHead h2{margin:0 0 8px;font-size:clamp(28px,3.2vw,42px);letter-spacing:-0.02em}
.sectionHead p{margin:0;color:var(--muted);font-weight:700}

/* Cards */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.card{
  padding:18px;border-radius:var(--r-xl);
  background:#fff;border:1px solid rgba(11,18,32,.08);
  box-shadow:var(--shadow2);
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:rgba(11,18,32,.14)}
.cardTop{display:flex;align-items:center;gap:10px}
.icon{
  width:40px;height:40px;border-radius:16px;display:grid;place-items:center;
  background:rgba(11,18,32,.04);border:1px solid rgba(11,18,32,.08);
}
.icon--yellow{background:rgba(250,204,21,.30);border-color:rgba(250,204,21,.45)}
.card h3{margin:0;font-size:16.5px}
.card p{margin:10px 0 12px;color:rgba(11,18,32,.70);font-weight:700}
.list{margin:0;padding-left:18px;color:rgba(11,18,32,.82)}
.list li{margin:7px 0;font-weight:650}

/* Pricing */
.toggleRow{display:flex;justify-content:center;align-items:center;gap:12px;flex-wrap:wrap;margin:10px 0 18px}
.toggleLabel{font-weight:950;color:rgba(11,18,32,.78)}
.savePill{font-weight:980;font-size:12px;padding:8px 10px;border-radius:999px;background:rgba(250,204,21,.25);border:1px solid rgba(250,204,21,.40)}
.toggle{
  width:54px;height:32px;border-radius:999px;border:1px solid rgba(11,18,32,.12);
  background:rgba(11,18,32,.05);position:relative;cursor:pointer;
}
.toggle[aria-pressed="true"]{background:rgba(250,204,21,.35);border-color:rgba(250,204,21,.55)}
.toggle__knob{
  position:absolute;top:50%;left:6px;transform:translateY(-50%);
  width:22px;height:22px;border-radius:999px;background:#fff;box-shadow:0 12px 24px rgba(11,18,32,.10);
  transition:left .18s ease;
}
.toggle[aria-pressed="true"] .toggle__knob{left:26px}

.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.priceCard{
  padding:18px;border-radius:var(--r-xl);background:#fff;border:1px solid rgba(11,18,32,.08);
  box-shadow:var(--shadow2);position:relative;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;
}
.priceCard:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:rgba(11,18,32,.14)}
.priceCard--featured{
  border-color:rgba(250,204,21,.55);
  box-shadow:0 22px 60px rgba(250,204,21,.18), var(--shadow2);
  transform:translateY(-6px);
}
.priceCard--featured:hover{transform:translateY(-8px)}
.ribbon{
  position:absolute;top:14px;right:14px;
  font-weight:980;font-size:12px;padding:8px 10px;border-radius:999px;
  background:linear-gradient(135deg,var(--y2),var(--y));
  border:1px solid rgba(250,204,21,.55);color:#1a1404;
}
.priceHead h3{margin:0 0 6px;font-size:18px}
.priceHead p{margin:0 0 12px;color:rgba(11,18,32,.70);font-weight:700}
.price{display:flex;align-items:flex-end;gap:8px;margin:12px 0}
.cur{font-weight:980;font-size:16px;margin-bottom:6px}
.val{font-weight:990;font-size:44px;letter-spacing:-.03em}
.suf{color:rgba(11,18,32,.62);font-weight:850;margin-bottom:8px}
.ticks{list-style:none;padding:0;margin:0 0 14px}
.ticks li{display:flex;gap:10px;align-items:flex-start;margin:8px 0;font-weight:700;color:rgba(11,18,32,.80)}
.ticks li::before{
  content:"";width:10px;height:10px;border-radius:999px;margin-top:5px;
  background:linear-gradient(135deg,var(--y2),var(--y));
  box-shadow:0 0 0 6px rgba(250,204,21,.14);
  flex:0 0 auto;
}

/* Booking */
.bookingGrid{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start}
.panel{
  padding:18px;border-radius:var(--r-xl);background:#fff;border:1px solid rgba(11,18,32,.08);
  box-shadow:var(--shadow2);
}
.panelHead h3{margin:0 0 6px;font-size:18px}
.panelHead p{margin:0 0 14px;color:rgba(11,18,32,.70);font-weight:700}
.label{font-weight:950;font-size:13px;color:rgba(11,18,32,.86);margin-bottom:8px}
.input{
  width:100%;padding:12px 12px;border-radius:14px;border:1px solid rgba(11,18,32,.12);background:#fff;outline:none;
}
.input:focus{border-color:rgba(250,204,21,.55);box-shadow:0 0 0 7px rgba(250,204,21,.20)}

.segRow{margin-bottom:14px}
.seg{display:flex;gap:10px;flex-wrap:wrap}
.segBtn{
  padding:10px 12px;border-radius:999px;border:1px solid rgba(11,18,32,.12);
  background:rgba(11,18,32,.03);font-weight:950;cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
}
.segBtn:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(11,18,32,.08)}
.segBtn.isActive{background:rgba(250,204,21,.25);border-color:rgba(250,204,21,.55)}

.addons{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:6px}
.addon{
  display:flex;align-items:center;gap:10px;padding:12px;border-radius:16px;
  border:1px solid rgba(11,18,32,.10);background:rgba(11,18,32,.02);cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease;
}
.addon:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(11,18,32,.08)}
.addon input{position:absolute;opacity:0;pointer-events:none}
.box{
  width:18px;height:18px;border-radius:6px;border:1px solid rgba(11,18,32,.22);background:#fff;position:relative;
}
.addon input:checked + .box{border-color:rgba(250,204,21,.70);box-shadow:0 0 0 6px rgba(250,204,21,.20)}
.addon input:checked + .box::after{
  content:"";position:absolute;inset:0;margin:auto;width:10px;height:10px;border-radius:4px;
  background:linear-gradient(135deg,var(--y2),var(--y));
}
.addon span{display:flex;justify-content:space-between;width:100%;font-weight:900;color:rgba(11,18,32,.86)}
.addon em{font-style:normal;font-weight:980;color:rgba(11,18,32,.70)}

.estimateBar{
  margin-top:14px;
  display:flex;justify-content:space-between;align-items:flex-end;gap:12px;
  padding:14px;border-radius:var(--r-xl);border:1px solid rgba(250,204,21,.45);
  background:linear-gradient(to bottom, rgba(250,204,21,.16), #fff);
}
.estimateLabel{font-weight:980}
.estimateSub{color:rgba(11,18,32,.66);font-weight:700;font-size:12.5px;margin-top:2px}
.estimatePrice{font-weight:990;font-size:40px;letter-spacing:-0.03em;line-height:1}
.estimateMeta{margin-top:10px;color:rgba(11,18,32,.72);font-weight:900;font-size:13px}

.postcode{margin-bottom:16px}
.postcodeRow{display:grid;grid-template-columns:1fr 160px;gap:10px;align-items:center}
.postcodeResult{
  margin-top:10px;padding:12px;border-radius:16px;border:1px solid rgba(11,18,32,.10);background:rgba(11,18,32,.02);
  font-weight:900;color:rgba(11,18,32,.80);
}
.postcodeResult.ok{border-color:rgba(250,204,21,.55);background:rgba(250,204,21,.18)}
.postcodeResult.bad{border-color:rgba(11,18,32,.18);background:rgba(11,18,32,.03)}

.slotTop{display:grid;grid-template-columns:110px 1fr 180px;gap:10px;align-items:center;margin-top:10px}
.slots{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}
.slot{
  padding:12px;border-radius:16px;border:1px solid rgba(11,18,32,.10);background:rgba(11,18,32,.02);
  font-weight:950;cursor:pointer;text-align:center;
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease, background .15s ease;
}
.slot:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(11,18,32,.08)}
.slot.isSelected{border-color:rgba(250,204,21,.65);background:rgba(250,204,21,.22)}
.slot.isBusy{opacity:.45;cursor:not-allowed;text-decoration:line-through}
.slot .sub{margin-top:4px;font-weight:850;font-size:12px;color:rgba(11,18,32,.66)}

.summary{
  margin-top:12px;padding:14px;border-radius:var(--r-xl);border:1px solid rgba(11,18,32,.08);background:#fff;box-shadow:var(--shadow2);
}
.sumRow{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid rgba(11,18,32,.06);font-weight:900}
.sumRow:last-of-type{border-bottom:none}
.sumNote{margin-top:10px;color:rgba(11,18,32,.62);font-weight:750;font-size:12.5px}
.proofGrid{display:grid;grid-template-columns:1.05fr .95fr;gap:14px;align-items:start}

/* Before/After */
.baFrame{position:relative;border-radius:var(--r-xl);overflow:hidden;border:1px solid rgba(11,18,32,.08);box-shadow:var(--shadow2);background:#fff;min-height:430px}
.baImg{width:100%;height:430px;object-fit:cover;display:block}
.baAfter{position:absolute;inset:0;width:55%;overflow:hidden}
.baLine{position:absolute;top:0;bottom:0;left:55%;width:2px;background:rgba(255,255,255,.92);box-shadow:0 0 0 10px rgba(250,204,21,.18)}
.baRange{position:absolute;left:12px;right:12px;bottom:14px;width:calc(100% - 24px);accent-color:var(--y)}

/* Gallery */
.gallery{display:grid;grid-template-columns:1fr;gap:12px}
.shot{margin:0;border-radius:var(--r-xl);overflow:hidden;border:1px solid rgba(11,18,32,.08);background:#fff;box-shadow:var(--shadow2);transition:transform .18s ease, box-shadow .18s ease}
.shot:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.shot img{width:100%;height:198px;object-fit:cover;display:block}
.shot figcaption{display:flex;align-items:center;gap:10px;padding:12px 14px;font-weight:950}
.tag{font-size:12px;padding:7px 10px;border-radius:999px;background:rgba(11,18,32,.05);border:1px solid rgba(11,18,32,.10)}
.tag--yellow{background:rgba(250,204,21,.25);border-color:rgba(250,204,21,.45)}

/* Reviews */
.reviewWrap{display:grid;grid-template-columns:44px 1fr 44px;gap:12px;align-items:center}
.arrow{
  width:44px;height:44px;border-radius:14px;border:1px solid rgba(11,18,32,.10);
  background:#fff;box-shadow:var(--shadow2);font-weight:990;font-size:22px;cursor:pointer;
}
.arrow:hover{transform:translateY(-1px);box-shadow:var(--shadow)}
.reviewTrack{display:flex;gap:12px;overflow:hidden;scroll-behavior:smooth}
.review{
  min-width:min(520px,100%);
  padding:18px;border-radius:var(--r-xl);background:#fff;border:1px solid rgba(11,18,32,.08);box-shadow:var(--shadow2);
}
.stars{color:#d4a100;letter-spacing:2px;font-weight:980}
.review p{margin:10px 0 14px;color:rgba(11,18,32,.74);font-weight:750}
.meta{display:flex;gap:10px;align-items:center}
.avatar{width:40px;height:40px;border-radius:16px;background:rgba(11,18,32,.06);border:1px solid rgba(11,18,32,.10)}
.avatar--yellow{background:rgba(250,204,21,.25);border-color:rgba(250,204,21,.45)}
.name{font-weight:980}
.sub{color:rgba(11,18,32,.62);font-weight:850;font-size:13px}

/* FAQ */
.faq{max-width:860px;margin:0 auto}
.faqItem{border-radius:var(--r-xl);background:#fff;border:1px solid rgba(11,18,32,.08);box-shadow:var(--shadow2);overflow:hidden}
.faqItem + .faqItem{margin-top:12px}
.faqQ{
  width:100%;text-align:left;padding:16px;border:none;background:transparent;cursor:pointer;
  font-weight:980;display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.faqIcon{width:18px;height:18px;border-radius:6px;border:1px solid rgba(11,18,32,.18);position:relative}
.faqIcon::before,.faqIcon::after{content:"";position:absolute;inset:0;margin:auto;width:10px;height:2px;background:rgba(11,18,32,.75);border-radius:2px}
.faqIcon::after{width:2px;height:10px}
.faqItem.isOpen .faqIcon::after{opacity:0}
.faqA{height:0;overflow:hidden;transition:height .22s ease}
.faqInner{padding:0 16px 16px;color:rgba(11,18,32,.70);font-weight:700}

/* Contact */
.contact{
  background:
    radial-gradient(800px 380px at 20% 20%, rgba(250,204,21,.22), transparent 65%),
    radial-gradient(900px 420px at 85% 10%, rgba(11,18,32,.06), transparent 65%),
    #fff;
  border-top:1px solid rgba(11,18,32,.06);
}
.contactGrid{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start}
.contactCard{padding:18px;border-radius:var(--r-xl);background:#fff;border:1px solid rgba(11,18,32,.08);box-shadow:var(--shadow2)}
.contactCard h3{margin:0 0 6px}
.contactCard p{margin:0 0 12px;color:rgba(11,18,32,.70);font-weight:700}
.contactActions{display:grid;gap:10px;margin:10px 0 12px}
.chips{display:flex;gap:10px;flex-wrap:wrap}
.chip{padding:9px 12px;border-radius:999px;font-weight:950;font-size:13px;background:rgba(11,18,32,.05);border:1px solid rgba(11,18,32,.10)}
.chip--yellow{background:rgba(250,204,21,.25);border-color:rgba(250,204,21,.45)}

.form{padding:18px;border-radius:var(--r-xl);background:#fff;border:1px solid rgba(11,18,32,.08);box-shadow:var(--shadow2)}
.form label{display:block;font-weight:950;font-size:13px;color:rgba(11,18,32,.86)}
.form input,.form textarea,.form select{
  width:100%;margin-top:8px;padding:12px;border-radius:14px;border:1px solid rgba(11,18,32,.12);
  background:#fff;color:var(--ink);outline:none;transition:border-color .15s ease, box-shadow .15s ease;
}
.form input:focus,.form textarea:focus,.form select:focus{border-color:rgba(250,204,21,.55);box-shadow:0 0 0 7px rgba(250,204,21,.20)}
.formRow{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.formEnd{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px}
.status{margin:0;color:rgba(11,18,32,.70);font-weight:950;font-size:13px}
.fineprint{margin:12px 0 0;color:rgba(11,18,32,.58);font-size:12.5px;font-weight:750}

/* Footer */
.footer{padding:26px 0;border-top:1px solid rgba(11,18,32,.06);background:#fff}
.footerInner{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.footerP{margin:8px 0 0;color:rgba(11,18,32,.64);font-weight:700}
.footerLinks{display:flex;gap:14px;flex-wrap:wrap}
.footerLinks a{text-decoration:none;color:rgba(11,18,32,.70);font-weight:950;font-size:13px}
.footerLinks a:hover{color:var(--ink)}
.brand--footer .brand__mark{width:34px;height:34px}

/* Floating actions (minimal) */
.floatActions{position:fixed;right:14px;bottom:14px;display:grid;gap:10px;z-index:60}
.fab{
  width:56px;height:56px;border-radius:18px;display:grid;place-items:center;
  text-decoration:none;font-weight:990;font-size:12px;border:1px solid rgba(11,18,32,.10);
  background:#fff;box-shadow:var(--shadow2);cursor:pointer;transition:transform .15s ease, box-shadow .15s ease;color:var(--ink);
}
.fab:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.fab--yellow{background:linear-gradient(135deg,var(--y2),var(--y));border-color:rgba(250,204,21,.50);color:#1a1404}

/* Reveal */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .55s ease, transform .55s ease}
.reveal.isVisible{opacity:1;transform:translateY(0)}

/* Responsive */
@media (max-width:980px){
  .hero__inner{grid-template-columns:1fr}
  .trustRow{grid-template-columns:repeat(2,1fr);max-width:520px}
  .grid3{grid-template-columns:repeat(2,1fr)}
  .pricing{grid-template-columns:1fr}
  .priceCard--featured{transform:none}
  .bookingGrid{grid-template-columns:1fr}
  .proofGrid{grid-template-columns:1fr}
  .contactGrid{grid-template-columns:1fr}
  .slotTop{grid-template-columns:1fr}
  .slots{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:640px){
  .menuBtn{display:block}
  .nav{
    position:absolute;left:4%;right:4%;top:66px;display:none;flex-direction:column;padding:14px;border-radius:18px;
    background:rgba(255,255,255,.92);border:1px solid rgba(11,18,32,.10);box-shadow:var(--shadow2);
  }
  .nav.isOpen{display:flex}
  .grid3{grid-template-columns:1fr}
  .addons{grid-template-columns:1fr}
  .slots{grid-template-columns:1fr}
  .formRow{grid-template-columns:1fr}
  .formEnd{flex-direction:column;align-items:stretch}
  .reviewWrap{grid-template-columns:1fr}
  .arrow{display:none}
  .reviewTrack{overflow:auto;scroll-snap-type:x mandatory}
  .review{scroll-snap-align:start}
  .baImg{height:360px}
  .baFrame{min-height:360px}
  .postcodeRow{grid-template-columns:1fr}
}
