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

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#141414;
  --surface:#1e1e1e;
  --surface2:#252525;
  --surface3:#2e2e2e;
  --border:#2f2f2f;
  --border2:#3a3a3a;
  --text:#c8c8c8;
  --text-muted:#7a7a7a;
  --text-dim:#484848;
  --btn:#2a2a2a;
  --btn-hover:#353535;
  --btn-border:#404040;
  --accent:#585858;
  --green:#4ec994;
  --red:#d05c5c;
  --radius:7px;
  --radius-sm:5px;
  --mono:'JetBrains Mono','Courier New',monospace;
  --sidebar:200px;
}

html,body{height:100%;font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);-webkit-user-select:none;user-select:none;}
.exec-textarea,.exec-output,.modal-val,.key-table td:first-child,.profile-dn-row input,.auth-form input,.profile-row input{-webkit-user-select:text;user-select:text;}
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:#303030;border-radius:2px;}

/* ===== AUTH ===== */
.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;}
.auth-wrapper{width:100%;display:flex;justify-content:center;}
.auth-card{
  background:var(--surface);border:1px solid var(--border);border-radius:12px;
  padding:34px 30px 30px;width:100%;max-width:390px;
  display:flex;flex-direction:column;align-items:center;gap:2px;overflow:hidden;
}
.auth-logo{width:68px;height:68px;object-fit:contain;border-radius:10px;margin-bottom:12px;}
.auth-brand{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.5px;}
.auth-sub{font-size:10px;font-weight:600;letter-spacing:2px;color:var(--text-dim);margin:5px 0 16px;}
.auth-panels{width:100%;position:relative;overflow:hidden;transition:height .36s cubic-bezier(.4,0,.2,1);}
.auth-panel{width:100%;transition:transform .36s cubic-bezier(.4,0,.2,1),opacity .26s ease;will-change:transform,opacity;}
#panelRegister{transform:translateX(0);opacity:1;}
#panelLogin{position:absolute;top:0;left:0;width:100%;transform:translateX(110%);opacity:0;pointer-events:none;}
.auth-panels.show-login #panelRegister{transform:translateX(-110%);opacity:0;pointer-events:none;}
.auth-panels.show-login #panelLogin{transform:translateX(0);opacity:1;pointer-events:all;position:relative;}
.auth-form{width:100%;display:flex;flex-direction:column;}
.auth-form label{font-size:9.5px;font-weight:600;letter-spacing:1.4px;color:var(--text-muted);margin:13px 0 5px;display:block;}
.auth-form label:first-child{margin-top:0;}
.auth-form input{
  width:100%;background:#191919;border:1px solid var(--border2);border-radius:var(--radius-sm);
  padding:10px 12px;color:var(--text);font-family:'Inter',sans-serif;font-size:13px;outline:none;transition:border-color .15s;
}
.auth-form input:focus{border-color:var(--accent);}
.auth-form input::placeholder{color:var(--text-dim);}
.btn-primary{
  background:var(--btn);color:var(--text);border:1px solid var(--btn-border);
  border-radius:var(--radius-sm);padding:10px 16px;font-family:'Inter',sans-serif;
  font-size:13px;font-weight:500;cursor:pointer;transition:background .13s,border-color .13s;
  margin-top:16px;width:100%;display:inline-flex;align-items:center;justify-content:center;gap:6px;
}
.btn-primary:hover{background:var(--btn-hover);border-color:var(--accent);}
.btn-secondary{
  background:transparent;color:var(--text-muted);border:1px solid var(--border2);
  border-radius:var(--radius-sm);padding:10px 16px;font-family:'Inter',sans-serif;
  font-size:13px;font-weight:500;cursor:pointer;transition:all .13s;
  display:inline-flex;align-items:center;gap:6px;
}
.btn-secondary:hover{background:var(--surface2);color:var(--text);}
.auth-switch{margin-top:14px;text-align:center;font-size:12.5px;color:var(--text-muted);}
.auth-switch a{color:var(--text);text-decoration:none;font-weight:500;}
.auth-switch a:hover{text-decoration:underline;}
.error-msg{color:var(--red);font-size:11.5px;min-height:15px;margin-top:6px;}

