/* ═══════════════════════════════════════════════════════════
   HobbyMice Web Panel — CSS v2
   ═══════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

:root {
  --bg:          #0f1117;
  --bg-card:     #1a1d27;
  --bg-sidebar:  #141620;
  --bg-input:    #222536;
  --border:      #2a2d3e;
  --text:        #e4e6f0;
  --text-dim:    #8b8fa3;
  --primary:     #6c63ff;
  --primary-dim: #5a52d5;
  --primary-bg:  rgba(108,99,255,.12);
  --accent:      #ff9f43;
  --success:     #2ed573;
  --success-bg:  rgba(46,213,115,.12);
  --danger:      #ff4757;
  --danger-bg:   rgba(255,71,87,.12);
  --warning:     #ffa502;
  --warning-bg:  rgba(255,165,2,.12);
  --info:        #54a0ff;
  --info-bg:     rgba(84,160,255,.12);
  --radius:      10px;
  --radius-sm:   6px;
  --sidebar-w:   250px;
  --transition:  .2s ease;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}

body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg);color:var(--text);
  min-height:100vh;line-height:1.5;
  -webkit-font-smoothing:antialiased;
}

a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}

::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}

/* ─── LOGIN ─────────────────────────────────────────────── */
.login-page{
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#0f1117 0%,#1a1d35 50%,#0f1117 100%);
  min-height:100vh;
}
.login-container{width:100%;max-width:420px;padding:20px}
.login-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:16px;padding:44px 36px;
  box-shadow:0 20px 60px rgba(0,0,0,.4);
}
.login-logo{text-align:center;margin-bottom:36px}
.logo-icon{font-size:52px;margin-bottom:8px}
.login-logo h1{font-size:26px;font-weight:700;letter-spacing:-.5px}
.login-logo .subtitle{color:var(--text-dim);font-size:13px;margin-top:4px;text-transform:uppercase;letter-spacing:2px}
.login-hint{text-align:center;color:var(--text-dim);font-size:12px;margin-top:20px}

/* ─── FORMS ─────────────────────────────────────────────── */
.form-group{margin-bottom:16px}
.form-group label{
  display:block;font-size:12px;font-weight:600;
  color:var(--text-dim);margin-bottom:6px;
  text-transform:uppercase;letter-spacing:.5px;
}
.input,input[type="text"],input[type="password"],input[type="number"],input[type="email"],input[type="date"],select,textarea{
  width:100%;padding:10px 14px;
  background:var(--bg-input);border:1px solid var(--border);
  border-radius:var(--radius-sm);color:var(--text);
  font-size:14px;font-family:inherit;outline:none;
  transition:border var(--transition),box-shadow var(--transition);
}
.input:focus,input:focus,select:focus,textarea:focus{
  border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg);
}
textarea{resize:vertical;min-height:80px}
.input-color{width:48px;height:36px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-input);cursor:pointer;padding:2px}
.input-sm{padding:7px 10px;font-size:13px}
.error-msg{background:var(--danger-bg);border:1px solid var(--danger);color:var(--danger);padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:12px}
.success-msg{background:var(--success-bg);border:1px solid var(--success);color:var(--success);padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:12px}
.save-status{margin-left:12px;font-size:13px;font-weight:500}

