/* Kilnfire Embed Styling */

/* Main container - transparent, no background box */
.kilnfire-classes {
  background-color: transparent !important;
  padding: 0 !important;
  margin: 20px 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  border-radius: 0 !important;
}

@media (prefers-color-scheme: dark) {
  .kilnfire-classes {
    background-color: var(--color3) !important;
  }
}

/* Wrapper div inside kilnfire-classes */
.kilnfire-classes > div {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
  gap: 20px !important;
  width: 100% !important;
  max-width: 100% !important;
  background: transparent !important;
  padding: 20px !important;
  margin: 0 !important;
}

/* Individual class cards - simplified */
.kilnfire-classes > div > div,
.kilnfire-classes > div > a {
  background-color: var(--color6) !important;
  border-radius: 8px !important;
  overflow: hidden !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1) !important;
  transition: transform 0.3s ease, box-shadow 0.3s ease !important;
  padding: 0 !important;
  margin: 0 !important;
  text-decoration: none !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Dark mode card styling */
@media (prefers-color-scheme: dark) {
  .kilnfire-classes > div > div,
  .kilnfire-classes > div > a {
    background-color: var(--color3) !important;
  }
}

.kilnfire-classes > div > div:hover,
.kilnfire-classes > div > a:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
}

/* Card images */
.kilnfire-classes img {
  height: 250px !important;
  width: 100% !important;
  object-fit: cover !important;
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Card content wrapper - same background as card */
.kilnfire-classes > div > div > div,
.kilnfire-classes > div > a > div {
  padding: 15px !important;
  flex-grow: 1 !important;
  background-color: transparent !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Headings and titles - MUCH LARGER */
.kilnfire-classes h3,
.kilnfire-classes h4,
.kilnfire-classes h5 {
  color: var(--color3) !important;
  font-size: 1.85rem !important;
  font-weight: 700 !important;
  margin: 0 0 12px 0 !important;
  padding: 0 !important;
  line-height: 1.3 !important;
}

/* Dark mode titles */
@media (prefers-color-scheme: dark) {
  .kilnfire-classes h3,
  .kilnfire-classes h4,
  .kilnfire-classes h5 {
    color: var(--color1) !important;
  }
}

/* Paragraph text */
.kilnfire-classes p {
  color: #666 !important;
  font-size: 0.95rem !important;
  line-height: 1.5 !important;
  margin: 5px 0 !important;
  padding: 0 !important;
}

/* Dark mode paragraphs - VERY LIGHT */
@media (prefers-color-scheme: dark) {
  .kilnfire-classes p,
  .kilnfire-classes div p {
    color: #f0f0f0 !important;
  }
}

/* Strong/bold text */
.kilnfire-classes strong {
  color: var(--color3) !important;
  font-weight: 700 !important;
}

/* Dark mode strong text */
@media (prefers-color-scheme: dark) {
  .kilnfire-classes strong,
  .kilnfire-classes div strong {
    color: var(--color1) !important;
  }
}

/* All text in dark mode cards should be light */
@media (prefers-color-scheme: dark) {
  .kilnfire-classes > div > div *,
  .kilnfire-classes > div > a * {
    color: #f0f0f0 !important;
  }

  .kilnfire-classes > div > div h3,
  .kilnfire-classes > div > div h4,
  .kilnfire-classes > div > div h5,
  .kilnfire-classes > div > a h3,
  .kilnfire-classes > div > a h4,
  .kilnfire-classes > div > a h5 {
    color: var(--color1) !important;
  }
}

/* Links and buttons */
.kilnfire-classes a:not([class*="kilnfire-classes"]) {
  color: var(--color1) !important;
  text-decoration: none !important;
}

.kilnfire-classes a:hover:not([class*="kilnfire-classes"]) {
  text-decoration: underline !important;
}

/* Button styling - RED/DARK BROWN in light mode, BLUE in dark mode */
.kilnfire-classes button,
a[class*="button"],
span[class*="button"] {
  background-color: var(--color3) !important;
  color: #ffffff !important;
  border: none !important;
  padding: 12px 24px !important;
  border-radius: 4px !important;
  font-weight: 700 !important;
  font-size: 1.3rem !important;
  transition: background-color 0.3s ease !important;
  cursor: pointer !important;
  text-decoration: none !important;
  display: inline-block !important;
  margin-top: 12px !important;
}

/* Dark mode buttons - BLUE */
@media (prefers-color-scheme: dark) {
  .kilnfire-classes button,
  a[class*="button"],
  span[class*="button"] {
    background-color: var(--color4) !important;
    color: #ffffff !important;
  }

  .kilnfire-classes button:hover,
  a[class*="button"]:hover,
  span[class*="button"]:hover {
    background-color: #4a7a9e !important;
  }
}

.kilnfire-classes button:hover,
a[class*="button"]:hover,
span[class*="button"]:hover {
  background-color: #6f3d42 !important;
  color: #ffffff !important;
}

/* Responsive adjustments */
@media (max-width: 1024px) {
  .kilnfire-classes > div {
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)) !important;
  }
}

