@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg0:#080a14;--bg1:#0d1020;--bg2:#121628;--bg3:#181d35;--bg4:#1e2440;--bg5:#252c4a;
  --hover:rgba(255,255,255,0.05);
  --accent:#f0a020;--accent-dim:rgba(240,160,32,0.15);--accent-hover:#e8920a;
  --purple:#9d8df1;--purple-dim:rgba(157,141,241,0.15);
  --text1:#edf0ff;--text2:#9ba3c4;--text3:#555e82;
  --border:rgba(255,255,255,0.06);--border2:rgba(255,255,255,0.1);
  --success:#4ade80;--error:#f87171;--warning:#fbbf24;
  --sidebar-w:244px;--right-w:220px;--header-h:52px;
  --font:'Outfit',sans-serif;
  --r0:#6b7280;--r1:#4ade80;--r2:#22c55e;--r3:#60a5fa;--r4:#3b82f6;--r5:#c084fc;--r6:#f0a020;
}
html,body{height:100%}
body{font-family:var(--font);background:var(--bg0);color:var(--text1);font-size:15px;line-height:1.5;overflow:hidden}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg5);border-radius:4px}
.hidden{display:none!important}
.flex{display:flex}.col{flex-direction:column}
.gap4{gap:4px}.gap8{gap:8px}.gap12{gap:12px}.gap16{gap:16px}
.ai-center{align-items:center}.jc-between{justify-content:space-between}
.w100{width:100%}.mt8{margin-top:8px}.mt16{margin-top:16px}
.text2{color:var(--text2)}.text3{color:var(--text3);font-size:12px}
.accent{color:var(--accent)}.bold{font-weight:600}

/* Auth */
.auth-bg{min-height:100vh;overflow-y:auto;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse 70% 60% at 50% 0%,rgba(240,160,32,0.08) 0%,transparent 70%),
  radial-gradient(ellipse 50% 50% at 80% 80%,rgba(157,141,241,0.06) 0%,transparent 60%),var(--bg0);padding:24px}
