/* 
Theme Name: KLG Estate Planning
Theme URI: https://github.com/elementor/hello-theme-child/
Description: Custom child theme for KLG Estate Planning
Author: Elementor Team
Author URI: https://elementor.com/
Template: hello-elementor
Version: 2.0.0
Text Domain: klg-estate-planning
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
*/

/* Add your custom styles here */



/*----- Header -----*/
.top-menu ul li {
padding-right: 15px;
padding-left: 15px;
}

/* Submenu styling */
.top-menu .sub-menu {
opacity: 0;
visibility: hidden;
transform: translateX(-50%) translateY(30px);
transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
box-shadow: 0 20px 100px rgba(0,0,0,0.1);
}

/* Show submenu on hover */
.top-menu li.menu-item-has-children:hover > .sub-menu,
.top-menu li.menu-item-has-children.elementor-item-active > .sub-menu {
opacity: 1;
visibility: visible;
transform: translateX(-50%) translateY(0);
}

/* Small arrow on submenu */
.top-menu .sub-menu:before {
content: "";
position: absolute;
top: -2px;
left: 50%;
width: 12px;
height: 12px;
background-color: #fff;
transform: rotate(45deg) translateX(-50%);
box-shadow: -3px -3px 5px rgba(0,0,0,0.04);
z-index: 999;
}

/* Header Arrows */
span.sub-arrow {
position: absolute;
left: -23px;
padding: 0 !important;
}

/* Main Header Default Style */
.main-header {
background-color: transparent !important;
background-image: linear-gradient(
to bottom,
rgb(0 0 0 / 0.7) 0%,
#fff0 100%
);
}

/* Smooth Transition for Both Headers */
.main-header,
.sub-header {
transition: all 0.4s ease;
}

/* Sub Header Default (Hidden) */
.sub-header {
position: fixed !important;
width: 100%;
top: -120px;
left: 0;
opacity: 0;
z-index: 9999;
}

/* Home Page: Team Name Squares */
.team-name .elementor-heading-title:before,
.team-box .elementor-heading-title:before {
content: "";
width: 16px;
height: 16px;
position: absolute;
top: -63px;
}

.team-name .elementor-heading-title:before {
background-color: #87b09f;
left: 0;
}

.team-box .elementor-heading-title:before {
background-color: #b98d33;
left: 0;
}

.team-name .elementor-heading-title:after,
.team-box .elementor-heading-title:after {
content: "";
width: 16px;
height: 16px;
position: absolute;
top: -54px;
left: 8px;
background-color: #384359;
}

/* Consultation Form Button */
.consultation-form button.elementor-button.elementor-size-sm {
box-shadow: 0 8px 0 #d4bb9a;
margin-top: 5px;
}
.gform-theme--foundation .gform_fields {
        row-gap: 25px !important;
    }
.consultation-form .gform_button{
    box-shadow: 0 8px 0 #d4bb9a !important;
    margin-top: 5px !important;
    outline: 0px !important;
}

/* Remove all Gravity Forms theme focus outlines for buttons */
.gform-theme.gform-theme--framework.gform_wrapper input.gform_button:focus,
.gform-theme.gform-theme--framework.gform_wrapper button.gform_button:focus {
    outline: none !important;
    border-color: inherit !important;
}
.gform_button:hover {
    text-decoration: none !important;
    -webkit-transform: translateY(-4px) !important;
    transform: translateY(-4px) !important;
    transition: 0.3s ease !important;
}
.ginput_container.ginput_container_text input {
    outline: 0px !important;
}

/* Team Member Column Layout */
.team-cont {
column-count: 3;
column-gap: 100px;
column-rule: 1px solid #ddd;
}

.team-cont p,
.team-cont h2 {
break-inside: avoid;
}

/* Blog Hover Effect */
.hov-ani {
transition: all 0.3s ease;
}
.hov-ani:hover {
transform: translateY(-5px);
}

/* Author Block */
.author-block a {
display: flex !important;
flex-direction: column !important;
}
.author-block .elementor-icon-list-icon {
display: block !important;
margin-bottom: 6px;
}
.author-block .elementor-icon-list-text {
display: block !important;
}
.author-block .elementor-post-info__item-prefix {
color: #000 !important;
}

/* Post Author */
.post-author-style li[itemprop="author"] a {
color: #fff !important;
font-weight: 700 !important;
}
.post-author-style li[itemprop="author"] .elementor-post-info__item-prefix {
font-weight: 400 !important;
}

