/* ========== TOKENS ========== */
:root{
  --brand:#008b52;
  --brand-2:#00b86b;
  --brand-3:#00d97e;
  --brand-dark:#005c36;
  --bg:#f6fbf8;
  --surface:#ffffff;
  --ink:#0d1f17;
  --ink-2:#3b524a;
  --ink-3:#6b7f78;
  --line:#e3ece8;
  --line-2:#cfded7;
  --shadow-sm: 0 2px 8px rgba(0,90,55,.06);
  --shadow:0 12px 40px rgba(0,90,55,.10);
  --shadow-lg:0 30px 60px rgba(0,90,55,.18);
  --shadow-xl:0 40px 80px rgba(0,90,55,.22);
  --radius:18px;
  --radius-sm:12px;
  --radius-lg:28px;
  --grad: linear-gradient(135deg,#008b52 0%, #00b86b 55%, #00d97e 100%);
  --grad-soft: linear-gradient(135deg,#e6f7ee 0%, #d2f1e0 100%);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Be Vietnam Pro', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img,video,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
input,textarea{font-family:inherit}

.container{max-width:1200px;margin:0 auto;padding:0 24px}
.grad{
  background:var(--grad);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.eyebrow{
  display:inline-block;
  font-size:13px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--brand);
  background:var(--grad-soft);
  padding:6px 12px;border-radius:999px;
  margin-bottom:14px;
}
.section-head{text-align:center;max-width:920px;margin:0 auto 40px}
.section-head h2{font-size:38px;line-height:1.2;margin:0 0 12px;font-weight:800;letter-spacing:-.02em;white-space:nowrap}
.section-head p{color:var(--ink-3);font-size:16px;margin:0}
.hidden{display:none !important}

/* ========== BUTTONS ========== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 22px;border-radius:12px;font-weight:700;font-size:15px;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  white-space:nowrap;cursor:pointer;
}
.btn-sm{padding:9px 16px;font-size:14px}
.btn-lg{padding:16px 28px;font-size:16px;border-radius:14px}
.btn-block{width:100%}
.btn-primary{
  background:var(--grad);color:#fff;
  box-shadow:0 10px 24px rgba(0,139,82,.35);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 32px rgba(0,139,82,.45)}
.btn-ghost{
  background:#fff;color:var(--ink);
  border:1.5px solid var(--line);
}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand)}

/* ========== NAV ========== */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(246,251,248,.85);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(0,139,82,.08);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 24px}
.logo{display:flex;align-items:center;font-weight:800}
.logo-img{display:block;width:120px;height:auto}
.logo-mark{
  width:36px;height:36px;border-radius:10px;
  background:var(--grad);color:#fff;
  display:grid;place-items:center;font-weight:900;font-size:18px;
  box-shadow:0 6px 14px rgba(0,139,82,.3);
}
.logo-text{font-size:18px;color:var(--ink)}
.logo-text em{font-style:normal;color:var(--brand);font-weight:700}
.nav-links{display:flex;gap:32px}
.nav-links a{font-weight:600;font-size:15px;color:var(--ink-2)}
.nav-links a:hover{color:var(--brand)}

/* ========== HERO ========== */
.hero{
  padding:48px 0 72px;position:relative;overflow:hidden;
}
.hero-bg-grid{
  position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 80% 10%, rgba(0,217,126,.18), transparent 50%),
    radial-gradient(circle at 10% 80%, rgba(0,139,82,.12), transparent 50%);
  pointer-events:none;
}
.hero-inner{
  display:grid;grid-template-columns:1.15fr 1fr;gap:56px;
  align-items:stretch;   /* both columns same height → kol-banner bottom = order-card bottom */
  position:relative;z-index:1;
}

/* Hero heading — 2 lines, each locked to 1 line */
.hero h1{
  font-size:36px;
  font-weight:900;
  line-height:1.28;
  letter-spacing:-.022em;
  margin:0 0 20px;
}
.h1-line{
  display:block;
  white-space:nowrap;
}
.h1-kol{
  color:var(--ink);
}
.h1-kol [data-kol]{
  color:var(--brand-dark);
  font-weight:800;
}
.tagline{
  display:flex;align-items:center;gap:12px;
  font-size:17px;color:var(--ink-2);
  margin:0 0 20px;font-weight:500;
}
.tagline strong{color:var(--brand-dark);font-weight:800}
.t-line{width:32px;height:2px;border-radius:2px;background:var(--grad);display:inline-block;flex-shrink:0}
.lead{font-size:15.5px;color:var(--ink-3);margin:0 0 32px;max-width:540px;line-height:1.65}

/* Stats */
.hero-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
  padding-top:28px;border-top:1px solid var(--line);
}
.stat strong{
  display:block;font-size:26px;font-weight:900;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  letter-spacing:-.02em;line-height:1.1;
}
.stat span{font-size:12px;color:var(--ink-3);line-height:1.35;display:block;margin-top:4px}