@media (max-width: 768px) {
  .kilnfire-classes > div {
    grid-template-columns: 1fr !important;
  }

  .kilnfire-classes img {
    height: 200px !important;
  }

  .kilnfire-classes h3,
  .kilnfire-classes h4,
  .kilnfire-classes h5 {
    font-size: 1.2rem !important;
  }
}

/* ===== KILNFIRE CALENDAR VIEW STYLING ===== */

/* Calendar wrapper - force vertical single-column layout */
.kilnfire-calendar.kilnfire-class-calendar {
  width: 100% !important;
  max-width: 100% !important;
  margin: 20px 0 !important;
  background-color: var(--color2) !important;
  border-radius: 8px !important;
  box-shadow: none !important;
  border: none !important;
  padding: 20px !important;
  display: flex !important;
  flex-direction: column !important;
}

@media (prefers-color-scheme: dark) {
  .kilnfire-calendar.kilnfire-class-calendar {
    background-color: var(--color3) !important;
  }
}

/* Calendar header - ensure it's full width above calendar */
.kilnfire-calendar-header {
  width: 100% !important;
  display: block !important;
  margin-bottom: 15px !important;
  padding: 0 !important;
  background-color: transparent !important;
  flex: none !important;
}

@media (prefers-color-scheme: dark) {
  .kilnfire-calendar-header {
    border: 1px solid transparent !important;
  }
}

/* Header left section - horizontal layout with navigation and title */
.kilnfire-calendar-header-left {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  width: 100% !important;
  flex-wrap: nowrap !important;
  gap: 15px !important;
  margin-bottom: 0 !important;
}

/* Hide the right header section if it exists */
.kilnfire-calendar-header-right {
  display: none !important;
}

/* Month title */
.kilnfire-calendar-month-title {
  font-size: 2.5rem !important;
  font-weight: 700 !important;
  color: var(--color3) !important;
  margin: 0 !important;
  flex: 1 !important;
  min-width: 150px !important;
  font-family: 'Open Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif !important;
}

@media (prefers-color-scheme: dark) {
  .kilnfire-calendar-month-title {
    color: var(--color1) !important;
  }
}

/* Navigation buttons */
.kilnfire-calendar-header-buttons {
  display: flex !important;
  gap: 5px !important;
  align-items: center !important;
}

.kilnfire-calendar-button {
  background-color: var(--color3) !important;
  color: white !important;
  border: none !important;
  padding: 8px 14px !important;
  border-radius: 4px !important;
  cursor: pointer !important;
  font-size: 1.25rem !important;
  transition: background-color 0.2s !important;
  font-weight: 500 !important;
  line-height: 1.25rem !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 40px !important;
  vertical-align: middle !important;
}

.kilnfire-calendar-button:hover {
  background-color: var(--color4) !important;
}

.kilnfire-calendar-button-prev,
.kilnfire-calendar-button-next {
  padding: 8px 14px !important;
  min-height: 40px !important;
}

@media (prefers-color-scheme: dark) {
  .kilnfire-calendar-button {
    background-color: var(--color4) !important;
  }
  
  .kilnfire-calendar-button:hover {
    background-color: var(--color1) !important;
    color: var(--color3) !important;
  }
}

/* Button icons */
.kilnfire-button-icon {
  width: 1.25rem !important;
  height: 1.25rem !important;
  display: inline-block !important;
  vertical-align: middle !important;
  flex-shrink: 0 !important;
}

.kilnfire-calendar-area-container {
  width: 100% !important;
  display: block !important;
  min-width: 0mportant;
  display: block !important;
}

.kilnfire-calendar-area-container {
  width: 100% !important;
  display: block !important;
}

@media (prefers-color-scheme: dark) {
  .kilnfire-calendar-area-container {
    border: 1px solid transparent !important;
  }
}

/* Day headers (S M T W T F S) */
.kilnfire-calendar-daysofweek {
  display: grid !important;
  grid-template-columns: repeat(7, 1fr) !important;
  gap: 2px !important;
  margin-bottom: 0 !important;
  background-color: var(--color2) !important;
  padding: 0 !important;
  border-radius: 0 !important;
}

.kilnfire-calendar-dayheader {
  text-align: center !important;
  font-weight: 700 !important;
  padding: 8px 5px !important;
  background-color: var(--color3) !important;
  color: white !important;
  font-size: 1.25rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
}

@media (prefers-color-scheme: dark) {
  .kilnfire-calendar-daysofweek {
    background-color: #333 !important;
  }
  .kilnfire-calendar-dayheader {
    background-color: #333 !important;
    color: #e0e0e0 !important;
  }
}