/* Blog Page Previous/Next Navigation */
.archive-blog a.page-numbers,
.blog-navigation a.page-numbers {
font-weight: 700;
color: #111;
display: inline-block;
padding: 8px 15px;
border: 1px solid rgba(0,0,0,.2);
text-decoration: none;
}

.archive-blog nav.elementor-pagination {
border-top: 1px solid rgba(0,0,0,.1);
border-bottom: 1px solid rgba(0,0,0,.1);
display: flex;
justify-content: flex-start;
align-items: center;
padding: 13px 15px;
gap: 2px;
}

.blog-navigation nav.elementor-pagination {
border-top: 1px solid rgba(0,0,0,.1);
border-bottom: 1px solid rgba(0,0,0,.1);
display: flex;
justify-content: space-between;
align-items: center;
padding: 15px 20px;
}

.archive-blog .elementor-pagination .page-numbers.dots,
.blog-navigation .elementor-pagination .page-numbers.dots {
padding: 8px 15px;
border: 1px solid !important;
}

.blog-navigation .elementor-pagination .prev.page-numbers:not([href]),
.blog-navigation .elementor-pagination .prev.page-numbers.disabled,
.blog-navigation .elementor-pagination .next.page-numbers:not([href]),
.blog-navigation .elementor-pagination .next.page-numbers.disabled {
visibility: hidden;
pointer-events: none;
}

.archive-blog .elementor-pagination .prev.page-numbers:not([href]),
.archive-blog .elementor-pagination .prev.page-numbers.disabled,
.archive-blog .elementor-pagination .next.page-numbers:not([href]),
.archive-blog .elementor-pagination .next.page-numbers.disabled {
display: none;
}

.archive-blog .elementor-pagination .page-numbers.current,
.blog-navigation .elementor-pagination .page-numbers.current {
border: 1px solid #000;
color: #000;
font-weight: 700;
padding: 8px 15px;
}

.blog-navigation .elementor-loop-container,
.archive-blog .elementor-posts-container {
padding: 0px 20px;
}

/* Archive Posts */
article.elementor-post img {
height: 340px;
object-fit: cover;
}

.archive-blog article.elementor-post {
border: 1px solid #dadada;
background: #fff;
padding: 10px !important;
transition: transform 0.4s ease-in-out, box-shadow 0.4s ease-in-out, border-color 0.4s ease-in-out;
will-change: transform, box-shadow;
}

.archive-blog article.elementor-post:hover {
transform: translateY(-5px);
border-color: #333;
box-shadow: 0 12px 20px rgba(0, 0, 0, 0.12);
}

.archive-blog h3.elementor-post__title a:hover {
color: #96713f;
}

.archive-blog article.elementor-post .elementor-post__text {
transition: inherit;
padding: 30px 30px 32px 30px;
}

.archive-blog .elementor-post-author::before {
content: "By:";
font-weight: 700;
margin-right: 3px;
color: #000 !important;
}

.archive-blog a.elementor-post__read-more {
border-bottom: 3px solid #96713f;
padding-bottom: 2px;
}

.archive-blog .elementor-post__meta-data {
border-top: 1px solid rgba(0,0,0,0.1);
border-bottom: 1px solid rgba(0,0,0,0.1);
padding: 10px 0;
}
/* Practices Page */

/* Default state */
.practice-tiles .elementor-heading-title {
transition: transform 0.4s ease, text-shadow 0.4s ease;
}

.practice-recipes-count .elementor-divider-separator {
transition: opacity 0.4s ease, transform 0.4s ease;
opacity: 1;
transform: scaleX(1);
display: block;
}

.practice-fader:hover .practice-tiles .elementor-heading-title {
transform: translateY(-25px);
text-shadow: 2px 2px 5px rgba(0,0,0,0.8);
}

/* Smoothly fade out the divider instead of hiding instantly */
.practice-recipes-count .elementor-divider {
opacity: 1;
}

.practice-fader:hover .practice-recipes-count .elementor-divider { display: none !important; }


/* Breadcrumb Wrapper */

.breadcrumbs-bar ul {
list-style: none;
margin: 0;
padding: 0;
display: flex;
flex-wrap: wrap;
align-items: center;
}

.breadcrumbs-bar ul li {
display: flex;
align-items: center;
font-size: 13px;
color: #000;
font-weight: 600;
}

.breadcrumbs-bar ul li:not(:last-child)::after {
content: ">";
margin: 0 10px;
color: rgba(0, 0, 0, 0.8);
font-size: 13px;
}

