:root {
  /* Fonts */
  --font-main: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

  /* Font Sizes */
  --font-size-xs: 15px;
  --font-size-sm: 18px;
  --font-size-base: 20px;
  --font-size-lg: 40px;
  --font-size-xl: 60px;

  /* Letter Spacing */
  --letter-spacing-tight: -0.5px;

  /* Font Weights */
  --font-weight-regular: 400;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;

  /* Colors */
  --color-black: #000;
  --color-dark: #333;
  --color-gray: #666;
  --color-light-gray: #f5f5f5;
  --color-white: #fff;
  --color-yellow: #F6EDD7;
  --color-highlight: #ffb614;
  --color-pulse: #ffc035;

  /* Line Heights */
  --line-tight: 1.1;
  --line-normal: 1.4;
  --line-relaxed: 1.6;

  /* Spacing */
  --space-sm: 15px;
  --space-md: 20px;
  --space-lg: 30px;
  --space-xl: 40px;
  --space-xxl: 60px; /* NEW: Added for extra spacing */
}

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

html, body {
  height: 100%;
  font-family: var(--font-main);
  background-color: var(--color-yellow);
  overflow: hidden;
  letter-spacing: var(--letter-spacing-tight);
}

/* Typography */
.heading-primary,
.heading-hero,
.heading-secondary {
  font-weight: var(--font-weight-bold);
  color: var(--color-black);
  text-align: left;
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: var(--space-md);
}

.heading-primary { font-size: var(--font-size-lg); }
.heading-hero { font-size: var(--font-size-xl); font-weight: var(--font-weight-regular); }
.heading-secondary { font-size: var(--font-size-lg); padding-left: 348px; }

.body-text,
.small-text {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  color: var(--color-black);
  line-height: var(--line-normal);
  text-align: left;
  letter-spacing: var(--letter-spacing-tight);
}

.body-text {
  padding: 0 357px 0 348px;
  margin-bottom: var(--space-lg);
}

.small-text {
  font-size: var(--font-size-xs);
}

/* Layout */
.page-wrapper {
  display: flex;
  flex-direction: column;
  height: 100vh;
  overflow: hidden;
}

.container {
  display: flex;
  width: 100vw;
  height: 100vh;
  justify-content: space-between;
  align-items: center;
  overflow: hidden;
  flex: 1;
}

.left, .right {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
}

.left {
  padding-left: 85px;
  padding-bottom: 70px;
  flex-direction: column;
}

.right {
  padding-right: 50px;
}

.screenshot-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  width: 100%;
}

.static-screenshot {
  max-height: 75vh;
  width: 110%;
  max-width: 110%;
  object-fit: contain;
}

/* App Store */
.badges {
  display: flex;
  gap: var(--space-sm);
}

.badges img {
  height: 55px;
  cursor: pointer;
  transition: transform 0.2s ease;
}

.badges img:hover {
  transform: translateY(-2px);
}

.coming-soon {
  font-size: var(--font-size-xs);
  font-weight: bold;
  color: var(--color-black);
  background-color: var(--color-highlight);
  border-radius: 25px;
  padding: 8px var(--space-md);
  width: fit-content;
  margin-bottom: 10px;
  animation: pulse 2s ease-in-out infinite;
  text-align: center;
  letter-spacing: var(--letter-spacing-tight);
}

@keyframes pulse {
  0%, 100% { background-color: var(--color-highlight); }
  50% { background-color: #FFD874; }
}

/* Footer */
.footer-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: var(--color-yellow);
  padding: var(--space-lg) 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  z-index: 999;
  gap: var(--space-xxl); /* Wider spacing between links */
}

.footer-nav a {
  text-decoration: none;
  color: var(--color-black);
  font-size: var(--font-size-base); /* Up from xs for better tap targets */
  font-weight: bold;
  transition: opacity 0.2s ease;
  letter-spacing: var(--letter-spacing-tight);
  padding: 6px 12px; /* Add breathing room */
}

/* Optional hover */
.footer-nav a:hover {
  opacity: 0.7;
}

/* Page Content Blocks */
.about-container,
.contact-container {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 100vh;
  padding: 60px 352px 120px;
  background-color: var(--color-yellow);
  box-sizing: border-box;
}

