
/*I Tried to Label everything so that its easier to find everything and be able to understand where everything is. Unlike the last guy that had this project. */

@font-face {
    font-family: Montserrat;
    src: url(../assets/MONTSERRAT-BLACK.ttf);
}

@font-face {
    font-family: Clarendon;
    src: url(../assets/Clarendon-Medium.ttf);
}

:root {
    --catbrown: #8e4b24;
    --catorange: #dd6b28;
    --catblue: #183969;
	--headerbrown: #a85424;
    --catdarkblue: #0c1b33; 
    --catlightdarkblue: #132d54;

	background-color: #eee;
    overflow-x: hidden;
    scroll-behavior: smooth;
}

body {
    margin: 0;
    padding: 0;
}

/* Header */

a {
    text-decoration: none;
    display: flex;
    align-items: center;
}

header {
	background-image: linear-gradient(var(--catblue), var(--catdarkblue));
	display: flex;
	justify-content: space-between;
	align-items: center;
	z-index: 1;
	position: relative;
}

header .btn {
    width: 240px;
    font-size: 27px;
}

.logo {
    height: calc(1.8em + 15px);
    margin: 10px 0.7vw 10px 1.5vw;

    transition: filter 0.3s;
}

header h1 {
    font-family: Montserrat;
    color: var(--catorange);
    font-size: 1.8em;
    margin: 0 1.5vw 0 1.5vw;

    /* margin: auto; */

    transition: 0.3s;
}

.logobox:hover img {
    filter: brightness(70%);
}

.logobox:hover h1 {
    color: #122a4f;
}  

/* Found a fancy button tutorial, here is the css */
/* Its the button that like glows when you hover over it*/
/*"fancy button" SMH*/
.btn {
    position: relative;
    width: 12vw;
    height: 42px;
    margin: 0 3vw 0 0;
    border-radius: 30px;
    display: flex;
    justify-content: center;
    align-items: center;
}
.btn a {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    background: rgba(255, 255, 255, 0.05);
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.3);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 30px;
    letter-spacing: 1px;
    text-decoration: none;
    overflow: hidden;
    color: var(--headerbrown);
    font-family: Montserrat;
    font-weight: bold;
    z-index: 1;
    transition: 0.5s;
    backdrop-filter: blur(15px);
}
/*Letter hover change*/
/*Become a Sponser and Donate to the Catalyst*/
.btn:hover a {
    letter-spacing: 3px;
    color: var(--catorange)
}
.btn a::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 50%;
    height: 100%;
    background: linear-gradient(to left, rgba(255, 255, 255, 0.08), transparent);
    transform: skewX(45deg) translate(0);
    transition: 0.5s;
    filter: blur(0px);
}
.btn:hover a::before {
    transform: skewX(45deg) translate(200px);
}
.btn::before {
    content: "";
    position: absolute;
    left: 50%;
    transform: translatex(-50%);
    bottom: -5px;
    width: 30px;
    height: 30px;
    background: var(--catblue);
    border-radius: 10px;
    transition: 0.5s;
}
.btn:hover::before /*lightup button*/ {
    bottom: 0;
    height: 50%;
    width: 80%;
    border-radius: 30px;
}

.btn::after {
    content: "";
    position: absolute;
    left: 50%;
    transform: translatex(-50%);
    top: -5px;
    width: 30px;
    height: 30px;
    background: var(--catblue);
    border-radius: 10px;
    transition: 0.5s;
}
.btn:hover::after /*lightup button*/ {
    top: 0;
    height: 50%;
    width: 80%;
    border-radius: 30px;
}
/* .btn::before,
.btn::after {
    background: var(--catblue);
    box-shadow: 0 0 5px var(--catblue), 0 0 15px var(--catblue), 0 0 30px var(--catblue),
        0 0 60px var(--catblue);
} */

.btn:hover::before,
.btn:hover::after {
    background: var(--catdarkblue);
    box-shadow: 0 0 5px var(--catdarkblue), 0 0 15px var(--catdarkblue), 0 0 30px var(--catdarkblue),
        0 0 60px var(--catdarkblue);
}

/* Main */

main {
    --skewAngle: 8deg;
    --height: calc(tan(var(--skewAngle)) * 50vw);
    --heroUp: calc(var(--height) * -1);
}
v  
/* Hero */