.breadcrumbs-bar ul li a {
text-decoration: none;
color: #000;
transition: color 0.3s ease;
font-weight: 600;
}

.breadcrumbs-bar ul li a:hover {
color: #000;
text-decoration: underline;
}

/* Desktop: 3 columns */
.category-tiles.columns-three {
display: grid !important;
gap: 25px 27px;
grid-template-columns: repeat(3, 1fr) !important;
}

/* Each tile */
.category-tile {
position: relative;
overflow: hidden;
min-height: 351px;
background-repeat: no-repeat;
background-size: cover;
background-position: center;
display: block;
transition: transform 0.4s ease, box-shadow 0.4s ease;
}

/* Overlay */
.category-fader {
position: absolute;
top: 0; left: 0; right: 0; bottom: 0;
background: linear-gradient(to top, rgba(0,0,0,0.25) 60%, rgba(0,0,0,0) 100%);
pointer-events: none;
transition: opacity 0.4s ease;
}

/* Content inside tile */
.category-content {
position: absolute;
bottom: 0; left: 0; right: 0;
padding: 30px;
display: flex;
flex-direction: column;
align-items: flex-start;
justify-content: flex-end;
gap: 15px;
z-index: 2;
}

/* Title */
.category-title {
color: #fff;
font-size: 39px;
font-weight: 600;
line-height: 44px;
text-shadow: 1px 1px 3px rgba(0,0,0,0.4);
transition: transform 0.4s ease, text-shadow 0.4s ease;
}

/* Count */
.category-count {
color: #fff;
font-size: 13px;
line-height: 13px;
padding: 5px 8px;
border: 2px solid #fff;
border-radius: 4px;
opacity: 1;
transition: opacity 0.4s ease, transform 0.4s ease;
}

/* Hover effects */
.category-tile:hover {
transform: scale(1.05);
box-shadow: 0 10px 20px rgba(0,0,0,0.2);
}

.category-tile:hover .category-title {
transform: translateY(-25px);
text-shadow: 2px 2px 5px rgba(0,0,0,0.8);
}

.category-tile:hover .category-count {
opacity: 0;
}

.client-say .elementor-testimonial-content {
    padding: 42px;
    background-color: #fff;
    box-shadow: 1px 1px 4px rgb(0 0 0 / .1);
    border-radius: 6px
}

.client-say .elementor-testimonial-meta.elementor-has-image.elementor-testimonial-image-position-aside {
    padding: 0px 40px;
}

.client-say .elementor-testimonial-content {
    margin-bottom: 13px !important;
}

/*---- password test page -----*/
form.post-password-form {
    max-width: 100% !important;
    margin: 0px;
    padding: 30px;
    background-color: #eeeeee;
    font-size: 16px;
}

form.post-password-form label {
    display: flex;
    justify-content: start;
    align-items: center;
    gap: 10px;
}

form.post-password-form input[type="submit"] {
    padding: 10px 25px;
    border: none;
    background-color: #343a8a;
    color: #fff;
    font-size: 14px;
    border-radius: 4px;
}
.e-n-tabs-heading{
    display:none !important;
}



/*post-button-box*/
.post-button-box {
    background-color: #f0f0f0;
    border-color: #0000;
    box-shadow: 0 5px 0 #d4d4d4;
    color: #666;
    border-radius: 5px;
    border: 1px solid #0000;
    font-size: 1em;
    word-wrap: break-word;
    text-align: center;
	padding:28px;
}

h3.estate-checklist-dl.pum-trigger {
    color: rgb(135, 176, 160);
    cursor: pointer;
    font-weight: 700;
}

/* ---------------- Media Queries ---------------- */
@media (max-width: 1024px) {
.team-cont { column-count: 2; }
.category-tiles.columns-three {
grid-template-columns: repeat(2, 1fr) !important;
gap: 20px !important;
}
.category-title {
font-size: 33px;
line-height: 40px;
}
.category-count {
padding: 2px 8px;
}
.category-tile {
min-height: 310px;
}
.category-content {
gap: 20px
}
}

@media (max-width: 767px) {
.team-cont { column-count: 1; }

.category-tiles.columns-three {
grid-template-columns: repeat(2, 1fr) !important;
gap: 30px !important;
}
.elementor-image-box-content {
    display: none;
}
}

@media (max-width: 425px) {
.client-say .elementor-testimonial {
display: flex !important;
flex-direction: column-reverse !important;
}
.category-tiles.columns-three {
grid-template-columns: 1fr !important;
}
}