/* ═══════════════════════════════════════════
   RESET & VARIABLES
═══════════════════════════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{
  --bg:#04040a;--bg2:#0b0b14;--bg3:#11111e;--bg4:#181828;
  --accent:#00f5d4;--pink:#ff2d78;--purple:#7c3aff;--yellow:#ffd60a;
  --text:#eeeef5;--text2:#aaabb8;--muted:#666680;
  --border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.13);
  --ga:0 0 30px rgba(0,245,212,.35);--gp:0 0 30px rgba(255,45,120,.35);--gv:0 0 30px rgba(124,58,255,.35);
  --r:10px;--rl:16px;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--text);font-family:'Syne',sans-serif;overflow-x:hidden;min-height:100vh}
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--purple);border-radius:3px}
img,svg{display:block}
a{text-decoration:none;color:inherit}
button,input,textarea,select{font-family:'Syne',sans-serif;border:none;outline:none}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}
/* noise grain */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");opacity:.35}

/* ═══ TYPOGRAPHY ═══ */
.mono{font-family:'DM Mono',monospace}
.bebas{font-family:'Bebas Neue',sans-serif;letter-spacing:.04em}

/* ═══ LAYOUT ═══ */
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
.page{display:none;min-height:100vh;padding-top:64px;animation:fadeUp .35s ease both}
.page.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

/* ═══ GRID BG ═══ */
.gridbg{background-image:linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);background-size:44px 44px}

/* ═══ BUTTONS ═══ */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:var(--r);font-size:14px;font-weight:700;cursor:pointer;border:none;transition:all .2s;white-space:nowrap;font-family:'Syne',sans-serif}
.btn-primary{background:var(--accent);color:var(--bg);box-shadow:var(--ga)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 48px rgba(0,245,212,.55)}
.btn-primary:active{transform:translateY(0)}
.btn-pink{background:var(--pink);color:#fff;box-shadow:var(--gp)}
.btn-pink:hover{transform:translateY(-2px);box-shadow:0 0 48px rgba(255,45,120,.55)}
.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border2)!important}
.btn-outline:hover{border-color:var(--accent)!important;color:var(--accent)}
.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border)!important}
.btn-ghost:hover{color:var(--pink);border-color:var(--pink)!important}
.btn-sm{padding:8px 16px;font-size:12px}
.btn-xs{padding:5px 12px;font-size:11px}

/* ═══ CARDS & INPUTS ═══ */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rl);padding:24px}
.input{background:var(--bg3);border:1px solid var(--border)!important;border-radius:var(--r);padding:11px 16px;color:var(--text);font-size:14px;outline:none;width:100%;transition:border-color .2s;font-family:'Syne',sans-serif}
.input:focus{border-color:var(--accent)!important}
.input::placeholder{color:var(--muted)}
textarea.input{resize:none}
select.input{cursor:pointer;appearance:none;-webkit-appearance:none}

/* ═══ BADGES ═══ */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:20px;font-size:11px;font-family:'DM Mono',monospace}
.ba{background:rgba(0,245,212,.1);color:var(--accent);border:1px solid rgba(0,245,212,.2)!important}
.bp{background:rgba(255,45,120,.1);color:var(--pink);border:1px solid rgba(255,45,120,.2)!important}
.bv{background:rgba(124,58,255,.1);color:var(--purple);border:1px solid rgba(124,58,255,.2)!important}
.bm{background:rgba(100,100,128,.1);color:var(--muted);border:1px solid var(--border)!important}
.by{background:rgba(255,214,10,.1);color:var(--yellow);border:1px solid rgba(255,214,10,.2)!important}

/* ═══ PULSE DOT ═══ */
.dot{width:7px;height:7px;border-radius:50%;background:var(--accent);display:inline-block;animation:pulse 2s ease infinite;flex-shrink:0}
.dot-p{background:var(--pink)}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}