.hero {
    height: 90vh;

    position: relative;
    top: 0;
    overflow: hidden;
    z-index: 0;

    margin-bottom: 2vh;
    
    transform: skewY(var(--skewAngle)) translateY(var(--heroUp));
}

.hero::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;

    background-size: cover;
    background-repeat: repeat;
    z-index: -1;
    background-image: url(../unused-assets/crowd2.jpg);
    background-position: 50% 60%;
    
    filter: brightness(86%);

    transform: skewY(calc(var(--skewAngle) * -1)) translateY(calc(var(--heroUp) * -1));
}

.hero div {
    transform: skewY(calc(var(--skewAngle) * -1)) translateY(calc(var(--heroUp) * -1));
}

h2 {
    color: var(--catblue);
    margin: 0 auto;
    width: fit-content;
    font-size: 5em;
    font-family: Athiti;
    transform: rotate(var(--skewAngle));
}

h3 {
    color: #222;
	color: var(--catorange);
	font-family: Montserrat;
	font-weight: 700;
	font-size: 3.0em;

    margin: 0 3vw 5vh 3vw;
	width: fit-content;
}
h6 {
    color: var(--catlightdarkblue);
    font-family: Montserrat;
    font-size: 1.4em;
    margin: 5px 5px 0 14%;
    width: fit-content;
}
/* Description */

.description h3 {
    transform: translateY(var(--heroUp));

    margin-bottom: calc(5vh + 4px);
}

.description p {
	color: #333;
	font-family: Athiti;
	font-weight: 600;
	font-size: 1.5em;

	transform: translateY(var(--heroUp));
	margin: 0 5vw;
	max-width: 55vw;
}

/* Another funny button */
/*Its the Tickets Button since it wasnt labeled before*/

.type--A {
    --line_color: #333;
    --back_color: transparent;

    font-family: Athiti;
   
}

.button {
    position : relative;
    z-index : 0;
    text-decoration : none;
    font-weight : bold;
    color : var(--line_color);
    letter-spacing : 2px;
    transition : all .3s ease;
}

.button__text {
    display : flex;
    justify-content : center;
    align-items : center;
    width : 100%;
    height : 100%;
}

.button::before, .button::after, .button__text::before, .button__text::after {
    content : '';
    position : absolute;
    height : 3px;
    border-radius : 2px;
    background : var(--line_color);
    transition : all .5s ease;
}

.button::before {
    top : 0;
    left : 54px;
    width : calc( 100% - 56px * 2 - 16px );
}

.button::after {
    top : 0;
    right : 54px;
    width : 8px;
}

.button__text::before {
    bottom : 0;
    right : 54px;
    width : calc( 100% - 56px * 2 - 16px );
}

.button__text::after {
    bottom : 0;
    left : 54px;
    width : 8px;
}

.button__line {
    position : absolute;
    top : 0;
    width : 56px;
    height : 100%;
    overflow : hidden;
}

.button__line::before {
    content : '';
    position : absolute;
    top : 0;
    width : 150%;
    height : 100%;
    box-sizing : border-box;
    border-radius : 300px;
    border : solid 3px var(--line_color);
}

.button__line:nth-child(1),
.button__line:nth-child(1)::before {
    left : 0;
}

.button__line:nth-child(2),
.button__line:nth-child(2)::before {
    right : 0;
}

.button:hover {
    letter-spacing : 4px;
}

.button:hover::before,
.button:hover .button__text::before {
    width : 8px;
}

.button:hover::after,
.button:hover .button__text::after {
    width : calc( 100% - 56px * 2 - 16px );
}

.button__drow1,
.button__drow2 {
    position : absolute;
    z-index : -1;
    border-radius : 16px;
    transform-origin : 16px 16px;
}

.button__drow1 {
    top : -16px;
    left : 40px;
    width : 32px;
    height : 0;
    transform : rotate( 30deg );
}

.button__drow2 {
    top : 44px;
    left : 77px;
    width : 32px;
    height : 0;
    transform : rotate(-127deg );
}

.button__drow1::before,
.button__drow1::after,
.button__drow2::before,
.button__drow2::after {
    content : '';
    position : absolute;
}

