/* ThreatReady — legal & subpage shared styles */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
--primary:#6D28FF;--primary-hover:#5B1FE0;--primary-light:#C4B5FD;
--primary-subtle:#EDE4FF;--primary-whisper:#F3EEFF;
--bg:#fff;--bg-subtle:#F8F9FC;--bg-alt:#F3EEFF;--bg-dark:#0B1020;
--surface:#fff;--surface-2:#F8F9FC;
--nav-bg:rgba(255,255,255,.9);
--text:#0B1020;--text-2:#52525b;--text-3:#737383;
--border:#e7e5eb;--border-2:#f0eef3;
--success:#10b981;--warning:#f59e0b;--danger:#ef4444;
--shadow-sm:0 1px 2px rgba(15,10,26,.04);
--shadow-md:0 4px 16px rgba(15,10,26,.06);
--shadow-lg:0 16px 48px rgba(109, 40, 255,.12);
--glow:0 0 0 4px rgba(109, 40, 255,.12);
--r-sm:8px;--r-md:12px;--r-lg:20px;--r-full:999px;
--font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
--mono:'SF Mono',Monaco,Menlo,'Courier New',monospace;
}
:root[data-theme="dark"]{
--primary:#8b5cf6;--primary-hover:#C4B5FD;--primary-light:#C4B5FD;
--primary-subtle:rgba(139,92,246,.22);--primary-whisper:rgba(139,92,246,.08);
--bg:#0c0816;--bg-subtle:#120e1e;--bg-alt:#171224;
--surface:#1a1525;--surface-2:#221c30;
--nav-bg:rgba(12,8,22,.9);
--text:#ece9f4;--text-2:#a29fb0;--text-3:#7a7688;
--border:#2a2438;--border-2:#1e1a2c;
--shadow-sm:0 1px 2px rgba(0,0,0,.25);
--shadow-md:0 4px 16px rgba(0,0,0,.35);
--shadow-lg:0 16px 48px rgba(0,0,0,.45);
--glow:0 0 0 4px rgba(139,92,246,.2);
}
html{transition:background-color .2s ease,color .2s ease}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--font);font-size:16px;line-height:1.6;color:var(--text);background:var(--bg)}
a{color:var(--primary);text-decoration:none;transition:color .15s ease}
a:hover{color:var(--primary-hover);text-decoration:underline}
img,svg{display:block;max-width:100%}

/* Nav */
.lnav{position:sticky;top:0;z-index:50;background:var(--nav-bg);-webkit-border-bottom:1px solid var(--border-2)}
.lnav-c{max-width:1200px;margin:0 auto;padding:14px 24px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.125rem;color:var(--text);letter-spacing:-.02em}
.logo-t{display:inline-block}
.logo:hover{text-decoration:none}
.logo-i{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--primary) 0%,#8B5CF6 100%);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 2px 8px rgba(109, 40, 255,.3)}
.logo-i svg{width:18px;height:18px}
.logo .dot{color:var(--primary)}
.lnav a.back{font-size:.875rem;color:var(--text-2);font-weight:500;display:inline-flex;align-items:center;gap:6px}
.lnav a.back:hover{color:var(--primary);text-decoration:none}
.lnav a.back svg{width:14px;height:14px}

/* Header */
.lhead{background:linear-gradient(180deg,var(--bg-subtle) 0%,var(--bg) 100%);padding:56px 0 40px;border-bottom:1px solid var(--border-2)}
.lhead-c{max-width:1400px;margin:0 auto;padding:0 24px}
.lhead .eyebrow{font-size:.75rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--primary);margin-bottom:14px;display:inline-block}
.lhead h1{font-size:clamp(1.875rem,4vw,2.5rem);font-weight:700;letter-spacing:-.02em;line-height:1.15;color:var(--text);margin-bottom:14px}
.lhead .meta{font-size:.875rem;color:var(--text-3)}
.lhead .intro{font-size:1.05rem;color:var(--text-2);margin-top:16px;line-height:1.55}

/* Body */
.lbody{max-width:1400px;margin:0 auto;padding:48px 24px 64px}
.lbody h2{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;color:var(--text);margin:40px 0 12px;padding-top:8px}
.lbody h2:first-child{margin-top:0}
.lbody h3{font-size:1.125rem;font-weight:700;color:var(--text);margin:24px 0 8px}
.lbody p{margin-bottom:14px;color:var(--text-2);line-height:1.65}
.lbody strong{color:var(--text);font-weight:600}
.lbody ul,.lbody ol{margin:0 0 14px;padding-left:22px;color:var(--text-2)}
.lbody li{margin-bottom:8px;line-height:1.6}
.lbody table{width:100%;border-collapse:collapse;margin:16px 0;font-size:.9rem}
.lbody th,.lbody td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border-2);vertical-align:top}
.lbody thead th{background:var(--bg-subtle);color:var(--text);font-weight:600;font-size:.8125rem;text-transform:uppercase;letter-spacing:.05em}
.lbody code{background:var(--bg-alt);padding:2px 6px;border-radius:4px;font-family:var(--mono);font-size:.9em;color:var(--primary-hover)}
.lbody .callout{background:var(--primary-whisper);border-left:3px solid var(--primary);padding:14px 18px;border-radius:0 var(--r-sm) var(--r-sm) 0;margin:20px 0;color:var(--text)}
.lbody .callout strong{display:block;margin-bottom:4px;color:var(--primary);font-size:.8125rem;text-transform:uppercase;letter-spacing:.08em}
.lbody .muted{color:var(--text-3);font-size:.875rem}

/* Example blocks for rubric */
.lbody .example{border:1px solid var(--border);border-radius:var(--r-md);padding:20px;margin:16px 0;background:var(--bg-subtle)}
.lbody .example-label{font-size:.7rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}
.lbody .example-score{display:inline-block;padding:2px 10px;border-radius:var(--r-full);font-size:.75rem;font-weight:700;font-family:var(--mono);margin-left:8px}
.lbody .example-score.weak{background:#fef2f2;color:#dc2626}
.lbody .example-score.mid{background:#fef3c7;color:#d97706}
.lbody .example-score.strong{background:#ecfdf5;color:#059669}
.lbody .example p{margin-bottom:8px;font-size:.95rem}

/* Definitions table for DPA */
.lbody .deflist{margin:16px 0}
.lbody .deflist dt{font-weight:600;color:var(--text);margin-top:12px}
.lbody .deflist dd{color:var(--text-2);margin-left:0;padding-left:16px;border-left:2px solid var(--border-2);margin-bottom:8px}

/* TOC on desktop */
.ltoc{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:20px;margin-bottom:32px;font-size:.875rem}
.ltoc h4{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:10px}
.ltoc ol{list-style:decimal;padding-left:20px;color:var(--text-2);margin:0}
.ltoc li{margin-bottom:4px;line-height:1.4}
.ltoc a{color:var(--text-2)}
.ltoc a:hover{color:var(--primary)}

/* Buttons (shared) */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;font-size:.95rem;font-weight:600;border-radius:var(--r-full);transition:all .18s ease;white-space:nowrap;cursor:pointer;border:1.5px solid transparent}
.btn-lg{padding:16px 32px;font-size:1rem}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 14px rgba(109, 40, 255,.3)}
.btn-primary:hover{background:var(--primary-hover);color:#fff;text-decoration:none;transform:translateY(-1px);box-shadow:0 6px 20px rgba(109, 40, 255,.4)}
.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border);box-shadow:var(--shadow-sm)}
.btn-secondary:hover{border-color:var(--primary);color:var(--primary);text-decoration:none}
.btn svg{width:16px;height:16px}

