/**
 * Theme Name: Idaho Webmaster v4 - Elementor Blocks
 * Template: Webmaster-v4
 * Description: The Blocks to use and edit for making any changes to a specific site.
 * Author: White Whale Web
 * Author URI: https://whitewhaleweb.com/
 * Version: 1.0.1
 * Text Domain: webmaster-bs4 Elementor blocks
 */


/*--------------------------------------------------------------
# 1. Featured Services Long Start
--------------------------------------------------------------*/


:root {
  --color-sidebar: #F2F1E7;      /* Sidebar / panel backgrounds */
  --color-links: #005C8F;        /* Links / buttons / accents */
  --color-cta: #394600;          /* CTA sections (same as links) */
  --color-icons: #DDE377;        /* Icons / highlights */
  --color-meta: #B1C3F7;         /* Meta / subtext / info boxes */
  --color-misc: #A85061;         /* Decorative / miscellaneous */
  --color-white: #FFFFFF;        /* White / background */
  --color-text: #000000;         /* Primary text color */
  --color-bg: #FFFEF1;           /* Page background */
}

.featured-services-long .e-con-inner {
	gap:20px!important;
}

.featured-services-long .featured-services-long-card {
    background-color: #E8E7C2; /* light beige background */
    padding: 60px 30px!important;
/*     max-width: 320px; */
    margin: 0 auto;
	gap: 20px;
	display: flex;
    text-align: center;
}

.featured-services-long .featured-services-long-card img,
.featured-services-long .featured-services-long-card svg {
    width: 60px;
    height: auto;
    margin-bottom: 25px;
}

.featured-services-long .featured-services-long-card h3 {
    font-size: 40px!important;
    font-weight: 700;
    color: #3C3C3C;
    margin-bottom: 20px;
}

.featured-services-long .featured-services-long-card p {
    font-size: 16px;
    line-height: 1.6;
    color: #3C3C3C;
    margin-bottom: 35px;
}

.featured-services-long .featured-services-long-card .cta-button {
    display: inline-block;
    background-color: #30758D!important;
    color: #fff!important;
    padding: 12px 30px;
    border-radius: 6px;
    text-decoration: none;
    font-weight: 600;
	font-size: 20px!important;
}
/*--------------------------------------------------------------
# 1. Featured Services Long End
--------------------------------------------------------------*/



/*--------------------------------------------------------------
# 1. 4-col GRID SMALL Start
--------------------------------------------------------------*/
/* GRID WRAPPER */
.icon-box-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 25px;
    margin: 40px 0;
	width: 820px !important;
    max-width: 100%;
    margin-left: auto !important;
    margin-right: auto !important;
    justify-content: center;
    align-items: center;
}


/* CARD STYLING */
.icon-box-grid .icon-box-card {
    background-color: #394600; /* teal background */
    padding: 15px 20px!important;
    text-align: center;
    display: flex;
	margin: 0px auto!important;
    flex-direction: column;
    align-items: center;
    justify-content: center;
	width: 100%;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.icon-box-grid  .elementor-icon-box-wrapper {
	gap: 10px;
}

.icon-box-grid .elementor-element {
	margin: 0px auto!important
}

/* ICON */
.icon-box-grid .icon-box-card img,
.icon-box-grid .icon-box-card svg {
    width: 30px;
    height: auto;
    margin-bottom: 10px;
    filter: brightness(0) invert(100%); /* make icons light */
}

/* TITLE */
.icon-box-grid .icon-box-card h3 {
    color: #F1F1D2; /* light beige text */
    font-size: 20px!important;
    font-weight: 700;
    margin: 0;
    line-height: 1.3;
}

/* OPTIONAL - On Hover */
.icon-box-grid .icon-box-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 6px 18px rgba(0,0,0,0.15);
}


/*--------------------------------------------------------------
# 1. 4-col GRID End
--------------------------------------------------------------*/






