/* 
Theme Name: Oechsli
Theme URI: https://wordpress.org
Description: Oechsli is a hybrid theme with block and elementor support.
Author: Oechsli
Author URI: https://wordpress.com/
Version: 2025.04.28
Text Domain: oechsli
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/


ul li::marker {
    color: var(--wp--preset--color--palette-2);
}

/*temp fix for pdf embeds*/
object.wp-block-file__embed {
    display: none;
}


p sup {
    font-size: small;
}

/* Add your breakpoint value here */
@media screen and (max-width: 768px) {

    /* Show the nested image */
    .wp-block-cover video img {
        display: block;
            height: auto;
    width: 100%;
    }
}

/* The Modal (background) */
.modal {
  display: none; /* Hidden by default */
  position: fixed; /* Stay in place */
  z-index: 9999; /* Sit on top */
  left: 0;
  top: 0;
  width: 100%; /* Full width */
  height: 100%; /* Full height */

  background-color: rgb(0,0,0); /* Fallback color */
  background-color: rgba(0,0,0,0.4); /* Black w/ opacity */
    justify-content: center;
    align-items: center;
    margin-left:0;
    margin-right:0;

}



/* Modal Content/Box */

.modal-content {
  position: relative;
  margin: auto;
  padding: 0;
  width: 100%;
    overflow: auto; /* Enable scroll if needed */

 /* animation-name: animatetop;
  animation-duration: 0.4s*/
}

/* Modal Header */
.modal-header {
  padding: 2px 16px;
}

/* Modal Body */
.modal-body {padding: 2px 16px;}

/* Modal Footer */
.modal-footer {
  padding: 2px 16px;
}





.modal.show-modal, .modal.auto-load {
    display: flex; /* Show the modal */
}




/* Add Animation */
@keyframes animatetop {
  from {top: -300px; opacity: 0}
  to {top: 0; opacity: 1}
}


/* The Close Button */
.close {
  color: #aaa;
  float: right;
  font-size: 28px;
  font-weight: bold;
}

.close:hover,
.close:focus {
  color: black;
  text-decoration: none;
  cursor: pointer;
}



/*oi-accordion block*/
.oi-accordion .accordion-item {}
.oi-accordion .wp-block-details summary {  display: flex;align-items: center;padding-left:10px; }
.oi-accordion .wp-block-details summary:marker { content:'';display:none;list-style-type:none; }
.oi-accordion .wp-block-details summary:before { content:'›';display: inline-block;font-size:35px;font-weight:bold;margin-right:5px;color:var(--wp--preset--color--palette-2); }
.oi-accordion .wp-block-details[open] summary:before  { transform: rotate(90deg);  }




/*oi accordion alt*/
.accordion {
    list-style: none;
}

.accordion-item {
    cursor: pointer;
}

.accordion-thumb {
    margin: 0;
    display: flex;
    align-items: center;
}

.accordion-panel {
    margin: 0;
    padding-bottom: .8rem;
    display: none;
}

.accordion-thumb img { width:15px;height:15px; }

.accordion-item.is-active .accordion-thumb img {
    transform: rotate(90deg);
    transition: transform .2s ease-out;
}

.accordion-item img {
    transition: transform .2s ease-out;
}

/*oi-tabs*/

/* Hide all tab content by default */
.tab-item {
    display: none;
}

/* Show the tab content when its corresponding tab button is active */
.tab-item.active {
    display: block;
}

.tabs .tab:hover { cursor:pointer; }

/*oi-slider*/


.oi-slider { overflow:visible; }

.swiffy-slider.slider-nav-outside-expand { overflow:visible; }

.slider-nav::before, .slider-nav::after { display:none; }

#oi-slider .slider-nav { 
    position: inherit; 
    top: none; 
    left: none; 
    bottom: none; 
    border: none; 
    background-color: inherit; 
    cursor: pointer; 
    padding: inherit; 
    visibility: inherit; 
    opacity: 1; 
    transition: inherit; 
    margin-bottom: inherit; 
    display: flex; 
    align-items: center;
    -webkit-filter: inherit; 
    filter: inherit; 
    transform: inherit;
}

