/*
Theme Name: DPJV-02
Theme URI: 
Author: Paul Bystrzan
Author URI: 
Description: DPJV Block Theme version 02
Requires at least: 6.8
Tested up to: 6.8
Requires PHP: 7.3
Version: 1.0
License: GNU General Public License v3 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: dpjv-02
Tags: blog, portfolio, entertainment, grid-layout, one-column, two-columns, three-columns, four-columns, block-patterns, block-styles, custom-logo, custom-menu, editor-style, featured-images, full-site-editing, full-width-template, rtl-language-support, style-variations, template-editing, theme-options, translation-ready, wide-blocks

dpjv-02 WordPress Theme, (C) 2025 Mike McAlister.
dpjv-02 is distributed under the terms of the GNU GPL.
*/

/* CSS Reset
---------------------------------------------------------------------------- */

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

html {
	box-sizing: border-box;
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
}

b,
strong {
	font-weight: var(--wp--custom--font-weight--semi-bold);
}

ol,
ul {
	padding: 0;
}

ol:where(:not([class*="wp-block"])),
ol:where(.wp-block-list),
ul:where(:not([class*="wp-block"])),
ul:where(.wp-block-list) {
	padding-inline-start: var(--wp--preset--spacing--medium);
}

div[class*="wp-block-"] figcaption {
	color: var(--wp--preset--color--secondary);
	font-size: var(--wp--preset--font-size--x-small);
	margin-bottom: 0;
	margin-top: 20px;
	text-align: center;
}

img,
figure {
	max-width: 100%;
	height: auto;
}

/* Temporary fix for text-decoration-thickness in Firefox */
@-moz-document url-prefix() {
	a {
		text-decoration-thickness: .1rem !important;
	}
}

/* Standardize form styling
--------------------------------------------- */

input,
button,
textarea,
select {
	font: inherit;
}

input[type="button"],
input[type="email"],
input[type="search"],
input[type="submit"],
input[type="text"],
textarea {
	-webkit-appearance: none;
	appearance: none;
}

input:not([type="submit"]),
select,
textarea,
.wp-block-post-comments-form input:not([type="submit"]):not([type="checkbox"]),
.wp-block-post-comments-form textarea,
.dpjv-filter-block .dpjv-search-input,
.dpjv-filter-block .dpjv-taxonomy-select,
.dpjv-multiselect-control {
	color: var(--wp--preset--color--main);
	border-radius: 4px;
	border: solid 1px var(--wp--preset--color--border-light);
	padding: .5em 1em;
	font-size: var(--wp--preset--font-size--small);
	background-color: var(--wp--preset--color--base);
}

input:focus-visible,
textarea:focus-visible {
	outline-color: var(--wp--preset--color--primary);
}

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

label {
	width: 100%;
	display: block;
}

::placeholder {
	color: var(--wp--preset--color--secondary);
	/* font-size: var(--wp--preset--font-size--small); */
	opacity: 0.75;
}

/* Helper styles
---------------------------------------------------------------------------- */

a.more-link {
	display: block;
}

/* Inline code */
*:not(.wp-block-code) > code {
	background-color: var(--wp--preset--color--tertiary);
	padding: 3px 5px;
	position: relative;
	border-radius: 3px;
}

.wp-block-categories {
	position: relative;
}

/* Adjust terms at bottom of posts */
.single .wp-block-group .wp-block-post-terms,
.blog .wp-block-group .wp-block-post-terms {
	margin-bottom: -8px !important;
}

/* Remove margin on term description on archive pages */
.wp-block-term-description p:last-child {
	margin-bottom: 0;
}

/* Remove last separator on post list */
.remove-border-and-padding .wp-block-post-template li:last-child .wp-block-separator {
	display: none;
}

/* Hide post meta div if no tags assigned */
.single .wp-block-group:has(> .post-meta:empty) {
	display: none;
}

.wp-block-group:empty:has(+ .comment-respond) {
	display: none;
}

.row-logos > figure {
	flex-shrink: 1 !important;
}

/* Sticky header */

body:not(.is-fullscreen-mode) header:has(>.is-position-sticky) {
	position: sticky;
	top: calc( 0px + var( --wp-admin--admin-bar--height, 0px ) );
	z-index: 100;
}

/* Account for admin bar on mobile */

