@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap');

/* ── Variables ── */
:root {
  --ink:      #0a0a0a;
  --cream:    #faf9f6;
  --green:    #00AB39;
  --green-dim:#008f30;
  --green-glow:rgba(0,171,57,0.18);
  --clay:     #c97a4a;
  --muted:    #888;
  --border:   rgba(255,255,255,0.08);
  --border-l: rgba(10,10,10,0.1);
  --font-display: 'Bebas Neue', sans-serif;
  --font-body:    'DM Sans', sans-serif;
}

/* ── Reset ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:var(--font-body); background:var(--ink); color:var(--cream); overflow-x:hidden; }
img,svg { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }

/* ── Typography ── */
.display { font-family:var(--font-display); line-height:0.95; letter-spacing:0.01em; }
.eyebrow  { font-size:0.7rem; font-weight:600; letter-spacing:0.18em; text-transform:uppercase; color:var(--green); }
.lead     { font-size:1.15rem; line-height:1.65; font-weight:300; }

/* ── Layout ── */
.container { max-width:1180px; margin:0 auto; padding:0 2rem; }
.section-dark  { background:var(--ink); color:var(--cream); padding:100px 0; }
.section-light { background:var(--cream); color:var(--ink); padding:100px 0; }

/* ── Nav ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:1.25rem 2rem;
  display:flex; align-items:center; justify-content:space-between;
  background:rgba(10,10,10,0.85);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
}
.nav-logo { display:flex; align-items:center; gap:0.6rem; }
.nav-logo-mark {
  width:32px; height:32px;
  background:var(--green);
  border-radius:6px;
  display:flex; align-items:center; justify-content:center;
}
.nav-logo-mark svg { width:18px; height:18px; fill:white; }
.nav-wordmark { font-family:var(--font-display); font-size:1.4rem; letter-spacing:0.05em; }
.nav-wordmark span { color:var(--green); }
.nav-links { display:flex; gap:2rem; align-items:center; }
.nav-links a { font-size:0.88rem; font-weight:500; color:rgba(250,249,246,0.7); transition:color .2s; }
.nav-links a:hover { color:var(--cream); }
.nav-cta {
  background:var(--green); color:white !important;
  padding:0.55rem 1.3rem; border-radius:6px;
  font-size:0.85rem !important; font-weight:600 !important;
  transition:background .2s !important;
}
.nav-cta:hover { background:var(--green-dim) !important; }
.nav-hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; }
.nav-hamburger span { display:block; width:22px; height:2px; background:var(--cream); border-radius:2px; }

/* ── Hero ── */
.hero {
  min-height:100vh;
  display:flex; flex-direction:column; justify-content:center;
  padding-top:80px;
  position:relative; overflow:hidden;
}
.hero-bg {
  position:absolute; inset:0; z-index:0;
  background:var(--ink);
}
.hero-grain {
  position:absolute; inset:0; z-index:1;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
  opacity:0.5; pointer-events:none;
}
.hero-art { position:absolute; right:-4%; top:50%; transform:translateY(-52%); z-index:1; width:min(560px, 55%); opacity:0.9; }
.hero-content { position:relative; z-index:2; padding:4rem 2rem 4rem; max-width:1180px; margin:0 auto; width:100%; }
.hero-hl {
  font-family:var(--font-display);
  font-size:clamp(3.8rem, 8vw, 8rem);
  line-height:0.93;
  max-width:680px;
  margin-bottom:1.5rem;
}
.hero-hl em { color:var(--green); font-style:normal; }
.hero-sub { font-size:1.1rem; font-weight:300; line-height:1.7; max-width:520px; color:rgba(250,249,246,0.75); margin-bottom:2.5rem; }
.hero-stats { display:flex; gap:2.5rem; margin-bottom:2.5rem; flex-wrap:wrap; }
.stat { }
.stat-val { font-family:var(--font-display); font-size:3rem; color:var(--green); line-height:1; }
.stat-label { font-size:0.78rem; color:rgba(250,249,246,0.55); margin-top:0.2rem; letter-spacing:0.04em; }
.hero-actions { display:flex; gap:1rem; align-items:center; flex-wrap:wrap; }
.btn-primary {
  background:var(--green); color:white;
  padding:0.85rem 2rem; border-radius:8px;
  font-size:0.95rem; font-weight:600;
  display:inline-flex; align-items:center; gap:0.5rem;
  transition:background .2s, transform .15s;
}
.btn-primary:hover { background:var(--green-dim); transform:translateY(-1px); }
.btn-ghost {
  color:var(--cream); border:1px solid var(--border);
  padding:0.85rem 2rem; border-radius:8px;
  font-size:0.95rem; font-weight:500;
  transition:border-color .2s, background .2s;
}
.btn-ghost:hover { border-color:rgba(255,255,255,0.25); background:rgba(255,255,255,0.04); }
.hero-trust { margin-top:3rem; font-size:0.78rem; color:rgba(250,249,246,0.35); letter-spacing:0.08em; text-transform:uppercase; }