/* Footer */
.lft{background:var(--bg-dark);color:rgba(255,255,255,.7);padding:48px 0 28px;margin-top:48px}
.lft-c{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}
.lft .logo{color:#fff}
.lft-l{display:flex;gap:24px;flex-wrap:wrap;list-style:none}
.lft-l a{color:rgba(255,255,255,.65);font-size:.875rem}
.lft-l a:hover{color:#fff;text-decoration:none}
.lft-bot{max-width:1200px;margin:28px auto 0;padding:16px 24px 0;border-top:1px solid rgba(255,255,255,.1);font-size:.8125rem;color:rgba(255,255,255,.5)}

/* Pilot page form */
.pilot-wrap{max-width:1400px;margin:0 auto;padding:48px 24px 72px}
.pilot-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:36px;box-shadow:var(--shadow-md)}
.pilot-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
@media (max-width:640px){.pilot-grid{grid-template-columns:1fr}}
.pilot-field{display:flex;flex-direction:column}
.pilot-field.full{grid-column:1/-1}
.pilot-field label{display:block;font-size:.8125rem;font-weight:600;color:var(--text);margin-bottom:6px}
.pilot-field label .req{color:var(--danger);margin-left:2px}
.pilot-field input[type=text],.pilot-field input[type=email],.pilot-field select,.pilot-field textarea{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-family:inherit;font-size:.95rem;color:var(--text);background:var(--surface);transition:border-color .15s ease}
.pilot-field input:focus,.pilot-field select:focus,.pilot-field textarea:focus{outline:none;border-color:var(--primary);box-shadow:var(--glow)}
.pilot-field textarea{min-height:100px;resize:vertical;line-height:1.5}
.pilot-roles{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:6px}
@media (max-width:640px){.pilot-roles{grid-template-columns:1fr}}
.pilot-roles label{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--text-2);font-weight:400;padding:8px 10px;border:1px solid var(--border);border-radius:var(--r-sm);cursor:pointer;transition:all .15s ease;margin:0}
.pilot-roles label:hover{border-color:var(--primary-light);background:var(--primary-whisper)}
.pilot-roles input[type=checkbox]{accent-color:var(--primary);width:16px;height:16px}
.pilot-note{font-size:.8125rem;color:var(--text-3);line-height:1.5;margin-top:14px}
.pilot-note a{font-weight:500}
.pilot-submit{margin-top:24px;width:100%;padding:14px}
.pilot-success{display:none;background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46;padding:18px 20px;border-radius:var(--r-md);margin-top:16px}
.pilot-success.show{display:block}
.pilot-success h3{font-size:1.05rem;font-weight:700;color:#065f46;margin-bottom:6px}
.pilot-success p{font-size:.875rem;color:#047857;line-height:1.5;margin:0}
.pilot-error{display:none;background:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:14px 18px;border-radius:var(--r-md);margin-top:16px;font-size:.875rem}
.pilot-error.show{display:block}
.honeypot{position:absolute;left:-9999px;opacity:0;pointer-events:none}

/* Rubric-specific */
.dim-card{border:1px solid var(--border);border-radius:var(--r-md);padding:20px;margin:16px 0;background:var(--surface)}
.dim-card-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.dim-card-h h3{margin:0;font-size:1.125rem}
.dim-weight{background:var(--primary-subtle);color:var(--primary);padding:3px 10px;border-radius:var(--r-full);font-size:.75rem;font-weight:700;font-family:var(--mono)}

/* Theme toggle (matches nav style) */
.theme-tog{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--text-2);transition:all .15s ease;border:none;background:none;cursor:pointer}
.theme-tog:hover{background:var(--primary-subtle);color:var(--primary);text-decoration:none}
.theme-tog svg{width:18px;height:18px}
.theme-tog .sun-i{display:none}
:root[data-theme="dark"] .theme-tog .moon-i{display:none}
:root[data-theme="dark"] .theme-tog .sun-i{display:block}
.lnav-r{display:flex;align-items:center;gap:8px}

/* Product-of-Aerovant strip in footers */
.aprod{max-width:1200px;margin:24px auto 0;padding:14px 24px;display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.08)}
.aprod span{font-size:.7rem;font-weight:600;letter-spacing:.2em;color:rgba(255,255,255,.5);text-transform:uppercase}
.aprod a{display:inline-flex;align-items:center;gap:6px;color:#fff;font-weight:700;font-size:.875rem;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;transition:color .15s ease}
.aprod a:hover{color:var(--primary-light);text-decoration:none}
.aprod a svg{width:12px;height:12px;opacity:.7}

/* Brand stack — ThreatReady + 'By AEROVANT TECHNOLOGIES' under logo */
.brand-stack{display:inline-flex;flex-direction:column;gap:1px;align-items:flex-start;line-height:1}
.brand-stack .logo{margin:0;line-height:1.2}
.brand-tag{font-size:.6875rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);text-decoration:none;display:inline-block;padding-left:42px;transition:color .15s ease;line-height:1.1;margin-top:1px;white-space:nowrap}
.brand-tag:hover{color:var(--primary);text-decoration:none}
.brand-tag-pre{color:var(--text-3);font-weight:500;letter-spacing:.1em;margin-right:3px;text-transform:none;font-size:.85em}
.brand-tag:hover .brand-tag-pre{color:var(--primary-light)}
/* Ensure nav bar centers both sides vertically */
.lnav-c{align-items:center;min-height:60px}
@media (max-width:480px){.brand-tag{padding-left:0;font-size:.625rem;letter-spacing:.1em}}

/* ============================================================
   Round 3 — colourful illustrated hero + visual upgrades
   ============================================================ */

/* Two-column hero with topic illustration */
.lhero{
  position:relative;
  overflow:hidden;
  padding:64px 0 56px;
  border-bottom:1px solid var(--border-2);
  background:
    radial-gradient(ellipse 80% 60% at 90% 0%, rgba(109, 40, 255,.12), transparent 60%),
    radial-gradient(ellipse 60% 80% at 10% 100%, rgba(168,85,247,.08), transparent 60%),
    linear-gradient(180deg, var(--bg-subtle) 0%, var(--bg) 100%);
}
.lhero::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 1px 1px, rgba(109, 40, 255,.08) 1px, transparent 0);
  background-size:24px 24px;
  opacity:.4;pointer-events:none;
}
.lhero-c{
  position:relative;z-index:1;
  max-width:1200px;margin:0 auto;padding:0 24px;
  display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:center;
}
.lhero-l{max-width:900px}
.lhero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;background:var(--primary-subtle);
  border-radius:999px;
  font-size:.75rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--primary);margin-bottom:18px;
}
.lhero-eyebrow svg{width:13px;height:13px}
.lhero h1{
  font-size:clamp(2rem,4.5vw,2.75rem);font-weight:800;
  letter-spacing:-.025em;line-height:1.08;color:var(--text);margin-bottom:14px;
}
.lhero h1 .accent{ color: #6D28FF; background: none; -webkit-text-fill-color: currentColor; }
.lhero .meta{
  font-size:.875rem;color:var(--text-3);
  display:inline-flex;align-items:center;gap:8px;
  padding:4px 12px;background:var(--surface);border:1px solid var(--border);
  border-radius:999px;margin-top:4px;
}
.lhero .meta::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--success);box-shadow:0 0 0 3px rgba(16,185,129,.18);
}
.lhero .intro{
  font-size:1.0625rem;color:var(--text-2);
  margin-top:18px;line-height:1.6;
}
.lhero .intro a{font-weight:600}
.lhero-r{position:relative;display:flex;align-items:center;justify-content:center}
.lhero-art{
  width:100%;max-width:380px;height:auto;
  filter:drop-shadow(0 24px 48px rgba(109, 40, 255,.18));
}
@media(max-width:900px){
  .lhero{padding:48px 0 40px}
  .lhero-c{grid-template-columns:1fr;gap:32px}
  .lhero-r{order:-1}
  .lhero-art{max-width:240px;margin:0 auto}
}

/* Trust badges row */
.lhero-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.lhero-badge{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 14px;background:var(--surface);
  border:1px solid var(--border);border-radius:999px;
  font-size:.8125rem;font-weight:500;color:var(--text-2);
  box-shadow:var(--shadow-sm);
  transition:all .18s ease;
}
.lhero-badge:hover{
  border-color:var(--primary-light);
  color:var(--primary);
  transform:translateY(-1px);
  box-shadow:var(--shadow-md);
}
.lhero-badge svg{width:14px;height:14px;color:var(--primary);flex-shrink:0}

