/* ============================================================
   EUDORA LANDING – Design Tokens + Component Styles
   Navy (#020617 bg · #0f172a surface · #22c55e accent)
   Font: Plus Jakarta Sans (UI) · JetBrains Mono (code)
   ============================================================ */

:root {
  --color-bg:           #020617;
  --color-surface:      #0f172a;
  --color-surface-high: #1e293b;
  --color-accent:       #22c55e;
  --color-accent-dim:   rgba(34,197,94,.12);
  --color-border:       #334155;
  --color-text:         #f8fafc;
  --color-text-muted:   #64748b;
  --color-text-sub:     #94a3b8;
  --color-danger:       #ef4444;
  --color-danger-dim:   rgba(239,68,68,.1);
  --color-danger-border:rgba(239,68,68,.35);
  --font-sans:  "Plus Jakarta Sans", system-ui, sans-serif;
  --font-mono:  "JetBrains Mono", monospace;
  --radius:     8px;
  --radius-lg:  16px;
  --max-w:      1200px;
  --nav-h:      64px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--color-bg);color:var(--color-text);font-family:var(--font-sans);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.container{max-width:var(--max-w);margin:0 auto;padding:0 48px}
@media(max-width:768px){.container{padding:0 20px}}

/* Nav */
.nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:100;background:rgba(2,6,23,.88);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border)}
.nav-inner{max-width:var(--max-w);margin:0 auto;padding:0 48px;height:100%;display:flex;align-items:center;justify-content:space-between;gap:32px}
@media(max-width:768px){.nav-inner{padding:0 20px}}
.nav-logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;letter-spacing:-.3px}
.nav-logo-mark{width:28px;height:28px;background:var(--color-accent);border-radius:6px;display:flex;align-items:center;justify-content:center}
.nav-logo-dot{width:8px;height:8px;background:var(--color-bg);border-radius:50%}
.nav-links{display:flex;align-items:center;gap:32px;list-style:none}
.nav-links a{font-size:14px;font-weight:500;color:var(--color-text-sub);transition:color .15s}
.nav-links a:hover{color:var(--color-text)}
.nav-cta{display:flex;align-items:center;gap:12px}
@media(max-width:768px){.nav-links{display:none}}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius);font-family:var(--font-sans);font-size:14px;font-weight:600;cursor:pointer;border:none;transition:opacity .15s,transform .1s;text-decoration:none}
.btn:active{transform:scale(.98)}
.btn-primary{background:var(--color-accent);color:#052e16}
.btn-primary:hover{opacity:.9}
.btn-outline{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}
.btn-outline:hover{border-color:var(--color-text-sub)}
.btn-sm{padding:8px 16px;font-size:13px}

/* Hero */
.hero{padding-top:calc(var(--nav-h) + 96px);padding-bottom:96px;text-align:center}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:var(--color-accent-dim);border:1px solid rgba(34,197,94,.3);border-radius:100px;font-size:12px;font-weight:600;color:var(--color-accent);letter-spacing:.5px;text-transform:uppercase;margin-bottom:32px;font-family:var(--font-mono)}
.hero-badge-dot{width:6px;height:6px;background:var(--color-accent);border-radius:50%;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.3}}
.hero h1{font-size:clamp(34px,6vw,64px);font-weight:700;line-height:1.1;letter-spacing:-1.5px;max-width:820px;margin:0 auto 24px;color:var(--color-text)}
.hero h1 span{color:var(--color-accent)}
.hero p{font-size:18px;color:var(--color-text-sub);max-width:600px;margin:0 auto 40px;line-height:1.7}
.hero-ctas{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}

/* Trust bar */
.trust-bar{border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);padding:20px 0;background:var(--color-surface)}
.trust-bar-inner{max-width:var(--max-w);margin:0 auto;padding:0 48px;display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap}
@media(max-width:768px){.trust-bar-inner{padding:0 20px;gap:20px}}
.trust-item{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--color-text-sub)}
.trust-item .material-symbols-outlined{font-size:16px;color:var(--color-accent)}

/* Section */
.section{padding:96px 0}
.section-border{border-top:1px solid var(--color-border)}
.section-label{display:inline-block;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--color-accent);margin-bottom:16px;font-family:var(--font-mono)}
.section-title{font-size:clamp(26px,4vw,44px);font-weight:700;letter-spacing:-.8px;line-height:1.15;margin-bottom:16px}
.section-sub{font-size:17px;color:var(--color-text-sub);max-width:560px;line-height:1.7}

