/* ===========================================================
   Deskrune — block library
   Reusable section primitives. Every page should be composed
   of these blocks for layout coherence.

   Inventory (matches BLOCKS.md):
     .block-lead-magnet     — free PDF capture row
     .choose-grid           — "help me choose" decision grid
     .product-grid          — product cards container
     .product-card          — single product card
     .comparison-table      — side-by-side spec table
     .faq-block             — accordion of <details>
     .sticky-buy-bar        — bottom-fixed buy bar (revealed on scroll)
     .section-inner-narrow  — narrow content rail (~720px)

   Tokens come from theme.css. Visuals continue visual-pass.css.
   2026-05-08
   =========================================================== */

/* Narrow content rail for FAQ + CTA banner */
.section-inner-narrow {
  max-width: var(--ds-container-narrow);
  margin: 0 auto;
}

/* ─── Lead magnet block ─── */
.block-lead-magnet {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(220px, 1fr);
  gap: var(--ds-s-7);
  align-items: center;
  background: var(--ds-surface);
  border: 1px solid var(--ds-rule);
  border-radius: var(--ds-r-lg);
  padding: var(--ds-s-7);
  box-shadow: var(--ds-shadow-1);
  margin-top: var(--ds-s-5);
}
@media (max-width: 760px) {
  .block-lead-magnet {
    grid-template-columns: 1fr;
    padding: var(--ds-s-5);
  }
}
.block-lead-magnet .blm-eyebrow {
  display: inline-block;
  font-family: var(--ds-font-sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ds-accent);
  background: var(--ds-accent-soft);
  padding: 4px 10px;
  border-radius: 999px;
  margin-bottom: var(--ds-s-3);
}
.block-lead-magnet h3 {
  font-family: var(--ds-font-serif);
  font-weight: 500;
  font-size: clamp(22px, 2.6vw, 30px);
  line-height: 1.18;
  color: var(--ds-ink);
  margin: 0 0 var(--ds-s-3);
}
.block-lead-magnet p {
  color: var(--ds-ink-soft);
  font-size: 16px;
  line-height: 1.55;
  margin: 0 0 var(--ds-s-4);
  max-width: 50ch;
}
.block-lead-magnet .blm-form {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  position: relative;
}
.block-lead-magnet input[type=email] {
  flex: 1;
  min-width: 220px;
  font-family: var(--ds-font-sans);
  font-size: 15px;
  padding: 14px 16px;
  border: 1px solid var(--ds-rule-strong);
  border-radius: var(--ds-r-md);
  background: var(--ds-bg);
  color: var(--ds-ink);
  min-height: 48px;
}
.block-lead-magnet input[type=email]:focus {
  outline: 0;
  border-color: var(--ds-accent);
  box-shadow: 0 0 0 4px var(--ds-focus-ring);
}
.block-lead-magnet .blm-tiny {
  font-size: 12px;
  color: var(--ds-ink-faint);
  margin-top: var(--ds-s-3);
  margin-bottom: 0;
}
.block-lead-magnet .blm-cover {
  display: block;
  position: relative;
  border-radius: var(--ds-r-md);
  overflow: hidden;
  aspect-ratio: 4 / 5;
  border: 1px solid var(--ds-rule);
  background: var(--ds-surface-2);
  text-decoration: none;
  color: var(--ds-ink);
}
.block-lead-magnet .blm-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.block-lead-magnet .blm-preview {
  position: absolute;
  bottom: 12px;
  left: 12px;
  font-family: var(--ds-font-sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  background: var(--ds-surface);
  color: var(--ds-ink);
  padding: 6px 10px;
  border-radius: var(--ds-r-sm);
  border: 1px solid var(--ds-rule);
  box-shadow: var(--ds-shadow-1);
}

/* ─── Help me choose ─── */
.choose-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--ds-s-3);
  margin-top: var(--ds-s-5);
}
.choose-card {
  background: var(--ds-surface);
  border: 1px solid var(--ds-rule);
  border-radius: var(--ds-r-md);
  padding: var(--ds-s-5);
  text-decoration: none;
  color: var(--ds-ink);
  display: flex;
  flex-direction: column;
  gap: var(--ds-s-3);
  transition:
    transform 380ms var(--ease-out-soft),
    border-color 240ms var(--ease-quiet),
    box-shadow 380ms var(--ease-out-soft);
}
.choose-card:hover {
  transform: translateY(-2px);
  border-color: var(--ds-rule-strong);
  box-shadow: var(--ds-shadow-2);
}
.choose-card.choose-recommended {
  border-color: var(--ds-accent);
  background: linear-gradient(180deg, var(--ds-accent-soft) 0%, var(--ds-surface) 80%);
}
.choose-card .choose-tag {
  font-family: var(--ds-font-sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ds-ink-faint);
}
.choose-card.choose-recommended .choose-tag { color: var(--ds-accent); }
.choose-card h3 {
  font-family: var(--ds-font-serif);
  font-weight: 500;
  font-size: 18px;
  line-height: 1.32;
  color: var(--ds-ink);
  margin: 0;
}
.choose-card .choose-rec {
  font-family: var(--ds-font-sans);
  font-weight: 600;
  font-size: 14px;
  color: var(--ds-accent);
  margin: 0;
}

