/*
 * ═══════════════════════════════════════════════════════════════
 *  modern-ui.css  —  YAGONA FAYL (global + navbar + sections)
 *  UzAeronavigation Training Complex
 *
 *  Fayl joyi:  static/complex/css/modern-ui.css
 *
 *  base.html da qo'llash tartibi:
 *    1. style.css          (mavjud — o'zgartirmang)
 *    2. float-button.css   (mavjud — o'zgartirmang)
 *    3. custom/navbar.css  — BU FAYLNI O'CHIRIB TASHLANG ← (endi kerak emas)
 *    4. modern-ui.css      ← SHU FAYLNI QO'SHING (barcha overrides shu yerda)
 *
 *  Ya'ni base.html da:
 *    <link rel="stylesheet" href="{% static 'complex/css/style.css' %}">
 *    <link rel="stylesheet" href="{% static 'complex/css/float-button.css' %}">
 *    <!-- custom/navbar.css ni O'CHIRING -->
 *    <link rel="stylesheet" href="{% static 'complex/css/modern-ui.css' %}">
 *
 *  TUZILMA:
 *   §1  CSS Variables
 *   §2  Global (body, scrollbar, focus)
 *   §3  Third-party overrides (tox, grecaptcha, modal-footer)
 *   §4  Typography helpers (.p, label required)
 *   §5  Animations (carousel, hero fade, fadeUp keyframe)
 *   §6  Navbar — full custom dropdown system
 *   §7  Buttons
 *   §8  Form controls
 *   §9  Hero section
 *   §10 About intro
 *   §11 Section headings
 *   §12 Service cards
 *   §13 Course categories — glassmorphism
 *   §14 Course cards (project-wrap)
 *   §15 Enroll form (login-wrap)
 *   §16 Counter section
 *   §17 Gallery / testimony carousel
 *   §18 Blog cards
 *   §19 Footer
 *   §20 Modals
 *   §21 Scroll-to-top button (JS creates it)
 *   §22 Responsive breakpoints
 * ═══════════════════════════════════════════════════════════════
 */


/* ══════════════════════════════════════════════════════════════
   §1  CSS VARIABLES
   ══════════════════════════════════════════════════════════════ */
:root {
    /* Brand palette */
    --c-blue:          #4986fc;
    --c-blue-dark:     #1d4ed8;
    --c-blue-light:    rgba(73, 134, 252, 0.14);
    --c-blue-glow:     rgba(73, 134, 252, 0.35);
    --c-green:         #22c55e;
    --c-green-dark:    #16a34a;
    --c-accent:        #38bdf8;        /* sky-blue highlight */

    /* Glassmorphism */
    --glass-white:     rgba(255, 255, 255, 0.10);
    --glass-white-md:  rgba(255, 255, 255, 0.18);
    --glass-border:    rgba(255, 255, 255, 0.22);
    --glass-blur:      blur(16px);
    --glass-blur-sm:   blur(8px);

    /* Cards */
    --card-radius:     18px;
    --card-shadow:     0 4px 28px rgba(0, 0, 0, 0.07);
    --card-hover:      0 16px 48px rgba(73, 134, 252, 0.20);

    /* Buttons */
    --btn-radius:      14px;

    /* Navbar */
    --nav-link:        #fff;
    --nav-link-hover:  #4986fc;
    --nav-active-line: red;
    --dd-bg:           #1a1a2e;
    --dd-hover:        rgba(73, 134, 252, 0.12);
    --dd-border:       rgba(73, 134, 252, 0.25);
    --dd-shadow:       0 8px 32px rgba(0, 0, 0, 0.45);

    /* Transitions */
    --t:               all 0.28s cubic-bezier(0.4, 0, 0.2, 1);
    --t-fast:          all 0.16s ease;
}


/* ══════════════════════════════════════════════════════════════
   §2  GLOBAL
   ══════════════════════════════════════════════════════════════ */
html { scroll-behavior: smooth; }

body {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    background: #f8faff;
    user-select: none;       /* ← mavjud global.css dan */
}

/* Sections */
.ftco-section { padding: 5em 0; }
@media (max-width: 767.98px) { .ftco-section { padding: 3em 0; } }