.nav-btn figure.wp-block-image { display:flex;align-items:center;justify-content:center; }


/*flipbox*/

[class^="flipbox-"] img, [class*=" flipbox-"] img {
    display: block;
    width: 100%;
}


.flipbox-container {
    display: grid !important;
    width: 100%; /* Adjust as needed */
    position: relative;
    perspective: 1000px; /* Adjust for depth effect */
    overflow: hidden;
}

.flipbox-front, .flipbox-back {
    grid-area: 1 / 1 / 2 / 2; /* Place both elements in the same grid cell */
    width: 100%;
    height: 100%; /* Ensure full container height */
    backface-visibility: hidden; /* Hide the back face of the element */
    transition: transform 0.6s ease-in-out; /* Smooth transition */
}

.flipbox-container:not(.flip):not(.flip-vertical):not(.slide):not(.slide-right) .flipbox-front { z-index:1; }

.flipbox-container:not(.flip):not(.flip-vertical):not(.slide):not(.slide-right) .flipbox-back { z-index: 0;backface-visibility: hidden;}

.flipbox-container:not(.flip):not(.flip-vertical):not(.slide):not(.slide-right):hover .flipbox-front { z-index:0; }

.flipbox-container:not(.flip):not(.flip-vertical):not(.slide):not(.slide-right):hover .flipbox-back { z-index:1; backface-visibility:visible;}


 @media only screen and (max-width: 768px) {
.flipbox-container.clicked .flipbox-front { transform: rotateY(180deg); }
.flipbox-container.clicked .flipbox-back { transform: rotateY(0deg);}
}


.flipbox-container.flip { overflow:inherit; }

.flipbox-container:not(.clicked) .flipbox-back {transform: rotateY(-180deg);}


@media only screen and (min-width: 768px) {
/* On hover, apply flip effect */
.flipbox-container.flip .flipbox-front {
    z-index: 1; /* Front group on top initially */
    transform: rotateY(0deg); /* Front side initially visible */

}


.flipbox-container.flip .flipbox-back {
    z-index: 0; /* Back group behind the front group initially */
    transform: rotateY(180deg); /* Back side initially hidden */
}



.flipbox-container.flip { overflow:inherit; }

.flipbox-container.flip:hover .flipbox-front {
    transform: rotateY(-180deg); /* Rotate front group to the back */
}

.flipbox-container.flip:hover .flipbox-back {
    transform: rotateY(0deg); /* Rotate back group to the front */
}


}/*media*/


/* Style for the slide effect */
.flipbox-container.slide .flipbox-back {
    transform: translateY(100%); /* Start below the front group */
    z-index: 2; /* Ensure it slides over the front group */
}

/* On hover, slide the back group up */
.flipbox-container.slide:hover .flipbox-back {
    transform: translateY(0); /* Slide up to cover the front group */
}



/* On hover, apply vertical flip effect */
.flipbox-container.flip-vertical .flipbox-front {
    z-index: 1; /* Front group on top initially */
    transform: rotateY(0deg); /* Front side initially visible */

}


.flipbox-container.flip-vertical .flipbox-back {
    z-index: 0; /* Back group behind the front group initially */
    transform: rotateY(180deg); /* Back side initially hidden */
}

.flipbox-container.flip-vertical { overflow:inherit; }

.flipbox-container.flip-vertical:hover .flipbox-front {
    transform: rotateX(180deg); /* Rotate front group vertically to the back */
}

.flipbox-container.flip-vertical:hover .flipbox-back {
    transform: rotateX(360deg); /* Rotate back group vertically to the front */
}

/* Style for the back group in vertical flip */
.flipbox-container.flip-vertical .flipbox-back {
    transform: rotateX(180deg); /* Set initial vertical rotation for the back group */
}


/* Style for the slide right effect */
.flipbox-container.slide-right .flipbox-back {
    transform: translateX(-100%); /* Start left of the front group */
    z-index: 2; /* Ensure it slides over the front group */
    transition: transform 0.6s ease-in-out; /* Smooth transition for slide */
}

