:root{
  --orange:#ff4800;
  --orange-2:#ff7a3c;
  --bg:#0d0d10;
  --bg-2:#16161c;
  --card:#1c1c24;
  --line:#2a2a33;
  --txt:#ffffff;
  --txt-dim:#9a9aa6;
  --green:#25d366;
  --like:#3ad29f;
  --nope:#ff4d63;
  --super:#33b5ff;
  --r:22px;
  --shadow:0 18px 50px rgba(0,0,0,.55);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  font-family:'Montserrat',system-ui,sans-serif;
  background:var(--bg);color:var(--txt);
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
}
#app{
  position:relative;
  width:100%;height:100%;
  max-width:480px;margin:0 auto;
  background:radial-gradient(120% 70% at 50% -10%, #20141a 0%, var(--bg) 55%);
  overflow:hidden;
}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
img{display:block;max-width:100%}

/* ---------- screens ---------- */
.screen{
  position:absolute;inset:0;
  display:none;flex-direction:column;
  padding:max(20px,env(safe-area-inset-top)) 20px 24px;
  animation:fade .35s ease;
}
.screen.is-active{display:flex}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---------- buttons ---------- */
.btn{
  border-radius:999px;padding:15px 26px;font-weight:700;font-size:16px;
  transition:transform .12s, box-shadow .2s, opacity .2s;letter-spacing:.2px;
}
.btn:active{transform:scale(.96)}
.btn--primary{background:linear-gradient(135deg,var(--orange),var(--orange-2));color:#fff;box-shadow:0 10px 26px rgba(255,72,0,.42)}
.btn--ghost{background:transparent;color:var(--txt-dim);border:1px solid var(--line)}
.btn:disabled{opacity:.45;pointer-events:none}
.btn--lg{padding:17px 30px;font-size:17px;width:100%}
.btn--icon{display:inline-flex;align-items:center;justify-content:center;gap:10px}
.btn--icon svg{flex-shrink:0}

/* ---------- intro ---------- */
.screen--intro{justify-content:center;text-align:center}
.intro-inner{display:flex;flex-direction:column;align-items:center;gap:18px}
.logo{font-weight:900;font-size:22px;letter-spacing:2px}
.logo span{color:var(--orange)}
.logo--sm{font-size:17px}
.intro-title{font-size:30px;font-weight:800;line-height:1.15;margin:6px 0 0}
.intro-sub{color:var(--txt-dim);font-size:15px;line-height:1.5;max-width:340px;margin:0}
.intro-sub b{color:var(--orange-2)}
.intro-cars{display:flex;justify-content:center;margin:6px 0 4px}
.intro-cars img{
  width:78px;height:104px;object-fit:cover;border-radius:16px;border:2px solid var(--bg);
  margin-left:-26px;box-shadow:var(--shadow);transform:rotate(var(--rot,0));
}
.intro-cars img:first-child{margin-left:0}
.intro-note{color:#5b5b66;font-size:12px;margin:2px 0 0}

/* ---------- steps (period / budget) ---------- */
.step-head{text-align:center;margin:24px 0 8px}
.step-dots{display:flex;gap:7px;justify-content:center;margin-bottom:22px}
.step-dots i{width:30px;height:5px;border-radius:3px;background:var(--line)}
.step-dots i.on{background:var(--orange)}
.step-title{font-size:25px;font-weight:800;margin:0 0 6px}
.step-sub{color:var(--txt-dim);font-size:14px;margin:0}

.period-grid{display:flex;flex-direction:column;gap:14px;margin-top:auto;margin-bottom:auto}
.period-card{
  display:flex;align-items:center;gap:16px;text-align:left;
  background:var(--card);border:1.5px solid var(--line);border-radius:var(--r);
  padding:20px 22px;transition:border-color .2s, transform .12s, background .2s;
}
.period-card:active{transform:scale(.98)}
.period-card:hover{border-color:var(--orange)}
.period-ico{font-size:30px}
/* generated luxury icons (fal.ai) */
.ic{display:inline-block;object-fit:contain;vertical-align:middle}
.period-ico .ic{width:38px;height:38px}
.empty-ico .ic{width:60px;height:60px}
.menu-ico .ic{width:28px;height:28px}
.sug-chip .ic{width:16px;height:16px;margin-right:5px;margin-top:-2px}
.period-name{font-size:19px;font-weight:700}
.period-desc{color:var(--txt-dim);font-size:13px;margin-top:2px}

/* ---------- budget ---------- */
.budget-box{margin:auto 0;text-align:center;padding:0 4px}
.budget-value{font-size:52px;font-weight:900;line-height:1}
.budget-value .cur{font-size:24px;color:var(--orange);vertical-align:middle}
.budget-period{color:var(--txt-dim);font-size:15px;margin:8px 0 30px}
input[type=range]{
  -webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:6px;
  background:var(--line);outline:none;
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--orange),var(--orange-2));
  box-shadow:0 6px 16px rgba(255,72,0,.5);cursor:grab;border:3px solid #fff2;
}
input[type=range]::-moz-range-thumb{width:30px;height:30px;border:none;border-radius:50%;background:var(--orange)}
.budget-scale{display:flex;justify-content:space-between;color:#5b5b66;font-size:12px;margin-top:12px}
.budget-hint{color:var(--orange-2);font-size:13px;font-weight:600;margin-top:18px;min-height:18px}
.budget-actions{display:flex;gap:12px;margin-top:8px}
.budget-actions .btn{flex:1}

/* ---------- deck ---------- */
#screen-deck{padding-top:max(14px,env(safe-area-inset-top))}
.deck-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.matches-btn{position:relative;width:46px;height:46px;border-radius:50%;background:var(--card);border:1px solid var(--line);display:grid;place-items:center;font-size:20px}
.matches-btn .heart{color:var(--orange)}
.matches-count{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 5px;border-radius:10px;background:var(--orange);color:#fff;font-size:11px;font-weight:700;display:grid;place-items:center}
.icon-btn{width:46px;height:46px;border-radius:50%;background:var(--card);border:1px solid var(--line);display:grid;place-items:center;color:var(--txt)}
.icon-btn:active{transform:scale(.92)}

.deck{position:relative;flex:1;margin-bottom:14px;margin-top:6px}

/* center swipe feedback (dating-app style) */
.swipe-fx{position:absolute;top:42%;left:50%;transform:translate(-50%,-50%) scale(.4);
  width:128px;height:128px;border-radius:50%;display:grid;place-items:center;
  font-size:64px;opacity:0;pointer-events:none;z-index:30;border:5px solid;}
.swipe-fx.go{animation:fxpop .65s ease}
.swipe-fx--like{color:var(--like);border-color:var(--like);background:rgba(58,210,159,.14)}
.swipe-fx--nope{color:var(--nope);border-color:var(--nope);background:rgba(255,77,99,.14)}
.swipe-fx--super{color:var(--super);border-color:var(--super);background:rgba(51,181,255,.16)}
@keyframes fxpop{0%{opacity:0;transform:translate(-50%,-50%) scale(.3) rotate(-12deg)}
  35%{opacity:1;transform:translate(-50%,-50%) scale(1.15) rotate(0)}
  70%{opacity:1;transform:translate(-50%,-50%) scale(1)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(1.05)}}
.deck-empty{display:none;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px;flex:1;padding:20px}
.deck-empty .empty-ico{font-size:54px}
.deck-empty h3{font-size:22px;margin:0}
.deck-empty p{color:var(--txt-dim);margin:0 0 8px;max-width:280px}
.deck-empty .btn{width:80%}
#screen-deck.is-empty .deck{display:none}
/* in empty state keep only the rewind button so the last card can still be undone */
#screen-deck.is-empty .ctrl--nope,#screen-deck.is-empty .ctrl--super,#screen-deck.is-empty .ctrl--like{display:none}
#screen-deck.is-empty .deck-empty{display:flex}

.cardx{
  position:absolute;inset:0;border-radius:var(--r);overflow:hidden;
  background:var(--card);box-shadow:var(--shadow);
  will-change:transform;user-select:none;touch-action:pan-y;
  display:flex;flex-direction:column;justify-content:flex-end;
}
.cardx img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cardx .grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.45) 38%,rgba(0,0,0,0) 62%)}
.cardx .meta{position:relative;padding:20px 22px 24px;z-index:2}
.cardx .brand{font-size:13px;font-weight:600;color:var(--orange-2);text-transform:uppercase;letter-spacing:1px}
.cardx .title{font-size:28px;font-weight:800;line-height:1.05;margin:3px 0 10px}
.cardx .loves{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;line-height:1.3}
.cardx .loves .lv-ico{color:var(--nope);font-size:17px;flex-shrink:0}
.cardx .tags{display:flex;gap:8px;margin-top:13px;flex-wrap:wrap}
.cardx .tag{font-size:11.5px;font-weight:600;padding:5px 11px;border-radius:999px;background:#ffffff1a;backdrop-filter:blur(4px)}
.cardx .tag--hash{color:#ffd9c2;background:#ff48002e;font-weight:700}
.cardx .tag--budget{background:#3ad29f2e;color:#7df0c4}
.cardx .tag--over{background:#ff4d6322;color:#ff97a4}

/* swipe stamps */
.stamp{position:absolute;top:34px;z-index:3;font-size:32px;font-weight:900;letter-spacing:2px;
  padding:6px 16px;border:4px solid;border-radius:12px;opacity:0;transform:rotate(-18deg);text-transform:uppercase}
.stamp--like{left:22px;color:var(--like);border-color:var(--like)}
.stamp--nope{right:22px;color:var(--nope);border-color:var(--nope);transform:rotate(18deg)}
.stamp--super{left:50%;transform:translateX(-50%) rotate(0);top:auto;bottom:120px;color:var(--super);border-color:var(--super)}

/* controls */
.deck-controls{display:flex;align-items:center;justify-content:center;gap:16px}
.ctrl{width:62px;height:62px;border-radius:50%;background:var(--card);border:1px solid var(--line);
  display:grid;place-items:center;font-size:26px;font-weight:700;transition:transform .12s, box-shadow .2s}
.ctrl:active{transform:scale(.88)}
.ctrl:disabled{opacity:.3;pointer-events:none}
.ctrl--undo{width:52px;height:52px;color:#f5b53f}
.ctrl--nope{color:var(--nope)}
.ctrl--like{color:var(--like)}
.ctrl--super{width:52px;height:52px;font-size:22px;color:var(--super)}
.ctrl--undo:hover{box-shadow:0 0 0 2px #f5b53f inset}
.ctrl--nope:hover{box-shadow:0 0 0 2px var(--nope) inset}
.ctrl--like:hover{box-shadow:0 0 0 2px var(--like) inset}
.ctrl--super:hover{box-shadow:0 0 0 2px var(--super) inset}

/* rewind animation — card flies back from where it left */
.cardx.ret-like{animation:retR .42s ease}
.cardx.ret-nope{animation:retL .42s ease}
.cardx.ret-super{animation:retU .42s ease}
@keyframes retR{from{transform:translateX(115%) rotate(16deg);opacity:.25}to{transform:none;opacity:1}}
@keyframes retL{from{transform:translateX(-115%) rotate(-16deg);opacity:.25}to{transform:none;opacity:1}}
@keyframes retU{from{transform:translateY(-115%);opacity:.25}to{transform:none;opacity:1}}

/* ---------- match overlay ---------- */
.match-overlay{position:absolute;inset:0;z-index:50;display:none;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:30px;background:rgba(8,4,6,.86);backdrop-filter:blur(8px)}
.match-overlay.is-active{display:flex;animation:fade .3s}
.match-inner{display:flex;flex-direction:column;align-items:center;width:100%;max-width:340px}
.match-burst{font-size:38px;font-weight:900;letter-spacing:1px;text-align:center;
  background:linear-gradient(135deg,var(--orange),#ffb14d);-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:pop .5s ease}
@keyframes pop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.12)}100%{transform:scale(1);opacity:1}}
.match-photo{width:180px;height:180px;border-radius:50%;overflow:hidden;border:4px solid var(--orange);margin:22px auto 14px;box-shadow:0 12px 40px rgba(255,72,0,.4);flex-shrink:0}
.match-photo img{width:100%;height:100%;object-fit:cover;object-position:center}
.match-name{font-size:24px;font-weight:800}
.match-text{color:var(--txt-dim);margin:8px 0 26px;max-width:300px}
.match-overlay .btn{width:100%;max-width:320px}
.match-overlay .btn--lg{margin-bottom:12px}

/* ---------- sheets (matches / chat) ---------- */
.screen--sheet{padding:0;background:var(--bg)}
.sheet-head,.chat-head{display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:max(14px,env(safe-area-inset-top)) 16px 14px;border-bottom:1px solid var(--line);background:var(--bg-2)}
.sheet-head h2{font-size:18px;margin:0}
.sheet-back{font-size:24px;width:40px;height:40px;border-radius:50%;display:grid;place-items:center}
.sheet-head span,.chat-head span{width:40px}

.matches-list{flex:1;overflow-y:auto;padding:8px 12px}
.match-row{display:flex;align-items:center;gap:14px;padding:12px;border-radius:16px;transition:background .2s}
.match-row:active{background:var(--card)}
.match-row img{width:62px;height:62px;border-radius:14px;object-fit:cover;flex-shrink:0}
.match-row .mr-name{font-size:16px;font-weight:700}
.match-row .mr-last{color:var(--txt-dim);font-size:13px;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:210px}
.match-row .mr-go{margin-left:auto;color:var(--orange);font-size:20px}
.match-row .mr-badge{margin-left:auto;background:var(--green);color:#04210f;font-size:11px;font-weight:700;padding:4px 9px;border-radius:999px}
.matches-empty{display:none;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:14px;flex:1;color:var(--txt-dim)}
#screen-matches.is-empty .matches-list{display:none}
#screen-matches.is-empty .matches-empty{display:flex}
.matches-empty .empty-ico{font-size:48px}

/* ---------- menu ---------- */
.menu-list{flex:1;overflow-y:auto;padding:16px 14px;display:flex;flex-direction:column;gap:12px}
.menu-item{display:flex;align-items:center;gap:15px;text-align:left;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:18px 18px;transition:border-color .2s,transform .12s;text-decoration:none;color:var(--txt)}
.menu-item:active{transform:scale(.98)}
.menu-item:hover{border-color:var(--orange)}
.menu-ico{font-size:26px;width:34px;text-align:center;flex-shrink:0}
.menu-tx{display:flex;flex-direction:column;gap:3px}
.menu-tx b{font-size:16.5px;font-weight:700}
.menu-tx i{font-size:13px;color:var(--txt-dim);font-style:normal}
.menu-go{margin-left:auto;color:var(--orange);font-size:18px}
.menu-foot{text-align:center;color:#5b5b66;font-size:12px;padding:14px}

/* ---------- sheet body (about screens) ---------- */
.sheet-body{flex:1;overflow-y:auto;padding:22px 18px max(24px,env(safe-area-inset-bottom))}
.about-logo{font-size:20px;text-align:center;margin-bottom:6px}
.about-lead{text-align:center;color:var(--txt-dim);font-size:15px;margin:0 0 24px}
.about-step{display:flex;gap:14px;margin-bottom:18px}
.about-step>span{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--orange),var(--orange-2));color:#fff;font-weight:800;display:grid;place-items:center;flex-shrink:0;font-size:15px}
.about-step b{font-size:16px}
.about-step p{margin:3px 0 0;color:var(--txt-dim);font-size:13.5px;line-height:1.45}
.about-note{color:var(--txt-dim);font-size:13px;line-height:1.5;margin:8px 0 22px;text-align:center}
.about-note a,.facts-line a,.reviews-orig a{color:var(--orange-2)}

/* rating + facts */
.rating-card{display:flex;align-items:center;gap:18px;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:18px 20px;margin-bottom:16px}
.rating-big{font-size:46px;font-weight:900;line-height:1;display:flex;align-items:flex-start;gap:2px}
.rating-big span{color:#ffc24b;font-size:24px;margin-top:4px}
.rating-src{font-weight:700;font-size:15px}
.rating-sub{color:var(--txt-dim);font-size:13px;margin-top:2px}
.rating-link{display:inline-block;margin-top:7px;color:var(--orange-2);font-size:13px;font-weight:600;text-decoration:none}
.facts-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:16px}
.fact{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:14px 10px;text-align:center}
.fact b{display:block;font-size:19px;font-weight:800;color:var(--orange-2)}
.fact i{font-style:normal;color:var(--txt-dim);font-size:11.5px;line-height:1.3;display:block;margin-top:4px}
.facts-line{color:var(--txt-dim);font-size:13px;line-height:1.55;margin:0 0 22px}

.reviews-title{font-size:17px;margin:0 0 14px}
.review-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:15px 16px;margin-bottom:12px}
.rev-head{display:flex;align-items:center;gap:11px;margin-bottom:9px}
.rev-av{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#3a3a44,#22222a);display:grid;place-items:center;font-weight:700;font-size:16px;flex-shrink:0}
.rev-head b{font-size:14.5px;display:block}
.rev-stars{color:#ffc24b;font-size:12px;letter-spacing:1px}
.rev-g{margin-left:auto;width:24px;height:24px;border-radius:50%;background:#fff;color:#4285F4;font-weight:800;display:grid;place-items:center;font-size:14px;flex-shrink:0}
.review-card p{margin:0;font-size:13.5px;line-height:1.5;color:#d6d6de}
.reviews-orig{color:#5b5b66;font-size:12px;text-align:center;margin:14px 0 20px}

/* ---------- chat ---------- */
.chat-peer{display:flex;align-items:center;gap:10px;flex:1}
.chat-peer img{width:42px;height:42px;border-radius:50%;object-fit:cover}
.chat-peer-name{font-size:16px;font-weight:700}
.chat-peer-status{font-size:12px;color:var(--like)}
.chat-peer-status.typing{color:var(--orange-2)}
.chat-body{flex:1;overflow-y:auto;padding:18px 14px;display:flex;flex-direction:column;gap:9px;
  background:linear-gradient(180deg,#0d0d10,#121218)}
.bubble{max-width:78%;padding:11px 15px;border-radius:18px;font-size:14.5px;line-height:1.4;animation:bubble .25s ease}
@keyframes bubble{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.bubble--in{align-self:flex-start;background:var(--card);border-bottom-left-radius:5px}
.bubble--out{align-self:flex-end;background:linear-gradient(135deg,var(--orange),var(--orange-2));color:#fff;border-bottom-right-radius:5px}
.bubble--sys{align-self:center;background:transparent;color:#5b5b66;font-size:12px;max-width:90%;text-align:center}
.b-time{display:block;font-size:10px;font-weight:500;opacity:.5;text-align:right;margin-top:3px;letter-spacing:.3px}
.bubble--out .b-time{opacity:.7}
.bubble--photo{padding:4px;position:relative;max-width:74%}
.bubble--photo img{width:240px;max-width:62vw;height:auto;border-radius:14px;display:block}
.b-time--img{position:absolute;right:11px;bottom:9px;margin:0;color:#fff;opacity:1;background:rgba(0,0,0,.45);padding:2px 7px;border-radius:9px;backdrop-filter:blur(2px);font-size:10px;font-weight:500}
.bubble--video{padding:4px;max-width:82%}
.bubble--video iframe{width:280px;max-width:68vw;aspect-ratio:16/9;border:0;border-radius:14px;display:block}
.bubble--photo.has-cap{padding-bottom:2px}
.bubble--photo .b-cap{display:block;padding:8px 9px 5px;font-size:13.5px;line-height:1.35}
.bubble--photo .b-cap .b-time{display:inline;opacity:.55;margin-left:4px}
.bubble--out.bubble--photo .b-cap .b-time{opacity:.75}
.typing-bub{align-self:flex-start;background:var(--card);border-radius:18px;border-bottom-left-radius:5px;padding:14px 16px;display:flex;gap:4px}
.typing-bub i{width:7px;height:7px;border-radius:50%;background:var(--txt-dim);animation:blink 1.2s infinite}
.typing-bub i:nth-child(2){animation-delay:.2s}
.typing-bub i:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}

.chat-input-wrap{display:flex;gap:10px;padding:12px 14px max(12px,env(safe-area-inset-bottom));border-top:1px solid var(--line);background:var(--bg-2)}
#chat-input{flex:1;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:13px 18px;color:var(--txt);font-size:15px;font-family:inherit;outline:none}
#chat-input:focus{border-color:var(--orange)}
#chat-input.invalid{border-color:var(--nope)}
#chat-input:disabled{opacity:.5;cursor:default}   /* stays visible while the car is typing, just inactive */
.chat-send{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--orange),var(--orange-2));color:#fff;font-size:18px;display:grid;place-items:center;flex-shrink:0}
.chat-send:disabled{opacity:.4}
.chat-locked{display:none;padding:12px 14px max(12px,env(safe-area-inset-bottom));border-top:1px solid var(--line);background:var(--bg-2)}
#screen-chat.is-done .chat-input-wrap{display:none}   /* in "done" the suggest-chips footer replaces the input */
#screen-chat.is-done .chat-locked{display:block}
.wa-btn{display:none;align-items:center;justify-content:center;gap:10px;width:100%;background:var(--green);color:#04210f;font-weight:800;font-size:16px;border-radius:999px;padding:15px;text-decoration:none;transition:transform .12s}
.wa-btn svg{flex-shrink:0}
.wa-btn:active{transform:scale(.97)}
#screen-chat.is-done .wa-btn{display:flex}
.suggest{display:none;margin-bottom:12px}
#screen-chat.is-done .suggest{display:block}
.suggest.busy{opacity:.45;pointer-events:none}
.suggest-title{font-size:12px;color:var(--txt-dim);text-align:center;margin-bottom:9px}
.suggest-chips{display:flex;flex-wrap:nowrap;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:0 2px 2px}
.suggest-chips::-webkit-scrollbar{display:none}
.sug-chip{flex:0 0 auto;white-space:nowrap;background:var(--card);border:1px solid var(--line);color:var(--txt);border-radius:999px;padding:9px 14px;font-size:13.5px;font-weight:600;font-family:inherit;transition:border-color .2s,transform .1s}
.sug-chip:active{transform:scale(.95)}
.sug-chip:hover{border-color:var(--orange)}
.improve-row{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:16px 18px;text-decoration:none;color:var(--txt);margin:18px 0 16px;transition:border-color .2s,transform .12s}
.improve-row:active{transform:scale(.98)}
.improve-row:hover{border-color:var(--orange)}

/* quick-reply buttons (resident question) */
.chat-quick{display:none;gap:10px;padding:12px 14px max(12px,env(safe-area-inset-bottom));border-top:1px solid var(--line);background:var(--bg-2)}
#screen-chat.is-quick .chat-input-wrap{display:none}
#screen-chat.is-quick .chat-quick{display:flex}
.quick-btn{flex:1;border-radius:999px;padding:14px 12px;font-weight:700;font-size:14.5px;font-family:inherit;
  background:var(--card);border:1.5px solid var(--orange);color:var(--txt);transition:transform .12s,background .2s}
.quick-btn:active{transform:scale(.96)}
.quick-btn:hover{background:#ff48001a}

/* ---------- info buttons + car profile ---------- */
.card-info{position:absolute;top:14px;right:14px;z-index:6;width:38px;height:38px;border-radius:50%;background:rgba(0,0,0,.42);backdrop-filter:blur(4px);color:#fff;display:grid;place-items:center;border:1px solid #ffffff33}
.card-info:active{transform:scale(.9)}
.icon-btn--sm{width:40px;height:40px}

/* swipeable media carousel (video + photos) — Tinder-style */
.prof-media-wrap{position:relative;border-radius:16px;overflow:hidden;margin-bottom:16px;background:#000}
.prof-media{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;aspect-ratio:4/3;scrollbar-width:none}
.prof-media::-webkit-scrollbar{display:none}
.pm-slide{flex:0 0 100%;scroll-snap-align:center;position:relative;background:#000;overflow:hidden}
.pm-slide img{width:100%;height:100%;object-fit:cover;display:block}
/* zoom the YouTube player so its title/controls are pushed off-screen (player fully hidden) */
.pm-video iframe{position:absolute;top:50%;left:50%;width:178%;height:178%;transform:translate(-50%,-50%);border:0;pointer-events:none}
.pm-bars{position:absolute;top:8px;left:8px;right:8px;z-index:3;display:flex;gap:4px}
.pm-bars i{flex:1;height:3px;border-radius:2px;background:#ffffff55}
.pm-bars i.on{background:#fff}
.prof-vtoggle{position:absolute;left:12px;bottom:12px;width:44px;height:44px;border-radius:50%;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);color:#fff;display:grid;place-items:center;border:1px solid #ffffff44;z-index:4}
.prof-vtoggle:active{transform:scale(.9)}
.prof-vtoggle .i-play{display:none}
.prof-vtoggle.paused .i-pause{display:none}
.prof-vtoggle.paused .i-play{display:block}
.prof-head .brand{font-size:13px;font-weight:600;color:var(--orange-2);text-transform:uppercase;letter-spacing:1px}
.prof-name{font-size:24px;font-weight:800;line-height:1.12;margin:3px 0 10px}
.prof-head .loves{font-size:15px;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.prof-head .loves .lv-ico{color:var(--nope)}
.prof-head .tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.prof-specs{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:22px}
.ps{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px 14px}
.ps b{font-size:16px;font-weight:800;display:block}
.ps i{font-style:normal;color:var(--txt-dim);font-size:12px}

@media(max-width:360px){
  .intro-title{font-size:26px}
  .cardx .title{font-size:24px}
  .ctrl{width:56px;height:56px}
}
