@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Archivo+Black&family=Girassol&family=Gochi+Hand&family=Lexend:wght@100..900&family=Outfit:wght@100..900&family=Young+Serif&display=swap');
@import url('https://fonts.googleapis.com/css2?family=League+Script&display=swap');

*{
    padding: 0;
    margin: 0;
    box-sizing: border-box;
}
html {
    font-family: Lexend;
    scroll-behavior: smooth;
    overflow-x: hidden;
    height: 100%;

}
body{
    height: 100%;
}

#skiplinks {
    width: 100%;
    position: absolute;
    left: -10000px;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
}
#skiplinks a {
    color: #5B5B5B;
}
#skiplinks a:focus {
    position: static;
    width: auto;
    height: auto;
}

.logo {
    color: #fff5de;
    cursor: pointer;
    font-weight: 700;
    font-size:  2.2em;
    background-color: #70661f;
    border-radius: 5px;
}
.logo a {
    text-decoration: none;
    color: #fff5de;
    padding: 1rem;
}

.nav {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    background-color: transparent;
    height: 65px;
    padding: 3em;
    position: relative;
    z-index: 1000;
    
}

.nav ul {
    font-weight:600;
    font-size:1.2em;
}
.menu li:hover {
    color:#e87f2a;
    cursor:pointer;
    transition: 0.4s;
}
.menu {
    display: flex;
    flex-direction: row;
    list-style-type: none;
    margin: 0;
    padding: 0;
}
.menu a {
    text-decoration: none;
    color: #fff5de;
    align-items: center;
    align-content: center;
    transition: color 1.2s;
}
.menu a:hover {
    color:#1a2a39;
    transition: 0.4s;
}
.menu > li {
    margin: 0 1rem;
    overflow: hidden;
    align-items: center;
    align-content: center;
}

.venues-m {
    background-color: #c96c21;
    border-radius: 5px;
    padding: 10px;
}

.map-m {
    background-color: #c96c21;
    border-radius: 5px;
    padding: 10px;
}

.gigs-m {
    background-color: #c96c21;
    border-radius: 5px;
    padding: 10px;
}

.featured-artists-m {
    background-color: #c96c21;
    border-radius: 5px;
    padding: 10px;
}

.menu-button-container {
    display: none;
    height: 100%;
    width: 30px;
    cursor: pointer;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

#menu-toggle {
  display: none;
}
.menu-button,
.menu-button::before,
.menu-button::after {
    display: block;
    background-color: #70661f;
    position: absolute;
    height: 5px;
    width: 32px;
    border-radius: 10px;
}
.menu-button::before {
    content: '';
    margin-top: -8px;
}

.menu-button::after {
    content: '';
    margin-top: 8px;
}
#menu-toggle:checked + .menu-button-container .menu-button::before {
    margin-top: 0px;
    transform: rotate(45deg);
}

#menu-toggle:checked + .menu-button-container .menu-button {
    background: rgba(255, 255, 255, 0);
}

#menu-toggle:checked + .menu-button-container .menu-button::after {
    margin-top: 0px;
    transform: rotate(-45deg);
}

@media (max-width: 1000px) {
  .menu-button-container {
    display: flex;
  }
  .menu {
    position: absolute;
    top: 0;
    margin-top: 50px;
    left: 0;
    flex-direction: column;
    width: 100%;
    justify-content: center;
    align-items: center;
    padding-top: 30px;
  }
  #menu-toggle ~ .menu li {
    height: 0;
    margin: 0;
    padding: 0;
    border: 0;
  }
  #menu-toggle:checked ~ .menu li {
    border: 1px solid white;
    height: 2.5em;
    padding: 2em;
      
  }
  .menu > li {
    display: flex;
    justify-content: center;
    margin: 0;
    padding: 0.5em 0;
    width: 100%;
    color: black;
   
    
  }
  .menu > li:not(:last-child) {
    border-bottom: 1px solid #444;
 
  }
}

#hero {
    max-width: 8000px;
    margin-top: -9em;
    height: 800px;
    background-image: url(Facebook\ Edit\ October\ 25\,\ 2024-92-evetographyy.jpg);
    opacity: 0.9;
    background-position: center;
    background-size: cover;
    box-shadow: inset 0 0 90px 70px rgb(0, 0, 0);
   
}



