:root {
  /* Colors - Dark blue theme */
  --bg: #0a1628;
  --card: #0f1f3d;
  --muted: #8b9dc3;
  --accent: #3b82f6;
  --primary: #1e40af;
  --success: #10b981;
  --danger: #ef4444;
  --gold: #fbbf24;

  /* Layout & surfaces */
  --glass: rgba(59, 130, 246, 0.08);
  --radius: 12px;
  --max-width: 1100px;

  /* Gear / card theming */
  --gear-thumb-size: 96px;        /* gear thumbnail size */
  --gear-padding: 16px;          /* padding inside larger gear cards */
  --gear-radius: 10px;           /* corner radius for gear cards */
  --gear-border-color: rgba(255,255,255,0.04);
  --gear-bg: rgba(255,255,255,0.02);
  --gear-shadow: 0 6px 18px rgba(2,6,23,0.6);
  --gear-hover-translate: -6px;
  --gear-hover-shadow: 0 12px 28px rgba(2,6,23,0.7);
  --gear-label-size: 0.98rem;

  /* Generic card hover/shadow tokens */
  --card-hover-translate: -6px;
  --card-hover-shadow: 0 12px 28px rgba(2,6,23,0.7);
}

* { box-sizing: border-box; }

/* Custom Scrollbar - Dark Blue Theme */
::-webkit-scrollbar {
  width: 12px;
  height: 12px;
}

::-webkit-scrollbar-track {
  background: #0a1628;
  border-radius: 6px;
}

::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #1e40af, #3b82f6);
  border-radius: 6px;
  border: 2px solid #0a1628;
}

::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, #3b82f6, #60a5fa);
}

::-webkit-scrollbar-corner {
  background: #0a1628;
}

/* Firefox scrollbar */
* {
  scrollbar-width: thin;
  scrollbar-color: #3b82f6 #0a1628;
}

html,body{height:100%;}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
  /* Gradient fallback if image fails to load */
  background: linear-gradient(135deg, #0a1628 0%, #1e3a5f 50%, #0a1628 100%) fixed;
  background-color: #0a1628;
  background-image: url('background.png');
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  background-attachment: fixed;
  color:#e6eef6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.35;
  padding:24px 12px;
}

.site-header{
  max-width:var(--max-width);
  margin:0 auto 18px auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  background: rgba(15, 31, 61, 0.95);
  backdrop-filter: blur(10px);
  padding: 20px;
  border-radius: 15px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.6);
}
.header-left{display:flex;align-items:center;gap:12px}
.site-title{font-size:1.5rem;margin:0;display:flex;align-items:center;gap:.6rem;color:#60a5fa;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,0.3)}
.site-logo{width:40px;height:40px;object-fit:cover;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,0.1)}

/* Social icons with glow effect */
.social-link{display:inline-block;transition:all 0.3s ease}
.social-link:hover .social-logo{filter:drop-shadow(0 0 12px rgba(59,130,246,0.8)) drop-shadow(0 0 20px rgba(59,130,246,0.6))}
.social-logo{transition:all 0.3s ease;filter:drop-shadow(0 0 6px rgba(59,130,246,0.4))}

/* Footer styling */
.site-footer{text-align:center;padding:24px 16px;margin-top:40px;background:rgba(10,22,40,0.95);backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,0.06)}
.site-footer small{color:var(--muted);font-size:0.9rem}

nav{display:flex;align-items:center;gap:12px}
.nav-user-section{display:flex;align-items:center;gap:8px}
.nav-controls{display:flex;align-items:center;gap:.5rem}
.navbar-avatar-wrap{display:flex;align-items:center}
.navbar-avatar-img{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid var(--accent)}
#user-greeting{color:var(--accent);font-weight:500;font-size:0.95rem}

.api-status{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--muted)}
.api-status-dot{width:10px;height:10px;border-radius:50%;background:var(--muted);display:inline-block}

