/* Bot bubble — glass panel + gold glow + top-highlight gloss */
.msg.bot .bubble{
  background:var(--panel);
  border:1px solid var(--gb);
  border-radius:4px var(--r3) var(--r3) var(--r3);
  box-shadow:var(--glow-bot),inset 0 1px 0 rgba(255,255,255,.08);
  color:var(--tx1);
}
/* bubbleBreath removed — gloss sweep handles animation */
/* Sweeping gloss animation */
.msg.bot .bubble::after{
  content:'';position:absolute;top:-10%;left:0;width:45%;height:120%;
  background:linear-gradient(90deg,transparent 10%,rgba(255,255,255,.22) 50%,transparent 90%);
  will-change:transform;
  animation:glossLoop 5.3s ease-in-out infinite;
  pointer-events:none;
}

/* User bubble — warm gold glow */
.msg.user .bubble{
  background:rgba(212,175,55,.15);
  border:1px solid rgba(212,175,55,.35);
  border-radius:var(--r3) 4px var(--r3) var(--r3);
  box-shadow:0 2px 12px rgba(212,175,55,.18),inset 0 1px 0 rgba(255,255,255,.08);
  color:#fff7e0;font-weight:600;
}
.msg.user .bubble::after{
  content:'';position:absolute;top:-10%;left:0;width:45%;height:120%;
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.26),transparent);
  will-change:transform,opacity;
  animation:glossLoop 5.3s ease-in-out .8s infinite;
  pointer-events:none;
}

/* Typing indicator */
.typing-dots{display:flex;align-items:center;gap:5px;padding:3px 2px;}
.typing-dots span{width:6px;height:6px;border-radius:50%;background:var(--g5);opacity:.5;
  animation:dotWave 1.4s ease-in-out infinite;}
.typing-dots span:nth-child(2){animation-delay:.18s;}
.typing-dots span:nth-child(3){animation-delay:.36s;}

/* ============================================================
   OPTION BUTTONS — gloss sweep
   ============================================================ */
.opts-wrap{width:100%;padding:3px 0;}
.opts-grid{display:grid;gap:7px;}
.opts-grid.c2{grid-template-columns:repeat(2,1fr);}
.opts-grid.c3{grid-template-columns:repeat(3,1fr);}
.opts-grid.c4{grid-template-columns:repeat(4,1fr);}

.opt-btn{
  position:relative;overflow:hidden;
  clip-path:inset(0 round var(--r2));
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:4px;padding:14px 8px;
  background:var(--panel);border:1.5px solid rgba(212,175,55,.36);border-radius:var(--r2);
  cursor:pointer;color:var(--tx1);
  transition:all var(--tf) var(--spring);
  animation:optIn .32s var(--spring) both;
}
/* Top gloss */
/* Sweeping gloss — entrance cascade + hover */
.opt-btn::after{content:'';position:absolute;top:-10%;left:0;width:50%;height:120%;
  background:linear-gradient(90deg,transparent 10%,rgba(255,255,255,.55) 50%,transparent 90%);
  will-change:transform;opacity:0;pointer-events:none;}
.opt-btn:hover::after{animation:glossLoop .65s ease-out forwards;}
.opt-btn:nth-child(1){animation-delay:.03s;}
.opt-btn:nth-child(2){animation-delay:.07s;}
.opt-btn:nth-child(3){animation-delay:.11s;}
.opt-btn:nth-child(4){animation-delay:.15s;}
.opt-btn:nth-child(5){animation-delay:.19s;}
.opt-btn:nth-child(6){animation-delay:.23s;}
.opt-btn:nth-child(7){animation-delay:.27s;}
.opt-btn:nth-child(8){animation-delay:.31s;}
.opt-btn:nth-child(9){animation-delay:.35s;}
.opt-btn:nth-child(10){animation-delay:.39s;}
.opt-btn:nth-child(11){animation-delay:.43s;}
.opt-btn:nth-child(12){animation-delay:.47s;}

.opt-btn:hover{border-color:rgba(212,175,55,.68);background:rgba(212,175,55,.1);
  box-shadow:0 8px 28px rgba(212,175,55,.2),inset 0 1px 0 rgba(255,255,255,.12);transform:translateY(-2px) scale(1.03);}
.opt-btn:active{transform:scale(.9);transition:transform .08s!important;}
.opt-btn:active::before{content:'';position:absolute;inset:0;border-radius:var(--r2);background:rgba(212,175,55,.15);animation:btnRipple .5s ease-out forwards;pointer-events:none;z-index:4;}
.opt-btn.selected{border-color:var(--g5);
  background:rgba(212,175,55,.18);
  box-shadow:var(--shgh),inset 0 0 0 1px rgba(212,175,55,.3);pointer-events:none;
  animation:selectPop .25s var(--spring);}

.opt-icon{font-size:19px;line-height:1;}
.vtype-icon{width:38px;height:23px;color:var(--g4);display:block;transition:color var(--tf);}
.vi{width:32px;height:32px;color:var(--g4);display:block;transition:color var(--tf),transform var(--tf);}
.opt-btn:hover .vtype-icon,.opt-btn.selected .vtype-icon{color:var(--g2);}
.opt-btn:hover .vi,.opt-btn.selected .vi{color:var(--g2);transform:scale(1.1);}
.opt-label{font-size:13px;font-weight:700;letter-spacing:.02em;text-align:center;color:rgba(255,255,255,.94);}
.opt-desc{font-size:9.5px;color:rgba(255,255,255,.6);letter-spacing:.02em;text-align:center;line-height:1.4;}

/* ============================================================
   BRAND FLIP CARDS — real logos, gloss, 5-col
   ============================================================ */
.brand-wrap{width:100%;}
.brand-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:7px;padding:3px 0;contain:layout;}

