/*
Theme Name: AM Blocks
Theme URI: https://abstractmarketing.ca
Author: Lance Hammond
Description: A simple block theme to use as a starting point. Developed for Abstract Marketing.
Requires at least: 6.5
Tested up to: 6.8.1
Requires PHP: 8.0
Version: 1.3.9
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: am-blocks
Tags: full-site-editing
*/

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

img:not([class]), iframe {
    display: block;
}

figure[class*="align"]:not(.alignfull) {
    display: block !important;
    max-width: var(--wp--style--global--content-size);
    margin-left: auto !important;
    margin-right: auto !important;
	float: none !important;
}

figure.alignleft :is(img, div) {
    float: left;
	margin-inline-end: 1rem;
}

figure.alignright :is(img, div) {
    float: right;
	margin-inline-start: 1rem;
}

figure.aligncenter :is(img, div) {
	margin-inline: auto;
	display: inline-block !important;
}

:is(input:not(:is([type="button"], [type="submit"])), select, textarea) {
	background-color: var(--wp--preset--color--base);
	border: 1px solid #bbb;
	border-radius: 5px;
	color: var(--wp--preset--color--contrast);
	font-family: inherit;
	font-size: var(--wp--preset--font-size--small);
	font-weight: 400;
	line-height: 1.65;
	padding: var(--wp--preset--spacing--30) var(--wp--preset--spacing--40);
	width: 100%;
}

:is(input:focus, textarea:focus, select:focus) {
    outline: 2px solid var(--wp--preset--color--primary);
}

:is(input[type="checkbox"], input[type="image"], input[type="radio"]) {
	width: auto;
}

::placeholder {
	color: var(--wp--preset--color--contrast);
	opacity: 0.5;
}

.wp-block-navigation svg {
    width: 44px;
    height: 44px;
}

.site-header {
    background: linear-gradient(
        to bottom,
        #0007,
        #fff2
    );
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);
}

@media (min-width: 992px) and (max-width: 1400px) {
    .site-header .wp-block-navigation > .wp-block-navigation-item:first-child {
        display: none;
    }
}

@media (min-width: 992px) and (max-width: 1300px) {
    .logos img {
        width: 280px !important;
    }
    
    .site-header .wp-block-social-links {
        display: none;
    }
}

@media (max-width: 991px) {
    .site-header .wp-block-social-links svg {
        width: 64px;
        height: 48px;
    }
}

.site-header nav.wp-block-navigation {
    margin-right: 20px;
}

.wp-block-navigation > li > a {
	line-height: 1.2;
}

.wp-block-navigation > li {
    position: relative;
}

@media (min-width: 999px) {
	.wp-block-navigation > li:hover::before,
	.wp-block-navigation > li.current-menu-item::before {
		content: '';
		position: absolute;
		inset: -6px -6px;
		background: #fff3;
		border-radius: 5px;
		pointer-events: none;
		backdrop-filter: blur(5px);
		z-index: -1;
	}
}

.is-menu-open .wp-block-navigation__container {
    width: 100%;
}

.has-modal-open .site-header {
    inset: 0;
}

.is-menu-open .items-justified-center .wp-block-navigation-item,
.is-menu-open .items-justified-center .wp-block-navigation-item a {
    text-align: center;
    justify-content: center;
}

.is-menu-open .items-justified-right .wp-block-navigation-item,
.is-menu-open .items-justified-right .wp-block-navigation-item a {
    text-align: right;
    justify-content: end;
}

.is-menu-open .wp-block-navigation-item {
    flex-direction: row !important;
    flex-wrap: wrap;
    gap: 0 !important;
    width: 100%;
    justify-content: space-between;
}

.is-menu-open .wp-block-navigation-submenu__toggle {
    display: inline-flex !important;
    flex: 0 0 1.5em;
    display: flex;
    justify-content: center;
    height: 1.5em;
    margin-inline: 0;
}

.is-menu-open .wp-block-navigation-submenu {
    flex: 100%;
}

.is-menu-open .wp-block-navigation-submenu__toggle[aria-expanded="false"] + ul {
    display: none;
}

