* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: 'Oswald', sans-serif;
  background: #fff;
  color: #000;
  scroll-behavior: smooth;
}

/* TOP NAV — matches slide 2 top bar */
.topnav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: 12px 24px;
  background: #fff;
  border-bottom: 1px solid #000;
  z-index: 100;
}

.logo {
  font-size: 28px;
  font-weight: bold;
  font-family: 'Oswald', sans-serif;
}

.nav-links {
  display: flex;
  gap: 20px;
  font-size: 15px;
}

.nav-links a {
  text-decoration: none;
  color: #000;
}

.nav-links a:hover {
  text-decoration: underline;
}

/* PAGE SECTIONS — each one is like a slide */
.page {
  min-height: 100vh;
  padding: 70px 40px 40px;
  position: relative;
  border-bottom: 1px solid #ccc;
}

.page-label {
  font-size: 16px;
  font-family: 'Oswald', sans-serif;
  margin-bottom: 4px;
}

.back-arrow {
  font-size: 18px;
  margin-right: 4px;
  cursor: pointer;
}

.page-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
}

.nav-links-inline {
  font-size: 14px;
  font-family: 'Oswald', sans-serif;
}

/* DIVIDERS — thin lines like in the slides */
.divider {
  border: none;
  border-top: 1px solid #000;
  margin: 8px 0 20px;
}

.line-long {
  border: none;
  border-top: 1px solid #000;
  margin: 8px 0;
  width: 100%;
}

.divider-dotted {
  border: none;
  border-top: 2px dotted #000;
  margin: 20px 0;
}

/* COLOR SETTINGS — bottom right, rainbow "Color" like slides */
.color-settings {
  position: absolute;
  bottom: 20px;
  right: 30px;
  font-size: 14px;
  font-family: 'Oswald', sans-serif;
  cursor: pointer;
}