/* Scrollbar */
::-webkit-scrollbar              { width: 6px; }
::-webkit-scrollbar-track        { background: #f1f5f9; }
::-webkit-scrollbar-thumb        { background: #c7d7f8; border-radius: 3px; }
::-webkit-scrollbar-thumb:hover  { background: var(--c-blue); }

/* Focus ring — a11y */
*:focus-visible {
    outline: 2px solid var(--c-blue);
    outline-offset: 3px;
    border-radius: 6px;
}


/* ══════════════════════════════════════════════════════════════
   §3  THIRD-PARTY OVERRIDES
   ══════════════════════════════════════════════════════════════ */
.tox-promotion-link          { display: none !important; }
.grecaptcha-badge            { display: none; }
.modal-footer:empty          { border-top: none !important; }

#overlay                     { transition: opacity 1s ease-in-out; }
#overlay.previous            { opacity: 0; }

#hero-wrap                   { transition: opacity .8s ease-in-out; }


/* ══════════════════════════════════════════════════════════════
   §4  TYPOGRAPHY HELPERS
   ══════════════════════════════════════════════════════════════ */
.p {
    text-indent: 30px;
    text-align: justify;
    margin: 0;
}

/* Required asterisk on labels */
label.required::after,
label:has(+ input[required])::after,
label:has(+ select[required])::after,
label:has(+ textarea[required])::after {
    content: " *";
    color: red;
    font-weight: bold;
}
.no-required-hint label.required::after,
.no-required-hint label:has(+ input[required])::after,
.no-required-hint label:has(+ select[required])::after,
.no-required-hint label:has(+ textarea[required])::after {
    content: none !important;
}

.form-required-hint {
    margin-top: 10px;
    font-size: 13px;
    color: #666;
    text-align: left !important;
}
.form-required-hint span { color: red; font-weight: bold; }


/* ══════════════════════════════════════════════════════════════
   §5  ANIMATIONS / KEYFRAMES
   ══════════════════════════════════════════════════════════════ */
@keyframes moveSlider {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-100%); }
}
.carousel-testimony          { display: flex; overflow: hidden; }
.carousel-testimony .owl-stage {
    display: flex;
    animation: moveSlider 360s linear infinite;
}

@keyframes fadeUp {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Scroll-reveal class added by modern-ui.js */
.ftco-animate.animated {
    animation: fadeUp 0.55s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}
.ftco-animate.animated:nth-child(1) { animation-delay: 0.05s; }
.ftco-animate.animated:nth-child(2) { animation-delay: 0.12s; }
.ftco-animate.animated:nth-child(3) { animation-delay: 0.19s; }
.ftco-animate.animated:nth-child(4) { animation-delay: 0.26s; }


/* ══════════════════════════════════════════════════════════════
   §6  NAVBAR
   ══════════════════════════════════════════════════════════════ */

/* Container */
#navContainer {
    width: 90%;
    margin: 0 auto;
    padding: 0;
}

/* Brand row (logo + toggler) */
.nav-brand-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

