/* ============================================================
   Bins and Beyond Ltd — style.css
   "TRAJECTORY" — poster-led, full-bleed photographic.
   Yellow + ink navy, green eco accent. Clash Display + Satoshi.
   Overrides token VALUES from tokens.css; builds all components.
   ============================================================ */

/* ---- Fonts (self-hosted) ---------------------------------- */
@font-face{font-family:"Clash Display";font-weight:500;font-display:swap;
  src:url("/static/fonts/ClashDisplay-Medium.woff2") format("woff2");}
@font-face{font-family:"Clash Display";font-weight:600;font-display:swap;
  src:url("/static/fonts/ClashDisplay-Semibold.woff2") format("woff2");}
@font-face{font-family:"Clash Display";font-weight:700;font-display:swap;
  src:url("/static/fonts/ClashDisplay-Bold.woff2") format("woff2");}
@font-face{font-family:"Satoshi";font-weight:400;font-display:swap;
  src:url("/static/fonts/Satoshi-Regular.woff2") format("woff2");}
@font-face{font-family:"Satoshi";font-weight:500;font-display:swap;
  src:url("/static/fonts/Satoshi-Medium.woff2") format("woff2");}
@font-face{font-family:"Satoshi";font-weight:700;font-display:swap;
  src:url("/static/fonts/Satoshi-Bold.woff2") format("woff2");}

/* ---- Brand token overrides -------------------------------- */
:root{
  --paper:#F7F4ED; --paper-2:#EFE8D8; --paper-3:#E7DECB;
  --ink:#0E2030; --ink-2:#17324C;
  --brand:#0F3D6B;
  --accent:#F8C01A; --accent-2:#E3A700; --accent-ink:#1A1303;
  --green:#46A92B; --spray:#1F86B4;
  --line:#DED6C4; --muted:#5A6675;

  /* map kit names */
  --c-bg:var(--paper); --c-surface:#FFFFFF; --c-ink:var(--ink);
  --c-ink-soft:var(--muted); --c-line:var(--line);
  --c-brand:var(--brand); --c-accent:var(--accent); --c-accent-ink:var(--accent-ink);
  --f-display:"Clash Display","Arial Narrow",sans-serif;
  --f-text:"Satoshi",system-ui,sans-serif;

  --nav-h:74px;
  --shadow-card:0 1px 2px rgba(14,32,48,.05),0 14px 34px rgba(14,32,48,.10);
  --shadow-float:0 20px 50px rgba(14,32,48,.20);
}

body{font-weight:400;}
h1,h2,h3,h4{font-family:var(--f-display);font-weight:700;letter-spacing:-.015em;color:var(--ink);}
strong{font-weight:700;}
a{color:inherit;}
.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:.6rem 1rem;z-index:9999;border-radius:0 0 8px 0;}
.skip:focus{left:0;}

/* ---- Buttons ---------------------------------------------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--f-text);
  font-weight:700;font-size:var(--step-0);line-height:1;padding:1rem 1.5rem;
  border-radius:var(--r-pill);transition:transform var(--dur-fast) var(--ease-out-soft),
  background var(--dur-fast) var(--ease-out-soft),box-shadow var(--dur-fast) var(--ease-out-soft);
  white-space:nowrap;}
.ico{width:1.2em;height:1.2em;flex:none;}   /* sane default — every icon without a contextual size falls back here */
.btn .ico{width:1.15em;height:1.15em;}
.btn--accent{background:var(--accent);color:var(--accent-ink);box-shadow:0 8px 20px rgba(248,192,26,.35);}
.btn--accent:hover{background:var(--accent-2);transform:translateY(-2px);box-shadow:0 12px 26px rgba(248,192,26,.45);}
.btn--ink{background:var(--ink);color:#fff;}
.btn--ink:hover{background:var(--ink-2);transform:translateY(-2px);}
.btn--ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line);}
.btn--ghost:hover{box-shadow:inset 0 0 0 1.5px var(--ink);}
.btn--light{background:rgba(255,255,255,.12);color:#fff;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.4);}
.btn--light:hover{background:rgba(255,255,255,.2);}
.btn--sm{padding:.66rem 1.05rem;font-size:var(--step--1);}
.btn--lg{padding:1.15rem 1.9rem;font-size:var(--step-1);}

.linkarrow{display:inline-flex;align-items:center;gap:.45rem;font-weight:700;color:var(--brand);}
.linkarrow .ico{width:1.1em;height:1.1em;transition:transform var(--dur-fast) var(--ease-out-soft);}
.linkarrow:hover .ico{transform:translateX(4px);}

/* ---- Eyebrow / kicker ------------------------------------- */
.kicker{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--f-text);
  font-weight:700;font-size:var(--step--1);letter-spacing:.04em;color:var(--brand);
  text-transform:none;}
