/*
  Neubrutalism, high contrast, zero deps.
  Tokens live in /tokens.json (documented in /A11Y.md).
*/

:root{
  --bg:#F7F2EA;
  --surface:#FFFFFF;
  --text:#121212;
  --muted:#2B2B2B;
  --border:#111111;
  --accent:#D7181F;
  --accentText:#FFFFFF;
  --chipBg:#111111;
  --chipText:#F7F2EA;
  --focus:#111111;
  --navBg: rgba(247,242,234,.92);
  --surfaceTint: rgba(255,255,255,.85);
  --surfaceTint2: rgba(255,255,255,.55);
  --accentSoft: rgba(215,24,31,.10);
  --accentSoft2: rgba(215,24,31,.16);
  --accentHover:#B00014;

  --r-s:10px;
  --r-m:16px;
  --r-l:22px;

  --shadow-neo: 8px 8px 0 rgba(0,0,0,.9);

  --section-y:30px;
  --container-x: min(1100px, calc(100% - 32px));

  --ease-out:cubic-bezier(.2,.8,.2,1);
  --ease-snap:cubic-bezier(.2,1,.2,1);
}

html[data-theme="dark"]{
  --bg:#0B0C10;
  --surface:#111218;
  --text:#F5F5F5;
  --muted:#D6D6D6;
  --border:#F5F5F5;
  --accent:#D7181F;
  --accentText:#FFFFFF;
  --chipBg:#F7F2EA;
  --chipText:#111111;
  --focus:#F7F2EA;
  --navBg: rgba(11,12,16,.88);
  --surfaceTint: rgba(17,18,24,.75);
  --surfaceTint2: rgba(17,18,24,.55);
  --accentSoft: rgba(215,24,31,.16);
  --accentSoft2: rgba(215,24,31,.24);
  --accentHover:#B00014;

  --shadow-neo: 8px 8px 0 rgba(0,0,0,.65);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  background: var(--bg);
  color: var(--text);
  line-height: 1.5;
  text-rendering: optimizeLegibility;
}

img{max-width:100%;height:auto;display:block;margin-inline:auto}

a{color:inherit}

.container{width:var(--container-x); margin-inline:auto}

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

.skip-link{
  position:absolute;
  left:12px;
  top:12px;
  padding:10px 12px;
  background: var(--surface);
  border:3px solid var(--border);
  border-radius: var(--r-s);
  box-shadow: var(--shadow-neo);
  transform: translateY(-160%);
  transition: transform .2s var(--ease-snap);
  z-index: 9999;
}
.skip-link:focus{transform: translateY(0)}

/* NAV */
.nav{
  position: sticky;
  top: 0;
  z-index: 1000;
  border-bottom: 3px solid var(--border);
  background: var(--navBg);
  backdrop-filter: blur(10px);
}

.nav-inner{
  width: var(--container-x);
  margin-inline: auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 12px 0;
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
}
.brand img{height:28px; width:auto}

.nav-toggle{
  display:none;
  border:3px solid var(--border);
  background: var(--surface);
  color: var(--text);
  border-radius: var(--r-s);
  width: 44px;
  height: 44px;
  box-shadow: var(--shadow-neo);
  cursor:pointer;
}
.nav-toggle:focus-visible{outline:4px solid var(--focus); outline-offset:3px}

.nav-links{
  display:flex;
  align-items:center;
  gap:14px;
}

.nav-links a{
  text-decoration:none;
  padding: 10px 12px;
  border-radius: var(--r-s);
  border: 2px solid transparent;
}
.nav-links a:hover{background: var(--surfaceTint)}
.nav-links a:focus-visible{outline:4px solid var(--focus); outline-offset:3px; background:var(--surface)}

.controls{display:flex; align-items:center; gap:10px}
.ctrl-btn{
  display:flex;
  align-items:center;
  gap:8px;
  padding: 10px 12px;
  border:3px solid var(--border);
  border-radius: var(--r-s);
  background: var(--surface);
  color: var(--text);
  box-shadow: var(--shadow-neo);
  cursor:pointer;
}
.ctrl-btn:hover{transform: translate(-1px,-1px)}
.ctrl-btn:active{transform: translate(1px,1px); box-shadow:none}
.ctrl-btn:focus-visible{outline:4px solid var(--focus); outline-offset:3px}