.color-c { color: #4285f4; }
.color-o { color: #ea4335; }
.color-l { color: #fbbc05; }
.color-o2 { color: #4285f4; }
.color-r { color: #34a853; }

/* ========== HOME (Slide 2) ========== */
.home-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 60vh;
}

.home-content h1 {
  font-size: 32px;
  font-weight: bold;
  font-family: 'Oswald', sans-serif;
  text-align: center;
}

.home-content h1 em {
  font-style: italic;
  font-family: 'Comic Sans MS', cursive, serif;
}

.click-info {
  margin-top: 20px;
  font-size: 14px;
}

/* ========== IPROXY (Slide 3) ========== */
#iproxy h2 {
  font-size: 26px;
  font-weight: bold;
  margin-bottom: 4px;
}

.small-note {
  font-size: 11px;
  color: #888;
  margin-bottom: 10px;
}

.tagline {
  font-size: 20px;
  margin-bottom: 24px;
}

.brand-row {
  display: flex;
  gap: 40px;
  align-items: center;
  flex-wrap: wrap;
}

.brand-item {
  text-decoration: none;
  color: #000;
}

.brand-text {
  font-size: 28px;
  font-weight: 900;
  font-family: sans-serif;
}

.brand-mc {
  font-family: sans-serif;
  font-size: 22px;
  letter-spacing: 2px;
  background: #000;
  color: #fff;
  padding: 4px 8px;
}

.roblox-icon {
  width: 40px;
  height: 40px;
  border: 2px solid #000;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
}

/* ========== ISTUFF AI (Slide 4) ========== */
.ai-content {
  display: flex;
  flex-direction: column;
  min-height: 60vh;
}

.ai-response-area {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: #000;
  padding: 40px;
}

.ai-input-area {
  margin-top: auto;
}

.ai-title {
  font-size: 28px;
  font-weight: bold;
  font-family: 'Oswald', sans-serif;
  margin-bottom: 4px;
}

.ai-input-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-top: 8px;
}

.ai-label {
  font-size: 18px;
  font-style: italic;
  font-family: 'Comic Sans MS', cursive, serif;
}

.ai-textbox {
  border: none;
  border-bottom: 1px solid #000;
  font-size: 16px;
  font-family: 'Oswald', sans-serif;
  padding: 4px 8px;
  width: 300px;
  outline: none;
  background: transparent;
}

.ai-sub {
  font-size: 11px;
  color: #888;
  margin-top: 2px;
}

/* ========== IGAMES+ (Slide 5) ========== */
.sidebar-label {
  position: absolute;
  left: 10px;
  top: 80px;
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 14px;
  line-height: 1.4;
}

.games-content {
  padding-left: 40px;
}

.games-hint {
  font-size: 14px;
  margin-bottom: 8px;
}

.games-hint a {
  color: #000;
}

.scroll-hint {
  font-size: 12px;
  color: #888;
  text-align: right;
  margin-bottom: 20px;
}

.games-title {
  font-size: 48px;
  font-weight: bold;
  font-family: 'Oswald', sans-serif;
  font-style: italic;
  text-align: center;
  margin-bottom: 20px;
}

.search-row {
  font-size: 18px;
  margin-bottom: 10px;
}

.game-search-box {
  display: block;
  width: 100%;
  border: none;
  border-bottom: 1px solid #000;
  font-size: 16px;
  font-family: 'Oswald', sans-serif;
  padding: 6px 8px;
  margin-top: 8px;
  outline: none;
  background: transparent;
}

.games-start {
  font-size: 28px;
  font-weight: bold;
  font-family: 'Oswald', sans-serif;
  text-align: center;
  margin: 20px 0;
}

.mini-games {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 16px;
}

.game-card {
  border: 1px solid #000;
  padding: 16px 24px;
  font-size: 16px;
  cursor: pointer;
  font-family: 'Oswald', sans-serif;
  transition: background 0.2s;
}

.game-card:hover {
  background: #eee;
}

.game-link {
  text-decoration: none;
  color: #000;
  background: #f0f0f0;
  font-weight: 700;
}

/* ========== APPS (Slide 6) ========== */
.apps-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 60vh;
}

.apps-title {
  font-size: 64px;
  font-weight: 900;
  font-family: sans-serif;
  letter-spacing: 4px;
  margin-bottom: 8px;
}

.apps-row {
  display: flex;
  gap: 24px;
  align-items: flex-start;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 24px;
}

.app-icon {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  text-decoration: none;
  color: #000;
}

.app-icon span {
  width: 64px;
  height: 64px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  color: #fff;
}

.app-icon small {
  font-size: 12px;
}

.spotify span { background: #1DB954; }
.youtube span { background: #FF0000; }
.netflix span { background: #E50914; font-weight: 900; font-family: sans-serif; }
.meme span { background: #8B4513; font-size: 32px; }

/* ========== QUESTIONS (Slide 7) ========== */
.questions-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 60vh;
}

.questions-content h2 {
  font-size: 40px;
  font-weight: bold;
  font-family: 'Oswald', sans-serif;
  font-style: italic;
  margin-bottom: 12px;
}

.questions-desc {
  font-size: 16px;
  text-align: center;
  margin-bottom: 16px;
}

.question-input-row {
  margin-top: 16px;
  width: 100%;
  max-width: 500px;
}

.question-input-row em {
  font-size: 22px;
  font-family: 'Comic Sans MS', cursive, serif;
  display: block;
  margin-bottom: 8px;
}

.question-textbox {
  border: none;
  border-bottom: 1px solid #000;
  font-size: 16px;
  font-family: 'Oswald', sans-serif;
  padding: 4px 8px;
  width: 100%;
  outline: none;
  background: transparent;
}

.question-reply {
  margin-top: 12px;
  font-size: 16px;
  font-style: italic;
}

/* GAME POPUP */
.game-popup {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: #fff;
  border: 2px solid #000;
  padding: 30px;
  z-index: 300;
  min-width: 320px;
  text-align: center;
  font-family: 'Oswald', sans-serif;
}

.game-popup.open {
  display: block;
}

.close-game {
  position: absolute;
  top: 8px;
  right: 12px;
  background: none;
  border: none;
  font-size: 24px;
  cursor: pointer;
}

/* RESPONSIVE */
@media (max-width: 600px) {
  .topnav {
    flex-direction: column;
    gap: 6px;
    padding: 8px 16px;
  }
  .nav-links {
    gap: 10px;
    flex-wrap: wrap;
    font-size: 13px;
  }
  .page {
    padding: 60px 20px 30px;
  }
  .home-content h1 {
    font-size: 22px;
  }
  .games-title {
    font-size: 32px;
  }
  .apps-title {
    font-size: 40px;
  }
}
