/* ============================================================
   MYTHICSTASH — SHARED STYLES
   Loaded by every page (index.html, profile.html, and every
   game-*.html page). Editing this file changes the look
   everywhere at once.
   ============================================================ */

:root{
  --bg:#11131F;
  --bg-elevated:#1A1D2E;
  --bg-elevated-2:#222538;
  --border:#2A2E45;
  --border-soft:#1F2233;
  --blue:#4F8EF7;
  --blue-dim:#3D74D6;
  --blue-soft:#1B2A4A;
  --teal:#3DD9C4;
  --teal-soft:#163530;
  --red:#F1554C;
  --red-soft:#2E1C1C;
  --text:#EEF0F7;
  --text-dim:#A2A6C2;
  --text-faint:#666A8A;
  --radius:10px;
  --radius-lg:16px;
  --shadow: 0 8px 24px rgba(0,0,0,0.4);
  --gap-page: 16px;
  --header-h: 56px;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',sans-serif;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
::selection{background:var(--blue); color:#0A0E1A;}
a{color:inherit; text-decoration:none;}
button{font-family:inherit; cursor:pointer;}
.hidden{display:none !important;}

h1,h2,h3,h4{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;
  letter-spacing:0.01em;
  margin:0;
  text-transform:uppercase;
}
.mono{font-family:'JetBrains Mono',monospace;}

/* ============================================================
   HEADER — hamburger | logo+search | profile+basket
   Mobile: two rows if logo is shown (logo row, then search row
   below it, full width). Desktop: everything in one row.
   ============================================================ */
.topbar{
  position:sticky; top:0; z-index:40;
  background:rgba(17,19,31,0.96);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--border-soft);
}
.topbar-inner{
  max-width:1280px; margin:0 auto;
  padding:10px var(--gap-page);
}
.topbar-row1{
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
}

.hamburger-btn{
  width:38px; height:38px; border-radius:8px; background:transparent;
  border:1px solid var(--border-soft); color:var(--text-dim); display:flex; align-items:center;
  justify-content:center; flex-shrink:0; padding:0;
}
.hamburger-btn:hover{border-color:var(--blue-dim); color:var(--blue); background:var(--bg-elevated);}

.desktop-nav{display:none; align-items:center; gap:2px; flex-shrink:0;}
.desktop-nav-link{
  display:flex; align-items:center; gap:7px; padding:8px 12px; border-radius:8px;
  color:var(--text-dim); font-size:13.5px; font-weight:600; background:transparent; border:none;
  white-space:nowrap;
}
.desktop-nav-link:hover{color:var(--text); background:var(--bg-elevated);}
.desktop-nav-link.active{color:var(--blue); background:var(--blue-soft);}
.desktop-nav-link svg{flex-shrink:0; width:16px; height:16px;}

.brand{display:flex; align-items:center; gap:8px; cursor:pointer; min-width:0; flex-shrink:0;}
.brand-mark{
  width:30px; height:30px; border-radius:8px;
  background:linear-gradient(160deg, var(--blue) 0%, var(--blue-dim) 100%);
  display:flex; align-items:center; justify-content:center;
  color:#0A0E1A; font-family:'Barlow Condensed'; font-weight:800; font-size:16px;
  flex-shrink:0;
}
.brand-name{font-size:16px; letter-spacing:0.01em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.brand-name span{color:var(--blue);}

.header-icons{display:flex; align-items:center; gap:8px; flex-shrink:0; margin-left:auto;}
.icon-btn{
  position:relative;
  width:38px; height:38px; border-radius:50%; background:var(--bg-elevated);
  border:1px solid var(--border); color:var(--text-dim); display:flex; align-items:center;
  justify-content:center; flex-shrink:0; padding:0;
}
.icon-btn:hover{border-color:var(--blue-dim); color:var(--blue);}
.icon-btn.signed-in{background:var(--blue-soft); border-color:var(--blue-dim); color:var(--blue);}
.icon-btn .badge{
  position:absolute; top:-4px; right:-4px; min-width:17px; height:17px; border-radius:9px;
  background:var(--blue); color:#0A0E1A; font-size:10px; font-weight:700; font-family:'JetBrains Mono';
  display:flex; align-items:center; justify-content:center; padding:0 4px; border:2px solid var(--bg);
}

/* ---------- search ----------
   Mobile: forced to its own full-width second row, below the
   logo/icons row. Desktop: sits inline between nav and icons. */
.search-wrap{position:relative; flex-basis:100%; order:3; margin-top:10px;}
.search-input-row{
  display:flex; align-items:center; gap:8px; background:var(--bg-elevated);
  border:1px solid var(--border); border-radius:24px; padding:0 14px; height:38px;
}
.search-input-row svg{flex-shrink:0; color:var(--text-faint);}
.search-input-row input{
  flex:1; background:transparent; border:none; color:var(--text); font-size:14px;
  font-family:'Inter'; outline:none; min-width:0; height:100%; padding:0;
}
.search-input-row input::placeholder{color:var(--text-faint);}
.search-clear-btn{
  background:transparent; border:none; color:var(--text-faint); padding:2px; flex-shrink:0;
  display:flex; align-items:center;
}
.search-clear-btn:hover{color:var(--text);}

.search-results{
  position:absolute; top:calc(100% + 8px); left:0; right:0; z-index:50;
  background:var(--bg-elevated); border:1px solid var(--border); border-radius:var(--radius-lg);
  box-shadow:var(--shadow); max-height:min(70vh, 460px); overflow-y:auto;
}
.search-results-empty{padding:18px 16px; font-size:13px; color:var(--text-faint); text-align:center;}
.search-result-row{
  display:flex; align-items:center; gap:12px; padding:11px 14px; border-bottom:1px solid var(--border-soft);
}
.search-result-row:last-child{border-bottom:none;}
.search-result-row:hover{background:var(--bg-elevated-2);}
.search-result-info{flex:1; min-width:0;}
.search-result-name{font-size:13.5px; font-weight:600; font-family:'Inter'; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.search-result-game{font-size:11.5px; color:var(--text-faint); font-family:'JetBrains Mono'; margin-top:1px;}
.search-result-price{font-size:13px; color:var(--blue); font-family:'JetBrains Mono'; font-weight:600; flex-shrink:0;}

/* ============================================================
   HAMBURGER SIDE MENU (left)
   ============================================================ */
.side-menu-overlay{
  position:fixed; inset:0; background:rgba(8,9,15,0.65); z-index:90;
  opacity:0; pointer-events:none; transition:opacity .2s ease;
}
.side-menu-overlay.open{opacity:1; pointer-events:auto;}
.side-menu{
  position:fixed; top:0; left:0; bottom:0; width:280px; max-width:84vw;
  background:var(--bg-elevated); border-right:1px solid var(--border-soft); z-index:91;
  transform:translateX(-100%); transition:transform .22s ease;
  display:flex; flex-direction:column; overflow-y:auto;
}
.side-menu.open{transform:translateX(0);}
.side-menu-head{
  display:flex; align-items:center; justify-content:space-between; padding:16px;
  border-bottom:1px solid var(--border-soft);
}
.side-menu-close{background:transparent; border:none; color:var(--text-faint); font-size:22px; padding:4px;}
.side-menu-body{padding:8px;}
.side-menu-link{
  display:flex; align-items:center; gap:12px; padding:12px 12px; border-radius:8px;
  color:var(--text-dim); font-size:14.5px; font-weight:500; width:100%; text-align:left;
  background:transparent; border:none;
}
.side-menu-link:hover{background:var(--bg-elevated-2); color:var(--text);}
.side-menu-link svg{flex-shrink:0; color:var(--text-faint); width:19px; height:19px;}
.side-menu-link.active{color:var(--blue); background:var(--blue-soft);}
.side-menu-link.active svg{color:var(--blue);}
.side-menu-section-label{
  font-size:11px; color:var(--text-faint); text-transform:uppercase; letter-spacing:0.06em;
  padding:14px 12px 6px;
}

/* ============================================================
   BASKET DRAWER (right)
   ============================================================ */
.basket-overlay{
  position:fixed; inset:0; background:rgba(8,9,15,0.65); z-index:90;
  opacity:0; pointer-events:none; transition:opacity .2s ease;
}
.basket-overlay.open{opacity:1; pointer-events:auto;}
.basket-drawer{
  position:fixed; top:0; right:0; bottom:0; width:380px; max-width:92vw;
  background:var(--bg-elevated); border-left:1px solid var(--border-soft); z-index:91;
  transform:translateX(100%); transition:transform .22s ease;
  display:flex; flex-direction:column;
}
.basket-drawer.open{transform:translateX(0);}
.basket-head{
  display:flex; align-items:center; justify-content:space-between; padding:16px;
  border-bottom:1px solid var(--border-soft); flex-shrink:0;
}
.basket-head h3{font-size:17px;}
.basket-close{background:transparent; border:none; color:var(--text-faint); font-size:22px; padding:4px;}
.basket-body{flex:1; overflow-y:auto; padding:12px 16px;}
.basket-empty{text-align:center; padding:48px 16px; color:var(--text-faint);}
.basket-empty svg{color:var(--text-faint); margin-bottom:10px;}
.basket-empty p{font-size:13.5px; margin:0;}
.basket-item{
  display:flex; gap:10px; padding:12px 0; border-bottom:1px solid var(--border-soft);
}
.basket-item-info{flex:1; min-width:0;}
.basket-item-name{font-size:13.5px; font-weight:600; font-family:'Inter';}
.basket-item-game{font-size:11px; color:var(--text-faint); font-family:'JetBrains Mono'; margin-top:2px;}
.basket-item-row{display:flex; align-items:center; justify-content:space-between; margin-top:8px; gap:8px;}
.qty-control{display:flex; align-items:center; gap:6px; background:var(--bg); border:1px solid var(--border); border-radius:8px;}
.qty-btn{width:26px; height:26px; background:transparent; border:none; color:var(--text-dim); font-size:15px; display:flex; align-items:center; justify-content:center;}
.qty-btn:hover{color:var(--blue);}
.qty-val{font-family:'JetBrains Mono'; font-size:13px; min-width:20px; text-align:center;}
.basket-item-price{font-family:'JetBrains Mono'; font-size:13.5px; color:var(--blue); font-weight:600;}
.basket-item-remove{background:transparent; border:none; color:var(--text-faint); padding:4px; flex-shrink:0;}
.basket-item-remove:hover{color:var(--red);}
.basket-foot{padding:16px; border-top:1px solid var(--border-soft); flex-shrink:0;}
.basket-total-row{display:flex; align-items:baseline; justify-content:space-between; margin-bottom:12px;}
.basket-total-label{font-size:13px; color:var(--text-dim);}
.basket-total-val{font-family:'JetBrains Mono'; font-size:20px; color:var(--blue); font-weight:600;}
.basket-note{font-size:11.5px; color:var(--text-faint); margin-top:10px; line-height:1.5; text-align:center;}

main{max-width:1180px; margin:0 auto; padding:24px var(--gap-page) 60px;}

/* ---------- hero ---------- */
.hero{
  padding:32px 0 28px;
  border-bottom:1px solid var(--border-soft);
  margin-bottom:28px;
}
.hero-eyebrow{
  font-family:'JetBrains Mono',monospace; font-size:11px; color:var(--blue);
  letter-spacing:0.1em; text-transform:uppercase; margin-bottom:12px;
  display:flex; align-items:center; gap:8px;
}
.hero-eyebrow::before{
  content:''; width:6px; height:6px; border-radius:50%; background:var(--teal);
  box-shadow:0 0 0 3px var(--teal-soft);
}
.hero h1{font-size:clamp(28px,7vw,54px); line-height:1.08;}
.hero p{
  font-size:14.5px; color:var(--text-dim); margin-top:14px; line-height:1.6;
  font-family:'Inter'; text-transform:none; font-weight:400; max-width:560px;
}
.hero-stats{display:flex; gap:24px; margin-top:22px; flex-wrap:wrap;}
.hero-stat-num{font-family:'JetBrains Mono'; font-size:20px; color:var(--blue); font-weight:600;}
.hero-stat-label{font-size:11px; color:var(--text-faint); text-transform:uppercase; letter-spacing:0.06em; margin-top:2px;}

/* ---------- section headers ---------- */
.section-head{
  display:flex; align-items:baseline; justify-content:space-between;
  margin-bottom:16px; gap:10px;
}
.section-head h2{font-size:19px; color:var(--text);}
.section-head .count{font-family:'JetBrains Mono'; font-size:12px; color:var(--text-faint); text-transform:none; letter-spacing:0; white-space:nowrap;}

/* ---------- game grid (mobile-first: single column) ---------- */
.game-grid{
  display:grid; grid-template-columns:1fr; gap:14px;
}
.game-card{
  position:relative; border:1px solid var(--border-soft); border-radius:var(--radius-lg);
  overflow:hidden; cursor:pointer; transition:border-color .15s ease;
  aspect-ratio:4/5; display:flex; flex-direction:column; justify-content:flex-end;
}
.game-card-img{
  position:absolute; inset:0; background-size:cover; background-position:center;
  transition:transform .35s ease;
}
.game-card:hover .game-card-img, .game-card:focus-visible .game-card-img, .game-card:active .game-card-img{transform:scale(1.08);}
.game-card:active{border-color:var(--blue-dim);}
.game-card::before{
  content:''; position:absolute; inset:0; z-index:1;
  background:rgba(10,11,18,0.08);
}
.game-card::after{
  content:''; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(10,11,18,0) 0%, rgba(10,11,18,0.55) 55%, rgba(10,11,18,0.97) 100%);
}
.game-card-tag{
  position:absolute; top:12px; left:12px; z-index:2;
  font-family:'JetBrains Mono'; font-size:10.5px;
  background:rgba(17,19,31,0.75); border:1px solid var(--border); color:var(--blue);
  padding:3px 8px; border-radius:20px; letter-spacing:0.03em;
}
.game-card-body{position:relative; z-index:2; padding:16px; display:flex; flex-direction:column; gap:6px;}
.game-card-title{font-size:18px; line-height:1.15; color:#fff;}
.game-card-desc{font-size:12.5px; color:rgba(238,240,247,0.78); line-height:1.5; font-family:'Inter';}
.game-card-footer{
  display:flex; align-items:center; justify-content:space-between; margin-top:6px;
  padding-top:10px; border-top:1px solid rgba(255,255,255,0.14);
}
.game-card-items{font-size:11.5px; color:rgba(238,240,247,0.6); font-family:'JetBrains Mono';}
.game-card-arrow{color:var(--blue); font-size:17px;}

.empty-state{
  text-align:center; padding:48px 16px; color:var(--text-faint);
  border:1px dashed var(--border); border-radius:var(--radius-lg);
}
.empty-state h3{color:var(--text-dim); font-size:15px; margin-bottom:8px; text-transform:none;}
.empty-state p{font-size:13.5px; margin:0;}

/* ---------- breadcrumb ---------- */
.crumb{
  display:flex; align-items:center; gap:6px; font-size:12px; color:var(--text-faint);
  margin-bottom:18px; font-family:'JetBrains Mono'; flex-wrap:wrap;
}
.crumb a{color:var(--text-dim);}
.crumb a:active{color:var(--blue);}

/* ---------- game page header ---------- */
.game-header{
  display:flex; gap:14px; align-items:center; margin-bottom:22px; flex-wrap:wrap;
  padding-bottom:20px; border-bottom:1px solid var(--border-soft);
}
.game-header-art{
  width:64px; height:64px; border-radius:var(--radius); flex-shrink:0;
  background-size:cover; background-position:center; border:1px solid var(--border);
}
.game-header h1{font-size:clamp(22px,6vw,40px);}
.game-header p{color:var(--text-dim); font-size:13px; margin-top:4px; max-width:560px; text-transform:none; font-family:'Inter';}

/* ---------- filter tabs ---------- */
.tab-row{
  display:flex; gap:6px; margin-bottom:18px; flex-wrap:nowrap;
  overflow-x:auto; -webkit-overflow-scrolling:touch; padding-bottom:2px;
  scrollbar-width:none;
}
.tab-row::-webkit-scrollbar{display:none;}
.tab-btn{
  background:var(--bg-elevated); border:1px solid var(--border-soft); color:var(--text-dim);
  padding:8px 15px; border-radius:24px; font-size:13px; font-weight:600; white-space:nowrap; flex-shrink:0;
}
.tab-btn.active{background:var(--blue-soft); border-color:var(--blue-dim); color:var(--blue);}

/* ---------- item grid (mobile-first: single column) ---------- */
.item-grid{display:grid; grid-template-columns:1fr; gap:12px;}
.item-card{
  background:var(--bg-elevated); border:1px solid var(--border-soft); border-radius:var(--radius-lg);
  padding:16px; display:flex; flex-direction:column; gap:8px; overflow:hidden;
}
.item-card-thumb{
  width:calc(100% + 32px); margin:-16px -16px 4px; height:140px;
  background-size:cover; background-position:center; flex-shrink:0;
}
.item-card-top{display:flex; align-items:flex-start; justify-content:space-between; gap:8px;}
.item-card-name{font-size:15px; font-family:'Inter'; font-weight:600; text-transform:none; line-height:1.3;}
.item-card-badge{
  font-family:'JetBrains Mono'; font-size:10px; color:var(--text-faint);
  background:var(--bg-elevated-2); border:1px solid var(--border-soft);
  padding:2px 7px; border-radius:12px; white-space:nowrap; text-transform:uppercase; letter-spacing:0.03em; flex-shrink:0;
}
.item-card-desc{font-size:12.5px; color:var(--text-dim); line-height:1.55;}
.item-card-bottom{
  display:flex; align-items:center; justify-content:space-between; margin-top:2px; gap:10px;
  padding-top:10px; border-top:1px solid var(--border-soft);
}
.item-price{font-family:'JetBrains Mono'; font-size:16px; color:var(--blue); font-weight:600; white-space:nowrap;}
.item-price .unit{font-size:10.5px; color:var(--text-faint); font-weight:400; margin-left:4px;}
.item-stock{font-size:11px; color:var(--teal); font-family:'JetBrains Mono'; display:flex; align-items:center; gap:5px; margin-top:2px;}
.item-stock::before{content:''; width:5px; height:5px; border-radius:50%; background:var(--teal); flex-shrink:0;}
.item-stock.out{color:var(--red);}
.item-stock.out::before{background:var(--red);}
.buy-btn{
  background:var(--blue); color:#0A0E1A; border:none; padding:9px 16px; border-radius:8px;
  font-size:13px; font-weight:700; letter-spacing:0.01em; flex-shrink:0; min-height:38px;
  display:flex; align-items:center; gap:6px;
}
.buy-btn:active{background:#6FA3F9;}
.buy-btn:disabled{background:var(--bg-elevated-2); color:var(--text-faint);}
.buy-btn.in-basket{background:var(--teal-soft); color:var(--teal); border:1px solid var(--teal);}

/* ---------- footer ---------- */
footer{
  border-top:1px solid var(--border-soft); padding:22px 16px; text-align:center;
  color:var(--text-faint); font-size:12px; line-height:1.6;
}
footer a{color:var(--blue-dim);}

/* ---------- buttons (generic) ---------- */
.btn{
  background:var(--bg-elevated); border:1px solid var(--border); color:var(--text);
  padding:9px 14px; border-radius:8px; font-size:13px; font-weight:600; display:inline-flex; align-items:center; gap:6px;
  min-height:38px;
}
.btn:active{border-color:var(--blue-dim); color:var(--blue);}
.btn-primary{background:var(--blue); color:#0A0E1A; border:none;}
.btn-primary:active{background:#6FA3F9; color:#0A0E1A;}
.btn-danger{border-color:#4A2A28; color:var(--red);}
.btn-danger:active{border-color:var(--red); background:var(--red-soft);}
.btn-sm{padding:7px 11px; font-size:12px; min-height:34px;}
.btn-block{width:100%; justify-content:center;}

/* ===================== ADMIN ===================== */
.admin-shell{display:flex; flex-direction:column; min-height:calc(100vh - 57px);}
.admin-sidebar{
  border-bottom:1px solid var(--border-soft); padding:12px var(--gap-page);
  display:flex; gap:6px; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none;
}
.admin-sidebar::-webkit-scrollbar{display:none;}
.admin-sidebar-label{display:none;}
.admin-nav-btn{
  display:flex; align-items:center; gap:8px; text-align:left; background:transparent;
  border:1px solid var(--border-soft); color:var(--text-dim); padding:8px 14px; border-radius:8px;
  font-size:13px; font-weight:600; white-space:nowrap; flex-shrink:0;
}
.admin-nav-btn.active{background:var(--blue-soft); color:var(--blue); border-color:var(--blue-dim);}
.admin-main{padding:20px var(--gap-page) 60px;}
.admin-head{display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; flex-wrap:wrap; gap:10px;}
.admin-head h2{font-size:20px;}

.publish-banner{
  display:flex; flex-direction:column; gap:10px; background:var(--blue-soft);
  border:1px solid var(--blue-dim); border-radius:var(--radius-lg); padding:14px 16px;
  margin-bottom:18px;
}
.publish-banner-title{font-size:14px; font-weight:600; font-family:'Inter'; color:var(--blue);}
.publish-banner-sub{font-size:12px; color:var(--text-dim); line-height:1.5; margin-top:3px;}
.publish-banner .btn{align-self:flex-start;}

.admin-stats-row{display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-bottom:22px;}
.stat-card{
  background:var(--bg-elevated); border:1px solid var(--border-soft); border-radius:var(--radius);
  padding:12px 10px;
}
.stat-card .num{font-family:'JetBrains Mono'; font-size:18px; color:var(--blue); font-weight:600;}
.stat-card .lbl{font-size:10px; color:var(--text-faint); text-transform:uppercase; letter-spacing:0.04em; margin-top:3px;}

.admin-game-row{
  display:flex; flex-wrap:wrap; align-items:center; gap:12px; background:var(--bg-elevated);
  border:1px solid var(--border-soft); border-radius:var(--radius); padding:13px 14px; margin-bottom:10px;
}
.admin-game-row.inactive{opacity:0.55;}
.admin-game-thumb{
  width:42px; height:42px; border-radius:8px; background-size:cover; background-position:center; flex-shrink:0;
  border:1px solid var(--border);
}
.admin-game-info{flex:1; min-width:120px;}
.admin-game-info .name{font-size:14px; font-weight:600; font-family:'Inter';}
.admin-game-info .meta{font-size:11px; color:var(--text-faint); font-family:'JetBrains Mono'; margin-top:2px;}
.admin-game-actions{display:flex; align-items:center; gap:6px; flex-wrap:wrap; width:100%; padding-top:4px; border-top:1px solid var(--border-soft); margin-top:6px;}

.toggle{
  position:relative; width:40px; height:23px; border-radius:14px; background:var(--bg-elevated-2);
  border:1px solid var(--border); flex-shrink:0;
}
.toggle.on{background:var(--teal-soft); border-color:var(--teal);}
.toggle-knob{
  position:absolute; top:2px; left:2px; width:17px; height:17px; border-radius:50%;
  background:var(--text-faint);
}
.toggle.on .toggle-knob{left:21px; background:var(--teal);}

.status-pill{
  font-size:10px; font-family:'JetBrains Mono'; padding:2px 8px; border-radius:12px; text-transform:uppercase;
  letter-spacing:0.03em; white-space:nowrap;
}
.status-pill.on{color:var(--teal); background:var(--teal-soft); border:1px solid #2E6058;}
.status-pill.off{color:var(--text-faint); background:var(--bg-elevated-2); border:1px solid var(--border);}

.admin-item-row{
  display:flex; flex-direction:column; gap:8px;
  background:var(--bg-elevated); border:1px solid var(--border-soft); border-radius:var(--radius);
  padding:13px 14px; margin-bottom:8px;
}
.admin-item-row.inactive{opacity:0.5;}
.admin-item-name{font-size:14px; font-weight:600; font-family:'Inter';}
.admin-item-name .sub{font-size:11.5px; color:var(--text-faint); font-weight:400; margin-top:2px; display:block;}
.admin-item-meta-row{display:flex; align-items:center; gap:12px; flex-wrap:wrap;}
.admin-item-cell{font-size:12.5px; color:var(--text-dim); font-family:'JetBrains Mono';}
.admin-item-actions{display:flex; gap:6px; align-items:center; flex-wrap:wrap; padding-top:6px; border-top:1px solid var(--border-soft); margin-top:2px;}
.admin-list-head{display:none;}

/* ---------- modal ---------- */
.modal-overlay{
  position:fixed; inset:0; background:rgba(8,9,15,0.75); z-index:100;
  display:flex; align-items:flex-end; justify-content:center;
  backdrop-filter:blur(2px);
}
.modal{
  background:var(--bg-elevated); border:1px solid var(--border); border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  width:100%; max-width:520px; max-height:92vh; overflow-y:auto; box-shadow:var(--shadow);
}
.modal-head{
  display:flex; align-items:center; justify-content:space-between; padding:18px 18px 16px;
  border-bottom:1px solid var(--border-soft); position:sticky; top:0; background:var(--bg-elevated);
}
.modal-head h3{font-size:17px;}
.modal-close{background:transparent; border:none; color:var(--text-faint); font-size:24px; line-height:1; padding:4px 6px;}
.modal-body{padding:18px; display:flex; flex-direction:column; gap:14px;}
.modal-foot{padding:14px 18px 18px; border-top:1px solid var(--border-soft); display:flex; flex-direction:column-reverse; gap:8px;}
.modal-foot .btn{width:100%; justify-content:center;}

.field{display:flex; flex-direction:column; gap:6px;}
.field label{font-size:12.5px; color:var(--text-dim); font-weight:600;}
.field .hint{font-size:11px; color:var(--text-faint); font-weight:400;}
.field-row{display:grid; grid-template-columns:1fr; gap:14px;}
input[type=text], input[type=number], input[type=url], input[type=email], input[type=password], textarea, select{
  background:var(--bg); border:1px solid var(--border); color:var(--text);
  padding:10px 12px; border-radius:8px; font-size:15px; font-family:'Inter'; width:100%;
  min-height:42px;
}
input:focus, textarea:focus, select:focus{outline:none; border-color:var(--blue-dim);}
textarea{resize:vertical; min-height:72px; font-family:'Inter';}
.checkbox-row{display:flex; align-items:center; gap:8px; font-size:13.5px; color:var(--text-dim);}
.checkbox-row input{width:auto; min-height:auto;}

.login-shell{
  max-width:380px; margin:48px auto; background:var(--bg-elevated); border:1px solid var(--border-soft);
  border-radius:var(--radius-lg); padding:24px 20px; text-align:center;
}
.login-shell h2{margin-bottom:6px; font-size:20px;}
.login-shell p{color:var(--text-faint); font-size:12.5px; margin-bottom:18px; text-transform:none;}

.profile-page{display:flex; flex-direction:column; gap:18px;}
.account-card{
  display:flex; align-items:center; gap:12px; background:var(--bg-elevated);
  border:1px solid var(--border-soft); border-radius:var(--radius-lg); padding:14px 16px; flex-wrap:wrap;
}
.account-avatar{
  width:42px; height:42px; border-radius:50%; background:var(--blue-soft); border:1px solid var(--blue-dim);
  color:var(--blue); display:flex; align-items:center; justify-content:center; font-size:16px; font-weight:600;
  font-family:'Inter'; flex-shrink:0;
}
.account-info{flex:1; min-width:140px;}
.account-email{font-size:14px; font-weight:600; font-family:'Inter'; word-break:break-all;}
.account-role{font-size:11.5px; color:var(--text-faint); font-family:'JetBrains Mono'; text-transform:uppercase; letter-spacing:0.04em; margin-top:2px;}

.toast{
  position:fixed; bottom:max(16px, env(safe-area-inset-bottom)); left:16px; right:16px;
  background:var(--bg-elevated-2); border:1px solid var(--teal);
  color:var(--text); padding:12px 16px; border-radius:8px; font-size:13px; z-index:200;
  box-shadow:var(--shadow); display:flex; align-items:center; gap:8px;
}
.toast.err{border-color:var(--red);}
.toast::before{content:'✓'; color:var(--teal); font-weight:700; flex-shrink:0;}
.toast.err::before{content:'!'; color:var(--red);}

/* ---------- tablet and up ---------- */
@media (min-width: 640px){
  .game-grid{grid-template-columns:repeat(2, 1fr);}
  .item-grid{grid-template-columns:repeat(2, 1fr);}
  .admin-stats-row{grid-template-columns:repeat(3, minmax(140px,1fr));}
  .field-row{grid-template-columns:1fr 1fr;}
  .modal-overlay{align-items:center; padding:24px;}
  .modal{border-radius:var(--radius-lg);}
  .modal-foot{flex-direction:row; justify-content:flex-end;}
  .modal-foot .btn{width:auto;}
  .toast{left:auto; right:24px; bottom:24px; max-width:340px;}
  .basket-drawer{width:400px;}
}

/* ---------- desktop: header becomes one row, search inline ---------- */
@media (min-width: 860px){
  :root{--gap-page:24px;}
  .topbar-row1{gap:20px; flex-wrap:nowrap;}
  .hamburger-btn{display:none;}
  .desktop-nav{display:flex;}
  .search-wrap{flex-basis:auto; order:0; margin-top:0; flex:1; max-width:420px; margin-left:auto;}
  .header-icons{margin-left:0;}
  .game-grid{grid-template-columns:repeat(3, 1fr);}
  .item-grid{grid-template-columns:repeat(3, 1fr);}
  .hero{padding:56px 0 40px;}
  .admin-shell{flex-direction:row;}
  .admin-sidebar{
    flex-direction:column; width:200px; border-bottom:none; border-right:1px solid var(--border-soft);
    padding:24px 14px; overflow-x:visible; position:sticky; top:57px; align-self:flex-start;
    height:calc(100vh - 57px);
  }
  .admin-sidebar-label{display:block; font-size:11px; color:var(--text-faint); text-transform:uppercase; letter-spacing:0.06em; padding:0 10px 10px;}
  .admin-nav-btn{width:100%; border-color:transparent;}
  .publish-banner{flex-direction:row; align-items:center; justify-content:space-between;}
  .publish-banner .btn{align-self:center; flex-shrink:0;}
  .admin-nav-btn:hover{background:var(--bg-elevated-2);}
  .admin-main{padding:28px 28px 60px;}
  .admin-game-actions{width:auto; border-top:none; margin-top:0; padding-top:0; margin-left:auto;}
  .admin-item-row{flex-direction:row; align-items:center;}
  .admin-item-name{flex:1.6;}
  .admin-item-meta-row{gap:18px; flex:1.4;}
  .admin-item-actions{border-top:none; margin-top:0; padding-top:0; margin-left:auto; flex-shrink:0;}
  .admin-list-head{
    display:flex; gap:14px; padding:0 14px; margin-bottom:8px; font-size:11px; color:var(--text-faint);
    text-transform:uppercase; letter-spacing:0.05em;
  }
}