/* ============================================================
   GOVERNANCE GAP – 3-column: IGA | Gap (red) | Eudora (green)
   ============================================================ */
.gap-grid{
  display:grid;
  grid-template-columns:1fr 220px 1fr;
  margin-top:56px;
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--color-border);
}
@media(max-width:900px){.gap-grid{grid-template-columns:1fr}}

/* Left card – IGA (neutral/muted) */
.gap-card-iga{
  padding:36px;
  background:var(--color-surface);
  border-right:1px solid var(--color-border);
}
@media(max-width:900px){.gap-card-iga{border-right:none;border-bottom:1px solid var(--color-border)}}

/* Middle card – The Gap (red warning) */
.gap-card-middle{
  padding:32px 24px;
  background:var(--color-danger-dim);
  border-right:1px solid var(--color-danger-border);
  border-left:1px solid var(--color-danger-border);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  gap:12px;
}
@media(max-width:900px){
  .gap-card-middle{border-left:none;border-right:none;border-top:1px solid var(--color-danger-border);border-bottom:1px solid var(--color-danger-border)}
}

.gap-unsolved-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 12px;
  background:rgba(239,68,68,.15);
  border:1px solid var(--color-danger-border);
  border-radius:100px;
  font-size:10px;
  font-weight:700;
  letter-spacing:.8px;
  text-transform:uppercase;
  color:#f87171;
  font-family:var(--font-mono);
}
.gap-unsolved-dot{
  width:5px;height:5px;
  background:#f87171;
  border-radius:50%;
  animation:pulse-dot 1.5s infinite;
}

.gap-middle-title{
  font-size:15px;
  font-weight:700;
  color:var(--color-text);
  margin:0;
}
.gap-middle-desc{
  font-size:13px;
  color:#f87171;
  line-height:1.55;
}
.gap-arrow{
  font-size:20px;
  color:var(--color-danger-border);
}

/* Right card – Eudora (green) */
.gap-card-eudora{
  padding:36px;
  background:rgba(34,197,94,.05);
  border-left:1px solid rgba(34,197,94,.2);
}
@media(max-width:900px){.gap-card-eudora{border-left:none;border-top:1px solid rgba(34,197,94,.2)}}

.gap-col-label{
  font-size:11px;
  font-weight:700;
  letter-spacing:1.2px;
  text-transform:uppercase;
  font-family:var(--font-mono);
  margin-bottom:12px;
}
.gap-col-label--muted{color:var(--color-text-muted)}
.gap-col-label--green{color:var(--color-accent)}

.gap-card-iga h4,.gap-card-eudora h4{font-size:20px;font-weight:700;margin-bottom:20px}

.gap-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.gap-list li{font-size:14px;color:var(--color-text-sub);display:flex;align-items:center;gap:8px}
.gap-list li::before{content:'';width:4px;height:4px;background:var(--color-text-muted);border-radius:50%;flex-shrink:0}
.gap-card-eudora .gap-list li{color:var(--color-text)}
.gap-card-eudora .gap-list li::before{background:var(--color-accent)}

