:root {
  --bg: #08060400;
  --bg0: #08060400;
  --bg1: #0d0a06;
  --bg2: #14100a;
  --bg3: #1c160e;
  --bg4: #231c11;
  --border: #2e2214;
  --border2: #3d2e18;
  --gold: #c8940e;
  --gold2: #e8b82a;
  --gold3: #f5d060;
  --golddim: #7a5a08;
  --red: #b03020;
  --red2: #d94030;
  --green: #2a7a3a;
  --green2: #38a84e;
  --text: #ddc99a;
  --text2: #a08858;
  --text3: #6a5538;
  --white: #f0e4c8;
  --shadow: 0 4px 24px rgba(0,0,0,.7);
  --shadowgold: 0 0 24px rgba(200,148,14,.25);
  --r: 6px;
  --font-d: 'Cinzel', serif;
  --font-b: 'Crimson Text', serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: #0d0a06;
  color: var(--text);
  font-family: var(--font-b);
  font-size: 17px;
  min-height: 100vh;
  overflow-x: hidden;
}
a { color: var(--gold2); text-decoration: none; }
a:hover { color: var(--gold3); }
button { cursor: pointer; font-family: var(--font-b); }
input, select, textarea {
  font-family: var(--font-b); font-size: 16px;
  background: var(--bg2); border: 1px solid var(--border2);
  color: var(--white); border-radius: var(--r); padding: 10px 14px; width: 100%;
  outline: none; transition: border-color .2s, box-shadow .2s;
}
input:focus, select:focus, textarea:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 2px rgba(200,148,14,.15);
}
input[type=file] { padding: 8px; background: var(--bg3); }
textarea { resize: vertical; min-height: 100px; }
select option { background: var(--bg2); }

/* PARTICLES */
#particles { position:fixed; inset:0; pointer-events:none; z-index:0; overflow:hidden; }
.par { position:absolute; width:2px; height:2px; background:var(--gold); border-radius:50%; animation:pfloat linear infinite; opacity:0; }
@keyframes pfloat { 0%{transform:translateY(100vh);opacity:0} 10%{opacity:.5} 90%{opacity:.2} 100%{transform:translateY(-50px);opacity:0} }

/* HEADER */
#header {
  position:sticky; top:0; z-index:100;
  background: rgba(13,10,6,.97);
  border-bottom: 1px solid var(--border2);
  backdrop-filter: blur(8px);
}
.header-inner {
  max-width:1280px; margin:0 auto; padding:0 20px;
  height:62px; display:flex; align-items:center; gap:20px;
}
.logo { display:flex; align-items:center; gap:10px; }
.logo-img { height:44px; width:44px; object-fit:contain; filter:drop-shadow(0 0 8px rgba(200,148,14,.5)); }
.logo-texts { display:flex; flex-direction:column; justify-content:center; }
.logo-text { font-family:var(--font-d); font-size:20px; font-weight:900; color:var(--white); letter-spacing:1px; line-height:1.1; }
.logo-accent { color:var(--gold2); }
.logo-sub { font-family:var(--font-d); font-size:9px; color:var(--text3); letter-spacing:3px; }
.nav-links { display:flex; align-items:center; gap:4px; margin-left:12px; }
.nav-links a { color:var(--text2); padding:6px 14px; border-radius:var(--r); font-family:var(--font-d); font-size:12px; letter-spacing:.5px; transition:all .2s; }
.nav-links a:hover { color:var(--gold2); background:rgba(200,148,14,.07); }
.nav-cta { background:linear-gradient(135deg,var(--golddim),var(--gold)) !important; color:var(--bg1) !important; font-weight:700 !important; }
.nav-cta:hover { box-shadow:var(--shadowgold); transform:translateY(-1px); }
.header-right { margin-left:auto; display:flex; align-items:center; gap:12px; }
#auth-buttons { display:flex; gap:8px; }
#user-nav { display:flex; align-items:center; gap:12px; }
.msg-btn { position:relative; font-size:20px; padding:4px; }
.badge {
  position:absolute; top:-4px; right:-6px;
  background:var(--red2); color:#fff; font-size:10px;
  min-width:16px; height:16px; border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-d); padding:0 3px;
}
.user-chip { display:flex; align-items:center; gap:7px; padding:5px 10px; border:1px solid var(--border2); border-radius:20px; font-size:14px; color:var(--text); transition:all .2s; }
.user-chip:hover { border-color:var(--gold); color:var(--gold2); }
.user-avatar-sm { font-size:18px; }