.about-content,
.contact-left {
  width: 100%;
  max-width: 100%;
}

.page-heading {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  margin-bottom: 35px;
  text-align: left;
}

.page-text {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-normal);
  text-align: left;
  margin-bottom: 20px;
}

.signature {
  margin-bottom: 0;
}

/* Contact Form */
.contact-form {
  max-width: 400px;
  background-color: var(--color-white);
  border-radius: 30px;
  padding: var(--space-lg);
  margin-top: var(--space-lg);
  box-sizing: border-box;
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  padding: var(--space-md);
  border-radius: 25px;
  background-color: var(--color-light-gray);
  border: none;
  font-family: inherit;
  margin-bottom: var(--space-md);
}

.contact-form textarea {
  min-height: 180px;
  resize: vertical;
}

.contact-form button {
  width: 100%;
  padding: var(--space-md);
  border-radius: 25px;
  border: none;
  font-size: var(--font-size-sm);
  font-weight: bold;
  background-color: var(--color-highlight);
  color: var(--color-black);
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.contact-form button:hover {
  background-color: var(--color-pulse);
}

/* ========== Mobile Responsive ========== */
@media (max-width: 768px) {
  html, body {
    overflow: auto;
  }

  /* Homepage layout stack */
  .container {
    flex-direction: column;
    height: auto;
    padding: 60px 20px 20px 20px;
    align-items: center;
    text-align: center;
  }

  .left {
    padding: 0 20px;
    order: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
    text-align: center;
  }

  .right {
    order: 2;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    margin-bottom: 10px;
    padding: 0;
  }

  .screenshot-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    margin: 0 auto;
  }

  .static-screenshot {
    max-height: 100vh;
    width: 100%;
    object-fit: contain;
  }

  /* Footer navigation (stacked or spaced for mobile) */
  .footer-nav {
    flex-direction: column;
    align-items: center;
    padding: 20px 0;
    background-color: var(--color-yellow);
    width: 100%;
    z-index: 999;
    gap: 12px;
  }

  .nav-btn,
  .footer-nav a {
    text-decoration: none;
    color: var(--color-black);
    font-size: 16px;
    font-weight: bold;
    text-align: center;
    padding: 10px 0;
    transition: opacity 0.2s ease;
  }

  .nav-btn:hover,
  .footer-nav a:hover {
    opacity: 0.7;
  }

  /* Typography for homepage */
  .heading-primary {
    font-size: 24px;
    text-align: center;
    margin-bottom: 15px;
  }

  .heading-hero {
    font-size: 40px;
    font-weight: bold;
    text-align: center;
    margin-bottom: 10px;
  }

  /* App Store section */
  .badges {
    display: flex;
    justify-content: center;
    margin: 20px 0 0;
  }

  .badges img {
    height: 50px;
  }

  .coming-soon {
    margin: 0;
    padding: 6px 16px;
    font-size: 12px;
    border-radius: 20px;
  }

  .google-badge-group {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
  }

  /* Unified Layout for Info Pages (About, Contact, Mission) */
  .about-container {
    padding: 40px 30px 120px 30px;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  .about-content {
    max-width: 100%;
    margin: 0 auto;
    padding: 0 20px;
    text-align: left;
    box-sizing: border-box;
    letter-spacing: -1px;
  }

  /* ✨ Typography for Info Pages ✨ */
  .about-title,
  .mission-title,
  .page-heading {
    font-size: 40px;
    font-weight: var(--font-weight-bold);
    text-align: left;
    margin-bottom: 25px;
    letter-spacing: -0.5px;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .about-intro,
  .about-founding,
  .mission-text,
  .page-text,
  .closing-text,
  .signature {
    font-size: 20px !important;
    font-weight: var(--font-weight-regular);
    text-align: left;
    margin-bottom: 20px;
    letter-spacing: -0.5px;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .contact-form {
    max-width: 350px;
    margin: 40px auto 0 auto;
    display: block;
  }

  .contact-right {
    order: 2;
    padding: 0 20px !important;
    display: flex;
    justify-content: center;
    align-items: center;
  }
}
