@import url('https://fonts.googleapis.com/css2?family=Jim+Nightshade&family=Playpen+Sans+Thai:wght@400;700&display=swap');

/* ═══ VARIABLES ═══ */
:root {
  --bg:        #07041a;
  --bg2:       #0c0823;
  --surface:   #110c2e;
  --surface2:  #181040;
  --surface3:  #1f1550;
  --purple:    #6d28d9;
  --purple-lt: #8b5cf6;
  --purple-dk: #4c1d95;
  --gold:      #d4af37;
  --gold-lt:   #f0cc60;
  --text:      #e8e0f5;
  --text-muted:#8070a8;
  --border:    #2a1a5e;
  --border-lt: rgba(109,40,217,0.35);
  --glow:      rgba(109,40,217,0.28);
  --gold-glow: rgba(212,175,55,0.25);
  --r:         14px;
  --r-sm:      8px;
}

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { background:var(--bg); color:var(--text); font-family:'Playpen Sans Thai',sans-serif; min-height:100vh; overflow-x:hidden; }

body::before {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse 60% 40% at 15% 10%, rgba(109,40,217,.10) 0%, transparent 70%),
    radial-gradient(ellipse 50% 50% at 85% 85%, rgba(139,92,246,.07) 0%, transparent 70%),
    radial-gradient(ellipse 40% 30% at 50% 50%, rgba(212,175,55,.03) 0%, transparent 70%);
}

::-webkit-scrollbar { width:7px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--surface3); border-radius:4px; }
::-webkit-scrollbar-thumb:hover { background:var(--purple-dk); }

/* ═══ NAVBAR ═══ */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:1rem 2rem;
  display:flex; align-items:center; justify-content:space-between;
  background:rgba(7,4,26,.8); backdrop-filter:blur(24px);
  border-bottom:1px solid rgba(109,40,217,.2);
  transition:background .3s;
}
.navbar-logo {
  font-family:'Jim Nightshade',cursive; font-size:1.7rem;
  color:var(--gold); text-decoration:none; letter-spacing:2px;
  text-shadow:0 0 24px var(--gold-glow);
}
.nav-sym { color:var(--purple-lt); margin:0 6px; opacity:.7; }

