:root {
  --calendar_primary-heading-text-color: #2b2b2b;
  --calendar_text-color: #3a2f24;
  --calendar_button-text-color: #1f3a32;
  --calendar_golden-border-color-1: #b67e04;
  --calendar_golden-border-color-2: #e0b860;
  --calendar_bg-paper-texture1: url("../assets/backgroundImage/body_bg_1.avif");
  --calendar_bg-button: url("../assets/backgroundImage/buttonBackground.avif");
  --calendar_font-home-heading: "Pirata One", serif;
  --calendar_font-heading: "Cinzel", serif;
  --calendar_font-text: "Inter", sans-serif;
}

body {
  background: var(--calendar_bg-paper-texture1) no-repeat top/cover;
}
/* Calander Page Styles  */
.calendar_page {
  position: relative;
}

/* Top Icons  */
.calendar_page .top_left_icon {
  position: absolute;
  top: 0;
  left: 0;
  width: 100px;
  height: auto;
}
.calendar_page .top_center_icon {
  position: absolute;
  top: -30px;
  left: 50%;
  transform: translateX(-50%);
  width: 250px;
  height: auto;
}
.calendar_page .top_right_icon {
  position: absolute;
  top: 0;
  right: 0;
  width: 100px;
  height: auto;
}

/* Responsive icon sizes*/
@media (max-width: 768px) {
  .calendar_page .top_left_icon {
    width: 80px;
    height: auto;
  }
  .calendar_page .top_center_icon {
    width: 200px;
    height: auto;
    top: -20px;
  }
  .calendar_page .top_right_icon {
    width: 80px;
    height: auto;
  }
}

/* Titles */
.calendar_page_title{
padding-top: 40px;
font-family: var(--calendar_font-heading);
font-size: 42px;
text-align:center;
margin-bottom:20px;
}

/* divider  */
.divider{
    width: 100%;
    margin: 0px 0px 1px 0px;
    padding-bottom: 2px;
    border: 4px ridge var(--calendar_golden-border-color-1);
    box-shadow: 5px 5px 10px var(--calendar_primary-heading-text-color);
}

/* Calendar Controls */
.calendar-controls {
display:flex;
justify-content:center;
align-items:center;
gap:20px;
margin-bottom:15px;
}
.calendar-controls button {
padding:6px 6px;
font-size:18px;
cursor:pointer;
color: var(--calendar_primary-heading-text-color);
background: transparent;
border: none;
}
#yearDisplay {
font-family: var(--calendar_font-heading);
font-size:24px;
}

/* Month Navigation */
.month-navigation {
display:flex;
flex-wrap:wrap;
justify-content:center;
margin-bottom:15px;
padding: 2px;
border: 2px ridge var(--calendar_golden-border-color-1);
}
.month-btn {
padding:10px 16px;
border:2px ridge var(--calendar_golden-border-color-1);
cursor:pointer;
font-size:14px;
font-weight: 500;
background:transparent;
font-family: var(--calendar_font-text);
}
.month-btn.active {
background: var(--calendar_bg-button);
color:white;
}

/* Selected Month Title */
.selected-month-title {
font-family: var(--calendar_font-heading);
font-size: 28px;
text-align: center;
margin-bottom: 10px;
color: var(--calendar_primary-heading-text-color);
}

/* Calendar */
.calendar-wrapper {
border:6px ridge var(--calendar_golden-border-color-1);
transition: height 0.5s ease;
width: 100%;
  overflow-x: auto; /* Enables horizontal scrolling */
  -webkit-overflow-scrolling: touch; /* Smooth scrolling for iOS */
}
.calendar-table {
width:100%;
border-collapse:collapse;
table-layout: fixed;
}
.calendar-table th {
font-family: var(--calendar_font-heading);
padding:10px;
border:2px ridge var(--calendar_golden-border-color-1);
background:var(--calendar_golden-border-color-1);
}
.calendar-table td {
height:80px;
vertical-align:top;
padding:15px;
border:3px ridge var(--calendar_golden-border-color-1);
font-weight:700;
font-family: var(--calendar_font-text);
overflow: auto;
}

/* Today */
.today {
background:var(--calendar_golden-border-color-1);
}

/* Event day */
.event-day {
background:var(--calendar_bg-button) center/cover;
}

/* Weekly Schedule */
.weekly-schedule {
margin-top:40px;
}
.weekly-schedule h2 {
font-family: var(--calendar_font-heading);
margin-bottom:10px;
}
.weekly-schedule ul {
list-style:none;
}
.weekly-schedule li {
padding:8px;
border-bottom:1px solid #ddd;
}

/* Saturday Highlight */

.saturday {
background: var(--calendar_bg-button);
color:white;
font-weight:600;
}

.weekly-schedule li{
  font-family: var(--calendar_font-text);
}

/* Events */
.events-section {
margin-top:40px;
}
.events-section h2 {
font-family: var(--calendar_font-heading);
margin-bottom:10px;
}
.events-table {
width:100%;
border-collapse:collapse;
}
.events-table th,
.events-table td {
border:2px ridge var(--calendar_golden-border-color-1);
padding:10px;
text-align:left;
}
.events-table tbody tr {
cursor:pointer;
}
.events-table tbody tr:hover {
background:#f0f0f0;
}

/* Event Detail */
.event-detail {
margin-top:20px;
border:6px ridge var(--calendar_golden-border-color-1);
padding:20px;
background:white;
animation: fadeIn .3s ease;
}

.event-detail h3 {
font-family: var(--calendar_font-heading);
margin-bottom:6px;
}
.event-detail h4 {
color:#555;
margin-bottom:10px;
}
.event-detail ul {
margin-top:10px;
padding-left:20px;
}

/* Base Overlay Styles */
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.516);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
  
  /* Hidden state for closing (Fade Down) */
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease-in-out;
}

/* Base Content Styles */
.event-detail {
  background: var(--calendar_bg-button) center/cover;
  padding: 40px 30px 30px;
  border: 6px ridge var(--calendar_golden-border-color-1);
  max-width: 650px;
  width: 90%;
  position: relative;
  
  /* Starting position for Fade Up */
  transform: translateY(20px); 
  transition: transform 0.3s ease-in-out;
}

/* Active State (When Popup Opens) */
.modal-overlay.active {
  opacity: 1;
  visibility: visible;
}

.modal-overlay.active .event-detail {
  transform: translateY(0); /* Moves up to center */
}

/* Close (X) Button */
.close-popup {
  position: absolute;
  top: 10px;
  right: 15px;
  font-size: 32px;
  font-weight: bold;
  cursor: pointer;
  color: #734f00;
  line-height: 1;
}