/* ─── BUTTONS ───────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 20px;border:none;border-radius:var(--radius-sm);
  font-size:13px;font-weight:600;cursor:pointer;
  transition:all var(--transition);font-family:inherit;text-decoration:none;
}
.btn:hover{text-decoration:none}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dim);transform:translateY(-1px);box-shadow:0 4px 12px rgba(108,99,255,.3)}
.btn-secondary{background:var(--bg-input);color:var(--text);border:1px solid var(--border)}
.btn-secondary:hover{border-color:var(--primary);color:var(--primary)}
.btn-outline{background:transparent;color:var(--text-dim);border:1px solid var(--border)}
.btn-outline:hover{color:var(--text);border-color:var(--text-dim)}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:#e8414f}
.btn-success{background:var(--success);color:#fff}
.btn-success:hover{background:#27c268}
.btn-warning{background:var(--warning);color:#1a1d27}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-xs{padding:4px 8px;font-size:11px;border-radius:4px}
.btn-full{width:100%;justify-content:center}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}
.btn-group{display:flex;gap:8px;flex-wrap:wrap}

/* ─── LAYOUT ────────────────────────────────────────────── */
.sidebar{
  position:fixed;left:0;top:0;width:var(--sidebar-w);height:100vh;
  background:var(--bg-sidebar);border-right:1px solid var(--border);
  display:flex;flex-direction:column;z-index:100;
}
.sidebar-header{display:flex;align-items:center;gap:10px;padding:20px;border-bottom:1px solid var(--border)}
.logo-icon-sm{font-size:26px}
.sidebar-title{font-size:16px;font-weight:700;letter-spacing:-.3px}
.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}
.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;color:var(--text-dim);text-decoration:none;
  border-radius:var(--radius-sm);font-size:13px;font-weight:500;
  transition:all var(--transition);margin-bottom:2px;
}
.nav-item:hover{color:var(--text);background:var(--bg-input);text-decoration:none}
.nav-item.active{color:#fff;background:var(--primary);box-shadow:0 2px 8px rgba(108,99,255,.25)}
.nav-icon{font-size:16px;width:22px;text-align:center;flex-shrink:0}
.nav-section{padding:18px 14px 6px}
.nav-section-label{font-size:10px;font-weight:700;color:var(--text-dim);letter-spacing:1.5px;text-transform:uppercase}
.sidebar-footer{padding:16px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.user-info{display:flex;flex-direction:column;gap:4px}
.user-name{font-size:13px;font-weight:600}
.user-role{font-size:11px}
.main-content{margin-left:var(--sidebar-w);padding:28px 32px;min-height:100vh}

/* ─── PAGES ─────────────────────────────────────────────── */
.page-header{margin-bottom:24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.page-header h2{font-size:22px;font-weight:700;letter-spacing:-.3px}
.page-header p{color:var(--text-dim);font-size:14px}
.search-bar{display:flex;gap:8px;align-items:center}
.search-bar .input{width:280px}

/* ─── CARDS ─────────────────────────────────────────────── */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:20px}
.card h3{font-size:15px;margin-bottom:16px;font-weight:600}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}

/* ─── STATS GRID ────────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:24px}
.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;text-align:center;transition:transform var(--transition),box-shadow var(--transition)}
.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.2)}
.stat-card.accent{border-color:var(--primary)}
.stat-icon{font-size:28px;margin-bottom:8px}
.stat-value{font-size:24px;font-weight:700}
.stat-label{font-size:11px;color:var(--text-dim);margin-top:4px;text-transform:uppercase;letter-spacing:.5px}

/* ─── PROFILE ───────────────────────────────────────────── */
.profile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}
.info-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}
.info-row:last-child{border-bottom:none}
.info-label{color:var(--text-dim);font-size:13px}
.info-value{font-size:13px;font-weight:500}
.title-current{padding:10px 14px;background:var(--bg-input);border-radius:var(--radius-sm);margin-bottom:12px;font-size:14px}

/* ─── BADGE ─────────────────────────────────────────────── */
.badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;white-space:nowrap}
.badge-admin{background:var(--danger-bg);color:var(--danger)}
.badge-modo{background:var(--primary-bg);color:var(--primary)}
.badge-staff{background:var(--warning-bg);color:var(--accent)}
.badge-player{background:rgba(139,143,163,.1);color:var(--text-dim)}
.badge-success{background:var(--success-bg);color:var(--success)}
.badge-danger{background:var(--danger-bg);color:var(--danger)}
.badge-warning{background:var(--warning-bg);color:var(--warning)}
.badge-info{background:var(--info-bg);color:var(--info)}