/* ═══ SPINNER ═══ */
.spinner{width:36px;height:36px;border:3px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .75s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ═══ NAVBAR ═══ */
.navbar{position:fixed;top:0;left:0;right:0;z-index:500;background:rgba(4,4,10,.92);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--border)}
.navbar-inner{max-width:1140px;margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:10px}
/* Logo SVG */
.nav-logo{display:flex;align-items:center;gap:12px;cursor:pointer;flex-shrink:0}
.nav-logo-img{width:32px;height:32px;border-radius:8px;object-fit:cover;box-shadow:0 0 15px rgba(0,245,212,0.3)}
.nav-logo-svg{width:32px;height:32px;flex-shrink:0}
.nav-logo-txt{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:.05em}
.nav-logo-txt .s{color:var(--accent)}.nav-logo-txt .c{color:var(--pink)}
.nav-online{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted);display:flex;align-items:center;gap:6px}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-link{padding:7px 14px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--muted);transition:all .2s;font-family:'Syne',sans-serif}
.nav-link:hover{color:var(--text)}
.nav-link.active{color:var(--accent);background:rgba(0,245,212,.08)}
.nav-cta{margin-left:8px}
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;background:none;border:none;cursor:pointer;margin-left:auto;padding:4px}
.hamburger span{display:block;height:2px;background:var(--text2);border-radius:2px;transition:all .25s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;flex-direction:column;gap:8px;background:var(--bg2);border-bottom:1px solid var(--border);overflow:hidden;max-height:0;transition:max-height .3s ease,padding .3s ease}
.mobile-menu.open{max-height:400px;padding:16px 24px 20px}
.mobile-link{font-size:16px;font-weight:600;color:var(--muted);padding:10px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:color .2s;background:none;text-align:left;font-family:'Syne',sans-serif;width:100%}
.mobile-link:hover,.mobile-link.active{color:var(--accent)}

/* ═══ AD SLOTS ═══ */
.ad-wrap{position:relative;margin:0 auto}
.ad-label{position:absolute;top:4px;left:8px;font-family:'DM Mono',monospace;font-size:9px;color:rgba(255,255,255,.18);z-index:1}
.ad-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(124,58,255,.06),rgba(255,45,120,.04));border:1px dashed rgba(124,58,255,.2);border-radius:var(--r);min-height:60px}
.ad-ph-inner{text-align:center}
.ad-ph-title{font-size:13px;font-weight:600;color:var(--text2);margin-bottom:3px}
.ad-ph-sub{font-family:'DM Mono',monospace;font-size:10px;color:var(--purple)}
.ad-leaderboard .ad-placeholder{height:90px}
.ad-billboard .ad-placeholder{height:220px}
.ad-rect .ad-placeholder{height:250px;width:300px}
.ad-native{position:relative;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:14px;cursor:pointer;transition:border-color .2s}
.ad-native:hover{border-color:rgba(124,58,255,.3)}
.ad-native-inner{display:flex;align-items:center;gap:12px}
.ad-native-icon{width:44px;height:44px;border-radius:10px;background:rgba(124,58,255,.1);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.ad-native-title{font-size:14px;font-weight:700;margin-bottom:3px;color:var(--text)}
.ad-native-desc{font-size:12px;color:var(--muted);font-family:'DM Mono',monospace}
.ad-native-body{flex:1}
.ad-interstitial{position:fixed;inset:0;background:rgba(0,0,0,.9);backdrop-filter:blur(10px);z-index:9000;display:none;align-items:center;justify-content:center;animation:fadeUp .25s ease}
.ad-inter-box{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--rl);padding:32px;max-width:520px;width:calc(100% - 32px);text-align:center;position:relative}
.ad-close{position:absolute;top:10px;right:10px;background:var(--bg3);border:1px solid var(--border)!important;border-radius:6px;color:var(--muted);cursor:pointer;font-size:14px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:color .2s}
.ad-close:hover{color:var(--text)}

/* ═══════════════════════════════════════════
   HOME PAGE
═══════════════════════════════════════════ */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:100px 24px 80px;position:relative;overflow:hidden}
.orb{position:absolute;border-radius:50%;filter:blur(88px);pointer-events:none}
.orb1{width:500px;height:500px;background:rgba(0,245,212,.07);top:5%;left:-12%}
.orb2{width:580px;height:580px;background:rgba(255,45,120,.05);bottom:-5%;right:-15%}
.orb3{width:340px;height:340px;background:rgba(124,58,255,.09);top:35%;right:15%}
.hero-eyebrow{display:flex;align-items:center;gap:8px;font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.18em;color:var(--accent);text-transform:uppercase;margin-bottom:24px;animation:fadeUp .6s ease both}
.hero-title{line-height:.88;margin-bottom:24px;animation:fadeUp .6s .1s ease both}
.hero-l1{display:block;font-family:'Bebas Neue',sans-serif;font-size:clamp(72px,13vw,148px);color:var(--text)}
.hero-l2{display:block;font-family:'Bebas Neue',sans-serif;font-size:clamp(72px,13vw,148px);background:linear-gradient(135deg,var(--accent),var(--pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:17px;color:var(--muted);max-width:420px;line-height:1.7;margin-bottom:36px;animation:fadeUp .6s .2s ease both}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;animation:fadeUp .6s .3s ease both}
.hero-stats{display:flex;gap:48px;margin-top:64px;flex-wrap:wrap;justify-content:center;animation:fadeUp .6s .4s ease both}
.hstat-num{font-family:'Bebas Neue',sans-serif;font-size:44px;color:var(--accent);line-height:1}
.hstat-label{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:.15em;margin-top:6px}

.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.feat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rl);padding:28px;cursor:pointer;transition:all .25s;position:relative;overflow:hidden}
.feat-card:hover{transform:translateY(-5px);border-color:rgba(0,245,212,.18)}
.feat-icon{width:52px;height:52px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:18px}
.feat-title{font-size:18px;font-weight:700;margin-bottom:10px}
.feat-desc{font-size:13px;color:var(--muted);line-height:1.65}

