/* Custom styling for PHP pages (loaded after templatemo-chain-app-dev.css) */

/* Remove the template's background icon images on stats/admin cards
   so FontAwesome icons don't have an "old icon" behind them. */
.stats-page .service-item .icon,
.stats-page .service-item:hover .icon,
.admin-page .service-item .icon,
.admin-page .service-item:hover .icon {
  background-image: none !important;
}

/* Round the small icon tiles in stats/admin cards */
.stats-page .service-item .icon,
.admin-page .service-item .icon,
.service-item .icon{
  border-radius: 18px !important;
  overflow: hidden;
}

/* Make FontAwesome icons look consistent inside the icon circle */
.stats-page .service-item .icon i,
.admin-page .service-item .icon i {
  font-size: 34px;
  line-height: 1;
}

/* Avoid extra top padding on inner pages */
.page-wrap {
  padding-top: 140px;
}

/* IMPORTANT FIX:
   The template adds a full-size decorative overlay on .main-banner via :after
   (z-index: 1). That overlay can sit ABOVE interactive elements on pages that
   include forms (e.g., login) and block clicks/typing.

   Solution:
   - The overlay must ignore pointer events.
   - The actual content container must be above it.

   This is safe globally because the overlay is purely decorative.
*/
.main-banner:after {
  pointer-events: none !important;
}

.main-banner .container,
.main-banner .left-content,
.main-banner .right-image {
  position: relative;
  z-index: 2;
}

/* In case another overlay remains for any reason, never block interaction */
#js-preloader {
  pointer-events: none;
}

/* Login box styling to match the overall design */
.login-box {
  margin-top: 10px;
  padding: 28px 26px;
  border-radius: 18px;
  background: var(--vp-card);
  box-shadow: var(--vp-shadow);
}

.login-box .form-label {
  font-weight: 600;
}

.login-box .form-control {
  border-radius: 12px;
  padding: 12px 14px;
}

.login-box .main-button {
  border: 0;
}

.login-box a {
  color: #4b8ef1;
  font-weight: 600;
}

/* Make card text value stand out a bit */
.stats-page .service-item p,
.admin-page .service-item p {
  font-size: 16px;
}


/* Player search/admin panel: match the index.html look & feel */
.player-search-page .small-muted { opacity: .75; }
.player-search-page .badge-soft {
  background: rgba(99,102,241,.12);
  color: #1e293b;
  border-radius: 999px !important;
}

.player-search-page .ps-card {
  border: 0;
  border-radius: 28px;
  box-shadow: 0 20px 60px rgba(0,0,0,.08);
  overflow: hidden;
}

.player-search-page .ps-card-header {
  background: transparent;
  border: 0;
  padding: 22px 26px 8px 26px;
}

.player-search-page .ps-card-body {
  padding: 18px 26px 26px 26px;
}

.player-search-page .form-control,
.player-search-page .form-select {
  border-radius: 16px;
  padding-top: 12px;
  padding-bottom: 12px;
}

.player-search-page .btn,
.player-search-page .ps-pill {
  border-radius: 999px !important;
  padding-left: 18px;
  padding-right: 18px;
}

.player-search-page .table thead th {
  border-top: 0;
  opacity: .75;
  font-weight: 700;
}

.player-search-page .table td,
.player-search-page .table th {
  border-color: rgba(0,0,0,.06);
}


/* Modern rounded form controls on custom pages */
.admin-page .form-select,
.admin-page .form-control,
.stats-page .form-select,
.stats-page .form-control {
  border-radius: 999px !important;
  padding-left: 16px;
  padding-right: 16px;
}

/* Make selects look less boxy on Windows browsers */
.admin-page .form-select,
.stats-page .form-select {
  min-height: 46px;
}

/* Softer cards */
.admin-page .card,
.stats-page .card {
  border-radius: 26px;
  overflow: hidden;
}

/* Improve table container rounding */
.admin-page .table-responsive {
  border-radius: 22px;
  overflow: hidden;
}


/* Admin tools modern form controls */
.admin-page .form-control,
.admin-page .form-select,
.admin-page input,
.admin-page select,
.admin-page textarea{
  border-radius: 999px !important;
}
.admin-page textarea{ border-radius: 18px !important; }

.admin-page .service-item{
  border-radius: 28px !important;
}


/* More modern pill selects/inputs */
.form-control.rounded-pill,
.form-select.rounded-pill {
  border-radius: 9999px !important;
}
.form-select.rounded-pill {
  padding-right: 2.5rem;
}


/* --- VP Dashboard style (ported from DiscordBot dashboard.css) --- */
:root{
  --vp-bg-card:#ffffff;
  --vp-bg-card-hover:#f0f4ff;
  --vp-text-primary:#2a2a2a;
  --vp-text-secondary:#7a7a7a;
  --vp-border:#e8e8e8;
  --vp-shadow:0 5px 30px rgba(67,97,238,.10);
  --vp-shadow-strong:0 10px 40px rgba(67,97,238,.16);
}

/* Always LIGHT mode (requested) */
body{ background: #f6f8ff; color: var(--vp-text-primary); }
/* Compatibility: some pages still toggle these classes on <body> */
body.dark, body.dark-mode, body.theme-dark{ background: var(--vp-bg) !important; color: var(--vp-text) !important; }

/* Hide any theme toggle buttons if they exist on some pages */
.theme-toggle, .theme-toggle-btn, .dark-toggle, .darkmode-toggle, #themeToggle, #darkModeToggle{
  display:none !important;
}

/* Modern cards */
.vp-card{
  background:var(--vp-bg-card);
  border:1px solid var(--vp-border);
  border-radius:24px;
  box-shadow:var(--vp-shadow);
  transition:transform .18s ease, box-shadow .18s ease, background-color .18s ease;
  overflow:hidden;
}
.vp-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--vp-shadow-strong);
  background:var(--vp-bg-card-hover);
}

/* Soft header strip inside cards */
.vp-card .vp-card-head{
  padding:14px 18px;
  font-weight:600;
  color:var(--vp-text-primary);
  background:rgba(67,97,238,.06);
  border-bottom:1px solid rgba(0,0,0,.04);
}
.vp-card .vp-card-body{ padding:18px; }

/* Pill form controls (selects were too square) */
.vp-form .form-control,
.vp-form .form-select{
  border-radius:9999px !important;
  padding-top:.65rem;
  padding-bottom:.65rem;
}
.vp-form .form-select{ padding-right:2.2rem; }
.vp-form .btn{ border-radius:9999px !important; }

/* Table wrapper looks like template */
.vp-table-wrap{
  border-radius:24px;
  overflow:hidden;
  box-shadow:var(--vp-shadow);
  border:1px solid var(--vp-border);
  background:#fff;
}
.vp-table-wrap thead th{
  background:rgba(67,97,238,.06);
  border-bottom:1px solid rgba(0,0,0,.06);
}



/* === VP Dashboard Card System (ported from DiscordBot dashboard.css) === */
:root{
  --vp-bg-card:#ffffff;
  --vp-bg-card-hover:#f0f4ff;
  --vp-text-primary:#2a2a2a;
  --vp-text-secondary:#7a7a7a;
  --vp-text-muted:#adb5bd;
  --vp-border:#e8e8e8;
  --vp-shadow:0 5px 30px rgba(67,97,238,.10);
  --vp-shadow-strong:0 10px 40px rgba(67,97,238,.16);
  --vp-primary: #4361ee;
  --vp-success: #2ecc71;
  --vp-warning: #f39c12;
  --vp-danger:  #e74c3c;
}

/* Modern card */
.vp-card{
  background:var(--vp-bg-card);
  border:1px solid var(--vp-border);
  border-radius:24px;
  box-shadow:var(--vp-shadow);
  transition:transform .18s ease, box-shadow .18s ease, background-color .18s ease, border-color .18s ease;
  overflow:hidden;
}
.vp-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--vp-shadow-strong);
  background:var(--vp-bg-card-hover);
}
.vp-card-head{
  padding:14px 18px;
  font-weight:600;
  color:var(--vp-text-primary);
  background:rgba(67,97,238,.06);
  border-bottom:1px solid rgba(0,0,0,.04);
}
.vp-card-body{ padding:18px; }

/* Stat grid like the bot dashboard */
.vp-stats-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:16px;
}
@media (max-width: 1199px){
  .vp-stats-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 575px){
  .vp-stats-grid{ grid-template-columns:1fr; }
}
.vp-stat{
  position:relative;
  padding:16px 18px;
  border-radius:24px;
  background:var(--vp-bg-card);
  border:1px solid var(--vp-border);
  box-shadow:var(--vp-shadow);
  transition:transform .18s ease, box-shadow .18s ease, background-color .18s ease;
  overflow:hidden;
}
.vp-stat:hover{ transform:translateY(-2px); box-shadow:var(--vp-shadow-strong); background:var(--vp-bg-card-hover); }
.vp-stat::before{
  content:"";
  position:absolute; left:0; top:0; height:4px; width:100%;
  background:rgba(67,97,238,.9);
}
.vp-stat.vp-success::before{ background:var(--vp-success); }
.vp-stat.vp-warning::before{ background:var(--vp-warning); }
.vp-stat.vp-danger::before{ background:var(--vp-danger); }
.vp-stat .vp-stat-top{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
}
.vp-stat .vp-stat-label{ font-size:.85rem; color:var(--vp-text-secondary); }
.vp-stat .vp-stat-value{ font-size:1.25rem; font-weight:700; color:var(--vp-text-primary); margin-top:6px; }
.vp-stat .vp-stat-sub{ font-size:.85rem; color:var(--vp-text-secondary); margin-top:2px; }
.vp-stat .vp-stat-icon{
  width:38px; height:38px;
  display:flex; align-items:center; justify-content:center;
  border-radius:999px;
  background:rgba(67,97,238,.12);
  color:var(--vp-primary);
}

/* Make stat mini icons fully round (requested) */
.vp-stat .vp-stat-icon img,
.vp-stat .vp-stat-icon svg{
  border-radius:999px;
}

/* Make long texts (applications / patchnotes / etc.) never overflow cards/modals */
.vp-field-value,
.vp-chat-body,
.vp-card p,
.vp-modal p{
  overflow-wrap:anywhere;
  word-break:break-word;
}

