/* ============================================================
   Avon Reclamation — "Foundry" design system
   Vanilla CSS. Tokens + components extracted from the style guide.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cabin:wght@400;500;600;700&display=swap');

:root{
  --gill:"Cabin","Gill Sans","Gill Sans Nova",system-ui,sans-serif;
  --orange:#ff4b33; --orange-bright:#ff6f5c; --orange-deep:#d63d29;
  --charcoal:#414042; --ink:#414042; --grey-mid:#6d6c70; --grey-line:#d8d7d9;
  --grey-100:#efeeec; --grey-50:#f7f6f4; --bg-light:#f9fafa; --footer:#414042; --white:#ffffff;
  --maxw:1180px; --pad:clamp(20px,5vw,64px);
  --header-h:84px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--gill);color:var(--ink);background:var(--bg-light);line-height:1.45;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--gill);font-weight:700;line-height:.95;text-transform:uppercase;letter-spacing:-.01em}
h1{color:var(--orange)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
.sec-pad{padding-block:clamp(48px,7vw,92px)}
.sec-pad.lightmask{position:relative;overflow:hidden}
.lightmask>.wrap{position:relative;z-index:1}
.lightmask .vmask{position:absolute;left:0;top:0;height:100%;width:auto;max-width:none;z-index:0;pointer-events:none}
.nmask-sec{position:relative;overflow:hidden}
.nmask-sec>.wrap{position:relative;z-index:1}
.nmask-sec .nmask{position:absolute;right:0;top:0;height:100%;width:auto;max-width:none;z-index:0;pointer-events:none}
.nmask-sec .nmask--left{right:auto;left:0}
.o{color:var(--orange)}
.mono{font-family:var(--gill);text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;color:var(--orange)}

/* ---------- Buttons ---------- */
.btn{font-family:var(--gill);text-transform:uppercase;letter-spacing:.12em;font-size:.8rem;font-weight:700;
  display:inline-flex;align-items:center;gap:.6rem;padding:1rem 1.6rem;border:2px solid transparent;cursor:pointer;transition:.18s ease;white-space:nowrap}
