/*-----------------------------------------------------------------------------------

	Klient:			Zahrady Chudomel
	Tier:			T1 Standard
	Postavil:		Riverlab (riverlab.cz)
	Verze:			1.0
	Dodáno:			Červen 2026

-----------------------------------------------------------------------------------

	OBSAH

	01. Hero sekce
	02. O nás
	03. Naše služby (karuselové karty)
	04. Statistiky
	05. Proč si vybrat nás
	06. Naše práce (project karty)
	07. Instagram feed
	08. Poptávkový formulář
	09. Patička – layout a Riverlab badge

-----------------------------------------------------------------------------------*/

/* ZAČÁTEK: 01. Hero sekce */
/* brand logo links and texts in header */
.brand-logo-link {
    text-decoration: none;
}
.brand-logo-text {
    font-size: 20px;
    font-weight: 800;
    color: #084c22;
    text-transform: uppercase;
    font-family: 'Inter Tight', sans-serif;
    letter-spacing: -0.5px;
}
.header-phone-custom {
    font-weight: 700;
    color: #084c22;
    margin-right: 20px;
    gap: 8px;
    font-family: 'Inter Tight', sans-serif;
    font-size: 16px;
    text-decoration: none;
}
.phone-icon-green {
    color: #8bb82d;
}
.svg-background-enable {
    enable-background: new 0 0 16 12.7;
}
.hero-btn-wrap {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}
/* KONEC: 01. Hero sekce */

/* ZAČÁTEK: 02. O nás */
/* text and descriptions in O nás section */
.about-subtitle {
    font-size: 20px;
    font-weight: 600;
    display: block;
    color: #8bb82d;
    margin-top: 10px;
    text-transform: none;
    line-height: 1.4;
}
.about-desc {
    margin-bottom: 30px;
}
/* KONEC: 02. O nás */

/* ZAČÁTEK: 03. Naše služby (karuselové karty) */
/* Jednotná výška karet služeb v swiper carouselu */
        .service-carousel .swiper-slide {
            height: auto;
        }
        .service-carousel .service-item {
            height: 100%;
            display: flex;
            flex-direction: column;
            justify-content: space-between;
        }
        .service-carousel .service-item .content {
            flex-grow: 1;
        }
        /* Barva ikony při najetí myší */
        .service-item .content .icon svg {
            transition: color 0.3s ease, fill 0.3s ease, stroke 0.3s ease;
        }
        .service-item:hover .content .icon svg {
            color: #C7DC49 !important;
        }
        .service-item:hover .content .icon svg path {
            fill: currentColor;
        }
/* KONEC: 03. Naše služby (karuselové karty) */

/* ZAČÁTEK: 04. Statistiky */
/* KONEC: 04. Statistiky */