.ctrl-label{font-size: 12px; font-weight:800; letter-spacing:.02em; text-transform:uppercase}
.ctrl-value{font-weight:800}
.ctrl-ico{opacity:.9}

.lang{position:relative}
.menu{
  position:absolute;
  right:0;
  top: calc(100% + 10px);
  min-width: 240px;
  background: var(--surface);
  border:3px solid var(--border);
  border-radius: var(--r-m);
  box-shadow: var(--shadow-neo);
  padding: 8px;
  display:none;
}
.menu[data-open="true"]{display:block}
.menu-item{
  width:100%;
  text-align:left;
  padding: 10px 10px;
  border-radius: 12px;
  border:2px solid transparent;
  background: transparent;
  color: var(--text);
  cursor:pointer;
  font-weight: 800;
}
.menu-item:hover{background: var(--accentSoft)}
.menu-item[aria-selected="true"]{border-color: var(--border); background: var(--accentSoft2)}
.menu-item:focus-visible{outline:4px solid var(--focus); outline-offset:3px}

.progress{height: 6px; background: var(--surfaceTint2)}
.progress-bar{height:100%; width:0%; background: var(--accent)}

/* HERO */
.hero{
  position:relative;
  overflow:hidden;
  border-bottom:3px solid var(--border);
}
.hero-bg{
  position:absolute;
  inset:0;
  pointer-events:none;
}
.hero-bg-blur{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter: blur(18px);
  transform: scale(1.06);
  opacity: .12;
}
.hero-bg-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity: .08;
  filter: saturate(.85) contrast(1.05);
}
.hero::before{
  content:"";
  position:absolute;
  inset:-20px;
  background:
    radial-gradient(800px 420px at 15% 10%, rgba(215,24,31,.18), transparent 60%),
    radial-gradient(900px 520px at 90% 30%, rgba(17,17,17,.10), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.14), transparent);
  opacity: 1;
  pointer-events:none;
}

.hero-grid{
  position:relative;
  padding: 28px 0 34px;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 22px;
  align-items:center;
}

.hero-copy h1{
  font-size: clamp(34px, 4vw, 56px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin:0;
}
.hero-copy .sub{
  margin: 14px 0 0;
  font-size: 18px;
  color: var(--muted);
  max-width: 54ch;
}

.hero-ctas{display:flex; gap:12px; margin-top: 18px; flex-wrap:wrap}

.trust{
  list-style:none;
  padding:0;
  margin: 18px 0 0;
  display:flex;
  gap: 12px;
  flex-wrap:wrap;
}
.trust li{
  display:flex;
  align-items:center;
  gap:8px;
  background: var(--surface);
  border: 3px solid var(--border);
  border-radius: 999px;
  padding: 10px 12px;
  box-shadow: var(--shadow-neo);
  font-weight: 800;
  font-size: 14px;
}
.dot{width:10px; height:10px; border-radius:999px; background: var(--accent); border:2px solid var(--border)}

.hero-pack{
  position:relative;
  display:grid;
  gap: 12px;
}

.packshot{
  background: var(--surface);
  border: 3px solid var(--border);
  border-radius: var(--r-l);
  box-shadow: var(--shadow-neo);
  padding: 14px;
}
.packshot img{object-fit:contain}

.hero-packshot img{width:100%; height:auto; aspect-ratio: 704/545}

.hero-chip{
  display:flex;
  gap:10px;
  justify-content:center;
  flex-wrap:wrap;
}
.hero-chip span{
  border: 3px solid var(--border);
  border-radius: 999px;
  padding: 10px 12px;
  font-weight: 900;
  letter-spacing:.01em;
  box-shadow: var(--shadow-neo);
}
.chip-strong{background: var(--accent); color: var(--accentText)}
.chip-soft{background: var(--chipBg); color: var(--chipText)}

/* BUTTONS */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  text-decoration:none;
  font-weight: 900;
  border-radius: 14px;
  padding: 12px 16px;
  border: 3px solid var(--border);
  box-shadow: var(--shadow-neo);
  transition: transform .2s var(--ease-out), box-shadow .2s var(--ease-out), background .2s var(--ease-out);
  min-height: 48px;
}
.btn:focus-visible{outline: 4px solid var(--focus); outline-offset: 3px}
.btn:hover{transform: translate(-1px,-1px)}
.btn:active{transform: translate(1px,1px); box-shadow:none}

