/* ==========================================
   1. CORMORANT GARAMOND (Headings)
   ========================================== */
@font-face { font-family: 'Cormorant Garamond'; font-style: normal; font-weight: 400; font-display: swap; src: url('./fonts/cormorant-garamond-v21-latin-regular.woff2') format('woff2'); }
@font-face { font-family: 'Cormorant Garamond'; font-style: italic; font-weight: 400; font-display: swap; src: url('./fonts/cormorant-garamond-v21-latin-italic.woff2') format('woff2'); }
@font-face { font-family: 'Cormorant Garamond'; font-style: normal; font-weight: 500; font-display: swap; src: url('./fonts/cormorant-garamond-v21-latin-500.woff2') format('woff2'); }
@font-face { font-family: 'Cormorant Garamond'; font-style: normal; font-weight: 600; font-display: swap; src: url('./fonts/cormorant-garamond-v21-latin-600.woff2') format('woff2'); }
@font-face { font-family: 'Cormorant Garamond'; font-style: normal; font-weight: 700; font-display: swap; src: url('./fonts/cormorant-garamond-v21-latin-700.woff2') format('woff2'); }

/* ==========================================
   2. DM SANS (Body Text)
   ========================================== */
@font-face { font-family: 'DM Sans'; font-style: normal; font-weight: 400; font-display: swap; src: url('./fonts/dm-sans-v17-latin-regular.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: normal; font-weight: 500; font-display: swap; src: url('./fonts/dm-sans-v17-latin-500.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: normal; font-weight: 600; font-display: swap; src: url('./fonts/dm-sans-v17-latin-600.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: normal; font-weight: 700; font-display: swap; src: url('./fonts/dm-sans-v17-latin-700.woff2') format('woff2'); }

/* ==========================================
   3. DM MONO (Technical/Ledger Text)
   ========================================== */
@font-face { font-family: 'DM Mono'; font-style: normal; font-weight: 400; font-display: swap; src: url('./fonts/dm-mono-v16-latin-regular.woff2') format('woff2'); }
@font-face { font-family: 'DM Mono'; font-style: normal; font-weight: 500; font-display: swap; src: url('./fonts/dm-mono-v16-latin-500.woff2') format('woff2'); }

:root {
  --stone-50: #f8f6f3; --stone-100: #f0ece6; --stone-200: #e4ddd4; --stone-300: #c5bbae;
  --stone-500: #7a7068; --stone-700: #4a4238; --stone-900: #161412;
  --sage-50: #edf2ef; --sage-100: #d4e4db; --sage-300: #8ab5a0;
  --sage-500: #4a8a70; --sage-600: #3a6050; --sage-800: #1e3d30;
  --copper: #b5720a; --copper-light: #fef3dc; --white: #ffffff;
  
  --mockup-bg: #242a33; 
  --mockup-card: #2f3640;
  --mockup-border: rgba(255,255,255,0.06);

  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body: 'DM Sans', system-ui, sans-serif;
  --font-mono: 'DM Mono', monospace;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body { background: var(--stone-50); color: var(--stone-900); font-family: var(--font-body); font-size: 17px; line-height: 1.7; overflow-x: hidden; text-rendering: geometricPrecision; }
.container { max-width: 1080px; margin: 0 auto; padding: 0 28px; }
.container-narrow { max-width: 760px; margin: 0 auto; padding: 0 28px; }

/* GLOBAL NAV */
nav { position: sticky; top: 0; z-index: 100; background: rgba(248,246,243,0.92); backdrop-filter: blur(16px); border-bottom: 0.5px solid var(--stone-200); }
.nav-inner { max-width: 1080px; margin: 0 auto; padding: 0 28px; height: 64px; display: flex; align-items: center; justify-content: space-between; }
.logo { font-family: var(--font-body); font-size: 18px; font-weight: 600; color: var(--stone-900); text-decoration: none; letter-spacing: 0.3px; }
.logo span { color: var(--sage-600); }
.nav-right { display: flex; align-items: center; gap: 28px; }
.nav-link { font-size: 14px; color: var(--stone-700); text-decoration: none; font-weight: 500; transition: color 0.2s; }
.nav-link:hover { color: var(--stone-900); }
.btn-nav { font-family: var(--font-body); font-size: 14px; font-weight: 500; background: var(--stone-900); color: var(--stone-50); padding: 10px 20px; border-radius: 6px; text-decoration: none; border: none; cursor: pointer; transition: background 0.2s; }
.btn-nav:hover { background: var(--sage-800); }
.nav-back { font-size: 13px; color: var(--stone-500); text-decoration: none; display: flex; align-items: center; gap: 6px; transition: color 0.2s; }
.nav-back:hover { color: var(--stone-900); }
.nav-back::before { content: '←'; }

/* HERO */
.hero { padding: 80px 0 64px; text-align: center; }
.hero-eyebrow { display: inline-flex; align-items: center; gap: 8px; background: var(--sage-50); border: 0.5px solid var(--sage-100); border-radius: 20px; padding: 6px 16px; font-size: 12px; color: var(--sage-600); font-weight: 600; letter-spacing: 0.5px; margin-bottom: 24px; }
.eyebrow-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--sage-500); animation: pulse 2.5s ease-in-out infinite; }
@keyframes pulse { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.5; transform: scale(0.85); } }
.hero-headline { font-family: var(--font-display); font-size: 56px; font-weight: 500; line-height: 1.1; letter-spacing: -0.5px; color: var(--stone-900); margin-bottom: 20px; }
.hero-headline em { font-style: italic; color: var(--sage-600); }
.hero-sub { font-size: 18px; color: var(--stone-700); line-height: 1.6; margin: 0 auto 40px; max-width: 600px; }
.hero-form-wrapper { max-width: 480px; margin: 0 auto; text-align: left; }
.scan-form { background: var(--white); border: 1px solid var(--stone-200); border-radius: 12px; padding: 24px; box-shadow: 0 10px 30px rgba(0,0,0,0.02); }
.form-label { font-family: var(--font-mono); font-size: 12px; font-weight: 600; color: var(--stone-700); letter-spacing: 1px; text-transform: uppercase; margin-bottom: 16px; display: block; }
.form-fields { display: flex; flex-direction: column; gap: 10px; }
input[type="text"], input[type="email"] { width: 100%; font-family: var(--font-body); font-size: 15px; color: var(--stone-900); background: var(--stone-50); border: 1px solid var(--stone-200); border-radius: 6px; height: 48px; padding: 0 16px; outline: none; transition: all 0.2s; }
input::placeholder { color: var(--stone-500); }
input:focus { border-color: var(--copper); box-shadow: 0 0 0 3px rgba(181,114,10,0.1); background: var(--white); }
.form-step-2 { display: none; flex-direction: column; gap: 10px; animation: fadeIn 0.3s ease; }
.form-step-2.visible { display: flex; }
.btn-scan { width: 100%; margin-top: 12px; font-family: var(--font-body); font-size: 16px; font-weight: 600; background: var(--sage-600); color: var(--white); border: none; border-radius: 6px; height: 52px; cursor: pointer; transition: all 0.2s; }
.btn-scan:hover { background: var(--sage-800); }
.form-trust { font-size: 13px; color: var(--stone-500); text-align: center; margin-top: 16px; display: flex; align-items: center; justify-content: center; gap: 12px; flex-wrap: wrap; }
.form-trust span { display: flex; align-items: center; }
.form-trust span + span::before { content: '·'; margin-right: 12px; color: var(--stone-300); }

/* SECTIONS & TYPOGRAPHY */
.section { padding: 88px 0; border-bottom: 1px solid var(--stone-200); }
.section.alt { background: var(--white); }
.section-header-left { margin-bottom: 40px; }
.section-tag { font-family: var(--font-mono); font-size: 12px; font-weight: 600; color: var(--sage-600); letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 16px; display: inline-flex; align-items: center; gap: 8px; }
.section-tag::before { content: ''; width: 24px; height: 1px; background: var(--sage-300); }
.section-title { font-family: var(--font-display); font-size: 42px; font-weight: 500; color: var(--stone-900); line-height: 1.15; margin-bottom: 20px; }
.section-title em { font-style: italic; color: var(--sage-600); }
.section-desc { font-size: 18px; color: var(--stone-700); line-height: 1.7; font-weight: 400; margin-bottom: 16px; }

/* REPORT MOCKUP */
.report-preview-section { padding: 88px 0; border-bottom: 1px solid var(--stone-200); background: var(--stone-50); overflow: hidden; }
.report-mockup-wrapper { margin-top: 48px; position: relative; }
.report-mockup-wrapper::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 120px; background: linear-gradient(to bottom, transparent, var(--stone-50)); pointer-events: none; z-index: 2; }
.report-mockup { background: var(--mockup-bg); border-radius: 16px; max-width: 820px; margin: 0 auto; overflow: hidden; box-shadow: 0 32px 80px rgba(0,0,0,0.18), 0 0 0 1px var(--mockup-border); max-height: 780px; position: relative; }
.rpt-header { padding: 20px 32px 16px; border-bottom: 1px solid var(--mockup-border); display: flex; align-items: center; justify-content: space-between; }
.rpt-brand { font-family: var(--font-body); font-size: 13px; font-weight: 600; color: var(--sage-300); letter-spacing: 0.3px; }
.rpt-brand-sep { color: rgba(255,255,255,0.2); margin: 0 8px; }
.rpt-brand-label { color: rgba(255,255,255,0.45); font-weight: 400; }
.rpt-date { font-family: var(--font-mono); font-size: 11px; color: rgba(255,255,255,0.3); }
.rpt-hotel-block { padding: 24px 32px 20px; }
.rpt-hotel-name { font-family: var(--font-display); font-size: 28px; font-weight: 500; color: #f0ece6; margin-bottom: 4px; }
.rpt-hotel-meta { font-family: var(--font-mono); font-size: 12px; color: rgba(255,255,255,0.35); }
.rpt-intro { padding: 0 32px 24px; font-size: 14px; line-height: 1.7; color: rgba(255,255,255,0.55); }
.rpt-intro strong { color: rgba(255,255,255,0.8); font-weight: 500; }
.rpt-finding { margin: 0 24px 16px; border: 1px solid var(--mockup-border); border-radius: 10px; padding: 24px 28px; background: var(--mockup-card); }
.rpt-finding-label { font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: #e8b97d; margin-bottom: 8px; }
.rpt-finding-query { font-size: 13px; color: rgba(255,255,255,0.4); margin-bottom: 12px; }
.rpt-finding-query span { color: rgba(255,255,255,0.6); }
.rpt-citing { font-family: var(--font-mono); font-size: 11px; font-weight: 600; color: #e74c3c; margin-bottom: 12px; display: flex; align-items: center; gap: 6px; }
.rpt-citing-dot { width: 6px; height: 6px; border-radius: 50%; background: #e74c3c; animation: pulse 2s ease-in-out infinite; }
.rpt-finding-body { font-size: 14px; line-height: 1.65; color: rgba(255,255,255,0.55); margin-bottom: 16px; }
.rpt-quote-block { border-left: 3px solid #e8b97d; padding: 12px 16px; background: rgba(232, 185, 125, 0.08); border-radius: 0 6px 6px 0; margin-bottom: 16px; }
.rpt-quote-text { font-family: var(--font-display); font-size: 17px; font-style: italic; color: #e8b97d; line-height: 1.5; }
.rpt-finding-consequence { font-size: 13px; color: rgba(255,255,255,0.4); line-height: 1.6; }
.rpt-finding-source { font-family: var(--font-mono); font-size: 11px; color: rgba(255,255,255,0.3); margin-top: 12px; }
.rpt-finding-source a { color: var(--sage-300); text-decoration: underline; text-underline-offset: 2px; }
.rpt-callout { margin: 8px 24px 16px; padding: 16px 20px; background: rgba(232, 185, 125, 0.08); border-left: 3px solid #e8b97d; border-radius: 0 8px 8px 0; font-size: 13px; line-height: 1.6; color: rgba(255,255,255,0.7); }
.rpt-callout strong { color: #e8b97d; font-weight: 600; }

/* BLIND SPOTS TABS */
.blind-spots { padding: 88px 0; border-bottom: 1px solid var(--stone-200); background: var(--white); }
.tab-container { border: 1px solid var(--stone-200); border-radius: 12px; overflow: hidden; box-shadow: 0 10px 30px rgba(0,0,0,0.02); }
.tab-nav { display: flex; background: var(--stone-50); border-bottom: 1px solid var(--stone-200); }
.tab-btn { flex: 1; padding: 20px 16px; text-align: center; background: transparent; border: none; font-family: var(--font-body); font-size: 14px; font-weight: 600; color: var(--stone-700); cursor: pointer; position: relative; transition: all 0.2s; border-right: 1px solid var(--stone-200); }
.tab-btn:last-child { border-right: none; }
.tab-btn.active { color: var(--sage-600); background: var(--white); }
.tab-btn.active::after { content: ''; position: absolute; bottom: -1px; left: 0; right: 0; height: 2px; background: var(--sage-500); }
.tab-content-wrap { padding: 40px; }
.tab-pane { display: none; }
.tab-pane.active { display: block; animation: fadeIn 0.4s ease; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(5px); } to { opacity: 1; transform: translateY(0); } }
.tab-tag-box { display: flex; justify-content: space-between; align-items: start; margin-bottom: 24px; gap: 20px; }
.tab-tag { font-family: var(--font-mono); font-size: 12px; font-weight: 600; color: var(--sage-600); background: var(--sage-50); padding: 4px 10px; border-radius: 4px; border: 0.5px solid var(--sage-100); }
.tab-stat-num { font-family: var(--font-display); font-size: 42px; font-weight: 500; color: var(--stone-900); line-height: 1; }
.tab-threat-title { font-family: var(--font-display); font-size: 32px; font-weight: 500; color: var(--stone-900); margin-bottom: 16px; line-height: 1.2; }
.tab-pane em { font-style: italic; color: var(--copper); font-weight: 500; }

/* LEDGER UI MOCKUP */
.ledger-mockup-wrapper { margin-top: 48px; position: relative; }
.ledger-mockup { background: var(--mockup-bg); border-radius: 16px; max-width: 820px; margin: 0 auto; overflow: hidden; box-shadow: 0 32px 80px rgba(0,0,0,0.18), 0 0 0 1px var(--mockup-border); }
.ldg-topbar { padding: 16px 28px; border-bottom: 1px solid var(--mockup-border); display: flex; align-items: center; justify-content: space-between; }
.ldg-topbar-left { display: flex; align-items: center; gap: 12px; }
.ldg-topbar-brand { font-family: var(--font-body); font-size: 14px; font-weight: 600; color: var(--sage-300); }
.ldg-topbar-sep { width: 1px; height: 16px; background: rgba(255,255,255,0.1); }
.ldg-topbar-hotel { font-size: 13px; color: rgba(255,255,255,0.5); font-weight: 500; }
.ldg-topbar-btn { font-family: var(--font-mono); font-size: 11px; font-weight: 600; background: var(--sage-600); color: var(--white); padding: 7px 14px; border-radius: 5px; border: none; letter-spacing: 0.3px; cursor: pointer;}
.ldg-tabs { display: flex; border-bottom: 1px solid var(--mockup-border); padding: 0 28px; }
.ldg-tab-btn { background: transparent; border: none; padding: 14px 20px; font-size: 13px; font-weight: 500; color: rgba(255,255,255,0.35); position: relative; font-family: var(--font-body); cursor: pointer; transition: color 0.2s;}
.ldg-tab-btn:hover { color: rgba(255,255,255,0.6); }
.ldg-tab-btn.active { color: var(--sage-300); }
.ldg-tab-btn.active::after { content: ''; position: absolute; bottom: -1px; left: 12px; right: 12px; height: 2px; background: var(--sage-500); border-radius: 1px; }
.ldg-ui-pane { display: none; animation: fadeIn 0.3s ease; }
.ldg-ui-pane.active { display: block; }
.ldg-empty-state { padding: 64px 32px; text-align: center; color: rgba(255,255,255,0.3); font-size: 14px; }
.ldg-view-toggle { display: flex; background: rgba(255,255,255,0.05); padding: 4px; border-radius: 6px; width: max-content; margin: 24px 24px 0; }
.ldg-toggle-btn { padding: 6px 14px; font-size: 11px; font-family: var(--font-mono); font-weight: 600; color: rgba(255,255,255,0.4); background: transparent; border: none; border-radius: 4px; cursor: pointer; transition: all 0.2s; text-transform: uppercase; letter-spacing: 0.5px;}
.ldg-toggle-btn.active { background: rgba(255,255,255,0.1); color: var(--white); box-shadow: 0 2px 4px rgba(0,0,0,0.2); }
.ldg-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--mockup-border); margin: 20px 24px 0; border-radius: 10px; overflow: hidden; }
.ldg-stat-card { background: var(--mockup-card); padding: 20px; }
.ldg-stat-label { font-family: var(--font-mono); font-size: 10px; font-weight: 600; color: rgba(255,255,255,0.3); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px; }
.ldg-stat-value { font-family: var(--font-display); font-size: 28px; font-weight: 500; color: #f0ece6; line-height: 1; }
.ldg-stat-value.green { color: var(--sage-300); }
.ldg-stat-value.amber { color: var(--copper); }
.ldg-entries { padding: 20px 24px 28px; }
.ldg-entry-row { display: grid; grid-template-columns: 140px 1fr 120px 100px; align-items: start; gap: 16px; padding: 18px 20px; border: 1px solid var(--mockup-border); border-radius: 8px; margin-bottom: 8px; background: var(--mockup-card); transition: background 0.15s; }
.ldg-entry-row:hover { background: rgba(255,255,255,0.04); }
.ldg-entry-theme { font-family: var(--font-mono); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.8px; margin-top: 4px;}
.ldg-entry-theme.green { color: #4ade80; }
.ldg-entry-theme.amber { color: var(--copper); }
.ldg-entry-theme.red { color: #f87171; }
.edit-element { display: none; }
.is-editing .edit-element { display: block; }
.is-editing .read-element { display: none; }
.ldg-entry-desc { font-size: 13px; color: rgba(255,255,255,0.55); line-height: 1.5; }
.ldg-edit-input { width: 100%; background: rgba(0,0,0,0.2); border: 1px solid rgba(255,255,255,0.1); color: rgba(255,255,255,0.8); padding: 8px 12px; border-radius: 4px; font-family: var(--font-body); font-size: 13px; resize: vertical; min-height: 50px; outline: none;}
.ldg-edit-input:focus { border-color: var(--sage-500); }
.ldg-entry-date { font-family: var(--font-mono); font-size: 11px; color: rgba(255,255,255,0.25); text-align: right; margin-top: 4px;}
.ldg-status-pill { font-family: var(--font-mono); font-size: 10px; font-weight: 700; padding: 5px 10px; border-radius: 4px; text-align: center; letter-spacing: 0.5px; text-transform: uppercase; }
.ldg-status-pill.resolved { background: rgba(74,222,128,0.1); color: #4ade80; }
.ldg-status-pill.monitoring { background: rgba(181,114,10,0.12); color: var(--copper); }
.ldg-status-pill.flagged { background: rgba(248,113,113,0.1); color: #f87171; }
.ldg-edit-select { background: rgba(0,0,0,0.2); border: 1px solid rgba(255,255,255,0.1); color: rgba(255,255,255,0.8); padding: 6px 8px; border-radius: 4px; font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; width: 100%; outline:none;}
.ldg-ai-track { grid-column: 1 / -1; display: flex; align-items: center; gap: 12px; padding: 10px 16px; margin-top: 4px; background: rgba(255,255,255,0.02); border-radius: 6px; border: 1px dashed var(--mockup-border); }
.ldg-ai-track-label { font-family: var(--font-mono); font-size: 10px; font-weight: 600; color: rgba(255,255,255,0.25); text-transform: uppercase; letter-spacing: 0.8px; white-space: nowrap; }
.ldg-ai-track-bar { flex: 1; height: 4px; border-radius: 2px; background: rgba(255,255,255,0.06); overflow: hidden; }
.ldg-ai-track-fill { height: 100%; border-radius: 2px; }
.ldg-ai-track-fill.green { background: var(--sage-500); }
.ldg-ai-track-fill.amber { background: var(--copper); }
.ldg-ai-track-pct { font-family: var(--font-mono); font-size: 11px; font-weight: 600; color: rgba(255,255,255,0.4); width: 36px; text-align: right; }

/* INFO GRIDS & PRICING */
.steps-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--stone-200); border-radius: 12px; overflow: hidden; }
.step-card { background: var(--white); padding: 32px 24px; }
.step-num { font-family: var(--font-mono); font-size: 13px; color: var(--sage-600); font-weight: 600; margin-bottom: 16px; }
.step-title { font-size: 18px; font-weight: 600; color: var(--stone-900); margin-bottom: 10px; }
.step-desc { font-size: 15px; color: var(--stone-700); }
.testimonial-strip { padding: 64px 0; border-bottom: 1px solid var(--stone-200); background: var(--sage-50); }
.testimonial-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 32px; }
.testimonial-card { background: var(--white); border: 1px solid var(--sage-100); border-radius: 10px; padding: 28px 32px; }
.testimonial-quote { font-family: var(--font-display); font-size: 20px; font-style: italic; color: var(--stone-900); line-height: 1.5; margin-bottom: 20px; }
.testimonial-author { font-size: 14px; font-weight: 600; color: var(--stone-700); }
.testimonial-role { font-size: 13px; color: var(--stone-500); font-family: var(--font-mono); }
.pricing-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 48px; }
.price-card { background: var(--white); border: 1px solid var(--stone-200); border-radius: 12px; padding: 40px 32px; display: flex; flex-direction: column; }
.price-card.featured { border: 2px solid var(--sage-300); }
.price-tier-badge { font-family: var(--font-mono); font-size: 11px; font-weight: 600; text-transform: uppercase; padding: 4px 12px; border-radius: 4px; margin-bottom: 20px; width: fit-content; }
.price-tier-badge.free-badge { background: var(--stone-100); color: var(--stone-700); }
.price-tier-badge.pro-badge { background: var(--sage-50); color: var(--sage-600); border: 1px solid var(--sage-100); }
.price-amount { font-family: var(--font-display); font-size: 48px; color: var(--stone-900); margin-bottom: 8px; line-height: 1; }
.price-amount.pro { color: var(--sage-600); }
.price-amount span { font-size: 18px; color: var(--stone-500); font-family: var(--font-body); }
.price-desc { font-size: 15px; color: var(--stone-700); margin-bottom: 24px; }
.price-features { list-style: none; flex: 1; margin-bottom: 32px; border-top: 1px solid var(--stone-100); padding-top: 24px; }
.price-features li { font-size: 15px; color: var(--stone-900); padding: 8px 0; display: flex; align-items: center; gap: 12px; }
.price-features li.dim { color: var(--stone-500); }
.feat-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--sage-500); flex-shrink: 0; }
.feat-dot.dim { background: var(--stone-200); }
.btn-price { text-align: center; font-size: 15px; font-weight: 600; padding: 14px; border-radius: 6px; text-decoration: none; transition: all 0.2s; display: block; }
.btn-price.outline { background: transparent; border: 1px solid var(--stone-300); color: var(--stone-900); }
.btn-price.outline:hover { background: var(--stone-100); }
.btn-price.solid { background: var(--sage-600); color: var(--white); }
.btn-price.solid:hover { background: var(--sage-800); }

/* FOOTER CTA & GLOBAL FOOTER */
.cta-section { padding: 88px 0 64px; background: var(--stone-900); text-align: center; }
.cta-headline { font-family: var(--font-display); font-size: 48px; color: var(--stone-50); margin: 16px auto 24px; }
.cta-headline em { color: var(--sage-300); font-style: italic; }
.cta-sub { font-size: 18px; color: var(--stone-300); max-width: 480px; margin: 0 auto 32px; }
footer { background: var(--stone-900); border-top: 1px solid rgba(255,255,255,0.08); padding: 32px 0; }
.footer-inner { max-width: 1080px; margin: 0 auto; padding: 0 28px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; }
.footer-left { font-size: 13px; color: var(--stone-500); font-family: var(--font-mono); }
.footer-links { display: flex; gap: 24px; }
.footer-links a { font-size: 13px; color: var(--stone-500); text-decoration: none; font-family: var(--font-mono); transition: color 0.2s; }
.footer-links a:hover { color: var(--stone-300); }

/* ==========================================
   LEGAL PAGE SPECIFIC OVERRIDES (.legal-page)
   ========================================== */
body.legal-page { font-size: 16px; }
body.legal-page nav .nav-inner { max-width: 760px; height: 56px; }
body.legal-page footer .footer-inner { max-width: 760px; }
body.legal-page main { max-width: 760px; margin: 0 auto; padding: 56px 28px 80px; }

.legal-page .doc-tag { font-family: var(--font-mono); font-size: 11px; font-weight: 500; color: var(--sage-600); letter-spacing: 2px; text-transform: uppercase; margin-bottom: 12px; display: block; }
.legal-page h1 { font-family: var(--font-display); font-size: 40px; font-weight: 400; color: var(--stone-900); line-height: 1.15; margin-bottom: 8px; letter-spacing: -0.3px; }
.legal-page .doc-meta { font-size: 13px; color: var(--stone-500); margin-bottom: 40px; padding-bottom: 32px; border-bottom: 0.5px solid var(--stone-200); font-family: var(--font-mono); }
.legal-page .doc-intro { font-size: 16px; color: var(--stone-700); line-height: 1.8; margin-bottom: 40px; font-weight: 300; }
.legal-page h2 { font-family: var(--font-display); font-size: 22px; font-weight: 500; color: var(--stone-900); margin: 40px 0 14px; line-height: 1.2; }
.legal-page h3 { font-size: 15px; font-weight: 500; color: var(--stone-900); margin: 24px 0 8px; }
.legal-page p { font-size: 15px; color: var(--stone-700); line-height: 1.75; margin-bottom: 14px; font-weight: 300; }
.legal-page ul { margin: 10px 0 14px 0; padding: 0; list-style: none; }
.legal-page ul li { font-size: 15px; color: var(--stone-700); line-height: 1.75; padding: 5px 0 5px 18px; position: relative; font-weight: 300; }
.legal-page ul li::before { content: ''; position: absolute; left: 0; top: 14px; width: 5px; height: 5px; border-radius: 50%; background: var(--sage-300); }
.legal-page a { color: var(--sage-600); text-decoration: none; }
.legal-page a:hover { text-decoration: underline; }
.legal-page .highlight-box { background: var(--sage-50); border: 0.5px solid var(--sage-100); border-left: 3px solid var(--sage-600); border-radius: 0 8px 8px 0; padding: 16px 20px; margin: 20px 0; }
.legal-page .highlight-box p { margin: 0; color: var(--stone-700); }
.legal-page .warning-box { background: #fef9ec; border: 0.5px solid #f0d898; border-left: 3px solid var(--copper); border-radius: 0 8px 8px 0; padding: 16px 20px; margin: 20px 0; }
.legal-page .warning-box p { margin: 0; color: var(--stone-700); }
.legal-page .contact-box { background: var(--white); border: 0.5px solid var(--stone-200); border-radius: 10px; padding: 24px; margin-top: 40px; }
.legal-page .contact-box h3 { margin-top: 0; }
.legal-page .contact-detail { font-family: var(--font-mono); font-size: 13px; color: var(--stone-700); margin-top: 8px; display: block; }

@media (max-width: 900px) { .steps-grid { grid-template-columns: 1fr 1fr; } .pricing-grid { grid-template-columns: 1fr; } .testimonial-grid { grid-template-columns: 1fr; } }
@media (max-width: 768px) {
  .hero-headline { font-size: 40px; } .section-title { font-size: 34px; } .cta-headline { font-size: 34px; }
  .tab-nav { flex-direction: column; } .tab-btn { border-right: none; border-bottom: 1px solid var(--stone-200); }
  .tab-content-wrap { padding: 24px; } .tab-stat-num { font-size: 32px; } .tab-threat-title { font-size: 24px; }
  .steps-grid { grid-template-columns: 1fr; }
  .rpt-header, .rpt-hotel-block, .rpt-intro { padding-left: 20px; padding-right: 20px; }
  .rpt-finding, .rpt-callout, .rpt-ledger-cta { margin-left: 12px; margin-right: 12px; }
  .ldg-stats { grid-template-columns: 1fr 1fr; }
  .ldg-entry-row { grid-template-columns: 1fr; gap: 12px; }
  .ldg-entry-date { text-align: left; margin-top:0; }
  .ldg-status-pill, .ldg-edit-select { width: max-content; }
}
@media (max-width: 600px) {
  .legal-page h1 { font-size: 30px; }
  .legal-page main { padding: 40px 20px 60px; }
  body.legal-page footer .footer-inner { flex-direction: column; text-align: center; }
}