.kicker::before{content:"";width:28px;height:2px;background:var(--accent);border-radius:2px;}
.kicker--light{color:rgba(255,255,255,.85);}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:var(--z-nav);
  background:#fff;border-bottom:1px solid var(--line);
  transition:box-shadow var(--dur) var(--ease-out-soft);}
.nav__inner{display:flex;align-items:center;gap:1.5rem;height:var(--nav-h);}
.nav.is-stuck{background:#fff;box-shadow:0 6px 20px rgba(14,32,48,.08);}

.brand{display:inline-flex;align-items:center;gap:.55rem;}
.brand__logo{width:auto;height:34px;flex:none;}
.brand__mark{width:36px;height:36px;flex:none;}
.brand__text{font-family:var(--f-display);font-weight:600;font-size:1.18rem;line-height:1.05;
  letter-spacing:-.01em;color:var(--ink);white-space:nowrap;}
.brand__text b{font-weight:700;}
.brand__text i{font-style:normal;font-weight:600;font-size:.62em;color:var(--accent-2);
  vertical-align:.35em;margin-left:.25em;letter-spacing:.08em;}

.nav__links{display:flex;gap:1.6rem;margin-left:auto;}
.nav__links a{font-weight:500;font-size:var(--step-0);color:var(--ink);position:relative;padding:.2rem 0;}
.nav__links a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;
  background:var(--accent);transition:right var(--dur-fast) var(--ease-out-soft);}
.nav__links a:hover::after{right:0;}

.nav__cta{display:flex;align-items:center;gap:1rem;}
.tel{display:inline-flex;align-items:center;gap:.4rem;font-weight:700;color:var(--ink);}
.tel .ico{width:1.05em;height:1.05em;color:var(--accent-2);}
.nav__burger{display:none;width:44px;height:44px;align-items:center;justify-content:center;color:var(--ink);}
.nav__burger .ico{width:26px;height:26px;}
.nav__burger .is-close{display:none;}
.nav.is-open .nav__burger .is-menu{display:none;}
.nav.is-open .nav__burger .is-close{display:block;}

.nav__drawer{display:none;}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;
  padding-top:var(--nav-h);overflow:hidden;background:var(--ink);}
.hero__media{position:absolute;inset:0;z-index:0;}
.hero__media img{width:100%;height:100%;object-fit:cover;}
.hero__media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(14,32,48,.55) 0%,rgba(14,32,48,.12) 35%,rgba(14,32,48,.55) 72%,rgba(14,32,48,.93) 100%);}
.hero__inner{position:relative;z-index:2;padding-block:clamp(2.5rem,7vw,5.5rem);width:100%;}
.hero__kicker{color:#fff;margin-bottom:1.2rem;}
.hero h1{color:#fff;font-size:var(--step-5);line-height:.98;letter-spacing:-.025em;
  max-width:18ch;text-shadow:0 2px 30px rgba(14,32,48,.35);}
.hero h1 .out{-webkit-text-stroke:2px var(--accent);color:transparent;text-shadow:none;}
.hero h1 .ln{display:block;}
.hero h1 .ln--3{color:var(--accent);}
.hero__lede{color:rgba(255,255,255,.92);font-size:var(--step-1);max-width:46ch;
  margin-top:1.6rem;font-weight:400;}
.hero__actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem;align-items:center;}
.hero__trust{display:flex;flex-wrap:wrap;gap:1.1rem 1.6rem;margin-top:2.2rem;
  color:rgba(255,255,255,.9);font-weight:500;font-size:var(--step--1);}
