/*
Theme Name: Catchy Labs Theme Child
Theme URI: https://catchylabs.com/
Description: Child theme for the Catchy Labs Elementor Theme WordPress theme.
Author: Bobby Danklefsen
Author URI: https://catchylabs.com/
Template: catchylabs-theme
Version: 1.0.1
Text Domain: cl-elementor
*/

:root {
   --clet-primary: #EC1C24;
	--clet-text: #333333;
}

.mxw-none img {
	max-width:none !important;
}

@media (min-width:1024px) {
	.img-fr img {
		float:right;	
	}
	
	.img-fl img {
		float:left;	
	}
}


/* Put all custom styles here
   ========================================================================== */

body,
.cl-simple-modal .content p {
    font-family: 'Futura LT' !important;
    font-weight: 400;
}

b,
strong {
    font-family: 'Futura Md BT' !important;
    font-weight: bold;
}

/**
* Correct the font size and margin on `h1` elements within `section` and
* `article` contexts in Chrome, Firefox, and Safari.
*/

h1, h2, h3, h4, h5, h6 {
    font-family: 'Futura LT' !important;
    font-weight: 500 ;
}

h1 strong, h2 strong, h3 strong, h4 strong, h5 strong, h6 strong, .bold-heading {
    font-family: 'Futura Md BT' !important;
}

.nav-menu .navbar .menu a {
   font-family: 'Futura Std2' !important;
}

/* WP Forms styles
   ========================================================================== */

body .wpforms-container .wpforms-field, 
body .wp-core-ui div.wpforms-container .wpforms-field {
   padding:0 0 10px;
}

body div.wpforms-container-full .wpforms-form label.wpforms-error, 
body div.wpforms-container-full .wpforms-form em.wpforms-error {
   color:white;
}

body div.wpforms-container-full .wpforms-form label.wpforms-error:before, 
body div.wpforms-container-full .wpforms-form em.wpforms-error:before {
   background-color:white;
}

body div.wpforms-container-full input[type="text"], 
body div.wpforms-container-full input[type="date"], 
body div.wpforms-container-full input[type="email"], 
body div.wpforms-container-full input[type="number"], 
body div.wpforms-container-full input[type="password"], 
body div.wpforms-container-full input[type="search"], 
body div.wpforms-container-full input[type="tel"], 
body div.wpforms-container-full input[type="url"], 
body div.wpforms-container-full select, 
body div.wpforms-container-full select option, 
body div.wpforms-container-full textarea {
   width: 100%;
   border: none;
   border-radius: 3px;
   padding: 0.5rem 1rem;
   -webkit-transition: all .3s;
   -o-transition: all .3s;
   background-color:#F3F3F3;
   transition: all .3s;
}

body div.wpforms-container-full input[type="text"]::placeholder, 
body div.wpforms-container-full input[type="date"]::placeholder, 
body div.wpforms-container-full input[type="email"]::placeholder, 
body div.wpforms-container-full input[type="number"]::placeholder, 
body div.wpforms-container-full input[type="password"]::placeholder, 
body div.wpforms-container-full input[type="search"]::placeholder, 
body div.wpforms-container-full input[type="tel"]::placeholder, 
body div.wpforms-container-full input[type="url"]::placeholder, 
body div.wpforms-container-full select::placeholder, 
body div.wpforms-container-full textarea::placeholder {
   opacity:0.8;
}

