/* ===========================================================================
   The Supplement Watch - Jelly Tide review
   Theme: Indigo Watch (deep royal-violet + verdict green/amber/red)
   Methodology: sw- single-hyphen components, .is-/.has- states,
   layout primitives, @layer cascade.
   =========================================================================== */

@layer reset, tokens, base, layout, components, sections, utilities, responsive;

/* ---------- fallback fonts (metric matched, anti-CLS) ------------------- */
@font-face{
  font-family:"Tomorrow Fallback";
  src:local("Arial");
  size-adjust:94%;
  ascent-override:92%;
  descent-override:24%;
}
@font-face{
  font-family:"Lato Fallback";
  src:local("Arial");
  size-adjust:99%;
}

@layer reset{
  *,*::before,*::after{box-sizing:border-box}
  html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
  body,h1,h2,h3,h4,p,figure,blockquote,dl,dd,ul,ol{margin:0}
  ul[class],ol[class]{list-style:none;padding:0}
  a{color:inherit}
  img,svg{display:block;max-width:100%}
  button,input,textarea,select{font:inherit;color:inherit}
  table{border-collapse:collapse;width:100%}
  :focus-visible{outline:3px solid var(--focus);outline-offset:2px;border-radius:4px}
  @media (prefers-reduced-motion:reduce){
    *{animation-duration:.01ms!important;transition-duration:.01ms!important}
  }
}

@layer tokens{
  :root{
    --ink:#1b1430;
    --ink-soft:#3a3152;
    --muted:#534d63;
    --violet-900:#2e1065;
    --violet-800:#3b1184;
    --violet-700:#4c1d95;
    --violet-600:#5b21b6;
    --violet-500:#6d28d9;
    --violet-400:#7c3aed;
    --violet-200:#ddd6fe;
    --violet-100:#ede9fe;
    --violet-050:#f5f3ff;
    --bg:#ffffff;
    --bg-tint:#f6f4fc;
    --card:#ffffff;
    --line:#e6e0f4;
    --line-strong:#d6cdeb;
    --pro:#15803d;--pro-bg:#e7f6ec;
    --con:#c0223b;--con-bg:#fbe9ec;
    --warn:#8a4b00;--warn-bg:#fdf2e0;--warn-line:#f0d49a;
    --star:#f59e0b;
    --focus:#7c3aed;
    --cta-a:#6d28d9;--cta-b:#7c3aed;
    --radius:14px;--radius-lg:22px;--radius-sm:9px;
    --shadow:0 12px 34px -16px rgba(46,16,101,.45);
    --shadow-sm:0 6px 18px -12px rgba(46,16,101,.4);
    --maxw:1120px;--maxw-prose:70ch;
    --font-head:"Tomorrow","Tomorrow Fallback",system-ui,sans-serif;
    --font-body:"Lato","Lato Fallback",system-ui,Arial,sans-serif;
    --step:clamp(1.4rem,1.1rem + 1.4vw,2rem);
  }
}

@layer base{
  body{
    font-family:var(--font-body);
    color:var(--ink);
    background:var(--bg);
    line-height:1.65;
    font-size:1.02rem;
    -webkit-font-smoothing:antialiased;
  }
  h1,h2,h3{font-family:var(--font-head);line-height:1.12;font-weight:800;color:var(--violet-900);letter-spacing:-.01em}
  h2{font-size:clamp(1.5rem,1.15rem + 1.5vw,2.1rem);margin-bottom:.5em}
  h3{font-size:1.22rem;font-weight:700;margin-bottom:.35em;color:var(--violet-800)}
  p{margin-bottom:1rem}
  p:last-child{margin-bottom:0}
  a{color:var(--violet-700);text-underline-offset:2px}
  a:hover{color:var(--violet-500)}
  strong{font-weight:700;color:var(--ink)}
  .sw-prose ul{margin:0 0 1rem;padding-left:1.2rem;list-style:disc}
  .sw-prose ul li{margin-bottom:.4rem}
}

