/* GutReset Landing — Apple-like, conversion-first, WCAG AA.
   Notes:
   - Desktop content left-aligned; Mobile (360–900px) centered.
   - Hard guard against horizontal overflow.
*/
:root{
  --bg0: #f6f8fb;
  --bg1: #eef3f1;
  --panel: rgba(255,255,255,.75);
  --panel2: rgba(255,255,255,.55);
  --text: #0b1220;
  --muted: rgba(11,18,32,.68);
  --hair: rgba(11,18,32,.10);
  --shadow: 0 18px 55px rgba(0,0,0,.10);
  --shadow2: 0 10px 26px rgba(0,0,0,.08);
  --radius: 22px;
  --radius2: 16px;
  --max: 1120px;

  /* Accents extracted from the label vibe (green/gold). */
  --a1: #1e8f3a;
  --a2: #86e070;
  --a3: #f4c24f;

  --cta0: linear-gradient(135deg, var(--a1), var(--a2));
  --cta1: linear-gradient(135deg, var(--a1), var(--a3));
  --focus: 2px solid rgba(30,143,58,.55);
  --focus2: 0 0 0 4px rgba(134,224,112,.25);
}

html, body { height: 100%; }
html { color-scheme: light; scroll-behavior: smooth; overflow-x: clip; }
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color: var(--text);
  background:
    radial-gradient(1200px 700px at 20% 10%, rgba(134,224,112,.35), transparent 55%),
    radial-gradient(900px 650px at 85% 20%, rgba(244,194,79,.22), transparent 60%),
    radial-gradient(900px 650px at 65% 90%, rgba(30,143,58,.22), transparent 55%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
  overflow-x: clip;
}

[data-theme="dark"]{
  color-scheme: dark;
  --bg0: #060a12;
  --bg1: #0b1020;
  --panel: rgba(10,14,25,.70);
  --panel2: rgba(10,14,25,.55);
  --text: #f5f7ff;
  --muted: rgba(245,247,255,.70);
  --hair: rgba(245,247,255,.12);
  --shadow: 0 22px 70px rgba(0,0,0,.55);
  --shadow2: 0 14px 34px rgba(0,0,0,.35);
  --focus: 2px solid rgba(134,224,112,.60);
  --focus2: 0 0 0 4px rgba(134,224,112,.22);
}

*{ box-sizing: border-box; }
img{ max-width:100%; height:auto; display:block; }
a{ color: inherit; text-decoration: none; }
a:hover{ text-decoration: underline; }
p{ margin: 0 0 12px; color: var(--muted); line-height: 1.6; }
h1,h2,h3{ margin:0 0 10px; letter-spacing: -0.02em; }
h1{ font-size: clamp(2.1rem, 3.2vw, 3.1rem); line-height:1.06; }
h2{ font-size: clamp(1.6rem, 2.0vw, 2.1rem); line-height:1.14; }
h3{ font-size: 1.05rem; line-height:1.2; color: var(--text); }
small{ color: var(--muted); }

.sr-only{
  position:absolute !important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}

.container{
  width: min(var(--max), calc(100% - 40px));
  margin-inline: auto;
}

header{
  position: sticky;
  top:0;
  z-index: 50;
  backdrop-filter: blur(14px);
  background: color-mix(in oklab, var(--panel), transparent 10%);
  border-bottom: 1px solid var(--hair);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 0;
}
.brand{
  display:flex; align-items:center; gap: 10px;
  min-width: 160px;
}
.logo{
  width: 34px; height: 34px;
  border-radius: 12px;
  background: var(--cta0);
  box-shadow: var(--shadow2);
  position:relative;
}
.logo::after{
  content:"";
  position:absolute; inset: 9px;
  border-radius: 9px;
  background: rgba(255,255,255,.22);
}
.wordmark{
  display:flex; flex-direction:column;
  line-height:1.0;
}
.wordmark strong{ font-size: 0.98rem; letter-spacing: -0.02em; }
.wordmark span{ font-size: 0.78rem; color: var(--muted); }