/* Applications chat: clearer separation between applicant and staff */
.vp-chat-msg{
  background:rgba(67,97,238,.04);
  border:1px solid rgba(0,0,0,.06);
  border-left:5px solid rgba(67,97,238,.55);
  border-radius:16px;
  padding:12px 12px 10px;
  margin:10px 0;
}
.vp-chat-msg--staff{
  background:rgba(46,204,113,.08);
  border-left-color:rgba(46,204,113,.75);
}
.vp-chat-badge{
  font-size:.72rem;
  font-weight:700;
  padding:4px 10px;
  border-radius:999px;
  background:rgba(67,97,238,.12);
  color:var(--vp-primary);
  margin-left:8px;
}
.vp-chat-msg--staff .vp-chat-badge{
  background:rgba(46,204,113,.18);
  color:var(--vp-success);
}
.vp-chat-time{ color:var(--vp-text-secondary); font-size:.8rem; margin-left:auto; }
.vp-chat-time-inline{ color:var(--vp-text-secondary); font-size:.75rem; margin-top:6px; text-align:right; }
.vp-chat-head{ display:flex; align-items:center; gap:8px; }
.vp-chat-author{ font-weight:800; }

/* Dropdown toggles: avoid white/washed focus styles (e.g. Moderator) */
.nav-menu a:focus,
.nav-menu a:active,
.nav-menu .dropdown > a:focus,
.nav-menu .dropdown > a:active{
  color:inherit !important;
  background:transparent !important;
}
.vp-stat.vp-success .vp-stat-icon{ background:rgba(46,204,113,.14); color:var(--vp-success); }
.vp-stat.vp-warning .vp-stat-icon{ background:rgba(243,156,18,.14); color:var(--vp-warning); }
.vp-stat.vp-danger .vp-stat-icon{ background:rgba(231,76,60,.14); color:var(--vp-danger); }

/* Forms: pills */
.vp-form .form-control,
.vp-form .form-select{
  border-radius:9999px !important;
  padding:.65rem 1rem;
}
.vp-form .btn{ border-radius:9999px !important; padding:.65rem 1.05rem; }
.vp-form .form-select{ padding-right:2.5rem; }

/* Tables in a card wrapper */
.vp-table{
  border-radius:24px;
  overflow:hidden;
  box-shadow:var(--vp-shadow);
  border:1px solid var(--vp-border);
  background:#fff;
}
.vp-table thead th{
  background:rgba(67,97,238,.06);
  border-bottom:1px solid rgba(0,0,0,.06);
}
.vp-table .table{ margin:0; }


/* ---------------- Stats/Admin cards: DISCORDBOT-LIKE but LIGHT (requested) ---------------- */
/* NOTE: The user wants the "2nd image" look (white cards), not the dark theme. */
.stats-page, .admin-page {
  --bg-secondary: #ffffff;
  --bg-tertiary: #f8fafc;
  --bg-accent: #f0f4ff;
  --text-primary: #2a2a2a;
  --text-secondary: #6b7280;
  --text-muted: #94a3b8;
  --accent-primary: #4b8ef1;
  --accent-secondary: #6a5af9;
  --border: rgba(0,0,0,.06);
  --shadow: rgba(0,0,0,.08);
}

.stats-page .service-item,
.admin-page .service-item,
.stats-page .discord-card,
.admin-page .discord-card {
  position: relative;
  background: var(--bg-secondary) !important;
  border: 1px solid var(--border) !important;
  border-radius: 22px !important;
  box-shadow: 0 14px 40px var(--shadow) !important;
  overflow: hidden;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background-color .18s ease;
}

/* Left accent stripe like DiscordBot cards */
.stats-page .service-item::before,
.admin-page .service-item::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: linear-gradient(180deg, var(--accent-primary), var(--accent-secondary));
  opacity: 0.75;
}

.stats-page .service-item:hover,
.admin-page .service-item:hover {
  transform: translateY(-2px);
  border-color: rgba(75,142,241,.35) !important;
  box-shadow: 0 18px 55px rgba(0,0,0,.10) !important;
  background: var(--bg-accent) !important;
}

.stats-page .service-item h4,
.admin-page .service-item h4,
.stats-page .discord-card h4,
.admin-page .discord-card h4 {
  color: var(--text-primary) !important;
}

.stats-page .service-item p,
.admin-page .service-item p,
.stats-page .discord-card p,
.admin-page .discord-card p {
  color: var(--text-secondary) !important;
}

.stats-page .service-item .icon,
.admin-page .service-item .icon {
  background: var(--bg-tertiary) !important;
  border: 1px solid var(--border) !important;
}

.stats-page .service-item .icon i,
.admin-page .service-item .icon i {
  color: var(--accent-primary) !important;
}

/* Tabs/buttons in the header of admin pages */
.stats-page .nav-tabs .nav-link,
.admin-page .nav-tabs .nav-link {
  color: var(--text-secondary);
  border-color: transparent;
}

.stats-page .nav-tabs .nav-link.active,
.admin-page .nav-tabs .nav-link.active {
  color: #ffffff;
  background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));
  border-color: transparent;
}

.stats-page .tab-content,
.admin-page .tab-content {
  color: var(--text-secondary);
}

/* Light form controls */
.stats-page input, .stats-page select, .stats-page textarea,
.admin-page input, .admin-page select, .admin-page textarea {
  background: var(--bg-tertiary) !important;
  border: 1px solid var(--border) !important;
  color: var(--text-primary) !important;
}

.stats-page input::placeholder, .admin-page input::placeholder { color: rgba(0,0,0,.45); }

.stats-page input:focus, .stats-page select:focus, .stats-page textarea:focus,
.admin-page input:focus, .admin-page select:focus, .admin-page textarea:focus {
  outline: none;
  box-shadow: 0 0 0 4px rgba(75,142,241,.12) !important;
  border-color: rgba(75,142,241,.45) !important;
}



/* --- DiscordBot-like Player Admin (LIGHT) --- */
.player-search-page .page-header h2{
  font-weight: 800;
  letter-spacing: .2px;
  color: var(--vp-text-primary);
}
.player-search-page .page-header i{
  color:#4b8ef1;
  margin-right: 8px;
}
.player-search-page .search-container{
  margin-top: 14px;
}
.player-search-page .search-box{
  background: var(--vp-card);
  border: 1px solid var(--vp-border);
  box-shadow: var(--vp-shadow);
  border-radius: 22px;
  padding: 16px;
}
.player-search-page .vp-search-form{
  display:flex;
  gap: 12px;
  align-items:center;
}
.player-search-page .search-input{
  flex:1;
  border: 0;
  outline: none;
  background: #f8fafc;
  border-radius: 999px !important;
  padding: 14px 18px;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.06);
}
.player-search-page .search-btn{
  border:0;
  border-radius: 999px !important;
  padding: 12px 18px;
  background: linear-gradient(135deg, #4b8ef1, #6a5af9);
  color:#fff;
  font-weight:700;
  box-shadow: 0 10px 26px rgba(75,142,241,.25);
}
.player-search-page .search-btn i{ margin-right:8px; }

.player-search-page .empty-state{
  margin: 70px 0 10px;
  text-align:center;
  color: var(--vp-text-secondary);
}
.player-search-page .empty-state i{
  font-size: 56px;
  color: #4b8ef1;
  margin-bottom: 14px;
}

.player-search-page .vp-data-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

/* --- DiscordBot player card (exact classes) --- */
.player-search-page{
  --bg-card: var(--vp-bg-card);
  --border: var(--vp-border);
  --shadow: var(--vp-shadow);
  --text-primary: var(--vp-text-primary);
  --text-secondary: var(--vp-text-secondary);
  --text-muted: var(--vp-text-muted);
  --primary: var(--vp-primary);
  --success: var(--vp-success);
  --warning: var(--vp-warning);
  --danger: var(--vp-danger);
}

.player-search-page .data-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}
@media (max-width: 1200px){
  .player-search-page .data-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 768px){
  .player-search-page .data-grid{ grid-template-columns: 1fr; }
}