/* ─── Product cards ─── */
.product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--ds-s-4);
  margin-top: var(--ds-s-5);
}
.product-card {
  background: var(--ds-surface);
  border: 1px solid var(--ds-rule);
  border-radius: var(--ds-r-md);
  padding: var(--ds-s-6);
  display: flex;
  flex-direction: column;
  gap: var(--ds-s-3);
  transition:
    transform 380ms var(--ease-out-soft),
    border-color 240ms var(--ease-quiet),
    box-shadow 380ms var(--ease-out-soft);
}
.product-card:hover {
  transform: translateY(-3px);
  border-color: var(--ds-rule-strong);
  box-shadow: var(--ds-shadow-2);
}
.product-card-feature {
  border-color: var(--ds-accent);
  background:
    radial-gradient(120% 100% at 0% 0%, var(--ds-accent-soft) 0%, transparent 60%),
    var(--ds-surface);
  box-shadow: 0 12px 32px -12px color-mix(in srgb, var(--ds-accent) 30%, transparent);
}
.product-card .pc-tag {
  display: inline-block;
  align-self: flex-start;
  font-family: var(--ds-font-sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ds-accent);
  background: var(--ds-accent-soft);
  padding: 4px 10px;
  border-radius: 999px;
}
.product-card h3 {
  font-family: var(--ds-font-serif);
  font-weight: 500;
  font-size: clamp(18px, 1.8vw, 22px);
  line-height: 1.2;
  color: var(--ds-ink);
  margin: 0;
}
.product-card p {
  color: var(--ds-ink-soft);
  font-size: 15px;
  line-height: 1.55;
  margin: 0;
  max-width: 50ch;
}
.product-card .pc-price {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-top: var(--ds-s-2);
}
.product-card .pc-now {
  font-family: var(--ds-font-serif);
  font-size: 28px;
  font-weight: 600;
  color: var(--ds-ink);
  line-height: 1;
}
.product-card .pc-was {
  color: var(--ds-ink-faint);
  text-decoration: line-through;
  font-size: 14px;
}
.product-card .pc-off {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--ds-accent);
  background: var(--ds-accent-soft);
  padding: 3px 7px;
  border-radius: var(--ds-r-sm);
  text-transform: uppercase;
}
.product-card .pc-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
  padding-top: var(--ds-s-3);
}

/* Kit fineprint */
.kits-fineprint {
  margin-top: var(--ds-s-6);
  font-size: 13px;
  color: var(--ds-ink-faint);
  max-width: 70ch;
  line-height: 1.6;
}