/* ===== DASHBOARD LAYOUT ===== */
.dash-page{display:flex;min-height:100vh;}
.sidebar{
  width:var(--sidebar);min-width:var(--sidebar);
  background:var(--surface);border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;height:100vh;overflow-y:auto;
}
.sidebar-top{padding:18px 12px 0;}
.sidebar-brand{font-size:17px;font-weight:700;color:var(--text);margin-bottom:12px;}
.tag-logged{display:block;font-size:9px;font-weight:600;letter-spacing:1.5px;color:var(--text-dim);margin-bottom:3px;}
.tag-username{display:block;font-size:12px;font-weight:600;color:var(--text-muted);word-break:break-all;}
.tag-admin{
  display:inline-block;background:rgba(175,50,40,.12);border:1px solid rgba(175,50,40,.25);
  color:#c06060;font-size:8.5px;font-weight:700;letter-spacing:1.5px;
  border-radius:3px;padding:2px 6px;margin-top:6px;
}
.sidebar-nav{flex:1;margin-top:14px;display:flex;flex-direction:column;gap:1px;padding:0 5px;}
.nav-item{
  display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:5px;
  font-size:12.5px;font-weight:500;color:var(--text-muted);cursor:pointer;
  text-decoration:none;transition:background .11s,color .11s;user-select:none;
}
.nav-item:hover,.nav-item.active{background:var(--surface2);color:var(--text);}
.nav-admin:hover,.nav-admin.active{background:rgba(175,50,40,.09);color:#c06060;}
.logout:hover{background:rgba(200,70,70,.07);color:var(--red);}
.nav-icon{width:14px;height:14px;object-fit:contain;filter:brightness(.5);flex-shrink:0;}
.nav-item:hover .nav-icon,.nav-item.active .nav-icon{filter:brightness(.9);}
.nav-admin .nav-icon{filter:brightness(.5) sepia(1) saturate(1.5) hue-rotate(-20deg) opacity(.7);}
.nav-admin:hover .nav-icon,.nav-admin.active .nav-icon{filter:brightness(1) sepia(1) saturate(2) hue-rotate(-20deg);}
.nav-icon-svg{width:14px;height:14px;flex-shrink:0;opacity:.45;}
.nav-item:hover .nav-icon-svg,.nav-item.active .nav-icon-svg{opacity:.9;}
.sidebar-footer{padding:8px 5px 14px;border-top:1px solid var(--border);margin-top:12px;display:flex;flex-direction:column;gap:6px;}
.sidebar-profile-row{display:flex;align-items:center;gap:9px;padding:6px 6px 0;}
.sidebar-avatar-wrap{width:30px;height:30px;flex-shrink:0;}
.sidebar-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;}
.sidebar-avatar-placeholder{width:30px;height:30px;border-radius:50%;background:var(--surface3);display:flex;align-items:center;justify-content:center;color:var(--text-dim);}
.sidebar-avatar-placeholder svg{width:16px;height:16px;}
.sidebar-profile-info{display:flex;flex-direction:column;gap:1px;overflow:hidden;}
.sidebar-displayname{font-size:11.5px;font-weight:600;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sidebar-version{font-size:9.5px;color:var(--text-dim);}

/* ===== MAIN ===== */
.main-content{margin-left:var(--sidebar);flex:1;padding:28px 34px;min-height:100vh;}
.section{display:none;animation:fadeSlide .2s ease;}
.section.active{display:block;}
@keyframes fadeSlide{from{opacity:0;transform:translateY(4px);}to{opacity:1;transform:none;}}
.section-header{margin-bottom:20px;}
.section-header h1{font-size:19px;font-weight:600;color:var(--text);}

/* ===== GAMES ===== */
.games-header{margin-bottom:16px;}
.games-title-row{display:flex;align-items:baseline;gap:12px;margin-bottom:12px;}
.games-title-row h1{font-size:19px;font-weight:600;color:var(--text);}
.games-stats{font-size:11.5px;color:var(--text-dim);}
.games-tabs{display:flex;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:3px;width:fit-content;}
.gtab{background:transparent;border:none;color:var(--text-muted);font-family:'Inter',sans-serif;font-size:12px;font-weight:500;padding:5px 14px;border-radius:4px;cursor:pointer;transition:all .13s;}
.gtab:hover{color:var(--text);}
.gtab.active{background:var(--surface3);color:var(--text);}
.games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:14px;margin-top:14px;}
.game-card{background:var(--surface);border:1px solid var(--border);border-radius:9px;overflow:hidden;transition:border-color .14s,transform .14s;}
.game-card:hover{border-color:var(--border2);transform:translateY(-2px);}
.game-thumb-wrap{position:relative;padding-top:60%;overflow:hidden;background:#111;}
.game-thumb{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s;}
.game-card:hover .game-thumb{transform:scale(1.03);}
.game-active-badge{
  position:absolute;top:8px;right:8px;
  background:rgba(10,10,10,.88);backdrop-filter:blur(4px);
  border:1px solid var(--border2);border-radius:4px;
  padding:3px 8px;font-size:11px;color:var(--green);font-weight:600;
  display:flex;align-items:center;gap:5px;
}
.g-dot{width:5px;height:5px;background:var(--green);border-radius:50%;flex-shrink:0;animation:blink 2s infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:.3;}}
.game-vuln-badge{
  position:absolute;bottom:8px;left:8px;
  background:rgba(160,40,40,.88);border:1px solid rgba(200,80,80,.3);
  border-radius:3px;padding:2px 7px;font-size:10px;color:#ffb0b0;font-weight:600;
}
.game-body{padding:13px 14px 14px;}
.game-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.game-meta{font-size:11px;color:var(--text-muted);margin-bottom:10px;}
.game-actions{display:flex;gap:6px;}
.game-btn-join{
  flex:1;background:var(--btn);color:var(--text);border:1px solid var(--btn-border);
  border-radius:4px;padding:8px 0;font-family:'Inter',sans-serif;font-size:12px;font-weight:500;cursor:pointer;transition:all .13s;
}
.game-btn-join:hover{background:var(--btn-hover);border-color:var(--accent);}
.game-btn-info{
  background:transparent;color:var(--text-muted);border:1px solid var(--border2);
  border-radius:4px;padding:8px 14px;font-family:'Inter',sans-serif;font-size:12px;cursor:pointer;transition:all .13s;
}
.game-btn-info:hover{background:var(--surface2);color:var(--text);}