/*--------------------------------------------------------------
# x. CTA LEFT ICON
--------------------------------------------------------------*/


.cta-section-elementor-left-icon {
    background-color: var(--color-cta)!important;
    margin: 50px 0px;
	padding-left:0px!important;
	padding-right: 0px!important;
}

.cta-section-elementor-left-icon p {
    color: #fff!important;
    margin-bottom: 30px!important
}

.cta-section-elementor-left-icon .elementor-element{
    gap: 0px;
}

.cta-section-elementor-left-icon h4 {
    margin-bottom: 10px;
	font-size: 30px!important;
	color: #fff!important;
    margin-top:0px!important;
	color: var(--color-white)!important;
}

.cta-section-elementor-left-icon a.elementor-button.elementor-button-link.elementor-size-sm {
    background: #fff!important;
    color: #04639F!important
}

a.elementor-button.elementor-button-link.elementor-size-sm:hover {
	background: #394600!important;
		color: #fff!important;
}

a.elementor-button.elementor-button-link.elementor-size-sm {
	 background: #005C8F!important;
	color: #fff!important;
}

.cta-section-elementor-left-icon a.elementor-button.elementor-button-link.elementor-size-sm:hover {
    background: #04639F!important;
    color: #fff!important
}

/* Mobile CTA-Left */


@media (max-width: 768px) {
    .cta-section-elementor-left-icon .elementor-element {
        padding-left: 20px!important;
        padding-right: 20px!important;
        gap: 10px;
    }
    .cta-section-elementor-left-icon img {
        padding-top: 50px;
        width: 40%!important;
        margin-bottom:30px;
    }
    .cta-section-elementor-left-icon a.elementor-button.elementor-button-link.elementor-size-sm {
        margin-bottom: 50px;
    }
}
/*--------------------------------------------------------------
# x. CTA LEFT ICON ENDS
--------------------------------------------------------------*/





/*--------------------------------------------------------------
# x. 4 FEATURED BOXES START
--------------------------------------------------------------*/



.nolinkstyle {
    gap: 0px!important
}

a:hover:not(.elementor-button):not(.nounderline) {
    text-decoration: none;
    font-style: normal;
    text-transform: none;
}

a.nounderline {
    text-decoration: none !important;
    font-size:20px
}

.nolinkstyle h5{
    margin-top: 0px!important;
    
}

.four-boxes .featured-button h5.elementor-heading-title.elementor-size-default {
    color: #fff!important;
    font-size: 20px!important;
    margin-top: 0px!important;
    padding: 5px 0px;
}

.four-boxes .featured-button {
    background:#005C8F!important;
}

.four-boxes .featured-button:hover {
	background:#394600!important;
}

@media (max-width: 767px) {
    .four-boxes .featured-button {
        margin-bottom: 20px;
    }
}

a.e-con:hover .featured-button {
    background-color: #394600 !important;
    color: #fff;
}

.four-boxes .elementor-element {
    gap:0px!important;
    column-gap: 20px !important;
}

.four-boxes .fetaured-box {
	height: 190px;
}
/*--------------------------------------------------------------
# x. 4 FEATURED BOXES END
--------------------------------------------------------------*/





/*--------------------------------------------------------------
# x. CTA TOP ICON START
--------------------------------------------------------------*/


.cta-top-icon-vertical .cta-full-text {
    margin-bottom: 110px!important;
}


.cta-top-icon-vertical .elementor-widget-button .elementor-button {
   padding-top: 12px!important;
    padding-bottom: 12px!important;
	background: #005C8F!important
}
.cta-top-icon-vertical .elementor-widget-button .elementor-button:hover {
    color: #fff!important;
    background: #000!important
}

}
.cta-top-icon-vertical .elementor-button:hover .elementor-button-text {
    color: #fff !important;
}

@media (max-width: 767px) {
    .cta-top-icon-vertical .cta-full-text {
        margin-bottom: 50px !important;
    }
}