.hamburger {
  width:38px; height:38px; display:flex; flex-direction:column;
  justify-content:center; gap:6px; cursor:pointer; padding:6px;
  border-radius:var(--r-sm); border:1px solid transparent; transition:all .2s;
}
.hamburger:hover { background:rgba(109,40,217,.15); border-color:var(--border); }
.hamburger span { display:block; height:2px; background:var(--text); border-radius:2px; transition:all .35s; }
.hamburger.open span:nth-child(1) { transform:translateY(8px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.open span:nth-child(3) { transform:translateY(-8px) rotate(-45deg); }

/* ═══ SIDEBAR ═══ */
.sidebar-overlay {
  position:fixed; inset:0; z-index:199;
  background:rgba(0,0,0,.65); backdrop-filter:blur(4px);
  opacity:0; pointer-events:none; transition:opacity .3s;
}
.sidebar-overlay.open { opacity:1; pointer-events:all; }

.sidebar {
  position:fixed; top:0; right:-340px; height:100vh; z-index:200;
  width:300px; background:var(--surface); border-left:1px solid var(--border);
  display:flex; flex-direction:column; transition:right .4s cubic-bezier(.4,0,.2,1); overflow-y:auto;
}
.sidebar.open { right:0; }

.sidebar-header {
  font-family:'Jim Nightshade',cursive; font-size:1.4rem; color:var(--gold);
  padding:1.5rem 1.5rem 1rem; border-bottom:1px solid var(--border); flex-shrink:0;
}
.sidebar-nav { list-style:none; padding:.75rem; }
.sidebar-nav li a {
  display:flex; align-items:center; gap:.7rem; padding:.75rem 1rem;
  color:var(--text-muted); text-decoration:none; border-radius:var(--r-sm);
  font-size:.95rem; transition:all .2s;
}
.sidebar-nav li a:hover { background:rgba(109,40,217,.18); color:var(--purple-lt); transform:translateX(4px); }
.nav-icon { color:var(--purple-lt); font-size:.9rem; width:18px; text-align:center; }

.sidebar-divider { height:1px; background:var(--border); margin:.5rem 1rem; }
.sidebar-social-title { padding:0 1.5rem; font-size:.72rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-muted); margin-bottom:.5rem; }
.sidebar-social { display:flex; gap:.6rem; flex-wrap:wrap; padding:0 1.25rem 1rem; }

.social-icon-btn {
  width:40px; height:40px; border-radius:10px;
  background:var(--surface2); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  text-decoration:none; overflow:hidden; transition:all .2s;
}
.social-icon-btn:hover { border-color:var(--purple-lt); box-shadow:0 0 14px var(--glow); transform:translateY(-2px); }
.social-icon-btn img { width:22px; height:22px; object-fit:contain; }

.sidebar-user-info { display:flex; align-items:center; gap:.75rem; padding:1rem 1.25rem .5rem; }
.sidebar-user-avatar { width:38px; height:38px; border-radius:50%; object-fit:cover; }
.sidebar-user-name { font-size:.9rem; color:var(--text); }
.sidebar-user-role { font-size:.75rem; color:var(--text-muted); }

.sidebar-badge-btn {
  display:flex; align-items:center; gap:.5rem; margin:.5rem 1rem;
  padding:.65rem 1rem; background:rgba(212,175,55,.08);
  border:1px solid rgba(212,175,55,.3); border-radius:var(--r-sm);
  color:var(--gold); font-size:.85rem; cursor:pointer;
  text-decoration:none; transition:all .2s;
}
.sidebar-badge-btn:hover { background:rgba(212,175,55,.15); }
.sidebar-logout-btn {
  display:flex; align-items:center; gap:.5rem; margin:.25rem 1rem;
  padding:.6rem 1rem; color:#f87171; font-size:.85rem;
  text-decoration:none; border-radius:var(--r-sm); transition:background .2s;
}
.sidebar-logout-btn:hover { background:rgba(239,68,68,.1); }
.sidebar-discord-btn {
  display:flex; align-items:center; gap:.6rem; margin:.5rem 1rem;
  padding:.75rem 1rem; background:rgba(88,101,242,.15);
  border:1px solid rgba(88,101,242,.35); border-radius:var(--r-sm);
  color:#c7cbff; font-size:.88rem; text-decoration:none; transition:all .2s;
}
.sidebar-discord-btn:hover { background:rgba(88,101,242,.25); }
.sidebar-admin-btn {
  display:flex; align-items:center; gap:.6rem; margin:.5rem 1rem 1.5rem;
  padding:.75rem 1rem; border:1px solid rgba(212,175,55,.25);
  border-radius:var(--r-sm); color:var(--gold); font-size:.88rem;
  text-decoration:none; transition:all .2s;
}
.sidebar-admin-btn:hover { background:rgba(212,175,55,.08); }

/* ═══ HERO ═══ */
.hero {
  min-height:100vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center; padding:7rem 2rem 4rem;
  position:relative; z-index:1; overflow:hidden;
}
.hero-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  filter:brightness(.28) saturate(1.4); z-index:-1;
}
.hero-bg-overlay {
  position:absolute; inset:0; z-index:-1;
  background:linear-gradient(to bottom, rgba(7,4,26,.45) 0%, rgba(7,4,26,.88) 100%);
}
.hero-cards { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.deco-card {
  position:absolute; width:55px; height:85px;
  border:1px solid rgba(109,40,217,.25); border-radius:7px; opacity:.12;
  background:linear-gradient(135deg, rgba(109,40,217,.1), transparent);
  animation:floatCard 7s ease-in-out infinite;
}
.deco-card::before {
  content:'✦'; position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  color:rgba(212,175,55,.4); font-size:1.4rem;
}
.deco-card:nth-child(1) { top:14%; left:7%;  animation-delay:0s; }
.deco-card:nth-child(2) { top:22%; right:9%; animation-delay:-2.5s; }
.deco-card:nth-child(3) { bottom:18%; left:6%;  animation-delay:-4.5s; }
.deco-card:nth-child(4) { bottom:25%; right:7%; animation-delay:-1s; }
@keyframes floatCard { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-18px)} }

.hero-ornament { font-size:1rem; letter-spacing:10px; color:var(--purple-lt); opacity:.6; margin-bottom:1.2rem; animation:fadeUp .8s ease both; }
.hero-logo-img { max-height:100px; max-width:280px; object-fit:contain; margin-bottom:1rem; filter:drop-shadow(0 0 20px rgba(212,175,55,.3)); animation:fadeUp .8s .05s ease both; }
.hero-title {
  font-family:'Jim Nightshade',cursive; font-size:clamp(3.5rem,11vw,9rem); line-height:.95;
  background:linear-gradient(135deg, var(--text) 10%, var(--gold) 50%, var(--purple-lt) 90%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  filter:drop-shadow(0 0 40px rgba(212,175,55,.2)); animation:fadeUp .8s .1s ease both;
}
.hero-subtitle {
  font-family:'Jim Nightshade',cursive; font-size:clamp(1rem,2.5vw,1.6rem);
  color:var(--gold); letter-spacing:8px; margin-top:.5rem; margin-bottom:1.5rem;
  opacity:.75; animation:fadeUp .8s .2s ease both;
}
.hero-desc { font-size:clamp(.9rem,2vw,1rem); color:var(--text-muted); max-width:480px; line-height:1.75; animation:fadeUp .8s .3s ease both; }
.hero-scroll {
  margin-top:3.5rem; display:flex; flex-direction:column; align-items:center; gap:.5rem;
  color:var(--text-muted); font-size:.7rem; letter-spacing:3px; text-transform:uppercase;
  text-decoration:none; animation:fadeUp .8s .5s ease both;
}
.scroll-line { width:1px; height:55px; background:linear-gradient(to bottom, var(--purple-lt), transparent); animation:pulseScroll 1.8s ease-in-out infinite; }
@keyframes pulseScroll { 0%,100%{opacity:.3;transform:scaleY(1)} 50%{opacity:1;transform:scaleY(1.15)} }
@keyframes fadeUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }

