/* =============================================
   Braeview Hermanus — Custom Styles
   Brand: Hummingbird-inspired jewel tones
   ============================================= */

:root {
  --teal-deep:    #0D6B75;
  --teal-mid:     #1AABBA;
  --teal-light:   #d0f0f3;
  --coral:        #E8874A;
  --coral-dark:   #c96c33;
  --bg-tint:      #F0FAFB;
  --text-main:    #3A3A3A;
  --text-muted:   #6c757d;
  --white:        #ffffff;
}

/* ---- Base ---- */
body {
  color: var(--text-main);
  font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
}

/* ---- Navbar ---- */
.navbar-brand img {
  height: 52px;
}
.site-navbar {
  background-color: var(--teal-deep) !important;
}
.site-navbar .nav-link {
  color: rgba(255,255,255,0.88) !important;
  font-weight: 500;
  letter-spacing: 0.03em;
  transition: color 0.2s;
}
.site-navbar .nav-link:hover,
.site-navbar .nav-link.active {
  color: var(--white) !important;
}
.site-navbar .navbar-toggler {
  border-color: rgba(255,255,255,0.4);
}
.site-navbar .navbar-toggler-icon {
  filter: invert(1);
}

/* ---- Buttons ---- */
.btn-coral {
  background-color: var(--coral);
  border-color: var(--coral);
  color: var(--white);
  font-weight: 600;
  letter-spacing: 0.04em;
}
.btn-coral:hover, .btn-coral:focus {
  background-color: var(--coral-dark);
  border-color: var(--coral-dark);
  color: var(--white);
}
.btn-outline-teal {
  border-color: var(--teal-mid);
  color: var(--teal-mid);
  font-weight: 600;
}
.btn-outline-teal:hover {
  background-color: var(--teal-mid);
  color: var(--white);
}
.btn-outline-white {
  border-color: rgba(255,255,255,0.8);
  color: var(--white);
  font-weight: 600;
}
.btn-outline-white:hover {
  background-color: rgba(255,255,255,0.15);
  color: var(--white);
}

/* ---- Hero ---- */
.hero-section {
  position: relative;
  min-height: 92vh;
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    160deg,
    rgba(13, 107, 117, 0.72) 0%,
    rgba(0, 0, 0, 0.45) 100%
  );
}
.hero-content {
  position: relative;
  z-index: 2;
  text-align: center;
  color: var(--white);
}
.hero-content h1 {
  font-size: clamp(2.4rem, 6vw, 4.5rem);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-shadow: 0 2px 12px rgba(0,0,0,0.35);
}
.hero-content .tagline {
  font-size: clamp(1rem, 2.5vw, 1.35rem);
  opacity: 0.92;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.hero-divider {
  width: 72px;
  height: 3px;
  background: var(--coral);
  margin: 1rem auto;
  border-radius: 2px;
}

/* ---- Page banner (inner pages) ---- */
.page-banner {
  background: linear-gradient(135deg, var(--teal-deep) 0%, var(--teal-mid) 100%);
  padding: 5rem 0 3rem;
  color: var(--white);
}
.page-banner h1 {
  font-weight: 700;
  letter-spacing: 0.03em;
}

/* ---- Section headings ---- */
.section-title {
  font-weight: 700;
  color: var(--teal-deep);
  letter-spacing: 0.02em;
}
.section-divider {
  width: 56px;
  height: 3px;
  background: var(--coral);
  margin: 0.5rem auto 1.5rem;
  border-radius: 2px;
}
.section-divider.left {
  margin-left: 0;
}

/* ---- Intro strip ---- */
.intro-section {
  background: var(--bg-tint);
  padding: 4rem 0;
}
.intro-section .lead {
  max-width: 720px;
  margin: 0 auto;
  color: var(--text-main);
  line-height: 1.8;
}
.badge-highlight {
  background-color: var(--teal-light);
  color: var(--teal-deep);
  font-size: 0.8rem;
  font-weight: 600;
  padding: 0.4em 0.85em;
  border-radius: 20px;
}

/* ---- Unit cards ---- */
.units-section {
  padding: 5rem 0;
}
.unit-card {
  border: none;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(13, 107, 117, 0.10);
  transition: transform 0.25s, box-shadow 0.25s;
  height: 100%;
}
.unit-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 36px rgba(13, 107, 117, 0.18);
}
.unit-card .card-img-top {
  height: 280px;
  object-fit: cover;
  transition: transform 0.35s ease;
}
.unit-card .img-link {
  position: relative;
  display: block;
  overflow: hidden;
}
.unit-card .img-link:hover .card-img-top {
  transform: scale(1.04);
}
.unit-card .img-overlay {
  position: absolute;
  inset: 0;
  background: rgba(13, 107, 117, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s ease;
}
.unit-card .img-link:hover .img-overlay {
  opacity: 1;
}
.unit-card .img-overlay span {
  color: #fff;
  font-weight: 700;
  font-size: 1.05rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 2px solid rgba(255,255,255,0.8);
  padding: 0.5rem 1.4rem;
  border-radius: 25px;
}
.unit-card .card-body {
  padding: 1.75rem;
}
.unit-card .unit-badge {
  background-color: var(--teal-deep);
  color: var(--white);
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.3em 0.8em;
  border-radius: 20px;
}
.unit-card .price-tag {
  color: var(--teal-deep);
  font-size: 1.1rem;
  font-weight: 700;
}
.amenity-icon {
  color: var(--teal-mid);
  font-size: 1.15rem;
}

/* ---- Pricing accordion ---- */
.pricing-section {
  background: var(--bg-tint);
  padding: 4rem 0;
}
.accordion-button:not(.collapsed) {
  background-color: var(--teal-deep);
  color: var(--white);
}
.accordion-button:not(.collapsed)::after {
  filter: invert(1);
}
.accordion-button {
  font-weight: 600;
  color: var(--teal-deep);
}
.pricing-table thead th {
  background-color: var(--teal-deep);
  color: var(--white);
  font-weight: 600;
  border: none;
}
.pricing-table td, .pricing-table th {
  padding: 0.65rem 1rem;
}
.pricing-table tbody tr:nth-child(even) {
  background-color: var(--bg-tint);
}
.peak-row {
  background-color: #fff3e8 !important;
  font-weight: 600;
}

/* ---- Gallery ---- */
.gallery-section {
  padding: 4rem 0;
}
.gallery-item {
  overflow: hidden;
  border-radius: 8px;
  cursor: pointer;
}
.gallery-item img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  transition: transform 0.35s ease;
  display: block;
}
.gallery-item:hover img {
  transform: scale(1.06);
}
.filter-btn {
  border: 2px solid var(--teal-mid);
  color: var(--teal-deep);
  background: transparent;
  padding: 0.45rem 1.4rem;
  border-radius: 25px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  font-size: 0.9rem;
}
.filter-btn:hover,
.filter-btn.active {
  background-color: var(--teal-deep);
  border-color: var(--teal-deep);
  color: var(--white);
}