.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.how-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rl);padding:24px}
.how-num{font-family:'Bebas Neue',sans-serif;font-size:56px;color:rgba(0,245,212,.15);line-height:1;margin-bottom:12px}
.how-title{font-size:16px;font-weight:700;margin-bottom:8px}
.how-desc{font-size:13px;color:var(--muted);line-height:1.6}

.cta-card{background:linear-gradient(135deg,rgba(0,245,212,.05),rgba(124,58,255,.05));border:1px solid rgba(0,245,212,.15);border-radius:24px;padding:72px 40px;text-align:center;position:relative;overflow:hidden}
.cta-orb{position:absolute;width:400px;height:400px;border-radius:50%;background:rgba(0,245,212,.06);filter:blur(80px);top:-100px;left:50%;transform:translateX(-50%);pointer-events:none}

.s-eye{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--purple);margin-bottom:10px}
.s-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(36px,5vw,60px);line-height:1;margin-bottom:14px}
.s-title .ac{color:var(--accent)}.s-title .pk{color:var(--pink)}
.s-sub{font-size:15px;color:var(--muted);max-width:540px;line-height:1.7}
.sec{padding:72px 0}

/* ═══════════════════════════════════════════
   CHAT PAGE
═══════════════════════════════════════════ */
.chat-layout{display:grid;grid-template-columns:1fr 300px;gap:20px;padding:20px 0 40px;align-items:start}
.chat-panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rl);display:flex;flex-direction:column;height:calc(100vh - 160px);min-height:520px;overflow:hidden}
.chat-hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);background:var(--bg3);flex-shrink:0}
.chat-hdr-l{display:flex;align-items:center;gap:12px}
.chat-hdr-r{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.s-av{width:40px;height:40px;border-radius:50%;background:rgba(0,245,212,.08);border:2px solid rgba(0,245,212,.3);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.s-name{font-size:15px;font-weight:700}
.s-meta{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted);display:flex;align-items:center;gap:5px;margin-top:2px}
.status-pill{font-family:'DM Mono',monospace;font-size:11px;padding:4px 10px;border-radius:20px;border:1px solid var(--border);color:var(--muted)}
.sp-conn{color:var(--accent)!important;border-color:rgba(0,245,212,.3)!important;background:rgba(0,245,212,.06)}
.sp-search{color:var(--yellow)!important;border-color:rgba(255,214,10,.3)!important;background:rgba(255,214,10,.06)}
.sp-disc{color:var(--pink)!important;border-color:rgba(255,45,120,.3)!important;background:rgba(255,45,120,.06)}
.chat-msgs{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:10px;scroll-behavior:smooth}
.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;padding:40px}
.chat-empty-icon{font-size:52px}
.chat-empty-title{font-size:20px;font-weight:700}
.chat-empty-sub{font-size:13px;color:var(--muted)}
.msg{display:flex;flex-direction:column;max-width:72%}
.msg-me{align-self:flex-end}.msg-them{align-self:flex-start}.msg-sys{align-self:center;max-width:90%}
.bubble{padding:10px 15px;border-radius:14px;font-size:14px;line-height:1.55;word-break:break-word;animation:fadeUp .2s ease}
.msg-me .bubble{background:rgba(0,245,212,.13);border:1px solid rgba(0,245,212,.22);border-radius:14px 14px 4px 14px}
.msg-them .bubble{background:var(--bg3);border:1px solid var(--border);border-radius:14px 14px 14px 4px}
.msg-sys .bubble{background:transparent;color:var(--muted);font-size:12px;font-family:'DM Mono',monospace;border:none;text-align:center}
.msg-time{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);margin-top:4px}
.msg-me .msg-time{text-align:right}
.disc-banner{display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 20px;background:rgba(255,45,120,.08);border:1px solid rgba(255,45,120,.2);border-radius:var(--r);font-size:13px;color:var(--pink);margin-top:8px}
.chat-input-row{display:flex;gap:8px;padding:14px 16px;border-top:1px solid var(--border);flex-shrink:0;background:var(--bg3)}
/* typing */
.typing-wrap{align-self:flex-start}
.typing{display:flex;align-items:center;gap:4px;padding:12px 16px;background:var(--bg3);border:1px solid var(--border);border-radius:14px 14px 14px 4px;width:52px}
.typing span{width:7px;height:7px;border-radius:50%;background:var(--muted);animation:typAnim 1.4s ease infinite}
.typing span:nth-child(2){animation-delay:.2s}
.typing span:nth-child(3){animation-delay:.4s}
@keyframes typAnim{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-6px)}}
.sb-title{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.15em;color:var(--purple);margin-bottom:8px}
.sb-sub{font-size:12px;color:var(--muted);line-height:1.6;margin-bottom:14px}
.int-tags{display:flex;flex-wrap:wrap;gap:7px}
.int-tag{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;border:1px solid var(--border)!important;background:var(--bg3);color:var(--muted);cursor:pointer;transition:all .2s;font-family:'Syne',sans-serif}
.int-tag:hover{border-color:var(--accent)!important;color:var(--accent)}
.int-tag.sel{border-color:var(--accent)!important;color:var(--accent);background:rgba(0,245,212,.08)}