/* ═══ SECTION ═══ */
.section { padding:5rem 2rem; position:relative; z-index:1; max-width:1300px; margin:0 auto; }
.section-header { text-align:center; margin-bottom:3rem; }
.section-label { font-size:.7rem; letter-spacing:4px; text-transform:uppercase; color:var(--purple-lt); margin-bottom:.75rem; opacity:.8; }
.section-title { font-family:'Jim Nightshade',cursive; font-size:clamp(2rem,5vw,3.5rem); color:var(--text); }
.section-ornament { display:flex; align-items:center; gap:1rem; justify-content:center; margin-top:1rem; }
.ornament-line { flex:1; max-width:80px; height:1px; background:linear-gradient(to right, transparent, var(--border)); }
.ornament-line.right { background:linear-gradient(to left, transparent, var(--border)); }
.ornament-symbol { color:var(--gold); font-size:1.1rem; }

/* ═══ DISCORD BANNER ═══ */
.discord-banner {
  background:rgba(88,101,242,.07); border:1px solid rgba(88,101,242,.25); border-radius:var(--r);
  padding:1rem 1.5rem; display:flex; align-items:center; justify-content:space-between; gap:1rem;
  max-width:640px; margin:0 auto 2.5rem;
}
.discord-banner-text { font-size:.9rem; color:var(--text-muted); }
.btn-discord {
  display:inline-flex; align-items:center; gap:.5rem; padding:.6rem 1.2rem;
  background:#5865f2; color:#fff; border-radius:var(--r-sm); text-decoration:none;
  font-size:.85rem; white-space:nowrap; transition:all .2s; font-family:'Playpen Sans Thai',sans-serif;
}
.btn-discord:hover { background:#4752c4; transform:translateY(-1px); }

/* ═══════════════════════════════════════
   PLAYER CARD — Full Image Style
═══════════════════════════════════════ */
.players-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(240px,1fr));
  gap:1.5rem;
}

.player-card {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:18px; overflow:hidden;
  cursor:pointer; position:relative;
  transition:all .35s cubic-bezier(.4,0,.2,1);
}
.player-card::after {
  content:'✦'; position:absolute; top:10px; right:13px;
  color:rgba(212,175,55,.2); font-size:.85rem; pointer-events:none; z-index:5;
}
.player-card:hover {
  transform:translateY(-8px);
  border-color:rgba(109,40,217,.6);
  box-shadow:0 24px 50px rgba(0,0,0,.55), 0 0 28px var(--glow);
}

/* ── Image Area ── */
.pc-img-area {
  position:relative;
  width:100%; height:230px;
  overflow:hidden;
  background:linear-gradient(135deg, var(--surface2), var(--surface3));
  flex-shrink:0;
}

.pc-img {
  width:100%; height:100%;
  object-fit:cover; object-position:top center;
  display:block;
  transition:transform .45s ease;
}
.player-card:hover .pc-img { transform:scale(1.06); }

.pc-img-placeholder {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  font-size:3.5rem; color:var(--text-muted); opacity:.3;
}

/* Gradient fade bottom of image */
.pc-img-gradient {
  position:absolute; bottom:0; left:0; right:0; height:70%;
  background:linear-gradient(to top, var(--surface) 0%, transparent 100%);
  pointer-events:none;
}

/* Name + role overlaid on image */
.pc-name-overlay {
  position:absolute; bottom:0; left:0; right:0;
  padding:.6rem 1.1rem .9rem; z-index:3;
}
.player-name {
  font-family:'Jim Nightshade',cursive; font-size:1.55rem; line-height:1;
  color:#fff; text-shadow:0 2px 8px rgba(0,0,0,.7), 0 0 20px rgba(109,40,217,.4);
  margin-bottom:.35rem;
}
.player-role {
  display:inline-block; padding:.18rem .75rem;
  background:rgba(109,40,217,.35); border:1px solid rgba(109,40,217,.5);
  border-radius:20px; font-size:.68rem; color:var(--purple-lt); letter-spacing:1px;
  backdrop-filter:blur(4px);
}

