/* ===================================
 * CSS RESET & BASE STYLES
 * =================================== */
 * {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
}

html,
body {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial,
    sans-serif;
  background: url('https://static.vecteezy.com/system/resources/previews/042/196/209/large_2x/ai-generated-role-playing-rpg-game-background-free-photo.jpg') 
              no-repeat center center/cover;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}


/* ===================================
 * CSS CUSTOM PROPERTIES
 * =================================== */
:root {
  /* Colors */
  --color-primary: #ff6b6b;
  --color-primary-hover: #ff5252;
  --color-secondary: #4ecdc4;
  --color-secondary-hover: #44a08d;
  --color-accent: #ffe66d;
  --color-success: #27ae60;
  --color-bg-dark: #2c3e50;
  --color-bg-light: #f8f9fa;
  --color-text-primary: #2c3e50;
  --color-text-secondary: #666666;
  --color-text-light: #ffffff;

  /* Neutral Grays */
  --gray-100: #f8f9fa;
  --gray-200: #e9ecef;
  --gray-300: #dee2e6;
  --gray-400: #ced4da;
  --gray-500: #95a5a6;

  /* Spacing */
  --space-xs: clamp(6px, 0.6vw, 12px);
  --space-sm: clamp(12px, 1.2vw, 20px);
  --space-md: clamp(16px, 1.8vw, 32px);
  --space-lg: clamp(24px, 2.8vw, 48px);
  --space-xl: clamp(36px, 4vw, 64px);

  /* Animation Timings */
  --transition-fast: 150ms;
  --transition-normal: 300ms;
  --transition-slow: 500ms;

  /* Easing Functions */
  --ease-out: cubic-bezier(0.0, 0, 0.2, 1);
  --ease-bounce: cubic-bezier(0.68, -0.6, 0.32, 1.6);

  /* Shadows */
  --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.1);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.15);
  --shadow-lg: 0 8px 32px rgba(0, 0, 0, 0.2);
  --shadow-xl: 0 12px 48px rgba(0, 0, 0, 0.25);

  /* Glows */
  --glow-primary: 0 0 20px rgba(255, 107, 107, 0.4);
  --glow-secondary: 0 0 20px rgba(78, 205, 196, 0.4);
  --glow-accent: 0 0 20px rgba(255, 230, 109, 0.4);

  /* Typography & base sizes */
  --base-font: clamp(14px, 1.2vw + 10px, 20px);

  /* Top bar & controls */
  --topbar-height: clamp(56px, 6.5vh, 110px);
  --top-button-size: clamp(48px, 6.5vw, 90px);
  --top-button-font: clamp(20px, 1.5vw + 12px, 40px);

  /* Game container sizing caps */
  --game-max-width: 900px;
  --game-max-height: 1600px;

  /* Dialogue / content sizing */
  --dialogue-height: clamp(45vh, 50vh, 65vh);
  --continue-width: clamp(140px, 18vw, 280px);
  --continue-height: clamp(60px, 9vh, 120px);
  --continue-font: clamp(15px, 1.2vw + 12px, 24px);

  /* Map icons */
  --map-icon-size: clamp(72px, 8.5vw, 140px);
  --lock-badge-size: clamp(36px, 3.5vw, 56px);
  --completed-badge-size: clamp(36px, 3.2vw, 48px);

  /* Minigame & buttons */
  --minigame-header: clamp(20px, 2.4vw, 36px);
  --minigame-button-height: clamp(72px, 9vh, 110px);

  /* Forms & misc */
  --form-input-padding: clamp(10px, 1vw, 20px);
  --feedback-max-width: clamp(85%, 65vw, 600px);
}

/* ===================================
 * GAME CONTAINER
 * =================================== */
 #gameContainer {
  width: min(95vw, var(--game-max-width));
  height: min(95vh, var(--game-max-height));
  max-width: var(--game-max-width);
  max-height: var(--game-max-height);
  aspect-ratio: 9 / 16;
  margin: auto;
  position: relative;
  background: var(--color-bg-dark);
  overflow: visible;
  padding-top: calc(var(--topbar-height) + var(--space-sm));
  border-radius: clamp(0px, 1vw, 24px);
  
 /* Intensified glowing border */
 box-shadow:
 0 0 16px rgba(255, 255, 255, 0.6),
 0 0 32px rgba(255, 255, 255, 0.4),
 0 0 48px rgba(0, 255, 255, 0.3),
 0 0 72px rgba(0, 255, 255, 0.2),
 0 0 96px rgba(255, 255, 255, 0.1);
