/* ===== WarungKita - Responsive + PWA-Ready ===== */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#FDFBF7;
  --sage:#6b8c4e;
  --sage-dark:#55723c;
  --sage-light:#82a566;
  --ink:#1a1814;
  --ink-soft:#5a5245;
  --line:#e8e3d9;
  --chip:#f0ede6;
  --green:#6fcf97;
  --red:#eb5757;
  --radius:32px;
  --shadow:0 24px 80px rgba(0,0,0,0.08),0 8px 32px rgba(0,0,0,0.04);
}
/* CRITICAL: lock the outer viewport so .phone stays perfectly solid during
   Android Chrome URL bar collapse/expand gestures. The flex centering + body
   scroll chain caused the entire UI to drift up/down on touch. We instead
   use fixed positioning: the body becomes a single-positioned wrapper, .phone
   fills the entire viewport (minus safe-area), and inner .chat-area handles
   scrolling. */
html,body{
  height:100%;
  overflow:hidden;
  position:fixed;
  top:0;left:0;right:0;bottom:0;
  width:100%;
  overscroll-behavior:none;
  touch-action:manipulation;
}
body{
  font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  background:#FDFBF7;
  padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
  -webkit-font-smoothing:antialiased;
  -webkit-tap-highlight-color:transparent;
}
.phone{
  width:100%;max-width:420px;margin:0 auto;background:var(--bg);
  border-radius:0;overflow:hidden;position:relative;
  height:100%;display:flex;flex-direction:column;
  box-shadow:var(--shadow);
}
/* Re-add rounded corners when there's enough height (>= 700px) */
@media (min-height:700px){
  body{padding:16px;padding-top:max(16px,env(safe-area-inset-top));padding-bottom:max(16px,env(safe-area-inset-bottom))}
  .phone{border-radius:var(--radius);height:calc(100% - 32px);max-height:900px}
}

