/* ============================================================
   Klaros · style.css
   Shared stylesheet for index.html, privacy/, terms/, gdpr/
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --navy:#1F2E6B;
  --navy-700:#19255A;
  --navy-900:#121A40;
  --red:#E82F17;
  --bg:#FAFAF7;
  --surface:#FFFFFF;
  --text:#1A1A1A;
  --muted:#6B7280;
  --border:#E5E7EB;
  --max:1100px;
  --max-narrow:780px;
  --sans:'Inter', system-ui, -apple-system, Segoe UI, sans-serif;
  --serif:'Fraunces', Georgia, serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  font-family:var(--sans);
  font-size:18px;
  line-height:1.6;
  color:var(--text);
  background:var(--bg);
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ---------- Layout ---------- */
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.wrap-narrow{max-width:var(--max-narrow);margin:0 auto;padding:0 24px}
section{padding:80px 0}
@media (min-width:1024px){section{padding:120px 0}}

.eyebrow{
  font-family:var(--sans);
  font-size:12px;
  font-weight:600;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--navy);
  margin-bottom:24px;
  display:inline-block;
}
.eyebrow.red{color:var(--red)}
.eyebrow.white{color:#fff;opacity:0.85}

h1,h2,h3{font-family:var(--serif);color:var(--navy);font-weight:600;line-height:1.1;letter-spacing:-0.01em}
h1{font-size:36px}
h2{font-size:28px;margin-bottom:24px}
h3{font-size:22px;line-height:1.25;letter-spacing:-0.005em}
@media (min-width:768px){
  h1{font-size:52px}
  h2{font-size:34px}
  h3{font-size:24px}
}
@media (min-width:1024px){
  h1{font-size:64px}
  h2{font-size:40px}
  h3{font-size:26px}
}

.lead{font-size:18px;color:#3a3a3a;max-width:720px;line-height:1.55}
@media (min-width:768px){.lead{font-size:21px}}

/* ---------- Logo ---------- */
.logo{
  font-family:var(--serif);
  font-weight:600;
  color:var(--navy);
  font-size:30px;
  letter-spacing:-0.01em;
  line-height:1;
}
.logo .l{color:var(--red)}
.logo-tag{
  display:block;
  font-family:var(--sans);
  font-size:13px;
  font-weight:500;
  color:var(--muted);
  margin-top:6px;
  letter-spacing:0;
}

/* ---------- Nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(255,255,255,0.96);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--border);
}
.nav-inner{
  max-width:var(--max);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px;
}
.nav-links{display:none;gap:36px;font-size:15px;color:var(--text)}
.nav-links a{position:relative;font-weight:500}
.nav-links a:hover{color:var(--navy)}
.nav-links a::after{
  content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;
  background:var(--navy);transform:scaleX(0);transform-origin:left;
  transition:transform 200ms ease;
}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-cta{
  display:none;
  background:var(--navy);color:#fff;
  padding:13px 22px;border-radius:6px;
  font-size:15px;font-weight:500;
  transition:background 180ms ease, transform 180ms ease, box-shadow 180ms ease;
  box-shadow:0 4px 12px -4px rgba(31,46,107,0.3);
}
.nav-cta:hover{background:var(--navy-700);transform:translateY(-1px);box-shadow:0 6px 16px -4px rgba(31,46,107,0.4)}
@media (min-width:1024px){
  .nav-links{display:flex}
  .nav-cta{display:inline-block}
}
.menu-btn{display:flex;flex-direction:column;gap:5px;padding:8px}
.menu-btn span{width:22px;height:1.5px;background:var(--navy);display:block}
@media (min-width:1024px){.menu-btn{display:none}}
.mobile-menu{
  display:none;background:#fff;border-top:1px solid var(--border);
  padding:20px 24px;
}
.mobile-menu.open{display:block}
.mobile-menu a{display:block;padding:12px 0;font-size:16px;border-bottom:1px solid var(--border)}
.mobile-menu a:last-child{border-bottom:none}
.mobile-menu .nav-cta{display:inline-block;margin-top:16px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 28px;
  font-family:var(--sans);font-weight:500;font-size:16px;
  border-radius:6px;
  transition:transform 160ms ease, background 180ms ease, box-shadow 200ms ease;
  cursor:pointer;
}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--navy-700);transform:translateY(-1px);box-shadow:0 8px 24px -10px rgba(31,46,107,0.45)}
.btn-red{background:var(--red);color:#fff;padding:18px 32px;font-size:17px}
.btn-red:hover{background:#cc2914;transform:translateY(-1px);box-shadow:0 10px 30px -10px rgba(232,47,23,0.55)}
.btn-text{
  display:inline-flex;align-items:center;gap:8px;
  font-weight:500;color:var(--navy);
  border-bottom:1px solid transparent;padding-bottom:2px;
  transition:gap 180ms ease, border-color 180ms ease;
}
.btn-text:hover{gap:14px;border-color:var(--navy)}
.btn-text.white{color:#fff}
.btn-text.white:hover{border-color:#fff}

/* ---------- Hero ---------- */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:140px 0 80px;
  background:var(--bg);
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(800px 400px at 85% 20%, rgba(31,46,107,0.05), transparent 60%),
    radial-gradient(600px 300px at 10% 90%, rgba(232,47,23,0.025), transparent 60%);
  pointer-events:none;
}
.hero-inner{position:relative;max-width:920px}
.hero h1{margin:18px 0 28px}
.hero h1 .accent{color:var(--navy);position:relative;display:inline-block}
.hero h1 .accent::after{
  content:"";position:absolute;left:0;right:0;bottom:6px;height:8px;
  background:var(--red);opacity:0.18;z-index:-1;border-radius:2px;
}
.hero-cta{display:flex;flex-wrap:wrap;align-items:center;gap:24px;margin-top:40px}
.hero-trust{
  margin-top:48px;
  font-size:14px;color:var(--muted);
  display:flex;flex-wrap:wrap;gap:6px 8px;align-items:center;
  font-weight:500;
}
.hero-trust .dot{color:var(--border)}
.hero-trust-cta{
  margin-top:14px;font-size:14px;color:var(--navy);font-weight:600;
  display:flex;align-items:center;gap:8px;
}
.hero-trust-cta::before{
  content:"";width:14px;height:2px;background:var(--red);
}

/* ---------- Stat cards ---------- */
.stat-grid{
  display:grid;grid-template-columns:1fr;gap:20px;
  margin:48px 0 64px;
}
@media (min-width:768px){.stat-grid{grid-template-columns:repeat(3,1fr);gap:24px}}
.stat-card{
  background:var(--surface);
  border:1px solid var(--border);
  padding:36px 32px;
  border-radius:8px;
  transition:transform 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
}
.stat-card:hover{transform:translateY(-2px);box-shadow:0 12px 32px -16px rgba(31,46,107,0.18);border-color:#d4d8e0}
.stat-num{
  font-family:var(--serif);
  font-size:64px;font-weight:600;
  color:var(--navy);line-height:1;
  margin-bottom:6px;letter-spacing:-0.02em;
}
.stat-num::after{
  content:"";display:block;width:32px;height:3px;background:var(--red);
  margin-top:16px;border-radius:2px;
}
.stat-body{font-size:17px;line-height:1.5;color:var(--text);margin-top:18px}
.stat-source{font-size:13px;color:var(--muted);margin-top:14px;font-weight:500}

.statement{
  font-family:var(--serif);font-weight:400;
  font-size:24px;line-height:1.35;color:var(--navy);
  max-width:880px;margin:0 auto;text-align:center;
  letter-spacing:-0.01em;
}
@media (min-width:768px){.statement{font-size:30px}}
@media (min-width:1024px){.statement{font-size:34px}}

/* ---------- Analogy ---------- */
.analogy-grid{
  display:grid;grid-template-columns:1fr;gap:24px;
  margin:48px 0;
}
@media (min-width:768px){.analogy-grid{grid-template-columns:1fr 1fr;gap:32px}}
.col{
  background:var(--surface);border:1px solid var(--border);
  padding:36px 32px;border-radius:8px;
}
.col-mark{
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:50%;
  font-family:var(--sans);font-weight:600;font-size:16px;
  margin-bottom:20px;
}
.col-wrong{border-top:3px solid var(--red)}
.col-wrong .col-mark{background:rgba(232,47,23,0.1);color:var(--red)}
.col-right{border-top:3px solid var(--navy)}
.col-right .col-mark{background:rgba(31,46,107,0.1);color:var(--navy)}
.col h3{margin-bottom:24px;font-size:24px}
.col-wrong h3{color:#1A1A1A}
.col ul{list-style:none}
.col ol{list-style:none;counter-reset:step}
.col li{
  padding:14px 0;border-bottom:1px solid var(--border);
  display:flex;gap:14px;align-items:flex-start;
  font-size:16px;line-height:1.5;
}
.col li:last-child{border-bottom:none}
.col-wrong li::before{content:"—";color:var(--red);flex-shrink:0;font-weight:600}
.col-right li{counter-increment:step}
.col-right ol li::before{
  content:counter(step);
  flex-shrink:0;width:26px;height:26px;border-radius:50%;
  background:var(--navy);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:600;font-family:var(--sans);
}
.col-footer{
  margin-top:24px;padding-top:20px;border-top:1px solid var(--border);
  font-size:15px;
}
.col-wrong .col-footer{font-style:italic;color:var(--muted)}
.col-right .col-footer{color:var(--navy);font-weight:600}

/* ---------- Foundation ---------- */
.found-grid{
  display:grid;grid-template-columns:1fr;gap:20px;margin-top:48px;
}
@media (min-width:768px){.found-grid{grid-template-columns:1fr 1fr;gap:24px}}
.found-card{
  background:var(--surface);border:1px solid var(--border);
  padding:36px 32px;border-radius:8px;
  transition:transform 200ms ease, box-shadow 200ms ease;
}
.found-card:hover{transform:translateY(-2px);box-shadow:0 12px 32px -16px rgba(31,46,107,0.15)}
.found-sym{
  font-size:32px;color:var(--navy);
  margin-bottom:20px;line-height:1;
}
.found-card h3{margin-bottom:14px}
.found-card p{font-size:16px;line-height:1.6;color:#3a3a3a}

/* ---------- LMI Section (navy) ---------- */
.lmi{background:var(--navy);color:#fff}
.lmi h2{color:#fff;max-width:900px}
.lmi-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:32px;
  margin:64px 0 72px;
  padding-top:48px;border-top:1px solid rgba(255,255,255,0.15);
}
@media (min-width:768px){.lmi-stats{grid-template-columns:repeat(4,1fr);gap:40px}}
.lmi-stat-num{
  font-family:var(--serif);font-size:48px;font-weight:600;
  color:var(--red);line-height:1;letter-spacing:-0.02em;
}
@media (min-width:768px){.lmi-stat-num{font-size:60px}}
@media (min-width:1024px){.lmi-stat-num{font-size:68px}}
.lmi-stat-label{
  margin-top:14px;font-size:15px;line-height:1.5;
  color:rgba(255,255,255,0.85);
}
.lmi-manifesto{
  font-family:var(--serif);font-weight:400;
  font-size:28px;line-height:1.3;color:#fff;
  text-align:center;max-width:760px;margin:0 auto;
  letter-spacing:-0.01em;
}
.lmi-manifesto span{display:block}
@media (min-width:768px){.lmi-manifesto{font-size:36px}}
@media (min-width:1024px){.lmi-manifesto{font-size:42px}}

/* ---------- Program timeline ---------- */
.phases{margin-top:56px;display:flex;flex-direction:column;gap:24px}
.phase{
  background:var(--surface);border:1px solid var(--border);
  border-radius:8px;padding:36px 32px;
  display:grid;grid-template-columns:1fr;gap:24px;
  transition:border-color 200ms ease, box-shadow 200ms ease;
}
.phase:hover{border-color:#d4d8e0;box-shadow:0 12px 32px -16px rgba(31,46,107,0.12)}
@media (min-width:768px){
  .phase{grid-template-columns:160px 1fr;gap:48px;padding:44px 40px}
}
.phase-num{
  font-family:var(--serif);font-weight:600;
  font-size:72px;color:var(--red);line-height:1;letter-spacing:-0.02em;
}
.phase-label{
  display:inline-block;font-size:13px;font-weight:600;
  letter-spacing:0.14em;text-transform:uppercase;
  color:var(--muted);margin-bottom:8px;
}
.phase h3{margin-bottom:18px;font-size:26px}
.phase p{
  font-size:17px;line-height:1.65;color:#2a2a2a;
  margin-bottom:22px;max-width:560px;
}
.phase-footer{
  font-style:italic;color:var(--muted);font-size:15px;
  padding-top:18px;border-top:1px solid var(--border);
}

/* ---------- Results (former Deliverables) ---------- */
.del-grid{
  display:grid;grid-template-columns:1fr;gap:32px;margin-top:48px;
}
@media (min-width:768px){.del-grid{grid-template-columns:1fr 1fr;gap:36px 48px}}
@media (min-width:1024px){.del-grid{grid-template-columns:repeat(3,1fr)}}
.del-item{
  position:relative;padding:8px 0 0 0;
}
.del-icon{
  width:40px;height:40px;border-radius:8px;
  background:rgba(31,46,107,0.06);
  display:flex;align-items:center;justify-content:center;
  color:var(--navy);
  margin-bottom:18px;
}
.del-icon svg{width:22px;height:22px}
.del-item h3{font-size:20px;margin-bottom:10px;line-height:1.3}
.del-item p{font-size:16px;line-height:1.55;color:#3a3a3a}

/* ---------- Why LMI cards ---------- */
.why-grid{display:grid;grid-template-columns:1fr;gap:20px;margin-top:48px}
@media (min-width:768px){.why-grid{grid-template-columns:1fr 1fr;gap:24px}}
.why-card{
  background:var(--surface);border:1px solid var(--border);
  padding:36px 32px;border-radius:8px;
  transition:transform 200ms ease, box-shadow 200ms ease;
}
.why-card:hover{transform:translateY(-2px);box-shadow:0 12px 32px -16px rgba(31,46,107,0.15)}
.why-card .sym{font-size:30px;color:var(--navy);margin-bottom:20px;line-height:1}
.why-card h3{font-size:22px;margin-bottom:14px}
.why-card p{font-size:16px;line-height:1.6;color:#3a3a3a}

/* ---------- About Klaros ---------- */
.about-body{max-width:720px;margin:32px auto 0}
.about-body p{margin-bottom:18px;font-size:17px;line-height:1.7;color:#2a2a2a}
.about-body p:first-of-type{font-size:18px}
.about-partner{
  margin-top:48px;text-align:center;
  font-size:14px;color:var(--muted);letter-spacing:0.5px;
}
.about-partner a{color:var(--navy);font-weight:500;border-bottom:1px solid transparent;transition:border-color 180ms}
.about-partner a:hover{border-color:var(--navy)}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:48px auto 0}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{
  width:100%;text-align:left;
  padding:24px 0;
  display:flex;justify-content:space-between;align-items:flex-start;gap:24px;
  font-family:var(--sans);font-size:18px;font-weight:500;color:var(--text);
  line-height:1.4;
}
.faq-q:hover{color:var(--navy)}
.faq-icon{
  flex-shrink:0;width:24px;height:24px;
  display:flex;align-items:center;justify-content:center;
  color:var(--navy);transition:transform 250ms ease;
  position:relative;
}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-icon::before,.faq-icon::after{
  content:"";position:absolute;background:var(--navy);
}
.faq-icon::before{width:14px;height:1.5px}
.faq-icon::after{width:1.5px;height:14px}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height 320ms ease, padding 320ms ease;
}
.faq-item.open .faq-a{padding:0 0 28px;max-height:600px}
.faq-a p{font-size:16px;line-height:1.65;color:#3a3a3a;max-width:720px}

/* ---------- Final CTA ---------- */
.final{background:var(--navy);color:#fff}
.final h2{color:#fff;text-align:center;max-width:900px;margin:0 auto 48px}
.steps{
  display:grid;grid-template-columns:1fr;gap:32px;
  margin:64px 0;
}
@media (min-width:768px){.steps{grid-template-columns:repeat(3,1fr);gap:40px}}
.step{padding-top:8px;border-top:1px solid rgba(255,255,255,0.2);position:relative}
.step-num{
  font-family:var(--serif);font-weight:600;
  font-size:40px;color:var(--red);line-height:1;
  margin:24px 0 16px;letter-spacing:-0.02em;
}
.step h3{color:#fff;font-size:22px;margin-bottom:12px}
.step p{font-size:16px;line-height:1.6;color:rgba(255,255,255,0.82)}
.final-cta{text-align:center;margin-top:24px}
.final-cta .btn-red{padding:20px 38px;font-size:18px}
.final-secondary{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:28px;color:#fff;font-size:15px;
  border-bottom:1px solid rgba(255,255,255,0.4);padding-bottom:3px;
  transition:border-color 180ms ease;
}
.final-secondary:hover{border-color:#fff}
.final-trust{
  text-align:center;margin-top:36px;
  color:rgba(255,255,255,0.6);font-size:14px;
}

/* ---------- Footer ---------- */
.footer{background:var(--navy-900);color:rgba(255,255,255,0.78);padding:80px 0 32px}
.footer-grid{
  display:grid;grid-template-columns:1fr;gap:48px;
}
@media (min-width:768px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr;gap:64px}}
.footer .logo{color:#fff;font-size:32px}
.footer .logo .l{color:var(--red)}
.footer-tag{font-family:var(--serif);font-size:18px;color:#fff;margin-top:14px;font-weight:400}
.footer-cr{font-size:13px;color:rgba(255,255,255,0.45);margin-top:20px;line-height:1.5}
.footer h4{
  font-family:var(--sans);font-size:13px;font-weight:600;
  color:#fff;text-transform:uppercase;letter-spacing:0.14em;
  margin-bottom:20px;
}
.footer ul{list-style:none}
.footer li{margin-bottom:12px;font-size:15px}
.footer li a{color:rgba(255,255,255,0.78);transition:color 180ms ease}
.footer li a:hover{color:#fff}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.12);
  margin-top:64px;padding-top:24px;
  display:flex;flex-wrap:wrap;gap:24px;
  font-size:13px;color:rgba(255,255,255,0.5);
}
.footer-bottom a{transition:color 180ms ease}
.footer-bottom a:hover{color:#fff}

/* ---------- WhatsApp sticky ---------- */
.wa{
  position:fixed;bottom:24px;right:24px;z-index:60;
  width:56px;height:56px;border-radius:50%;
  background:var(--red);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px -6px rgba(232,47,23,0.45);
  transition:transform 200ms ease, box-shadow 200ms ease;
}
.wa:hover{transform:translateY(-2px) scale(1.04);box-shadow:0 14px 32px -8px rgba(232,47,23,0.6)}
.wa svg{width:28px;height:28px}

/* ---------- Misc ---------- */
.section-head{margin-bottom:8px}
.section-sub{color:#3a3a3a;font-size:18px;line-height:1.6;max-width:720px;margin-bottom:8px}
.center{text-align:center}
.divider-statement{margin-top:64px;padding-top:0}

/* ---------- Legal pages ---------- */
.legal-page{padding:140px 0 80px;min-height:100vh}
.legal-content{max-width:780px;margin:0 auto;padding:0 24px}
.legal-content h1{font-size:38px;margin-bottom:14px}
.legal-content .lead-sub{color:var(--muted);font-size:15px;margin-bottom:48px}
.legal-content h2{font-size:24px;margin:48px 0 16px;color:var(--navy)}
.legal-content h3{font-size:18px;margin:28px 0 10px;color:var(--text)}
.legal-content p{margin-bottom:16px;font-size:16px;line-height:1.7;color:#2a2a2a}
.legal-content ul,.legal-content ol{margin:12px 0 20px 24px}
.legal-content li{margin-bottom:8px;font-size:16px;line-height:1.6;color:#2a2a2a}
.legal-content strong{font-weight:600;color:var(--text)}
.legal-content a{color:var(--navy);border-bottom:1px solid rgba(31,46,107,0.3);transition:border-color 180ms}
.legal-content a:hover{border-color:var(--navy)}
.legal-content table{
  width:100%;border-collapse:collapse;margin:24px 0;font-size:15px;
}
.legal-content th,.legal-content td{
  text-align:left;padding:12px 16px;
  border-bottom:1px solid var(--border);
}
.legal-content th{
  background:rgba(31,46,107,0.04);color:var(--navy);font-weight:600;
}
.legal-back{
  display:inline-block;margin-top:48px;padding-top:24px;
  border-top:1px solid var(--border);width:100%;
  color:var(--muted);font-size:14px;
}
.legal-back a{color:var(--navy);font-weight:500;border-bottom:1px solid transparent}
.legal-back a:hover{border-bottom-color:var(--navy)}

/* Reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity 700ms ease, transform 700ms ease}
.reveal.in{opacity:1;transform:none}