/* On hover, slide the back group right */
.flipbox-container.slide-right:hover .flipbox-back {
    transform: translateX(0); /* Slide right to cover the front group */
}

/* Ensuring the front group stays in place */
.flipbox-container.slide-right .flipbox-front {
    position: relative;
    z-index: 1; /* Keep the front group below the sliding back group */
}



/* Initial style for the back group with fade effect */
.flipbox-container.fader .flipbox-back {
    opacity: 0; /* Start as invisible */
    transition: opacity 1s ease-in-out; /* Smooth transition for fade-in and fade-out */
    z-index: 2; /* Ensure it's above the front group */
    pointer-events: none; /* Prevent interference with hover state */
}

/* On hover, fade the back group in */
.flipbox-container.fader:hover .flipbox-back {
    opacity: 1; /* Fade in to become visible */
    pointer-events: auto; /* Allow interaction when visible */
}

/* Ensuring the front group stays in place */
.flipbox-container.fader .flipbox-front {
    position: relative;
    z-index: 1; /* Keep the front group below the fading back group */
    transition: opacity 1s ease-in-out; /* Add a matching fade for the front */
}

/* On hover, optionally fade out the front group */
.flipbox-container.fader:hover .flipbox-front {
    opacity: 0.5; /* Slight fade-out effect for the front */
}





.oi-block-gallery .oi-gallery-block-image {
    overflow: hidden; /* Optional, for controlling the image view in the block */
}

.oi-block-gallery .oi-gallery-block-image img {
    width: 100%; /* Makes image take full width of the block */
    height: auto; /* Keeps aspect ratio of the image */
    transition: transform 0.3s ease; /* Optional, for a zoom effect on hover */
}

.oi-block-gallery .oi-gallery-block-image:hover img {
    transform: scale(1.1); /* Optional, zoom effect on hover */
}


.oi-gallery-block-image { margin:0; }

/*//slider*/
.swiffy-slider { overflow:hidden; }

.slider-container.wp-block-post-template { grid-template-columns: inherit !important;  }


.swiffy-slider .wp-block-buttons>.wp-block-button { display:flex; }


.slider-nav-visible .slider-nav { z-index:99; }

.wp-block-buttons.slider-indicators { position:relative;left:0;right:0; }



.oi-block-gallery.slider  {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
}

.oi-block-gallery.slider .wp-block-image {
    flex: 0 0 25%; /* Each image takes up 25% of the width */
    scroll-snap-align: start;
    overflow: hidden;
}

/* Styling for navigation arrows */
.oi-block-gallery .slider-arrow {
    position: absolute;
    top: 50%;
    z-index: 10;
    background-color: #fff; /* Example styling */
    border-radius: 50%;
    width: 30px; /* Adjust size as needed */
    height: 30px; /* Adjust size as needed */
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transform: translateY(-50%);
}

.oi-block-gallery .slider-arrow.left {
    left: 10px;
}

.oi-block-gallery .slider-arrow.right {
    right: 10px;
}


/*from old custom.css*/
body.boxed .wp-site-blocks { position:relative; }

/* Removes the block gap on site blocks container */
:where(.wp-site-blocks) > * {
    margin-block-start: 0;
  }

.wp-block-social-link:hover { transform:none; }

body.boxed .wp-site-blocks { max-width: var(--wp--style--global--wide-size);margin:0 auto;background-color:var(--wp--preset--color--palette-9); }



@media only screen and  (max-width: 786px) {

    .row-to-column { flex-direction:column;  }

    .reverse-columns, .reverse-column {
        flex-direction: column-reverse;
        
    }

    .wp-block-column .wp-block-image { margin-bottom:var(--global-sm-spacing); }
}



/* Default styles: hide mobile header */
.site-header.is-mobile-header {
  display: none;

}

/* Media Query for Mobile Devices */
@media screen and (max-width: 768px) {
  /* Hide desktop header */
  #site-header.has-mobile-header {
    display: none;
  }
  /* Show mobile header */
  .site-header.is-mobile-header  {
    display: block;
  }
}