/*--------------------------------------------------------------
# x. CTA TOP ICON END
--------------------------------------------------------------*/




/*--------------------------------------------------------------
# x. ALERT STARTS
--------------------------------------------------------------*/


.attention-cta {
    background: #257916
}

.attention-cta-text p {
    color: #fff !important;
    font-size: 24px !important;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    margin-bottom: 0px;
}

@media (max-width: 767px) {
    .attention-cta-text p {
        display: grid;
        justify-content: center;
        align-items: center;
        text-align: center;
        line-height: 1.2em;
    }
    .attention-cta {
        padding: 40px!important;
    }
    i.fa-sharp.fa-solid.fa-triangle-exclamation {
        margin: 0px!important;
    }
    strong {
        margin-top: 20px!important
    }
}


/*--------------------------------------------------------------
# x. ALERT ENDS
--------------------------------------------------------------*/



/*--------------------------------------------------------------
# 13A. HOMEPAGE ANNOUNCEMENTS GRID STARTS
--------------------------------------------------------------*/

.custom-post-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 30px;
  margin-top: 30px;
}
@media (max-width: 990px) {
  .custom-post-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
    gap: 30px;
    margin-top: 30px;
  }
}

.custom-post-item {
  background: #fff;
  border-radius: 4px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.custom-post-thumb img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 4px;
}

.custom-post-meta {
  font-size: 0.9em;
  color: var(--color-links);
  margin: 10px 0 5px;
}

.custom-post-title {
  font-size: 1.1em;
  font-weight: 700;
  margin: 0 0 20px;
}

h3.custom-post-title {
	line-height: 1.2em;
}

.custom-post-title a {
  color: #276099;
  text-decoration: none;
	font-size:20px;
	line-height: 1.2em
}

.custom-post-title a:hover {
  color: var(--color-links);
  font-style: normal;
}

.custom-post-excerpt {
  font-size: 0.95em;
  line-height: 1.6;
  color: var(--color-text);
  margin-bottom: auto;
}

.custom-learn-more {
  display: inline-block;
  margin-top: 30px;
  padding: 7px 50px;
  background-color: var(--color-links);
  color: var(--color-white);
  font-weight: bold;
  border-radius: 4px;
  text-align: center;
  font-size: 20px;
  text-decoration: none;
  width: 220px;
}

.custom-learn-more:hover {
  background-color: var(--color-text);
	text-decoration: none;
	font-style: normal;
	color: var(--color-white)!important;
}

.page-id-19066 h3.custom-post-title {
	margin-top: 0px;
	margin-bottom: 20px;
}

.page-id-19066 .custom-post-meta {
	margin: 10px 0 0px;
}

/* Homepage Announcement Button Group */
.home-page-grp-buttons a.wp-block-button__link.wp-element-button{
	padding: 7px 50px!important;
	background: var(--color-cta)!important;
	border-radius: 4px;
}

.home-page-grp-buttons a.wp-block-button__link.wp-element-button:hover{
	padding: 7px 50px!important;
	background: var(--color-text)!important;
	border-radius: 4px;
}

.wp-block-buttons.is-content-justification-left {
    justify-content: flex-start;
	gap: 20px!important;
}
	

/*--------------------------------------------------------------
# 13A. HOMEPAGE ANNOUNCEMENTS GRID ENDS
--------------------------------------------------------------*/


/*--------------------------------------------------------------
# 13C. HOMEPAGE EVENTS CALENDAR STARTS
--------------------------------------------------------------*/

