/* === Oscar's Tree Academy — FVW Foundation Build v6 === */
/* Now with image fallback styles + better quiz option display */

:root {
  --color-primary: #FFFFFF;
  --color-secondary: #54595F;
  --color-text: #7A7A7A;
  --color-accent: #61CE70;
  --color-green-deep: #1F3A02;
  --color-green-mid: #30411E;
  --color-green-olive: #67AA56;
  --font-primary: Tahoma, sans-serif;
  --font-body: Roboto, sans-serif;
  --font-serif: 'Roboto Slab', serif;
  --font-display: 'Red Hat Display', sans-serif;
}

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

body {
  font-family: var(--font-body);
  color: var(--color-text);
  background: #fff;
  font-size: 16px;
  line-height: 1.6;
}

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

/* === IMAGE FALLBACKS for blocked-or-empty src === */
img:not([src]),
img[src=""],
img[src=" "],
img[src*="Ellipse-"] {
  background: var(--color-green-mid);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-accent);
  font-size: 14px;
  font-weight: 500;
  text-align: center;
  min-height: 80px;
  border-radius: 50%;
}

/* When image is empty src, show a placeholder */
img[src=""]::before {
  content: attr(alt) " (image unavailable)";
  display: block;
  padding: 20px;
  color: var(--color-text);
}

a { color: var(--color-green-olive); text-decoration: none; }
a:hover { color: var(--color-accent); }

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-serif);
  color: var(--color-secondary);
  margin: 0 0 16px;
  line-height: 1.2;
}

p { margin: 0 0 16px; }

/* === SECTIONS === */
.vsil-section { width: 100%; position: relative; }
.vsil-section.vsil-header { padding: 16px 0; background: transparent; }
.vsil-section.vsil-section-heading { background: transparent; padding: 30px 20px; text-align: center; }
.vsil-section.vsil-section-heading h2 { font-size: 28px; color: var(--color-secondary); margin: 0; }

.vsil-section.vsil-hero {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  min-height: 600px;
  color: #fff;
}
.vsil-section.vsil-hero .vsil-hero-text h2,
.vsil-section.vsil-hero .vsil-hero-text p {
  color: #fff;
}