/* ========== KOL BANNER (below stats, bottom-aligned with order card) ========== */
.hero-left{
  display:flex;
  flex-direction:column;
}
.kol-banner{
  position:relative;
  margin-top:auto;     /* pushes banner to bottom, aligning with order card base */
  padding-top:28px;    /* breathing room from stats */
  padding:28px 24px 24px;
  border-radius:20px;
  background:linear-gradient(160deg,#ffffff 0%, #f4fbf7 100%);
  border:1px solid rgba(0,139,82,.18);
  box-shadow:0 8px 28px rgba(0,139,82,.10);
}
.kol-banner::before{
  content:"";
  position:absolute;left:0;top:20px;bottom:20px;width:4px;
  background:var(--grad);border-radius:0 4px 4px 0;
}
.kol-banner-label{
  display:inline-flex;align-items:center;gap:7px;
  font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:var(--brand);margin-bottom:16px;
}
.kol-banner-label::before{content:"★";font-size:10px}
.kol-banner-body{
  display:flex;align-items:center;gap:20px;
}
/* Avatar image */
.kol-channel-img{
  position:relative;flex-shrink:0;
  width:96px;height:96px;border-radius:20px;
  overflow:hidden;
  box-shadow:0 10px 28px rgba(0,139,82,.28);
  border:3px solid #fff;
}
.kol-avatar-img{
  width:100%;height:100%;
  object-fit:cover;object-position:center top;
  display:block;
}
.verify-badge{
  position:absolute;bottom:-5px;right:-5px;
  width:26px;height:26px;border-radius:50%;
  background:#1da1f2;color:#fff;
  display:grid;place-items:center;font-size:12px;font-weight:900;
  border:3px solid #fff;
  box-shadow:0 4px 10px rgba(29,161,242,.4);
  z-index:1;
}
.kol-banner-info{flex:1;min-width:0}
.kol-banner-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:4px}
.kol-banner-head h4{margin:0;font-size:20px;font-weight:800;color:var(--ink);line-height:1.2}
.kol-partner{
  font-size:10.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;
  padding:3px 9px;border-radius:6px;
  background:var(--grad-soft);color:var(--brand-dark);white-space:nowrap;
}
.kol-bio{
  margin:0 0 14px;font-size:13px;color:var(--ink-3);line-height:1.4;
}
.kol-socials{display:flex;gap:8px;flex-wrap:wrap}
.ksoc{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 14px;border-radius:9px;
  font-size:13px;font-weight:700;color:var(--ink-2);
  background:#fff;border:1.5px solid var(--line);
  transition:transform .15s ease, color .15s ease, border-color .15s ease, box-shadow .2s ease;
}
.ksoc svg{width:15px;height:15px;flex-shrink:0}
.ksoc:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.08)}
.ksoc-fb:hover{color:#1877f2;border-color:#1877f2;background:#f0f5ff}
.ksoc-yt:hover{color:#ff0000;border-color:#ff0000;background:#fff5f5}
.ksoc-tt:hover{color:#111;border-color:#111;background:#f7f7f7}

/* ========== ORDER CARD ========== */
.order-card{
  position:sticky;top:90px;
  background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:22px;
  box-shadow:var(--shadow-xl);
}
.oc-deal{
  display:flex;align-items:center;gap:8px;
  padding:9px 12px;border-radius:10px;
  background:var(--grad-soft);
  border:1px dashed rgba(0,139,82,.3);
  font-size:13px;color:var(--ink-2);
  margin-bottom:16px;
}
.oc-deal-ico{font-size:16px}
.oc-deal strong{color:var(--brand-dark);font-weight:800}
.oc-head{display:flex;align-items:start;justify-content:space-between;margin-bottom:18px}
.oc-title h3{margin:0 0 4px;font-size:20px;font-weight:800}
.oc-sub{font-size:13px;color:var(--ink-3)}
.oc-sub strong{color:var(--ink);font-weight:700}
.oc-shield{
  width:42px;height:42px;border-radius:12px;
  background:var(--grad-soft);
  display:grid;place-items:center;font-size:20px;
}

/* plan options */
.plan-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}
.plan-opt{
  position:relative;cursor:pointer;display:block;
}
.plan-opt input{position:absolute;opacity:0;pointer-events:none}
.po-inner{
  position:relative;
  border:2px solid var(--line);border-radius:14px;
  padding:14px 14px 14px 18px;
  display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;
  transition:border-color .2s ease, background .2s ease;
}
.plan-opt:hover .po-inner{border-color:var(--brand-2)}
.plan-opt input:checked ~ .po-inner{
  border-color:var(--brand);
  background:linear-gradient(180deg,#f0faf4 0%, #fff 100%);
}
.plan-opt input:checked ~ .po-inner .po-radio::after{
  transform:scale(1);
}
.po-name{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.po-name strong{font-size:15px;font-weight:800}
.po-tag{
  font-size:10px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;
  padding:3px 7px;border-radius:5px;
  background:var(--grad-soft);color:var(--brand-dark);
}
.po-tag-pro{background:var(--grad);color:#fff}
.po-bonus{font-size:12px;color:var(--ink-3);line-height:1.4}
.po-bonus b{color:var(--brand-dark);font-weight:700}
.po-price{text-align:right;line-height:1.1}
.po-amount{display:block;font-size:18px;font-weight:900;color:var(--ink)}
.po-amount i{font-style:normal;font-size:13px;color:var(--brand);margin-left:1px}
.po-per{font-size:11px;color:var(--ink-3)}
.po-radio{
  width:20px;height:20px;border-radius:50%;
  border:2px solid var(--line-2);
  position:relative;flex-shrink:0;
  transition:border-color .2s ease;
}
.plan-opt input:checked ~ .po-inner .po-radio{border-color:var(--brand)}
.po-radio::after{
  content:"";position:absolute;inset:3px;border-radius:50%;
  background:var(--grad);
  transform:scale(0);transition:transform .2s ease;
}
.plan-opt-best{margin-top:10px}
.po-best{
  position:absolute;top:-10px;right:14px;z-index:2;
  background:var(--grad);color:#fff;
  font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  padding:4px 10px;border-radius:999px;
  box-shadow:0 6px 14px rgba(0,139,82,.35);
}

/* order summary inside card */
.oc-summary{
  background:var(--grad-soft);
  border-radius:12px;padding:12px 14px;margin-bottom:14px;
}
.ocs-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--ink-2);padding:3px 0}
.ocs-row strong{color:var(--ink);font-weight:700}
.ocs-final{padding-top:8px;margin-top:4px;border-top:1px dashed rgba(0,139,82,.25)}
.ocs-final span{font-size:14px}
.ocs-final strong{font-size:20px;color:var(--brand);font-weight:900}

.oc-trust{
  display:flex;justify-content:space-around;gap:8px;
  margin-top:14px;padding-top:14px;border-top:1px dashed var(--line);
  font-size:11px;color:var(--ink-3);text-align:center;
}

/* ========== SHOWCASE ========== */
.showcase{
  padding:64px 0;background:#fff;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.showcase-inner{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.sc-text h2{font-size:38px;line-height:1.15;margin:8px 0 14px;font-weight:800;letter-spacing:-.02em}
.sc-text p{color:var(--ink-3);font-size:16px;margin:0 0 22px}
.sc-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.sc-list li{display:flex;align-items:center;gap:10px;font-size:15px;color:var(--ink-2)}
.check{
  flex-shrink:0;width:20px;height:20px;border-radius:50%;
  background:var(--grad);color:#fff;
  display:grid;place-items:center;font-size:11px;font-weight:900;
}

.sc-media{position:relative;display:flex;justify-content:center}
.phone-frame{
  position:relative;width:280px;aspect-ratio:9/19;
  background:#0d1f17;border-radius:42px;
  padding:10px;overflow:hidden;
  box-shadow:0 40px 80px rgba(0,139,82,.25), 0 0 0 2px rgba(0,0,0,.1);
}
.phone-notch{
  position:absolute;top:18px;left:50%;transform:translateX(-50%);
  width:80px;height:22px;border-radius:14px;
  background:#000;z-index:2;
}
.phone-frame video{
  width:100%;height:100%;border-radius:32px;object-fit:cover;
}
.sc-glow{
  position:absolute;inset:-40px;z-index:-1;
  background:radial-gradient(circle, rgba(0,184,107,.25), transparent 60%);
  filter:blur(40px);
}

/* ========== FEATURES ========== */
.features{padding:64px 0}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.feat-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.feat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:rgba(0,139,82,.25)}
.feat-card h3{margin:18px 0 6px;font-size:19px;font-weight:700}
.feat-card p{margin:0;color:var(--ink-3);font-size:14px;line-height:1.55}
.feat-visual{
  aspect-ratio:16/10;border-radius:14px;
  background:var(--grad-soft);
  position:relative;overflow:hidden;
}
.feat-visual-img{background:#000}
.feat-visual-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .4s ease;
}
.feat-card:hover .feat-visual-img img{transform:scale(1.04)}

/* feat visual: map */
.visual-map .road{
  position:absolute;top:40%;left:0;right:0;height:8px;
  background:#fff;border-radius:4px;
  box-shadow:0 2px 4px rgba(0,139,82,.1);
  transform:rotate(-8deg);
}
.visual-map .road.r2{top:65%;height:6px;transform:rotate(6deg);opacity:.7}
.visual-map .pin{
  position:absolute;top:30%;left:60%;
  width:24px;height:24px;border-radius:50% 50% 50% 0;
  background:var(--brand);transform:rotate(-45deg);
  box-shadow:0 6px 14px rgba(0,139,82,.35);
}
.visual-map .pin::after{
  content:"";position:absolute;inset:6px;border-radius:50%;background:#fff;
}

/* feat visual: cam */
.visual-cam{display:grid;place-items:center}
.cam-icon{
  position:relative;z-index:2;
  width:56px;height:56px;border-radius:14px;
  background:#fff;display:grid;place-items:center;font-size:26px;
  box-shadow:var(--shadow);
}
.pulse-ring{
  position:absolute;width:60px;height:60px;border-radius:50%;
  border:2px solid var(--brand);opacity:0;
  animation:pulse-ring 2s ease-out infinite;
}
.pulse-ring.d2{animation-delay:1s}
@keyframes pulse-ring{
  0%{transform:scale(.6);opacity:.8}
  100%{transform:scale(2.4);opacity:0}
}

/* feat visual: speed */
.visual-speed{display:flex;align-items:center;justify-content:center;gap:14px;padding:18px}
.speed-sign{
  width:54px;height:54px;border-radius:50%;
  background:#fff;border:5px solid #d32f2f;
  display:grid;place-items:center;
  font-weight:900;font-size:18px;color:#0d1f17;
  box-shadow:var(--shadow-sm);
}
.speed-sign.sm{width:42px;height:42px;border-width:4px;font-size:14px;opacity:.7}
.speed-sign.xs{width:36px;height:36px;border-width:3px;font-size:12px;opacity:.5}

/* feat visual: route */
.visual-route{position:relative}
.visual-route svg{width:100%;height:100%;animation:dash 2s linear infinite}
@keyframes dash{to{stroke-dashoffset:-24}}
.route-pin{
  position:absolute;width:14px;height:14px;border-radius:50%;
  background:var(--brand);box-shadow:0 0 0 4px rgba(0,139,82,.2);
}
.route-pin.start{bottom:18%;left:3%}
.route-pin.end{top:24%;right:3%;background:#fff;border:3px solid var(--brand)}

/* feat visual: community */
.visual-community{display:flex;align-items:center;justify-content:center;padding:18px}
.cmt-avatar{
  width:42px;height:42px;border-radius:50%;
  border:3px solid #fff;margin-left:-10px;
}
.cmt-avatar:nth-child(1){background:linear-gradient(135deg,#00d97e,#00b86b);margin-left:0}
.cmt-avatar:nth-child(2){background:linear-gradient(135deg,#008b52,#005c36)}
.cmt-avatar:nth-child(3){background:linear-gradient(135deg,#00b86b,#00d97e)}
.cmt-plus{
  margin-left:-10px;
  width:auto;padding:0 12px;height:42px;border-radius:21px;
  background:var(--grad);color:#fff;
  display:grid;place-items:center;font-weight:800;font-size:12px;
  border:3px solid #fff;
}

/* feat visual: voice */
.visual-voice{display:grid;place-items:center}
.voice-mic{
  position:relative;z-index:2;
  width:56px;height:56px;border-radius:50%;
  background:var(--grad);
  display:grid;place-items:center;font-size:24px;
  box-shadow:0 10px 24px rgba(0,139,82,.4);
}
.voice-wave{
  position:absolute;border-radius:50%;
  border:2px solid var(--brand);opacity:0;
  width:60px;height:60px;
  animation:voice 2.2s ease-out infinite;
}
.voice-wave.w2{animation-delay:.7s}
.voice-wave.w3{animation-delay:1.4s}
@keyframes voice{
  0%{transform:scale(.7);opacity:.6}
  100%{transform:scale(2.6);opacity:0}
}

/* ========== COMPARE FREE vs PRO ========== */
.compare{padding:64px 0;background:#fff;border-top:1px solid var(--line)}
.compare-wrap{
  max-width:880px;margin:0 auto;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  border:1px solid var(--line);
  background:#fff;
}
.compare-wrap img{
  width:100%;height:auto;display:block;
}

/* ========== HOW IT WORKS ========== */
.how{padding:64px 0;background:#fff;border-top:1px solid var(--line)}
.how-grid{
  display:grid;grid-template-columns:1fr auto 1fr auto 1fr;gap:24px;align-items:start;
  max-width:1000px;margin:0 auto 40px;
}
.how-step{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:28px 24px;text-align:center;
}
.how-num{
  width:48px;height:48px;border-radius:14px;
  background:var(--grad);color:#fff;
  display:grid;place-items:center;font-weight:900;font-size:20px;
  margin:0 auto 14px;
  box-shadow:0 10px 20px rgba(0,139,82,.3);
}
.how-step h3{margin:0 0 6px;font-size:17px;font-weight:700}
.how-step p{margin:0;color:var(--ink-3);font-size:14px;line-height:1.55}
.how-arrow{color:var(--brand);font-size:26px;align-self:center}
.how-cta{text-align:center}

/* ========== FAQ ========== */
.faq{padding:64px 0}
.faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-list details{
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:18px 22px;transition:border-color .2s ease, box-shadow .2s ease;
}
.faq-list details[open]{border-color:var(--brand-2);box-shadow:var(--shadow-sm)}
.faq-list summary{
  cursor:pointer;font-weight:700;font-size:16px;
  list-style:none;display:flex;justify-content:space-between;align-items:center;
}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{
  content:"";
  width:10px;height:10px;
  border-right:2.5px solid var(--brand);
  border-bottom:2.5px solid var(--brand);
  transform:rotate(45deg) translate(-3px,-3px);
  transition:transform .25s ease;
  flex-shrink:0;margin-left:14px;
}
.faq-list details[open] summary::after{
  transform:rotate(-135deg) translate(-3px,-3px);
}
.faq-list p{margin:12px 0 0;color:var(--ink-3);font-size:14.5px;line-height:1.6}

/* ========== FOOTER ========== */
.footer{background:var(--ink);color:#9eb5ac;padding:32px 0}
.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer-brand{display:flex;align-items:center;gap:12px;font-size:14px}
.footer-logo-img{width:92px;filter:brightness(0) invert(1);opacity:.92}
.footer-links{display:flex;gap:24px;font-size:14px}
.footer-links a:hover{color:#fff}

/* ========== MODAL ========== */
.modal{
  position:fixed;inset:0;z-index:100;
  display:none;align-items:center;justify-content:center;
  padding:20px;
}
.modal.show{display:flex;animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-backdrop{
  position:absolute;inset:0;
  background:rgba(13,31,23,.6);
  backdrop-filter:blur(6px);
}
.modal-card{
  position:relative;background:#fff;border-radius:var(--radius-lg);
  max-width:560px;width:100%;padding:28px;
  box-shadow:var(--shadow-lg);
  max-height:92vh;overflow-y:auto;
  animation:popIn .35s cubic-bezier(.16,1,.3,1);
}
@keyframes popIn{
  from{transform:scale(.92) translateY(20px);opacity:0}
  to{transform:scale(1) translateY(0);opacity:1}
}
.modal-close{
  position:absolute;top:14px;right:14px;
  width:36px;height:36px;border-radius:10px;
  background:var(--bg);color:var(--ink);
  font-size:24px;display:grid;place-items:center;
  z-index:3;
}
.modal-close:hover{background:var(--line)}

/* Stepper */
.stepper{
  display:flex;align-items:center;justify-content:center;gap:14px;
  margin-bottom:24px;
}
.step{display:flex;align-items:center;gap:8px;opacity:.45;transition:opacity .25s ease}
.step.active{opacity:1}
.step-dot{
  width:30px;height:30px;border-radius:50%;
  background:var(--line);color:var(--ink-2);
  display:grid;place-items:center;font-weight:800;font-size:14px;
  transition:background .25s ease, color .25s ease;
}
.step.active .step-dot{background:var(--grad);color:#fff;box-shadow:0 6px 14px rgba(0,139,82,.3)}
.step-label{font-size:13px;font-weight:700;color:var(--ink-2)}
.step.active .step-label{color:var(--ink)}
.step-line{width:60px;height:2px;background:var(--line);border-radius:2px}

.modal-head{text-align:center;margin-bottom:20px}
.modal-head h3{margin:0 0 6px;font-size:22px;font-weight:800}
.modal-head p{margin:0;color:var(--ink-3);font-size:14px}
.modal-badge{
  width:54px;height:54px;border-radius:50%;
  background:var(--grad);color:#fff;
  font-size:26px;font-weight:900;
  display:grid;place-items:center;margin:0 auto 12px;
  box-shadow:0 10px 24px rgba(0,139,82,.4);
}

/* Mini summary in step 1 */
.mini-summary{
  display:flex;align-items:center;gap:12px;
  background:var(--grad-soft);border-radius:12px;
  padding:12px 14px;margin-bottom:18px;
}
.ms-icon{
  width:40px;height:40px;border-radius:10px;
  background:#fff;display:grid;place-items:center;font-size:20px;
  flex-shrink:0;
}
.ms-info{flex:1;min-width:0}
.ms-info strong{display:block;font-size:14px;font-weight:800}
.ms-info span{font-size:12px;color:var(--ink-3)}
.ms-price{font-size:18px;font-weight:900;color:var(--brand)}

/* Form */
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:13px;font-weight:700;color:var(--ink-2);margin-bottom:5px}
.form-group input,
.form-group textarea{
  width:100%;padding:12px 14px;border:1.5px solid var(--line);
  border-radius:10px;font-size:14px;background:#fff;
  transition:border-color .15s ease, box-shadow .15s ease;
  resize:vertical;
}
.form-group input:focus,
.form-group textarea:focus{
  outline:none;border-color:var(--brand);
  box-shadow:0 0 0 4px rgba(0,139,82,.12);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-hint{font-size:12px;color:var(--ink-3);margin:-6px 0 14px}

.checkbox{
  display:flex;align-items:flex-start;gap:8px;
  font-size:13px;color:var(--ink-2);margin:8px 0 18px;cursor:pointer;
}
.checkbox input{margin-top:3px;accent-color:var(--brand)}
.checkbox a{color:var(--brand);text-decoration:underline}

.qr-note{
  background:var(--grad-soft);
  border-radius:10px;padding:12px 14px;
  font-size:13px;color:var(--ink-2);margin-bottom:16px;text-align:center;
}
.qr-note strong{color:var(--ink);font-weight:700}

.payment-preview{
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  overflow:hidden;
  margin-bottom:14px;
}
.preview-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  padding:12px 14px;
  border-bottom:1px solid var(--line);
  font-size:14px;
}
.preview-row:last-child{border-bottom:0}
.preview-row span{color:var(--ink-3);font-weight:600}
.preview-row strong{
  color:var(--ink);
  font-weight:800;
  text-align:right;
  overflow-wrap:anywhere;
}
.preview-total{
  background:var(--grad-soft);
  align-items:center;
}
.preview-total strong{
  color:var(--brand);
  font-size:20px;
  font-weight:900;
}

.modal-actions{display:grid;grid-template-columns:auto 1fr;gap:10px}

.return-success-card{
  max-width:460px;
  padding:34px 28px 28px;
  text-align:center;
}
.return-success-icon{
  width:64px;
  height:64px;
  border-radius:50%;
  background:var(--grad);
  color:#fff;
  display:grid;
  place-items:center;
  margin:0 auto 16px;
  font-size:34px;
  font-weight:900;
  box-shadow:0 12px 26px rgba(0,139,82,.32);
}
.return-success-card.return-status-failed .return-success-icon{
  background:linear-gradient(135deg,#f59e0b,#dc2626);
  box-shadow:0 12px 26px rgba(220,38,38,.22);
}
.return-success-card.return-status-pending .return-success-icon{
  background:linear-gradient(135deg,#f59e0b,#10b981);
  box-shadow:0 12px 26px rgba(245,158,11,.22);
}
.return-success-head{margin-bottom:16px}
.return-success-head h3{font-size:26px}
.return-success-head p{
  max-width:340px;
  margin:0 auto;
  line-height:1.55;
}
.return-support-note{
  background:var(--grad-soft);
  border:1px solid rgba(0,139,82,.14);
  border-radius:12px;
  padding:12px 14px;
  color:var(--ink-2);
  font-size:14px;
  font-weight:600;
  line-height:1.5;
  margin-bottom:18px;
}
.return-success-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}

/* ========== RESPONSIVE ========== */
@media (max-width: 480px){
  .hero h1{font-size:26px}
  .h1-line{white-space:normal}
  .return-success-actions{grid-template-columns:1fr}
}
@media (max-width: 1024px){
  .hero{padding:32px 0 56px}
  .hero h1{font-size:46px}
  .section-head h2{font-size:32px}
  .hero-inner{grid-template-columns:1fr;gap:32px;align-items:start}
  .hero-left{display:block}       /* reset flex column — no need to bottom-align when stacked */
  .kol-banner{margin-top:32px}    /* restore normal spacing */
  .order-card{position:static;max-width:560px;margin:0 auto;width:100%}
  .showcase-inner{grid-template-columns:1fr;gap:40px}
  .sc-media{order:-1}
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .how-grid{grid-template-columns:1fr;gap:14px}
  .how-arrow{transform:rotate(90deg);justify-self:center}
}
@media (max-width: 720px){
  .nav-links{display:none}
  .hero{padding:24px 0 48px}
  .hero h1{font-size:32px}
  .tagline{font-size:15px;gap:10px}
  .lead{font-size:14.5px;margin-bottom:24px}
  .hero-stats{grid-template-columns:repeat(2,1fr);gap:20px;padding-top:24px}
  .stat strong{font-size:22px}
  .kol-banner{padding:18px;margin-top:24px}
  .kol-channel-img{width:76px;height:76px}
  .kol-banner-head h4{font-size:17px}
  .section-head h2{font-size:26px;white-space:normal}
  .sc-text h2{font-size:26px}
  .feat-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .preview-row{flex-direction:column;gap:4px}
  .preview-row strong{text-align:left}
  .modal-actions{grid-template-columns:1fr}
  .modal-card{padding:22px 18px}
  .phone-frame{width:240px}
}