/* Homepage Events General Layout */
.homepage-events {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.homepage-events a.tribe-events-calendar-list__event-title-link.tribe-common-anchor-thin {
    font-size: 30px!important;
}

.homepage-events .tribe-events-calendar-list__event-description p {
    color: var(--color-text) !important;
    font-size: 1.0em !important
}

.homepage-events .tribe-common--breakpoint-medium.tribe-common .tribe-common-l-container {
    padding-left: 0px !important;
    padding-right: 0px !important
}

.homepage-events .tribe-common--breakpoint-medium.tribe-events .tribe-events-calendar-list__event-row {
    margin-bottom: 50px
}

.homepage-events .tribe-events-calendar-list__event-date-tag {
    min-width: 200px !important;
    height: 200px;
}

/* Event Item Layout */
.event-item {
    display: grid;
    grid-template-columns: 150px 1fr 240px;
    align-items: stretch;
    gap: 4rem!important;
    background: #fff;
    padding: 1rem 0rem;
}

.event-item {
    display: grid;
    grid-template-columns: 150px 1fr 295px;
    align-items: stretch;
    gap: 1.5rem;
    background: #fff;
    padding: 1rem 0rem;
}

/* Event Date Box */
.event-date {
    background-color: var(--color-misc);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-white);
    border-radius: 4px;
    padding: 0.5rem;
    text-align: center;
    height: 190px;
    width: 190px;
}

.event-date-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    line-height: 1.2;
}

.event-date .month {
    font-weight: 400;
    font-size: 1.5rem;
    text-transform: uppercase;
}

.event-date .day {
    font-size: 3.12rem;
    font-weight: 900;
}

.event-date .year {
    font-size: 1rem;
    opacity: 0.9;
}

/* Optional: alternate color by index */
.event-item:nth-child(1) .event-date { background-color: var(--color-misc); }

/* Event Content */
.event-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.event-title {
    font-weight: 700;
    font-size: 1.25rem;
    margin-bottom: 10px;
}

.event-title a {
    color: var(--color-text);
    text-decoration: none!important;
    font-weight: 700 !important;
    font-size: 1.5rem!important;
}

.event-title a:hover {
    text-decoration: none;
    font-style: normal;
}

.event-datetime {
    font-size: 1.5rem!important;
    color: var(--color-text);
    margin-bottom: 0rem;
}

.event-excerpt {
    font-size: 1rem;
    color: var(--color-text);
}

/* Event Venue */
p.event-venue {
    display: flex;
    gap: 4px;
    color: var(--color-links);
}

a.event-venue-link:hover {
    font-style: normal
}

a.event-more-link {
    color: var(--color-links);
}

a.event-more-link:hover {
    font-style: normal;
}

/* Event Image */
.event-image {
    border-radius: 4px;
    overflow: hidden;
    height: 190px;
}

.event-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* View All Events Button */
.view-all-events {
    text-align: left;
}

.btn-view-all-events {
    display: inline-block;
    background-color: var(--color-links);
    color: var(--color-white) !important;
    font-weight: 700;
    font-size: 20px;
    color: var(--color-white);
    padding: 7px 50px;
    border-radius: 4px;
    text-decoration: none;
    transition: background-color 0.3s ease;
}

.btn-view-all-events:hover {
    background-color: var(--color-text);
    text-decoration: none;
    font-style: normal;
    color: var(--color-white)!important
}

/* Homepage Events Responsive */
@media (max-width: 768px) {
    .view-all-events {
        text-align: center;
    }

    .event-item {
        grid-template-columns: 1fr;
        text-align: center;
        display: block
    }

    .event-image {
        order: -1;
    }
	.archive .entry-header {
    display: flex;
    flex-direction: column;
}
	.custom-blog-page nav{
		padding: 0px;
	}
}

.search #content {
	background: transparent;
}

.fa-search:hover {
	text-decoration: none!important
}

@media (max-width: 767px) {
    .event-date {
        background-color: var(--color-misc);
        display: flex;
        align-items: center;
        justify-content: center;
        color: var(--color-white);
        border-radius: 4px;
        padding: 0.5rem;
        text-align: center;
        height: 150px;
        width: 150px;
        margin: 30px auto;
    }

    .event-excerpt {
        margin-bottom:30px;
    }

    .event-image {
        height: 190px;
        width: 295px;
        margin: 0 auto;
    }

    p.event-venue {
        display: flex;
        gap: 4px;
        color: var(--color-links);
        margin: 10px auto;
    }

    a.event-venue-link {
        display: block;
        margin: 0 auto;
    }
}