/* ── How it works ── */
.steps-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2.5rem; margin-top:3rem; }
.step { padding:2.5rem; border:1px solid var(--border-l); border-radius:12px; position:relative; }
.section-light .step { background:white; }
.section-dark .step  { background:rgba(255,255,255,0.03); border-color:var(--border); }
.step-num { font-family:var(--font-display); font-size:5rem; color:var(--green); opacity:0.18; line-height:1; margin-bottom:1rem; }
.step h3  { font-size:1.15rem; font-weight:600; margin-bottom:0.6rem; }
.step p   { font-size:0.9rem; line-height:1.65; opacity:0.7; }

/* ── Features ── */
.feature-block { padding:80px 0; }
.feature-inner { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; max-width:1180px; margin:0 auto; padding:0 2rem; }
.feature-inner.reverse { direction:rtl; }
.feature-inner.reverse > * { direction:ltr; }
.feature-tag { display:inline-block; background:var(--green-glow); color:var(--green); padding:0.25rem 0.8rem; border-radius:4px; font-size:0.7rem; font-weight:600; letter-spacing:0.15em; text-transform:uppercase; margin-bottom:1rem; }
.feature-inner h2 { font-family:var(--font-display); font-size:clamp(2rem,4vw,3.5rem); line-height:1.0; margin-bottom:1rem; }
.feature-inner p  { font-size:1rem; line-height:1.75; opacity:0.75; }
.feature-tier { font-size:0.78rem; font-weight:500; margin-top:1.5rem; opacity:0.5; }
.screenshot-box {
  aspect-ratio:16/10;
  border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--border);
  overflow:hidden;
  position:relative;
}
.screenshot-box .ss-label {
  position:absolute; bottom:1rem; left:50%; transform:translateX(-50%);
  font-size:0.72rem; opacity:0.35; white-space:nowrap;
  letter-spacing:0.06em;
}

