*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#f0faf9;--bg2:#e8f4ff;
  --card:#ffffff;--border:#c8ecec;
  --accent:#00b4cc;--accent2:#007a8e;
  --text:#1c3d48;--muted:#7a9faa;
  --wa:#25d366;--tg:#2aabee;
  --shadow:0 8px 32px rgba(0,100,120,.1);
}
html,body{height:100%;
  background:linear-gradient(160deg,var(--bg) 0%,#f7fcff 55%,var(--bg2) 100%);
  color:var(--text);font-family:'Segoe UI',system-ui,sans-serif;overflow:hidden}

/* Soap bubbles background */
#cv{position:fixed;inset:0;z-index:0;opacity:.65}

.screen{position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;padding:20px;z-index:1;
  transition:opacity .45s,transform .45s}
.screen.hidden{opacity:0;pointer-events:none;transform:translateY(14px)}

/* ── INTRO ── */
#intro{gap:18px;text-align:center}

.klini-wrap{position:relative;width:220px;height:220px;margin:0 auto}
.klini-wrap::before{content:'';position:absolute;inset:-18px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,180,204,.22) 0%,transparent 68%);
  opacity:.5;z-index:0;pointer-events:none}

.klini-img{position:relative;z-index:1;width:100%;height:100%;object-fit:contain;
  clip-path:circle(44%);transform-origin:50% 92%;
  filter:drop-shadow(0 10px 28px rgba(0,180,204,.3));
  animation:drop-in .65s cubic-bezier(.34,1.56,.64,1) both}

@keyframes drop-in{
  0%{transform:translateY(-70px) scale(.75);opacity:0}
  60%{transform:translateY(8px) scale(1.04);opacity:1}
  80%{transform:translateY(-3px) scale(.98)}
  100%{transform:translateY(0) scale(1)}
}
@keyframes klini-idle{
  0%,100%{transform:translateY(0) rotate(-.4deg) scale(1)}
  25%{transform:translateY(-6px) rotate(.6deg) scale(1.012)}
  55%{transform:translateY(-10px) rotate(1.1deg) scale(1.02)}
  80%{transform:translateY(-4px) rotate(.2deg) scale(1.008)}
}
.klini-img.wiggle{animation:klini-wiggle .55s ease-in-out forwards!important}
@keyframes klini-wiggle{
  0%{transform:rotate(0) scale(1)}
  18%{transform:rotate(-9deg) scale(1.07)}
  42%{transform:rotate(7deg) scale(1.07)}
  64%{transform:rotate(-4deg) scale(1.03)}
  84%{transform:rotate(3deg) scale(1.01)}
  100%{transform:rotate(0) scale(1)}
}
.klini-img.bounce{animation:klini-bounce .6s cubic-bezier(.34,1.56,.64,1) forwards!important}
@keyframes klini-bounce{
  0%{transform:translateY(0) scale(1)}
  35%{transform:translateY(-22px) scale(1.11)}
  65%{transform:translateY(6px) scale(.93)}
  100%{transform:translateY(0) scale(1)}
}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* Sparkle deco around character */
.sparkle{position:absolute;font-size:18px;pointer-events:none;color:var(--accent);
  animation:spark 2.4s ease-in-out infinite}
.s1{top:12px;right:8px;animation-delay:0s}
.s2{top:40px;left:4px;animation-delay:.7s}
.s3{bottom:28px;right:2px;animation-delay:1.4s;font-size:13px}
.s4{bottom:12px;left:18px;animation-delay:2s;font-size:12px}
@keyframes spark{0%,100%{opacity:0;transform:scale(.4) rotate(0deg)}50%{opacity:1;transform:scale(1) rotate(20deg)}}

.intro-title{font-size:1.9rem;font-weight:900;line-height:1.25;color:var(--text)}
.intro-title em{color:var(--accent);font-style:normal}
.intro-sub{color:var(--muted);font-size:.93rem;margin-top:4px}

.brand-badge{display:inline-flex;align-items:center;gap:6px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:white;border-radius:50px;padding:4px 14px;font-size:.78rem;
  font-weight:800;letter-spacing:.06em;margin-bottom:4px}

.btn-start{background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#fff;border:none;padding:16px 52px;border-radius:50px;
  font-size:1.08rem;font-weight:900;cursor:pointer;
  box-shadow:0 8px 28px rgba(0,180,204,.35);
  transition:transform .2s,box-shadow .2s}
.btn-start:hover{transform:scale(1.06);box-shadow:0 14px 36px rgba(0,180,204,.5)}
.btn-start:active{transform:scale(.98)}

.stat-chip{display:inline-flex;align-items:center;gap:6px;
  background:rgba(0,180,204,.1);border:1.5px solid rgba(0,180,204,.25);
  border-radius:50px;padding:7px 16px;font-size:.82rem;color:var(--accent2);font-weight:600}
.stat-chip span{font-weight:800;color:var(--accent)}

.trust-row{display:flex;gap:12px;color:var(--muted);font-size:.75rem;flex-wrap:wrap;justify-content:center}
.trust-row b{color:var(--accent2)}

/* ── CHAT ── */
#chat{flex-direction:row;padding:0;align-items:stretch;max-width:860px;width:100%;margin:0 auto}
.chat-left{width:130px;flex-shrink:0;display:flex;flex-direction:column;
  align-items:center;justify-content:flex-end;padding-bottom:28px;gap:6px}
@media(max-width:560px){.chat-left{display:none}}
.chat-klini-img{width:100px;height:100px;object-fit:contain;
  filter:drop-shadow(0 6px 16px rgba(0,180,204,.2));
  animation:float 3.2s ease-in-out infinite}
