/* ===== vibethecoder design system ===== */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@500;600;700;800&family=Inter:wght@400;500;600&display=swap');

:root {
  --orange:#ff7a18;
  --pink:#e5168c;
  --magenta:#ff2e92;
  --purple:#8b2fc9;
  --blue:#2d6cff;
  --grad: linear-gradient(100deg, #ff7a18 0%, #ff2e92 35%, #8b2fc9 68%, #2d6cff 100%);
  --grad-soft: linear-gradient(100deg, #fff0e6 0%, #ffe6f3 40%, #f1e6ff 70%, #e6effff 100%);
  --ink:#16121f;
  --body:#4a4358;
  --muted:#8a8398;
  --line:#ece8f3;
  --bg:#ffffff;
  --bg-soft:#faf8ff;
  --radius:18px;
  --shadow:0 24px 60px -30px rgba(80,30,120,.45);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;
  color:var(--body);background:var(--bg);line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Plus Jakarta Sans',sans-serif;color:var(--ink);line-height:1.1;letter-spacing:-.02em}
a{color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}

/* gradient text */
.grad-text{
  background:var(--grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:none;
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:1rem;
  padding:14px 26px;border-radius:999px;text-decoration:none;transition:transform .15s ease,box-shadow .2s ease,filter .2s ease;
}
.btn-grad{background:var(--grad);color:#fff;box-shadow:0 14px 30px -12px rgba(229,22,140,.6)}
.btn-grad:hover{transform:translateY(-2px);filter:brightness(1.05)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{transform:translateY(-2px)}
.btn-ghost{background:#fff;color:var(--ink);border:2px solid var(--line)}
.btn-ghost:hover{border-color:var(--purple);color:var(--purple)}

/* ---------- nav ---------- */
nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.nav-brand{display:flex;align-items:center;gap:10px;font-family:'Plus Jakarta Sans';font-weight:800;font-size:1.25rem;color:var(--ink);text-decoration:none}
.nav-brand img{height:38px;width:auto}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{text-decoration:none;font-weight:600;color:var(--body);font-size:.96rem;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--purple)}
.nav-links .btn{padding:10px 20px;font-size:.92rem}
.nav-toggle{display:none;background:none;border:none;font-size:1.6rem;cursor:pointer;color:var(--ink)}

/* ---------- hero ---------- */
.hero{padding:90px 0 80px;background:radial-gradient(1200px 500px at 75% -20%, #fdeaf5, transparent),var(--bg);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:'Plus Jakarta Sans';font-weight:700;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--purple);background:#f4ecff;border:1px solid #e7d9ff;padding:7px 16px;border-radius:999px;margin-bottom:24px}
.hero h1{font-size:clamp(2.6rem,5.5vw,4.4rem);font-weight:800;margin-bottom:20px}
.hero p.lead{font-size:clamp(1.08rem,2vw,1.3rem);color:var(--body);max-width:540px;margin-bottom:32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.hero-note{font-size:.9rem;color:var(--muted)}
.hero-art{position:relative;display:grid;place-items:center}
.hero-art .glow{position:absolute;inset:0;background:var(--grad);filter:blur(70px);opacity:.28;border-radius:50%}
.hero-art img{position:relative;width:100%;max-width:420px;filter:drop-shadow(0 30px 50px rgba(80,30,120,.35))}

/* ---------- sections ---------- */
section{padding:88px 0}
.section-soft{background:var(--bg-soft)}
.section-dark{background:var(--ink);color:#cfc8da}
.section-dark h1,.section-dark h2,.section-dark h3{color:#fff}
.section-grad{background:var(--grad);color:#fff}
.section-grad h2{color:#fff}
.section-head{text-align:center;max-width:640px;margin:0 auto 56px}
.section-head .eyebrow{margin-bottom:18px}
.section-head h2{font-size:clamp(2rem,4vw,2.9rem);font-weight:800;margin-bottom:14px}
.section-head p{font-size:1.1rem;color:var(--body)}
.section-dark .section-head p{color:#cfc8da}

/* ---------- cards / grids ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px 28px;transition:transform .2s,box-shadow .2s}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.card .ico{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:18px;background:var(--grad);color:#fff}
.card h3{font-size:1.25rem;margin-bottom:8px}
.card p{font-size:.98rem;color:var(--body)}

/* ---------- prompt block ---------- */
.prompt-box{background:#16121f;border-radius:20px;padding:8px;box-shadow:var(--shadow);max-width:760px;margin:0 auto;overflow:hidden}
.prompt-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px}
.prompt-bar .dots{display:flex;gap:7px}
.prompt-bar .dots span{width:12px;height:12px;border-radius:50%}
.prompt-bar .dots span:nth-child(1){background:#ff5f57}
.prompt-bar .dots span:nth-child(2){background:#febc2e}
.prompt-bar .dots span:nth-child(3){background:#28c840}
.copy-btn{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:7px 14px;font-size:.85rem;font-weight:600;cursor:pointer;font-family:'Plus Jakarta Sans';transition:background .2s}
.copy-btn:hover{background:rgba(255,255,255,.2)}
.prompt-box pre{margin:0;padding:6px 22px 24px;color:#e7e2f0;font-family:ui-monospace,'SF Mono',Menlo,monospace;font-size:.86rem;line-height:1.7;white-space:pre-wrap;overflow-x:auto}

/* ---------- email capture ---------- */
.email-form{display:flex;gap:10px;max-width:480px;margin:0 auto;background:#fff;padding:8px;border-radius:14px;box-shadow:var(--shadow)}
.email-form input{flex:1;border:none;outline:none;background:transparent;padding:12px 16px;font-size:1rem;font-family:inherit;color:var(--ink)}
.email-form .btn{padding:12px 22px}

/* ---------- roadmap ---------- */
.road{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.road-item{display:flex;gap:18px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px 24px;transition:transform .2s,box-shadow .2s}
.road-item:hover{transform:translateX(4px);box-shadow:var(--shadow)}
.road-num{flex:none;width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-family:'Plus Jakarta Sans';font-weight:800;color:#fff;background:var(--grad)}
.road-item.soon .road-num{background:#ece8f3;color:var(--muted)}
.road-body h3{font-size:1.1rem;margin-bottom:3px}
.road-body p{font-size:.94rem;color:var(--muted)}
.tag{font-family:'Plus Jakarta Sans';font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border-radius:999px;margin-left:auto;flex:none}
.tag.live{background:#e7fbef;color:#0a8f3c}
.tag.soon{background:#f3eefc;color:var(--purple)}

/* ---------- CTA band ---------- */
.cta-band{text-align:center}
.cta-band h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:14px}
.cta-band p{max-width:520px;margin:0 auto 28px;font-size:1.1rem}
.cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- footer ---------- */
footer{background:var(--ink);color:#a79fb8;padding:60px 0 36px}
.foot-grid{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap}
.foot-brand img{height:40px;margin-bottom:14px}
.foot-brand p{max-width:280px;font-size:.95rem;color:#a79fb8}
.foot-col h4{color:#fff;font-family:'Plus Jakarta Sans';font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.foot-col a{display:block;text-decoration:none;color:#a79fb8;font-size:.95rem;margin-bottom:10px;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-cols{display:flex;gap:56px;flex-wrap:wrap}
.foot-bottom{margin-top:46px;padding-top:22px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.85rem;color:#7a7289}

/* ---------- misc ---------- */
.center{text-align:center}
.mt-32{margin-top:32px}
.pill-row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:18px}
.pill{background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 18px;font-size:.9rem;font-weight:600;color:var(--body)}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero-cta,.eyebrow{justify-content:center}
  .hero p.lead{margin-left:auto;margin-right:auto}
  .hero-art{order:-1;max-width:340px;margin:0 auto}
  .grid-3{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .nav-links{position:fixed;inset:72px 0 auto 0;background:#fff;flex-direction:column;padding:24px;gap:18px;border-bottom:1px solid var(--line);display:none}
  .nav-links.open{display:flex}
  .nav-toggle{display:block}
}
@media(max-width:520px){
  .email-form{flex-direction:column}
  .email-form .btn{width:100%;justify-content:center}
  section{padding:64px 0}
}