/* ===== EXECUTOR ===== */
.exec-layout{display:flex;flex-direction:column;gap:0;}

.exec-tabs-bar{
  display:flex;align-items:stretch;
  background:var(--surface2);border:1px solid var(--border);border-bottom:none;
  border-radius:var(--radius) var(--radius) 0 0;
  padding:5px 6px 0;gap:2px;overflow-x:auto;min-height:38px;
}
.exec-tabs-list{display:flex;gap:2px;flex:1;}
.exec-tab{
  display:flex;align-items:center;gap:6px;flex-shrink:0;
  background:transparent;border:1px solid transparent;border-bottom:none;
  border-radius:5px 5px 0 0;color:var(--text-muted);
  font-family:'Inter',sans-serif;font-size:12px;padding:5px 12px;
  cursor:pointer;transition:all .11s;white-space:nowrap;user-select:none;
}
.exec-tab:hover{color:var(--text);background:rgba(255,255,255,.04);}
.exec-tab.active{background:var(--bg);color:var(--text);border-color:var(--border);}
.tab-name{}
.tab-rename-input{
  background:transparent;border:none;border-bottom:1px solid var(--accent);
  color:var(--text);font-family:'Inter',sans-serif;font-size:12px;
  outline:none;width:80px;padding:0 2px;-webkit-user-select:text;user-select:text;
}
.exec-tab-close{
  width:14px;height:14px;border-radius:2px;font-size:12px;line-height:1;
  color:var(--text-dim);background:transparent;border:none;cursor:pointer;
  padding:0;display:flex;align-items:center;justify-content:center;transition:all .1s;
}
.exec-tab-close:hover{background:rgba(255,255,255,.08);color:var(--text);}
.exec-newtab{
  background:transparent;border:none;color:var(--text-dim);
  font-size:20px;cursor:pointer;padding:0 8px 3px;line-height:1;
  transition:color .11s;flex-shrink:0;align-self:center;
}
.exec-newtab:hover{color:var(--text);}

