/*
Theme Name: LD Block Theme
Author: Lawrence Davis
Author URI: https://lawrencedavis.co.uk
Requires at least: 6.1
Tested up to: 6.3
Requires PHP: 5.6
Version: 0.1
Text Domain: ld_block_theme
*/


/* LAYOUT */

main, footer {
margin-block-start: 0;
margin-block-end: 0;
}
.entry-content.wp-block-post-content {
margin-block-start: 0;
}
.wp-site-blocks {
padding-top: 0;
padding-bottom: 0;
}
.has-global-padding > .alignfull {
margin-right: 0 !important;
margin-left: 0 !important;
}
.has-global-padding > .alignfull > .has-global-padding, .has-global-padding, .wp-block-group.fixed-after {
padding-right: 0;
padding-left: 0;
}


/* GENERAL */

body {
-moz-osx-font-smoothing: grayscale;
overflow-x: hidden;
}
a {
transition: all 0.3s ease-in-out;
}
a:focus-visible {
outline: none;
}
strong {
font-weight: 700;
}
.wp-block-quote {
border: 0;
padding: 2em 0 0;
position: relative;
margin: 0;
margin-block-start: 0.5em !important; 
}
blockquote::before {
content: open-quote;
display: block;
text-align: left;
color: var(--wp--preset--color--secondary);
font-size: 100px;
line-height: 0.6;
position: absolute;
left: -5px;
top: 0;
width: 40px;
height: 30px;
margin: 0;
}
blockquote:after {
visibility: hidden;
content: close-quote;
}


/* COLOUR REF */

.white-filter path,
.icon-container.has-base-color path {
fill: var(--wp--preset--color--base);
}
.icon-container.has-primary-color path {
fill: var(--wp--preset--color--primary) !important;
}
.icon-container.has-secondary-color path {
fill: var(--wp--preset--color--secondary) !important;
}
.icon-container.has-tertiary-color path {
fill: var(--wp--preset--color--tertiary) !important;
}


/* HEADING DECOR */

.title-overline::before,
.title-underline::after {
content: "";
display: block;
width: 100px;
max-width: 75%;
height: 1px;
background: var(--wp--preset--color--secondary);
margin-top: 20px;
margin-bottom: 20px;
}
.has-text-align-center.title-underline::after {
margin-left: auto;
margin-right: auto;
}
.dark-bg .title-overline::before,
.dark-bg .title-underline::after {
background: var(--wp--preset--color--base);
}
#header-info .title-underline::after {
margin-top: 7px;
margin-bottom: 7px;
}


/* HEADER */

#site-header #pmd path {
fill: var(--wp--preset--color--base);
}
#site-header #header-logo svg, 
#site-header #header-logo .icon-container {
width: clamp(180px, calc(11.25rem + ((1vw - 7.68px) * 10.4167)), 300px) !important;
}
#header-info .title-underline::after {
margin-top: 10px;
margin-bottom: 7px;
}


/* NAVIGATION */

.main-nav.wp-block-navigation .wp-block-navigation-item__content {
text-transform: uppercase;
color: var(--wp--preset--color--base);
letter-spacing: 0.1em;
}
.main-nav.wp-block-navigation .wp-block-navigation-item__content:hover {
color: var(--wp--preset--color--secondary);
}
ul.wp-block-navigation__container > .wp-block-navigation-item.current-menu-item a, ul.wp-block-navigation__container > .wp-block-navigation-item.current-menu-item a, ul.wp-block-navigation__container > .wp-block-navigation-item.wp-block-navigation-submenu .current-menu-ancestor a {
color: var(--wp--preset--color--secondary);
font-weight: 700;
}
.wp-block-navigation-item.open-on-click .wp-block-navigation-submenu__toggle {
padding: 0 .85em 0 0;
background: transparent !important;
}
.main-nav.wp-block-navigation .wp-block-navigation__submenu-container > li > a {
font-size: 0.8em;
font-weight: 700;
}
.wp-block-navigation-item.open-on-click .wp-block-navigation-submenu__toggle + .wp-block-navigation__submenu-icon {
margin-left: 0;
}


/* FORM */