.hero__trust span{display:inline-flex;align-items:center;gap:.45rem;}
.hero__trust .ico{width:1.15em;height:1.15em;color:var(--accent);}

/* trajectory line + rocket riding it */
.traj{position:fixed;left:max(18px,3vw);top:0;bottom:0;width:2px;z-index:5;pointer-events:none;
  background:linear-gradient(var(--spray),rgba(31,134,174,0));opacity:0;transition:opacity .6s;}
.traj.is-on{opacity:.5;}
.traj__rocket{position:absolute;left:50%;top:0;transform:translate(-50%,0);width:26px;height:26px;}
@media (max-width:920px){.traj{display:none;}}

/* ============================================================
   SECTION SHELLS
   ============================================================ */
.section{padding-block:var(--sp-2xl);}
.section--tight{padding-block:var(--sp-xl);}
.lead{font-size:var(--step-1);color:var(--ink-2);max-width:54ch;}
.sec-head{max-width:42rem;margin-bottom:var(--sp-l);}
.sec-head h2{font-size:var(--step-3);margin-top:.7rem;}
.sec-head p{margin-top:.9rem;color:var(--muted);font-size:var(--step-0);}
.center{text-align:center;margin-inline:auto;}
.center .kicker{justify-content:center;}

/* ============================================================
   TRANSFORMATION (honest before/after, one photo)
   ============================================================ */
.transform{position:relative;background:var(--ink);color:#fff;overflow:hidden;}
.transform__grid{display:grid;grid-template-columns:1fr 1.25fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center;}
.transform__copy .kicker{color:rgba(255,255,255,.8);}
.transform h2{color:#fff;font-size:var(--step-3);margin-top:.8rem;}
.transform__copy p{color:rgba(255,255,255,.82);margin-top:1rem;}
/* draggable before/after comparison slider */
.ba{position:relative;border-radius:var(--r-l);overflow:hidden;box-shadow:var(--shadow-float);
  aspect-ratio:4/3;touch-action:none;user-select:none;--clip:50%;cursor:ew-resize;}
.ba__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none;}
.ba__before{position:absolute;inset:0;clip-path:inset(0 calc(100% - var(--clip)) 0 0);}
.ba__handle{position:absolute;top:0;bottom:0;left:var(--clip);width:3px;
  background:var(--accent);transform:translateX(-50%);z-index:3;}
.ba__handle::before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:46px;height:46px;border-radius:50%;background:var(--accent);box-shadow:0 4px 16px rgba(14,32,48,.4);}
.ba__grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:4;
  color:var(--accent-ink);width:24px;height:24px;}
.ba__tag{position:absolute;bottom:1rem;font-family:var(--f-display);font-weight:700;z-index:2;
  font-size:var(--step--1);letter-spacing:.02em;padding:.35rem .8rem;border-radius:var(--r-pill);
  backdrop-filter:blur(4px);pointer-events:none;}
