/*
Theme Name: Marketspective
Theme URI: https://marketspective.com
Author: Marketspective
Author URI: https://marketspective.com
Description: Premium market research platform theme — editorial design, white/navy palette, reports CPT.
Version: 1.0.0
License: Proprietary
Text Domain: marketspective
*/

/* ===========================================================================
   DESIGN TOKENS
   =========================================================================== */
:root {
  --paper:      #FFFFFF;
  --panel:      #FFFFFF;
  --ink:        #0A0A0F;
  --ink-soft:   #6C6F78;
  --rule:       #ECECEF;
  --accent:     #2E5BFF;
  --accent-soft:#E3EAFF;
  --chip:       #F4F4F6;

  --serif: "Source Serif 4", "Source Serif Pro", "Times New Roman", Georgia, serif;
  --sans:  "IBM Plex Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
  --mono:  "JetBrains Mono", "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --container: 1320px;
  --gutter: 28px;
  --radius: 2px;
  --pad-section-y: 56px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--serif);
  font-size: 17px;
  line-height: 1.55;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1, h2, h3, h4 { font-family: var(--serif); font-weight: 400; letter-spacing: -0.01em; margin: 0; }
h1 { font-size: clamp(36px, 4.5vw, 68px); line-height: 0.98; letter-spacing: -0.025em; }
h2 { font-size: 32px; line-height: 1.05; letter-spacing: -0.015em; }
h3 { font-size: 22px; line-height: 1.2; }
h4 { font-size: 16px; line-height: 1.25; font-weight: 600; }
a  { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; background: none; border: 0; padding: 0; color: inherit; }
img { max-width: 100%; height: auto; }

.container { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }

.eyebrow {
  font-family: var(--sans);
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-soft);
}

/* ===========================================================================
   TOPBAR / HEADER
   =========================================================================== */
.topbar {
  border-bottom: 1px solid var(--rule);
  background: var(--paper);
  position: sticky; top: 0; z-index: 30;
  backdrop-filter: blur(8px);
}
.topbar__inner {
  display: grid;
  grid-template-columns: 200px 1fr auto;
  align-items: center;
  gap: 20px;
  padding: 12px var(--gutter);
  max-width: var(--container); margin: 0 auto;
}
.brand { display: flex; align-items: center; gap: 10px; text-decoration: none; }
.brand__mark {
  width: 32px; height: 32px;
  background: var(--ink); color: var(--paper);
  display: grid; place-items: center; flex-shrink: 0;
}
.brand__mark svg { width: 18px; height: 18px; }
.brand__name { font-family: var(--serif); font-size: 19px; letter-spacing: -0.01em; }
.brand__name b { font-weight: 600; }
.brand__name em { font-style: italic; color: var(--ink-soft); font-weight: 400; }

.main-nav { display: flex; align-items: center; gap: 2px; }
.nav-link {
  font-family: var(--sans); font-size: 14px; font-weight: 500;
  padding: 7px 14px; color: var(--ink-soft); transition: color .15s;
  text-decoration: none;
}
.nav-link:hover, .nav-link.current-menu-item { color: var(--ink); }
.nav-link.current-menu-item { border-bottom: 2px solid var(--accent); }

.user-tools { display: flex; align-items: center; gap: 12px; }
.user-tools .btn-browse {
  font-family: var(--sans); font-size: 13px; font-weight: 500;
  padding: 8px 16px; background: var(--accent); color: var(--paper);
  text-decoration: none; transition: background .15s;
}
.user-tools .btn-browse:hover { background: var(--ink); }

/* Mobile hamburger */
.hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 4px; }
.hamburger span { display: block; width: 22px; height: 2px; background: var(--ink); transition: all .2s; }

/* ===========================================================================
   HERO (Homepage full hero)
   =========================================================================== */