/* ZAČÁTEK: 05. Proč si vybrat nás */
/* spacing and checklist items in Proč si vybrat nás section */
.feature-item-spacing {
    margin-bottom: 25px;
}
.feature-item-no-spacing {
    margin-bottom: 0;
}
.feature-img-container {
    height: 100%;
    border-radius: 12px;
    min-height: 250px;
}
.fit-cover {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.feature-row-spacing {
    margin-top: 35px !important;
}
.feature-checklist {
    list-style: none;
    padding-left: 0;
    margin-bottom: 0;
}
.feature-checklist-item {
    color: #fff;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-family: 'Inter Tight', sans-serif;
    font-size: 16px;
}
.feature-checklist-item-spacing {
    margin-bottom: 15px;
}
.feature-checklist-item-no-spacing {
    margin-bottom: 0;
}
.feature-checklist-icon {
    color: #C7DC49;
    margin-top: 4px;
}
/* KONEC: 05. Proč si vybrat nás */

/* ZAČÁTEK: 06. Naše práce (project karty) */
/* Úpravy sekce Naše práce */
        .project-carousel-custom {
            width: 100%;
            overflow: hidden;
        }
        .project-carousel-custom .swiper-slide {
            height: auto;
        }
        .project-card {
            cursor: default;
            display: flex;
            flex-direction: column;
            justify-content: space-between;
            height: 100%;
            padding: 32px 32px 32px;
            transition: all 0.3s ease-in-out;
        }
        .project-card:hover {
            background-color: var(--cp-color-heading-primary); /* #084c22 */
        }
        .project-card .title {
            transition: color 0.3s ease-in-out;
            margin-top: 0;
            margin-bottom: 20px;
        }
        .project-card:hover .title {
            color: #ffffff !important;
        }
        .project-card .process-item {
            background: transparent;
            padding: 0;
            border-radius: 0;
            height: auto;
            margin-bottom: 20px;
        }
        .project-card:hover .process-item span {
            color: #ffffff !important;
            border-color: #ffffff !important;
        }
        .project-card .process-item span {
            transition: color 0.3s ease-in-out, border-color 0.3s ease-in-out;
        }
        .project-divider {
            border-bottom: 1px solid rgba(16, 85, 31, 0.2);
            margin-top: 20px;
            margin-bottom: 20px;
            width: 100%;
            transition: border-color 0.3s ease-in-out;
        }
        .project-card:hover .project-divider {
            border-color: rgba(255, 255, 255, 0.2);
        }
        .project-quote-text {
            font-family: 'Inter Tight', sans-serif;
            font-size: 15px;
            line-height: 1.6;
            font-style: italic;
            font-weight: 400;
            padding: 0;
            margin-bottom: 10px;
            color: #444;
            transition: color 0.3s ease-in-out;
        }
        .project-quote-text img {
            width: 22px;
            height: auto;
            float: left;
            margin-right: 10px;
            margin-top: 4px;
            transition: filter 0.3s ease-in-out;
        }
        .project-card:hover .project-quote-text {
            color: #e9f3ef !important;
        }
        .project-card:hover .project-quote-text img {
            filter: brightness(0) invert(1) opacity(0.9);
        }
        .project-author-line {
            font-family: 'Inter Tight', sans-serif;
            font-size: 14px;
            font-weight: 500;
            color: #666;
            transition: color 0.3s ease-in-out;
        }
        .project-author-line .name {
            color: #084c22;
            font-weight: 600;
            transition: color 0.3s ease-in-out;
        }
        .project-author-line .loc {
            color: #666;
            transition: color 0.3s ease-in-out;
        }
        .project-card:hover .project-author-line {
            color: rgba(255, 255, 255, 0.6) !important;
        }
        .project-card:hover .project-author-line .name {
            color: #ffffff !important;
        }
        .project-card:hover .project-author-line .loc {
            color: #b5cbc5 !important;
        }
        .project-badge {
            background-color: var(--cp-color-theme-primary);
            color: #fff;
            display: inline-block;
            padding: 3px 8px;
            font-size: 11px;
            font-weight: 700;
            border-radius: 4px;
            text-transform: uppercase;
            margin-bottom: 8px;
            font-family: 'Inter Tight', sans-serif;
            letter-spacing: 0.5px;
        }
        .project-img-wrap {
            position: relative;
            border-radius: 8px;
            overflow: hidden;
            height: 180px;
            border: 1px solid rgba(0,0,0,0.05);
        }
/* additional classes for project section background and layouts */
.project-section-custom {
    background: #f7f9f6;
}
.project-top-custom {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 50px;
    flex-wrap: wrap;
    gap: 30px;
}
.photo-row-spacing {
    margin-bottom: 20px;
}
.color-inherit {
    color: inherit;
}
/* KONEC: 06. Naše práce (project karty) */

/* ZAČÁTEK: 07. Instagram feed */
/* Styling Instagram sekce */
        .instagram-post-card {
            display: block;
            width: 100%;
            text-decoration: none;
        }
        .instagram-post-card .post-img {
            position: relative;
            width: 100%;
            aspect-ratio: 1 / 1;
            overflow: hidden;
            border-radius: 12px;
            box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
            background-color: #e5ece9;
        }
        .instagram-post-card .post-img img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            transition: transform 0.4s ease;
        }
        .instagram-post-card .post-overlay {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: rgba(16, 85, 31, 0.5);
            display: flex;
            align-items: center;
            justify-content: center;
            opacity: 0;
            transition: opacity 0.3s ease;
        }
        .instagram-post-card .post-overlay i {
            color: #ffffff;
            font-size: 32px;
            transform: scale(0.8);
            transition: transform 0.3s ease;
        }
        .instagram-post-card:hover .post-img img {
            transform: scale(1.08);
        }
        .instagram-post-card:hover .post-overlay {
            opacity: 1;
        }
        .instagram-post-card:hover .post-overlay i {
            transform: scale(1);
        }
/* spacing adjustments for instagram section heading */
.instagram-heading-spacing {
    margin-bottom: 50px;
}
/* KONEC: 07. Instagram feed */

