/* ============================================================
   1ST CALL BAILIFF HELP — Landing page styles
   Brand: logo green → teal → purple gradient on white
   ============================================================ */

:root{
  /* Brand colours pulled from the logo */
  --green:      #6FC23C;
  --green-deep: #4C9E25;
  --teal:       #2FA6C7;
  --purple:     #7E2DBE;
  --purple-deep:#651FA0;

  /* Signature gradient (matches the shield) */
  --grad: linear-gradient(135deg, var(--green) 0%, var(--teal) 48%, var(--purple) 100%);
  --grad-soft: linear-gradient(135deg, #f3fbed 0%, #eef8fb 50%, #f6effc 100%);

  --ink:    #1b2030;
  --slate:  #4a5163;
  --muted:  #737b8c;
  --line:   #e7e9ef;
  --paper:  #ffffff;
  --wash:   #f7f8fb;

  --radius: 18px;
  --radius-sm: 12px;
  --shadow-sm: 0 2px 10px rgba(27,32,48,.06);
  --shadow:    0 18px 50px -22px rgba(27,32,48,.28);
  --shadow-lg: 0 34px 80px -30px rgba(101,31,160,.42);

  --maxw: 1200px;
  --font-display: "Plus Jakarta Sans", system-ui, sans-serif;
  --font-body: "Mulish", system-ui, sans-serif;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:108px; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.62;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{ font-family:var(--font-display); line-height:1.08; margin:0; letter-spacing:-.02em; color:var(--ink); }
p{ margin:0; }
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }

/* Gradient text & helpers ----------------------------------- */
.grad-text{
  background:var(--grad);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
}
.green{ color:var(--green-deep); }
.purple{ color:var(--purple); }
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--font-display); font-weight:700;
  font-size:13px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--purple);
}
.eyebrow::before{
  content:""; width:26px; height:3px; border-radius:3px; background:var(--grad);
}
.eyebrow.center::after{
  content:""; width:26px; height:3px; border-radius:3px; background:var(--grad);
}

/* Buttons --------------------------------------------------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--font-display); font-weight:800; font-size:16px;
  padding:15px 28px; border-radius:999px; border:0; cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
  white-space:nowrap; line-height:1;
}
.btn svg{ width:18px; height:18px; }
.btn-primary{ background:var(--grad); color:#fff; box-shadow:0 14px 30px -12px rgba(101,31,160,.6); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 20px 40px -12px rgba(101,31,160,.7); }
.btn-ghost{ background:#fff; color:var(--ink); border:1.5px solid var(--line); }
.btn-ghost:hover{ border-color:var(--green); color:var(--green-deep); transform:translateY(-2px); }
.btn-white{ background:#fff; color:var(--purple); box-shadow:var(--shadow-sm); }
.btn-white:hover{ transform:translateY(-2px); }
.btn-wa{ background:#25D366; color:#fff; box-shadow:0 12px 26px -12px rgba(37,211,102,.7); }
.btn-wa:hover{ transform:translateY(-2px); }
.btn-lg{ padding:18px 36px; font-size:18px; }
.btn-block{ width:100%; }

/* ============================================================
   ANNOUNCEMENT BAR
   ============================================================ */