.hero-full-wrap {
  border-bottom: 1px solid var(--rule);
  background: var(--paper);
  background-image: radial-gradient(circle, var(--rule) 1px, transparent 1px);
  background-size: 28px 28px;
}
.hero-full {
  display: grid;
  grid-template-columns: 1fr 440px;
  gap: 64px;
  min-height: calc(100vh - 57px);
  max-height: 920px;
  align-items: center;
  padding: 80px var(--gutter);
  max-width: var(--container);
  margin: 0 auto;
}
.hero-full__eyebrow {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  font-family: var(--sans); font-size: 11px; font-weight: 500;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--ink-soft); margin-bottom: 24px;
}
.hero-full__eyebrow strong { color: var(--accent); }
.hero-full__eyebrow .sep { color: var(--rule); }
.hero-full__title {
  font-family: var(--serif);
  font-size: clamp(62px, 7.8vw, 104px);
  line-height: .91; letter-spacing: -.03em;
  margin-bottom: 28px;
}
.hero-full__title em { font-style: italic; color: var(--accent); }
.hero-full__body {
  font-family: var(--sans); font-size: 18px; color: var(--ink-soft);
  line-height: 1.55; max-width: 480px; margin-bottom: 36px;
}
.hero-full__search {
  display: flex; border: 2px solid var(--ink); background: var(--paper); max-width: 520px; margin-bottom: 16px;
}
.hero-full__search input {
  flex: 1; padding: 14px 18px; border: 0; background: transparent;
  font-family: var(--sans); font-size: 15px; color: var(--ink); outline: 0;
}
.hero-full__search input::placeholder { color: var(--ink-soft); }
.hero-full__search button {
  padding: 0 26px; background: var(--accent); color: var(--paper);
  font-family: var(--sans); font-size: 14px; font-weight: 500;
  border: 0; cursor: pointer; white-space: nowrap; transition: background .15s;
}
.hero-full__search button:hover { background: var(--ink); }
.hero-full__chips { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; max-width: 520px; }
.hero-full__chips .try-label { font-family: var(--sans); font-size: 12.5px; color: var(--ink-soft); }
.hero-full__actions { display: flex; gap: 12px; align-items: center; margin-top: 28px; flex-wrap: wrap; }
.hero-btn-primary {
  padding: 15px 30px; background: var(--ink); color: var(--paper);
  font-family: var(--sans); font-size: 14.5px; font-weight: 500;
  border: 0; cursor: pointer; transition: background .15s; text-decoration: none; display: inline-block;
}
.hero-btn-primary:hover { background: var(--accent); color: var(--paper); }
.hero-btn-secondary {
  padding: 14px 24px; background: transparent; color: var(--ink);
  font-family: var(--sans); font-size: 14.5px; font-weight: 500;
  border: 1.5px solid var(--rule); cursor: pointer; transition: all .15s;
  text-decoration: none; display: inline-block;
}
.hero-btn-secondary:hover { border-color: var(--ink); }

/* Hero suggestion chips */
.hero-chip {
  padding: 5px 13px; background: var(--chip); border: 1px solid var(--rule);
  font-family: var(--sans); font-size: 12.5px; cursor: pointer; transition: all .15s;
}
.hero-chip:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }

/* Hero preview card */
.hero-preview {
  border: 1px solid var(--rule); background: var(--paper);
  overflow: hidden;
  box-shadow: 14px 14px 0 var(--accent-soft);
}
.hero-preview__accentbar { height: 3px; background: var(--accent); }
.hero-preview__inner { padding: 24px; }
.hero-preview__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.hero-preview__tag {
  font-family: var(--sans); font-size: 10px; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase;
  padding: 3px 8px; background: var(--accent-soft); color: var(--accent);
}
.hero-preview__cagr {
  font-family: var(--mono); font-size: 12px; font-weight: 500;
  color: var(--accent); background: var(--accent-soft); padding: 4px 8px;
}
.hero-preview__title { font-family: var(--serif); font-size: 21px; line-height: 1.15; margin-bottom: 3px; }
.hero-preview__sub { font-family: var(--sans); font-size: 12px; color: var(--ink-soft); margin-bottom: 18px; }
.hero-preview__kpis {
  display: grid; grid-template-columns: repeat(3,1fr);
  border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); margin-bottom: 18px;
}
.hp-kpi { padding: 12px 14px; border-right: 1px solid var(--rule); }
.hp-kpi:last-child { border-right: 0; }
.hp-kpi__val { display: block; font-family: var(--serif); font-size: 17px; font-weight: 600; letter-spacing: -.02em; }
.hp-kpi__label { display: block; font-family: var(--sans); font-size: 10.5px; color: var(--ink-soft); margin-top: 1px; }
.hero-preview__actions {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
  margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--rule);
}
.hp-cta {
  text-align: center; padding: 10px 14px; font-family: var(--sans);
  font-size: 13px; font-weight: 500; cursor: pointer; transition: all .15s;
  text-decoration: none; display: block;
}
.hp-cta--primary { background: var(--accent); color: var(--paper); border: 0; }
.hp-cta--primary:hover { background: var(--ink); }
.hp-cta--ghost { background: transparent; color: var(--ink); border: 1px solid var(--rule); }
.hp-cta--ghost:hover { border-color: var(--ink); }