.brand-card{height:90px;cursor:pointer;perspective:700px;animation:optIn .28s var(--spring) both;}
/* Stagger delays */
.brand-card:nth-child(1){animation-delay:.02s}.brand-card:nth-child(2){animation-delay:.04s}
.brand-card:nth-child(3){animation-delay:.06s}.brand-card:nth-child(4){animation-delay:.08s}
.brand-card:nth-child(5){animation-delay:.10s}.brand-card:nth-child(6){animation-delay:.12s}
.brand-card:nth-child(7){animation-delay:.14s}.brand-card:nth-child(8){animation-delay:.16s}
.brand-card:nth-child(9){animation-delay:.18s}.brand-card:nth-child(10){animation-delay:.20s}
.brand-card:nth-child(11){animation-delay:.22s}.brand-card:nth-child(12){animation-delay:.24s}
.brand-card:nth-child(13){animation-delay:.26s}.brand-card:nth-child(14){animation-delay:.28s}
.brand-card:nth-child(15){animation-delay:.30s}.brand-card:nth-child(16){animation-delay:.32s}
.brand-card:nth-child(17){animation-delay:.34s}.brand-card:nth-child(18){animation-delay:.36s}
.brand-card:nth-child(19){animation-delay:.38s}.brand-card:nth-child(20){animation-delay:.40s}
.brand-card:nth-child(21){animation-delay:.42s}.brand-card:nth-child(22){animation-delay:.44s}

.brand-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;
  transition:transform .6s var(--spring);}
/* Gold check overlay appears on front face after selection */
.brand-card.flipped .brand-front::before{
  content:'✓';position:absolute;top:5px;right:7px;
  font-size:13px;font-weight:900;color:var(--g3);
  text-shadow:0 0 10px rgba(212,175,55,.9);
  animation:checkPop .35s var(--spring);z-index:4;
}
.brand-card.flipped .brand-inner{transform:rotateY(360deg);}
.brand-card:not(.flipped):hover{transform:scale(1.06);}
.brand-card:not(.flipped):active{transform:scale(.95);}
.brand-card:not(.flipped):hover .brand-inner{transform:rotateY(6deg);}

.brand-face{
  position:absolute;inset:0;
  backface-visibility:hidden;-webkit-backface-visibility:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:5px;border-radius:var(--r2);overflow:hidden;
}
/* Top gloss on both faces */
/* Sweeping gloss — entrance once (staggered via nth-child) + hover */
.brand-face::after{
  content:'';position:absolute;top:-10%;left:0;width:55%;height:120%;
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.32),transparent);
  will-change:transform,opacity;
  pointer-events:none;z-index:3;
  animation:none;opacity:0;
}
.brand-card:not(.flipped):hover .brand-front::after{
  animation:glossLoop .65s ease-out forwards;
}
.brand-card.flipped:hover .brand-back::after{
  animation:glossLoop .65s ease-out forwards;
}

.brand-front{
  background:rgba(28,28,36,.97);
  border:1px solid var(--gb);
  box-shadow:0 3px 10px rgba(0,0,0,.35);
  transition:background .3s,border-color .3s,box-shadow .3s;
}
/* Selected highlight — shown after 360° spin completes */
.brand-card.flipped .brand-front{
  background:rgba(212,175,55,.18);
  border-color:var(--g4);
  box-shadow:0 0 24px rgba(212,175,55,.45),inset 0 0 16px rgba(212,175,55,.08);
}
.brand-card:not(.flipped):hover .brand-front{
  box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 8px 24px rgba(0,0,0,.45),var(--shg);
  transform:translateY(-2px) scale(1.04);
}
.brand-back{
  background:rgba(212,175,55,.16);
  border:1px solid var(--g5);
  box-shadow:inset 0 0 20px rgba(212,175,55,.08);
  transform:rotateY(180deg); /* back face — never visible at 360° spin */
  visibility:hidden;
}

