/* Lasos Web App — shares the landing page's design language:
   dark #09090c, Sora display / Nunito Sans body, purple→cyan gradient. */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#09090c;--surface:#13131a;--surface-2:#1a1a24;--border:#20202c;
  --text:#e4e4ed;--muted:#64647a;--purple:#9b7dff;--cyan:#2cd9ff;
  --red:#ff5d73;--green:#3ddc97;--amber:#ffc555;
  --grad:linear-gradient(135deg,#9b7dff 0%,#2cd9ff 100%);
  --nav-h:60px;--topbar-h:56px;--sidebar-w:210px;
  --font-display:'Sora',sans-serif;--font-body:'Nunito Sans',sans-serif;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:15px;line-height:1.6;overflow-x:hidden}
button{font-family:inherit;color:inherit}
a{color:inherit}
img{display:block}
.hidden{display:none !important}

/* ───────── Shell ───────── */
.topbar{position:fixed;top:0;left:0;right:0;z-index:60;height:var(--topbar-h);display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:rgba(9,9,12,0.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.topbar-logo{display:flex;align-items:center;gap:9px;text-decoration:none}
.topbar-logo img{height:30px;border-radius:8px}
.topbar-logo span{font-family:var(--font-display);font-weight:700;font-size:17px;letter-spacing:-0.02em}
.topbar-actions{display:flex;gap:6px}
.icon-btn{background:none;border:none;cursor:pointer;width:38px;height:38px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;color:var(--muted);transition:color .2s,background .2s;font-size:15px}
.icon-btn:hover{color:var(--text);background:var(--surface)}
.icon-btn svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.mainnav{position:fixed;z-index:60;display:flex}
.nav-item{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--muted);font-weight:700;font-size:13px;border-radius:11px;transition:color .2s,background .2s;position:relative}
.nav-item svg{width:21px;height:21px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;flex:none}
.nav-item.active{color:var(--purple)}
.nav-item:hover{color:var(--text)}
.nav-item.active:hover{color:var(--purple)}
.nav-badge{position:absolute;background:var(--red);color:#fff;font-style:normal;font-size:10px;font-weight:800;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}

/* mobile: bottom tab bar */
@media(max-width:879px){
  .mainnav{bottom:0;left:0;right:0;height:calc(var(--nav-h) + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background:rgba(9,9,12,0.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);justify-content:space-around}
  .nav-item{flex-direction:column;gap:3px;font-size:9.5px;justify-content:center;flex:1}
  .nav-badge{top:6px;right:calc(50% - 18px)}
  .view{padding:calc(var(--topbar-h) + 14px) 14px calc(var(--nav-h) + 28px)}
}
/* desktop: left sidebar */
@media(min-width:880px){
  .mainnav{top:var(--topbar-h);left:0;bottom:0;width:var(--sidebar-w);flex-direction:column;gap:4px;padding:18px 12px;border-right:1px solid var(--border)}
  .nav-item{padding:11px 14px}
  .nav-item.active{background:rgba(155,125,255,0.1)}
  .nav-badge{top:8px;right:10px}
  .view{padding:calc(var(--topbar-h) + 24px) 24px 60px;margin-left:var(--sidebar-w)}
}
.view{max-width:960px;margin-left:auto;margin-right:auto}
@media(min-width:880px){.view{margin-left:max(var(--sidebar-w),calc((100% - 960px)/2))}}

/* ───────── Typography helpers ───────── */
.grad-text{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.h-display{font-family:var(--font-display);font-weight:800;letter-spacing:-0.03em}
.section-label{font-size:10.5px;font-weight:800;letter-spacing:0.15em;text-transform:uppercase;color:var(--purple);margin:26px 0 12px;font-family:var(--font-display)}
.muted{color:var(--muted)}
.small{font-size:12.5px}

/* ───────── Buttons / inputs ───────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;font-weight:700;font-size:13.5px;padding:11px 20px;border-radius:10px;text-decoration:none;transition:opacity .2s,transform .15s,border-color .2s;background:var(--grad);color:#09090c}
.btn:hover{opacity:0.88;transform:translateY(-1px)}
.btn:disabled{opacity:0.4;cursor:not-allowed;transform:none}
.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}
.btn-outline:hover{border-color:var(--purple)}
.btn-danger{background:transparent;border:1px solid rgba(255,93,115,0.4);color:var(--red)}
.btn-sm{padding:7px 14px;font-size:12.5px;border-radius:8px}
.btn-pill{border-radius:100px}
.input,textarea.input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text);font-family:var(--font-body);font-size:14px;padding:11px 14px;outline:none;transition:border-color .2s}
.input:focus{border-color:var(--purple)}
textarea.input{resize:vertical;min-height:72px}
.field{margin-bottom:16px}
.field label{display:block;font-size:11.5px;font-weight:800;letter-spacing:0.07em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.field .hint{font-size:12px;color:var(--muted);margin-top:5px}

/* toggle switch */
.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 0;border-bottom:1px solid var(--border)}
.toggle-row:last-child{border-bottom:none}
.toggle-row .t-label{font-weight:700;font-size:14px}
.toggle-row .t-desc{font-size:12px;color:var(--muted)}
.switch{position:relative;width:44px;height:25px;flex:none;cursor:pointer}
.switch input{opacity:0;width:0;height:0}
.switch .knob{position:absolute;inset:0;background:var(--surface-2);border:1px solid var(--border);border-radius:100px;transition:background .2s}
.switch .knob::before{content:"";position:absolute;width:18px;height:18px;left:3px;top:2.5px;border-radius:50%;background:var(--muted);transition:transform .2s,background .2s}
.switch input:checked + .knob{background:rgba(155,125,255,0.35);border-color:var(--purple)}
.switch input:checked + .knob::before{transform:translateX(18px);background:var(--purple)}

/* ───────── Cards / lists ───────── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:18px}
.list-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--border)}
.list-row:last-child{border-bottom:none}
.list-row .grow{flex:1;min-width:0}
.list-row .title{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.list-row .sub{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;background:var(--surface-2);flex:none}
.avatar-sm{width:34px;height:34px}
.avatar-lg{width:84px;height:84px}
.avatar-fallback{display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;color:var(--purple);background:rgba(155,125,255,0.12)}
.art{width:44px;height:44px;border-radius:9px;object-fit:cover;background:var(--surface-2);flex:none}
.score-pill{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-display);font-weight:800;font-size:12px;color:#09090c;background:var(--grad);border-radius:100px;padding:3px 10px;flex:none}
.tag{display:inline-block;background:rgba(44,217,255,0.08);border:1px solid rgba(44,217,255,0.25);color:var(--cyan);border-radius:100px;font-size:11px;font-weight:700;padding:2.5px 10px;margin:2px 3px 2px 0}
.empty{color:var(--muted);text-align:center;padding:42px 20px;font-size:14px}
.spinner{width:26px;height:26px;border:3px solid var(--border);border-top-color:var(--purple);border-radius:50%;animation:spin 0.8s linear infinite;margin:36px auto}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-block{padding:30px 0}

/* ───────── Login ───────── */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:24px;position:relative;overflow:hidden}
.login-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-55%);width:760px;height:760px;background:radial-gradient(ellipse,rgba(155,125,255,0.14) 0%,rgba(44,217,255,0.05) 50%,transparent 70%);pointer-events:none}
.login-inner{position:relative;max-width:420px;animation:fadeUp .6s ease both}
.login-inner img.logo{width:84px;height:84px;border-radius:22px;margin:0 auto 22px;box-shadow:0 22px 60px -18px rgba(155,125,255,0.55)}
.login-inner h1{font-family:var(--font-display);font-size:32px;font-weight:800;letter-spacing:-0.03em;line-height:1.1;margin-bottom:12px}
.login-inner p{color:var(--muted);margin-bottom:30px}
.btn-google{width:100%;background:#fff;color:#1a1a1a;font-size:14.5px;padding:13px 20px}
.login-foot{margin-top:26px;font-size:12px;color:var(--muted)}
.login-foot a{color:var(--muted)}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

/* ───────── Discover people grid ───────── */
.people-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:14px}
.person-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:16px;cursor:pointer;transition:border-color .2s,transform .15s,box-shadow .2s;animation:fadeUp .35s ease both;display:flex;flex-direction:column}
.person-card:hover{border-color:var(--purple);transform:translateY(-2px);box-shadow:0 18px 44px -22px rgba(155,125,255,0.35)}
.pc-head{display:flex;align-items:center;gap:11px}
.pc-head .who{flex:1;min-width:0}
.pc-head .who strong{font-family:var(--font-display);font-size:15.5px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pc-head .who span{font-size:12px;color:var(--muted)}
.pc-bio{font-size:12.5px;color:var(--muted);margin-top:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pc-actions{display:flex;gap:8px;margin-top:auto;padding-top:14px}
.pa-btn{flex:1;background:var(--surface-2);border:1px solid var(--border);border-radius:100px;cursor:pointer;font-weight:800;font-size:12px;padding:8px 10px;transition:border-color .2s,background .2s;white-space:nowrap}
.pa-btn.like.on,.pa-btn.like:hover{border-color:var(--red);background:rgba(255,93,115,0.12)}
.pa-btn.follow.on,.pa-btn.follow:hover{border-color:var(--cyan);background:rgba(44,217,255,0.1)}
.rank-chip{flex:none;font-family:var(--font-display);font-weight:800;font-size:11px;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:3px 7px}
.pc-counts{font-size:12px;color:var(--cyan);font-weight:700;margin-top:9px}
.pc-shared-label{font-size:10px;font-weight:800;letter-spacing:0.13em;text-transform:uppercase;color:var(--muted);margin:10px 0 6px;font-family:var(--font-display)}

/* ───────── Discover deck ───────── */
.deck-wrap{max-width:560px;margin:0 auto}
.deck-card{background:var(--surface);border:1px solid var(--border);border-radius:22px;overflow:hidden;animation:fadeUp .4s ease both;box-shadow:0 28px 64px -28px rgba(155,125,255,0.25)}
.deck-head{display:flex;align-items:center;gap:14px;padding:18px 18px 4px;cursor:pointer}
.deck-head .who{flex:1;min-width:0}
.deck-head .who strong{font-family:var(--font-display);font-size:18px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.deck-head .who span{font-size:12.5px;color:var(--muted)}
.deck-bio{padding:8px 18px 0;font-size:13.5px;color:var(--muted)}
.deck-section{padding:12px 18px 0}
.deck-section h4{font-size:10.5px;font-weight:800;letter-spacing:0.13em;text-transform:uppercase;color:var(--cyan);margin-bottom:8px;font-family:var(--font-display)}
.artist-strip{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
.artist-strip::-webkit-scrollbar{display:none}
.artist-strip img{width:54px;height:54px;border-radius:12px;object-fit:cover;border:1px solid var(--border)}
.deck-quote{margin:12px 18px 0;background:var(--surface-2);border-left:3px solid var(--purple);border-radius:8px;padding:9px 12px;font-size:12.5px;color:var(--muted);font-style:italic}
.deck-now{display:flex;align-items:center;gap:8px;margin:12px 18px 0;font-size:12.5px;color:var(--cyan)}
.deck-now .eq{display:inline-flex;gap:2px;align-items:flex-end;height:12px}
.deck-now .eq i{width:3px;background:var(--cyan);animation:eq 0.9s ease-in-out infinite}
.deck-now .eq i:nth-child(2){animation-delay:.2s}.deck-now .eq i:nth-child(3){animation-delay:.4s}
@keyframes eq{0%,100%{height:4px}50%{height:12px}}
.deck-actions{display:flex;gap:10px;padding:18px;justify-content:center}
.deck-actions .act{width:58px;height:58px;border-radius:50%;border:1px solid var(--border);background:var(--surface-2);cursor:pointer;font-size:22px;display:flex;align-items:center;justify-content:center;transition:transform .15s,border-color .2s,background .2s}
.deck-actions .act:hover{transform:translateY(-3px) scale(1.05)}
.deck-actions .act.skip:hover{border-color:var(--muted)}
.deck-actions .act.like.on,.deck-actions .act.like:hover{border-color:var(--red);background:rgba(255,93,115,0.12)}
.deck-actions .act.follow.on,.deck-actions .act.follow:hover{border-color:var(--cyan);background:rgba(44,217,255,0.1)}

/* ───────── Song drops carousel ───────── */
.drops-strip{display:flex;gap:12px;overflow-x:auto;padding:4px 2px 10px;scrollbar-width:none}
.drops-strip::-webkit-scrollbar{display:none}
.drop-card{flex:none;width:168px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:12px;cursor:pointer;transition:border-color .2s,transform .15s;position:relative}
.drop-card:hover{border-color:var(--purple);transform:translateY(-2px)}
.drop-card .art-lg{width:100%;aspect-ratio:1;border-radius:11px;object-fit:cover;background:var(--surface-2);margin-bottom:9px}
.drop-card .d-track{font-weight:800;font-size:13px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.drop-card .d-artist{font-size:11.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:7px}
.drop-card .d-user{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted)}
.drop-card .d-user img{width:20px;height:20px;border-radius:50%;object-fit:cover}
.drop-card .d-self-cta{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;aspect-ratio:1;border:1.5px dashed rgba(155,125,255,0.5);border-radius:11px;margin-bottom:9px;color:var(--purple);font-weight:800;font-size:12.5px;text-align:center;padding:8px}
.drop-card .d-self-cta .plus{width:34px;height:34px;border-radius:50%;background:rgba(155,125,255,0.15);display:flex;align-items:center;justify-content:center;font-size:20px}
.drop-card .d-caption{font-size:11.5px;color:var(--text);background:var(--surface-2);border-radius:8px;padding:5px 8px;margin-bottom:7px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.drop-react-bar{display:flex;gap:5px;margin-top:8px}
.drop-react-bar button{background:var(--surface-2);border:1px solid var(--border);border-radius:100px;cursor:pointer;font-size:12px;padding:3px 8px;transition:border-color .2s,background .2s}
.drop-react-bar button.on{border-color:var(--purple);background:rgba(155,125,255,0.18)}
.drop-react-bar .cnt{font-size:10.5px;color:var(--muted);margin-left:3px}
.drop-score{position:absolute;top:18px;right:18px}

/* ───────── Concerts ───────── */
.concert-row{display:flex;gap:14px;align-items:center;padding:14px 0;border-bottom:1px solid var(--border)}
.concert-row:last-child{border-bottom:none}
.concert-date{flex:none;width:52px;text-align:center;background:var(--surface-2);border:1px solid var(--border);border-radius:11px;padding:7px 4px}
.concert-date .d{font-family:var(--font-display);font-weight:800;font-size:18px;line-height:1.1}
.concert-date .m{font-size:10px;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;color:var(--cyan)}
.chat-list{display:flex;flex-direction:column;gap:10px;padding:14px 0}
.chat-msg{max-width:78%;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:9px 13px;font-size:13.5px}
.chat-msg.mine{align-self:flex-end;background:rgba(155,125,255,0.14);border-color:rgba(155,125,255,0.35)}
.chat-msg .m-who{font-size:11px;font-weight:800;color:var(--purple);margin-bottom:2px;cursor:pointer}
.chat-msg .m-time{font-size:10px;color:var(--muted);margin-top:3px;text-align:right}
.chat-compose{display:flex;gap:8px;position:sticky;bottom:calc(var(--nav-h) + 10px)}
@media(min-width:880px){.chat-compose{bottom:10px}}

/* ───────── Profile ───────── */
.profile-head{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.profile-head .info{flex:1;min-width:200px}
.profile-head h2{font-family:var(--font-display);font-size:24px;font-weight:800;letter-spacing:-0.02em}
.profile-head .uname{color:var(--muted);font-size:13.5px}
.profile-stats{display:flex;gap:22px;margin:14px 0}
.profile-stats .stat{cursor:pointer}
.profile-stats b{font-family:var(--font-display);font-size:17px;display:block;line-height:1.2}
.profile-stats span{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:0.06em;font-weight:700}
.roast-box{background:linear-gradient(135deg,rgba(155,125,255,0.1),rgba(44,217,255,0.06));border:1px solid rgba(155,125,255,0.3);border-radius:14px;padding:14px 16px;margin-top:16px;font-size:13.5px}
.roast-box .r-label{font-size:10px;font-weight:800;letter-spacing:0.14em;text-transform:uppercase;color:var(--purple);margin-bottom:6px;font-family:var(--font-display)}
.track-row-play{position:relative;cursor:pointer}
.track-row-play::after{content:"▶";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(9,9,12,0.55);color:#fff;font-size:13px;border-radius:9px;opacity:0;transition:opacity .15s}
.track-row-play:hover::after{opacity:1}
.rank-num{flex:none;width:22px;text-align:center;font-family:var(--font-display);font-weight:800;font-size:13px;color:var(--muted)}

/* ───────── Notifications ───────── */
.notif-row{display:flex;gap:12px;padding:13px 10px;border-radius:12px;cursor:pointer;transition:background .15s;align-items:flex-start}
.notif-row:hover{background:var(--surface)}
.notif-row.unread{background:rgba(155,125,255,0.07)}
.notif-row .n-dot{flex:none;width:8px;height:8px;border-radius:50%;background:var(--purple);margin-top:8px}
.notif-row.read .n-dot{background:transparent}
.notif-row .n-body{flex:1;min-width:0}
.notif-row .n-title{font-weight:800;font-size:13.5px}
.notif-row .n-text{font-size:12.5px;color:var(--muted)}
.notif-row .n-time{font-size:11px;color:var(--muted);flex:none}

/* ───────── Modal / sheet ───────── */
.modal-backdrop{position:fixed;inset:0;z-index:90;background:rgba(0,0,0,0.65);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .18s ease both}
@media(min-width:640px){.modal-backdrop{align-items:center}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:20px 20px 0 0;width:100%;max-width:560px;max-height:86vh;overflow-y:auto;padding:22px;animation:slideUp .22s ease both}
@media(min-width:640px){.modal{border-radius:20px}}
@keyframes slideUp{from{transform:translateY(28px);opacity:0}to{transform:none;opacity:1}}
.modal h3{font-family:var(--font-display);font-size:18px;font-weight:800;margin-bottom:16px;letter-spacing:-0.01em}
.modal .modal-x{position:absolute;top:14px;right:14px}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.modal-head h3{margin-bottom:0}

/* ───────── Toast ───────── */
#toast-root{position:fixed;bottom:calc(var(--nav-h) + 18px);left:50%;transform:translateX(-50%);z-index:120;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}
@media(min-width:880px){#toast-root{bottom:24px}}
.toast{background:var(--surface-2);border:1px solid var(--border);color:var(--text);font-size:13px;font-weight:700;border-radius:100px;padding:10px 20px;box-shadow:0 10px 36px rgba(0,0,0,0.5);animation:fadeUp .25s ease both;max-width:88vw;text-align:center}
.toast.err{border-color:rgba(255,93,115,0.5);color:var(--red)}
.toast.ok{border-color:rgba(61,220,151,0.4)}

/* ───────── Audio player bar ───────── */
.player{position:fixed;z-index:80;left:12px;right:12px;bottom:calc(var(--nav-h) + 12px);max-width:430px;margin:0 auto;display:flex;align-items:center;gap:11px;background:rgba(19,19,26,0.96);border:1px solid var(--border);border-radius:14px;padding:9px 12px;box-shadow:0 18px 48px rgba(0,0,0,0.55);backdrop-filter:blur(14px)}
@media(min-width:880px){.player{bottom:18px;left:auto;right:24px;margin:0}}
.player img{width:40px;height:40px;border-radius:8px;object-fit:cover}
.player-meta{flex:1;min-width:0}
.player-meta strong{display:block;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.player-meta span{font-size:11.5px;color:var(--muted)}
#player-toggle{font-size:17px;color:var(--purple)}

/* ───────── Misc ───────── */
.page-title{font-family:var(--font-display);font-size:22px;font-weight:800;letter-spacing:-0.02em;margin-bottom:4px}
.page-sub{color:var(--muted);font-size:13px;margin-bottom:18px}
.grid-artists{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:12px}
.grid-artists .ga{text-align:center;cursor:default}
.grid-artists img{width:100%;aspect-ratio:1;border-radius:14px;object-fit:cover;border:1px solid var(--border);margin-bottom:6px}
.grid-artists .ga-name{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.searchbar{display:flex;gap:8px;margin-bottom:18px}
.seg{display:inline-flex;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:3px;margin-bottom:14px}
.seg button{background:none;border:none;border-radius:8px;padding:7px 16px;cursor:pointer;font-weight:800;font-size:12.5px;color:var(--muted)}
.seg button.on{background:rgba(155,125,255,0.16);color:var(--purple)}
.lang-toggle{display:inline-flex;gap:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:3px}
.lang-toggle button{background:none;border:none;color:var(--muted);font-size:12px;font-weight:800;padding:4px 11px;border-radius:6px;cursor:pointer}
.lang-toggle button.active{background:rgba(155,125,255,0.16);color:var(--purple)}
.banner-info{background:rgba(44,217,255,0.07);border:1px solid rgba(44,217,255,0.25);border-radius:12px;padding:12px 14px;font-size:13px;margin-bottom:16px}
.divider{border:none;border-top:1px solid var(--border);margin:22px 0}