transition: box-shadow 0.3s ease-in-out;
}

/* Optional: Animate glow for a more dynamic effect */
#gameContainer:hover {
box-shadow:
 0 0 24px rgba(255, 255, 255, 0.8),
 0 0 48px rgba(255, 255, 255, 0.6),
 0 0 72px rgba(0, 255, 255, 0.5),
 0 0 96px rgba(0, 255, 255, 0.3),
 0 0 120px rgba(255, 255, 255, 0.2);
}


/* Canvas should fill container responsively */
#canvas {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

/* ===================================
 * TOP BAR
 * =================================== */
#topBar {
  position: absolute;
  top: 1;
  left: 0;
  width: 100%;
  height: var(--topbar-height);
  padding: 0 var(--space-sm);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-sm);
  z-index: 100;
}

.top-button {
  width: var(--top-button-size);
  height: var(--top-button-size);
  background: rgba(251, 255, 236, 0.95);
  border: none;
  border-radius: clamp(10px, 1vw, 16px);
  font-size: var(--top-button-font);
  cursor: pointer;
  box-shadow: var(--shadow-md);
  transition: all var(--transition-normal) var(--ease-out);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}
.top-button:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
  background: rgb(101, 113, 153);
}
.top-button:active {
  transform: translateY(0);
}
.top-button::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 120%;
  height: 120%;
  transform: translate(-50%, -50%);
  pointer-events: none;
  z-index: 0;
}

/* ===================================
 * DIALOGUE / UI ELEMENTS
 * =================================== */
#dialogueBox {
  width: 100%;
  height: var(--dialogue-height);
  max-height: calc(var(--game-max-height) * 0.9);
  padding: var(--space-md);
  box-sizing: border-box;
}

#speakerName {
  font-size: clamp(16px, 1.6vw, 28px);
  padding-left: var(--space-sm);
  margin-bottom: calc(var(--space-sm) / 1.2);
}

#dialogueText {
  font-size: clamp(15px, 1.1vw + 2px, 22px);
  line-height: 1.7;
  padding: 0 var(--space-sm);
  margin-bottom: var(--space-md);
  overflow-y: auto;
}

.choice-button {
  min-height: clamp(72px, 10vh, 110px);
  padding: clamp(10px, 1.2vw, 32px);
  font-size: clamp(15px, 1.2vw + 2px, 22px);
  border-radius: clamp(10px, 1vw, 16px);
}

#continueButton {
  position: absolute;
  bottom: var(--space-md);
  left: 50%;
  transform: translateX(-50%);
  width: var(--continue-width);
  height: var(--continue-height);
  font-size: var(--continue-font);
  border-radius: clamp(32px, 5vw, 60px);
  position: relative;
  z-index: 1;
}

/* ===================================
 * MINIGAME ELEMENTS
 * =================================== */
.minigame-header {
  font-size: var(--minigame-header);
  margin-bottom: var(--space-md);
}

.minigame-instructions {
  font-size: clamp(14px, 1vw + 8px, 18px);
  margin-bottom: var(--space-sm);
}

.minigame-button {
  height: var(--minigame-button-height);
  font-size: clamp(16px, 1.3vw + 6px, 22px);
  border-radius: clamp(10px, 1vw, 16px);
}

/* ===================================
 * MAP ICONS
 * =================================== */
.map-icon {
  width: var(--map-icon-size);
  height: var(--map-icon-size);
  position: relative;
}

.map-icon.locked::after {
  font-size: var(--lock-badge-size);
}

.map-icon.completed::before {
  width: var(--completed-badge-size);
  height: var(--completed-badge-size);
  font-size: clamp(18px, 1.6vw, 28px);
  border-width: clamp(2px, 0.2vw, 4px);
}

/* ===================================
 * MODAL CONTENT
 * =================================== */
.modal-content {
  width: min(90%, 800px);
  max-width: 90%;
  padding: clamp(var(--space-md), 2.6vw, var(--space-xl));
  border-radius: clamp(12px, 1.2vw, 20px);
  position: relative;
  z-index: 2;
}