/* Logo */
#logo {
    max-width: 310px;
    height: auto;
    transition: opacity 0.2s ease;
}
@media (max-width: 991.98px) { #logo { max-width: 40%; } }
@media (max-width: 767.98px) { #logo { max-width: 40%; } }
@media (max-width: 575.98px) { #logo { max-width: 45%; } }

/* Nav links base */
.navbar-nav .nav-item .nav-link {
    white-space: nowrap;
    color: var(--nav-link);
    display: inline-block;
    padding: 0.5rem 1rem;
    transition: color var(--t-fast);
}
.navbar-nav .nav-item .nav-link:hover { color: var(--nav-link-hover); }

/* Active underline */
.navbar-nav .nav-item.active > .nav-link::after {
    content: "";
    display: block;
    width: 100%;
    height: 2px;
    background: var(--nav-active-line);
    margin-top: 2px;
}

/* Transparent navbar on top (desktop) */
@media (min-width: 992px) {
    .ftco-navbar-light:not(.scrolled):not(.awake) {
        background-color: rgba(0, 0, 0, 0.4) !important;
    }
}

/* ── Arrow icons ── */
.nav-arrow, .submenu-arrow {
    font-size: 10px;
    margin-left: 3px;
    transition: transform 0.2s ease;
}

/* ── Custom dropdown wrapper ── */
.nav-dropdown          { position: relative; }
.nav-dropdown-toggle   { cursor: pointer; }

/* ── Dropdown menu (shared base for 1st & 2nd level) ── */
.nav-dropdown-menu,
.nav-submenu-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 210px;
    list-style: none;
    margin: 0;
    padding: 6px 0;
    background: var(--dd-bg);
    border: 1px solid var(--dd-border);
    border-radius: 8px;
    box-shadow: var(--dd-shadow);
    z-index: 1050;
    opacity: 0;
    transform: translateY(6px);
    transition: opacity 0.18s ease, transform 0.18s ease;
    pointer-events: none;
}

/* Dropdown links */
.nav-dropdown-menu li a,
.nav-submenu-menu li a {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 9px 18px;
    color: #d0d8f0;
    font-size: 14px;
    text-decoration: none;
    white-space: nowrap;
    transition: background 0.16s, color 0.16s;
}
.nav-dropdown-menu li a:hover,
.nav-submenu-menu li a:hover {
    background: var(--dd-hover);
    color: var(--nav-link-hover);
}
.nav-dropdown-menu li.active > a,
.nav-submenu-menu li.active > a {
    color: var(--nav-link-hover);
    font-weight: 600;
}

/* ── OPEN state — mobile JS .open class ── */
.nav-dropdown.open > .nav-dropdown-menu,
.nav-submenu.open  > .nav-submenu-menu {
    display: block;
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

/* ── DESKTOP — CSS hover ── */
@media (min-width: 992px) {
    .nav-dropdown:hover > .nav-dropdown-menu {
        display: block;
        opacity: 1;
        transform: translateY(0);
        pointer-events: auto;
    }
    /* Hover gap bridge (prevents gap closing menu) */
    .nav-dropdown-menu::before {
        content: "";
        position: absolute;
        top: -8px; left: 0;
        width: 100%; height: 8px;
    }
    /* Arrow rotate on open */
    .nav-dropdown:hover > .nav-dropdown-toggle .nav-arrow {
        transform: rotate(180deg);
    }
}

/* ── Nested submenu ── */
.nav-submenu         { position: relative; }
.nav-submenu-toggle  {
    display: flex !important;
    justify-content: space-between;
    align-items: center;
}

/* Desktop: open to the right */
@media (min-width: 992px) {
    .nav-submenu-menu {
        top: 0;
        left: 100%;
        margin-top: 0;
        margin-left: 2px;
    }
    .nav-submenu:hover > .nav-submenu-menu {
        display: block;
        opacity: 1;
        transform: translateY(0);
        pointer-events: auto;
    }
    /* Hover bridge — left side */
    .nav-submenu-menu::before {
        content: "";
        position: absolute;
        top: 0; left: -8px;
        width: 8px; height: 100%;
    }
    .nav-submenu:hover > .nav-submenu-toggle .submenu-arrow {
        color: var(--nav-link-hover);
    }
}

/* Mobile: submenu stacks below */
@media (max-width: 991.98px) {
    .nav-dropdown-menu {
        position: static;
        box-shadow: none;
        border: none;
        border-left: 2px solid var(--dd-border);
        border-radius: 0;
        margin-left: 1rem;
        background: transparent;
    }
    .nav-submenu-menu {
        position: static !important;
        box-shadow: none;
        border: none;
        border-left: 2px solid var(--dd-border);
        border-radius: 0;
        margin-left: 1rem;
        background: transparent;
        padding: 0;
    }
    .nav-submenu-menu li a { padding: 7px 14px; font-size: 13px; }
}

/* Inline icon images in navbar */
.nav-icon-img { height: 20px; width: auto; border-radius:45%;}


/* ══════════════════════════════════════════════════════════════
   §7  BUTTONS
   ══════════════════════════════════════════════════════════════ */
.btn {
    border-radius: var(--btn-radius) !important;
    padding: 0.55rem 1.7rem;
    font-weight: 600;
    letter-spacing: 0.4px;
    font-size: 14px;
    transition: var(--t) !important;
    position: relative;
    overflow: hidden;
}

/* Shimmer sweep */
.btn::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.22) 50%, transparent 70%);
    background-size: 200% 100%;
    background-position: 200% 0;
    transition: background-position 0.5s ease;
    border-radius: inherit;
    pointer-events: none;
}
.btn:hover::before { background-position: -200% 0; }

.btn-primary {
    background: linear-gradient(135deg, var(--c-blue) 0%, var(--c-blue-dark) 100%) !important;
    border: none !important;
    box-shadow: 0 4px 18px var(--c-blue-glow);
}
.btn-primary:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 28px var(--c-blue-glow) !important;
}

.btn-success {
    background: linear-gradient(135deg, var(--c-green) 0%, var(--c-green-dark) 100%) !important;
    border: none !important;
    box-shadow: 0 4px 18px rgba(34,197,94,0.3);
}
.btn-success:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 28px rgba(34,197,94,0.45) !important;
}

.btn-white {
    background: linear-gradient(135deg, var(--c-green) 0%, var(--c-green-dark) 100%) !important;
    border: none !important;
    box-shadow: 0 4px 18px rgba(34,197,94,0.3);
}

.btn-info      { border-radius: var(--btn-radius) !important; transition: var(--t) !important; }
.btn-info:hover { transform: translateY(-2px) !important; }
.btn-white:hover { transform: translateY(-2px) !important; }
.btn-white     { border-radius: var(--btn-radius) !important; }

.btn-outline-primary,
.btn-outline-success,
.btn-outline-info,
.btn-outline-warning,
.btn-outline-dark {
    border-radius: var(--btn-radius) !important;
    border-width: 1.5px !important;
    transition: var(--t) !important;
}
.btn-outline-primary:hover,
.btn-outline-success:hover,
.btn-outline-info:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px var(--c-blue-light) !important;
}
.btn:active { transform: translateY(0) scale(0.98) !important; box-shadow: none !important; }


/* ══════════════════════════════════════════════════════════════
   §8  FORM CONTROLS
   ══════════════════════════════════════════════════════════════ */