.wpcf7-form .input-group {
margin-block-end: 0.7rem;
}
.wpcf7-form p {
font-weight: 400;
margin-block-start: 0;
margin-block-end: 0;
}
.wpcf7-form label {
font-size: 0.9em;
line-height: 1.3;
font-weight: 600;
}
.req-symbol {
font-weight: 400;
color: red;
}
.wpcf7-spinner {
display: block !important;
margin: 5px auto 0 !important;
}
select, textarea, input[type="text"], input[type="email"], input[type="number"], input[type="tel"] {
width: 100%;
max-width: 100%;
}
select, textarea, input[type="text"], input[type="email"],
input[type="number"], input[type="tel"] {
font-family: var(--wp--preset--font-family--bio-sans);
font-size: var(--wp--preset--font-size--small);
border: 1px solid var(--wp--preset--color--tertiary);
padding: 0.8em;
margin: 0 0 0.8em 0;
background: transparent;
color: var(--wp--preset--color--primary);
box-sizing: border-box;
-webkit-appearance: none !important;
appearance: none;
-webkit-transition: all 0.3s ease-in-out;
transition: all 0.3s ease-in-out;
}
input[type="reset"], input[type="submit"], button {
border: 1px solid var(--wp--preset--color--primary);
background: transparent;
color: var(--wp--preset--color--primary);
padding: 0.8em 2.5em;
border-radius: 0;
font-weight: 600 !important;
width: auto;
text-transform: uppercase;
letter-spacing: 0.1em;
font-size: var(--wp--preset--font-size--x-small);
}
input[type="reset"]:hover, input[type="submit"]:hover, button:hover {
background: var(--wp--preset--color--primary);
color: var(--wp--preset--color--base);
}
textarea:focus, input[type="text"]:focus, input[type="email"]:focus,
input[type="number"]:focus, input[type="tel"]:focus {
border-color: var(--wp--preset--color--primary);
}
textarea:focus-visible, input[type="text"]:focus-visible, input[type="email"]:focus-visible, input[type="number"]:focus-visible, input[type="tel"]:focus-visible {
outline: transparent;
}
textarea {
min-height: 1em;
}
.wpcf7-form-control::-moz-placeholder, .wpcf7-form-control::-ms-input-placeholder, .wpcf7-form-control::-webkit-input-placeholder {
color: var(--wp--preset--color--secondary);
opacity: 1;
}
.wpcf7-list-item {
margin: 0.5em 0 1em !important;
}
.wpcf7-acceptance .wpcf7-list-item-label {
font-weight: 400;
}
.wpcf7-form .wpcf7-not-valid-tip {
font-size: 0.9em;
font-style: oblique;
color: var(--wp--preset--color--primary);
}
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output, .wpcf7 form.payment-required .wpcf7-response-output {
border: none;
border-top: 1px solid var(--wp--preset--color--primary) !important;
font-size: 0.9em;
margin: 2em 0;
padding: 1em 0;
font-style: oblique;
}
.dark-bg .wpcf7-form label {
color: var(--wp--preset--color--base);
}
.dark-bg .wpcf7-acceptance .wpcf7-list-item-label a {
font-weight: 700;
color: var(--wp--preset--color--base);
}


/* BUTTON */

.wp-block-buttons.is-layout-flex  {
gap: 0.5em;
}
.wp-block-button__link {
position: relative;
}
.wp-block-button > .wp-block-button__link, .wp-block-button.is-style-outline > .wp-block-button__link {
color: var(--wp--preset--color--base);
padding: 0.9em 2.5em;
-webkit-transition: all 0.3s ease-in-out;
transition: all 0.3s ease-in-out;
}
.wp-block-button .wp-block-button__link.is-style-outline, .wp-block-button.is-style-outline > .wp-block-button__link {
border-width: 1px
}
.wp-block-button.is-style-outline > .wp-block-button__link {
border-color: var(--wp--preset--color--primary);
color: var(--wp--preset--color--primary);
}
.wp-block-button.is-style-outline > .wp-block-button__link:hover {
border-color: var(--wp--preset--color--primary);
background: var(--wp--preset--color--primary);
color: var(--wp--preset--color--base);
}
.dark-bg .wp-block-button.is-style-outline > .wp-block-button__link {
background: transparent;
border-color: var(--wp--preset--color--base);
color: var(--wp--preset--color--base);
}
.dark-bg .wp-block-button.is-style-outline > .wp-block-button__link:hover {
border-color: var(--wp--preset--color--base);
background: var(--wp--preset--color--base);
color: var(--wp--preset--color--primary);
}


/* BLOCK UPDATES */

.wp-block-social-links .wp-social-link, 
.wp-block-social-links .wp-social-link svg,
.wp-block-social-links .wp-social-link span,
.wp-block-outermost-icon-block svg,
.wp-block-outermost-icon-block .icon-container {
-webkit-transition: all 0.5s ease-in-out;
transition: all 0.5s ease-in-out;
}
.wp-block-cover.has-custom-content-position.has-custom-content-position .wp-block-cover__inner-container {
width: 100%;
}