.brand-logo-img{
  width:42px;height:42px;object-fit:contain;position:relative;z-index:1;
  padding:7px;
  background:linear-gradient(160deg,#ffffff 0%,#f0f0f0 100%);
  border-radius:50%;
  /* 3D raised effect: top-left highlight, bottom-right shadow, ambient glow */
  box-shadow:
    0 1px 0 rgba(255,255,255,.9) inset,
    0 -1px 0 rgba(0,0,0,.05) inset,
    2px 4px 8px rgba(0,0,0,.22),
    0 1px 2px rgba(0,0,0,.15),
    -1px -1px 0 rgba(255,255,255,.6);
  filter:none;
  transition:transform .18s var(--spring),box-shadow .18s;
}
.brand-card:not(.flipped):hover .brand-logo-img{
  transform:scale(1.1) translateY(-2px);
  box-shadow:
    0 1px 0 rgba(255,255,255,.9) inset,
    0 -1px 0 rgba(0,0,0,.05) inset,
    3px 7px 14px rgba(0,0,0,.2),
    0 2px 4px rgba(212,175,55,.3),
    -1px -1px 0 rgba(255,255,255,.7);
}
.brand-card:not(.flipped):active .brand-logo-img{
  transform:scale(.97) translateY(1px);
  box-shadow:
    0 1px 0 rgba(255,255,255,.9) inset,
    0 -1px 0 rgba(0,0,0,.08) inset,
    1px 2px 4px rgba(0,0,0,.4),
    0 0 0 rgba(212,175,55,0),
    -1px -1px 0 rgba(255,255,255,.5);
}


.brand-name-txt{
  font-size:7.5px;font-weight:700;letter-spacing:.04em;color:var(--tx2);
  text-align:center;position:relative;z-index:1;line-height:1.2;
  max-width:90%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.brand-check{
  font-size:26px;color:var(--g4);position:relative;z-index:1;
  filter:drop-shadow(0 0 10px rgba(212,175,55,.9));
  animation:checkPop .38s var(--spring);
}
.brand-sel-name{
  font-size:7.5px;font-weight:700;color:var(--g2);text-align:center;
  position:relative;z-index:1;letter-spacing:.04em;
  max-width:90%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

.brand-confirm{
  margin-top:10px;width:100%;padding:13px;
  background:var(--panel);border:1px solid var(--gb);border-radius:var(--r2);
  cursor:pointer;color:var(--tx3);font-family:var(--fb);font-size:13px;font-weight:700;
  letter-spacing:.04em;text-align:center;
  transition:all var(--tm) var(--eout);
  position:relative;overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.brand-confirm::before{content:'';position:absolute;inset:0;background:var(--gsh);pointer-events:none;}
.brand-confirm.ready{
  background:rgba(212,175,55,.16);
  border-color:var(--g5);color:var(--g2);box-shadow:var(--shg);
}
.brand-confirm:disabled{opacity:.45;cursor:not-allowed;}
.brand-skip-btn{display:block;width:100%;margin-top:10px;background:rgba(255,255,255,.04);border:1px dashed rgba(212,175,55,.28);
  cursor:pointer;font-family:var(--fb);font-size:12px;font-weight:800;letter-spacing:.03em;
  color:#ffe7a1;padding:10px 14px;text-align:center;transition:all var(--tf);border-radius:12px;}
.brand-skip-btn:hover{color:var(--g4);background:rgba(212,175,55,.08);border-color:rgba(212,175,55,.42);transform:translateY(-1px);}

/* ============================================================
   REVIEW / INLINE EDIT
   ============================================================ */
.review-card{background:var(--panel);border:1px solid var(--gb);border-radius:var(--r3);
  overflow:hidden;box-shadow:var(--shg),var(--sh2);position:relative;}
.review-card::before{content:'';position:absolute;inset:0;background:var(--gsh);pointer-events:none;}
.review-head{padding:11px 16px;
  background:linear-gradient(90deg,rgba(212,175,55,.12),transparent);
  border-bottom:1px solid rgba(212,175,55,.14);
  font-family:var(--fd);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--g3);}
.review-row{display:grid;grid-template-columns:78px 1fr;border-bottom:1px solid rgba(255,255,255,.04);transition:background var(--tf);animation:floatUp .25s var(--eout) both;}
.review-row:last-child{border-bottom:none;}
.review-row:hover{background:rgba(255,255,255,.015);}
.rev-label{font-size:9.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  color:var(--tx3);padding:10px 0 10px 16px;align-self:center;}
.rev-val-wrap{display:flex;align-items:center;justify-content:space-between;padding:8px 12px 8px 8px;gap:6px;}
.rev-val{font-size:13px;font-weight:600;color:var(--tx1);flex:1;word-break:break-word;}
.rev-input{
  background:rgba(212,175,55,.07);border:1px solid var(--gbh);border-radius:8px;
  color:var(--tx1);font-family:var(--fb);font-size:13px;font-weight:600;
  padding:6px 10px;outline:none;width:100%;transition:all var(--tf);}
.rev-input:focus{border-color:var(--g4);box-shadow:0 0 0 3px rgba(212,175,55,.1);}
select.rev-input{
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23D4AF37' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;
  background-color:rgba(212,175,55,.07);padding-right:30px;cursor:pointer;}
select.rev-input option{background:#1a1a22;color:var(--tx1);}
.rev-edit-btn{padding:7px 13px;background:linear-gradient(135deg,rgba(212,175,55,.22),rgba(212,175,55,.1));border:1px solid rgba(212,175,55,.42);
  border-radius:999px;cursor:pointer;color:#ffe7a1;font-size:10.5px;font-weight:800;
  letter-spacing:.05em;white-space:nowrap;transition:all var(--tf);flex-shrink:0;box-shadow:0 6px 20px rgba(212,175,55,.16);}
.rev-edit-btn:hover{background:linear-gradient(135deg,rgba(212,175,55,.32),rgba(212,175,55,.14));border-color:var(--g5);transform:translateY(-1px);box-shadow:0 8px 24px rgba(212,175,55,.22);}
.rev-save-btn{padding:3px 9px;background:rgba(74,222,128,.12);border:1px solid rgba(74,222,128,.3);
  border-radius:6px;cursor:pointer;color:#4ade80;font-size:9px;font-weight:700;
  letter-spacing:.06em;white-space:nowrap;transition:all var(--tf);flex-shrink:0;}
.rev-save-btn:hover{background:rgba(74,222,128,.22);}

.submit-btn{margin-top:10px;width:100%;padding:15px;background:var(--grad);border:none;
  border-radius:var(--r2);cursor:pointer;color:#0a0800;font-family:var(--fd);font-size:12px;
  font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  box-shadow:0 6px 32px rgba(212,175,55,.42);
  transition:all var(--tf) var(--spring);position:relative;overflow:hidden;}
.submit-btn::after{content:'';position:absolute;top:0;left:-100%;width:200%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.32),transparent);transition:left .5s;}
.submit-btn:hover::after{left:100%;}
.submit-btn:hover{box-shadow:0 8px 44px rgba(212,175,55,.6);transform:translateY(-1px);}
.submit-btn:active{transform:scale(.97);}

/* ============================================================
   COMPLETION
   ============================================================ */
.completion{text-align:center;padding:14px 8px;animation:completionReveal .6s var(--eout) both;}
.check-ring{width:76px;height:76px;margin:0 auto 14px;}
.check-ring svg{width:100%;height:100%;}
.check-circle{fill:none;stroke:url(#ckg);stroke-width:2.5;stroke-dasharray:210;stroke-dashoffset:210;animation:drawCircle .75s var(--eout) .1s forwards;}
.check-tick{fill:none;stroke:var(--g3);stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:40;stroke-dashoffset:40;animation:drawTick .4s var(--eout) .7s forwards;filter:drop-shadow(0 0 6px rgba(212,175,55,.6));}
.comp-title{font-family:var(--fd);font-size:20px;font-weight:800;letter-spacing:.06em;
  background:var(--gradb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px;}
.comp-text{font-size:13px;color:var(--tx2);line-height:1.65;max-width:320px;margin:0 auto 6px;}
.comp-text strong{color:var(--g3);}
.comp-summary{margin:10px 0 14px;background:var(--panel);border:1px solid var(--gb);border-radius:var(--r2);
  padding:10px 14px;text-align:left;position:relative;overflow:hidden;
  box-shadow:var(--shg);}
.comp-summary::before{content:'';position:absolute;inset:0;background:var(--gsh);pointer-events:none;}
.comp-summary-title{font-family:var(--fd);font-size:9px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--g4);margin-bottom:8px;}
.comp-summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px 12px;}
.cs-item{font-size:11.5px;color:var(--tx2);line-height:1.4;}
.cs-item strong{color:var(--tx1);font-weight:700;}
.cs-deal-row{grid-column:1/-1;border-top:1px solid rgba(212,175,55,.12);padding-top:6px;margin-top:2px;}
.cs-deal-val{color:var(--g4);font-weight:700;}
.comp-btns{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px;}
.comp-btns .btn-deals{grid-column:1/-1;}
.comp-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:var(--r2);
  text-decoration:none;font-size:13px;font-weight:700;letter-spacing:.04em;cursor:pointer;
  transition:all var(--tf) var(--spring);position:relative;overflow:hidden;border:none;}
.comp-btn::before{content:'';position:absolute;inset:0;background:var(--gsh);pointer-events:none;}
.comp-btn::after{content:'';position:absolute;top:-10%;left:0;width:50%;height:120%;
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.2),transparent);
  will-change:transform,opacity;opacity:0;pointer-events:none;}
.comp-btn svg{width:17px;height:17px;flex-shrink:0;}
.comp-btn:hover::after{animation:glossLoop .65s ease-out forwards;}
.btn-email{background:var(--panelh);border:1px solid var(--gb);color:var(--g2);box-shadow:var(--shg);}
.btn-restart{background:rgba(212,175,55,.1);border:1.5px solid rgba(212,175,55,.4);color:var(--g3);font-weight:700;}
.btn-deals{background:linear-gradient(135deg,rgba(96,165,250,.16),rgba(37,99,235,.08));
  border:1px solid rgba(96,165,250,.3);color:rgba(147,197,253,.9);}
.btn-deals:hover{box-shadow:0 4px 20px rgba(96,165,250,.25) !important;}
.btn-share{background:rgba(212,175,55,.16);
  border:1px solid rgba(212,175,55,.4);color:var(--g2);}
.btn-share:hover{box-shadow:var(--shg) !important;}
.comp-btn:hover{transform:translateY(-2px) scale(1.03);}
.comp-btn:active{transform:scale(.97);}

/* ============================================================
   CHAT ACTION DOCK
   ============================================================ */
.chat-action-dock{padding:0 14px 8px;flex-shrink:0;animation:completionReveal .28s var(--spring) both;}
.chat-back-btn{width:100%;display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--panel);border:1px solid var(--gb);border-radius:18px;box-shadow:var(--glow-bot),inset 0 1px 0 rgba(255,255,255,.08);position:relative;overflow:hidden;cursor:pointer;transition:all var(--tf) var(--spring);color:var(--tx1);text-align:left;}
.chat-back-btn::after{content:'';position:absolute;top:-10%;left:0;width:48%;height:120%;background:linear-gradient(105deg,transparent,rgba(255,255,255,.2),transparent);opacity:0;pointer-events:none;}
.chat-back-btn:hover{transform:translateY(-2px);border-color:var(--gbh);box-shadow:var(--shg),inset 0 1px 0 rgba(255,255,255,.1);}
.chat-back-btn:hover::after{animation:glossLoop .65s ease-out forwards;}
.chat-back-btn:active{transform:scale(.985);}
.chat-back-icon{width:40px;height:40px;flex-shrink:0;border-radius:14px;display:flex;align-items:center;justify-content:center;background:rgba(212,175,55,.12);border:1px solid rgba(212,175,55,.25);color:var(--g3);box-shadow:inset 0 1px 0 rgba(255,255,255,.08);}
.chat-back-icon svg{width:18px;height:18px;}
.chat-back-copy{display:flex;flex-direction:column;gap:2px;min-width:0;}
.chat-back-copy strong{font-size:13px;letter-spacing:.03em;color:var(--g2);}
.chat-back-copy small{font-size:11px;line-height:1.45;color:var(--tx2);}