.form-control {
    border-radius: 12px !important;
    border: 1.5px solid #dde4f3 !important;
    padding: 0.6rem 1rem !important;
    font-size: 14px !important;
    transition: var(--t-fast) !important;
    background: #f8faff !important;
    height: auto !important;  /* override style.css 36px fixed height */
}
.form-control:focus {
    border-color: var(--c-blue) !important;
    box-shadow: 0 0 0 3px var(--c-blue-light) !important;
    background: #fff !important;
}
textarea.form-control  { border-radius: 14px !important; height: auto !important; }
select.form-control    { border-radius: 12px !important; }

/* login-wrap pill inputs keep original pill style */
.login-wrap .form-control {
    border-radius: 40px !important;
    height: 52px !important;
}


/* ══════════════════════════════════════════════════════════════
   §9  HERO SECTION
   ══════════════════════════════════════════════════════════════ */
.hero-wrap { position: relative; overflow: hidden; }

/* Gradient light mesh */
.hero-wrap::before {
    content: "";
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse 60% 80% at 20% 50%, rgba(73,134,252,0.18) 0%, transparent 70%),
        radial-gradient(ellipse 40% 60% at 80% 30%, rgba(56,189,248,0.12) 0%, transparent 70%);
    z-index: 1;
    pointer-events: none;
}
/* Dot grid */
.hero-wrap::after {
    content: "";
    position: absolute; inset: 0;
    background-image: radial-gradient(circle, rgba(255,255,255,0.06) 1px, transparent 1px);
    background-size: 40px 40px;
    z-index: 1;
    pointer-events: none;
}
.hero-wrap .container,
.hero-wrap .row { position: relative; z-index: 2; }

/* Subheading glass badge */

.slider-text .subheading {
    display: inline-block;
    background: rgba(255,255,255,0.12);
    backdrop-filter: var(--glass-blur-sm);
    -webkit-backdrop-filter: var(--glass-blur-sm);
    border: 1px solid rgba(255,255,255,0.25);
    padding: 5px 18px;
    border-radius: 50px;
    font-size: 11.5px;
    font-weight: 700;
    letter-spacing: 2px;
    color: var(--c-accent) !important;
    text-transform: uppercase;
    margin-bottom: 8px;
}

.slider-text h1 {
    font-size: clamp(1.8rem, 4.5vw, 3.2rem);
    font-weight: 600;
    letter-spacing: -0.5px;
    line-height: 1.02;
    text-shadow: 0 2px 20px rgba(0,0,0,0.4);
}
.slider-text .caps {
    font-size: 15px;
    color: rgba(255,255,255,0.85);
    line-height: 1.8;
}
.slider-text .mb-0 {
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 2px !important;
}


/* ══════════════════════════════════════════════════════════════
   §10 ABOUT INTRO
   ══════════════════════════════════════════════════════════════ */
.ftco-about {
    background: linear-gradient(160deg, #f0f5ff 0%, #fff 60%);
}

.about-wrap .img,
.about-wrap .img-2 {
    border-radius: 20px !important;
    transition: var(--t);
    box-shadow: 0 12px 40px rgba(73,134,252,0.12);
}
.about-wrap .img:hover,
.about-wrap .img-2:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 50px rgba(73,134,252,0.2);
}


/* ══════════════════════════════════════════════════════════════
   §11 SECTION HEADINGS
   ══════════════════════════════════════════════════════════════ */
.heading-section .subheading {
    display: inline-block;
    background: var(--c-blue-light);
    color: var(--c-blue) !important;
    padding: 4px 14px;
    border-radius: 50px;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 10px !important;
    border: 1px solid rgba(73,134,252,0.2);
}

.heading-section h2 {
    font-weight: 800 !important;
    letter-spacing: -0.4px;
    color: #1e2d55;
}

/* Blue gradient dash under h2 */
.heading-section.text-center h2::after {
    content: "";
    display: block;
    width: 44px; height: 3px;
    background: linear-gradient(90deg, var(--c-blue), var(--c-accent));
    border-radius: 2px;
    margin: 12px auto 0;
}
.heading-section:not(.text-center) h2::after {
    content: "";
    display: block;
    width: 44px; height: 3px;
    background: linear-gradient(90deg, var(--c-blue), var(--c-accent));
    border-radius: 2px;
    margin: 12px 0 0;
}


/* ══════════════════════════════════════════════════════════════
   §12 SERVICE CARDS (.services)
   ══════════════════════════════════════════════════════════════ */
.services {
    background: #fff !important;
    border-radius: var(--card-radius) !important;
    border: 1px solid rgba(73,134,252,0.08) !important;
    box-shadow: var(--card-shadow) !important;
    padding: 24px !important;
    transition: var(--t) !important;
    position: relative;
    overflow: hidden;
}
/* Top accent bar */
.services::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--c-blue), var(--c-accent));
    border-radius: 18px 18px 0 0;
    opacity: 0;
    transition: opacity 0.3s;
}
.services:hover {
    transform: translateY(-5px);
    box-shadow: var(--card-hover) !important;
    border-color: rgba(73,134,252,0.18) !important;
}
.services:hover::before { opacity: 1; }