/* Media Query for Desktops and Laptops */
@media screen and (min-width: 769px) {
  /* Show desktop header */
  .site-header {
    display: block;
  }
  /* Hide mobile header */
  .site-header.is-mobile-header  {
    display: none;
  }
}


.xwp-block-group-is-layout-flow > * {
    margin-block-start: 0;
    margin-block-end: 0;
}

.wp-block-search { position:relative; }
.page-header { padding:1em 0; }




body[class*="header-transparent"] .hero {
  padding-top: clamp(3em, 5vw, 9em) !important;
}



.xwp-block-site-logo a, .xcustom-logo-link { min-width:200px; }
.xwp-block-site-logo img { width:100%; }


.wp-block-site-logo svg { width: 100%;height:auto; }

.hero { padding:2em 1em; }




.wp-block-cover.cover-contain .wp-block-cover__image-background { object-fit:contain; }




.card {
  position: relative;
  min-width: 0;
  word-wrap: break-word;
  background-color: #fff;
  background-clip: border-box;
  border: 1px solid var(--wp--preset--color--palette-7);
  border-radius: 0.25rem;
  padding:1em;
  
}


body.modern-theme .card { box-shadow: 0 0.375rem 1.5rem 0 rgba(140,152,164,.125); }




.is-sticky {
    position: sticky;
    top: 100px;
    z-index: 99;
}
.offset-100 {
    top:100px;
}

.offset-150 {
    top:150px;
}

.offset-200 {
    top:200px;
}

.overflow-hidden { overflow:hidden; }
.position-absolute { position:absolute; }
.position-relative { position:relative; }
.width-100 { width:100%; }
.width-100.wp-block-cover.has-custom-content-position.has-custom-content-position .wp-block-cover__inner-container  { width:100%; }


.group-left-center {
    display: flex;
    flex-direction: column;
    align-items: start;
    justify-content: center;
    }




.my-pagination .wp-block-query-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 20px;
  }
.my-pagination .wp-block-query-pagination-numbers {
    display: flex;
    align-items: center;
    list-style: none;
    padding: 0;
    margin: 0;
  }

.my-pagination .page-numbers {
    display: flex;
    margin: 0 2px;
    border-radius: 4px;
    text-decoration: none;
    color: var(--wp--preset--color--palette-3);
    font-size: 18px;
    background-color: var(--wp--preset--color--palette-7);
    border-radius: 100px;
    width: 30px;
    height: 30px;
    justify-content: center;
    align-items: center;
}

 .my-pagination .page-numbers.current, .my-pagination .page-numbers:hover {
    background-color:  var(--wp--preset--color--palette-5);
    color: var(--wp--preset--color--palette-9);
  }


.my-pagination  .page-numbers.dots {
    margin: 0 8px;
    padding:3px 12px;
    border:0;
    background:none;
    color: var(--wp--preset--color--palette-8);
  }

.my-pagination .page-numbers.dots:hover { background-color:none; }


.my-pagination .wp-block-query-pagination-previous,  
.my-pagination .wp-block-query-pagination-next {   color: var(--wp--preset--color--palette-3); }

.my-pagination .wp-block-query-pagination-next {
    display: inline-block;
    margin-left: 10px;  
    text-decoration: none;
    
  }

 .my-pagination .wp-block-query-pagination-next-arrow {
    margin-left: 4px;
    font-size: 18px;
    vertical-align: middle;
  }



[class*="my-animate-"] {
    opacity: 0;
}


.my-animate-fadeinup {
    opacity: 0;
    transform: translateY(100%);
}




/*icon block*/
.wp-block-outermost-icon-block a:hover {
    transform: none;
}


/*List block*/

.wp-block-list {
padding-left: 1.2rem;
}



/*team*/


.mt-minus-2 { margin-top: -3vw !important;}
.mt-minus-3 { margin-top: -4vw !important; }
.mt-minus-4 { margin-top: -5vw !important; }
.mt-minus-5 { margin-top: -6vw !important; }
.mt-minus-6 { margin-top: -7vw !important; }
.mt-minus-7 { margin-top: -8vw !important; }
.mt-minus-8 { margin-top: -9vw !important; }