/* ─── TABLE ─────────────────────────────────────────────── */
.data-table{width:100%;border-collapse:collapse;font-size:13px}
.data-table th{text-align:left;padding:10px 12px;color:var(--text-dim);font-weight:600;font-size:11px;border-bottom:2px solid var(--border);text-transform:uppercase;letter-spacing:.5px}
.data-table td{padding:10px 12px;border-bottom:1px solid var(--border)}
.data-table tr:hover td{background:rgba(108,99,255,.04)}
.data-table .actions{white-space:nowrap}

/* ─── PAGINATION ────────────────────────────────────────── */
.pagination{display:flex;gap:6px;justify-content:center;margin-top:16px;flex-wrap:wrap}
.pagination button{padding:6px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;font-size:13px;font-family:inherit;transition:all var(--transition)}
.pagination button.active{background:var(--primary);border-color:var(--primary)}
.pagination button:hover:not(.active){border-color:var(--primary)}

/* ─── EDIT GRID ─────────────────────────────────────────── */
.edit-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:20px}
.edit-grid .full-width{grid-column:1/-1}

/* ─── INVENTORY ─────────────────────────────────────────── */
.inventory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}
.inv-item{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;text-align:center;transition:all var(--transition)}
.inv-item:hover{border-color:var(--primary)}
.inv-item-id{font-size:16px;font-weight:700;color:var(--primary)}
.inv-item-qty{font-size:11px;color:var(--text-dim);margin-top:4px}
.empty-state{color:var(--text-dim);font-size:14px;text-align:center;padding:40px}
.section-title{font-size:16px;font-weight:600;margin-bottom:16px}

/* ─── TABS ──────────────────────────────────────────────── */
.tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:20px}
.tab{padding:10px 20px;font-size:13px;font-weight:500;color:var(--text-dim);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition);background:none;border-top:none;border-left:none;border-right:none;font-family:inherit}
.tab:hover{color:var(--text)}
.tab.active{color:var(--primary);border-bottom-color:var(--primary)}
.tab-content{display:none}
.tab-content.active{display:block}

/* ─── SANCTION CARDS ────────────────────────────────────── */
.sanction-card{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px;transition:all var(--transition)}
.sanction-card:hover{border-color:var(--primary-dim)}
.sanction-card.active-ban{border-left:3px solid var(--danger)}
.sanction-card.expired-ban{border-left:3px solid var(--text-dim);opacity:.7}
.sanction-card.cancelled-ban{border-left:3px solid var(--warning);opacity:.7}
.sanction-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.sanction-meta{display:flex;gap:12px;flex-wrap:wrap;font-size:12px;color:var(--text-dim)}
.sanction-meta span{display:flex;align-items:center;gap:4px}
.sanction-reason{font-size:13px;padding:8px 12px;background:var(--bg);border-radius:var(--radius-sm);margin-top:8px}

/* ─── LOG ENTRY ─────────────────────────────────────────── */
.log-entry{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px}
.log-entry:last-child{border-bottom:none}
.log-time{color:var(--text-dim);font-size:12px;white-space:nowrap;min-width:140px}
.log-author{color:var(--primary);font-weight:500;min-width:100px}
.log-action{flex:1}