/* ═══════════════════════════════════════════
   CONFESSIONS PAGE
═══════════════════════════════════════════ */
.conf-layout{display:grid;grid-template-columns:1fr 280px;gap:20px;padding:20px 0 60px;align-items:start}
.conf-comp-title{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.15em;color:var(--pink);margin-bottom:12px}
.conf-footer{display:flex;align-items:flex-start;gap:10px;flex-wrap:wrap}
.cat-tags{display:flex;flex-wrap:wrap;gap:6px;flex:1}
.cat-btn{padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid var(--border)!important;background:var(--bg3);color:var(--muted);cursor:pointer;transition:all .2s;font-family:'Syne',sans-serif}
.cat-btn:hover{border-color:var(--pink)!important;color:var(--pink)}
.cat-btn.sel{border-color:var(--pink)!important;color:var(--pink);background:rgba(255,45,120,.08)}
.char-c{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted)}
.char-c.warn{color:var(--pink)}
.conf-filters{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.filter-tags{display:flex;flex-wrap:wrap;gap:6px}
.filter-btn{padding:5px 13px;border-radius:20px;font-size:12px;font-weight:600;border:1px solid var(--border)!important;background:transparent;color:var(--muted);cursor:pointer;transition:all .2s;font-family:'Syne',sans-serif}
.filter-btn:hover{color:var(--text);border-color:var(--border2)!important}
.filter-btn.sel{color:var(--accent);border-color:rgba(0,245,212,.3)!important;background:rgba(0,245,212,.06)}
.sort-btns{display:flex;gap:4px}
.sort-btn{padding:5px 12px;border-radius:8px;font-size:12px;font-weight:700;border:none;background:transparent;color:var(--muted);cursor:pointer;transition:all .2s;font-family:'Syne',sans-serif;text-transform:capitalize}
.sort-btn:hover{color:var(--text)}
.sort-btn.sel{color:var(--accent);background:rgba(0,245,212,.08)}
.conf-feed{display:flex;flex-direction:column;gap:12px}
.conf-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rl);padding:20px;transition:all .2s;cursor:default;animation:fadeUp .3s ease both}
.conf-card:hover{border-color:rgba(255,45,120,.2);transform:translateY(-2px)}
.conf-card-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:6px}
.conf-time{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted)}
.conf-text{font-size:15px;line-height:1.7;color:var(--text);margin-bottom:16px}
.conf-expand-btn{background:none;border:none;color:var(--accent);font-size:12px;cursor:pointer;font-family:'Syne',sans-serif;font-weight:600}
.conf-actions{display:flex;gap:6px;flex-wrap:wrap}
.conf-act{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:8px;font-size:13px;font-weight:600;border:1px solid var(--border)!important;background:var(--bg3);color:var(--muted);cursor:pointer;transition:all .2s;font-family:'Syne',sans-serif}
.conf-act:hover{border-color:var(--pink)!important;color:var(--pink)}
.conf-act.liked{color:var(--pink);border-color:rgba(255,45,120,.4)!important;background:rgba(255,45,120,.08)}
.conf-act.reacted{color:var(--accent);border-color:rgba(0,245,212,.4)!important;background:rgba(0,245,212,.06)}
/* trending sb */
.trending-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:opacity .2s}
.trending-item:hover{opacity:.8}
.trending-item:last-child{border-bottom:none}
.trending-rank{font-family:'Bebas Neue',sans-serif;font-size:20px;color:rgba(0,245,212,.25);line-height:1.2;flex-shrink:0;width:22px}
.trending-text{font-size:12px;color:var(--text2);line-height:1.5;flex:1}
.trending-likes{font-size:11px;color:var(--pink);font-family:'DM Mono',monospace;flex-shrink:0}