.nav-desktop{
  display:flex; align-items:center; gap: 14px;
  flex-wrap: wrap;
  justify-content:flex-end;
}
.burger{
  display:none;
  padding: 8px 10px;
}
.mobile-nav{
  position: fixed;
  inset: 0;
  z-index: 100;
  display:none;
}
.mobile-nav.is-open{ display:block; }
.mobile-nav__backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.34);
  backdrop-filter: blur(8px);
}
.mobile-nav__panel{
  position:absolute;
  left: 14px;
  right: 14px;
  top: 70px;
  margin-inline:auto;
  width: min(560px, calc(100% - 28px));
  border: 1px solid var(--hair);
  background: color-mix(in oklab, var(--panel), transparent 4%);
  border-radius: 22px;
  box-shadow: var(--shadow);
  padding: 12px;
}
.mobile-nav__top{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  padding: 6px 6px 10px;
}
.mobile-nav__title{ font-weight: 800; letter-spacing: -0.02em; }
.nav-mobile{
  display:flex;
  flex-direction:column;
  gap: 6px;
  padding: 6px;
}
.nav-mobile .navlink{
  font-size: 1rem;
  display:block;
  width:100%;
  color: var(--text);
  background: color-mix(in oklab, var(--panel2), transparent 16%);
  border: 1px solid var(--hair);
  border-radius: 16px;
  padding: 12px 12px;
}
.nav-mobile .navlink:hover{ text-decoration:none; filter: brightness(1.02); }

.navlink{
  font-size: 0.92rem;
  color: var(--muted);
  padding: 8px 10px;
  border-radius: 12px;
}
.navlink:focus-visible{ outline: var(--focus); box-shadow: var(--focus2); }

.controls{
  display:flex; align-items:center; gap: 10px;
}
.btn{
  appearance:none;
  border: 1px solid var(--hair);
  background: color-mix(in oklab, var(--panel2), transparent 18%);
  color: var(--text);
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 600;
  font-size: 0.92rem;
  display:inline-flex; align-items:center; gap: 8px;
  cursor:pointer;
  box-shadow: var(--shadow2);
}
.btn:hover{ filter: brightness(1.02); }
.btn:focus-visible{ outline: var(--focus); box-shadow: var(--focus2); }
.btn--primary{
  border: 0;
  background: var(--cta0);
  color: #04110a;
}
.btn--ghost{
  background: transparent;
  box-shadow:none;
}
.btn--tiny{
  padding: 8px 10px;
  font-size: 0.88rem;
}

.progress{
  position:absolute;
  left:0; right:0; bottom:-1px;
  height: 2px;
  background: linear-gradient(90deg, var(--a2), var(--a3));
  transform-origin:left;
  transform: scaleX(0);
}

main{ overflow-x: clip; }

html.nav-open, html.nav-open body{ overflow: hidden; }


.section{
  padding: 30px 0;
  border-bottom: 1px solid var(--hair);
}
.section--hero{ padding-top: 18px; border-bottom: 0; }
.section--full{ min-height: 100svh; display:flex; flex-direction:column; justify-content:center; align-items:stretch; }
.section--full > .container{ width: min(var(--max), calc(100% - 40px)); }

.section > h1,
.section > h2{
  width: min(var(--max), calc(100% - 40px));
  margin-inline: auto;
}
.section--hero > h1{ margin-bottom: 16px; }
.section > h2{ margin-bottom: 14px; }


.kicker{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid var(--hair);
  background: color-mix(in oklab, var(--panel2), transparent 24%);
  color: var(--muted);
  font-size: 0.92rem;
  margin-bottom: 14px;
}
.kicker .dot{
  width: 10px;height:10px;border-radius:999px;
  background: var(--cta0);
  box-shadow: 0 0 0 4px rgba(134,224,112,.18);
}

.hero-grid{
  display:grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 26px;
  align-items:center;
}
/* HERO (section-level grid): keep H1 in the left column with the copy card */
.section--hero.hero-grid{
  grid-template-rows: auto 1fr;
}
.section--hero.hero-grid > h1{
  grid-column: 1;
  grid-row: 1;
  width: auto;
  margin: 0;
  text-align: left;
  align-self: end;
}
.section--hero.hero-grid > .hero-card{
  grid-column: 1;
  grid-row: 2;
}
.section--hero.hero-grid > .hero-media{
  grid-column: 2;
  grid-row: 1 / span 2;
}