.main-title h1 {
    font-size: 90px;
    font-weight: 800;
    text-align: center;
    position: relative;
    padding-top: 2.5em;
    color: #fff5de;
    text-shadow: 2px 2px 30px #000;
    
}

h1 {
    text-align: center;
    font-size: 28px;
    margin-bottom: 30px;
}



.main-title h3 {
    font-size: 1.2em;
    font-weight: 500;
    line-height: 1.6em;
    text-align: center;
    color: #fff5de;
    margin-left: 20em;
    margin-right: 20em;
    margin-bottom: 4em;
    border-radius: 40px;
    background:rgba(13, 13, 13, 0.568);
    padding: 2.5em;
    
}


#gigs details li {
    font-size: 1em;
}

#gigs details ul {
    list-style: none;
}


.container2 {
    width: 100%;
    height: 100%;
    font-family: Lexend;
    position: relative;
}

.container2 h1{
    padding-left: 4em;
    padding-top: .5em;
    padding-bottom: .5em;
    color: black;
    text-align: center;
    font-size: 3rem;
    font-family: Lexend;
    align-items: center;
  }

  details{ 
    background-color: #fff5de;
    color: #c96c21;
   
  }

.month h1 {
    padding-top: 1em;
    color: #c96c21;
    margin-left: -1.5em;
    
}

.weektitle h1 {
    color: #1a2a39;
    padding-top: 1em;


}

.weektitle  {
    color: #1a2a39;
    margin-left: -4.5em;
}

.monthlast {
    padding-bottom: 10em;
}

.monthweek {
  
}

#divider {
  max-width: 5000px;
  height: 7px;
  background-color: #e5d9b6;
  transition: 0.6s;
}

.listings {
  
  padding-left: 5.5em;
  display: flex;
  align-items: center;         /* vertical alignment */
  justify-content: space-between; /* space between elements */
  gap: 0.5em;
  
  
}

.listings a {
  text-decoration: none;
  display: flex;               /* ensures <p> inside are aligned */
  align-items: center;
}

.listings p {
  margin: 0;
  padding: 0.5em 1em;
  font-size: 2em;
  font-weight: 500;
  text-align: left;
}

.titleitem {
  margin-left: 20em;            /* add some left padding for spacing */
  /* Optional: min-width if needed */
  max-width: 15em;               /* small width to avoid unnecessary spacing */
}

.weeklast {
  white-space: nowrap;

 
}

li.monthend {
    border-bottom: 20px solid #1a2a39;
 
  }

  li.monthbottom {
  
    padding-bottom: 3.5em;
  
  }


.last {
    padding-bottom: 2em;
}

details[open] {
    color: #1a2a39; /* Optional: Change text color too */
    transition: background-color 0.3s ease, color 0.3s ease;
    
  }

/* Open state for week (changes summary + headings + listings) */

#monthweek[open] {
    margin-top: -0.2em;  /* Adjust this to shift everything up */
  }
  
  #monthweek[open] > summary.month h1 {
    margin-bottom: -0.5em; /* Optional: further reduce space below the month title */
  }
  
  #monthweek[open] .weektitle h1 {
    margin-top: -0.2em;  /* Optional: reduce space above the week title */
  }
  
  #monthweek[open] .listings {
    margin-top: -0.2em;  /* Optional: adjust space above the listings */
  }