/* Squircle icon */
.services .icon {
    width: 62px !important;
    height: 62px !important;
    border-radius: 18px !important;
    margin-bottom: 14px !important;
    transition: var(--t);
    box-shadow: 0 6px 20px rgba(73,134,252,0.25);
}
.services .icon.icon-2 { box-shadow: 0 6px 20px rgba(228,73,173,0.25); }
.services .icon.icon-3 { box-shadow: 0 6px 20px rgba(252,153,39,0.25); }
.services .icon.icon-4 { box-shadow: 0 6px 20px rgba(36,210,200,0.25); }
.services:hover .icon  { transform: scale(1.08) rotate(-4deg); }
.services .icon img    { max-width: 54% !important; }

.services .media-body h3 {
    font-size: 15.5px !important;
    font-weight: 700 !important;
    color: #1e2d55;
    line-height: 1.4;
}
.services .media-body p {
    font-size: 13.5px;
    color: #64748b;
    line-height: 1.7;
    margin: 0;
}


/* ══════════════════════════════════════════════════════════════
   §13 COURSE CATEGORIES — glassmorphism
   ══════════════════════════════════════════════════════════════ */
.course-category {
    width: 100% !important;
    height: 230px !important;
    border-radius: 22px !important;
    margin-bottom: 28px !important;
    overflow: hidden;
    display: flex !important;
    align-items: flex-end !important;
    justify-content: stretch !important;
    background-size: cover !important;
    background-position: center !important;
    position: relative !important;
    box-shadow: 0 6px 32px rgba(0,0,0,0.18) !important;
    transition: var(--t) !important;
    text-decoration: none !important;
}
.course-category:hover {
    transform: translateY(-8px) scale(1.015) !important;
    box-shadow: 0 20px 56px rgba(0,0,0,0.28) !important;
    text-decoration: none !important;
}

/* Corner glow */
.course-category::before {
    content: "";
    position: absolute;
    top: -40px; right: -40px;
    width: 120px; height: 120px;
    background: radial-gradient(circle, rgba(73,134,252,0.4) 0%, transparent 70%);
    border-radius: 50%;
    z-index: 1;
    opacity: 0;
    transition: opacity 0.4s;
}
.course-category:hover::before { opacity: 1; }

/* Gradient overlay */
.course-category::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(175deg, rgba(10,22,70,0.05) 0%, rgba(10,22,70,0.72) 100%) !important;
    border-radius: 22px !important;
    z-index: 1 !important;
    opacity: 1 !important;
    transition: background 0.3s;
}
.course-category:hover::after {
    background: linear-gradient(175deg, rgba(10,22,70,0.08) 0%, rgba(20,60,180,0.76) 100%) !important;
}

/* Glass text bar */
.course-category .text {
    position: relative !important;
    z-index: 2 !important;
    width: 100% !important;
    padding: 16px 20px 18px !important;
    background: rgba(255,255,255,0.10) !important;
    backdrop-filter: var(--glass-blur) !important;
    -webkit-backdrop-filter: var(--glass-blur) !important;
    border-top: 1px solid var(--glass-border) !important;
    transition: background 0.3s;
    text-align: left !important;
}
.course-category:hover .text { background: rgba(255,255,255,0.18) !important; }

.course-category .text h3 {
    color: #fff !important;
    font-size: 17px !important;
    font-weight: 700 !important;
    margin: 0 0 4px !important;
    text-shadow: 0 1px 6px rgba(0,0,0,0.35);
    letter-spacing: -0.2px;
}
.course-category .text span {
    color: rgba(255,255,255,0.88) !important;
    font-size: 12.5px !important;
    font-weight: 500;
}


/* ══════════════════════════════════════════════════════════════
   §14 COURSE CARDS (.project-wrap)
   ══════════════════════════════════════════════════════════════ */
.project-wrap {
    border-radius: var(--card-radius) !important;
    overflow: hidden;
    box-shadow: var(--card-shadow) !important;
    border: 1px solid rgba(73,134,252,0.07) !important;
    background: #fff;
    transition: var(--t);
}
.project-wrap:hover {
    transform: translateY(-6px);
    box-shadow: var(--card-hover) !important;
    border-color: rgba(73,134,252,0.18) !important;
}

.project-wrap .img {
    display: block;
    overflow: hidden;
    height: 240px;
    background-size: cover;
    background-position: center;
    transition: transform 0.5s ease;
}
.project-wrap:hover .img { transform: scale(1.05); }

.project-wrap .img .price {
    background: linear-gradient(135deg, var(--c-blue) 0%, var(--c-blue-dark) 100%) !important;
    border-radius: 0 8px 8px 0 !important;
    padding: 5px 14px 5px 10px !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    box-shadow: 2px 2px 12px rgba(0,0,0,0.18);
}
.project-wrap .img .price::after,
.project-wrap .img .price::before { display: none !important; }

