/* =====================================================
   ACBUY — main stylesheet
   Palette (acbuy.lat-inspired): acbuy red #E12B33, true black #0F0F0F, surface #FEE2E4
   Haul Reviews uses a distinct scheme so the two pages never feel alike.
   ===================================================== */

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

:root {
    --c-primary: #E12B33;
    --c-primary-d: #B71F26;
    --c-primary-l: #FF3A42;
    --c-accent: #0ea5e9;
    --c-accent-d: #0284c7;
    --c-ok: #10B981;
    --c-warn: #F59E0B;
    --c-bad: #EF4444;
    --c-ink: #0F0F0F;
    --c-ink-soft: #1A1A1A;
    --c-mute: #737373;
    --c-line: #E5E5E5;
    --c-bg: #ffffff;
    --c-surface: #FEE2E4;
    --c-surface-2: #FDD3D6;
    --c-surface-neutral: #FAFAFA;
    --radius: 14px;
    --radius-sm: 8px;
    --shadow-sm: 0 1px 2px rgba(0,0,0,.05);
    --shadow: 0 4px 12px rgba(0,0,0,.08);
    --shadow-lg: 0 12px 32px rgba(0,0,0,.12);
    --shadow-red: 0 8px 24px rgba(225,43,51,.25);
    --max: 1200px;
}

* { box-sizing: border-box; }
body { color: var(--c-ink); background: var(--c-bg); font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; -webkit-font-smoothing: antialiased; }
a { color: var(--c-primary); text-decoration: none; }
a:hover { color: var(--c-primary-d); }

h1,h2,h3,h4 { color: var(--c-ink); line-height: 1.22; margin: 0 0 .6em; font-weight: 800; letter-spacing: -.01em; }
h1 { font-size: clamp(2rem, 4.2vw, 3.2rem); }
h2 { font-size: clamp(1.5rem, 2.4vw, 2.1rem); }
h3 { font-size: 1.25rem; }
p  { margin: 0 0 1em; color: var(--c-ink-soft); }

