@charset "UTF-8"; 

/* CSS Document */

/* ===== Palette ===== */
:root{
  --forest-900:#0F2A1F;
  --forest-700:#1B3C2F;
  --forest-100:#DFF6E8;

  --cap:#F0433A;
  --cap-rim:#C0352D;

  --mint:#8CCE94;
  --cream:#F4E8CF;
  --chai:#B58A66;

  --cocoa:#46322A;
  --glow:#FFEAA7;
}

/* ===== Base ===== */
*{ box-sizing:border-box }
html,body{ margin:0 }
body{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
  color: var(--forest-100);
  background: var(--forest-700);
}
.wrapper{ max-width:1200px; width:100%; margin-inline:auto; padding-inline:clamp(16px,4vw,32px) }
.visually-hidden{
  position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden;
  clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* ===== Header / Nav ===== */
.site-header{
  position:sticky; top:0; z-index:100;
  background: rgba(8, 28, 22, .86);
  border-bottom:1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(6px);
}

.logo img{
  filter: drop-shadow(0 1px 0 rgba(0,0,0,.35)) brightness(1.08);
}

.site-header .wrapper{
  width:min(1200px,92vw);
  padding:16px 0;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.logo{ display:inline-flex; align-items:center; text-decoration:none }
.primary-nav{ display:flex; align-items:center; gap:16px; flex-wrap:wrap }
.primary-nav a{
  color:var(--forest-100); text-decoration:none; font-size:.95rem;
  padding:8px 10px; border-radius:10px; opacity:.92;
}
.primary-nav a:hover,.primary-nav a:focus-visible{ opacity:1; background:rgba(255,255,255,.06); outline:none }

.btn{ display:inline-block; padding:10px 16px; border-radius:999px; border:1px solid rgba(255,255,255,.18); background:rgba(255,255,255,.06) }
.btn.cta{ background:var(--forest-100); color:var(--forest-700); border-color:transparent; font-weight:600 }
.btn.cta:hover,.btn.cta:focus-visible{ filter:brightness(.95) }

/* Hamburger */
.hamburger{ display:none; width:44px; height:44px; border:0; background:transparent; cursor:pointer; position:relative; border-radius:8px }
.hamburger:focus-visible{ outline:2px solid rgba(255,255,255,.6); outline-offset:2px }
.hamburger span{ position:absolute; left:10px; right:10px; height:2px; background:var(--forest-100); transition:transform .25s, opacity .2s, top .25s }
.hamburger span:nth-child(1){ top:14px } .hamburger span:nth-child(2){ top:21px } .hamburger span:nth-child(3){ top:28px }
.menu-open .hamburger span:nth-child(1){ top:21px; transform:rotate(45deg) }
.menu-open .hamburger span:nth-child(2){ opacity:0 }
.menu-open .hamburger span:nth-child(3){ top:21px; transform:rotate(-45deg) }

@media (max-width:720px){
  .hamburger{ display:inline-flex; align-items:center; justify-content:center }
  .primary-nav{
    position:fixed; left:0; right:0; top:64px;
    background: rgba(15,42,31,.98); backdrop-filter: blur(6px);
    border-bottom:1px solid rgba(255,255,255,.08);
    display:grid; gap:8px; padding:12px 16px 16px;
    transform:scaleY(0); transform-origin:top; transition:transform .25s; pointer-events:none;
  }
  .menu-open .primary-nav{ transform:scaleY(1); pointer-events:auto }
  .primary-nav a{ display:block; padding:12px 14px; font-size:1rem; border-radius:12px }
  .primary-nav .btn.cta{ justify-self:start }
}

/* ===== Hero ===== */
.hero{
  padding: clamp(32px,6vw,96px) 0;
  background:
    radial-gradient(120% 120% at 50% 0%, rgba(255,255,255,.04), transparent 40%),
    var(--forest-900);
}
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; align-items:center; gap:clamp(24px,4vw,48px) }
.hero-copy h1{
  font-family:Poppins, Inter, system-ui, sans-serif; font-weight:700;
  font-size:clamp(2rem,4.8vw,3.75rem); line-height:1.1; margin:0 0 12px; color:var(--forest-100);
}
.hero-copy .sub{ margin:0 0 20px; font-size:1.05rem; color: color-mix(in oklab, var(--forest-100) 85%, black); max-width:46ch }
.actions{ display:flex; gap:12px; flex-wrap:wrap }
.btn.ghost{ background:transparent; border:1px solid rgba(255,255,255,.28); color:var(--forest-100) }
.btn.ghost:hover,.btn.ghost:focus-visible{ background:rgba(255,255,255,.06) }

@media (max-width:900px){
  .hero-grid{ grid-template-columns:1fr }
  .art-stage{ order:-1; margin-bottom:12px }
}

/* ===== Art Stage (container) ===== */
.art-stage{
  width:min(560px,100%); aspect-ratio:4/3; border-radius:16px; background:var(--forest-700);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.10), 0 20px 40px rgba(0,0,0,.35);
  display:grid; place-items:center; position:relative; overflow:hidden;
}
.art-stage::before{
  content:""; position:absolute; inset:0;
  background: radial-gradient(120% 120% at 50% -20%, rgba(255,255,255,.10), transparent 45%),
              radial-gradient(80% 80% at 50% 120%, rgba(0,0,0,.25), transparent 60%);
  pointer-events:none;
}