/* Tarot corner ornaments */
.pc-corner {
  position:absolute; width:18px; height:18px; z-index:4; pointer-events:none;
}
.pc-corner::before,.pc-corner::after {
  content:''; position:absolute; background:var(--gold); opacity:.5; border-radius:1px;
}
.pc-corner::before { width:100%; height:2px; top:0; left:0; }
.pc-corner::after  { width:2px; height:100%; top:0; left:0; }
.pc-corner.tl { top:10px; left:10px; }
.pc-corner.tr { top:10px; right:10px; transform:scaleX(-1); }

/* ── Card Body ── */
.pc-body {
  padding:.9rem 1.1rem 1.1rem;
  display:flex; flex-direction:column; gap:.55rem;
}

.player-desc {
  font-size:.82rem; color:var(--text-muted); line-height:1.6;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
}

.pc-meta {
  display:flex; flex-direction:column; gap:.35rem;
}
.player-discord {
  display:flex; align-items:center; gap:.4rem; font-size:.75rem; color:var(--text-muted);
}
.discord-dot {
  width:7px; height:7px; border-radius:50%; background:#5865f2; flex-shrink:0;
  box-shadow:0 0 5px rgba(88,101,242,.5);
}
.player-badge {
  display:inline-block; padding:.15rem .65rem;
  background:rgba(212,175,55,.1); border:1px solid rgba(212,175,55,.35);
  border-radius:4px; font-size:.7rem; color:var(--gold);
}

/* ── Card Social Row ── */
.card-social-row {
  display:flex; gap:.45rem; flex-wrap:wrap;
  padding-top:.6rem; border-top:1px solid rgba(42,26,94,.5);
}
.card-social-btn {
  width:30px; height:30px; border-radius:8px;
  background:var(--surface2); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  text-decoration:none; overflow:hidden; transition:all .2s;
}
.card-social-btn:hover { border-color:var(--purple-lt); transform:translateY(-2px); box-shadow:0 4px 10px var(--glow); }
.card-social-btn img { width:18px; height:18px; object-fit:contain; }
.card-social-btn.lg { width:36px; height:36px; border-radius:10px; }
.card-social-btn.lg img { width:22px; height:22px; }

/* "กดดูโปรไฟล์" hint */
.card-view-btn {
  font-size:.72rem; color:var(--purple-lt); text-align:center;
  opacity:0; transition:opacity .25s; letter-spacing:.5px; padding-top:.25rem;
}
.player-card:hover .card-view-btn { opacity:1; }

/* ── Skeleton Cards ── */
.skeleton-card { pointer-events:none; }
.skel {
  background:linear-gradient(90deg, var(--surface2) 25%, rgba(109,40,217,.08) 50%, var(--surface2) 75%);
  background-size:200% 100%; animation:shimmer 1.6s infinite; border-radius:4px;
}
/* Skeleton uses old layout — override for new */
.skeleton-card .player-card-top {
  height:230px; background:var(--surface2); position:relative;
}
.skeleton-card .player-skin-wrapper {
  position:absolute; inset:0; bottom:auto; left:auto; transform:none;
}
.skeleton-card .player-skin.skeleton {
  width:100%; height:100%; border-radius:0; border:none;
}
.player-card-body { padding:.9rem 1.1rem 1.1rem; display:flex; flex-direction:column; gap:.5rem; }
.skel-name   { height:22px; width:55%; }
.skel-role   { height:16px; width:35%; border-radius:20px; }
.skel-desc   { height:10px; width:80%; }
.skel-desc2  { height:10px; width:60%; }
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

.no-players { text-align:center; padding:4rem 2rem; color:var(--text-muted); }

/* ═══ ABOUT ═══ */
.section-about { background:linear-gradient(to bottom, transparent, rgba(17,12,46,.5), transparent); }
.about-content { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1.5rem; max-width:900px; margin:0 auto; }
.about-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r); padding:2rem 1.5rem; text-align:center; transition:all .3s; }
.about-card:hover { border-color:var(--border-lt); transform:translateY(-4px); box-shadow:0 12px 30px rgba(0,0,0,.3); }
.about-icon { font-size:2rem; color:var(--gold); margin-bottom:1rem; }
.about-card h3 { font-family:'Jim Nightshade',cursive; font-size:1.4rem; color:var(--text); margin-bottom:.5rem; }
.about-card p  { font-size:.88rem; color:var(--text-muted); line-height:1.65; }

/* ═══ FOOTER ═══ */
.footer { padding:3rem 2rem 2rem; border-top:1px solid var(--border); text-align:center; position:relative; z-index:1; }
.footer-logo { font-family:'Jim Nightshade',cursive; font-size:2rem; color:var(--gold); opacity:.5; margin-bottom:1rem; }
.footer-social { display:flex; gap:.75rem; justify-content:center; flex-wrap:wrap; margin-bottom:1.25rem; }
.footer-text { font-size:.75rem; color:var(--text-muted); letter-spacing:2px; }

