/* Axiom Sovereign — Extended Components
   Builds on styles.css (navy #0a0f1a, gold #c89b3c, white, gray #f9f9f9)
   Never overwrites base variables — only adds new component classes
   ================================================================ */

/* ── Extra Variables ── */
:root {
  --navy-mid:   #111827;
  --navy-light: #1a2a4a;
  --gold-light: #e0b85a;
  --gold-dim:   rgba(200,155,60,0.10);
  --gold-border:rgba(200,155,60,0.22);
  --text-mid:   #444444;
  --text-light: #888888;
  --border:     #e2e2e2;
  --white:      #ffffff;
}

/* ── Sticky Header override ── */
header { position: sticky; top: 0; z-index: 100; }

/* ── Logo sub-line ── */
.logo { display:flex; flex-direction:column; gap:1px; text-decoration:none; }
.logo-sub { font-size:0.62rem; color:rgba(200,155,60,0.5); letter-spacing:1.5px; font-weight:normal; text-transform:uppercase; }

/* ── Nav additions ── */
nav a.active { color: var(--axiom-gold); }
nav a.nav-cta {
  background: var(--axiom-gold);
  color: var(--axiom-navy) !important;
  font-weight: bold;
  border-radius: 2px;
  padding: 7px 18px;
}
nav a.nav-cta:hover { background: var(--gold-light); }

/* ── Hero additions ── */
.hero-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 3.5rem;
  align-items: center;
}
.hero-eyebrow {
  font-size:0.72rem; letter-spacing:3px; text-transform:uppercase;
  color:var(--axiom-gold); margin-bottom:16px;
  display:flex; align-items:center; gap:10px;
}
.hero-eyebrow::before { content:''; width:18px; height:1px; background:var(--axiom-gold); }
.hero h1 { text-align:left; }
.hero p.tagline { text-align:left; max-width:500px; }
.hero p.body-copy { font-size:0.9rem; color:rgba(255,255,255,0.5); line-height:1.75; max-width:500px; margin-bottom:28px; }
.hero .accent { color:var(--axiom-gold); font-style:italic; font-weight:300; }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:32px; }
.hero-markets {
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  padding-top:22px; border-top:1px solid rgba(200,155,60,0.18);
}
.hero-markets-label { font-size:0.68rem; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,0.3); }
.market-tag { font-size:0.68rem; letter-spacing:1.5px; text-transform:uppercase; padding:3px 11px; border-radius:2px; }
.market-us   { background:rgba(200,155,60,0.1); color:var(--axiom-gold); border:1px solid var(--gold-border); }
.market-intl { background:rgba(255,255,255,0.04); color:rgba(255,255,255,0.4); border:1px solid rgba(255,255,255,0.1); }

/* Hero stats */
.hero-stats { display:flex; flex-direction:column; gap:12px; }
.stat-card {
  background:rgba(255,255,255,0.04);
  border:1px solid var(--gold-border);
  border-left:3px solid var(--axiom-gold);
  padding:16px 20px;
}
.stat-num  { font-size:1.9rem; font-weight:700; color:var(--axiom-gold); line-height:1; margin-bottom:4px; }
.stat-label{ font-size:0.82rem; color:rgba(255,255,255,0.55); margin-bottom:2px; }
.stat-sub  { font-size:0.7rem; color:rgba(255,255,255,0.28); }

/* ── Buttons (additional) ── */
.btn-ghost {
  border:2px solid rgba(255,255,255,0.25);
  color:rgba(255,255,255,0.7);
  padding:11px 26px;
  font-weight:bold;
  text-decoration:none;
  display:inline-block;
  border-radius:2px;
  font-size:0.88rem;
  background:transparent;
  transition:all 0.2s;
}
.btn-ghost:hover { border-color:var(--axiom-gold); color:var(--axiom-gold); }
.btn-text {
  color:var(--axiom-gold); background:none; border:none;
  font-size:0.85rem; font-weight:600;
  text-decoration:none; cursor:pointer; padding:0;
  display:inline-flex; align-items:center; gap:6px;
  transition:gap 0.2s;
}
.btn-text:hover { gap:10px; }