/* ===========================================================================
   TRUST BAR
   =========================================================================== */
.trust-bar { border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.trust-bar__inner {
  max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter);
  display: grid; grid-template-columns: repeat(4,1fr);
}
.trust-bar__item { padding: 24px 28px; border-right: 1px solid var(--rule); }
.trust-bar__item:last-child { border-right: 0; }
.trust-bar__num { display: block; font-family: var(--serif); font-size: 28px; font-weight: 600; letter-spacing: -.02em; }
.trust-bar__label { display: block; font-family: var(--sans); font-size: 12.5px; color: var(--ink-soft); margin-top: 2px; }

/* ===========================================================================
   SECTION (HOME)
   =========================================================================== */
.section-home { padding: var(--pad-section-y) var(--gutter); max-width: var(--container); margin: 0 auto; }
.section-home--border { border-top: 1px solid var(--rule); }
.section-home__hd { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 28px; }
.section-home__hd h2 { font-size: 24px; }
.section-home__hd a { font-family: var(--sans); font-size: 13.5px; color: var(--accent); }
.section-home__hd a:hover { text-decoration: underline; }

/* ===========================================================================
   INDUSTRY GRID
   =========================================================================== */
.industry-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
.cat-tile {
  background: var(--paper); border: 1px solid var(--rule);
  border-top: 3px solid var(--tile-accent, var(--accent));
  padding: 24px 20px 20px;
  display: flex; flex-direction: column; gap: 0;
  cursor: pointer; text-decoration: none; color: inherit;
  transition: box-shadow .18s, transform .18s;
}
.cat-tile:hover { box-shadow: 0 6px 24px rgba(0,0,0,.07); transform: translateY(-3px); }
.cat-tile__name { font-family: var(--sans); font-size: 14px; font-weight: 600; transition: color .15s; line-height: 1.3; margin-bottom: 4px; }
.cat-tile:hover .cat-tile__name { color: var(--tile-accent, var(--accent)); }
.cat-tile__count { font-family: var(--mono); font-size: 11px; color: var(--ink-soft); margin-bottom: 14px; }
.cat-tile--more { background: var(--chip); border: 1px dashed var(--rule); border-top: 3px solid var(--accent); align-items: center; justify-content: center; text-align: center; min-height: 100px; }

/* ===========================================================================
   REPORT CARDS
   =========================================================================== */
.reports-strip-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
.reports-strip-wrap::-webkit-scrollbar { display: none; }
.reports-strip { display: flex; gap: 16px; padding: 4px 2px 16px; min-width: max-content; }
.cards-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }

