/* ====================================================================
   Site overrides – ekstrahirano iz layouts/app.blade.php
   Theme-zavisne varijable (:root, gradient overlays, logo filter)
   ostaju inline u layoutu jer ovise o config/theme.php izboru.
   ==================================================================== */

/* === Sticky header (uvijek vidljiv na vrhu) === */
html { scroll-padding-top: 90px; }
header.main-header {
    position: sticky;
    top: 0;
    z-index: 200;
    background: var(--white-color);
    box-shadow: 0 2px 14px rgba(45, 36, 64, 0.08);
}
header.main-header .header-sticky {
    position: relative !important;
    top: 0 !important;
    transform: none !important;
    background: transparent !important;
    box-shadow: none !important;
    border-radius: 0 !important;
}
header.main-header .header-sticky.hide {
    transform: none !important;
}

/* === Globalne unifikacije === */
.section-title h3::before { display: none !important; }
.section-title h3 { padding-left: 0 !important; }

.our-services    { background-image: none !important; }
.main-footer     { background-image: none !important; }
.our-appointment { background-image: none !important; }

.bg-section { background-color: var(--soft-bg-color); }
.bg-section.dark-section { background-color: var(--secondary-color); }

h1, h2, h3, h4, h5, h6,
.section-title h1, .section-title h2, .section-title h3,
.section-title .sub-heading {
    color: var(--secondary-color);
}
.dark-section h1, .dark-section h2, .dark-section h3,
.dark-section h4, .dark-section h5, .dark-section h6,
.dark-section .section-title h1,
.dark-section .section-title h2,
.dark-section .section-title h3,
.dark-section .section-title .sub-heading {
    color: var(--white-color);
}

.header-contact-now i,
.header-contact-now svg {
    background-color: var(--primary-color) !important;
    color: var(--white-color);
    fill: var(--white-color);
}
.header-contact-now:hover i,
.header-contact-now:hover svg {
    background-color: var(--secondary-color) !important;
}

/* Active nav link */
.navbar-nav .nav-item .nav-link.active { color: var(--primary-color) !important; }

/* Mobile (slicknav) menu hover/focus – glowix postavlja primary na primary bg pa nestaje */
.slicknav_nav a:hover,
.slicknav_nav a:focus,
.slicknav_nav a:active,
.slicknav_nav .slicknav_row:hover,
.slicknav_nav .slicknav_row:focus {
    color: var(--secondary-color) !important;
    background-color: transparent !important;
}

/* === Global btn-default hover — arrow circle + slide fill = secondary === */
.btn-default:hover::before { background-color: var(--secondary-color) !important; }
.btn-default:hover::after  { background: var(--secondary-color) !important; }
/* btn-highlighted zadržava bijeli hover (light CTA na tamnoj pozadini) */
.btn-default.btn-highlighted:hover::before { background-color: var(--white-color) !important; }
.btn-default.btn-highlighted:hover::after  { background: var(--white-color) !important; }

/* btn unutar tamnih kartica (about-us-body, services-cta-box, service-cta-bottom) */
.about-us-body .btn-default:hover,
.services-cta-box .btn-default:hover,
.service-cta-bottom .btn-default:hover { color: var(--secondary-color) !important; }
.about-us-body .btn-default:hover::after,
.services-cta-box .btn-default:hover::after,
.service-cta-bottom .btn-default:hover::after { background: var(--white-color) !important; }
.about-us-body .btn-default:hover::before,
.services-cta-box .btn-default:hover::before,
.service-cta-bottom .btn-default:hover::before { background-color: var(--primary-color) !important; }

/* === Unified inner-page header === */
.page-header {
    position: relative;
    padding: 0;
    background-color: var(--secondary-color);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    overflow: hidden;
    text-align: center;
    margin: 0;
    border-radius: 0;
    max-width: none;
    width: 100%;
    height: 60vh;
    min-height: 460px;
    display: flex;
    align-items: center;
}
.page-header > .container { width: 100%; }
.page-header .row { justify-content: center; }
.page-header .page-header-box {
    color: #fff;
    max-width: 880px;
    margin: 0 auto;
}
.page-header .page-header-box .sub-heading {
    display: block !important;
    color: var(--primary-color) !important;
    font-size: 13px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 14px;
}
.page-header h1 {
    display: block !important;
    color: #fff !important;
    font-size: 50px;
    line-height: 1.15;
    margin: 0 0 18px;
    padding: 0;
}
.page-header .page-header-box > p { color: rgba(255,255,255,.9); font-size: 17px; line-height: 1.6; max-width: 700px; margin: 0 auto 22px; }
.page-header .breadcrumb { margin: 0; background: transparent; padding: 0; justify-content: center; }
.page-header .breadcrumb-item,
.page-header .breadcrumb-item a { color: rgba(255,255,255,.85); }
.page-header .breadcrumb-item.active { color: var(--primary-color); }
.page-header .breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,.6); }

@media (max-width: 768px) {
    .page-header {
        height: auto;
        min-height: 0;
        padding: 100px 0 60px;
    }
    .page-header h1 { font-size: 32px; }
}

/* === Service cards: equalize heights and tidy "Saznajte više" === */
.our-services .service-item { display: flex; flex-direction: column; }
.our-services .service-content { display: flex; flex-direction: column; flex-grow: 1; }
.our-services .service-content > p { flex-grow: 1; }
.our-services .service-image { margin-top: auto; }