/* ----------------------------------------------------------------- layout */
@layer layout{
  .sw-wrap{width:min(100% - 2.4rem,var(--maxw));margin-inline:auto}
  .sw-section{padding-block:clamp(2.4rem,1.6rem + 3vw,4rem)}
  .sw-stack > * + *{margin-top:1.05rem}
  .sw-cluster{display:flex;flex-wrap:wrap;gap:.7rem;align-items:center}
  .sw-grid{display:grid;gap:1rem}
  .sw-prose{max-width:var(--maxw-prose)}
  .sw-prose > * + *{margin-top:1rem}
  main{display:block}
}

/* ------------------------------------------------------------- components */
@layer components{

  /* skip link */
  .sw-skip{position:absolute;left:-999px;top:0;background:var(--violet-700);color:#fff;
    padding:.7rem 1.1rem;border-radius:0 0 10px 0;z-index:60}
  .sw-skip:focus{left:0;color:#fff}

  /* header */
  .sw-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);
    backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line)}
  .sw-header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;
    padding-block:.7rem}
  .sw-brand{display:flex;align-items:center;gap:.55rem;font-family:var(--font-head);
    font-weight:800;color:var(--violet-900);font-size:1.06rem;letter-spacing:-.02em;text-decoration:none}
  .sw-brand:hover{color:var(--violet-700)}
  .sw-brand-mark{width:30px;height:30px;flex:none}
  .sw-brand-sub{display:block;font-family:var(--font-body);font-weight:400;font-size:.62rem;
    letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
  .sw-nav-list{display:flex;align-items:center;gap:.3rem}
  .sw-nav-link{display:inline-block;padding:.5rem .7rem;border-radius:8px;text-decoration:none;
    color:var(--ink-soft);font-weight:700;font-size:.93rem}
  .sw-nav-link:hover{background:var(--violet-050);color:var(--violet-700)}
  .sw-nav-link.is-current{color:var(--violet-700);background:var(--violet-050)}
  .sw-header-cta{display:inline-flex;align-items:center;gap:.4rem;background:linear-gradient(135deg,var(--cta-a),var(--cta-b));
    color:#fff;text-decoration:none;font-weight:800;font-size:.86rem;padding:.6rem .9rem;border-radius:10px;
    letter-spacing:.02em;box-shadow:var(--shadow-sm)}
  .sw-header-cta:hover{color:#fff;filter:brightness(1.06)}
  .sw-nav-toggle{display:none;background:none;border:1px solid var(--line-strong);border-radius:9px;
    padding:.45rem .55rem;cursor:pointer;color:var(--violet-800)}

  /* disclosure banner */
  .sw-disclosure{background:var(--violet-050);border-bottom:1px solid var(--line)}
  .sw-disclosure-inner{display:flex;gap:.7rem;align-items:flex-start;padding-block:.6rem}
  .sw-disclosure-icon{flex:none;width:18px;height:18px;margin-top:.18rem;color:var(--violet-600)}
  .sw-disclosure-text{font-size:.82rem;color:var(--ink-soft);line-height:1.5}
  .sw-disclosure-text a{font-weight:700}

  /* breadcrumb */
  .sw-breadcrumb{padding-block:.7rem;border-bottom:1px solid var(--line);background:var(--bg)}
  .sw-breadcrumb ol{display:flex;flex-wrap:wrap;gap:.35rem;font-size:.8rem;color:var(--muted)}
  .sw-breadcrumb a{text-decoration:none;font-weight:700;color:var(--violet-700)}
  .sw-breadcrumb li[aria-current]{color:var(--muted)}

  /* hero */
  .sw-hero{position:relative;overflow:hidden;color:#f4f0ff;
    background:
      radial-gradient(120% 90% at 85% 8%,rgba(124,58,237,.55),transparent 60%),
      radial-gradient(90% 80% at 12% 95%,rgba(14,165,233,.18),transparent 55%),
      linear-gradient(135deg,#2a0d5f 0%,#3b1184 45%,#5b21b6 100%)}
  .sw-hero-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:2rem;align-items:center;
    padding-block:clamp(2rem,1.2rem + 3vw,3.4rem)}
  .sw-eyebrow{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--font-head);
    font-weight:700;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;
    color:#d6c8ff;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.18);
    padding:.35rem .7rem;border-radius:999px}
  .sw-h1{font-size:clamp(1.95rem,1.3rem + 3.4vw,3.2rem);color:#fff;margin:.7rem 0 .4rem;line-height:1.04}
  .sw-h1 em{font-style:normal;color:#ffd23f}
  .sw-lede{font-size:1.08rem;color:#e7defb;max-width:46ch}
  .sw-byline{display:flex;flex-wrap:wrap;gap:.5rem 1rem;align-items:center;margin-top:1.1rem;
    font-size:.84rem;color:#d9cdf6}
  .sw-byline strong{color:#fff}
  .sw-byline a{color:#ffd23f;font-weight:700}
  .sw-hero-chips{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:1.2rem}
  .sw-hero-chip{display:inline-flex;align-items:center;gap:.35rem;font-size:.76rem;font-weight:700;
    color:#efe9ff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);
    padding:.34rem .6rem;border-radius:8px}
  .sw-hero-chip svg{width:14px;height:14px;color:#86efac}

  /* hero media + product fallback card */
  .sw-hero-media{position:relative;justify-self:center;width:min(100%,360px);aspect-ratio:1/1}
  .sw-product{position:absolute;inset:0;display:grid;place-items:center;border-radius:var(--radius-lg);
    background:linear-gradient(160deg,#f7f3ff,#e6dcfb);box-shadow:var(--shadow);overflow:hidden}
  .sw-product-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;
    text-align:center;padding:1.2rem;color:var(--violet-800)}
  .sw-product-fallback span{font-family:var(--font-head);font-weight:800;line-height:.95;
    font-size:clamp(1.8rem,1.2rem + 3vw,2.6rem);letter-spacing:-.02em}
  .sw-product-fallback small{margin-top:.5rem;font-size:.7rem;letter-spacing:.16em;
    text-transform:uppercase;color:var(--violet-600)}
  .sw-product img{position:relative;width:100%;height:100%;object-fit:contain;padding:.6rem;
    filter:drop-shadow(0 18px 26px rgba(20,8,50,.35))}
  .sw-hero-rating{position:absolute;left:-.6rem;bottom:-.8rem;background:#fff;color:var(--ink);
    border-radius:14px;padding:.6rem .8rem;box-shadow:var(--shadow);display:flex;gap:.55rem;align-items:center}
  .sw-hero-rating b{font-family:var(--font-head);font-size:1.5rem;line-height:1;color:var(--violet-700)}
  .sw-hero-rating small{display:block;font-size:.66rem;color:var(--muted);letter-spacing:.04em}

  /* stars (display) */
  .sw-stars{display:inline-flex;gap:1px;color:var(--star);vertical-align:middle}
  .sw-stars svg{width:1em;height:1em}
  .sw-stars.is-lg{font-size:1.35rem}
  .sw-stars .is-empty{color:#d8cff0}
  .sw-star-half{position:relative;display:inline-block;width:1em;height:1em;color:#d8cff0}
  .sw-star-half svg{width:1em;height:1em}
  .sw-star-half .sw-star-fill{position:absolute;inset:0;width:50%;overflow:hidden;color:var(--star)}
  .sw-star-half .sw-star-fill svg{width:1em;max-width:none}

  /* generic card */
  .sw-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);
    padding:clamp(1.1rem,.8rem + 1vw,1.7rem);box-shadow:var(--shadow-sm)}

  /* verdict box */
  .sw-verdict{position:relative;background:#fff;border:1px solid var(--line-strong);
    border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;margin-top:-2.6rem;z-index:5}
  .sw-verdict-top{display:grid;grid-template-columns:auto 1fr;gap:1.3rem;align-items:center;
    padding:clamp(1.1rem,.8rem + 1.3vw,1.7rem);border-bottom:1px dashed var(--line-strong)}
  .sw-score{display:flex;flex-direction:column;align-items:center;justify-content:center;
    background:linear-gradient(160deg,var(--violet-700),var(--violet-500));color:#fff;
    border-radius:16px;padding:1rem 1.3rem;min-width:120px}
  .sw-score b{font-family:var(--font-head);font-size:2.9rem;line-height:.95;font-weight:800}
  .sw-score small{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;opacity:.9;margin-top:.2rem}
  .sw-score .sw-stars{margin-top:.35rem;color:#ffd23f}
  .sw-score .is-empty{color:rgba(255,255,255,.35)}
  .sw-verdict-headline{font-family:var(--font-head);font-weight:800;font-size:1.18rem;color:var(--violet-900);
    margin-bottom:.4rem}
  .sw-verdict-summary{font-size:1rem;color:var(--ink-soft)}
  .sw-facts{display:grid;grid-template-columns:repeat(3,1fr);gap:0;
    padding:clamp(1.1rem,.8rem + 1.3vw,1.6rem)}
  .sw-fact{display:flex;flex-direction:column-reverse;gap:.15rem;padding:.6rem .8rem;
    border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
  .sw-fact dt{font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
  .sw-fact dd{font-weight:700;color:var(--ink);font-size:1rem}
  .sw-verdict-foot{display:flex;flex-wrap:wrap;gap:.7rem 1rem;align-items:center;justify-content:space-between;
    padding:clamp(1rem,.7rem + 1vw,1.4rem);background:var(--violet-050)}

  /* CTA buttons */
  .sw-cta{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
    font-family:var(--font-head);font-weight:800;letter-spacing:.02em;text-decoration:none;
    padding:.85rem 1.4rem;border-radius:12px;border:2px solid transparent;cursor:pointer;
    min-height:48px;font-size:1rem;text-align:center}
  .sw-cta.is-primary{background:linear-gradient(135deg,var(--cta-a),var(--cta-b));color:#fff;
    box-shadow:var(--shadow-sm)}
  .sw-cta.is-primary:hover{color:#fff;filter:brightness(1.07)}
  .sw-cta.is-ghost{background:#fff;color:var(--violet-700);border-color:var(--violet-200)}
  .sw-cta.is-ghost:hover{background:var(--violet-050)}
  .sw-cta.is-big{font-size:1.1rem;padding:1rem 1.7rem}
  .sw-cta-note{font-size:.76rem;color:var(--muted);margin-top:.5rem;max-width:42ch}
  .sw-cta-wrap{display:flex;flex-direction:column;gap:.2rem}
  .sw-cta.is-light{background:#fff;color:var(--violet-700);border-color:#fff}
  .sw-cta.is-light:hover{background:#f1ecff;color:var(--violet-800)}

  /* curiosity price band (gentle nudge toward the official offer) */
  .sw-pricetease{display:flex;flex-wrap:wrap;align-items:center;gap:1rem 1.6rem;justify-content:space-between;
    background:linear-gradient(135deg,var(--violet-700),var(--violet-500));color:#fff;
    border-radius:var(--radius-lg);padding:clamp(1.2rem,.9rem + 1.1vw,1.7rem) clamp(1.3rem,1rem + 1.4vw,2rem);
    box-shadow:var(--shadow)}
  .sw-pricetease-txt{max-width:56ch}
  .sw-pricetease-txt b{display:block;font-family:var(--font-head);font-weight:800;font-size:1.18rem;margin-bottom:.3rem;color:#fff}
  .sw-pricetease-txt span{color:#e9e1fb;font-size:.97rem}
  .sw-pricetease .sw-cta{flex:none}
  .sw-pricetease-note{flex-basis:100%;font-size:.74rem;color:#cebef5;margin:.2rem 0 0}

  /* sticky mobile CTA (appears after the reader scrolls past the hero) */
  .sw-stickybar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:none;
    align-items:center;gap:.6rem;justify-content:space-between;
    background:rgba(28,18,51,.97);color:#fff;padding:.5rem .8rem calc(.5rem + env(safe-area-inset-bottom));
    box-shadow:0 -10px 26px -14px rgba(0,0,0,.55);transform:translateY(115%);
    transition:transform .28s ease}
  .sw-stickybar.is-visible{transform:translateY(0)}
  .sw-stickybar-info{font-size:.76rem;line-height:1.25;min-width:0}
  .sw-stickybar-info b{display:block;font-family:var(--font-head);font-weight:800;font-size:.95rem}
  .sw-stickybar-info span{color:#c9bbf0}
  .sw-stickybar .sw-cta{padding:.55rem .95rem;min-height:42px;font-size:.85rem;flex:none}
  .sw-stickybar-close{flex:none;background:transparent;border:0;color:#b6a9d8;width:30px;height:30px;
    border-radius:8px;cursor:pointer;line-height:0;display:grid;place-items:center}
  .sw-stickybar-close:hover{background:rgba(255,255,255,.14);color:#fff}
  .sw-stickybar-close svg{width:16px;height:16px}

  /* trust badges row */
  .sw-badges{display:flex;flex-wrap:wrap;gap:.5rem}
  .sw-badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:700;
    color:var(--violet-800);background:var(--violet-050);border:1px solid var(--line);
    padding:.4rem .7rem;border-radius:8px}
  .sw-badge svg{width:15px;height:15px;color:var(--violet-500)}

  /* callout blocks (tldr / takeaways / note) */
  .sw-callout{border:1px solid var(--line-strong);border-left:5px solid var(--violet-500);
    background:var(--violet-050);border-radius:12px;padding:1.1rem 1.2rem}
  .sw-callout h2,.sw-callout h3{margin-bottom:.4rem}
  .sw-kicker{font-family:var(--font-head);font-weight:800;letter-spacing:.1em;text-transform:uppercase;
    font-size:.74rem;color:var(--violet-600);margin-bottom:.5rem}
  .sw-takeaways ul{display:grid;gap:.6rem;padding:0;list-style:none}
  .sw-takeaways li{position:relative;padding-left:1.7rem}
  .sw-takeaways li::before{content:"";position:absolute;left:0;top:.32em;width:14px;height:14px;
    border-radius:50%;background:var(--violet-500);
    box-shadow:0 0 0 4px var(--violet-100)}

  /* flag / warning watchdog box */
  .sw-flag{display:flex;gap:.7rem;background:var(--warn-bg);border:1px solid var(--warn-line);
    border-radius:12px;padding:1rem 1.1rem;color:#5d3500}
  .sw-flag svg{flex:none;width:20px;height:20px;color:var(--warn);margin-top:.15rem}
  .sw-flag strong{color:#5d3500}

  /* pros & cons */
  .sw-proscons{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
  .sw-pc{border-radius:var(--radius);padding:1.2rem;border:1px solid var(--line)}
  .sw-pc.is-pro{background:var(--pro-bg);border-color:#bfe6cb}
  .sw-pc.is-con{background:var(--con-bg);border-color:#f3c6ce}
  .sw-pc h3{display:flex;align-items:center;gap:.5rem}
  .sw-pc.is-pro h3{color:var(--pro)}
  .sw-pc.is-con h3{color:var(--con)}
  .sw-pc ul{display:grid;gap:.55rem;padding:0;list-style:none}
  .sw-pc li{position:relative;padding-left:1.6rem;font-size:.96rem}
  .sw-pc li svg{position:absolute;left:0;top:.18em;width:18px;height:18px}
  .sw-pc.is-pro li svg{color:var(--pro)}
  .sw-pc.is-con li svg{color:var(--con)}

  /* criteria bars */
  .sw-criteria{display:grid;gap:.85rem}
  .sw-criterion{display:grid;grid-template-columns:minmax(140px,1fr) 2fr auto;gap:.8rem;align-items:center}
  .sw-criterion-name{font-weight:700;font-size:.92rem;color:var(--ink-soft)}
  .sw-bar{height:11px;background:var(--violet-100);border-radius:999px;overflow:hidden}
  .sw-bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--violet-600),var(--violet-400))}
  .sw-criterion-num{font-family:var(--font-head);font-weight:800;color:var(--violet-700);font-size:.95rem;min-width:2.4rem;text-align:right}

  /* tables */
  .sw-table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:#fff}
  .sw-table{font-size:.94rem}
  .sw-table caption{text-align:left;font-size:.8rem;color:var(--muted);padding:.6rem .9rem}
  .sw-table th,.sw-table td{padding:.7rem .9rem;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
  .sw-table thead th{background:var(--violet-050);color:var(--violet-800);font-family:var(--font-head);
    font-weight:700;font-size:.85rem;letter-spacing:.02em}
  .sw-table tbody tr:last-child td{border-bottom:none}
  .sw-table td strong{color:var(--violet-800)}
  .sw-table .is-highlight{background:var(--violet-050)}

  /* snapshot metric grid */
  .sw-snapshot{display:grid;grid-template-columns:repeat(4,1fr);gap:.9rem}
  .sw-metric{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem;text-align:center}
  .sw-metric b{display:block;font-family:var(--font-head);font-weight:800;font-size:1.9rem;color:var(--violet-700);line-height:1}
  .sw-metric span{display:block;margin-top:.4rem;font-size:.78rem;color:var(--muted);line-height:1.35}

  /* rating distribution */
  .sw-dist{display:grid;gap:.5rem}
  .sw-dist-row{display:grid;grid-template-columns:54px 1fr 48px;gap:.6rem;align-items:center;font-size:.88rem}
  .sw-dist-row span:first-child{font-weight:700;color:var(--ink-soft)}
  .sw-dist-bar{height:14px;background:var(--violet-100);border-radius:999px;overflow:hidden}
  .sw-dist-fill{height:100%;background:linear-gradient(90deg,var(--star),#fbbf24);border-radius:999px}
  .sw-dist-row b{text-align:right;font-weight:700;color:var(--muted)}

  /* theme frequency */
  .sw-themes{display:grid;gap:.7rem}
  .sw-theme{display:grid;gap:.25rem}
  .sw-theme-head{display:flex;justify-content:space-between;font-size:.9rem}
  .sw-theme-head span{font-weight:700;color:var(--ink-soft)}
  .sw-theme-head b{color:var(--violet-700)}
  .sw-theme-bar{height:9px;background:var(--violet-100);border-radius:999px;overflow:hidden}
  .sw-theme-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--violet-500),var(--violet-400))}
  .sw-theme.is-neg .sw-theme-fill{background:linear-gradient(90deg,#e8895b,#f0b08a)}
  .sw-theme.is-neg b{color:#b4541f}

  /* testimonials */
  .sw-reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
  .sw-review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem;display:flex;flex-direction:column;gap:.6rem}
  .sw-review-top{display:flex;align-items:center;gap:.7rem}
  .sw-avatar{width:42px;height:42px;border-radius:50%;flex:none;display:grid;place-items:center;
    font-family:var(--font-head);font-weight:800;color:#fff;font-size:1rem;
    background:linear-gradient(150deg,var(--violet-600),var(--violet-400))}
  .sw-review-id{font-size:.85rem;line-height:1.3}
  .sw-review-id b{display:block;color:var(--ink)}
  .sw-review-id span{color:var(--muted);font-size:.78rem}
  .sw-review-stars{color:var(--star);font-size:.95rem}
  .sw-review p{font-size:.93rem;color:var(--ink-soft);margin:0}
  .sw-verified{display:inline-flex;align-items:center;gap:.3rem;font-size:.72rem;font-weight:700;
    color:var(--pro);background:var(--pro-bg);padding:.2rem .5rem;border-radius:6px;align-self:flex-start}
  .sw-verified svg{width:13px;height:13px}
  .sw-review.is-critical{border-color:#f0d49a;background:#fffaf0}

  /* review submission form */
  .sw-form{background:#fff;border:1px solid var(--line-strong);border-radius:var(--radius-lg);
    padding:clamp(1.2rem,.9rem + 1.2vw,2rem);box-shadow:var(--shadow-sm)}
  .sw-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
  .sw-field{display:flex;flex-direction:column;gap:.35rem}
  .sw-field.is-full{grid-column:1/-1}
  .sw-label{font-weight:700;font-size:.88rem;color:var(--ink-soft)}
  .sw-label .sw-req{color:var(--con)}
  .sw-hint{font-weight:400;font-size:.76rem;color:var(--muted)}
  .sw-input,.sw-textarea,.sw-select{width:100%;border:1.5px solid var(--line-strong);border-radius:10px;
    padding:.7rem .8rem;background:#fff;min-height:46px}
  .sw-textarea{min-height:120px;resize:vertical}
  .sw-input:focus,.sw-textarea:focus,.sw-select:focus{border-color:var(--violet-500)}
  /* star input (radio group) */
  .sw-stars-input{display:inline-flex;flex-direction:row-reverse;gap:.15rem}
  .sw-stars-input input{position:absolute;width:1px;height:1px;opacity:0;overflow:hidden}
  .sw-stars-input label{cursor:pointer;color:#d8cff0;padding:.1rem;line-height:0;border-radius:6px}
  .sw-stars-input label svg{width:30px;height:30px}
  .sw-stars-input input:checked ~ label,
  .sw-stars-input label:hover,
  .sw-stars-input label:hover ~ label{color:var(--star)}
  .sw-stars-input input:focus-visible + label{outline:3px solid var(--focus);outline-offset:2px}
  .sw-consent{display:flex;gap:.55rem;align-items:flex-start;font-size:.86rem;color:var(--ink-soft)}
  .sw-consent input{width:20px;height:20px;margin-top:.15rem;flex:none}
  .sw-honey{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
  .sw-form-note{font-size:.78rem;color:var(--muted)}
  .sw-form-success{display:none;background:var(--pro-bg);border:1px solid #bfe6cb;color:#14532d;
    border-radius:12px;padding:1rem 1.1rem;font-size:.95rem}
  .sw-form-success.is-shown{display:block}
  .sw-form.is-done .sw-form-body{display:none}

  /* FAQ */
  .sw-faq{display:grid;gap:.7rem}
  .sw-faq details{border:1px solid var(--line);border-radius:12px;background:#fff;overflow:hidden}
  .sw-faq summary{cursor:pointer;list-style:none;padding:1rem 1.1rem;font-weight:700;color:var(--violet-800);
    display:flex;justify-content:space-between;gap:1rem;align-items:center}
  .sw-faq summary::-webkit-details-marker{display:none}
  .sw-faq summary::after{content:"+";font-family:var(--font-head);font-size:1.3rem;color:var(--violet-500);flex:none}
  .sw-faq details[open] summary::after{content:"\2013"}
  .sw-faq-a{padding:0 1.1rem 1.1rem;color:var(--ink-soft);font-size:.96rem}

  /* footer */
  .sw-footer{background:#1c1233;color:#cfc4ea;padding-block:2.6rem 1.6rem;font-size:.9rem}
  .sw-footer a{color:#e4dcff;text-decoration:none}
  .sw-footer a:hover{color:#fff;text-decoration:underline}
  .sw-footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:1.8rem;margin-bottom:1.6rem}
  .sw-footer-head{font-family:var(--font-head);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;
    color:#fff;margin-bottom:.7rem;font-weight:700}
  .sw-footer-brand{display:flex;align-items:center;gap:.5rem;font-family:var(--font-head);font-weight:800;
    color:#fff;font-size:1.05rem;margin-bottom:.6rem}
  .sw-footer-brand svg{width:26px;height:26px}
  .sw-footer-col ul{display:grid;gap:.45rem}
  .sw-footer p{color:#b6a9d8;font-size:.85rem;margin-bottom:.7rem}
  .sw-footer-legal{border-top:1px solid rgba(255,255,255,.14);padding-top:1.2rem;display:grid;gap:.8rem}
  .sw-disclaimer{font-size:.76rem;color:#9c8fc2;line-height:1.55}
  .sw-disclaimer strong{color:#cfc4ea}
  .sw-copyright{font-size:.78rem;color:#9c8fc2}

  /* misc */
  .sw-updated{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--muted)}
  .sw-anchor{scroll-margin-top:90px}
  .sw-lead{font-size:1.12rem;color:var(--ink-soft)}
  .sw-section.is-tint{background:var(--bg-tint)}
  .sw-section.is-deep{background:linear-gradient(160deg,#2a0d5f,#4c1d95);color:#ece6fb}
  .sw-section.is-deep h2{color:#fff}
  .sw-divider{height:1px;background:var(--line);border:0;margin:0}
}

/* ---------------------------------------------------------------- sections */
@layer sections{
  .sw-section-head{max-width:60ch;margin-bottom:1.4rem}
  .sw-section-head p{color:var(--muted)}
  .sw-two{display:grid;grid-template-columns:1.05fr .95fr;gap:2rem;align-items:start}
}

/* -------------------------------------------------------------- utilities */
@layer utilities{
  .sw-u-center{text-align:center}
  .sw-u-muted{color:var(--muted)}
  .sw-u-mt{margin-top:1.4rem}
  .sw-u-mt-sm{margin-top:.7rem}
  .sw-u-sr{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0}
  .sw-u-nowrap{white-space:nowrap}
  .sw-u-fullcta{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}
}

/* ------------------------------------------------------------- responsive */
@layer responsive{
  @media (max-width:920px){
    .sw-hero-grid{grid-template-columns:1fr;gap:1.4rem}
    .sw-hero-media{order:-1;width:min(100%,280px)}
    .sw-two{grid-template-columns:1fr}
    .sw-reviews{grid-template-columns:1fr 1fr}
    .sw-snapshot{grid-template-columns:repeat(2,1fr)}
  }
  @media (max-width:760px){
    .sw-nav{position:fixed;inset:62px 0 auto 0;background:#fff;border-bottom:1px solid var(--line);
      box-shadow:var(--shadow);padding:.6rem 1.2rem 1rem;display:none}
    .sw-nav.is-open{display:block}
    .sw-nav-list{flex-direction:column;align-items:stretch;gap:.15rem}
    .sw-nav-link{padding:.7rem .6rem}
    .sw-nav-toggle{display:inline-flex}
    .sw-header-cta{display:none}
    .sw-stickybar{display:flex}
    body.stickybar-on{padding-bottom:64px}
    .sw-pricetease{flex-direction:column;align-items:flex-start;text-align:left}
    .sw-pricetease .sw-cta{width:100%}
    .sw-verdict-top{grid-template-columns:1fr;text-align:center}
    .sw-score{flex-direction:row;gap:.7rem;justify-content:center;min-width:0}
    .sw-score b{font-size:2.2rem}
    .sw-facts{grid-template-columns:1fr 1fr}
    .sw-proscons{grid-template-columns:1fr}
    .sw-form-grid{grid-template-columns:1fr}
    .sw-criterion{grid-template-columns:1fr auto;grid-template-areas:"name num" "bar bar"}
    .sw-criterion-name{grid-area:name}
    .sw-criterion-num{grid-area:num}
    .sw-bar{grid-area:bar}
    .sw-footer-grid{grid-template-columns:1fr}
  }
  @media (max-width:520px){
    .sw-reviews{grid-template-columns:1fr}
    .sw-snapshot{grid-template-columns:1fr 1fr}
    .sw-facts{grid-template-columns:1fr}
    .sw-metric b{font-size:1.6rem}
  }
}