/* BANNER */

#banner {
min-height: 30vw;
}
#banner.home-banner {
min-height: 40vw;
}


/* ICON BG */
.icon-bg {
position: relative;
overflow: hidden;
}
.icon-bg::after {
content: "";
display: block;
width: 75%;
max-width: clamp(400px, calc(25rem + ((1vw - 7.68px) * 34.7222)), 800px);
height: clamp(400px, calc(25rem + ((1vw - 7.68px) * 34.7222)), 800px);
position: absolute;
right: -5%;
bottom: -20%;
background-image: url('/wp-content/uploads/pmd-icon.svg');
background-repeat: no-repeat;
background-position: left top;
background-size: cover;
opacity: 0.5;
}
.icon-bg > .wp-block-group {
position: relative;
z-index: 1;
}


/* ACCORDION */

.gutena-accordion-block > .gutena-accordion-block__panel > .gutena-accordion-block__panel-title {
padding: 0 0 7px !important;
border-bottom: 1px solid var(--wp--preset--color--secondary);
}
.gutena-accordion-block > .gutena-accordion-block__panel.active > .gutena-accordion-block__panel-title {
border-bottom-color: var(--wp--preset--color--primary);
}
.gutena-accordion-block > .gutena-accordion-block__panel > .gutena-accordion-block__panel-title > .gutena-accordion-block__panel-title-inner h6 {
font-size: var(--wp--preset--font-size--x-small);
font-weight: 700;
text-transform: uppercase;
}
.gutena-accordion-block > .gutena-accordion-block__panel > .gutena-accordion-block__panel-content {
font-size: var(--wp--preset--font-size--x-small);
line-height: inherit;
}


/* TESTIMONIALS */

.testimonials .wp-block-outermost-icon-block .icon-container {
margin-left: -10px;
}
.wp-block-cb-carousel .slick-slide {
overflow: hidden;
padding-left: 0;
padding-right: 0;
}
.slick-dots {
text-align: left;
margin-left: -10px;
}
.slick-dots li {
width: 8px;
height: 8px;
margin: 0 10px;
}
.slick-dots li button {
width: 8px;
height: 8px;
padding: 0;
}
.slick-dots li button::before {
font-size: 8px;
color: var(--wp--preset--color--secondary);
width: 8px;
height: 8px;
}
.slick-dots li.slick-active button::before {
opacity: 1;
color: var(--wp--preset--color--secondary);
}


/* COOKIE CONTENT */

.cky-btn-revisit-wrapper {
background: var(--wp--preset--color--secondary) !important;
}
.cky-cookie-audit-table th {
color: var(--wp--preset--color--secondary) !important;
}
.cky-cookie-audit-table th, .cky-cookie-audit-table tr:nth-child(2n+1) td {
background-color: transparent !important;
border-color: var(--wp--preset--color--secondary) !important;
font-size: var(--wp--preset--font-size--x-small) !important;
}
.cky-audit-table-element h3 {
font-size: var(--wp--preset--font-size--small);
font-weight: bold;
}


/* FOOTER */

#site-footer {
font-size: 90%;
}
#site-footer #footer-logo .icon-container {
width: clamp(200px, calc(12.5rem + ((1vw - 7.68px) * 8.6806)), 300px) !important;
}
#site-footer #pmd path {
fill: var(--wp--preset--color--base);
}
#site-footer .wp-block-social-links.is-style-logos-only .wp-social-link svg {
height: 30px;
width: 30px;
margin-bottom: -4px;
}
.footer-details .icon-container {
height: 25px;
}
.footer-text .ld::before {
content: "";
background-image: url("https://lawrencedavis.co.uk/wp-content/uploads/LD-icon.svg");
background-repeat: no-repeat;
background-size: contain;
display: inline-block;
width: 12px;
height: 9px;
margin: 0 7px 0 0;
vertical-align: baseline;
filter: brightness(0) saturate(100%) invert(59%) sepia(6%) saturate(912%) hue-rotate(140deg) brightness(92%) contrast(89%);
}


/* MEDIA */

@media screen and (min-width: 782px) {
.top-details.wp-block-group {
margin-block-end: -3em !important;
}
div.form-row {
display: flex;
gap: 1rem;
}
div.form-row .input-group {
-ms-flex-preferred-size: 0;
flex-basis: 0;
-webkit-box-flex: 1;
-ms-flex-positive: 1;
flex-grow: 1;
}
.static-content {
position: static;
z-index: 1;
}
}