.vsil-section.vsil-carousel { padding: 60px 20px; color: #333; background: transparent; }
.vsil-section.vsil-intro { padding: 80px 20px; background: #fff; color: #555; }
.vsil-section.vsil-intro h2 { color: #54595F; font-size: 32px; }
.vsil-section.vsil-intro p, .vsil-section.vsil-intro li { color: #6b6b6b; }

.vsil-section.vsil-callout { padding: 80px 20px; background: var(--color-green-deep); color: #fff; text-align: center; }
.vsil-section.vsil-callout h2, .vsil-section.vsil-callout h3 { color: #fff; }

.vsil-section.vsil-news-strip { padding: 30px 20px; background: var(--color-green-mid); color: #fff; text-align: center; }
.vsil-section.vsil-news-strip h2 { color: #fff; }

.vsil-section.vsil-quiz-section { padding: 60px 20px; background: #fff; }

.vsil-section.vsil-testimonials { padding: 60px 20px; background: #f7f7f4; }

.vsil-section.vsil-about { padding: 60px 20px; background: var(--color-green-deep); color: #fff; text-align: center; }
.vsil-section.vsil-about h2 { color: #fff; }
.vsil-section.vsil-about p { color: #d8e6d8; }

.vsil-section.vsil-footer { background: var(--color-green-deep); color: #e8eee8; padding: 60px 0 0; }

/* === SECTION INNER LAYOUTS === */
.vsil-header-inner {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 30px;
}

.vsil-hero-inner {
  max-width: 1140px;
  margin: 0 auto;
  padding: 80px 20px;
  display: flex;
  align-items: center;
  gap: 60px;
}
.vsil-hero-text { flex: 1; }
.vsil-hero-image { flex: 0 0 400px; }

.vsil-callout-inner {
  max-width: 900px;
  margin: 0 auto;
}

.vsil-quiz-inner {
  max-width: 1140px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 40px;
  align-items: start;
}
.vsil-quiz-card { background: #fff; border-radius: 8px; padding: 24px; text-align: center; }

.vsil-intro-inner {
  max-width: 1140px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 50px;
}

.vsil-testimonials-inner {
  max-width: 1140px;
  margin: 0 auto;
  text-align: center;
}

.vsil-testimonial-slider {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 24px;
  margin-top: 40px;
}
.vsil-testimonial {
  background: #fff;
  border-radius: 12px;
  padding: 24px;
  text-align: center;
}

.vsil-footer-inner {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 20px;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1.2fr;
  gap: 50px;
}

/* === CAROUSEL === */
.vsil-carousel {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 20px;
}
.vsil-slides {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
}
.vsil-slide {
  background: #fff;
  color: var(--color-text);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}
.vsil-slide img {
  aspect-ratio: 4/5;
  object-fit: cover;
  width: 100%;
  /* If slide image is empty/missing, show a placeholder */
  background: var(--color-green-mid);
}
.vsil-slide h3 {
  padding: 14px 18px 6px;
  color: var(--color-secondary);
  font-size: 20px;
}
.vsil-slide p {
  padding: 0 18px 14px;
  font-size: 14px;
}

/* === NAV === */
.vsil-nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 30px;
}
.vsil-nav a {
  color: #fff;
  font-weight: 500;
  padding: 6px 0;
}

/* === CTA === */
.vsil-cta {
  display: inline-block;
  padding: 10px 24px;
  border-radius: 4px;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  transition: all 0.2s;
  margin: 12px 0;
  background: var(--color-green-mid);
  color: #fff;
  border: 1px solid transparent;
}
.vsil-cta-outline {
  background: transparent;
  color: var(--color-green-olive);
  border-color: var(--color-green-olive);
}
.vsil-cta-outline:hover {
  background: var(--color-green-olive);
  color: #fff;
}

/* === HEADER LOGO === */
.vsil-header .vsil-img {
  width: 110px !important;
  max-width: 110px !important;
  height: 110px;
  object-fit: contain;
}

/* === QUIZ === */
.vsil-quiz-questions {
  background: #fff;
  color: var(--color-text);
  border-radius: 8px;
  padding: 30px 40px;
}
.vsil-quiz-questions h2 {
  color: var(--color-secondary);
  text-align: center;
  font-size: 28px;
  margin-bottom: 30px;
}
.vsil-quiz-questions h2 .vsil-fun { color: var(--color-green-olive); }

.vsil-q {
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 1px solid #eee;
}
.vsil-q:last-child { border-bottom: none; }

.vsil-q-opts {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.vsil-q-opt {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: 6px;
  cursor: pointer;
  background: #fafaf6;
  border: 1px solid #eee;
  /* If option label is empty, show a placeholder */
  min-height: 44px;
}
.vsil-q-opt:hover { background: #f0f5e8; }
.vsil-q-opt input { margin: 0; flex-shrink: 0; }
.vsil-toggle {
  display: inline-block;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid var(--color-green-olive);
  flex-shrink: 0;
}
.vsil-q-opt input:checked ~ .vsil-toggle {
  background: var(--color-green-olive);
}
.vsil-q-label {
  flex: 1;
  color: var(--color-secondary);
}
/* Show placeholder text in empty options */
.vsil-q-opt:has(.vsil-q-label:empty)::before {
  content: "Option text unavailable";
  color: #bbb;
  font-style: italic;
}

/* === LIST === */
.vsil-list { list-style: disc; padding-left: 24px; }
.vsil-list li {
  color: var(--color-text);
  margin-bottom: 4px;
}

/* === ANIMATED HEADLINE === */
.vsil-animated {
  display: inline-block;
  font-size: 48px;
  color: #fff;
  margin: 20px 0;
}
.vsil-animated span {
  display: inline-block;
  animation: bounce 2s infinite;
  margin: 0 8px;
}
.vsil-animated span:nth-child(2) {
  color: var(--color-accent);
  animation-delay: 0.5s;
}
@keyframes bounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}

/* === AVATAR / TESTIMONIAL === */
.vsil-avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--color-green-mid);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  font-weight: 600;
  margin: 0 auto 12px;
}

/* Fallback for empty testimonial avatars */
.vsil-testimonial .vsil-img[src=""],
.vsil-testimonial .vsil-img:not([src]) {
  background: var(--color-green-mid);
  color: var(--color-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
}

/* === COOKIE BANNER === */
.vsil-cookie {
  position: fixed;
  bottom: 20px;
  left: 20px;
  right: 20px;
  padding: 16px 24px;
  background: var(--color-green-deep);
  color: #fff;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  z-index: 100;
  box-shadow: 0 4px 16px rgba(0,0,0,0.2);
}
.vsil-cookie-accept, .vsil-cookie-reject {
  background: var(--color-accent);
  color: #fff;
  border: none;
  padding: 8px 16px;
  border-radius: 4px;
  cursor: pointer;
  font-weight: 500;
}

/* === FALLBACKS when inner div missing === */
.vsil-intro:not(:has(.vsil-intro-inner)) {
  display: flex;
  align-items: center;
  gap: 50px;
  padding: 80px 20px;
  max-width: 1140px;
  margin: 0 auto;
  flex-wrap: wrap;
}
.vsil-intro:not(:has(.vsil-intro-inner)) > img {
  max-width: 320px;
  flex: 0 0 320px;
}
.vsil-intro:not(:has(.vsil-intro-inner)) > h2,
.vsil-intro:not(:has(.vsil-intro-inner)) > p,
.vsil-intro:not(:has(.vsil-intro-inner)) > ul {
  flex: 1;
  min-width: 300px;
}

.vsil-testimonials:not(:has(.vsil-testimonials-inner)) {
  padding: 60px 20px;
  max-width: 1140px;
  margin: 0 auto;
  text-align: center;
}

.vsil-footer:not(:has(.vsil-footer-inner)) {
  padding: 60px 20px;
}

/* === RESPONSIVE === */
@media (max-width: 900px) {
  .vsil-hero-inner,
  .vsil-intro-inner,
  .vsil-quiz-inner,
  .vsil-footer-inner {
    flex-direction: column;
    grid-template-columns: 1fr;
  }
  .vsil-hero-image { flex: none; width: 100%; max-width: 400px; margin: 0 auto; }
  .vsil-nav ul { flex-wrap: wrap; gap: 14px; font-size: 14px; }
}

/* === FIX PATCH: placeholder styling for option 5-8 placeholders === */
.vsil-q-opt .vsil-q-label:empty,
.vsil-q-opt .vsil-q-label[data-option-text^="Option "] {
    color: #aaa;
    font-style: italic;
}

/* Show Option N text muted */
.vsil-q-label { line-height: 1.4; }

/* === AVATAR FALLBACK for blocked images === */
.vsil-avatar-fallback {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: var(--color-green-mid);
    color: var(--color-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    font-weight: 600;
    margin: 0 auto 12px;
}

/* === Better quiz option text styling === */
.vsil-q-opt {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px 14px;
    border-radius: 6px;
    cursor: pointer;
    background: #fafaf6;
    border: 1px solid #eee;
    min-height: 44px;
}
.vsil-q-opt input[type=radio] { margin-top: 4px; }
.vsil-q-opt:hover { background: #f0f5e8; border-color: var(--color-green-olive); }

/* === Carousel slide title styling === */
.vsil-slide h3 {
    margin: 0;
    padding: 14px 18px 6px;
    color: var(--color-secondary);
    font-size: 18px;
    font-weight: 600;
}
.vsil-slide p {
    margin: 0;
    padding: 0 18px 14px;
    font-size: 13px;
    color: var(--color-text);
    line-height: 1.5;
}
.vsil-slide .vsil-cta { margin: 0 18px 18px; }