.button__drow1::before {
    bottom : 0;
    left : 0;
    width : 0;
    height : 32px;
    border-radius : 16px;
    transform-origin : 16px 16px;
    transform : rotate( -60deg );
}

.button__drow1::after {
    top : -10px;
    left : 45px;
    width : 0;
    height : 32px;
    border-radius : 16px;
    transform-origin : 16px 16px;
    transform : rotate( 69deg );
}

.button__drow2::before {
    bottom : 0;
    left : 0;
    width : 0;
    height : 32px;
    border-radius : 16px;
    transform-origin : 16px 16px;
    transform : rotate( -146deg );
}

.button__drow2::after {
    bottom : 26px;
    left : -40px;
    width : 0;
    height : 32px;
    border-radius : 16px;
    transform-origin : 16px 16px;
    transform : rotate( -262deg );
}

.button__drow1,
.button__drow1::before,
.button__drow1::after,
.button__drow2,
.button__drow2::before,
.button__drow2::after {
    background : var( --back_color );
}

.button:hover .button__drow1 {
    animation : drow1 ease-in .06s;
    animation-fill-mode : forwards;
}

.button:hover .button__drow1::before {
    animation : drow2 linear .08s .06s;
    animation-fill-mode : forwards;
}

.button:hover .button__drow1::after {
    animation : drow3 linear .03s .14s;
    animation-fill-mode : forwards;
}

.button:hover .button__drow2 {
    animation : drow4 linear .06s .2s;
    animation-fill-mode : forwards;
}

.button:hover .button__drow2::before {
    animation : drow3 linear .03s .26s;
    animation-fill-mode : forwards;
}

.button:hover .button__drow2::after {
    animation : drow5 linear .06s .32s;
    animation-fill-mode : forwards;
}

@keyframes drow1 {
    0%   { height : 0; }
    100% { height : 100px; }
}

@keyframes drow2 {
    0%   { width : 0; opacity : 0;}
    10%  { opacity : 0;}
    11%  { opacity : 1;}
    100% { width : 120px; }
}

@keyframes drow3 {
    0%   { width : 0; }
    100% { width : 80px; }
}

@keyframes drow4 {
    0%   { height : 0; }
    100% { height : 120px; }
}

@keyframes drow5 {
    0%   { width : 0; }
    100% { width : 124px; }
}
/*Reason that the ticket buttons align to the bottom of the cards*/
.button-position {
    margin-top: auto;
    padding-bottom: 1em;
}

/* Schedule */
/* DO NOT REMOVE IT WILL NUKE ITSELF*/

.schedule {
    width: calc(100vw - 6vw);
    margin: 0 0 13vh 3vw;
}

.cardrow {
    width: fit-content;
    --cardrowBottomMargin: 6.5vw;
    margin: 0 6.5vw;
    display: flex;
    overflow: hidden;
}

.card {
    --foldSize: 40px;
    
    min-height: 100%;
    width: 360px;
    min-width: 360px;
    background-image: linear-gradient(var(--catorange), var(--headerbrown));
    margin-right: 80px;
    border: none;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: relative;

    transition: transform 0.5s;
    
}
.main-part {
   display: flex; 
   flex-direction: column;
    flex-grow: 1;
 
}


.outdoor {
    --outdoorYellow1: #dd6b28;
    --outdoorYellow2: #a85424;

    background-image: none;
    background-color: transparent;
    height: auto;
}

.card::before {
    content: '';
    position: absolute;
    top: 0; right: 0;
    border-top: var(--foldSize) solid #eee;
    width: 0;


    --foldColor: transparent;
    border-left: var(--foldSize) solid var(--foldColor);
}

.card::after {
    content: '';
    position: absolute;
    bottom: 0; right: 0;
    border-top: var(--foldSize) solid #eee;
    width: 0;

    transform: rotate(90deg);


    --foldColor: transparent;
    border-left: var(--foldSize) solid var(--foldColor);
}

.outdoor::after {
    display: none;
}

.outdoor::before {
    display: none;
}
/*fold/dog ear coloring/sizing stuff*/
.outdoor .main-part::before {
    content: '';
    position: absolute;
    top: 0; right: 0;
    border-top: var(--foldSize) solid #ffffff;
    width: 0;

    --foldColor: transparent;
    border-left: var(--foldSize) solid var(--foldColor);
}
/*The reason that the cards are in a row instead of a colum*/
.schedule-flex{
    display: flex;
  }