/* ============================================================
   INPUT
   ============================================================ */
.inp-wrap{padding:6px 14px 8px;flex-shrink:0;
  background:rgba(8,8,12,.92);
  border-top:1px solid rgba(255,255,255,.04);
  backdrop-filter:blur(8px);transition:all var(--tm) var(--eout);
  max-height:120px;overflow:hidden;}
.inp-wrap.hidden{opacity:0;pointer-events:none;transform:translateY(6px);max-height:0 !important;padding-top:0;padding-bottom:0;overflow:hidden;}
.inp-box{display:flex;align-items:center;gap:10px;padding:8px 8px 8px 18px;
  background:var(--panelh);border:1.5px solid rgba(212,175,55,.32);border-radius:50px;
  box-shadow:var(--sh2),0 0 0 0 rgba(212,175,55,0);
  transition:border-color var(--tf),box-shadow var(--tf);position:relative;overflow:hidden;}
.inp-box::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.16),transparent);}
.inp-box:focus-within{border-color:rgba(212,175,55,.7);box-shadow:var(--sh2),0 0 0 4px rgba(212,175,55,.13),0 0 28px rgba(212,175,55,.14);}
.inp-box.shake{animation:shake .34s ease-in-out;border-color:rgba(239,68,68,.5);}
.txt-inp{flex:1;background:none;border:none;outline:none;color:var(--tx1);
  font-family:var(--fb);font-size:17px;font-weight:500;min-width:0;caret-color:var(--g4);letter-spacing:.01em;}
.txt-inp::placeholder{color:var(--tx3);}
.snd-btn{width:40px;height:40px;flex-shrink:0;border-radius:50%;border:none;cursor:pointer;
  background:var(--grad);display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 14px rgba(212,175,55,.34);transition:all var(--tf) var(--spring);
  position:relative;overflow:hidden;}
.snd-btn::after{content:'';position:absolute;top:-10%;left:0;width:50%;height:120%;
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.3),transparent);
  will-change:transform,opacity;opacity:0;pointer-events:none;}
.snd-btn:not(:disabled):hover::after{animation:glossLoop .65s ease-out forwards;}
.snd-btn:disabled{background:rgba(255,255,255,.07);cursor:not-allowed;box-shadow:none;}
.snd-btn:disabled::after{display:none;}
.snd-btn:not(:disabled):hover{transform:scale(1.1);box-shadow:0 4px 20px rgba(212,175,55,.52);}
.snd-btn:not(:disabled):active{transform:scale(.9);}
.snd-btn svg{width:15px;height:15px;position:relative;z-index:1;}
.snd-btn:disabled svg{opacity:.28;}

/* ============================================================
   SKIP BUTTON (phone step)
   ============================================================ */
.skip-wrap{display:none;justify-content:center;padding:6px 0 2px;}
.skip-btn{background:rgba(255,255,255,.04);border:1px dashed rgba(212,175,55,.28);cursor:pointer;
  font-family:var(--fb);font-size:11.5px;font-weight:800;letter-spacing:.04em;
  color:#ffe7a1;padding:8px 14px;border-radius:999px;
  transition:all var(--tf);text-decoration:none;}
.skip-btn:hover{color:var(--g3);background:rgba(212,175,55,.08);border-color:rgba(212,175,55,.45);transform:translateY(-1px);}

/* ============================================================
   MATH CAPTCHA MODAL
   ============================================================ */