.rcard {
  background: var(--panel); border: 1px solid var(--rule);
  padding: 20px; display: flex; flex-direction: column; gap: 10px;
  cursor: pointer; transition: border-color .15s, box-shadow .15s;
  text-decoration: none; color: inherit;
}
.rcard--strip { width: 272px; flex-shrink: 0; }
.rcard:hover { border-color: var(--accent); box-shadow: 4px 4px 0 var(--accent-soft); }
.rcard__head { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.rcard__cat { font-family: var(--sans); font-size: 10px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; padding: 3px 7px; background: var(--accent-soft); color: var(--accent); }
.rcard__date { font-family: var(--mono); font-size: 11px; color: var(--ink-soft); }
.rcard__title { font-family: var(--serif); font-size: 16px; font-weight: 500; line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.rcard__desc { font-family: var(--sans); font-size: 12.5px; color: var(--ink-soft); line-height: 1.5; margin: 0; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.rcard__foot { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-top: auto; padding-top: 12px; border-top: 1px solid var(--rule); }
.rcard__cagr { font-family: var(--mono); font-size: 11.5px; font-weight: 500; color: var(--accent); background: var(--accent-soft); padding: 3px 7px; }
.rcard__cta { font-family: var(--sans); font-size: 12.5px; color: var(--ink-soft); transition: color .15s; }
.rcard:hover .rcard__cta { color: var(--accent); }

/* ===========================================================================
   HOW IT WORKS
   =========================================================================== */
.how-it-works { padding: var(--pad-section-y) var(--gutter); border-top: 1px solid var(--rule); }
.how-it-works__inner { max-width: var(--container); margin: 0 auto; }
.how-it-works__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 48px; margin-top: 32px; }
.how-step { display: flex; flex-direction: column; gap: 12px; position: relative; }
.how-step:not(:last-child)::after { content: '→'; position: absolute; right: -28px; top: 12px; font-size: 20px; color: var(--rule); }
.how-step__num { font-family: var(--mono); font-size: 10.5px; letter-spacing: .1em; color: var(--accent); }
.how-step__title { font-family: var(--serif); font-size: 20px; font-weight: 500; }
.how-step__desc { font-family: var(--sans); font-size: 14px; color: var(--ink-soft); line-height: 1.6; }

/* ===========================================================================
   CTA BANNER
   =========================================================================== */
.cta-banner { background: var(--ink); color: var(--paper); padding: 72px var(--gutter); text-align: center; }
.cta-banner__inner { max-width: var(--container); margin: 0 auto; }
.cta-banner__title { font-family: var(--serif); font-size: clamp(28px, 3.5vw, 44px); margin-bottom: 12px; color: var(--paper); }
.cta-banner__sub { font-family: var(--sans); font-size: 15px; color: rgba(255,255,255,.55); margin-bottom: 28px; }
.cta-banner__stats { display: flex; align-items: center; justify-content: center; gap: 32px; margin-bottom: 32px; flex-wrap: wrap; }
.cta-banner__stat { font-family: var(--sans); font-size: 13px; color: rgba(255,255,255,.6); display: flex; align-items: center; gap: 6px; }
.cta-banner__stat::before { content: ''; width: 5px; height: 5px; background: var(--accent); border-radius: 50%; display: block; }
.btn-cta { display: inline-flex; align-items: center; gap: 8px; padding: 14px 28px; background: var(--accent); color: var(--paper); font-family: var(--sans); font-size: 14px; font-weight: 500; border: 0; cursor: pointer; transition: background .15s; text-decoration: none; }
.btn-cta:hover { background: var(--paper); color: var(--ink); }
.btn-cta-ghost { display: inline-flex; align-items: center; gap: 8px; padding: 13px 24px; background: transparent; border: 1px solid rgba(255,255,255,.25); color: rgba(255,255,255,.75); font-family: var(--sans); font-size: 14px; font-weight: 500; cursor: pointer; transition: all .15s; text-decoration: none; margin-left: 12px; }
.btn-cta-ghost:hover { border-color: var(--paper); color: var(--paper); }

/* ===========================================================================
   SITE FOOTER
   =========================================================================== */
.site-footer { background: var(--ink); color: var(--paper); padding: 56px 0 32px; }
.footer__top { display: grid; grid-template-columns: 260px 1fr; gap: 60px; padding: 0 var(--gutter) 48px; max-width: var(--container); margin: 0 auto; border-bottom: 1px solid rgba(255,255,255,.1); }
.footer__brand .brand__mark { background: rgba(255,255,255,.15); color: var(--paper); }
.footer__brand .brand__name { color: var(--paper); }
.footer__brand .brand__name em { color: rgba(255,255,255,.45); }
.footer__tagline { font-family: var(--sans); font-size: 13px; color: rgba(255,255,255,.45); margin-top: 14px; line-height: 1.6; max-width: 220px; }
.footer__cols { display: grid; grid-template-columns: repeat(4,1fr); gap: 28px; }
.footer__col h5 { font-family: var(--sans); font-size: 10px; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; color: rgba(255,255,255,.35); margin-bottom: 14px; }
.footer__col a { display: block; font-family: var(--sans); font-size: 13.5px; color: rgba(255,255,255,.6); margin-bottom: 9px; transition: color .15s; text-decoration: none; }
.footer__col a:hover { color: var(--paper); }
.footer__bottom { display: flex; align-items: center; justify-content: space-between; padding: 28px var(--gutter) 0; max-width: var(--container); margin: 0 auto; flex-wrap: wrap; gap: 16px; }
.footer__copy { font-family: var(--sans); font-size: 12.5px; color: rgba(255,255,255,.3); margin: 0; }

/* ===========================================================================
   PAGE HEADER
   =========================================================================== */
.page-hdr { padding: 36px var(--gutter) 30px; border-bottom: 1px solid var(--rule); }
.page-hdr__inner { max-width: var(--container); margin: 0 auto; }
.page-hdr__title { font-family: var(--serif); font-size: clamp(28px, 3.5vw, 42px); margin-bottom: 6px; }
.page-hdr__sub { font-family: var(--sans); font-size: 15px; color: var(--ink-soft); }

/* ===========================================================================
   BROWSE / ARCHIVE LAYOUT
   =========================================================================== */
.browse-layout { max-width: var(--container); margin: 0 auto; padding: 32px var(--gutter); display: grid; grid-template-columns: 1fr 260px; gap: 32px; align-items: start; }
.browse-sidebar { display: flex; flex-direction: column; gap: 20px; position: sticky; top: 80px; }
.sidebar-panel { border: 1px solid var(--rule); padding: 20px; background: var(--panel); }
.sidebar-panel__title { font-family: var(--sans); font-size: 10.5px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 14px; }
.sidebar-cta-card { background: var(--accent); color: var(--paper); padding: 20px; }
.sidebar-cta-card h4 { font-family: var(--serif); font-size: 17px; font-weight: 500; margin-bottom: 8px; color: var(--paper); }
.sidebar-cta-card p { font-family: var(--sans); font-size: 13px; color: rgba(255,255,255,.7); margin: 0 0 14px; line-height: 1.5; }
.sidebar-cta-card a { font-family: var(--sans); font-size: 13px; font-weight: 600; color: var(--paper); border-bottom: 1px solid rgba(255,255,255,.4); }

/* Filter bar */
.filter-bar { position: sticky; top: 57px; z-index: 20; background: var(--paper); border-bottom: 1px solid var(--rule); }
.filter-bar__inner { max-width: var(--container); margin: 0 auto; padding: 12px var(--gutter); display: flex; align-items: center; gap: 8px; overflow-x: auto; scrollbar-width: none; flex-wrap: wrap; }
.filter-chip { padding: 6px 13px; background: var(--chip); border: 1px solid var(--rule); font-family: var(--sans); font-size: 12.5px; color: var(--ink-soft); cursor: pointer; white-space: nowrap; transition: all .15s; flex-shrink: 0; border-radius: 0; }
.filter-chip:hover, .filter-chip.is-active { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* Pagination */
.pagination { display: flex; align-items: center; justify-content: center; gap: 4px; padding: 24px 0; border-top: 1px solid var(--rule); }
.pg-btn { width: 36px; height: 36px; display: grid; place-items: center; border: 1px solid var(--rule); background: var(--panel); font-family: var(--sans); font-size: 13px; color: var(--ink-soft); cursor: pointer; transition: all .15s; text-decoration: none; }
.pg-btn:hover, .pg-btn.is-active { border-color: var(--accent); color: var(--accent); }
.pg-btn.is-active { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* ===========================================================================
   SINGLE REPORT PAGE (rhero + tabs + purchase rail)
   =========================================================================== */
.rhero { position: relative; }
.rhero__band { background: linear-gradient(180deg, #FBFCFE 0%, #EFF2F8 100%); color: var(--ink); border-bottom: 1px solid var(--rule); padding: 44px var(--gutter) 64px; }
.rhero__inner { max-width: var(--container); margin: 0 auto; display: grid; grid-template-columns: minmax(0,1.55fr) minmax(280px,360px); gap: 52px; align-items: center; }
.rhero__tags { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 20px; }
.rtag { font-family: var(--mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; padding: 5px 11px; border: 1px solid var(--rule); color: var(--ink-soft); background: var(--paper); }
.rtag--solid { background: var(--accent); border-color: var(--accent); color: #fff; }
.rhero__title { font-family: var(--serif); font-size: 44px; font-weight: 600; line-height: 1.08; letter-spacing: -.02em; margin: 0 0 18px; max-width: 18ch; color: var(--ink); }
.rhero__statement { font-family: var(--serif); font-size: 20px; line-height: 1.5; color: var(--ink-soft); max-width: 60ch; margin: 0 0 28px; }
.rhero__actions { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 24px; }
.rbtn { display: inline-flex; align-items: center; gap: 8px; font-family: var(--sans); font-size: 14px; font-weight: 600; padding: 12px 22px; cursor: pointer; border: 1px solid transparent; transition: filter .15s, border-color .15s, background .15s; text-decoration: none; }
.rbtn--primary { background: var(--accent); color: #fff; border-color: var(--accent); }
.rbtn--primary:hover { filter: brightness(1.1); }
.rbtn--ghost { background: var(--paper); border-color: var(--rule); color: var(--ink); }
.rbtn--ghost:hover { border-color: var(--ink); }
.rhero__meta { font-family: var(--sans); font-size: 13px; color: var(--ink-soft); display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.rhero__meta strong { color: var(--ink); font-weight: 600; }
.rhero__meta .dot { color: var(--rule); }

/* Report cover (portrait "book" card) */
.rhero__cover { display: flex; justify-content: flex-end; }
.report-cover { position: relative; overflow: hidden; width: 100%; max-width: 340px; min-height: 408px; background: linear-gradient(158deg, #18213c 0%, #243a73 45%, var(--accent) 100%); color: #fff; padding: 28px 28px 24px; display: flex; flex-direction: column; box-shadow: 0 26px 64px rgba(24,33,60,.34); }
.report-cover__sheen { position: absolute; inset: 0; background: linear-gradient(125deg, rgba(255,255,255,.16) 0%, rgba(255,255,255,0) 42%); pointer-events: none; }
.report-cover__top { display: flex; align-items: center; justify-content: space-between; position: relative; z-index: 1; }
.report-cover__brand { font-family: var(--serif); font-size: 17px; color: #fff; }
.report-cover__brand b { font-weight: 700; }
.report-cover__brand em { font-style: italic; font-weight: 400; opacity: .85; }
.report-cover__badge { font-family: var(--mono); font-size: 9px; letter-spacing: .08em; text-transform: uppercase; padding: 4px 8px; border: 1px solid rgba(255,255,255,.4); color: rgba(255,255,255,.85); }
.report-cover__body { flex: 1; display: flex; flex-direction: column; justify-content: center; position: relative; z-index: 1; }
.report-cover__eyebrow { font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.7); margin-bottom: 14px; }
.report-cover__title { font-family: var(--serif); font-size: 30px; font-weight: 600; line-height: 1.12; letter-spacing: -.01em; margin: 0 0 18px; color: #fff; }
.report-cover__period { font-family: var(--mono); font-size: 13px; color: rgba(255,255,255,.85); padding-top: 16px; border-top: 1px solid rgba(255,255,255,.25); display: inline-block; }
.report-cover__foot { position: relative; z-index: 1; }
.report-cover__spark { width: 100%; height: 30px; display: block; margin-bottom: 10px; opacity: .9; }
.report-cover__sub { font-family: var(--sans); font-size: 12px; color: rgba(255,255,255,.7); }

/* Snapshot stat cards */
.snapshot { max-width: var(--container); margin: -36px auto 44px; padding: 0 var(--gutter); display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; position: relative; z-index: 2; }
.snap { background: var(--paper); border: 1px solid var(--rule); border-top: 3px solid var(--ink); padding: 22px 22px 20px; box-shadow: 0 12px 36px rgba(10,10,20,.10); display: flex; flex-direction: column; gap: 10px; }
.snap--accent { border-top-color: var(--accent); }
.snap__lbl { font-family: var(--mono); font-size: 10.5px; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-soft); }
.snap__val { font-family: var(--serif); font-size: 34px; font-weight: 700; letter-spacing: -.02em; color: var(--ink); line-height: 1; }
.snap--accent .snap__val { color: var(--accent); }

/* 3-column layout (report body) */
.report-layout { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); display: grid; grid-template-columns: 200px 1fr 340px; gap: 40px; }
.jump { position: sticky; top: 90px; align-self: start; padding-top: 32px; }
.jump .eyebrow { margin-bottom: 12px; display: block; }
.jump ol { list-style: none; padding: 0; margin: 0; counter-reset: jmp; }
.jump li { counter-increment: jmp; }
.jump a { display: grid; grid-template-columns: 24px 1fr; align-items: baseline; gap: 8px; padding: 7px 0; font-family: var(--sans); font-size: 13px; color: var(--ink-soft); border-bottom: 1px dotted var(--rule); transition: color .15s; text-decoration: none; }
.jump a::before { content: counter(jmp, decimal-leading-zero); font-family: var(--mono); font-size: 10px; color: var(--ink-soft); }
.jump a.is-active, .jump a:hover { color: var(--ink); }
.jump a.is-active::before { color: var(--accent); }

/* Tabs */
.tabs { display: flex; gap: 0; border-bottom: 1px solid var(--rule); margin-bottom: 32px; }
.tab { padding: 13px 20px 13px 0; margin-right: 20px; font-family: var(--sans); font-size: 14px; font-weight: 500; color: var(--ink-soft); border-bottom: 2px solid transparent; margin-bottom: -1px; transition: color .15s, border-color .15s; cursor: pointer; background: none; border-left: 0; border-right: 0; border-top: 0; }
.tab.is-active { color: var(--ink); border-bottom-color: var(--accent); }
.tab-panel { display: none; }
.tab-panel.is-active { display: block; }

/* Section */
.section { padding: var(--pad-section-y) 0; border-bottom: 1px solid var(--rule); }
.section__head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 18px; }
.section__title { display: flex; align-items: baseline; gap: 14px; }
.section__title .num { font-family: var(--mono); font-size: 13px; color: var(--accent); }
.section__intro { font-family: var(--serif); font-style: italic; color: var(--ink-soft); font-size: 16px; line-height: 1.6; max-width: 620px; margin: 0 0 26px; }
.main-content { padding-top: 32px; min-width: 0; }

/* Report content wysiwyg output */
.report-section-content { font-family: var(--sans); font-size: 15px; line-height: 1.7; color: var(--ink); }
.report-section-content p { margin: 0 0 14px; }
.report-section-content h2, .report-section-content h3 { font-family: var(--serif); margin: 24px 0 12px; }
.report-section-content ul, .report-section-content ol { margin: 0 0 14px; padding-left: 22px; }
.report-section-content table { width: 100%; border-collapse: collapse; margin: 16px 0; }
.report-section-content table th { font-weight: 600; background: var(--chip); padding: 10px 14px; border: 1px solid var(--rule); font-family: var(--sans); font-size: 13px; }
.report-section-content table td { padding: 10px 14px; border: 1px solid var(--rule); font-size: 14px; }

/* FAQ */
.faqs { border-top: 1px solid var(--rule); }
.faq-item { border-bottom: 1px solid var(--rule); }
.faq-question { width: 100%; text-align: left; display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 18px 0; cursor: pointer; font-family: var(--serif); font-size: 17px; color: var(--ink); transition: color .15s; background: none; border: 0; }
.faq-question:hover { color: var(--accent); }
.faq-icon { width: 24px; height: 24px; display: grid; place-items: center; border: 1px solid var(--ink); font-family: var(--sans); font-size: 14px; font-weight: 500; transition: transform .2s, background .15s, color .15s; flex-shrink: 0; }
.faq-item.is-open .faq-icon { transform: rotate(45deg); background: var(--ink); color: var(--paper); }
.faq-answer { display: none; padding: 0 0 20px; max-width: 680px; }
.faq-item.is-open .faq-answer { display: block; }
.faq-answer p { margin: 0; font-family: var(--serif); font-size: 15.5px; line-height: 1.65; color: var(--ink-soft); }

/* Purchase rail */
.rail { position: sticky; top: 90px; align-self: start; padding-top: 32px; }
.purchase { background: var(--panel); border: 1px solid var(--ink); padding: 24px; position: relative; }
.purchase__badge { position: absolute; top: -1px; right: -1px; padding: 4px 10px; background: var(--ink); color: var(--paper); font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; }
.purchase__eyebrow { margin-bottom: 6px; display: block; }
.purchase__title { font-family: var(--serif); font-size: 21px; margin-bottom: 4px; }
.purchase__hint { font-family: var(--sans); font-size: 12px; color: var(--ink-soft); margin-bottom: 18px; }
.cta-buy { width: 100%; display: flex; justify-content: space-between; align-items: center; padding: 13px 16px; background: var(--accent); color: var(--paper); font-family: var(--sans); font-size: 14px; font-weight: 500; transition: background .15s; border: 0; cursor: pointer; text-decoration: none; margin-bottom: 14px; }
.cta-buy:hover { background: var(--ink); }
.purchase__alt { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--rule); display: flex; flex-direction: column; gap: 2px; }
.purchase__alt a { display: flex; justify-content: space-between; width: 100%; font-family: var(--sans); font-size: 13px; color: var(--ink); padding: 6px 0; border-bottom: 1px dotted var(--rule); text-decoration: none; transition: color .15s; }
.purchase__alt a:hover { color: var(--accent); }
.purchase__alt a:last-child { border-bottom: 0; }

/* ===========================================================================
   GENERIC PAGE CONTENT
   =========================================================================== */
.page-content { max-width: 820px; margin: 0 auto; padding: 48px var(--gutter) 72px; }
.page-content h1 { font-size: 36px; margin-bottom: 16px; }
.page-content h2 { font-size: 24px; margin: 32px 0 12px; }
.page-content p { font-family: var(--sans); font-size: 15px; line-height: 1.7; color: var(--ink-soft); margin: 0 0 14px; }
.page-content a { color: var(--accent); text-decoration: underline; }
.page-content ul { font-family: var(--sans); font-size: 15px; line-height: 1.7; color: var(--ink-soft); margin: 0 0 14px; padding-left: 22px; }

/* ===========================================================================
   BREADCRUMBS
   =========================================================================== */
.breadcrumbs-nav { background: var(--chip); border-bottom: 1px solid var(--rule); padding: 11px var(--gutter); }
.breadcrumbs-nav__inner { max-width: var(--container); margin: 0 auto; display: flex; align-items: center; gap: 6px; font-family: var(--sans); font-size: 12.5px; color: var(--ink-soft); }
.breadcrumbs-nav a { color: var(--ink-soft); text-decoration: none; }
.breadcrumbs-nav a:hover { color: var(--accent); }
.breadcrumbs-nav .sep { color: var(--rule); font-size: 14px; }
.breadcrumbs-nav .current { color: var(--ink); }

/* ===========================================================================
   404 PAGE
   =========================================================================== */
.error-page { text-align: center; padding: 120px var(--gutter); max-width: 600px; margin: 0 auto; }
.error-page__code { font-family: var(--mono); font-size: 80px; color: var(--accent); line-height: 1; margin-bottom: 16px; }
.error-page h1 { font-size: 32px; margin-bottom: 12px; }
.error-page p { font-family: var(--sans); font-size: 16px; color: var(--ink-soft); margin-bottom: 28px; }

/* ===========================================================================
   RESPONSIVE
   =========================================================================== */
@media (max-width: 1080px) {
  .hero-full { grid-template-columns: 1fr; min-height: auto; padding: 64px var(--gutter); max-height: none; }
  .hero-preview { display: none; }
  .report-layout { grid-template-columns: 1fr; max-width: 780px; }
  .jump { display: none; }
  .rail { position: static; padding-top: 0; }
  .rhero__inner { grid-template-columns: 1fr; gap: 32px; }
  .rhero__cover { justify-content: flex-start; }
  .snapshot { grid-template-columns: repeat(2, 1fr); margin-top: 20px; }
  .browse-layout { grid-template-columns: 1fr; }
  .browse-sidebar { display: none; }
  .cards-grid { grid-template-columns: repeat(2,1fr); }
  .industry-grid { grid-template-columns: repeat(3,1fr); }
  .trust-bar__inner { grid-template-columns: repeat(2,1fr); }
  .footer__top { grid-template-columns: 1fr; gap: 32px; }
  .footer__cols { grid-template-columns: repeat(2,1fr); }
  .how-it-works__grid { grid-template-columns: 1fr; gap: 28px; }
  .how-step:not(:last-child)::after { display: none; }
}
@media (max-width: 760px) {
  .topbar__inner { display: flex; align-items: center; gap: 12px; position: relative; }
  .topbar__inner > .brand { margin-right: auto; }
  .user-tools > .btn-browse { display: none; }
  .main-nav { display: none; position: absolute; top: 100%; left: 0; right: 0; flex-direction: column; align-items: stretch; gap: 0; background: var(--paper); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); padding: 4px var(--gutter); box-shadow: 0 14px 26px rgba(0,0,0,.09); z-index: 70; }
  .main-nav.is-open { display: flex; }
  .main-nav .nav-link { padding: 13px 2px; font-size: 15px; border-bottom: 1px solid var(--rule); }
  .hamburger { display: flex; }
  .rhero__band { padding: 26px var(--gutter) 38px; }
  .rhero__title { font-size: 29px; }
  .snapshot { grid-template-columns: 1fr 1fr; }
  .cards-grid { grid-template-columns: 1fr; }
  .industry-grid { grid-template-columns: repeat(2,1fr); gap: 10px; }
  .footer__cols { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px) {
  .snapshot { grid-template-columns: 1fr; }
  .snap__val { font-size: 30px; }
  .trust-bar__inner { grid-template-columns: 1fr 1fr; }
}