.topbar{
  background:var(--grad); color:#fff;
  font-family:var(--font-display); font-weight:600; font-size:14px;
}
.topbar .wrap{ display:flex; align-items:center; justify-content:center; gap:26px; padding:9px 28px; flex-wrap:wrap; }
.topbar .ti{ display:inline-flex; align-items:center; gap:8px; }
.topbar .ti svg{ width:15px; height:15px; }
.topbar .sep{ opacity:.45; }
@media(max-width:680px){ .topbar .hide-sm{ display:none; } }

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:sticky; top:0; z-index:60;
  background:rgba(255,255,255,.86); backdrop-filter:blur(14px) saturate(1.4);
  border-bottom:1px solid var(--line);
}
.header .wrap{ display:flex; align-items:center; gap:24px; height:78px; }
.brand img{ height:60px; width:auto; }
.nav{ display:flex; gap:30px; margin-left:14px; }
.nav a{
  font-family:var(--font-display); font-weight:600; font-size:15px; color:var(--slate);
  position:relative; padding:4px 0;
}
.nav a:hover{ color:var(--ink); }
.nav a::after{ content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0; background:var(--grad); transition:width .2s ease; border-radius:2px; }
.nav a:hover::after{ width:100%; }
.header-cta{ display:flex; align-items:center; gap:16px; margin-left:auto; }
.header-phone{ display:flex; flex-direction:column; line-height:1.1; text-align:right; }
.header-phone small{ font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); font-weight:700; }
.header-phone b{ font-family:var(--font-display); font-size:20px; color:var(--ink); }
.header-phone b:hover{ color:var(--green-deep); }
.burger{ display:none; background:none; border:0; cursor:pointer; padding:6px; }
.burger span{ display:block; width:24px; height:2.5px; background:var(--ink); border-radius:2px; margin:5px 0; transition:.2s; }
@media(max-width:1040px){ .nav{ display:none; } .burger{ display:block; } }
@media(max-width:860px){
  .header-phone{ display:none; }
}
@media(max-width:560px){ .header-cta .btn-primary{ display:none; } }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; overflow:hidden; padding:70px 0 90px; background:var(--paper); }
.hero::before{
  content:""; position:absolute; top:-220px; right:-180px; width:680px; height:680px; border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(111,194,60,.18), rgba(47,166,199,.12) 45%, transparent 70%);
  filter:blur(8px); z-index:0;
}
.hero::after{
  content:""; position:absolute; bottom:-260px; left:-200px; width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle at 60% 40%, rgba(126,45,190,.16), transparent 68%);
  z-index:0;
}
.hero .wrap{ position:relative; z-index:2; display:grid; grid-template-columns:1.08fr .92fr; gap:56px; align-items:center; }

.hero-badges{ display:flex; gap:10px; flex-wrap:wrap; margin:18px 0 22px; }
.pill{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-display); font-weight:700; font-size:13.5px;
  padding:8px 15px; border-radius:999px; background:#fff; border:1.5px solid var(--line); color:var(--slate);
  box-shadow:var(--shadow-sm);
}
.pill svg{ width:15px; height:15px; color:var(--green-deep); }

.hero h1{ font-size:clamp(38px,5vw,62px); font-weight:800; }
.hero h1 .grad-text{ display:inline; }
.hero-sub{ font-size:19px; color:var(--slate); margin:22px 0 26px; max-width:560px; }
.hero-ticks{ display:grid; grid-template-columns:1fr 1fr; gap:12px 24px; margin:0 0 30px; max-width:540px; }
.tick{ display:flex; align-items:center; gap:11px; font-family:var(--font-display); font-weight:700; font-size:16px; color:var(--ink); }
.tick .ic{
  flex:0 0 26px; width:26px; height:26px; border-radius:50%; display:grid; place-items:center;
  background:var(--grad); color:#fff;
}
.tick .ic svg{ width:14px; height:14px; }
.hero-actions{ display:flex; gap:14px; align-items:center; flex-wrap:wrap; }
.hero-rating{ display:flex; align-items:center; gap:12px; margin-top:26px; }
.stars{ display:inline-flex; gap:2px; color:#ffb400; }
.stars svg{ width:18px; height:18px; }
.hero-rating b{ font-family:var(--font-display); }
.hero-rating span{ color:var(--muted); font-size:14px; }

/* Enquiry form card */
.form-card{
  position:relative; background:#fff; border-radius:24px; padding:32px;
  box-shadow:var(--shadow-lg); border:1px solid var(--line);
}
.form-card::before{
  content:""; position:absolute; inset:0; border-radius:24px; padding:2px;
  background:var(--grad); -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; opacity:.5; pointer-events:none;
}
.form-card h3{ font-size:24px; font-weight:800; }
.form-card .fc-sub{ color:var(--slate); font-size:15px; margin:6px 0 20px; }
.field{ margin-bottom:14px; }
.field label{ display:block; font-family:var(--font-display); font-weight:700; font-size:13px; color:var(--slate); margin-bottom:7px; }
.field input, .field select, .field textarea{
  width:100%; padding:13px 15px; border:1.5px solid var(--line); border-radius:12px;
  font-family:var(--font-body); font-size:16px; color:var(--ink); background:#fff; transition:.16s;
}
.field textarea{ resize:vertical; min-height:80px; }
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--green); box-shadow:0 0 0 4px rgba(111,194,60,.14);
}
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.form-note{ display:flex; align-items:center; gap:8px; justify-content:center; color:var(--muted); font-size:13px; margin-top:14px; }
.form-note svg{ width:14px; height:14px; color:var(--green-deep); }