.mb-minus-2 { bottom: -3vw; z-index: 999; }
.mb-minus-3 { bottom: -4vw; z-index: 999; }
.mb-minus-4 { bottom: -5vw; z-index: 999; }
.mb-minus-5 { bottom: -6vw;z-index: 999; }
.mb-minus-6 { bottom: -7vw;z-index: 999; }
.mb-minus-7 { bottom: -8vw;z-index: 999; }
.mb-minus-8 { bottom: -9vw;z-index: 999; }


.mt-minus-20 { margin-top: calc(var(--wp--preset--spacing--20) * -1) !important;top: calc(var(--wp--preset--spacing--20) * -1) !important; }
.mt-minus-30 { margin-top: calc(var(--wp--preset--spacing--30) * -1) !important;top: calc(var(--wp--preset--spacing--30) * -1) !important; }
.mt-minus-40 { margin-top: calc(var(--wp--preset--spacing--30) * -1) !important;top: calc(var(--wp--preset--spacing--30) * -1) !important; }
.mt-minus-50 { margin-top: calc(var(--wp--preset--spacing--50) * -1) !important;top: calc(var(--wp--preset--spacing--50) * -1) !important; }
.mt-minus-60 { margin-top: calc(var(--wp--preset--spacing--60) * -1) !important;top: calc(var(--wp--preset--spacing--60) * -1) !important; }
.mt-minus-70 { margin-top: calc(var(--wp--preset--spacing--70) * -1) !important;top: calc(var(--wp--preset--spacing--70) * -1) !important; }
.mt-minus-80 { margin-top: calc(var(--wp--preset--spacing--80) * -1) !important;top: calc(var(--wp--preset--spacing--80) * -1) !important; }


.mb-minus-20 { margin-bottom: calc(var(--wp--preset--spacing--20) * -1) !important; }
.mb-minus-30 { margin-bottom: calc(var(--wp--preset--spacing--30) * -1) !important; }
.mb-minus-40 { margin-bottom: calc(var(--wp--preset--spacing--40) * -1) !important; }
.mb-minus-50 { margin-bottom: calc(var(--wp--preset--spacing--50) * -1) !important; }
.mb-minus-60 { margin-bottom: calc(var(--wp--preset--spacing--60) * -1) !important; }
.mb-minus-70 { margin-bottom: calc(var(--wp--preset--spacing--70) * -1) !important; }
.mb-minus-80 { margin-bottom: calc(var(--wp--preset--spacing--80) * -1) !important; }


@media only screen and (min-width : 768px) {  
.ml-minus-20 { margin-left: calc(var(--wp--preset--spacing--20) * -1) !important; }
.ml-minus-30 { margin-left: calc(var(--wp--preset--spacing--30) * -1) !important; }
.ml-minus-40 { margin-left: calc(var(--wp--preset--spacing--40) * -1) !important; }
.ml-minus-50 { margin-left: calc(var(--wp--preset--spacing--50) * -1) !important; }
.ml-minus-60 { margin-left: calc(var(--wp--preset--spacing--60) * -1) !important; }
.ml-minus-70 { margin-left: calc(var(--wp--preset--spacing--70) * -1) !important; }
.ml-minus-80 { margin-left: calc(var(--wp--preset--spacing--80) * -1) !important; }

.mr-minus-20 { margin-right: calc(var(--wp--preset--spacing--20) * -1) !important; }
.mr-minus-30 { margin-right: calc(var(--wp--preset--spacing--30) * -1) !important; }
.mr-minus-40 { margin-right: calc(var(--wp--preset--spacing--40) * -1) !important; }
.mr-minus-50 { margin-right: calc(var(--wp--preset--spacing--50) * -1) !important; }
.mr-minus-60 { margin-right: calc(var(--wp--preset--spacing--60) * -1) !important; }
.mr-minus-70 { margin-right: calc(var(--wp--preset--spacing--70) * -1) !important; }
.mr-minus-80 { margin-right: calc(var(--wp--preset--spacing--80) * -1) !important; }
}