/* Buttons */
.btn{background:linear-gradient(135deg, #1e40af 0%, #1e3a8a 100%);border:none;color:white;padding:.55rem .9rem;border-radius:25px;cursor:pointer;font-weight:600;transition:all 0.3s ease;box-shadow:0 4px 15px rgba(30,64,175,0.4)}
.btn:hover{transform:translateY(-2px);box-shadow:0 6px 25px rgba(59,130,246,0.6)}
.btn:disabled{opacity:0.6;cursor:not-allowed;transform:none !important;box-shadow:0 4px 15px rgba(30,64,175,0.4) !important}
.btn-primary{background:linear-gradient(135deg, #1e40af 0%, #1e3a8a 100%);color:white;}
.btn-accent{background:linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);color:white;}
.btn-delete{background:linear-gradient(135deg, #f093fb 0%, #f5576c 100%);color:white}
.btn-small{padding:.35rem .65rem;font-size:.9rem}

.card{background:rgba(15,31,61,0.95);backdrop-filter:blur(10px);border-radius:15px;padding:20px;box-shadow:0 8px 32px rgba(0,0,0,0.6);max-width:var(--max-width);margin:0 auto 12px;color:#e6eef6}
.hidden{display:none !important}

.hint{color:var(--muted);font-size:.95rem}
.accent-text{color:var(--accent)}

/* Forms */
.form-group{margin-bottom:16px}
.form-group label{display:block;margin-bottom:6px;color:var(--accent);font-weight:500;font-size:0.95rem}
.form-input,input[type=text], input[type=number], input[type=email], input[type=password], textarea, select{
  width:100%;padding:.7rem .8rem;border-radius:8px;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.02);color:#e6eef6;font-size:0.95rem;transition:border-color .2s ease
}
.form-input:focus,input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent)}
.error-message{color:var(--danger);font-size:0.9rem;margin-top:8px;display:none}
.success-message{color:#22c55e;font-size:0.9rem;margin-top:8px;padding:8px 12px;background:rgba(34,197,94,0.1);border-radius:6px;border:1px solid rgba(34,197,94,0.3)}
label{display:block;margin:.45rem 0}

/* Auth form grid for wider layout */
.auth-form-grid{display:grid !important;grid-template-columns:1fr 1fr !important;gap:8px !important;column-gap:16px !important}
.auth-modal-wrapper{max-height:90vh;overflow:hidden}
.vocation-modal-body{padding:8px 16px 12px 16px}
.auth-form-grid .form-group{margin-bottom:6px}
.auth-form-grid .form-group label{margin-bottom:4px;font-size:0.9rem}
.hidden-form{display:none !important}

@media (max-width:720px){
  .auth-form-grid{grid-template-columns:1fr !important}
  .auth-form-grid .form-group{grid-column:1 / -1 !important}
  .site-header{padding-bottom:12px;flex-direction:row;align-items:center}
  .site-title{font-size:1.2rem}
}

.form-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:12px}

/* Listing grid */
#listings{max-width:var(--max-width);margin:18px auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.listing-card{background:linear-gradient(180deg, rgba(255,255,255,0.02), transparent);padding:12px;border-radius:8px;border:1px solid rgba(255,255,255,0.03)}
.listing-card img{width:100%;height:140px;object-fit:cover;border-radius:6px}
.listing-title{font-weight:700;color:var(--primary);margin:.5rem 0}
.listing-meta{display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:.9rem}

/* Vocation cards */
.vocation-card,.common-card,.shared-card{background:#0f1f3d;backdrop-filter:blur(10px);border:2px solid transparent;transition:all 0.3s ease}
.vocation-card:hover,.common-card:hover,.shared-card:hover{border-color:#3b82f6;box-shadow:0 6px 25px rgba(59,130,246,0.5)}

/* Knight vocation card - Cyan theme */
.vocation-card-knight:hover{border-color:#00ffff;box-shadow:0 6px 25px rgba(0,255,255,0.6)}

/* Ranger vocation card - Pink/Magenta theme */
.vocation-card-ranger:hover{border-color:#ff00ff;box-shadow:0 6px 25px rgba(255,0,255,0.6)}

/* Mage & Shaman vocation card - Green/Orange dynamic theme */
.vocation-card-mage-shaman{
  --mage-shaman-border: #ffa500;
  --mage-shaman-glow: 0 6px 25px rgba(255,165,0,0.6);
}
.vocation-card-mage-shaman:hover{
  border-color: var(--mage-shaman-border);
  box-shadow: var(--mage-shaman-glow);
}

/* Search filters */
.search-filters-card .filter-content{padding-top:8px}
.search-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}

/* Filter header for collapsible sections */
.filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.filter-content{transition:all 0.3s ease}

/* Stats card */
.stats-card .stats-grid{display:flex;gap:12px;flex-wrap:wrap}
.stat-item{background:transparent;padding:8px;border-radius:8px;min-width:120px;text-align:center}
.stat-value{font-weight:800;color:var(--primary);font-size:1.25rem}
.stat-label{color:var(--muted);font-size:.9rem}

/* Modals */
.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(2,6,23,0.5);z-index:200}
#user-popup{z-index:500}
.modal-inner{background:linear-gradient(180deg,#06121b,#071424);padding:18px;border-radius:12px;max-height:85vh;overflow:auto;color:inherit}
.modal-inner.small{max-width:420px}
.modal-inner.dark{background:#061018}
.image-modal-content{position:relative;max-width:90vw;max-height:90vh}
.image-modal-content img{max-width:100%;max-height:80vh;border-radius:8px}
.image-modal-close{position:absolute;top:8px;right:8px;background:transparent;border:0;color:var(--muted);font-size:1.4rem}

/* Avatar helpers */
.avatar-wrap{width:64px;height:64px;border-radius:10px;background:rgba(255,255,255,0.02);display:flex;align-items:center;justify-content:center;overflow:hidden}
.avatar-wrap.small{width:44px;height:44px}
.avatar-img{width:100%;height:100%;object-fit:cover}

/* Notification Banner */
.notification-banner{
  position:fixed;
  top:20px;
  left:50%;
  transform:translateX(-50%);
  z-index:9999;
  background:rgba(59,130,246,0.15);
  border:2px solid #3b82f6;
  border-radius:12px;
  padding:16px 24px;
  color:#e6eef6;
  font-size:0.95rem;
  font-weight:500;
  max-width:500px;
  backdrop-filter:blur(10px);
  box-shadow:0 8px 32px rgba(0,0,0,0.6);
  animation:slideDown 0.3s ease;
}

@keyframes slideDown{
  from{opacity:0;transform:translate(-50%,-20px)}
  to{opacity:1;transform:translate(-50%,0)}
}

@keyframes pulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.05)}
}

/* Loader */
.listings-loader{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:18px}
.loader-spinner{width:36px;height:36px;border-radius:50%;border:4px solid rgba(255,255,255,0.06);border-top-color:var(--primary);animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Small screens */
@media (max-width:720px){
  .site-header{flex-direction:column;align-items:flex-start;padding-bottom:8px}
  #listings{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}
  .form-actions{flex-direction:column;align-items:stretch}
}

/* Accessibility helpers */
.chip-clear{background:transparent;border:0;color:var(--muted);font-weight:700;cursor:pointer}

/* Utility */
.full-width{width:100%}
.muted{color:var(--muted)}
.section-separator{height:1px;background:rgba(255,255,255,0.03);margin:.5rem 0;border-radius:2px}

/* Vocation / category card helpers (centralized from vocation pages) */
.vocation-heading{
  margin:32px 0 16px 0;
  color:#60a5fa;
  font-size:1.2rem;
  text-align:center;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1.5px;
  text-shadow:0 2px 8px rgba(96,165,250,0.3);
}
.vocation-heading:first-of-type{margin-top:24px}
.cats{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:12px}
.cat-card{min-width:120px;padding:14px;border-radius:12px;background:#0f1f3d;backdrop-filter:blur(10px);border:2px solid transparent;cursor:pointer;text-align:center;display:flex;flex-direction:column;align-items:center;box-shadow:0 4px 15px rgba(0,0,0,0.4);transition:all 0.3s ease}
.cat-card:hover{transform:scale(1.05);border-color:#3b82f6;box-shadow:0 6px 25px rgba(59,130,246,0.5)}
.cat-card img{width:64px;height:64px;object-fit:contain;border-radius:6px;display:block;margin:0 auto;image-rendering:pixelated}
.cat-card .cat-label{margin-top:8px;font-weight:700;color:#60a5fa}
.common-card .item-label,.shared-card .item-label{margin-top:8px;font-weight:700;color:#60a5fa}
.subheading{font-size:0.95rem;color:var(--muted);margin:0 0 8px 0}
.two-column-row{display:flex;gap:20px;align-items:flex-start;justify-content:space-between;margin-top:12px}
.two-column-row .group-left,.two-column-row .group-right{flex:1;min-width:0}

@media (max-width:720px){
  .cat-card{min-width:140px}
  .two-column-row{flex-direction:column}
}

/* Right-align Off Hand column so single card sits under right-side heading */
.two-column-row .group-right{display:flex;justify-content:flex-end}
.two-column-row .group-right .cats{justify-content:flex-end}

/* Gear set modifier: larger square cards centered under heading (used only on vocation gear set rows) */
.vocation-gear-panel{max-width:980px;margin:0 auto;padding:12px 22px 20px;background:transparent}

/* Gear set row */
.gear-row{display:flex;gap:20px;justify-content:center;margin:6px 0 18px;flex-wrap:wrap}
.gear-card{min-width:140px;padding:14px;border-radius:var(--gear-radius);background:#0f1f3d;border:2px solid transparent;display:flex;flex-direction:column;align-items:center;box-shadow:0 10px 22px rgba(2,6,23,0.6);transform:translateZ(0);transition:all 0.3s ease}
.gear-card:hover{transform:translateY(-8px);border-color:#3b82f6;box-shadow:0 12px 35px rgba(59,130,246,0.6)}
.gear-card:active{transform:translateY(-4px) scale(0.98);box-shadow:0 8px 20px rgba(59,130,246,0.8)}

/* Vocation-specific gear card colors */
.gear-card.gear-card-knight:hover{transform:translateY(-8px);border-color:#00ffff;box-shadow:0 12px 35px rgba(0,255,255,0.6)}
.gear-card.gear-card-ranger:hover{transform:translateY(-8px);border-color:#ff00ff;box-shadow:0 12px 35px rgba(255,0,255,0.6)}
.gear-card.gear-card-mage:hover{transform:translateY(-8px);border-color:#ffa500;box-shadow:0 12px 35px rgba(255,165,0,0.6)}
.gear-card.gear-card-shaman:hover{transform:translateY(-8px);border-color:#00ff00;box-shadow:0 12px 35px rgba(0,255,0,0.6)}

.gear-card img{width:var(--gear-thumb-size);height:var(--gear-thumb-size);object-fit:contain;border-radius:10px;transition:transform 0.2s ease;image-rendering:pixelated}
.gear-card:active img{transform:scale(0.95)}
.gear-card .cat-label{margin-top:10px;font-weight:700;color:var(--accent);font-size:var(--gear-label-size);text-decoration:none}
.gear-card .cat-label:hover{text-decoration:underline}

/* Centered heading above the gear set */
.gear-heading-wrapper{display:flex;align-items:center;justify-content:center;padding-top:4px;padding-bottom:6px}
.gear-set-title{font-size:1.6rem;color:var(--primary);margin:0;font-weight:800;letter-spacing:0.6px;text-shadow:0 1px 0 rgba(0,0,0,0.4)}

/* Animations */
@keyframes heading-pop {from{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:none}}
.gear-set-title{animation:heading-pop 420ms cubic-bezier(.2,.85,.3,1) both}

@keyframes card-entrance {from{opacity:0;transform:translateY(12px) scale(.995)}to{opacity:1;transform:none}}
.gear-row .gear-card{opacity:0;animation:card-entrance 420ms cubic-bezier(.2,.85,.3,1) both}
.gear-row .gear-card:nth-child(1){animation-delay:120ms}
.gear-row .gear-card:nth-child(2){animation-delay:200ms}
.gear-row .gear-card:nth-child(3){animation-delay:280ms}
.gear-row .gear-card:nth-child(4){animation-delay:340ms}
.gear-row .gear-card:nth-child(5){animation-delay:420ms}
.gear-row .gear-card:nth-child(6){animation-delay:500ms}

/* Two-column headings and alignment */
.two-column-row{display:flex;gap:20px;align-items:flex-start;justify-content:space-between;margin-top:18px}
.two-column-row .group-left .subheading{text-align:left}
.two-column-row .group-right .subheading{text-align:right}

@media (max-width:720px){
  .vocation-gear-panel{padding:12px}
  .gear-row{gap:12px;justify-content:center}
  .gear-card{min-width:110px}
  .gear-set-title{font-size:1.25rem}
  .two-column-row{flex-direction:column}
  .two-column-row .group-right .subheading{text-align:left}
  .gear-row .gear-card{opacity:1;animation:none}
}

/* Slight hover pop for all category cards to match screenshot feel */
.cat-card, .gear-card{transition:transform .14s ease, box-shadow .14s ease}
.cat-card:hover{transform:translateY(var(--card-hover-translate));box-shadow:var(--card-hover-shadow)}
/* .gear-card:hover{transform:translateY(var(--gear-hover-translate));box-shadow:var(--gear-hover-shadow)} - REMOVED: Conflicts with vocation-specific gear card colors */

/* Vocation gear modal */
.vocation-modal{position:fixed;inset:0;background:rgba(2,6,23,0.85);z-index:300;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px);opacity:0;transition:opacity .3s ease}
.vocation-modal.active{display:flex;opacity:1}
.vocation-modal-content{background:linear-gradient(180deg,#06121b,#071424);border-radius:12px;max-width:1020px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px rgba(2,6,23,0.9);transform:scale(0.95);transition:transform .3s cubic-bezier(.2,.85,.3,1)}
.vocation-modal.active .vocation-modal-content{transform:scale(1)}
.vocation-modal-header{display:flex;align-items:center;padding:10px 18px 8px 18px;border-bottom:1px solid rgba(255,255,255,0.03)}
.vocation-modal-back{background:transparent;border:0;color:var(--accent);font-size:0.95rem;cursor:pointer;display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;transition:background .2s}
.vocation-modal-back:hover{background:rgba(255,255,255,0.06)}
.vocation-modal-close{position:absolute;top:14px;right:14px;background:transparent;border:0;color:var(--muted);font-size:1.8rem;cursor:pointer;z-index:10;line-height:1;padding:4px 8px;border-radius:6px;transition:background .2s}
.vocation-modal-close:hover{background:rgba(255,255,255,0.06)}
.vocation-modal-footer{text-align:center;padding:12px;color:var(--muted);font-size:0.9rem}

/* Item listing modal */
.item-modal{position:fixed;inset:0;background:rgba(2,6,23,0.85);z-index:400;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px);opacity:0;transition:opacity .3s ease}
.item-modal.active{display:flex;opacity:1}
.item-modal-content{background:linear-gradient(180deg,#06121b,#071424);border-radius:12px;width:90vw;max-width:1100px;max-height:90vh;display:flex;flex-direction:column;position:relative;box-shadow:0 20px 60px rgba(2,6,23,0.9);transform:scale(0.95);transition:transform .3s cubic-bezier(.2,.85,.3,1)}
.item-modal.active .item-modal-content{transform:scale(1)}
.item-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid rgba(255,255,255,0.03);flex-shrink:0;position:relative}
.item-modal-back{background:transparent;border:0;color:var(--accent);font-size:0.95rem;cursor:pointer;display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;transition:background .2s}
.item-modal-back:hover{background:rgba(255,255,255,0.06)}
.item-modal-title{margin:0;font-size:1.3rem;color:#60a5fa;position:absolute;left:50%;transform:translateX(-50%);font-weight:700}
.item-modal-close{background:transparent;border:0;color:var(--muted);font-size:1.8rem;cursor:pointer;line-height:1;padding:4px 8px;border-radius:6px;transition:background .2s}
.item-modal-close:hover{background:rgba(255,255,255,0.06)}
.item-modal-body{padding:24px;overflow-y:auto;flex:1}
.item-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:16px}
.item-grid-card{background:#0f1f3d;border:2px solid transparent;border-radius:8px;padding:12px;display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:transform .14s ease, box-shadow .14s ease}
.item-grid-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px rgba(2,6,23,0.7)}
.item-grid-card img{width:80px;height:80px;object-fit:contain;border-radius:6px;image-rendering:pixelated}
.item-grid-card .item-name{margin-top:8px;font-size:0.9rem;color:var(--accent);font-weight:600;text-align:center;word-break:break-word}

/* Marketplace header actions */
.marketplace-header-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:20px}

/* Marketplace tabs */
.marketplace-tabs{display:flex;gap:12px;border-bottom:2px solid rgba(255,255,255,0.1);padding-bottom:0;flex:1}
.marketplace-tab{background:transparent;border:none;color:var(--text-secondary);font-size:1rem;font-weight:600;padding:12px 24px;cursor:pointer;border-bottom:3px solid transparent;transition:all .2s ease;position:relative;bottom:-2px}
.marketplace-tab:hover{color:var(--accent)}
.marketplace-tab.active{color:var(--accent);border-bottom-color:var(--accent)}

/* Marketplace content */
.marketplace-content{position:relative}
.marketplace-view{display:none}
.marketplace-view.active{display:block}
.marketplace-listings{display:flex;flex-direction:column;gap:12px}

/* Marketplace listing cards - Grid Layout */
.marketplace-listing{background:rgba(15,31,61,0.9);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,0.05);border-radius:8px;padding:12px 14px;display:grid;grid-template-columns:85px 30px 135px 90px 90px 36px 170px 1fr;gap:5px;align-items:center;transition:all 0.2s ease;box-shadow:0 2px 8px rgba(0,0,0,0.3)}
.marketplace-listing:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(59,130,246,0.3);border-color:rgba(59,130,246,0.3)}

/* Grid Columns */
.listing-user-col{}
.listing-user-label{color:rgba(255,255,255,0.5);font-size:0.85rem;font-weight:500;transition:color 0.2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.listing-user-label:hover{color:#60a5fa}

.listing-icon-col{display:flex;justify-content:center}
.listing-item-icon{width:24px;height:24px;object-fit:contain;image-rendering:pixelated}

.listing-item-col{}
.listing-item-name{color:#60a5fa;font-weight:600;font-size:0.95rem;display:flex;align-items:center;gap:4px}

.listing-primary-col,.listing-secondary-col,.listing-bonus-col,.listing-enchant-col{font-size:0.85rem}
.listing-enchant-col{display:flex;justify-content:center}
.listing-bonus-col{display:flex;align-items:center;gap:6px}
.bonus-separator{color:rgba(255,255,255,0.3);font-weight:400}
.stat-item{font-weight:500;white-space:nowrap}
.stat-bonus{color:#fbbf24;font-weight:600;font-size:0.8rem;text-transform:uppercase;letter-spacing:0.5px;white-space:nowrap}
.stat-empty{color:rgba(255,255,255,0.2);font-size:0.9rem}
.enchant-icon{vertical-align:middle}
.elite-icon{vertical-align:middle}

.listing-price{display:flex;align-items:center;gap:6px;color:#e6eef6;font-weight:700;font-size:1rem;margin-right:12px}
.gold-icon-inline{width:18px;height:18px;object-fit:contain;image-rendering:pixelated}

.listing-action-col{justify-self:end;display:flex;align-items:center;gap:12px;padding-right:8px}

.listing-buy-btn{background:#3b82f6;color:#fff;border:none;padding:8px 20px;border-radius:6px;font-size:0.9rem;font-weight:600;cursor:pointer;transition:all 0.2s ease;white-space:nowrap}
.listing-buy-btn:hover{background:#60a5fa;transform:translateY(-1px)}
.listing-sell-btn{background:#ef4444}
.listing-sell-btn:hover{background:#f87171}

@media(max-width:768px){
  .marketplace-listing{grid-template-columns:1fr;gap:8px;padding:14px 16px}
  .listing-user-col,.listing-icon-col,.listing-item-col,.listing-primary-col,.listing-secondary-col,.listing-bonus-col,.listing-enchant-col,.listing-action-col{justify-self:start}
  .listing-action-col{justify-self:stretch;padding-right:0;flex-direction:column;align-items:stretch}
  .listing-action-col button{width:100%}
  .listing-price{margin-right:0;margin-bottom:8px;justify-content:center}
  .listing-buy-btn{flex:1;text-align:center}
}
.item-modal-footer{text-align:center;padding:12px;color:var(--muted);font-size:0.9rem;border-top:1px solid rgba(255,255,255,0.03);flex-shrink:0}

@media (max-width:720px){
  .item-modal-content{width:96vw;max-height:90vh;margin:5vh auto}
  .item-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}
  .item-modal-body{padding:16px;max-height:calc(90vh - 120px);overflow-y:auto}
  .item-grid-card img{width:64px;height:64px;image-rendering:pixelated}
  .item-grid-card{padding:10px}
}

/* Hide 'No listings match your filters' message */
#listings-section .hint:not(.discord-links):not(#selected-item-info) {display:none !important}

/* Stacked weapon/offhand layout for modal */
.vocation-modal .vocation-gear-panel{padding-top:0}
.vocation-modal .weapon-offhand-sections{display:flex;gap:40px;margin-top:18px;justify-content:center;align-items:flex-start}
.vocation-modal .weapon-section, .vocation-modal .offhand-section{display:flex;flex-direction:column;align-items:center;min-width:200px}
.vocation-modal .weapon-section .subheading{text-align:left;font-size:1rem;margin-bottom:10px}
.vocation-modal .offhand-section .subheading{text-align:right;font-size:1rem;margin-bottom:10px}
.vocation-modal .weapon-section .cats, .vocation-modal .offhand-section .cats{justify-content:center}

@media (max-width:720px){
  .vocation-modal-content{max-width:96vw;max-height:90vh;margin:5vh auto}
  .vocation-modal-close{top:8px;right:8px;font-size:1.6rem}
  .vocation-modal-header{padding:10px 14px}
  .vocation-modal-body{max-height:calc(90vh - 120px);overflow-y:auto}
  .vocation-modal .weapon-offhand-sections{flex-direction:column;gap:18px;align-items:center;width:100%}
  .vocation-modal .weapon-section, .vocation-modal .offhand-section{width:100%;display:flex;flex-direction:column;align-items:center}
  .vocation-modal .weapon-section .subheading, .vocation-modal .offhand-section .subheading{text-align:center;width:100%}
  .vocation-modal .weapon-section .cats, .vocation-modal .offhand-section .cats{justify-content:center;width:100%;display:flex}
  .cat-card{min-width:110px;padding:10px}
  .cat-card img{width:52px;height:52px}
}

/* User Profile Popup Styles */
.profile-header{display:flex;gap:16px;align-items:flex-start;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,0.06)}
.profile-header .avatar-wrap{width:80px;height:80px;flex-shrink:0}
.profile-info{flex:1;display:flex;flex-direction:column;justify-content:flex-start}
.discord-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.discord-username{color:var(--accent);font-weight:600;cursor:pointer;padding:4px 8px;background:rgba(59,130,246,0.1);border-radius:6px;transition:background 0.2s;user-select:all}
.discord-username:hover{background:rgba(59,130,246,0.2)}
.copy-hint{color:var(--success);font-size:0.85rem;font-weight:500;animation:fadeIn 0.3s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.profile-section{margin-bottom:20px}
.profile-section:last-of-type{margin-bottom:24px}

/* Reputation System Styles */
.rating-container{display:flex;flex-direction:column;gap:16px}
.rating-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.rating-label{color:var(--muted);font-size:0.95rem;min-width:90px;font-weight:600}
.stars{display:flex;gap:4px}
.star{font-size:1.8rem;color:#2c3e50;cursor:pointer;transition:all 0.2s ease;text-shadow:0 0 2px rgba(0,0,0,0.3)}
.star:hover{transform:scale(1.2);color:#fbbf24}
.star.filled{color:#fbbf24;text-shadow:0 0 8px rgba(251,191,36,0.6)}
.star.half-filled{background:linear-gradient(90deg, #fbbf24 50%, #2c3e50 50%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.rating-text{color:var(--muted);font-size:0.95rem;margin-left:8px;min-width:120px}

/* Transaction History Styles */
.transaction-history-list{scrollbar-width:thin;scrollbar-color:var(--accent) rgba(255,255,255,0.05)}
.transaction-history-list::-webkit-scrollbar{width:8px}
.transaction-history-list::-webkit-scrollbar-track{background:rgba(255,255,255,0.02);border-radius:4px}
.transaction-history-list::-webkit-scrollbar-thumb{background:var(--accent);border-radius:4px}
.transaction-history-list::-webkit-scrollbar-thumb:hover{background:var(--primary)}
.transaction-item{background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.06);border-radius:8px;padding:12px;margin-bottom:12px}
.transaction-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.transaction-header strong{color:var(--accent);font-size:1rem}
.transaction-details{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;color:var(--muted);font-size:0.9rem}
.transaction-price{display:flex;align-items:center;gap:4px;color:var(--gold);font-weight:600}
.transaction-actions{display:flex;gap:8px;align-items:center}
.rep-given{color:var(--success);font-size:0.9rem;font-weight:600;display:flex;align-items:center;gap:4px}
.gold-icon-small{width:16px;height:16px;object-fit:contain;vertical-align:middle}

@media (max-width:480px){
  .profile-header{flex-direction:column;text-align:center}
  .rating-row{flex-direction:column;align-items:flex-start;gap:8px}
  .rating-label{min-width:auto}
  .transaction-header{flex-direction:column;align-items:flex-start;gap:4px}
  .transaction-details{flex-direction:column;align-items:flex-start;gap:4px}
  .modal-inner{padding:12px;max-height:92vh;overflow-y:auto}
  .vocation-modal-content,.item-modal-content{max-width:98vw;max-height:92vh}
  #user-popup .modal-inner{max-width:98vw}
  .form-actions{gap:8px}
  .btn{padding:0.6rem 0.8rem;font-size:0.9rem}
  .site-title{font-size:1rem}
  .site-header{padding:14px}
  .site-logo{width:32px;height:32px}
  .auth-modal-wrapper{max-height:92vh}
  .vocation-modal-header h2{font-size:1.3rem}
  .item-modal-header h2{font-size:1.3rem}
  .vocation-modal-close,.item-modal-close{font-size:1.8rem;padding:4px 10px}
  .form-input,input,textarea,select{padding:0.6rem;font-size:0.9rem}
  label{font-size:0.85rem}
  .card{padding:16px;margin-bottom:10px}
  #sell-modal .vocation-modal-content{max-width:95vw;padding:0}
  #sell-modal .vocation-modal-body{padding:16px 12px;max-height:calc(92vh - 80px);overflow-y:auto}
  #sell-modal .form-group{margin-bottom:10px}
  #sell-modal .form-group label{font-size:0.9rem;margin-bottom:6px}
  #sell-modal h4{font-size:0.95rem;margin:10px 0 8px}
  #sell-modal .vocation-modal-header{padding:12px 16px;position:sticky;top:0;background:#06121b;z-index:10}
  #chat-room-modal .modal-inner{max-width:96vw;max-height:94vh}
  #chat-messages{padding:12px}
  #chat-input{font-size:0.9rem;padding:8px 12px}
  #chat-send-btn{padding:8px 16px;font-size:0.9rem}
  .chat-message div{max-width:85%!important}
}

/* Burger Menu Styles */
#burger-menu-btn{font-size:1.12rem;padding:8px 14px;min-width:auto}
.burger-menu-container{position:relative}
.burger-menu-header{position:sticky;top:0;z-index:10;background:linear-gradient(180deg,#06121b,#071424)}
.burger-menu-body{scrollbar-width:thin;scrollbar-color:var(--accent) rgba(255,255,255,0.05)}
.burger-menu-body::-webkit-scrollbar{width:8px}
.burger-menu-body::-webkit-scrollbar-track{background:rgba(255,255,255,0.02);border-radius:4px}
.burger-menu-body::-webkit-scrollbar-thumb{background:var(--accent);border-radius:4px}
.burger-menu-body::-webkit-scrollbar-thumb:hover{background:var(--primary)}
.menu-tabs{display:flex;gap:8px;border-bottom:2px solid rgba(255,255,255,0.06);flex-wrap:wrap}
.menu-tab{background:transparent;border:none;color:var(--muted);padding:12px 16px;cursor:pointer;font-size:0.95rem;font-weight:600;border-bottom:3px solid transparent;transition:all 0.3s ease;flex:1;min-width:150px}
.menu-tab:hover{color:var(--accent);background:rgba(59,130,246,0.1)}
.menu-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.menu-tab-content{display:none}
.menu-tab-content.active{display:block}
.offers-list{display:flex;flex-direction:column;gap:12px;padding-bottom:12px}
.offer-item{background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.06);border-radius:8px;padding:14px;transition:all 0.2s ease}
.offer-item:hover{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.1)}
.offer-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px;gap:12px}
.offer-item-image{width:40px;height:40px;object-fit:contain;image-rendering:pixelated;flex-shrink:0}
.offer-item-name{color:var(--accent);font-size:1.05rem;font-weight:700;flex:1}
.offer-category{color:var(--muted);font-size:0.85rem;font-style:italic;margin-top:2px}
.offer-price{color:var(--gold);font-weight:600;font-size:1rem;display:flex;align-items:center;gap:4px;white-space:nowrap}
.offer-details{display:flex;gap:16px;margin-bottom:10px;flex-wrap:wrap;align-items:center}
.offer-detail{color:var(--muted);font-size:0.9rem}
.offer-stats{width:100%;margin-top:6px;padding-top:6px;border-top:1px solid rgba(255,255,255,0.04)}
.offer-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.history-item{background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.06);border-radius:8px;padding:14px;margin-bottom:12px}
.history-header{display:flex;align-items:flex-start;margin-bottom:8px;gap:12px}
.history-type{display:inline-block;padding:3px 8px;border-radius:4px;font-size:0.8rem;font-weight:600;text-transform:uppercase;letter-spacing:0.5px}
.history-type.sold{background:rgba(16,185,129,0.2);color:var(--success)}
.history-type.bought{background:rgba(59,130,246,0.2);color:var(--accent)}
.history-date{color:var(--muted);font-size:0.85rem}
.history-details{margin-bottom:8px}
.history-user{color:var(--accent);font-weight:600}
.history-rep-status{display:flex;align-items:center;gap:6px;margin-top:8px;padding:8px;background:rgba(255,255,255,0.02);border-radius:6px}
.rep-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;font-size:0.85rem;font-weight:600}
.rep-badge.given{background:rgba(16,185,129,0.2);color:var(--success)}
.rep-badge.pending{background:rgba(251,191,36,0.2);color:var(--gold)}
.rep-badge.can-give{background:rgba(59,130,246,0.2);color:var(--accent)}

/* Chat Room Styles */
.chat-messages{scrollbar-width:thin;scrollbar-color:var(--accent) rgba(255,255,255,0.05)}
.chat-messages::-webkit-scrollbar{width:8px}
.chat-messages::-webkit-scrollbar-track{background:rgba(255,255,255,0.02);border-radius:4px}
.chat-messages::-webkit-scrollbar-thumb{background:var(--accent);border-radius:4px}
.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--primary)}
.chat-message{margin-bottom:8px;animation:fadeIn 0.3s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.chat-msg-left{align-self:flex-start}
.chat-msg-right{align-self:flex-end}

/* Giveaway Styles */
.giveaway-subtabs{display:flex;gap:8px;margin-bottom:1rem;border-bottom:2px solid rgba(255,255,255,0.06);padding-bottom:8px;flex-wrap:wrap}
.giveaway-subtab{background:transparent;border:none;color:var(--muted);padding:8px 16px;cursor:pointer;font-size:0.9rem;font-weight:600;border-bottom:3px solid transparent;transition:all 0.3s ease}
.giveaway-subtab:hover{color:var(--accent);background:rgba(59,130,246,0.1);border-radius:6px 6px 0 0}
.giveaway-subtab.active{color:var(--accent);border-bottom-color:var(--accent)}
.giveaway-subtab-content{display:none}
.giveaway-subtab-content.active{display:block}
.giveaway-card{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:8px;padding:16px;margin-bottom:12px;transition:all 0.2s ease}
.giveaway-card:hover{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.1);transform:translateY(-2px)}
.item-card-small{cursor:pointer;padding:8px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:6px;text-align:center;transition:all 0.2s}
.item-card-small:hover{background:rgba(59,130,246,0.1);border-color:var(--accent);transform:scale(1.05)}
.btn-gold{background:var(--gold);color:#0a1628;font-weight:600}
.btn-gold:hover{background:#fcd34d;transform:translateY(-2px);box-shadow:0 4px 12px rgba(251,191,36,0.4)}

@media (max-width:720px){
  .burger-menu-container{max-height:92vh!important;width:96vw}
  .menu-tabs{flex-direction:row;gap:4px;justify-content:space-between}
  .menu-tab{min-width:auto;flex:1;padding:10px 8px;font-size:0.85rem;border-bottom:3px solid transparent}
  .menu-tab.active{border-bottom-color:var(--accent)}
  .offer-header{flex-direction:row;align-items:center;flex-wrap:wrap}
  .offer-details{flex-direction:column;gap:8px;align-items:flex-start}
  .offer-item-name{font-size:0.95rem}
  .offer-price{font-size:0.9rem}
  .burger-menu-body{max-height:calc(92vh - 120px)}
  .history-header{flex-wrap:wrap}
  .giveaway-subtabs{gap:4px}
  .giveaway-subtab{padding:8px 12px;font-size:0.85rem}
}