.ba__tag--before{left:1rem;background:rgba(14,32,48,.72);color:#fff;}
.ba__tag--after{right:1rem;background:var(--accent);color:var(--accent-ink);}
.ba__hint{position:absolute;top:1rem;left:50%;transform:translateX(-50%);z-index:2;
  background:rgba(14,32,48,.72);color:#fff;font-size:var(--step--1);font-weight:600;
  padding:.3rem .8rem;border-radius:var(--r-pill);pointer-events:none;
  transition:opacity var(--dur) var(--ease-out-soft);}
.ba.is-touched .ba__hint{opacity:0;}
.ba__handle:focus-visible{outline:3px solid #fff;outline-offset:2px;}
@media (max-width:760px){.transform__grid{grid-template-columns:1fr;}.ba{aspect-ratio:4/3;}}

/* ============================================================
   SERVICES — alternating photo+type rows ("trajectory" climb)
   ============================================================ */
.svc-row{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(1.5rem,5vw,4.5rem);
  align-items:center;padding-block:clamp(2rem,5vw,3.5rem);border-top:1px solid var(--line);}
.svc-row:first-of-type{border-top:0;}
.svc-row:nth-child(even) .svc-row__media{order:2;}
.svc-row__media{position:relative;border-radius:var(--r-l);overflow:hidden;aspect-ratio:4/3;
  box-shadow:var(--shadow-card);background:var(--paper-2);}
.svc-row__media img{width:100%;height:100%;object-fit:contain;}
.svc-row__media.ba .ba__img{object-fit:cover;}   /* before/after slider images must fill, not letterbox */
.svc-row__n{position:absolute;left:1rem;bottom:1rem;width:46px;height:46px;border-radius:12px;
  background:var(--paper);display:grid;place-items:center;color:var(--brand);box-shadow:var(--shadow-card);}
.svc-row__n .ico{width:24px;height:24px;}
.svc-row__copy h3{font-size:var(--step-2);}
.svc-row__copy p{margin-top:.7rem;color:var(--muted);}
.svc-row__copy .linkarrow{margin-top:1.1rem;}
@media (max-width:780px){
  .svc-row{grid-template-columns:1fr;gap:1.2rem;}
  .svc-row:nth-child(even) .svc-row__media{order:0;}
}

/* ============================================================
   BIN SUBSCRIPTION — yellow poster band
   ============================================================ */
.bins{background:var(--accent);color:var(--accent-ink);position:relative;overflow:hidden;}
.bins__grid{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center;}
.bins .kicker{color:var(--ink);}
.bins .kicker::before{background:var(--ink);}
.bins h2{color:var(--ink);font-size:var(--step-3);margin-top:.7rem;max-width:18ch;}
.bins p{color:#3a2f08;margin-top:1rem;max-width:48ch;font-weight:500;}
.bins__actions{display:flex;gap:.8rem;margin-top:1.6rem;flex-wrap:wrap;}
.price{text-align:center;background:var(--ink);color:#fff;border-radius:var(--r-l);
  padding:1.8rem 2.4rem;box-shadow:var(--shadow-float);}
.price__num{font-family:var(--f-display);font-weight:700;font-size:clamp(3.4rem,7vw,5rem);
  line-height:1;color:var(--accent);}
.price__unit{font-size:var(--step--1);color:rgba(255,255,255,.8);margin-top:.4rem;font-weight:500;}
.bins__chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.4rem;}
.chip{display:inline-flex;align-items:center;gap:.4rem;background:rgba(14,32,48,.1);
  color:var(--ink);font-weight:600;font-size:var(--step--1);padding:.4rem .8rem;border-radius:var(--r-pill);}
.chip .ico{width:1.05em;height:1.05em;}
@media (max-width:720px){.bins__grid{grid-template-columns:1fr;}.price{justify-self:start;}}

/* ============================================================
   COMMERCIAL — deep navy "and beyond" night-sky band
   ============================================================ */
.beyond{background:var(--ink);color:#fff;position:relative;overflow:hidden;
  background-image:radial-gradient(1px 1px at 20% 30%,rgba(255,255,255,.5),transparent),
    radial-gradient(1px 1px at 70% 20%,rgba(255,255,255,.35),transparent),
    radial-gradient(1.5px 1.5px at 40% 70%,rgba(255,255,255,.3),transparent),
    radial-gradient(1px 1px at 85% 60%,rgba(255,255,255,.4),transparent),
    radial-gradient(1px 1px at 55% 45%,rgba(255,255,255,.25),transparent);}
.beyond__grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(1.5rem,5vw,4rem);align-items:center;}
.beyond .kicker{color:var(--accent);}
.beyond .kicker::before{background:var(--accent);}
.beyond h2{color:#fff;font-size:var(--step-3);margin-top:.8rem;}
.beyond p{color:rgba(255,255,255,.82);margin-top:1rem;}
.beyond__actions{margin-top:1.8rem;display:flex;gap:.8rem;flex-wrap:wrap;}
.assure{display:grid;gap:.9rem;}
.assure li{display:flex;gap:.85rem;align-items:flex-start;list-style:none;
  padding:1rem 1.2rem;border-radius:var(--r-m);background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);}
.assure .ico{width:1.5em;height:1.5em;color:var(--accent);flex:none;margin-top:.1rem;}
.assure b{display:block;color:#fff;font-family:var(--f-display);font-weight:600;}
.assure span{color:rgba(255,255,255,.72);font-size:var(--step--1);}
@media (max-width:780px){.beyond__grid{grid-template-columns:1fr;}}

/* ============================================================
   GALLERY — broken masonry
   ============================================================ */
.gallery-grid{columns:3;column-gap:1rem;}
.gallery-grid .gtile{break-inside:avoid;margin-bottom:1rem;position:relative;
  border-radius:var(--r-m);overflow:hidden;display:block;box-shadow:var(--shadow-card);cursor:zoom-in;}
.gtile img{width:100%;transition:transform 1s var(--ease-out-expo);}
.gtile:hover img{transform:scale(1.06);}
.gtile__cap{position:absolute;left:0;right:0;bottom:0;padding:1.4rem .9rem .8rem;
  background:linear-gradient(transparent,rgba(14,32,48,.85));color:#fff;
  font-size:var(--step--1);opacity:0;transform:translateY(8px);
  transition:opacity var(--dur-fast),transform var(--dur-fast);}
.gtile:hover .gtile__cap{opacity:1;transform:none;}
.gtile__cat{display:inline-block;background:var(--accent);color:var(--accent-ink);
  font-weight:700;font-size:.7rem;padding:.15rem .5rem;border-radius:4px;margin-bottom:.35rem;}
@media (max-width:900px){.gallery-grid{columns:2;}}
@media (max-width:560px){.gallery-grid{columns:1;}}

/* lightbox */
.lbox{position:fixed;inset:0;z-index:var(--z-modal);background:rgba(8,16,26,.94);
  display:none;align-items:center;justify-content:center;padding:1.5rem;}
.lbox.is-open{display:flex;}
.lbox img{max-width:92vw;max-height:86vh;border-radius:var(--r-m);box-shadow:var(--shadow-float);}
.lbox__close{position:absolute;top:1.2rem;right:1.2rem;width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.12);color:#fff;display:grid;place-items:center;}
.lbox__close .ico{width:26px;height:26px;}
.lbox__nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;
  background:rgba(255,255,255,.12);color:#fff;display:grid;place-items:center;}
.lbox__nav .ico{width:26px;height:26px;}
.lbox__prev{left:1rem;}.lbox__next{right:1rem;}.lbox__prev .ico{transform:rotate(180deg);}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.reviews{background:var(--paper-2);}
.reviews__head{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;
  flex-wrap:wrap;margin-bottom:var(--sp-l);}
.reviews__score{display:flex;align-items:center;gap:.6rem;font-weight:700;}
.stars{display:inline-flex;color:var(--accent);}
.stars .ico{width:1.15em;height:1.15em;}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;}
.review{background:var(--c-surface);border:1px solid var(--line);border-radius:var(--r-l);
  padding:1.6rem;display:flex;flex-direction:column;gap:1rem;box-shadow:var(--shadow-card);}
.review .stars{margin-bottom:-.2rem;}
.review blockquote{font-size:var(--step-0);color:var(--ink-2);line-height:1.55;}
.review__by{margin-top:auto;font-weight:700;}
.review__by span{display:block;font-weight:500;color:var(--muted);font-size:var(--step--1);}
@media (max-width:860px){.review-grid{grid-template-columns:1fr;}}

/* ============================================================
   FAQ accordion
   ============================================================ */
.faq{max-width:48rem;margin-inline:auto;}
.faq__item{border-top:1px solid var(--line);}
.faq__item:last-child{border-bottom:1px solid var(--line);}
.faq__q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1rem;
  text-align:left;padding:1.4rem 0;font-family:var(--f-display);font-weight:600;
  font-size:var(--step-1);color:var(--ink);}