/* Desktop calendar grid - force single column display */
.kilnfire-calendar-desktop {
  display: grid !important;
  grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
  gap: 2px !important;
  background-color: var(--color2) !important;
  padding: 0 !important;
  width: 100% !important;
}

@media (prefers-color-scheme: dark) {
  .kilnfire-calendar-desktop {
    background-color: var(--color3) !important;
  }
}

/* Force dates area to be full width */
.kilnfire-calendar-dates-area {
  width: 100% !important;
  display: block !important;
}

/* Hide mobile calendar on desktop */
.kilnfire-calendar-mobile {
  display: none !important;
}

/* Individual day cells */
.kilnfire-calendar-day {
  min-height: 100px !important;
  padding: 8px !important;
  background-color: var(--color2) !important;
  position: relative !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-start !important;
  overflow: hidden !important;
  min-width: 0 !important;
}

@media (prefers-color-scheme: dark) {
  .kilnfire-calendar-day {
    background-color: var(--color3) !important;
    border: 1px solid var(--color2) !important;
  }
}

/* Day number */
.kilnfire-calendar-day time {
  display: block !important;
  font-size: 1.6rem !important;
  font-weight: 600 !important;
  color: var(--color3) !important;
  margin-bottom: 5px !important;
  text-align: center !important;
}

@media (prefers-color-scheme: dark) {
  .kilnfire-calendar-day time {
    color: #e0e0e0 !important;
  }
}

/* Today highlight */
.kilnfire-calendar-is-today {
  background-color: var(--color1) !important;
  color: white !important;
  padding: 4px 8px !important;
  border-radius: 4px !important;
  font-weight: bold !important;
  display: inline-block !important;
  text-align: center !important;
  min-width: 2rem !important;
}

/* Event list in each day */
.kilnfire-calendar-day-events {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 3px !important;
  width: 100% !important;
  align-items: stretch !important;
}

/* Individual event */
.kilnfire-calendar-event {
  background-color: var(--color2) !important;
  border-radius: 3px !important;
  padding: 4px 6px !important;
  font-size: 1rem !important;
  font-weight: bold !important;
  overflow-x: auto !important;
  width: 100% !important;
}

.kilnfire-calendar-event a {
  text-decoration: none !important;
  color: var(--color3) !important;
  display: block !important;
}

.kilnfire-calendar-event a:hover {
  color: var(--color1) !important;
}

@media (prefers-color-scheme: dark) {
  .kilnfire-calendar-event {
    background-color: var(--color3) !important;
  }
  
  li.kilnfire-calendar-event {
    background-color: var(--color3) !important;
  }
  
  .kilnfire-calendar-event a {
    color: white !important;
  }
  
  .kilnfire-calendar-event a:hover {
    color: white !important;
  }
  
  .kilnfire-event-not-available {
    background-color: var(--color3) !important;
    opacity: 0.7 !important;
  }
}

/* Event time and title */
.kilnfire-calendar-event-time {
  font-weight: bold !important;
  display: block !important;
  font-size: 0.9rem !important;
  color: var(--color3) !important;
}

.kilnfire-calendar-event-title {
  margin: 2px 0 0 0 !important;
  font-size: 1.35rem !important;
  line-height: 1.2 !important;
  color: var(--color3) !important;
}

@media (prefers-color-scheme: dark) {
  .kilnfire-calendar-event-time {
    color: white !important;
  }
  .kilnfire-calendar-event-title {
    color: white !important;
  }
}

/* Not available events */
.kilnfire-event-not-available {
  background-color: var(--color2) !important;
}

.kilnfire-event-not-available a,
.kilnfire-event-not-available .kilnfire-calendar-event-time,
.kilnfire-event-not-available .kilnfire-calendar-event-title {
  color: #888 !important;
}

.kilnfire-event-not-available a,
.kilnfire-event-not-available .kilnfire-calendar-event-time,
.kilnfire-event-not-available .kilnfire-calendar-event-title {
  color: #888 !important;
}

/* Responsive mobile view */
@media (max-width: 768px) {
  .kilnfire-calendar-desktop {
    display: none !important;
  }
  
  .kilnfire-calendar-mobile {
    display: grid !important;
    grid-template-columns: repeat(7, 1fr) !important;
    gap: 2px !important;
    background-color: #e0e0e0 !important;
    padding: 2px !important;
  }
  
  .kilnfire-calendar-header-left {
    flex-direction: column !important;
    align-items: center !important;
  }
  
  .kilnfire-calendar-month-title {
    font-size: 1.4rem !important;
    text-align: center !important;
  }
  
  .kilnfire-calendar-day {
    min-height: 60px !important;
    padding: 4px !important;
  }
}