/* ═══════════════════════════════════════════
   MATCHING PAGE
═══════════════════════════════════════════ */
.match-layout{display:grid;grid-template-columns:1fr 300px;gap:24px;padding:32px 0 60px;align-items:start}
.card-stack{display:flex;flex-direction:column;align-items:center;gap:24px}
.swipe-card{background:var(--bg2);border:1px solid var(--border);border-radius:24px;padding:40px 32px;width:100%;max-width:420px;text-align:center;transition:transform .35s ease,opacity .35s ease;position:relative;overflow:hidden}
.swipe-card::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(0,245,212,.05),transparent 60%);pointer-events:none}
.swipe-card.anim-like{transform:translateX(90px) rotate(9deg);opacity:0;pointer-events:none}
.swipe-card.anim-pass{transform:translateX(-90px) rotate(-9deg);opacity:0;pointer-events:none}
.sc-avatar{font-size:72px;margin-bottom:16px;filter:drop-shadow(0 0 20px rgba(0,245,212,.3))}
.sc-name{font-size:26px;font-weight:800;margin-bottom:6px}
.sc-meta{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted);margin-bottom:16px}
.sc-bio{font-size:14px;color:var(--text2);line-height:1.7;margin-bottom:20px}
.sc-tags{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;margin-bottom:16px}
.shared-banner{display:inline-block;padding:6px 16px;border-radius:20px;font-family:'DM Mono',monospace;font-size:11px;color:var(--accent);background:rgba(0,245,212,.08);border:1px solid rgba(0,245,212,.2)!important}
.swipe-actions{display:flex;align-items:center;gap:20px}
.swipe-btn{border-radius:50%;border:2px solid;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;background:var(--bg2);font-size:22px}
.sb-pass{width:58px;height:58px;border-color:rgba(255,45,120,.4)!important;color:var(--pink);font-size:18px}
.sb-pass:hover{background:rgba(255,45,120,.12);box-shadow:var(--gp);transform:scale(1.1)}
.sb-like{width:68px;height:68px;border-color:rgba(0,245,212,.4)!important;color:var(--accent);font-size:24px}
.sb-like:hover{background:rgba(0,245,212,.12);box-shadow:var(--ga);transform:scale(1.1)}
.sb-star{width:52px;height:52px;border-color:rgba(255,214,10,.4)!important;color:var(--yellow);font-size:18px}
.sb-star:hover{background:rgba(255,214,10,.1);box-shadow:0 0 20px rgba(255,214,10,.3);transform:scale(1.1)}
.swipe-hint{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted)}
/* match popup */
.match-overlay{position:fixed;inset:0;background:rgba(0,0,0,.88);backdrop-filter:blur(10px);z-index:8000;display:none;align-items:center;justify-content:center;animation:fadeUp .3s ease}
.match-popup{background:var(--bg2);border:1px solid rgba(0,245,212,.22);border-radius:24px;padding:48px 40px;text-align:center;max-width:400px;width:calc(100% - 32px);box-shadow:0 0 60px rgba(0,245,212,.12)}
.match-fire{font-size:56px;margin-bottom:12px}
.match-title{font-family:'Bebas Neue',sans-serif;font-size:56px;background:linear-gradient(135deg,var(--accent),var(--pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:20px;line-height:1}
.match-avs{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:16px}
.match-av{width:64px;height:64px;border-radius:50%;background:rgba(0,245,212,.08);border:2px solid rgba(0,245,212,.3)!important;display:flex;align-items:center;justify-content:center;font-size:30px}
.match-sub{font-size:15px;color:var(--muted);margin-bottom:28px}
.match-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.match-sb{position:sticky;top:84px;display:flex;flex-direction:column;gap:16px}
.ms-profile{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.ms-av-me{width:48px;height:48px;border-radius:50%;background:rgba(0,245,212,.1);border:2px solid rgba(0,245,212,.3)!important;display:flex;align-items:center;justify-content:center;font-size:22px}
.matches-list{display:flex;flex-direction:column;gap:10px}
.match-item{display:flex;align-items:center;gap:10px}
.match-item-av{font-size:22px}
.match-item-name{font-size:14px;font-weight:600}
.match-item-country{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted)}
.match-empty{font-size:13px;color:var(--muted);text-align:center;padding:16px 0}
/* Filter labels */
.filter-lbl{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text2);cursor:pointer;padding:8px 0;border-bottom:1px solid var(--border)}
.filter-lbl:last-child{border-bottom:none}
input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}