.player-search-page .player-card{
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 20px;
  transition: all 0.3s ease;
  box-shadow: var(--shadow);
}
.player-search-page .player-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 15px 30px rgba(67, 97, 238, 0.12);
}
.player-search-page .player-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  margin-bottom:15px;
}
.player-search-page .player-name{
  font-size:20px;
  font-weight:600;
  color:var(--text-primary);
}
.player-search-page .player-badges{ display:flex; gap:8px; flex-wrap:wrap; justify-content:flex-end; }
.player-search-page .badge{
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
}
.player-search-page .badge-banned{ background: rgba(231, 76, 60, 0.15); color: var(--danger); }
.player-search-page .badge-muted{ background: rgba(243, 156, 18, 0.15); color: var(--warning); }
.player-search-page .badge-admin{ background: rgba(114, 9, 183, 0.12); color: #7209b7; }
.player-search-page .badge-rank{ background: rgba(67, 97, 238, 0.12); color: var(--primary); }

.player-search-page .player-level-info{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:15px;
  padding:10px 15px;
  background: linear-gradient(135deg, rgba(67, 97, 238, 0.08) 0%, rgba(91, 192, 235, 0.08) 100%);
  border-radius: 12px;
}
.player-search-page .level-badge{
  display:flex;
  align-items:center;
  gap:6px;
  background: linear-gradient(135deg, var(--primary) 0%, #5bc0eb 100%);
  color:#fff;
  padding:6px 12px;
  border-radius: 20px;
  font-weight:600;
  font-size:13px;
  white-space:nowrap;
  min-height:40px;
}
.player-search-page .level-badge i{ color:#ffd700; }
.player-search-page .xp-bar-container{
  flex:1;
  height:8px;
  background: var(--border);
  border-radius:4px;
  overflow:hidden;
}
.player-search-page .xp-bar{
  height:100%;
  background: linear-gradient(90deg, var(--primary) 0%, #5bc0eb 100%);
  border-radius:4px;
  transition: width 0.3s ease;
}
.player-search-page .xp-text{
  font-size:12px;
  color: var(--text-muted);
  white-space:nowrap;
  min-height:40px;
}

.player-search-page .player-stats{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
  margin-bottom:15px;
}
.player-search-page .player-stats .stat{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:14px;
  color: var(--text-secondary);
}
.player-search-page .player-stats .stat i{ width:20px; text-align:center; }
.player-search-page .stat-cash i{ color: var(--success); }
.player-search-page .stat-gold i{ color: var(--warning); }
.player-search-page .stat-xp i{ color: var(--primary); }
.player-search-page .stat-login i{ color: var(--primary); }
.player-search-page .stat-register i{ color: var(--text-muted); }

.player-search-page .punishment-info{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius: 8px;
  font-size: 13px;
  margin-bottom: 10px;
}
.player-search-page .punishment-banned{ background: rgba(231, 76, 60, 0.10); color: var(--danger); }
.player-search-page .punishment-muted{ background: rgba(243, 156, 18, 0.10); color: var(--warning); }

.player-search-page .player-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  padding-top:15px;
  border-top: 1px solid var(--border);
}
.player-search-page .action-btn{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:8px 16px;
  font-size:13px;
  font-weight:600;
  border:none;
  border-radius:20px;
  cursor:pointer;
  transition: all 0.3s ease;
}
.player-search-page .btn-primary{ background: rgba(67, 97, 238, 0.1); color: var(--primary); }
.player-search-page .btn-primary:hover{ background: var(--primary); color:#fff; }
.player-search-page .btn-success{ background: rgba(46, 204, 113, 0.1); color: var(--success); }
.player-search-page .btn-success:hover{ background: var(--success); color:#fff; }
.player-search-page .btn-warning{ background: rgba(243, 156, 18, 0.1); color: var(--warning); }
.player-search-page .btn-warning:hover{ background: var(--warning); color:#fff; }
.player-search-page .btn-danger{ background: rgba(231, 76, 60, 0.1); color: var(--danger); }
.player-search-page .btn-danger:hover{ background: var(--danger); color:#fff; }
.player-search-page .btn-info{ background: rgba(91, 192, 235, 0.15); color: #0b7285; }
.player-search-page .btn-info:hover{ background: #5bc0eb; color:#fff; }

/* --- DiscordBot-like action modal --- */
.vp-modal-overlay{
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
  display: none;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s ease;
  z-index: 9999;
}
.vp-modal-overlay.active{
  display: flex;
  opacity: 1;
  pointer-events: auto;
}
.vp-modal{
  width: min(520px, 92vw);
  background: #fff;
  border-radius: 22px;
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 24px 70px rgba(0,0,0,.25);
  overflow: hidden;
}
.vp-modal-header{
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding: 18px 18px 14px;
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.vp-modal-title{
  font-size: 18px;
  font-weight: 900;
  color: #111827;
  margin: 0;
}
.vp-modal-close{
  width: 40px;
  height: 40px;
  border-radius: 999px !important;
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
  font-size: 22px;
  line-height: 1;
  cursor:pointer;
  transition: transform .12s ease, box-shadow .12s ease;
}
.vp-modal-close:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 25px rgba(0,0,0,.12);
}
.player-search-page #modalContent{
  padding: 18px;
}
.player-search-page .form-group{
  margin-bottom: 14px;
}
.player-search-page .form-group label{
  display:block;
  font-weight: 800;
  font-size: 13px;
  color: #374151;
  margin-bottom: 8px;
}
.player-search-page .form-group input,
.player-search-page .form-group select{
  width: 100%;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,.12);
  background: #f8fafc;
  outline: none;
}
.player-search-page .form-group input:focus,
.player-search-page .form-group select:focus{
  border-color: rgba(67, 97, 238, .45);
  box-shadow: 0 0 0 4px rgba(67, 97, 238, .12);
  background: #fff;
}
.vp-modal-actions{
  display:flex;
  justify-content:flex-end;
  gap: 10px;
  margin-top: 14px;
}
.vp-modal-btn{
  border: none;
  border-radius: 999px !important;
  padding: 10px 16px;
  font-weight: 800;
  font-size: 13px;
  cursor:pointer;
}
.vp-modal-btn-cancel{
  background: rgba(0,0,0,.05);
  color:#111827;
}
.vp-modal-btn-confirm{
  background: linear-gradient(135deg, #4361ee 0%, #5bc0eb 100%);
  color:#fff;
}
.vp-modal-btn-danger{
  background: linear-gradient(135deg, #ef4444 0%, #f97316 100%);
  color:#fff;
}
@media (max-width: 1200px){
  .player-search-page .vp-data-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 768px){
  .player-search-page .vp-search-form{ flex-direction:column; align-items:stretch; }
  .player-search-page .search-btn{ width:100%; }
  .player-search-page .vp-data-grid{ grid-template-columns: 1fr; }
}

.player-search-page .vp-player-card{
  background: var(--vp-card);
  border: 1px solid var(--vp-border);
  border-radius: 22px;
  box-shadow: var(--vp-shadow);
  padding: 18px;
  transition: transform .18s ease, box-shadow .18s ease;
}
.player-search-page .vp-player-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 55px rgba(0,0,0,.12);
}
.player-search-page .vp-player-top{
  display:flex;
  justify-content:space-between;
  gap: 10px;
  align-items:flex-start;
  margin-bottom: 12px;
}
.player-search-page .vp-player-name{
  font-size: 20px;
  font-weight: 900;
  color: #1f2937;
}
.player-search-page .vp-player-tags{
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content:flex-end;
}
.player-search-page .vp-tag{
  font-size: 11px;
  font-weight: 800;
  padding: 6px 10px;
  border-radius: 999px !important;
  letter-spacing: .2px;
}
.player-search-page .vp-tag-soft{ background: rgba(99,102,241,.14); color:#1f2937; }
.player-search-page .vp-tag-warn{ background: rgba(245,158,11,.18); color:#7c2d12; }
.player-search-page .vp-tag-danger{ background: rgba(239,68,68,.16); color:#7f1d1d; }

.player-search-page .vp-level-wrap{
  background: #f1f6ff;
  border-radius: 16px;
  padding: 12px 12px 10px;
  display:grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items:center;
  margin-bottom: 12px;
}
.player-search-page .vp-level-pill{
  background: #60a5fa;
  color:#fff;
  font-weight:800;
  border-radius: 999px !important;
  padding: 8px 12px;
  display:inline-flex;
  align-items:center;
  gap: 8px;
  white-space:nowrap;
  min-height:40px;
  box-shadow: 0 10px 20px rgba(96,165,250,.25);
}
.player-search-page .vp-progress{
  height: 8px;
  background: rgba(0,0,0,.08);
  border-radius: 999px !important;
  overflow:hidden;
}
.player-search-page .vp-progress-bar{
  height: 100%;
  background: linear-gradient(90deg, #4b8ef1, #6a5af9);
  border-radius: 999px !important;
}
.player-search-page .vp-level-xp{
  font-size: 12px;
  color: rgba(31,41,55,.55);
  font-weight: 700;
  white-space:nowrap;
  min-height:40px;
}

.player-search-page .vp-stats{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 14px;
  padding: 6px 2px 12px;
}
.player-search-page .vp-stat{
  display:flex;
  align-items:center;
  gap: 10px;
  color: rgba(31,41,55,.72);
  font-weight: 700;
  font-size: 13px;
}
.player-search-page .vp-stat i{
  width: 18px;
  color: #4b8ef1;
}

.player-search-page .vp-alert-strip{
  margin-top: 4px;
  margin-bottom: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(245,158,11,.12);
  color:#92400e;
  font-weight: 800;
  font-size: 12px;
  display:flex;
  align-items:center;
  gap: 8px;
}

.player-search-page .vp-actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  border-top: 1px solid rgba(0,0,0,.06);
  padding-top: 12px;
}
.player-search-page .vp-action{
  border:0;
  border-radius: 999px !important;
  padding: 9px 12px;
  font-weight: 800;
  font-size: 12px;
  display:inline-flex;
  align-items:center;
  gap: 8px;
}
.player-search-page .vp-action i{ opacity: .9; }
.player-search-page .vp-action-danger{ background: rgba(239,68,68,.12); color:#b91c1c; }
.player-search-page .vp-action-warn{ background: rgba(245,158,11,.14); color:#b45309; }
.player-search-page .vp-action-primary{ background: rgba(99,102,241,.14); color:#3730a3; }
.player-search-page .vp-action-success{ background: rgba(34,197,94,.14); color:#166534; }
.player-search-page .vp-action-info{ background: rgba(59,130,246,.14); color:#1d4ed8; }

.player-search-page .vp-modal{
  border-radius: 20px;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 18px 70px rgba(0,0,0,.18);
}
.player-search-page .vp-modal .vp-modal-header{
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.player-search-page .vp-modal-form .form-control,
.player-search-page .vp-modal-form .form-select{
  border-radius: 14px;
  padding-top: 12px;
  padding-bottom: 12px;
}


/* ---------------- Rounded custom dropdown (fix for square native menus) ---------------- */
/* Native <select> dropdown lists cannot be reliably styled across OS/browsers.
   We replace specific selects (class vp-custom-select) with a custom dropdown. */
.vp-select{ position:relative; width:100%; }
.vp-select-native{
  /* keep it in the DOM for form submits */
  position:absolute !important;
  inset:0;
  opacity:0 !important;
  pointer-events:none !important;
}
.vp-select-btn{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: .65rem 1rem;
  border-radius: 9999px;
  background: var(--vp-input);
  border: 1px solid var(--vp-border);
  color: var(--vp-input-text);
  font-weight: 700;
}
.vp-select-btn:focus{ outline:none; box-shadow:0 0 0 4px rgba(75,142,241,.12); border-color: rgba(75,142,241,.45); }
.vp-select-caret{ opacity:.6; }
.vp-select-menu{
  position:absolute;
  left:0; right:0;
  top: calc(100% + 8px);
  background: var(--vp-card);
  border: 1px solid var(--vp-border);
  border-radius: 18px;
  box-shadow: var(--vp-shadow);
  padding: 8px;
  display:none;
  max-height: 320px;
  overflow:auto;
  z-index: 999;
}
.vp-select.open .vp-select-menu{ display:block; }
.vp-select-item{
  width:100%;
  text-align:left;
  border:0;
  background: transparent;
  border-radius: 14px;
  padding: 10px 12px;
  font-weight: 700;
  color:#1f2937;
}
.vp-select-item:hover{ background: rgba(75,142,241,.10); }
.vp-select-item.is-selected{ background: rgba(75,142,241,.14); }
.vp-select-item.is-disabled{ opacity:.45; cursor:not-allowed; }


/* ---------------- "DiscordBot" boxes with left color strip ---------------- */
/* Apply the accent strip to the main content cards/boxes (not to header/footer). */
.main-banner .card,
.main-banner .service-item,
.player-search-page .vp-player-card,
.player-search-page .ps-card,
.admin-page .ps-card,
.stats-page .discord-card,
.admin-page .discord-card{
  position: relative;
}

.main-banner .card::before,
.main-banner .service-item::before,
.player-search-page .vp-player-card::before,
.player-search-page .ps-card::before,
.admin-page .ps-card::before,
.stats-page .discord-card::before,
.admin-page .discord-card::before{
  content:"";
  position:absolute;
  left:10px;
  top: 18px;
  bottom: 18px;
  width: 6px;
  border-radius: 999px !important;
  background: linear-gradient(180deg, #4b8ef1, #6a5af9);
  opacity: .9;
}

/* Optional accent variants you can add in HTML if needed */
.accent-success::before{ background: linear-gradient(180deg, #22c55e, #2ecc71) !important; }
.accent-warning::before{ background: linear-gradient(180deg, #f59e0b, #f39c12) !important; }
.accent-danger::before{ background: linear-gradient(180deg, #ef4444, #e74c3c) !important; }

/* Make sure padding doesn't collide with the strip */
.main-banner .card .card-body,
.player-search-page .vp-player-card,
.main-banner .service-item{
  padding-left: 26px;
}


/* --- Instant player search (DiscordBot style) --- */
.vp-search-wrap{position:relative;}
#playerSuggestions{position:absolute; left:0; right:0; top:100%; margin-top:8px; background:#fff; border:1px solid rgba(15,23,42,.12); border-radius:16px; box-shadow:0 12px 30px rgba(15,23,42,.10); overflow:hidden; display:none; z-index:50;}
#playerSuggestions.is-open{display:block;}
#playerSuggestions .vp-sugg-item{width:100%; text-align:left; padding:10px 14px; background:transparent; border:0; cursor:pointer; font-weight:600;}
#playerSuggestions .vp-sugg-item:hover{background:rgba(37,99,235,.08);}
#playerSearchMeta{margin-top:10px; font-size:13px; opacity:.75;}
.vp-results-grid{display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:16px;}
#playerResults.is-loading{opacity:.65; filter:grayscale(.05);}
.vp-actions{display:flex; flex-wrap:wrap; gap:8px; margin-top:12px;}
.vp-action-btn{border-radius:14px;}
/* Rounded selects / custom controls */
select.form-control, select.custom-select{border-radius:14px !important;}

.vp-search-options{margin-top:10px;}
.vp-toggle{display:inline-flex; align-items:center; gap:8px; font-weight:600; font-size:13px; opacity:.85; user-select:none;}
.vp-toggle input{width:16px; height:16px; border-radius:6px;}

/* --- DiscordBot-like toast notifications --- */
.vp-toast{
  position: fixed;
  left: 50%;
  bottom: 26px;
  transform: translateX(-50%) translateY(20px);
  opacity: 0;
  padding: 14px 22px;
  border-radius: 16px;
  font-weight: 700;
  box-shadow: 0 18px 45px rgba(15,23,42,0.18);
  z-index: 9999;
  transition: opacity .25s ease, transform .25s ease;
  background: #22c55e;
  color: #fff;
  min-width: 240px;
  text-align: center;
}
.vp-toast.is-show{opacity:1; transform: translateX(-50%) translateY(0);}
.vp-toast-error{background:#ef4444;}
.vp-toast-success{background:#22c55e;}
.vp-toast-warning{background:#f59e0b;}


/* Rounded DiscordBot-like pill tabs (Stats / Admin Tools / Discordbot)
   Theme-aware (works in Light + Dark) */
.vp-tabs{
  gap: 14px;
}
.vp-tabs .nav-item{ margin: 0 6px; }

.vp-tabs .nav-link{
  border-radius: 999px !important;
  padding: 10px 18px !important;
  background: var(--vp-card) !important;
  border: 1px solid var(--vp-border) !important;
  box-shadow: var(--vp-shadow) !important;
  color: var(--vp-muted) !important;
  font-weight: 600;
}
.vp-tabs .nav-link:hover{
  transform: translateY(-1px);
  box-shadow: var(--vp-shadow) !important;
  color: var(--vp-text) !important;
}
.vp-tabs .nav-link.active{
  color: #fff !important;
  border-color: transparent !important;
  background: linear-gradient(135deg, #3b82f6 0%, #60a5fa 100%) !important;
  box-shadow: 0 18px 40px rgba(59, 130, 246, 0.30) !important;
}
.vp-tabs .vp-external:not(.active) {
  background: var(--vp-card) !important;
}
.vp-tabs .badge {
  border-radius: 999px !important;
  padding: 6px 10px !important;
}

/* Search meta line: keep it subtle like DiscordBot */
#playerSearchMeta {
  margin-top: 10px;
  color: #6b7785;
  font-size: 13px;
}

/* Header account dropdown (desktop + mobile) */
.account-dropdown{position:relative;}
.account-dropdown-menu{
  display:none;
  position:absolute;
  right:0;
  top:calc(100% + 10px);
  min-width:240px;
  background:#fff;
  border:1px solid rgba(0,0,0,0.06);
  border-radius:16px;
  box-shadow:0 24px 70px rgba(15,23,42,0.12);
  padding:10px;
  z-index:9999;
}
.account-dropdown-menu li{list-style:none; margin:4px 0; padding:0;}
.account-dropdown-menu a{
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:12px 14px;
  border-radius:12px;
  white-space:nowrap;
  min-height:40px;
  color:#2c2f33 !important;
  font-weight:700;
  font-size:14px;
  transition: all .15s ease;
}
.account-dropdown-menu a:hover{
  background:#f2f6ff;
}
.account-dropdown.is-open .account-dropdown-menu{display:block;}

@media (max-width: 991px){
  .account-dropdown-menu{
    position:static;
    min-width:unset;
    box-shadow:none;
    border:0;
    padding:0 0 10px 0;
  }
  .account-dropdown.is-open .account-dropdown-menu{display:block;}
}

/* =============================
   Common UI helpers (Apply / Patchnotes / Panels)
   ============================= */

.vp-input{
  width:100%;
  padding:12px 14px;
  border-radius:14px;
  outline:none;
}

.vp-form-actions{ text-align:center; margin-top:6px; }

.vp-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 18px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,0.08);
  background:#fff;
  color:#111827;
  font-weight:700;
  box-shadow:0 8px 18px rgba(29,44,86,0.08);
  transition:transform .12s ease, box-shadow .12s ease;
}
.vp-btn:hover{ transform:translateY(-1px); box-shadow:0 14px 26px rgba(29,44,86,0.12); }

.vp-btn-primary{
  border:0;
  color:#fff;
  background:linear-gradient(120deg,#1e70ff,#57c2ff);
}
.vp-btn-sm{ padding:8px 12px; font-weight:700; }

.vp-pill-tabs{ display:flex; gap:10px; flex-wrap:wrap; }
.vp-pill{ padding:10px 16px; border-radius:999px; cursor:pointer; font-weight:700; }

/* Applications panel cards */
.vp-ticket-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:18px;
}
.vp-ticket-card{
  position:relative;
  border-radius:22px;
  padding:18px 18px 16px 18px;
  overflow:hidden;
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 18px 45px rgba(16,24,40,.08);
  transition: transform .14s ease, box-shadow .14s ease;
}
.vp-ticket-card:hover{
  transform: translateY(-2px);
  box-shadow:0 26px 65px rgba(16,24,40,.12);
}
html[data-theme="dark"] .vp-ticket-card{
  background: rgba(30,36,54,.92);
  border-color: rgba(255,255,255,.08);
}

/* Left accent like DiscordBot cards */
.vp-ticket-card::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:6px;
  border-radius:22px 0 0 22px;
  background: rgba(59,130,246,.55);
}
.vp-ticket-card.status-open::before{ background: rgba(59,130,246,.55); }
.vp-ticket-card.status-investigating::before{ background: rgba(245,158,11,.65); }
.vp-ticket-card.status-resolved::before{ background: rgba(34,197,94,.65); }

.vp-ticket-header{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:10px; }
.vp-ticket-title{ font-weight:900; font-size:16px; line-height:1.25; }
.vp-ticket-status{ font-size:11px; font-weight:900; padding:6px 10px; border-radius:999px; background:#f2f2f2; }
.vp-ticket-status.open{ background:rgba(59,130,246,0.15); color:#2563eb; }
.vp-ticket-status.investigating{ background:rgba(245,158,11,0.18); color:#b45309; }
.vp-ticket-status.resolved{ background:rgba(34,197,94,0.18); color:#15803d; }
.vp-ticket-meta{ display:flex; gap:12px; flex-wrap:wrap; font-size:12px; opacity:.85; margin-bottom:10px; }
.vp-ticket-message{ font-size:13px; line-height:1.4; max-height:72px; overflow:hidden; opacity:.95; }
.vp-ticket-card.expanded .vp-ticket-message{ max-height:none; }
.vp-ticket-actions{ display:flex; gap:10px; flex-wrap:wrap; margin-top:14px; }
.vp-action{
  border:0;
  padding:9px 13px;
  border-radius:999px;
  font-weight:900;
  font-size:12px;
  letter-spacing:.2px;
  cursor:pointer;
  transition: transform .12s ease, filter .12s ease;
}
.vp-action:hover{ transform: translateY(-1px); filter: brightness(.98); }
.vp-action.view{ background:rgba(59,130,246,0.18); color:#1d4ed8; }
.vp-action.claim{ background:rgba(245,158,11,0.18); color:#b45309; }
.vp-action.resolve{ background:rgba(34,197,94,0.18); color:#15803d; }
.vp-action.delete{ background:rgba(239,68,68,0.18); color:#b91c1c; }

/* Patchnotes */
.vp-patch-list{ display:flex; flex-direction:column; gap:14px; }
.vp-patch-item{
  display:block;
  padding:16px 18px;
  border-radius:18px;
  text-decoration:none !important;
  color:inherit !important;
}
.vp-patch-title{ font-weight:900; font-size:17px; }
.vp-patch-meta{ font-size:12px; opacity:.85; margin-top:4px; }
.vp-patch-content{ margin-top:16px; }
.vp-patch-content img{ max-width:100%; border-radius:14px; }

/* Editor */
.vp-editor-toolbar{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-bottom:12px; }
.vp-editor-toolbar .vp-btn.active{ outline:2px solid rgba(30,112,255,0.35); }
.vp-editor-split{ display:block; }
.vp-preview-pane{ margin-top:12px; }
.vp-preview-inner{ padding:14px; border-radius:18px; border:1px dashed rgba(0,0,0,0.12); }
.vp-emoji-picker{ gap:8px; flex-wrap:wrap; margin:8px 0 10px 0; }
.vp-emoji-picker button{ border:1px solid rgba(0,0,0,0.08); background:#fff; border-radius:12px; padding:6px 10px; font-size:18px; }


/* ===== Header cleanup + Online pill (DiscordBot-like) ===== */
.header-area .main-nav{display:flex;align-items:center;gap:18px;justify-content:space-between;flex-wrap:nowrap;}
.header-area .main-nav .logo{flex:0 0 auto;}
.header-area .main-nav ul.nav{flex:1 1 auto;display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:nowrap;min-width:0;margin:0;}
.header-area .main-nav ul.nav a{white-space:nowrap;}
.header-area .main-nav ul.nav>li{margin:0 !important;}
.header-area .vp-header-actions{flex:0 0 auto;display:flex;align-items:center;justify-content:flex-end;gap:12px;}

/* Community dropdown: keep all items perfectly left-aligned ("Contact" was slightly offset on some browsers) */
.account-dropdown-menu{ text-align:left !important; }
.account-dropdown-menu li{ width:100% !important; }

/* Keep the CTA from forcing weird wrapping */
.header-area .vp-header-actions .gradient-button{margin:0;}
.header-area .vp-header-actions .gradient-button a{white-space:nowrap;
  min-height:40px;}

/* When the menu collapses to burger, let layout stack nicely */
@media (max-width: 992px){
  .header-area .main-nav{gap:10px;}
  .header-area .main-nav ul.nav{justify-content:flex-start;}
  .header-area .vp-header-actions{display:none;} /* CTA hidden when burger menu is used */
}

/* Floating theme button (bottom-right) */
.vp-theme-fab{
  position:fixed;
  right:18px;
  bottom:18px;
  width:52px;
  height:52px;
  border-radius:999px;
  border:0;
  cursor:pointer;
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 10px 30px rgba(0,0,0,.18);
  background:linear-gradient(105deg,#4b8ef1 0%,#0dcaf0 100%);
  color:#fff;
}
.vp-theme-fab:active{transform:translateY(1px);}
.vp-theme-fab i{font-size:18px;}

/* If you have another floating button, avoid overlap */
@media (max-width: 576px){
  .vp-theme-fab{right:14px;bottom:14px;}
}


/* Dropdown alignment fixes (make ALL dropdowns identical) */
.account-dropdown-menu{
  min-width: 240px;
  padding: 10px;
}
.account-dropdown-menu li{
  list-style: none;
  margin: 0;
  padding: 0;
}
.account-dropdown-menu a{
  display: none;
  align-items: center;
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  white-space: nowrap;
  text-align: left;
  line-height: 1;
  font-weight: 700;
  gap: 10px;
}
.account-dropdown-menu a:hover{
  background: rgba(67, 97, 238, 0.08);
}
.account-dropdown-menu .dropdown-sep{
  height: 1px;
  margin: 8px 6px;
  background: rgba(0,0,0,.06);
}


/* Header nav alignment fixes */
.header-area .main-nav .nav li a{
  display:flex;
  align-items:center;
  justify-content:center;
  line-height: 1;
}
.header-area .main-nav .nav li{
  display:flex;
  align-items:center;
}

/* Rounded select like DiscordBot */
select.vp-input{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  background-image: linear-gradient(45deg, transparent 50%, rgba(0,0,0,.35) 50%),
                    linear-gradient(135deg, rgba(0,0,0,.35) 50%, transparent 50%);
  background-position: calc(100% - 18px) calc(1em + 2px), calc(100% - 13px) calc(1em + 2px);
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 42px !important;
  border-radius: 999px !important;
}
html[data-theme="dark"] select.vp-input{
  background-image: linear-gradient(45deg, transparent 50%, rgba(255,255,255,.6) 50%),
                    linear-gradient(135deg, rgba(255,255,255,.6) 50%, transparent 50%);
}

/* ===== Apply page custom select (rounded, Discordbot-style) ===== */
.vp-req{color:#ff4d4f;font-weight:700;margin-left:4px;}
.vp-form-hint{font-size:12px;color:var(--vp-muted);margin-top:6px;}

.vp-select{
  position:relative;
  width:100%;
  height:46px;
  border-radius:999px;
  border:1px solid var(--vp-border);
  background:var(--vp-input);
  display:flex;
  align-items:center;
  padding:0 18px;
  cursor:pointer;
  user-select:none;
}
.vp-select:focus{outline:none;box-shadow:0 0 0 4px rgba(30,112,255,.15);}
.vp-select-value{flex:1;color:var(--vp-text);font-weight:600;}
.vp-select-caret{color:var(--vp-muted);font-size:14px;}
.vp-select-menu{
  position:absolute;
  left:0;
  right:0;
  top:calc(100% + 8px);
  background:var(--vp-card);
  border:1px solid var(--vp-border);
  border-radius:16px;
  box-shadow:var(--vp-shadow);
  padding:8px;
  display:none;
  z-index:50;
}
.vp-select.open .vp-select-menu{display:block;}
.vp-select-option{
  width:100%;
  text-align:left;
  border:0;
  background:transparent;
  padding:10px 12px;
  border-radius:12px;
  color:var(--vp-text);
  font-weight:600;
}
.vp-select-option:hover{background:rgba(30,112,255,.08);}


/* ==============================
   Applications chat readability
   ============================== */
.vp-chat{
  margin-top:14px;
  padding:14px;
  border-radius:18px;
  background: rgba(255,255,255,.65);
  border: 1px solid rgba(0,0,0,.06);
}
html[data-theme="dark"] .vp-chat{
  background: rgba(20,24,36,.65);
  border-color: rgba(255,255,255,.08);
}
.vp-chat-list{
  display:flex;
  flex-direction:column;
  gap:10px;
  max-height:340px;
  overflow:auto;
  padding-right: 6px;
}
.vp-chat-msg{
  display:flex;
  flex-direction:column;
  max-width: 78%;
  border-radius: 16px;
  padding: 10px 12px;
  border: 1px solid rgba(0,0,0,.06);
  background: #fff;
  box-shadow: 0 10px 30px rgba(16,24,40,.06);
}
html[data-theme="dark"] .vp-chat-msg{
  background: rgba(30,36,54,.92);
  border-color: rgba(255,255,255,.08);
}
.vp-chat-msg--staff{
  align-self:flex-end;
  border-color: rgba(60,120,255,.25);
  background: rgba(60,120,255,.08);
}
html[data-theme="dark"] .vp-chat-msg--staff{
  background: rgba(60,120,255,.18);
}
.vp-chat-head{
  display:flex;
  align-items:baseline;
  gap:8px;
  margin-bottom: 6px;
}
.vp-chat-author{
  font-weight: 800;
  font-size: 13px;
}
.vp-chat-badge{
  font-size: 11px;
  padding: 3px 8px;
  border-radius: 999px !important;
  background: rgba(0,0,0,.06);
}
html[data-theme="dark"] .vp-chat-badge{
  background: rgba(255,255,255,.08);
}
.vp-chat-time{
  margin-left:auto;
  font-size: 12px;
  opacity: .65;
  white-space: nowrap;
}
.vp-chat-body{
  font-size: 14px;
  line-height: 1.45;
  white-space: pre-wrap;
  word-break: break-word;
}

/* Small timestamp shown for grouped follow-ups (Discord-like readability) */
.vp-chat-time-inline{
  margin-top: 6px;
  align-self: flex-end;
  font-size: 11px;
  opacity: .55;
  white-space: nowrap;
}
.vp-chat-date-sep{
  align-self:center;
  font-size: 12px;
  opacity:.65;
  padding: 6px 10px;
  border-radius: 999px !important;
  background: rgba(0,0,0,.04);
  border: 1px solid rgba(0,0,0,.05);
  margin: 6px 0;
}
html[data-theme="dark"] .vp-chat-date-sep{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.08);
}
/* Follow-up message (same author, close in time) */
.vp-chat-msg--followup .vp-chat-head{display:none}
.vp-chat-msg--followup{padding-top:8px;margin-top:-4px;opacity:.98}
.vp-chat-msg--followup .vp-chat-body{margin-top:0}


/* Unread badge (mobile app style) */
.vp-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 6px;border-radius:999px;background:#e11d48;color:#fff;font-size:12px;font-weight:800;line-height:18px;margin-left:8px;vertical-align:middle;box-shadow:0 6px 16px rgba(225,29,72,.25);} 
.account-toggle .vp-badge{transform:translateY(-1px);} 
.account-dropdown-menu .vp-badge{margin-left:10px;}

/* Header dropdown toggles: keep consistent color on focus/active */
.navbar .dropdown-toggle:focus,
.navbar .dropdown-toggle:active{
  color:inherit !important;
  background:transparent !important;
  box-shadow:none !important;
}

/* ===== FINAL Dropdown Polish (DiscordBot-like) ===== */
.account-dropdown { position: relative; }
.account-toggle{
  display:flex !important;
  align-items:center;
  justify-content:center;
  line-height:1 !important;
}
.account-toggle:focus,
.account-toggle:active{
  outline:none;
  background:transparent !important;
  color:inherit !important;
  box-shadow:none !important;
}

.account-dropdown-menu{
  min-width: 240px !important;
  padding: 10px !important;
}
.account-dropdown-menu li{ margin:0 !important; }
.account-dropdown-menu a{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:100% !important;
  padding: 12px 14px !important;
  border-radius: 14px !important;
  text-align:center !important;
  line-height: 1 !important;
  min-height: 42px !important;
  gap: 10px !important;
}
.account-dropdown-menu a:hover{ background: rgba(67, 97, 238, 0.08) !important; }
.account-dropdown-menu a:active{ transform: translateY(0.5px); }

/* Dropdown item alignment: keep flex everywhere (prevents items like 'Contact' / 'Logout' drifting) */
.account-dropdown-menu a:visited{color:inherit !important;}
.account-dropdown-menu a span, .account-dropdown-menu a i{margin:0 !important;}


/* Keep separators perfectly aligned */
.account-dropdown-menu .dropdown-sep{
  height:1px !important;
  margin:8px 6px !important;
  background: rgba(0,0,0,.06) !important;
}
html[data-theme="dark"] .account-dropdown-menu .dropdown-sep{ background: rgba(255,255,255,.10) !important; }

/* Prevent the Moderator dropdown from turning white (link focus/active) */
.header-area .main-nav .nav li a.account-toggle:focus,
.header-area .main-nav .nav li a.account-toggle:active{
  background: transparent !important;
  color: inherit !important;
}

/* ----------------------------- */
/* ULTRA Darkmode hardening      */
/* ----------------------------- */
html[data-theme="dark"] body,
body.dark, body.dark-mode, body.theme-dark{
  background: var(--vp-bg) !important;
  color: var(--vp-text) !important;
}

html[data-theme="dark"] .section-heading h2,
html[data-theme="dark"] h1,
html[data-theme="dark"] h2,
html[data-theme="dark"] h3,
html[data-theme="dark"] h4,
html[data-theme="dark"] p,
html[data-theme="dark"] span,
html[data-theme="dark"] small{ color: var(--vp-text) !important; }

html[data-theme="dark"] .service-item,
html[data-theme="dark"] .vp-card,
html[data-theme="dark"] .player-card,
html[data-theme="dark"] .vp-shell,
html[data-theme="dark"] .vp-modal,
html[data-theme="dark"] .vp-modal-content,
html[data-theme="dark"] .vp-modal-body,
html[data-theme="dark"] .vp-modal-header,
html[data-theme="dark"] .vp-panel,
html[data-theme="dark"] .vp-white-shell{
  background: var(--vp-card) !important;
  border-color: var(--vp-border) !important;
  color: var(--vp-text) !important;
}

html[data-theme="dark"] .vp-shell{ box-shadow: 0 28px 70px rgba(0,0,0,.45) !important; }
html[data-theme="dark"] .vp-modal-overlay{ background: rgba(0,0,0,.55) !important; }

/* Inputs */
html[data-theme="dark"] input,
html[data-theme="dark"] textarea,
html[data-theme="dark"] select{
  background: rgba(255,255,255,.04) !important;
  border-color: rgba(255,255,255,.10) !important;
  color: var(--vp-text) !important;
}
html[data-theme="dark"] input::placeholder,
html[data-theme="dark"] textarea::placeholder{ color: rgba(255,255,255,.45) !important; }

/* Stats cards icon rounding + better contrast */
.services .service-item .icon,
.vp-stat-icon{
  border-radius: 16px !important;
  overflow: hidden;
}

/* Make sure any <img> inside icon boxes also looks rounded */
.services .service-item .icon img,
.vp-stat-icon img{ border-radius: 14px !important; }

/* Footer should never flip to white in dark mode */
html[data-theme="dark"] footer,
html[data-theme="dark"] .footer{
  background: transparent !important;
  color: rgba(255,255,255,.75) !important;
}
html[data-theme="dark"] footer a{ color: rgba(255,255,255,.85) !important; }

/* Fix the occasional "light" focused card */
html[data-theme="dark"] .service-item:hover,
html[data-theme="dark"] .vp-stat:hover{ background: rgba(255,255,255,.05) !important; }

html[data-theme="dark"] .service-item.is-active,
html[data-theme="dark"] .service-item.active,
html[data-theme="dark"] .vp-stat.is-active,
html[data-theme="dark"] .vp-stat.active{
  background: rgba(255,255,255,.04) !important;
}


/* =========================================================
   ULTRA DARK MODE FIX (match DiscordBot behavior)
   Ensures EVERY box/text/icon respects the global theme vars
   ========================================================= */
html[data-theme="dark"] body{
  background: var(--vp-bg) !important;
  color: var(--vp-text) !important;
}

/* Generic typography */
html[data-theme="dark"] h1,
html[data-theme="dark"] h2,
html[data-theme="dark"] h3,
html[data-theme="dark"] h4,
html[data-theme="dark"] h5,
html[data-theme="dark"] h6,
html[data-theme="dark"] .title,
html[data-theme="dark"] .section-title,
html[data-theme="dark"] .card-title{
  color: var(--vp-text) !important;
}
html[data-theme="dark"] p,
html[data-theme="dark"] .text-muted,
html[data-theme="dark"] .small,
html[data-theme="dark"] small{
  color: var(--vp-muted) !important;
}

/* Boxes / cards everywhere */
html[data-theme="dark"] .service-item,
html[data-theme="dark"] .discord-card,
html[data-theme="dark"] .player-card,
html[data-theme="dark"] .vp-patch-item,
html[data-theme="dark"] .vp-ticket-card,
html[data-theme="dark"] .vp-card,
html[data-theme="dark"] .vp-stat,
html[data-theme="dark"] .ps-card,
html[data-theme="dark"] .card,
html[data-theme="dark"] .modal-content,
html[data-theme="dark"] .modal,
html[data-theme="dark"] .modal-body,
html[data-theme="dark"] .modal-header,
html[data-theme="dark"] .modal-footer{
  background: var(--vp-card) !important;
  border-color: var(--vp-border) !important;
  color: var(--vp-text) !important;
}

/* Card inner strips that were hardcoded light */
html[data-theme="dark"] .vp-card-head,
html[data-theme="dark"] .ps-card-header{
  background: rgba(255,255,255,.04) !important;
  border-bottom-color: var(--vp-border) !important;
  color: var(--vp-text) !important;
}

/* Tables */
html[data-theme="dark"] .table,
html[data-theme="dark"] .table-responsive,
html[data-theme="dark"] .vp-table,
html[data-theme="dark"] .vp-table-wrap{
  background: var(--vp-card) !important;
  border-color: var(--vp-border) !important;
}
html[data-theme="dark"] .table thead th,
html[data-theme="dark"] .vp-table thead th,
html[data-theme="dark"] .vp-table-wrap thead th{
  background: rgba(255,255,255,.04) !important;
  color: var(--vp-muted) !important;
  border-bottom-color: var(--vp-border) !important;
}
html[data-theme="dark"] .table td,
html[data-theme="dark"] .table th{
  border-color: var(--vp-border) !important;
  color: var(--vp-text) !important;
}
html[data-theme="dark"] .table tbody tr:hover{
  background: rgba(255,255,255,.03) !important;
}

/* Forms (Bootstrap) */
html[data-theme="dark"] .form-control,
html[data-theme="dark"] .form-select,
html[data-theme="dark"] textarea,
html[data-theme="dark"] input{
  background: var(--vp-input) !important;
  color: var(--vp-input-text) !important;
  border-color: var(--vp-border) !important;
}
/* Custom inputs used on Apply/Patchnotes/Admin panels */
html[data-theme="dark"] .vp-input,
html[data-theme="dark"] .vp-select,
html[data-theme="dark"] .vp-select *{
  background: var(--vp-input) !important;
  color: var(--vp-input-text) !important;
  border-color: var(--vp-border) !important;
}
html[data-theme="dark"] .form-control::placeholder,
html[data-theme="dark"] textarea::placeholder{
  color: rgba(229,231,235,.55) !important;
}
html[data-theme="dark"] .vp-input::placeholder{
  color: rgba(229,231,235,.55) !important;
}

/* Checkboxes / switches (fix the "white pills") */
html[data-theme="dark"] .form-check-input,
html[data-theme="dark"] input[type="checkbox"],
html[data-theme="dark"] input[type="radio"]{
  background-color: rgba(255,255,255,.08) !important;
  border-color: var(--vp-border) !important;
  accent-color: var(--vp-link);
}
html[data-theme="dark"] .form-check-input:checked{
  background-color: var(--vp-link) !important;
  border-color: var(--vp-link) !important;
}

/* Buttons that became unreadable */
html[data-theme="dark"] .btn.btn-light,
html[data-theme="dark"] .btn-light{
  background: rgba(255,255,255,.08) !important;
  border-color: var(--vp-border) !important;
  color: var(--vp-text) !important;
}

/* Icon tiles + SVGs + FontAwesome
   IMPORTANT: Do NOT touch the landing-page service icons (they use background-images).
   Only restyle the dashboard cards (stats/admin/tools/discordbot pages). */
html[data-theme="dark"] .stats-page .service-item .icon,
html[data-theme="dark"] .admin-page .service-item .icon,
html[data-theme="dark"] .vp-stat .vp-stat-icon,
html[data-theme="dark"] .vp-stat-icon{
  background: rgba(255,255,255,.06) !important;
  border-color: var(--vp-border) !important;
  color: var(--vp-link) !important;
}
html[data-theme="dark"] .service-item .icon i,
html[data-theme="dark"] .service-item .icon svg,
html[data-theme="dark"] .vp-stat-icon i,
html[data-theme="dark"] .vp-stat-icon svg{
  color: var(--vp-link) !important;
  fill: currentColor !important;
}

/* Landing page social icons: center inline SVGs (e.g. TikTok) inside the 50x50 icon box */
.vp-social-icon{
  display: flex;
  align-items: center;
  justify-content: center;
}
.vp-social-icon svg{ fill: currentColor; }

/* Make all "Our Socials" logos the same visual size (FontAwesome + SVG) */
body.home-page #media.services.section .service-item .icon{
  display:flex;
  align-items:center;
  justify-content:center;
}
body.home-page #media.services.section .service-item .icon i{
  font-size: 22px !important;
  line-height: 1 !important;
}
body.home-page #media.services.section .service-item .icon svg{
  width: 22px !important;
  height: 22px !important;
  display:block;
}

/* Reduce the large gap between "Our Socials" and the footer on the landing page */
body.home-page #media.services.section{
  padding-bottom: 20px !important;
}
body.home-page footer{
  margin-top: 30px !important;
  padding-top: 140px !important;
}

/* Stats/Admin text inside cards */
html[data-theme="dark"] .stats-page .service-item h4,
html[data-theme="dark"] .admin-page .service-item h4,
html[data-theme="dark"] .stats-page .discord-card h4,
html[data-theme="dark"] .admin-page .discord-card h4,
html[data-theme="dark"] .vp-stat .vp-stat-value{
  color: var(--vp-text) !important;
}
html[data-theme="dark"] .stats-page .service-item p,
html[data-theme="dark"] .admin-page .service-item p,
html[data-theme="dark"] .stats-page .discord-card p,
html[data-theme="dark"] .admin-page .discord-card p,
html[data-theme="dark"] .vp-stat .vp-stat-label,
html[data-theme="dark"] .vp-stat .vp-stat-sub{
  color: var(--vp-muted) !important;
}

/* Badges that were dark-on-dark */
html[data-theme="dark"] .badge,
html[data-theme="dark"] .badge-soft,
html[data-theme="dark"] .vp-chat-badge{
  background: rgba(96,165,250,.14) !important;
  color: #cfe6ff !important;
  border-color: rgba(96,165,250,.22) !important;
}

/* Login box override (custom-pages.css sets it to white) */
html[data-theme="dark"] .login-box{
  background: var(--vp-card) !important;
  border: 1px solid var(--vp-border) !important;
  box-shadow: var(--vp-shadow) !important;
}

/* Chart containers / canvases: keep dark surface */
html[data-theme="dark"] canvas,
html[data-theme="dark"] .chart-container,
html[data-theme="dark"] .apexcharts-canvas,
html[data-theme="dark"] .chartjs-render-monitor{
  color: var(--vp-text) !important;
}

/* Make sure links stay visible */
html[data-theme="dark"] a{ color: var(--vp-link) !important; }

/* Switches / checkboxes */
html[data-theme="dark"] .form-check-input{
  background-color: rgba(255,255,255,.10) !important;
  border-color: var(--vp-border) !important;
}
html[data-theme="dark"] .form-check-input:checked{
  background-color: #4a8cff !important;
  border-color: #4a8cff !important;
}

/* Dark overrides for inline-styled widgets (applications / suggestions / lightbox) */
html[data-theme="dark"] #appThreadBox,
html[data-theme="dark"] #appEmojiPop,
html[data-theme="dark"] #playerSuggestions,
html[data-theme="dark"] .vp-chat-list{
  background: var(--vp-card) !important;
  border-color: var(--vp-border) !important;
  color: var(--vp-text) !important;
}
html[data-theme="dark"] #appReplyEmoji,
html[data-theme="dark"] #pnLightboxClose{
  background: rgba(255,255,255,.08) !important;
  border-color: var(--vp-border) !important;
  color: var(--vp-text) !important;
}

/* --- Hard darkmode overrides for pages that shipped with LIGHT-only CSS --- */
html[data-theme="dark"] .player-search-page .search-box{
  background: var(--vp-card) !important;
  border: 1px solid var(--vp-border) !important;
  box-shadow: var(--vp-shadow) !important;
}
html[data-theme="dark"] .player-search-page .search-input{
  background: var(--vp-input) !important;
  color: var(--vp-input-text) !important;
  box-shadow: inset 0 0 0 1px var(--vp-border) !important;
}
html[data-theme="dark"] .player-search-page .search-input::placeholder{ color: rgba(229,231,235,.55) !important; }
html[data-theme="dark"] .player-search-page .empty-state{ color: var(--vp-muted) !important; }
html[data-theme="dark"] .player-search-page .empty-state i{ color: var(--vp-link) !important; }

/* Apply/Thread: kill white surfaces */
html[data-theme="dark"] .vp-thread,
html[data-theme="dark"] .vp-thread-reply,
html[data-theme="dark"] .vp-thread-messages,
html[data-theme="dark"] .vp-form,
html[data-theme="dark"] .vp-select,
html[data-theme="dark"] .vp-select-menu,
html[data-theme="dark"] .vp-modal,
html[data-theme="dark"] .modal-content{
  background: var(--vp-card) !important;
  border-color: var(--vp-border) !important;
  color: var(--vp-text) !important;
}
html[data-theme="dark"] .vp-input,
html[data-theme="dark"] .vp-select-value{
  background: var(--vp-input) !important;
  color: var(--vp-input-text) !important;
  border-color: var(--vp-border) !important;
}

/* Emoji picker: prevent layout shift + keep it inside viewport */
.emoji-slot .emoji-picker-popup{
  left: auto !important;
  right: 0 !important;
  max-width: min(360px, calc(100vw - 40px)) !important;
}

/* Bootstrap modal close icon in dark mode */
html[data-theme="dark"] .modal .btn-close{ filter: invert(1) grayscale(100%) brightness(1.2); }

/* Make close buttons readable + consistent (fix white-on-white X in player actions) */
html[data-theme="dark"] .modal .btn-close,
html[data-theme="dark"] .btn-close{
  background-color: rgba(255,255,255,.10) !important;
  border-radius: 999px !important;
  padding: .6rem !important;
  opacity: .95 !important;
}

/* Patchnotes readability */
html[data-theme="dark"] .vp-patch-title,
html[data-theme="dark"] .vp-patch-meta,
html[data-theme="dark"] .vp-patch-content,
html[data-theme="dark"] .vp-patch-content *{
  color: var(--vp-text) !important;
}
html[data-theme="dark"] .pn-embed,
html[data-theme="dark"] .pn-embed-main{
  background: rgba(255,255,255,.03) !important;
  border-color: var(--vp-border) !important;
}
html[data-theme="dark"] .vp-patch-content a{ color: var(--vp-link) !important; }

/* Apply page: labels + helper texts */
html[data-theme="dark"] .vp-form-row label,
html[data-theme="dark"] .vp-form-hint,
html[data-theme="dark"] #applyStatus,
html[data-theme="dark"] .vp-search-meta{
  color: var(--vp-muted) !important;
}

/* Switches / checkboxes that showed up as white pills */
html[data-theme="dark"] .form-check-input,
html[data-theme="dark"] input[type="checkbox"],
html[data-theme="dark"] input[type="radio"]{
  background-color: rgba(255,255,255,.08) !important;
  border-color: var(--vp-border) !important;
}
html[data-theme="dark"] .form-check-input:checked,
html[data-theme="dark"] input[type="checkbox"]:checked,
html[data-theme="dark"] input[type="radio"]:checked{
  background-color: var(--vp-link) !important;
  border-color: var(--vp-link) !important;
}
html[data-theme="dark"] input[type="checkbox"],
html[data-theme="dark"] input[type="radio"]{
  accent-color: var(--vp-link);
}

/* ==========================
   ULTRA DARKMODE FINAL FIXES (v3)
   - Buttons, modals, message boxes, patchnotes/editor tables
   ========================== */

html[data-theme="dark"] .vp-btn{
  background: rgba(255,255,255,.07) !important;
  border-color: var(--vp-border) !important;
  color: var(--vp-text) !important;
  box-shadow: none !important;
}
html[data-theme="dark"] .vp-btn:hover{
  background: rgba(255,255,255,.10) !important;
  transform: translateY(-1px);
}

/* Keep primary buttons vivid but ensure text is always visible */
html[data-theme="dark"] .vp-btn-primary{ color:#fff !important; }

/* Modal header/title/close button */
html[data-theme="dark"] .vp-modal-title{ color: var(--vp-text) !important; }
html[data-theme="dark"] .vp-modal-head{ border-bottom-color: var(--vp-border) !important; }
html[data-theme="dark"] .vp-modal-close{
  background: rgba(255,255,255,.08) !important;
  border-color: var(--vp-border) !important;
  color: var(--vp-text) !important;
  box-shadow: none !important;
}

/* Application view modal: message + attachments */
html[data-theme="dark"] .vp-msg-box{
  background: var(--vp-input) !important;
  color: var(--vp-input-text) !important;
  border: 1px solid var(--vp-border) !important;
  border-radius: 12px !important;
  padding: 14px !important;
}
html[data-theme="dark"] .vp-attach-card{
  background: rgba(255,255,255,.04) !important;
  border: 1px solid var(--vp-border) !important;
  border-radius: 12px !important;
}
html[data-theme="dark"] .vp-attach-card *{ color: var(--vp-text) !important; }

/* Any remaining bootstrap-ish inputs that appear (forms in panels/modals) */
html[data-theme="dark"] .form-control,
html[data-theme="dark"] input.form-control,
html[data-theme="dark"] textarea.form-control,
html[data-theme="dark"] select.form-control{
  background: var(--vp-input) !important;
  color: var(--vp-input-text) !important;
  border-color: var(--vp-border) !important;
}
html[data-theme="dark"] .form-control::placeholder{ color: rgba(229,231,235,.55) !important; }

/* Patchnotes editor/list tables: kill light borders */
html[data-theme="dark"] .discord-card table tr{ border-top-color: var(--vp-border) !important; }
html[data-theme="dark"] .discord-card table thead tr{ opacity: .85 !important; }
html[data-theme="dark"] .discord-card table th,
html[data-theme="dark"] .discord-card table td{ color: var(--vp-text) !important; }

/* Custom checkbox label used in patchnotes editor */
html[data-theme="dark"] .vp-check{
  color: var(--vp-text) !important;
}
html[data-theme="dark"] .vp-check input{
  accent-color: var(--vp-link);
  background: rgba(255,255,255,.08) !important;
  border-color: var(--vp-border) !important;
}

/* Tabs (Stats/Admin Tools/Discordbot) when inactive should not be white */
html[data-theme="dark"] .vp-pill-tabs .vp-pill{
  background: rgba(255,255,255,.06) !important;
  border: 1px solid var(--vp-border) !important;
  color: var(--vp-text) !important;
}
html[data-theme="dark"] .vp-pill-tabs .vp-pill.active{
  background: linear-gradient(120deg,#1e70ff,#57c2ff) !important;
  border: 0 !important;
  color: #fff !important;
}


/* =========================
   V4: Final polish fixes
   - Accept/Reject colors
   - Application message wrapping
   - Dark preloader overlay
   ========================= */

/* Accept / Reject buttons distinct colors (all pages) */
html[data-theme="dark"] .vp-action.accept,
html[data-theme="dark"] button.vp-action.accept{
  background: rgba(46, 204, 113, .18) !important;
  color: #d9ffe9 !important;
  border: 1px solid rgba(46, 204, 113, .35) !important;
}
html[data-theme="dark"] .vp-action.accept:hover,
html[data-theme="dark"] button.vp-action.accept:hover{
  background: rgba(46, 204, 113, .28) !important;
}

html[data-theme="dark"] .vp-action.reject,
html[data-theme="dark"] button.vp-action.reject{
  background: rgba(231, 76, 60, .18) !important;
  color: #ffe2de !important;
  border: 1px solid rgba(231, 76, 60, .35) !important;
}
html[data-theme="dark"] .vp-action.reject:hover,
html[data-theme="dark"] button.vp-action.reject:hover{
  background: rgba(231, 76, 60, .28) !important;
}

/* If accept/reject are plain buttons without vp-action */
html[data-theme="dark"] button.vp-accept{ 
  background: rgba(46, 204, 113, .18) !important;
  color: #d9ffe9 !important;
  border: 1px solid rgba(46, 204, 113, .35) !important;
}
html[data-theme="dark"] button.vp-reject{ 
  background: rgba(231, 76, 60, .18) !important;
  color: #ffe2de !important;
  border: 1px solid rgba(231, 76, 60, .35) !important;
}

/* Application message boxes should wrap, never overflow */
.vp-ticket-message,
.vp-msg-box{
  max-width: 100% !important;
  white-space: pre-wrap !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
}

/* Also wrap chat bubbles / conversations */
.vp-chat .vp-bubble,
.vp-chat .vp-message,
.vp-chat .vp-line,
.vp-attach-card{
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
}

/* Theme transition (do not touch preloader/progress bars) */
html, body,
.discord-card,
.vp-card,
.vp-ticket-card,
.vp-modal,
.vp-tabs .nav-link,
.vp-select,
.vp-input,
.vp-chat-msg{
  transition: background-color .18s ease, color .18s ease, border-color .18s ease, box-shadow .18s ease;
}

/* Social icon sizing: keep FA + SVG identical */
.vp-social-card .vp-social-icon,
.vp-social-card .vp-social-icon i,
.vp-social-card .vp-social-icon svg{
  width: 22px !important;
  height: 22px !important;
  font-size: 22px !important;
  line-height: 22px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* SVG viewBox padding compensation (so TikTok matches FA visually) */
.vp-social-card .vp-social-icon svg{
  transform: translateY(0px) scale(0.92);
  transform-origin: center;
}





/* Action buttons (Accept / Reject) - consistent in Light + Dark */
.vp-action.accept{
  background: #16a34a !important;
  color: #fff !important;
  border: 1px solid rgba(0,0,0,0.10) !important;
}
.vp-action.accept:hover{ filter: brightness(1.05); }

.vp-action.reject{
  background: #dc2626 !important;
  color: #fff !important;
  border: 1px solid rgba(0,0,0,0.10) !important;
}
.vp-action.reject:hover{ filter: brightness(1.05); }



/* Message wrapping (prevent overflow on long strings) */
.vp-msg-box, .vp-ticket-message, .vp-conversation .message, .vp-thread-message{
  white-space: pre-wrap !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  max-width: 100% !important;
}


/* Smooth theme switching (do NOT touch loader/progress bar) */
html, body,
.discord-card, .vp-card, .vp-modal, .modal-content,
.vp-tabs .nav-link, .vp-ticket-card, .vp-chat-msg{
  transition: background-color .18s ease, color .18s ease, border-color .18s ease, box-shadow .18s ease;
}

/* Social icons: force same visual size for FA + SVG */
.vp-social-card .vp-social-icon,
.vp-social-card .vp-social-icon i,
.vp-social-card .vp-social-icon svg{
  width: 22px !important;
  height: 22px !important;
  font-size: 22px !important;
  line-height: 22px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.vp-social-card .vp-social-icon svg{
  transform-origin: center;
  transform: scale(0.92);
}


/* Online pill (header + cards) */
.vp-online-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.10);
  color: var(--vp-text, #fff);
  font-weight:600;
  font-size:14px;
  white-space:nowrap;
}
body.light-mode .vp-online-pill{
  background: rgba(0,0,0,.04);
  border-color: rgba(0,0,0,.08);
  color: #0b1220;
}
.vp-online-pill--card{ padding:8px 12px; font-size:13px; }
.vp-online-label{ opacity:.9; font-weight:600; }

/* Header theme toggle button */
.vp-theme-toggle-btn{
  width:40px;
  height:40px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.08);
  color: var(--vp-text, #fff);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
body.light-mode .vp-theme-toggle-btn{
  background: rgba(0,0,0,.04);
  border-color: rgba(0,0,0,.10);
  color:#0b1220;
}
.vp-theme-toggle-btn i{font-size:15px;}
.vp-online-dot{
  width:10px; height:10px;
  border-radius:50%;
  background:#2ecc71;
  box-shadow: 0 0 0 0 rgba(46,204,113,.55);
  animation: vpPulseOnline 1.35s infinite;
  flex:0 0 auto;
}
@keyframes vpPulseOnline{
  0%{ box-shadow:0 0 0 0 rgba(46,204,113,.55); }
  70%{ box-shadow:0 0 0 10px rgba(46,204,113,0); }
  100%{ box-shadow:0 0 0 0 rgba(46,204,113,0); }
}
.vp-card-topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:10px;
}
@media (max-width: 992px){
  .vp-online-pill{ display:none; } /* keep header clean on mobile */
  .vp-online-pill--card{ display:inline-flex; }
}


/* Stronger status badges (Applications Panel) */
.vp-ticket-status { font-weight:700; letter-spacing:.6px; padding:6px 12px; border-radius:999px; font-size:12px; text-transform:uppercase; border:1px solid rgba(255,255,255,.14); }
html[data-theme="light"] .vp-ticket-status { border-color: rgba(0,0,0,.12); }

.vp-ticket-status.accepted { background: rgba(34,197,94,.38); color: #d1fae5; border-color: rgba(34,197,94,.55); }
.vp-ticket-status.rejected { background: rgba(239,68,68,.38); color: #fee2e2; border-color: rgba(239,68,68,.55); }
.vp-ticket-status.open { background: rgba(59,130,246,.16); color: #3b82f6; border-color: rgba(59,130,246,.35); }
.vp-ticket-status.investigating { background: rgba(245,158,11,.18); color: #f59e0b; border-color: rgba(245,158,11,.35); }
.vp-ticket-status.resolved { background: rgba(168,85,247,.18); color: #a855f7; border-color: rgba(168,85,247,.35); }

html[data-theme="light"] .vp-ticket-status.accepted { background: rgba(34,197,94,.28); color: #065f46; border-color: rgba(34,197,94,.55); }
html[data-theme="light"] .vp-ticket-status.rejected { background: rgba(239,68,68,.28); color: #7f1d1d; border-color: rgba(239,68,68,.55); }
html[data-theme="light"] .vp-ticket-status.open { background: rgba(59,130,246,.10); }
html[data-theme="light"] .vp-ticket-status.investigating { background: rgba(245,158,11,.10); }
html[data-theme="light"] .vp-ticket-status.resolved { background: rgba(168,85,247,.10); }

/* Mobile: keep badges readable */
@media (max-width: 576px){
  .vp-ticket-status{ font-size:11px; padding:6px 10px; }
}

/* Status pills (Apply) */
.vp-pill.vp-pill--accepted{ background: rgba(34,197,94,.20); color:#22c55e; border:1px solid rgba(34,197,94,.35); }
.vp-pill.vp-pill--rejected{ background: rgba(239,68,68,.20); color:#ef4444; border:1px solid rgba(239,68,68,.35); }
.vp-pill.vp-pill--open{ background: rgba(59,130,246,.18); color:#3b82f6; border:1px solid rgba(59,130,246,.35); }
.vp-pill.vp-pill--investigating{ background: rgba(245,158,11,.20); color:#f59e0b; border:1px solid rgba(245,158,11,.35); }
.vp-pill.vp-pill--resolved{ background: rgba(168,85,247,.20); color:#a855f7; border:1px solid rgba(168,85,247,.35); }
html[data-theme="light"] .vp-pill.vp-pill--accepted{ background: rgba(34,197,94,.12); }
html[data-theme="light"] .vp-pill.vp-pill--rejected{ background: rgba(239,68,68,.12); }

/* ===== v21 Dropdown consistency (Community / User / Moderator) ===== */
.navbar .dropdown-menu{
  background: var(--vp-card, rgba(16,26,43,.96)) !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 18px !important;
  padding: 10px !important;
  min-width: 240px;
  box-shadow: 0 18px 45px rgba(0,0,0,.35) !important;
}
html[data-theme="light"] .navbar .dropdown-menu{
  background: #ffffff !important;
  border-color: rgba(0,0,0,.08) !important;
  box-shadow: 0 18px 45px rgba(0,0,0,.10) !important;
}

.navbar .dropdown-menu .dropdown-item,
.navbar .dropdown-menu a.dropdown-item,
.navbar .dropdown-menu button.dropdown-item{
  width: 100%;
  display: flex !important;
  align-items: center;
  justify-content: flex-start !important;
  gap: 10px;
  padding: 12px 14px !important;
  border-radius: 14px !important;
  margin: 2px 0 !important;
  font-weight: 600;
  letter-spacing: .2px;
  text-align: left !important;
  text-indent: 0 !important;
  white-space: nowrap;
  color: rgba(255,255,255,.92) !important;
}
html[data-theme="light"] .navbar .dropdown-menu .dropdown-item,
html[data-theme="light"] .navbar .dropdown-menu a.dropdown-item,
html[data-theme="light"] .navbar .dropdown-menu button.dropdown-item{
  color: rgba(15,23,42,.92) !important;
}

.navbar .dropdown-menu .dropdown-item:hover,
.navbar .dropdown-menu .dropdown-item:focus{
  background: rgba(59,130,246,.16) !important;
}
html[data-theme="light"] .navbar .dropdown-menu .dropdown-item:hover,
html[data-theme="light"] .navbar .dropdown-menu .dropdown-item:focus{
  background: rgba(59,130,246,.10) !important;
}

.navbar .dropdown-menu .dropdown-divider{
  margin: 8px 4px !important;
  border-top: 1px solid rgba(255,255,255,.10) !important;
}
html[data-theme="light"] .navbar .dropdown-menu .dropdown-divider{
  border-top-color: rgba(0,0,0,.08) !important;
}

/* Remove any accidental per-item padding overrides that caused "Contact" shift */
.navbar .dropdown-menu .dropdown-item *{ margin-left: 0 !important; }

/* Emoji rendering reliability across browsers/OS */
body, button, input, textarea {
  font-family: inherit, "Poppins", system-ui, -apple-system, "Segoe UI", Roboto, Arial,
    "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji";
}