/* ─── LEADERBOARD ───────────────────────────────────────── */
.lb-rank{font-weight:700;font-size:16px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--bg-input);flex-shrink:0}
.lb-rank.gold{background:#ffd700;color:#1a1d27}
.lb-rank.silver{background:#c0c0c0;color:#1a1d27}
.lb-rank.bronze{background:#cd7f32;color:#1a1d27}
.lb-row{display:flex;align-items:center;gap:16px;padding:12px 16px;border-bottom:1px solid var(--border);transition:background var(--transition)}
.lb-row:hover{background:var(--bg-input)}
.lb-name{font-weight:600;flex:1}
.lb-value{font-weight:700;font-size:16px;color:var(--accent)}

/* ─── MODAL ─────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:1000;backdrop-filter:blur(4px)}
.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:28px;width:100%;max-width:480px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.modal h3{font-size:18px;margin-bottom:20px}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}

/* ─── TOAST ─────────────────────────────────────────────── */
.toast-container{position:fixed;top:20px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:8px}
.toast{padding:12px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;box-shadow:0 4px 20px rgba(0,0,0,.3);animation:slideIn .3s ease;min-width:280px;display:flex;align-items:center;gap:8px}
.toast-success{background:var(--success);color:#fff}
.toast-error{background:var(--danger);color:#fff}
.toast-warning{background:var(--warning);color:#1a1d27}
.toast-info{background:var(--info);color:#fff}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

/* ─── MISC HELPERS ──────────────────────────────────────── */
.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}
.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}
.text-dim{color:var(--text-dim)}.text-sm{font-size:12px}.text-xs{font-size:11px}.text-center{text-align:center}
.font-bold{font-weight:700}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hidden{display:none!important}.w-full{width:100%}

/* ─── RESPONSIVE ────────────────────────────────────────── */
@media(max-width:768px){
  .sidebar{width:60px}
  .sidebar-title,.nav-item span:not(.nav-icon),.nav-section-label,.user-name,.user-role{display:none}
  .sidebar-header{justify-content:center;padding:16px 8px}
  .nav-item{justify-content:center;padding:10px}
  .sidebar-footer{flex-direction:column;gap:8px}
  .main-content{margin-left:60px;padding:20px 16px}
  .search-bar .input{width:180px}
  .stats-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
  .edit-grid{grid-template-columns:1fr}
  .profile-grid{grid-template-columns:1fr}
  .modal{margin:16px;max-width:calc(100% - 32px)}
  .chat-windows{right:8px;gap:8px}
  .chat-window{width:280px;height:340px}
}

/* ═══════════════════════════════════════════════════════════
   SOCIAL FEATURES
   ═══════════════════════════════════════════════════════════ */

/* ─── FRIENDS GRID ──────────────────────────────────────── */
.friends-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.friend-card{
  background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px;display:flex;align-items:center;gap:14px;
  transition:all var(--transition);position:relative;
}
.friend-card:hover{border-color:var(--primary);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.2)}
.friend-avatar{
  width:44px;height:44px;border-radius:50%;
  background:var(--bg-card);display:flex;align-items:center;justify-content:center;
  font-size:22px;flex-shrink:0;
}
.friend-info{flex:1;min-width:0}
.friend-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.friend-meta{font-size:11px;color:var(--text-dim)}
.friend-online{position:absolute;top:14px;left:48px;width:10px;height:10px;border-radius:50%;background:var(--success);border:2px solid var(--bg-input)}
.friend-offline{position:absolute;top:14px;left:48px;width:10px;height:10px;border-radius:50%;background:var(--text-dim);border:2px solid var(--bg-input)}
.friend-actions{display:flex;gap:6px;flex-shrink:0}

/* ─── FEED ──────────────────────────────────────────────── */
.feed-compose{margin-bottom:20px}
.feed-compose-header{display:flex;gap:12px;align-items:flex-start}
.feed-compose-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-bg);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.feed-compose .input{min-height:auto}

.feed-post{
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;margin-bottom:14px;transition:all var(--transition);
}
.feed-post:hover{border-color:rgba(108,99,255,.3)}
.feed-post-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.feed-post-avatar{width:38px;height:38px;border-radius:50%;background:var(--primary-bg);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.feed-post-author{font-weight:600;font-size:14px}
.feed-post-time{font-size:11px;color:var(--text-dim)}
.feed-post-content{font-size:14px;line-height:1.6;margin-bottom:12px;word-wrap:break-word}
.feed-post-actions{display:flex;gap:16px;padding-top:12px;border-top:1px solid var(--border)}
.feed-action-btn{
  background:none;border:none;color:var(--text-dim);font-size:13px;font-weight:500;
  cursor:pointer;display:flex;align-items:center;gap:6px;padding:6px 10px;
  border-radius:var(--radius-sm);transition:all var(--transition);font-family:inherit;
}
.feed-action-btn:hover{background:var(--bg-input);color:var(--text)}
.feed-action-btn.liked{color:var(--danger)}
.feed-action-btn .count{font-weight:600}

/* ─── MARRIAGE ──────────────────────────────────────────── */
.marriage-status-box{padding:20px;text-align:center}
.marriage-status-box .soulmate-name{
  font-size:24px;font-weight:700;color:var(--primary);letter-spacing:-.5px;margin:8px 0;
}
.marriage-status-box .soulmate-label{font-size:13px;color:var(--text-dim)}
.marriage-heart{font-size:48px;margin-bottom:12px;animation:heartbeat 1.5s ease-in-out infinite}
@keyframes heartbeat{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}

.proposal-card{
  background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;
}
.proposal-card .proposal-from{font-weight:600;font-size:14px}
.proposal-card .proposal-date{font-size:11px;color:var(--text-dim)}

/* ═══════════════════════════════════════════════════════════
   CHAT WIDGET (Facebook Messenger Style)
   ═══════════════════════════════════════════════════════════ */

.chat-widget{
  position:fixed;bottom:20px;right:20px;z-index:900;
  display:flex;flex-direction:column;align-items:flex-end;gap:8px;
}

.chat-toggle{
  width:52px;height:52px;border-radius:50%;
  background:var(--primary);color:#fff;border:none;
  font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(108,99,255,.4);
  transition:all .2s;position:relative;
}
.chat-toggle:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(108,99,255,.5)}

.chat-badge{
  position:absolute;top:-4px;right:-4px;
  min-width:20px;height:20px;border-radius:10px;
  background:var(--danger);color:#fff;font-size:11px;font-weight:700;
  display:flex;align-items:center;justify-content:center;padding:0 5px;
}

.chat-sidebar{
  position:fixed;bottom:80px;right:20px;
  width:280px;max-height:420px;
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:12px;overflow:hidden;
  box-shadow:0 8px 40px rgba(0,0,0,.5);
  display:flex;flex-direction:column;
}
.chat-sidebar-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 16px;border-bottom:1px solid var(--border);
  font-weight:600;font-size:14px;
}
.chat-sidebar-close{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:16px;padding:4px}
.chat-sidebar-list{flex:1;overflow-y:auto;padding:8px}

.chat-friend-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;
  transition:all var(--transition);position:relative;
}
.chat-friend-item:hover{background:var(--bg-input)}
.chat-friend-item .avatar{width:34px;height:34px;border-radius:50%;background:var(--bg-input);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.chat-friend-item .name{font-size:13px;font-weight:500;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-friend-item .online-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.chat-friend-item .online-dot.on{background:var(--success)}
.chat-friend-item .online-dot.off{background:var(--text-dim)}
.chat-friend-item .unread-badge{
  min-width:18px;height:18px;border-radius:9px;
  background:var(--danger);color:#fff;font-size:10px;font-weight:700;
  display:flex;align-items:center;justify-content:center;padding:0 4px;
}

.chat-bubbles{display:flex;flex-direction:column-reverse;gap:8px;margin-bottom:8px}

/* ─── CHAT WINDOW ───────────────────────────────────────── */
.chat-windows{
  position:fixed;bottom:20px;right:84px;
  display:flex;flex-direction:row-reverse;gap:12px;z-index:899;
}

.chat-window{
  width:320px;height:400px;
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:12px;overflow:hidden;
  box-shadow:0 8px 40px rgba(0,0,0,.4);
  display:flex;flex-direction:column;
}

.chat-window-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;border-bottom:1px solid var(--border);
  background:var(--bg-sidebar);cursor:pointer;
}
.chat-window-header .chat-name{font-weight:600;font-size:13px;display:flex;align-items:center;gap:8px}
.chat-window-header .chat-controls{display:flex;gap:4px}
.chat-window-header .chat-controls button{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:14px;padding:4px;border-radius:4px;transition:all .15s}
.chat-window-header .chat-controls button:hover{background:var(--bg-input);color:var(--text)}

.chat-messages{
  flex:1;overflow-y:auto;padding:12px;
  display:flex;flex-direction:column;gap:6px;
}

.chat-msg{max-width:80%;padding:8px 12px;border-radius:12px;font-size:13px;line-height:1.4;word-wrap:break-word}
.chat-msg.sent{align-self:flex-end;background:var(--primary);color:#fff;border-bottom-right-radius:4px}
.chat-msg.received{align-self:flex-start;background:var(--bg-input);border-bottom-left-radius:4px}
.chat-msg .chat-msg-time{font-size:10px;opacity:.6;margin-top:3px;display:block}

.chat-input-bar{
  display:flex;gap:6px;padding:10px;border-top:1px solid var(--border);background:var(--bg-sidebar);
}
.chat-input-bar input{
  flex:1;padding:8px 12px;background:var(--bg-input);border:1px solid var(--border);
  border-radius:20px;color:var(--text);font-size:13px;font-family:inherit;outline:none;
}
.chat-input-bar input:focus{border-color:var(--primary)}
.chat-input-bar button{
  width:34px;height:34px;border-radius:50%;background:var(--primary);color:#fff;
  border:none;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;
  transition:all .15s;flex-shrink:0;
}
.chat-input-bar button:hover{background:var(--primary-dim)}

/* ═══ GAME CHAT ═══ */
.gc-layout{display:flex;gap:0;height:calc(100vh - 180px);min-height:500px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.gc-sidebar{width:220px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;background:rgba(0,0,0,.15)}
.gc-filter-bar{padding:12px;border-bottom:1px solid var(--border)}
.gc-filter-bar select{width:100%}
.gc-rooms{flex:1;overflow-y:auto;padding:4px 0}
.gc-room-item{padding:10px 14px;cursor:pointer;transition:background .15s;border-bottom:1px solid rgba(255,255,255,.03)}
.gc-room-item:hover{background:rgba(245,166,35,.06)}
.gc-room-item.active{background:rgba(245,166,35,.12);border-left:3px solid var(--primary)}
.gc-room-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gc-room-meta{font-size:11px;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gc-chat-area{flex:1;display:flex;flex-direction:column;min-width:0}
.gc-chat-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);background:rgba(0,0,0,.1)}
.gc-chat-title{font-weight:600;font-size:14px}
.gc-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:4px}
.gc-msg{padding:6px 12px;border-radius:8px;font-size:13px;line-height:1.5;max-width:100%;animation:fadeIn .2s}
.gc-msg-room{background:rgba(79,195,247,.06);border-left:3px solid var(--accent)}
.gc-msg-whisper{background:rgba(245,166,35,.06);border-left:3px solid var(--primary)}
.gc-msg-tribe{background:rgba(102,187,106,.06);border-left:3px solid #66bb6a}
.gc-msg-panel{opacity:.8;font-style:italic}
.gc-msg .gc-from{font-weight:600;color:var(--primary);margin-right:6px}
.gc-msg .gc-room-tag{font-size:11px;color:var(--text-muted);margin-right:6px;background:rgba(255,255,255,.05);padding:1px 6px;border-radius:4px}
.gc-msg .gc-time{font-size:11px;color:var(--text-muted);float:right;margin-left:12px}
.gc-msg .gc-type-badge{font-size:10px;padding:1px 5px;border-radius:3px;margin-right:4px;font-weight:600}
.gc-type-room{background:rgba(79,195,247,.15);color:var(--accent)}
.gc-type-whisper{background:rgba(245,166,35,.15);color:var(--primary)}
.gc-type-tribe{background:rgba(102,187,106,.15);color:#66bb6a}
.gc-input-bar{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border);align-items:center;background:rgba(0,0,0,.1)}
.gc-send-type{width:120px;flex-shrink:0}
.gc-send-to{width:140px;flex-shrink:0}
.gc-send-content{flex:1}
.gc-no-to .gc-send-to{display:none}

@media(max-width:768px){
  .gc-layout{flex-direction:column;height:auto;min-height:auto}
  .gc-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border);max-height:200px}
  .gc-messages{min-height:300px}
  .gc-input-bar{flex-wrap:wrap}
  .gc-send-type,.gc-send-to{width:calc(50% - 4px)}
  .gc-send-content{width:100%}
}