/* Cijela service kartica = link */
.service-item-link {
    display: block;
    text-decoration: none;
    color: inherit;
}
.service-item-link:hover { color: inherit; text-decoration: none; }
.service-item-link .service-content-title h2 { transition: color .2s ease; }
.service-item-link:hover .service-content-title h2 { color: var(--primary-color); }
.service-item-link .service-image figure { overflow: hidden; border-radius: 30px; }
.service-item-link .service-image img { transition: transform .5s ease-out; }
.service-item-link:hover .service-image img { transform: scale(1.06); }

/* === Generic bottom spacer prije footera === */
.page-bottom-spacer { height: 80px; display: block; }
@media (max-width: 768px) {
    .page-bottom-spacer { height: 40px; }
}

/* === Reusable sidebar (service-detail, /faq...) === */
.page-single-sidebar { position: sticky; top: 100px; display: flex; flex-direction: column; gap: 20px; }
@media (max-width: 991px) { .page-single-sidebar { position: static; } }

.sidebar-block {
    background: var(--soft-bg-color);
    border-radius: 16px;
    padding: 26px 28px;
}
.sidebar-block h3 {
    margin: 0 0 18px;
    font-size: 18px;
    font-weight: 600;
    color: var(--secondary-color);
    padding-bottom: 14px;
    border-bottom: 1px solid var(--divider-color);
}
.sidebar-services ul { list-style: none; padding: 0; margin: 0; }
.sidebar-services ul li + li { margin-top: 4px; }
.sidebar-services ul li a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 11px 14px;
    border-radius: 10px;
    color: var(--secondary-color);
    text-decoration: none;
    font-weight: 500;
    font-size: 15px;
    transition: background .2s ease, color .2s ease;
}
.sidebar-services ul li a i {
    font-size: 12px;
    opacity: .4;
    transition: transform .2s ease, opacity .2s ease, color .2s ease;
}
.sidebar-services ul li a:hover {
    background: #fff;
    color: var(--primary-color);
}
.sidebar-services ul li a:hover i { opacity: 1; transform: translateX(3px); color: var(--primary-color); }
.sidebar-services ul li a.active {
    background: var(--primary-color);
    color: #fff;
}
.sidebar-services ul li a.active i { opacity: 1; color: #fff; }

.sidebar-contact-list { list-style: none; padding: 0; margin: 0; }
.sidebar-contact-list li {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 15px;
    color: var(--secondary-color);
    padding: 6px 0;
}
.sidebar-contact-list li + li { border-top: 1px solid var(--divider-color); }
.sidebar-contact-list li .ico {
    flex: 0 0 36px;
    width: 36px; height: 36px;
    border-radius: 50%;
    background: #fff;
    color: var(--primary-color);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
}
.sidebar-contact-list li a {
    color: var(--secondary-color);
    text-decoration: none;
    transition: color .2s ease;
}
.sidebar-contact-list li a:hover { color: var(--primary-color); }

/* === Reusable FAQ accordion (service-detail, /faq) === */
.page-single-faqs { margin-top: 0; }
.page-single-faqs .section-title { margin-bottom: 24px; }
.page-single-faqs .faq-accordion .accordion-item {
    margin-bottom: 14px;
    padding-bottom: 14px;
}
.page-single-faqs .faq-accordion .accordion-item:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
}
.page-single-faqs .faq-accordion .accordion-button {
    font-size: 21px;
    line-height: 1.45;
    padding-top: 14px;
    padding-bottom: 14px;
    color: var(--secondary-color) !important;
    font-weight: 600;
}
.page-single-faqs .faq-accordion .accordion-button:not(.collapsed) {
    color: var(--secondary-color) !important;
    padding-bottom: 8px;
}
.page-single-faqs .faq-accordion .accordion-button::after {
    color: var(--secondary-color) !important;
}
.page-single-faqs .faq-accordion .accordion-body { line-height: 1.65; padding-top: 6px; }

/* === Privola checkbox + form alerti === */
.form-privola { margin: 4px 0 18px; font-size: 14px; line-height: 1.5; color: var(--secondary-color); }
.form-privola-label { display: flex; gap: 10px; align-items: flex-start; cursor: pointer; color: inherit; }
.form-privola input[type="checkbox"] { margin-top: 3px; flex: 0 0 16px; accent-color: var(--primary-color); }
.form-privola a { color: var(--primary-color); font-weight: 600; text-decoration: underline; }
.form-privola a:hover { color: var(--secondary-color); }
.form-privola .text-danger { color: #c83d3d; }

/* Forma na tamnoj pozadini (kontakt) – privola treba bijeli tekst */
.contact-form .form-privola,
.contact-form .form-privola-label,
.contact-form .form-privola span { color: #fff !important; }
.contact-form .form-privola a { color: var(--primary-color) !important; }
.contact-form .form-privola a:hover { color: #fff !important; }

.form-alert {
    padding: 14px 18px;
    border-radius: 12px;
    font-size: 15px;
    margin-bottom: 20px;
}
.form-alert-success { background: #e8f5e9; color: #1b5e20; border: 1px solid #c8e6c9; }
.form-alert-error   { background: #fdecea; color: #b71c1c; border: 1px solid #f5c6cb; }
.form-validation-list { margin: 6px 0 0 1.2rem; padding: 0; font-size: 14px; }