.btn-orange{background:var(--orange);color:#fff}
.btn-orange:hover{background:var(--ink);transform:translate(-2px,-2px)}
.btn-ghost{border-color:currentColor;color:inherit}
.btn-ghost:hover{background:var(--orange);border-color:var(--orange);color:#fff}
.btn-line{border-color:var(--orange);color:var(--orange)}
.btn-line:hover{background:var(--orange);color:#fff}
.nav-tel{display:inline-flex;align-items:center;background:var(--ink);color:#fff;padding:1rem 2.4rem;
  font-size:.8rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-family:var(--gill);cursor:pointer;transition:.18s}
.nav-tel:hover{background:#414042}

/* ---------- Header / Nav ---------- */
header{position:sticky;top:0;z-index:50;background:var(--bg-light);border-bottom:1px solid var(--grey-line)}
header .nav{display:flex;align-items:center;gap:1.5rem;min-height:var(--header-h)}
header .logo{display:flex;align-items:center;flex:none}
header .logo img{height:42px;width:auto}
.nav-links{margin-left:auto;display:flex;align-items:center;gap:1.6rem}
.nav-links a:not(.nav-tel){font-family:var(--gill);text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;font-weight:600;color:var(--ink);padding:.4rem 0;border-bottom:2px solid transparent;transition:.16s}
.nav-links a:not(.nav-tel):hover,.nav-links a.active{color:var(--orange);border-bottom-color:var(--orange)}
/* pink-marked breathing space around the call button */
.nav-links .nav-tel{margin-left:1.1rem}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:.5rem;margin-left:auto}
.burger span{width:26px;height:3px;background:var(--ink);transition:.2s}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:#414042;color:#fff}
.hero .bgmark{position:absolute;right:-8%;top:50%;transform:translateY(-50%);height:150%;width:auto;opacity:.07;pointer-events:none}
/* Right-anchored section-bg shape (bleeds off-canvas to the left, sits beneath content) */
.hero .herobg{position:absolute;right:0;top:0;height:100%;width:auto;max-width:none;opacity:1;pointer-events:none}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.25fr .85fr;gap:clamp(2rem,5vw,4rem);
  align-items:center;padding-block:clamp(48px,8vw,104px)}
.hero.compact .wrap{grid-template-columns:1fr;padding-block:clamp(40px,6vw,72px)}
.hero .eyebrow{display:inline-block;background:var(--orange);color:#fff;padding:.5rem .8rem;margin-bottom:1.3rem;
  font-family:var(--gill);text-transform:uppercase;letter-spacing:.16em;font-size:.7rem;font-weight:600}
.hero h1{font-size:clamp(2.4rem,6vw,4.4rem);color:var(--orange)}
.disperse{display:inline-flex;cursor:pointer}
.disperse .char{display:inline-block;transition:transform .75s cubic-bezier(.33,1,.68,1);will-change:transform}
.disperse.is-open .char{transform:translate(var(--dx,0),var(--dy,0)) rotate(var(--dr,0deg))}
.hero h1 .em{color:var(--orange)}
.hero p.lead{margin-top:1.2rem;max-width:54ch;color:#cfced1;font-size:1.08rem;text-transform:none;font-weight:400;letter-spacing:0;line-height:1.55}
.hero .cta{margin-top:1.8rem;display:flex;gap:1rem;flex-wrap:wrap}

.hero-card{background:var(--orange);color:#fff;padding:clamp(1.8rem,2.4vw,2.4rem);border-left:8px solid #fff}
/* legacy price card (e.g. Container Hire) */
.hero-card:not(.hc-features) .big{font-family:var(--gill);font-weight:700;font-size:3.4rem;line-height:.9}
.hero-card:not(.hc-features) .sub{font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;margin-top:.4rem;color:rgba(255,255,255,.85)}
.hero-card:not(.hc-features) hr{border:0;border-top:2px solid rgba(255,255,255,.4);margin:1.3rem 0}
.hero-card:not(.hc-features) ul{list-style:none;display:flex;flex-direction:column;gap:.9rem}
.hero-card:not(.hc-features) li{display:flex;gap:.8rem;align-items:flex-start}
.hero-card:not(.hc-features) li b{font-family:var(--gill);font-size:.8rem;color:var(--ink)}
.hero-card:not(.hc-features) li span{font-size:.94rem;text-transform:none}
/* Stretch the card to the left column's full height and spread its content */
.hero-card.hc-tall{align-self:stretch;display:flex;flex-direction:column}
.hero-card.hc-tall hr{margin-top:auto}
/* feature-blocks card (Home) — stretches to match the left column height */
.hero-card.hc-features{align-self:stretch;display:flex;flex-direction:column}
.hero-card .hc-eyebrow{font-family:var(--gill);text-transform:uppercase;letter-spacing:-.01em;font-size:clamp(1.9rem,2.8vw,2.7rem);font-weight:700;line-height:.95;color:#fff}
.hero-card .hc-list{list-style:none;display:flex;flex-direction:column;margin-top:auto}
.hero-card .hc-list li{display:flex;gap:1rem;align-items:center;padding:1rem 0}
.hero-card .hc-list li+li{border-top:1px solid rgba(255,255,255,.35)}
.hero-card .hc-list b{font-family:var(--gill);font-weight:700;font-size:1.5rem;color:var(--ink);line-height:1;flex:none;min-width:1.5em}
.hero-card .hc-h{display:block;font-family:var(--gill);font-weight:700;text-transform:uppercase;letter-spacing:.01em;font-size:1.08rem;line-height:1.05}
.hero-card .hc-p{display:block;font-size:.92rem;color:rgba(255,255,255,.92);margin-top:.28rem;text-transform:none;line-height:1.35}
.hero-card .hc-cta{display:flex;align-items:center;justify-content:space-between;gap:.6rem;margin-top:auto;background:var(--ink);color:#fff;padding:1rem 1.3rem;font-family:var(--gill);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;transition:.18s}
.hero-card .hc-cta:hover{background:#414042;transform:translate(-2px,-2px)}

/* ---------- LED promo ticker ---------- */
.led-ticker{position:relative;overflow:hidden;background:#58595b;
  height:clamp(42px,6vw,56px);border-top:1px solid rgba(0,0,0,.25);border-bottom:1px solid rgba(0,0,0,.25)}
/* The "screen": a solid unlit-dot fill that the moving text paints over.
   A shared, panel-fixed dot mask carves both fill & text into a dot-matrix grid,
   so lit (#ff4b33) dots switch on over the static dark (#414042) dots. */
.led-screen{position:absolute;inset:0;background:#414042;
  -webkit-mask-image:radial-gradient(circle,#000 42%,transparent 47%);
  mask-image:radial-gradient(circle,#000 42%,transparent 47%);
  -webkit-mask-size:3.94px 3.94px;mask-size:3.94px 3.94px;
  -webkit-mask-position:center;mask-position:center}
.led-track{position:absolute;top:0;left:0;height:100%;display:flex;align-items:center;
  white-space:nowrap;will-change:transform;animation:led-scroll 20.48s linear infinite}
.led-seg{display:inline-flex;align-items:center;flex:none;
  font-family:var(--gill);font-weight:700;text-transform:uppercase;
  letter-spacing:.16em;font-size:clamp(18px,3.1vw,28px);line-height:1;color:#ff4b33}
.led-seg .promo{padding:0 .5ch}
.led-seg .sep{display:inline-block;width:4.8ch}
.led-sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap}
@keyframes led-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.led-track{animation:none}}
@media(max-width:760px){.led-ticker{height:clamp(64px,14vw,84px)}.led-seg{font-size:clamp(27px,6vw,42px)}}

/* page hero on light, slim variant */
.pagehero{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.pagehero .pagehero-bg{position:absolute;right:0;top:0;height:100%;width:auto;max-width:none;pointer-events:none}
.pagehero::before{content:"";position:absolute;inset:0;background-image:
  linear-gradient(#fff 1px,transparent 1px),linear-gradient(90deg,#fff 1px,transparent 1px);
  background-size:46px 46px;opacity:.05}
.pagehero-plain{background:#414042}
.pagehero-plain::before{display:none}
.pagehero .wrap{position:relative;z-index:2;padding-block:clamp(40px,6vw,76px)}
.pagehero h1{font-size:clamp(2.1rem,5vw,3.6rem);color:var(--orange)}
.pagehero h1 .em{color:var(--orange)}
.pagehero p{margin-top:1rem;max-width:60ch;color:#cfced1;text-transform:none;font-weight:400;letter-spacing:0;line-height:1.55}
.crumb{font-family:var(--gill);text-transform:uppercase;letter-spacing:.14em;font-size:.7rem;color:var(--orange-bright);margin-bottom:1rem}
.crumb a{color:#cfced1}.crumb a:hover{color:#fff}

/* ---------- Section label ---------- */
.seclabel{display:flex;align-items:center;gap:1rem;margin-bottom:2.2rem;flex-wrap:wrap}
.seclabel .idx{font-family:var(--gill);font-weight:600;font-size:.72rem;letter-spacing:.12em;background:var(--orange);color:#fff;padding:.5rem .8rem;text-transform:uppercase}
.seclabel h2{font-size:clamp(1.6rem,3.4vw,2.4rem);color:var(--ink)}
.seclabel .note{font-size:.86rem;color:var(--grey-mid);margin-left:auto;max-width:42ch;text-align:right;line-height:1.45}

/* About section with V-shape background */
.about{position:relative;overflow:hidden}
.about>.wrap{position:relative;z-index:1}
.about-bg{position:absolute;top:0;left:0;height:100%;width:auto;max-width:none;z-index:0;pointer-events:none}
.about .split .media{position:static;top:auto}
.about .split .prose{margin-top:4px}

/* Process section with N-shape background */
.process{position:relative;overflow:hidden}
.process>.wrap{position:relative;z-index:1}
.process-bg{position:absolute;top:0;left:0;height:100%;width:auto;max-width:none;z-index:0;pointer-events:none}

/* generic prose */
.prose h2{font-size:clamp(1.5rem,3vw,2.1rem);color:var(--ink);margin:1.8rem 0 .9rem}
.prose h2:first-child{margin-top:0}
.prose h2 .o{color:var(--orange)}
.prose p{margin:0 0 1rem;max-width:62ch;color:var(--ink);font-size:1.02rem}
.prose p.intro{font-size:1.12rem;color:var(--charcoal);font-weight:500}
.prose strong{font-weight:700}
.prose ul.ticks{list-style:none;margin:.4rem 0 1.4rem;display:grid;gap:.6rem}
.prose ul.ticks li{position:relative;padding-left:1.8rem;color:var(--ink);font-size:1.02rem}
.prose ul.ticks li::before{content:"";position:absolute;left:0;top:.45em;width:.7rem;height:.7rem;background:var(--orange)}

/* two-column content layout */
.split{display:grid;grid-template-columns:1.4fr .9fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.split-req{grid-template-columns:.5fr 1.5fr}
.split .media{position:static;align-self:start}
.split .media.media-fill{align-self:stretch;position:static;top:auto;display:flex;flex-direction:column}
.split .media.media-fill .mapframe,
.split .media.media-fill .statpanel{flex:1;height:auto;min-height:0}
.split .media.media-shorten{margin-bottom:20px}
.media-frame{border-top:8px solid var(--orange);background:#fff;box-shadow:0 18px 40px -28px rgba(0,0,0,.4)}
.media-frame img{width:100%;height:auto;display:block}
.media-frame .cap{padding:.9rem 1.1rem;font-family:var(--gill);text-transform:uppercase;letter-spacing:.1em;font-size:.66rem;color:var(--grey-mid)}
.media-stack .media-frame{box-shadow:none}
.media-stack .statpanel{border-left:0}

/* ---------- Service cards ---------- */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.4rem;align-items:stretch}
.svc{background:var(--charcoal);color:#fff;padding:2.2rem;transition:.25s;display:flex;flex-direction:column}
.svc:hover{background:var(--ink)}
.svc .num{font-family:var(--gill);color:var(--orange-bright);font-size:.85rem;letter-spacing:.1em}
.svc h3{font-size:1.45rem;margin:1rem 0 .7rem}
.svc p{color:#cfced1;font-size:.96rem}
.svc .more{display:inline-flex;margin-top:auto;padding-top:1.4rem;font-family:var(--gill);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--orange-bright);gap:.5rem;transition:.18s}
.svc:hover .more{gap:.9rem}

/* charcoal section band with light boxes */
.band-mid{color:#fff;position:relative;overflow:hidden}
.band-mid>.wrap{position:relative;z-index:1}
.band-mid .services-bg{position:absolute;top:0;right:0;height:100%;width:auto;max-width:none;z-index:0;pointer-events:none}
.band-mid .seclabel h2{color:#fff}
.band-mid .seclabel .note{color:#cfced1}
.band-mid .svc{background:var(--bg-light);color:var(--ink);border-top:8px solid var(--orange)}
.band-mid .svc:hover{background:#fff;transform:translateY(-4px);
  box-shadow:inset 8px 0 0 0 var(--orange),inset -8px 0 0 0 var(--orange),inset 0 -8px 0 0 var(--orange),0 22px 44px -28px rgba(0,0,0,.55)}
.band-mid .svc .num{color:var(--orange)}
.band-mid .svc h3{color:var(--ink)}
.band-mid .svc p{color:var(--grey-mid)}
.band-mid .svc .more{color:var(--orange)}

/* hire / fact cards */
.hirecard{background:#fff;border-top:8px solid var(--orange);padding:1.8rem;height:100%}
.hirecard .n{font-family:var(--gill);color:var(--orange);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase}
.hirecard h3{font-size:1.35rem;margin:.6rem 0;color:var(--ink)}
.hirecard p{color:var(--grey-mid);font-size:.95rem}
.factgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--grey-line);border:1px solid var(--grey-line);margin-top:1.4rem}
.factgrid .f{background:#fff;padding:1.2rem}
.factgrid .k{display:block;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--orange);margin-bottom:.3rem}
.factgrid .v{font-size:1.05rem;font-weight:700;color:var(--ink)}

/* stat + accept panels */
.statpanel{background:var(--ink);color:#fff;padding:2rem;border-left:8px solid #fff;height:100%}
.statpanel .n{font-family:var(--gill);font-weight:700;font-size:3rem;color:var(--orange);line-height:.9}
.statpanel .t{font-family:var(--gill);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:#cfced1;margin-top:.6rem}

/* numbered steps */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.4rem}
.step{background:#414042;color:#fff;padding:2rem;border-top:8px solid var(--orange);box-shadow:0 18px 40px -30px rgba(0,0,0,.35)}
.step .n{font-family:var(--gill);font-weight:700;font-size:3.6rem;color:var(--orange);line-height:.8}
.step h3{font-size:1.2rem;margin:.7rem 0 .5rem;color:#fff}
.step p{color:#cfced1;font-size:.93rem}
/* White-card variant of the process section */
.process-light .step{background:#fff}
.process-light .step h3{color:var(--ink)}
.process-light .step p{color:var(--grey-mid)}
/* Dark variant of the How-it-works / process section */
.process-dark{background:#414042}
.process-dark .seclabel h2{color:#fff}
.process-dark .seclabel .note{color:#cfced1}
.process-dark .step{background:#58595b}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:1rem}
.chip-el{background:var(--ink);color:#fff;border:0;padding:.9rem 1.3rem;font-family:var(--gill);font-weight:500;
  text-transform:uppercase;font-size:1.02rem;letter-spacing:.01em;transition:.18s}
.chip-el:hover{background:var(--orange);color:#fff;transform:translateY(-3px)}
.chip-el span{font-family:var(--gill);font-weight:600;font-size:.7rem;color:var(--orange-bright);margin-right:.5rem}
.chip-el:hover span{color:#fff}
.chips-white .chip-el{background:#fff;color:var(--ink);box-shadow:0 6px 18px -10px rgba(0,0,0,.25)}
.chips-white .chip-el:hover{background:#fff;color:var(--ink);transform:none}
.chips-white .chip-el:hover span{color:var(--orange-bright)}
.chips-grey .chip-el{background:#f9fafa;color:var(--ink);box-shadow:0 6px 18px -10px rgba(0,0,0,.25)}
.chips-grey .chip-el:hover{background:#f9fafa;color:var(--ink);transform:none}
.chips-grey .chip-el:hover span{color:var(--orange-bright)}

/* eyebrows / tags */
.eyebrow-orange{display:inline-block;background:var(--orange);color:#fff;padding:.5rem .8rem;font-family:var(--gill);text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;margin-bottom:1rem}
.accept-tag{display:inline-block;background:var(--orange);color:#fff;font-family:var(--gill);font-weight:600;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;padding:.5rem .85rem}

/* ---------- Accept / CTA band ---------- */
.band-dark{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.band-dark .bgmark{position:absolute;right:-6%;top:50%;transform:translateY(-50%);height:150%;opacity:.06;pointer-events:none}
.accept-card{position:relative;z-index:2;display:grid;grid-template-columns:1.3fr .9fr;gap:clamp(2rem,5vw,3.5rem);align-items:center;border-left:8px solid var(--orange);padding:clamp(1.6rem,4vw,2.6rem);background:rgba(255,255,255,.02)}
.accept-card h2{font-size:clamp(1.6rem,3.2vw,2.4rem);margin:.9rem 0 1.3rem;color:#fff}
.accept-card h2 .o{color:var(--orange-bright)}
.accept-card p{color:#cfced1;text-transform:none}
.accept-card .cta{display:flex;flex-wrap:wrap;gap:20px}
.accept-ways{display:flex;flex-direction:column;gap:1rem}
.way{background:var(--charcoal);padding:1.1rem 1.3rem;border-left:8px solid var(--orange)}
.way .k{display:block;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--orange-bright);margin-bottom:.25rem}
.way .v{font-size:1rem;font-weight:600;color:#fff}
.way .v a{color:inherit;text-decoration:none}
.way .v a:hover{color:var(--orange)}

/* light f9fafa accept section with a white card */
.band-orange{background:var(--bg-light);color:var(--ink);position:relative;overflow:hidden}
.band-orange .bgmark{position:absolute;right:-6%;top:50%;transform:translateY(-50%);height:150%;opacity:.05;pointer-events:none}
.band-orange .accept-card{border-left-color:var(--ink);background:#fff;box-shadow:0 22px 50px -34px rgba(0,0,0,.45)}
.band-orange .accept-tag{background:var(--orange);color:#fff}
.band-orange .accept-card h2{color:var(--ink)}
.band-orange .accept-card h2 .o{color:var(--orange)}
.band-orange .accept-card p{color:var(--grey-mid)}
.band-orange .way{background:var(--ink);border-left-color:var(--orange)}
.band-orange .way .k{color:var(--orange-bright)}

/* light-theme CTA band */
.band-light{background:var(--bg-light);color:var(--ink);position:relative;overflow:hidden}
.band-light .bgmark{display:none}
.band-light .accept-card{border-left-color:var(--orange);background:#fff;box-shadow:0 22px 50px -34px rgba(0,0,0,.22)}
.band-light .accept-card h2{color:var(--ink)}
.band-light .accept-card h2 .o{color:var(--orange)}
.band-light .accept-card p{color:var(--grey-mid)}
.band-light .way{background:#f9fafa;border-left-color:var(--orange)}
.band-light .way .k{color:var(--orange)}
.band-light .way .v{color:var(--ink)}

/* dark "why it matters" section with 58595b cards */
.why-dark .seclabel h2{color:#fff}
.why-dark .seclabel .note{color:#e0dfe1}
.why-dark .hirecard{background:#58595b}
.why-dark .hirecard h3{color:#fff}
.why-dark .hirecard p{color:#e0dfe1}

/* granules / sustainability section */
.band-dark .seclabel h2{color:#fff}
.band-dark .seclabel .note{color:#cfced1}
.sustain{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,3.6rem);align-items:center}
.sustain .lead{color:#cfced1;font-size:1.12rem;line-height:1.6;text-transform:none;max-width:50ch}
.sustain .lead strong{color:#fff;font-weight:700}
.sustain .sustain-line{margin:0 0 1.2rem;font-family:var(--gill);font-weight:700;text-transform:uppercase;letter-spacing:-.01em;line-height:1;font-size:clamp(1.2rem,2.4vw,1.7rem);color:var(--orange-bright)}
.sustain .cta{margin-top:1.6rem;display:flex;gap:1rem;flex-wrap:wrap}
.uses{background:var(--charcoal);border-left:8px solid var(--orange);padding:clamp(1.6rem,3vw,2.2rem)}
.uses .uses-k{display:block;font-family:var(--gill);text-transform:uppercase;letter-spacing:.14em;font-size:.7rem;color:var(--orange-bright);margin-bottom:1.2rem}
.uses ul{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:.85rem 1.4rem}
.uses li{position:relative;padding-left:1.6rem;color:#fff;font-size:1rem;line-height:1.3}
.uses li::before{content:"";position:absolute;left:0;top:.4em;width:.7rem;height:.7rem;background:var(--orange)}
@media(max-width:760px){.sustain{grid-template-columns:1fr}.uses ul{grid-template-columns:1fr}}

/* the strapline lockup */
.strap{background:var(--orange);color:#414042}
.strap--vbg{position:relative;overflow:hidden}
.strap--vbg>.wrap{position:relative;z-index:1}
.strap--vbg .strap-vbg{position:absolute;left:0;top:0;height:100%;width:auto;max-width:none;z-index:0;pointer-events:none}
.strap--vbg .strap-vbg--right{left:auto;right:0}
.strap .wrap{padding-block:clamp(34px,5vw,56px);display:flex;align-items:center;justify-content:center;gap:clamp(1rem,3vw,2.4rem);flex-wrap:nowrap}
.strap .strap-art{height:clamp(92px,11vw,150px);width:auto;flex:none;align-self:center;display:block}
.strap-cta{display:flex;flex-direction:column;align-items:center;gap:1rem;flex:none}
.strap-cta .btn{margin:0}
.strap-recyc{height:clamp(38px,4.6vw,58px);width:auto;flex:none;align-self:center;transform:rotate(-360deg);transition:transform 1s cubic-bezier(.33,1,.68,1)}
.strap:has(.strap-art--bank) .strap-recyc{height:clamp(19px,2.3vw,29px)}
.strap:has(.strap-art--bank) .strap-cta{gap:.4rem}
.strap-recyc.in{transform:rotate(0)}
@media(prefers-reduced-motion:reduce){.strap-recyc{transform:none;transition:none}}
.strap .strap-art--bank{height:clamp(58px,6.9vw,94px)}
.strap .strap-art--mobile{display:none}
.strap p{font-family:var(--gill);font-weight:700;text-transform:uppercase;letter-spacing:-.01em;line-height:.98;font-size:clamp(1.4rem,3.4vw,2.4rem);text-align:left}
.strap .btn-ghost{flex:none;display:inline-block;white-space:normal;text-align:center;line-height:1.2}
.strap .btn-ghost:hover{background:#fff;border-color:#fff;color:var(--orange)}
.strap .strap-btn-spaced{margin-left:25px}
@media(max-width:820px){.strap .wrap{flex-direction:column;flex-wrap:wrap}.strap p{text-align:center}.strap .strap-btn-spaced{margin-left:0}}
@media(max-width:600px){.strap .strap-art--desktop{display:none}.strap .strap-art--mobile{display:block}.strap .strap-art--text{height:clamp(38px,8.4vw,55px)}.strap .btn-ghost{white-space:nowrap}.strap .btn-break{display:none}
  .strap:has(.strap-art--text) .wrap,.strap--row .wrap{display:grid;grid-template-columns:auto auto;grid-template-areas:"title icon" "btn btn";justify-content:center;align-items:center;column-gap:1rem;row-gap:1.2rem}
  .strap:has(.strap-art--text) .strap-cta,.strap--row .strap-cta{display:contents}
  .strap:has(.strap-art--text) .strap-art--text{grid-area:title}
  .strap:has(.strap-art--text) .strap-recyc,.strap--row .strap-recyc{grid-area:icon}
  .strap:has(.strap-art--text) .strap-cta .btn,.strap--row .strap-cta .btn{grid-area:btn;justify-self:center}
  .strap--big .strap-recyc{height:clamp(76px,9.2vw,116px)}
  .strap--big .strap-art{transform:translateX(25px)}
  .strap:has(.strap-art--bank) .strap-recyc{height:clamp(48px,5.8vw,73px)}
  .strap--big2 .strap-recyc{height:clamp(68px,8.3vw,104px);transform:translateX(25px)}
  .strap--big2 .strap-art{transform:translateX(55px)}}

/* ---------- Form ---------- */
.formdemo{background:var(--ink);color:#fff;padding:clamp(1.8rem,4vw,2.8rem)}
.formdemo .grow{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}
.gfield{display:flex;flex-direction:column;margin-bottom:1.3rem}
.gfield_label{font-family:var(--gill);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:#bdbcbf;margin-bottom:.45rem}
.formdemo input,.formdemo textarea{width:100%;background:transparent;border:0;border-bottom:3px solid rgba(255,255,255,.38);border-radius:0;color:#fff;font-family:var(--gill);font-size:1rem;padding:.55rem 0;outline:none;transition:border-color .18s}
.formdemo textarea{resize:vertical;min-height:84px}
.formdemo input::placeholder,.formdemo textarea::placeholder{color:rgba(255,255,255,.35)}
.formdemo input:focus,.formdemo textarea:focus{border-bottom-color:var(--orange-bright)}
.formnote{font-size:.78rem;color:#9b9a9d;margin-top:.4rem}

/* contact detail list */
.contact-list{list-style:none;display:grid;gap:1px;background:var(--grey-line);border:1px solid var(--grey-line)}
.contact-list li{background:#fff;padding:1.2rem 1.3rem;display:flex;gap:1rem;align-items:baseline;flex-wrap:wrap}
.contact-list .k{font-family:var(--gill);text-transform:uppercase;letter-spacing:.12em;font-size:.68rem;color:var(--orange);min-width:90px;font-weight:700}
.contact-list .v{font-size:1.05rem;font-weight:600;color:var(--ink)}
/* Stacked variant — label over value, narrower */
.contact-list-stack li{flex-direction:column;align-items:flex-start;gap:.3rem;background:#f9fafa}
.contact-list-stack .k{min-width:0}
.mapframe{border:1px solid var(--grey-line);width:100%;height:340px;display:block}
/* Contact: equal-width columns, form stretches to match the left column height */
.contact-split{grid-template-columns:1fr 1fr;align-items:stretch}
.contact-split>div{display:flex;flex-direction:column}
.contact-split .formdemo{flex:1 1 auto}
/* Contact: light-theme enquiry form */
.contact-split .formdemo{background:transparent;color:var(--ink);border:0;box-shadow:none;padding:0}
.contact-split .formdemo .gfield_label{color:var(--grey-mid);font-weight:700}
.contact-split .formdemo input,.contact-split .formdemo textarea{color:var(--ink);border-bottom-color:rgba(0,0,0,.18)}
.contact-split .formdemo input::placeholder,.contact-split .formdemo textarea::placeholder{color:rgba(0,0,0,.32)}
.contact-split .formdemo input:focus,.contact-split .formdemo textarea:focus{border-bottom-color:var(--orange-bright)}
.contact-split .formnote{color:var(--grey-mid)}

/* ---------- Footer ---------- */
footer{background:var(--footer);color:#9b9a9d;padding-block:2.6rem;font-family:var(--gill);font-size:.8rem;letter-spacing:.02em;line-height:1.6}
footer .ftop{display:flex;justify-content:space-between;gap:2rem;align-items:flex-start;flex-wrap:wrap;padding-bottom:1.8rem;border-bottom:1px solid rgba(255,255,255,.1)}
footer .logo img{height:30px;width:auto;opacity:.92}
footer .fnav{display:flex;gap:1.4rem;flex-wrap:wrap;margin-top:.8rem}
footer .fnav a{color:#c8c7ca;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem}
footer .fnav a:hover{color:var(--orange-bright)}
footer .fmeta{text-align:right}
footer .fmeta a{color:#c8c7ca}footer .fmeta a:hover{color:#fff}
footer .fbar{display:flex;justify-content:space-between;gap:1.2rem 2rem;flex-wrap:wrap;align-items:center;padding-top:1.6rem}
.flic{display:flex;gap:.4rem 1.6rem;flex-wrap:wrap}
.flic a{color:#c8c7ca;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem}
.flic a span{color:var(--orange-bright)}
.fpolicies{display:flex;gap:.7rem;flex-wrap:wrap}
.fbtn{border:1px solid rgba(255,255,255,.25);color:#cfced1;text-transform:uppercase;letter-spacing:.12em;font-size:.66rem;padding:.55rem .9rem;transition:.18s}
.fbtn:hover{background:var(--orange);border-color:var(--orange);color:#fff}

/* ---------- Dropdown navigation ---------- */
.has-sub{position:relative;display:flex;align-items:center}
.has-sub>.nav-top{font-family:var(--gill);text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;font-weight:600;color:var(--ink);padding:.4rem 0;border-bottom:2px solid transparent;transition:.16s;display:inline-flex;align-items:center;gap:.4rem;cursor:pointer}
.has-sub>.nav-top::after{content:"";width:.42rem;height:.42rem;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:translateY(-2px) rotate(45deg);transition:.16s;opacity:.7}
.has-sub:hover>.nav-top,.has-sub:focus-within>.nav-top,.has-sub>.nav-top.active{color:var(--orange);border-bottom-color:var(--orange)}
.submenu{position:absolute;top:100%;left:0;min-width:250px;background:#58595b;display:flex;flex-direction:column;padding:.4rem 0;opacity:0;visibility:hidden;transform:translateY(10px);transition:.18s ease;z-index:60;box-shadow:0 22px 46px -24px rgba(0,0,0,.65)}
.has-sub:hover .submenu,.has-sub:focus-within .submenu{opacity:1;visibility:visible;transform:none}
.nav-links .submenu a{color:#f9fafa;padding:.72rem 1.3rem;font-family:var(--gill);font-size:.76rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;border:0;border-left:3px solid transparent;transition:.16s}
.nav-links .submenu a:hover{background:var(--charcoal);color:#f9fafa;border-left-color:var(--orange)}
.nav-links .submenu a.active{background:var(--charcoal);color:#f9fafa;border-left-color:var(--orange);font-weight:700}

/* ---------- Header Home link + Request CTA ---------- */
.nav-links a.nav-cta{display:inline-flex;align-items:center;background:var(--orange);color:#fff;padding:1rem 1.6rem;font-family:var(--gill);font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;border-bottom:0;transition:.18s}
.nav-links a.nav-cta:hover{background:var(--ink);color:#fff;border-bottom:0}

/* ---------- Hero media image (right column) ---------- */
.hero-media{position:relative;align-self:stretch;min-height:300px;border-left:8px solid #fff;overflow:hidden;box-shadow:0 22px 50px -30px rgba(0,0,0,.6)}
.hero-media img{width:100%;height:100%;min-height:300px;object-fit:cover;display:block}

/* ---------- USP / trust strip ---------- */
.trust{background:var(--charcoal);color:#fff}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.trust .t{display:flex;align-items:center;gap:.8rem;padding:1.5rem clamp(.6rem,2vw,1.4rem);font-family:var(--gill);text-transform:uppercase;letter-spacing:.03em;font-weight:600;font-size:.92rem;line-height:1.15}
.trust .t+.t{box-shadow:inset 1px 0 0 rgba(255,255,255,.14)}
.trust .t::before{content:"";width:.72rem;height:.72rem;background:var(--orange);flex:none}
@media(max-width:760px){.trust .wrap{grid-template-columns:1fr 1fr}.trust .t+.t{box-shadow:none}.trust .t{border-top:1px solid rgba(255,255,255,.12)}}

/* ---------- Services section (light grey) + 'All services' CTA card ---------- */
#services{position:relative;overflow:hidden}
#services>.wrap{position:relative;z-index:1}
.services-v{position:absolute;top:0;left:0;height:100%;width:auto;max-width:none;z-index:0;pointer-events:none}
#services .svc{background:#fff;color:var(--ink);border-top:8px solid var(--orange);box-shadow:0 6px 18px -10px rgba(0,0,0,.25)}
#services .svc:hover{background:#fff;transform:translateY(-4px);
  box-shadow:inset 8px 0 0 0 var(--orange),inset -8px 0 0 0 var(--orange),inset 0 -8px 0 0 var(--orange),0 22px 44px -28px rgba(0,0,0,.55)}
#services .svc .num{color:var(--orange)}
#services .svc h3{color:var(--ink)}
#services .svc p{color:var(--grey-mid)}
#services .svc .more{color:var(--orange)}

/* ---------- Areas: N vector left, pills left, full-bleed map right ---------- */
.areas{position:relative;overflow:hidden}
.areas>.wrap{position:relative;z-index:1}
.areas-n{position:absolute;top:0;left:0;height:100%;width:auto;max-width:none;z-index:0;pointer-events:none}
.areas-bleed{position:relative;z-index:1;display:grid;grid-template-columns:.9fr 1.1fr;align-items:stretch}
.areas-bleed .mapframe{width:100%;height:100%;min-height:340px;margin:0;border:0;display:block}
.areas-bleed .area-pills{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:.9rem;padding:clamp(1.6rem,4vw,2.6rem);padding-left:max(var(--pad),calc((100vw - var(--maxw)) / 2 + var(--pad)))}
.area-pill{display:inline-flex;align-items:center;gap:.6rem;background:transparent;border:2px solid #fff;color:#fff;padding:1rem 1.6rem;font-family:var(--gill);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:.8rem;white-space:nowrap;transition:.18s ease}
.area-pill:hover{background:#fff;color:var(--ink)}
@media(max-width:760px){.areas-bleed{grid-template-columns:1fr}.areas-bleed .mapframe{min-height:240px}}

/* ---------- Dark-grey band (how it works / areas / about) ---------- */
.band-grey{background:#58595b;color:#fff}
.band-grey .process-bg{left:auto;right:0}
.band-grey .seclabel h2{color:#fff}
.band-grey .seclabel .note{color:#e0dfe1}
.band-grey .prose .intro{color:#fff}
.band-grey .prose p{color:#e0dfe1}
.band-grey .prose h2{color:#fff}
.band-grey .prose ul.ticks li{color:#e6e5e7}

/* ---------- Accreditations strip ---------- */
.creds{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.cred{background:#fff;border:1px solid var(--grey-line);border-top:8px solid var(--orange);padding:1.5rem 1.2rem;text-align:center;display:flex;flex-direction:column;gap:.45rem;align-items:center;justify-content:center}
.cred .k{font-family:var(--gill);text-transform:uppercase;letter-spacing:.1em;font-size:.64rem;color:var(--grey-mid)}
.cred .v{font-family:var(--gill);font-weight:700;text-transform:uppercase;color:var(--ink);font-size:1rem;line-height:1.1}
.cred .v span{color:var(--orange)}
@media(max-width:760px){.creds{grid-template-columns:1fr 1fr}}
/* audit-trail section A vector (right) */
.tabs{margin-top:1.4rem}
.tablist{display:flex;gap:1.4rem;margin-bottom:1.8rem}
.tab{font-family:var(--gill);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:.76rem;color:var(--grey-mid);background:none;border:0;border-bottom:3px solid transparent;padding:.7rem .1rem;margin-bottom:-1px;cursor:pointer;transition:.18s}
.tab:hover{color:var(--ink)}
.tab.is-active{color:var(--orange);border-bottom-color:var(--orange)}
.tabpanels{display:grid}
.tabpanels>.tabpanel{grid-area:1/1;display:block;visibility:hidden;opacity:0;transition:opacity .2s ease}
.tabpanels>.tabpanel.is-active{visibility:visible;opacity:1}
.audit-grid{display:flex;align-items:center;gap:clamp(1.5rem,4vw,3rem)}
.audit-grid .cred{flex:none;min-width:220px}
.tabpanel .hirecard{box-shadow:0 8px 24px -16px rgba(0,0,0,.14)}
.audit-blurb{font-size:1.05rem;line-height:1.6;color:var(--ink);max-width:34ch}
@media(max-width:760px){.audit-grid{flex-direction:column;align-items:flex-start}}
.audit{position:relative;overflow:hidden}
.audit>.wrap{position:relative;z-index:1}
.audit-a{position:absolute;top:0;right:0;height:100%;width:auto;max-width:none;z-index:0;pointer-events:none}

/* ---------- Closing CTA band ---------- */
.closing-orange{background:var(--orange);color:#414042;position:relative;overflow:hidden}
.closing-orange .closing h2{color:#414042}
.closing-orange .closing h2 .o{color:#fff}
.closing-orange .closing p{color:#fff}
.closing-orange .btn-orange{background:#414042;color:#fff;border-color:#414042}
.closing-orange .btn-orange:hover{background:#fff;color:#414042;border-color:#fff;transform:translate(-2px,-2px)}
.closing-orange .btn-ghost{border-color:#414042;color:#414042}
.closing-orange .btn-ghost:hover{background:#414042;color:#fff;border-color:#414042}
.closing-recyc{position:absolute;top:0;right:0;height:100%;width:auto;max-width:none;z-index:0;pointer-events:none}
/* Home-only brand lockup sat to the left of the closing CTA */
.closing-logo{position:absolute;top:50%;transform:translateY(-50%);
  left:calc(max(var(--pad),calc(50% - var(--maxw)/2)) - 144px);
  width:clamp(170px,15vw,240px);height:auto;z-index:0;pointer-events:none}
@media(max-width:1200px){.closing-logo{display:none}}
.closing{position:relative;z-index:2;text-align:center;max-width:680px;margin:0 auto}
.closing-title{display:block;width:100%;max-width:350px;height:auto;margin:0 auto 1.2rem;padding-bottom:15px;cursor:pointer;overflow:visible}
.closing-title .st1{transform-box:fill-box;transform-origin:center;transition:transform .7s cubic-bezier(.33,1,.68,1)}
.closing-title.is-open .st1{transform:translate(var(--dx,0),var(--dy,0)) rotate(var(--dr,0deg))}
.closing h2{font-size:clamp(1.8rem,4vw,3rem);color:var(--ink);margin-bottom:1rem}
.closing p{color:var(--grey-mid);text-transform:none;font-size:1.08rem;line-height:1.55;margin-bottom:1.8rem}
.closing .cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ---------- Multi-column footer ---------- */
.fcols{display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:2rem;padding-bottom:1.8rem;border-bottom:1px solid rgba(255,255,255,.1)}
.fbrand .logo img{height:33px;width:auto;opacity:.92}
.fbrand{color:#fff}
.fbrand p{margin:1rem 0 calc(.8rem - 6px);color:#fff;font-size:.8rem;max-width:30ch;line-height:1.6}
.fbrand a{color:#c8c7ca}.fbrand a:hover{color:#fff}
.fbrand a[href^="tel:"]{display:inline-block;margin-top:7px}
.fcol h4{font-family:var(--gill);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--orange-bright);margin-bottom:.9rem;font-weight:700}
.fcol nav{display:flex;flex-direction:column;gap:.55rem}
.fcol a{color:#c8c7ca;text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;line-height:1.4}
.fcol a:hover{color:var(--orange-bright)}
@media(max-width:900px){.fcols{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.fcols{grid-template-columns:1fr}}
/* Homepage: nudge footer brand text down on desktop & tablet only */
@media(min-width:521px){.home .fbrand p{margin-top:calc(1rem + 10px)}}

/* ---------- FAQ accordion ---------- */
.faq{display:grid;gap:1px;background:var(--grey-line);border:1px solid var(--grey-line)}
.faq details{background:#fff}
.faq summary{list-style:none;cursor:pointer;padding:1.3rem 1.4rem;display:flex;align-items:center;gap:1rem;font-family:var(--gill);font-weight:700;text-transform:uppercase;letter-spacing:.01em;font-size:1.02rem;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:"+";font-family:var(--gill);font-weight:700;font-size:1.4rem;color:var(--orange);line-height:1;flex:none;width:1rem;transition:.18s}
.faq details[open] summary::before{content:"–";color:var(--orange)}
.faq summary:hover{color:var(--orange)}
.faq .faq-a{padding:0 1.4rem 1.4rem 3.4rem}
.faq .faq-a p{color:var(--grey-mid);font-size:1rem;margin:0 0 .8rem;max-width:64ch}
.faq .faq-a p:last-child{margin-bottom:0}

/* ---------- Legal / single-column prose pages ---------- */
.legal{max-width:80ch}
.legal .prose h2{font-size:clamp(1.3rem,2.6vw,1.8rem)}
.legal .prose h3{font-size:1.15rem;color:var(--ink);text-transform:uppercase;margin:1.6rem 0 .6rem}
.legal .prose a{color:var(--orange);text-decoration:underline}
.legal .prose ul:not(.ticks){margin:.4rem 0 1.2rem 1.4rem;color:var(--ink)}
.legal .prose ul:not(.ticks) li{margin-bottom:.4rem;font-size:1.02rem}
.legal .updated{font-family:var(--gill);text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;color:var(--grey-mid);margin-bottom:1.8rem}

/* ---------- Areas coverage list ---------- */
.arealist{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1px;background:var(--grey-line);border:1px solid var(--grey-line)}
.arealist .a{background:#fff;padding:1.1rem 1.2rem;font-family:var(--gill);font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:.92rem;color:var(--ink)}
.arealist .a::before{content:"› ";color:var(--orange)}
/* 5-across areas grid (Somerset) — f9fafa cells, no wrapping */
.arealist-5{grid-template-columns:repeat(5,1fr)}
.arealist-5 .a{background:#f9fafa;white-space:nowrap}
@media(max-width:860px){.arealist-5{grid-template-columns:repeat(2,1fr)}.arealist-5 .a{white-space:normal}}

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

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .hero .wrap{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .split-req{grid-template-columns:1fr}
  .split .media{position:static}
  .accept-card{grid-template-columns:1fr}
  footer .fmeta{text-align:left}
}
@media(max-width:760px){
  .nav-links{position:fixed;inset:var(--header-h) 0 auto 0;background:var(--bg-light);border-bottom:1px solid var(--grey-line);
    flex-direction:column;align-items:stretch;gap:0;padding:.5rem var(--pad) 1.2rem;margin:0;
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:.2s}
  .nav-links.open{transform:none;opacity:1;pointer-events:auto}
  .nav-links a:not(.nav-tel){padding:.9rem 0;border-bottom:1px solid var(--grey-line)}
  .nav-links .nav-tel{margin:1rem 0 0;justify-content:center}
  .nav-links a.nav-cta{margin:.7rem 0 0;justify-content:center}
  .has-sub{flex-direction:column;align-items:stretch}
  .has-sub>.nav-top{padding:.9rem 0;border-bottom:1px solid var(--grey-line);justify-content:space-between}
  .has-sub>.nav-top::after{margin-left:auto}
  .submenu{position:static;opacity:1;visibility:visible;transform:none;background:transparent;box-shadow:none;padding:.2rem 0 .6rem .9rem}
  .nav-links .submenu a{color:var(--grey-mid);padding:.6rem 0;border-bottom:1px solid var(--grey-line);border-left:0}
  .nav-links .submenu a:hover{background:transparent;color:var(--orange);border-left:0}
  .nav-links .submenu a.active{background:transparent;color:var(--orange);border-left:0}
  .burger{display:flex}
  .seclabel .note{margin-left:0;text-align:left}
  .formdemo .grow{grid-template-columns:1fr}
}

/* ---------- Page loader ---------- */
.loader{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;
  background:#fff}
.loader.is-hidden{display:none}

/* From Uiverse.io by Nawsome */
.boxes {
  --size: 32px;
  --duration: 800ms;
  height: calc(var(--size) * 2);
  width: calc(var(--size) * 3);
  position: relative;
  transform-style: preserve-3d;
  transform-origin: 50% 50%;
  margin-top: calc(var(--size) * 1.5 * -1);
  transform: rotateX(60deg) rotateZ(45deg) rotateY(0deg) translateZ(0px);
}

.boxes .box {
  width: var(--size);
  height: var(--size);
  top: 0;
  left: 0;
  position: absolute;
  transform-style: preserve-3d;
}

.boxes .box:nth-child(1) {
  transform: translate(100%, 0);
  -webkit-animation: box1 var(--duration) linear infinite;
  animation: box1 var(--duration) linear infinite;
}

.boxes .box:nth-child(2) {
  transform: translate(0, 100%);
  -webkit-animation: box2 var(--duration) linear infinite;
  animation: box2 var(--duration) linear infinite;
}

.boxes .box:nth-child(3) {
  transform: translate(100%, 100%);
  -webkit-animation: box3 var(--duration) linear infinite;
  animation: box3 var(--duration) linear infinite;
}

.boxes .box:nth-child(4) {
  transform: translate(200%, 0);
  -webkit-animation: box4 var(--duration) linear infinite;
  animation: box4 var(--duration) linear infinite;
}

.boxes .box > div {
  --background: #ff4b33;
  --top: auto;
  --right: auto;
  --bottom: auto;
  --left: auto;
  --translateZ: calc(var(--size) / 2);
  --rotateY: 0deg;
  --rotateX: 0deg;
  position: absolute;
  width: 100%;
  height: 100%;
  background: var(--background);
  top: var(--top);
  right: var(--right);
  bottom: var(--bottom);
  left: var(--left);
  transform: rotateY(var(--rotateY)) rotateX(var(--rotateX)) translateZ(var(--translateZ));
}

.boxes .box > div:nth-child(1) {
  --top: 0;
  --left: 0;
}

.boxes .box > div:nth-child(2) {
  --background: #b3331f;
  --right: 0;
  --rotateY: 90deg;
}

.boxes .box > div:nth-child(3) {
  --background: #e0432d;
  --rotateX: -90deg;
}

.boxes .box > div:nth-child(4) {
  --background: #ffb3a8;
  --top: 0;
  --left: 0;
  --translateZ: calc(var(--size) * 3 * -1);
}

@-webkit-keyframes box1 {
  0%, 50% {
    transform: translate(100%, 0);
  }

  100% {
    transform: translate(200%, 0);
  }
}

@keyframes box1 {
  0%, 50% {
    transform: translate(100%, 0);
  }

  100% {
    transform: translate(200%, 0);
  }
}

@-webkit-keyframes box2 {
  0% {
    transform: translate(0, 100%);
  }

  50% {
    transform: translate(0, 0);
  }

  100% {
    transform: translate(100%, 0);
  }
}

@keyframes box2 {
  0% {
    transform: translate(0, 100%);
  }

  50% {
    transform: translate(0, 0);
  }

  100% {
    transform: translate(100%, 0);
  }
}

@-webkit-keyframes box3 {
  0%, 50% {
    transform: translate(100%, 100%);
  }

  100% {
    transform: translate(0, 100%);
  }
}

@keyframes box3 {
  0%, 50% {
    transform: translate(100%, 100%);
  }

  100% {
    transform: translate(0, 100%);
  }
}

@-webkit-keyframes box4 {
  0% {
    transform: translate(200%, 0);
  }

  50% {
    transform: translate(200%, 100%);
  }

  100% {
    transform: translate(100%, 100%);
  }
}

@keyframes box4 {
  0% {
    transform: translate(200%, 0);
  }

  50% {
    transform: translate(200%, 100%);
  }

  100% {
    transform: translate(100%, 100%);
  }
}

@media(prefers-reduced-motion:reduce){.boxes .box{animation:none}}