/* Features grid */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--color-border);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;margin-top:56px}
@media(max-width:1024px){.features-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.features-grid{grid-template-columns:1fr}}
.feature-card{background:var(--color-surface);padding:36px;transition:background .15s}
.feature-card:hover{background:var(--color-surface-high)}
.feature-icon{width:44px;height:44px;background:var(--color-accent-dim);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.feature-icon .material-symbols-outlined{font-size:22px;color:var(--color-accent)}
.feature-card h3{font-size:16px;font-weight:700;margin-bottom:10px}
.feature-card p{font-size:14px;color:var(--color-text-sub);line-height:1.65}

/* Deploy cards */
.deploy-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:56px}
@media(max-width:768px){.deploy-grid{grid-template-columns:1fr}}
.deploy-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:36px;transition:border-color .2s}
.deploy-card:hover{border-color:var(--color-text-muted)}
.deploy-icon{width:44px;height:44px;background:var(--color-accent-dim);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.deploy-icon .material-symbols-outlined{font-size:22px;color:var(--color-accent)}
.deploy-card h3{font-size:18px;font-weight:700;margin-bottom:10px}
.deploy-card p{font-size:14px;color:var(--color-text-sub);line-height:1.65;margin-bottom:24px}
.deploy-card a{font-size:13px;font-weight:600;color:var(--color-accent)}
.deploy-card a:hover{text-decoration:underline}

/* Pricing */
.pricing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:56px}
@media(max-width:1024px){.pricing-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.pricing-grid{grid-template-columns:1fr}}
.pricing-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:32px;display:flex;flex-direction:column;position:relative}
.pricing-card--featured{border-color:var(--color-accent);background:linear-gradient(160deg,rgba(34,197,94,.06) 0%,var(--color-surface) 60%)}
.pricing-recommended{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--color-accent);color:#052e16;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:3px 12px;border-radius:100px;white-space:nowrap;font-family:var(--font-mono)}
.pricing-plan{font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--color-text-muted);font-family:var(--font-mono);margin-bottom:8px}
.pricing-card h3{font-size:20px;font-weight:700;margin-bottom:4px}
.pricing-price{font-size:13px;color:var(--color-text-sub);margin-bottom:24px}
.pricing-features{list-style:none;display:flex;flex-direction:column;gap:10px;flex:1;margin-bottom:28px}
.pricing-features li{font-size:13px;color:var(--color-text-sub);display:flex;align-items:flex-start;gap:8px}
.check-icon{width:16px;height:16px;background:var(--color-accent-dim);border-radius:4px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.check-icon .material-symbols-outlined{font-size:12px;color:var(--color-accent)}
.pricing-enterprise-note{font-size:12px;color:var(--color-text-muted);margin-top:12px;text-align:center}
.pricing-enterprise-note a{color:var(--color-accent)}
.pricing-enterprise-note a:hover{text-decoration:underline}

/* Self-host quickstart */
.quickstart{display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:start;margin-top:56px}
@media(max-width:768px){.quickstart{grid-template-columns:1fr}}
.quickstart-downloads{display:flex;flex-direction:column;gap:12px}
.dl-btn{display:inline-flex;align-items:center;gap:10px;padding:12px 20px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);font-size:14px;font-weight:500;color:var(--color-text);text-decoration:none;transition:border-color .15s;white-space:nowrap}
.dl-btn:hover{border-color:var(--color-text-muted)}
.dl-btn .material-symbols-outlined{font-size:18px;color:var(--color-accent)}
.quickstart-note{font-size:13px;color:var(--color-text-muted);margin-top:16px;line-height:1.6}
.quickstart-note a{color:var(--color-accent)}
.quickstart-note a:hover{text-decoration:underline}

/* ============================================================
   TERMINAL – pre-wrap preserves line breaks, wraps at edge
   ============================================================ */
.terminal{background:#000;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;font-family:var(--font-mono);font-size:13px}
.terminal-bar{background:var(--color-surface-high);padding:10px 16px;display:flex;align-items:center;gap:6px;border-bottom:1px solid var(--color-border)}
.terminal-dot{width:10px;height:10px;border-radius:50%}
.terminal-dot:nth-child(1){background:#ff5f57}
.terminal-dot:nth-child(2){background:#febc2e}
.terminal-dot:nth-child(3){background:#28c840}
.terminal-body{
  padding:24px;
  color:#94a3b8;
  line-height:2;
  white-space:pre-wrap;
  word-break:break-all;
  overflow-x:auto;
}
.terminal-body .comment{color:#475569}
.terminal-body .prompt{color:var(--color-accent)}
.terminal-body .cmd{color:#e2e8f0}

/* Footer */
.footer{border-top:1px solid var(--color-border);padding:40px 0;background:var(--color-surface)}
.footer-inner{max-width:var(--max-w);margin:0 auto;padding:0 48px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px}
@media(max-width:768px){.footer-inner{padding:0 20px;flex-direction:column;align-items:flex-start}}
.footer-logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:15px}
.footer-copy{font-size:13px;color:var(--color-text-muted);margin-top:4px}
.footer-links{display:flex;gap:24px;list-style:none}
.footer-links a{font-size:13px;color:var(--color-text-muted);transition:color .15s}
.footer-links a:hover{color:var(--color-text)}

.material-symbols-outlined{font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24;vertical-align:middle;line-height:1}
