@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&display=swap');

:root {
  --gold: #FFD700; --gold-d: #B8860B; --gold-g: rgba(255,215,0,.35);
  --green: #5AC54F; --green-d: #2E6B28; --green-g: rgba(90,197,79,.35);
  --red: #FF4444; --cyan: #4FC3D4;
  --bg: #080d08; --border: #2e2e2e; --dim: #555;
}
*{margin:0;padding:0;box-sizing:border-box}
body{
  background:var(--bg);
  background-image:
    radial-gradient(ellipse 100% 60% at 50% 0%,rgba(90,197,79,.07) 0%,transparent 65%),
    repeating-linear-gradient(0deg,transparent,transparent 31px,rgba(255,255,255,.012) 32px),
    repeating-linear-gradient(90deg,transparent,transparent 31px,rgba(255,255,255,.012) 32px);
  background-size:100% 100%,32px 32px,32px 32px;
  min-height:100vh;
  font-family:'Press Start 2P',monospace;
  color:#ccc;
  overflow-x:hidden;
  padding-top:40px; /* Space for top banner */
}
#bgCanvas{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.25}

.wrapper{position:relative;z-index:1;width:100%;max-width:720px;margin:0 auto;padding:36px 16px 60px}
.gold-bar{height:3px;background:repeating-linear-gradient(90deg,var(--gold) 0 16px,var(--gold-d) 16px 32px);box-shadow:0 0 16px var(--gold-g);margin-bottom:4px}
.gold-bar.b{margin-top:4px;margin-bottom:0}