/* HEADER */
.header{background:linear-gradient(135deg,#6b8c4e,#82a566);padding:clamp(10px,4.5vw,20px) clamp(8px,4vw,20px) clamp(8px,3.5vw,16px);color:#fff;flex-shrink:0;position:relative}
.header-top{display:flex;flex-direction:column;align-items:stretch;margin-bottom:2px}
.header-left{display:flex;align-items:center;gap:6px;flex:1;min-width:0;overflow:hidden;flex-wrap:wrap}
.header-title{font-size:clamp(10px,3.2vw,13px);font-weight:500;opacity:0.85;letter-spacing:0.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.header-actions-left{display:flex;align-items:center;gap:6px;margin-top:6px;margin-bottom:2px;justify-content:flex-start}
.header-icon-btn{
  width:clamp(36px,11vw,48px);height:clamp(36px,11vw,48px);
  background:rgba(255,255,255,0.2);border:1.5px solid rgba(255,255,255,0.35);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  transition:transform 0.15s,background 0.15s;
  flex-shrink:0;
}
.header-icon-btn:active{transform:scale(0.92);background:rgba(255,255,255,0.3)}
.header-icon-btn svg{width:clamp(18px,5.5vw,24px);height:clamp(18px,5.5vw,24px);display:none;color:#fff;stroke-width:2.4}
.header-icon-btn .btn-fallback{display:block;font-size:clamp(14px,4.5vw,20px);line-height:1}
.tutup-btn{padding:clamp(4px,1.5vw,6px) clamp(8px,3vw,14px);background:rgba(255,255,255,0.2);border:1.5px solid rgba(255,255,255,0.35);border-radius:16px;color:#fff;font-size:clamp(10px,3vw,12px);font-weight:500;cursor:pointer;font-family:inherit;transition:background 0.2s;-webkit-tap-highlight-color:transparent}
.tutup-btn:active{background:rgba(255,255,255,0.35)}
.warung-name{font-size:clamp(14px,5.2vw,20px);font-weight:700;letter-spacing:-0.3px;line-height:1.2;overflow:hidden;text-overflow:ellipsis}
.dot{width:7px;height:7px;background:#6fcf97;border-radius:50%;display:inline-block;box-shadow:0 0 0 2px rgba(111,207,151,0.25)}
.dot.merah{background:#eb5757;box-shadow:0 0 0 2px rgba(235,87,87,0.25)}
.warung-status{font-size:clamp(10px,2.8vw,13px)}

/* QUICK ACTIONS */
.quick-actions{
  display:flex;gap:clamp(4px,1.5vw,8px);padding:clamp(8px,3vw,12px) clamp(8px,3.5vw,16px);overflow-x:auto;scrollbar-width:none;
  flex-shrink:0;-webkit-overflow-scrolling:touch;
  position:relative;scroll-behavior:smooth;
}
/* Right-edge fade indicator — only when content overflows */
.quick-actions:not(.no-scroll)::after{
  content:"";position:absolute;top:0;right:0;bottom:0;width:48px;
  background:linear-gradient(to right,rgba(253,251,247,0) 0%,rgba(253,251,247,0.95) 70%,var(--bg) 100%);
  pointer-events:none;border-radius:0 var(--radius) 0 0;
  transition:opacity 0.2s;
}
/* Hide fade when scrolled to end OR when no scroll needed */
.quick-actions.scrolled-end::after,.quick-actions.no-scroll::after{opacity:0}
.q-chip-chevron{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:50%;
  background:transparent;color:var(--sage);cursor:pointer;border:none;
  flex-shrink:0;-webkit-tap-highlight-color:transparent;
  margin-left:auto;align-self:center;transition:background 0.2s;
}
.q-chip-chevron:active{background:var(--chip)}
.quick-actions::-webkit-scrollbar{display:none}
.q-chip{padding:clamp(8px,2.8vw,12px) clamp(12px,3.5vw,18px);background:var(--chip);border-radius:24px;font-size:clamp(11px,3vw,14px);color:var(--ink-soft);white-space:nowrap;border:none;cursor:pointer;font-family:inherit;font-weight:500;transition:background 0.2s;-webkit-tap-highlight-color:transparent;min-height:clamp(36px,10vw,44px);display:flex;align-items:center}
.q-chip:active{background:#e3dcd0}

/* QUICK-SELL BUTTONS (stok items) */
.quick-sell{
  display:flex;gap:clamp(4px,1.5vw,8px);padding:0 clamp(8px,3.5vw,16px) clamp(4px,1.8vw,8px);overflow-x:auto;scrollbar-width:none;
  flex-shrink:0;-webkit-overflow-scrolling:touch;
}
.quick-sell::-webkit-scrollbar{display:none}
.qs-btn{
  padding:clamp(10px,3vw,14px) clamp(14px,4vw,20px);background:#fff;border:1.5px solid var(--sage);border-radius:24px;
  font-size:clamp(12px,3.2vw,15px);font-weight:600;color:var(--sage);white-space:nowrap;
  cursor:pointer;font-family:inherit;transition:all 0.15s;
  -webkit-tap-highlight-color:transparent;flex-shrink:0;min-height:clamp(40px,11vw,48px);display:flex;align-items:center;
}
.qs-btn:active{background:var(--sage);color:#fff;transform:scale(0.96)}

/* CHAT AREA */
.chat-area{flex:1;overflow-y:auto;padding:clamp(8px,3vw,12px) clamp(8px,3.5vw,16px);scroll-behavior:smooth;-webkit-overflow-scrolling:touch}
.chat-area::-webkit-scrollbar{width:0}
.date-label{text-align:center;font-size:clamp(9px,2.5vw,11px);color:#b0a89a;margin-bottom:clamp(6px,2vw,12px);font-weight:500}

/* MESSAGES */
.msg-row{display:flex;margin-bottom:clamp(6px,2vw,10px)}
.msg-row.in{justify-content:flex-start}
.msg-row.out{justify-content:flex-end}
.msg{max-width:85%;padding:clamp(8px,2.5vw,11px) clamp(10px,3vw,15px);border-radius:20px;font-size:clamp(11px,3.2vw,14px);line-height:1.5;position:relative;word-break:break-word;overflow-wrap:break-word}
.msg.in{background:#f0ede6;color:var(--ink);border-bottom-left-radius:6px}
.msg.out{background:var(--sage);color:#fff;border-bottom-right-radius:6px}
.msg-time{font-size:clamp(8px,2.2vw,10px);color:inherit;opacity:0.55;text-align:right;margin-top:3px}
.msg.out .msg-time{color:rgba(255,255,255,0.7)}
.msg.in .msg-time{color:#8b8b8b}
.msg.bot{background:#fff;border:1.5px solid var(--line);border-bottom-left-radius:6px;box-shadow:0 2px 8px rgba(0,0,0,0.03)}
.msg.bot .bot-name{font-weight:600;color:var(--sage);font-size:clamp(10px,2.8vw,12px);margin-bottom:3px}
.check-green{display:inline-block;width:clamp(11px,3vw,14px);height:clamp(11px,3vw,14px);background:var(--green);border-radius:50%;color:#fff;font-size:9px;text-align:center;line-height:14px;margin-left:4px;vertical-align:middle}

/* BUTTONS IN CHAT */
.chat-btns{display:flex;gap:clamp(4px,1.5vw,8px);margin-top:clamp(6px,2vw,8px);flex-wrap:wrap}
.ok-btn{padding:clamp(8px,2.8vw,12px) clamp(16px,4.5vw,22px);background:var(--sage);color:#fff;border-radius:24px;font-size:clamp(12px,3.2vw,15px);font-weight:500;border:none;cursor:pointer;font-family:inherit;-webkit-tap-highlight-color:transparent;min-height:clamp(40px,11vw,48px);display:flex;align-items:center;justify-content:center}
.koreksi-btn{padding:clamp(8px,2.8vw,10px) clamp(14px,4vw,18px);background:transparent;color:var(--sage);border-radius:24px;font-size:clamp(12px,3.2vw,15px);font-weight:500;border:1.5px solid #d4cdbe;cursor:pointer;font-family:inherit;-webkit-tap-highlight-color:transparent;min-height:clamp(40px,11vw,48px);display:flex;align-items:center;justify-content:center}
.koreksi-btn:active{transform:scale(0.95)}

/* INPUT BAR */
.input-bar{padding:clamp(6px,2vw,10px) clamp(8px,3.5vw,16px) calc(clamp(10px,3vw,18px) + env(safe-area-inset-bottom));display:flex;gap:clamp(4px,1.5vw,8px);align-items:center;flex-shrink:0;background:var(--bg);border-top:1px solid var(--line)}
.input-field{flex:1;min-width:0;padding:clamp(8px,2.8vw,12px) clamp(10px,3vw,18px);border:1.5px solid var(--line);border-radius:24px;font-family:inherit;font-size:clamp(11px,3.2vw,14px);background:#fff;color:var(--ink);outline:none;transition:border 0.2s}
.input-field:focus{border-color:var(--sage)}
.input-field::placeholder{color:#c4bdb0}
.send-btn{width:clamp(44px,12vw,54px);height:clamp(44px,12vw,54px);background:var(--sage);border-radius:50%;border:none;color:#fff;font-size:clamp(16px,4.5vw,20px);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform 0.15s;-webkit-tap-highlight-color:transparent}
.send-btn:active{transform:scale(0.9)}
.send-btn:disabled{background:#d4cdbe;cursor:not-allowed}

/* ONBOARDING */
.onboarding{display:none;padding:clamp(20px,6vw,32px) clamp(16px,5vw,24px);text-align:center;flex:1;justify-content:center;flex-direction:column}
.onboarding.active{display:flex}
.onboard-icon{font-size:clamp(40px,15vw,64px);margin-bottom:clamp(10px,3vw,16px);line-height:1}
.onboard-icon img{width:clamp(64px,20vw,96px);height:clamp(64px,20vw,96px);display:block;margin:0 auto clamp(10px,3vw,16px)}
.onboard-title{font-size:clamp(16px,5.5vw,22px);font-weight:700;color:var(--ink);margin-bottom:8px;letter-spacing:-0.3px}
.onboard-desc{font-size:clamp(11px,3.2vw,14px);color:#7a7468;line-height:1.6;margin-bottom:clamp(16px,4vw,24px)}
.start-btn{padding:clamp(12px,4vw,16px) clamp(32px,10vw,48px);background:var(--sage);color:#fff;border:none;border-radius:28px;font-size:clamp(14px,4.2vw,18px);font-weight:600;cursor:pointer;font-family:inherit;transition:transform 0.2s;-webkit-tap-highlight-color:transparent;min-height:clamp(44px,12vw,52px)}
.tagline{font-size:clamp(9px,2.5vw,12px);color:#b0a89a;margin-top:clamp(8px,2.5vw,12px)}
.setup-input{width:100%;padding:clamp(10px,3.5vw,14px) clamp(12px,4vw,18px);border:1.5px solid var(--line);border-radius:16px;font-family:inherit;font-size:clamp(13px,4vw,16px);background:#fff;color:var(--ink);outline:none;text-align:center;transition:border 0.2s}
.setup-input:focus{border-color:var(--sage)}
.main-chat{display:none;flex:1;flex-direction:column;overflow:hidden}
.main-chat.active{display:flex}

/* MODALS */
.modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.45);z-index:100;justify-content:center;align-items:center;padding:24px}
.modal-overlay.active{display:flex}
.modal-box{background:var(--bg);border-radius:24px;padding:clamp(20px,5vw,28px) clamp(16px,4vw,24px) clamp(14px,3.5vw,20px);max-width:360px;width:100%;text-align:center;box-shadow:0 24px 80px rgba(0,0,0,0.15);animation:modalIn 0.25s ease;max-height:85vh;overflow-y:auto}
@keyframes modalIn{from{transform:scale(0.94);opacity:0}to{transform:scale(1);opacity:1}}
.modal-icon{font-size:clamp(32px,8vw,48px);margin-bottom:clamp(8px,2vw,12px)}
.modal-title{font-size:clamp(15px,4vw,18px);font-weight:700;color:var(--ink);margin-bottom:6px}
.modal-desc{font-size:clamp(12px,3.2vw,14px);color:#7a7468;line-height:1.5;margin-bottom:clamp(14px,3.5vw,20px)}
.modal-actions{display:flex;gap:clamp(6px,2vw,10px);justify-content:center;flex-wrap:wrap}
.modal-btn{padding:clamp(12px,3.5vw,16px) clamp(24px,6vw,32px);border-radius:24px;font-size:clamp(14px,3.8vw,16px);font-weight:600;border:none;cursor:pointer;font-family:inherit;min-width:clamp(100px,28vw,140px);transition:transform 0.2s;-webkit-tap-highlight-color:transparent;min-height:clamp(44px,12vw,52px)}
.modal-btn:active{transform:scale(0.96)}
.modal-btn.primary{background:var(--sage);color:#fff}
.modal-btn.secondary{background:var(--chip);color:var(--ink-soft)}
.modal-btn.green{background:var(--green);color:var(--ink)}

/* REKAP TABLE */
.rekap-card{background:#f8f6f1;border-radius:16px;padding:clamp(8px,2.5vw,12px) clamp(10px,3vw,16px);text-align:left}
.r-line{display:flex;justify-content:space-between;font-size:clamp(10px,2.8vw,13px);padding:3px 0;gap:6px}
.r-lbl{color:var(--ink-soft);flex:1;min-width:0}
.r-val{font-weight:600;color:var(--ink);text-align:right;white-space:nowrap}
.r-untung .r-lbl,.r-untung .r-val{color:#2f7d4f;font-weight:700}
.rekap-divider{height:1px;background:var(--line);margin:6px 0}
.rekap-share-row{display:flex;gap:8px;margin-top:12px}

/* PROGRESS BAR */
.progress-wrap{margin:6px 0 2px}
.progress-bar{width:100%;height:10px;background:#e8e3d9;border-radius:8px;overflow:hidden;position:relative}
.progress-fill{height:100%;background:linear-gradient(90deg,#6fcf97,#3a9d63);border-radius:8px;transition:width 0.4s ease}
.progress-bar.over .progress-fill{background:linear-gradient(90deg,#f0c75e,#d9a441)}
.progress-label{font-size:11px;color:var(--ink-soft);margin-top:3px;text-align:right}

/* RIWAYAT ITEM */
.riwayat-item{background:#fff;border:1px solid var(--line);border-radius:12px;padding:clamp(6px,1.8vw,8px) clamp(8px,2.5vw,10px);margin:6px 0;font-size:clamp(10px,2.8vw,12px)}
.riwayat-id{font-size:clamp(9px,2.5vw,11px);color:#b0a89a;margin-bottom:3px;font-weight:500}
.riwayat-line{color:var(--ink-soft);line-height:1.6}
.riwayat-total{color:var(--ink);margin-top:3px;padding-top:3px;border-top:1px dashed var(--line)}

/* CLOSED OVERLAY */
.closed-overlay{display:none;position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.65);z-index:50;backdrop-filter:blur(4px);justify-content:center;align-items:center;flex-direction:column;padding:32px;color:#fff;text-align:center;border-radius:var(--radius)}
.closed-overlay.active{display:flex}
.closed-icon{font-size:clamp(36px,12vw,56px);margin-bottom:clamp(10px,3vw,16px);opacity:0.9}
.closed-title{font-size:clamp(16px,4.5vw,20px);font-weight:700;margin-bottom:4px}
.closed-desc{font-size:clamp(11px,3vw,14px);opacity:0.8;line-height:1.5;margin-bottom:clamp(14px,3.5vw,20px)}
.buka-btn{padding:clamp(10px,3.5vw,14px) clamp(28px,9vw,40px);background:var(--green);color:var(--ink);border:none;border-radius:28px;font-size:clamp(13px,4vw,16px);font-weight:700;cursor:pointer;font-family:inherit;transition:transform 0.2s;-webkit-tap-highlight-color:transparent}
.buka-btn:active{transform:scale(0.96)}

/* PWA INSTALL BANNER */
.install-banner{display:none;position:fixed;left:16px;right:16px;bottom:calc(16px + env(safe-area-inset-bottom));background:var(--ink);color:#fff;border-radius:18px;padding:14px 16px;z-index:200;box-shadow:0 12px 40px rgba(0,0,0,0.25);align-items:center;gap:12px;animation:slideUp 0.3s ease}
.install-banner.show{display:flex}
@keyframes slideUp{from{transform:translateY(120%);opacity:0}to{transform:translateY(0);opacity:1}}
.install-banner-icon{width:44px;height:44px;background:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.install-banner-text{flex:1;min-width:0}
.install-banner-title{font-size:13px;font-weight:600;line-height:1.2}
.install-banner-desc{font-size:11px;opacity:0.75;margin-top:2px}
.install-banner-btn{padding:8px 14px;background:var(--sage);color:#fff;border:none;border-radius:14px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;flex-shrink:0;-webkit-tap-highlight-color:transparent}
.install-banner-close{background:transparent;border:none;color:#fff;opacity:0.5;font-size:18px;cursor:pointer;padding:4px;-webkit-tap-highlight-color:transparent}

/* RESPONSIVE — TABLET & DESKTOP */
@media(min-width:768px){
  body{padding:24px}
  .phone{max-width:440px;height:min(820px,calc(100vh - 48px))}
}
@media(min-width:1024px){
  body{padding:32px;background:linear-gradient(135deg,#f5efe6 0%,#ede5d6 100%)}
  .phone{max-width:440px}
}

/* RESPONSIVE — MOBILE BREAKPOINTS */
@media(max-width:480px){
  body{padding:0}
  .phone{border-radius:0;height:100dvh;height:100vh;box-shadow:none}
  .closed-overlay{border-radius:0}
}
/* Ultra-tiny screens (foldable cover screen, old feature phones) */
@media(max-width:280px){
  .header{padding:8px 6px 6px}
  .header-left{gap:4px}
  .header-title{font-size:9px}
  .warung-name{font-size:13px}
  .warung-status{font-size:9px}
  .tutup-btn{padding:3px 6px;font-size:9px;border-radius:12px}
  .header-icon-btn{width:24px;height:24px;border-width:1px}
  .header-icon-btn .btn-fallback{font-size:10px}
  .quick-actions{padding:6px 6px;gap:3px}
  .q-chip{padding:4px 6px;font-size:8px;border-radius:14px}
  .quick-sell{padding:0 6px 4px;gap:3px}
  .qs-btn{padding:5px 7px;font-size:9px;border-radius:16px;border-width:1px}
  .chat-area{padding:6px 6px}
  .msg{font-size:10px;padding:6px 8px;max-width:90%;border-radius:14px}
  .msg-time{font-size:7px}
  .msg.bot .bot-name{font-size:9px}
  .input-bar{padding:4px 6px calc(8px + env(safe-area-inset-bottom));gap:3px}
  .input-field{padding:6px 8px;font-size:10px;border-radius:16px;border-width:1px}
  .send-btn{width:30px;height:30px;font-size:11px;border-radius:50%}
  .onboarding{padding:12px 8px}
  .onboard-icon{font-size:32px;margin-bottom:6px}
  .onboard-title{font-size:14px}
  .onboard-desc{font-size:10px;margin-bottom:12px}
  .start-btn{padding:8px 20px;font-size:11px;border-radius:20px}
  .tagline{font-size:8px}
  .setup-input{padding:8px 10px;font-size:11px;border-radius:12px}
  .modal-overlay{padding:8px}
  .modal-box{padding:14px 10px 10px;max-width:100%;border-radius:16px}
  .modal-icon{font-size:24px;margin-bottom:6px}
  .modal-title{font-size:13px}
  .modal-desc{font-size:10px;margin-bottom:10px}
  .modal-btn{padding:7px 12px;font-size:11px;min-width:70px;border-radius:16px}
  .rekap-card{padding:6px 8px;border-radius:10px}
  .r-line{font-size:9px;gap:4px}
  .riwayat-item{padding:5px 6px;font-size:9px;border-radius:8px}
  .riwayat-id{font-size:8px}
  .closed-icon{font-size:28px;margin-bottom:6px}
  .closed-title{font-size:13px}
  .closed-desc{font-size:9px;margin-bottom:10px}
  .buka-btn{padding:8px 20px;font-size:11px;border-radius:20px}
}
@media(max-height:600px){
  /* Short screens (landscape phone) */
  .phone{height:100vh;border-radius:0;box-shadow:none}
  .onboarding{padding:20px 24px}
  .onboard-icon{font-size:48px;margin-bottom:8px}
  .onboard-desc{margin-bottom:16px}
}
@media(prefers-color-scheme:dark){
  /* Dark mode hint (not full impl, just safe defaults) */
  :root{--bg:#FDFBF7} /* keep cream for now */
}

/* TYPING INDICATOR (animated dots for async AI summaries) */
.typing-dots{display:inline-flex;align-items:center;gap:4px;vertical-align:middle;margin:0 2px}
.typing-dots span{width:6px;height:6px;border-radius:50%;background:var(--sage);display:inline-block;animation:typingBounce 1.4s infinite ease-in-out both}
.typing-dots span:nth-child(1){animation-delay:-0.32s}
.typing-dots span:nth-child(2){animation-delay:-0.16s}
@keyframes typingBounce{0%,80%,100%{transform:scale(0.5);opacity:0.35}40%{transform:scale(1);opacity:1}}

/* iOS input zoom prevention */
@supports(-webkit-touch-callout:none){
  .input-field,.setup-input{font-size:16px}
}

/* Reduce motion for accessibility */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important}
}

/* PROMOSI (AI-generated WA Story caption) */
.promo-box{background:var(--chip);border-left:3px solid #8b7e6a;border-radius:10px;padding:clamp(10px,3vw,14px);margin:6px 0 10px;font-size:clamp(13px,3.4vw,15px);line-height:1.55;color:var(--ink);white-space:pre-wrap}
.promo-actions{display:flex;gap:8px;flex-wrap:wrap}
.promo-btn{flex:1;min-width:120px;min-height:44px;padding:10px 14px;border:none;border-radius:12px;background:#f0ede6;color:#5a5245;font-family:inherit;font-weight:600;font-size:clamp(12px,3.2vw,14px);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform 0.15s}
.promo-btn:active{transform:scale(0.96)}
.promo-btn.wa{background:#6fcf97;color:#fff}