/*--------------------------------------------------------------
# 13C. HOMEPAGE EVENTS CALENDAR ENDS
--------------------------------------------------------------*/



/*--------------------------------------------------------------
# 13C. NEWS AND ALERTS START
--------------------------------------------------------------*/

.custom-news-alerts-wrapper {
    display: flex;
    flex-direction: column;
    gap: 40px;
    margin-top: 30px;
}

.custom-news-alerts-item {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 20px;
}

.custom-news-image {
    flex: 0 0 250px;
    max-width: 250px;
}

.custom-news-image img.news-thumb {
    width: 100%;
    height: auto;
    border-radius: 6px;
    object-fit: cover;
}

.custom-news-content {
    flex: 1;
}

.custom-news-title {
    margin-top: 0;
    font-size: 1.25em!important;
    font-weight: 600;
	margin-bottom: 10px;
	color: var(--color-links)!important
}

.custom-news-meta {
    font-size: 1rem;
    color: #0056a3;
    margin-bottom: 10px;
}

.custom-news-meta a {
    color: #0056a3;
    margin-left: 10px;
    text-decoration: underline!important;
    font-weight: 500;
	text-transform: uppercase;
	font-size: 1rem
}
.custom-news-meta a:hover {
	text-transform: uppercase!important;
}

.custom-news-excerpt {
    font-size: 0.95rem;
    line-height: 1.6;
    margin-bottom: 1rem;
}

.cta-text-left h2 {
    font-size: 1.87rem;
}

.custom-news-excerpt a {
    font-weight: 100;
    font-size: 0.85rem;
	text-decoration: underline!important;
    color: #0056a3;
}

.custom-news-button {
    display: inline-block;
    background-color: #005C8F;
    color: white;
    font-weight: 600;
    padding: 8px 50px;
    text-align: center;
    text-decoration: none;
    border-radius: 4px;
    font-size: 1.25em;
    transition: background 0.3s ease;
	width: max-content;
}

.custom-news-button a {
	color: #fff;
	text-decoration: none;
}

.custom-news-button a:hover {
	color: #fff!important;
	font-style: normal;
	text-decoration: none
} 

.custom-news-button:hover {
   background: var(--color-cta)!important;
	color: var(--color-white)!important;
	font-style: normal;
	text-decoration: none
		
}

/* 📱 Responsive Adjustments */
@media (max-width: 768px) {
    .custom-news-alerts-item {
        flex-direction: column;
        align-items: center;
    }

    .custom-news-image, .custom-news-content {
        max-width: 100%;
        flex: 1 1 100%;
    }

    .custom-news-button {
        width: 100%;
        text-align: center;
    }
	
	.elementor-slide-description h3 {
		font-size: 18px;
		 white-space: normal;
  word-wrap: break-word;
  overflow-wrap: break-word;
	}
	.elementor-slide-description {
		width: 100%!important
	}
	.swiper-slide-inner {
		padding: 10%!important;
	}
	
	 #colophon {
        padding: 0px 0;
        background-size: cover;
        background-position: center;
        height: 700px!important;
    }
	
	.footer-navigation ul {
		padding-left: 0px!important
	}
	
}

@media (max-width: 480px) {
    #colophon {
        padding: 0px 0;
        background-size: cover;
        background-position: center;
        height: 700px!important;
    }
}

#mega-menu-wrap-primary 
#mega-menu-primary 
li.mega-menu-item-has-children > a.mega-menu-link > span.mega-indicator::after {
  content: "\f0d7"; /* fa-caret-down */
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  font-size: 18px!important;
  display: inline-block;
  margin-left: 4px;
	margin-top: -2px;
  vertical-align: middle;
  transition: transform 0.25s ease;
}