/* ── Sections ── */
.section-dark  { background:var(--axiom-navy); color:#fff; padding:80px 0; }
.section-light { background:var(--axiom-gray);  padding:80px 0; }
.section-white { background:#fff;               padding:80px 0; }
.section-dark  .section-title { color:#fff; }

.gold-rule { width:34px; height:3px; background:var(--axiom-gold); margin-bottom:16px; }
.section-eyebrow {
  font-size:0.7rem; letter-spacing:3px; text-transform:uppercase;
  color:var(--axiom-gold); margin-bottom:10px;
  display:flex; align-items:center; gap:10px;
}
.section-eyebrow::before { content:''; width:16px; height:1px; background:var(--axiom-gold); }
.section-title { font-size:clamp(1.6rem,2.8vw,2.3rem); font-weight:700; line-height:1.15; margin-bottom:12px; letter-spacing:-0.3px; }
.section-intro { font-size:0.95rem; color:var(--text-mid); line-height:1.75; max-width:600px; margin-bottom:3rem; }
.section-dark .section-intro { color:rgba(255,255,255,0.55); }

/* ── Grid ── */
.g2 { display:grid; grid-template-columns:1fr 1fr;           gap:24px; }
.g3 { display:grid; grid-template-columns:repeat(3,1fr);      gap:24px; }
.g4 { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:24px; }

/* ── Philosophy strip ── */
.philosophy-strip { background:var(--axiom-gray); border-top:1px solid #e0e0e0; border-bottom:1px solid #e0e0e0; padding:60px 0; }
.phil-inner { max-width:1200px; margin:0 auto; padding:0 40px; display:grid; grid-template-columns:1fr 2fr; gap:4rem; align-items:center; }
.phil-heading { font-size:1.3rem; font-weight:700; color:var(--axiom-navy); line-height:1.3; }
.phil-cols { display:grid; grid-template-columns:1fr 1fr; gap:2rem; }
.phil-block strong { display:block; font-size:0.92rem; color:var(--axiom-navy); margin-bottom:8px; }
.phil-block p { font-size:0.87rem; color:var(--text-mid); line-height:1.7; }

/* ── Service cards (dark bg) ── */
.svc-card {
  background:rgba(255,255,255,0.04);
  border:1px solid var(--gold-border);
  border-top:3px solid var(--axiom-gold);
  padding:30px;
  transition:border-color 0.2s;
}
.svc-card:hover { border-color:rgba(200,155,60,0.45); }
.svc-num   { font-size:0.68rem; letter-spacing:2px; color:rgba(200,155,60,0.45); text-transform:uppercase; margin-bottom:16px; }
.svc-title { font-size:1.1rem; font-weight:700; color:#fff; margin-bottom:10px; }
.svc-body  { font-size:0.88rem; color:rgba(255,255,255,0.55); line-height:1.7; margin-bottom:16px; }
.svc-list  { list-style:none; margin-bottom:20px; }
.svc-list li {
  font-size:0.83rem; color:rgba(255,255,255,0.45);
  padding:5px 0; border-bottom:1px solid rgba(255,255,255,0.06);
  display:flex; gap:8px; line-height:1.4;
}
.svc-list li:last-child { border-bottom:none; }
.svc-list li::before { content:'—'; color:var(--axiom-gold); flex-shrink:0; font-size:0.78rem; }

/* ── Serve cards (light bg) ── */
.serve-card { background:#fff; border:1px solid var(--border); padding:28px; transition:all 0.25s; position:relative; overflow:hidden; }
.serve-card::after { content:''; position:absolute; bottom:0; left:0; right:0; height:3px; background:var(--axiom-gold); transform:scaleX(0); transform-origin:left; transition:transform 0.3s; }
.serve-card:hover { box-shadow:0 6px 22px rgba(0,0,0,0.07); transform:translateY(-2px); }
.serve-card:hover::after { transform:scaleX(1); }
.region-tag { font-size:0.66rem; letter-spacing:2px; text-transform:uppercase; padding:3px 10px; border-radius:2px; display:inline-block; margin-bottom:12px; }
.rt-us   { background:rgba(200,155,60,0.08); color:var(--axiom-gold); border:1px solid var(--gold-border); }
.rt-b2b  { background:#eff6ff; color:#2563eb; border:1px solid #bfdbfe; }
.rt-intl { background:#f0fdf4; color:#16a34a; border:1px solid #bbf7d0; }
.serve-title { font-size:1rem; font-weight:700; color:var(--axiom-navy); margin-bottom:9px; }
.serve-body  { font-size:0.86rem; color:var(--text-mid); line-height:1.7; margin-bottom:12px; }
.serve-tags  { font-size:0.76rem; color:var(--text-light); line-height:1.6; border-top:1px solid var(--border); padding-top:10px; }

/* ── Research cards ── */
.rc { background:#fff; border:1px solid var(--border); border-top:4px solid var(--axiom-gold); padding:28px; display:flex; flex-direction:column; transition:all 0.2s; }
.rc:hover { box-shadow:0 6px 22px rgba(0,0,0,0.07); transform:translateY(-2px); }
.rc-num    { font-size:0.68rem; letter-spacing:2px; text-transform:uppercase; color:var(--axiom-gold); margin-bottom:6px; }
.rc-series { font-size:0.75rem; color:var(--text-light); text-transform:uppercase; letter-spacing:0.8px; margin-bottom:8px; }
.rc-title  { font-size:1rem; font-weight:700; color:var(--axiom-navy); margin-bottom:9px; line-height:1.3; }
.rc-body   { font-size:0.85rem; color:var(--text-mid); line-height:1.65; flex:1; margin-bottom:16px; }
.rc-tags   { display:flex; flex-wrap:wrap; gap:5px; margin-bottom:16px; }
.rc-tag    { font-size:0.68rem; padding:2px 8px; border-radius:2px; background:var(--gold-dim); color:var(--axiom-gold); border:1px solid var(--gold-border); }
.rc-actions{ display:flex; gap:8px; flex-wrap:wrap; }
.btn-dl    { background:var(--axiom-gold); color:var(--axiom-navy); padding:7px 15px; border-radius:2px; font-size:0.8rem; font-weight:bold; text-decoration:none; transition:background 0.2s; }
.btn-dl:hover { background:var(--gold-light); }
.btn-assess{ border:1px solid var(--gold-border); color:var(--axiom-gold); background:transparent; padding:7px 15px; border-radius:2px; font-size:0.8rem; text-decoration:none; transition:all 0.2s; }
.btn-assess:hover { background:var(--gold-dim); }

/* ── Insight cards ── */
.ic { background:#fff; border:1px solid var(--border); padding:26px; display:flex; flex-direction:column; transition:all 0.2s; text-decoration:none; }
.ic:hover { box-shadow:0 6px 22px rgba(0,0,0,0.07); transform:translateY(-2px); border-color:rgba(200,155,60,0.3); }
.ic-kicker  { font-size:0.68rem; letter-spacing:2px; text-transform:uppercase; color:var(--axiom-gold); margin-bottom:8px; }
.ic-title   { font-size:1rem; font-weight:700; color:var(--axiom-navy); line-height:1.3; margin-bottom:9px; }
.ic-excerpt { font-size:0.85rem; color:var(--text-mid); line-height:1.65; flex:1; margin-bottom:14px; }
.ic-meta    { font-size:0.73rem; color:var(--text-light); display:flex; gap:10px; border-top:1px solid var(--border); padding-top:10px; }
.ic-readmore{ font-size:0.8rem; color:var(--axiom-gold); font-weight:600; text-decoration:none; display:inline-flex; align-items:center; gap:5px; transition:gap 0.2s; }
.ic-readmore:hover { gap:9px; }

/* ── Assessment cards ── */
.asc { background:#fff; border:1px solid var(--border); overflow:hidden; display:flex; flex-direction:column; transition:all 0.2s; }
.asc:hover { box-shadow:0 6px 22px rgba(0,0,0,0.07); transform:translateY(-2px); }
.asc-head  { background:var(--axiom-navy); padding:22px; border-bottom:3px solid var(--axiom-gold); }
.asc-time  { font-size:0.68rem; letter-spacing:2px; text-transform:uppercase; color:var(--axiom-gold); margin-bottom:7px; }
.asc-title { font-size:0.98rem; font-weight:700; color:#fff; line-height:1.3; }
.asc-body  { padding:22px; flex:1; display:flex; flex-direction:column; }
.asc-desc  { font-size:0.86rem; color:var(--text-mid); line-height:1.65; margin-bottom:14px; }
.asc-covers{ font-size:0.68rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-light); margin-bottom:7px; }
.asc-items { list-style:none; margin-bottom:18px; flex:1; }
.asc-items li { font-size:0.83rem; color:var(--text-mid); padding:3px 0; display:flex; gap:7px; align-items:flex-start; }
.asc-items li::before { content:'→'; color:var(--axiom-gold); flex-shrink:0; font-size:0.75rem; margin-top:2px; }
.asc-btn {
  display:block; text-align:center;
  background:var(--axiom-navy); color:var(--axiom-gold);
  padding:10px; font-size:0.84rem; font-weight:bold;
  text-decoration:none; border:1px solid var(--gold-border);
  transition:all 0.2s; margin-top:auto;
}
.asc-btn:hover { background:var(--axiom-gold); color:var(--axiom-navy); }

/* ── Engagement model ── */
.eng-card { background:#fff; border:1px solid var(--border); border-top:4px solid var(--axiom-gold); padding:30px; }
.eng-tier  { font-size:0.68rem; letter-spacing:2px; text-transform:uppercase; color:var(--axiom-gold); margin-bottom:8px; }
.eng-title { font-size:1.2rem; font-weight:700; color:var(--axiom-navy); margin-bottom:4px; }
.eng-price { font-size:0.82rem; color:var(--text-light); font-style:italic; margin-bottom:14px; }
.eng-body  { font-size:0.87rem; color:var(--text-mid); line-height:1.7; margin-bottom:14px; }
.eng-items { list-style:none; }
.eng-items li { font-size:0.84rem; color:var(--text-mid); padding:5px 0; border-bottom:1px solid var(--border); display:flex; gap:8px; }
.eng-items li:last-child { border-bottom:none; }
.eng-items li::before { content:'—'; color:var(--axiom-gold); flex-shrink:0; }

/* Trust Pack */
.trust-pack { background:var(--axiom-navy); border:1px solid var(--gold-border); padding:32px; display:grid; grid-template-columns:1fr auto; gap:2rem; align-items:center; }
.tp-kicker  { font-size:0.68rem; letter-spacing:2px; text-transform:uppercase; color:var(--axiom-gold); margin-bottom:7px; }
.tp-title   { font-size:1.15rem; font-weight:700; color:#fff; margin-bottom:8px; }
.tp-body    { font-size:0.88rem; color:rgba(255,255,255,0.55); line-height:1.7; max-width:580px; }

/* ── Page header (inner pages) ── */
.page-hdr { background:linear-gradient(135deg,var(--axiom-navy) 0%,#1a2a4a 100%); padding:70px 0 56px; color:#fff; }
.page-hdr-inner { max-width:1200px; margin:0 auto; padding:0 40px; }
.page-hdr-eyebrow { font-size:0.7rem; letter-spacing:3px; text-transform:uppercase; color:var(--axiom-gold); margin-bottom:12px; display:flex; align-items:center; gap:10px; }
.page-hdr-eyebrow::before { content:''; width:14px; height:1px; background:var(--axiom-gold); }
.page-hdr h1 { font-size:clamp(1.8rem,3vw,2.7rem); font-weight:700; line-height:1.15; color:#fff; margin-bottom:12px; letter-spacing:-0.3px; }
.page-hdr p  { font-size:0.97rem; color:rgba(255,255,255,0.6); max-width:600px; line-height:1.7; }

/* ── Credentials ── */
.cred-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.cred-item { background:var(--axiom-navy); border:1px solid var(--gold-border); padding:13px 16px; transition:border-color 0.2s; }
.cred-item:hover { border-color:rgba(200,155,60,0.45); }
.cred-abbr { font-size:0.92rem; font-weight:700; color:var(--axiom-gold); margin-bottom:3px; }
.cred-name { font-size:0.74rem; color:rgba(255,255,255,0.4); line-height:1.3; }

/* ── CTA band ── */
.cta-band { background:var(--axiom-navy); padding:80px 0; position:relative; overflow:hidden; }
.cta-band::before {
  content:''; position:absolute; top:0; left:0; right:0; bottom:0;
  background-image: linear-gradient(rgba(200,155,60,0.025) 1px,transparent 1px), linear-gradient(90deg,rgba(200,155,60,0.025) 1px,transparent 1px);
  background-size:48px 48px; pointer-events:none;
}
.cta-inner { position:relative; z-index:1; max-width:660px; margin:0 auto; text-align:center; padding:0 40px; }
.cta-heading { font-size:clamp(1.8rem,3.5vw,2.7rem); font-weight:700; color:#fff; margin-bottom:14px; line-height:1.15; letter-spacing:-0.3px; }
.cta-heading span { color:var(--axiom-gold); }
.cta-sub    { font-size:0.95rem; color:rgba(255,255,255,0.55); line-height:1.75; margin-bottom:30px; }
.cta-actions{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.cta-note   { margin-top:18px; font-size:0.78rem; color:rgba(255,255,255,0.28); }
.cta-note a { color:var(--axiom-gold); text-decoration:none; }

/* ── Footer ── */
.footer-top { display:flex; justify-content:space-between; align-items:flex-start; flex-wrap:wrap; gap:1.5rem; padding-bottom:26px; margin-bottom:20px; border-bottom:1px solid rgba(255,255,255,0.06); }
.footer-logo { font-weight:700; font-size:1.05rem; color:var(--axiom-gold); letter-spacing:1.5px; text-transform:uppercase; text-decoration:none; display:block; margin-bottom:4px; }
.footer-tagline { font-size:0.72rem; color:rgba(255,255,255,0.22); letter-spacing:0.8px; }
.footer-links { display:flex; gap:18px; flex-wrap:wrap; align-items:center; }
.footer-links a { font-size:0.83rem; color:rgba(255,255,255,0.32); text-decoration:none; transition:color 0.2s; }
.footer-links a:hover { color:var(--axiom-gold); }
.footer-legal { font-size:0.73rem; color:rgba(255,255,255,0.18); line-height:1.6; }

/* ── Intl section ── */
.intl-inner { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start; }
.intl-principle { background:var(--axiom-gray); border-left:4px solid var(--axiom-gold); padding:15px 18px; margin-bottom:12px; }
.intl-principle-label { font-size:0.68rem; letter-spacing:2px; text-transform:uppercase; color:var(--axiom-gold); margin-bottom:5px; }
.intl-principle p { font-size:0.86rem; color:var(--text-mid); line-height:1.65; }
.intl-regions { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.intl-region { background:#fff; border:1px solid var(--border); border-top:3px solid var(--axiom-gold); padding:18px; }
.intl-flag   { font-size:1.4rem; margin-bottom:7px; display:block; }
.intl-rname  { font-weight:700; color:var(--axiom-navy); margin-bottom:7px; font-size:0.95rem; }
.intl-region p { font-size:0.82rem; color:var(--text-mid); line-height:1.6; }

/* ── Responsive ── */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;}
  .hero-stats{flex-direction:row;flex-wrap:wrap;}
  .stat-card{flex:1;min-width:150px;}
  .g3,.g2{grid-template-columns:1fr 1fr;}
  .intl-inner,.phil-inner{grid-template-columns:1fr;gap:2rem;}
  .trust-pack{grid-template-columns:1fr;}
}
@media(max-width:768px){
  .container{padding:0 20px;}
  .page-hdr-inner{padding:0 20px;}
  nav a:not(.nav-cta){display:none;}
  .g3,.g2,.g4{grid-template-columns:1fr;}
  .cred-grid{grid-template-columns:1fr;}
  .intl-regions{grid-template-columns:1fr;}
  .phil-cols{grid-template-columns:1fr;gap:1.5rem;}
}

/* ── Assessment page overrides (light background) ── */
body {
  background: #ffffff;
}

.assess-wrapper,
.assessment-container,
main {
  background: #ffffff !important;
}

/* Question text and container */
.question-text,
.q-text {
  color: #0a0f1a;
  font-size: 1.05rem;
  line-height: 1.6;
  margin-bottom: 1.5rem;
  font-weight: 500;
}

/* Answer buttons - much better contrast */
.answer-option,
.btn-answer,
button.answer {
  background: #f9f9f9 !important;
  border: 2px solid #c89b3c !important;
  color: #0a0f1a !important;
  padding: 14px 18px !important;
  margin-bottom: 10px !important;
  font-size: 0.95rem !important;
  line-height: 1.5 !important;
  text-align: left !important;
  cursor: pointer;
  transition: all 0.2s;
  border-radius: 3px;
}

.answer-option:hover,
.btn-answer:hover,
button.answer:hover {
  background: #f0f0f0 !important;
  border-color: #e0b85a !important;
}

.answer-option.selected,
.btn-answer.selected,
button.answer.selected,
.answer-option.active,
.btn-answer.active {
  background: #c89b3c !important;
  color: #ffffff !important;
  border-color: #c89b3c !important;
  font-weight: 600;
}

/* Continue button - highly visible */
.continue-btn,
.btn-continue,
button[type="button"].continue,
.assessment-btn {
  background: #c89b3c !important;
  color: #0a0f1a !important;
  padding: 12px 32px !important;
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  border: none !important;
  border-radius: 3px;
  cursor: pointer;
  margin-top: 2rem !important;
  display: inline-block !important;
  transition: background 0.2s;
}

.continue-btn:hover,
.btn-continue:hover,
button[type="button"].continue:hover,
.assessment-btn:hover {
  background: #e0b85a !important;
}

.continue-btn:disabled,
.btn-continue:disabled {
  background: #cccccc !important;
  color: #666666 !important;
  cursor: not-allowed;
}

/* Back button */
.back-btn,
.btn-back {
  background: transparent !important;
  color: #0a0f1a !important;
  border: 2px solid #0a0f1a !important;
  padding: 10px 24px !important;
  font-weight: 600 !important;
  cursor: pointer;
  border-radius: 3px;
  transition: all 0.2s;
}

.back-btn:hover,
.btn-back:hover {
  background: #0a0f1a !important;
  color: #ffffff !important;
}

/* Progress indicator */
.progress,
.question-number,
.q-counter {
  color: #0a0f1a;
  font-size: 0.9rem;
  margin-bottom: 1rem;
}

/* Results section */
.results,
.assessment-results,
.result-section {
  background: #f9f9f9;
  border: 1px solid #e0e0e0;
  border-left: 4px solid #c89b3c;
  padding: 2rem;
  margin-top: 2rem;
}

.results h2,
.result-title {
  color: #0a0f1a;
  font-size: 1.4rem;
  margin-bottom: 1rem;
}

.results p,
.result-text {
  color: #444444;
  line-height: 1.7;
  margin-bottom: 0.75rem;
}

.risk-score,
.score-display {
  font-size: 2.2rem;
  font-weight: 700;
  color: #c89b3c;
  margin: 1rem 0;
}

.risk-level {
  font-size: 1.1rem;
  font-weight: 600;
  color: #0a0f1a;
  margin-bottom: 1rem;
}

/* Email input */
input[type="email"],
.email-input {
  background: #ffffff !important;
  border: 2px solid #c89b3c !important;
  color: #0a0f1a !important;
  padding: 12px 16px !important;
  font-size: 0.95rem !important;
  border-radius: 3px;
  margin: 1rem 0;
}

input[type="email"]:focus,
.email-input:focus {
  outline: none;
  border-color: #e0b85a !important;
  box-shadow: 0 0 0 3px rgba(200,155,60,0.1);
}

/* Label text */
label {
  color: #0a0f1a;
  font-weight: 600;
  display: block;
  margin-bottom: 0.5rem;
}

/* Main container padding */
.assess-main,
.assessment-main,
.main-content {
  max-width: 700px;
  margin: 0 auto;
  padding: 2rem;
  background: #ffffff;
}