/* ZAČÁTEK: 08. Poptávkový formulář */
/* Vylepšení poptávkového formuláře */
        .consult-section {
            z-index: 2 !important;
        }
        .consult-contact-content {
            background-color: #ffffff !important;
            box-shadow: 0 10px 45px rgba(0, 0, 0, 0.08) !important;
            overflow: visible !important;
            border-radius: 12px !important;
        }
        .consult-contact-content .nice-select.form-control {
            background-color: #ffffff !important;
            border: 1px solid #b5cbc5 !important;
            border-radius: 12px !important;
            height: 56px !important;
            padding: 0 24px !important;
            display: flex !important;
            align-items: center !important;
            width: 100% !important;
            color: #555 !important;
        }
        .consult-contact-content .nice-select.form-control.open {
            z-index: 999 !important;
        }
        .consult-contact-content .nice-select.form-control::after {
            right: 24px !important;
        }
        .consult-contact-content .nice-select.form-control .list {
            border-radius: 12px !important;
            border: 1px solid #b5cbc5 !important;
            box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15) !important;
            width: 100% !important;
            background-color: #ffffff !important;
            z-index: 999 !important;
        }
        .consult-contact-content .nice-select.form-control .option {
            padding-left: 24px !important;
            padding-right: 24px !important;
            line-height: 40px !important;
            min-height: 40px !important;
        }
        /* Úpravy tlačítka Odeslat */
        .submit-btn {
            color: #ffffff !important;
            font-weight: 700 !important;
            transition: all 0.3s ease-in-out !important;
            border-radius: 0 0 12px 12px !important;
        }
        .submit-btn:hover, .submit-btn:focus, .submit-btn:active {
            color: #ffffff !important;
            background-color: var(--cp-color-heading-primary) !important;
        }
        /* Úpravy nadpisu a popisu formuláře */
        .consult-contact-content .contact-title {
            margin-bottom: 12px !important;
        }
        .consult-contact-content .contact-description {
            font-family: var(--cp-ff-body) !important;
            font-size: 15px !important;
            font-weight: 400 !important;
            color: var(--cp-color-text-body) !important;
            line-height: 1.6 !important;
            margin-bottom: 32px !important;
        }
/* sub-heading and GDPR checkbox formatting in poptávkový formulář */
.sub-heading-spacing {
    margin-bottom: 15px;
}
.gdpr-row-spacing {
    margin-top: 15px;
    margin-bottom: 15px;
}
.gdpr-form-check {
    display: flex;
    align-items: flex-start;
    gap: 10px;
}
.gdpr-checkbox {
    width: 20px;
    height: 20px;
    margin-top: 2px;
    border: 1px solid rgba(16, 85, 31, 0.2);
    border-radius: 4px;
    cursor: pointer;
    flex-shrink: 0;
}
.gdpr-label {
    font-size: 14px;
    color: #555;
    cursor: pointer;
    line-height: 1.4;
    font-family: 'Inter Tight', sans-serif;
    font-weight: 500;
    user-select: none;
}
/* KONEC: 08. Poptávkový formulář */