/* ── Comparison table ── */
.comparison-wrap { overflow-x:auto; margin-top:3rem; }
.comparison-table { width:100%; border-collapse:collapse; min-width:680px; }
.comparison-table th,
.comparison-table td { padding:1rem 1.25rem; font-size:0.88rem; border-bottom:1px solid var(--border); text-align:left; }
.comparison-table th { font-weight:600; font-size:0.72rem; letter-spacing:0.1em; text-transform:uppercase; color:rgba(250,249,246,0.45); }
.comparison-table .us td { background:rgba(0,171,57,0.06); }
.comparison-table .us td:first-child { color:var(--green); font-weight:600; }
.comparison-table td.check { color:var(--green); font-weight:700; }
.comparison-table td.cross { color:#e05252; }
.section-light .comparison-table th { color:rgba(10,10,10,0.4); }
.section-light .comparison-table th,
.section-light .comparison-table td { border-color:var(--border-l); }
.section-light .comparison-table .us td { background:rgba(0,171,57,0.06); }

/* ── Pricing ── */
.pricing-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; margin-top:3rem; }
.pricing-card {
  border:1px solid var(--border-l); border-radius:12px;
  padding:2rem 1.75rem;
  display:flex; flex-direction:column;
  background:white;
  transition:box-shadow .2s, transform .2s;
}
.section-dark .pricing-card { background:rgba(255,255,255,0.03); border-color:var(--border); }
.pricing-card:hover { transform:translateY(-4px); box-shadow:0 24px 60px rgba(0,0,0,0.12); }
.pricing-card.featured { border-color:var(--green); box-shadow:0 0 0 1px var(--green), 0 24px 60px rgba(0,171,57,0.1); }
.pricing-tier { font-size:0.72rem; font-weight:600; letter-spacing:0.15em; text-transform:uppercase; color:var(--green); margin-bottom:0.75rem; }
.pricing-price { font-family:var(--font-display); font-size:3.5rem; line-height:1; margin-bottom:0.2rem; }
.pricing-period { font-size:0.8rem; opacity:0.45; margin-bottom:1.75rem; }
.pricing-features { list-style:none; flex:1; margin-bottom:2rem; }
.pricing-features li { font-size:0.85rem; padding:0.5rem 0; border-bottom:1px solid var(--border-l); display:flex; align-items:flex-start; gap:0.6rem; line-height:1.5; }
.section-dark .pricing-features li { border-color:var(--border); }
.pricing-features li::before { content:"✓"; color:var(--green); font-weight:700; flex-shrink:0; margin-top:0.05rem; }
.btn-plan { display:block; text-align:center; padding:0.75rem 1rem; border-radius:8px; font-size:0.88rem; font-weight:600; transition:background .2s, color .2s; }
.btn-plan-outline { border:1px solid currentColor; }
.btn-plan-outline:hover { background:var(--green); color:white; border-color:var(--green); }
.btn-plan-fill { background:var(--green); color:white; }
.btn-plan-fill:hover { background:var(--green-dim); }

/* ── Early adopter CTA ── */
.cta-band { padding:100px 0; text-align:center; position:relative; overflow:hidden; }
.cta-band h2 { font-family:var(--font-display); font-size:clamp(2.5rem,6vw,6rem); max-width:800px; margin:0 auto 1.5rem; }
.cta-band p  { max-width:480px; margin:0 auto 2.5rem; opacity:0.65; }

/* ── FAQ ── */
.faq-list { max-width:760px; margin:3rem auto 0; }
.faq-item { border-bottom:1px solid var(--border-l); }
.section-dark .faq-item { border-color:var(--border); }
.faq-q {
  width:100%; text-align:left; background:none; border:none; cursor:pointer;
  padding:1.4rem 0; display:flex; justify-content:space-between; align-items:center;
  font-family:var(--font-body); font-size:1rem; font-weight:500;
  color:inherit;
}
.faq-q .icon { font-size:1.2rem; transition:transform .3s; opacity:0.5; }
.faq-item.open .icon { transform:rotate(45deg); opacity:1; }
.faq-a { overflow:hidden; max-height:0; transition:max-height .35s ease; }
.faq-a p { padding-bottom:1.4rem; font-size:0.92rem; line-height:1.7; opacity:0.7; }

/* ── Vertical pages ── */
.vertical-hero { padding:160px 2rem 80px; text-align:center; max-width:900px; margin:0 auto; }
.vertical-hero h1 { font-family:var(--font-display); font-size:clamp(3rem,7vw,7rem); line-height:0.93; margin-bottom:1.25rem; }
.vertical-hero p  { font-size:1.1rem; opacity:0.7; max-width:560px; margin:0 auto 2rem; }
.vertical-features { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:3rem; }
.vf-card { padding:2rem; border:1px solid var(--border-l); border-radius:12px; background:white; }
.section-dark .vf-card { background:rgba(255,255,255,0.03); border-color:var(--border); }
.vf-icon { width:40px; height:40px; background:var(--green-glow); border-radius:8px; display:flex; align-items:center; justify-content:center; margin-bottom:1rem; }
.vf-icon svg { width:22px; height:22px; stroke:var(--green); fill:none; stroke-width:2; }
.vf-card h3 { font-size:1rem; font-weight:600; margin-bottom:0.5rem; }
.vf-card p  { font-size:0.87rem; line-height:1.65; opacity:0.65; }
.testimonial-placeholder { max-width:600px; margin:4rem auto 0; padding:2.5rem; border:1px dashed rgba(0,171,57,0.3); border-radius:12px; text-align:center; }
.testimonial-placeholder p { font-size:0.8rem; opacity:0.35; }