/* BUTTONS */
.btn { display:inline-flex; align-items:center; gap:6px; padding:9px 20px; border:none; border-radius:var(--r); font-size:15px; font-weight:600; transition:all .2s; font-family:var(--font-d); letter-spacing:.3px; }
.btn-gold { background:linear-gradient(135deg,#7a5a08,#c8940e,#e8b82a,#c8940e,#7a5a08); background-size:200%; color:var(--bg1); box-shadow:0 2px 12px rgba(200,148,14,.3); }
.btn-gold:hover { background-position:right; box-shadow:var(--shadowgold); transform:translateY(-1px); }
.btn-ghost { background:transparent; color:var(--text2); border:1px solid var(--border2); }
.btn-ghost:hover { color:var(--gold2); border-color:var(--gold); }
.btn-red { background:var(--red); color:#fff; }
.btn-red:hover { background:var(--red2); }
.btn-green { background:var(--green); color:#fff; }
.btn-green:hover { background:var(--green2); }
.btn-sm { padding:6px 14px; font-size:13px; }
.btn-lg { padding:13px 28px; font-size:17px; }
.btn-full { width:100%; justify-content:center; }
.btn:disabled { opacity:.5; cursor:not-allowed; transform:none !important; }

/* LAYOUT */
#app { position:relative; z-index:1; min-height:calc(100vh - 62px); }
.container { max-width:1280px; margin:0 auto; padding:0 20px; }
.page { padding:36px 20px; max-width:1280px; margin:0 auto; }

/* HERO */
.hero { background:linear-gradient(180deg,#0d0a06 0%,#1a1208 40%,#0d0a06 100%); padding:72px 20px 56px; text-align:center; position:relative; overflow:hidden; }
.hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 0%,rgba(200,148,14,.1) 0%,transparent 60%); pointer-events:none; }
.hero-eyebrow { display:inline-block; border:1px solid var(--gold); color:var(--gold2); font-family:var(--font-d); font-size:10px; letter-spacing:3px; padding:5px 18px; border-radius:20px; margin-bottom:20px; background:rgba(200,148,14,.05); }
.hero h1 { font-family:var(--font-d); font-size:clamp(28px,4.5vw,58px); font-weight:900; color:var(--white); line-height:1.1; margin-bottom:14px; text-shadow:0 0 40px rgba(200,148,14,.25); }
.hero h1 span { color:var(--gold2); }
.hero p { font-size:18px; color:var(--text2); max-width:520px; margin:0 auto 32px; line-height:1.6; }
.hero-search { display:flex; max-width:580px; margin:0 auto 44px; background:var(--bg3); border:1px solid var(--border2); border-radius:8px; overflow:hidden; box-shadow:0 4px 30px rgba(0,0,0,.5); }
.hero-search input { flex:1; background:transparent; border:none; padding:14px 20px; font-size:16px; color:var(--white); border-radius:0; }
.hero-search button { background:var(--gold); color:var(--bg1); border:none; padding:14px 28px; font-family:var(--font-d); font-size:13px; font-weight:700; letter-spacing:.5px; cursor:pointer; transition:background .2s; white-space:nowrap; }
.hero-search button:hover { background:var(--gold2); }
.hero-stats { display:flex; justify-content:center; gap:44px; flex-wrap:wrap; }
.stat-num { display:block; font-family:var(--font-d); font-size:26px; font-weight:900; color:var(--gold2); }
.stat-label { font-size:11px; color:var(--text3); letter-spacing:2px; text-transform:uppercase; }

/* DIVIDER */
.divider { height:1px; background:linear-gradient(90deg,transparent,var(--border2),var(--gold),var(--border2),transparent); }

/* SECTION */
.section { padding:44px 20px; max-width:1280px; margin:0 auto; }
.section-title { font-family:var(--font-d); font-size:20px; font-weight:700; color:var(--white); margin-bottom:22px; display:flex; align-items:center; gap:10px; }
.section-title::after { content:''; flex:1; height:1px; background:linear-gradient(90deg,var(--border2),transparent); }

/* CATEGORY GRID */
.cat-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(100px,1fr)); gap:10px; }
.cat-card { background:var(--bg3); border:1px solid var(--border); border-radius:var(--r); padding:14px 8px; text-align:center; cursor:pointer; transition:all .2s; }
.cat-card:hover, .cat-card.active { border-color:var(--gold); background:var(--bg4); box-shadow:0 0 14px rgba(200,148,14,.12); transform:translateY(-2px); }
.cat-icon { font-size:24px; display:block; margin-bottom:5px; }
.cat-name { font-size:11px; color:var(--text2); font-family:var(--font-d); }

/* OFFER CARDS */
.offers-layout { display:grid; grid-template-columns:200px 1fr; gap:24px; }
.sidebar { }
.sidebar-box { background:var(--bg3); border:1px solid var(--border); border-radius:var(--r); padding:16px; margin-bottom:12px; }
.sidebar-label { font-family:var(--font-d); font-size:11px; letter-spacing:1.5px; color:var(--text3); margin-bottom:10px; text-transform:uppercase; }
.filter-item { padding:7px 10px; cursor:pointer; border-radius:4px; font-size:14px; color:var(--text2); transition:all .15s; }
.filter-item:hover { color:var(--gold2); background:rgba(200,148,14,.06); }
.filter-item.active { color:var(--gold2); background:rgba(200,148,14,.1); }

.offers-toolbar { display:flex; justify-content:space-between; align-items:center; margin-bottom:18px; flex-wrap:wrap; gap:10px; }
.offers-count { font-size:14px; color:var(--text3); }
.toolbar-right { display:flex; gap:8px; flex-wrap:wrap; }
.filter-select { background:var(--bg3); border:1px solid var(--border2); color:var(--text); padding:7px 12px; border-radius:var(--r); font-size:13px; font-family:var(--font-d); cursor:pointer; width:auto; }
.type-tabs { display:flex; gap:6px; margin-bottom:16px; }
.type-tab { padding:6px 16px; border:1px solid var(--border2); border-radius:20px; font-size:13px; font-family:var(--font-d); cursor:pointer; color:var(--text2); background:transparent; transition:all .2s; }
.type-tab.active { border-color:var(--gold); color:var(--gold2); background:rgba(200,148,14,.1); }

.offers-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:14px; }
.offer-card { background:var(--bg3); border:1px solid var(--border); border-radius:var(--r); overflow:hidden; transition:all .25s; cursor:pointer; }
.offer-card:hover { border-color:var(--golddim); box-shadow:0 8px 28px rgba(0,0,0,.5),0 0 18px rgba(200,148,14,.1); transform:translateY(-3px); }
.offer-img { width:100%; height:180px; background:var(--bg4); display:flex; align-items:center; justify-content:center; font-size:52px; border-bottom:1px solid var(--border); position:relative; overflow:hidden; }
.offer-img img { width:100%; height:100%; object-fit:cover; object-position:center; display:block; }
.offer-type-badge { position:absolute; top:8px; right:8px; padding:3px 9px; border-radius:3px; font-size:10px; font-family:var(--font-d); letter-spacing:.5px; font-weight:700; }
.badge-auction { background:rgba(176,48,32,.85); color:#ffb8a0; }
.badge-buy { background:rgba(42,122,58,.85); color:#a0ffb8; }
.badge-both { background:rgba(180,120,0,.85); color:#ffe090; }
.badge-buy { background:rgba(42,122,58,.85); color:#a0ffb8; }
.offer-body { padding:12px; }
.offer-cat { font-size:10px; color:var(--text3); font-family:var(--font-d); letter-spacing:1px; text-transform:uppercase; margin-bottom:3px; }
.offer-title { font-size:14px; color:var(--white); font-weight:600; margin-bottom:8px; line-height:1.3; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.offer-footer { display:flex; justify-content:space-between; align-items:center; }
.offer-price { font-family:var(--font-d); font-size:18px; font-weight:700; color:var(--gold2); }
.offer-price small { font-size:11px; color:var(--text3); }
.offer-meta2 { font-size:11px; color:var(--text3); text-align:right; }
.auction-end { font-size:11px; color:var(--red2); font-family:var(--font-d); margin-top:4px; }

/* OFFER DETAIL */
.detail-grid { display:grid; grid-template-columns:1fr 320px; gap:28px; }
.detail-images { position:relative; }
.main-img { width:100%; aspect-ratio:16/10; background:var(--bg3); border:1px solid var(--border); border-radius:var(--r); display:flex; align-items:center; justify-content:center; font-size:80px; overflow:hidden; margin-bottom:10px; }
.main-img img { width:100%; height:100%; object-fit:contain; object-position:center; display:block; background:var(--bg2); }
.thumb-row { display:flex; gap:8px; overflow-x:auto; padding-bottom:4px; }
.thumb { width:80px; height:60px; background:var(--bg4); border:2px solid var(--border); border-radius:4px; cursor:pointer; overflow:hidden; flex-shrink:0; transition:border-color .2s; }
.thumb:hover, .thumb.active { border-color:var(--gold); }
.thumb img { width:100%; height:100%; object-fit:cover; object-position:center; display:block; }
.detail-title { font-family:var(--font-d); font-size:24px; font-weight:700; color:var(--white); margin-bottom:10px; }
.detail-meta { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:18px; }
.meta-pill { background:var(--bg4); border:1px solid var(--border); padding:4px 12px; border-radius:20px; font-size:13px; color:var(--text2); font-family:var(--font-d); }
.detail-desc { color:var(--text); line-height:1.75; font-size:16px; }
.sidebar-box-title { font-family:var(--font-d); font-size:12px; letter-spacing:1.5px; color:var(--text3); margin-bottom:14px; text-transform:uppercase; }
.price-big { font-family:var(--font-d); font-size:32px; font-weight:900; color:var(--gold2); margin-bottom:6px; }
.price-sub { font-size:13px; color:var(--text3); margin-bottom:16px; }
.bid-row { display:flex; gap:8px; margin-bottom:10px; }
.bid-row input { flex:1; }
.bids-list { max-height:200px; overflow-y:auto; }
.bid-item { display:flex; justify-content:space-between; padding:6px 0; border-bottom:1px solid var(--border); font-size:14px; }
.bid-item:last-child { border-bottom:none; }
.bid-user { color:var(--text2); }
.bid-amount { color:var(--gold2); font-family:var(--font-d); font-weight:700; }
.seller-row { display:flex; align-items:center; gap:12px; margin-bottom:14px; }
.seller-avatar { width:44px; height:44px; background:var(--bg4); border:2px solid var(--border2); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:20px; }
.seller-name { font-weight:600; color:var(--white); font-size:15px; }
.seller-stats-row { display:flex; gap:12px; font-size:12px; color:var(--text3); margin-top:3px; }
.stars { color:var(--gold2); }
.tutor-box { background:linear-gradient(135deg,rgba(42,122,58,.12),rgba(42,122,58,.06)); border:1px solid rgba(42,122,58,.3); border-radius:var(--r); padding:14px; margin-top:10px; }
.tutor-title { font-family:var(--font-d); font-size:13px; color:var(--green2); margin-bottom:6px; }
.tutor-desc { font-size:13px; color:var(--text2); line-height:1.5; margin-bottom:10px; }
.payment-btns { display:flex; gap:8px; }
.pay-btn { flex:1; padding:8px; border:1px solid var(--border2); border-radius:var(--r); background:var(--bg4); color:var(--text); font-family:var(--font-d); font-size:12px; cursor:pointer; transition:all .2s; text-align:center; }
.pay-btn:hover, .pay-btn.selected { border-color:var(--gold); color:var(--gold2); background:rgba(200,148,14,.08); }

/* TIMER */
.auction-timer { font-family:var(--font-d); color:var(--red2); font-size:15px; margin-bottom:10px; }
.auction-timer.ending { animation:blink 1s infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.4} }

/* ADD OFFER FORM */
.add-page { max-width:680px; margin:0 auto; padding:40px 20px; }
.page-title { font-family:var(--font-d); font-size:26px; font-weight:900; color:var(--white); margin-bottom:6px; }
.page-sub { color:var(--text2); font-size:15px; margin-bottom:32px; }
.form-group { margin-bottom:20px; }
.form-label { display:block; margin-bottom:6px; font-family:var(--font-d); font-size:12px; letter-spacing:.8px; color:var(--text2); text-transform:uppercase; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.img-preview { display:flex; gap:8px; flex-wrap:wrap; margin-top:10px; }
.img-prev-item { width:80px; height:60px; background:var(--bg4); border:1px solid var(--border); border-radius:4px; overflow:hidden; position:relative; }
.img-prev-item img { width:100%; height:100%; object-fit:cover; }
.type-select { display:flex; gap:10px; margin-bottom:4px; }
.type-opt { flex:1; padding:12px; border:1px solid var(--border2); border-radius:var(--r); cursor:pointer; text-align:center; transition:all .2s; }
.type-opt.selected { border-color:var(--gold); background:rgba(200,148,14,.08); }
.type-opt-icon { font-size:22px; display:block; margin-bottom:4px; }
.type-opt-name { font-family:var(--font-d); font-size:13px; color:var(--white); }
.type-opt-desc { font-size:12px; color:var(--text3); }
#auction-fields { display:none; }
#buynow-field { display:block; }

/* ACCOUNT PAGE */
.account-grid { display:grid; grid-template-columns:220px 1fr; gap:24px; }
.account-nav { }
.account-nav-item { padding:10px 14px; border-radius:var(--r); cursor:pointer; font-family:var(--font-d); font-size:13px; color:var(--text2); transition:all .2s; display:flex; align-items:center; gap:8px; }
.account-nav-item:hover { color:var(--gold2); background:rgba(200,148,14,.06); }
.account-nav-item.active { color:var(--gold2); background:rgba(200,148,14,.1); }
.account-panel { background:var(--bg3); border:1px solid var(--border); border-radius:var(--r); padding:24px; }
.panel-title { font-family:var(--font-d); font-size:18px; color:var(--white); margin-bottom:20px; display:flex; align-items:center; gap:8px; }
.stat-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:24px; }
.stat-card { background:var(--bg4); border:1px solid var(--border); border-radius:var(--r); padding:16px; text-align:center; }
.stat-card-num { font-family:var(--font-d); font-size:24px; color:var(--gold2); display:block; }
.stat-card-label { font-size:12px; color:var(--text3); margin-top:4px; }
.offer-row { display:flex; align-items:center; gap:12px; padding:12px 0; border-bottom:1px solid var(--border); }
.offer-row:last-child { border-bottom:none; }
.offer-row-img { width:56px; height:42px; background:var(--bg4); border-radius:4px; overflow:hidden; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:20px; }
.offer-row-img img { width:100%; height:100%; object-fit:cover; }
.offer-row-info { flex:1; }
.offer-row-title { font-size:14px; color:var(--white); font-weight:600; }
.offer-row-meta { font-size:12px; color:var(--text3); margin-top:2px; }
.offer-row-price { font-family:var(--font-d); font-size:16px; color:var(--gold2); margin-right:8px; }
.status-pill { padding:2px 8px; border-radius:3px; font-size:10px; font-family:var(--font-d); }
.status-active { background:rgba(42,122,58,.2); color:var(--green2); border:1px solid rgba(42,122,58,.3); }
.status-ended { background:rgba(176,48,32,.2); color:#f88; border:1px solid rgba(176,48,32,.3); }

/* MESSAGES */
.messages-grid { display:grid; grid-template-columns:260px 1fr; gap:0; background:var(--bg3); border:1px solid var(--border); border-radius:var(--r); overflow:hidden; min-height:500px; }
.conv-list { border-right:1px solid var(--border); overflow-y:auto; }
.conv-item { padding:14px 16px; border-bottom:1px solid var(--border); cursor:pointer; transition:background .15s; }
.conv-item:hover, .conv-item.active { background:var(--bg4); }
.conv-name { font-size:14px; font-weight:600; color:var(--white); display:flex; justify-content:space-between; }
.conv-preview { font-size:12px; color:var(--text3); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.conv-time { font-size:11px; color:var(--text3); }
.conv-unread { background:var(--gold); color:var(--bg1); font-size:10px; font-family:var(--font-d); padding:1px 6px; border-radius:8px; }
.chat-area { display:flex; flex-direction:column; }
.chat-header { padding:16px 20px; border-bottom:1px solid var(--border); font-family:var(--font-d); color:var(--white); font-size:15px; }
.chat-messages { flex:1; overflow-y:auto; padding:16px 20px; display:flex; flex-direction:column; gap:10px; max-height:420px; }
.msg-bubble { max-width:70%; padding:10px 14px; border-radius:var(--r); font-size:15px; line-height:1.5; }
.msg-bubble.mine { background:rgba(200,148,14,.15); border:1px solid rgba(200,148,14,.2); align-self:flex-end; color:var(--white); }
.msg-bubble.theirs { background:var(--bg4); border:1px solid var(--border); align-self:flex-start; color:var(--text); }
.msg-time { font-size:11px; color:var(--text3); margin-top:3px; }
.chat-input-row { padding:14px 16px; border-top:1px solid var(--border); display:flex; gap:8px; }
.chat-input-row input { flex:1; }
.chat-empty { display:flex; align-items:center; justify-content:center; flex:1; color:var(--text3); font-size:15px; }

/* MODAL */
#modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.75); z-index:200; backdrop-filter:blur(3px); }
#modal-overlay.open { display:block; }
#modal-box { display:none; position:fixed; top:50%; left:50%; transform:translate(-50%,-50%); z-index:201; width:90%; max-width:440px; max-height:90vh; overflow-y:auto; }
#modal-box.open { display:block; }
.modal { background:var(--bg3); border:1px solid var(--border2); border-radius:8px; padding:32px; box-shadow:0 20px 60px rgba(0,0,0,.8),0 0 40px rgba(200,148,14,.08); }
.modal-title { font-family:var(--font-d); font-size:20px; font-weight:700; color:var(--white); margin-bottom:4px; text-align:center; }
.modal-sub { font-size:14px; color:var(--text2); text-align:center; margin-bottom:22px; }
.modal-foot { text-align:center; margin-top:14px; font-size:14px; color:var(--text3); }
.modal-foot a { color:var(--gold2); }
.modal-close { position:absolute; top:12px; right:16px; background:none; border:none; color:var(--text2); font-size:22px; cursor:pointer; }
.modal-close:hover { color:var(--white); }
.ornament { display:flex; align-items:center; gap:12px; justify-content:center; margin-bottom:18px; }
.orn-line { flex:1; max-width:60px; height:1px; background:linear-gradient(90deg,transparent,var(--border2)); }
.orn-icon { color:var(--gold2); font-size:18px; }
.form-error { color:var(--red2); font-size:13px; margin-top:6px; }

/* TOAST */
#toast-container { position:fixed; bottom:24px; right:24px; z-index:300; pointer-events:none; }
.toast { background:var(--bg4); border:1px solid var(--border2); border-left:3px solid var(--gold); color:var(--white); padding:12px 18px; border-radius:var(--r); font-size:15px; margin-top:8px; animation:slideIn .3s ease; box-shadow:0 4px 20px rgba(0,0,0,.5); }
.toast.error { border-left-color:var(--red2); }
.toast.success { border-left-color:var(--green2); }
@keyframes slideIn { from{transform:translateX(100px);opacity:0} to{transform:translateX(0);opacity:1} }

/* PAGINATION */
.pagination { display:flex; justify-content:center; gap:6px; margin-top:28px; }
.pager { background:var(--bg3); border:1px solid var(--border); color:var(--text2); padding:6px 12px; border-radius:var(--r); font-family:var(--font-d); font-size:13px; cursor:pointer; transition:all .2s; }
.pager:hover, .pager.active { border-color:var(--gold); color:var(--gold2); }

/* EMPTY / LOADING */
.empty { text-align:center; padding:52px 20px; color:var(--text3); }
.empty-icon { font-size:50px; display:block; margin-bottom:14px; }
.empty h3 { font-family:var(--font-d); color:var(--text2); font-size:18px; margin-bottom:6px; }
.loading { text-align:center; padding:40px; color:var(--text3); font-family:var(--font-d); letter-spacing:2px; }
.spinner { display:inline-block; width:32px; height:32px; border:3px solid var(--border2); border-top-color:var(--gold); border-radius:50%; animation:spin .7s linear infinite; margin-bottom:10px; }
@keyframes spin { to{transform:rotate(360deg)} }
.back-btn { background:none; border:none; color:var(--text2); font-size:14px; cursor:pointer; display:flex; align-items:center; gap:6px; margin-bottom:22px; font-family:var(--font-d); padding:0; transition:color .2s; }
.back-btn:hover { color:var(--gold2); }

/* PROFILE PAGE */
.profile-header { display:flex; align-items:center; gap:20px; margin-bottom:28px; padding:24px; background:var(--bg3); border:1px solid var(--border); border-radius:var(--r); }
.profile-avatar { width:72px; height:72px; background:var(--bg4); border:2px solid var(--border2); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:36px; }
.profile-name { font-family:var(--font-d); font-size:24px; color:var(--white); }
.profile-since { font-size:13px; color:var(--text3); margin-top:4px; }
.review-item { padding:14px 0; border-bottom:1px solid var(--border); }
.review-item:last-child { border-bottom:none; }
.review-author { font-size:13px; color:var(--text2); margin-bottom:4px; }
.review-text { font-size:15px; color:var(--text); }

/* RESPONSIVE */
@media(max-width:900px) {
  .offers-layout { grid-template-columns:1fr; }
  .detail-grid { grid-template-columns:1fr; }
  .account-grid { grid-template-columns:1fr; }
  .messages-grid { grid-template-columns:1fr; }
  .stat-cards { grid-template-columns:1fr 1fr; }
  .nav-links { display:none; }
}
@media(max-width:600px) {
  .hero h1 { font-size:26px; }
  .form-row { grid-template-columns:1fr; }
  .stat-cards { grid-template-columns:1fr; }
}

/* === SERVER CARDS === */
.servers-hero { padding:60px 20px 40px; text-align:center; background:linear-gradient(180deg,#0d0a06,#1a1208 50%,#0d0a06); position:relative; }
.servers-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 0%,rgba(200,148,14,.1),transparent 60%); pointer-events:none; }
.server-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:20px; }
.server-card { background:var(--bg3); border:1px solid var(--border); border-radius:var(--r); padding:28px 24px; cursor:pointer; transition:all .25s; position:relative; overflow:hidden; }
.server-card::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(200,148,14,.04),transparent); pointer-events:none; }
.server-card:hover { border-color:var(--gold); transform:translateY(-3px); box-shadow:0 12px 32px rgba(0,0,0,.5),0 0 20px rgba(200,148,14,.12); }
.server-card-icon { font-size:40px; margin-bottom:14px; display:flex; align-items:center; justify-content:center; min-height:64px; }
.server-card-icon img { max-height:70px; max-width:100%; object-fit:contain; filter:drop-shadow(0 2px 8px rgba(0,0,0,.5)); }
.server-card-name { font-family:var(--font-d); font-size:20px; color:var(--white); margin-bottom:4px; }
.server-card-rates { font-size:13px; color:var(--gold2); font-family:var(--font-d); margin-bottom:8px; }
.server-card-desc { font-size:14px; color:var(--text2); line-height:1.5; margin-bottom:16px; }
.server-card-footer { display:flex; justify-content:space-between; align-items:center; }
.server-offer-count { font-size:12px; color:var(--text3); }
.server-badge-soon { position:absolute; top:12px; right:12px; background:var(--bg4); border:1px solid var(--border2); color:var(--text3); font-size:10px; font-family:var(--font-d); padding:2px 8px; border-radius:3px; letter-spacing:1px; }

/* === ADMIN PANEL === */
.admin-layout { display:grid; grid-template-columns:220px 1fr; gap:0; min-height:calc(100vh - 62px); }
.admin-sidebar { background:var(--bg2); border-right:1px solid var(--border); padding:20px 0; }
.admin-logo { padding:0 16px 20px; border-bottom:1px solid var(--border); margin-bottom:12px; }
.admin-logo-title { font-family:var(--font-d); font-size:14px; color:var(--gold2); letter-spacing:1px; }
.admin-logo-role { font-size:11px; color:var(--text3); margin-top:2px; }
.admin-nav-section { padding:8px 16px 4px; font-size:10px; color:var(--text3); font-family:var(--font-d); letter-spacing:2px; text-transform:uppercase; margin-top:8px; }
.admin-nav-item { display:flex; align-items:center; gap:10px; padding:10px 16px; cursor:pointer; font-size:14px; color:var(--text2); transition:all .15s; border-left:2px solid transparent; }
.admin-nav-item:hover { color:var(--gold2); background:rgba(200,148,14,.05); }
.admin-nav-item.active { color:var(--gold2); background:rgba(200,148,14,.08); border-left-color:var(--gold2); }
.admin-nav-item .nav-icon { font-size:16px; width:20px; text-align:center; }
.admin-content { padding:28px; overflow-y:auto; }
.admin-title { font-family:var(--font-d); font-size:22px; color:var(--white); margin-bottom:20px; display:flex; align-items:center; gap:10px; }

.stat-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:12px; margin-bottom:28px; }
.stat-box { background:var(--bg3); border:1px solid var(--border); border-radius:var(--r); padding:18px 16px; text-align:center; }
.stat-box-num { font-family:var(--font-d); font-size:28px; color:var(--gold2); display:block; }
.stat-box-label { font-size:11px; color:var(--text3); margin-top:4px; letter-spacing:1px; text-transform:uppercase; }
.stat-box.warn .stat-box-num { color:var(--red2); }
.stat-box.ok .stat-box-num { color:var(--green2); }

.data-table { width:100%; border-collapse:collapse; font-size:14px; }
.data-table th { background:var(--bg4); border-bottom:1px solid var(--border2); padding:10px 12px; text-align:left; font-family:var(--font-d); font-size:11px; letter-spacing:1px; color:var(--text3); text-transform:uppercase; }
.data-table td { padding:10px 12px; border-bottom:1px solid var(--border); color:var(--text); vertical-align:middle; }
.data-table tr:hover td { background:rgba(255,255,255,.02); }
.data-table tr:last-child td { border-bottom:none; }

.role-pill { padding:2px 8px; border-radius:3px; font-size:10px; font-family:var(--font-d); letter-spacing:.5px; }
.role-admin { background:rgba(176,48,32,.2); color:#f88; border:1px solid rgba(176,48,32,.3); }
.role-tutor { background:rgba(42,122,58,.2); color:var(--green2); border:1px solid rgba(42,122,58,.3); }
.role-user { background:rgba(100,80,40,.2); color:var(--text2); border:1px solid var(--border); }

.action-btns { display:flex; gap:6px; flex-wrap:wrap; }
.search-bar { display:flex; gap:8px; margin-bottom:16px; }
.search-bar input { flex:1; max-width:320px; }

.tutor-card { background:var(--bg3); border:1px solid var(--border); border-radius:var(--r); padding:18px; margin-bottom:12px; }
.tutor-card-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:10px; }
.tutor-card-title { font-family:var(--font-d); font-size:15px; color:var(--white); }
.tutor-status { padding:3px 10px; border-radius:3px; font-size:11px; font-family:var(--font-d); }
.status-pending { background:rgba(200,148,14,.15); color:var(--gold2); border:1px solid rgba(200,148,14,.3); }
.status-in_progress { background:rgba(42,122,58,.15); color:var(--green2); border:1px solid rgba(42,122,58,.3); }
.status-completed { background:rgba(100,80,40,.15); color:var(--text2); border:1px solid var(--border); }
.status-cancelled { background:rgba(176,48,32,.15); color:#f88; border:1px solid rgba(176,48,32,.3); }
.tutor-card-meta { font-size:13px; color:var(--text2); margin-bottom:12px; line-height:1.7; }
.tutor-card-actions { display:flex; gap:8px; flex-wrap:wrap; }
.send-msg-form { margin-top:12px; display:flex; gap:8px; }
.send-msg-form input { flex:1; font-size:14px; padding:7px 12px; }

/* TABS */
.tabs { display:flex; gap:0; border-bottom:1px solid var(--border); margin-bottom:20px; }
.tab { padding:10px 18px; cursor:pointer; font-family:var(--font-d); font-size:13px; color:var(--text2); border-bottom:2px solid transparent; transition:all .15s; }
.tab:hover { color:var(--gold2); }
.tab.active { color:var(--gold2); border-bottom-color:var(--gold2); }

/* SERVER SELECT in add offer */
.server-select-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:10px; margin-bottom:4px; }
.server-opt { padding:14px; border:1px solid var(--border2); border-radius:var(--r); cursor:pointer; transition:all .2s; text-align:center; }
.server-opt:hover, .server-opt.selected { border-color:var(--gold); background:rgba(200,148,14,.07); }
.server-opt-name { font-family:var(--font-d); font-size:14px; color:var(--white); }
.server-opt-rates { font-size:12px; color:var(--gold2); margin-top:2px; }

/* === ROLE BADGES === */
.role-badge { display:inline-flex; align-items:center; gap:3px; padding:2px 7px; border-radius:3px; font-size:10px; font-family:var(--font-d); letter-spacing:.5px; vertical-align:middle; margin-left:4px; }
.role-badge-admin { background:rgba(220,60,20,.15); color:#ff9977; border:1px solid rgba(220,60,20,.3); }
.role-badge-tutor { background:rgba(42,122,58,.15); color:var(--green2); border:1px solid rgba(42,122,58,.3); }

/* === SOLD STATUS === */
.offer-sold { opacity:.75; }
.offer-sold .offer-img::after { content:''; position:absolute; inset:0; background:rgba(0,0,0,.35); }
.sold-overlay { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); background:rgba(42,122,58,.92); color:#fff; font-family:var(--font-d); font-size:13px; letter-spacing:1px; padding:6px 16px; border-radius:4px; font-weight:700; z-index:2; white-space:nowrap; }
.sold-banner { background:linear-gradient(135deg,rgba(42,122,58,.2),rgba(42,122,58,.1)); border:1px solid rgba(42,122,58,.4); border-radius:var(--r); padding:14px; text-align:center; font-family:var(--font-d); font-size:18px; color:var(--green2); letter-spacing:2px; margin-bottom:12px; }

/* === OFFER STATUS BADGE === */
.offer-status-sold { position:absolute; top:8px; left:8px; background:rgba(42,122,58,.9); color:#fff; font-family:var(--font-d); font-size:10px; letter-spacing:1px; padding:3px 9px; border-radius:3px; }
