/*
Theme Name: mipTheme 12.0.0 AI
Theme URI: https://www.myitplanet.de
Author: Anonymous
Author URI: https://www.myitplanet.de
Description: mipTheme 2025.
Version: 12.0.0
License: GNU General Public License v2 o7r later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Tags: black,
Text Domain: miptheme

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned with others.
*/

:root {
    --mip-primary: #0c7081;
    --mip-primary-rgb: 12, 112, 129;
    --bs-primary: #0c7081;
    --bs-primary-rgb: 12, 112, 129;
}

.text-custom-primary {
    color: var(--mip-primary) !important;
}

.bg-custom-primary-soft {
    background-color: rgba(var(--mip-primary-rgb), 0.1) !important;
}

/* Bootstrap Color Overrides */
.btn-primary {
    --bs-btn-bg: var(--mip-primary);
    --bs-btn-border-color: var(--mip-primary);
    --bs-btn-hover-bg: #095966;
    --bs-btn-hover-border-color: #095966;
}

.btn-outline-primary {
    --bs-btn-color: var(--mip-primary);
    --bs-btn-border-color: var(--mip-primary);
    --bs-btn-hover-bg: var(--mip-primary);
    --bs-btn-hover-border-color: var(--mip-primary);
}

.bg-primary {
    background-color: var(--mip-primary) !important;
}

.text-primary {
    color: var(--mip-primary) !important;
}

.hover-shadow {
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.3s ease;
}

.hover-shadow:hover {
    transform: translateY(-8px);
    box-shadow: 0 1.5rem 4rem rgba(12, 112, 129, 0.15) !important;
}

.hover-scale {
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.card:hover .hover-scale {
    transform: scale(1.08);
}

.object-fit-cover {
    object-fit: cover;
}

/* Pagination Styling */
.pagination,
.navigation.pagination {
    margin-top: 3rem;
    margin-bottom: 3rem;
    display: block;
    /* Overwrite flex from bootstrap if applied to nav */
}

.pagination .nav-links,
.navigation.pagination .nav-links {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.pagination .page-numbers,
.navigation.pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 45px;
    height: 45px;
    padding: 0 0.5rem;
    border-radius: 12px;
    background-color: #fff;
    color: var(--mip-primary);
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
    font-weight: 600;
    border: 1px solid rgba(0, 0, 0, 0.05);
}

.pagination .page-numbers.current,
.navigation.pagination .page-numbers.current {
    background-color: var(--mip-primary);
    color: white;
    box-shadow: 0 8px 20px rgba(var(--mip-primary-rgb), 0.3);
    border-color: var(--mip-primary);
}

.pagination .page-numbers:hover:not(.current):not(.dots),
.navigation.pagination .page-numbers:hover:not(.current):not(.dots) {
    background-color: #f8f9fa;
    transform: translateY(-3px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    color: var(--mip-primary);
}

.pagination .page-numbers.dots,
.navigation.pagination .page-numbers.dots {
    background: transparent;
    box-shadow: none;
    border: none;
    color: #adb5bd;
}

.pagination .page-numbers i,
.navigation.pagination .page-numbers i {
    font-size: 1.2rem;
}

.screen-reader-text {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
    word-wrap: normal !important;
}



/* Glassmorphism Navbar */
.navbar-glass {
    background: rgba(255, 255, 255, 0.7) !important;
    backdrop-filter: blur(12px) saturate(180%);
    -webkit-backdrop-filter: blur(12px) saturate(180%);
    border-bottom: 1px solid rgba(255, 255, 255, 0.3);
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

.navbar-glass .nav-link {
    font-weight: 500;
    color: #333 !important;
    transition: color 0.3s ease;
}

.navbar-glass .nav-link:hover {
    color: var(--mip-primary) !important;
}

.navbar-glass .navbar-brand {
    font-weight: 700;
    color: #000 !important;
}


/* Base Styles improvements */
body {
    background-color: #f4f7f8;
    color: #2d3436;
}

/* Hero Section Responsiveness */
.custom-hero-ratio {
    --bs-aspect-ratio: 56.25%;
    /* 16:9 for mobile */
}

@media (min-width: 992px) {
    .custom-hero-ratio {
        --bs-aspect-ratio: 33.333%;
        /* ~21:7 or 3:1 for desktop */
    }
}


.lead-alternate {
    font-size: 1.15rem;
    line-height: 1.8;
    font-weight: 400;
}

/* Expandable Search */
.expandable-search {
    position: relative;
    display: flex;
    align-items: center;
}

.search-form {
    position: relative;
    display: flex;
    align-items: center;
    background: rgba(255, 255, 255, 0.4);
    border-radius: 50px;
    padding: 5px;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    border: 1px solid rgba(0, 0, 0, 0.05);
}

.search-input {
    width: 0;
    border: none;
    outline: none;
    background: none;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    padding: 0;
    font-size: 0.9rem;
    color: #333;
}

.search-submit {
    background: none;
    border: none;
    color: var(--mip-primary);
    padding: 5px 10px;
    cursor: pointer;
    font-size: 1.1rem;
    transition: transform 0.3s ease;
}

.expandable-search:hover .search-form,
.expandable-search:focus-within .search-form {
    width: 240px;
    background: #fff;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
    border-color: var(--mip-primary);
    padding-left: 15px;
}

.expandable-search:hover .search-input,
.expandable-search:focus-within .search-input {
    width: 100%;
    padding: 0 10px;
}

.expandable-search:hover .search-submit {
    transform: scale(1.1);
}

@media (max-width: 991.98px) {
    .expandable-search {
        width: 100%;
        margin-top: 1rem;
    }

    .search-form {
        width: 100% !important;
        background: #fff;
        padding-left: 15px;
    }

    .search-input {
        width: 100% !important;
        padding: 0 10px;
    }
}