/* ═══════════════════════════════════════════
   VIDEO PAGE
═══════════════════════════════════════════ */
.video-layout{display:grid;grid-template-columns:1fr 280px;gap:20px;padding:20px 0 60px;align-items:start}
.vid-cs{text-align:center;padding:40px 32px}
.video-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:0 auto 24px;width:100%;max-width:560px}
.vid-tile{border-radius:var(--rl);overflow:hidden;position:relative;aspect-ratio:4/3;background:var(--bg3);border:1px solid var(--border)}
.vid-tile.remote{grid-column:1/-1;aspect-ratio:16/9}
.vid-ph{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:180px}
.vid-tile.remote .vid-ph{min-height:240px}
.vid-icon{font-size:48px;opacity:.35}
.vid-lbl{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted);letter-spacing:.1em}
.vid-live{position:absolute;top:12px;left:12px}
.vid-controls{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}
.vid-ctrl-btn{width:44px;height:44px;border-radius:50%;border:1px solid var(--border)!important;background:var(--bg3);color:var(--text2);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.vid-ctrl-btn:hover{border-color:var(--accent)!important;color:var(--accent)}
.vid-ctrl-btn.danger{border-color:rgba(255,45,120,.3)!important;color:var(--pink)}
.vid-ctrl-btn.danger:hover{background:rgba(255,45,120,.1)}
.vid-ctrl-btn.active-ctrl{border-color:var(--accent)!important;background:rgba(0,245,212,.1);color:var(--accent)}
.setup-steps{display:flex;flex-direction:column;gap:20px}
.setup-step{display:flex;gap:16px;align-items:flex-start}
.setup-num{font-family:'Bebas Neue',sans-serif;font-size:32px;color:rgba(0,245,212,.2);line-height:1;flex-shrink:0;width:40px;padding-top:2px}
.setup-title{font-size:15px;font-weight:700;margin-bottom:10px}
.setup-code{background:var(--bg);border:1px solid var(--border);border-radius:var(--r);padding:14px 16px;font-family:'DM Mono',monospace;font-size:11px;line-height:1.7;color:var(--accent);overflow-x:auto;white-space:pre-wrap;word-break:break-all}

/* ═══════════════════════════════════════════
   TOAST
═══════════════════════════════════════════ */
.toast-wrap{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:99999;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none}
.toast{background:var(--bg3);border:1px solid var(--border2);border-radius:10px;padding:12px 20px;font-size:13px;font-weight:600;animation:fadeUp .3s ease;white-space:nowrap;box-shadow:0 8px 30px rgba(0,0,0,.4);color:var(--text);max-width:90vw;overflow:hidden;text-overflow:ellipsis}
.toast.toast-ok{border-color:rgba(0,245,212,.3)!important;color:var(--accent)}
.toast.toast-err{border-color:rgba(255,45,120,.3)!important;color:var(--pink)}

/* ═══════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════ */
.footer{border-top:1px solid var(--border);padding:60px 0 32px;margin-top:auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}
.footer-logo{font-family:'Bebas Neue',sans-serif;font-size:26px;margin-bottom:12px}
.footer-logo .s{color:var(--accent)}.footer-logo .c{color:var(--pink)}
.footer-tag{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:16px}
.footer-col{display:flex;flex-direction:column;gap:10px}
.fc-title{font-family:'DM Mono',monospace;font-size:11px;color:var(--purple);letter-spacing:.15em;margin-bottom:4px}
.footer-link{font-size:14px;color:var(--muted);cursor:pointer;transition:color .2s;background:none;border:none;text-align:left;font-family:'Syne',sans-serif}
.footer-link:hover{color:var(--accent)}
.footer-tech{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-socials{display:flex;gap:8px}
.social-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--border)!important;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:13px;cursor:pointer;color:var(--muted);transition:all .2s}
.social-btn:hover{border-color:var(--accent)!important;color:var(--accent)}
.divider{height:1px;background:var(--border);margin:32px 0 20px}