/* Color-coded callouts */
.lbody .callout-info{background:var(--primary-whisper);border-left-color:var(--primary)}
.lbody .callout-info strong{color:var(--primary)}
.lbody .callout-success{background:#ecfdf5;border-left-color:var(--success)}
.lbody .callout-success strong{color:#059669}
.lbody .callout-warning{background:#fffbeb;border-left-color:var(--warning)}
.lbody .callout-warning strong{color:#d97706}
:root[data-theme="dark"] .lbody .callout-success{background:rgba(16,185,129,.10);border-left-color:#10b981}
:root[data-theme="dark"] .lbody .callout-success strong{color:#34d399}
:root[data-theme="dark"] .lbody .callout-warning{background:rgba(245,158,11,.10);border-left-color:#f59e0b}
:root[data-theme="dark"] .lbody .callout-warning strong{color:#fbbf24}

/* Section header with decorative icon */
.lbody .section-h{
  display:flex;align-items:center;gap:12px;
  margin:44px 0 14px;padding-top:8px;
}
.lbody .section-h-ic{
  width:34px;height:34px;border-radius:9px;flex-shrink:0;
  background:linear-gradient(135deg,var(--primary) 0%,#8B5CF6 100%);
  color:#fff;display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 6px 14px rgba(109, 40, 255,.25);
}
.lbody .section-h-ic svg{width:18px;height:18px}
.lbody .section-h h2{margin:0;padding:0}

/* Highlight cards (key feature blocks) */
.lbody .hicards{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:16px;margin:24px 0 28px;
}
.lbody .hicard{
  padding:20px;border-radius:14px;
  background:var(--surface);border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
  transition:all .2s ease;
}
.lbody .hicard:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
  border-color:var(--primary-light);
}
.lbody .hicard-ic{
  width:38px;height:38px;border-radius:10px;
  display:inline-flex;align-items:center;justify-content:center;
  margin-bottom:10px;color:#fff;
}
.lbody .hicard h4{
  font-size:.9375rem;font-weight:700;color:var(--text);
  margin:0 0 4px;letter-spacing:-.005em;
}
.lbody .hicard p{
  font-size:.8125rem;color:var(--text-2);line-height:1.55;margin:0;
}



/* ============================================================
   FINAL — Obsidian White + Royal Amethyst (clean, no overrides)
   - Light mode: Obsidian White background, Royal Amethyst accents
   - Dark mode: deep purple-black with lighter Royal Amethyst
   - Full-width layout (no narrow side margins)
   - Better reading typography
   ============================================================ */

/* LIGHT MODE BODY — soft Obsidian White with subtle lavender hints */
body{
  font-size: 17px;
  background: #FFFFFF;
  min-height: 100vh;
  color: var(--text);
}

/* DARK MODE BODY — rich deep purple-black */
:root[data-theme="dark"] body{
  background:
    radial-gradient(ellipse 70% 50% at 15% 0%, rgba(139, 92, 246, 0.18), transparent 55%),
    radial-gradient(ellipse 60% 50% at 85% 100%, rgba(196, 181, 253, 0.06), transparent 55%),
    linear-gradient(180deg, #0c0816 0%, #120e1e 100%);
  background-attachment: fixed;
}

/* HERO — light gradient with subtle purple radial in light mode */
.lhero{
  background:
    radial-gradient(ellipse 80% 60% at 90% 0%, rgba(109, 40, 255, 0.10), transparent 55%),
    radial-gradient(ellipse 60% 80% at 10% 100%, rgba(196, 181, 253, 0.16), transparent 55%);
  border-bottom: 1px solid var(--border-2);
}
.lhero::before{
  background-image: radial-gradient(circle at 1px 1px, rgba(109, 40, 255, 0.06) 1px, transparent 0);
  opacity: 0.4;
}

/* HERO h1 accent — Royal Amethyst gradient */
.lhero h1 .accent{ color: #6D28FF; background: none; -webkit-text-fill-color: currentColor; }

/* DARK MODE HERO */
:root[data-theme="dark"] .lhero{
  background:
    radial-gradient(ellipse 80% 60% at 90% 0%, rgba(139, 92, 246, 0.20), transparent 55%),
    radial-gradient(ellipse 60% 80% at 10% 100%, rgba(196, 181, 253, 0.10), transparent 55%);
  border-bottom: 1px solid var(--border-2);
}
:root[data-theme="dark"] .lhero h1 .accent{ color: #C4B5FD; background: none; -webkit-text-fill-color: currentColor; }

/* FULL-WIDTH LAYOUT — content fills the viewport, no narrow side margins */
.lnav-c{
  max-width: none;
  padding: 14px clamp(20px, 4vw, 56px);
}
.lhero-c{
  max-width: none;
  padding: 0 clamp(24px, 4vw, 64px);
  gap: 48px;
}
.lhero-l{ max-width: 1100px; }

.lbody{
  max-width: none;
  margin: 32px 0;
  padding: 48px clamp(24px, 5vw, 72px) 56px;
  border-radius: 0;
  border-left: none;
  border-right: none;
  background: var(--surface);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  box-shadow: 0 4px 24px rgba(11, 16, 32, 0.04);
}
:root[data-theme="dark"] .lbody{
  background: var(--surface);
  box-shadow: 0 4px 28px rgba(0, 0, 0, 0.30);
}

/* Inner content stays readable inside full-width card */
.lbody > *{
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}
.lbody > h2:first-child{ margin-top: 0; }

.lclose{
  max-width: none;
  margin: 0 0 40px;
  padding: 22px clamp(24px, 4vw, 56px) 0;
}

/* Footer also full-width */
.lft-c{ max-width: none; padding: 0 clamp(24px, 4vw, 56px); }
.lft-bot{ max-width: none; padding: 16px clamp(24px, 4vw, 56px) 0; }
.aprod{ max-width: none; padding: 14px clamp(24px, 4vw, 56px); }

/* Responsive — slightly tighter on small screens */
@media (max-width: 720px){
  .lbody{ margin: 20px 0; padding: 32px 20px; }
  .lhero-c{ gap: 32px; }
}

/* TYPOGRAPHY — comfortable reading */
.lbody p{ font-size: 1.0625rem; line-height: 1.75; margin-bottom: 16px; }
.lbody li{ font-size: 1.0625rem; line-height: 1.7; margin-bottom: 10px; }
.lbody h2{ font-size: 1.625rem; margin: 44px 0 14px; letter-spacing: -0.018em; }
.lbody h2:first-child{ margin-top: 0; }
.lbody h3{ font-size: 1.1875rem; margin: 28px 0 10px; }
.lbody table{ font-size: 1rem; }
.lbody table th, .lbody table td{ padding: 12px 14px; }
.lbody .callout{ font-size: 1.0625rem; line-height: 1.7; padding: 16px 20px; margin: 24px 0; border-left-width: 4px; }
.lhero .intro{ font-size: 1.125rem; line-height: 1.65; }
.lhero h1{ font-size: clamp(2.125rem, 4.5vw, 2.875rem); }

/* DARK MODE — ensure body content text colors flip correctly */
:root[data-theme="dark"] .lbody p,
:root[data-theme="dark"] .lbody li{ color: var(--text-2); }
:root[data-theme="dark"] .lbody h2,
:root[data-theme="dark"] .lbody h3,
:root[data-theme="dark"] .lbody strong{ color: var(--text); }

/* Code blocks — light in light mode, dark in dark mode */
.lbody code{
  background: var(--primary-whisper);
  color: var(--primary-hover);
  padding: 2px 6px;
  border-radius: 4px;
  font-family: var(--mono);
  font-size: 0.9em;
}
:root[data-theme="dark"] .lbody code{
  background: rgba(196, 181, 253, 0.10);
  color: #C4B5FD;
}

/* CALLOUTS — work in both modes */
.lbody .callout,
.lbody .callout-info{
  background: var(--primary-whisper);
  border-left-color: var(--primary);
}
.lbody .callout strong,
.lbody .callout-info strong{ color: var(--primary); }
.lbody .callout-success{ background: rgba(16, 185, 129, 0.08); border-left-color: #10b981; }
.lbody .callout-success strong{ color: #059669; }
.lbody .callout-warning{ background: rgba(245, 158, 11, 0.10); border-left-color: #f59e0b; }
.lbody .callout-warning strong{ color: #d97706; }

:root[data-theme="dark"] .lbody .callout,
:root[data-theme="dark"] .lbody .callout-info{
  background: rgba(139, 92, 246, 0.12);
  border-left-color: #8B5CF6;
}
:root[data-theme="dark"] .lbody .callout strong{ color: #C4B5FD; }
:root[data-theme="dark"] .lbody .callout-success{ background: rgba(16, 185, 129, 0.12); }
:root[data-theme="dark"] .lbody .callout-success strong{ color: #34d399; }
:root[data-theme="dark"] .lbody .callout-warning{ background: rgba(245, 158, 11, 0.12); }
:root[data-theme="dark"] .lbody .callout-warning strong{ color: #fbbf24; }

/* Section icon tile — Royal Amethyst gradient */
.lbody .section-h-ic{
  background: #6D28FF;
  box-shadow: 0 6px 14px rgba(109, 40, 255, 0.25);
}

/* Cards inside body — light/dark aware */
.lbody .hicard,
.ltoc,
.dim-card,
.lbody .example{
  background: var(--surface-2);
  border-color: var(--border);
}

/* Tables */
.lbody table th, .lbody table td{ border-bottom-color: var(--border-2); color: var(--text-2); }
.lbody thead th{ background: var(--surface-2); color: var(--text); }

/* Definitions */
.lbody .deflist dt{ color: var(--text); }
.lbody .deflist dd{ color: var(--text-2); border-left-color: var(--border-2); }

/* Sample-report banner — Royal Amethyst gradient */
.rbanner{
  background: #6D28FF;
}

/* Logo brand mark — Royal Amethyst */
.logo-i{
  background: #6D28FF;
  box-shadow: 0 2px 10px rgba(109, 40, 255, 0.30);
}

/* Body links */
.lbody a{ color: var(--primary); }
.lbody a:hover{ color: var(--primary-hover); }

/* Hero badges — light/dark aware */
.lhero-badge{
  background: var(--surface);
  border-color: var(--border);
  color: var(--text-2);
  box-shadow: var(--shadow-sm);
}
.lhero-badge:hover{
  border-color: var(--primary);
  color: var(--primary);
  background: var(--primary-whisper);
  transform: translateY(-1px);
}
.lhero-badge svg{ color: var(--primary); }

/* Hero meta */
.lhero .meta{
  background: var(--surface);
  border-color: var(--border);
  color: var(--text-2);
}

/* Hero eyebrow */
.lhero-eyebrow{
  background: var(--primary-subtle);
  color: var(--primary);
}
.lhero-eyebrow svg{ color: var(--primary); }

/* Sample report — make sure it works in both modes */
.rhead, .rsec, .rtimeline, .rcandid-card, .rscoreboard,
.rqcard, .rqa, .rqa-row, .rfeedback, .rrec, .rinteg,
.rmeta-card, .rdims-card, .rdim, .rbar-card{
  background: var(--surface);
  border-color: var(--border);
}
.rhead-top, .rcandid-id, .rmeta-cell{
  background: var(--surface-2);
  border-color: var(--border-2);
  color: var(--text-2);
}
.rmeta-cell .l{ color: var(--text-3); }
.rmeta-cell .v{ color: var(--text); }
.rcname, .rqcard h3, .rsec h2, .rover-score{ color: var(--text); }
.rcmeta, .rqcard p{ color: var(--text-2); }
.rbar-l{ color: var(--text); }
.rbar-l small{ color: var(--text-3); }
.rbar-t{ background: var(--primary-whisper); }
.rbar-v{ color: var(--text); }
.roverall{ background: var(--surface-2); }
.rover-label{ color: var(--text-3); }
.rlogo-org{ background: var(--surface-2); border-color: var(--border-2); }
.rlogo-org-t strong{ color: var(--text); }
.rlogo-org-t span{ color: var(--text-3); }

/* Theme toggle visible and styled */
.theme-tog{ color: var(--text-2); }
.theme-tog:hover{ background: var(--primary-subtle); color: var(--primary); }



/* ============================================================
   PROFESSIONAL TOUCHES (per design guidelines)
   - Smooth gradients instead of solid dark
   - Soft purple-tinted shadows on cards
   - Rounded corners refined
   - 3-color palette: Purple + White + Soft Lavender + Indigo accent
   ============================================================ */

/* FOOTER — replace solid dark with smooth indigo-purple gradient */
.lft{
  background: linear-gradient(135deg, #6D28FF 0%, #5B1FE0 100%) !important;
  position: relative;
  overflow: hidden;
}
.lft::before{
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 40% at 80% 20%, rgba(196, 181, 253, 0.18), transparent 60%),
    radial-gradient(ellipse 50% 50% at 10% 90%, rgba(109, 40, 255, 0.20), transparent 60%);
  pointer-events: none;
}
.lft > *{ position: relative; z-index: 1; }

/* Footer text uses lavender-tinted whites */
.lft .logo{ color: #FFFFFF; }
.lft-l a{ color: rgba(237, 228, 255, 0.78); transition: color 0.15s; }
.lft-l a:hover{ color: #FFFFFF; }
.lft-bot{ border-top: 1px solid rgba(237, 228, 255, 0.18); color: rgba(237, 228, 255, 0.6); }
.aprod{ border-top: 1px solid rgba(237, 228, 255, 0.12); }
.aprod span{ color: rgba(237, 228, 255, 0.55); }
.aprod a{ color: #FFFFFF; }
.aprod a:hover{ color: #C4B5FD; }

/* CARDS — soft purple-tinted shadows + refined rounded corners */
.lbody,
.rhead, .rsec, .rqcard, .rqa, .rfeedback, .rtimeline,
.rcandid-card, .rscoreboard, .rmeta-card, .rdims-card,
.rdim, .rbar-card, .rrec, .rinteg{
  border-radius: 16px;
  box-shadow:
    0 1px 2px rgba(11, 16, 32, 0.04),
    0 8px 24px rgba(109, 40, 255, 0.06) !important;
  transition: box-shadow 0.2s ease;
}

.lbody:hover,
.rhead:hover, .rsec:hover, .rqcard:hover{
  box-shadow:
    0 1px 2px rgba(11, 16, 32, 0.04),
    0 12px 36px rgba(109, 40, 255, 0.10) !important;
}

/* Dark mode card shadows */
:root[data-theme="dark"] .lbody,
:root[data-theme="dark"] .rhead,
:root[data-theme="dark"] .rsec,
:root[data-theme="dark"] .rqcard,
:root[data-theme="dark"] .rqa,
:root[data-theme="dark"] .rfeedback{
  box-shadow:
    0 1px 2px rgba(0, 0, 0, 0.35),
    0 8px 28px rgba(0, 0, 0, 0.40) !important;
}

/* Inner cards — slightly tighter rounded corners */
.lbody .hicard, .ltoc, .dim-card, .lbody .example,
.rmeta-cell, .rcandid-id, .rhead-top{
  border-radius: 12px;
}

/* HERO H1 — multi-color gradient (Royal Amethyst + Indigo + Soft Lavender) */
.lhero h1 .accent{ color: #6D28FF; background: none; -webkit-text-fill-color: currentColor; }

/* BUTTONS — Royal Amethyst → Indigo gradient with soft glow */
.btn-primary, .pilot-submit{
  background: #6D28FF !important;
  color: #fff !important;
  border: none !important;
  border-radius: 12px !important;
  padding: 12px 24px !important;
  font-weight: 600 !important;
  box-shadow:
    0 4px 14px rgba(109, 40, 255, 0.30),
    0 1px 0 rgba(255, 255, 255, 0.2) inset !important;
  transition: all 0.2s ease !important;
}

.btn-primary:hover, .pilot-submit:hover{
  background: #5B1FE0 !important;
  transform: translateY(-1px) !important;
  box-shadow:
    0 8px 24px rgba(109, 40, 255, 0.40),
    0 1px 0 rgba(255, 255, 255, 0.2) inset !important;
}

/* SECTION DIVIDERS — subtle gradient line instead of solid border */
.lbody h2{
  position: relative;
  padding-bottom: 12px;
}
.lbody h2::after{
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 48px;
  height: 3px;
  background: #6D28FF;
  border-radius: 2px;
}
:root[data-theme="dark"] .lbody h2::after{
  background: #C4B5FD;
}

/* HERO BADGES — pill shape, soft lavender background, purple text */
.lhero-badge{
  background: #FFFFFF !important;
  border: 1px solid #EDE4FF !important;
  border-radius: 999px !important;
  padding: 8px 16px !important;
  color: #6D28FF !important;
  font-weight: 500 !important;
  box-shadow: 0 2px 8px rgba(109, 40, 255, 0.06) !important;
}

.lhero-badge:hover{
  border-color: #6D28FF !important;
  color: #6D28FF !important;
  background: #F3EEFF !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 12px rgba(109, 40, 255, 0.12) !important;
}

:root[data-theme="dark"] .lhero-badge{
  background: rgba(46, 28, 65, 0.40) !important;
  border-color: rgba(196, 181, 253, 0.20) !important;
  color: #C4B5FD !important;
}

/* HERO EYEBROW — refined pill with gradient */
.lhero-eyebrow{
  background: #EDE4FF !important;
  color: #6D28FF !important;
  border: 1px solid rgba(109, 40, 255, 0.12) !important;
  padding: 6px 14px !important;
  border-radius: 999px !important;
  box-shadow: 0 2px 6px rgba(109, 40, 255, 0.08) !important;
}

:root[data-theme="dark"] .lhero-eyebrow{
  background: rgba(139, 92, 246, 0.18) !important;
  color: #C4B5FD !important;
  border-color: rgba(196, 181, 253, 0.20) !important;
}

/* META PILL on hero */
.lhero .meta{
  background: #FFFFFF !important;
  border: 1px solid #E7E5EB !important;
  border-radius: 999px !important;
  padding: 6px 14px !important;
  box-shadow: 0 1px 3px rgba(11, 16, 32, 0.04) !important;
}

/* SAMPLE REPORT BANNER — gradient with shimmer */
.rbanner{
  background: #6D28FF !important;
  position: relative;
  overflow: hidden;
}
.rbanner::after{
  content: '';
  position: absolute;
  top: 0;
  right: -10%;
  width: 50%;
  height: 100%;
  background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.10) 50%, transparent 100%);
  pointer-events: none;
}

/* SECTION ICON TILES — gradient backgrounds */
.lbody .section-h-ic{
  background: #6D28FF !important;
  box-shadow: 0 6px 16px rgba(109, 40, 255, 0.30) !important;
  border-radius: 12px !important;
}

/* PILOT REASSURE BOXES — refined cards */
.pilot-rbox{
  background: #FFFFFF !important;
  border: 1px solid #EDE4FF !important;
  border-radius: 14px !important;
  box-shadow: 0 4px 16px rgba(109, 40, 255, 0.06) !important;
  transition: all 0.2s ease;
}
.pilot-rbox:hover{
  border-color: rgba(109, 40, 255, 0.20) !important;
  box-shadow: 0 8px 24px rgba(109, 40, 255, 0.12) !important;
  transform: translateY(-2px);
}
.pilot-rbox svg{
  background: #EDE4FF !important;
  color: #6D28FF !important;
  padding: 8px !important;
  border-radius: 10px !important;
  width: 36px !important;
  height: 36px !important;
  margin-bottom: 12px !important;
}

/* FORM INPUTS — clean with purple focus */
.pilot-field input,
.pilot-field select,
.pilot-field textarea{
  background: #FFFFFF !important;
  border: 1px solid #E7E5EB !important;
  border-radius: 10px !important;
  padding: 10px 14px !important;
  transition: all 0.15s ease;
}
.pilot-field input:focus,
.pilot-field select:focus,
.pilot-field textarea:focus{
  border-color: #6D28FF !important;
  box-shadow: 0 0 0 4px rgba(109, 40, 255, 0.10) !important;
  outline: none !important;
}

/* PILOT NEXT-STEPS box */
.pilot-next{
  background: #F3EEFF !important;
  border: 1px solid #EDE4FF !important;
  border-radius: 14px !important;
  box-shadow: 0 4px 16px rgba(109, 40, 255, 0.06) !important;
}
.pilot-next h4{
  color: #6D28FF !important;
}


/* TABLES — purple themed */
.lbody table{
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  margin: 20px 0;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(11, 16, 32, 0.04), 0 4px 16px rgba(109, 40, 255, 0.06);
  border: 1px solid #EDE4FF;
}
.lbody table thead th{
  background: #6D28FF !important;
  color: #FFFFFF !important;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.8125rem;
  padding: 14px 18px;
  text-align: left;
  border-bottom: none;
}
.lbody table tbody tr{
  background: #FFFFFF;
  transition: background 0.15s ease;
}
.lbody table tbody tr:nth-child(even){
  background: #F8F9FC;
}
.lbody table tbody tr:hover{
  background: #F3EEFF;
}
.lbody table td{
  padding: 14px 18px;
  border-bottom: 1px solid #EDE4FF !important;
  color: #0B1020;
  font-size: 0.9375rem;
}
.lbody table tbody tr:last-child td{
  border-bottom: none !important;
}
.lbody table tbody tr td:first-child{
  font-weight: 500;
  color: #6D28FF;
}

/* Dark mode tables */
:root[data-theme="dark"] .lbody table{
  border-color: rgba(196, 181, 253, 0.15);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3), 0 4px 16px rgba(0, 0, 0, 0.4);
}
:root[data-theme="dark"] .lbody table tbody tr{
  background: var(--surface);
}
:root[data-theme="dark"] .lbody table tbody tr:nth-child(even){
  background: var(--surface-2);
}
:root[data-theme="dark"] .lbody table tbody tr:hover{
  background: rgba(139, 92, 246, 0.10);
}
:root[data-theme="dark"] .lbody table td{
  color: var(--text-2);
  border-bottom-color: var(--border-2) !important;
}
:root[data-theme="dark"] .lbody table tbody tr td:first-child{
  color: #C4B5FD;
}


/* LIGHTNING BOLT LOGO — transparent, no background container, aligned with text */
.logo{
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
}
.logo-i{
  background: transparent !important;
  box-shadow: none !important;
  width: 26px !important;
  height: 26px !important;
  border-radius: 0 !important;
  padding: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0;
}
.logo-i svg, .logo-i img{
  width: 100% !important;
  height: 100% !important;
  object-fit: contain;
  display: block;
}
.logo-t{
  line-height: 1 !important;
}

/* Footer logo — slightly larger, same alignment */
.lft .logo-i{
  width: 30px !important;
  height: 30px !important;
}

/* ============================================================
   PRIVACY-STYLE LAYOUT — 2-column TOC sidebar + numbered sections
   ============================================================ */

/* 2-column body layout: sticky TOC sidebar + main content */
.lbody-grid{
  display: grid !important;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 56px;
  max-width: 1320px !important;
  margin: 32px auto !important;
  padding: 48px clamp(24px, 4vw, 56px) !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

.lbody-grid > *{
  max-width: none !important;
  margin: 0 !important;
}

@media (max-width: 980px){
  .lbody-grid{
    grid-template-columns: 1fr;
    gap: 24px;
  }
}

/* Sidebar — sticky on scroll */
.lbody-side{
  position: relative;
}

.ltoc-sticky{
  position: sticky;
  top: 88px;
  background: transparent;
  padding: 0;
}

.ltoc-sticky h4{
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #6B7280;
  margin: 0 0 16px 0;
  padding: 0 14px;
}

.ltoc-sticky ol.toc-list{
  list-style: none;
  margin: 0;
  padding: 0;
}

.ltoc-sticky ol.toc-list li{
  margin: 0;
  padding: 0;
}

.ltoc-sticky ol.toc-list a{
  display: flex;
  align-items: baseline;
  gap: 8px;
  padding: 10px 14px;
  border-left: 3px solid transparent;
  font-size: 0.9375rem;
  color: #4B5563;
  text-decoration: none;
  line-height: 1.4;
  transition: all 0.15s ease;
  font-weight: 400;
}

.ltoc-sticky ol.toc-list a:hover{
  color: #6D28FF;
  background: rgba(109, 40, 255, 0.04);
  border-left-color: rgba(109, 40, 255, 0.20);
}

.ltoc-sticky ol.toc-list a.active,
.ltoc-sticky ol.toc-list a.is-active{
  background: #EDE4FF;
  color: #6D28FF;
  border-left-color: #6D28FF;
  font-weight: 600;
}

.ltoc-sticky .toc-num{
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
  min-width: 22px;
}

/* Dark mode TOC */
:root[data-theme="dark"] .ltoc-sticky h4{ color: var(--text-3); }
:root[data-theme="dark"] .ltoc-sticky ol.toc-list a{ color: var(--text-2); }
:root[data-theme="dark"] .ltoc-sticky ol.toc-list a:hover{
  color: #C4B5FD;
  background: rgba(139, 92, 246, 0.10);
  border-left-color: rgba(196, 181, 253, 0.30);
}
:root[data-theme="dark"] .ltoc-sticky ol.toc-list a.active,
:root[data-theme="dark"] .ltoc-sticky ol.toc-list a.is-active{
  background: rgba(139, 92, 246, 0.18);
  color: #C4B5FD;
  border-left-color: #C4B5FD;
}

/* Numbered section headings — purple square badge */
.num-h2{
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  margin: 56px 0 18px 0 !important;
  padding-bottom: 0 !important;
  font-size: 1.625rem !important;
  font-weight: 700;
  color: #0B1020;
  scroll-margin-top: 96px;
}

.num-h2:first-child{ margin-top: 0 !important; }

.num-h2::after{
  display: none !important;
}

.num-badge{
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: #6D28FF;
  color: #FFFFFF;
  border-radius: 8px;
  font-size: 1rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(109, 40, 255, 0.20);
  line-height: 1;
}

.num-title{
  display: inline-block;
  position: relative;
  padding-bottom: 8px;
}

.num-title::after{
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 32px;
  height: 2px;
  background: #6D28FF;
  border-radius: 2px;
}

:root[data-theme="dark"] .num-h2{ color: var(--text); }
:root[data-theme="dark"] .num-badge{
  background: #8B5CF6;
  box-shadow: 0 4px 12px rgba(139, 92, 246, 0.30);
}
:root[data-theme="dark"] .num-title::after{ background: #C4B5FD; }

/* Body content holder — contains all the section text */
.lbody-content{
  background: #FFFFFF;
  border: 1px solid #E5E7EB;
  border-radius: 16px;
  padding: 40px 48px;
  box-shadow: 0 1px 3px rgba(11, 16, 32, 0.04), 0 8px 24px rgba(109, 40, 255, 0.04);
}

:root[data-theme="dark"] .lbody-content{
  background: var(--surface);
  border-color: var(--border);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.30), 0 8px 24px rgba(0, 0, 0, 0.40);
}

@media (max-width: 720px){
  .lbody-content{ padding: 28px 22px; }
  .num-badge{ width: 30px; height: 30px; font-size: 0.875rem; }
  .num-h2{ font-size: 1.375rem !important; gap: 10px !important; }
}

/* Company info card (used in section 1) */
.company-card{
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 22px 26px;
  background: linear-gradient(135deg, #F8F6FF 0%, #F3EEFF 100%);
  border: 1px solid #EDE4FF;
  border-radius: 14px;
  margin: 24px 0;
}

.company-avatar{
  width: 52px;
  height: 52px;
  background: linear-gradient(135deg, #EDE4FF 0%, #C4B5FD 100%);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #6D28FF;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(109, 40, 255, 0.15);
}

.company-avatar svg{
  width: 26px;
  height: 26px;
}

.company-info{ flex: 1; min-width: 0; }
.company-name{ font-weight: 700; font-size: 1.0625rem; color: #0B1020; margin-bottom: 2px; }
.company-meta{ font-size: 0.875rem; color: #6B7280; margin-bottom: 6px; }
.company-contact{ font-size: 0.875rem; color: #4B5563; }
.company-contact a{ color: #6D28FF; font-weight: 500; }

:root[data-theme="dark"] .company-card{
  background: rgba(139, 92, 246, 0.08);
  border-color: rgba(196, 181, 253, 0.20);
}
:root[data-theme="dark"] .company-name{ color: var(--text); }
:root[data-theme="dark"] .company-meta{ color: var(--text-3); }
:root[data-theme="dark"] .company-contact{ color: var(--text-2); }
:root[data-theme="dark"] .company-contact a{ color: #C4B5FD; }

@media (max-width: 600px){
  .company-card{ flex-direction: column; align-items: flex-start; gap: 12px; padding: 18px; }
}


/* ============================================================
   PREMIUM POLISH — distinguishes report pages from index page
   Subtle mesh background, gradient accents, refined cards
   ============================================================ */

/* Subtle purple mesh background — adds depth vs flat white */
body{
  background:
    radial-gradient(ellipse 50% 40% at 100% 0%, rgba(196, 181, 253, 0.14), transparent 55%),
    radial-gradient(ellipse 45% 35% at 0% 100%, rgba(109, 40, 255, 0.06), transparent 55%),
    radial-gradient(ellipse 30% 25% at 50% 50%, rgba(168, 85, 247, 0.03), transparent 55%),
    #FFFFFF !important;
  background-attachment: fixed !important;
}

:root[data-theme="dark"] body{
  background:
    radial-gradient(ellipse 50% 40% at 100% 0%, rgba(139, 92, 246, 0.18), transparent 55%),
    radial-gradient(ellipse 45% 35% at 0% 100%, rgba(196, 181, 253, 0.08), transparent 55%),
    linear-gradient(180deg, #0c0816 0%, #120e1e 100%) !important;
}

/* Numbered badges — gradient with depth + glow */
.num-badge{
  background: linear-gradient(135deg, #7C3AED 0%, #6D28FF 50%, #5B21B6 100%) !important;
  box-shadow:
    0 4px 14px rgba(109, 40, 255, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.20),
    inset 0 -1px 0 rgba(0, 0, 0, 0.10) !important;
  border-radius: 9px !important;
}

/* Title accent line — subtle gradient + slightly bolder */
.num-title::after{
  width: 40px !important;
  height: 2.5px !important;
  background: linear-gradient(90deg, #6D28FF 0%, #C4B5FD 100%) !important;
}

.lbody h2::after{
  width: 56px !important;
  height: 2.5px !important;
  background: linear-gradient(90deg, #6D28FF 0%, #C4B5FD 100%) !important;
}

/* Body content card — premium depth with inner highlight */
.lbody-content{
  background: #FFFFFF !important;
  border: 1px solid #EDE4FF !important;
  border-radius: 18px !important;
  box-shadow:
    0 1px 2px rgba(11, 16, 32, 0.03),
    0 16px 48px rgba(109, 40, 255, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.85) !important;
}

:root[data-theme="dark"] .lbody-content{
  background: rgba(26, 21, 37, 0.85) !important;
  border-color: rgba(196, 181, 253, 0.12) !important;
  box-shadow:
    0 1px 2px rgba(0, 0, 0, 0.30),
    0 16px 48px rgba(0, 0, 0, 0.45) !important;
}

/* TOC sidebar — refined active state */
.ltoc-sticky ol.toc-list a{
  border-radius: 0 !important;
  margin-bottom: 2px;
  transition: all 0.18s ease !important;
}

.ltoc-sticky ol.toc-list a.active,
.ltoc-sticky ol.toc-list a.is-active{
  background: linear-gradient(90deg, #EDE4FF 0%, rgba(243, 238, 255, 0.4) 100%) !important;
  border-left-color: #6D28FF !important;
  color: #5B21B6 !important;
  box-shadow: 0 1px 2px rgba(109, 40, 255, 0.08);
}

/* Hero eyebrow pill — refined */
.lhero-eyebrow{
  background: linear-gradient(135deg, #EDE4FF 0%, #F3EEFF 100%) !important;
  border: 1px solid rgba(109, 40, 255, 0.14) !important;
  box-shadow:
    0 2px 8px rgba(109, 40, 255, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.6) !important;
  font-weight: 700 !important;
}

/* Hero badges (pill row) — refined */
.lhero-badge{
  background: #FFFFFF !important;
  border: 1px solid #EDE4FF !important;
  box-shadow:
    0 1px 2px rgba(11, 16, 32, 0.03),
    0 4px 12px rgba(109, 40, 255, 0.05) !important;
  transition: all 0.18s ease !important;
}

.lhero-badge:hover{
  border-color: #C4B5FD !important;
  background: linear-gradient(135deg, #FFFFFF 0%, #F8F6FF 100%) !important;
  box-shadow:
    0 1px 2px rgba(11, 16, 32, 0.04),
    0 8px 20px rgba(109, 40, 255, 0.12) !important;
  transform: translateY(-1px);
}

/* Hero meta date pill */
.lhero .meta{
  background: #FFFFFF !important;
  border: 1px solid #EDE4FF !important;
  box-shadow:
    0 1px 2px rgba(11, 16, 32, 0.03),
    0 4px 12px rgba(109, 40, 255, 0.05) !important;
  font-weight: 500;
}

/* Tables — premium */
.lbody table{
  box-shadow:
    0 1px 2px rgba(11, 16, 32, 0.03),
    0 12px 32px rgba(109, 40, 255, 0.08) !important;
  border: 1px solid #EDE4FF !important;
}

.lbody table thead th{
  background: linear-gradient(135deg, #7C3AED 0%, #6D28FF 50%, #5B21B6 100%) !important;
  position: relative;
}

/* Section icon tile — gradient with glow */
.lbody .section-h-ic{
  background: linear-gradient(135deg, #7C3AED 0%, #6D28FF 100%) !important;
  box-shadow:
    0 6px 18px rgba(109, 40, 255, 0.30),
    inset 0 1px 0 rgba(255, 255, 255, 0.15) !important;
}

/* Buttons — premium gradient with depth */
.btn-primary,
.pilot-submit{
  background: linear-gradient(135deg, #7C3AED 0%, #6D28FF 100%) !important;
  box-shadow:
    0 4px 14px rgba(109, 40, 255, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.20) !important;
}

.btn-primary:hover,
.pilot-submit:hover{
  background: linear-gradient(135deg, #6D28FF 0%, #5B21B6 100%) !important;
  box-shadow:
    0 8px 24px rgba(109, 40, 255, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.20) !important;
}

/* Pilot reassure boxes — refined hover */
.pilot-rbox{
  border-radius: 14px !important;
  box-shadow:
    0 1px 2px rgba(11, 16, 32, 0.03),
    0 4px 16px rgba(109, 40, 255, 0.05) !important;
  transition: all 0.20s ease !important;
}

.pilot-rbox:hover{
  border-color: #C4B5FD !important;
  box-shadow:
    0 1px 2px rgba(11, 16, 32, 0.04),
    0 12px 32px rgba(109, 40, 255, 0.14) !important;
  transform: translateY(-2px);
}

.pilot-rbox svg{
  background: linear-gradient(135deg, #C4B5FD 0%, #A78BFA 100%) !important;
  color: #FFFFFF !important;
  box-shadow:
    0 4px 12px rgba(109, 40, 255, 0.20),
    inset 0 1px 0 rgba(255, 255, 255, 0.20) !important;
}

/* Footer — refined gradient */
.lft{
  background: linear-gradient(135deg, #5B21B6 0%, #6D28FF 60%, #7C3AED 100%) !important;
  box-shadow: 0 -1px 0 rgba(196, 181, 253, 0.15) inset;
}

/* Company info card — premium gradient */
.company-card{
  background: linear-gradient(135deg, #FFFFFF 0%, #F8F6FF 50%, #F3EEFF 100%) !important;
  border: 1px solid #EDE4FF !important;
  box-shadow:
    0 1px 2px rgba(11, 16, 32, 0.03),
    0 8px 24px rgba(109, 40, 255, 0.06) !important;
}

.company-avatar{
  background: linear-gradient(135deg, #C4B5FD 0%, #A78BFA 100%) !important;
  color: #FFFFFF !important;
  box-shadow:
    0 4px 14px rgba(109, 40, 255, 0.20),
    inset 0 1px 0 rgba(255, 255, 255, 0.20) !important;
}

/* Refined typography on content */
.lbody-content h2,
.lbody h2{
  letter-spacing: -0.022em !important;
}

.lbody p, .lbody li{
  color: #4B5563 !important;
}

:root[data-theme="dark"] .lbody p,
:root[data-theme="dark"] .lbody li{
  color: var(--text-2) !important;
}


/* ============================================================
   FINAL — Header (transparent purple) + Footer (highlighted, centered)
   ============================================================ */

/* Nav — DARK purple theme (distinguishes report pages from light index page) */
.lnav{
  background: linear-gradient(135deg, #1A0F2E 0%, #2D1B4E 100%) !important;
  backdrop-filter: saturate(180%) blur(12px) !important;
  -webkit-backdrop-filter: saturate(180%) blur(12px) !important;
  border-bottom: 1px solid rgba(109, 40, 255, 0.30) !important;
  box-shadow: 0 1px 0 rgba(109, 40, 255, 0.10), 0 4px 16px rgba(11, 6, 23, 0.20) !important;
  position: relative;
  overflow: hidden;
}

.lnav::before{
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 50% 80% at 80% 50%, rgba(139, 92, 246, 0.18), transparent 60%);
  pointer-events: none;
}

.lnav > *{ position: relative; z-index: 1; }

/* Logo text and back link become light on dark nav */
.lnav .logo,
.lnav .logo-t,
.lnav .logo .dot{ color: #FFFFFF !important; }
.lnav a.back{ color: rgba(237, 228, 255, 0.78) !important; }
.lnav a.back:hover{ color: #FFFFFF !important; }
.lnav a.back svg{ color: rgba(237, 228, 255, 0.78); }
.theme-tog{ color: rgba(237, 228, 255, 0.78) !important; }
.theme-tog:hover{ background: rgba(196, 181, 253, 0.12) !important; color: #FFFFFF !important; }

/* Dark mode — slightly different shade so the toggle still feels distinct */
:root[data-theme="dark"] .lnav{
  background: linear-gradient(135deg, #0c0816 0%, #1a0f2e 100%) !important;
  border-bottom: 1px solid rgba(196, 181, 253, 0.20) !important;
}

/* Footer — already has gradient, but center everything inside */
.lft{
  text-align: center !important;
  padding: 56px 0 32px !important;
}

.lft-c{
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  gap: 24px !important;
}

.lft .logo{
  margin: 0 auto !important;
  justify-content: center !important;
}

.lft-l{
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 24px !important;
  margin: 0 auto !important;
}

.lft-bot{
  text-align: center !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  border-top: 1px solid rgba(237, 228, 255, 0.18) !important;
  margin: 28px auto 0 !important;
}

.aprod{
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
  flex-wrap: wrap !important;
}



/* ============================================================
   FIXED NAV — header stays at top while content scrolls
   ============================================================ */

.lnav{
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  z-index: 1000 !important;
  /* Strong glass / mirror effect - more transparent so you see content blurred through */
  background: linear-gradient(135deg, rgba(26, 15, 46, 0.65) 0%, rgba(45, 27, 78, 0.65) 100%) !important;
  backdrop-filter: saturate(200%) blur(28px) !important;
  -webkit-backdrop-filter: saturate(200%) blur(28px) !important;
  border-bottom: 1px solid rgba(196, 181, 253, 0.22) !important;
  box-shadow: 0 4px 24px rgba(11, 6, 23, 0.20), inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

:root[data-theme="dark"] .lnav{
  background: linear-gradient(135deg, rgba(12, 8, 22, 0.85) 0%, rgba(26, 15, 46, 0.85) 100%) !important;
  border-bottom: 1px solid rgba(196, 181, 253, 0.22) !important;
}

/* Body needs top padding so content doesn't hide under fixed nav */
body{
  padding-top: 72px !important;
}

@media (max-width: 720px){
  body{ padding-top: 64px !important; }
}


/* ============================================================
   FINAL — sample-report .lclose footer (centered + highlighted)
   ============================================================ */

.lclose{
  background: linear-gradient(135deg, #5B21B6 0%, #6D28FF 50%, #7C3AED 100%) !important;
  color: rgba(255, 255, 255, 0.85) !important;
  text-align: center !important;
  padding: 24px clamp(20px, 4vw, 56px) !important;
  margin: 32px 0 0 0 !important;
  max-width: none !important;
  font-size: 0.875rem !important;
  border-top: 1px solid rgba(196, 181, 253, 0.20) !important;
  position: relative;
  overflow: hidden;
}

.lclose::before{
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 80% at 80% 50%, rgba(196, 181, 253, 0.18), transparent 60%),
    radial-gradient(ellipse 50% 60% at 10% 50%, rgba(109, 40, 255, 0.20), transparent 60%);
  pointer-events: none;
}

.lclose > *{ position: relative; z-index: 1; }

.lclose a{
  color: #FFFFFF !important;
  text-decoration: underline !important;
  text-decoration-color: rgba(255, 255, 255, 0.4) !important;
  font-weight: 500;
}

.lclose a:hover{
  color: #C4B5FD !important;
  text-decoration-color: #C4B5FD !important;
}

@media (max-width: 720px){
  .lclose{ margin: 24px 0 0 0 !important; }
}

/* ============================================================
   ROUND 63 — Back-to-top floating button
   Invisible at top of page, fades + slides in once user has
   scrolled past 300px. Click smoothly scrolls to top.
   The button itself is injected by back-to-top.js — this CSS
   styles whatever element gets the .b2t class.
   ============================================================ */
.b2t{
  position:fixed;
  right:24px;
  bottom:24px;
  z-index:60;
  width:48px;
  height:48px;
  border:none;
  border-radius:50%;
  background:linear-gradient(135deg,var(--primary) 0%,#8B5CF6 100%);
  color:#fff;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  /* Hidden by default — fade + slide in when .visible is added */
  opacity:0;
  transform:translateY(16px);
  pointer-events:none;
  transition:opacity .25s ease, transform .25s ease, box-shadow .2s ease, background .2s ease;
  box-shadow:0 6px 20px -4px rgba(109,40,255,.45),
             0 2px 4px rgba(15,10,26,.1);
}
.b2t.visible{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.b2t:hover{
  background:linear-gradient(135deg,var(--primary-hover) 0%,#7c3aed 100%);
  box-shadow:0 10px 28px -4px rgba(109,40,255,.55),
             0 3px 6px rgba(15,10,26,.12);
  transform:translateY(-2px);
}
.b2t:focus-visible{
  outline:none;
  box-shadow:0 6px 20px -4px rgba(109,40,255,.45),
             0 0 0 4px rgba(109,40,255,.25);
}
.b2t:active{
  transform:translateY(0) scale(.96);
}
.b2t svg{
  width:22px;
  height:22px;
  stroke:currentColor;
}
/* Dark mode — slightly different shadow tint for contrast */
:root[data-theme="dark"] .b2t{
  box-shadow:0 6px 20px -4px rgba(139,92,246,.5),
             0 2px 4px rgba(0,0,0,.3);
}
:root[data-theme="dark"] .b2t:hover{
  box-shadow:0 10px 28px -4px rgba(139,92,246,.6),
             0 3px 6px rgba(0,0,0,.4);
}
/* Mobile — smaller button, tighter to edge */
@media (max-width:640px){
  .b2t{
    right:16px;
    bottom:16px;
    width:42px;
    height:42px;
  }
  .b2t svg{width:18px;height:18px}
}
/* Respect users who prefer reduced motion — no slide, just fade */
@media (prefers-reduced-motion:reduce){
  .b2t{transition:opacity .15s ease}
  .b2t,
  .b2t:hover,
  .b2t:active{transform:none}
}

/* ============================================================
   ROUND 64 — Restore old nav logo style (per user request)
   Bring back the pre-overlay format: larger "ThreatReady" text
   (1.75rem / 28px) and CSS-painted logo using the logo.png /
   logo-dark.png background-image (no <img> tag inside the span).
   Sits at the end of the file so it overrides every earlier
   .logo / .logo-i / .logo-t rule including the line 893+ block.
   ============================================================ */
:root{--logo-img:url("logo.png")}
:root[data-theme="dark"]{--logo-img:url("logo-dark.png")}

.lnav .logo,
.logo{
  display:flex !important;
  align-items:center !important;
  gap:11px !important;
  font-weight:700 !important;
  font-size:1.75rem !important;       /* 28px — old size */
  color:var(--text) !important;
  letter-spacing:-.025em !important;
  line-height:1 !important;
}
.lnav .logo .logo-i,
.logo .logo-i{
  width:42px !important;              /* old: 42x36 */
  height:36px !important;
  display:inline-block !important;
  background-image:var(--logo-img) !important;
  background-size:contain !important;
  background-repeat:no-repeat !important;
  background-position:center !important;
  background-color:transparent !important;
  box-shadow:none !important;
  border-radius:0 !important;
  padding:0 !important;
  flex-shrink:0 !important;
}
/* If any page still has a nested <img> inside .logo-i (footer of pilot.html
   may, for instance), hide it — the CSS background-image is the source of
   truth now and we don't want two lightning bolts stacked. */
.logo-i img,
.logo-i svg{display:none !important}

.logo .logo-t,
.lnav .logo .logo-t{
  display:inline-block !important;
  line-height:1 !important;
  font-size:inherit !important;       /* inherits 1.75rem from .logo */
}

/* Footer logo — keep its own slightly different size if present.
   Footer typically uses .lft .logo, override the proportions:  */
.lft .logo{
  font-size:1.25rem !important;       /* footer is a bit smaller than nav */
}
.lft .logo .logo-i{
  width:32px !important;
  height:28px !important;
}


/* ============================================================
   ROUND 65 — Restore old hero-illustration size on legal pages
   The uploaded redesign made the hero SVG art 380px wide; round
   62 had it at ~180px. Bringing it back to 200px so the page
   feels balanced (illustration supports, doesn't dominate).
   ============================================================ */
.lhero-art{
  max-width:200px !important;
}
@media(max-width:900px){
  .lhero-art{max-width:160px !important}
}

/* ============================================================
   ROUND 65 — Mobile overflow fix for legal page TOC sidebar
   The .lbody-side / .ltoc-sticky was overflowing the viewport
   by ~23px on phones because nested padding wasn't accounted
   for. Force everything to honor the box-sizing math.
   ============================================================ */
@media (max-width:640px){
  /* The grid column itself: force a hard cap to the viewport content area,
     and let children shrink with min-width:0 (otherwise grid items default
     to min-content which expands to the widest line). */
  .lbody-grid{
    grid-template-columns:minmax(0,1fr) !important;
  }
  .lbody-grid > *{
    min-width:0 !important;
    max-width:100% !important;
  }
  .lbody-side,
  .ltoc-sticky,
  .ltoc-sticky ol.toc-list{
    max-width:100% !important;
    width:auto !important;
    box-sizing:border-box !important;
    min-width:0 !important;
  }
  /* TOC items shouldn't stretch beyond container */
  .ltoc-sticky ol.toc-list li,
  .ltoc-sticky ol.toc-list a{
    max-width:100% !important;
    word-break:break-word;
  }
}

/* Wide tables (e.g. rubric weighting matrix) should scroll horizontally
   inside their own container on phones, not push the whole page sideways. */
@media (max-width:640px){
  .lbody table{
    display:block;
    overflow-x:auto;
    width:100%;
    -webkit-overflow-scrolling:touch;
  }
}

/* ============================================================
   ROUND 66 — Match additional-page footer to the landing-page
   footer: solid dark background (not purple gradient), tighter
   padding, logo at landing-page size (1.625rem), no decorative
   overlay, no extra borders between aprod / lft-bot rows.
   ============================================================ */

/* 1. Background: solid dark, kill the gradient and the radial overlay.
   Use the same hex as the landing-page footer (#0F0A1A) so both feel
   like one design system rather than two slightly different darks. */
.lft{
  background:#0F0A1A !important;
  padding:40px 0 18px !important;
  margin-top:48px !important;
}
.lft::before{display:none !important}

/* 2. Inner container — slimmer + tidy column gap */
.lft-c{
  max-width:1320px !important;
  padding:0 24px !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  gap:14px !important;
  margin:0 auto !important;
}

/* 3. Logo — match landing-page footer (1.625rem, white) */
.lft .logo{
  color:#fff !important;
  font-size:1.625rem !important;
  letter-spacing:-.025em !important;
  line-height:1 !important;
  gap:10px !important;
  margin:0 !important;
}
.lft .logo .logo-i{
  width:34px !important;
  height:28px !important;
}
.lft .logo .logo-t{
  font-size:inherit !important;
  color:#fff !important;
}

/* 4. Links row — tight horizontal list, no border */
.lft-l{
  display:flex !important;
  flex-wrap:wrap !important;
  justify-content:center !important;
  gap:8px 28px !important;
  margin:0 !important;
  padding:0 !important;
  list-style:none !important;
}
.lft-l li{margin:0 !important}
.lft-l a{
  color:rgba(255,255,255,.65) !important;
  font-size:.8125rem !important;
  text-decoration:none !important;
  transition:color .15s ease !important;
}
.lft-l a:hover{
  color:#fff !important;
  text-decoration:none !important;
}

/* 5. AEROVANT attribution row — no top border, tight spacing */
.aprod{
  margin:14px auto 0 !important;
  padding:14px 24px 0 !important;
  border-top:1px solid rgba(255,255,255,.08) !important;
  max-width:1320px !important;
  display:flex !important;
  align-items:baseline !important;
  justify-content:center !important;
  gap:10px !important;
  flex-wrap:wrap !important;
}
.aprod span{
  color:rgba(255,255,255,.45) !important;
  font-size:.6875rem !important;
  font-weight:600 !important;
  letter-spacing:.18em !important;
  text-transform:uppercase !important;
}
.aprod a{
  color:#fff !important;
  font-size:.8125rem !important;
  font-weight:700 !important;
  letter-spacing:.12em !important;
  text-transform:uppercase !important;
  text-decoration:none !important;
  display:inline-flex !important;
  align-items:center !important;
  gap:6px !important;
}
.aprod a:hover{color:#C4B5FD !important}
.aprod a svg{width:12px !important;height:12px !important;opacity:.7 !important}

/* 6. Copyright line — bottom, slim, no border */
.lft-bot{
  max-width:1320px !important;
  margin:10px auto 0 !important;
  padding:10px 24px 0 !important;
  border-top:1px solid rgba(255,255,255,.06) !important;
  font-size:.75rem !important;
  color:rgba(255,255,255,.45) !important;
  text-align:center !important;
}
.lft-bot a{color:rgba(255,255,255,.7) !important}

/* 7. Mobile — stack tidy, reduced padding */
@media (max-width:640px){
  .lft{padding:32px 0 14px !important;margin-top:32px !important}
  .lft-c{gap:12px !important}
  .lft-l{gap:8px 18px !important}
  .lft .logo{font-size:1.375rem !important}
  .aprod{padding:12px 24px 0 !important;gap:8px !important}
  .lft-bot{padding:8px 24px 0 !important;font-size:.7rem !important}
}