/* ═══ PLAYER POPUP ═══ */
.popup-overlay {
  position:fixed; inset:0; z-index:600;
  background:rgba(0,0,0,.82); backdrop-filter:blur(10px);
  display:flex; align-items:center; justify-content:center; padding:1rem;
  opacity:0; pointer-events:none; transition:opacity .3s;
}
.popup-overlay.open { opacity:1; pointer-events:all; }

.popup-card {
  position:relative; width:100%; max-width:380px;
  background:var(--surface); border:1px solid var(--border); border-radius:20px;
  overflow:hidden; max-height:92vh; overflow-y:auto;
  transform:translateY(24px) scale(.97); transition:transform .35s cubic-bezier(.4,0,.2,1);
  box-shadow:0 32px 80px rgba(0,0,0,.7), 0 0 40px rgba(109,40,217,.15);
}
.popup-overlay.open .popup-card { transform:translateY(0) scale(1); }
.popup-card::-webkit-scrollbar { width:4px; }
.popup-card::-webkit-scrollbar-thumb { background:var(--surface3); border-radius:2px; }

.popup-close {
  position:absolute; top:12px; right:12px; z-index:10;
  width:32px; height:32px; border-radius:50%;
  background:rgba(0,0,0,.55); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.12); color:var(--text); font-size:.85rem;
  cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all .2s;
}
.popup-close:hover { background:rgba(239,68,68,.3); border-color:rgba(239,68,68,.5); color:#f87171; }

.popup-img-frame { position:relative; width:100%; height:340px; overflow:hidden; background:linear-gradient(135deg,var(--surface2),var(--surface3)); flex-shrink:0; }
.popup-img { width:100%; height:100%; object-fit:cover; object-position:top center; display:block; transition:transform .4s; }
.popup-card:hover .popup-img { transform:scale(1.03); }
.popup-img-gradient {
  position:absolute; inset:0;
  background:linear-gradient(to bottom, transparent 30%, rgba(17,12,46,.7) 70%, var(--surface) 100%);
  pointer-events:none;
}
.popup-frame-corner { position:absolute; width:22px; height:22px; z-index:2; pointer-events:none; }
.popup-frame-corner::before,.popup-frame-corner::after { content:''; position:absolute; background:var(--gold); opacity:.55; border-radius:1px; }
.popup-frame-corner::before { width:100%; height:2px; }
.popup-frame-corner::after  { width:2px; height:100%; }
.popup-frame-corner.tl { top:12px; left:12px; }
.popup-frame-corner.tr { top:12px; right:12px; transform:scaleX(-1); }
.popup-frame-corner.bl { bottom:12px; left:12px; transform:scaleY(-1); }
.popup-frame-corner.br { bottom:12px; right:12px; transform:scale(-1); }

.popup-name-overlay { position:absolute; bottom:0; left:0; right:0; padding:1rem 1.25rem .8rem; z-index:3; }
.popup-name { font-family:'Jim Nightshade',cursive; font-size:2.2rem; line-height:1; color:#fff; text-shadow:0 2px 12px rgba(0,0,0,.8),0 0 30px rgba(109,40,217,.5); }

.popup-body { padding:1rem 1.5rem 1.75rem; display:flex; flex-direction:column; gap:.75rem; }
.popup-discord-row { display:flex; align-items:center; gap:.6rem; }
.popup-discord-avatar { width:30px; height:30px; border-radius:50%; object-fit:cover; border:2px solid rgba(88,101,242,.4); }
.popup-discord-name { font-size:.82rem; color:#8fa3f7; }
.popup-role {
  display:inline-block; padding:.2rem .85rem;
  background:rgba(109,40,217,.18); border:1px solid rgba(109,40,217,.35);
  border-radius:20px; font-size:.72rem; color:var(--purple-lt); letter-spacing:1px; align-self:flex-start;
}
.popup-desc {
  font-size:.88rem; color:var(--text-muted); line-height:1.7;
  padding:.85rem 1rem; background:rgba(255,255,255,.03);
  border-left:2px solid rgba(212,175,55,.3); border-radius:0 6px 6px 0;
}
.popup-badge-wrap { display:flex; }
.popup-social { display:flex; gap:.5rem; flex-wrap:wrap; padding-top:.5rem; border-top:1px solid rgba(42,26,94,.6); }

/* ═══ BUTTONS ═══ */
.btn {
  display:inline-flex; align-items:center; gap:.5rem; padding:.65rem 1.4rem;
  border-radius:var(--r-sm); font-family:'Playpen Sans Thai',sans-serif; font-size:.9rem;
  cursor:pointer; transition:all .2s; border:none; text-decoration:none; line-height:1;
}
.btn-primary { background:var(--purple); color:#fff; box-shadow:0 4px 14px rgba(109,40,217,.3); }
.btn-primary:hover { background:var(--purple-lt); transform:translateY(-1px); }
.btn-ghost { background:transparent; color:var(--text-muted); border:1px solid var(--border); }
.btn-ghost:hover { background:rgba(255,255,255,.05); color:var(--text); }

/* ═══ TOAST ═══ */
.toast {
  position:fixed; bottom:1.5rem; right:1.5rem; z-index:999;
  padding:.75rem 1.2rem; border-radius:var(--r-sm); font-size:.88rem; pointer-events:none;
  transform:translateY(80px); opacity:0; transition:all .35s cubic-bezier(.4,0,.2,1);
}
.toast.show { transform:translateY(0); opacity:1; }
.toast.success { background:rgba(34,197,94,.12); border:1px solid rgba(34,197,94,.3); color:#4ade80; }
.toast.error   { background:rgba(239,68,68,.12); border:1px solid rgba(239,68,68,.3); color:#f87171; }

/* ═══ RESPONSIVE ═══ */
@media (max-width:640px) {
  .players-grid { grid-template-columns:1fr 1fr; gap:1rem; }
  .pc-img-area { height:180px; }
  .player-name { font-size:1.25rem; }
  .discord-banner { flex-direction:column; text-align:center; }
  .navbar { padding:.9rem 1rem; }
  .section { padding:4rem 1rem; }
}
@media (max-width:400px) {
  .players-grid { grid-template-columns:1fr; }
}
@media (max-width:480px) {
  .popup-img-frame { height:260px; }
  .popup-name { font-size:1.8rem; }
}

/* ═══ HERO LOGO ═══ */
.hero-logo-img { max-height:100px; max-width:280px; object-fit:contain; margin-bottom:1rem; filter:drop-shadow(0 0 20px rgba(212,175,55,.3)); animation:fadeUp .8s .05s ease both; }

/* ═══ AUDIO BUTTON ═══ */
.audio-btn {
  position: fixed;
  bottom: 1.5rem; left: 1.5rem;
  z-index: 300;
  width: 42px; height: 42px;
  border-radius: 50%;
  background: var(--surface2);
  border: 1px solid var(--border);
  color: var(--text-muted);
  font-size: .95rem;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .25s;
  box-shadow: 0 4px 16px rgba(0,0,0,.3);
}
.audio-btn:hover {
  border-color: var(--purple-lt);
  color: var(--purple-lt);
  box-shadow: 0 4px 20px var(--glow);
  transform: scale(1.08);
}
/* กำลังเล่น — pulse animation */
.audio-btn.playing {
  border-color: var(--purple);
  color: var(--purple-lt);
  animation: audioPulse 2s ease-in-out infinite;
}
@keyframes audioPulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(109,40,217,.4); }
  50%      { box-shadow: 0 0 0 8px rgba(109,40,217,.0); }
}

/* ═══════════════════════════════════════
   DEVELOPER CARDS (Premium)
═══════════════════════════════════════ */
.dev-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1.5rem;
  max-width: 900px;
  margin: 0 auto;
}

.dev-card {
  position: relative;
  height: 340px;
  border-radius: 20px;
  overflow: hidden;
  cursor: pointer;
  border: 1px solid var(--border);
  transition: all .4s cubic-bezier(.4,0,.2,1);
  box-shadow: 0 8px 32px rgba(0,0,0,.4);
}
.dev-card:hover {
  transform: translateY(-10px) scale(1.02);
  box-shadow: 0 24px 60px rgba(0,0,0,.6), 0 0 40px rgba(255,106,193,.15);
  border-color: rgba(255,106,193,.4);
}

/* Background image */
.dev-card-bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  transition: transform .5s ease;
}
.dev-card:hover .dev-card-bg { transform: scale(1.06); }

/* Multi-layer gradient */
.dev-card-overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(to top, rgba(7,4,26,.97) 0%, rgba(7,4,26,.6) 50%, rgba(7,4,26,.2) 100%),
    linear-gradient(135deg, rgba(255,106,193,.08) 0%, rgba(124,106,255,.08) 100%);
}

/* Corner ornaments (gold) */
.dev-card-corner {
  position: absolute; width: 20px; height: 20px; z-index: 3; pointer-events: none;
}
.dev-card-corner::before,.dev-card-corner::after {
  content: ''; position: absolute;
  background: linear-gradient(135deg,#ff6ac1,#7c6aff); border-radius: 1px;
}
.dev-card-corner::before { width: 100%; height: 2px; }
.dev-card-corner::after  { width: 2px; height: 100%; }
.dev-card-corner.tl { top:12px;left:12px; }
.dev-card-corner.tr { top:12px;right:12px;transform:scaleX(-1); }
.dev-card-corner.bl { bottom:12px;left:12px;transform:scaleY(-1); }
.dev-card-corner.br { bottom:12px;right:12px;transform:scale(-1); }

/* Content */
.dev-card-content {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 1.5rem;
  z-index: 2;
}
.dev-label {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .18rem .7rem;
  background: linear-gradient(135deg, rgba(255,106,193,.25), rgba(124,106,255,.25));
  border: 1px solid rgba(255,106,193,.4);
  border-radius: 20px; font-size: .68rem; color: #f0abfc;
  letter-spacing: 1px; margin-bottom: .6rem;
}
.dev-name {
  font-family: 'Jim Nightshade', cursive;
  font-size: 2rem; color: #fff; line-height: 1;
  text-shadow: 0 2px 12px rgba(0,0,0,.8);
  margin-bottom: .3rem;
}
.dev-position {
  font-size: .82rem; color: rgba(255,255,255,.65);
  margin-bottom: .75rem;
}
.dev-social { display: flex; gap: .4rem; }
.dev-card-social-btn {
  width: 30px; height: 30px; border-radius: 8px;
  background: rgba(255,255,255,.1); backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.15);
  display: flex; align-items: center; justify-content: center;
  text-decoration: none; transition: all .2s;
}
.dev-card-social-btn:hover { background:rgba(255,106,193,.3); border-color:rgba(255,106,193,.5); transform:translateY(-2px); }
.dev-card-social-btn img { width: 16px; height: 16px; object-fit: contain; }

/* Avatar top-right */
.dev-card-avatar {
  position: absolute; top: 16px; right: 16px; z-index: 3;
  width: 52px; height: 52px; border-radius: 50%;
  object-fit: cover;
  border: 2px solid rgba(255,106,193,.6);
  box-shadow: 0 0 16px rgba(255,106,193,.3);
}

/* Skeleton */
.dev-card-skeleton {
  height: 340px; border-radius: 20px;
  background: linear-gradient(90deg, var(--surface2) 25%, rgba(255,106,193,.05) 50%, var(--surface2) 75%);
  background-size: 200% 100%; animation: shimmer 1.6s infinite;
}

/* ═══ ADMIN MEMBER CARDS ═══ */
.admin-member-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px,1fr));
  gap: 1rem;
  max-width: 900px; margin: 0 auto;
}

