/* 
 * Gabby's Waves of Love - Base Styles
 * Using modern CSS features for a clean, responsive layout.
 */

@import url('https://fonts.googleapis.com/css2?family=Pacifico&family=Playwrite+US+Modern:wght@100..400&display=swap');

:root {
  /* Ocean and Beach Color Palette */
  --color-primary: #0077be; /* Deep Ocean Blue */
  --color-secondary: #00a8cc; /* Tropical Turquoise */
  --color-accent: #e2725b; /* Terra Cotta / Coral Accent */
  --color-sand: #f4ece1; /* Light Sandy Beige */
  --color-sand-light: #fdfaf7; /* Very light sand for content blocks */
  --color-sand-dark: #c2b280; /* Darker sand for accents and hovers */
  --color-background: var(--color-sand);
  --color-text: #2c3e50; /* Soft Dark Blue-Grey */
  --color-white: #ffffff;

  /* Typography */
  --font-family-sans: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  --font-family-title: 'Pacifico', cursive;
  --font-family-header: 'Playwrite US Modern', cursive;
  --font-size-base: 16px;
  --line-height-base: 1.6;

  /* Spacing */
  --spacing-unit: 1rem;
}

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

body {
  font-family: var(--font-family-sans);
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  color: var(--color-text);
  background-color: var(--color-background);
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

main {
  flex: 1;
  max-width: 1200px;
  margin: 0 auto;
  padding: calc(var(--spacing-unit) * 2);
}

header {
  background-color: var(--color-primary);
  color: var(--color-white);
  padding: var(--spacing-unit);
}

header .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}

header h1 {
  font-family: var(--font-family-title);
  font-size: 2.5rem;
  margin-bottom: 0;
}

nav {
  font-family: var(--font-family-header);
  font-size: 1.2rem;
  display: flex;
  gap: 1.5rem;
}

nav a {
  color: var(--color-white);
  text-decoration: none;
}

nav a:hover {
  color: var(--color-sand-dark);
  text-decoration: underline;
}

a {
  color: var(--color-primary);
  text-decoration: none;
  transition: all 0.2s ease-in-out;
}

a:hover {
  color: var(--color-secondary);
  text-decoration: underline;
}

a:active {
  color: var(--color-sand-dark);
}
footer {
  background-color: var(--color-primary);
  color: var(--color-white);
  padding: calc(var(--spacing-unit) * 2) var(--spacing-unit);
}

footer .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 2rem;
  max-width: 1000px;
}

.footer-quote {
  display: flex;
  align-items: center;
  gap: 1rem;
  text-align: left;
  flex: 1;
}

.footer-quote img {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  object-fit: cover;
}

.footer-quote blockquote {
  font-family: var(--font-family-header);
  font-size: 1.1rem;
  font-style: italic;
  margin: 0;
}

.footer-info {
  text-align: right;
}

.footer-info p {
  margin-bottom: 0.5rem;
}

footer a {
  color: var(--color-sand-dark);
  text-decoration: none;
}

footer a:hover {
  color: var(--color-white);
  text-decoration: underline;
}

@media (max-width: 768px) {
  header .container {
    flex-direction: column;
    gap: 1.5rem;
    text-align: center;
  }

  nav {
    justify-content: center;
    flex-wrap: wrap;
    gap: 1rem;
  }

  footer .container {
    flex-direction: column;
    text-align: center;
  }
  .footer-quote {
    flex-direction: column;
    text-align: center;
  }
  .footer-info {
    text-align: center;
  }
}

h1, h2, h3 {
...
  margin-bottom: var(--spacing-unit);
  color: var(--color-primary);
}

h1 { font-family: var(--font-family-title); }
h2, h3 { font-family: var(--font-family-header); }

p {
  margin-bottom: var(--spacing-unit);
}

.container {
  max-width: 800px;
  margin: 0 auto;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}