.project-wrap .text { padding: 20px 22px 22px !important; }
.project-wrap .text h3 {
    font-size: 17px !important;
    font-weight: 700 !important;
    color: #1e2d55;
    line-height: 1.4;
    margin-bottom: 8px !important;
}
.project-wrap .text h3 a { color: inherit; }
.project-wrap .text h3 a:hover { color: var(--c-blue) !important; text-decoration: none; }

.project-wrap .text .advisor { font-size: 12.5px !important; color: #8899bb; text-transform: none !important; }
.project-wrap .text .advisor span { color: var(--c-blue) !important; font-weight: 700; }


/* ══════════════════════════════════════════════════════════════
   §15 ENROLL FORM (.login-wrap)
   ══════════════════════════════════════════════════════════════ */
.login-wrap {
    border-radius: 22px !important;
    border: 1px solid rgba(73,134,252,0.10) !important;
    box-shadow: 0 8px 48px rgba(73,134,252,0.10) !important;
    background: #fff !important;
    overflow: hidden;
    position: relative;
}
/* Top color strip */
.login-wrap::before {
    content: "";
    display: block;
    height: 4px;
    background: linear-gradient(90deg, var(--c-blue), var(--c-accent));
    border-radius: 22px 22px 0 0;
}
.login-wrap::after { background: rgba(73,134,252,0.04) !important; height: 5px !important; border-radius: 0 !important; }

.login-wrap h3 { font-size: 20px !important; font-weight: 800 !important; color: #1e2d55 !important; letter-spacing: -0.3px; }


/* ══════════════════════════════════════════════════════════════
   §16 COUNTER SECTION
   ══════════════════════════════════════════════════════════════ */
#section-counter { position: relative; overflow: hidden; }

#section-counter::before {
    content: "";
    position: absolute; inset: 0;
    z-index: 0;
}
#section-counter .container { position: relative; z-index: 1; }

/* Glass stat card */
.block-18 {
    background: rgba(255,255,255,0.10) !important;
    backdrop-filter: var(--glass-blur) !important;
    -webkit-backdrop-filter: var(--glass-blur) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: 20px !important;
    padding: 28px 32px !important;
    gap: 20px;
    transition: var(--t);
    box-shadow: 0 8px 40px rgba(0,0,0,0.28);
}
.block-18:hover { background: rgba(255,255,255,0.18) !important; transform: translateY(-4px); }

.block-18 .icon {
    width: 62px !important; height: 62px !important;
    background: rgba(255,255,255,0.15) !important;
    border-radius: 18px !important;
    border: 1px solid rgba(255,255,255,0.25) !important;
    flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    transition: var(--t);
}
.block-18:hover .icon { transform: scale(1.1) rotate(-5deg); }
.block-18 .icon span { font-size: 30px !important; }

.block-18 .text strong.number {
    font-size: 40px !important; font-weight: 800 !important;
    letter-spacing: -1px; line-height: 1; display: block;
}
.block-18 .text span {
    font-size: 11.5px !important; letter-spacing: 1px;
    text-transform: uppercase; opacity: 0.85; margin-top: 4px;
}
.counter-wrap { padding: 12px; }


/* ══════════════════════════════════════════════════════════════
   §17 GALLERY / TESTIMONY CAROUSEL
   ══════════════════════════════════════════════════════════════ */
.testimony-section {
    background: linear-gradient(160deg, #f0f5ff 0%, #e8eeff 100%) !important;
    position: relative; overflow: hidden;
}
.testimony-section::before {
    content: "";
    position: absolute; top: -60px; right: -60px;
    width: 300px; height: 300px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(73,134,252,0.08) 0%, transparent 70%);
    pointer-events: none;
}

.testimony-wrap { padding: 8px !important; }
.testimony-wrap .text img {
    width: 100%; height: 220px;
    object-fit: cover;
    border-radius: 16px !important;
    box-shadow: 0 6px 24px rgba(0,0,0,0.12);
    transition: var(--t); display: block;
}
.testimony-wrap:hover .text img {
    transform: scale(1.03);
    box-shadow: 0 12px 36px rgba(73,134,252,0.2);
}


/* ══════════════════════════════════════════════════════════════
   §18 BLOG CARDS
   ══════════════════════════════════════════════════════════════ */
.blog-entry {
    border-radius: var(--card-radius) !important;
    overflow: hidden;
    background: #fff;
    box-shadow: var(--card-shadow);
    border: 1px solid rgba(73,134,252,0.07);
    transition: var(--t);
    margin-bottom: 28px !important;
}
.blog-entry:hover {
    transform: translateY(-6px);
    box-shadow: var(--card-hover);
    border-color: rgba(73,134,252,0.16);
}

.block-20 {
    border-radius: 0 !important;
    height: 220px !important;
    overflow: hidden;
    background-size: cover !important;
    background-position: center !important;
    transition: transform 0.5s ease;
}
.blog-entry:hover .block-20 { transform: scale(1.05); }

.blog-entry .text { padding: 20px 22px !important; border-radius: 0 0 var(--card-radius) var(--card-radius) !important; }
.blog-entry .text .heading { font-size: 17px !important; font-weight: 700 !important; color: #1e2d55; line-height: 1.45; margin-bottom: 14px !important; }
.blog-entry .text .heading a { color: inherit; }
.blog-entry .text .heading a:hover { color: var(--c-blue) !important; text-decoration: none; }


/* ══════════════════════════════════════════════════════════════
   §19 FOOTER
   ══════════════════════════════════════════════════════════════ */
.ftco-footer { background: #0d1b3e !important; position: relative; overflow: hidden; }
.ftco-footer::before {
    content: "";
    position: absolute; top: -100px; left: -100px;
    width: 400px; height: 400px;
    background: radial-gradient(circle, rgba(73,134,252,0.07) 0%, transparent 70%);
    pointer-events: none;
}

.ftco-footer .ftco-footer-widget h2 {
    font-size: 15px !important; font-weight: 700 !important;
    color: #fff !important; position: relative; padding-bottom: 10px; margin-bottom: 20px !important;
}
.ftco-footer .ftco-footer-widget h2::after {
    content: "";
    position: absolute; bottom: 0; left: 0;
    width: 28px; height: 2px;
    background: var(--c-blue); border-radius: 2px;
}
.ftco-footer .ftco-footer-widget h2.company-name::after {
    background: none;
}

.ftco-footer a { transition: var(--t-fast) !important; }
.ftco-footer a:hover { color: var(--c-accent) !important; padding-left: 4px; }

.ftco-footer-social li a {
    width: 40px !important; height: 40px !important;
    border-radius: 12px !important;
    background: rgba(255,255,255,0.07) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    display: inline-flex !important; align-items: center !important; justify-content: center !important;
    transition: var(--t) !important; margin: 3px;
}
.ftco-footer-social li a:hover {
    background: var(--c-blue) !important; border-color: var(--c-blue) !important;
    transform: translateY(-3px) scale(1.1) !important;
    box-shadow: 0 6px 20px var(--c-blue-glow);
}


/* ══════════════════════════════════════════════════════════════
   §20 MODALS
   ══════════════════════════════════════════════════════════════ */
.modal-content {
    border-radius: 20px !important; border: none !important;
    box-shadow: 0 24px 80px rgba(0,0,0,0.22) !important; overflow: hidden;
}
.modal-header {
    background: linear-gradient(135deg, #f0f5ff 0%, #e8eeff 100%) !important;
    border-bottom: 1px solid rgba(73,134,252,0.12) !important;
    padding: 18px 24px !important;
}
.modal-header h5 { font-weight: 700 !important; color: #1e2d55 !important; }
.modal-backdrop.show { backdrop-filter: blur(4px); }


/* ══════════════════════════════════════════════════════════════
   §21 SCROLL-TO-TOP (JS creates #scrollTopBtn)
   ══════════════════════════════════════════════════════════════ */
#scrollTopBtn {
    position: fixed;
    bottom: 28px; right: 28px;
    width: 46px; height: 46px;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--c-blue), var(--c-blue-dark));
    color: #fff; border: none; cursor: pointer;
    display: none; align-items: center; justify-content: center;
    font-size: 20px;
    box-shadow: 0 6px 24px var(--c-blue-glow);
    z-index: 9999; transition: var(--t);
}
#scrollTopBtn:hover { transform: translateY(-3px); box-shadow: 0 10px 32px var(--c-blue-glow); }
#scrollTopBtn.visible { display: flex; }


/* ══════════════════════════════════════════════════════════════
   §22 RESPONSIVE
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 991.98px) {
    .course-category  { height: 200px !important; }
    .block-18         { padding: 20px 22px !important; margin-bottom: 16px; }
}

@media (max-width: 767.98px) {
    .course-category          { height: 175px !important; }
    .course-category .text h3 { font-size: 15px !important; }
    .slider-text h1           { font-size: 1.9rem; }
    .slider-text .mb-0        { flex-direction: column; }
    .block-18                 { flex-direction: row; gap: 16px; }
    .block-18 .text strong.number { font-size: 32px !important; }
    .btn                      { padding: 0.5rem 1.3rem; font-size: 13px; }
    .services                 { padding: 18px !important; }
    .services .icon           { width: 52px !important; height: 52px !important; }
    .project-wrap .img        { height: 200px; }
    .block-20                 { height: 180px !important; }
    .heading-section h2       { font-size: 24px !important; }
    #scrollTopBtn             { bottom: 18px; right: 18px; }
}

@media (max-width: 575.98px) {
    .ftco-section             { padding: 2.5em 0; }
    .course-category          { height: 160px !important; }
    .course-category .text    { padding: 12px 14px !important; }
}






/* Mavjud .login-wrap uslubiga qo'shimcha */
.login-wrap {
    --c-blue: #4986fc;
    --c-accent: #1e2d55;
}

/* Inputlarni tekislash */
.enroll-form-ui .form-control {
    height: 50px !important;
    background: #f8faff !important; /* Bir oz maviroq fon */
    border: 1px solid rgba(73, 134, 252, 0.15) !important;
    border-radius: 12px !important; /* Yumshoqroq burchaklar */
    padding: 10px 15px !important;
    font-size: 15px;
    color: #1e2d55;
    transition: all 0.3s ease;
}

.enroll-form-ui .form-control:focus {
    background: #fff !important;
    border-color: var(--c-blue) !important;
    box-shadow: 0 4px 12px rgba(73, 134, 252, 0.08) !important;
}

/* Tugma dizayni */
.enroll-submit-btn {
    height: 50px;
    padding: 0 35px !important;
    border-radius: 12px !important;
    background: linear-gradient(90deg, var(--c-blue), var(--c-accent)) !important;
    border: none !important;
    color: #fff !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    transition: transform 0.2s ease, box-shadow 0.2s ease !important;
}

.enroll-submit-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(73, 134, 252, 0.3) !important;
}

/* Captcha qutisi */
.captcha-box {
    background: rgba(73, 134, 252, 0.03);
    border-radius: 15px;
    border: 1px dashed rgba(73, 134, 252, 0.2);
}

/* Label uslubi */
.enroll-form-ui .label {
    margin-bottom: 6px !important;
    margin-left: 4px;
    font-size: 11px !important;
}

/* Mobil moslashuvchanlik */
@media (max-width: 991px) {
    .enroll-form-ui .form-group {
        margin-bottom: 20px;
    }
    .enroll-submit-btn {
        width: 100%;
    }
}

/* Mobil va Planshet uchun (991px dan kichik) */
@media (max-width: 991px) {
    .enroll-form-ui .d-flex.flex-column {
        display: flex !important;
    }

    /* Inputlarni to'liq qatorga yoyish */
    .enroll-form-ui .col-md-12 {
        width: 100% !important;
    }

    /* Captcha qutisini mobilda markazlashtirish */
    .captcha-box {
        margin: 15px 0;
        transform: scale(0.9); /* Mobilda biroz kichraytiramiz sig'ishi uchun */
    }

    /* Tugmani mobilda eng pastga tushirish uchun order */
    .order-3 {
        order: 3 !important;
        margin-top: 10px;
    }

    .order-2 {
        order: 2 !important;
    }
}

/* Desktop uchun qo'shimcha */
@media (min-width: 992px) {
    .captcha-box {
        transform-origin: left center;
        transform: scale(0.85); /* Desktopda ham juda katta ko'rinmasligi uchun */
    }
}


/* Konteyner desktopda hamma narsani bir qatorga teradi */
.enroll-flex-wrapper {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 15px;
}

.fields-area {
    display: flex;
    flex: 1; /* Bo'sh joyni to'ldiradi */
    gap: 10px;
}

.field-item {
    flex: 1;
    min-width: 150px;
}

.captcha-area {
    order: 2; /* Desktopda o'rtada yoki oxirida */
}

.button-area {
    order: 3;
}

/* MOBIL VA PLANSHET (Desktop emas) */
@media (max-width: 991px) {
    .enroll-flex-wrapper {
        flex-direction: column; /* Ustun shakliga o'tish */
        align-items: stretch;
    }

    .fields-area {
        flex-direction: column;
        order: 1; /* Birinchi ma'lumotlar */
    }

    .captcha-area {
        order: 2; /* IKKINCHI CAPTCHA - Mana shu joyi tartibni to'g'rilaydi */
        display: flex;
        justify-content: center;
        margin: 10px 0;
    }

    .button-area {
        order: 3; /* OXIRI TUGMA */
    }

    .captcha-area iframe {
        /* Captcha mobilda ekrandan chiqib ketmasligi uchun */
        transform: scale(0.9);
        transform-origin: center;
    }
}

/* DESKTOPDA AGAR CAPTCHA PASTDA TURISHI KERAK BO'LSA */
@media (min-width: 992px) {
    .captcha-area {
        flex-basis: 100%; /* Captchani alohida yangi qatorga tushiradi (pastga) */
        order: 3; /* Tugmadan ham pastga tushadi */
        justify-content: flex-start;
        display: flex;
    }

    .button-area {
        order: 2; /* Tugma inputlar bilan bir qatorda qoladi */
    }
}


.captcha-area {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    visibility: hidden; /* Elementni butkul yashirish uchun */
    transition: max-height 0.6s ease, opacity 0.5s ease, visibility 0.5s;
    width: 100%;
}

.captcha-area.show {
    max-height: 150px; /* Joy yetarli bo'lishi uchun */
    opacity: 1;
    visibility: visible;
    margin-top: 15px;
    margin-bottom: 15px;
}

.mock-legend {
    border-top: 1px solid #eee;
    padding-top: 10px;
}

.mock-legend .badge {
    font-size: 0.75rem;
}