/* Small Devices, Tablets */
@media only screen and (max-width: 991px) and (min-width: 768px) {


.site-logo .icon-containerx  {  width:90% !important; }
  [class*="wp-container-"].columns-1 { grid-template-columns: repeat(1, 1fr); }
  [class*="wp-container-"].columns-2 { grid-template-columns: repeat(2, 1fr); }
  [class*="wp-container-"].columns-3 { grid-template-columns: repeat(2, 1fr); }
  [class*="wp-container-"].columns-4 { grid-template-columns: repeat(3, 1fr); }
  [class*="wp-container-"].columns-5 { grid-template-columns: repeat(3, 1fr); }

}

/* Extra Small Devices, Phones */
@media only screen and (max-width: 767px) {

.site-logo .icon-containerx  {  width:80% !important; }

  [class*="wp-container-"].columns-1 { grid-template-columns: repeat(2, 1fr); }
  [class*="wp-container-"].columns-2 { grid-template-columns: repeat(2, 1fr); }
  [class*="wp-container-"].columns-3 { grid-template-columns: repeat(2, 1fr); }
  [class*="wp-container-"].columns-4 { grid-template-columns: repeat(2, 1fr); }
  [class*="wp-container-"].columns-5 { grid-template-columns: repeat(2, 1fr); }
}


/* Extra Small Devices, Phones */
@media only screen and (max-width: 576px) {

.site-logo .icon-containerx  {  width:70% !important; }

  [class*="wp-container-"].columns-1 { grid-template-columns: repeat(1, 1fr); }
  [class*="wp-container-"].columns-2 { grid-template-columns: repeat(1, 1fr); }
  [class*="wp-container-"].columns-3 { grid-template-columns: repeat(1, 1fr); }
  [class*="wp-container-"].columns-4 { grid-template-columns: repeat(1, 1fr); }
  [class*="wp-container-"].columns-5 { grid-template-columns: repeat(1, 1fr); }
}






/*Hide*/


@media (max-width: 768px) {
    /* CSS in here for mobile only */
   .hide-on-mobile, .hide-on-mobile * {
    display: none;
    }
}
@media (min-width: 769px) and (max-width: 1024px) {
    /* CSS in here for tablet only */
    .hide-on-tablet, .hide-on-tablet * {
        display: none;
      }
}
@media (min-width: 1025px) {
    /* CSS in here for desktop only */
    .hide-on-desktop,  .hide-on-desktop * {
        display: none;
      }
}




/*two column fullwidth section pattern*/
@media only screen and (min-width : 768px) {
.pad-my-column {
    padding-left: calc((100vw - var(--wp--style--global--content-size)) / 2) !important;
}
}




.gf-horizontal-form form{ 

    display: flex;
    gap: 10px;

 }



 /*Content Toggle*/

/* Ensure the toggle content group is collapsed by default */
.toggle-content-group {
    display: none; /* Hidden by default */
    transition: max-height 0.3s ease, opacity 0.3s ease;
}

/* Optional: Styling for the clickable paragraph */
.toggle-header-group p {
    cursor: pointer;
}






/* Custom, iPhone Retina */
@media only screen and (min-width : 320px) {

}

/* Extra Small Devices, Phones */
@media only screen and (min-width : 576px) {

}
/* Small Devices, Tablets */
@media only screen and (min-width : 768px) {

}
/* Medium Devices, Desktops */
@media only screen and (min-width : 992px) {

}

/* Large Devices, Wide Screens */
@media only screen and (min-width : 1200px) {

}

/*==========  Non-Mobile  ==========*/
/* Large Devices, Wide Screens */
@media only screen and (max-width : 1200px) {

}
/* Medium Devices, Desktops */
@media only screen and (max-width : 992px) {
  
}
/* Small Devices, Tablets */
@media only screen and (max-width : 768px) {  


}
/* Extra Small Devices, Phones */
@media only screen and (max-width : 576px) {
}
/* Custom, iPhone Retina */
@media only screen and (max-width : 320px) {
}



