/* ============================================================
   reviews.css — Shared styles for all product review pages
   Used by: immunocal-review, immunocal-platinum-review,
            immunocal-sport-review, nutricost-glutathione-review
   ============================================================ */

/* ── BREADCRUMB ──────────────────────────────────────────── */
.breadcrumb { background: rgba(0,0,0,.2); border-bottom: 1px solid var(--border); padding: 10px 0; font-size: .78rem; color: var(--text-muted); }
.breadcrumb .container { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.breadcrumb a { color: var(--page-light); text-decoration: none; }
.breadcrumb a:hover { text-decoration: underline; }
.breadcrumb .sep { color: var(--border); }

/* ── TOP BAND ────────────────────────────────────────────── */
.top-band { width: 100%; display: block; padding: 10px 20px; text-align: center; font-size: .72rem; letter-spacing: 3px; text-transform: uppercase; font-weight: 700; border-bottom: 2px solid var(--page-orange); background: var(--page-band-bg, #09090b); color: var(--page-band-text, var(--page-orange)); box-sizing: border-box; }
.top-band span { color: var(--page-orange); }

/* ── PRODUCT HERO ────────────────────────────────────────── */
.product-hero { display: grid; grid-template-columns: 340px 1fr; gap: 48px; align-items: start; padding: 56px 0 48px; }
@media(max-width:800px){ .product-hero { grid-template-columns: 1fr; } }

.product-image-wrap { background: #fff; border-radius: 16px; overflow: hidden; display: flex; align-items: center; justify-content: center; aspect-ratio: 1; padding: 24px; position: sticky; top: 20px; border: 2px solid var(--page-primary); box-shadow: 0 0 30px var(--page-glow); }
.product-image-wrap img { max-width: 100%; max-height: 100%; object-fit: contain; }

.review-eyebrow { font-size: .68rem; letter-spacing: 3px; text-transform: uppercase; color: var(--page-light); margin-bottom: 10px; }

.product-title { font-family: 'Bebas Neue', sans-serif; font-size: clamp(1.8rem,4vw,3rem); letter-spacing: 1px; line-height: 1.1; margin-bottom: 8px; color: #fff; }
.product-title span { color: var(--page-light); background: none; -webkit-text-fill-color: var(--page-light); }

.product-subtitle { font-size: .9rem; color: var(--text-muted); margin-bottom: 18px; line-height: 1.5; }

.rating-row { display: flex; align-items: center; gap: 10px; margin-bottom: 22px; flex-wrap: wrap; }
.rating-stars { color: var(--gold); font-size: 1.2rem; }
.rating-score { font-size: 1.3rem; font-weight: 700; color: #fff; }
.rating-count { font-size: .82rem; color: var(--text-muted); }
.sales-badge { background: rgba(249,115,22,.12); border: 1px solid rgba(249,115,22,.3); color: var(--page-orange); font-size: .72rem; font-weight: 700; padding: 4px 10px; border-radius: 20px; letter-spacing: 1px; }

.price-row { display: flex; align-items: baseline; gap: 10px; margin-bottom: 20px; }
.price-main { font-family: 'Bebas Neue', sans-serif; font-size: 2.4rem; color: #fff; line-height: 1; }
.price-per { font-size: .82rem; color: var(--text-muted); }

/* ── STAT CARDS — orange numbers across all pages ────────── */
.stats-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; margin-bottom: 22px; }
.stats-grid.cols-3 { grid-template-columns: repeat(3,1fr); }
.stats-grid.cols-6 { grid-template-columns: repeat(3,1fr); }
@media(max-width:700px){ .stats-grid, .stats-grid.cols-3, .stats-grid.cols-6 { grid-template-columns: 1fr 1fr; } }

.stat-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: 12px; padding: 18px 14px; text-align: center; }
.stat-card .stat-num { font-family: 'Bebas Neue', sans-serif; font-size: 2rem; color: var(--page-orange); line-height: 1; margin-bottom: 4px; }
.stat-card .stat-label { font-size: .7rem; color: var(--text-muted); line-height: 1.4; }

/* ── SPECS ───────────────────────────────────────────────── */
.specs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 22px; }
.spec-item { background: var(--bg-card); border: 1px solid var(--border); border-radius: 10px; padding: 12px 14px; }
.spec-label { font-size: .65rem; letter-spacing: 2px; text-transform: uppercase; color: var(--page-light); margin-bottom: 4px; }
.spec-value { font-size: .9rem; font-weight: 600; color: #fff; }

/* ── CERT TAGS ───────────────────────────────────────────── */
.certs-row { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 22px; }
.cert-tag { font-size: .72rem; font-weight: 600; background: rgba(255,255,255,.05); border: 1px solid var(--border); border-radius: 20px; padding: 5px 12px; color: var(--text-muted); }

/* ── FEATURE LIST ────────────────────────────────────────── */
.features-list { list-style: none; margin-bottom: 28px; display: flex; flex-direction: column; gap: 10px; }
.features-list li { display: flex; gap: 10px; font-size: .9rem; color: var(--text-muted); line-height: 1.5; }
.fp-bullet { color: var(--page-orange); font-weight: 700; min-width: 16px; margin-top: 1px; }

/* ── CTA ─────────────────────────────────────────────────── */
.cta-wrap { display: flex; flex-direction: column; gap: 10px; }
.btn-cta { display: inline-block; background: var(--page-btn-grad); color: #fff; font-weight: 700; font-size: 1rem; padding: 16px 28px; border-radius: 10px; text-decoration: none; text-align: center; box-shadow: 0 4px 20px var(--page-btn-shadow); transition: opacity .2s, transform .15s; letter-spacing: .5px; }
.btn-cta:hover { opacity: .88; transform: translateY(-1px); }
.guarantee-note { font-size: .82rem; color: var(--page-orange); font-weight: 600; }
.trust-note { font-size: .76rem; color: var(--text-muted); }

/* ── AMAZON CHOICE BADGE ─────────────────────────────────── */
.amazon-choice-badge { background: #232f3e; color: var(--page-orange); font-size: .72rem; font-weight: 700; letter-spacing: 1px; padding: 5px 12px; border-radius: 4px; display: inline-block; margin-bottom: 12px; }

/* ── CONTENT SECTIONS ────────────────────────────────────── */
.content-wrap { padding-bottom: 60px; }
.content-section { padding: 48px 0; border-top: 1px solid var(--border); }
.content-section .eyebrow { font-size: .68rem; letter-spacing: 3px; text-transform: uppercase; color: var(--page-light); margin-bottom: 10px; }
.content-section h2 { font-family: 'Bebas Neue', sans-serif; font-size: 1.9rem; letter-spacing: 1px; margin-bottom: 18px; }
.content-section p { font-size: .93rem; color: var(--text-muted); line-height: 1.8; margin-bottom: 14px; }

/* ── CALLOUT BOX ─────────────────────────────────────────── */
.callout-box { background: var(--page-callout-bg); border: 1px solid var(--page-callout-border); border-left: 4px solid var(--page-primary); border-radius: 10px; padding: 22px 24px; margin: 24px 0; }
.callout-box h3 { font-size: 1rem; font-weight: 700; color: var(--page-orange); margin-bottom: 8px; }
.callout-box p { font-size: .88rem; color: var(--text-muted); line-height: 1.7; margin: 0; }

/* ── INGREDIENT / SCIENCE NUMBERED ITEMS ────────────────── */
.science-list, .rank-steps { display: flex; flex-direction: column; gap: 14px; margin-top: 20px; }
.science-item, .rank-step { background: var(--bg-card); border: 1px solid var(--border); border-radius: 12px; padding: 20px 22px; display: flex; gap: 18px; align-items: flex-start; }
.science-num, .step-num { font-family: 'Bebas Neue', sans-serif; font-size: 2rem; color: var(--page-orange); line-height: 1; min-width: 40px; }
.science-item h4, .rank-step h3 { font-size: .95rem; font-weight: 700; color: #fff; margin-bottom: 5px; }
.science-item p, .rank-step p { font-size: .85rem; color: var(--text-muted); line-height: 1.6; margin: 0; }

/* ── INGREDIENT CARDS ────────────────────────────────────── */
.ingredients-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-top: 24px; }
@media(max-width:700px){ .ingredients-grid { grid-template-columns: 1fr; } }
.ingredient-card { background: var(--bg-card); border: 1px solid var(--border); border-top: 3px solid var(--page-primary); border-radius: 14px; padding: 26px 22px; }
.ingredient-num { font-family: 'Bebas Neue', sans-serif; font-size: 2.8rem; color: var(--page-orange); line-height: 1; margin-bottom: 8px; }
.ingredient-card h3 { font-size: 1rem; font-weight: 700; color: #fff; margin-bottom: 6px; }
.ingredient-card .subtitle { font-size: .72rem; letter-spacing: 2px; text-transform: uppercase; color: var(--page-light); margin-bottom: 12px; display: block; }
.ingredient-card p { font-size: .85rem; color: var(--text-muted); line-height: 1.65; margin: 0; }

/* ── BENEFITS / PERFORMANCE GRID ────────────────────────── */
.benefits-grid, .perf-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 20px; }
@media(max-width:600px){ .benefits-grid, .perf-grid { grid-template-columns: 1fr; } }
.benefit-item, .perf-item { background: var(--bg-card); border: 1px solid var(--border); border-radius: 10px; padding: 16px 18px; display: flex; gap: 14px; align-items: flex-start; transition: border-color .2s; }
.benefit-item:hover, .perf-item:hover { border-color: rgba(249,115,22,.3); }
.benefit-icon, .perf-icon { font-size: 1.3rem; min-width: 26px; }
.benefit-item strong, .perf-item strong { display: block; font-size: .9rem; color: #fff; margin-bottom: 4px; }
.benefit-item p, .perf-item p { font-size: .84rem; color: var(--text-muted); line-height: 1.55; margin: 0; }

/* ── FACT SHEET ──────────────────────────────────────────── */
.fact-sheet { display: flex; flex-direction: column; border: 1px solid var(--border); border-radius: 12px; overflow: hidden; margin-top: 20px; }
.fact-row { display: grid; grid-template-columns: 160px 1fr; border-bottom: 1px solid var(--border); }
.fact-row:last-child { border-bottom: none; }
.fact-key { padding: 14px 18px; font-size: .72rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--page-orange); background: var(--bg-card); display: flex; align-items: center; }
.fact-val { padding: 14px 18px; font-size: .88rem; color: var(--text-muted); line-height: 1.55; display: flex; align-items: center; }

/* ── COMPARISON TABLE ────────────────────────────────────── */
.compare-wrap { overflow-x: auto; margin-top: 24px; }
.compare-tbl { width: 100%; border-collapse: collapse; font-size: .85rem; }
.compare-tbl th { background: var(--bg-card); padding: 12px 16px; text-align: left; font-size: .68rem; letter-spacing: 2px; text-transform: uppercase; color: var(--text-muted); border-bottom: 2px solid var(--border); }
.compare-tbl th.page-col { color: var(--page-orange); border-bottom-color: var(--page-orange); }
.compare-tbl td { padding: 12px 16px; border-bottom: 1px solid var(--border); color: var(--text-muted); vertical-align: middle; }
.compare-tbl td.page-col { background: rgba(249,115,22,.05); color: #fff; font-weight: 600; }
.compare-tbl tr:hover td { background: rgba(255,255,255,.02); }
.compare-tbl .check { color: var(--green); font-weight: 700; font-size: 1rem; }
.compare-tbl .cross { color: var(--red); font-weight: 700; font-size: 1rem; }

/* ── PROS / CONS ─────────────────────────────────────────── */
.pros-cons-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 20px; }
@media(max-width:600px){ .pros-cons-grid { grid-template-columns: 1fr; } }
.pros-col { background: var(--bg-card); border: 1px solid var(--border); border-top: 3px solid var(--page-orange); border-radius: 12px; padding: 24px; }
.cons-col { background: var(--bg-card); border: 1px solid var(--border); border-top: 3px solid var(--red); border-radius: 12px; padding: 24px; }
.pros-col h3 { color: var(--page-orange); font-size: .85rem; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 14px; }
.cons-col h3 { color: var(--red); font-size: .85rem; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 14px; }
.pros-col ul, .cons-col ul { list-style: none; display: flex; flex-direction: column; gap: 9px; }
.pros-col li, .cons-col li { font-size: .87rem; color: var(--text-muted); padding-left: 18px; position: relative; line-height: 1.5; }
.pros-col li::before { content: '✓'; position: absolute; left: 0; color: var(--page-orange); font-weight: 700; }
.cons-col li::before { content: '✗'; position: absolute; left: 0; color: var(--red); font-weight: 700; }

/* ── VERDICT BOX ─────────────────────────────────────────── */
.verdict-box { background: var(--page-verdict-bg); border: 1px solid var(--page-verdict-border); border-radius: 16px; padding: 44px 40px; text-align: center; margin: 48px 0; box-shadow: 0 0 40px var(--page-verdict-glow); }
.verdict-box .eyebrow { font-size: .68rem; letter-spacing: 3px; text-transform: uppercase; color: var(--page-light); margin-bottom: 10px; }
.verdict-score { font-family: 'Bebas Neue', sans-serif; font-size: 5rem; color: var(--page-orange); line-height: 1; }
.verdict-stars { color: var(--gold); font-size: 1.4rem; margin-bottom: 16px; }
.verdict-box h2 { font-family: 'Bebas Neue', sans-serif; font-size: 1.8rem; letter-spacing: 1px; margin-bottom: 16px; }
.verdict-box p { max-width: 680px; margin: 0 auto 28px; font-size: .95rem; color: var(--text-muted); line-height: 1.8; }
.btn-verdict { display: inline-block; background: var(--page-btn-grad); color: #fff; font-weight: 700; font-size: 1rem; padding: 16px 32px; border-radius: 10px; text-decoration: none; box-shadow: 0 4px 20px var(--page-btn-shadow); transition: opacity .2s, transform .15s; }
.btn-verdict:hover { opacity: .88; transform: translateY(-1px); }

/* ── CUSTOMER REVIEWS ────────────────────────────────────── */
.reviews-section { padding: 48px 0; border-top: 1px solid var(--border); }
.reviews-section .eyebrow { font-size: .68rem; letter-spacing: 3px; text-transform: uppercase; color: var(--page-light); margin-bottom: 10px; }
.reviews-section h2 { font-family: 'Bebas Neue', sans-serif; font-size: 1.9rem; letter-spacing: 1px; margin-bottom: 28px; }
.reviews-summary { display: flex; align-items: center; gap: 20px; margin-bottom: 32px; }
.big-score { font-family: 'Bebas Neue', sans-serif; font-size: 4rem; color: var(--page-orange); line-height: 1; }
.score-stars { color: var(--gold); font-size: 1.3rem; margin-bottom: 4px; }
.score-count { font-size: .82rem; color: var(--text-muted); }
.reviews-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media(max-width:640px){ .reviews-grid { grid-template-columns: 1fr; } }
.review-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: 12px; padding: 22px; }
.review-top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 8px; }
.reviewer-name { font-weight: 700; font-size: .9rem; color: #fff; }
.review-date { font-size: .75rem; color: var(--text-muted); margin-top: 2px; }
.review-stars { color: var(--gold); font-size: .95rem; }
.review-title { font-weight: 700; font-size: .9rem; margin-bottom: 8px; color: #fff; }
.review-text { font-size: .85rem; color: var(--text-muted); line-height: 1.65; }
.verified-badge { font-size: .7rem; color: var(--green); font-weight: 600; margin-top: 10px; }

/* ── FAQ ─────────────────────────────────────────────────── */
.faq-section { padding: 48px 0; border-top: 1px solid var(--border); }
.faq-section .eyebrow { font-size: .68rem; letter-spacing: 3px; text-transform: uppercase; color: var(--page-light); margin-bottom: 10px; }
.faq-section h2 { font-family: 'Bebas Neue', sans-serif; font-size: 1.9rem; letter-spacing: 1px; margin-bottom: 24px; }
.faq-item { background: var(--bg-card); border: 1px solid var(--border); border-radius: 10px; margin-bottom: 10px; overflow: hidden; }
.faq-question { width: 100%; background: none; border: none; padding: 18px 22px; font-family: 'DM Sans', sans-serif; font-size: .93rem; font-weight: 600; color: var(--text); cursor: pointer; display: flex; justify-content: space-between; align-items: center; text-align: left; }
.faq-question:hover { color: #fff; }
.faq-chevron { color: var(--page-light); font-size: 1.2rem; transition: transform .2s; }
.faq-question.open .faq-chevron { transform: rotate(180deg); }
.faq-answer { display: none; padding: 16px 22px 20px; font-size: .87rem; color: var(--text-muted); line-height: 1.75; border-top: 1px solid var(--border); }

/* ── MISC ────────────────────────────────────────────────── */
.context-box { background: linear-gradient(135deg, rgba(249,115,22,.04) 0%, var(--bg-card) 100%); border: 1px solid rgba(249,115,22,.2); border-radius: 14px; padding: 28px; margin: 32px 0; }
.context-box h3 { font-family: 'Bebas Neue', sans-serif; font-size: 1.4rem; letter-spacing: 1px; margin-bottom: 14px; color: #fff; }
.context-box p { font-size: .88rem; color: var(--text-muted); line-height: 1.75; margin-bottom: 10px; }
.product-disclaimer { background: var(--bg-card); border: 1px solid var(--border); border-radius: 12px; padding: 22px 24px; margin: 32px 0; font-size: .78rem; color: var(--text-muted); line-height: 1.7; }

/* ── QUALITY BADGES (Nutricost) ──────────────────────────── */
.quality-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; margin-top: 24px; }
@media(max-width:600px){ .quality-grid { grid-template-columns: 1fr 1fr; } }
.quality-badge { background: var(--bg-card); border: 1px solid var(--border); border-radius: 12px; padding: 20px 14px; text-align: center; transition: border-color .2s, transform .2s; }
.quality-badge:hover { border-color: var(--page-orange); transform: translateY(-2px); }
.quality-badge .qb-icon { font-size: 2rem; margin-bottom: 10px; display: block; }
.quality-badge h4 { font-size: .82rem; font-weight: 700; color: #fff; margin-bottom: 4px; }
.quality-badge p { font-size: .75rem; color: var(--text-muted); line-height: 1.4; margin: 0; }

/* ── SUPPLEMENT FACTS (Nutricost) ────────────────────────── */
.supfacts { background: #fff; border-radius: 12px; padding: 28px; max-width: 440px; margin-top: 24px; }
.supfacts h3 { font-family: serif; font-size: 1.6rem; font-weight: 900; color: #000; border-bottom: 8px solid #000; padding-bottom: 4px; margin-bottom: 8px; }
.supfacts .sf-row { font-size: .82rem; color: #000; border-bottom: 1px solid #ccc; padding: 5px 0; display: flex; justify-content: space-between; }
.supfacts .sf-row.thick { border-bottom: 4px solid #000; }
.supfacts .sf-header { display: flex; justify-content: space-between; font-weight: 700; font-size: .78rem; color: #000; border-bottom: 4px solid #000; padding: 4px 0; }
.supfacts .sf-ingredient { display: flex; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid #ccc; }
.supfacts .sf-ingredient span { font-size: .85rem; color: #000; }
.supfacts .sf-ingredient .amount { font-weight: 700; }
.supfacts .sf-note { font-size: .72rem; color: #000; margin-top: 8px; }
.supfacts .sf-other { font-size: .75rem; color: #333; margin-top: 12px; line-height: 1.5; }
