/* ===========================================================================
   CarAudioNow — Product-driven buyer's guide styles
   File: gillion-child/assets/can-guide.css
   Loaded only on guides that use the can/* blocks (has_block gate).
   All classes are cag- prefixed to avoid collisions with Gillion + plugins.
   Reconciled to the markup emitted by render-pick-card.php / render-compare-table.php
   and the page-chrome authored as wp:html blocks.
   =========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root{
  --can-navy:#1A1A2E; --can-navy2:#232a45; --can-ink:#1d1c2b;
  --can-red:#E74C3C; --can-red-d:#c0392b; --can-marine:#5BC0DE;
  --can-muted:#6b7280; --can-line:#e7e9ee; --can-mist:#f6f7f9; --can-paper:#fff;
  --can-good:#1f9d57; --can-bad:#d6483f; --can-amber:#f5a623;
  --can-shadow:0 1px 2px rgba(16,24,40,.06),0 8px 24px rgba(16,24,40,.08);
  --can-shadow-lg:0 12px 40px rgba(16,24,40,.16);
  --can-radius:14px; --can-container:1180px;
}

/* Scope a sane baseline to our components only (don't restyle the whole theme). */
.cag-guide,
.cag-subnav,
.cag-hero,
.cag-trust,
.cag-compare-wrap,
.cag-section,
.cag-pick,
.cag-stickybuy{ font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif; }

html:has(.cag-pick), html:has(.cag-compare){ scroll-behavior:smooth; scroll-padding-top:140px; }

.cag-wrap{ max-width:var(--can-container); margin:0 auto; padding:0 20px; }
.cag-section{ padding:42px 0; }
.cag-section--tight{ padding:26px 0; }
.cag-muted{ color:var(--can-muted); }
.cag-eyebrow{ font-size:12.48px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--can-red); }
.cag-shead{ display:flex; align-items:baseline; gap:12px; flex-wrap:wrap; margin-bottom:6px; }
.cag-shead .cag-num{ font-size:12.8px; font-weight:800; color:var(--can-red); }
.cag-shead h2{ margin:0; font-size:clamp(22.4px,2.6vw,32px); font-weight:800; letter-spacing:-.01em; line-height:1.2; }