/* HEADER */
.header{text-align:center;padding:40px 20px 28px}
.duck{font-size:52px;display:block;margin-bottom:14px;animation:bob 2s ease-in-out infinite;user-select:none;cursor:default}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.title{font-size:clamp(20px,5.5vw,36px);color:var(--gold);text-shadow:4px 4px 0 #000,0 0 40px var(--gold-g);animation:glow 2.4s ease-in-out infinite;letter-spacing:3px}
@keyframes glow{0%,100%{text-shadow:4px 4px 0 #000,0 0 20px rgba(255,215,0,.4)}50%{text-shadow:4px 4px 0 #000,0 0 60px rgba(255,215,0,.85)}}
.sub{font-size:clamp(6px,1.5vw,8px);color:var(--green);letter-spacing:2px;line-height:2;margin-top:10px;text-shadow:0 0 10px var(--green-g)}

/* NAV */
.nav { display: flex; gap: 10px; justify-content: center; margin-bottom: 24px; flex-wrap: wrap; }
.nav-link { background: #0a0a0a; border: 2px solid var(--border); color: #aaa; text-decoration: none; font-size: clamp(6px, 1.5vw, 8px); padding: 10px 16px; transition: all 0.2s; letter-spacing: 2px; }
.nav-link:hover { border-color: var(--green); color: var(--green); }
.nav-link.active { border-color: var(--gold); color: var(--gold); background: rgba(255,215,0,0.05); }

/* STATUS STRIP */
.status-strip{display:flex;align-items:center;gap:14px;background:#0d0d0d;border:3px solid var(--border);padding:12px 18px;margin-bottom:12px;flex-wrap:wrap}
.dot{width:12px;height:12px;flex-shrink:0}
.dot.online{background:var(--green);box-shadow:0 0 10px var(--green);animation:blink 1.2s ease-in-out infinite}
.dot.offline{background:var(--red);box-shadow:0 0 8px var(--red)}
.dot.checking{background:var(--gold);box-shadow:0 0 8px var(--gold);animation:blink .6s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.slbl{font-size:clamp(7px,1.8vw,10px);text-shadow:1px 1px 0 #000}
.slbl.online{color:var(--green)}.slbl.offline{color:var(--red)}.slbl.checking{color:var(--gold)}
.smeta{display:flex;gap:14px;margin-left:auto;flex-wrap:wrap;align-items:center}
.meta{font-size:6px;color:var(--dim);letter-spacing:1px}
.meta b{color:var(--gold)}.meta.g b{color:var(--green)}
.rbtn{background:transparent;border:2px solid #2a2a2a;color:var(--dim);font-family:'Press Start 2P',monospace;font-size:6px;padding:5px 9px;cursor:pointer;transition:all .15s;letter-spacing:1px}
.rbtn:hover{border-color:var(--green);color:var(--green)}
.rbtn.spin{animation:spin .5s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* IP PANELS */
.panels{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
@media(max-width:500px){.panels{grid-template-columns:1fr}}
.ip-panel{background:linear-gradient(180deg,#1a1a1a,#111);border:4px solid var(--border);overflow:hidden}
.ip-head{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:3px solid}
.ip-head.java{background:linear-gradient(180deg,#2e6b28,#1a3d18);border-color:var(--green)}
.ip-head.bedrock{background:linear-gradient(180deg,#1a4a7a,#0d2a4a);border-color:var(--cyan)}
.px-icon{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;width:20px;height:20px;flex-shrink:0}
.px-icon div{border-radius:1px}
.g0{background:#5AC54F}.g1{background:#3A7D35}.g2{background:#8B6040}.g3{background:#6B4020}.g4{background:#4a9a40}.g5{background:#7B5030}
.d0{background:#4FC3D4}.d1{background:#2A8FA0}.d2{background:#7DE0EE}.d3{background:#1A6070}
.ip-title{font-size:clamp(7px,1.5vw,9px);color:#fff;text-shadow:2px 2px 0 #000}
.ip-body{padding:12px}
.ip-row{background:#000;border:2px solid #1e1e1e;padding:10px 12px;display:flex;align-items:center;gap:8px;margin-bottom:8px;position:relative;overflow:hidden;flex-wrap:wrap}
.ip-row::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px}
.java .ip-row::before{background:var(--green);box-shadow:0 0 8px var(--green)}
.bedrock .ip-row::before{background:var(--cyan);box-shadow:0 0 8px var(--cyan)}
.ip-addr{font-size:clamp(7px,1.8vw,10px);flex:1;word-break:break-all;text-shadow:0 0 10px currentColor,1px 1px 0 #000;user-select:all;cursor:text}
.java .ip-addr{color:var(--green)}.bedrock .ip-addr{color:var(--cyan)}
.cbtn{background:linear-gradient(180deg,#2a2a2a,#181818);border:2px solid #000;box-shadow:inset 1px 1px 0 rgba(255,255,255,.12),1px 2px 0 #000;color:#aaa;font-family:'Press Start 2P',monospace;font-size:clamp(5px,1vw,6px);padding:7px 10px;cursor:pointer;white-space:nowrap;transition:all .1s;letter-spacing:1px;flex-shrink:0}
.cbtn:hover{color:var(--gold);border-color:var(--gold-d)}
.cbtn:active{transform:translate(1px,2px);box-shadow:none}
.cbtn.copied{background:linear-gradient(180deg,var(--gold),var(--gold-d));color:#000}
.cbtn:disabled{opacity:.6;cursor:default}
.port-chip{font-size:6px;color:var(--dim);background:#0a0a0a;border:1px solid #1e1e1e;padding:4px 8px;letter-spacing:1px}
.port-chip b{color:var(--gold)}

/* ══ PLAYER SECTION ══ */
.psection{background:#0a0a0a;border:4px solid var(--border);overflow:hidden;margin-bottom:12px}
.psection-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:14px 18px;border-bottom:3px solid var(--border);flex-wrap:wrap}
.psection-title{font-size:clamp(7px,1.8vw,10px);color:#fff;letter-spacing:2px;text-shadow:2px 2px 0 #000}
.count-badge{border:2px solid;font-size:7px;padding:4px 10px;letter-spacing:1px;white-space:nowrap}
.count-badge.online{border-color:var(--green);color:var(--green);background:rgba(90,197,79,.08);text-shadow:0 0 8px var(--green-g)}
.count-badge.empty{border-color:var(--dim);color:var(--dim)}

/* search */
.search-wrap{padding:10px 18px;border-bottom:2px solid var(--border)}
.search{width:100%;background:#000;border:2px solid #1e1e1e;color:var(--green);font-family:'Press Start 2P',monospace;font-size:clamp(7px,1.5vw,9px);padding:9px 12px;letter-spacing:1px;outline:none;transition:border-color .2s}
.search::placeholder{color:#252525}
.search:focus{border-color:var(--green)}

/* list */
.plist{padding:4px 0;min-height:80px}
.pitem{display:flex;align-items:center;gap:14px;padding:10px 18px;border-bottom:1px solid #0f0f0f;transition:background .15s}
.pitem:last-child{border:none}
.pitem:hover{background:rgba(90,197,79,.04)}
.av-wrap{position:relative;flex-shrink:0}
.av{width:44px;height:44px;image-rendering:pixelated;border:2px solid #1e1e1e;background:#111;display:block}
.av-dot{position:absolute;bottom:-2px;right:-2px;width:10px;height:10px;background:var(--green);border:2px solid var(--bg);box-shadow:0 0 6px var(--green)}
.pinfo{flex:1;min-width:0}
.pname{font-size:clamp(8px,2vw,12px);color:#e0e0e0;letter-spacing:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:1px 1px 0 #000}
.psub{font-size:5px;color:var(--dim);letter-spacing:2px;margin-top:5px}
.pbadge{font-size:5px;padding:3px 7px;border:1px solid;letter-spacing:1px;flex-shrink:0;white-space:nowrap}
.badge-op{border-color:var(--gold);color:var(--gold)}
.badge-mod{border-color:var(--cyan);color:var(--cyan)}
.badge-member{border-color:#2a2a2a;color:#3a3a3a}
.pranks{font-size:8px;color:#1e1e1e;min-width:20px;text-align:right;flex-shrink:0}

/* state messages */
.state{text-align:center;padding:32px 20px;font-size:7px;color:#252525;letter-spacing:2px;line-height:2.5}
.state .emo{font-size:30px;display:block;margin-bottom:12px}
.state .note{font-size:5px;color:#1e1e1e;margin-top:10px;line-height:2;letter-spacing:1px}
.state .note code{color:#2e2e2e;font-family:'Press Start 2P',monospace}

.spin-icon{display:inline-block;width:12px;height:12px;border:2px solid #222;border-top-color:var(--green);animation:spin .6s linear infinite;vertical-align:middle;margin-right:8px}
.noresult{text-align:center;padding:20px;font-size:7px;color:#252525;letter-spacing:2px}

/* debug panel */
.debug{background:#050905;border:2px solid #1a2a1a;padding:10px 14px;margin:0;font-size:5px;color:#2a3a2a;letter-spacing:1px;line-height:2;word-break:break-all}
.debug b{color:#3a5a3a}

.lastupdated{font-size:5px;color:#1e1e1e;text-align:right;padding:5px 18px 8px;letter-spacing:1px}

/* SOCIAL */
.social{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:12px}
.sbtn{display:flex;align-items:center;gap:7px;padding:10px 14px;text-decoration:none;font-family:'Press Start 2P',monospace;font-size:clamp(6px,1.3vw,7px);color:#fff;border:3px solid #000;box-shadow:inset 1px 1px 0 rgba(255,255,255,.2),2px 4px 0 #000;text-shadow:1px 1px 0 #000;letter-spacing:1px;transition:all .1s}
.sbtn:active{transform:translate(2px,4px);box-shadow:none}
.sbtn svg{width:13px;height:13px;fill:currentColor}
.mess{background:linear-gradient(180deg,#00B2FF,#006AFF)}.mess:hover{filter:brightness(1.1)}
.disc{background:linear-gradient(180deg,#5865F2,#4752C4)}.disc:hover{filter:brightness(1.1)}

/* TOAST */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(12px);background:#0d0d0d;border:2px solid var(--green);color:var(--green);font-size:7px;padding:9px 16px;z-index:300;letter-spacing:2px;opacity:0;transition:all .3s;pointer-events:none;white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

.footer{text-align:center;padding-top:20px;font-size:5px;color:#1e1e1e;letter-spacing:3px;line-height:3}
.footer a{color:#2a2a2a;text-decoration:none}.footer a:hover{color:var(--green)}

@media(max-width:480px){
  .status-strip{flex-direction:column;align-items:flex-start;gap:10px}
  .smeta{margin-left:0}
  .ip-row{flex-direction:column;align-items:stretch}
  .cbtn{width:100%;text-align:center;font-size:8px;padding:10px}
  .social{flex-direction:column;align-items:center}
}

/* GLOBAL TOP BANNER */
.top-banner { position: fixed; top: 0; left: 0; right: 0; height: 40px; background: rgba(0,0,0,0.8); border-bottom: 2px solid var(--gold); z-index: 1000; display: flex; justify-content: center; align-items: center; cursor: pointer; transition: background 0.2s; backdrop-filter: blur(4px); }
.top-banner:hover { background: rgba(0,0,0,0.95); }
.banner-text { font-size: clamp(6px, 1.2vw, 8px); color: var(--gold); letter-spacing: 2px; text-shadow: 1px 1px 0 #000; display: flex; align-items: center; gap: 10px; }
.banner-text span { color: #fff; }
.banner-btn { background: var(--gold); color: #000; padding: 4px 10px; font-size: 6px; letter-spacing: 1px; transition: transform 0.15s; }
.top-banner:active .banner-btn { transform: scale(0.9); }

/* PLAYER AVATAR HOVER */
.pitem .av { transition: transform 0.2s cubic-bezier(0.175, 0.885, 0.32, 1.275); cursor: pointer; }
.pitem:hover .av { transform: scale(1.15) rotate(5deg); border-color: var(--gold); }
.pitem:hover .pname { color: var(--gold); }

/* PLAYER AVATAR MODAL */
#player-modal { display: none; position: fixed; z-index: 2000; left: 0; top: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,0.8); justify-content: center; align-items: center; backdrop-filter: blur(5px); }
.player-modal-content { background: var(--panel); border: 4px solid var(--border); padding: 30px; text-align: center; position: relative; max-width: 90%; width: 320px; box-shadow: 0 0 30px rgba(0,0,0,0.8); }
.close-player-modal { position: absolute; top: -15px; right: -15px; background: var(--red); color: #fff; width: 30px; height: 30px; border: 2px solid #000; display: flex; justify-content: center; align-items: center; cursor: pointer; font-size: 16px; font-weight: bold; }
.close-player-modal:hover { background: #ff6666; }
.player-modal-name { font-size: 16px; color: var(--gold); margin-bottom: 20px; text-shadow: 2px 2px 0 #000; }
.player-modal-body { display: flex; flex-direction: column; align-items: center; gap: 15px; }
.player-modal-img { width: 120px; image-rendering: pixelated; filter: drop-shadow(0 10px 10px rgba(0,0,0,0.5)); animation: float 3s ease-in-out infinite; }

/* STATUS WIDGET */
.status-widget { background: var(--panel); border: 4px solid var(--border); padding: 20px; margin-bottom: 20px; }
.sw-row { display: flex; justify-content: space-between; align-items: center; padding: 12px 0; border-bottom: 2px dashed rgba(255,255,255,0.1); font-size: clamp(6px, 1.5vw, 8px); }
.sw-row:last-child { border-bottom: none; }
.sw-label { color: #aaa; letter-spacing: 1px; }
.sw-val { font-weight: bold; text-shadow: 1px 1px 0 #000; text-align: right; }
.sw-val.gold { color: var(--gold); }
.sw-val.green { color: var(--green); }
.sw-val.cyan { color: var(--cyan); }