.admin-member-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px; overflow: visible;
  cursor: pointer;
  transition: all .3s cubic-bezier(.4,0,.2,1);
  position: relative;
}
.admin-member-card::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(109,40,217,.04), transparent);
  pointer-events: none;
}
.admin-member-card:hover {
  transform: translateY(-6px);
  border-color: rgba(109,40,217,.5);
  box-shadow: 0 16px 36px rgba(0,0,0,.4), 0 0 20px var(--glow);
}

.admin-member-img-area {
  position: relative; height: 90px; overflow: visible;
  background: linear-gradient(135deg, var(--surface2), var(--surface3));
  border-radius: 14px 14px 0 0; overflow: hidden;
}
.admin-member-bg {
  width: 100%; height: 100%;
  object-fit: cover; opacity: .55;
  transition: transform .4s;
}
.admin-member-card:hover .admin-member-bg { transform: scale(1.08); }
.admin-member-img-area-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, var(--surface) 0%, rgba(7,4,26,.3) 100%);
}
/* Avatar — fixed ที่ขอบล่างของ bg image */
.admin-member-avatar {
  position: absolute; top: 54px; left: 50%; transform: translateX(-50%);
  width: 72px; height: 72px; border-radius: 50%;
  object-fit: cover;
  border: 4px solid var(--surface);
  box-shadow: 0 0 0 2px var(--purple), 0 4px 20px rgba(109,40,217,.5);
  z-index: 2;
}