.container { max-width: var(--max); margin: 0 auto; padding: 0 20px; }
.text-center { text-align: center; }
.screen-reader-text { position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.skip-link { position:absolute; top:-40px; left:0; background:#000; color:#fff; padding:8px 12px; z-index:9999; }
.skip-link:focus { top:0; }

/* ===== Top bar =================================================== */
.topbar { background: var(--c-ink); color: #FDD3D6; font-size: 13px; }
.topbar__inner { display:flex; justify-content:space-between; gap:12px; padding: 8px 20px; align-items:center; flex-wrap:wrap; }
.topbar__msg { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.topbar__msg strong { color:#fff; }
.topbar__links { flex-shrink: 0; }
.topbar__links a { color:#FDD3D6; margin: 0 4px; }
.topbar__links a:hover { color:#fff; text-decoration: underline; }

/* ===== Header ==================================================== */
.site-header { background: #fff; border-bottom: 1px solid var(--c-line); position: sticky; top:0; z-index: 90; box-shadow: var(--shadow-sm); }
.site-header__inner { display:flex; align-items:center; gap:20px; padding: 14px 20px; flex-wrap: nowrap; min-width: 0; }
.site-branding { flex: 0 0 auto; min-width: 0; }
.brand { display:flex; align-items:center; gap:10px; color: var(--c-ink); text-decoration: none; min-width: 0; }
.brand__mark { flex: 0 0 auto; display:inline-flex; align-items:center; justify-content:center; width:38px; height:38px; border-radius:8px; background: var(--c-primary); color:#fff; font-weight:900; font-size:15px; letter-spacing:.5px; box-shadow: var(--shadow-sm); }
.brand__text { display:flex; flex-direction:column; line-height:1.1; min-width: 0; }
.brand__name { font-weight:900; font-size:18px; color: var(--c-ink); white-space: nowrap; }
.brand__tag { font-size:11px; color: var(--c-mute); margin-top:2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.custom-logo { max-height: 44px; width:auto; }

.main-navigation { margin-left:auto; min-width: 0; flex: 0 1 auto; }
.primary-menu { list-style:none; margin:0; padding:0; display:flex; align-items:center; gap: 4px; flex-wrap: nowrap; }
.primary-menu > li { position: relative; }
.primary-menu > li > a { display:inline-flex; align-items:center; gap:6px; padding: 9px 12px; color: var(--c-ink); font-weight: 600; border-radius: 6px; font-size: 14.5px; white-space: nowrap; border-bottom: 2px solid transparent; }
.primary-menu > li > a:hover { color: var(--c-primary); text-decoration: none; }
.primary-menu .caret { font-size: 10px; opacity: .7; }

.nav-cta { background: var(--c-primary); color:#fff !important; font-weight:700 !important; padding: 9px 16px !important; border-radius: 6px !important; box-shadow: var(--shadow-sm); border-bottom-color: transparent !important; }
.nav-cta:hover { background: var(--c-primary-d) !important; color:#fff !important; transform: translateY(-1px); box-shadow: var(--shadow-red); }
.nav-cta--accent { background: var(--c-ink); }
.nav-cta--accent:hover { background: #1A1A1A !important; }

/* mega dropdown — anchor to trigger's left edge so it never hangs off-screen */
.has-mega-dropdown { position: relative; }
.mega-dropdown { position: absolute; top: 100%; left: 0; transform: translateY(8px); width: max-content; max-width: min(640px, calc(100vw - 40px)); background:#fff; border:1px solid var(--c-line); border-radius: var(--radius); box-shadow: var(--shadow-lg); padding: 16px; opacity: 0; visibility: hidden; transition: opacity .15s, transform .15s; z-index: 100; }
.has-mega-dropdown:hover .mega-dropdown,
.has-mega-dropdown.is-open .mega-dropdown,
.has-mega-dropdown:focus-within .mega-dropdown { opacity: 1; visibility: visible; transform: translateY(0); }
.mega-dropdown__inner { display: grid; grid-template-columns: repeat(3, minmax(160px, 1fr)); gap: 8px; }
.mega-item { display:flex; align-items:center; gap:10px; padding: 10px 12px; border-radius: 10px; color: var(--c-ink); transition: background .15s; }
.mega-item:hover { background: var(--c-surface); color: var(--c-primary); text-decoration:none; }
.mega-item__emoji { font-size: 22px; }
.mega-item__label { font-weight: 600; font-size: 14px; }

.nav-toggle { display:none; margin-left:auto; background:transparent; border:0; width:44px; height:44px; flex-direction:column; justify-content:center; align-items:center; gap:5px; cursor:pointer; }
.nav-toggle span { display:block; width:24px; height:2px; background: var(--c-ink); border-radius:2px; transition: transform .2s, opacity .2s; }
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ===== Buttons =================================================== */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding: 12px 22px; border-radius: 8px; font-weight: 700; font-size: 15px; line-height: 1.1; border: 0; cursor: pointer; transition: transform .15s, box-shadow .2s, background .2s; box-shadow: var(--shadow-sm); text-decoration: none; }
.btn:hover { transform: translateY(-2px); box-shadow: var(--shadow); text-decoration: none; }
.btn--lg { padding: 15px 30px; font-size: 16px; }
.btn--xl { padding: 18px 28px; font-size: 17px; flex-direction: column; align-items: flex-start; gap: 2px; min-width: 240px; }
.btn--xl .btn__title { font-size: 18px; font-weight: 800; }
.btn--xl .btn__sub { font-size: 12px; opacity: .85; font-weight: 500; }
.btn--primary { background: var(--c-primary); color:#fff; box-shadow: 0 4px 12px rgba(225,43,51,.2); }
.btn--primary:hover { background: var(--c-primary-d); color:#fff; box-shadow: var(--shadow-red); }
.btn--secondary { background: var(--c-ink); color:#fff; }
.btn--secondary:hover { background:#1A1A1A; color:#fff; }
.hero .btn--secondary { background: rgba(255,255,255,.10); color:#fff; border: 1px solid rgba(255,255,255,.28); box-shadow: none; }
.hero .btn--secondary:hover { background: rgba(255,255,255,.20); color:#fff; }
.btn--accent { background: var(--c-accent); color:#fff; }
.btn--accent:hover { background: var(--c-accent-d); color:#fff; }
.btn--ghost { background: transparent; color: var(--c-primary); border: 2px solid var(--c-primary); box-shadow:none; }
.btn--ghost:hover { background: var(--c-primary); color:#fff; border-color: var(--c-primary); }

/* ===== Hero (Home) ================================================ */
.hero { background: linear-gradient(135deg, #0F0F0F 0%, #1A1A1A 60%, #2a0a0c 100%); color:#fff; padding: 72px 0 80px; position: relative; overflow:hidden; }
.hero::before { content:""; position:absolute; right:-120px; top:-120px; width:460px; height:460px; background: radial-gradient(circle, rgba(225,43,51,.30), transparent 65%); pointer-events:none; }
.hero__inner { display:grid; grid-template-columns: 1.15fr .85fr; gap: 56px; align-items:center; position: relative; z-index: 1; }
.hero .eyebrow { background: var(--c-primary); color:#fff; border-color: var(--c-primary); }
.hero__title { margin: 0 0 18px; color:#fff; }
.hero__title .accent { color: var(--c-primary-l); }
.hero__sub { font-size: 17px; color: rgba(255,255,255,.82); margin-bottom: 28px; max-width: 60ch; }
.hero__cta { display:flex; flex-wrap:wrap; gap: 14px; margin-bottom: 18px; }
.hero__register { display:flex; align-items:center; gap: 14px; margin-bottom: 24px; }
.hero__register span { color: rgba(255,255,255,.7); font-size: 14px; }
.hero__bullets { list-style:none; padding:0; margin:0; display:flex; flex-wrap:wrap; gap: 18px; color: rgba(255,255,255,.82); font-size: 14px; }
.hero__bullets li strong { color:#fff; }

.eyebrow { display:inline-block; background:#fff; color: var(--c-primary); border:1px solid var(--c-surface-2); padding: 6px 12px; border-radius: 999px; font-size: 12px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; margin-bottom: 18px; }

.hero__visual { position: relative; min-height: 360px; }
.hero-card { position:absolute; background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); backdrop-filter: blur(10px); border-radius: var(--radius); box-shadow: var(--shadow); padding: 18px 18px 16px; display:flex; flex-direction:column; gap:6px; min-width: 230px; color:#fff; }
.hero-card__tag { font-size:11px; font-weight:800; color: var(--c-primary-l); background: rgba(225,43,51,.15); padding: 3px 8px; border-radius:999px; align-self: flex-start; letter-spacing: .04em; text-transform: uppercase; }
.hero-card__title { font-weight:800; color:#fff; font-size: 16px; }
.hero-card__meta { color: rgba(255,255,255,.65); font-size: 13px; }
.hero-card--1 { top: 10px; left: 0; }
.hero-card--2 { top: 100px; right: 0; }
.hero-card--3 { bottom: 10px; left: 60px; }

/* counter strip on Home */
.counter-strip { background: var(--c-ink); padding: 28px 0; color:#fff; }
.counter-strip__inner { display:grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.counter { text-align: center; }
.counter__num { display:block; font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 900; color:#fff; letter-spacing: -.02em; }
.counter__label { display:block; font-size: 13px; color:#cbd5e1; margin-top: 4px; }

/* ===== Sections (shared) ========================================= */
.section { padding: 72px 0; }
.section--cats { background: #ffffff; }
.section--guides { background: var(--c-surface-neutral); }
.section--how { background: #ffffff; }
.section--trust { background: var(--c-ink); color:#fff; }
.section--trust .section__title, .section--trust h3 { color:#fff; }
.section--trust .section__sub { color: rgba(255,255,255,.7); }
.section--trust .trust p { color: rgba(255,255,255,.75); }
.section--trust .trust strong { color:#fff; }
.section--latest { background: var(--c-bg); }
.section__head { text-align:center; max-width: 760px; margin: 0 auto 48px; }
.section__title { font-size: clamp(1.7rem, 3vw, 2.4rem); }
.section__sub { color: var(--c-mute); font-size: 16px; }

/* category grid */
.cat-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.cat-card { background:#fff; border:1px solid var(--c-line); border-radius: var(--radius); padding: 24px; display:flex; flex-direction:column; gap: 8px; transition: transform .3s, box-shadow .3s, border-color .3s; color: var(--c-ink); position: relative; overflow: hidden; }
.cat-card::before { content:""; position:absolute; top:0; left:0; width:100%; height:4px; background: var(--c-primary); transform: scaleX(0); transform-origin: left; transition: transform .3s; }
.cat-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: var(--c-primary); text-decoration:none; color: var(--c-ink); }
.cat-card:hover::before { transform: scaleX(1); }
.cat-card__emoji { font-size: 36px; }
.cat-card__name { font-size: 18px; font-weight: 800; color: var(--c-ink); }
.cat-card__cta { font-size: 14px; color: var(--c-primary); font-weight: 700; margin-top: 6px; }

/* guide grid */
.guide-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.guide-grid--4 { grid-template-columns: repeat(4, 1fr); }
.guide-card { background:#fff; border-radius: var(--radius); padding: 28px; border:1px solid var(--c-line); border-left: 4px solid var(--c-primary); box-shadow: var(--shadow-sm); display:flex; flex-direction:column; gap: 12px; transition: transform .2s, box-shadow .2s, border-color .2s; }
.guide-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.guide-card--haul-reviews { border-top: 4px solid var(--c-primary); }
.guide-card__title a { color: var(--c-ink); }
.guide-card__title a:hover { color: var(--c-primary); text-decoration:none; }
.guide-card__desc { color: var(--c-ink-soft); margin: 0; }
.guide-card__list { list-style:none; padding:0; margin: 8px 0; display:flex; flex-direction:column; gap: 6px; }
.guide-card__list li a { color: var(--c-ink-soft); display:block; padding: 4px 0; border-bottom: 1px dashed var(--c-line); }
.guide-card__list li a:hover { color: var(--c-primary); }
.guide-card__cta { margin-top:auto; font-weight:700; color: var(--c-primary); }

/* steps */
.steps { list-style:none; padding:0; margin:0; display:grid; grid-template-columns: repeat(5, 1fr); gap: 18px; }
.step { background: #fff; border:1px solid var(--c-line); border-radius: var(--radius); padding: 22px 20px; position: relative; transition: box-shadow .2s, border-color .2s; }
.step:hover { box-shadow: var(--shadow); border-color: var(--c-surface-2); }
.step__num { display:inline-flex; align-items:center; justify-content:center; width:36px; height:36px; border-radius:50%; background:var(--c-primary); color:#fff; font-weight:800; font-size: 1.05rem; margin-bottom: 10px; }
.step h3 { font-size: 16px; margin-bottom: 6px; }
.step p  { font-size: 14px; color: var(--c-mute); margin:0; }

/* trust grid */
.trust-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.trust { background: rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.10); border-radius: var(--radius); padding: 22px; }
.trust h3 { color:#fff; font-size: 17px; margin-bottom: 6px; }
.trust p  { color: rgba(255,255,255,.75); font-size: 14px; margin:0; }

/* post grid (blog) */
.post-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.post-grid--archive { grid-template-columns: repeat(3, 1fr); }
.post-card { background:#fff; border:1px solid var(--c-line); border-radius: var(--radius); padding: 22px; display:flex; flex-direction:column; gap:10px; transition: transform .15s, box-shadow .15s; }
.post-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.post-card__cat { font-size:11px; font-weight:800; color: var(--c-primary); text-transform: uppercase; letter-spacing: .06em; }
.post-card__title { margin:0; font-size: 18px; }
.post-card__title a { color: var(--c-ink); }
.post-card__title a:hover { color: var(--c-primary); text-decoration:none; }
.post-card__excerpt { color: var(--c-ink-soft); font-size: 14.5px; margin: 0; }
.post-card__cta { color: var(--c-primary); font-weight: 700; font-size: 14px; margin-top: auto; }

/* ===== CTA strip =================================================== */
.cta-strip { background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-d) 100%); color:#fff; padding: 56px 0; position: relative; overflow: hidden; }
.cta-strip::before { content:""; position:absolute; top:-50%; right:-10%; width:300px; height:300px; background: radial-gradient(circle, rgba(255,255,255,.2) 0%, transparent 70%); pointer-events:none; }
.cta-strip__inner { display:flex; justify-content: space-between; align-items: center; gap: 32px; flex-wrap: wrap; position: relative; }
.cta-strip__copy h2 { color:#fff; margin-bottom: 8px; }
.cta-strip__copy p { color: rgba(255,255,255,.95); margin:0; }
.cta-strip__buttons { display:flex; gap: 12px; flex-wrap: wrap; }
.cta-strip__buttons .btn--primary { background:#fff; color: var(--c-primary); box-shadow: none; }
.cta-strip__buttons .btn--primary:hover { background: #F5F5F5; color: var(--c-primary-d); }
.cta-strip__buttons .btn--secondary { background: var(--c-ink); color:#fff; border-color: var(--c-ink); }
.cta-strip__buttons .btn--accent { background: var(--c-ink); color:#fff; }

/* ===== Pages / Articles =========================================== */
.page-wrap { padding: 48px 20px 72px; }
.page-head { margin-bottom: 32px; }
.breadcrumbs { font-size: 13px; color: var(--c-mute); margin-bottom: 14px; }
.breadcrumbs a { color: var(--c-mute); }
.breadcrumbs a:hover { color: var(--c-primary); }
.page-title { margin-bottom: 10px; }
.page-desc { color: var(--c-ink-soft); font-size: 17px; max-width: 720px; }
.page-content { max-width: 820px; font-size: 17px; color: var(--c-ink-soft); }
.page-content h2 { margin-top: 1.6em; }
.page-content ul, .page-content ol { padding-left: 1.4em; }
.page-content li { margin: .35em 0; }

.guide-section { margin-top: 56px; }

.related-cta { margin-top: 48px; background: var(--c-surface); border:1px solid #FDD3D6; border-radius: var(--radius); padding: 32px; }
.related-cta h2 { margin-bottom: 8px; }
.related-cta__buttons { display:flex; gap:12px; flex-wrap:wrap; margin-top: 16px; }

.single-article { padding: 48px 20px 56px; max-width: 880px; }
.article-head { margin: 12px 0 24px; }
.article-eyebrow { display:inline-block; color: var(--c-primary); font-weight: 800; font-size: 12px; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 12px; }
.article-title { font-size: clamp(1.8rem, 3.4vw, 2.6rem); margin-bottom: 8px; }
.article-meta { color: var(--c-mute); font-size: 13px; margin: 0; }
.article-body { font-size: 17.5px; color: var(--c-ink-soft); line-height: 1.8; }
.article-body h2 { margin-top: 1.6em; color: var(--c-ink); }
.article-body h3 { margin-top: 1.4em; color: var(--c-ink); }
.article-body p { margin: 0 0 1.1em; }
.article-body ul, .article-body ol { padding-left: 1.4em; margin: 0 0 1.2em; }
.article-body li { margin: .3em 0; }
.article-body blockquote { margin: 1.2em 0; padding: 14px 18px; border-left: 4px solid var(--c-primary); background: var(--c-surface); color: var(--c-ink); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; }
.article-body a { color: var(--c-primary); border-bottom: 1px dashed #FDD3D6; }
.article-body a:hover { color: var(--c-primary-d); border-bottom-style: solid; }

.article-footer { margin-top: 36px; }
.article-tags { font-size: 13px; color: var(--c-mute); margin-bottom: 20px; }
.tag-label { font-weight: 700; color: var(--c-ink); margin-right: 4px; }

.article-cta { background: var(--c-surface); border-radius: var(--radius); padding: 28px; margin: 24px 0; border:1px solid #FDD3D6; }
.article-cta h2 { font-size: 22px; margin-bottom: 8px; }
.article-cta p { color: var(--c-ink-soft); margin-bottom: 16px; }
.article-cta__buttons { display:flex; flex-wrap:wrap; gap:12px; }

.related-posts { margin-top: 32px; padding: 24px; background:#fff; border:1px solid var(--c-line); border-radius: var(--radius); }
.related-posts h2 { font-size: 19px; margin-bottom: 12px; }
.related-posts ul { list-style:none; padding:0; margin:0; display:grid; grid-template-columns: repeat(2, 1fr); gap: 8px 24px; }
.related-posts a { color: var(--c-ink); border-bottom: 1px dashed var(--c-line); display:block; padding: 6px 0; }
.related-posts a:hover { color: var(--c-primary); }

.pagination { margin-top: 32px; display:flex; justify-content:center; }
.pagination .page-numbers { display:inline-flex; align-items:center; justify-content:center; min-width:38px; height:38px; padding: 0 12px; margin: 0 4px; border-radius: 8px; background:#fff; border:1px solid var(--c-line); color: var(--c-ink); font-weight: 600; }
.pagination .page-numbers.current { background: var(--c-primary); color:#fff; border-color: var(--c-primary); }
.pagination .page-numbers:hover { border-color: var(--c-primary); color: var(--c-primary); text-decoration:none; }
.pagination .page-numbers.current:hover { color:#fff; }

/* 404 */
.error-cta { display:flex; justify-content:center; gap:12px; flex-wrap:wrap; margin: 24px 0 32px; }
.error-links { list-style:none; padding:0; display:flex; justify-content:center; gap: 14px; flex-wrap:wrap; }
.error-links a { background:#fff; border:1px solid var(--c-line); padding: 10px 14px; border-radius: 999px; color: var(--c-ink); }
.error-links a:hover { border-color: var(--c-primary); color: var(--c-primary); text-decoration: none; }

/* ===== Footer ===================================================== */
.site-footer { background: var(--c-ink); color:#D4D4D4; padding: 64px 0 0; }
.site-footer a { color:#D4D4D4; }
.site-footer a:hover { color: var(--c-primary-l); }
.site-footer__grid { display:grid; grid-template-columns: 2fr 1fr 1.2fr 1fr; gap: 32px; padding-bottom: 40px; }
.footer-col h4 { color:#fff; font-size: 14px; text-transform: uppercase; letter-spacing: .08em; margin: 0 0 14px; font-weight: 700; }
.footer-col ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap: 8px; font-size: 14.5px; }
.footer-cats { columns: 2; column-gap: 12px; }
.footer-cats li { break-inside: avoid; }
.brand--footer .brand__name { color:#fff; }
.footer-about { color:#A3A3A3; font-size: 14.5px; }
.footer-cta { display:flex; gap: 10px; flex-wrap:wrap; margin-top: 16px; }
.site-footer__bottom { border-top: 1px solid rgba(255,255,255,.10); padding: 18px 0; font-size: 13px; color:#737373; }
.site-footer__bottom p { margin:0; color:#737373; }

/* =====================================================================
   HAUL REVIEWS — distinct review-driven layout. Different palette tone,
   different hero, different content. This is what stops the Haul Reviews
   page from looking like the homepage.
   ===================================================================== */

.is-haul-reviews { background: #fafaf9; }

.review-hero { background: linear-gradient(135deg, #0F0F0F 0%, #1A1A1A 70%, #2a0a0c 100%); color:#fff; padding: 64px 0 56px; position: relative; overflow: hidden; }
.review-hero::after { content:""; position:absolute; inset:0; background-image: radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px); background-size: 24px 24px; opacity: .5; pointer-events:none; }
.review-hero__inner { display: grid; grid-template-columns: 1.3fr .9fr; gap: 48px; align-items: center; position: relative; z-index: 1; }
.eyebrow--review { background: rgba(255,255,255,.12); color: var(--c-primary-l); border-color: rgba(255,255,255,.18); }
.review-hero__title { color:#fff; margin: 0 0 16px; font-size: clamp(2rem, 3.8vw, 3rem); }
.review-hero__title .accent { color: var(--c-primary-l); }
.review-hero__sub { color: rgba(255,255,255,.75); font-size: 17px; max-width: 60ch; margin-bottom: 28px; }
.review-hero__stats { display:grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 28px; }
.rh-stat { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-radius: var(--radius); padding: 14px 16px; }
.rh-stat__num { display:block; font-size: 24px; font-weight: 900; color: var(--c-primary-l); }
.rh-stat__label { display:block; font-size: 12px; color: rgba(255,255,255,.6); margin-top: 2px; text-transform: uppercase; letter-spacing: .05em; }
.review-hero__cta { display:flex; gap: 12px; flex-wrap:wrap; }
.review-hero .btn--ghost { color:#fff; border-color: rgba(255,255,255,.4); }
.review-hero .btn--ghost:hover { background: rgba(255,255,255,.08); border-color:#fff; color:#fff; }

.review-hero__board { background: rgba(0,0,0,.35); border: 1px solid rgba(255,255,255,.1); backdrop-filter: blur(6px); border-radius: var(--radius); padding: 24px; }
.board__title { color:#fff; font-size: 14px; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 14px; }
.board__list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap: 12px; }
.board__list li { display:grid; grid-template-columns: 64px 1fr 36px; align-items: center; gap: 12px; }
.board__bar { display:block; height: 10px; background: rgba(255,255,255,.08); border-radius: 999px; overflow: hidden; }
.board__bar span { display:block; height:100%; border-radius: 999px; background: linear-gradient(90deg, var(--c-primary-l), #fbbf24); }
.board__count { color:#fff; font-weight: 800; text-align: right; }
.board__note { color: rgba(255,255,255,.55); font-size: 12px; margin-top: 14px; margin-bottom: 0; }

.board__badge { display:inline-flex; align-items:center; justify-content:center; padding: 4px 8px; border-radius: 999px; font-size: 11px; font-weight: 900; letter-spacing: .06em; text-transform: uppercase; }
.board__badge--buy { background:#16a34a; color:#fff; }
.board__badge--wait { background:#f59e0b; color:#0f172a; }
.board__badge--skip { background:#ef4444; color:#fff; }

/* verdict pills (used inside cards) */
.verdict { display:inline-flex; align-items:center; justify-content:center; padding: 4px 10px; border-radius: 999px; font-size: 11px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; }
.verdict--buy  { background:#dcfce7; color:#166534; border: 1px solid #86efac; }
.verdict--wait { background:#fef3c7; color:#92400e; border: 1px solid #fde68a; }
.verdict--skip { background:#fee2e2; color:#991b1b; border: 1px solid #fecaca; }

/* filter chips */
.review-filter { background:#fff; border-bottom: 1px solid var(--c-line); position: sticky; top: 72px; z-index: 50; }
.review-filter__inner { display:flex; align-items: center; gap: 8px; padding: 14px 20px; overflow-x: auto; }
.review-filter__label { color: var(--c-mute); font-size: 13px; margin-right: 4px; white-space: nowrap; }
.chip { background:#fff; border:1px solid var(--c-line); color: var(--c-ink); padding: 8px 14px; border-radius: 999px; font-weight: 600; font-size: 13px; cursor: pointer; transition: background .15s, color .15s, border-color .15s; white-space: nowrap; }
.chip:hover { border-color: var(--c-primary); color: var(--c-primary); }
.chip.is-active { background: var(--c-ink); color:#fff; border-color: var(--c-ink); }

/* featured review */
.featured-review { background: var(--c-surface); padding: 56px 0; border-bottom: 1px solid #FDD3D6; }
.featured-review__inner { background:#fff; border:1px solid var(--c-line); border-radius: var(--radius); padding: 36px; box-shadow: var(--shadow); }
.featured-review__meta { display:flex; align-items:center; gap: 12px; margin-bottom: 12px; }
.featured-review__eyebrow { color: var(--c-primary); font-weight: 800; font-size: 12px; letter-spacing: .08em; text-transform: uppercase; }
.featured-review__cat { color: var(--c-mute); font-size: 13px; }
.featured-review__title { margin: 0 0 16px; font-size: clamp(1.6rem, 2.6vw, 2.2rem); }
.featured-review__quote { border-left: 4px solid var(--c-primary); padding: 6px 0 6px 18px; margin: 0 0 24px; font-size: 18px; color: var(--c-ink); font-style: italic; }
.featured-review__grid { display:grid; grid-template-columns: 1fr 1fr 1.2fr; gap: 28px; }
.featured-review__col h3 { font-size: 14px; text-transform: uppercase; letter-spacing: .08em; color: var(--c-mute); margin-bottom: 12px; }
.featured-review__verdict { display:flex; align-items: center; gap: 12px; margin-top: 18px; padding-top: 16px; border-top: 1px dashed var(--c-line); }
.featured-review__price { color: var(--c-mute); font-size: 14px; }

.proscons { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap: 6px; font-size: 14.5px; }
.proscons li { padding-left: 22px; position: relative; color: var(--c-ink-soft); }
.proscons--pros li::before { content: "✓"; position:absolute; left: 0; color: var(--c-ok); font-weight: 900; }
.proscons--cons li::before { content: "✕"; position:absolute; left: 0; color: var(--c-bad); font-weight: 900; }

/* scoreboard */
.scoreboard { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap: 8px; }
.scoreboard li { display:grid; grid-template-columns: 80px 1fr 32px; align-items:center; gap: 10px; font-size: 13px; }
.scoreboard__axis { color: var(--c-ink-soft); font-weight: 600; }
.scoreboard__bar { display:block; height: 8px; background: #f1f5f9; border-radius: 999px; overflow: hidden; }
.scoreboard__bar span { display:block; height: 100%; border-radius: 999px; background: linear-gradient(90deg, #FF3A42, #fb923c, #facc15, #4ade80); }
.scoreboard__value { color: var(--c-ink); font-weight: 800; text-align: right; }
.scoreboard--compact li { grid-template-columns: 64px 1fr 28px; font-size: 12px; }
.scoreboard--compact .scoreboard__bar { height: 6px; }

/* review grid */
.review-grid-wrap { background: #fafaf9; padding: 72px 0; }
.review-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.review-card { background:#fff; border:1px solid var(--c-line); border-radius: var(--radius); padding: 22px; display:flex; flex-direction:column; gap: 14px; transition: transform .15s, box-shadow .15s; }
.review-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.review-card.is-hidden { display:none; }
.review-card__head { display:flex; justify-content: space-between; align-items: center; }
.review-card__cat { font-size:11px; font-weight:800; color: var(--c-primary); text-transform: uppercase; letter-spacing: .06em; }
.review-card__title { margin: 0; font-size: 17px; color: var(--c-ink); }
.review-card__meta { color: var(--c-mute); font-size: 13px; margin: 0; display:flex; gap: 8px; align-items: center; }
.review-card__price { color: var(--c-ink); font-weight: 700; }
.dot { color: var(--c-line); }
.review-card__score { display:grid; grid-template-columns: 96px 1fr; gap: 18px; align-items: center; padding: 14px; background: #fafaf9; border-radius: var(--radius-sm); border: 1px dashed var(--c-line); }
.review-card__big { text-align: center; }
.review-card__big-num { display:block; font-size: 36px; font-weight: 900; color: var(--c-ink); line-height: 1; }
.review-card__big-out { display:block; font-size: 11px; color: var(--c-mute); margin-top: 2px; letter-spacing: .06em; text-transform: uppercase; }
.review-card__quote { margin: 0; padding: 0; border-left: 3px solid var(--c-primary); padding-left: 12px; font-size: 13.5px; color: var(--c-ink-soft); font-style: italic; }
.review-card__foot { margin-top:auto; }
.review-card__cta { color: var(--c-primary); font-weight: 700; font-size: 13px; }

/* methodology */
.section--methodology { background:#fff; padding: 72px 0; border-top: 1px solid var(--c-line); }
.methodology__inner { display:grid; grid-template-columns: 1.2fr 1fr; gap: 48px; align-items: center; }
.methodology__list { list-style: none; padding: 0; margin: 14px 0 20px; display:flex; flex-direction:column; gap: 8px; font-size: 15px; color: var(--c-ink-soft); }
.methodology__list strong { color: var(--c-ink); }
.methodology__note { color: var(--c-mute); font-size: 14px; }
.methodology__visual { background: var(--c-surface); border-radius: var(--radius); padding: 28px; border: 1px solid #FDD3D6; }
.methodology__card h3 { margin-bottom: 14px; }
.methodology__verdict-row { margin-top: 16px; margin-bottom: 0; color: var(--c-ink); font-weight: 600; font-size: 14px; }

/* reviewers */
.section--reviewers { background: #f8fafc; padding: 72px 0; }
.reviewer-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.reviewer { background:#fff; border:1px solid var(--c-line); border-radius: var(--radius); padding: 22px; }
.reviewer__avatar { display:inline-flex; align-items:center; justify-content:center; width: 48px; height: 48px; border-radius: 50%; background: linear-gradient(135deg, var(--c-primary), #FF3A42); color:#fff; font-weight: 900; font-size: 16px; margin-bottom: 12px; }
.reviewer h3 { margin-bottom: 2px; }
.reviewer__role { color: var(--c-primary); font-weight: 700; font-size: 13px; margin-bottom: 8px; }
.reviewer p { color: var(--c-ink-soft); font-size: 14px; margin:0; }

/* faq */
.section--faq { background: #ffffff; padding: 72px 0; }
.faq__inner { max-width: 820px; margin: 0 auto; }
.faq-item { background: #fafaf9; border:1px solid var(--c-line); border-radius: var(--radius-sm); padding: 16px 20px; margin-bottom: 10px; }
.faq-item summary { font-weight: 700; cursor: pointer; color: var(--c-ink); list-style: none; position: relative; padding-right: 24px; }
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item summary::after { content: "+"; position:absolute; right: 0; top: 0; color: var(--c-primary); font-weight: 900; transition: transform .15s; }
.faq-item[open] summary::after { content: "−"; }
.faq-item p { color: var(--c-ink-soft); font-size: 15px; margin: 10px 0 0; }

/* submit */
.section--submit { background: var(--c-surface); padding: 64px 0; border-top: 1px solid #FDD3D6; }
.submit__inner { text-align: center; max-width: 720px; margin: 0 auto; }
.submit__buttons { display:flex; gap: 12px; flex-wrap: wrap; justify-content: center; margin-top: 18px; }

.section--latest-reviews { background:#fff; padding: 72px 0; border-top: 1px solid var(--c-line); }

/* ===== Responsive ================================================= */
@media (max-width: 1180px) {
    /* Nav starts shrinking here — prevents overflow between 900–1200px */
    .site-header__inner { gap: 14px; }
    .brand__tag { display: none; }
    .primary-menu { gap: 2px; }
    .primary-menu > li > a { padding: 8px 10px; font-size: 14px; }
    .nav-cta { padding: 8px 14px !important; }
    .mega-dropdown { max-width: min(560px, calc(100vw - 40px)); }
    .mega-dropdown__inner { grid-template-columns: repeat(3, minmax(140px, 1fr)); }
}

@media (max-width: 1024px) {
    .hero__inner { grid-template-columns: 1fr; }
    .hero__visual { display:none; }
    .cat-grid { grid-template-columns: repeat(3, 1fr); }
    .guide-grid, .guide-grid--4 { grid-template-columns: repeat(2, 1fr); }
    .steps { grid-template-columns: repeat(2, 1fr); }
    .trust-grid { grid-template-columns: repeat(2, 1fr); }
    .post-grid, .post-grid--archive { grid-template-columns: repeat(2, 1fr); }
    .site-footer__grid { grid-template-columns: repeat(2, 1fr); }
    .mega-dropdown { max-width: min(480px, calc(100vw - 40px)); }
    .counter-strip__inner { grid-template-columns: repeat(2, 1fr); }
    .review-hero__inner { grid-template-columns: 1fr; }
    .review-hero__stats { grid-template-columns: repeat(2, 1fr); }
    .review-grid { grid-template-columns: repeat(2, 1fr); }
    .reviewer-grid { grid-template-columns: repeat(2, 1fr); }
    .featured-review__grid { grid-template-columns: 1fr; }
    .methodology__inner { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
    .nav-toggle { display:inline-flex; }
    .main-navigation { position: absolute; top: 100%; left: 0; right: 0; background:#fff; border-top:1px solid var(--c-line); display:none; padding: 8px 12px 16px; box-shadow: var(--shadow); max-height: calc(100vh - 60px); overflow-y: auto; }
    .main-navigation.is-open { display:block; }
    .primary-menu { flex-direction: column; align-items: stretch; gap: 2px; flex-wrap: nowrap; }
    .primary-menu > li > a { padding: 12px 14px; font-size: 15px; border-bottom: 1px solid var(--c-line); border-radius: 0; }
    .nav-cta { border-radius: 6px !important; margin: 6px 0; }
    .has-mega-dropdown .mega-dropdown { position: static; transform: none; max-width: none; box-shadow: none; border: 0; padding: 4px 0 8px; display: none; opacity: 1; visibility: visible; }
    .has-mega-dropdown.is-open .mega-dropdown { display:block; }
    .mega-dropdown__inner { grid-template-columns: repeat(2, 1fr); }
    .site-header__inner { flex-wrap: nowrap; }
    .cat-grid { grid-template-columns: repeat(2, 1fr); }
    .steps { grid-template-columns: 1fr; }
    .trust-grid { grid-template-columns: 1fr; }
    .post-grid, .post-grid--archive { grid-template-columns: 1fr; }
    .site-footer__grid { grid-template-columns: 1fr; }
    .cta-strip__inner { flex-direction: column; text-align:center; }
    .cta-strip__buttons { justify-content:center; }
    .related-posts ul { grid-template-columns: 1fr; }
    .hero__cta .btn--xl { min-width: 100%; }
    .topbar__inner { font-size: 12px; }
    .topbar__links { display:none; }
    .review-hero__stats { grid-template-columns: repeat(2, 1fr); }
    .review-grid { grid-template-columns: 1fr; }
    .reviewer-grid { grid-template-columns: 1fr; }
    .guide-grid, .guide-grid--4 { grid-template-columns: 1fr; }
    .review-filter { top: 60px; }
}

@media (max-width: 480px) {
    .cat-grid { grid-template-columns: 1fr 1fr; }
    .mega-dropdown__inner { grid-template-columns: 1fr; }
    .counter-strip__inner { grid-template-columns: 1fr 1fr; }
}