body div.wpforms-container-full input[type=submit]:not(:hover):not(:active), 
body div.wpforms-container-full button[type=submit]:not(:hover):not(:active), 
body div.wpforms-container-full .wpforms-page-button:not(:hover):not(:active), 
body .wp-core-ui div.wpforms-container-full input[type=submit]:not(:hover):not(:active), 
body .wp-core-ui div.wpforms-container-full button[type=submit]:not(:hover):not(:active), 
body .wp-core-ui div.wpforms-container-full .wpforms-page-button:not(:hover):not(:active), 
body div.wpforms-container-full input[type=submit]:hover, 
body div.wpforms-container-full input[type=submit]:active, 
body div.wpforms-container-full button[type=submit]:hover, 
body div.wpforms-container-full button[type=submit]:active, 
body div.wpforms-container-full .wpforms-page-button:hover, 
body div.wpforms-container-full .wpforms-page-button:active, 
body .wp-core-ui div.wpforms-container-full input[type=submit]:hover, 
body .wp-core-ui div.wpforms-container-full input[type=submit]:active, 
body .wp-core-ui div.wpforms-container-full button[type=submit]:hover, 
body .wp-core-ui div.wpforms-container-full button[type=submit]:active, 
body .wp-core-ui div.wpforms-container-full .wpforms-page-button:hover, 
body .wp-core-ui div.wpforms-container-full .wpforms-page-button:active {
   background-color:var(--clet-primary, #333);
   text-transform:uppercase;
   letter-spacing:2px;
   padding:20px;
   height:auto;
   border:solid thin var(--clet-primary, #333);
   color:white;
   margin-top:10px;
}

body .wpforms-container .wpforms-field, 
body .wp-core-ui div.wpforms-container .wpforms-field {
   padding:10px 0;
}

body div.wpforms-container-full .wpforms-confirmation-container-full, 
body div[submit-success]>.wpforms-confirmation-container-full:not(.wpforms-redirection-message) { 
   border:solid thin var(--clet-primary, #333);
   background:white;
   padding:20px;
   text-align:center;
}

body div.wpforms-container-full .wpforms-confirmation-container-full, 
body div[submit-success]>.wpforms-confirmation-container-full:not(.wpforms-redirection-message) {
   color: var(--clet-text, #333);
}

/* Project Single Page Styles
   ========================================================================== */

.project-container {
   max-width: 1000px;
   margin: 0 auto;
   padding: 2rem;
}

.project-header {
   text-align: center;
   margin-bottom: 2rem;
}

.project-title {
   font-size: 2.5rem;
   font-weight: bold;
   color: var(--clet-text, #333);
   margin: 0;
   line-height: 1.2;
}

.project-meta {
   text-align: center;
   margin-bottom: 2.5rem;
   padding-bottom: 1.5rem;
   border-bottom: 2px solid #f0f0f0;
}

.project-categories,
.project-states {
   margin-bottom: 0.75rem;
   font-size: 1rem;
}

.meta-label {
   font-weight: bold;
   color: var(--clet-primary, #BF1D2C);
   margin-right: 0.5rem;
}

.project-content {
   margin-bottom: 3rem;
   font-size: 1.1rem;
   line-height: 1.7;
   color: var(--clet-text, #333);
}

/* Project Carousel Styles
   ========================================================================== */

.project-carousel {
   margin-top: 3rem;
}

.carousel-container {
   position: relative;
   background: #f8f8f8;
   border-radius: 8px;
   overflow: hidden;
   box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.carousel-track {
   position: relative;
   width: 100%;
   height: 500px;
}

.carousel-slide {
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   opacity: 0;
   transition: opacity 0.5s ease-in-out;
   display: flex;
   align-items: center;
   justify-content: center;
}

.carousel-slide.active {
   opacity: 1;
}

.carousel-image-link {
   display: flex;
   align-items: center;
   justify-content: center;
   width: 100%;
   height: 100%;
   cursor: pointer;
   transition: opacity 0.3s ease;
}

.carousel-image-link:hover {
   opacity: 0.9;
}

.carousel-image-link:focus {
   outline: 3px solid var(--clet-primary, #BF1D2C);
   outline-offset: 2px;
}

.carousel-slide img {
   max-width: 100%;
   max-height: 100%;
   object-fit: contain;
   border-radius: 4px;
   transition: transform 0.3s ease;
}

.carousel-image-link:hover img {
   transform: scale(1.02);
}

.carousel-caption {
   position: absolute;
   bottom: 0;
   left: 0;
   right: 0;
   background: rgba(0, 0, 0, 0.7);
   color: white;
   padding: 1rem;
   text-align: center;
   font-size: 0.9rem;
}

.carousel-btn {
   position: absolute;
   top: 50%;
   transform: translateY(-50%);
   background: rgba(255, 255, 255, 0.9);
   border: none;
   width: 50px;
   height: 50px;
   border-radius: 50%;
   cursor: pointer;
   display: flex;
   align-items: center;
   justify-content: center;
   transition: all 0.3s ease;
   z-index: 10;
   box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.carousel-btn:hover {
   background: white;
   transform: translateY(-50%) scale(1.1);
}

.carousel-btn:focus {
   outline: 2px solid var(--clet-primary, #BF1D2C);
   outline-offset: 2px;
}

.carousel-prev {
   left: 20px;
}

.carousel-next {
   right: 20px;
}

.carousel-btn svg {
   color: var(--clet-text, #333);
}

.carousel-indicators {
   position: absolute;
   bottom: 20px;
   left: 50%;
   transform: translateX(-50%);
   display: flex;
   gap: 10px;
   z-index: 10;
}

.carousel-indicator {
   width: 12px;
   padding:0;
   height: 12px;
   border-radius: 50%;
   border: 2px solid white;
   background: rgba(255, 255, 255, 0.5);
   cursor: pointer;
   transition: all 0.3s ease;
}

.carousel-indicator:hover,
.carousel-indicator.active {
   background: white;
   transform: scale(1.2);
}

.carousel-indicator:focus {
   outline: 2px solid var(--clet-primary, #BF1D2C);
   outline-offset: 2px;
}

/* Responsive Styles
   ========================================================================== */

@media (max-width: 768px) {
   .project-container {
      padding: 1rem;
   }
   
   .project-title {
      font-size: 2rem;
   }
   
   .carousel-track {
      height: 300px;
   }
   
   .carousel-btn {
      width: 40px;
      height: 40px;
   }
   
   .carousel-prev {
      left: 10px;
   }
   
   .carousel-next {
      right: 10px;
   }
   
   .carousel-indicators {
      bottom: 15px;
   }
   
   .carousel-indicator {
      width: 10px;
      height: 10px;
   }
}

@media (max-width: 480px) {
   .project-container {
      padding: 0.75rem;
   }
   
   .project-title {
      font-size: 1.75rem;
   }
   
   .carousel-track {
      height: 250px;
   }
   
   .carousel-caption {
      padding: 0.75rem;
      font-size: 0.8rem;
   }
}

/* Projects Grid Styles
   ========================================================================== */

.projects-grid-container {
   margin: 0 auto;
}

/* Filter Styles */
.projects-filters {
   margin-bottom: 2rem;
   text-align: center;
}

.filter-dropdowns {
   display: flex;
   justify-content: center;
   align-items: flex-end;
   gap: 2rem;
   flex-wrap: wrap;
}

.filter-group {
   display: flex;
   flex-direction: column;
   align-items: flex-start;
   min-width: 200px;
}

.filter-group label {
   font-weight: bold;
   color: var(--clet-text, #333);
   margin-bottom: 0.5rem;
   font-size: 0.9rem;
   display:none;
}

.filter-group select {
   width: 100%;
   padding: 0.75rem 1rem;
   border:none;
   border-bottom: 2px solid #e0e0e0;
   border-radius: 4px;
   background: white;
   font-size: 1rem;
   color: var(--clet-text, #333);
   cursor: pointer;
   transition: border-color 0.3s ease;
}

.filter-group select:focus {
   outline: none;
   border-color: var(--clet-primary, #BF1D2C);
}

.filter-submit {
   background: var(--clet-primary, #BF1D2C);
   color: white;
   border: none;
   padding: 0.75rem 1.5rem;
   border-radius: 4px;
   font-size: 1rem;
   font-weight: bold;
   cursor: pointer;
   transition: background-color 0.3s ease;
   min-height: 50px;
   /* display:none; */
}

.filter-submit:hover {
   background: #a01729;
}

/* Projects Grid */
.projects-grid {
   display: grid;
   grid-template-columns: repeat(3, 1fr);
   gap: 2rem;
   margin-bottom: 3rem;
}

.project-card {
   background: white;
   overflow: hidden;
   transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.project-card:hover {
   transform: translateY(-5px);
   box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
}

.project-card-link {
   display: block;
   text-decoration: none;
   color: inherit;
}

.project-card-link:hover {
   text-decoration: none;
}

.project-image-container {
   position: relative;
   width: 100%;
   padding-bottom: 70%; /* Creates a perfect square */
   overflow: hidden;
   background: #f8f8f8;
}

.project-thumbnail {
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   height: 100% !important;
   object-fit: cover;
   transition: transform 0.3s ease;
}

.project-card:hover .project-thumbnail {
   transform: scale(1.05);
}

.project-placeholder {
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   display: flex;
   align-items: center;
   justify-content: center;
   background: #f0f0f0;
   color: #999;
   font-size: 1.1rem;
}

.project-info {
   padding: 1.5rem;
   text-align: center;
   background-color: #444444;
}

.project-info h3 {
   color:white;
   margin: 0;
}

.project-info .project-title {
   font-size: 1.2rem;
   font-weight: normal;
   color: white;
   margin: 0;
   line-height: 1.3;
}

.projects-grid-container .project-meta {
   display: flex;
   gap: 0.75rem;
   flex-wrap: wrap;
}

.project-category,
.project-state {
   font-size: 0.85rem;
   padding: 0.25rem 0.75rem;
   border-radius: 20px;
   font-weight: 500;
}

.project-category {
   background: rgba(191, 29, 44, 0.1);
   color: var(--clet-primary, #BF1D2C);
}

.project-state {
   background: #f0f0f0;
   color: var(--clet-text, #333);
}

/* No Projects Found */
.no-projects-found {
   text-align: center;
   padding: 3rem;
   color: #666;
   font-size: 1.1rem;
}

.clear-filters-link {
   display: inline-block;
   margin-top: 1.5rem;
   padding: 0.75rem 1.5rem;
   background: var(--clet-primary, #EC1C24);
   color: white;
   text-decoration: none;
   border-radius: 4px;
   font-weight: 500;
   transition: background-color 0.3s ease, transform 0.2s ease;
   font-size: 1rem;
}

.clear-filters-link:hover {
   background: #c5161c;
   text-decoration: none;
   color: white;
   transform: translateY(-1px);
}

.clear-filters-link:focus {
   outline: 2px solid var(--clet-primary, #EC1C24);
   outline-offset: 2px;
}

/* Pagination Styles */
.projects-pagination {
   margin-top: 2rem;
   text-align: center;
}

.projects-pagination .page-numbers {
   display: inline-flex;
   list-style: none;
   margin: 0;
   padding: 0;
   gap: 0.5rem;
}

.projects-pagination .page-numbers li {
   margin: 0;
}

.projects-pagination .page-numbers a,
.projects-pagination .page-numbers span {
   display: block;
   padding: 0.75rem 1rem;
   border: 2px solid #e0e0e0;
   border-radius: 4px;
   text-decoration: none;
   color: var(--clet-text, #333);
   font-weight: 500;
   transition: all 0.3s ease;
}

.projects-pagination .page-numbers a:hover,
.projects-pagination .page-numbers .current {
   background: var(--clet-primary, #BF1D2C);
   color: white;
   border-color: var(--clet-primary, #BF1D2C);
}

/* Responsive Styles */
@media (max-width: 768px) {
   .projects-grid-container {
      padding: 1rem;
   }
   
   .filter-dropdowns {
      flex-direction: column;
      align-items: center;
      gap: 1rem;
   }
   
   .filter-group {
      width: 100%;
      max-width: 300px;
   }
   
   .projects-grid {
      grid-template-columns: repeat(2, 1fr);
      gap: 1rem;
   }
   
   .project-info {
      padding: 1rem;
   }
   
   .project-info .project-title {
      font-size: 1.1rem;
   }
}

@media (max-width: 480px) {
   .projects-grid {
      grid-template-columns: 1fr;
      gap: 1.5rem;
   }
   
   .filter-dropdowns {
      gap: 0.75rem;
   }
   
   .filter-submit {
      width: 100%;
      max-width: 300px;
   }
   
   .projects-pagination .page-numbers a,
   .projects-pagination .page-numbers span {
      padding: 0.5rem 0.75rem;
      font-size: 0.9rem;
   }
}

/* Project Modal Styles
   ========================================================================== */

.project-modal {
   position: fixed;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   background: rgba(0, 0, 0, 0.8);
   z-index: 9999;
   display: flex;
   align-items: center;
   justify-content: center;
   opacity: 0;
   visibility: hidden;
   transition: all 0.3s ease;
}

.project-modal.show {
   opacity: 1;
   visibility: visible;
}

.modal-overlay {
   width: 100%;
   height: 100%;
   display: flex;
   align-items: center;
   justify-content: center;
   padding: 2rem;
}

.modal-content {
   background: #4C4C4C;
   width: 80%;
   max-width: 1200px;
   max-height: 90vh;
   position: relative;
   overflow: hidden;
   transform: scale(0.8);
   transition: transform 0.3s ease;
   padding:0 50px;
}

.project-modal.show .modal-content {
   transform: scale(1);
}

.modal-close {
   position: absolute;
   top: 15px;
   right: 15px;
   background: none;
   border: none;
   color: white;
   font-size: 2rem;
   cursor: pointer;
   z-index: 10;
   width: 40px;
   height: 40px;
   display: flex;
   align-items: center;
   justify-content: center;
   border-radius: 50%;
   transition: background-color 0.3s ease;
}

.modal-close:hover {
   background: rgba(255, 255, 255, 0.2);
}

.modal-body {
   display: flex;
   min-height: 550px;
   padding-top:20px;
}

.modal-carousel {
   flex: 0 0 60%;
   position: relative;
}

.modal-carousel-container {
   position: relative;
   width: 100%;
   height: 100%;
}

.modal-carousel-track {
   position: relative;
   width: 100%;
   height: 90%;
}

.modal-carousel-slide {
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   opacity: 0;
   transition: opacity 0.5s ease-in-out;
   display: flex;
   align-items: center;
   justify-content: center;
}

.modal-carousel-slide.active {
   opacity: 1;
}

.modal-carousel-slide img {
   max-width: 100%;
   max-height: 100%;
   object-fit: contain;
   cursor: pointer;
}

.modal-carousel-btn {
   position: absolute;
   top: 44%;
   transform: translateY(-50%);
   background: rgba(255, 255, 255, 0.9);
   border: none;
   width: 50px;
   height: 50px;
   border-radius: 50%;
   cursor: pointer;
   display: flex;
   align-items: center;
   justify-content: center;
   transition: all 0.3s ease;
   z-index: 10;
}

.modal-carousel-btn:hover {
   background: white;
   transform: translateY(-50%) scale(1.1);
}

.modal-carousel-prev {
   left: 20px;
}

.modal-carousel-next {
   right: 20px;
}

.modal-carousel-btn svg {
   color: #333;
}

.modal-carousel-indicators {
   position: absolute;
   bottom: 20px;
   left: 50%;
   transform: translateX(-50%);
   display: flex;
   gap: 10px;
   z-index: 10;
}

.modal-carousel-indicator {
   width: 12px;
   height: 12px;
   border-radius: 50%;
   border: 2px solid white;
   background: rgba(255, 255, 255, 0.5);
   cursor: pointer;
   transition: all 0.3s ease;
   padding:0;
}

.modal-carousel-indicator:hover,
.modal-carousel-indicator.active {
   background: white;
   transform: scale(1.2);
}

.modal-info {
   flex: 1;
   display: flex;
   flex-direction: column;
   justify-content: flex-end;
   padding: 2rem 2rem 2rem 3rem;
   color: white;
}

.modal-info.full-width {
   flex: 1;
   justify-content: center;
   padding: 3rem;
   text-align: center;
}

.modal-info.full-width .modal-text-content {
   padding-bottom: 0;
   justify-content: center;
}

.modal-text-content {
   display: flex;
   flex-direction: column;
   justify-content: flex-end;
   height: 100%;
   padding-bottom:100px;
}

.modal-title {
   font-size: 2rem;
   font-weight: bold;
   margin: 0 0 1.5rem 0;
   color: white;
   line-height: 1.2;
}

.modal-content-text {
   font-size: 1.1rem;
   line-height: 1.6;
   color: white;
}

.modal-content-text p {
   margin-bottom: 1rem;
}

.modal-content-text p:last-child {
   margin-bottom: 0;
}

/* Modal Taxonomy Styles */
.modal-taxonomy-info {
   margin-bottom: 1.5rem;
}

.project-taxonomy-tags {
   display: flex;
   flex-wrap: wrap;
   gap: 0.75rem;
}

.taxonomy-tag {
   display: inline-block;
   padding: 0.5rem 1rem;
   border-radius: 25px;
   font-size: 0.9rem;
   font-weight: 500;
   text-transform: capitalize;
   transition: all 0.3s ease;
   border: 2px solid transparent;
}

.category-tag {
   background: rgba(236, 28, 36, 0.9);
   color: white;
   border-color: rgba(236, 28, 36, 0.3);
}

.category-tag:hover {
   background: rgba(236, 28, 36, 1);
   transform: translateY(-1px);
}

.state-tag {
   background: rgba(255, 255, 255, 0.9);
   color: #333;
   border-color: rgba(255, 255, 255, 0.3);
}

.state-tag:hover {
   background: rgba(255, 255, 255, 1);
   transform: translateY(-1px);
}

/* Hide modal on mobile - keep original link behavior */
@media (max-width: 768px) {
   .project-modal {
      display: none !important;
   }
}

/* Modal responsive adjustments for smaller desktops/tablets */
@media (min-width: 769px) and (max-width: 1024px) {
   .modal-content {
      width: 90%;
   }
   
   .modal-body {
      height: 60vh;
      min-height: 400px;
   }
   
   .modal-title {
      font-size: 1.5rem;
   }
   
   .modal-content-text {
      font-size: 1rem;
   }
   
   .modal-info {
      padding: 1.5rem;
   }
}

/* Loading Overlay Styles
   ========================================================================== */

.projects-loading-overlay {
   position: fixed;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   background: rgba(255, 255, 255, 0.95);
   z-index: 10000;
   display: flex;
   align-items: center;
   justify-content: center;
   opacity: 0;
   visibility: hidden;
   transition: all 0.3s ease;
}

.projects-loading-overlay.show {
   opacity: 1;
   visibility: visible;
}

.loading-spinner {
   display: flex;
   flex-direction: column;
   align-items: center;
   gap: 1rem;
}

.loading-spinner-icon {
   width: 60px;
   height: 60px;
   animation: spin 1s linear infinite;
}

.loading-spinner-icon svg {
   width: 100%;
   height: 100%;
   color: var(--clet-primary, #EC1C24);
}

.loading-text {
   font-size: 1.1rem;
   color: var(--clet-text, #333);
   font-weight: 500;
   text-align: center;
}

@keyframes spin {
   from {
      transform: rotate(0deg);
   }
   to {
      transform: rotate(360deg);
   }
}

/* Loading overlay responsive adjustments */
@media (max-width: 768px) {
   .loading-spinner-icon {
      width: 50px;
      height: 50px;
   }
   
   .loading-text {
      font-size: 1rem;
   }
}

@media (max-width: 480px) {
   .loading-spinner-icon {
      width: 40px;
      height: 40px;
   }
   
   .loading-text {
      font-size: 0.9rem;
   }
}

/* Projects Map Styles
   ========================================================================== */

.projects-map-container {
   margin: 0 auto;
   width: 100%;
}

.projects-map {
   width: 100%;
   height: 600px;
   overflow: hidden;
   box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
   background: #f8f8f8;
}

/* Map responsive heights */
@media (max-width: 1366px) {
   .projects-map {
      height: 450px;
   }
}

@media (max-width: 1024px) {
   .projects-map {
      height: 350px;
   }
}

@media (max-width: 768px) {
   .projects-map {
      height: 300px;
      border-radius: 4px;
   }
}

@media (max-width: 480px) {
   .projects-map {
      height: 300px;
   }
}