.cag-btn{ display:inline-flex; align-items:center; gap:8px; font-weight:800; padding:13px 20px; border-radius:11px; font-size:15.2px; cursor:pointer; border:0; transition:.15s; text-decoration:none; }
.cag-btn:hover{ text-decoration:none; transform:translateY(-1px); }
.cag-btn-red{ background:var(--can-red); color:#fff; }
.cag-btn-red:hover{ background:var(--can-red-d); color:#fff; }
.cag-btn-ghost{ background:rgba(255,255,255,.08); color:#fff; border:1px solid rgba(255,255,255,.28); }
.cag-btn-ghost:hover{ background:rgba(255,255,255,.16); color:#fff; }
.cag-btn-marine{ background:var(--can-marine); color:#08344a; }
.cag-btn-marine:hover{ background:#7fd0e8; color:#08344a; }

/* Full-bleed helper: break sections out of the theme's 1200px content container. */
.cag-bleed{ width:100vw; position:relative; left:50%; right:50%; margin-left:-50vw; margin-right:-50vw; }

/* ---------- Sticky sub-nav ---------- */
.cag-subnav{ position:fixed; top:77px; left:0; right:0; width:auto; margin:0; z-index:55; background:rgba(26,26,46,.97); backdrop-filter:saturate(160%) blur(8px); color:#fff; border-bottom:1px solid rgba(255,255,255,.08); opacity:0; visibility:hidden; transition:opacity .2s ease; }
.cag-subnav.cag-stuck{ opacity:1; visibility:visible; }
.cag-subnav .cag-wrap{ display:flex; align-items:center; gap:14px; height:60px; }
.cag-subnav .cag-brand{ font-weight:900; letter-spacing:-.02em; font-size:16px; white-space:nowrap; }
.cag-subnav .cag-brand b{ color:var(--can-red); }
.cag-subnav nav{ display:flex; gap:6px; overflow-x:auto; flex:1; scrollbar-width:none; }
.cag-subnav nav::-webkit-scrollbar{ display:none; }
.cag-subnav a.cag-pill{ color:#cfd3e6; font-size:13.44px; font-weight:600; padding:7px 12px; border-radius:20px; white-space:nowrap; transition:.15s; text-decoration:none; }
.cag-subnav a.cag-pill:hover{ background:rgba(255,255,255,.08); color:#fff; text-decoration:none; }
.cag-subnav a.cag-pill.cag-active{ background:var(--can-red); color:#fff; }
.cag-subnav .cag-nav-cta{ background:#fff; color:var(--can-navy); font-weight:800; font-size:13.12px; padding:9px 14px; border-radius:10px; white-space:nowrap; text-decoration:none; }
.cag-subnav .cag-nav-cta:hover{ background:#f0f0f0; text-decoration:none; }

/* ---------- Hero (answer-first) ---------- */
.cag-hero{ position:relative; color:#fff; background:linear-gradient(120deg,#15162b 0%, #1A1A2E 45%, #251f45 100%); overflow:hidden; --cag-hero-bg:none; }
/* Backdrop image is injected per-page from the page's featured image via the
   --cag-hero-bg custom property (set inline in cag_render_hero). No featured
   image -> falls back to "none" (gradient only). */
.cag-hero::after{ content:""; position:absolute; inset:0; background:var(--cag-hero-bg) center/cover; opacity:.16; mix-blend-mode:luminosity; }
.cag-hero .cag-wrap{ position:relative; z-index:2; padding:40px 20px 30px; }
.cag-hero h1{ font-size:clamp(30.4px,4.4vw,48px); font-weight:900; color:#fff; max-width:18ch; line-height:1.15; margin:0 0 .3em; }
.cag-hero .cag-dek{ font-size:16.96px; color:#d7dbf0; max-width:60ch; margin:0 0 18px; }
.cag-hero-meta{ display:flex; flex-wrap:wrap; gap:8px 18px; font-size:13.76px; color:#aeb4d6; margin-bottom:22px; }
.cag-hero-meta span{ display:inline-flex; align-items:center; gap:6px; }
.cag-dot{ width:8px; height:8px; border-radius:50%; background:var(--can-marine); display:inline-block; }
.cag-hero-actions{ display:flex; gap:12px; flex-wrap:wrap; margin-bottom:8px; }

/* answer-first verdict grid — fits 5, scrolls horizontally beyond that */
.cag-verdict{ display:flex; gap:12px; margin-top:26px; overflow-x:auto; scroll-snap-type:x mandatory; padding-bottom:6px; scrollbar-width:thin; scrollbar-color:rgba(255,255,255,.3) transparent; }
.cag-verdict::-webkit-scrollbar{ height:6px; }
.cag-verdict::-webkit-scrollbar-thumb{ background:rgba(255,255,255,.25); border-radius:3px; }
.cag-vcard{ flex:0 0 calc((100% - 48px)/5); min-width:148px; scroll-snap-align:start; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); border-radius:12px; padding:14px; text-decoration:none; color:#fff; transition:.18s; display:flex; flex-direction:column; gap:6px; }
.cag-vcard:hover{ background:rgba(255,255,255,.12); border-color:var(--can-marine); text-decoration:none; transform:translateY(-2px); color:#fff; }
.cag-vcard .cag-vsize{ font-size:11.84px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; color:var(--can-marine); }
.cag-vcard .cag-vprod{ font-weight:700; font-size:15.2px; line-height:1.25; }
.cag-vcard .cag-vseries{ font-size:11.2px; font-weight:700; letter-spacing:.02em; color:#ffd98a; }
.cag-vcard .cag-vprice{ font-size:13.12px; color:#c9cee8; margin-top:auto; }
.cag-vcard .cag-varrow{ font-size:12.48px; color:#fff; opacity:.7; }

/* ---------- Trust bar ---------- */
.cag-trust{ background:var(--can-navy2); color:#dfe3f4; }
.cag-trust .cag-wrap{ display:flex; align-items:center; gap:18px; padding:14px 20px; flex-wrap:wrap; }
.cag-trust img{ width:46px; height:46px; border-radius:50%; border:2px solid var(--can-marine); }
.cag-trust .cag-who{ font-size:14.4px; }
.cag-trust .cag-who b{ color:#fff; }
.cag-trust .cag-pts{ display:flex; gap:16px; flex-wrap:wrap; margin-left:auto; font-size:13.12px; }
.cag-trust .cag-pts span{ display:inline-flex; align-items:center; gap:7px; }
.cag-ck{ color:var(--can-marine); font-weight:900; }

/* ---------- Comparison table ---------- */
.cag-compare-wrap{ padding:42px 0; }
.cag-compare-h{ font-size:clamp(22.4px,2.6vw,32px); font-weight:800; letter-spacing:-.01em; margin:0 0 10px; }
.cag-table-scroll{ overflow-x:auto; border-radius:var(--can-radius); border:1px solid var(--can-line); box-shadow:var(--can-shadow); }
table.cag-compare{ width:100%; border-collapse:collapse; min-width:760px; font-size:14.4px; background:#fff; }
table.cag-compare thead th{ position:sticky; top:0; background:var(--can-navy); color:#fff !important; text-align:left; padding:13px 12px !important; font-size:11.84px; letter-spacing:.02em; text-transform:uppercase; cursor:pointer; white-space:normal; line-height:1.22; vertical-align:bottom; }
table.cag-compare thead th:hover{ background:#23243f; }
table.cag-compare thead th .cag-ar{ opacity:.5; font-size:11.2px; }
table.cag-compare tbody td{ padding:13px 12px !important; border-bottom:1px solid var(--can-line); vertical-align:middle; }
table.cag-compare tbody tr[data-jump]{ cursor:pointer; }
table.cag-compare tbody tr:hover{ background:var(--can-mist); }
.cag-cmp-prod{ display:flex; align-items:center; gap:10px; min-width:140px; }
.cag-cmp-prod img{ width:44px; height:44px; object-fit:contain; background:#f1f2f6; border-radius:8px; padding:4px; flex:none; }
.cag-cmp-prod .cag-nm{ font-weight:700; line-height:1.2; }
/* Dedicated "Sizes"/"Channels" comparison column: a wrap of compact variant chips */
.cag-th-sizes{ background:var(--can-navy); color:#fff !important; text-align:left; padding:13px 12px !important; font-size:11.84px; letter-spacing:.02em; text-transform:uppercase; white-space:normal; line-height:1.22; vertical-align:bottom; }
.cag-cmp-sizecell{ min-width:120px; }
.cag-szchip{ display:inline-block; font-size:11.84px; font-weight:700; color:var(--can-navy); background:#eef1f8; border-radius:7px; padding:3px 8px; margin:2px 3px 2px 0; white-space:nowrap; }
.cag-szchip--one{ background:transparent; color:var(--can-muted); padding-left:0; }
.cag-sz{ display:inline-block; font-weight:800; font-size:12.8px; background:#eef1f8; color:var(--can-navy); padding:5px 10px; border-radius:8px; }
.cag-rating{ display:inline-flex; align-items:center; gap:6px; font-weight:800; }
.cag-stars{ color:var(--can-amber); letter-spacing:1px; font-size:13.6px; }
.cag-price-cell{ font-weight:800; color:var(--can-ink); white-space:nowrap; }
.cag-tbtn{ display:inline-block; background:var(--can-red); color:#fff; font-weight:800; font-size:12.8px; padding:8px 14px; border-radius:9px; white-space:nowrap; text-decoration:none; }
.cag-tbtn:hover{ background:var(--can-red-d); color:#fff; text-decoration:none; }
.cag-disclosure{ font-size:11.84px; color:var(--can-muted); margin:11px 0 0; font-style:italic; }

/* ---------- How we test ---------- */
.cag-howtest{ background:var(--can-mist); border:1px solid var(--can-line); border-radius:var(--can-radius); padding:24px; }
.cag-howtest .cag-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:8px; }
.cag-crit{ background:#fff; border:1px solid var(--can-line); border-radius:11px; padding:14px; }
.cag-crit b{ display:block; margin-bottom:3px; }
.cag-crit p{ margin:0; font-size:13.76px; color:var(--can-muted); }

/* ---------- Buyer context ---------- */
.cag-context ol{ counter-reset:c; list-style:none; padding:0; margin:14px 0 0; display:grid; gap:12px; }
.cag-context li{ position:relative; padding:14px 16px 14px 56px; background:#fff; border:1px solid var(--can-line); border-radius:12px; box-shadow:var(--can-shadow); }
.cag-context li::before{ counter-increment:c; content:counter(c); position:absolute; left:14px; top:14px; width:30px; height:30px; border-radius:8px; background:var(--can-navy); color:#fff; display:grid; place-items:center; font-weight:800; font-size:15.2px; }

/* ---------- Pick cards ---------- */
.cag-pick{ scroll-margin-top:140px; border:1px solid var(--can-line); border-radius:18px; overflow:hidden; box-shadow:var(--can-shadow); margin-bottom:30px; background:#fff; }
.cag-pick-head{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; padding:16px 22px; background:linear-gradient(90deg,var(--can-navy),#262c49); color:#fff; }
.cag-award{ display:inline-flex; align-items:center; gap:8px; font-weight:900; font-size:17.92px; }
.cag-award .cag-ic{ width:26px; height:26px; background:var(--can-red); border-radius:7px; display:grid; place-items:center; font-size:14.4px; }
.cag-bestfor{ background:rgba(91,192,222,.16); color:#bfe9f6; border:1px solid rgba(91,192,222,.4); font-weight:700; font-size:12.8px; padding:5px 11px; border-radius:20px; }
.cag-series-tag{ display:inline-flex; align-items:center; gap:6px; background:rgba(245,166,35,.16); color:#ffd98a; border:1px solid rgba(245,166,35,.42); font-weight:800; font-size:12.16px; letter-spacing:.01em; padding:5px 11px; border-radius:20px; }
.cag-series-tag .cag-ic{ font-size:11px; line-height:1; }
.cag-rate{ margin-left:auto; display:flex; align-items:center; gap:8px; font-weight:800; }
.cag-rate .cag-score{ background:#fff; color:var(--can-navy); border-radius:8px; padding:3px 9px; font-size:15.2px; }
.cag-rate .cag-stars{ color:#ffd36b; }
.cag-pick-body{ display:grid; grid-template-columns:1.05fr 1fr; gap:0; }
.cag-media{ position:relative; background:linear-gradient(135deg,#eef1f7,#dfe3ef); min-height:300px; display:flex; align-items:center; padding:22px; }
.cag-media-track{ display:flex; gap:14px; overflow-x:auto; scroll-snap-type:x mandatory; width:100%; scrollbar-width:none; }
.cag-media-track::-webkit-scrollbar{ display:none; }
.cag-media-track img{ scroll-snap-align:center; margin:0 auto; max-height:280px; width:auto; object-fit:contain; filter:drop-shadow(0 10px 24px rgba(0,0,0,.18)); flex:0 0 100%; }
.cag-dots{ position:absolute; bottom:14px; left:0; right:0; display:flex; gap:7px; justify-content:center; }
.cag-cdot{ width:8px; height:8px; padding:0; border:0; border-radius:50%; background:rgba(26,26,46,.22); cursor:pointer; transition:transform .15s, background .15s; }
.cag-cdot:hover{ background:rgba(26,26,46,.45); }
.cag-cdot.is-active{ background:var(--can-navy); transform:scale(1.25); }
.cag-cdot:focus-visible{ outline:2px solid var(--can-marine); outline-offset:2px; }
.cag-buy{ padding:22px; }
.cag-pick-name{ font-size:18.88px; margin:0 0 4px; font-weight:800; }
.cag-pick-sub{ color:var(--can-muted); font-size:13.76px; margin:0 0 14px; }
.cag-quickspecs{ display:grid; grid-template-columns:1fr 1fr; gap:8px; margin:0 0 16px; }
.cag-quickspecs div{ background:var(--can-mist); border:1px solid var(--can-line); border-radius:9px; padding:8px 10px; font-size:13.12px; }
.cag-quickspecs b{ display:block; color:var(--can-muted); font-weight:600; font-size:11.2px; text-transform:uppercase; letter-spacing:.04em; }
.cag-buy-row{ display:grid; gap:8px; }
.cag-buy-row .cegg-button, .cag-buy-row a.btn{ width:100%; }

/* Series variant (size / channels / impedance) selector inside the buy area */
.cag-sizes{ margin:0 0 14px; }
.cag-sizes-h{ font-size:11.2px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:var(--can-muted); margin:0 0 8px; }
.cag-size-tabs{ display:flex; flex-wrap:wrap; gap:8px; margin:0 0 12px; }
.cag-size-tab{ display:flex; flex-direction:column; align-items:flex-start; gap:1px; padding:8px 14px; border-radius:11px; background:#fff; border:1.5px solid var(--can-line); color:var(--can-navy); cursor:pointer; font:inherit; line-height:1.15; text-align:left; transition:.15s; }
.cag-size-tab:hover{ border-color:var(--can-marine); }
.cag-size-tab.is-active{ background:var(--can-navy); border-color:var(--can-navy); color:#fff; box-shadow:var(--can-shadow); }
.cag-size-tab .cag-size-lab{ font-weight:800; font-size:13.92px; }
.cag-size-tab .cag-size-price{ font-size:11.84px; font-weight:600; color:var(--can-muted); }
.cag-size-tab.is-active .cag-size-price{ color:#cfd6ef; }
.cag-size-pane[hidden]{ display:none; }

.cag-pick-detail{ padding:6px 22px 22px; border-top:1px solid var(--can-line); }
.cag-why h4{ font-size:16px; margin:16px 0 6px; font-weight:800; }
.cag-why p{ margin:0 0 8px; }
.cag-specs-pros{ display:grid; grid-template-columns:1.1fr 1fr; gap:18px; margin-top:18px; }
table.cag-spectable{ width:100%; border-collapse:collapse; font-size:13.6px; }
table.cag-spectable td{ padding:8px 10px; border-bottom:1px solid var(--can-line); }
table.cag-spectable tr:nth-child(odd){ background:var(--can-mist); }
table.cag-spectable td:first-child{ font-weight:700; width:46%; color:var(--can-navy); }
.cag-proscons{ display:grid; gap:12px; }
.cag-pc{ border-radius:12px; padding:14px 16px; }
.cag-pro{ background:#eef8f1; border:1px solid #cdeed8; }
.cag-con{ background:#fdeeee; border:1px solid #f6d4d2; }
.cag-pc h5{ margin:0 0 8px; font-size:14.72px; }
.cag-pro h5{ color:var(--can-good); }
.cag-con h5{ color:var(--can-bad); }
.cag-pc ul{ margin:0; padding-left:6px; list-style:none; }
.cag-pc li{ position:relative; padding:3px 0 3px 24px; font-size:13.76px; }
.cag-pro li::before{ content:"✓"; position:absolute; left:0; color:var(--can-good); font-weight:900; }
.cag-con li::before{ content:"✕"; position:absolute; left:0; color:var(--can-bad); font-weight:900; }

/* ---------- Fit guide CTA ---------- */
.cag-fitcta{ background:linear-gradient(120deg,var(--can-navy),#243a52); color:#fff; border-radius:18px; padding:30px; display:flex; align-items:center; gap:24px; flex-wrap:wrap; overflow:hidden; position:relative; }
.cag-fitcta::before{ content:""; position:absolute; right:-40px; top:-40px; width:220px; height:220px; background:radial-gradient(circle,var(--can-marine),transparent 70%); opacity:.4; }
.cag-fitcta .cag-fc-txt{ flex:1 1 320px; position:relative; z-index:2; }
.cag-fitcta h2{ color:#fff; margin:0 0 6px; font-weight:800; }
.cag-fitcta p{ color:#cfe6f1; margin:0 0 4px; max-width:54ch; }
.cag-fitcta .cag-btn{ position:relative; z-index:2; }

/* ---------- FAQ ---------- */
.cag-faq h2{ margin-bottom:6px; }
.cag-faq-list{ display:grid; gap:10px; margin-top:14px; }
.cag-faq-item{ border:1px solid var(--can-line); border-radius:12px; background:#fff; padding:0 18px; box-shadow:var(--can-shadow); }
.cag-faq-item summary{ list-style:none; cursor:pointer; padding:15px 0; font-weight:700; font-size:16px; display:flex; justify-content:space-between; gap:14px; align-items:center; }
.cag-faq-item summary::-webkit-details-marker{ display:none; }
.cag-faq-item summary .cag-pm{ flex:none; width:24px; height:24px; border-radius:7px; background:var(--can-mist); display:grid; place-items:center; color:var(--can-red); font-weight:900; transition:.2s; }
.cag-faq-item[open] summary .cag-pm{ transform:rotate(45deg); background:var(--can-red); color:#fff; }
.cag-faq-item .cag-ans{ padding:0 0 16px; color:#3a3a4a; font-size:14.72px; }
.cag-faq-item .cag-ans p{ margin:0 0 8px; }

/* ---------- Related ---------- */
.cag-related-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:14px; }
.cag-rc{ border:1px solid var(--can-line); border-radius:12px; overflow:hidden; background:#fff; box-shadow:var(--can-shadow); transition:.15s; text-decoration:none; }
.cag-rc:hover{ transform:translateY(-3px); box-shadow:var(--can-shadow-lg); text-decoration:none; }
.cag-rc .cag-thumb{ aspect-ratio:16/10; background:linear-gradient(135deg,#e7eaf2,#d4d9e6); }
.cag-rc .cag-rc-body{ padding:12px 14px; }
.cag-rc .cag-rc-body b{ font-size:14.4px; line-height:1.3; display:block; color:var(--can-ink); }
.cag-rc .cag-rc-body span{ font-size:12.16px; color:var(--can-muted); }

/* ---------- Author ---------- */
.cag-author{ display:flex; gap:20px; background:var(--can-mist); border:1px solid var(--can-line); border-radius:var(--can-radius); padding:24px; align-items:flex-start; }
.cag-author img{ width:96px; height:96px; border-radius:14px; border:2px solid var(--can-marine); flex:none; background:#fff; }
.cag-author h3{ margin:0 0 4px; }
.cag-author .cag-role{ color:var(--can-red); font-weight:700; font-size:13.76px; margin-bottom:8px; }
.cag-author p{ font-size:14.4px; margin:0 0 8px; }

/* ---------- Sticky buy bar (markup built by can-guide.js) ---------- */
.cag-stickybuy{ position:fixed; left:0; right:0; bottom:0; z-index:70; background:#fff; border-top:1px solid var(--can-line); box-shadow:0 -8px 30px rgba(16,24,40,.12); transform:translateY(110%); transition:transform .28s ease; }
.cag-stickybuy.cag-show{ transform:translateY(0); }
.cag-stickybuy .cag-inner{ max-width:var(--can-container); margin:0 auto; display:flex; align-items:center; gap:16px; padding:11px 20px; }
.cag-stickybuy img{ width:42px; height:42px; object-fit:contain; background:#f1f2f6; border-radius:8px; padding:3px; flex:none; }
.cag-stickybuy .cag-sb-name{ min-width:0; font-weight:800; font-size:14.4px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cag-stickybuy .cag-sb-name small{ display:block; color:var(--can-muted); font-size:12.16px; font-weight:600; }
.cag-stickybuy .cag-sb-price{ font-weight:900; font-size:16.8px; margin-left:auto; white-space:nowrap; }
.cag-stickybuy .cag-sb-go{ background:var(--can-red); color:#fff; font-weight:800; padding:11px 18px; border-radius:11px; font-size:14.4px; text-decoration:none; white-space:nowrap; }
.cag-stickybuy .cag-sb-go:hover{ background:var(--can-red-d); color:#fff; text-decoration:none; }
.cag-stickybuy .cag-sb-close{ background:none; border:0; color:var(--can-muted); font-size:20.8px; cursor:pointer; padding:4px 6px; }

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .cag-vcard{ flex-basis:calc((100% - 12px)/2); }
  .cag-pick-body{ grid-template-columns:1fr; }
  .cag-media{ min-height:230px; }
  .cag-specs-pros{ grid-template-columns:1fr; }
  .cag-howtest .cag-grid{ grid-template-columns:1fr; }
  .cag-related-grid{ grid-template-columns:repeat(2,1fr); }
  .cag-trust .cag-pts{ margin-left:0; width:100%; }
}
@media(max-width:600px){
  .cag-vcard{ flex-basis:72%; min-width:0; }
  .cag-quickspecs{ grid-template-columns:1fr 1fr; }
  .cag-subnav nav{ display:none; }
  .cag-author{ flex-direction:column; }
  .cag-hero-actions .cag-btn{ flex:1; }
  .cag-stickybuy .cag-sb-name small{ display:none; }
}


/* Force Inter across the redesign components (Gillion sets Roboto on h1-h4/p directly). */
.cag-guide,.cag-guide *,.cag-subnav,.cag-subnav *,.cag-compare-wrap,.cag-compare-wrap *,.cag-section,.cag-section *,.cag-section--tight,.cag-section--tight *,.cag-pick,.cag-pick *,.cag-stickybuy,.cag-stickybuy *{font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif !important;}

/* ---------- Buy Now CTA (comparison table) ---------- */
.cag-buy-cta{ display:inline-flex; flex-direction:column; align-items:center; gap:1px; background:var(--can-red); color:#fff; font-weight:800; padding:7px 12px; border-radius:9px; text-decoration:none; line-height:1.15; white-space:nowrap; transition:.15s; }
.cag-buy-cta:hover{ background:var(--can-red-d); color:#fff; text-decoration:none; transform:translateY(-1px); }
.cag-buy-cta-top{ font-size:13.5px; }
.cag-buy-cta-top b{ font-weight:900; }
.cag-buy-cta-sub{ font-size:10.5px; font-weight:600; opacity:.85; }
.cag-buy-cta--alt{ background:#eef1f8; color:var(--can-navy); font-weight:700; padding:9px 14px; }
.cag-buy-cta--alt:hover{ background:#e3e7f2; color:var(--can-navy); }

/* ---------- Cross-links to deeper size lists ---------- */
.cag-crosslinks{ margin-top:13px; display:flex; flex-wrap:wrap; align-items:center; gap:8px; }
.cag-crosslinks-label{ font-size:13px; font-weight:700; color:var(--can-muted); }
.cag-crosslink{ font-size:13.5px; font-weight:700; color:var(--can-red); text-decoration:none; background:#fdeef0; border:1px solid #f6d4d8; padding:5px 11px; border-radius:20px; transition:.15s; }
.cag-crosslink:hover{ background:var(--can-red); color:#fff; text-decoration:none; }

/* ---------- Bigger, bolder Content Egg buy buttons inside pick cards ---------- */
.cag-buy-row .cegg-click,
.cag-buy-row .egg-btns-row a.btn{ font-size:16px !important; font-weight:800 !important; padding:15px 18px !important; line-height:1.25 !important; border-radius:11px !important; letter-spacing:.01em; }

/* ---------- APH-39: monetized fallback CTA when a pick has no live priced offer ---------- */
.cag-buy-row .cag-buy-fallback{ display:flex; align-items:center; justify-content:center; gap:7px; width:100%; box-sizing:border-box; background:var(--can-red); color:#fff; font-size:16px; font-weight:800; padding:15px 18px; border-radius:11px; line-height:1.25; letter-spacing:.01em; text-decoration:none; transition:.15s; }
.cag-buy-row .cag-buy-fallback:hover{ background:var(--can-red-d); color:#fff; text-decoration:none; transform:translateY(-1px); }
.cag-buy-row .cag-buy-fallback .cag-bf-arrow{ font-weight:700; }

/* ---------- Pick media: Video / Photos toggle + lazy video facade ---------- */
.cag-media{ flex-direction:column; align-items:stretch; justify-content:center; gap:12px; }
.cag-media-switch{ align-self:center; display:inline-flex; gap:2px; padding:3px; background:rgba(26,26,46,.08); border-radius:999px; }
.cag-ms-btn{ display:inline-flex; align-items:center; gap:7px; border:0; background:transparent; color:var(--can-navy); font-size:12.5px; font-weight:800; padding:6px 15px; border-radius:999px; cursor:pointer; transition:.15s; }
.cag-ms-btn:hover{ color:var(--can-red); }
.cag-ms-btn.is-active{ background:#fff; color:var(--can-navy); box-shadow:0 1px 3px rgba(16,24,40,.2); }
.cag-ms-ic{ width:13px; height:13px; display:inline-block; position:relative; }
.cag-ms-play::before{ content:""; position:absolute; inset:0; margin:auto; width:0; height:0; border-style:solid; border-width:6px 0 6px 10px; border-color:transparent transparent transparent currentColor; }
.cag-ms-photo{ border:2px solid currentColor; border-radius:3px; box-sizing:border-box; }
.cag-media-stage{ position:relative; width:100%; }
.cag-media-pane[hidden]{ display:none; }
.cag-media-photos{ position:relative; }
.cag-video-facade{ position:relative; display:block; width:100%; aspect-ratio:16/9; padding:0; border:0; border-radius:12px; overflow:hidden; cursor:pointer; background:#000; box-shadow:0 10px 24px rgba(0,0,0,.18); }
.cag-video-facade img{ width:100%; height:100%; object-fit:cover; display:block; transition:.25s; }
.cag-video-facade:hover img{ transform:scale(1.04); opacity:.92; }
.cag-video-play{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:64px; height:45px; border-radius:12px; background:var(--can-red); box-shadow:0 6px 18px rgba(0,0,0,.4); transition:.15s; }
.cag-video-play::before{ content:""; position:absolute; left:50%; top:50%; transform:translate(-42%,-50%); width:0; height:0; border-style:solid; border-width:10px 0 10px 16px; border-color:transparent transparent transparent #fff; }
.cag-video-facade:hover .cag-video-play{ background:var(--can-red-d); transform:translate(-50%,-50%) scale(1.07); }
.cag-media-video iframe{ width:100%; aspect-ratio:16/9; border:0; border-radius:12px; display:block; box-shadow:0 10px 24px rgba(0,0,0,.18); }

/* ---------- Photo carousel: uniform, naturally-framed product cards ---------- */
/* Each image gets the same white "stage" card so products sit centered with
   breathing room and white-bg shots blend in (no hard rectangle vs the gray). */
.cag-media-photos{ display:flex; flex-direction:column; gap:10px; }
.cag-media-photos .cag-media-track{ align-items:stretch; }
.cag-media-photos .cag-media-track img{
  flex:0 0 100%; width:100%; max-height:none; margin:0;
  aspect-ratio:3/2; object-fit:contain;            /* matches the product photos (~1.44–1.66) so they nearly fill the card */
  background:#fff; border-radius:12px; padding:14px; box-sizing:border-box;
  box-shadow:0 10px 24px rgba(16,24,40,.12); filter:none;
}
.cag-media-photos .cag-dots{ position:static; bottom:auto; left:auto; right:auto; margin:2px 0 0; }
@media (max-width:768px){ .cag-media-photos .cag-media-track img{ padding:12px; } }

/* ---------- Carousel arrows (desktop affordance; mobile uses swipe) ---------- */
.cag-cnav{ position:absolute; top:50%; transform:translateY(-50%); z-index:3; display:flex; align-items:center; justify-content:center; width:34px; height:34px; padding:0; border:0; border-radius:50%; background:rgba(255,255,255,.82); box-shadow:0 2px 10px rgba(16,24,40,.2); color:var(--can-navy); cursor:pointer; opacity:.72; transition:opacity .15s, background .15s; }
.cag-cnav:hover{ opacity:1; background:#fff; }
.cag-cnav:focus-visible{ outline:2px solid var(--can-marine); outline-offset:2px; opacity:1; }
.cag-cnav[disabled]{ opacity:0; pointer-events:none; }
.cag-cnav::before{ content:""; width:9px; height:9px; border-style:solid; border-color:currentColor; border-width:2px 2px 0 0; }
.cag-cprev{ left:10px; }
.cag-cprev::before{ transform:rotate(-135deg); margin-left:4px; }
.cag-cnext{ right:10px; }
.cag-cnext::before{ transform:rotate(45deg); margin-right:4px; }
@media (max-width:768px){ .cag-cnav{ display:none; } }

/* ===========================================================================
   Child sub-guide chrome — parent back-link (in hero) + sibling sub-guide nav.
   Auto-rendered from page hierarchy (post_parent) by render-guide-family.php.
   =========================================================================== */

/* "Parent guide" back-link — a marine-accent pill at the top of the dark hero;
   filled circular ↑ badge + "PARENT GUIDE" kicker over the bold parent title, with
   a "View all →" affordance and a solid-cyan hover so it reads as a clear up-link. */
.cag-parentlink{ display:inline-flex; align-items:center; gap:11px; margin:0 0 20px; padding:8px 16px 8px 9px; border-radius:999px; background:rgba(91,192,222,.13); border:1.5px solid rgba(91,192,222,.55); color:#eef9fd !important; font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif; text-decoration:none; transition:.18s; box-shadow:0 6px 20px rgba(0,0,0,.22); }
.cag-parentlink:hover{ background:var(--can-marine); border-color:var(--can-marine); color:#08344a !important; text-decoration:none; transform:translateY(-1px); box-shadow:0 10px 26px rgba(91,192,222,.40); }
.cag-parentlink .cag-parentlink-ar{ display:inline-grid; place-items:center; flex:none; width:28px; height:28px; border-radius:50%; background:var(--can-marine); color:#08344a; font-size:15px; font-weight:900; transition:.18s; }
.cag-parentlink:hover .cag-parentlink-ar{ background:#08344a; color:var(--can-marine); }
.cag-parentlink-txt{ display:flex; flex-direction:column; line-height:1.15; }
.cag-parentlink-kicker{ font-size:10px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--can-marine); transition:.18s; }
.cag-parentlink:hover .cag-parentlink-kicker{ color:#08344a; }
.cag-parentlink-txt b{ font-size:14.72px; font-weight:800; }
.cag-parentlink-go{ margin-left:4px; font-size:12.5px; font-weight:800; opacity:.85; white-space:nowrap; }
@media(max-width:600px){ .cag-parentlink-go{ display:none; } }
/* Two+ parents: the real post_parent + editor-set secondary "Related guide" links,
   laid out as a wrapping row. A single parent renders no wrapper (unchanged). The
   "--related" variant is the same pill, slightly de-emphasised so the true parent
   reads first. */
.cag-parentlinks{ display:flex; flex-wrap:wrap; gap:10px; margin:0 0 20px; }
.cag-parentlinks .cag-parentlink{ margin:0; }
.cag-parentlink--related{ background:rgba(91,192,222,.07); border-color:rgba(91,192,222,.38); }
.cag-parentlink--related .cag-parentlink-ar{ background:rgba(91,192,222,.85); }

/* "More <Parent> guides" — the across-cluster band at the end of a sub-guide. */
.cag-siblings{ background:var(--can-mist); border-top:1px solid var(--can-line); border-bottom:1px solid var(--can-line); }
.cag-sib-head{ margin-bottom:16px; }
.cag-sib-head .cag-sib-parent{ margin-left:auto; font-size:13.6px; font-weight:700; color:var(--can-red); text-decoration:none; white-space:nowrap; }
.cag-sib-head .cag-sib-parent:hover{ text-decoration:underline; }
.cag-sib-nav{ display:flex; flex-wrap:wrap; gap:10px; }
.cag-sib-pill{ display:inline-flex; align-items:center; padding:9px 16px; border-radius:999px; background:#fff; border:1px solid var(--can-line); color:var(--can-navy); font-size:13.76px; font-weight:700; text-decoration:none; box-shadow:var(--can-shadow); transition:.15s; }
a.cag-sib-pill:hover{ background:var(--can-red); border-color:var(--can-red); color:#fff; text-decoration:none; transform:translateY(-2px); box-shadow:var(--can-shadow-lg); }
.cag-sib-pill.is-current{ background:var(--can-navy); border-color:var(--can-navy); color:#fff; cursor:default; box-shadow:none; }
@media(max-width:600px){ .cag-sib-head .cag-sib-parent{ margin-left:0; width:100%; } }

/* Author-bio block (E-E-A-T) — reuses .cag-author; adds the content column + link. */
.cag-author-main{ flex:1; min-width:0; }
.cag-author-main h3{ font-size:18.4px; }
.cag-author-main .cag-role{ color:var(--can-red); font-weight:700; font-size:13.76px; margin-bottom:8px; }
.cag-author-link{ display:inline-block; margin-top:4px; font-weight:800; font-size:13.76px; color:var(--can-red); text-decoration:none; }
.cag-author-link:hover{ text-decoration:underline; }

/* Related-links: text-only variant of the .cag-rc card (no thumbnail) with an arrow. */
.cag-rc--link{ display:flex; align-items:center; }
.cag-rc--link .cag-rc-body{ width:100%; padding:14px 16px; }
.cag-rc--link .cag-rc-body b{ position:relative; display:block; padding-right:18px; }
.cag-rc--link .cag-rc-body b::after{ content:"→"; position:absolute; right:0; top:0; color:var(--can-red); font-weight:900; transition:transform .15s; }
.cag-rc--link:hover .cag-rc-body b::after{ transform:translateX(3px); }