.is-menu-open .wp-block-navigation-submenu__toggle svg {
    transition: transform .2s ease;
    transform: rotate(-90deg);
    width: .85em;
}

.is-menu-open .wp-block-navigation-submenu__toggle[aria-expanded="true"] svg {
    transform: rotate(0deg);
}

.is-menu-open .wp-block-navigation-item {
    font-size: 24px !important;
}

.is-menu-open .wp-block-navigation-item .wp-block-navigation-item span {
    font-size: .85em;
}

.site-footer a {
	text-decoration: none;
}

.wp-block-page-list,
.wp-block-page-list ul {
    list-style: '» ';
    line-height: 1.2;
}

.wp-block-page-list a {
    text-decoration: none;
    font-weight: 500;
    font-size: .9em;
    padding-block: 4px;
    display: inline-block;
}

.wp-block-page-list li:hover,
.wp-block-page-list li:hover a {
    color: var(--wp--preset--color--primary)
}

/**
 * Filtered Gallery
 */

img {
    max-width: 100%;
}

.kvc-gallery .filter {
    margin-bottom: 24px;
    justify-content: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 0;
    border: none;
}

.kvc-gallery .filter label {
    border: 1px solid var(--wp--preset--color--primary);
    border-radius: 20px;
    white-space: nowrap;
    display: inline-block;
    padding: 0 10px;
}

.kvc-gallery input {
    filter: contrast(0) brightness(2);
}

.kvc-gallery input:not(:checked) {
    opacity: 0;
    width: 0;
    margin: 0;
    overflow: hidden;
}

.kvc-gallery .images {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 24px;
}

.kvc-gallery img {
    width: 100%;
}

/* Hide images based on selected radio */
.kvc-gallery:has(.bat:checked) a:not([data-category="bat"]) { opacity: 0; display: none; }
.kvc-gallery:has(.kit:checked) a:not([data-category="kit"]) { opacity: 0; display: none; }
.kvc-gallery:has(.kit:checked) a:not([data-category="kit"]) { opacity: 0; display: none; }
.kvc-gallery:has(.bas:checked) a:not([data-category="bas"]) { opacity: 0; display: none; }
.kvc-gallery:has(.hom:checked) a:not([data-category="hom"]) { opacity: 0; display: none; }
.kvc-gallery:has(.aux:checked) a:not([data-category="aux"]) { opacity: 0; display: none; }
.kvc-gallery:has(.con:checked) a:not([data-category="con"]) { opacity: 0; display: none; }
.kvc-gallery:has(.sid:checked) a:not([data-category="sid"]) { opacity: 0; display: none; }

.kvc-gallery:has(.liv:checked) a:not([data-category="liv"]) { opacity: 0; display: none; }
.kvc-gallery:has(.flor:checked) a:not([data-category="flor"]) { opacity: 0; display: none; }
.kvc-gallery:has(.ext:checked) a:not([data-category="ext"]) { opacity: 0; display: none; }
.kvc-gallery:has(.bed:checked) a:not([data-category="bed"]) { opacity: 0; display: none; }

/* Hide filters for categories when images with that cat don't exist */
.kvc-gallery:not(:has(img[data-category="bat"])) label.bat { display: none; }
.kvc-gallery:not(:has(img[data-category="kit"])) label.kit { display: none; }
.kvc-gallery:not(:has(img[data-category="kit"])) label.kit { display: none; }
.kvc-gallery:not(:has(img[data-category="bas"])) label.bas { display: none; }
.kvc-gallery:not(:has(img[data-category="hom"])) label.hom { display: none; }
.kvc-gallery:not(:has(img[data-category="aux"])) label.aux { display: none; }
.kvc-gallery:not(:has(img[data-category="con"])) label.con { display: none; }
.kvc-gallery:not(:has(img[data-category="sid"])) label.sid { display: none; }

.kvc-gallery:not(:has(img[data-category="liv"])) label.liv { display: none; }
.kvc-gallery:not(:has(img[data-category="flor"])) label.flor { display: none; }
.kvc-gallery:not(:has(img[data-category="ext"])) label.ext { display: none; }
.kvc-gallery:not(:has(img[data-category="bed"])) label.bed { display: none; }

