/* ── VinGreen Sales Page — matches vingreentech.com theme ──────── */

/* ── Reset & Base ──────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

:root {
  --green:      #36b626;
  --green-dk:   #2a9a1e;
  --green-lt:   #e8f8e6;
  --green-mid:  #d4f0d1;
  --dark:       #232323;
  --body:       #616161;
  --light-bg:   #f7f9f7;
  --white:      #ffffff;
  --border:     #e8e8e8;
  --shadow:     0 4px 24px rgba(0,0,0,.09);
  --shadow-hv:  0 8px 40px rgba(54,182,38,.18);
  --radius:     8px;
  --radius-pill:30px;
  --max:        1200px;
  --ease:       .3s ease;
}

body {
  font-family: 'Open Sans', 'Segoe UI', system-ui, -apple-system, sans-serif;
  background: var(--white);
  color: var(--body);
  line-height: 1.7;
  font-size: 15px;
  -webkit-font-smoothing: antialiased;
}

a { text-decoration: none; transition: color var(--ease); }
img { max-width: 100%; display: block; }
ul { list-style: none; }

/* ── Layout ────────────────────────────────────────────────────── */
.container { max-width: var(--max); margin: 0 auto; padding: 0 20px; }
.row   { display: flex; flex-wrap: wrap; margin: 0 -15px; }
.col   { padding: 0 15px; flex: 1 1 0; }
.tc { text-align: center; }
.pt-80 { padding-top: 80px; }
.pb-70 { padding-bottom: 70px; }
.mb-50 { margin-bottom: 50px; }

