@layer reset, tokens, base, layout, components, sections, utilities;

@layer reset {
  *,*::before,*::after { box-sizing: border-box; }
  * { margin: 0; }
  html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
  img,svg { display: block; max-width: 100%; }
  a { color: inherit; }
  button { font: inherit; cursor: pointer; }
  ul { list-style: none; padding: 0; }
}

@layer tokens {
  :root {
    --raspberry: #d11f45;
    --raspberry-deep: #a8163a;
    --raspberry-ink: #7c0f2c;
    --magenta: #ec4f86;
    --magenta-soft: #f78fb3;
    --blush: #fde7ec;
    --blush-2: #fbd5de;
    --cream: #fff7f4;
    --white: #ffffff;
    --ink: #2c0f1a;
    --ink-soft: #6b4751;
    --line: #f3d3db;
    --good: #1f9d6b;
    --hero-grad: linear-gradient(135deg,#b81740 0%,#d11f45 46%,#ec4f86 100%);
    --pill-grad: linear-gradient(135deg,#d11f45,#ec4f86);
    --shadow-sm: 0 2px 10px rgba(124,15,44,.08);
    --shadow-md: 0 14px 34px rgba(124,15,44,.14);
    --radius: 22px;
    --radius-sm: 14px;
    --wrap: 1140px;
    --font-head: "Quicksand", system-ui, sans-serif;
    --font-body: "Assistant", system-ui, sans-serif;
  }
}

@layer base {
  body {
    font-family: var(--font-body);
    color: var(--ink);
    background: var(--cream);
    line-height: 1.65;
    font-size: 17px;
    -webkit-font-smoothing: antialiased;
  }
  h1,h2,h3,h4 { font-family: var(--font-head); font-weight: 700; line-height: 1.14; color: var(--raspberry-ink); }
  h1 { font-size: clamp(2.1rem, 5.4vw, 3.5rem); letter-spacing: -.5px; }
  h2 { font-size: clamp(1.6rem, 3.6vw, 2.4rem); letter-spacing: -.3px; }
  h3 { font-size: 1.22rem; }
  p { margin: 0 0 1rem; }
  a { text-decoration: none; }
  a:hover { text-decoration: underline; }
  strong { font-weight: 700; }
  :focus-visible { outline: 3px solid var(--magenta); outline-offset: 2px; border-radius: 6px; }
}

@layer layout {
  .jt-wrap { width: min(100% - 2.4rem, var(--wrap)); margin-inline: auto; }
  .jt-narrow { width: min(100% - 2.4rem, 760px); margin-inline: auto; }
  section { padding: clamp(2.6rem, 6vw, 4.6rem) 0; }
  .jt-grid { display: grid; gap: 1.4rem; }
  @media (min-width: 760px) { .jt-2 { grid-template-columns: 1fr 1fr; } .jt-3 { grid-template-columns: repeat(3,1fr); } }
}

@layer components {
  .jt-skip { position: absolute; left: -999px; top: 0; background: var(--ink); color:#fff; padding:.7rem 1rem; z-index: 200; border-radius: 0 0 10px 0; }
  .jt-skip:focus { left: 0; }

  .jt-ribbon { background: var(--raspberry-ink); color: #ffe7ee; text-align: center; font-size: .82rem; padding: .5rem 1rem; letter-spacing: .2px; }
  .jt-ribbon strong { color: #fff; }

  .jt-head { position: sticky; top: 0; z-index: 100; background: rgba(255,247,244,.94); backdrop-filter: blur(8px); border-bottom: 1px solid var(--line); }
  .jt-head__row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: .7rem 0; }
  .jt-logo { font-family: var(--font-head); font-weight: 700; font-size: 1.5rem; color: var(--raspberry); letter-spacing: -.5px; }
  .jt-logo span { color: var(--magenta); }
  .jt-logo:hover { text-decoration: none; }
  .jt-nav { display: flex; align-items: center; gap: 1.3rem; }
  .jt-nav a { font-weight: 600; font-size: .98rem; color: var(--ink); }
  .jt-nav a.is-active { color: var(--raspberry); }
  .jt-burger { display: none; background: none; border: 0; font-size: 1.7rem; color: var(--raspberry); line-height: 1; padding: .2rem .4rem; }

  .jt-btn { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; background: var(--pill-grad); color: #fff; font-family: var(--font-head); font-weight: 700; padding: .85rem 1.5rem; border-radius: 999px; border: 0; box-shadow: var(--shadow-sm); transition: transform .12s ease, box-shadow .12s ease; text-align: center; }
  .jt-btn:hover { text-decoration: none; transform: translateY(-2px); box-shadow: var(--shadow-md); }
  .jt-btn--ghost { background: #fff; color: var(--raspberry); border: 2px solid var(--blush-2); box-shadow: none; }
  .jt-btn--lg { font-size: 1.12rem; padding: 1.05rem 2rem; width: 100%; }
  .jt-btn--block { width: 100%; }

  .jt-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.5rem; box-shadow: var(--shadow-sm); }
  .jt-badge { display: inline-block; background: var(--blush); color: var(--raspberry-deep); font-weight: 700; font-size: .76rem; padding: .3rem .7rem; border-radius: 999px; letter-spacing: .3px; }
  .jt-badge--solid { background: var(--raspberry); color: #fff; }

  .jt-bcrumb { font-size: .85rem; color: var(--ink-soft); padding: .8rem 0; }
  .jt-bcrumb a { color: var(--raspberry); font-weight: 600; }
  .jt-bcrumb span { opacity: .6; }

  .jt-foot { background: var(--ink); color: #f4dbe2; padding: 3rem 0 1.6rem; font-size: .92rem; }
  .jt-foot h4 { color: #fff; font-size: 1rem; margin-bottom: .7rem; }
  .jt-foot a { color: #f4dbe2; }
  .jt-foot__cols { display: grid; gap: 1.8rem; }
  @media (min-width: 760px) { .jt-foot__cols { grid-template-columns: 1.6fr 1fr 1fr 1fr; } }
  .jt-foot__cols li { margin-bottom: .45rem; }
  .jt-foot__legal { border-top: 1px solid rgba(255,255,255,.14); margin-top: 2rem; padding-top: 1.3rem; font-size: .8rem; color: #d8b6c0; }
  .jt-foot__legal p { margin-bottom: .7rem; }

  table.jt-table { width: 100%; border-collapse: collapse; background: #fff; border-radius: var(--radius-sm); overflow: hidden; box-shadow: var(--shadow-sm); font-size: .96rem; }
  .jt-table th, .jt-table td { text-align: left; padding: .8rem .95rem; border-bottom: 1px solid var(--line); vertical-align: top; }
  .jt-table th[scope=row] { font-family: var(--font-head); font-weight: 600; color: var(--raspberry-ink); width: 42%; }
  .jt-table thead th { background: var(--blush); color: var(--raspberry-deep); font-family: var(--font-head); }
  .jt-table tr:last-child th, .jt-table tr:last-child td { border-bottom: 0; }

  details.jt-faq { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-sm); padding: .2rem 1.1rem; margin-bottom: .8rem; box-shadow: var(--shadow-sm); }
  details.jt-faq summary { font-family: var(--font-head); font-weight: 600; color: var(--raspberry-ink); padding: .9rem 0; cursor: pointer; list-style: none; display: flex; justify-content: space-between; gap: 1rem; }
  details.jt-faq summary::-webkit-details-marker { display: none; }
  details.jt-faq summary::after { content: "+"; color: var(--magenta); font-size: 1.3rem; }
  details.jt-faq[open] summary::after { content: "\2013"; }
  details.jt-faq p { padding-bottom: .9rem; }
}

@layer sections {
  .jt-hero { background: var(--hero-grad); color: #fff; }
  .jt-hero h1 { color: #fff; }
  .jt-hero__grid { display: grid; gap: 2rem; align-items: center; padding: clamp(2.4rem,5vw,3.8rem) 0; }
  @media (min-width: 860px) { .jt-hero__grid { grid-template-columns: 1.05fr .95fr; } }
  .jt-hero p.lead { font-size: 1.15rem; color: #ffe3ec; max-width: 34ch; }
  .jt-hero__pills { display: flex; flex-wrap: wrap; gap: .5rem; margin: 1.2rem 0; }
  .jt-hero__pills span { background: rgba(255,255,255,.16); color: #fff; padding: .35rem .8rem; border-radius: 999px; font-size: .82rem; font-weight: 600; }
  .jt-hero__art { position: relative; text-align: center; }
  .jt-hero__art img { margin-inline: auto; filter: drop-shadow(0 24px 40px rgba(80,8,28,.45)); width: min(82%, 400px); height: auto; }

  .jt-stats { display: grid; grid-template-columns: repeat(2,1fr); gap: 1rem; margin-top: 1.6rem; }
  @media (min-width: 560px) { .jt-stats { grid-template-columns: repeat(4,1fr); } }
  .jt-stats div { background: rgba(255,255,255,.12); border-radius: var(--radius-sm); padding: .9rem; text-align: center; }
  .jt-stats b { display: block; font-family: var(--font-head); font-size: 1.5rem; color: #fff; }
  .jt-stats small { color: #ffd9e4; font-size: .76rem; }

  .jt-tldr { background: #fff; border-left: 6px solid var(--magenta); border-radius: var(--radius-sm); padding: 1.3rem 1.5rem; box-shadow: var(--shadow-sm); }
  .jt-tldr h2 { font-size: 1.05rem; text-transform: uppercase; letter-spacing: 1px; color: var(--magenta); margin-bottom: .5rem; }
  .jt-tldr p { margin: 0; font-size: 1.05rem; }

  .jt-keyfacts { background: var(--blush); }
  .jt-pillar { border-top: 5px solid var(--magenta); }
  .jt-pillar h3 { color: var(--raspberry); }
  .jt-dose { font-family: var(--font-head); font-weight: 600; color: var(--magenta); }

  .jt-price { display: grid; gap: 1.5rem; align-items: stretch; }
  @media (min-width: 880px) { .jt-price { grid-template-columns: repeat(3,1fr); } }
  .jt-plan { background: #fff; border: 2px solid var(--line); border-radius: var(--radius); padding: 1.8rem 1.4rem; text-align: center; position: relative; display: flex; flex-direction: column; }
  .jt-plan.is-popular { border-color: var(--raspberry); box-shadow: var(--shadow-md); }
  @media (min-width: 880px) { .jt-plan.is-popular { transform: translateY(-14px); } }
  .jt-plan__tag { position: absolute; top: -14px; left: 50%; transform: translateX(-50%); background: var(--raspberry); color: #fff; font-family: var(--font-head); font-weight: 700; font-size: .76rem; padding: .35rem .9rem; border-radius: 999px; letter-spacing: .5px; }
  .jt-plan__n { font-family: var(--font-head); font-weight: 700; font-size: 1.5rem; color: var(--raspberry-ink); }
  .jt-plan__supply { color: var(--ink-soft); font-size: .85rem; }
  .jt-plan__packshot { display: flex; justify-content: center; align-items: center; margin: 1rem 0 .6rem; min-height: 130px; }
  .jt-plan__packshot img { max-width: 100%; max-height: 130px; width: auto; height: auto; filter: drop-shadow(0 8px 14px rgba(124,15,44,.22)); }
  .jt-plan__per { font-family: var(--font-head); font-weight: 700; color: var(--ink); }
  .jt-plan__per b { font-size: 2.6rem; color: var(--raspberry); }
  .jt-plan__list { margin: 1rem 0; font-size: .92rem; text-align: left; }
  .jt-plan__list li { padding: .3rem 0 .3rem 1.5rem; position: relative; }
  .jt-plan__list li::before { content: "\2714"; position: absolute; left: 0; color: var(--good); font-weight: 700; }
  .jt-plan__list li.no { color: var(--ink-soft); }
  .jt-plan__list li.no::before { content: "\2715"; color: #c9a7b0; }
  .jt-plan__save { color: var(--raspberry); font-weight: 700; }
  .jt-plan__was { text-decoration: line-through; color: var(--ink-soft); }
  .jt-plan__total { font-family: var(--font-head); font-weight: 700; font-size: 1.15rem; }
  .jt-plan .jt-btn { margin-top: auto; }

  .jt-rev { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.4rem; box-shadow: var(--shadow-sm); }
  .jt-rev__top { display: flex; align-items: center; gap: .7rem; margin-bottom: .6rem; }
  .jt-ava { width: 44px; height: 44px; border-radius: 50%; background: var(--pill-grad); color: #fff; display: grid; place-items: center; font-family: var(--font-head); font-weight: 700; }
  .jt-ava--name b { display: block; font-weight: 700; color: var(--ink); }
  .jt-ava--name small { color: var(--ink-soft); }
  .jt-stars { color: #f5a623; letter-spacing: 2px; }
  .jt-verified { color: var(--good); font-size: .78rem; font-weight: 700; }

  .jt-snap { display: grid; grid-template-columns: repeat(2,1fr); gap: 1rem; }
  @media (min-width: 720px) { .jt-snap { grid-template-columns: repeat(4,1fr); } }
  .jt-snap div { background: var(--blush); border-radius: var(--radius-sm); padding: 1.1rem; text-align: center; }
  .jt-snap b { display: block; font-family: var(--font-head); font-size: 1.7rem; color: var(--raspberry); }
  .jt-snap small { color: var(--ink-soft); font-size: .8rem; }

  .jt-bar { margin: .5rem 0; }
  .jt-bar__row { display: flex; justify-content: space-between; font-size: .9rem; margin-bottom: .2rem; }
  .jt-bar__track { height: 11px; background: var(--blush-2); border-radius: 999px; overflow: hidden; }
  .jt-bar__fill { height: 100%; background: var(--pill-grad); border-radius: 999px; }

  .jt-cta-band { background: var(--hero-grad); color: #fff; text-align: center; border-radius: var(--radius); padding: 2.4rem 1.4rem; }
  .jt-cta-band h2 { color: #fff; }
  .jt-cta-band p { color: #ffe3ec; }

  .jt-byline { font-size: .86rem; color: var(--ink-soft); background: var(--blush); border-radius: 999px; padding: .5rem 1rem; display: inline-block; margin: .4rem 0 1.2rem; }
  .jt-take { background: var(--raspberry-ink); color: #fff; border-radius: var(--radius); padding: 1.6rem 1.7rem; }
  .jt-take h2 { color: #fff; }
  .jt-take ul li { padding: .45rem 0 .45rem 1.7rem; position: relative; border-bottom: 1px solid rgba(255,255,255,.12); }
  .jt-take ul li:last-child { border-bottom: 0; }
  .jt-take ul li::before { content: "\25C6"; position: absolute; left: 0; color: var(--magenta-soft); }
  .jt-updated { color: var(--ink-soft); font-size: .85rem; font-style: italic; }
  dl.jt-gloss dt { font-family: var(--font-head); font-weight: 700; color: var(--raspberry); margin-top: .9rem; }
  dl.jt-gloss dd { margin: 0; }
}

@layer utilities {
  .u-center { text-align: center; }
  .u-mt0 { margin-top: 0; }
  .u-mb0 { margin-bottom: 0; }
  .u-mt1 { margin-top: 1rem; }
  .u-mt2 { margin-top: 2rem; }
  .u-lead { font-size: 1.12rem; color: var(--ink-soft); }
  .u-eyebrow { text-transform: uppercase; letter-spacing: 2px; font-size: .78rem; font-weight: 700; color: var(--magenta); }
  .u-flex { display: flex; flex-wrap: wrap; gap: .8rem; }
  .u-pill-list li { padding-left: 1.6rem; position: relative; margin-bottom: .5rem; }
  .u-pill-list li::before { content: "\2714"; position: absolute; left: 0; color: var(--good); font-weight: 700; }
  @media (max-width: 759px) {
    .jt-nav { position: fixed; inset: 0 0 0 auto; width: min(78%,300px); background: var(--cream); flex-direction: column; align-items: flex-start; padding: 5rem 1.6rem; gap: 1.2rem; transform: translateX(100%); transition: transform .25s ease; box-shadow: var(--shadow-md); }
    .jt-nav.is-open { transform: translateX(0); }
    .jt-burger { display: block; }
  }
}