.kvc-gallery label:hover {
    background: var(--wp--preset--color--tertiary);
}

.kvc-gallery label:has(:checked) {
    background: var(--wp--preset--color--primary);
    color: #fff;
    border-color: var(--wp--preset--color--primary-2);
}

.ryu-douse img {
    animation: ryuEmber 10s linear;
}

@keyframes ryuEmber {
    0% {
		opacity: 0;
        transform: scale(1.3);
    }
    10% { opacity: 0; }
	15% { opacity: 1; }
    100% {
        transform: scale(1)
    }
}

.cover-slider :is(h1, p) {
    text-shadow: 0 .05em .2em black !important;
}

:is(h1, h2, h3, h4, h5, h6):has(img.wp-image-93) {
    display: flex;
    align-items: center;
    gap: 4px;
}

:is(h1, h2, h3, h4, h5, h6) img.wp-image-93 {
    flex-shrink: 0;
}

.services-grid {
    position: relative;
    overflow: hidden;
}

.services-grid h2 {
    text-shadow: 2px 2px 8px #000;
}

.services-grid a {
    text-decoration: none;
}

.services-grid a::before {
    content: 'a';
    position: absolute;
    inset: -50vw;
}

.am-testimonial__name {
    color: var(--wp--preset--color--primary);
}

.bounce {
  animation: bounce 5s ease infinite;
}

@keyframes bounce {
	0%, 20%, 50%, 80%, 100% {transform: translateY(0);}
	40% {transform: translateY(10px);}
	60% {transform: translateY(6px);}
}

.kvc-gallery.masonry img {
    aspect-ratio: unset !important;
	height: auto !important;
	aspect-ratio: unset !important;
}

.kvc-gallery.masonry .images a {
    display: block;
    position: absolute;
    padding: 2px;
}

.am-testimonials cite::before {
  content: '-';
  margin-right: 4px;
}

.wp-block-button__link:has(img) {
  display: flex;
  gap: 5px;
}

.wp-block-cover .wp-block-post-title {
  text-shadow:
    0 0 18px #000,
    0 0 4px #000
}

.cover-link {
  position: relative;
  overflow: hidden;
}

.cover-link a:first-of-type::before {
  content: '';
  position: absolute;
  inset: -400px;
  z-index: 1;
}

@media (min-width: 1024px) {
  .site-header .wp-block-social-link svg {
    color: #fff !important;
  }
}

.wp-block-navigation__responsive-container {
  background: #333c !important;
}

.has-modal-open .site-header .wp-block-navigation__container {
  gap: 25px !important;
}

.has-modal-open .site-header .wp-block-navigation__container li ul {
  gap: 10px !important;
}

.has-modal-open .wp-block-social-links {
  transform: translateY(150%);
}

.has-modal-open .wp-block-buttons {
  transform: translateY(-150%);
}

.wp-block-navigation__submenu-container {
  background: #222a !important;
}

@media (min-width: 782px) {
  .center-last-row > :last-child {
    transform: translateX(calc(50% + 8px));
  }
}

:is(.page-id-30, .page-id-42) .page-header + div svg path[opacity=".66"] {
  fill: var(--wp--preset--color--primary) !important;
  opacity: 100;
  z-index: -1;
}

@media (min-width: 992px) {
    .wp-block-navigation__submenu-container {
        --offset: 10px;
        transform: translateY(var(--offset));
        box-shadow: 5px 5px 10px #0003;
        border: none !important;
    }
    
    .wp-block-navigation__submenu-container::after {
        position: absolute;
        content: '';
        width: 100%;
        height: var(--offset);
        top: calc(var(--offset) / -1);
        background: transparent;
    }
    
    .wp-block-navigation__submenu-container a {
        line-height: 1.3;
    }
}

@media (max-width: 850px) {
  figure.alignright,
  figure.alignleft {
    text-align: center;
  }
  figure.alignright img,
  figure.alignleft img {
    float: none !important;
    margin: 0;
  }
}