/* ==========================================================================
   LENTORAX — Hair Colour Company  |  Design System
   Theme: Emerald / Lime on near-black  ·  Green + Black
   Self-contained. No Bootstrap. Vanilla CSS.
   ========================================================================== */

/* ---------- Design tokens ---------- */
:root{
  --bg:            #05090710;         /* placeholder, overridden below */
  --bg:            #060A08;
  --bg-2:          #0A110D;
  --surface:       #0E1712;
  --surface-2:     #12201A;
  --surface-3:     #16281F;
  --line:          rgba(255,255,255,.08);
  --line-strong:   rgba(255,255,255,.14);

  --green:         #22C55E;
  --green-bright:  #4ADE80;
  --green-soft:    #86EFAC;
  --lime:          #BEF264;
  --green-deep:    #052E16;
  --green-ink:     #03150B;

  --text:          #E9F1EB;
  --muted:         #93A79B;
  --muted-2:       #6E8377;

  --grad: linear-gradient(120deg, var(--lime) 0%, var(--green-bright) 45%, var(--green) 100%);
  --grad-soft: linear-gradient(135deg, rgba(74,222,128,.16), rgba(34,197,94,.04));
  --glow: 0 0 0 1px rgba(74,222,128,.25), 0 18px 50px -12px rgba(34,197,94,.55);

  --radius:   18px;
  --radius-lg: 26px;
  --radius-sm: 12px;

  --shadow:    0 24px 60px -24px rgba(0,0,0,.7);
  --container: 1200px;

  --font-display: "Space Grotesk", "Segoe UI", system-ui, sans-serif;
  --font-body:    "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  --ease: cubic-bezier(.2,.7,.2,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  font-size:16px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; line-height:1.1; margin:0; letter-spacing:-.02em; }
p{ margin:0; }
ul{ margin:0; padding:0; list-style:none; }
::selection{ background:var(--green-bright); color:var(--green-ink); }

/* Ambient page background glow */
body::before{
  content:""; position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(60vw 60vw at 82% -8%, rgba(34,197,94,.18), transparent 60%),
    radial-gradient(45vw 45vw at 0% 40%, rgba(74,222,128,.08), transparent 60%),
    radial-gradient(50vw 50vw at 50% 120%, rgba(34,197,94,.10), transparent 60%);
}
body::after{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.4;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 0%, #000 30%, transparent 75%);
}

/* ---------- Layout helpers ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:24px; }
.section{ padding:110px 0; position:relative; }
.section--tight{ padding:72px 0; }
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--font-display); font-size:.78rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase; color:var(--green-bright);
  padding:7px 15px; border:1px solid var(--line-strong); border-radius:100px;
  background:var(--grad-soft);
}
.eyebrow::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--green-bright); box-shadow:0 0 12px var(--green-bright); }
.section-head{ max-width:660px; margin-bottom:56px; }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-title{ font-size:clamp(2rem, 4.5vw, 3.25rem); margin:20px 0 16px; }
.section-title .g{ background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.lead{ color:var(--muted); font-size:1.075rem; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--font-display); font-weight:600; font-size:.98rem; letter-spacing:.01em;
  padding:15px 28px; border-radius:100px; border:1px solid transparent;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s, color .25s;
  white-space:nowrap;
}
.btn svg{ width:18px; height:18px; }
.btn-primary{ background:var(--grad); color:var(--green-ink); box-shadow:var(--glow); }
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 0 0 1px rgba(74,222,128,.4), 0 26px 60px -14px rgba(34,197,94,.75); }
.btn-ghost{ background:rgba(255,255,255,.03); color:var(--text); border-color:var(--line-strong); backdrop-filter:blur(6px); }
.btn-ghost:hover{ transform:translateY(-3px); border-color:var(--green); background:rgba(34,197,94,.08); }
.btn-lg{ padding:18px 36px; font-size:1.05rem; }

/* ---------- Navbar ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  transition:padding .3s var(--ease), background .3s, border-color .3s, backdrop-filter .3s;
  padding:22px 0;
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.nav.scrolled{
  padding:12px 0;
  background:rgba(6,10,8,.72);
  backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--line);
}
.brand{ display:flex; align-items:center; gap:11px; font-family:var(--font-display); font-weight:700; font-size:1.35rem; letter-spacing:.02em; }
.brand .mark{
  width:34px; height:34px; border-radius:9px; display:grid; place-items:center;
  background:var(--grad); color:var(--green-ink); font-weight:700; font-size:1.15rem;
  box-shadow:0 8px 22px -8px rgba(34,197,94,.8);
}
.brand .reg{ font-size:.62em; vertical-align:super; color:var(--green-bright); font-weight:600; }
.nav-links{ display:flex; align-items:center; gap:6px; }
.nav-links a{
  font-size:.94rem; font-weight:500; color:var(--muted); padding:9px 15px; border-radius:100px;
  transition:color .2s, background .2s;
}
.nav-links a:hover{ color:var(--text); background:rgba(255,255,255,.05); }
.nav-cta{ display:flex; align-items:center; gap:12px; }
.nav-toggle{ display:none; background:none; border:1px solid var(--line-strong); border-radius:10px; padding:9px; color:var(--text); }
.nav-toggle svg{ width:22px; height:22px; }

/* ---------- Hero ---------- */
.hero{ position:relative; padding:190px 0 90px; overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center; }
.hero h1{ font-size:clamp(2.6rem, 6vw, 4.6rem); line-height:1.02; margin-bottom:24px; }
.hero h1 .g{ background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero .lead{ font-size:1.18rem; max-width:520px; margin-bottom:34px; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:40px; }
.hero-trust{ display:flex; flex-wrap:wrap; gap:26px; }
.hero-trust .t{ display:flex; align-items:center; gap:10px; color:var(--muted); font-size:.92rem; }
.hero-trust svg{ width:20px; height:20px; color:var(--green-bright); flex:none; }

/* Hero visual */
.hero-visual{ position:relative; }
.hero-visual .halo{
  position:absolute; inset:-8% -6% -8% -6%; z-index:0; border-radius:50%;
  background:radial-gradient(circle at 50% 45%, rgba(74,222,128,.35), rgba(34,197,94,.08) 45%, transparent 70%);
  filter:blur(10px); animation:pulse 6s var(--ease) infinite;
}
.hero-visual .stage{
  position:relative; z-index:1; border-radius:var(--radius-lg);
  background:linear-gradient(160deg, var(--surface-2), var(--surface));
  border:1px solid var(--line); padding:22px; box-shadow:var(--shadow);
  overflow:hidden;
}
.hero-visual .stage::before{
  content:""; position:absolute; inset:0; background:
    radial-gradient(70% 60% at 70% 10%, rgba(190,242,100,.14), transparent 60%);
}
.hero-visual img{ position:relative; border-radius:14px; width:100%; height:460px; object-fit:contain; background:linear-gradient(160deg,#f6f8f4,#e8ece7); }
.hero-badge{
  position:absolute; z-index:2; display:flex; align-items:center; gap:12px;
  background:rgba(10,17,13,.82); backdrop-filter:blur(12px);
  border:1px solid var(--line-strong); border-radius:16px; padding:14px 18px; box-shadow:var(--shadow);
}
.hero-badge .n{ font-family:var(--font-display); font-weight:700; font-size:1.5rem; background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero-badge .l{ font-size:.78rem; color:var(--muted); line-height:1.3; }
.hero-badge.b1{ top:26px; left:-26px; }
.hero-badge.b2{ bottom:30px; right:-22px; }
@keyframes pulse{ 0%,100%{ transform:scale(1); opacity:.9 } 50%{ transform:scale(1.05); opacity:1 } }

/* ---------- Marquee ---------- */
.marquee{ border-block:1px solid var(--line); background:rgba(255,255,255,.015); overflow:hidden; padding:20px 0; }
.marquee-track{ display:flex; gap:56px; width:max-content; animation:scroll 32s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee .item{ display:flex; align-items:center; gap:12px; font-family:var(--font-display); font-weight:600; font-size:1.05rem; color:var(--muted); white-space:nowrap; }
.marquee .item svg{ width:20px; height:20px; color:var(--green-bright); }
.marquee .dot{ color:var(--green); }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* ---------- Bento product grid ---------- */
.bento{ display:grid; grid-template-columns:repeat(6,1fr); gap:22px; }
.card{
  position:relative; border-radius:var(--radius-lg); border:1px solid var(--line);
  background:linear-gradient(165deg, var(--surface-2), var(--surface));
  padding:32px; overflow:hidden; transition:transform .4s var(--ease), border-color .4s, box-shadow .4s;
}
.card:hover{ transform:translateY(-6px); border-color:rgba(74,222,128,.4); box-shadow:var(--shadow); }
.card .tag{ display:inline-block; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--green-bright); font-family:var(--font-display); font-weight:600; margin-bottom:14px; }
.card h3{ font-size:1.5rem; margin-bottom:10px; }
.card p{ color:var(--muted); font-size:.96rem; }
.card .card-media{ margin:-32px -32px 24px; height:230px; overflow:hidden; background:var(--green-ink); }
.card .card-media img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.card:hover .card-media img{ transform:scale(1.06); }
.card .link{ display:inline-flex; align-items:center; gap:8px; margin-top:18px; color:var(--green-bright); font-weight:600; font-family:var(--font-display); font-size:.95rem; }
.card .link svg{ width:16px; height:16px; transition:transform .25s; }
.card:hover .link svg{ transform:translateX(4px); }
.col-4{ grid-column:span 4; } .col-3{ grid-column:span 3; } .col-2{ grid-column:span 2; } .col-6{ grid-column:span 6; }

/* Feature mini-cards */
.feature-card{ display:flex; flex-direction:column; gap:14px; }
.feature-card .ico{
  width:52px; height:52px; border-radius:14px; display:grid; place-items:center; flex:none;
  background:var(--grad-soft); border:1px solid var(--line-strong); color:var(--green-bright);
}
.feature-card .ico svg{ width:26px; height:26px; }
.feature-card h4{ font-size:1.18rem; }

/* Flagship — horizontal product showcase (product shown in full, not cropped) */
.product-hero{ padding:0; }
.product-hero .ph-grid{ display:grid; grid-template-columns:.92fr 1.08fr; align-items:stretch; }
.product-hero .media{
  background:linear-gradient(160deg,#f6f8f4,#e7ebe6);
  display:grid; place-items:center; padding:26px; border-right:1px solid var(--line);
}
.product-hero .media img{ width:100%; height:100%; max-height:340px; object-fit:contain; }
.product-hero .copy{ padding:38px 40px; align-self:center; }
.product-hero .copy h3{ font-size:1.6rem; }

/* 4-up feature row under the flagship */
.features4{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; margin-top:22px; }

/* ---------- Process steps ---------- */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; position:relative; }
.step{
  position:relative; border-radius:var(--radius-lg); border:1px solid var(--line);
  background:linear-gradient(170deg, var(--surface-2), var(--surface)); overflow:hidden;
  transition:transform .4s var(--ease), border-color .4s;
}
.step:hover{ transform:translateY(-6px); border-color:rgba(74,222,128,.35); }
.step .num{
  position:absolute; top:16px; left:16px; z-index:2; width:42px; height:42px; border-radius:12px;
  display:grid; place-items:center; font-family:var(--font-display); font-weight:700; font-size:1.15rem;
  background:var(--grad); color:var(--green-ink); box-shadow:0 10px 24px -8px rgba(34,197,94,.8);
}
.step .media{ height:210px; overflow:hidden; }
.step .media img{ width:100%; height:100%; object-fit:cover; }
.step .body{ padding:24px 26px 30px; }
.step h4{ font-size:1.28rem; margin-bottom:8px; }
.step p{ color:var(--muted); font-size:.95rem; }
.step-time{ display:inline-flex; align-items:center; gap:8px; margin-top:16px; color:var(--green-bright); font-family:var(--font-display); font-weight:600; font-size:.9rem; }

/* ---------- Ingredients ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.ingredient-list{ display:grid; gap:16px; margin-top:8px; }
.ingredient{
  display:flex; gap:18px; padding:22px; border-radius:var(--radius); border:1px solid var(--line);
  background:rgba(255,255,255,.02); transition:border-color .3s, background .3s;
}
.ingredient:hover{ border-color:rgba(74,222,128,.35); background:rgba(34,197,94,.05); }
.ingredient .ico{ width:48px; height:48px; border-radius:12px; flex:none; display:grid; place-items:center; background:var(--grad-soft); border:1px solid var(--line-strong); color:var(--green-bright); }
.ingredient .ico svg{ width:24px; height:24px; }
.ingredient h4{ font-size:1.12rem; margin-bottom:4px; }
.ingredient p{ color:var(--muted); font-size:.92rem; }
.split-visual{ position:relative; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow); background:linear-gradient(160deg,#f6f8f4,#e7ebe6); }
.split-visual img{ width:100%; height:520px; object-fit:contain; }
.split-visual .tint{ position:absolute; inset:auto 0 0 0; height:45%; background:linear-gradient(to top, rgba(3,21,11,.55), transparent); }
.split-visual .cap{ position:absolute; left:20px; right:20px; bottom:20px; background:rgba(6,10,8,.78); backdrop-filter:blur(8px); border:1px solid var(--line-strong); border-radius:14px; padding:16px 18px; }
.split-visual .cap h3{ font-size:1.5rem; margin-bottom:6px; }
.split-visual .cap p{ color:var(--green-soft); font-size:.95rem; }

/* ---------- Shades ---------- */
.shades{ display:flex; flex-wrap:wrap; gap:22px; justify-content:center; }
.shade{ text-align:center; transition:transform .3s var(--ease); }
.shade:hover{ transform:translateY(-6px); }
.shade .swatch{
  width:104px; height:104px; border-radius:50%; margin:0 auto 14px; position:relative;
  border:2px solid var(--line-strong); box-shadow:inset 0 -14px 26px rgba(0,0,0,.5), 0 16px 32px -14px rgba(0,0,0,.7);
}
.shade .swatch::after{ content:""; position:absolute; top:16%; left:20%; width:34%; height:24%; border-radius:50%; background:radial-gradient(circle, rgba(255,255,255,.35), transparent 70%); }
.shade .name{ font-family:var(--font-display); font-weight:600; font-size:.98rem; }
.shade .avail{ font-size:.78rem; color:var(--muted-2); }
.shade.soon{ opacity:.55; }

/* ---------- Stats ---------- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.stat{ text-align:center; padding:34px 20px; border-radius:var(--radius); border:1px solid var(--line); background:linear-gradient(170deg, var(--surface-2), var(--surface)); }
.stat .n{ font-family:var(--font-display); font-weight:700; font-size:clamp(2.1rem,4vw,2.9rem); background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.stat .l{ color:var(--muted); font-size:.92rem; margin-top:6px; }

/* ---------- Comparison ---------- */
.compare{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.compare .col-c{ padding:32px; border-radius:var(--radius-lg); border:1px solid var(--line); }
.compare .them{ background:rgba(255,255,255,.02); }
.compare .us{ background:linear-gradient(160deg, rgba(34,197,94,.12), rgba(34,197,94,.02)); border-color:rgba(74,222,128,.4); }
.compare h4{ font-size:1.25rem; margin-bottom:20px; display:flex; align-items:center; gap:10px; }
.compare ul li{ display:flex; gap:12px; padding:11px 0; border-top:1px solid var(--line); color:var(--muted); font-size:.96rem; }
.compare ul li:first-child{ border-top:none; }
.compare svg{ width:20px; height:20px; flex:none; margin-top:2px; }
.compare .us svg{ color:var(--green-bright); }
.compare .them svg{ color:var(--muted-2); }

/* ---------- Dealership CTA ---------- */
.cta-band{ position:relative; border-radius:var(--radius-lg); overflow:hidden; padding:66px 56px; border:1px solid rgba(74,222,128,.3);
  background:linear-gradient(120deg, rgba(34,197,94,.16), rgba(5,46,22,.5)); }
.cta-band::before{ content:""; position:absolute; inset:0; z-index:0;
  background:radial-gradient(50% 120% at 90% 10%, rgba(190,242,100,.22), transparent 60%); }
.cta-band .inner{ position:relative; z-index:1; display:flex; align-items:center; justify-content:space-between; gap:36px; flex-wrap:wrap; }
.cta-band h2{ font-size:clamp(1.8rem,3.6vw,2.7rem); max-width:640px; }
.cta-band p{ color:var(--green-soft); margin-top:12px; max-width:520px; }

/* ---------- Contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:26px; }
.contact-card{ padding:32px; border-radius:var(--radius-lg); border:1px solid var(--line); background:linear-gradient(170deg,var(--surface-2),var(--surface)); }
.contact-item{ display:flex; gap:16px; padding:16px 0; border-top:1px solid var(--line); }
.contact-item:first-of-type{ border-top:none; }
.contact-item .ico{ width:46px; height:46px; border-radius:12px; flex:none; display:grid; place-items:center; background:var(--grad-soft); border:1px solid var(--line-strong); color:var(--green-bright); }
.contact-item .ico svg{ width:22px; height:22px; }
.contact-item .k{ font-size:.8rem; color:var(--muted-2); text-transform:uppercase; letter-spacing:.12em; }
.contact-item .v{ font-family:var(--font-display); font-weight:600; font-size:1.08rem; }
.field{ margin-bottom:16px; }
.field label{ display:block; font-size:.85rem; color:var(--muted); margin-bottom:7px; }
.field input,.field textarea{
  width:100%; padding:14px 16px; border-radius:12px; border:1px solid var(--line-strong);
  background:rgba(255,255,255,.03); color:var(--text); font-family:inherit; font-size:.96rem; transition:border-color .2s, background .2s;
}
.field input:focus,.field textarea:focus{ outline:none; border-color:var(--green); background:rgba(34,197,94,.06); }
.field textarea{ resize:vertical; min-height:120px; }

/* ---------- Footer ---------- */
.footer{ border-top:1px solid var(--line); padding:74px 0 34px; background:var(--bg-2); }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; }
.footer h5{ font-family:var(--font-display); font-size:.82rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted-2); margin-bottom:18px; }
.footer-links li{ margin-bottom:11px; }
.footer-links a{ color:var(--muted); font-size:.95rem; transition:color .2s; }
.footer-links a:hover{ color:var(--green-bright); }
.footer .about{ color:var(--muted); font-size:.95rem; max-width:320px; margin:16px 0 22px; }
.socials{ display:flex; gap:12px; }
.socials a{ width:42px; height:42px; border-radius:12px; display:grid; place-items:center; border:1px solid var(--line-strong); color:var(--muted); transition:all .25s; }
.socials a:hover{ color:var(--green-ink); background:var(--grad); border-color:transparent; transform:translateY(-3px); }
.socials svg{ width:18px; height:18px; }
.footer-bottom{ margin-top:56px; padding-top:26px; border-top:1px solid var(--line); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; color:var(--muted-2); font-size:.88rem; }
.footer-bottom a{ color:var(--green-bright); }

/* ---------- Scroll to top ---------- */
.to-top{ position:fixed; right:26px; bottom:26px; z-index:90; width:48px; height:48px; border-radius:14px;
  display:grid; place-items:center; background:var(--grad); color:var(--green-ink); border:none;
  box-shadow:var(--glow); opacity:0; transform:translateY(16px); pointer-events:none; transition:all .3s var(--ease); }
.to-top.show{ opacity:1; transform:none; pointer-events:auto; }
.to-top svg{ width:22px; height:22px; }

/* ---------- Scroll reveal ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s } .reveal.d2{ transition-delay:.16s } .reveal.d3{ transition-delay:.24s } .reveal.d4{ transition-delay:.32s }

/* ---------- Responsive ---------- */
@media (max-width: 980px){
  .hero-grid{ grid-template-columns:1fr; gap:48px; }
  .hero-visual{ max-width:520px; margin-inline:auto; }
  .split{ grid-template-columns:1fr; gap:36px; }
  .split-visual img{ height:400px; }
  .stats{ grid-template-columns:repeat(2,1fr); }
  .compare{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:34px; }
  .col-4,.col-3,.col-2{ grid-column:span 3; }
  .bento{ grid-template-columns:repeat(6,1fr); }
  .product-hero .ph-grid{ grid-template-columns:1fr; }
  .product-hero .media{ border-right:none; border-bottom:1px solid var(--line); }
  .features4{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:1fr; max-width:460px; margin-inline:auto; }
  .nav-links, .nav-cta .btn-ghost{ display:none; }
  .nav-toggle{ display:inline-flex; }
}
@media (max-width: 620px){
  .section{ padding:76px 0; }
  .hero{ padding:150px 0 60px; }
  .bento .card{ grid-column:span 6; }
  .features4{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:1fr 1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .cta-band{ padding:44px 26px; }
  .hero-badge.b1{ left:8px; } .hero-badge.b2{ right:8px; }
  .split-visual img{ height:320px; }
}

/* ---------- Mobile menu panel ---------- */
.mobile-menu{
  position:fixed; inset:0 0 0 auto; width:min(82vw,340px); z-index:120;
  background:var(--bg-2); border-left:1px solid var(--line); padding:26px 24px;
  transform:translateX(100%); transition:transform .35s var(--ease); display:flex; flex-direction:column; gap:6px;
}
.mobile-menu.open{ transform:none; box-shadow:-30px 0 60px rgba(0,0,0,.6); }
.mobile-menu a{ padding:14px 12px; border-radius:12px; font-family:var(--font-display); font-weight:500; color:var(--text); border-bottom:1px solid var(--line); }
.mobile-menu a:hover{ background:rgba(34,197,94,.08); color:var(--green-bright); }
.mobile-menu .close{ align-self:flex-end; background:none; border:1px solid var(--line-strong); border-radius:10px; padding:8px; color:var(--text); margin-bottom:14px; }
.mobile-menu .close svg{ width:20px; height:20px; }
.overlay-bg{ position:fixed; inset:0; z-index:110; background:rgba(0,0,0,.55); backdrop-filter:blur(3px); opacity:0; pointer-events:none; transition:opacity .3s; }
.overlay-bg.show{ opacity:1; pointer-events:auto; }

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
}