.admin-member-body {
  padding: 2.8rem 1rem 1rem;
  text-align: center;
}
.admin-member-name {
  font-family: 'Jim Nightshade', cursive;
  font-size: 1.25rem; color: var(--text); margin-bottom: .25rem;
}
.admin-member-pos {
  font-size: .72rem; color: var(--purple-lt);
  padding: .15rem .65rem;
  background: rgba(109,40,217,.15); border: 1px solid rgba(109,40,217,.3);
  border-radius: 20px; display: inline-block; margin-bottom: .6rem;
}
.admin-member-desc {
  font-size: .78rem; color: var(--text-muted); line-height: 1.55;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  margin-bottom: .6rem;
}
.admin-member-social { display: flex; justify-content: center; gap: .4rem; }
.admin-member-card-hint {
  font-size: .68rem; color: var(--purple-lt); opacity: 0;
  transition: opacity .2s; padding-top: .3rem;
}
.admin-member-card:hover .admin-member-card-hint { opacity: 1; }

/* Skeleton admin */
.admin-member-skeleton {
  height: 240px; border-radius: 14px;
  background: linear-gradient(90deg, var(--surface2) 25%, rgba(109,40,217,.06) 50%, var(--surface2) 75%);
  background-size: 200% 100%; animation: shimmer 1.6s infinite;
}

.section-admins {
  background: linear-gradient(to bottom, rgba(17,12,46,.3), transparent);
}