/* ---- Activities ---- */
.activity-card {
  border: none;
  border-radius: 12px;
  padding: 2rem 1.5rem;
  text-align: center;
  background: var(--white);
  box-shadow: 0 2px 16px rgba(13, 107, 117, 0.08);
  transition: transform 0.25s, box-shadow 0.25s;
  height: 100%;
}
.activity-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 32px rgba(13, 107, 117, 0.16);
}
.activity-icon {
  font-size: 2.8rem;
  color: var(--teal-mid);
  margin-bottom: 1rem;
}
.activity-card h5 {
  font-weight: 700;
  color: var(--teal-deep);
  margin-bottom: 0.5rem;
}

/* ---- CTA strip ---- */
.cta-strip {
  background: linear-gradient(135deg, var(--teal-deep) 0%, var(--teal-mid) 100%);
  padding: 4rem 0;
  color: var(--white);
  text-align: center;
}
.cta-strip h2 {
  font-weight: 700;
  margin-bottom: 0.5rem;
}

/* ---- Footer ---- */
.site-footer {
  background-color: var(--teal-deep);
  color: rgba(255,255,255,0.85);
  padding: 3rem 0 1.5rem;
}
.site-footer a {
  color: rgba(255,255,255,0.75);
  text-decoration: none;
  transition: color 0.2s;
}
.site-footer a:hover {
  color: var(--white);
}
.site-footer .footer-heading {
  color: var(--white);
  font-weight: 700;
  letter-spacing: 0.05em;
  font-size: 0.85rem;
  text-transform: uppercase;
  margin-bottom: 1rem;
}
.footer-divider {
  border-color: rgba(255,255,255,0.15);
}
.footer-icon {
  color: var(--coral);
  margin-right: 0.5rem;
}

/* ---- Video thumbnail ---- */
.video-thumb img {
  aspect-ratio: 16/9;
  object-fit: cover;
  transition: brightness 0.2s;
}
.video-thumb:hover img {
  brightness: 0.85;
  filter: brightness(0.85);
}
.video-play-btn {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 5rem;
  color: white;
  text-shadow: 0 2px 16px rgba(0,0,0,0.5);
  transition: transform 0.2s;
}
.video-thumb:hover .video-play-btn {
  transform: scale(1.1);
}

/* ---- Utility ---- */
.bg-tint { background-color: var(--bg-tint); }
.text-teal { color: var(--teal-deep); }
.text-coral { color: var(--coral); }