/*The Ombre Stuff for the coming up areas*/

.outdoor .details {
    width: 100%;
    display: flex;
    flex-direction: column;

    border-top: 1px solid #9c4d1f;

    background-image: linear-gradient(#a85424, #ec6e22);
}

.outdoor .details .droparrow {
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: space-between;

    cursor: pointer;
}

.outdoor .details .content {
    display: none;

    transition: 0.8s;
}

.showdetails .content {
    display: block !important;
}

.showdetails .droparrow img {
    transform: rotate(90deg);
}

.add-to-cardrow {
    margin-bottom: 160px;
}

.details li {
    color: #333;
    font-family: Athiti;
    font-size: 20px;
}

.outdoor .details h5 {
    margin: 0 0 0 11px;

    display: inline;
}

.outdoor .details img {
    filter: invert(15%) sepia(0%) saturate(1%) hue-rotate(316deg) brightness(100%) contrast(85%);
    height: 30px;
    
    margin: 0 17px 0 5px;

    transition: 0.4s;
}

.outdoor .main-part {
    background-image: linear-gradient(var(--outdoorYellow1), var(--outdoorYellow2));

    min-height: 225px;
}

.schedule a {
    text-decoration: none;
    color: #333;
}

.schedule h3 {
    margin-left: 0;
}

.schedule h4 {
    color: #333;
    font-family: Athiti;
    font-size: 3em;
    margin: 5px 5px 0 10%;
    width: fit-content;
}

.schedule h5 {
    color: #333;
    font-family: Athiti;
    font-size: 2em;
    margin: 5px 5px 0 14%;
    width: fit-content;
}

.button {    
    color: #333;
    font-family: Athiti;
    font-size: 1.5em;
    margin: 20px auto;
    border-radius: 100px;

    width: 210px;
    height: 47px;
}

.top a {
    color: inherit;
    text-decoration: underline;
}

.arrows {
    --arrowMargin: 8vw;
    width: calc(100vw - var(--arrowMargin));
    margin: 40px var(--arrowMargin) 20px 0;
    
    display: flex;
    justify-content: flex-end;
}

.arrow {
    width: 30px;

    cursor: pointer;

    transition: filter 0.3s;
}

.arrow:first-of-type {
    transform: scaleX(-1);
    margin-right: 25px;

    filter: invert(69%) sepia(25%) saturate(0%) hue-rotate(212deg) brightness(84%) contrast(93%);
    cursor: default;
}
/* This is the Scroll buttons css*/
.left {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}

.right {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
}

.scroll-images {
    position: relative;
    width: 100%;
    padding: 40px 0px;
    height: auto;
    display: flex;
    flex-wrap: nowrap;
    overflow-x: hidden;
    overflow-y: hidden;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
}



.child img, .child > svg {
    position: absolute;
    margin-top: -195px;
    width: 80px;
    height: 80px;
    object-fit: cover;
    object-position: center;
    border-radius: 50%;
    background: #03A9F4;
}

.scroll-images::-webkit-scrollbar {
    width: 5px;
    height: 8px;
    background-color: #aaa;
}

.scroll-images::-webkit-scrollbar-thumb {
    background-color: pink;
}

button {
    background-color: transparent;
    border: none;
    outline: none;
    cursor: pointer;
    font-size: 25px;
}

/* Sponsors */

.sponsors {
    width: 100%;
    background-image: linear-gradient(var(--catblue), var(--catlightdarkblue));
    text-align: center;
    margin-bottom: 7vh;

    overflow: auto;
}

.sponsors h4 {
    color: #B1B9C4;
    font-family: Montserrat;
    font-size: 2.5em;
    margin: 2.4vh 0;
}

.sponsors .buttons {
    display: flex;
    width: fit-content;
    margin: auto;
    flex-wrap: wrap;
}

.sponsors .btn {
    min-width: 420px;
    width: fit-content;
    margin: 0 4vw 3vh;
    display: inline-block;

    height: 47px;
}

.sponsors .btn a {
    font-size: 28px;
}

/* FAQ */
.faq h3 .mobile {
    display: none;
}
.faq {
    margin-bottom: 7vh;
    font-family: Montserrat;
}

.dropdowns {
    display: flex;
    flex-direction: column;
}

.dropdown-container {
    display: none;
    position: absolute;
    background-color: white;
    box-shadow: 0px 5px 10px rgba(0,0,0,0.1);
    width: 100%;
    z-index: 1;
    left: 0;
    padding-top: 150px;
}

.dropdown {
    margin-bottom: 5vh;
}
  
.dropdown-btn {
    padding: 15px;
    background-image: linear-gradient(var(--catblue), var(--catdarkblue));
    border: none;
    cursor: pointer;
    position: relative;
    text-align: center;
    font-size: 1.65em;
    margin: auto;
    width: 40vw;
    color: var(--headerbrown);
    font-weight: bold;
    font-family: Athiti;
    border-radius: 20px;

    display: flex;
    justify-content: right;
    align-items: center;
    text-align: center;


    transition: 0.3s;
}

.dropdown-btn img {
    height: 40px;

    margin: 5px 10px;

    filter: invert(15%) sepia(0%) saturate(1%) hue-rotate(316deg) brightness(100%) contrast(85%);
    transition: 0.45s;
}

.dropdown-btn:hover img {
    rotate: 15deg;
}

.button-changes img {
    rotate: 90deg;
}

.button-changes:hover img {
    rotate: 75deg;
}

.dropdown-btn h4 {
    color: #B1B9C4; 
    margin: 0;
    width: 100%;
}
  
.dropdown-container p {
    padding-left: 300px;
    color: var(--headerbrown);
    text-align: center;
}
  
.dropdown-btn:hover {
    background-color: var(--brown);
}

.button-changes {
    border-radius: 26px 26px 10px 10px;
}

.hide {
    display: none;
}

.dropdown-content p {
    font-family: Athiti;
    margin: auto;
    text-align: center;
    max-width: 30vw;
    font-size: 1.5em;

    margin-top: 20px;
}

/* Donate */

.donate {
    /* background-image: linear-gradient(var(--catorange), var(--headerbrown)); */
    text-align: center;

    margin-bottom: 13vh;
    margin-top: 15vh;
}

.donate hr {
    width: 55vw;
    color: #222;
    margin: 0 auto;
}

.donate .btn {
    width: 460px;
    height: 47px;

    margin: 35px auto;
}

.donate .btn a {
    font-size: 28px;
    font-family: Montserrat;
}

/* Footer */

footer {
	background-image: linear-gradient(var(--catorange), var(--headerbrown));
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;

	color: var(--catblue);
	font-family: Athiti;
	font-size: 22.4px;
	font-weight: 400;
}

footer p {
	margin: 0;
	padding: 1vh 1vw;

	color: #eee;
}

.socials {
	margin: 0 1.3vw;

	display: flex;
	justify-content: space-between;
}

footer a {
	--socialHeight: 32px;
	
	height: var(--socialHeight);
	margin: calc(var(--socialHeight) / 3);
}

footer a img {
	height: var(--socialHeight);
}


  .cover {
    position: relative;
    padding: 0px 30px;
    margin-top: 100px;
}

/* The grid: Four equal columns that floats next to each other */
.column {
    float: left;
    width: 16%;
    padding: 10px;
  }
  .row {
     margin-left: 150px;
  }
  
  /* Style the images inside the grid */
  .column img {
    height: 150px;
    width: 150px;
    opacity: 0.8;
    cursor: pointer;
  }
  
  .column img:hover {
    opacity: 1;
  }
  
  /* Clear floats after the columns */
  .row:after {
    content: "";
    display: table;
    clear: both;
  }
  
  /* The expanding image container (positioning is needed to position the close button and the text) */
  .container {
    position: relative;
    display: none;
  }
  
  /* Expanding image text */
  #imgtext {
    position: absolute;
    bottom: 15px;
    left: 15px;
    color: white;
    font-size: 20px;
  }
  
  /* Closable button inside the image */
  .closebtn {
    position: absolute;
    top: 10px;
    right: 15px;
    color: var(--catlightdarkblue);
    font-size: 35px;
    cursor: pointer;
  }