/* ═══ DISCORD BANNER — Not Registered ═══ */
.discord-banner-warn {
  background: rgba(239,68,68,.06);
  border-color: rgba(239,68,68,.25);
  gap: .85rem;
  align-items: flex-start;
}
.discord-warn-icon {
  color: #f87171; font-size: 1.3rem; flex-shrink: 0; padding-top: .1rem;
}

/* Sidebar not registered notice */
.sidebar-not-registered {
  margin: .25rem 1rem .5rem;
  padding: .65rem .9rem;
  background: rgba(239,68,68,.07);
  border: 1px solid rgba(239,68,68,.2);
  border-radius: var(--r-sm);
  font-size: .78rem; color: #f87171; line-height: 1.5;
  display: flex; gap: .5rem; align-items: flex-start;
}
.sidebar-not-registered i { flex-shrink: 0; margin-top: .15rem; }

/* ═══ SIDEBAR — Not Registered User ═══ */
.sidebar-unreg {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 1.25rem 1rem .75rem;
  gap: .4rem;
}

.sidebar-unreg-avatar-wrap {
  position: relative;
  margin-bottom: .35rem;
}
.sidebar-unreg-avatar {
  width: 64px; height: 64px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid rgba(239,68,68,.4);
  box-shadow: 0 0 0 3px rgba(239,68,68,.1), 0 4px 16px rgba(0,0,0,.4);
  display: block;
}
.sidebar-unreg-dot {
  position: absolute; bottom: 2px; right: 2px;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: #f87171;
  border: 2px solid var(--surface);
  box-shadow: 0 0 6px rgba(239,68,68,.5);
}

/* ชื่อ Discord */
.sidebar-unreg .sidebar-user-name {
  font-size: .95rem;
  color: var(--text);
  font-weight: 700;
}

/* กำกับ "ยังไม่มีรายชื่อ" */
.sidebar-unreg-label {
  display: flex; align-items: center; gap: .35rem;
  font-size: .75rem; color: #f87171;
  background: rgba(239,68,68,.08);
  border: 1px solid rgba(239,68,68,.2);
  border-radius: 20px;
  padding: .2rem .75rem;
}

.sidebar-unreg-hint {
  font-size: .72rem;
  color: var(--text-muted);
  line-height: 1.4;
  padding: 0 .5rem;
}

/* ═══ COOKIE BANNER ═══ */
#cookieBanner {
  position: fixed;
  bottom: -200px;
  left: 50%; transform: translateX(-50%);
  width: calc(100% - 2rem);
  max-width: 760px;
  z-index: 800;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 1.1rem 1.4rem;
  box-shadow: 0 -4px 40px rgba(0,0,0,.5), 0 0 24px rgba(109,40,217,.1);
  transition: bottom .5s cubic-bezier(.4,0,.2,1), opacity .4s;
  opacity: 0;
}
#cookieBanner.show { bottom: 1.25rem; opacity: 1; }
#cookieBanner.hide { bottom: -200px; opacity: 0; }

.cookie-inner {
  display: flex; align-items: center; gap: 1.25rem; flex-wrap: wrap;
}
.cookie-left { flex: 1; min-width: 200px; }
.cookie-title {
  display: flex; align-items: center; gap: .5rem;
  font-size: .92rem; color: var(--text);
  font-weight: 700; margin-bottom: .35rem;
}
.cookie-title i { color: var(--gold); }
.cookie-desc {
  font-size: .8rem; color: var(--text-muted); line-height: 1.55;
}
.cookie-link {
  color: #60a5fa; text-decoration: none; margin-left: .25rem;
}
.cookie-link:hover { text-decoration: underline; }

.cookie-actions { display: flex; gap: .6rem; flex-shrink: 0; }

.cookie-btn-accept {
  display: flex; align-items: center; gap: .4rem;
  padding: .6rem 1.2rem;
  background: var(--purple); color: #fff;
  border: none; border-radius: var(--r-sm);
  font-family: 'Playpen Sans Thai', sans-serif;
  font-size: .85rem; cursor: pointer;
  box-shadow: 0 4px 12px rgba(109,40,217,.3);
  transition: all .2s; white-space: nowrap;
}
.cookie-btn-accept:hover { background: var(--purple-lt); transform: translateY(-1px); }

.cookie-btn-decline {
  padding: .6rem 1rem;
  background: transparent; color: var(--text-muted);
  border: 1px solid var(--border); border-radius: var(--r-sm);
  font-family: 'Playpen Sans Thai', sans-serif;
  font-size: .85rem; cursor: pointer;
  transition: all .2s; white-space: nowrap;
}
.cookie-btn-decline:hover { background: rgba(255,255,255,.04); color: var(--text); }

@media (max-width: 540px) {
  .cookie-inner { flex-direction: column; align-items: flex-start; }
  .cookie-actions { width: 100%; }
  .cookie-btn-accept, .cookie-btn-decline { flex: 1; justify-content: center; }
}
