/* HOT Like — Modern Redesign 2026 */
/* Base: variables, reset, layout, forms, buttons */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');
:root{
--bg:#0b0b12;--bg2:#13131e;--bg3:rgba(255,255,255,0.05);
--glass:rgba(255,255,255,0.07);--border:rgba(255,255,255,0.08);
--text:#f0f0f5;--text2:rgba(255,255,255,0.6);--text3:rgba(255,255,255,0.35);
--coral:#E8637A;--coral2:#d4506a;--peach:#F5A477;
--violet:#8B5CF6;--sky:#38BDF8;--gold:#FBBF24;--red:#EF4444;
--grad1:linear-gradient(135deg,#E8637A,#F5A477);
--grad2:linear-gradient(135deg,#8B5CF6,#6D28D9);
--grad3:linear-gradient(135deg,#FBBF24,#F59E0B);
--r:16px;--r2:22px;--r3:30px;
--nav:68px;--head:54px;--safe:env(safe-area-inset-bottom,0px);
--shadow:0 4px 20px rgba(0,0,0,0.3);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%;overflow:hidden}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;user-select:none;-webkit-user-select:none}
#app{height:100vh;display:flex;flex-direction:column;position:relative;overflow:hidden}
.screen{display:none;flex-direction:column;flex:1;overflow-y:auto;overflow-x:hidden;padding-bottom:calc(var(--nav) + var(--safe) + 10px)}
.screen.active{display:flex}
.hidden{display:none!important}

/* Loading */
#screen-loading{justify-content:center;align-items:center;background:var(--bg);padding-bottom:0}
.loading-content{text-align:center}
.logo-pulse{font-size:64px;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}
.logo-text{font-size:32px;font-weight:700;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-top:10px}
.loader{width:100px;height:3px;background:var(--bg3);border-radius:8px;margin:20px auto 0;overflow:hidden}
.loader-bar{width:35%;height:100%;background:var(--grad1);border-radius:8px;animation:load 1.2s ease-in-out infinite}
@keyframes load{0%{transform:translateX(-100%)}100%{transform:translateX(380%)}}

/* Onboarding */
.onboarding-container{padding:20px;max-width:420px;margin:0 auto;width:100%}
.onboarding-header{text-align:center;margin-bottom:20px}
.logo-small{font-size:44px;margin-bottom:6px}
.onboarding-header h1{font-size:22px;font-weight:700}
.subtitle{color:var(--text2);margin-top:4px;font-size:14px}

/* Forms */
.form-glass{background:var(--glass);border:1px solid var(--border);border-radius:var(--r2);padding:18px;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}
.form-row{display:flex;gap:10px}
.form-row .form-group{flex:1}
input[type="text"],input[type="number"],select,textarea{width:100%;padding:11px 13px;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:12px;color:var(--text);font-family:inherit;font-size:15px;transition:border-color .2s;outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--coral)}
textarea{resize:none}
select option{background:#1a1a2e}
input[type="date"]{width:100%;padding:11px 13px;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:12px;color:var(--text);font-family:inherit;font-size:15px;-webkit-appearance:none;outline:none;transition:border-color .2s}
input[type="date"]:focus{border-color:var(--coral)}
input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer}

/* Chips & Tags */
.goal-chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{padding:8px 16px;border-radius:20px;border:1px solid var(--border);background:var(--bg3);color:var(--text2);font-size:13px;cursor:pointer;transition:all .2s;font-family:inherit}
.chip.active{background:var(--grad1);color:#fff;border-color:transparent}
.tags-input-wrap{background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:12px;padding:8px;display:flex;flex-wrap:wrap;gap:6px;min-height:42px;align-items:center}
.tags-list{display:flex;flex-wrap:wrap;gap:6px}
.tag-item{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--grad2);border-radius:10px;font-size:12px}
.tag-item .tag-remove{cursor:pointer;opacity:.7;font-size:14px}
.tags-input-wrap input{flex:1;min-width:80px;border:none;background:transparent;color:#fff;outline:none;font-size:14px;padding:4px}

/* Buttons */
.btn-primary{width:100%;padding:13px;border:none;border-radius:14px;background:var(--grad1);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .15s;font-family:inherit}
.btn-primary:active{transform:scale(.98);opacity:.9}
.btn-glow{box-shadow:0 4px 16px rgba(232,99,122,.3)}
.btn-secondary{width:100%;padding:11px;border:1px solid var(--border);border-radius:14px;background:transparent;color:var(--text2);font-size:14px;font-weight:500;cursor:pointer;transition:background .2s;font-family:inherit;margin-top:8px}
.btn-secondary:active{background:var(--bg3)}
.btn-icon{width:38px;height:38px;border-radius:50%;border:1px solid var(--border);background:var(--bg3);font-size:17px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.required{color:var(--coral)}

/* Photo Upload */
.photo-upload-area{margin-bottom:4px}
.photo-preview{width:130px;height:130px;margin:0 auto;border-radius:50%;border:2px dashed var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:border-color .2s;overflow:hidden;background:rgba(255,255,255,0.03)}
.photo-preview:active{border-color:var(--coral)}
.photo-preview .photo-placeholder{font-size:36px;margin-bottom:4px}
.photo-preview p{font-size:11px;color:var(--text3);text-align:center;padding:0 8px}
.photo-preview.has-photo{border-style:solid;border-color:var(--coral)}
.photo-preview.has-photo img{width:100%;height:100%;object-fit:cover}

/* City Autocomplete */
.city-autocomplete{position:relative}
.city-suggestions{display:none;position:absolute;top:100%;left:0;right:0;z-index:20;background:rgba(18,18,31,.97);border:1px solid var(--border);border-radius:0 0 12px 12px;backdrop-filter:blur(16px);max-height:180px;overflow-y:auto;box-shadow:0 8px 20px rgba(0,0,0,.4);margin-top:-1px}
.city-suggestions.visible{display:block}
.city-option{padding:10px 14px;cursor:pointer;font-size:14px;color:var(--text2);transition:background .15s;border-bottom:1px solid rgba(255,255,255,.03)}
.city-option:last-child{border-bottom:none}
.city-option:hover,.city-option.active{background:rgba(232,99,122,.12);color:var(--text)}
.city-option strong{color:var(--coral);font-weight:600}
/* HOT Like — Components (cards, swipe, nav, popups, profile, shop) */

/* Swipe Header */
.swipe-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;height:var(--head)}
.logo-mini{font-size:26px}
.header-title{font-size:18px;font-weight:700;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent}

/* Cards */
.cards-container{flex:1;position:relative;display:flex;align-items:center;justify-content:center;padding:0 16px;overflow:hidden}
.swipe-card{position:absolute;width:calc(100% - 32px);max-width:370px;aspect-ratio:3/4;border-radius:var(--r3);overflow:hidden;cursor:grab;touch-action:none;box-shadow:var(--shadow);will-change:transform}
.swipe-card:active{cursor:grabbing}
.swipe-card .card-photo{width:100%;height:100%;object-fit:cover;background:var(--bg2)}
.swipe-card .card-gradient{position:absolute;bottom:0;left:0;right:0;height:55%;background:linear-gradient(transparent,rgba(0,0,0,.8));pointer-events:none}
.swipe-card .card-info{position:absolute;bottom:0;left:0;right:0;padding:18px;z-index:2}
.card-info .card-name{font-size:24px;font-weight:700;display:flex;align-items:center;gap:8px}
.card-info .card-name .vip-badge{font-size:11px;background:var(--grad3);padding:2px 8px;border-radius:8px;font-weight:600;color:#000}
.card-info .card-name .verified-badge{font-size:16px}
.card-info .card-location{color:rgba(255,255,255,.75);font-size:13px;margin-top:3px}
.card-info .card-bio{color:rgba(255,255,255,.65);font-size:13px;margin-top:6px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-info .card-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.card-info .card-tags span{padding:3px 9px;background:rgba(255,255,255,.12);border-radius:8px;font-size:11px}
.card-info .card-goal{display:inline-block;margin-top:6px;padding:3px 10px;background:rgba(232,99,122,.25);border-radius:10px;font-size:12px}
.card-report-btn{position:absolute;top:10px;right:10px;z-index:5;width:30px;height:30px;border-radius:50%;border:none;background:rgba(0,0,0,.35);backdrop-filter:blur(8px);color:rgba(255,255,255,.6);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.swipe-stamp{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);font-size:72px;z-index:10;pointer-events:none;transition:transform .15s ease;filter:drop-shadow(0 0 16px rgba(0,0,0,.4))}
.swipe-card.swiping-right .stamp-like{transform:translate(-50%,-50%) rotate(-12deg) scale(1)}
.swipe-card.swiping-left .stamp-dislike{transform:translate(-50%,-50%) rotate(12deg) scale(1)}
.no-photo{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--grad2);font-size:72px}

/* Swipe Actions */
.swipe-actions{display:flex;justify-content:center;align-items:center;gap:10px;padding:10px 16px 6px}
.action-btn{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s,opacity .15s;background:var(--bg3);border:1.5px solid var(--border);color:rgba(255,255,255,.65);position:relative}
.action-btn:active{transform:scale(.9);opacity:.8}
.action-like{width:60px;height:60px;background:var(--grad1);border:none;color:#fff;box-shadow:0 4px 16px rgba(232,99,122,.35)}
.action-dislike{width:60px;height:60px;background:var(--bg3);border:1.5px solid rgba(239,68,68,.3);color:#EF4444}
.action-superlike{background:var(--grad2);border:none;color:#fff;box-shadow:0 3px 12px rgba(139,92,246,.3)}
.action-anon{background:linear-gradient(135deg,#0EA5E9,#0284C7);border:none;color:#fff}
.action-undo{color:var(--gold);border-color:rgba(251,191,36,.2)}
.action-gift{color:#F472B6;border-color:rgba(244,114,182,.2)}
.swipe-counter{text-align:center;font-size:11px;color:var(--text3);padding-bottom:4px}

/* Card Animations */
.card-exit-right{animation:exitR .4s ease forwards}
.card-exit-left{animation:exitL .4s ease forwards}
.card-exit-up{animation:exitU .4s ease forwards}
@keyframes exitR{to{transform:translateX(150%) rotate(25deg);opacity:0}}
@keyframes exitL{to{transform:translateX(-150%) rotate(-25deg);opacity:0}}
@keyframes exitU{to{transform:translateY(-150%) scale(.5);opacity:0}}

/* Empty State */
.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center}
.empty-state.hidden{display:none}
.empty-icon{font-size:56px;margin-bottom:14px}
.empty-state h3{font-size:18px;margin-bottom:6px}
.empty-state p{color:var(--text2);font-size:14px;margin-bottom:18px}

/* Popup */
.popup{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}
.popup.hidden{display:none}
.popup-overlay{position:absolute;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(4px)}
.popup-content{position:relative;z-index:1;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);padding:24px;width:100%;max-width:350px;animation:popIn .25s ease}
@keyframes popIn{from{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}
.popup-content h2,.popup-content h3{text-align:center;margin-bottom:10px}

/* Match Popup */
.match-content{text-align:center}
.match-hearts{font-size:56px}
.match-content h2{font-size:24px;font-weight:700;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.match-photos{display:flex;justify-content:center;gap:12px;margin:14px 0}
.match-photos img{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid var(--coral)}

/* Filters */
.filters-content{max-height:80vh;overflow-y:auto}
.range-group{display:flex;gap:8px}
.range-group input[type="range"]{flex:1;-webkit-appearance:none;height:4px;background:var(--bg3);border-radius:4px;outline:none}
.range-group input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--grad1);cursor:pointer;border:2px solid #fff}

/* Gifts Popup */
.gifts-grid{display:flex;gap:10px;justify-content:center;margin-top:14px}
.gift-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 18px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);cursor:pointer;transition:border-color .2s;font-family:inherit;color:var(--text)}
.gift-item:active{border-color:var(--coral)}
.gift-item span{font-size:32px}
.gift-item small{font-size:12px;color:var(--text2)}
.gift-item em{font-size:11px;color:var(--gold);font-style:normal}

/* Report */
.btn-report{width:100%;margin-top:8px;padding:10px;background:none;border:1px solid rgba(255,165,0,.25);border-radius:12px;color:#FFA500;font-size:13px;cursor:pointer;font-family:inherit;transition:background .2s}
.report-reasons{display:flex;flex-direction:column;gap:5px}
.report-reason-btn{width:100%;text-align:left;padding:10px 13px;background:var(--bg3);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:13px;cursor:pointer;font-family:inherit;transition:border-color .2s}
.report-reason-btn.selected{background:rgba(255,165,0,.12);border-color:rgba(255,165,0,.4);color:#FFA500}

/* Screen Header */
.screen-header{padding:13px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.screen-header h2{font-size:20px;font-weight:700}
.header-action-btn{padding:6px 13px;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);border-radius:14px;color:#EF4444;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit}

/* Matches */
.matches-list{padding:12px;display:flex;flex-direction:column;gap:8px}
.match-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);cursor:pointer;transition:background .2s}
.match-item:active{background:rgba(255,255,255,.08)}
.match-item img{width:50px;height:50px;border-radius:50%;object-fit:cover;border:2px solid var(--coral)}
.match-avatar-placeholder{width:50px;height:50px;border-radius:50%;border:2px solid var(--coral);background:var(--grad2);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.match-item .match-info{flex:1}
.match-item .match-name{font-weight:600;font-size:14px}
.match-item .match-meta{font-size:12px;color:var(--text2);margin-top:2px}
.match-item .match-action{padding:7px 12px;background:var(--grad1);border:none;border-radius:18px;color:#fff;font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap}
.match-actions-row{display:flex;gap:6px;flex-shrink:0}
.match-action-anon{background:linear-gradient(135deg,#0EA5E9,#0284C7)!important;padding:7px 10px!important}
.item-delete-btn{width:26px;height:26px;border-radius:50%;border:none;background:rgba(239,68,68,.1);color:#EF4444;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.4;transition:opacity .2s}
.item-delete-btn:active{opacity:1}

/* Messages */
.messages-list{padding:12px;display:flex;flex-direction:column;gap:8px}
.msg-item{display:flex;align-items:flex-start;gap:12px;padding:13px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);transition:background .2s}
.msg-item.unread{border-left:3px solid var(--coral)}
.msg-avatar{width:42px;height:42px;border-radius:50%;background:var(--grad2);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.msg-body{flex:1}
.msg-body .msg-from{font-weight:600;font-size:14px}
.msg-body .msg-text{font-size:13px;color:var(--text2);margin-top:3px;line-height:1.4}
.msg-body .msg-time{font-size:11px;color:var(--text3);margin-top:3px}

/* Profile */
.profile-view{padding:16px}
.profile-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden}
.profile-photo-wrap{width:100%;aspect-ratio:1;position:relative;cursor:pointer;overflow:hidden}
.profile-photo-wrap img{width:100%;height:100%;object-fit:cover;position:absolute;top:0;left:0}
.profile-photo-wrap .photo-nav{position:absolute;top:8px;left:8px;right:8px;display:flex;gap:3px;z-index:3}
.profile-photo-wrap .photo-dot{flex:1;height:3px;background:rgba(255,255,255,.25);border-radius:3px;transition:background .2s}
.profile-photo-wrap .photo-dot.active{background:#fff}
.profile-details{padding:18px}
.profile-details h2{font-size:22px;font-weight:700;display:flex;align-items:center;gap:8px}
.profile-details .profile-location{color:var(--text2);margin-top:4px;font-size:14px}
.profile-details .profile-bio{margin-top:10px;line-height:1.5;color:var(--text2);font-size:14px}
.profile-details .profile-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.profile-details .profile-tags span{padding:5px 12px;background:var(--grad2);border-radius:12px;font-size:12px}
.profile-edit-btn{margin-top:14px}
.profile-photos-manage{display:flex;gap:8px;margin-top:10px}
.photo-thumb{position:relative;width:60px;height:60px;border-radius:10px;overflow:hidden}
.photo-thumb img{width:100%;height:100%;object-fit:cover}
.photo-del-btn{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;border:none;background:rgba(0,0,0,.7);color:#EF4444;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center}

/* Gifts Showcase */
.gifts-showcase{margin-top:14px;padding:14px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--r)}
.gifts-showcase-header{font-size:14px;font-weight:700;margin-bottom:10px}
.gifts-showcase-items{display:flex;flex-wrap:wrap;gap:8px}
.gift-showcase-item{display:flex;flex-direction:column;align-items:center;padding:10px 12px;min-width:68px;background:var(--bg3);border:1px solid var(--border);border-radius:14px}
.gift-showcase-emoji{font-size:28px}
.gift-showcase-count{margin-top:3px;font-size:16px;font-weight:700;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.gift-showcase-name{font-size:10px;color:var(--text3);margin-top:1px}
.gifts-total{width:100%;margin-top:6px;padding-top:6px;border-top:1px solid var(--border);font-size:11px;color:var(--text3)}
.gifts-empty,.gifts-loading{width:100%;text-align:center;padding:10px;color:var(--text3);font-size:13px}

/* User Profile Popup */
.user-profile-card{padding:0;overflow:hidden;max-height:85vh;overflow-y:auto}
.up-photos{width:100%}
.up-photos img{width:100%;aspect-ratio:1;object-fit:cover;display:block}
.up-photos img+img{margin-top:2px}
.up-details{padding:18px}
.up-details h2{font-size:20px;font-weight:700;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.up-location{color:var(--text2);font-size:13px;margin-top:3px}
.up-bio{color:var(--text2);font-size:14px;margin-top:10px;line-height:1.5}
.up-goal{display:inline-block;margin-top:8px;padding:5px 12px;background:rgba(232,99,122,.15);border-radius:12px;font-size:13px}
.up-details .profile-tags{margin-top:10px}
.up-anon-section{margin-top:14px;padding:12px;background:rgba(255,255,255,.04);border-radius:14px;border:1px solid var(--border)}
.up-anon-label{font-size:14px;font-weight:600;margin-bottom:6px}
.up-anon-section textarea{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:10px;color:var(--text);padding:10px;font-size:14px;font-family:inherit;resize:none;outline:none}
.up-anon-section textarea:focus{border-color:var(--coral)}
.btn-anon-send{width:100%;margin-top:8px;padding:10px;background:linear-gradient(135deg,#334155,#1E293B);border:none;border-radius:10px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit}

/* Shop */
.shop-grid{padding:14px;display:flex;flex-direction:column;gap:8px}
.shop-item{display:flex;align-items:center;gap:12px;padding:14px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);cursor:pointer;transition:border-color .2s}
.shop-item:active{border-color:var(--coral)}
.shop-icon{font-size:28px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg3);border-radius:12px}
.shop-info{flex:1}
.shop-info .shop-title{font-weight:600;font-size:14px}
.shop-info .shop-desc{font-size:12px;color:var(--text2);margin-top:2px}
.shop-price{padding:6px 12px;background:var(--grad3);border-radius:12px;font-size:13px;font-weight:700;color:#000;white-space:nowrap}
.shop-badge{margin-top:3px;font-size:11px;font-weight:600;color:var(--gold)}

/* Bottom Nav */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav) + var(--safe));padding-bottom:var(--safe);background:rgba(11,11,18,.94);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;z-index:50}
.bottom-nav.hidden{display:none}
.nav-btn{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;color:var(--text3);cursor:pointer;padding:8px 12px;transition:color .2s;font-family:inherit;position:relative}
.nav-btn span{font-size:20px}
.nav-btn small{font-size:10px;font-weight:500}
.nav-btn.active{color:var(--coral)}
.badge{position:absolute;top:2px;right:4px;min-width:15px;height:15px;background:var(--coral);border-radius:8px;font-size:10px;display:flex;align-items:center;justify-content:center;padding:0 4px;font-style:normal;font-weight:700;color:#fff}
.badge.hidden{display:none}
.vip-badge{font-size:11px;background:var(--grad3);padding:2px 8px;border-radius:8px;font-weight:600;color:#000}

/* Scrollbar */
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

/* Responsive */
@media(max-width:380px){.swipe-card{aspect-ratio:2.8/4}.action-btn{width:42px;height:42px}.action-like,.action-dislike{width:54px;height:54px}}