/* the actual textarea editor */
.exec-textarea{
  width:100%;
  height:360px;
  background:#161616;
  color:#c8c8c8;
  border:1px solid var(--border);
  border-top:none;
  border-bottom:none;
  border-radius:0;
  padding:14px 16px;
  font-family:var(--mono);
  font-size:13px;
  line-height:1.7;
  outline:none;
  resize:none;
  display:block;
  tab-size:4;
  -moz-tab-size:4;
  caret-color:#bbb;
  -webkit-user-select:text;
  user-select:text;
  overflow-y:auto;
}
.exec-textarea::placeholder{color:#484848;}
.exec-textarea:focus{border-color:var(--border);}

.exec-actions{
  display:flex;align-items:center;gap:7px;
  padding:8px 0 6px;
  border:1px solid var(--border);border-top:none;border-bottom:none;
  padding-left:0;
}
/* undo the border trick — just use gap */
.exec-actions{border:none;padding:8px 0 6px;}

.btn-exec{
  background:var(--btn);color:var(--text);border:1px solid var(--btn-border);
  border-radius:var(--radius-sm);padding:8px 16px;font-family:'Inter',sans-serif;
  font-size:13px;font-weight:500;cursor:pointer;transition:all .12s;
  display:inline-flex;align-items:center;gap:6px;
}
.btn-exec svg{width:11px;height:11px;}
.btn-exec:hover{background:var(--btn-hover);border-color:var(--accent);}

.btn-clear-exec{
  background:transparent;color:var(--text-muted);border:1px solid var(--border2);
  border-radius:var(--radius-sm);padding:8px 14px;font-family:'Inter',sans-serif;
  font-size:13px;font-weight:500;cursor:pointer;transition:all .12s;
}
.btn-clear-exec:hover{background:rgba(200,70,70,.08);color:var(--red);border-color:rgba(200,70,70,.3);}

.btn-hide-exec,.btn-copy-exec{
  background:transparent;color:var(--text-muted);border:1px solid var(--border2);
  border-radius:var(--radius-sm);padding:8px 14px;font-family:'Inter',sans-serif;
  font-size:13px;font-weight:500;cursor:pointer;transition:all .12s;
}
.btn-hide-exec:hover,.btn-copy-exec:hover{background:var(--surface2);color:var(--text);}

.exec-output{
  background:#111;border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);
  padding:10px 14px;font-family:var(--mono);font-size:12px;color:var(--text-muted);
  min-height:44px;white-space:pre-wrap;word-break:break-word;line-height:1.6;
  -webkit-user-select:text;user-select:text;
}

/* ===== PROFILE ===== */
.profile-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;max-width:420px;display:flex;flex-direction:column;gap:18px;
}
.profile-avatar-section{display:flex;align-items:center;gap:16px;}
.profile-avatar-wrap{position:relative;width:68px;height:68px;cursor:pointer;flex-shrink:0;border-radius:50%;overflow:hidden;}
.profile-avatar-img{width:68px;height:68px;border-radius:50%;object-fit:cover;display:block;}
.profile-avatar-ph{width:68px;height:68px;border-radius:50%;background:var(--surface3);display:flex;align-items:center;justify-content:center;color:var(--text-dim);}
.profile-avatar-ph svg{width:28px;height:28px;}
.avatar-overlay{
  position:absolute;inset:0;border-radius:50%;
  background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;
  font-size:9px;font-weight:600;color:#fff;letter-spacing:.5px;opacity:0;transition:opacity .14s;
}
.profile-avatar-wrap:hover .avatar-overlay{opacity:1;}
.profile-names{display:flex;flex-direction:column;gap:7px;flex:1;}
.profile-username-val{font-size:17px;font-weight:600;color:var(--text);}
.profile-dn-row{display:flex;gap:5px;}
.profile-dn-row input{
  flex:1;background:#191919;border:1px solid var(--border2);border-radius:var(--radius-sm);
  padding:7px 10px;color:var(--text);font-family:'Inter',sans-serif;font-size:12.5px;outline:none;transition:border-color .14s;
}
.profile-dn-row input:focus{border-color:var(--accent);}
.profile-dn-row input::placeholder{color:var(--text-dim);}
.btn-save-dn{
  background:var(--btn);color:var(--text-muted);border:1px solid var(--btn-border);
  border-radius:var(--radius-sm);padding:7px 11px;font-family:'Inter',sans-serif;
  font-size:11.5px;cursor:pointer;transition:all .12s;white-space:nowrap;
}
.btn-save-dn:hover{background:var(--btn-hover);color:var(--text);}
.profile-divider{height:1px;background:var(--border);}
.profile-row label{display:block;font-size:9.5px;font-weight:600;letter-spacing:1.4px;color:var(--text-muted);margin-bottom:7px;}
.profile-row input{
  width:100%;background:#191919;border:1px solid var(--border2);border-radius:var(--radius-sm);
  padding:9px 11px;color:var(--text);font-family:'Inter',sans-serif;font-size:13px;outline:none;transition:border-color .14s;
}
.profile-row input:focus{border-color:var(--accent);}