/* ── Contact ── */
.contact-form { max-width:560px; margin:3rem auto 0; }
.form-row { margin-bottom:1.25rem; }
.form-row label { display:block; font-size:0.82rem; font-weight:500; margin-bottom:0.4rem; opacity:0.7; }
.form-row input,
.form-row textarea,
.form-row select {
  width:100%; padding:0.85rem 1rem; border-radius:8px; border:1px solid var(--border);
  background:rgba(255,255,255,0.04); color:var(--cream);
  font-family:var(--font-body); font-size:0.92rem; outline:none;
  transition:border-color .2s;
}
.section-light .form-row input,
.section-light .form-row textarea { background:white; border-color:var(--border-l); color:var(--ink); }
.form-row input:focus,
.form-row textarea:focus { border-color:var(--green); }
.form-row textarea { resize:vertical; min-height:140px; }

/* ── Footer ── */
footer {
  background:var(--ink); border-top:1px solid var(--border);
  padding:3rem 2rem; text-align:center;
}
.footer-logo { font-family:var(--font-display); font-size:1.8rem; letter-spacing:0.05em; margin-bottom:1rem; }
.footer-logo span { color:var(--green); }
.footer-links { display:flex; gap:2rem; justify-content:center; flex-wrap:wrap; margin-bottom:1.5rem; }
.footer-links a { font-size:0.82rem; opacity:0.4; transition:opacity .2s; }
.footer-links a:hover { opacity:0.8; }
.footer-meta { font-size:0.75rem; opacity:0.25; line-height:1.8; }

/* ── Section titles ── */
.section-title { font-family:var(--font-display); font-size:clamp(2.2rem,5vw,4.5rem); max-width:700px; }
.section-sub { margin-top:1rem; max-width:560px; opacity:0.65; line-height:1.7; }

/* ── Breadcrumb for sub-pages ── */
.breadcrumb { padding:90px 2rem 0; max-width:1180px; margin:0 auto; }
.breadcrumb a { font-size:0.8rem; opacity:0.4; transition:opacity .2s; }
.breadcrumb a:hover { opacity:0.7; }
.breadcrumb span { font-size:0.8rem; opacity:0.4; padding:0 0.5rem; }

/* ── Responsive ── */
@media (max-width:900px) {
  .hero-art { display:none; }
  .feature-inner { grid-template-columns:1fr; gap:2.5rem; }
  .feature-inner.reverse { direction:ltr; }
  .steps-grid { grid-template-columns:1fr; }
  .pricing-grid { grid-template-columns:repeat(2,1fr); }
  .vertical-features { grid-template-columns:1fr 1fr; }
  nav .nav-links { display:none; }
  .nav-hamburger { display:flex; }
}
@media (max-width:600px) {
  .pricing-grid { grid-template-columns:1fr; }
  .vertical-features { grid-template-columns:1fr; }
  .hero-stats { gap:1.5rem; }
  .steps-grid { gap:1.5rem; }
}

/* ── Page-load fade ── */
@keyframes fadeUp { from { opacity:0; transform:translateY(24px); } to { opacity:1; transform:none; } }
.fade-up { animation: fadeUp 0.7s ease both; }
.fade-up-1 { animation-delay:0.1s; }
.fade-up-2 { animation-delay:0.22s; }
.fade-up-3 { animation-delay:0.34s; }
.fade-up-4 { animation-delay:0.46s; }
.fade-up-5 { animation-delay:0.58s; }