.auth-box{width:100%;max-width:420px;background:var(--bg2);border:1px solid var(--border2);border-radius:20px;padding:40px;box-shadow:0 24px 80px rgba(0,0,0,.5)}
.auth-logo{text-align:center;margin-bottom:32px}
.auth-logo .logo-icon{width:64px;height:64px;border-radius:20px;background:linear-gradient(135deg,var(--accent),#e8920a);display:inline-flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:16px;box-shadow:0 8px 32px rgba(240,160,32,.3)}
.auth-logo h1{font-size:24px;font-weight:700}
.auth-logo p{color:var(--text2);font-size:13px;margin-top:4px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 14px;background:var(--bg3);border:1px solid var(--border2);border-radius:10px;color:var(--text1);font-family:var(--font);font-size:15px;transition:border-color .2s,box-shadow .2s;outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}
.form-group select option{background:var(--bg3)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:10px;font-family:var(--font);font-size:15px;font-weight:600;cursor:pointer;border:none;transition:all .2s;text-decoration:none}
.btn-primary{background:var(--accent);color:#000}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 16px rgba(240,160,32,.3)}
.btn-ghost{background:transparent;color:var(--text2);border:1px solid var(--border2)}
.btn-ghost:hover{background:var(--hover);color:var(--text1)}
.btn-danger{background:rgba(248,113,113,.15);color:var(--error);border:1px solid rgba(248,113,113,.2)}
.btn-danger:hover{background:rgba(248,113,113,.25)}
.btn-sm{padding:6px 12px;font-size:13px;border-radius:8px}
.btn-full{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.alert{padding:12px 14px;border-radius:10px;font-size:14px;display:flex;align-items:center;gap:8px;margin-top:12px}
.alert-error{background:rgba(248,113,113,.1);color:var(--error);border:1px solid rgba(248,113,113,.2)}
.alert-success{background:rgba(74,222,128,.1);color:var(--success);border:1px solid rgba(74,222,128,.2)}
.alert-info{background:rgba(157,141,241,.1);color:var(--purple);border:1px solid rgba(157,141,241,.2)}
.alert-warning{background:rgba(251,191,36,.1);color:var(--warning);border:1px solid rgba(251,191,36,.2)}

/* Site gate */
#site-gate{position:fixed;inset:0;z-index:9999;background:radial-gradient(ellipse 70% 60% at 50% 20%,rgba(240,160,32,.1) 0%,transparent 70%),var(--bg0);display:flex;align-items:center;justify-content:center}
#site-gate .gate-box{width:100%;max-width:380px;background:var(--bg2);border:1px solid var(--border2);border-radius:20px;padding:48px 40px;text-align:center;box-shadow:0 24px 80px rgba(0,0,0,.6)}
#site-gate .lock-icon{font-size:48px;margin-bottom:20px}
#site-gate h2{font-size:22px;font-weight:700}
#site-gate p{color:var(--text2);font-size:14px;margin:8px 0 24px}

/* Main layout */
#app{display:flex;height:100vh;overflow:hidden}
#sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--bg1);display:flex;flex-direction:column;border-right:1px solid var(--border)}
.sidebar-header{height:var(--header-h);padding:0 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);font-weight:700;font-size:15px;cursor:pointer;transition:background .15s}
.sidebar-header:hover{background:var(--hover)}
.channel-list{flex:1;overflow-y:auto;padding:8px 0}
.category-block{margin-bottom:4px}
.category-header{padding:4px 8px 4px 14px;display:flex;align-items:center;gap:6px;color:var(--text3);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;transition:color .15s}
.category-header:hover{color:var(--text2)}
.category-arrow{font-size:9px;transition:transform .2s}
.category-arrow.open{transform:rotate(90deg)}
.channel-item{margin:1px 8px;padding:6px 10px;display:flex;align-items:center;gap:8px;border-radius:6px;cursor:pointer;color:var(--text2);font-size:14px;transition:background .15s,color .15s}
.channel-item:hover{background:var(--hover);color:var(--text1)}
.channel-item.active{background:var(--accent-dim);color:var(--accent);font-weight:600}
.channel-icon{font-size:15px;flex-shrink:0}
.ch-type-badge{margin-left:auto;font-size:9px;padding:1px 5px;border-radius:4px;background:var(--bg4);color:var(--text3);text-transform:uppercase;letter-spacing:.05em}
.sidebar-dm{border-top:1px solid var(--border);padding:8px}
.dm-item{padding:6px 8px;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:10px;transition:background .15s}
.dm-item:hover{background:var(--hover)}
.user-panel{height:56px;background:var(--bg0);border-top:1px solid var(--border);display:flex;align-items:center;gap:10px;padding:0 8px;flex-shrink:0}
.user-panel .avatar{flex-shrink:0}
.user-panel .uname{font-size:14px;font-weight:600;line-height:1.2}
.user-panel .urole{font-size:11px;color:var(--text3)}
.user-panel-actions{margin-left:auto;display:flex;gap:4px}
.icon-btn{width:30px;height:30px;border-radius:6px;background:transparent;border:none;cursor:pointer;color:var(--text2);display:flex;align-items:center;justify-content:center;font-size:16px;transition:background .15s,color .15s}
.icon-btn:hover{background:var(--hover);color:var(--text1)}

/* Main content */
#main-content{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg0)}
.channel-header{height:var(--header-h);padding:0 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);flex-shrink:0}
.channel-header .ch-name{font-size:16px;font-weight:700}
.channel-header .ch-desc{font-size:13px;color:var(--text3);border-left:1px solid var(--border2);padding-left:12px;margin-left:4px}
.channel-header-actions{margin-left:auto;display:flex;gap:6px}

/* Messages */
#messages-area{flex:1;overflow-y:auto;padding:16px 20px 8px;display:flex;flex-direction:column;gap:2px}
.msg-group{display:flex;gap:14px;padding:6px 0}
.msg-group:hover{background:var(--hover);border-radius:8px;margin:0 -8px;padding:6px 8px}
.msg-group:hover .msg-actions{opacity:1}
.avatar{width:38px;height:38px;border-radius:50%;flex-shrink:0;background:var(--bg4);display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;overflow:hidden;position:relative}
.avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.avatar.sm{width:28px;height:28px;font-size:12px}
.avatar.lg{width:52px;height:52px;font-size:20px}
.online-dot{position:absolute;bottom:0;right:0;width:11px;height:11px;border-radius:50%;border:2px solid var(--bg1)}
.online-dot.online{background:var(--success)}
.online-dot.offline{background:var(--text3)}
.msg-body{flex:1;min-width:0}
.msg-header{display:flex;align-items:baseline;gap:8px;margin-bottom:2px}
.msg-author{font-weight:600;font-size:15px}
.msg-time{font-size:11px;color:var(--text3)}
.msg-content{font-size:15px;line-height:1.55;word-break:break-word;color:var(--text1)}
.msg-actions{margin-left:auto;display:flex;gap:2px;opacity:0;transition:opacity .15s;flex-shrink:0}
.msg-actions button{padding:3px 7px;border-radius:5px;background:var(--bg4);border:none;color:var(--text2);cursor:pointer;font-size:13px;transition:all .15s}
.msg-actions button:hover{background:var(--bg5);color:var(--text1)}
.msg-actions button.del:hover{color:var(--error)}
.date-separator{display:flex;align-items:center;gap:12px;padding:16px 0 8px;color:var(--text3);font-size:12px;font-weight:600}
.date-separator::before,.date-separator::after{content:'';flex:1;height:1px;background:var(--border)}
.typing-indicator{padding:4px 0;color:var(--text3);font-size:13px;font-style:italic;height:24px}

/* Input */
.input-area{padding:12px 20px 16px;flex-shrink:0}
.input-box{background:var(--bg3);border:1px solid var(--border2);border-radius:12px;display:flex;align-items:center;gap:8px;padding:0 12px;transition:border-color .2s}
.input-box:focus-within{border-color:rgba(240,160,32,.4)}
#msg-input{flex:1;background:transparent;border:none;outline:none;color:var(--text1);font-family:var(--font);font-size:15px;padding:14px 0}
#msg-input::placeholder{color:var(--text3)}
.input-btn{background:transparent;border:none;cursor:pointer;color:var(--text2);font-size:20px;padding:4px;border-radius:6px;transition:color .15s}
.input-btn:hover{color:var(--accent)}

/* Right sidebar */
#members-sidebar{width:var(--right-w);flex-shrink:0;background:var(--bg1);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.members-header{height:var(--header-h);padding:0 16px;display:flex;align-items:center;border-bottom:1px solid var(--border);font-size:13px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.06em}
#members-list{flex:1;overflow-y:auto;padding:8px 0}
.member-section-title{padding:8px 16px 4px;font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em}
.member-item{margin:1px 8px;padding:5px 8px;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .15s}
.member-item:hover{background:var(--hover)}
.member-name{font-size:14px;color:var(--text2);line-height:1.2}
.member-item:hover .member-name{color:var(--text1)}

/* Role badges */
.role-badge{font-size:10px;font-weight:700;padding:1px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.05em}
.role-0{color:var(--r0);background:rgba(107,114,128,.15)}
.role-1{color:var(--r1);background:rgba(74,222,128,.12)}
.role-2{color:var(--r2);background:rgba(34,197,94,.12)}
.role-3{color:var(--r3);background:rgba(96,165,250,.12)}
.role-4{color:var(--r4);background:rgba(59,130,246,.12)}
.role-5{color:var(--r5);background:rgba(192,132,252,.12)}
.role-6{color:var(--r6);background:rgba(240,160,32,.15)}

/* Modal */
.modal-overlay{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px}
.modal{width:100%;max-width:480px;background:var(--bg2);border:1px solid var(--border2);border-radius:16px;box-shadow:0 24px 60px rgba(0,0,0,.5);overflow:hidden}
.modal-header{padding:20px 24px 0;display:flex;align-items:center;justify-content:space-between}
.modal-header h3{font-size:18px;font-weight:700}
.modal-close{width:28px;height:28px;border-radius:6px;background:var(--hover);border:none;cursor:pointer;color:var(--text2);font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.modal-close:hover{background:var(--bg5);color:var(--text1)}
.modal-body{padding:20px 24px 24px}
.dm-messages{height:320px;overflow-y:auto;background:var(--bg1);border-radius:10px;padding:12px;margin-bottom:12px;display:flex;flex-direction:column;gap:8px}
.dm-msg{max-width:80%;padding:8px 12px;border-radius:12px;font-size:14px}
.dm-msg.mine{background:var(--accent-dim);border:1px solid rgba(240,160,32,.2);align-self:flex-end;color:var(--text1)}
.dm-msg.theirs{background:var(--bg3);align-self:flex-start;color:var(--text1)}
.dm-msg .dm-time{font-size:10px;color:var(--text3);margin-top:2px}
.profile-modal-header{height:80px;background:linear-gradient(135deg,var(--bg3),var(--bg4));position:relative}
.profile-modal-avatar{position:absolute;bottom:-24px;left:20px}

/* Settings */
.settings-layout{display:flex;height:100vh}
.settings-sidebar{width:220px;flex-shrink:0;background:var(--bg1);border-right:1px solid var(--border);padding:20px 0;overflow-y:auto}
.settings-sidebar-title{padding:0 16px 8px;font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em}
.settings-nav-item{margin:1px 8px;padding:8px 12px;border-radius:6px;cursor:pointer;color:var(--text2);font-size:14px;font-weight:500;transition:background .15s,color .15s}
.settings-nav-item:hover{background:var(--hover);color:var(--text1)}
.settings-nav-item.active{background:var(--accent-dim);color:var(--accent)}
.settings-sep{height:1px;background:var(--border);margin:8px 12px}
.settings-content{flex:1;overflow-y:auto;padding:40px;max-width:680px}
.settings-section{display:none}
.settings-section.active{display:block}
.settings-title{font-size:22px;font-weight:800;margin-bottom:4px}
.settings-sub{color:var(--text2);font-size:14px;margin-bottom:28px}
.settings-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:16px}
.settings-row{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}
.settings-row:last-child{border-bottom:none}
.settings-row-label{font-size:14px;font-weight:600}
.settings-row-desc{font-size:12px;color:var(--text3);margin-top:2px}
.toggle{position:relative;width:42px;height:24px;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;inset:0;background:var(--bg5);border-radius:24px;cursor:pointer;transition:background .2s}
.toggle-slider::before{content:'';position:absolute;left:3px;top:3px;width:18px;height:18px;border-radius:50%;background:white;transition:transform .2s}
.toggle input:checked+.toggle-slider{background:var(--accent)}
.toggle input:checked+.toggle-slider::before{transform:translateX(18px)}

/* Admin */
.admin-tabs{display:flex;gap:2px;padding:16px 20px 0;border-bottom:1px solid var(--border);flex-shrink:0}
.admin-tab{padding:8px 16px;border-radius:8px 8px 0 0;cursor:pointer;font-size:14px;font-weight:600;color:var(--text2);border:1px solid transparent;border-bottom:none;transition:all .15s}
.admin-tab:hover{color:var(--text1)}
.admin-tab.active{color:var(--accent);border-color:var(--border);background:var(--bg2)}
.admin-content{flex:1;overflow-y:auto;padding:24px}
.admin-panel{display:none}
.admin-panel.active{display:block}
.data-table{width:100%;border-collapse:collapse}
.data-table th{text-align:left;padding:10px 14px;font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border)}
.data-table td{padding:12px 14px;border-bottom:1px solid var(--border);font-size:14px;vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:var(--hover)}

/* Register */
.verif-options{display:flex;gap:12px;margin-top:4px}
.verif-option{flex:1;padding:16px;border-radius:12px;cursor:pointer;border:2px solid var(--border2);background:var(--bg3);text-align:center;transition:all .2s}
.verif-option:hover{border-color:rgba(240,160,32,.4);background:var(--accent-dim)}
.verif-option.selected{border-color:var(--accent);background:var(--accent-dim)}
.verif-option .icon{font-size:28px;margin-bottom:8px}
.verif-option .label{font-size:13px;font-weight:600}
.verif-option .sublabel{font-size:11px;color:var(--text3);margin-top:2px}
.upload-zone{border:2px dashed var(--border2);border-radius:12px;padding:32px;text-align:center;cursor:pointer;transition:all .2s}
.upload-zone:hover,.upload-zone.drag{border-color:var(--accent);background:var(--accent-dim)}
.upload-zone .icon{font-size:36px;margin-bottom:8px}

/* Welcome */
#welcome-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text3)}
#welcome-screen .big-icon{font-size:64px;margin-bottom:8px}
#welcome-screen h2{font-size:24px;font-weight:700;color:var(--text2)}
#welcome-screen p{font-size:15px;max-width:360px;text-align:center}

/* Toast */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{padding:12px 16px;border-radius:10px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px;max-width:320px;animation:toastIn .3s ease;box-shadow:0 8px 24px rgba(0,0,0,.3)}
.toast.success{background:rgba(74,222,128,.15);color:var(--success);border:1px solid rgba(74,222,128,.2)}
.toast.error{background:rgba(248,113,113,.15);color:var(--error);border:1px solid rgba(248,113,113,.2)}
.toast.info{background:rgba(157,141,241,.15);color:var(--purple);border:1px solid rgba(157,141,241,.2)}
@keyframes toastIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* Notif badge */
.notif-badge{min-width:18px;height:18px;padding:0 5px;background:var(--error);border-radius:9px;font-size:11px;font-weight:700;color:white;display:inline-flex;align-items:center;justify-content:center}

/* Misc */
.divider{height:1px;background:var(--border);margin:16px 0}
.text-center{text-align:center}
.mt4{margin-top:4px}
.pointer{cursor:pointer}

@media(max-width:768px){#members-sidebar{display:none}}