@media (max-width: 900px){
  .section--hero.hero-grid{
    grid-template-rows: auto auto auto;
  }
  .section--hero.hero-grid > h1{
    grid-column: 1;
    grid-row: 1;
    text-align: center;
  }
  .section--hero.hero-grid > .hero-card{ grid-row: 2; }
  .section--hero.hero-grid > .hero-media{
    grid-column: 1;
    grid-row: 3;
  }
}

.hero-card{
  border: 1px solid var(--hair);
  background: var(--panel);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 22px;
  overflow:hidden;
}
.hero-card .actions{
  display:flex; gap: 12px; flex-wrap: wrap;
  margin-top: 16px;
}
.bullets{
  display:grid; gap: 10px;
  margin: 14px 0 0;
  padding:0; list-style:none;
}
.bullets li{
  display:flex; gap: 10px; align-items:flex-start;
  color: var(--muted);
}
.bullets li svg{ flex: 0 0 auto; margin-top: 2px; }
.trust{
  margin-top: 12px;
  font-size: 0.86rem;
  color: var(--muted);
}
.hero-media{
  border-radius: var(--radius);
  border: 1px solid var(--hair);
  background: color-mix(in oklab, var(--panel), transparent 8%);
  box-shadow: var(--shadow);
  padding: 18px;
  position:relative;
  overflow:hidden;
}
.hero-media::before{
  content:"";
  position:absolute; inset:-30%;
  background: radial-gradient(closest-side, rgba(134,224,112,.35), transparent 60%);
  filter: blur(8px);
  transform: rotate(12deg);
}
.hero-media figure{ margin:0; position:relative; }
.hero-media img{
  margin-inline:auto;
  max-height: 520px;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 18px 35px rgba(0,0,0,.28));
}
.hero-media .mask{
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.0), rgba(0,0,0,.08));
  pointer-events:none;
  display:none;
}

.grid-2{
  display:grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 26px;
  align-items:start;
}

.panel{
  border: 1px solid var(--hair);
  background: var(--panel);
  border-radius: var(--radius);
  box-shadow: var(--shadow2);
  padding: 20px;
}

.steps{
  display:grid; gap: 12px;
}
.step{
  border: 1px solid var(--hair);
  background: color-mix(in oklab, var(--panel2), transparent 10%);
  border-radius: 18px;
  padding: 14px;
}
.step[aria-current="true"]{
  border-color: color-mix(in oklab, var(--a2), var(--hair) 35%);
  box-shadow: 0 0 0 4px rgba(134,224,112,.16);
}
.step p{ margin: 6px 0 0; }
.sticky{
  position: sticky;
  top: 86px;
}

.cards{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 14px;
}
.card{
  border: 1px solid var(--hair);
  background: var(--panel);
  border-radius: var(--radius2);
  box-shadow: var(--shadow2);
  padding: 16px;
  display:flex;
  flex-direction: column;
  align-items: stretch;
  min-height: 100%;
}
.card h3{ margin-bottom: 8px; }
.card p{ margin-bottom: 0; }
.card figure{
  margin: 0 0 10px;
  display:flex; justify-content:center; align-items:center;
  min-height: 120px;
}
.card figure img{ object-fit: contain; max-height: 160px; }