/* ─── Comparison table ─── */
.comparison-wrap {
  margin-top: var(--ds-s-5);
  overflow-x: auto;
  border: 1px solid var(--ds-rule);
  border-radius: var(--ds-r-md);
  background: var(--ds-surface);
}
.comparison-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--ds-font-sans);
  font-size: 14px;
  color: var(--ds-ink);
}
.comparison-table thead th {
  text-align: left;
  padding: 14px 18px;
  background: var(--ds-surface-2);
  color: var(--ds-ink-soft);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--ds-rule);
}
.comparison-table tbody td {
  padding: 14px 18px;
  border-bottom: 1px solid var(--ds-rule);
  color: var(--ds-ink-soft);
  vertical-align: middle;
}
.comparison-table tbody tr:last-child td { border-bottom: 0; }
.comparison-table tbody tr:hover td { background: var(--ds-surface-2); }
.comparison-table a { color: var(--ds-accent); text-decoration: none; }
.comparison-table a:hover { text-decoration: underline; }

/* ─── FAQ accordion ─── */
.faq-block {
  margin-top: var(--ds-s-5);
  border: 1px solid var(--ds-rule);
  border-radius: var(--ds-r-md);
  background: var(--ds-surface);
  overflow: hidden;
}
.faq-block details {
  border-bottom: 1px solid var(--ds-rule);
}
.faq-block details:last-child { border-bottom: 0; }
.faq-block summary {
  list-style: none;
  cursor: pointer;
  padding: 18px 22px;
  font-family: var(--ds-font-sans);
  font-size: 16px;
  font-weight: 600;
  color: var(--ds-ink);
  position: relative;
  padding-right: 48px;
  transition: background-color 200ms var(--ease-quiet);
}
.faq-block summary:hover { background: var(--ds-surface-2); }
.faq-block summary::-webkit-details-marker { display: none; }
.faq-block summary::after {
  content: "+";
  position: absolute;
  right: 22px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 22px;
  color: var(--ds-accent);
  font-weight: 400;
  transition: transform 220ms var(--ease-out-soft);
  line-height: 1;
}
.faq-block details[open] > summary::after {
  content: "−";
}
.faq-block details[open] > summary {
  background: var(--ds-surface-2);
}
.faq-block p {
  margin: 0;
  padding: 0 22px 22px;
  color: var(--ds-ink-soft);
  font-size: 15px;
  line-height: 1.65;
  max-width: 65ch;
}
.faq-block a { color: var(--ds-accent); }

/* ─── Sticky buy bar ─── */
.sticky-buy-bar {
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: 16px;
  z-index: 80;
  background: var(--ds-surface);
  color: var(--ds-ink);
  border: 1px solid var(--ds-rule);
  border-radius: var(--ds-r-md);
  padding: 10px 16px;
  box-shadow: var(--ds-shadow-3);
  transform: translateY(140%);
  opacity: 0;
  transition:
    transform 420ms var(--ease-out-soft),
    opacity 420ms var(--ease-out-soft);
  pointer-events: none;
}
.sticky-buy-bar.is-visible {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}
.sticky-buy-bar .sbb-inner {
  max-width: var(--ds-container);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--ds-s-4);
  flex-wrap: wrap;
}
.sticky-buy-bar .sbb-text {
  display: flex;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
  min-width: 0;
}
.sticky-buy-bar .sbb-text strong {
  font-family: var(--ds-font-sans);
  font-size: 14px;
  color: var(--ds-ink);
}
.sticky-buy-bar .sbb-price {
  font-family: var(--ds-font-serif);
  font-size: 17px;
  color: var(--ds-ink);
  font-weight: 600;
}
.sticky-buy-bar .sbb-price s {
  color: var(--ds-ink-faint);
  font-weight: 400;
  font-size: 13px;
  margin-left: 6px;
}
.sticky-buy-bar .sbb-actions {
  display: flex;
  gap: 8px;
}
.sticky-buy-bar .sbb-actions .hero-action {
  padding: 10px 16px;
  font-size: 13px;
  min-height: 40px;
}
@media (max-width: 560px) {
  .sticky-buy-bar { left: 8px; right: 8px; bottom: 8px; padding: 10px 12px; }
  .sticky-buy-bar .sbb-secondary { display: none; }
  .sticky-buy-bar .sbb-actions .hero-action { width: auto; }
  .sticky-buy-bar .sbb-text { flex: 1 1 100%; }
}

/* Print: hide all sticky/floating UI */
@media print {
  .sticky-buy-bar { display: none !important; }
}