/* ===== CSS ART: Frog + Mushroom ===== */
.frog-stage{ place-items:center }
.frog-mush{ --w:320px; --stroke:8px; --blush:#f6b4c2; position:relative; width:var(--w); height:calc(var(--w) * 1.15) }
.frog-mush{ top: 14px; }


/* ground shadow */
.frog-mush .shadow{
  position:absolute; left:50%; bottom: 0; height: 26px; transform:translateX(-50%);
  width:68%; height:22px; border-radius:999px;
  background: radial-gradient(closest-side, rgba(0,0,0,.45), transparent 70%); filter:blur(6px);
}

/* cap back */
.frog-mush .cap-back{
  position:absolute; left:50%; top:-9px; transform:translateX(-50%);
  width:calc(var(--w) * 1.20); height:calc(var(--w) * .58);
  background: linear-gradient(180deg, var(--cap), var(--cap-rim));
  border: var(--stroke) solid var(--cocoa); border-radius:999px; box-shadow: inset 0 10px 0 rgba(255,255,255,.12);
  z-index:33;
}
.frog-mush .cap-back .spots{
  position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(16px 14px at 24% 26%, #FFF7EC 99%, transparent 100%),
    radial-gradient(20px 18px at 54% 20%, #FFF7EC 99%, transparent 100%),
    radial-gradient(18px 16px at 78% 34%, #FFF7EC 99%, transparent 100%),
    radial-gradient(16px 14px at 34% 49%, #FFF7EC 99%, transparent 100%),
    radial-gradient(14px 12px at 64% 48%, #FFF7EC 99%, transparent 100%);
}

/* brim (front) */
.frog-mush .brim{
  position:absolute; left:50%; top: calc(var(--w) * .39); transform:translateX(-50%);
  width:86%; height:13%; background:var(--cream);
  border: var(--stroke) solid var(--cocoa); border-top-width: calc(var(--stroke) * .9);
  border-radius: 0 0 220px 220px / 0 0 140px 140px; overflow:hidden; z-index:48;
}
.frog-mush .brim .gilllines{
  position:absolute; inset:8% 10% 12%;
  background: repeating-conic-gradient(from 180deg at 50% 100%, rgba(70,50,42,.85) 0 6deg, transparent 6deg 18deg);
  opacity:.10;
}
.frog-mush .cap-shadow{
  position:absolute; left:50%; top: calc(var(--w) * .52); transform:translateX(-50%);
  width:76%; height:18px; border-radius:999px; background: radial-gradient(closest-side, rgba(0,0,0,.28), transparent 70%);
  filter:blur(3px); z-index:47; pointer-events:none;
}

/* body */
.frog-mush .body{
  position:absolute; left:50%; bottom:30px; transform:translateX(-50%);
  width:calc(var(--w) * .62); height:calc(var(--w) * .80);
  background:var(--mint); border:var(--stroke) solid var(--cocoa);
  border-radius:44% 44% 36% 36% / 46% 46% 28% 28%; z-index:30;
}

/* pupils */
.frog-mush .pupil{ position:absolute; top:40%; width:26px; height:26px; border-radius:50%; background:var(--cocoa); z-index:36 }
.frog-mush .pupil.left{ left:25% } .frog-mush .pupil.right{ right:25% }
.frog-mush .pupil::after{ content:""; position:absolute; top:18%; left:18%; width:26%; height:26%; border-radius:50%; background:#fff; opacity:.55 }


/* cheeks + mouth + belly */
.frog-mush .blush{ position:absolute; top:46%; width:30px; height:18px; border-radius:999px; background: radial-gradient(closest-side, #f6b4c2, transparent 70%); opacity:.55; z-index:35 }
.frog-mush .blush.left{ left:18% } .blush.right{ right:18% }
.frog-mush .mouth{ position:absolute; left:50%; top:48%; transform:translateX(-50%); width:22%; height:12%; border-bottom: var(--stroke) solid var(--cocoa); border-radius:0 0 999px 999px; z-index:36 }
.frog-mush .belly{ position:absolute; left:50%; bottom:7%; transform:translateX(-50%); width:58%; height:42%; background:#fffdf8; border-radius:50%; z-index:32 }

/* cup */
.frog-mush .cup{ position:absolute; left:50%; top:62%; transform:translateX(-50%); width:40%; height:26%; z-index:33 }
.frog-mush .cup .lip{
  position:absolute; left:50%; top:0; transform:translateX(-50%);
  width:100%; height:28%; background:var(--cream); border:var(--stroke) solid var(--cocoa); border-bottom-width: calc(var(--stroke)*.7);
  border-radius:999px; box-shadow: inset 0 4px 0 rgba(255,255,255,.18); z-index:2;
}
.frog-mush .cup .tea{ position:absolute; left:50%; top:10%; transform:translateX(-50%); width:86%; height:26%; background: color-mix(in oklab, var(--chai) 80%, black 6%); border-radius:999px; z-index:1 }
.frog-mush .cup .bowl{ position:absolute; left:0; right:0; bottom:0; top:18%; background:var(--cream); border:var(--stroke) solid var(--cocoa); border-top-width:0; border-radius:0 0 22px 22px / 0 0 18px 18px }
.frog-mush .cup .handle{ position:absolute; right:-8%; top:34%; width:26%; height:40%; background:var(--cream); border:var(--stroke) solid var(--cocoa); border-left-width:calc(var(--stroke)*.8); border-radius:999px }
.frog-mush .cup .steam{ position:absolute; top:-34%; width:6px; height:36px; left:50%; transform:translateX(-50%); background: linear-gradient(to top, rgba(255,255,255,0), rgba(255,255,255,.6)); border-radius:999px; filter:blur(.4px); animation:wisp 3.8s ease-in-out infinite }
.frog-mush .cup .steam.s1{ left:46%; animation-delay:.2s } .steam.s2{ left:52%; animation-delay:.9s; height:42px } .steam.s3{ left:58%; animation-delay:1.6s; height:34px }
@keyframes wisp{ 0%{ transform:translate(-50%,0) scale(1); opacity:.8 } 60%{ transform:translate(-50%,-14px) scale(1.05); opacity:.5 } 100%{ transform:translate(-50%,-22px) scale(1.1); opacity:.2 } }

/* arms + feet */
.frog-mush .arm{
  position:absolute; top:58%; width:28%; height:28%; border: var(--stroke) solid transparent;
  border-left-color:var(--cocoa); border-bottom-color:var(--cocoa); border-radius:50%; background:none; z-index:36
}
.frog-mush .arm.left{ left:14%; transform:rotate(16deg) }
.frog-mush .arm.right{ right:14%; transform:scaleX(-1) rotate(16deg) }
.frog-mush .foot{ position:absolute; bottom:-6%; width:22%; height:12%; background:var(--mint); border: var(--stroke) solid var(--cocoa); border-radius:22px; z-index:30 }
.frog-mush .foot.left{ left:22% } .frog-mush .foot.right{ right:22% }
.frog-mush .foot { bottom: -5%; }

/* ===== Blends ===== */
.blends{
  padding-block:clamp(32px,6vw,96px);
  background: radial-gradient(120% 120% at 50% -20%, rgba(255,255,255,.03), transparent 50%), var(--forest-900);
  border-top:1px solid rgba(255,255,255,.06);
}
.section-head{ display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:clamp(16px,3vw,24px); flex-wrap:wrap }
.section-head h2{ font-family:Poppins, Inter, system-ui, sans-serif; font-weight:700; font-size:clamp(1.75rem,3.8vw,2.25rem); margin:0; color:var(--forest-100) }
.pills{ display:flex; gap:8px; flex-wrap:wrap }
.pill{ padding:8px 12px; border-radius:999px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); color:var(--forest-100); font:inherit; cursor:pointer }
.pill.is-active{ background:rgba(255,255,255,.12) }

.blend-grid{ display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:clamp(12px,3vw,20px) }
@media (max-width:960px){ .blend-grid{ grid-template-columns:repeat(2,1fr) } }
@media (max-width:640px){ .blend-grid{ grid-template-columns:1fr } }

.blend-card{
  display:grid; grid-template-rows:auto 1fr;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.10); border-radius:16px; overflow:hidden;
  box-shadow:0 8px 24px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.06);
  transition:transform .18s, box-shadow .18s;
}
.blend-card:hover{ transform:translateY(-3px); box-shadow:0 14px 28px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.08) }
.blend-card[hidden]{ display:none !important }

.thumb{ aspect-ratio:16/9; width:100%; position:relative; overflow:hidden }
.thumb::after{ content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(255,255,255,.10), transparent 40%); pointer-events:none }
.thumb img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center; display:block; transform:scale(1); transition:transform .25s }
.blend-card:hover .thumb img{ transform:scale(1.04) }
.thumb--chai{ background: linear-gradient(135deg, color-mix(in oklab, var(--chai) 80%, #000 10%), var(--chai)) }
.thumb--mint{ background: linear-gradient(135deg, color-mix(in oklab, var(--mint) 80%, #000 8%), var(--mint)) }
.thumb--jasmine{ background: linear-gradient(135deg, color-mix(in oklab, var(--cream) 85%, #000 6%), var(--cream)) }

.blend-card .content{ padding:14px 14px 16px; display:grid; gap:10px }
.blend-name{ font-weight:700; margin:0; color:var(--forest-100); font-size:1.05rem }
.meta{ margin:0; opacity:.85; color:var(--forest-100); font-size:.92rem; line-height:1.35 }

/* ===== Story ===== */
.story{
  padding-block:clamp(40px,8vw,120px);
  background: radial-gradient(120% 140% at 0% 0%, rgba(255,255,255,.03), transparent 50%), var(--forest-900);
  border-top:1px solid rgba(255,255,255,.06);
}
.story-grid{ display:grid; grid-template-columns:1.1fr .9fr; align-items:center; gap:clamp(20px,4vw,48px) }
.story-visual{
  position:relative; border-radius:18px; overflow:hidden; background:var(--forest-700);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.10), 0 18px 36px rgba(0,0,0,.35); aspect-ratio:4/3;
}
.story-visual img{ width:100%; height:100%; object-fit:cover; object-position:center; display:block; transform:scale(1); transition:transform .35s }
.story-visual:hover img{ transform:scale(1.03) }
.story-visual::before, .story-visual::after{
  content:""; position:absolute; left:14%; bottom:10%; width:28%; height:36%;
  background: radial-gradient(40% 30% at 50% 70%, rgba(255,255,255,.16), transparent 70%),
              radial-gradient(38% 28% at 60% 40%, rgba(255,255,255,.10), transparent 70%);
  filter:blur(6px); animation:rise 6s linear infinite; pointer-events:none;
}
.story-visual::after{ left:auto; right:12%; bottom:12%; width:22%; height:30%; animation-duration:7.5s; opacity:.9 }
@keyframes rise{ from{ transform:translateY(10%) scale(1); opacity:.85 } to{ transform:translateY(-18%) scale(1.08); opacity:.35 } }

.story-copy .kicker{ margin:0 0 8px; font-size:.9rem; letter-spacing:.12em; text-transform:uppercase; color: color-mix(in oklab, var(--forest-100) 70%, black) }
.story-copy h2{ margin:0 0 10px; font-family:Poppins, Inter, system-ui, sans-serif; font-weight:700; font-size:clamp(1.9rem,4.2vw,2.5rem); color:var(--forest-100) }
.story-copy p{ margin:0 0 14px; max-width:52ch }
.values{ list-style:none; padding:0; margin:8px 0 18px; display:grid; gap:8px }
.values li{ position:relative; padding-left:28px }
.values li::before{ content:""; position:absolute; left:0; top:6px; width:16px; height:16px; border-radius:50%; background:var(--forest-100); box-shadow: inset 0 0 0 6px var(--forest-700) }
@media (max-width:900px){ .story-grid{ grid-template-columns:1fr } .story-visual{ order:-1 } }

/* ===== Reviews (trimmed) ===== */
.reviews{
  padding-block:clamp(32px,6vw,96px);
  background: radial-gradient(140% 120% at 50% -30%, rgba(255,255,255,.03), transparent 50%), var(--forest-900);
  border-top:1px solid rgba(255,255,255,.06);
}
.review-grid{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:clamp(12px,3vw,20px) }
@media (max-width:960px){ .review-grid{ grid-template-columns:repeat(2,1fr) } }
@media (max-width:640px){ .review-grid{ grid-template-columns:1fr } }
.review-card{
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.10); border-radius:16px; padding:14px;
  display:grid; gap:10px; box-shadow:0 8px 24px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.06);
}
.review-head{ display:flex; align-items:center; gap:10px }
.avatar{ width:40px; height:40px; border-radius:50%; border:2px solid rgba(255,255,255,.18); background:var(--forest-100); object-fit:cover; display:block }
.rating{ font-size:18px; letter-spacing:.08em; color:var(--glow); text-shadow:0 1px 0 rgba(0,0,0,.35); position:relative }
.rating .half{ position:absolute; right:0; top:0; bottom:0; width:50%; background:linear-gradient(90deg, transparent 50%, rgba(0,0,0,.35) 50%); -webkit-background-clip:text; background-clip:text; color:transparent }
.review-foot{ display:flex; align-items:center; justify-content:space-between; gap:10px; font-size:.9rem; opacity:.85 }
.blend-pill{ padding:6px 10px; border-radius:999px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12) }

/* ===== Contact ===== */
.contact{
  padding-block:clamp(40px,8vw,120px);
  background: radial-gradient(140% 120% at 50% -30%, rgba(255,255,255,.03), transparent 50%), var(--forest-900);
  border-top:1px solid rgba(255,255,255,.06);
}
.contact-grid{ display:grid; grid-template-columns:1fr 1.2fr; gap:clamp(20px,4vw,48px); align-items:start }
@media (max-width:900px){ .contact-grid{ grid-template-columns:1fr } }
.contact-intro .kicker{ margin:0 0 8px; font-size:.9rem; letter-spacing:.12em; text-transform:uppercase; color: color-mix(in oklab, var(--forest-100) 70%, black) }
.contact-intro h2{ margin:0 0 10px; font-family:Poppins, Inter, system-ui, sans-serif; font-weight:700; font-size:clamp(1.9rem,4.2vw,2.5rem); color:var(--forest-100) }
.contact-ways{ list-style:none; padding:0; margin:12px 0 18px; display:grid; gap:6px }
.contact-ways a{ color:var(--forest-100); text-decoration:underline }
.contact-cards{ display:grid; gap:10px; grid-template-columns:1fr 1fr }
.contact-cards .mini-card{ background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.10); border-radius:14px; padding:12px }
.contact-cards .mini-card strong{ display:block; margin-bottom:4px }
@media (max-width:640px){ .contact-cards{ grid-template-columns:1fr } }

.contact-form{
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.10); border-radius:16px;
  padding:clamp(14px,3vw,18px); box-shadow:0 8px 24px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.06);
}
.contact-form .row{ display:grid; grid-template-columns:1fr 1fr; gap:10px }
@media (max-width:640px){ .contact-form .row{ grid-template-columns:1fr } }
.field{ display:grid; gap:6px }
.field label{ font-size:.92rem; opacity:.9 }
.field .muted{ opacity:.65; font-weight:400 }
.contact-form input[type="text"], .contact-form input[type="email"], .contact-form select, .contact-form textarea{
  width:100%; padding:10px 12px; border-radius:12px; border:1px solid rgba(255,255,255,.18); background:rgba(255,255,255,.06); color:var(--forest-100); outline:none
}
.contact-form textarea{ resize:vertical; min-height:140px }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus{
  border-color: color-mix(in oklab, var(--forest-100) 60%, black); box-shadow: 0 0 0 3px rgba(223,246,232,.15)
}
.check{ display:flex; align-items:center; gap:8px; margin:6px 0 2px }
.check input{ accent-color:var(--forest-100) }
.contact-form .actions{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-top:6px }
.contact-form .form-hint{ margin:0; opacity:.8; font-size:.9rem }
.form-status{ margin:6px 0 0; min-height:1em; opacity:.9 }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden }

/* ===== Footer ===== */
.site-footer{
  margin-top:clamp(24px,6vw,72px);
  background: radial-gradient(120% 120% at 50% -40%, rgba(255,255,255,.04), transparent 50%), var(--forest-700);
  border-top:1px solid rgba(255,255,255,.08); color:var(--forest-100);
}
.footer-grid{ display:grid; grid-template-columns:1.2fr 1fr 1fr 1.4fr; gap:clamp(16px,3vw,32px); padding-block:clamp(24px,5vw,48px) }
.footer-brand .tag{ margin:8px 0 12px; opacity:.9 }
.social{ display:flex; gap:10px; padding:0; margin:0; list-style:none }
.social a{ display:grid; place-items:center; width:36px; height:36px; border-radius:999px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); text-decoration:none; font-size:18px; line-height:1; transition:transform .15s, background .15s }
.social a:hover{ transform:translateY(-2px); background:rgba(255,255,255,.12) }
.footer-head{ margin:4px 0 10px; font-weight:700; font-family:Poppins, Inter, system-ui, sans-serif }
.footer-nav ul{ padding:0; margin:0; list-style:none; display:grid; gap:8px }
.footer-nav a{ color:var(--forest-100); text-decoration:none; opacity:.9 }
.footer-nav a:hover{ opacity:1; text-decoration:underline }
.newsletter .note{ margin:0 0 10px; opacity:.85 }
.subscribe{ display:flex; gap:8px; flex-wrap:wrap }
.subscribe input{ flex:1 1 220px; min-width:0; padding:10px 12px; border-radius:12px; border:1px solid rgba(255,255,255,.18); background:rgba(255,255,255,.06); color:var(--forest-100) }
.subscribe input::placeholder{ color: color-mix(in oklab, var(--forest-100) 75%, black) }

.footer-bar{ border-top:1px solid rgba(255,255,255,.08); background: color-mix(in oklab, var(--forest-700) 90%, black) }
.bar-grid{ padding-block:12px; display:flex; align-items:center; justify-content:space-between; gap:12px }
.bar-grid small{ opacity:.8 }
.to-top{ color:var(--forest-100); text-decoration:none; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); padding:6px 10px; border-radius:999px }
.to-top:hover{ background:rgba(255,255,255,.12) }

/* Footer responsive */
@media (max-width:980px){ .footer-grid{ grid-template-columns:1fr 1fr } }
@media (max-width:640px){ .footer-grid{ grid-template-columns:1fr } .bar-grid{ flex-direction:column; align-items:flex-start } }