/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */
@media(max-width:860px){
  .chat-layout,.conf-layout,.match-layout,.video-layout{grid-template-columns:1fr}
  .chat-sb,.conf-sb,.match-sb,.video-sb{display:none}
  .chat-panel{height:calc(100dvh - 130px)}
  .nav-links{display:none}.nav-cta{display:none}
  .hamburger{display:flex}
  .mobile-menu{display:flex}
  .how-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:540px){
  .how-grid{grid-template-columns:1fr}
  .hero-stats{gap:28px}
  .cta-card{padding:48px 20px}
  .video-grid{grid-template-columns:1fr}
  .vid-tile.remote{grid-column:1}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .nav-online{display:none}
  .wrap{padding:0 16px}
  .hero{padding:80px 16px 60px}
  .hero-btns{flex-direction:column;align-items:center}
  .hero-btns .btn{width:100%;justify-content:center}
  .match-popup{padding:32px 20px}
}

/* ═══════════════════════════════════════════
   COOKIE CONSENT BANNER
═══════════════════════════════════════════ */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:99998;background:rgba(11,11,20,.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(124,58,255,.25);padding:18px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;transform:translateY(100%);transition:transform .4s cubic-bezier(.16,1,.3,1)}
.cookie-banner.show{transform:translateY(0)}
.cookie-text{font-size:13px;color:var(--text2);line-height:1.6;flex:1;min-width:220px}
.cookie-text a{color:var(--accent);text-decoration:underline;cursor:pointer}
.cookie-btns{display:flex;gap:8px;flex-shrink:0;flex-wrap:wrap}

