/* 🧭 MASTER.CSS - Game & Grub RPG Website */

/* RESET & BASISINSTELLINGEN */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  overflow-y: scroll;
  scroll-behavior: smooth;
}

body {
  font-family: 'Georgia', serif;
  background-color: var(--bg-color, #fdf6e3);
  color: var(--text-color, #3b2e1a);
  line-height: 1.6;
  user-select: none;
}

/* KLEURENVARIABELEN */
:root {
  --bg-color: #fdf6e3;
  --text-color: #3b2e1a;
  --card-bg: #fffef7;
  --border-color: #a67c52;
  --accent-hover: #e9c46a;
}

body.theme-dark {
  --bg-color: #2a2a2a;
  --text-color: #fdf6e3;
  --card-bg: #3a3a3a;
  --border-color: #a67c52;
  --accent-hover: #ffd54f;
}

/* HEADER & NAVIGATIE */
header {
  background-color: var(--card-bg);
  border-bottom: 2px solid var(--border-color);
  padding: 20px 0 10px;
  text-align: center;
}

.site-banner {
  display: block;
  margin: 0 auto;
  max-width: 200px;
  height: auto;
}

nav {
  display: flex;
  justify-content: center;
  gap: 15px;
  padding: 10px 0;
  background-color: var(--card-bg);
  border-top: 1px solid var(--border-color);
  border-bottom: 1px solid var(--border-color);
}

nav a {
  text-decoration: none;
  color: var(--text-color);
  font-weight: bold;
}

nav a:hover {
  color: var(--accent-hover);
}

/* BUTTONS */
.button, button {
  background-color: var(--border-color);
  color: #fff;
  padding: 10px 18px;
  border-radius: 6px;
  border: none;
  font-weight: bold;
  cursor: pointer;
  transition: 0.2s;
}

.button:hover, button:hover {
  background-color: var(--accent-hover);
  color: var(--text-color);
}

/* LAYOUT */
main {
  max-width: 960px;
  margin: 40px auto;
  padding: 0 20px;
}

/* PARCHMENT BOX */
.parchment-box {
  background-color: var(--card-bg);
  border: 2px solid var(--border-color);
  border-radius: 8px;
  padding: 20px;
  box-shadow: inset 0 0 8px rgba(0,0,0,0.05);
  margin-bottom: 20px;
}

/* EDIT CONTAINER */
.edit-container {
  background-color: var(--card-bg);
  border: 2px solid var(--border-color);
  border-radius: 8px;
  padding: 20px;
  max-width: 960px;
  margin: 40px auto;
}

/* SELECTIE & OPTIES */
.avatar-selection,
.badge-selection,
.border-selection {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 10px 0 20px;
}

/* AVATARS */
.avatar-option {
  width: 70px;
  height: 70px;
  object-fit: cover;
  border: 3px solid transparent;
  border-radius: 6px;
  cursor: pointer;
}
.avatar-option.selected {
  border-color: var(--border-color);
}

/* BADGES */
.badge-option {
  width: 32px;
  height: 32px;
  object-fit: cover;
  border: 2px solid transparent;
  border-radius: 6px;
  cursor: pointer;
}
.badge-option.selected {
  border-color: var(--border-color);
}

/* BORDERS */
.border-option {
  width: 50px;
  height: 50px;
  border: 3px solid transparent;
  border-radius: 6px;
  cursor: pointer;
}
.border-option.selected {
  outline: 2px solid var(--border-color);
}

/* SPECIFIEKE BORDER-KLEUREN */
.border-gold { border-color: gold; }
.border-blue { border-color: dodgerblue; }
.border-green { border-color: green; }
.border-fire { border-color: red; }
.border-shadow { border-color: gray; }

/* PREVIEW */
.preview-box {
  text-align: center;
  margin-top: 20px;
}

.preview-avatar {
  width: 120px;
  height: 140px;
  object-fit: cover;
  border-radius: 6px;
  border: 3px solid transparent;
}
.preview-avatar.border-gold { border-color: gold; }
.preview-avatar.border-blue { border-color: dodgerblue; }
.preview-avatar.border-green { border-color: green; }
.preview-avatar.border-fire { border-color: red; }
.preview-avatar.border-shadow { border-color: gray; }

.badge-preview img {
  width: 32px;
  margin: 5px;
  object-fit: cover;
}

/* XP BAR */
.exp-bar {
  background-color: #ddd;
  height: 16px;
  border-radius: 8px;
  overflow: hidden;
  margin: 8px 0 16px;
}

.exp-fill {
  background-color: var(--border-color);
  height: 100%;
  width: 0%;
  transition: width 0.4s ease;
}

/* FOOTER */
footer {
  text-align: center;
  font-size: 0.9em;
  color: var(--border-color);
  padding: 15px;
  border-top: 1px solid #d5b98b;
  margin-top: 40px;
}

/* PLAYER STATS */
.profile-container {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
  align-items: flex-start;
  background-color: var(--card-bg);
  padding: 25px;
  border-radius: 10px;
  box-shadow: 0 0 10px rgba(0,0,0,0.05);
}

.avatar-frame {
  width: 200px;
  height: 240px;
  overflow: hidden;
  border: 3px solid var(--border-color);
  border-radius: 6px;
  flex-shrink: 0;
}

.avatar-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.badges-row img {
  width: 32px;
  margin-right: 5px;
}

/* THEME TOGGLE */
.theme-toggle {
  position: absolute;
  top: 20px;
  right: 20px;
  background: transparent;
  border: none;
  font-size: 1.5em;
  cursor: pointer;
}
