/* ===========================================
   CENTRALIZED FONT & COLOR SYSTEM
   =========================================== */

/* Color Palette */
:root {
  --primary-green: #50c878;
  --primary-teal: #20b2aa;
  --accent-teal: #008080;
  --sea-green: #20B2AA;
  --background-light: #f6fffd;
  --background-accent: #e0f7fa;
  --background-card: #e6f7f7;
  --text-primary: #6c757d;  /* Bootstrap's text-muted color */
  --text-secondary: #495057;
}

/* Typography System */
body {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  color: var(--text-primary);
  background: var(--background-light);
}

/* Standardize all paragraph text to match text-muted styling */
p, .lead {
  color: var(--text-primary) !important;
  font-weight: 400;
  line-height: 1.6;
}

/* Headings */
h1, h2, h3, h4, h5, h6 {
  color: var(--primary-teal);
  font-weight: 600;
}

/* Special styling for main page title */
.main-title {
  color: var(--primary-green) !important;
}

/* Icons */
.icon-primary {
  color: var(--primary-green);
}

/* ===========================================
   COMPONENT STYLES
   =========================================== */

/* Water-themed minimal highlights */
.card {
  border-radius: 0.5rem;
  border: none;
  background: var(--background-card);
}
.card-title {
  color: var(--primary-teal);
}
.card-subtitle {
  color: var(--primary-green);
}

/* Links */
a {
  color: var(--primary-teal);
  text-decoration: underline dotted;
}
a:hover {
  color: var(--primary-green);
  text-decoration: underline;
}

/* Navigation */
.navbar-water {
  background: linear-gradient(90deg, var(--primary-teal) 0%, var(--primary-green) 100%);
}
.navbar-water .nav-link.active, .navbar-water .nav-link:focus {
  color: var(--primary-green) !important;
}

/* Banner */
.banner-water {
  background: var(--background-accent);
  color: var(--accent-teal);
  font-style: italic;
  font-size: 3.3rem;
  letter-spacing: 0.05em;
  padding: 1.2rem 0 0.7rem 0;
  text-align: center;
  font-family: 'Segoe UI', Arial, sans-serif;
  text-transform: lowercase;

  text-decoration-line: underline;
  text-decoration-style: wavy;
  text-decoration-color: var(--sea-green);
}

/* Footer */
.footer-text {
  color: var(--accent-teal);
}

/* ===========================================
   BOOTSTRAP OVERRIDES
   =========================================== */

html {
  font-size: 14px;
}

@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

html {
  position: relative;
  min-height: 100%;
}

body {
  margin-bottom: 60px;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
  color: var(--bs-secondary-color);
  text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
  text-align: start;
}