.chat-name{font-size:.75rem;font-weight:800;color:var(--accent2);letter-spacing:.06em;text-transform:uppercase}
.chat-status{font-size:.68rem;color:var(--muted);display:flex;align-items:center;gap:4px}
.chat-status::before{content:'';width:6px;height:6px;border-radius:50%;
  background:var(--wa);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

.chat-right{flex:1;display:flex;flex-direction:column;padding:14px 14px 14px 0}
@media(max-width:560px){.chat-right{padding:14px}}

.progress-bar{height:4px;background:var(--border);border-radius:4px;margin-bottom:14px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#00d4b8);
  border-radius:4px;transition:width .6s cubic-bezier(.4,0,.2,1)}

.messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding-right:2px}
.messages::-webkit-scrollbar{width:3px}
.messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}

.msg{opacity:0;transform:translateY(8px);transition:opacity .3s,transform .3s}
.msg.show{opacity:1;transform:none}
.bubble{max-width:82%;padding:11px 15px;border-radius:18px;font-size:.93rem;line-height:1.45}
.bubble-bot{background:var(--card);border:1.5px solid var(--border);
  border-bottom-left-radius:4px;align-self:flex-start;box-shadow:var(--shadow)}
.bubble-user{background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#fff;font-weight:700;border-bottom-right-radius:4px;align-self:flex-end;margin-left:auto}

.typing span{display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--muted);margin:0 2px;animation:tdot 1.1s infinite}
.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}
@keyframes tdot{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-6px)}}

.options{display:flex;flex-wrap:wrap;gap:7px;margin-top:2px}
.opt{background:var(--card);border:2px solid var(--border);color:var(--text);
  padding:10px 18px;border-radius:50px;font-size:.88rem;cursor:pointer;
  transition:all .18s;box-shadow:0 2px 8px rgba(0,100,120,.06)}
.opt:hover{border-color:var(--accent);color:var(--accent)}
.opt.on{background:linear-gradient(135deg,var(--accent),var(--accent2));
  border-color:transparent;color:#fff;font-weight:700;box-shadow:0 4px 16px rgba(0,180,204,.3)}
.opt.off{opacity:.4;pointer-events:none}

.range-val{font-size:1.5rem;font-weight:900;color:var(--accent);margin-bottom:8px}
input[type=range]{width:100%;-webkit-appearance:none;height:5px;border-radius:4px;
  background:var(--border);outline:none;margin-bottom:10px}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;
  border-radius:50%;background:var(--accent);cursor:pointer;
  box-shadow:0 0 14px rgba(0,180,204,.5)}

.cb-row{display:flex;align-items:center;gap:10px;padding:8px 0;cursor:pointer;
  font-size:.9rem;border-bottom:1.5px solid var(--border)}
.cb-row:last-of-type{border:none}
.cb-row input{accent-color:var(--accent);width:17px;height:17px;cursor:pointer}
.cb-price{color:var(--muted);margin-left:auto;font-size:.82rem}

/* ── RESULT ── */
#result{gap:16px;max-width:420px;width:100%}
.price-card{background:var(--card);border:2px solid rgba(0,180,204,.25);
  border-radius:24px;padding:28px;width:100%;box-shadow:var(--shadow),
  inset 0 1px 0 rgba(255,255,255,.8)}
.price-lbl{color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.1em}
.price-num{font-size:3.4rem;font-weight:900;color:var(--accent);margin:4px 0 16px;
  animation:pop .55s cubic-bezier(.34,1.56,.64,1)}
@keyframes pop{from{opacity:0;transform:scale(.65)}to{opacity:1;transform:scale(1)}}
.price-list{display:flex;flex-direction:column;gap:5px}
.price-row{display:flex;align-items:center;gap:8px;font-size:.88rem;color:var(--muted)}
.price-row::before{content:'✓';color:var(--accent);font-weight:900;flex-shrink:0}

.action-btns{display:flex;flex-direction:column;gap:9px;width:100%}
.btn-wa,.btn-tg{display:flex;align-items:center;justify-content:center;gap:9px;
  border:none;padding:16px;border-radius:16px;font-size:1rem;font-weight:800;
  cursor:pointer;transition:transform .18s,box-shadow .18s}
.btn-wa{background:var(--wa);color:#fff;box-shadow:0 4px 20px rgba(37,211,102,.3)}
.btn-tg{background:var(--tg);color:#fff;box-shadow:0 4px 20px rgba(42,171,238,.3)}
.btn-wa:hover,.btn-tg:hover{transform:scale(1.03);box-shadow:0 8px 28px rgba(0,0,0,.2)}
.btn-back{background:transparent;border:2px solid var(--border);color:var(--muted);
  padding:11px;border-radius:14px;font-size:.87rem;cursor:pointer;
  transition:border-color .18s,color .18s;width:100%}
.btn-back:hover{border-color:var(--accent);color:var(--accent2)}
.result-note{background:rgba(0,180,204,.08);border:1.5px solid rgba(0,180,204,.2);
  border-radius:14px;padding:11px 16px;font-size:.82rem;color:var(--accent2);
  text-align:center;line-height:1.5;width:100%}
.result-note strong{color:var(--accent)}
.result-footer{font-size:.72rem;color:var(--muted);text-align:center;line-height:1.7}

/* ── CONFETTI ── */
.confetti-piece{position:fixed;pointer-events:none;z-index:999;
  animation:confetti-fall 1.4s ease-in forwards}
@keyframes confetti-fall{
  0%{transform:translateY(-20px) rotate(0deg);opacity:1}
  100%{transform:translateY(100vh) rotate(720deg);opacity:0}
}