/* ===== ADMIN ===== */
.admin-hero{display:flex;align-items:center;gap:14px;padding:18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;}
.admin-hero-logo{width:44px;height:44px;object-fit:contain;border-radius:7px;flex-shrink:0;}
.admin-hero-text h1{font-size:18px;font-weight:600;color:var(--text);margin-bottom:2px;}
.admin-hero-text p{font-size:12px;color:var(--text-muted);}
.admin-bar{display:flex;align-items:center;gap:7px;margin-bottom:13px;}
.key-count{font-size:11.5px;color:var(--text-dim);margin-left:4px;}
.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}
.key-table{width:100%;border-collapse:collapse;font-size:12px;}
.key-table thead th{background:var(--surface2);color:var(--text-muted);font-weight:600;font-size:9.5px;letter-spacing:1px;text-transform:uppercase;padding:9px 14px;text-align:left;border-bottom:1px solid var(--border);}
.key-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s;}
.key-table tbody tr:last-child{border-bottom:none;}
.key-table tbody tr:hover{background:var(--surface2);}
.key-table td{padding:9px 14px;color:var(--text-muted);vertical-align:middle;}
.key-table td:first-child{color:var(--text);font-family:var(--mono);font-size:11px;}
.status-avail{color:var(--green);font-weight:600;}
.status-used{color:var(--text-dim);}
.copy-btn{background:var(--btn);color:var(--text-muted);border:1px solid var(--btn-border);border-radius:4px;padding:4px 11px;font-size:11px;cursor:pointer;transition:all .11s;font-family:'Inter',sans-serif;}
.copy-btn:hover{background:var(--btn-hover);color:var(--text);}
.copy-btn.copied{color:var(--green);border-color:var(--green);}

/* ===== MODAL ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.72);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity .18s;padding:20px;}
.modal-overlay.open{opacity:1;pointer-events:all;}
.modal{background:var(--surface);border:1px solid var(--border2);border-radius:10px;max-width:460px;width:100%;max-height:80vh;overflow-y:auto;transform:translateY(6px) scale(.98);transition:transform .2s;position:relative;}
.modal-overlay.open .modal{transform:none;}
.modal-close{position:sticky;top:0;float:right;margin:10px 10px 0 0;background:var(--surface2);border:1px solid var(--border);border-radius:4px;color:var(--text-muted);font-size:16px;cursor:pointer;width:26px;height:26px;display:flex;align-items:center;justify-content:center;transition:all .11s;z-index:1;}
.modal-close:hover{background:var(--surface3);color:var(--text);}
.modal-content{padding:18px 20px 20px;clear:both;}
.modal-content h2{font-size:15px;font-weight:600;color:var(--text);margin-bottom:12px;}
.modal-row{display:flex;justify-content:space-between;align-items:flex-start;padding:6px 0;border-bottom:1px solid var(--border);font-size:12px;}
.modal-row:last-child{border-bottom:none;}
.modal-key{color:var(--text-muted);flex-shrink:0;}
.modal-val{color:var(--text);font-weight:500;text-align:right;max-width:60%;}
.modal-section-title{font-size:9px;font-weight:600;letter-spacing:1.3px;color:var(--text-dim);margin:12px 0 5px;text-transform:uppercase;}

/* ===== TOAST ===== */
.toast{position:fixed;bottom:18px;right:18px;background:var(--surface2);border:1px solid var(--border2);color:var(--text);padding:9px 16px;border-radius:var(--radius);font-size:12.5px;z-index:9999;opacity:0;transform:translateY(5px);transition:opacity .17s,transform .17s;pointer-events:none;}
.toast.show{opacity:1;transform:none;}