@media screen and (min-width: 1201px) {
.wp-block-navigation .has-child .wp-block-navigation__submenu-container {
-webkit-transition: all .5s ease-in-out;
transition: all .5s ease-in-out;
top: 60px;
}
.wp-block-navigation .has-child .wp-block-navigation-submenu__toggle[aria-expanded="true"] ~ .wp-block-navigation__submenu-container {
top: 100%;
}
nav.main-nav.wp-block-navigation .wp-block-navigation__submenu-container {
margin-top: 0.5em;
left: 50% !important;
margin-left: -105px;
border: 0;
box-shadow: 0 1px 15px rgba(0,0,0,.1);
min-width: 180px !important;
padding: 0 10px;
}
.main-nav.wp-block-navigation .wp-block-navigation__submenu-container > li:not(:last-child) {
border-bottom: 1px solid var(--wp--preset--color--tertiary);
}
.main-nav.wp-block-navigation .wp-block-navigation__submenu-container > li > a {
color: var(--wp--preset--color--secondary);
text-align: center;
justify-content: center;
padding: 0.9em 1em;
}
.main-nav.wp-block-navigation .wp-block-navigation__submenu-container > li > a:hover {
color: var(--wp--preset--color--primary);
}
}

@media screen and (max-width: 1200px) {
.wp-block-navigation__responsive-container-open svg {
transform: scaleX(1.8) scaleY(1.1);
pointer-events: all;
}
      
/* mobile viewport */
.wp-block-navigation__responsive-container-open:not(.always-shown) {
display: flex !important;
}
.wp-block-navigation__responsive-container:not(.hidden-by-default):not(.is-menu-open) .wp-block-navigation__responsive-container-close {
display:block;
}
.wp-block-navigation__responsive-container:not(.hidden-by-default):not(.is-menu-open) { 
display:none;
}
.wp-block-navigation .has-child .wp-block-navigation-submenu__toggle[aria-expanded="false"] ~ .wp-block-navigation__submenu-container {
position: absolute;
visibility: hidden;
opacity: 0;
height: 0;
width: auto;
display: none;
}
.wp-block-navigation .has-child .wp-block-navigation-submenu__toggle[aria-expanded="true"] ~ .wp-block-navigation__submenu-container {
display: block;
opacity: 1;
overflow: visible;
visibility: visible;
width: 95%;
height: auto;
}
/* end mobile viewport */
	
.main-nav.wp-block-navigation:not(.has-background) .wp-block-navigation__responsive-container.is-menu-open {
background-color: #1c2a30e3;
color: var(--wp--preset--color--base);
padding: 30px;
margin: auto;
max-width: 100%;
box-sizing: border-box;
-webkit-backdrop-filter: blur(10px);
backdrop-filter: blur(10px);
}
#site-header ul.wp-block-navigation__container {
max-width: 300px;
margin: 2rem auto 0;
width: 100%;
text-align: left;
gap: 0;
position: relative;
z-index: 1000;
}
ul.wp-block-navigation__container > .wp-block-navigation-item {
border-bottom: 1px solid #ffffff45;
width: 100%;
}
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation-item__content {
padding: 1em 0;
width: 100%;
}
.wp-block-navigation-item.open-on-click .wp-block-navigation-submenu__toggle + .wp-block-navigation__submenu-icon {
display: block;
margin: 0 0.3em;
position: absolute;
right: 0;
top: 20px;
height: 0.8em;
width: 0.8em;
color: var(--wp--preset--color--secondary);
-webkit-transition: all 0.2s ease-in-out;
transition: all 0.2s ease-in-out;
}
}

@media screen and (max-width: 781px) {
#header-main {
padding-top: 10px !important;
}
#header-main .top-details {
justify-content: center;
}
.invert {
order: -1;
}
.wp-block-buttons.is-content-justification-right, .wp-block-outermost-icon-block.items-justified-right {
justify-content: flex-start !important;
}
#banner {
min-height: 300px;
}
.ratio figure {
aspect-ratio: 3/2 !important;
}
.gutena-testimonial-block .tns-outer {
position: relative;
max-width: 85vw;
}
#footer-logo .icon-container {
margin: 0 auto;
}
#footer-details .wp-block-group {
justify-content: center;
}
#footer-details p.has-text-align-right {
text-align: center;
}
}