.pricing{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.plan{
  border: 1px solid var(--hair);
  background: var(--panel);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 18px;
  display:flex;
  flex-direction: column;
}
.plan .badge{
  display:inline-flex;
  align-self:flex-start;
  padding: 8px 10px;
  border-radius: 999px;
  font-size: 0.82rem;
  border: 1px solid var(--hair);
  background: color-mix(in oklab, var(--panel2), transparent 10%);
  color: var(--muted);
}
.plan figure{
  margin: 12px 0 8px;
  display:flex; justify-content:center; align-items:center;
  min-height: 220px;
}
.plan figure img{ max-height: 240px; object-fit: contain; margin-inline:auto; }
.plan .price{
  font-size: 1.05rem;
  font-weight: 800;
  margin-top: 6px;
}
.plan .total{ margin-top: 6px; }
.plan .save{
  margin-top: 8px;
  display:inline-flex;
  align-items:center;
  gap: 8px;
  color: var(--text);
  font-weight: 700;
}
.plan .cta{
  margin-top:auto;
  padding-top: 14px;
}
.plan .cta a{ width: 100%; justify-content:center; }

.hr{
  height: 1px;
  background: var(--hair);
  margin: 14px 0;
}

details{
  border: 1px solid var(--hair);
  background: color-mix(in oklab, var(--panel2), transparent 12%);
  border-radius: 18px;
  padding: 12px 14px;
}
summary{
  cursor:pointer;
  font-weight: 700;
  color: var(--text);
  list-style:none;
}
summary::-webkit-details-marker{ display:none; }
details[open] summary{ margin-bottom: 10px; }

.accordion{
  display:grid; gap: 10px;
  margin-top: 14px;
}
.ac-item{
  border: 1px solid var(--hair);
  background: var(--panel);
  border-radius: 18px;
  overflow:hidden;
}
.ac-btn{
  width:100%;
  background: transparent;
  border:0;
  padding: 14px 14px;
  display:flex;
  justify-content: space-between;
  align-items:center;
  gap: 10px;
  cursor:pointer;
  color: var(--text);
  font-weight: 800;
  text-align:left;
}
.ac-btn:focus-visible{ outline: var(--focus); box-shadow: var(--focus2); }
.ac-panel{
  padding: 0 14px 14px;
  display:none;
}
.ac-panel[hidden]{ display:none; }
.ac-panel.is-open{ display:block; }

footer{
  padding: 26px 0 40px;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 16px;
}
.footer-links{
  display:flex; flex-wrap: wrap; gap: 10px;
}
.footer-links a{ padding: 8px 10px; border-radius: 12px; border:1px solid var(--hair); background: color-mix(in oklab, var(--panel2), transparent 14%); }
.footer-small{ font-size: 0.86rem; color: var(--muted); margin-top: 10px; }

.lang{
  position: relative;
}
.lang-menu{
  position:absolute;
  right: 0;
  top: calc(100% + 10px);
  width: 210px;
  border: 1px solid var(--hair);
  background: var(--panel);
  border-radius: 18px;
  box-shadow: var(--shadow);
  padding: 6px;
  display:none;
}
.lang-menu[aria-hidden="false"]{ display:block; }
.lang-menu button{
  width:100%;
  border:0;
  background: transparent;
  color: var(--text);
  padding: 10px 10px;
  border-radius: 14px;
  cursor:pointer;
  text-align:left;
  font-weight: 650;
}
.lang-menu button:hover{ background: color-mix(in oklab, var(--panel2), transparent 10%); }
.lang-menu button:focus-visible{ outline: var(--focus); box-shadow: var(--focus2); }

.floating-cta{
  position: fixed;
  left: 14px;
  right: 14px;
  bottom: 14px;
  z-index: 80;
  display:none;
  pointer-events:none;
}
.floating-cta .inner{
  width: min(560px, 100%);
  margin-inline:auto;
  border: 1px solid var(--hair);
  background: color-mix(in oklab, var(--panel), transparent 8%);
  border-radius: 999px;
  box-shadow: var(--shadow);
  padding: 10px;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  pointer-events: auto;
}
.floating-cta .inner .label{
  display:flex; flex-direction:column;
  padding-left: 10px;
}
.floating-cta .inner .label strong{ font-size: 0.95rem; }
.floating-cta .inner .label span{ font-size: 0.78rem; color: var(--muted); }

.reveal{ opacity: 0; transform: translateY(10px); transition: opacity .55s ease, transform .55s ease; }
.reveal.in{ opacity: 1; transform: translateY(0); }

@media (max-width: 900px){
  .section > h1, .section > h2{ text-align:center; }
  .hero-grid, .grid-2{ grid-template-columns: 1fr; }
  .sticky{ position: relative; top: auto; }
  .cards, .pricing{ grid-template-columns: 1fr; }
  .nav-desktop{ display:none; }
  .burger{ display:inline-flex; }
  .hero-media .mask{ display:block; background: linear-gradient(180deg, rgba(0,0,0,.28), rgba(0,0,0,.06)); }
}
@media (min-width: 901px){
  .nav-desktop{ display:flex; }
  .burger{ display:none; }
  .mobile-nav{ display:none !important; }
  .container{ text-align: left; }
}
@media (max-width: 900px){
  .container{ text-align: center; }
  .hero-card .actions{ justify-content:center; }
  .kicker{ justify-content:center; }
  .bullets li{ justify-content:center; text-align:left; }
  .footer-grid{ grid-template-columns: 1fr; }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  .reveal{ transition: none; transform:none; }
}