/* ── FINAL POLISH ────────────────────────────────────────────────────────── */
/* First bot message (welcome) — slightly larger, more impactful */
.msg.bot:first-child .bubble {
  font-size: 14.5px;
  line-height: 1.72;
}

/* Review step — cleaner row layout */
.review-card { gap: 0; }
.review-row {
  border-bottom: 1px solid rgba(212,175,55,.08);
  transition: background var(--tf);
}
.review-row:last-child { border-bottom: none; }
.review-row:hover { background: rgba(212,175,55,.03); }

/* Deal selected banner — more premium */
.deal-selected-banner {
  background: linear-gradient(135deg, rgba(212,175,55,.1), rgba(212,175,55,.04));
  border: 1px solid rgba(212,175,55,.3);
  border-radius: 14px;
  padding: 16px 18px;
  position: relative;
  overflow: hidden;
}
.deal-selected-banner::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(212,175,55,.6), transparent);
}

/* Better progress bar labels on narrow screens */
@media(max-width:400px) {
  #progStepText { font-size: 9px; }
}

/* Typing dots — slightly larger and smoother */
.typing-dots span {
  width: 7px;
  height: 7px;
}

/* Skip / phone skip button — more visible */
.skip-btn {
  font-size: 12px;
  letter-spacing: .02em;
}

/* Completion screen — slightly more breathing room */
.completion {
  padding: 6px 0 4px;
}

/* ═══════════════════════════════════════════════════════════════
   HOT DEAL SECTION
   ═══════════════════════════════════════════════════════════════ */
.hot-tab{
  background:rgba(212,175,55,.12)!important;
  color:var(--g5)!important;
  border-color:rgba(212,175,55,.28)!important;
}
.hot-tab.active,
.hot-tab:hover{
  background:rgba(212,175,55,.22)!important;
  color:var(--g4)!important;
}
.hot-why-no-promo{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);
  border-radius:14px;
  padding:18px 16px;
  margin-bottom:20px;
}
.hot-icon-badge{
  font-size:18px;
  color:var(--g5);
  margin-bottom:10px;
  opacity:.7;
}
.hot-section-title{
  font-family:var(--fd);
  font-size:10px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--g5);
  margin:0 0 10px;
}
.hot-body-text{
  font-size:12.5px;
  color:var(--tx2);
  line-height:1.75;
  margin:0 0 8px;
}
.hot-deal-section{
  border:1px solid rgba(212,175,55,.28);
  border-radius:14px;
  padding:16px;
  background:rgba(212,175,55,.04);
}
.hot-deal-label{
  display:flex;
  align-items:center;
  gap:7px;
  margin-bottom:14px;
}
.hot-flame{ font-size:16px; }
.hot-label-text{
  font-family:var(--fd);
  font-size:9px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  background:var(--gradb);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.hot-deal-card{
  background:linear-gradient(135deg,rgba(212,175,55,.10),rgba(212,175,55,.04));
  border:1px solid rgba(212,175,55,.22);
  border-radius:12px;
  padding:14px 14px 10px;
  margin-bottom:12px;
}
.hot-deal-badge{
  display:inline-block;
  font-size:9px;
  font-weight:800;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--g5);
  border:1px solid rgba(212,175,55,.3);
  border-radius:20px;
  padding:3px 10px;
  margin-bottom:8px;
}
.hot-deal-headline{
  font-size:15px;
  font-weight:800;
  color:var(--tx1);
  line-height:1.4;
  margin-bottom:6px;
}
.hot-deal-sub{
  font-size:12px;
  color:var(--tx2);
  margin-bottom:6px;
}
.hot-deal-exp{
  font-size:11px;
  color:rgba(212,175,55,.6);
  margin-bottom:6px;
}
.hot-deal-notes{
  font-size:12px;
  color:var(--tx3);
  line-height:1.6;
  margin-bottom:6px;
}
.hot-deal-fine-print{
  font-size:10px;
  color:rgba(255,255,255,.25);
  font-style:italic;
  border-top:1px solid rgba(255,255,255,.06);
  padding-top:8px;
  margin-top:8px;
}
.hot-deal-empty{
  text-align:center;
  padding:16px 0;
  color:var(--tx3);
  font-size:12.5px;
}
.hot-deal-empty-sub{
  font-size:11px;
  color:rgba(255,255,255,.25);
  margin-top:6px;
}
.hot-deal-cta-wrap{
  border-top:1px solid rgba(212,175,55,.14);
  padding-top:14px;
  margin-top:2px;
}
.hot-deal-cta-text{
  font-size:12px;
  color:var(--tx2);
  line-height:1.65;
  margin-bottom:12px;
}
.hot-deal-email-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  width:100%;
  padding:13px;
  background:linear-gradient(135deg,rgba(212,175,55,.22),rgba(212,175,55,.08));
  border:1px solid rgba(212,175,55,.42);
  border-radius:12px;
  color:var(--g4);
  font-size:13px;
  font-weight:800;
  letter-spacing:.04em;
  cursor:pointer;
  transition:all .2s;
}
.hot-deal-email-btn:hover{
  background:linear-gradient(135deg,rgba(212,175,55,.32),rgba(212,175,55,.14));
}
.hot-deal-email-btn svg{
  width:16px;height:16px;stroke:currentColor;flex-shrink:0;
}
.hot-deal-email-reveal{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  padding:12px;
  background:rgba(212,175,55,.06);
  border:1px solid rgba(212,175,55,.2);
  border-radius:12px;
}
.hot-deal-email-link{
  font-size:14px;
  font-weight:800;
  color:var(--g4);
  text-decoration:none;
}
.hot-deal-email-link:hover{ text-decoration:underline; }
.hot-deal-email-addr{
  font-size:11px;
  color:rgba(212,175,55,.5);
  font-family:monospace;
  letter-spacing:.04em;
}
.hot-deal-admin-toggle{
  border-top:1px solid rgba(255,255,255,.05);
  padding-top:12px;
  margin-top:10px;
  text-align:right;
}
.hot-admin-btn{
  font-size:10px;
  color:rgba(255,255,255,.2);
  background:none;
  border:none;
  cursor:pointer;
  letter-spacing:.04em;
  transition:color .2s;
}
.hot-admin-btn:hover{ color:rgba(255,255,255,.4); }