@media(max-width:980px){
  .hero .wrap{ grid-template-columns:1fr; gap:40px; }
  .hero-ticks{ max-width:none; }
}
@media(max-width:520px){
  .hero-ticks{ grid-template-columns:1fr; }
  .field-row{ grid-template-columns:1fr; }
}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust{ background:var(--ink); color:#fff; }
.trust .wrap{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; padding:34px 28px; }
.trust .ts{ text-align:center; }
.trust .ts b{ font-family:var(--font-display); font-weight:800; font-size:34px; display:block; }
.trust .ts span{ color:#b9bfce; font-size:14px; font-weight:600; }
.trust .ts b .grad-text{ background:var(--grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
@media(max-width:720px){ .trust .wrap{ grid-template-columns:1fr 1fr; gap:26px; } }

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
section{ position:relative; }
.section{ padding:88px 0; }
.section.wash{ background:var(--wash); }
.sec-head{ max-width:720px; margin:0 auto 52px; text-align:center; }
.sec-head.left{ margin-left:0; text-align:left; }
.sec-head h2{ font-size:clamp(30px,3.6vw,46px); font-weight:800; margin:16px 0 0; }
.sec-head p{ color:var(--slate); font-size:18px; margin-top:16px; }
.sec-head.left .eyebrow::after{ display:none; }

/* What we do cards */
.cards-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.svc{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:32px 28px;
  box-shadow:var(--shadow-sm); transition:transform .2s ease, box-shadow .2s ease, border-color .2s;
}
.svc:hover{ transform:translateY(-5px); box-shadow:var(--shadow); border-color:transparent; }
.svc .ic{
  width:62px; height:62px; border-radius:16px; display:grid; place-items:center; margin-bottom:20px;
  background:var(--grad-soft); border:1px solid var(--line);
}
.svc .ic svg{ width:30px; height:30px; }
.svc h3{ font-size:21px; font-weight:800; margin-bottom:10px; }
.svc p{ color:var(--slate); font-size:15.5px; }
@media(max-width:880px){ .cards-3{ grid-template-columns:1fr; } }

/* Steps */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; counter-reset:step; }
.step{ position:relative; background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:34px 28px 30px; box-shadow:var(--shadow-sm); }
.step .num{
  position:absolute; top:-22px; left:28px; width:48px; height:48px; border-radius:14px;
  background:var(--grad); color:#fff; display:grid; place-items:center;
  font-family:var(--font-display); font-weight:800; font-size:22px; box-shadow:var(--shadow-sm);
}
.step h3{ font-size:20px; font-weight:800; margin:14px 0 8px; }
.step p{ color:var(--slate); font-size:15.5px; }
@media(max-width:880px){ .steps{ grid-template-columns:1fr; gap:36px; } }

/* ============================================================
   DO-NOT (dark, eye-catching)
   ============================================================ */
.donot{ background:var(--ink); color:#fff; padding:88px 0; position:relative; overflow:hidden; }
.donot::before{
  content:""; position:absolute; right:-160px; top:-160px; width:520px; height:520px; border-radius:50%;
  background:radial-gradient(circle, rgba(126,45,190,.4), transparent 70%);
}
.donot::after{
  content:""; position:absolute; left:-160px; bottom:-160px; width:480px; height:480px; border-radius:50%;
  background:radial-gradient(circle, rgba(111,194,60,.26), transparent 70%);
}
.donot .wrap{ position:relative; z-index:2; }
.donot .sec-head h2{ color:#fff; }
.donot .sec-head p{ color:#c4cad8; }
.donot-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.dn{
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius:var(--radius);
  padding:30px 26px; backdrop-filter:blur(4px);
}
.dn .ic{ width:54px; height:54px; border-radius:14px; display:grid; place-items:center; margin-bottom:18px; }
.dn.no .ic{ background:rgba(111,194,60,.20); color:#9fe06a; }
.dn.yes .ic{ background:var(--grad); color:#fff; }
.dn .ic svg{ width:26px; height:26px; }
.dn h3{ color:#fff; font-size:19px; font-weight:800; margin-bottom:9px; }
.dn p{ color:#c4cad8; font-size:15px; }
.dn.yes{ background:linear-gradient(135deg, rgba(111,194,60,.16), rgba(126,45,190,.16)); border-color:rgba(111,194,60,.35); }
@media(max-width:900px){ .donot-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:520px){ .donot-grid{ grid-template-columns:1fr; } }

/* ============================================================
   DEBTS
   ============================================================ */
.debts-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.debt{
  display:flex; gap:18px; background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:26px; box-shadow:var(--shadow-sm); transition:transform .2s, box-shadow .2s;
}
.debt:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.debt .ic{ flex:0 0 52px; width:52px; height:52px; border-radius:14px; background:var(--grad-soft); border:1px solid var(--line); display:grid; place-items:center; }
.debt .ic svg{ width:26px; height:26px; }
.debt h3{ font-size:18px; font-weight:800; margin-bottom:6px; }
.debt p{ color:var(--slate); font-size:14.5px; }
.writeoff{
  margin-top:34px; background:var(--grad); border-radius:22px; padding:34px 40px; color:#fff;
  display:flex; align-items:center; justify-content:space-between; gap:28px; flex-wrap:wrap;
  box-shadow:var(--shadow-lg);
}
.writeoff h3{ color:#fff; font-size:26px; font-weight:800; }
.writeoff p{ color:rgba(255,255,255,.9); margin-top:6px; max-width:560px; }
@media(max-width:920px){ .debts-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:600px){ .debts-grid{ grid-template-columns:1fr; } }

/* ============================================================
   WHEN TO GET HELP (split)
   ============================================================ */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; }
.checklist{ display:grid; gap:14px; margin-top:26px; }
.cl{ display:flex; gap:14px; align-items:flex-start; background:#fff; border:1px solid var(--line); border-radius:14px; padding:16px 18px; box-shadow:var(--shadow-sm); }
.cl .ic{ flex:0 0 26px; width:26px; height:26px; border-radius:50%; background:var(--grad); color:#fff; display:grid; place-items:center; margin-top:1px; }
.cl .ic svg{ width:14px; height:14px; }
.cl b{ font-family:var(--font-display); font-size:16px; }
.split-media{ position:relative; }
.split-media .split-img{ width:100%; height:460px; object-fit:cover; border-radius:24px; box-shadow:var(--shadow); }
.split-media .float{
  position:absolute; left:-26px; bottom:30px; background:#fff; border-radius:16px; padding:18px 22px;
  box-shadow:var(--shadow); border:1px solid var(--line); display:flex; align-items:center; gap:14px;
}
.split-media .float .ic{ width:46px; height:46px; border-radius:12px; background:var(--grad); color:#fff; display:grid; place-items:center; }
.split-media .float b{ font-family:var(--font-display); font-size:26px; display:block; line-height:1; }
.split-media .float span{ font-size:13px; color:var(--muted); }
@media(max-width:920px){ .split{ grid-template-columns:1fr; gap:40px; } .split-media .split-img{ height:340px; } }

/* ============================================================
   BAILIFFS WE HANDLE (logo wall)
   ============================================================ */
.logo-wall{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; max-width:980px; margin:0 auto; }
.logo-wall img{ width:100%; height:110px; object-fit:contain; padding:18px; border-radius:14px; background:#fff; border:1px solid var(--line); }
@media(max-width:900px){ .logo-wall{ grid-template-columns:repeat(3,1fr); } }
@media(max-width:560px){ .logo-wall{ grid-template-columns:repeat(2,1fr); } }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.reviews{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.review{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:28px 26px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; }
.review .stars{ margin-bottom:14px; }
.review p{ color:var(--slate); font-size:15px; flex:1; }
.review .who{ display:flex; align-items:center; gap:12px; margin-top:20px; }
.review .av{ width:44px; height:44px; border-radius:50%; background:var(--grad); color:#fff; display:grid; place-items:center; font-family:var(--font-display); font-weight:800; }
.review .who b{ font-family:var(--font-display); display:block; font-size:15px; }
.review .who span{ font-size:12.5px; color:var(--muted); }
@media(max-width:1000px){ .reviews{ grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ .reviews{ grid-template-columns:1fr; } }

/* ============================================================
   FAQ
   ============================================================ */
.faq{ max-width:840px; margin:0 auto; }
.qa{ background:#fff; border:1px solid var(--line); border-radius:14px; margin-bottom:14px; box-shadow:var(--shadow-sm); overflow:hidden; }
.qa summary{
  list-style:none; cursor:pointer; padding:22px 24px; display:flex; align-items:center; gap:16px;
  font-family:var(--font-display); font-weight:700; font-size:18px; color:var(--ink);
}
.qa summary::-webkit-details-marker{ display:none; }
.qa .plus{ margin-left:auto; flex:0 0 28px; width:28px; height:28px; border-radius:50%; background:var(--grad-soft); border:1px solid var(--line); display:grid; place-items:center; transition:.2s; }
.qa .plus svg{ width:15px; height:15px; color:var(--purple); transition:.25s; }
.qa[open] .plus{ background:var(--grad); }
.qa[open] .plus svg{ color:#fff; transform:rotate(45deg); }
.qa .ans{ padding:0 24px 24px; color:var(--slate); font-size:15.5px; }
.qa .ans a{ color:var(--green-deep); font-weight:700; }

/* ============================================================
   CTA
   ============================================================ */
.cta{ padding:90px 0; }
.cta-box{
  position:relative; overflow:hidden; background:var(--grad); border-radius:30px; padding:64px 56px;
  text-align:center; color:#fff; box-shadow:var(--shadow-lg);
}
.cta-box::before{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 80% 20%, rgba(255,255,255,.18), transparent 50%); }
.cta-box > *{ position:relative; z-index:2; }
.cta-box h2{ color:#fff; font-size:clamp(30px,4vw,48px); font-weight:800; max-width:760px; margin:0 auto; }
.cta-box p{ color:rgba(255,255,255,.92); font-size:19px; margin:18px auto 30px; max-width:620px; }
.cta-actions{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
@media(max-width:600px){ .cta{ padding:64px 0; } .cta-box{ padding:44px 24px; border-radius:22px; } }

/* WhatsApp band */
.wa-band{ display:flex; align-items:center; justify-content:center; gap:18px; flex-wrap:wrap; margin-top:34px; color:var(--slate); }
.wa-band p{ font-size:15.5px; max-width:520px; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--ink); color:#c4cad8; padding:70px 0 36px; }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer .brand-f img{ height:54px; margin-bottom:18px; }
.footer .brand-f p{ font-size:14.5px; max-width:360px; }
.footer h4{ color:#fff; font-size:15px; font-family:var(--font-display); margin-bottom:16px; letter-spacing:.04em; }
.footer ul{ list-style:none; padding:0; margin:0; display:grid; gap:2px; }
.footer ul a{ display:inline-block; padding:9px 0; font-size:14.5px; color:#c4cad8; }
.footer ul a:hover{ color:#fff; }
.moneyhelper{ display:flex; align-items:center; gap:16px; margin-top:14px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:14px; padding:16px 18px; }
.moneyhelper .mh-logo{ font-family:var(--font-display); font-weight:800; color:#fff; font-size:15px; line-height:1.2; flex:0 0 auto; }
.moneyhelper .mh-logo span{ display:block; color:var(--green); font-size:12px; }
.moneyhelper p{ font-size:13px; color:#aab0c0; }
.compliance{ font-size:12.5px; color:#8e94a6; line-height:1.7; margin-top:30px; }
.compliance p{ margin-bottom:12px; }
.footer-bottom{ display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-top:24px; font-size:13px; color:#8e94a6; }
@media(max-width:820px){ .footer-top{ grid-template-columns:1fr 1fr; } .footer .brand-f{ grid-column:1/-1; } }
@media(max-width:520px){ .footer-top{ grid-template-columns:1fr; } }

/* Floating WhatsApp button */
.wa-float{
  position:fixed; right:max(22px, env(safe-area-inset-right)); bottom:max(22px, env(safe-area-inset-bottom)); z-index:80;
  width:60px; height:60px; border-radius:50%; background:#25D366; color:#fff;
  display:grid; place-items:center; box-shadow:0 14px 30px -8px rgba(37,211,102,.7);
  transition:transform .2s;
}
.wa-float:hover{ transform:scale(1.07); }
.wa-float svg{ width:32px; height:32px; }

/* Mobile menu */
.mobile-menu{ display:none; position:fixed; inset:0; z-index:90; }
.mobile-menu.open{ display:block; }
.mobile-menu .scrim{ position:absolute; inset:0; background:rgba(27,32,48,.5); }
.mobile-menu .panel{ position:absolute; top:0; right:0; width:min(320px,82vw); height:100%; background:#fff; padding:26px; box-shadow:var(--shadow-lg); display:flex; flex-direction:column; gap:6px; }
.mobile-menu .panel a{ font-family:var(--font-display); font-weight:700; font-size:18px; padding:14px 6px; border-bottom:1px solid var(--line); }
.mobile-menu .panel .btn{ margin-top:18px; }
.mobile-menu .panel .close{ align-self:flex-end; background:none; border:0; font-size:28px; cursor:pointer; color:var(--ink); }

/* reveal on scroll — scoped to .js so content is never hidden if JS fails to run */
.js .reveal{ opacity:0; transform:translateY(24px); transition:opacity .6s ease, transform .6s ease; }
.js .reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .js .reveal{ opacity:1; transform:none; transition:none; }
}