.faq__q .pm{flex:none;width:30px;height:30px;border-radius:50%;background:var(--paper-2);
  display:grid;place-items:center;position:relative;transition:background var(--dur-fast);}
.faq__q .pm::before,.faq__q .pm::after{content:"";position:absolute;width:13px;height:2px;
  background:var(--ink);border-radius:2px;transition:transform var(--dur-fast) var(--ease-out-soft);}
.faq__q .pm::after{transform:rotate(90deg);}
.faq__item.is-open .pm{background:var(--accent);}
.faq__item.is-open .pm::after{transform:rotate(0);}
.faq__a{overflow:hidden;height:0;}
.faq__a-inner{padding:0 0 1.4rem;color:var(--muted);max-width:60ch;}

/* ============================================================
   CTA / contact
   ============================================================ */
.cta-band{background:var(--ink);color:#fff;}
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(1.5rem,5vw,4rem);align-items:start;}
.contact-aside h2{color:#fff;font-size:var(--step-3);}
.contact-aside .lead{color:rgba(255,255,255,.82);}
.contact-points{display:grid;gap:1rem;margin-top:1.8rem;}
.contact-points a,.contact-points div{display:flex;gap:.8rem;align-items:center;
  color:#fff;font-weight:600;}
.contact-points .ico{width:1.4em;height:1.4em;color:var(--accent);flex:none;}
.contact-points span{display:block;font-weight:400;color:rgba(255,255,255,.7);font-size:var(--step--1);}
.contact-points .tel-num{font-weight:700;font-size:var(--step-1);}
@media (max-width:600px){.contact-points .tel-num{font-size:1.15rem;}}

.qform{background:var(--c-surface);border-radius:var(--r-l);padding:clamp(1.4rem,3vw,2.2rem);
  box-shadow:var(--shadow-float);}
.qform h3{font-size:var(--step-2);}
.qform p.muted{color:var(--muted);margin-top:.3rem;margin-bottom:1.2rem;font-size:var(--step--1);}
.field{margin-bottom:1rem;}
.field label{display:block;font-weight:600;font-size:var(--step--1);margin-bottom:.4rem;color:var(--ink);}
.field input,.field select,.field textarea{width:100%;background:var(--paper);
  border:1.5px solid var(--line);border-radius:var(--r-m);padding:.85rem 1rem;
  font-size:var(--step-0);color:var(--ink);transition:border-color var(--dur-fast),box-shadow var(--dur-fast);}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brand);
  box-shadow:0 0 0 4px rgba(15,61,107,.12);}