/* ── HOT DEAL OVERLAY PAGE ────────────────────────────────────────────── */
.hot-deal-overlay{
  position:fixed;inset:0;z-index:90;display:flex;align-items:flex-end;justify-content:center;
  background:rgba(0,0,0,0);pointer-events:none;
  visibility:hidden;
  transition:background var(--tm),visibility 0s linear var(--tm);
}
.hot-deal-overlay.open{
  background:rgba(0,0,0,.78);pointer-events:all;backdrop-filter:blur(5px);
  visibility:visible;
  transition:background var(--tm),visibility 0s linear 0s;
}
.hot-deal-page{
  width:100%;max-width:540px;max-height:85vh;max-height:85dvh;
  background:linear-gradient(168deg,var(--d1) 0%,var(--d3) 100%);
  border:1px solid var(--gb);border-radius:var(--r4) var(--r4) 0 0;
  display:flex;flex-direction:column;overflow:hidden;
  transform:translateY(100%);transition:transform var(--tm) var(--eout);
  box-shadow:0 -20px 60px rgba(0,0,0,.65);
}
.hot-deal-overlay.open .hot-deal-page{ transform:translateY(0); }

.hot-deal-page-hdr{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px;border-bottom:1px solid var(--gb);
  background:linear-gradient(90deg,rgba(212,175,55,.1),transparent);
  flex-shrink:0;
}
.hot-deal-page-title{
  font-family:var(--fd);font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hot-deal-page-close{
  width:28px;height:28px;border-radius:50%;background:var(--gl1);border:1px solid var(--gb);
  cursor:pointer;color:var(--tx2);font-size:17px;display:flex;align-items:center;justify-content:center;
  transition:all var(--tf);
}
.hot-deal-page-close:hover{ background:var(--gl3);color:var(--tx1); }

.hot-deal-page-body{
  flex:1;overflow-y:auto;padding:20px;
}

/* Deal card */
.hot-deal-card{
  background:linear-gradient(145deg,rgba(212,175,55,.12),rgba(212,175,55,.04));
  border:1px solid rgba(212,175,55,.28);border-radius:16px;
  padding:20px;margin-bottom:16px;
}
.hot-deal-photo-wrap{
  border-radius:10px;overflow:hidden;margin-bottom:14px;
  max-height:220px;background:rgba(255,255,255,.04);
}
.hot-deal-photo{
  width:100%;max-height:220px;object-fit:cover;display:block;
}
.hot-deal-badge{
  display:inline-block;font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  background:linear-gradient(90deg,rgba(212,175,55,.25),rgba(212,175,55,.1));
  border:1px solid rgba(212,175,55,.4);color:var(--g4);
  border-radius:20px;padding:3px 10px;margin-bottom:10px;
}
.hot-deal-headline{
  font-family:var(--fd);font-size:22px;font-weight:700;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:6px;line-height:1.2;
}
.hot-deal-sub{ font-size:13px;color:var(--tx2);margin-bottom:8px; }
.hot-deal-exp{ font-size:11px;color:var(--tx3);margin-bottom:6px; }
.hot-deal-notes{ font-size:12px;color:var(--tx2);margin-bottom:10px;line-height:1.6; }
.hot-deal-fine-print{ font-size:10px;color:var(--tx3);font-style:italic; }

/* Empty state */
.hot-deal-empty{ text-align:center;padding:32px 12px; }
.hot-deal-empty-icon{ font-size:42px;margin-bottom:10px; }
.hot-deal-empty-title{ font-family:var(--fd);font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--tx2);margin-bottom:8px; }
.hot-deal-empty-sub{ font-size:13px;color:var(--tx3);line-height:1.65;max-width:340px;margin:0 auto 10px; }
.hot-deal-disclaimer{ font-size:10px;color:rgba(255,255,255,.25);font-style:italic;line-height:1.55;margin-top:8px; }

/* CTA */
.hot-deal-email-btn{
  width:100%;display:flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(135deg,rgba(212,175,55,.22),rgba(212,175,55,.08));
  border:1px solid rgba(212,175,55,.45);color:var(--g4);
  border-radius:12px;padding:14px 20px;font-size:13px;font-weight:700;cursor:pointer;
  margin-bottom:12px;transition:all var(--tf);
}
.hot-deal-email-btn:hover{ background:linear-gradient(135deg,rgba(212,175,55,.32),rgba(212,175,55,.14)); }
.hot-deal-email-btn svg{ width:16px;height:16px;stroke:var(--g4);fill:none;flex-shrink:0; }

.hot-deal-email-reveal{
  background:rgba(212,175,55,.06);border:1px solid rgba(212,175,55,.2);
  border-radius:10px;padding:12px 14px;margin-bottom:12px;
}
.hot-deal-email-link{
  display:block;color:var(--g3);font-size:13px;font-weight:700;margin-bottom:4px;
}
.hot-deal-email-plain{ font-size:11px;color:var(--tx3); }

/* Footer */
.hot-deal-page-footer{
  padding:10px 16px;border-top:1px solid rgba(212,175,55,.1);flex-shrink:0;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:rgba(0,0,0,.2);
}
.hot-deal-admin-btn{
  display:flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.3);border-radius:8px;
  padding:6px 12px;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;
  transition:all var(--tf);
}
.hot-deal-admin-btn:hover{ background:rgba(255,255,255,.08);color:var(--tx2); }
.hot-deal-admin-btn svg{ width:14px;height:14px;stroke:currentColor;fill:none; }

/* Hot deal header button */
.hdr-hotdeal-btn{
  background:rgba(212,175,55,.1);
}
.hdr-hotdeal-btn .lbl{ color:var(--g5); }
.hdr-hotdeal-btn:hover{ background:rgba(212,175,55,.2); }

/* Hot deal completion button */
.comp-btn.btn-hotdeal{
  background:linear-gradient(135deg,rgba(212,175,55,.2),rgba(212,175,55,.06));
  border-color:rgba(212,175,55,.4);color:var(--g4);
}