/* ── Scroll reveal ─────────────────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .6s ease, transform .6s ease;
}
.reveal.in-view {
  opacity: 1;
  transform: translateY(0);
}

/* ── VinGreen Topbar ───────────────────────────────────────────── */
.topbar {
  background: var(--green);
  padding: 10px 0;
  font-size: 13px;
  color: #fff;
}
.topbar-inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: .5rem; }
.topbar a { color: #fff; }
.topbar a:hover { color: #d4f0d1; }
.topbar-contact { display: flex; align-items: center; flex-wrap: wrap; gap: 4px 16px; }
.topbar-contact a { display: flex; align-items: center; gap: 6px; }
.topbar-social { display: flex; align-items: center; gap: 8px; }
.topbar-social a { font-size: 14px; }

/* ── Navigation ────────────────────────────────────────────────── */
.main-nav {
  background: var(--white);
  border-bottom: 1px dashed var(--green);
  position: sticky; top: 0; z-index: 500;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
  transition: box-shadow var(--ease);
}
.main-nav.scrolled {
  box-shadow: 0 4px 20px rgba(0,0,0,.12);
}
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 80px; }
.nav-logo-text {
  font-size: 22px; font-weight: 800; color: var(--dark);
  display: flex; align-items: center; gap: 10px; flex-shrink: 0;
}
.nav-logo-text span { color: var(--green); }
.nav-logo-icon {
  width: 40px; height: 40px; border-radius: 10px;
  background: var(--green); display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 18px;
}
.nav-menu { display: flex; align-items: center; gap: 4px; }
.nav-menu a {
  color: var(--dark); font-size: 14px; font-weight: 600;
  padding: 8px 12px; border-radius: 4px; transition: color var(--ease);
}
.nav-menu a:hover { color: var(--green); }
.nav-cta {
  background: var(--green); color: #fff !important;
  padding: 10px 24px !important; border-radius: var(--radius-pill) !important;
  border: 2px solid var(--green); transition: all var(--ease) !important;
  margin-left: 4px;
}
.nav-cta:hover { background: var(--green-dk) !important; border-color: var(--green-dk) !important; }

/* ── Hamburger ─────────────────────────────────────────────────── */
.hamburger {
  display: none;
  flex-direction: column; justify-content: center; align-items: center;
  width: 44px; height: 44px; gap: 5px;
  background: none; border: none; cursor: pointer; padding: 4px;
  border-radius: 6px; transition: background var(--ease);
}
.hamburger:hover { background: var(--green-lt); }
.hamburger span {
  display: block; width: 24px; height: 2px;
  background: var(--dark); border-radius: 2px;
  transition: transform .3s ease, opacity .3s ease;
  transform-origin: center;
}
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── Section Title ─────────────────────────────────────────────── */
.section-title { margin-bottom: 50px; }
.section-title .sub { font-size: 13px; font-weight: 700; color: var(--green); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 8px; }
.section-title h2 { font-size: 36px; font-weight: 800; color: var(--dark); line-height: 1.2; margin-bottom: 12px; }
.section-title h2 span { color: var(--green); }
.section-title p { font-size: 15px; color: var(--body); max-width: 580px; }
.section-title.tc p { margin: 0 auto; }
.em-bar { display: inline-block; width: 80px; height: 4px; background: var(--green); border-radius: 4px; margin: 12px 0 16px; position: relative; }
.em-bar::before {
  content: ''; position: absolute; left: -8px; top: -4px;
  width: 12px; height: 12px; border-radius: 50%; background: var(--green); opacity: .4;
}
.em-bar::after {
  content: ''; position: absolute; right: -8px; top: -4px;
  width: 12px; height: 12px; border-radius: 50%; background: var(--green); opacity: .4;
}

/* ── Buttons ───────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 34px; border-radius: var(--radius-pill);
  font-size: 16px; font-weight: 600; cursor: pointer;
  border: 2px solid transparent; transition: all var(--ease);
  line-height: 1;
}
.btn-primary { background: var(--green); color: #fff; border-color: var(--green); }
.btn-primary:hover { background: var(--green-dk); border-color: var(--green-dk); color: #fff; box-shadow: var(--shadow-hv); }
.btn-outline { background: transparent; color: var(--green); border-color: var(--green); }
.btn-outline:hover { background: var(--green); color: #fff; }
.btn-white { background: #fff; color: var(--green); border-color: #fff; }
.btn-white:hover { background: var(--green); color: #fff; border-color: var(--green); }

/* ── Hero / Banner ─────────────────────────────────────────────── */
.hero {
  background: linear-gradient(135deg, #0a2a06 0%, #0f3a09 40%, #1a5210 100%);
  position: relative; overflow: hidden; padding: 100px 0 80px;
}
.hero::before {
  content: ''; position: absolute; inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%2336b626' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.hero-content { position: relative; z-index: 2; }
.hero-eyebrow {
  display: inline-block; background: rgba(255,255,255,.12); color: #a3f09a;
  border: 1px solid rgba(54,182,38,.4); padding: 6px 18px; border-radius: 999px;
  font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  margin-bottom: 20px;
}
.hero h1 {
  font-size: clamp(2rem, 5vw, 3.2rem); font-weight: 800; color: #fff;
  line-height: 1.15; margin-bottom: 18px; letter-spacing: -.01em;
}
.hero h1 span { color: var(--green); }
.hero-sub { font-size: 17px; color: rgba(255,255,255,.8); max-width: 600px; margin-bottom: 36px; line-height: 1.75; }
.hero-btns { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 36px; }
.hero-trust { display: flex; gap: 20px; flex-wrap: wrap; }
.hero-trust span { display: flex; align-items: center; gap: 7px; color: rgba(255,255,255,.75); font-size: 13px; font-weight: 500; }
.hero-trust i { color: var(--green); font-size: 15px; }
.hero-visual { display: flex; justify-content: flex-end; }

/* Architecture card */
.arch-box {
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15);
  border-radius: 12px; padding: 28px 24px;
  backdrop-filter: blur(8px); width: 100%; max-width: 460px;
}
.arch-box h4 { color: #fff; font-size: 15px; font-weight: 700; margin-bottom: 20px; display: flex; align-items: center; gap: 8px; }
.arch-box h4 i { color: var(--green); }
.arch-flow { display: flex; flex-direction: column; gap: 10px; }
.arch-step {
  display: flex; align-items: center; gap: 12px;
  background: rgba(255,255,255,.06); border-radius: 8px; padding: 12px 14px;
  border: 1px solid rgba(255,255,255,.08);
}
.arch-step i { color: var(--green); width: 22px; text-align: center; font-size: 16px; }
.arch-step .as-text { flex: 1; }
.arch-step .as-name { font-size: 13px; font-weight: 700; color: #fff; }
.arch-step .as-desc { font-size: 11px; color: rgba(255,255,255,.55); }
.arch-arrow { text-align: center; color: var(--green); font-size: 16px; margin: 2px 0; }
.arch-note { margin-top: 14px; padding: 10px 14px; background: rgba(54,182,38,.15); border-radius: 6px; border-left: 3px solid var(--green); font-size: 12px; color: rgba(255,255,255,.75); }
.arch-note strong { color: var(--green); }

/* ── Stats counter ─────────────────────────────────────────────── */
.stats-area { background: var(--green); padding: 50px 0; }
.stats-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; text-align: center; }
.stat-item { border-right: 1px solid rgba(255,255,255,.2); padding: 10px 20px; }
.stat-item:last-child { border-right: none; }
.stat-num {
  font-size: 48px; font-weight: 800; color: #fff; line-height: 1;
  display: flex; align-items: baseline; justify-content: center; gap: 2px;
}
.stat-unit { font-size: 22px; font-weight: 700; color: rgba(255,255,255,.85); }
.stat-label { font-size: 13px; color: rgba(255,255,255,.85); margin-top: 8px; }

/* ── How it works ──────────────────────────────────────────────── */
.work-area { background: var(--white); }
.work-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 30px; }
.work-card {
  text-align: center; padding: 40px 28px;
  border: 1px solid var(--border); border-radius: var(--radius);
  background: var(--white); transition: all var(--ease);
  position: relative;
}
.work-card:hover { box-shadow: var(--shadow-hv); border-color: var(--green); transform: translateY(-4px); }
.work-num {
  position: absolute; top: -16px; left: 50%; transform: translateX(-50%);
  width: 32px; height: 32px; background: var(--green); color: #fff;
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 800; box-shadow: 0 4px 12px rgba(54,182,38,.35);
}
.work-icon {
  width: 80px; height: 80px; margin: 0 auto 20px;
  background: var(--green-lt); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 32px; color: var(--green); transition: all var(--ease);
}
.work-card:hover .work-icon { background: var(--green); color: #fff; }
.work-card h4 { font-size: 17px; font-weight: 700; color: var(--dark); margin-bottom: 12px; }
.work-card p  { font-size: 14px; color: var(--body); line-height: 1.7; }

/* ── Dashboard mockup ──────────────────────────────────────────── */
.mockup-outer { border-radius: 12px; overflow: hidden; box-shadow: var(--shadow); border: 1px solid var(--border); }
.mock-bar { display: flex; align-items: center; gap: 6px; background: #f1f1f1; padding: 10px 16px; border-bottom: 1px solid var(--border); }
.mdot { width: 12px; height: 12px; border-radius: 50%; }
.md-r{background:#ef4444;} .md-y{background:#f59e0b;} .md-g{background:#22c55e;}
.mock-url { flex: 1; background: #fff; border-radius: 6px; padding: 4px 14px; font-size: 12px; color: #888; margin: 0 10px; border: 1px solid #e0e0e0; }
.mock-body { display: flex; background: #fff; min-height: 260px; }
.mock-side { width: 160px; background: #f8faf8; border-right: 1px solid var(--border); padding: 16px 10px; flex-shrink: 0; }
.ms-brand { font-size: 13px; font-weight: 800; color: var(--green); padding: 8px; margin-bottom: 12px; display: flex; align-items: center; gap: 6px; }
.ms-item { display: flex; align-items: center; gap: 8px; padding: 8px 10px; border-radius: 6px; font-size: 12px; color: var(--body); margin-bottom: 2px; }
.ms-item.on { background: var(--green-lt); color: var(--green); font-weight: 700; }
.ms-item i { width: 14px; text-align: center; }
.ms-sep { height: 1px; background: var(--border); margin: 8px 4px; }
.mock-main { flex: 1; padding: 16px 20px; }
.mock-kpis { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; margin-bottom: 14px; }
.m-kpi { background: var(--light-bg); border: 1px solid var(--border); border-radius: 8px; padding: 10px 12px; }
.mk-n { font-size: 18px; font-weight: 800; color: var(--dark); }
.mk-n.cg{color:var(--green);} .mk-n.ca{color:#f59e0b;} .mk-n.cb{color:#3b82f6;}
.mk-l { font-size: 10px; color: var(--body); margin-top: 2px; }
.mock-job { display: flex; align-items: center; gap: 10px; background: var(--light-bg); border: 1px solid var(--border); border-radius: 6px; padding: 8px 12px; margin-bottom: 6px; font-size: 12px; }
.mj-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.mj-n { flex: 1; font-weight: 600; color: var(--dark); }
.mj-a { color: var(--body); font-size: 11px; }
.mj-t { color: var(--body); margin-left: auto; font-size: 11px; padding-left: 8px; }
.mj-b { padding: 2px 8px; border-radius: 999px; font-size: 10px; font-weight: 700; }
.bk-ok  { background: #dcfce7; color: #16a34a; }
.bk-run { background: #dbeafe; color: #2563eb; }
.bk-due { background: #fef3c7; color: #d97706; }

/* ── Features ──────────────────────────────────────────────────── */
.feat-area { background: var(--light-bg); }
.feat-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.feat-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 32px 28px; transition: all var(--ease);
}
.feat-card:hover { box-shadow: var(--shadow-hv); border-color: var(--green); transform: translateY(-4px); }
.feat-icon {
  width: 60px; height: 60px; border-radius: 50%; margin-bottom: 20px;
  background: var(--green-lt); display: flex; align-items: center; justify-content: center;
  font-size: 22px; color: var(--green); transition: all var(--ease);
}
.feat-card:hover .feat-icon { background: var(--green); color: #fff; }
.feat-card h4 { font-size: 17px; font-weight: 700; color: var(--dark); margin-bottom: 10px; }
.feat-card p  { font-size: 14px; color: var(--body); line-height: 1.7; }

/* ── Use cases ─────────────────────────────────────────────────── */
.uc-area { background: var(--white); }
.uc-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 24px; }
.uc-card {
  display: flex; gap: 18px; align-items: flex-start;
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 28px; transition: all var(--ease);
}
.uc-card:hover { box-shadow: var(--shadow-hv); border-color: var(--green); }
.uc-icon-wrap {
  width: 56px; height: 56px; border-radius: 50%; flex-shrink: 0;
  background: var(--green-lt); display: flex; align-items: center; justify-content: center;
  font-size: 22px; color: var(--green);
}
.uc-card h4 { font-size: 16px; font-weight: 700; color: var(--dark); margin-bottom: 8px; }
.uc-card p  { font-size: 14px; color: var(--body); line-height: 1.7; }

/* ── Testimonials ──────────────────────────────────────────────── */
.testi-area { background: var(--light-bg); }
.testi-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px; }
.testi-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 32px 28px;
  transition: all var(--ease); display: flex; flex-direction: column;
}
.testi-card:hover { box-shadow: var(--shadow-hv); border-color: var(--green); transform: translateY(-4px); }
.testi-quote { font-size: 28px; color: var(--green); margin-bottom: 12px; line-height: 1; }
.testi-stars { display: flex; gap: 3px; margin-bottom: 16px; }
.testi-stars i { color: #f59e0b; font-size: 14px; }
.testi-text {
  font-size: 14px; color: var(--body); line-height: 1.75;
  font-style: italic; flex: 1; margin-bottom: 24px;
}
.testi-author { display: flex; align-items: center; gap: 14px; }
.testi-avatar {
  width: 46px; height: 46px; border-radius: 50%; flex-shrink: 0;
  background: var(--green); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; font-weight: 800; letter-spacing: .03em;
}
.testi-name { font-size: 14px; font-weight: 700; color: var(--dark); }
.testi-role { font-size: 12px; color: var(--body); margin-top: 2px; }

/* ── Pricing ───────────────────────────────────────────────────── */
.pricing-area { background: var(--white); }
.pricing-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.price-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 36px 30px;
  transition: all var(--ease); display: flex; flex-direction: column;
}
.price-card.featured {
  background: var(--green); border-color: var(--green);
  transform: scale(1.03);
  box-shadow: 0 16px 48px rgba(54,182,38,.3);
}
.price-card.featured h3,
.price-card.featured p,
.price-card.featured .price-amount,
.price-card.featured li { color: #fff !important; }
.price-card.featured .price-divider { background: rgba(255,255,255,.25); }
.price-card.featured li::before { color: rgba(255,255,255,.8) !important; }
.price-card.featured .price-note { color: rgba(255,255,255,.75) !important; }
.price-badge {
  display: inline-block; background: #fff; color: var(--green);
  font-size: 11px; font-weight: 800; padding: 4px 14px;
  border-radius: 999px; margin-bottom: 16px;
  text-transform: uppercase; letter-spacing: .06em;
}
.price-card h3 { font-size: 20px; font-weight: 800; color: var(--dark); margin-bottom: 6px; }
.price-card .tagline { font-size: 13px; color: var(--body); margin-bottom: 18px; }
.price-amount { font-size: 28px; font-weight: 800; color: var(--dark); margin-bottom: 4px; }
.price-amount .unit { font-size: 14px; font-weight: 400; color: var(--body); }
.price-note { font-size: 12px; color: var(--body); margin-bottom: 18px; }
.price-divider { height: 1px; background: var(--border); margin-bottom: 18px; }
.price-list { margin-bottom: 28px; display: flex; flex-direction: column; gap: 10px; }
.price-list li { font-size: 14px; color: var(--body); display: flex; align-items: flex-start; gap: 8px; }
.price-list li::before { content: '\f00c'; font-family: 'Font Awesome 5 Free'; font-weight: 900; color: var(--green); flex-shrink: 0; font-size: 12px; margin-top: 2px; }
.price-card.featured .price-list li::before { color: rgba(255,255,255,.9); }
.price-cta { margin-top: auto; }

/* ── Compare table ─────────────────────────────────────────────── */
.compare-area { background: var(--light-bg); }
.table-wrap { overflow-x: auto; border-radius: var(--radius); border: 1px solid var(--border); }
table { width: 100%; border-collapse: collapse; }
thead th {
  padding: 14px 16px; text-align: left; font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em; background: var(--light-bg);
  border-bottom: 2px solid var(--border); color: var(--body);
}
thead th.hl { color: var(--green); background: var(--green-lt); }
tbody td { padding: 13px 16px; border-bottom: 1px solid #f0f0f0; font-size: 14px; }
tbody tr:last-child td { border-bottom: none; }
tbody tr:hover td { background: #fafff9; }
.td-hl { background: var(--green-lt) !important; }
.chk  { color: var(--green); font-weight: 700; }
.cross{ color: #ccc; }
.part { color: #f59e0b; }

/* ── FAQ accordion ─────────────────────────────────────────────── */
.faq-area { background: var(--white); }
.faq-list { max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; gap: 12px; }
.faq-item {
  border: 1px solid var(--border); border-radius: var(--radius);
  overflow: hidden; transition: border-color var(--ease);
}
.faq-item.open { border-color: var(--green); }
.faq-question {
  width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 18px 22px; background: var(--white); border: none; cursor: pointer;
  font-family: inherit; font-size: 15px; font-weight: 700; color: var(--dark);
  text-align: left; transition: background var(--ease), color var(--ease);
}
.faq-question:hover { background: var(--green-lt); color: var(--green); }
.faq-item.open .faq-question { background: var(--green-lt); color: var(--green); }
.faq-icon { flex-shrink: 0; font-size: 14px; color: var(--green); transition: transform .3s ease; }
.faq-item.open .faq-icon { transform: rotate(180deg); }
.faq-answer {
  max-height: 0; overflow: hidden;
  transition: max-height .35s ease, padding .35s ease;
  padding: 0 22px;
}
.faq-item.open .faq-answer {
  max-height: 400px;
  padding: 0 22px 20px;
}
.faq-answer p { font-size: 14px; color: var(--body); line-height: 1.8; }

/* ── Contact ───────────────────────────────────────────────────── */
.contact-area { background: var(--light-bg); }
.contact-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 50px; }
.contact-info h3 { font-size: 24px; font-weight: 800; color: var(--dark); margin-bottom: 12px; }
.contact-info p { font-size: 15px; color: var(--body); line-height: 1.75; margin-bottom: 28px; }
.contact-item {
  display: flex; align-items: center; gap: 16px;
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 16px 20px; margin-bottom: 14px;
  transition: all var(--ease);
}
.contact-item:hover { border-color: var(--green); box-shadow: 0 4px 16px rgba(54,182,38,.12); }
.ci-icon {
  width: 48px; height: 48px; border-radius: 50%; flex-shrink: 0;
  background: var(--green-lt); display: flex; align-items: center; justify-content: center;
  font-size: 18px; color: var(--green);
}
.ci-label { font-size: 11px; font-weight: 700; color: var(--body); text-transform: uppercase; letter-spacing: .06em; }
.ci-val { font-size: 15px; font-weight: 700; color: var(--dark); }
.ci-val a { color: var(--dark); }
.ci-val a:hover { color: var(--green); }
.contact-form-box {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 36px; box-shadow: var(--shadow);
}
.contact-form-box h4 { font-size: 20px; font-weight: 800; color: var(--dark); margin-bottom: 24px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.form-group label { font-size: 13px; font-weight: 700; color: var(--dark); }
.form-group input,
.form-group select,
.form-group textarea {
  padding: 12px 16px; border: 1px solid var(--border); border-radius: var(--radius);
  font-size: 14px; color: var(--dark); font-family: inherit;
  outline: none; transition: border-color var(--ease); width: 100%;
  background: var(--white);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color: var(--green); box-shadow: 0 0 0 3px rgba(54,182,38,.1); }
.form-group textarea { resize: vertical; min-height: 100px; }
.form-note { font-size: 12px; color: var(--body); margin-top: 10px; }

/* ── CTA strip ─────────────────────────────────────────────────── */
.cta-strip {
  background: linear-gradient(135deg, #0a2a06, #1a5210);
  padding: 70px 0; text-align: center; position: relative; overflow: hidden;
}
.cta-strip::before {
  content: ''; position: absolute; inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%2336b626' fill-opacity='0.06'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.cta-strip .cta-inner { position: relative; z-index: 2; }
.cta-strip h2 { font-size: clamp(1.8rem, 4vw, 2.5rem); font-weight: 800; color: #fff; margin-bottom: 14px; }
.cta-strip p { color: rgba(255,255,255,.8); font-size: 16px; margin-bottom: 32px; }
.cta-btns { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.cta-trust { display: flex; gap: 24px; justify-content: center; flex-wrap: wrap; margin-top: 24px; }
.cta-trust span { color: rgba(255,255,255,.75); font-size: 13px; display: flex; align-items: center; gap: 6px; }
.cta-trust i { color: var(--green); }

/* ── Footer ────────────────────────────────────────────────────── */
footer { background: #0d1f0a; padding: 60px 0 0; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 40px; }
.f-brand .f-logo { font-size: 20px; font-weight: 800; color: #fff; margin-bottom: 16px; display: flex; align-items: center; gap: 10px; }
.f-logo-icon { width: 36px; height: 36px; border-radius: 9px; background: var(--green); display: flex; align-items: center; justify-content: center; font-size: 16px; color: #fff; }
.f-brand p { font-size: 14px; color: rgba(255,255,255,.55); line-height: 1.75; margin-bottom: 20px; max-width: 240px; }
.f-social { display: flex; gap: 10px; flex-wrap: wrap; }
.f-social a {
  width: 36px; height: 36px; border-radius: 50%; background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1); display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.65); font-size: 14px; transition: all var(--ease);
}
.f-social a:hover { background: var(--green); border-color: var(--green); color: #fff; }
.footer-col h5 { font-size: 14px; font-weight: 800; color: #fff; margin-bottom: 18px; position: relative; padding-bottom: 12px; }
.footer-col h5::after { content: ''; position: absolute; bottom: 0; left: 0; width: 36px; height: 2px; background: var(--green); border-radius: 2px; }
.footer-col a { display: flex; align-items: center; gap: 8px; color: rgba(255,255,255,.55); font-size: 14px; margin-bottom: 10px; transition: color var(--ease); }
.footer-col a i { color: var(--green); width: 14px; font-size: 12px; }
.footer-col a:hover { color: var(--green); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.08); padding: 20px 0; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.footer-bottom p { font-size: 13px; color: rgba(255,255,255,.4); }
.footer-bottom a { color: var(--green); }

/* ── WhatsApp float button ─────────────────────────────────────── */
.wa-float {
  position: fixed; bottom: 88px; right: 24px; z-index: 1000;
  width: 56px; height: 56px; border-radius: 50%;
  background: #25d366; color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 28px;
  box-shadow: 0 4px 16px rgba(37,211,102,.45);
  transition: transform var(--ease), box-shadow var(--ease);
  animation: wa-pulse 2.5s ease-in-out infinite;
}
.wa-float:hover {
  color: #fff;
  transform: scale(1.1);
  box-shadow: 0 6px 24px rgba(37,211,102,.6);
  animation: none;
}
@keyframes wa-pulse {
  0%, 100% { box-shadow: 0 4px 16px rgba(37,211,102,.45); }
  50%       { box-shadow: 0 4px 28px rgba(37,211,102,.75); }
}

/* ── Scroll-to-top button ──────────────────────────────────────── */
.scroll-top {
  position: fixed; bottom: 24px; right: 24px; z-index: 1000;
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--green); color: #fff; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px;
  box-shadow: 0 4px 14px rgba(54,182,38,.4);
  opacity: 0; pointer-events: none;
  transition: opacity .3s ease, transform .3s ease, box-shadow .3s ease;
  transform: translateY(10px);
}
.scroll-top.visible {
  opacity: 1; pointer-events: auto; transform: translateY(0);
}
.scroll-top:hover {
  background: var(--green-dk);
  box-shadow: 0 6px 20px rgba(54,182,38,.55);
  transform: translateY(-2px);
}

/* ── Responsive 992px ──────────────────────────────────────────── */
@media (max-width: 992px) {
  .feat-grid { grid-template-columns: repeat(2,1fr); }
  .work-grid { grid-template-columns: repeat(2,1fr); }
  .pricing-grid { grid-template-columns: 1fr 1fr; }
  .price-card.featured { transform: none; }
  .stats-grid { grid-template-columns: repeat(2,1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .f-brand { grid-column: 1 / -1; }
  .contact-grid { grid-template-columns: 1fr; }
  .hero .row { flex-direction: column; }
  .hero-visual { justify-content: flex-start; margin-top: 32px; }
  .arch-box { max-width: 100%; }
  .testi-grid { grid-template-columns: repeat(2,1fr); }
}

/* ── Responsive 768px ──────────────────────────────────────────── */
@media (max-width: 768px) {
  .hero { padding: 60px 0 50px; }
  .hero h1 { font-size: 2rem; }
  .feat-grid, .work-grid, .uc-grid, .pricing-grid, .testi-grid { grid-template-columns: 1fr; }
  .price-card.featured { transform: none; }
  .stats-grid { grid-template-columns: repeat(2,1fr); }
  .mock-side { display: none; }
  .mock-kpis { grid-template-columns: repeat(2,1fr); }
  .section-title h2 { font-size: 26px; }
  .footer-grid { grid-template-columns: 1fr; gap: 28px; }
  .form-row { grid-template-columns: 1fr; }
  .topbar-inner { justify-content: center; }
  .footer-bottom { flex-direction: column; text-align: center; }

  /* Mobile nav */
  .hamburger { display: flex; }
  .nav-menu {
    display: none;
    position: absolute; top: 100%; left: 0; right: 0;
    background: var(--white);
    border-top: 1px dashed var(--green);
    border-bottom: 1px solid var(--border);
    padding: 12px 20px 20px;
    flex-direction: column; align-items: flex-start; gap: 4px;
    box-shadow: 0 8px 24px rgba(0,0,0,.1);
  }
  .nav-menu.open { display: flex; }
  .nav-menu a { width: 100%; padding: 10px 14px; border-radius: 6px; }
  .nav-cta { margin-left: 0 !important; text-align: center; }
  .main-nav { position: sticky; }
}


/* ═══════════════════════════════════════════════════════════════════
   DEMO VIDEO PLAYER
   ═══════════════════════════════════════════════════════════════════ */

.demo-area { background: var(--light-bg); }

.demo-player {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 12px 48px rgba(0,0,0,.12);
}

.demo-bar {
  display: flex; align-items: center; gap: 8px;
  background: #f1f3f4; padding: 10px 16px;
  border-bottom: 1px solid var(--border); flex-wrap: wrap;
}
.demo-url {
  flex: 1; background: #fff; border: 1px solid #ddd;
  border-radius: 20px; padding: 5px 14px;
  font-size: 12px; color: #666; white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis; min-width: 0;
}
.demo-tabs { display: flex; gap: 4px; flex-wrap: wrap; }
.dt {
  padding: 4px 13px; font-size: 12px; font-weight: 600;
  color: var(--body); border-radius: 20px; cursor: pointer;
  transition: all .2s; white-space: nowrap;
}
.dt:hover { background: var(--green-lt); color: var(--green); }
.dt.active { background: var(--green); color: #fff; }

.demo-screens { position: relative; min-height: 380px; }
.demo-screen { display: none; min-height: 380px; animation: demoFade .35s ease; }
.demo-screen.active { display: flex; }
@keyframes demoFade {
  from { opacity: 0; transform: translateX(14px); }
  to   { opacity: 1; transform: translateX(0); }
}

.ds-sidebar {
  width: 155px; background: #f8faf8;
  border-right: 1px solid var(--border);
  padding: 14px 8px; flex-shrink: 0;
}
.ds-brand { font-size: 13px; font-weight: 800; color: var(--green); padding: 6px 8px 14px; display: flex; align-items: center; gap: 6px; }
.ds-nav-item { display: flex; align-items: center; gap: 8px; padding: 8px 10px; border-radius: 6px; font-size: 12px; color: var(--body); margin-bottom: 2px; }
.ds-nav-item.ds-active { background: var(--green-lt); color: var(--green); font-weight: 700; }
.ds-sep { border: none; border-top: 1px solid var(--border); margin: 8px 4px; }

.ds-body { flex: 1; padding: 16px 20px; overflow: hidden; background: #fff; }
.ds-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.ds-header h3 { font-size: 16px; font-weight: 800; color: var(--dark); display: flex; align-items: center; gap: 10px; }
.ds-count { font-size: 12px; background: var(--green-lt); color: var(--green); padding: 2px 10px; border-radius: 999px; font-weight: 700; }
.ds-live-pill { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--body); background: var(--light-bg); border: 1px solid var(--border); border-radius: 999px; padding: 3px 12px; }
.ds-blink { color: #22c55e; font-size: 8px; animation: blink-dot 1.5s infinite; }
@keyframes blink-dot { 0%,100%{opacity:1} 50%{opacity:.2} }

.ds-btn { background: var(--green); color: #fff; border: none; padding: 7px 16px; border-radius: 999px; font-size: 12px; font-weight: 700; display: inline-flex; align-items: center; gap: 6px; font-family: inherit; cursor: default; }
.ds-btn-outline { background: transparent; color: var(--body); border: 1px solid var(--border); }

.ds-kpis { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; margin-bottom: 14px; }
.ds-kpi { background: var(--light-bg); border: 1px solid var(--border); border-radius: 8px; padding: 10px 12px; }
.dk-num { font-size: 20px; font-weight: 800; color: var(--dark); }
.dk-num.cg { color: var(--green); }
.dk-num.cb { color: #3b82f6; }
.dk-num.ca { color: #f59e0b; }
.dk-label { font-size: 10px; color: var(--body); margin-top: 2px; }
.ds-section-label { font-size: 11px; font-weight: 700; color: var(--body); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 8px; }

.ds-job-row { display: flex; align-items: center; gap: 10px; background: var(--light-bg); border: 1px solid var(--border); border-radius: 6px; padding: 8px 12px; margin-bottom: 5px; font-size: 12px; }
.dj-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.dj-name { flex: 1; font-weight: 600; color: var(--dark); }
.dj-agent { color: var(--body); font-size: 11px; }
.ds-badge { padding: 2px 10px; border-radius: 999px; font-size: 10px; font-weight: 700; white-space: nowrap; display: inline-flex; align-items: center; gap: 4px; }
.ds-badge.ok  { background: #dcfce7; color: #16a34a; }
.ds-badge.run { background: #dbeafe; color: #2563eb; }
.ds-badge.due { background: #fef3c7; color: #d97706; }

.ds-table-head, .ds-table-row { display: grid; grid-template-columns: 2fr 1.2fr 1.2fr 1.3fr .9fr; gap: 8px; align-items: center; padding: 7px 12px; font-size: 12px; }
.ds-table-head { font-size: 10px; font-weight: 700; color: var(--body); text-transform: uppercase; letter-spacing: .05em; }
.ds-table-row { background: var(--light-bg); border: 1px solid var(--border); border-radius: 6px; margin-bottom: 4px; color: var(--dark); }
.ds-table-row span:first-child { font-weight: 600; }

.ds-agents-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; }
.ds-agent-card { background: var(--light-bg); border: 1px solid var(--border); border-radius: 8px; padding: 14px; position: relative; }
.ds-agent-card.online  { border-left: 3px solid #22c55e; }
.ds-agent-card.offline { border-left: 3px solid #e5e7eb; opacity: .7; }
.dag-dot { width: 10px; height: 10px; border-radius: 50%; position: absolute; top: 14px; right: 14px; }
.online .dag-dot  { background: #22c55e; box-shadow: 0 0 0 3px rgba(34,197,94,.2); }
.offline .dag-dot { background: #9ca3af; }
.dag-name { font-size: 13px; font-weight: 700; color: var(--dark); margin-bottom: 4px; }
.dag-os   { font-size: 11px; color: var(--body); margin-bottom: 4px; }
.dag-last { font-size: 10px; color: #9ca3af; }

.ds-log-filter { display: flex; gap: 6px; margin-bottom: 12px; flex-wrap: wrap; }
.dlf { padding: 4px 14px; font-size: 11px; font-weight: 700; border-radius: 999px; cursor: default; border: 1px solid var(--border); color: var(--body); }
.dlf.active { background: var(--green); color: #fff; border-color: var(--green); }
.ds-log-row { display: grid; grid-template-columns: .8fr 1.8fr 1.2fr 1.1fr .7fr; gap: 8px; align-items: center; background: var(--light-bg); border: 1px solid var(--border); border-radius: 6px; padding: 8px 12px; margin-bottom: 4px; font-size: 11px; }
.dl-time  { color: var(--body); font-family: monospace; }
.dl-job   { font-weight: 600; color: var(--dark); }
.dl-agent, .dl-size { color: var(--body); }

.ds-form { max-width: 640px; }
.ds-field { margin-bottom: 12px; }
.ds-field label { display: block; font-size: 12px; font-weight: 700; color: var(--dark); margin-bottom: 5px; }
.ds-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.ds-input { background: var(--light-bg); border: 1px solid var(--border); border-radius: 6px; padding: 8px 12px; font-size: 12px; color: var(--dark); font-family: inherit; display: flex; align-items: center; gap: 6px; }
.ds-schedule-pills { display: flex; gap: 6px; flex-wrap: wrap; }
.dsp { padding: 5px 14px; font-size: 12px; font-weight: 600; border-radius: 999px; border: 1px solid var(--border); color: var(--body); cursor: default; }
.dsp.active { background: var(--green); color: #fff; border-color: var(--green); }
.ds-save-btn { background: var(--green); color: #fff; border: none; padding: 10px 24px; border-radius: 999px; font-size: 14px; font-weight: 700; cursor: default; font-family: inherit; display: inline-flex; align-items: center; gap: 8px; margin-top: 6px; }

.demo-controls { background: #f8faf8; border-top: 1px solid var(--border); padding: 12px 20px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.demo-play-btn { width: 40px; height: 40px; border-radius: 50%; background: var(--green); border: none; color: #fff; font-size: 14px; cursor: pointer; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: background .2s; }
.demo-play-btn:hover { background: var(--green-dk); }
.demo-progress-wrap { flex: 1; height: 5px; background: var(--border); border-radius: 5px; overflow: hidden; min-width: 80px; }
.demo-progress-bar { height: 100%; background: var(--green); border-radius: 5px; width: 0%; transition: width .08s linear; }
.demo-dots { display: flex; gap: 8px; flex-shrink: 0; }
.demo-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--border); cursor: pointer; transition: background .2s, transform .2s; }
.demo-dot:hover { transform: scale(1.3); }
.demo-dot.active { background: var(--green); }
.demo-caption { font-size: 12px; color: var(--body); flex: 2; text-align: right; font-style: italic; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

@media (max-width: 900px) {
  .demo-tabs { display: none; }
  .ds-kpis { grid-template-columns: repeat(2,1fr); }
  .ds-agents-grid { grid-template-columns: repeat(2,1fr); }
  .ds-table-head, .ds-table-row { grid-template-columns: 2fr 1.2fr 1.2fr; }
  .ds-table-head span:nth-child(n+4), .ds-table-row span:nth-child(n+4) { display: none; }
  .ds-log-row { grid-template-columns: .9fr 1.8fr 1fr; }
  .ds-log-row span:nth-child(n+4) { display: none; }
  .demo-caption { display: none; }
}
@media (max-width: 600px) {
  .ds-sidebar { display: none; }
  .ds-field-row { grid-template-columns: 1fr; }
  .ds-agents-grid { grid-template-columns: 1fr 1fr; }
  .ds-kpis { grid-template-columns: 1fr 1fr; }
}