.btn-primary{background: var(--accent); color: var(--accentText)}
.btn-primary:hover{background: var(--accentHover)}
.btn-ghost{background: var(--surface); color: var(--text)}

/* MAIN */
main{display:block}
section{padding-block: var(--section-y)}
section > h2{
  font-size: clamp(22px, 2.3vw, 30px);
  margin:0;
  padding-top: 15px;
  padding-bottom: 10px;
  letter-spacing: -0.01em;
}

article{
  margin-top: 16px;
  background: var(--surface);
  border: 3px solid var(--border);
  border-radius: var(--r-l);
  box-shadow: var(--shadow-neo);
  padding: 16px 16px 14px;
}
article > h3{
  margin:0;
  padding-top: 15px;
  padding-bottom: 10px;
  font-size: 18px;
  letter-spacing: -0.01em;
}
article p{margin:0; color: var(--muted)}

.bullets{
  margin-top: 16px;
  background: var(--surface);
  border:3px solid var(--border);
  border-radius: var(--r-l);
  box-shadow: var(--shadow-neo);
  padding: 14px 16px;
}
.bullets ul{
  margin:0;
  padding-left: 18px;
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px 18px;
}
.bullets li{font-weight: 800}

.proof{
  margin-top: 18px;
  display:grid;
  grid-template-columns: 1.3fr .7fr .7fr;
  gap: 14px;
  align-items:stretch;
}

.proof-card{
  background: var(--surface);
  border:3px solid var(--border);
  border-radius: var(--r-l);
  box-shadow: var(--shadow-neo);
  padding: 16px;
  display:flex;
  flex-direction:column;
}
.proof-card h3{
  margin:0;
  padding-top: 15px;
  padding-bottom: 10px;
}
.proof-card p{margin:0; color: var(--muted)}
.proof-card .btn{margin-top:auto; width: fit-content}

.proof-fig, .proof-pack{
  background: var(--surface);
  border:3px solid var(--border);
  border-radius: var(--r-l);
  box-shadow: var(--shadow-neo);
  padding: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
}

/* PRICING */
.pricing{margin-top: 18px}
.price-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px;
}
.price-card{
  background: var(--surface);
  border: 3px solid var(--border);
  border-radius: var(--r-l);
  box-shadow: var(--shadow-neo);
  padding: 14px;
  display:flex;
  flex-direction:column;
  min-height: 100%;
  position:relative;
}
.price-card[data-featured="true"]::after{
  content:"";
  position:absolute;
  inset:-6px;
  border: 3px dashed var(--accent);
  border-radius: calc(var(--r-l) + 8px);
  pointer-events:none;
}

.badge{
  display:inline-flex;
  align-items:center;
  padding: 8px 10px;
  border-radius: 999px;
  border:3px solid var(--border);
  background: var(--chipBg);
  color: var(--chipText);
  font-weight: 900;
  letter-spacing:.01em;
  width: fit-content;
}

.price-name{
  margin: 10px 0 0;
  padding-top: 15px;
  padding-bottom: 10px;
  font-size: 20px;
}
.price-note{margin:0; color: var(--muted); font-weight: 700}

.price-meta{margin-top: 10px}
.price{font-size: 28px; font-weight: 1000; margin:0; letter-spacing:-.02em}
.unit{margin: 2px 0 0; color: var(--muted); font-weight: 800}