#monthweek[open] > summary.weektitle {
    background-color: #efe3be;
    
  }
  
  #monthweek[open] > summary.weektitle h1 {
    color: #c96c21;
  }
  
  /* Listings color change when parent is open */
  #monthweek[open] .listings {
    background-color: #70661f;
  }
  
  #monthweek[open] .listings p {
    color: #1a2a39;
  }

  #monthweek[open] .listings p:hover {
    color: #c96c21;
  }

  #monthweek[open] .listings {
    background-color: #efe3be;
  }

  #monthweek[open] .weeklast {
    padding-bottom: 1em;
    display: inline-block; /* Ensures padding applies visually */
  }
  
  /* Optional: Month section open styling */
  details[open] > summary.month {
    background-color: #efe3be;
  }
  
  details[open] > summary.month h1 {
    color: #1a2a39;
   
  }
  



  .listings p:hover {
    color: #c96c21;
    cursor: pointer;
  }
  
  #monthweek[open] summary {
    content: "\002B";
    color:#1a2a39;
  }


  summary {
    list-style: none;
    display: flex;
    justify-content: space-between;
    font-weight: 500;
    cursor: pointer;
    position: relative;
  }
  
  summary::-webkit-details-marker {
    display: none;
  }
  
  summary::after {
    content: "\002B";
    font-size: 5em;
    padding-right: 2em;
    transition: transform 0.2s ease;
  }
  
  /* When details is open, change icon */
  details[open] > summary::after {
    content: "\00D7";
    font-size: 5em;
    padding-right: 2em;
  }

  summary,
  .weektitle,
  .weektitle h1,
  .listings,
  .listings p {
    transition: background-color 0.3s ease, color 0.3s ease;
  }




footer {
    width: 100%;
    padding-top: 4em;
    
    background-image:  linear-gradient(rgba(77, 78, 74, 0.748),rgba(0,0,0,0.8)), url("250130 - LS Dunes-33-oliverboj.jpg");
    background-size: cover;
    background-position: center;
    box-shadow: inset 0 0 150px 80px rgb(23, 23, 23);
   
}
.Fcontainer {
    width: 90%;
    margin: auto;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
}

.Fcontainer li a:hover {
    color: #e87f2a;
    transition: all 0.5s ease;
}
.col-1 {
    flex-basis: 30%;
    padding: 10px;
    margin-bottom: 10px;
    color: #fff5de;
    text-shadow: 0px 0px 30px #000000;
}

.col-1 h3 {
    color: #fff5de;
    width: 270px;
    font-size: 20px;
    margin-bottom: 15px;
    font-family: Lexend;
    border-radius: 5px;
}

.col-1 a {
   color: #fff5de;
   text-shadow: 0px 0px 30px #000000;
}

.col-1 p {
    
    color: #fff5de;
    font-size: 15px;
    
}
.col-2 {
    padding: 10px;
    margin-bottom: 10px;
    color: #fff5de;

}
.col-2 h3 {
    color: #fff5de;
    font-size: 20px;
    margin-bottom: 15px;
    font-family: Lexend;
}
.col-2 ul {
    list-style: none;
    color: #fff;
}
.col-2 ul li {
    margin-bottom: 10px;
}
.col-2 ul li a {
    color: #fff5de;
    text-decoration: none;
    transition: color 1.2s;
    text-shadow: 0px 0px 30px #000000;
}
.col-3 {
    padding: 10px;
    margin-bottom: 10px;
}
.col-3 h3 {
    color: #fff5de;
    font-size: 20px;
    font-family: Lexend;
    margin-bottom: 15px;
    text-decoration: none;
}

.col-3 a {
    text-decoration: none;
    transition: color 1.2s;

}

.col-3 ul {
    list-style: none;
}
.col-3 ul li {
    margin-bottom: 10px;
}
.col-3 ul li a {
    color: #fff5de;
    text-decoration: none;
    text-shadow: 0px 0px 30px #000000;
}


  @media (min-width: 80em) {
    .columns-header {
      grid-auto-flow: column;
      padding: 5rem auto;
      transition: smooth;
     }
  }
  
  @media (max-width: 80em) {
    #hero {
      grid-auto-flow: row;
      transition: smooth;
    }
    .main-image {
        margin-left: 2rem;
        transition: smooth;
        margin-bottom: -2rem;
    }
    .main-title h1{
        margin-left: 2rem;
    }
  }

  @media (max-width: 80em) {
    .main-title h1{
        margin-top: -9rem;
        transition: smooth;
    }

}

@media only screen and (max-device-width: 1366px) {
    .parallax {
      background-attachment: scroll;
    }
  }

/* Unified style for all title items */
.titleitem, .titleitem2, .titleitem3, .titleitem4 {
    width: 20em;
    margin-right: 0;
    display: flex;
    align-items: center;
}

/* Consistent styling for weeklast items */
.weeklast {
    width: 10em;
    display: flex;
    align-items: center;
}
