*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden;font-family:'Outfit',system-ui,sans-serif}
:root{--bg:#f8f6fc;--bg2:#fff;--surface:#f0ecf9;--text:#2d2640;--muted:#8e85a3;--border:#e4ddf0;--accent:#e44058;--accent-soft:rgba(228,64,88,.08);--secondary:#9b6dff;--secondary-soft:rgba(155,109,255,.08);--gradient:linear-gradient(135deg,#e44058,#c026d3);--tag-bg:#f0eaff;--tag-text:#7c3aed;--tag-border:rgba(124,58,237,.15);--shadow:0 4px 24px rgba(228,64,88,.2);--cam-a:linear-gradient(180deg,#f5f0ff,#ede6fb);--cam-b:linear-gradient(180deg,#fdf0f4,#fbe8ee);--chat-bg:rgba(255,255,255,.92);--msg-me:rgba(228,64,88,.1);--msg-other:#f0ecf9;--overlay:rgba(248,246,252,.9)}
body{background:var(--bg);color:var(--text)}

/* ═══ WELCOME ═══ */
.welcome-page{height:100vh;overflow:auto;position:relative}
.welcome-bg{position:fixed;inset:0;background:linear-gradient(135deg,#a78bfa 0%,#c084fc 25%,#e879a8 55%,#f0abbc 80%,#fbc2d4 100%);overflow:hidden;z-index:0}
.blob{position:absolute;border-radius:50%;background:rgba(255,255,255,.1)}
.b1{top:5%;left:5%;width:220px;height:220px;animation:fA 8s ease-in-out infinite}
.b2{bottom:8%;right:6%;width:260px;height:260px;background:rgba(255,255,255,.07);animation:fB 10s ease-in-out infinite}
.b3{top:40%;right:18%;width:140px;height:140px;background:rgba(255,255,255,.05);animation:fA 14s ease-in-out infinite}
.b4{bottom:30%;left:10%;width:110px;height:110px;border-radius:30px;background:rgba(255,255,255,.04);transform:rotate(45deg);animation:fB 9s ease-in-out infinite}
.b5{top:18%;right:40%;width:80px;height:80px;background:rgba(255,255,255,.06);animation:fA 11s ease-in-out infinite 2s}
.wnav{position:relative;z-index:1;display:flex;align-items:center;padding:0 28px;height:64px}
.wnav-logo{display:flex;align-items:center;gap:10px}
.wnav-icon{width:40px;height:40px;border-radius:13px;background:rgba(255,255,255,.25);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;font-size:22px}
.wnav-logo span{color:#fff;font-weight:800;font-size:22px;letter-spacing:-.5px}
.wcontent{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 64px - 260px);padding:20px 32px 0;gap:60px;overflow:hidden;max-width:1200px;margin:0 auto}
.wleft{flex:1 1 0;min-width:0;max-width:540px;overflow:hidden}
.wright{flex:0 0 340px;min-width:0}
.wtitle{font-size:46px;font-weight:900;line-height:1.04;color:#fff;letter-spacing:-2px;margin-bottom:20px;text-shadow:0 2px 24px rgba(0,0,0,.06)}

/* Feature carousel */
.fcarousel{position:relative;height:220px;margin-bottom:16px}
.fslide{position:absolute;inset:0;display:flex;background:rgba(255,255,255,.08);border-radius:22px;backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);overflow:hidden;opacity:0;transform:scale(.95);transition:all .7s cubic-bezier(.4,0,.2,1);pointer-events:none}
.fslide.active{opacity:1;transform:scale(1);pointer-events:auto}
.fanim{flex:1 1 55%;position:relative;border-right:1px solid rgba(255,255,255,.08);min-width:0;display:flex;align-items:center;justify-content:center;overflow:hidden}
.fanim-col{flex-direction:column;gap:4px}
.fanim-center{flex-direction:column;gap:0}
.ftext{flex:0 0 45%;padding:24px 20px;display:flex;flex-direction:column;justify-content:center}
.ftt{color:#ffe600;font-weight:900;font-size:26px;margin-bottom:6px;letter-spacing:-.5px;text-shadow:0 0 20px rgba(255,230,0,.5),0 2px 4px rgba(0,0,0,.15)}
.ftd{color:rgba(255,255,255,.7);font-size:13px;line-height:1.5}
.fdots{display:flex;gap:8px;padding-left:4px}
.fdot{height:10px;border-radius:5px;border:none;cursor:pointer;background:rgba(255,255,255,.3);transition:all .4s;width:10px}
.fdot.active{width:36px;background:#fff}

/* Welcome animations */
.atag{position:absolute;padding:7px 14px;border-radius:20px;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.25);color:#fff;font-size:12px;font-weight:700;white-space:nowrap;animation:tagF 3.5s ease-in-out infinite}
.ainput{position:relative;z-index:2;display:flex;align-items:center;gap:8px;padding:9px 16px;background:rgba(255,255,255,.25);border-radius:14px;border:1px solid rgba(255,255,255,.3)}
.ainput span{color:rgba(255,255,255,.5);font-size:12px}
.acursor{width:2px;height:16px;background:rgba(255,255,255,.6);animation:blink 1s step-end infinite}
.afr{display:flex;align-items:center;gap:8px;padding:6px 10px;background:rgba(255,255,255,.1);border-radius:10px;border:1px solid rgba(255,255,255,.15);width:85%;max-width:180px;animation:fSlide .5s ease both,fPulse 3s ease-in-out infinite}
.afav{width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:800;flex-shrink:0}
.afi{flex:1;min-width:0}.afi b{color:#fff;font-size:10px;display:block}.afi small{color:rgba(255,255,255,.5);font-size:8px}
.afdot{width:6px;height:6px;border-radius:50%;background:#34d399;box-shadow:0 0 5px #34d399}
.aring{position:absolute;border-radius:50%;border:2px solid rgba(255,255,255,.15)}
.r1{width:70px;height:70px;animation:ring 1.5s ease-out infinite}
.r2{width:110px;height:110px;animation:ring 1.8s ease-out infinite .3s}
.r3{width:150px;height:150px;animation:ring 2.1s ease-out infinite .6s}
.aphone{width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.2);border:2px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;animation:shake .8s ease-in-out infinite;z-index:2}
.acalling{position:absolute;bottom:12%;color:rgba(255,255,255,.7);font-size:11px;font-weight:600;animation:fadeIO 2s ease-in-out infinite}
.amatch-l,.amatch-r{position:absolute;width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center}
.amatch-l{background:rgba(244,114,182,.3);border:2px solid rgba(244,114,182,.4);animation:mL 2s ease-in-out infinite}
.amatch-r{background:rgba(167,139,250,.3);border:2px solid rgba(167,139,250,.4);animation:mR 2s ease-in-out infinite}
.aspark{position:absolute;font-size:26px;animation:spark 2s ease-in-out infinite;z-index:3}
.amatched{position:absolute;bottom:10%;color:rgba(255,255,255,.7);font-size:11px;font-weight:600;animation:fadeIO 2s ease-in-out infinite 1s}

/* Login card */
.lcard{background:rgba(255,255,255,.2);backdrop-filter:blur(28px);border-radius:24px;padding:32px 28px;border:1px solid rgba(255,255,255,.3);box-shadow:0 12px 48px rgba(0,0,0,.08);animation:cardIn .7s ease .3s both}
.lcard h2{color:#fff;font-size:22px;font-weight:800;text-align:center;margin-bottom:4px}
.lsub{color:rgba(255,255,255,.6);font-size:13px;text-align:center;margin-bottom:28px}
.btn-gw{display:flex;width:100%;padding:14px 20px;border-radius:14px;border:none;background:#fff;color:#2d2640;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;align-items:center;justify-content:center;gap:10px;box-shadow:0 4px 16px rgba(0,0,0,.06);text-decoration:none;margin-bottom:14px;transition:transform .12s}
.btn-gw:active{transform:scale(.98)}
.btn-guest{width:100%;padding:14px 0;border-radius:14px;border:2px solid rgba(255,255,255,.5);background:rgba(255,255,255,.1);color:#fff;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s;margin-bottom:18px}
.btn-guest:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.7)}
.llegal{color:rgba(255,255,255,.4);font-size:11px;line-height:1.5;text-align:center}
.llegal a{color:rgba(255,255,255,.6);text-decoration:underline}

/* Swipe cards */
.swipe-section{position:relative;z-index:1;padding:24px 0 40px}
.sst{text-align:center;color:rgba(255,255,255,.7);font-size:18px;font-weight:700;margin-bottom:4px}
.sss{text-align:center;color:rgba(255,255,255,.4);font-size:13px;margin-bottom:16px}
.swrap{position:relative;width:100%;overflow:hidden;padding:40px 0}
.sarrow{position:absolute;top:50%;right:30px;transform:translateY(-50%);z-index:10;animation:swipeHint 2s ease-in-out infinite}
.strack{display:flex;gap:20px;padding-left:20px;transition:transform .8s cubic-bezier(.4,0,.2,1)}
.scard{flex:0 0 320px;height:200px;border-radius:24px;overflow:hidden;position:relative;transition:all .8s cubic-bezier(.4,0,.2,1)}
.scard.active{opacity:1;transform:scale(1);border:2px solid rgba(255,255,255,.3);box-shadow:0 8px 32px rgba(0,0,0,.15)}
.scard:not(.active){opacity:.35;transform:scale(.88);border:1px solid rgba(255,255,255,.1)}
.scard-inner{display:flex;height:100%;position:relative}
.scard-cam{flex:1;position:relative;overflow:hidden}
.scard-cam:first-child{border-right:2px solid rgba(255,255,255,.15)}
.sc-person{display:flex;flex-direction:column;align-items:center;gap:6px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}
.sc-emoji{width:48px;height:48px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:20px}
.sc-name{font-size:11px;font-weight:700;color:rgba(0,0,0,.5)}
.sc-waves{position:absolute;bottom:8px;right:8px;display:flex;gap:2px;align-items:flex-end}
.sc-wave{width:2.5px;border-radius:2px;background:#fff;opacity:.8;animation:wave .7s ease-in-out infinite alternate}
.sc-live{position:absolute;top:10px;left:10px;display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:10px;background:rgba(0,0,0,.45);backdrop-filter:blur(8px)}
.sc-live-dot{width:6px;height:6px;border-radius:50%;background:#ef4444;box-shadow:0 0 8px #ef4444}
.sc-live span{color:#fff;font-size:10px;font-weight:700}
.sc-topic{position:absolute;top:10px;right:10px;padding:4px 12px;border-radius:12px;background:rgba(255,255,255,.9)}
.sc-topic span{font-size:11px;font-weight:700;color:#7c3aed}
.sc-timer{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);padding:3px 10px;border-radius:8px;background:rgba(0,0,0,.45)}
.sc-timer span{color:rgba(255,255,255,.9);font-size:10px;font-weight:600}
.sswipe{text-align:center;color:rgba(255,255,255,.35);font-size:12px;font-weight:600;margin-top:16px;letter-spacing:1px}
.sswipe span{animation:swipeText 2s ease-in-out infinite;display:inline-block}

/* ═══ APP ═══ */
.app-page{height:100vh;display:flex;flex-direction:column;overflow:hidden}
.topnav{display:flex;align-items:center;padding:0 16px;height:52px;background:var(--overlay);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:50;flex-shrink:0}
.tn-logo{display:flex;align-items:center;gap:7px;margin-right:16px}
.tn-icon{width:30px;height:30px;border-radius:9px;background:var(--gradient);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:900}
.tn-logo span{font-weight:800;font-size:15px;letter-spacing:-.5px}
.tn-tabs{display:flex;gap:2px;background:var(--surface);border-radius:12px;padding:3px}
.nt{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:9px;border:none;background:transparent;color:var(--muted);cursor:pointer;font-size:12px;font-weight:400;transition:all .2s;font-family:inherit}
.nt.active{background:#fff;color:var(--accent);font-weight:700;box-shadow:0 1px 6px rgba(0,0,0,.04)}
.tn-right{margin-left:auto}
.tn-online{font-size:11px;color:#22c55e;font-weight:600;display:flex;align-items:center;gap:5px}
.odot{width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 8px #22c55e;display:inline-block}
.main-area{flex:1;position:relative;overflow:hidden}
.cameras{position:absolute;inset:0;display:flex}
.cam{flex:1;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.cam-stranger{background:var(--cam-b);border-right:1px solid var(--border);order:1}
.cam-you{background:var(--cam-a);order:2}
.cam video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;transform:scaleX(-1)}
.watermark{position:absolute;bottom:14px;left:14px;z-index:2;display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.7);font-size:18px;font-weight:700;letter-spacing:.3px;pointer-events:none;text-shadow:0 2px 6px rgba(0,0,0,.4);font-family:'Outfit',system-ui,sans-serif}
.wm-icon{width:32px;height:32px;border-radius:10px;background:var(--gradient);display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:900;box-shadow:0 2px 8px rgba(228,64,88,.3)}
.cam-ph{text-align:center;color:var(--muted);z-index:0}.cam-ph p{margin-top:8px;font-size:12px;font-weight:600}

/* Overlay */
.overlay{position:absolute;inset:0;background:var(--overlay);backdrop-filter:blur(40px);display:none;align-items:center;justify-content:center;z-index:20;overflow:auto}
.overlay.active{display:flex}
.overlay-box{width:100%;max-width:500px;padding:20px}
.ov-label{text-align:center;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.ov-title{font-size:44px;font-weight:900;line-height:1.08;letter-spacing:-1.8px;text-align:center;margin-bottom:10px}
.ov-title span{background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.ov-sub{color:var(--muted);font-size:14px;text-align:center;margin-bottom:24px}
.tag-wrap{display:flex;flex-wrap:wrap;gap:8px;padding:14px 16px;background:#fff;border:2px solid var(--border);border-radius:18px;cursor:text;min-height:52px;align-items:center;box-shadow:0 2px 12px rgba(155,109,255,.04);transition:border-color .3s}
.tag-wrap:focus-within{border-color:var(--secondary)}
.tag{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:var(--tag-bg);color:var(--tag-text);border-radius:20px;font-size:13px;font-weight:700;border:1.5px solid var(--tag-border);animation:tagPop .25s ease}
.tag .tx{cursor:pointer;opacity:.4;font-size:16px;line-height:1}.tag .tx:hover{opacity:1}
#tagInput{flex:1;min-width:120px;background:transparent;border:none;outline:none;color:var(--muted);font-size:14px;font-family:inherit}
.tag-hint{color:var(--muted);font-size:11px;margin-top:6px;text-align:center}
.home-buttons{margin-top:20px;display:flex;flex-direction:column;gap:14px}
.btn-filters-home{width:100%;padding:18px 0;border-radius:18px;border:2px solid var(--border);background:#fff;color:var(--text);font-size:17px;font-weight:800;cursor:pointer;font-family:inherit;box-shadow:0 2px 8px rgba(0,0,0,.03);display:flex;align-items:center;justify-content:center;gap:10px;transition:all .3s}
.premium-badge{padding:2px 8px;border-radius:8px;background:linear-gradient(135deg,#f59e0b,#fbbf24);font-size:9px;color:#fff;font-weight:700}
.btn-start{width:100%;padding:18px 0;border-radius:18px;border:none;background:var(--gradient);color:#fff;font-size:17px;font-weight:800;cursor:pointer;font-family:inherit;box-shadow:var(--shadow);transition:transform .12s;display:flex;align-items:center;justify-content:center;gap:10px}
.btn-start:active{transform:scale(.97)}

/* Search/Connect anims inside stranger panel */
.search-anim,.connect-anim{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:5;background:linear-gradient(135deg,rgba(45,38,64,.92),rgba(80,50,120,.88));backdrop-filter:blur(20px)}
.search-anim.hidden,.connect-anim.hidden{display:none}
.friend-toast.hidden{display:none}

/* Search animation — pulsing rings + icon */
.sa-pulse-ring{position:absolute;width:140px;height:140px;border-radius:50%;border:2px solid rgba(155,109,255,.3);animation:saPulse 2s ease-out infinite}
.sa-ring-2{width:200px;height:200px;animation-delay:.5s}
.sa-icon{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#9b6dff,#e44058);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px rgba(155,109,255,.4);z-index:2}
.sa-title{font-size:18px;font-weight:800;color:#fff;letter-spacing:-.3px;z-index:2}
.sa-dots{display:flex;gap:8px;z-index:2}
.sa-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.6);animation:dotBounce 1.2s ease-in-out infinite}
.sa-cancel{padding:10px 28px;border-radius:14px;border:1.5px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08);color:rgba(255,255,255,.7);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;z-index:2;transition:all .2s}
.sa-cancel:hover{background:rgba(255,255,255,.15);color:#fff}

@keyframes saPulse{0%{transform:scale(.8);opacity:.6}100%{transform:scale(1.8);opacity:0}}

/* Match found animation */
.connect-anim{background:linear-gradient(135deg,rgba(45,38,64,.95),rgba(80,50,120,.92));gap:8px}
.ca-burst{position:absolute;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(228,64,88,.3) 0%,transparent 70%);animation:caBurst 1.5s ease-out infinite}
.ca-match-label{font-size:42px;font-weight:900;letter-spacing:-1.5px;background:linear-gradient(135deg,#fbbf24,#f472b6,#9b6dff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;z-index:2;animation:caMatchPop .6s cubic-bezier(.175,.885,.32,1.275) both}
.ca-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#f472b6,#9b6dff);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:28px;box-shadow:0 8px 32px rgba(244,114,182,.35);z-index:2;animation:connectPop .5s ease .2s both;border:3px solid rgba(255,255,255,.2)}
.ca-name{font-size:22px;font-weight:800;color:#fff;z-index:2;animation:fadeIn .4s ease .3s both}
.ca-country{font-size:13px;color:rgba(255,255,255,.6);font-weight:600;z-index:2;animation:fadeIn .4s ease .4s both}
.ca-tags{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;z-index:2;animation:fadeIn .4s ease .5s both}
.ca-tags span{padding:4px 12px;border-radius:12px;background:rgba(155,109,255,.25);border:1px solid rgba(155,109,255,.3);color:#fff;font-size:11px;font-weight:700}

@keyframes caBurst{0%{transform:scale(.5);opacity:.6}100%{transform:scale(2.5);opacity:0}}
@keyframes caMatchPop{0%{opacity:0;transform:scale(.3) rotate(-10deg)}100%{opacity:1;transform:scale(1) rotate(0)}}

/* Stranger info pill — top-left during streaming */
.stranger-info{position:absolute;top:12px;left:12px;right:12px;z-index:6;display:flex;align-items:center;gap:8px}
.stranger-info.hidden{display:none}
.si-pill{display:inline-flex;align-items:center;gap:10px;padding:6px 14px 6px 6px;background:rgba(0,0,0,.5);backdrop-filter:blur(12px);border-radius:24px;border:1px solid rgba(255,255,255,.1)}
.si-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#f472b6,#9b6dff);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:14px;flex-shrink:0}
.si-details{display:flex;flex-direction:column;gap:1px}
.si-name{font-weight:700;font-size:14px;color:#fff;line-height:1.2;text-shadow:0 1px 4px rgba(0,0,0,.3)}
.si-loc{font-size:11px;color:rgba(255,255,255,.55);line-height:1;font-weight:500}
.si-add-btn{padding:8px 16px;border-radius:16px;background:linear-gradient(135deg,#fbbf24,#f59e0b);border:none;color:#fff;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:6px;box-shadow:0 3px 12px rgba(245,158,11,.35);transition:transform .12s;flex-shrink:0;margin-left:auto;white-space:nowrap}
.si-add-btn:active{transform:scale(.93)}
.si-add-btn.hidden{display:none}
.si-sent{margin-left:auto;padding:8px 14px;border-radius:14px;color:rgba(255,255,255,.5);font-size:12px;font-weight:600;flex-shrink:0;background:rgba(255,255,255,.08);border-radius:16px}
.si-sent.hidden{display:none}
.si-accept-btn{margin-left:auto;padding:8px 16px;border-radius:16px;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;color:#fff;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:6px;box-shadow:0 3px 12px rgba(34,197,94,.35);transition:transform .12s;flex-shrink:0;animation:popIn .3s ease;white-space:nowrap}
.si-accept-btn:active{transform:scale(.93)}
.si-accept-btn.hidden{display:none}

/* Friend toasts */
.friend-toast{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:7;padding:14px 28px;border-radius:18px;backdrop-filter:blur(16px);animation:toastIn .4s ease;display:flex;align-items:center;gap:10px;font-size:14px;font-weight:700;background:rgba(0,0,0,.6);color:#fff;white-space:nowrap;border:1px solid rgba(255,255,255,.1)}
.toast-gold{background:rgba(245,158,11,.2);border:1px solid rgba(245,158,11,.3);color:#fff}
.toast-green{background:rgba(34,197,94,.2);border:1px solid rgba(34,197,94,.3);color:#fff}

/* Stream UI */
.stream-ui{position:absolute;inset:0;z-index:20;pointer-events:none}.stream-ui.hidden{display:none}.stream-ui>*{pointer-events:auto}
.stream-chat{position:absolute;bottom:76px;left:calc(50% + 16px);width:calc(50% - 32px);max-width:300px;display:flex;flex-direction:column;gap:8px}
.stream-messages{background:var(--chat-bg);border-radius:16px;padding:14px;max-height:200px;overflow:auto;border:1px solid var(--border);box-shadow:0 4px 16px rgba(0,0,0,.03);min-height:60px}
.stream-message{display:flex;align-items:flex-end;gap:6px;margin-bottom:6px}
.stream-message.stream-personal{flex-direction:row-reverse}
.sm-avatar{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.sm-avatar-them{background:linear-gradient(135deg,#f472b6,#9b6dff);color:#fff}
.sm-avatar-me{background:var(--gradient);color:#fff}
.sm-bubble{padding:8px 12px;border-radius:14px;font-size:13px;max-width:80%;word-wrap:break-word}
.sm-bubble-them{background:#fff;color:var(--text);border:1px solid var(--border);border-radius:14px 14px 14px 4px}
.sm-bubble-me{background:var(--gradient);color:#fff;border-radius:14px 14px 4px 14px}
.stream-input{display:flex;gap:8px}
.stream-input input{flex:1;padding:10px 14px;border-radius:14px;border:1.5px solid var(--border);background:#fff;color:var(--text);font-size:13px;font-family:inherit;outline:none}
.stream-input button{padding:10px 18px;border-radius:14px;border:none;background:var(--gradient);color:#fff;font-weight:700;font-size:12px;cursor:pointer;font-family:inherit}
.ctrl-bar{position:absolute;bottom:0;left:0;right:0;padding:12px 24px;background:rgba(248,246,252,.92);backdrop-filter:blur(20px);border-top:1px solid var(--border);display:flex;justify-content:center;align-items:center;gap:12px}
.cb{width:50px;height:50px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:transform .12s;position:relative}
.cb:active{transform:scale(.9)}
.cb-gold{background:linear-gradient(135deg,#fbbf24,#f59e0b);border:2px solid #fde68a;box-shadow:0 4px 12px rgba(245,158,11,.3)}
.cb-gold .cb-badge{position:absolute;top:-4px;right:-4px;padding:1px 5px;border-radius:6px;background:linear-gradient(135deg,#f59e0b,#ec4899);font-size:8px;color:#fff;font-weight:800}
.cb-filters{height:50px;padding:0 20px;border-radius:25px;background:rgba(155,109,255,.08);border:2px solid rgba(155,109,255,.2);box-shadow:0 2px 8px rgba(155,109,255,.1);color:var(--secondary);font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:6px;transition:transform .12s}
.cb-filters:active{transform:scale(.93)}
.cb-green{background:linear-gradient(135deg,#22c55e,#16a34a);border:2px solid #86efac;box-shadow:0 4px 12px rgba(34,197,94,.35)}
.btn-stop{height:52px;padding:0 32px;border-radius:26px;background:var(--gradient);border:none;cursor:pointer;font-size:15px;color:#fff;font-weight:800;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:var(--shadow);transition:transform .12s;white-space:nowrap}
.btn-stop:active{transform:scale(.95)}

/* Side panels */
.side-panel{position:absolute;inset:0;background:var(--overlay);backdrop-filter:blur(32px);z-index:25;display:none;justify-content:center;align-items:flex-start;padding-top:40px;overflow:auto;animation:fadeIn .3s ease}
.side-panel.active{display:flex}
.sp-inner{width:100%;max-width:560px;padding:20px 24px}

/* Popups */
.popup-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(8px);z-index:9999}
.popup-overlay.hidden{display:none}
.popup-box{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:28px;padding:36px 28px;width:520px;max-width:92%;max-height:90vh;overflow:auto;box-shadow:0 16px 48px rgba(0,0,0,.12);border:1px solid var(--border);z-index:10000;animation:popIn .3s ease}
.popup-box.hidden{display:none}
.popup-x{position:absolute;top:14px;right:18px;background:none;border:none;font-size:22px;color:var(--muted);cursor:pointer}

/* ═══ ANIMATIONS ═══ */
@keyframes fA{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-25px) scale(1.03)}}
@keyframes fB{0%,100%{transform:translateY(0)}50%{transform:translateY(18px)}}
@keyframes cardIn{from{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes tagF{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-10px) rotate(2deg)}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
@keyframes fSlide{from{opacity:0;transform:translateX(-16px)}to{opacity:1;transform:translateX(0)}}
@keyframes fPulse{0%,100%{background:rgba(255,255,255,.1)}50%{background:rgba(255,255,255,.16)}}
@keyframes ring{0%{transform:scale(1);opacity:.5}100%{transform:scale(2.2);opacity:0}}
@keyframes shake{0%,100%{transform:rotate(0)}10%{transform:rotate(12deg)}20%{transform:rotate(-12deg)}30%{transform:rotate(8deg)}40%{transform:rotate(-8deg)}50%,100%{transform:rotate(0)}}
@keyframes fadeIO{0%,100%{opacity:0}30%,70%{opacity:1}}
@keyframes mL{0%,100%{transform:translateX(-45px)}40%,60%{transform:translateX(-6px)}}
@keyframes mR{0%,100%{transform:translateX(45px)}40%,60%{transform:translateX(6px)}}
@keyframes spark{0%,30%{opacity:0;transform:scale(0)}45%{opacity:1;transform:scale(1.3)}55%{opacity:1;transform:scale(1)}70%,100%{opacity:0;transform:scale(0)}}
@keyframes swipeHint{0%,100%{transform:translateY(-50%) translateX(0);opacity:.5}50%{transform:translateY(-50%) translateX(10px);opacity:1}}
@keyframes swipeText{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}
@keyframes wave{0%{height:4px}100%{height:16px}}
@keyframes tagPop{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
@keyframes swipeL{0%,100%{transform:translateX(0) rotate(0deg);opacity:.5}50%{transform:translateX(-40px) rotate(-12deg);opacity:0}}
@keyframes swipeR{0%,100%{transform:translateX(0) rotate(0deg);opacity:.5}50%{transform:translateX(40px) rotate(12deg);opacity:0}}
@keyframes searchPulse{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.06)}}
@keyframes dotBounce{0%,100%{transform:translateY(0);opacity:.3}50%{transform:translateY(-8px);opacity:1}}
@keyframes popIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
@keyframes connectPop{from{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}

::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}
input[type=range]{-webkit-appearance:none;appearance:none;background:var(--border);border-radius:2px;height:6px}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.1)}

@media(max-width:768px){
  .tn-tabs{display:none}.ov-title{font-size:32px}.stream-chat{left:8px;width:calc(100% - 16px);bottom:70px}
  .cameras{flex-direction:column}.cam-stranger{border-right:none;border-bottom:1px solid var(--border)}
  .wcontent{flex-direction:column;padding:20px;gap:16px}.wleft{max-width:100%}.wright{flex:0 0 auto;width:100%}
  .wtitle{font-size:32px}.fcarousel{height:180px}
}

/* Incoming call overlay */
.call-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(24px);z-index:200;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease}
.call-overlay.hidden{display:none}
.call-popup{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px 40px;animation:popIn .4s ease}
.call-avatar{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,#f472b6,#9b6dff);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:40px;box-shadow:0 8px 40px rgba(155,109,255,.4);animation:callPulse 2s ease-in-out infinite}
.call-name{font-size:28px;font-weight:800;color:#fff;letter-spacing:-.5px}
.call-label{font-size:15px;color:rgba(255,255,255,.6);font-weight:500;margin-top:-8px}
.call-buttons{display:flex;gap:40px;margin-top:24px}
.call-btn-reject{width:72px;height:72px;border-radius:50%;background:#ef4444;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(239,68,68,.4);transition:transform .12s}
.call-btn-reject:active{transform:scale(.9)}
.call-btn-accept{width:72px;height:72px;border-radius:50%;background:#22c55e;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(34,197,94,.4);transition:transform .12s;animation:callBounce 1.5s ease-in-out infinite}
.call-btn-accept:active{transform:scale(.9)}
@keyframes callPulse{0%,100%{box-shadow:0 8px 40px rgba(155,109,255,.4)}50%{box-shadow:0 8px 60px rgba(155,109,255,.6),0 0 0 16px rgba(155,109,255,.1)}}
@keyframes callBounce{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}

/* Registration popup */
.reg-avatar-wrap{position:relative;width:100px;height:100px;cursor:pointer;margin:0 auto 8px}
.reg-avatar{width:100px;height:100px;border-radius:50%;background:var(--secondary);display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:800;color:#fff;overflow:hidden;transition:opacity .15s}
.reg-avatar:hover{opacity:.85}
.reg-avatar img{width:100%;height:100%;object-fit:cover}
.reg-cam{position:absolute;bottom:2px;right:2px;width:28px;height:28px;border-radius:50%;background:#fff;border:2px solid #fff;display:flex;align-items:center;justify-content:center}
.reg-cam-inner{width:22px;height:22px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center}
.reg-field{display:flex;align-items:center;gap:10px;padding:14px 16px;background:var(--surface);border-radius:14px;border:1px solid var(--border);margin-bottom:12px}
.reg-field input{flex:1;border:none;background:transparent;font-size:15px;font-weight:600;color:var(--text);outline:none;font-family:inherit}
.reg-field input::placeholder{color:var(--muted);font-weight:500}
.reg-field .rf-icon{font-size:18px;flex-shrink:0}
.reg-field .rf-count{font-size:11px;color:var(--muted)}
.reg-gender{display:flex;gap:10px;margin-bottom:12px}
.reg-gender-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 0;background:var(--surface);border-radius:14px;border:1px solid var(--border);cursor:pointer;font-size:15px;font-weight:700;color:var(--text);transition:all .15s;font-family:inherit}
.reg-gender-btn.sel{background:rgba(155,109,255,.08);border-color:var(--secondary);color:var(--secondary)}
.reg-gender-btn.locked{opacity:.5;cursor:not-allowed}
.reg-save{width:100%;padding:16px 0;border-radius:16px;border:none;background:var(--gradient);color:#fff;font-size:16px;font-weight:800;cursor:pointer;font-family:inherit;box-shadow:var(--shadow)}
.reg-save:active{transform:scale(.98)}
.reg-lock{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:3px}