.price-card .packshot{
  margin-top: 12px;
  padding: 10px;
}
.price-card .packshot img{width:100%; height:auto; aspect-ratio: 720/520}

.cta-wrap{margin-top:auto; padding-top: 12px}
.cta-wrap .btn{width:100%}

/* FAQ */
.faq{margin-top: 18px}
.faq-head{
  display:flex;
  gap: 12px;
  align-items:center;
  justify-content:space-between;
  background: var(--surface);
  border:3px solid var(--border);
  border-radius: var(--r-l);
  box-shadow: var(--shadow-neo);
  padding: 14px 16px;
}
.kicker{margin:0; font-weight: 1000; letter-spacing:-.01em}

.faq-list{margin-top: 12px; display:grid; gap: 10px}
.faq-item{
  background: var(--surface);
  border:3px solid var(--border);
  border-radius: var(--r-l);
  box-shadow: var(--shadow-neo);
  overflow:hidden;
}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding: 12px 14px;
  font-weight: 900;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:focus-visible{outline: 4px solid var(--focus); outline-offset: -4px}
.faq-a{padding: 0 14px 14px}
.faq-a p{margin:0; color: var(--muted); font-weight: 700}
.chev{font-size: 18px}

/* FINAL */
.final{
  margin-top: 18px;
  background: var(--surface);
  border:3px solid var(--border);
  border-radius: var(--r-l);
  box-shadow: var(--shadow-neo);
  padding: 16px;
  text-align:center;
}
.final h3{margin:0; padding-top: 15px; padding-bottom: 10px; font-size: 22px; letter-spacing:-.01em}
.final p{margin:0; color: var(--muted); font-weight: 700}
.final .btn{margin-top: 14px}

/* FOOTER */
footer{
  border-top: 3px solid var(--border);
  padding: 22px 0;
}
.footer-inner{width: var(--container-x); margin-inline:auto; text-align:center}
.footer-link{
  display:inline-block;
  padding: 10px 12px;
  border:3px solid var(--border);
  border-radius: var(--r-s);
  background: var(--surface);
  box-shadow: var(--shadow-neo);
  text-decoration:none;
  font-weight: 900;
}
.footer-link:focus-visible{outline: 4px solid var(--focus); outline-offset: 3px}
.footer-note{margin: 14px 0 0; font-weight: 900}
.footer-copy{margin: 6px 0 0; color: var(--muted); font-weight: 800}

/* REVEAL */
.reveal{opacity: 0; transform: translateY(10px); transition: opacity .6s var(--ease-out), transform .6s var(--ease-out)}
.reveal.is-in{opacity: 1; transform: translateY(0)}

/* RESPONSIVE */
@media (max-width: 900px){
  .nav-toggle{display:inline-flex; align-items:center; justify-content:center}
  .nav-links{
    position:absolute;
    right: 16px;
    top: 72px;
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap: 8px;
    background: var(--bg);
    border:3px solid var(--border);
    border-radius: var(--r-l);
    box-shadow: var(--shadow-neo);
    padding: 10px;
    width: min(360px, calc(100% - 32px));
  }
  .nav-links[data-open="true"]{display:flex}
  .controls{flex-direction:column; align-items:stretch}
  .ctrl-btn{justify-content:space-between}

  .hero-grid{grid-template-columns: 1fr; text-align:center}
  .hero-copy .sub{margin-inline:auto}
  .hero-ctas{justify-content:center}
  .btn{width: min(100%, 360px)}
  .trust{justify-content:center}

  /* lists/bullets: left aligned */
  .bullets ul{grid-template-columns: 1fr; text-align:left}

  .proof{grid-template-columns: 1fr;}
  .proof-card .btn{width: min(100%, 360px); margin-inline:auto}

  .price-grid{grid-template-columns: 1fr}
}

@media (prefers-reduced-motion: reduce){
  .reveal{transition:none; opacity:1; transform:none}
  .btn, .ctrl-btn{transition:none}
  .btn:hover, .ctrl-btn:hover{transform:none}
}