.field textarea{min-height:120px;resize:vertical;}
.field--row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.hp{position:absolute;left:-9999px;}
.qform .btn{width:100%;justify-content:center;margin-top:.4rem;}
.qform__foot{margin-top:1rem;font-size:var(--step--1);color:var(--muted);text-align:center;}
@media (max-width:820px){.contact-grid{grid-template-columns:1fr;}.field--row{grid-template-columns:1fr;}}

/* ============================================================
   PAGE HEADER (interior pages)
   ============================================================ */
.phead{background:var(--ink);color:#fff;padding-top:calc(var(--nav-h) + 3rem);
  padding-bottom:3rem;position:relative;overflow:hidden;}
.phead__media{position:absolute;inset:0;opacity:.4;}
.phead__media img{width:100%;height:100%;object-fit:cover;}
.phead::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,32,48,.6),rgba(14,32,48,.92));}
.phead__inner{position:relative;z-index:2;}
.phead .kicker{color:var(--accent);}
.phead .kicker::before{background:var(--accent);}
.phead h1{color:#fff;font-size:var(--step-4);margin-top:.7rem;}
.phead p{color:rgba(255,255,255,.85);margin-top:.9rem;font-size:var(--step-1);max-width:50ch;}
.crumb{font-size:var(--step--1);color:rgba(255,255,255,.7);margin-bottom:.4rem;}
.crumb a:hover{color:#fff;}

/* prose for legal + service detail */
.prose{max-width:44rem;}
.prose h2{font-size:var(--step-2);margin-top:2rem;}
.prose h3{font-size:var(--step-1);margin-top:1.4rem;}
.prose p,.prose li{color:var(--ink-2);margin-top:.8rem;max-width:none;}
.prose ul{padding-left:1.2rem;margin-top:.6rem;}
.prose a{color:var(--brand);text-decoration:underline;text-underline-offset:3px;}

/* service detail */
.svc-detail{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:start;}
.svc-detail__media{border-radius:var(--r-l);overflow:hidden;position:sticky;top:calc(var(--nav-h) + 1.5rem);box-shadow:var(--shadow-card);}
.svc-aside{background:var(--paper-2);border-radius:var(--r-l);padding:1.6rem;}
.svc-aside h4{font-size:var(--step-1);}
.svc-aside ul{list-style:none;margin-top:1rem;display:grid;gap:.6rem;}
.svc-aside li a{display:flex;justify-content:space-between;align-items:center;padding:.7rem .9rem;
  border-radius:var(--r-m);background:var(--c-surface);border:1px solid var(--line);font-weight:600;}
.svc-aside li a:hover{border-color:var(--brand);}
.svc-aside li a .ico{width:1.05em;height:1.05em;color:var(--brand);}
.svc-aside li.is-current a{background:var(--ink);color:#fff;border-color:var(--ink);}
.svc-aside li.is-current a .ico{color:var(--accent);}
@media (max-width:820px){.svc-detail{grid-template-columns:1fr;}.svc-detail__media{position:static;}}

/* about */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,5vw,4rem);align-items:center;}
.about-grid__media{border-radius:var(--r-l);overflow:hidden;box-shadow:var(--shadow-card);}
.about-grid__media img{width:100%;height:auto;display:block;}
.coverage{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:var(--sp-l);}
.cov{background:var(--c-surface);border:1px solid var(--line);border-radius:var(--r-l);padding:1.4rem;}
.cov .ico{width:1.6em;height:1.6em;color:var(--brand);}
.cov h4{font-size:var(--step-1);margin-top:.7rem;}
.cov p{color:var(--muted);margin-top:.4rem;font-size:var(--step--1);}
@media (max-width:820px){.about-grid{grid-template-columns:1fr;}.coverage{grid-template-columns:1fr;}}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{background:var(--ink);color:rgba(255,255,255,.72);padding-top:var(--sp-xl);}
.foot__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2rem;padding-bottom:var(--sp-l);}
.brand--foot{display:inline-block;}
.foot__logo{height:96px;width:auto;background:var(--paper);padding:.8rem 1rem;border-radius:16px;box-shadow:var(--shadow-card);}
.foot__tag{color:var(--accent);font-family:var(--f-display);font-weight:600;font-size:var(--step-1);margin-top:1rem;}
.foot__small{margin-top:.7rem;font-size:var(--step--1);max-width:36ch;}
.foot__social{display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem;color:#fff;font-weight:600;}
.foot__social .ico{width:1.3em;height:1.3em;color:var(--accent);}
.foot__col h4{color:#fff;margin-bottom:1rem;font-family:var(--f-text);
  font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:var(--step--1);}
.foot__col a{display:block;padding:.32rem 0;color:rgba(255,255,255,.72);}
.foot__col a:hover{color:#fff;}
.foot__contact p{color:rgba(255,255,255,.72);font-size:var(--step--1);display:flex;gap:.5rem;align-items:flex-start;}
.foot__contact .ico{width:1.1em;height:1.1em;color:var(--accent);margin-top:.15rem;flex:none;}
.foot__contact span{color:rgba(255,255,255,.5);}
.foot__tel{display:inline-flex;align-items:center;gap:.5rem;color:#fff;font-weight:700;font-size:var(--step-1);margin-bottom:.9rem;}
.foot__tel .ico{width:1.1em;height:1.1em;color:var(--accent);}
.foot__contact .btn{margin-top:1rem;}
.foot__legal{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;
  padding-block:1.4rem;border-top:1px solid rgba(255,255,255,.12);font-size:var(--step--1);}
.foot__legal nav{display:flex;gap:1.2rem;}
.foot__legal a:hover{color:#fff;}
.foot__credit a{color:var(--accent);}
@media (max-width:860px){.foot__grid{grid-template-columns:1fr 1fr;}}
@media (max-width:520px){.foot__grid{grid-template-columns:1fr;}.foot__legal{justify-content:center;text-align:center;}}

/* ============================================================
   FLASHES / cookie / preloader
   ============================================================ */
.flashes{position:fixed;top:calc(var(--nav-h) + .5rem);left:50%;transform:translateX(-50%);
  z-index:var(--z-toast);width:min(92%,40rem);display:grid;gap:.5rem;}
.flash{padding:.85rem 1.1rem;border-radius:var(--r-m);font-weight:600;box-shadow:var(--shadow-card);}
.flash--success{background:#e9f7e4;color:#1f5e12;border:1px solid #bfe6b2;}
.flash--error{background:#fde9e7;color:#8a2118;border:1px solid #f3c2bc;}
.flash--warning{background:#fef3d6;color:#7a560a;border:1px solid #f4dca0;}

.cookie{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:var(--z-overlay);
  max-width:34rem;background:var(--c-surface);border:1px solid var(--line);border-radius:var(--r-l);
  padding:1.2rem 1.3rem;box-shadow:var(--shadow-float);}
.cookie p{font-size:var(--step--1);color:var(--ink-2);max-width:none;}
.cookie p a{color:var(--brand);text-decoration:underline;}
.cookie__btns{display:flex;gap:.6rem;margin-top:.9rem;justify-content:flex-end;}

.preloader{position:fixed;inset:0;z-index:var(--z-modal);background:var(--ink);
  display:grid;place-items:center;}
.preloader__inner{display:flex;align-items:center;gap:.7rem;
  clip-path:inset(0 100% 0 0);animation:wipe .8s var(--ease-out-expo) .15s forwards;}
.preloader__mark{width:46px;height:46px;}
.preloader__word{font-family:var(--f-display);font-weight:700;color:#fff;font-size:clamp(1.4rem,5vw,2.2rem);}
@keyframes wipe{to{clip-path:inset(0 0 0 0);}}
html.is-loaded .preloader{display:none;}
@media (prefers-reduced-motion:reduce){.preloader__inner{clip-path:none;animation:none;}}

/* utility */
.mt-l{margin-top:var(--sp-l);}
.wrap--narrow{max-width:52rem;}

/* ============================================================
   MOBILE NAV
   ============================================================ */
@media (max-width:1040px){
  .nav__links{display:none;}
  .nav__cta .tel{display:none;}
  .nav__burger{display:flex;}
  .nav__drawer{display:block;position:fixed;inset:var(--nav-h) 0 auto 0;background:#fff;
    padding:1.2rem var(--gutter) 2rem;box-shadow:0 20px 40px rgba(14,32,48,.18);
    border-bottom:1px solid var(--line);transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:transform var(--dur-fast) var(--ease-out-soft),opacity var(--dur-fast);z-index:var(--z-nav);}
  .nav.is-open .nav__drawer{transform:none;opacity:1;pointer-events:auto;}
  .nav__drawer[hidden]{display:block;}
  .nav__drawer a{display:block;padding:.85rem 0;font-family:var(--f-display);font-weight:600;
    font-size:var(--step-1);color:var(--ink);border-bottom:1px solid var(--line);}
  .nav__drawer .btn{display:flex;justify-content:center;margin-top:1.1rem;border-bottom:0;}
  .nav__drawer .drawer-tel{display:flex;align-items:center;gap:.5rem;justify-content:center;
    margin-top:1rem;font-weight:700;border-bottom:0;color:var(--brand);
    font-size:var(--step-0);white-space:nowrap;}
  .nav__drawer .drawer-tel .ico{width:1.15em;height:1.15em;}
  .nav.is-open.is-hero .nav__burger{color:var(--ink);}
  /* keep the free-quote button always visible at 360px */
  .nav__cta{margin-left:auto;}
}
@media (max-width:600px){
  .brand__text{font-size:.95rem;}
  .nav__inner{gap:.55rem;}
  .nav__cta .btn{padding:.55rem 1rem;font-size:.92rem;}   /* shrink the Free-quote button so it never crowds the wordmark */
}
@media (max-width:430px){
  .brand__text{font-size:.82rem;}
  .nav__cta .btn{padding:.5rem .85rem;font-size:.86rem;}
}
@media (max-width:360px){
  .brand__text{font-size:.7rem;}   /* full "Bins and Beyond Ltd" stays on one line and clears the button, nothing hidden */
  .nav__cta .btn{padding:.45rem .7rem;font-size:.8rem;}
  .nav__inner{gap:.4rem;}
}