/* Multi hot deals + stronger mobile back/edit visibility */
.chat-action-dock{display:block;width:100%;position:relative;z-index:8;}
.chat-action-dock[style*="display:none"]{display:none !important;}
.hot-deals-stack{display:grid;gap:14px;}
.hot-deal-card--multi{display:flex;flex-direction:column;gap:10px;}
.hot-deal-inline-cta{margin-top:4px;}
.hot-deal-email-btn--inline{width:100%;}
.hot-deal-email-reveal--inline{margin-top:10px;}
.dz-admin-box--deals{max-width:1120px;}
.dz-hotdeal-manager{display:grid;grid-template-columns:320px minmax(0,1fr);gap:18px;align-items:start;}
.dz-hotdeal-list-wrap{background:rgba(255,255,255,.03);border:1px solid rgba(212,175,55,.14);border-radius:20px;padding:14px;box-shadow:inset 0 1px 0 rgba(255,255,255,.04);}
.dz-hotdeal-list-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px;}
.dz-hotdeal-list-title{font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--g3);}
.dz-hotdeal-list{display:flex;flex-direction:column;gap:10px;max-height:62vh;overflow:auto;padding-right:2px;}
.dz-hotdeal-row{display:flex;gap:10px;align-items:flex-start;justify-content:space-between;padding:12px;border:1px solid rgba(255,255,255,.06);border-radius:16px;background:rgba(255,255,255,.025);}
.dz-hotdeal-row.is-active{border-color:rgba(212,175,55,.38);box-shadow:0 0 0 1px rgba(212,175,55,.12) inset, 0 10px 24px rgba(0,0,0,.16);}
.dz-hotdeal-row-main{min-width:0;flex:1;}
.dz-hotdeal-row-kicker{font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--g3);margin-bottom:5px;}
.dz-hotdeal-row-headline{font-size:14px;font-weight:800;color:var(--tx1);line-height:1.35;}
.dz-hotdeal-row-sub{font-size:12px;color:var(--tx2);line-height:1.5;margin-top:4px;}
.dz-hotdeal-row-actions{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end;}
.dz-hotdeal-form{min-width:0;}
.dz-admin-meta{font-size:12px;color:var(--tx3);margin-top:2px;margin-bottom:4px;}
.dz-empty-state{padding:16px;border:1px dashed rgba(212,175,55,.22);border-radius:16px;color:var(--tx3);font-size:12px;line-height:1.6;text-align:center;}
/* ============================================================
   BUTTON UNIFORMITY FIXES
   ============================================================ */

/* ── Option buttons: consistent min-height across all grids ─ */
.opt-btn{
  min-height:88px;
}
/* Desc text: clamp to 2 lines, consistent height */
.opt-desc{
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  min-height:28px;  /* reserve space even when empty */
  font-size:9.5px;
  color:var(--tx3);
  letter-spacing:.02em;
  text-align:center;
  line-height:1.4;
}
/* Budget/label-only grids — shorter since no icon/desc */
.opts-grid.c3 .opt-btn:not(:has(.opt-icon)):not(:has(.opt-desc)),
.opts-grid.c2 .opt-btn:not(:has(.opt-icon)):not(:has(.opt-desc)){
  min-height:52px;
}

/* ── Header action buttons: consistent visual weight ────── */
.hdr-lbl-btn{
  min-width:72px;
}
/* Hot Deal button gets a subtle flame glow treatment */
.hdr-hotdeal-btn{
  background:rgba(212,175,55,.1);
  border-color:rgba(212,175,55,.3);
}
.hdr-hotdeal-btn .lbl{color:var(--g5);}
.hdr-hotdeal-btn:hover{
  background:rgba(212,175,55,.2);
  border-color:rgba(212,175,55,.5);
}

/* ── Comp / Done screen buttons — uniform ────────────────── */
.comp-btns{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin-top:14px;
}
.comp-btn{
  display:flex;align-items:center;justify-content:center;
  gap:7px;padding:12px 10px;
  border-radius:var(--r2);
  cursor:pointer;font-family:var(--fb);
  font-size:11.5px;font-weight:700;letter-spacing:.04em;
  transition:all var(--tf) var(--spring);
  min-height:48px;
}
.comp-btn svg,.comp-btn .icon-flame{width:15px;height:15px;flex-shrink:0;}
.btn-hotdeal{
  background:rgba(212,175,55,.14);
  border:1px solid rgba(212,175,55,.35);
  color:var(--g3);
}
.btn-hotdeal:hover{background:rgba(212,175,55,.24);transform:translateY(-2px);}
.btn-share{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  color:var(--tx2);
}
.btn-share:hover{background:rgba(255,255,255,.1);transform:translateY(-2px);}
.btn-restart{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  color:var(--tx3);
}
.btn-restart:hover{background:rgba(255,255,255,.08);transform:translateY(-2px);}

/* ── Consent text in review step — professional ──────────── */
.review-consent{
  font-size:11px;
  color:rgba(255,255,255,.32);
  line-height:1.65;
  padding:12px 14px;
  border-top:1px solid rgba(255,255,255,.05);
  background:rgba(0,0,0,.12);
}
.rv-legal-link{
  background:none;border:none;cursor:pointer;
  color:rgba(212,175,55,.65);font-size:11px;font-weight:700;
  text-decoration:underline;text-underline-offset:2px;
  padding:0;
  transition:color .15s;
}
.rv-legal-link:hover{color:var(--g4);}

/* ── Notes textarea ─────────────────────────────────────── */
.notes-wrap{
  padding:0 14px 10px;flex-shrink:0;
  animation:optIn .28s var(--spring) both;
}
.notes-txt{
  width:100%;min-height:90px;max-height:200px;resize:none;
  background:var(--panel);border:1px solid var(--gb);border-radius:var(--r2);
  color:var(--tx1);font-family:var(--fb);font-size:14px;line-height:1.6;
  padding:12px 14px;outline:none;
  transition:border-color var(--tf),box-shadow var(--tf);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}
.notes-txt:focus{border-color:var(--g5);box-shadow:0 0 0 3px rgba(212,175,55,.12),inset 0 1px 0 rgba(255,255,255,.05);}
.notes-footer{display:flex;justify-content:space-between;align-items:center;margin-top:6px;}
.notes-char{font-size:10px;color:var(--tx3);font-weight:600;letter-spacing:.04em;}
.notes-send-btn{
  padding:8px 18px;background:var(--grad);border:none;
  border-radius:999px;cursor:pointer;color:#0a0800;
  font-family:var(--fd);font-size:10px;font-weight:800;letter-spacing:.1em;
  box-shadow:0 4px 18px rgba(212,175,55,.32);
  transition:all var(--tf) var(--spring);
}
.notes-send-btn:hover{box-shadow:0 6px 24px rgba(212,175,55,.48);transform:translateY(-1px);}
.notes-skip-btn{
  display:block;width:100%;margin-top:8px;
  background:none;border:1px dashed rgba(212,175,55,.22);
  cursor:pointer;font-family:var(--fb);font-size:12px;font-weight:700;
  letter-spacing:.03em;color:rgba(255,224,130,.6);
  padding:10px 14px;text-align:center;
  transition:all var(--tf);border-radius:12px;
}
.notes-skip-btn:hover{color:var(--g4);background:rgba(212,175,55,.07);border-color:rgba(212,175,55,.38);}