/* ZAČÁTEK: 09. Patička – layout a Riverlab badge */
/* Velikost loga v patičce */
        .newsletter-wrap .newsletter-logo {
            font-size: 140px !important;
        }
        @media (max-width: 1399px) {
            .newsletter-wrap .newsletter-logo {
                font-size: 120px !important;
            }
        }
        @media (max-width: 1199px) {
            .newsletter-wrap .newsletter-logo {
                font-size: 100px !important;
            }
        }
        @media only screen and (max-width: 992px) {
            .newsletter-wrap .newsletter-logo {
                font-size: 80px !important;
            }
        }
        @media only screen and (max-width: 767px) {
            .newsletter-wrap .newsletter-logo {
                font-size: 55px !important;
            }
        }
        /* Vzor listů na pozadí patičky */
        .footer-1 .footer-wrapper .bg-img {
            background-image: url('../img/shapes/footer-leaf-pattern.png') !important;
            background-repeat: repeat !important;
            background-size: 1200px auto !important;
            background-position: center !important;
            opacity: 0.03 !important;
        }
        /* Pozadí CTA sekce */
        .footer-top .bg-img {
            background-image: url('../img/bg-img/footer-bg.jpg') !important;
            background-size: cover !important;
            background-position: center !important;
        }
        /* Dvousloupcový layout Kontaktu */
        .footer-widget .footer-list-wrap {
            display: flex !important;
            flex-wrap: nowrap !important;
            justify-content: flex-start !important;
            gap: 48px !important;
        }
        .footer-widget .footer-list-wrap .address-list:first-child {
            flex: 1 1 40% !important;
            min-width: 0 !important;
        }
        .footer-widget .footer-list-wrap .address-list:last-child {
            flex: 1 1 60% !important;
            min-width: 0 !important;
        }
        /* Riverlab badge */
        .rl-badge {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            text-decoration: none !important;
            color: rgba(255, 255, 255, 0.75) !important;
            font-size: 11px;
            font-weight: 400;
            letter-spacing: 0.02em;
            opacity: 0.65 !important;
            transition: opacity 0.2s ease, color 0.2s ease;
        }
        .rl-badge:hover {
            opacity: 1 !important;
            color: #a68bff !important;
        }
        .rl-badge svg { flex-shrink: 0; fill: currentColor; }
        /* Zarovnání copyright řádku */
        .copyright-area .copyright-content {
            justify-content: flex-start !important;
            gap: 72px !important;
        }
        @media (min-width: 1200px) {
            .copyright-area .copyright-content {
                display: grid !important;
                grid-template-columns: 60.2% 1fr !important;
                align-items: center !important;
            }
            .copyright-area .copyright-content .social-list {
                padding-left: 24px !important;
                margin-left: 0 !important;
            }
        }
/* brand logo, copyright formatting, and logo image in footer */
.footer-logo-link {
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.footer-logo-icon {
    width: 20px;
    height: auto;
}
.brand-logo-text-footer {
    font-size: 22px;
    font-weight: 400;
    color: #fff;
    font-family: 'Inter Tight', sans-serif;
    letter-spacing: -0.5px;
    white-space: nowrap;
}
.copyright-text-container {
    display: inline-flex;
    align-items: center;
    gap: 15px;
    flex-wrap: wrap;
}
.margin-zero {
    margin: 0;
}
/* KONEC: 09. Patička – layout a Riverlab badge */

/* Custom additions for logo image & running text styling */
.brand-logo-link {
    display: inline-flex !important;
    align-items: center !important;
    gap: 12px !important;
    text-decoration: none !important;
}

/* Header logo icon styling */
.header-logo .brand-logo-img {
    height: 52px !important; /* visual proportion */
    width: auto !important;
    object-fit: contain !important;
}

/* Sidebar and Mobile logo icon styling */
.side-menu-logo .brand-logo-img,
.side-menu-head .brand-logo-img {
    height: 40px !important;
    width: auto !important;
    object-fit: contain !important;
}

/* Override theme hardcoded margins on header logo img */
.header .primary-header-inner .header-logo img {
    margin: 0 !important;
}

/* Align brand logo link inside absolute header-logo container */
.header-logo {
    left: 0 !important;
    bottom: 0 !important;
    height: 92px !important;
}
.header-logo .brand-logo-link {
    height: 100% !important;
    padding-left: 32px !important;
}

/* Reduce text font size slightly in header logo to prevent overflow */
.header-logo .brand-logo-text {
    font-size: 19px !important;
    white-space: nowrap !important;
}

/* Prevent white background bleeding around header-logo */
.header .primary-header-inner {
    background: linear-gradient(108.7deg, transparent 208px, var(--cp-color-common-white) 208px) !important;
}

@media (max-width: 992px) {
    /* Reset linear-gradient on mobile/tablet view when logo is hidden or stack changes */
    .header .primary-header-inner {
        background: var(--cp-color-common-white) !important;
    }
}

.hero-section .running-text {
    width: 100% !important;
    left: 0 !important;
    overflow: hidden !important;
}
.hero-section .running-text ul {
    gap: 80px;
}
@media only screen and (max-width: 767px) {
    .hero-section .running-text ul {
        gap: 40px;
    }
}

/* Footer contact section alignment fix (CSS Grid) */
.footer-widget .footer-contact-wrap {
    display: block !important;
}
.footer-widget .footer-contact-grid {
    display: grid !important;
    grid-template-columns: 42% 1fr !important;
    column-gap: 30px !important;
    row-gap: 24px !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}
.footer-widget .footer-contact-grid li {
    margin-bottom: 0 !important;
}
@media (max-width: 480px) {
    .footer-widget .footer-contact-grid {
        grid-template-columns: 1fr !important;
        row-gap: 20px !important;
    }
}


