/* Hamaro Minecraft control panel — plain CSS, no build step, theme-aware. */
:root {
  --grass: #78b943;
  --grass-dark: #5a9430;
  --dirt: #7a5a3a;
  --bg: #f4f1ea;
  --card: #ffffff;
  --ink: #2b2b2b;
  --muted: #6b6b6b;
  --line: #ddd6c8;
  --danger: #c0392b;
}
@media (prefers-color-scheme: dark) {
  :root { --bg: #1b1d1a; --card: #262924; --ink: #ecebe6; --muted: #a5a49c; --line: #3a3d37; }
}
* { box-sizing: border-box; }
body {
  margin: 0; background: var(--bg); color: var(--ink);
  font-family: ui-rounded, "SF Pro Rounded", system-ui, -apple-system, "Segoe UI", sans-serif;
  line-height: 1.45;
}
main { max-width: 640px; margin: 0 auto; padding: 24px 16px 48px; }
header { text-align: center; margin-bottom: 20px; }
h1 { font-size: 2rem; margin: 0; letter-spacing: .5px; }
.grass {
  display: inline-block; width: .9em; height: .9em; vertical-align: -0.08em; margin-right: .1em;
  background: linear-gradient(to bottom, var(--grass) 0 45%, var(--dirt) 45% 100%);
  border-radius: 4px; image-rendering: pixelated;
}
.sub { color: var(--muted); margin: 4px 0 0; }

.card {
  background: var(--card); border: 2px solid var(--line); border-radius: 16px;
  padding: 32px 24px; text-align: center; box-shadow: 0 4px 16px rgba(0,0,0,.06);
}
#status-face { font-size: 3.5rem; }
#status-line { font-size: 1.25rem; margin: 8px 0 20px; }

.bigbtn {
  font: inherit; font-size: 1.5rem; font-weight: 700; color: #fff; cursor: pointer;
  background: var(--grass); border: 0; border-bottom: 5px solid var(--grass-dark);
  border-radius: 14px; padding: 18px 40px; width: 100%; max-width: 380px;
  transition: transform .06s;
}
.bigbtn:active { transform: translateY(3px); border-bottom-width: 2px; }
.bigbtn:disabled { opacity: .6; cursor: wait; }

.bar { height: 14px; background: var(--line); border-radius: 7px; overflow: hidden; max-width: 380px; margin: 0 auto; }
#bar-fill { height: 100%; width: 3%; background: var(--grass); border-radius: 7px; transition: width 1s linear; }
#progress-note { color: var(--muted); margin-top: 10px; font-size: .95rem; }

.addr-row { display: flex; gap: 8px; justify-content: center; align-items: center; flex-wrap: wrap; }
#addr {
  font-size: 1.3rem; background: var(--bg); border: 2px dashed var(--grass);
  padding: 8px 16px; border-radius: 10px; user-select: all;
}
#players-line { margin-top: 12px; font-size: 1.05rem; }
.hint { color: var(--muted); font-size: .9rem; margin-top: 12px; }
.note { text-align: center; color: var(--muted); font-size: .95rem; max-width: 460px; margin: 18px auto; }

button {
  font: inherit; cursor: pointer; background: var(--card); color: var(--ink);
  border: 2px solid var(--line); border-radius: 10px; padding: 8px 14px;
}
button:hover { border-color: var(--grass); }
button.danger { border-color: var(--danger); color: var(--danger); }
input, textarea {
  font: inherit; background: var(--card); color: var(--ink);
  border: 2px solid var(--line); border-radius: 10px; padding: 8px 12px;
}
textarea { width: 100%; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: .85rem; }
.row { display: flex; gap: 8px; margin-top: 12px; flex-wrap: wrap; align-items: center; }
.row input { flex: 1; min-width: 160px; }
.cols { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
@media (max-width: 520px) { .cols { grid-template-columns: 1fr; } }

details#admin { margin-top: 32px; border-top: 2px solid var(--line); padding-top: 16px; }
summary { cursor: pointer; color: var(--muted); font-weight: 600; }
#login-box { display: flex; gap: 8px; margin-top: 14px; flex-wrap: wrap; }
#login-box input { flex: 1; min-width: 180px; }
.err { color: var(--danger); align-self: center; }

#tabs { display: flex; gap: 6px; margin: 16px 0 12px; flex-wrap: wrap; }
.tab { border-radius: 10px 10px 0 0; border-bottom: 0; padding: 8px 14px; opacity: .7; }
.tab.active { opacity: 1; border-color: var(--grass); font-weight: 700; }
.tabpane { border: 2px solid var(--line); border-radius: 0 12px 12px 12px; padding: 16px; }

ul#world-list, ul#backup-list, #whitelist, #opslist { list-style: none; padding: 0; margin: 8px 0; }
ul#world-list li, ul#backup-list li, #whitelist li, #opslist li {
  display: flex; align-items: center; gap: 10px; padding: 8px 10px;
  border-bottom: 1px solid var(--line); flex-wrap: wrap;
}
.badge { background: var(--grass); color: #fff; border-radius: 6px; font-size: .75rem; padding: 2px 8px; }
li .spacer { flex: 1; }
li.selected { outline: 2px solid var(--grass); border-radius: 8px; }
pre#cmd-out {
  background: var(--bg); border: 1px solid var(--line); border-radius: 8px;
  padding: 10px; min-height: 60px; white-space: pre-wrap; overflow-x: auto; font-size: .85rem;
}
#op-status { margin-top: 12px; padding: 10px 14px; border-radius: 10px; background: var(--bg); border: 1px solid var(--line); font-size: .9rem; }
.logout-row { justify-content: flex-end; }
footer { text-align: center; color: var(--muted); font-size: .85rem; margin-top: 40px; }
footer a { color: inherit; }
.hidden { display: none !important; }