#header-search::placeholder {
  color: #000;
  opacity: 1; /* Firefox */
}

#header-search::-webkit-input-placeholder {
  color: #000;
}

#header-search:-ms-input-placeholder {
  color: #000;
}

#header-search::-ms-input-placeholder {
  color: #000;
}

/* Input font */
#s-1 {
  font-family: "Atkinson Hyperlegible", Atkinson, sans-serif;
}

/* Placeholder text */
#s-1::placeholder {
  color: #000;
  opacity: 1; /* Firefox */
  font-family: "Atkinson Hyperlegible", Atkinson, sans-serif;
}

#s-1::-webkit-input-placeholder {
  color: #000;
  font-family: "Atkinson Hyperlegible", Atkinson, sans-serif;
}

#s-1:-ms-input-placeholder {
  color: #000;
  font-family: "Atkinson Hyperlegible", Atkinson, sans-serif;
}

#s-1::-ms-input-placeholder {
  color: #000;
  font-family: "Atkinson Hyperlegible", Atkinson, sans-serif;
}

#mega-menu-wrap-primary 
#mega-menu-primary 
li.mega-menu-item-has-children.mega-toggle-on 
> a.mega-menu-link 
> span.mega-indicator::after {
  content: "\f0d8"; /* fa-caret-up */
}

/*--------------------------------------------------------------
# 13C. NEWS AND ALERTS END
--------------------------------------------------------------*/

/*--------------------------------------------------------------
# 14C. HOME SLIDER START
--------------------------------------------------------------*/

.home-slider-full {
    width: 100vw !important;          /* take full viewport width */
    max-width: 100vw !important;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;               /* pull left edge */
    margin-right: -50vw;              /* pull right edge */
}

.home-slider-full .elementor.elementor .e-con>.elementor-widget{
width: 100vw !important;          /* take full viewport width */
    max-width: 100vw !important;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;               /* pull left edge */
    margin-right: -50vw;
}


.elementor-4932 .elementor-element.elementor-element-48a787e {
    width: 100vw !important;
    max-width: 100vw !important;
    position: relative!important;
    left: 50%!important;
    right: 50%!important;
    margin-left: -50vw!important;
    margin-right: -50vw!important;
}

.elementor-slide-description {
	width: 820px;
	
	
}

.elementor-slide-description h2 {
	margin-bottom: 10px;
	color: var(--color-icons);
	font-size: 40px!important
}

.swiper-slide-inner .elementor-button {
	padding: 8px 50px;
	font-size: 20px;
	background: var(--color-icons)!important;
	border-radius: 4px!important;
	border: none!important;
	color: var(--color-cta)!important;
}

.swiper-slide-inner .elementor-button:hover {
	background: var(--color-white)!important;
	color: var(--color-text);
}

/*--------------------------------------------------------------
# 14C. HOME SLIDER END
--------------------------------------------------------------*/



/* HEADER SEARCH BAR */

.modal-body .fa-search {
	color: #005C8F!important;
	font-size: 30px
}

.site-branding .fa-search {
	color: #005C8F!important;
	font-size: 30px;
	margin-top: 1px;
}

.search-toggle {
	background: none;
}

.search-bar-wrapper {
    background: var(--color7);
    padding: 10px 20px;
    border: 1px solid #EDEDED;
}

.modal-body .input-group {
    width: 100%;
    height: 60px!important;
}

.custom_header_search .search-submit i{
	font-size: 30px!important;
	margin-top: 3px;
}

.page-id-4900 .sidebars {
	display: none!important;

}
	
.page-id-4900 div#primary {
	width: 100%
}

/* TABLEPRESS */

.tablepress>:where(thead,tfoot)>tr>* {
	background: #A85061!important
}