/* ═══════════════════════════════════════════
   AGE GATE
═══════════════════════════════════════════ */
.age-gate{position:fixed;inset:0;z-index:100000;background:rgba(4,4,10,.97);backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;animation:fadeUp .4s ease}
.age-gate-box{background:var(--bg2);border:1px solid var(--border2);border-radius:24px;padding:48px 40px;text-align:center;max-width:420px;width:calc(100% - 32px)}
.age-gate-icon{font-size:56px;margin-bottom:16px}
.age-gate-title{font-family:'Bebas Neue',sans-serif;font-size:48px;margin-bottom:12px;background:linear-gradient(135deg,var(--accent),var(--pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.age-gate-sub{font-size:15px;color:var(--muted);margin-bottom:32px;line-height:1.7}
.age-gate-btns{display:flex;flex-direction:column;gap:10px}

/* ═══════════════════════════════════════════
   REAL AD SLOT STYLES
═══════════════════════════════════════════ */
.adsense-slot{display:block;text-align:center;overflow:hidden}
.ad-leaderboard .adsense-slot{min-height:90px}
.ad-billboard .adsense-slot{min-height:250px}
.ad-rect .adsense-slot{min-height:250px;max-width:300px;margin:0 auto}
.ad-halfpage .adsense-slot{min-height:600px;max-width:300px;margin:0 auto}
.ad-responsive .adsense-slot{min-height:100px}

/* ═══════════════════════════════════════════
   LEGAL PAGES (PRIVACY / TERMS)
═══════════════════════════════════════════ */
.legal-page{max-width:780px;margin:0 auto;padding:60px 24px}
.legal-h1{font-family:'Bebas Neue',sans-serif;font-size:clamp(40px,7vw,72px);line-height:1;margin-bottom:8px}
.legal-h1 .ac{color:var(--accent)}.legal-h1 .pk{color:var(--pink)}
.legal-meta{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted);margin-bottom:48px}
.legal-body h2{font-size:20px;font-weight:800;margin:40px 0 14px;color:var(--text)}
.legal-body h3{font-size:16px;font-weight:700;margin:24px 0 10px;color:var(--accent)}
.legal-body p{font-size:15px;color:var(--text2);line-height:1.8;margin-bottom:16px}
.legal-body ul{padding-left:20px;margin-bottom:16px}
.legal-body li{font-size:15px;color:var(--text2);line-height:1.8;margin-bottom:6px}
.legal-body a{color:var(--accent);text-decoration:underline}
.legal-toc{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rl);padding:24px;margin-bottom:40px}
.legal-toc-title{font-family:'DM Mono',monospace;font-size:10px;color:var(--purple);letter-spacing:.15em;margin-bottom:12px}
.legal-toc a{display:block;font-size:14px;color:var(--muted);padding:5px 0;border-bottom:1px solid var(--border);text-decoration:none;transition:color .2s;cursor:pointer}
.legal-toc a:hover{color:var(--accent)}
.legal-toc a:last-child{border-bottom:none}
.legal-notice{background:rgba(0,245,212,.05);border:1px solid rgba(0,245,212,.2);border-radius:var(--r);padding:16px 20px;font-size:13px;color:var(--text2);line-height:1.7;margin-bottom:24px}

/* ═══════════════════════════════════════════
   REPORT MODAL
═══════════════════════════════════════════ */
.report-modal{position:fixed;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(10px);z-index:9500;display:none;align-items:center;justify-content:center}
.report-box{background:var(--bg2);border:1px solid var(--border2);border-radius:20px;padding:32px;max-width:400px;width:calc(100% - 32px)}
.report-title{font-size:20px;font-weight:800;margin-bottom:8px}
.report-sub{font-size:13px;color:var(--muted);margin-bottom:20px}
.report-opts{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.report-opt{background:var(--bg3);border:1px solid var(--border)!important;border-radius:var(--r);padding:12px 16px;font-size:14px;color:var(--text2);cursor:pointer;text-align:left;transition:all .2s;font-family:'Syne',sans-serif}
.report-opt:hover,.report-opt.sel{border-color:var(--pink)!important;color:var(--pink);background:rgba(255,45,120,.06)}


/* ═══ ALIGNMENT & LAYOUT FIXES ═══ */
/* Chat input row — keep send button from shrinking */
.chat-input-row .btn{flex-shrink:0}
.chat-input-row .input{flex:1;min-width:0}
/* Ad wrap consistent spacing */
.ad-wrap{width:100%;overflow:hidden;margin-bottom:8px}
.ad-wrap .ad-label{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);letter-spacing:.1em;text-align:center;margin-bottom:4px;display:block}
/* Fix leaderboard ad height */
.ad-leaderboard{min-height:70px}
.ad-billboard{min-height:90px}
/* Fix confession card action buttons overflow on mobile */
@media(max-width:480px){
  .conf-actions{gap:4px}
  .conf-act{padding:5px 8px;font-size:12px}
}
/* Swipe card full width on mobile */
@media(max-width:860px){
  .swipe-card{max-width:100%}
  .card-stack{width:100%}
}
/* Video grid fix on small screens */
@media(max-width:480px){
  .video-grid{grid-template-columns:1fr}
  .vid-tile.remote{grid-column:1;aspect-ratio:16/9}
}
/* Fix hero stats overflow */
@media(max-width:400px){
  .hero-stats{gap:20px}
  .hstat-num{font-size:32px}
}
/* Fix confessions sidebar sticky on mobile (hidden, but prevent issues when visible) */
.conf-sb,.chat-sb,.match-sb,.video-sb{min-width:0}
/* Cookie banner responsive */
@media(max-width:540px){
  .cookie-banner{padding:14px 16px}
  .cookie-btns{width:100%;justify-content:flex-end}
}
/* Age gate responsive */
@media(max-width:480px){
  .age-gate-box{padding:32px 20px}
  .age-gate-title{font-size:36px}
}
/* Legal page responsive */
@media(max-width:540px){
  .legal-page{padding:40px 16px}
  .legal-h1{font-size:clamp(32px,10vw,60px)}
}
/* How grid 2-col on tablet */
@media(max-width:860px){
  .how-grid{grid-template-columns:1fr 1fr}
}
/* Fix nav online count truncation */
.nav-online{max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* Fix footer grid on tablet */
@media(max-width:860px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}
/* Ensure adsbygoogle doesn't collapse */
ins.adsbygoogle{display:block!important;min-height:50px}
/* Report modal backdrop click area */
.report-modal{cursor:default}
/* Match overlay ensure above everything except age gate */
.match-overlay{z-index:8000}
.ad-interstitial{z-index:9000}