@media (max-width: 600px) {
	header:has(>.is-position-sticky) {
		top: 0;
	}
}

/* Mobile helper classes */

@media (max-width: 781px) {
	.dpjv-02-hide-on-mobile {
		display: none;
	}

	.dpjv-02-unstick-mobile {
		position: static;
	}

	header:has(>.dpjv-02-unstick-mobile) {
		position: static;
	}
}

.wp-block-navigation-item:has([aria-current="page"]) > :where(a, button, .wp-block-navigation__submenu-icon) {
    font-weight: bold !important;
}

:root :where(.wp-block-navigation) {
    /* font-size: 12px; */
}



/* alt inverted border colors from theme palette */
.has-primary-background-color { --clr: var(--wp--preset--color--primary) !important; } .has-primary-accent-background-color { --clr: var(--wp--preset--color--primary-accent) !important; } .has-primary-alt-background-color { --clr: var(--wp--preset--color--primary-alt) !important; } .has-primary-alt-accent-background-color { --clr: var(--wp--preset--color--primary-alt-accent) !important; } .has-main-background-color { --clr: var(--wp--preset--color--main) !important; } .has-main-accent-background-color { --clr: var(--wp--preset--color--main-accent) !important; } .has-base-background-color { --clr: var(--wp--preset--color--base) !important; } .has-secondary-background-color { --clr: var(--wp--preset--color--secondary) !important; } .has-tertiary-background-color { --clr: var(--wp--preset--color--tertiary) !important; } .has-border-light-background-color { --clr: var(--wp--preset--color--border-light) !important; } .has-border-dark-background-color { --clr: var(--wp--preset--color--border-dark) !important; }



.bindings-group {
    width: 100%
}

.bindings-group>:first-child {
    width: 120px;
    min-width: 120px;
    flex-basis: 120px;
}

body.wp-admin .bindings-group:has(p:empty) {
    opacity: .4
}

body.wp-theme-dpjv-02:not(.block-editor-page) .bindings-group:has(p:empty) {
    display: none!important
}


main { hyphens: auto; }



.wpcf7-form-control-wrap, .wpcf7-form-control-wrap textarea {
    width: 100%;
    display: block;
}
.wpcf7-form-control-wrap {
margin: 8px 0 0 0;}


.wpcf7 .send-inner {
    display: flex;
    justify-content: space-between;
    width: 100%;
    gap: 1em;
}

.wpcf7 span.wpcf7-spinner {
    display: none;
}

.wpcf7 .wpcf7-submit {
    background-color: var(--wp--preset--color--secondary);
    height: 48px;
    min-width: 200px;
    align-self: center;
}

.wpcf7 .altcha-widget-wrap {margin: 0 !important;}

.wpcf7 .altcha-error, .altcha-footer {
    font-size: .6em;
}

.wpcf7 .altcha {
    flex-direction: row;
    --altcha-max-width: 100%;
    align-items: center;
    --altcha-color-border: var(--wp--preset--color--primary);
}

.wpcf7 .altcha-checkbox input {
    accent-color: var(--wp--preset--color--primary);
}
form, textarea, input {
accent-color: var(--wp--preset--color--primary);
}







.card-team-member {
    min-height: 100%;
    position: relative;
    --radius: 12px;
    --border-width: 3px;
    border-radius: calc(var(--radius) + var(--border-width));
    overflow: hidden;
    border: var(--border-width) solid var(--wp--preset--color--base);
    outline: 1px solid var(--wp--preset--color--primary-accent);
    aspect-ratio: 3 / 4;
}

.card-team-member__image {
    /* aspect-ratio: 3 / 4; */
    border-radius: var(--radius);
    overflow: hidden;
    width: 100%;
    height: 100%;
}