/* ── Completion summary ─────────────────────────────────── */
.comp-summary{
  background:rgba(212,175,55,.05);
  border:1px solid rgba(212,175,55,.14);
  border-radius:var(--r2);
  padding:14px 16px;
  margin:14px 0;
  text-align:left;
}
.comp-summary-title{
  font-family:var(--fd);font-size:8px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(212,175,55,.5);margin-bottom:10px;
}
.comp-summary-grid{display:flex;flex-direction:column;gap:4px;}
.cs-item{font-size:12px;color:rgba(255,255,255,.5);line-height:1.5;}
.cs-item strong{color:rgba(255,255,255,.7);}
.cs-deal-row{border-top:1px solid rgba(212,175,55,.1);padding-top:6px;margin-top:4px;}
.cs-deal-val{color:var(--g5);font-weight:600;}

/* ── Completion text ─────────────────────────────────────── */
.comp-title{
  font-family:var(--fd);font-size:18px;font-weight:900;letter-spacing:.1em;
  background:var(--gradb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:10px;
}
.comp-text{font-size:14px;color:var(--tx2);line-height:1.7;margin-bottom:8px;}
.comp-disclaimer{
  font-size:10px;color:rgba(255,255,255,.25);line-height:1.6;
  padding:10px 12px;background:rgba(0,0,0,.18);
  border-radius:8px;margin:10px 0 14px;
  border:1px solid rgba(255,255,255,.04);
}

/* ── Check ring animation ─────────────────────────────────── */
.check-circle{
  stroke:var(--g5);fill:none;stroke-width:2;
  stroke-dasharray:188;stroke-dashoffset:188;
  animation:drawCircle .6s var(--eout) .1s forwards;
}
.check-tick{
  stroke:var(--g3);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:48;stroke-dashoffset:48;
  animation:drawTick .4s var(--eout) .65s forwards;
}

/* Lifestyle selector strip */

/* ── Lifestyle strip — social proof row ─────────────────────── */
.lifestyle-proof{
  display:flex;align-items:center;flex-wrap:wrap;gap:6px 10px;
  margin-top:12px;
}
.lp-item{
  display:flex;align-items:center;gap:5px;
  font-size:11px;font-weight:700;letter-spacing:.03em;
  color:rgba(255,255,255,.62);
  white-space:nowrap;
}
.lp-item svg{width:12px;height:12px;flex-shrink:0;}
.lp-sep{color:rgba(212,175,55,.3);font-size:10px;}

/* ── Lifestyle button text tweak — specialist label ─────────── */
.lifestyle-btn-primary{
  font-weight:800;
}

.lifestyle-strip{display:grid;grid-template-columns:1.35fr .95fr;gap:16px;align-items:center;
  margin:10px 14px 0;padding:14px 16px;border:1px solid rgba(212,175,55,.14);border-radius:18px;
  background:linear-gradient(135deg,rgba(255,255,255,.03),rgba(212,175,55,.05));
  box-shadow:0 18px 40px rgba(0,0,0,.2), inset 0 1px 0 rgba(255,255,255,.05);}
.lifestyle-kicker{font-size:10px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--g3);margin-bottom:6px;}
.lifestyle-title{font-size:18px;font-weight:800;line-height:1.15;color:#fff;}
.lifestyle-sub{margin:8px 0 0;font-size:12px;line-height:1.5;color:rgba(255,255,255,.7);max-width:58ch;}
.lifestyle-actions{display:grid;grid-template-columns:1fr;gap:10px;}
.lifestyle-btn{appearance:none;border:1px solid rgba(212,175,55,.18);background:rgba(255,255,255,.03);color:#fff;
  padding:12px 14px;border-radius:14px;font-weight:800;letter-spacing:.02em;cursor:pointer;
  box-shadow:0 10px 26px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.05);
  transition:transform .2s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease;}
.lifestyle-btn:hover{transform:translateY(-1px);border-color:rgba(212,175,55,.34);background:rgba(255,255,255,.05);}
.lifestyle-btn-primary{background:linear-gradient(135deg,rgba(212,175,55,.2),rgba(212,175,55,.1));}
.trust-strip-extra{display:none;}

/* ══════════════════════════════════════════════════════════════
   LIFESTYLE STRIP — enhanced interactions & transitions
   ══════════════════════════════════════════════════════════════ */
.lifestyle-strip{
  transition:opacity .25s ease, transform .25s ease;
}
.lifestyle-strip.hiding{
  opacity:0;
  transform:translateY(-8px);
  pointer-events:none;
}
.lifestyle-btn{
  font-size:14px;
  position:relative;
  overflow:hidden;
}
.lifestyle-btn::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.12) 50%,transparent 70%);
  opacity:0;
  transition:opacity .2s;
  pointer-events:none;
}
.lifestyle-btn:hover::after{opacity:1;}
.lifestyle-btn:active{transform:scale(.97);}
.lifestyle-btn-primary{
  border-color:rgba(212,175,55,.38);
  box-shadow:0 12px 32px rgba(212,175,55,.18), inset 0 1px 0 rgba(255,255,255,.08);
}
.lifestyle-btn-primary:hover{
  border-color:rgba(212,175,55,.6);
  box-shadow:0 16px 38px rgba(212,175,55,.28), inset 0 1px 0 rgba(255,255,255,.12);
}

/* ── Inline option grid in lifestyle flow (same as main opts) ── */
.lifestyle-opts-wrap .opt-btn{
  border:1px solid var(--gb);
  background:var(--gl1);
}

/* ── Progress bar: hide step text when no step started ───────── */
.prog-label:empty{
  display:none;
}

/* ── Lifestyle strip — gloss sweep matching chat bubbles ─────────────────── */
.lifestyle-strip{
  position:relative;overflow:hidden;
}
.lifestyle-strip::before{
  content:'';position:absolute;top:-10%;left:-30%;width:60%;height:120%;
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.05),transparent);
  pointer-events:none;
  animation:glossLoop 6.5s ease-in-out 1.2s infinite;
}