.card-team-member__image:after {
    content: "";
    z-index: 2;
    background: linear-gradient(10deg, #060e19cf, #0000);
    width: 100%;
    height: 100%;
    position: absolute !important;
    inset: 0;
    opacity: .5;
    z-index: 1;
}

.card-team-member__image img {
    border-radius: calc(var(--radius) + 2px);
    width: 100%;
    height: 100%;
    max-width: 999px;
    object-fit: cover;
    object-position: 50% 50%;
}

.card-team-member__contact {
    position: absolute !important;
    top: 5px;
    right: 5px;
    margin: 0 !important;
    z-index: 3;
}

.card-team-member__name-role {
    background-color: var(--wp--preset--color--base);
    padding: 16px 8px 16px 6px !important;
    max-width: calc(100% - 30px) !important;
    border-top-right-radius: var(--radius);
    border-bottom-right-radius: var(--radius);
    min-height: 4.8em;
    position: absolute !important;
    z-index: 3;
    bottom: 0;
    left: 0;
    min-width: 70%;
}

.card-team-member__name-role::before, .card-team-member__name-role::after {
    content: '';
    position: absolute;
    bottom: 0;
    right: calc(-1 * var(--radius));
    background: transparent;
    width: var(--radius);
    height: var(--radius);
    border-bottom-right-radius: var(--radius);
    box-shadow: 6px 6px 0 5px var(--clr);
}

.card-team-member__name-role::before {
    top: auto !important;
    right: calc(-1 * var(--radius)) !important;
    bottom: 0 !important;
    left: auto !important;
    transform: scale(-1, 1);
}

.card-team-member__name-role::after {
    top: calc(-1 * var(--radius)) !important;
    right: auto !important;
    bottom: auto !important;
    left: 0 !important;
    transform: scale(-1, 1);
}


.card-kuratorium-member {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0;
    align-items: center;
    outline: 1px solid var(--wp--preset--color--primary-accent);
    border-radius: 12px;
    margin: 0 !important;
    margin-block-start: 0 !important;
    margin-block-end: 0 !important;
}
:root :where(.editor-styles-wrapper) :where(.is-layout-constrained)>.block-library-block__reusable-block-container {
    margin-block-start: 0;
}

.card-kuratorium-member .card-team-member {
    outline: none;
    /* aspect-ratio: 3 / 4; */
    min-height: initial;
}
.card-kuratorium-member .card-team-member__image {
    width: 200px;
}

.card-kuratorium-member .card-team-member__bio {
    margin: var(--wp--preset--spacing--small) 0;
    padding: 0 var(--wp--preset--spacing--small);
    max-height: 222px;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    overflow-scrolling: touch;
    background:
    /* Shadow Cover TOP */
    linear-gradient(
      white 30%,
      rgba(255, 255, 255, 0)
    ) center top,
    
    /* Shadow Cover BOTTOM */
    linear-gradient(
      rgba(255, 255, 255, 0), 
      white 70%
    ) center bottom,
    
    /* Shadow TOP */
    radial-gradient(
      farthest-side at 50% 0,
      rgba(0, 0, 0, .3),
      rgba(0, 0, 0, 0)
    ) center top,
    
    /* Shadow BOTTOM */
    radial-gradient(
      farthest-side at 50% 100%,
      rgba(0, 0, 0, .3),
      rgba(0, 0, 0, 0)
    ) center bottom;
    background-repeat: no-repeat;
    background-size: 150% 40px, 150% 40px, 104% 15px, 104% 15px;
    background-attachment: local, local, scroll, scroll;
}

.card-kuratorium-member .card-team-member__name-role {
	min-height: initial !important;
	--wp--preset--font-size--base: 12px;
}

.card-kuratorium-member .card-team-member__name-role strong {
	letter-spacing: -.015em;
}

@media (max-width: 480px) {
	.card-kuratorium-member {
	    display: block;
	}

	.card-kuratorium-member .card-team-member__bio {
	    max-height: unset;
	    padding: var(--wp--preset--spacing--small) var(--wp--preset--spacing--small) var(--wp--preset--spacing--medium) var(--wp--preset--spacing--small);
	}
	.card-kuratorium-member .card-team-member__image,
	.card-kuratorium-member .card-team-member {
		width: 100%;
		aspect-ratio: 1 /1;
	}
}

@media (min-width: 1024px) {
	.card-kuratorium-member {
	    margin: 0 !important;
	}
    .card-kuratorium-member {
        display: grid;
        grid-template-columns: auto 1fr;
        gap: 0;
        align-items: center;
        outline: 1px solid var(--wp--preset--color--primary-accent);
        border-radius: 12px;
    }
	.wrapper-kuratorium {
		display: grid;
		gap: var(--wp--preset--spacing--medium);
		grid-template-columns: 1fr 1fr;
	}
}