/* =====================================================================
   APSIK Redesign Overlay (Corporate Professional Â· Navy + Gold)
   ---------------------------------------------------------------------
   Loaded AFTER theme stylesheets so all rules win without !important
   except where theme uses higher specificity. Scope = homepage variant 21
   plus globally-shared elements (navbar, buttons, sections, cards).
   To revert: remove the <link> tag from partials/_head.blade.php and
   delete this file. No other files depend on it.
   ===================================================================== */

:root {
    /* Brand palette */
    --apsik-navy-900: #0B2240;
    --apsik-navy-800: #0F2A4A;
    --apsik-navy-700: #16365E;
    --apsik-navy-100: #E8EEF6;
    --apsik-gold-500: #C9A227;
    --apsik-gold-400: #D8B547;
    --apsik-gold-100: #F6EFD7;
    --apsik-ink-900: #0E1726;
    --apsik-ink-700: #2A3447;
    --apsik-ink-500: #4B5668;
    --apsik-ink-400: #6B7280;
    --apsik-line:    #E5E9F0;
    --apsik-bg-soft: #F7F9FC;
    --apsik-white:   #FFFFFF;

    /* Typography */
    --apsik-font-sans:  'Outfit', 'Manrope', 'Roboto', system-ui, -apple-system, Segoe UI, Arial, sans-serif;
    --apsik-font-serif: 'Source Serif Pro', 'Playfair Display', Georgia, 'Times New Roman', serif;

    /* Elevation & motion */
    --apsik-shadow-sm: 0 1px 2px rgba(15, 42, 74, 0.06), 0 1px 3px rgba(15, 42, 74, 0.04);
    --apsik-shadow-md: 0 6px 16px rgba(15, 42, 74, 0.08), 0 2px 6px rgba(15, 42, 74, 0.05);
    --apsik-shadow-lg: 0 18px 40px rgba(15, 42, 74, 0.14), 0 6px 14px rgba(15, 42, 74, 0.08);
    --apsik-radius-sm: 8px;
    --apsik-radius-md: 14px;
    --apsik-radius-lg: 20px;
    --apsik-ease: cubic-bezier(.2, .7, .2, 1);
}

/* =====================================================================
   1. Base typography & global polish
   ===================================================================== */
body {
    font-family: var(--apsik-font-sans);
    color: var(--apsik-ink-700);
    background: var(--apsik-white);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "ss01", "ss02";
}

h1, h2, h3, h4, h5, h6,
.banner-title, .title, .section-title-21 .title,
.work-title, .blog-title, .service-title, .feedback-para,
.connect-title {
    font-family: var(--apsik-font-serif);
    color: var(--apsik-navy-900);
    letter-spacing: -0.01em;
}

h1, .banner-title { font-weight: 700; line-height: 1.1; }
h2, .title        { font-weight: 700; line-height: 1.18; }
h3                { font-weight: 600; line-height: 1.3; }

p, .service-para, .work-para, .counter-title-para,
.banner-small-title, .section-title-21 .subtitle,
.connect-item, .feedback-para {
    color: var(--apsik-ink-500);
    line-height: 1.7;
}

a { transition: color .2s var(--apsik-ease); }
a:hover { color: var(--apsik-gold-500); }

::selection { background: var(--apsik-gold-100); color: var(--apsik-navy-900); }

/* =====================================================================
   2. Navbar (header)
   ===================================================================== */
.header-style-03,
.header-variant-21 {
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: saturate(160%) blur(10px);
    -webkit-backdrop-filter: saturate(160%) blur(10px);
    border-bottom: 1px solid var(--apsik-line);
    box-shadow: var(--apsik-shadow-sm);
    position: sticky;
    top: 0;
    z-index: 50;
}
.header-variant-21 .navbar { padding: 14px 0; }
.header-variant-21 .navbar-nav > .nav-item > .nav-link,
.header-variant-21 .navbar-nav > li > a {
    color: var(--apsik-navy-900) !important;
    font-weight: 500;
    font-family: var(--apsik-font-sans);
    letter-spacing: .01em;
    padding: 10px 14px !important;
    transition: color .2s var(--apsik-ease);
}
.header-variant-21 .navbar-nav > .nav-item > .nav-link:hover,
.header-variant-21 .navbar-nav > li > a:hover { color: var(--apsik-gold-500) !important; }

.header-variant-21 .nav-right-content .sidebar-area .bars a .side-bars { background: var(--apsik-navy-900); }
.header-variant-21 .nav-right-content .sidebar-area .bars a .side-bars .bar-line,
.header-variant-21 .nav-right-content .sidebar-area .bars a .side-bars::before,
.header-variant-21 .nav-right-content .sidebar-area .bars a .side-bars::after { background: var(--apsik-gold-500); }

/* =====================================================================
   3. HERO â€” Rebuild (banner-area.home-21)
   ===================================================================== */
.banner-area.home-21,
.banner-area.home-21.home-21-section-bg {
    position: relative;
    background:
        radial-gradient(1100px 600px at 90% -10%, rgba(201,162,39,.10), transparent 60%),
        radial-gradient(900px 500px at -10% 110%, rgba(15,42,74,.08), transparent 60%),
        linear-gradient(180deg, #FAFBFD 0%, #F2F5FA 100%);
    padding: 110px 0 130px;
    overflow: hidden;
    border-bottom: 1px solid var(--apsik-line);
}
.banner-area.home-21::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(15,42,74,.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(15,42,74,.05) 1px, transparent 1px);
    background-size: 56px 56px;
    -webkit-mask-image: radial-gradient(ellipse at 50% 40%, #000 35%, transparent 75%);
            mask-image: radial-gradient(ellipse at 50% 40%, #000 35%, transparent 75%);
    pointer-events: none;
    z-index: 0;
}
.banner-area.home-21 .banner-bottom-mask,
.banner-area.home-21 .agency-top-thumb,
.banner-area.home-21 .banner-thumb-shape { opacity: .55; }
.banner-area.home-21 .banner-social-links { z-index: 1; }
.banner-area.home-21 .container { position: relative; z-index: 2; }

.banner-area.home-21 .banner-title {
    font-size: clamp(2.4rem, 4.4vw, 4rem);
    color: var(--apsik-navy-900);
    margin-bottom: 22px;
}
.banner-area.home-21 .banner-title .banner-title-shape {
    color: var(--apsik-gold-500);
    background: linear-gradient(180deg, transparent 65%, rgba(201,162,39,.18) 65%);
    padding: 0 6px;
}
.banner-area.home-21 .banner-small-title,
.banner-area.home-21 .banner-small-title p {
    font-size: 1.05rem;
    color: var(--apsik-ink-500);
    max-width: 560px;
}

.banner-area.home-21 .banner-btn-contents {
    display: flex;
    align-items: center;
    gap: 22px;
    flex-wrap: wrap;
}
.banner-area.home-21 .banner-btn-contents .need-help {
    color: var(--apsik-ink-400);
    font-size: .95rem;
}
.banner-area.home-21 .banner-btn-contents .need-help a {
    color: var(--apsik-navy-800);
    font-weight: 600;
    border-bottom: 1px solid var(--apsik-gold-400);
    padding-bottom: 1px;
}

/* New badge above hero title (injected via blade) */
.apsik-hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px 16px;
    margin-bottom: 22px;
    background: rgba(15, 42, 74, .06);
    border: 1px solid var(--apsik-line);
    color: var(--apsik-navy-800);
    font-size: .82rem;
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    border-radius: 999px;
}
.apsik-hero-eyebrow::before {
    content: "";
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--apsik-gold-500);
    box-shadow: 0 0 0 4px rgba(201,162,39,.18);
}

/* Hero image frame */
.banner-area.home-21 .banner-wrapper-thumb { position: relative; }
.banner-area.home-21 .banner-single-thumb img {
    border-radius: var(--apsik-radius-lg);
    box-shadow: var(--apsik-shadow-lg);
    background: var(--apsik-white);
}

/* =====================================================================
   4. Buttons
   ===================================================================== */
.cmn-btn,
.btn-bg-heading,
.btn-bg-5,
.boxed-btn,
.submit-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 14px 28px !important;
    font-family: var(--apsik-font-sans) !important;
    font-weight: 600 !important;
    letter-spacing: .01em;
    border-radius: var(--apsik-radius-sm) !important;
    border: 1px solid transparent;
    transition: transform .2s var(--apsik-ease), box-shadow .2s var(--apsik-ease), background .2s var(--apsik-ease), color .2s var(--apsik-ease) !important;
    box-shadow: var(--apsik-shadow-sm);
}
.cmn-btn.btn-bg-heading,
.banner-btn-contents .cmn-btn {
    background: var(--apsik-navy-900) !important;
    color: var(--apsik-white) !important;
}
.cmn-btn.btn-bg-heading:hover,
.banner-btn-contents .cmn-btn:hover {
    background: var(--apsik-navy-700) !important;
    transform: translateY(-2px);
    box-shadow: var(--apsik-shadow-md);
}
.cmn-btn.btn-bg-5 {
    background: var(--apsik-gold-500) !important;
    color: var(--apsik-navy-900) !important;
    border-color: var(--apsik-gold-500) !important;
}
.cmn-btn.btn-bg-5:hover {
    background: var(--apsik-gold-400) !important;
    border-color: var(--apsik-gold-400) !important;
    transform: translateY(-2px);
    box-shadow: var(--apsik-shadow-md);
}
.boxed-btn, .submit-btn {
    background: var(--apsik-navy-900) !important;
    color: var(--apsik-white) !important;
}
.boxed-btn:hover, .submit-btn:hover {
    background: var(--apsik-gold-500) !important;
    color: var(--apsik-navy-900) !important;
}

.explore-btn, .case-btn, .reading-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--apsik-navy-800) !important;
    font-weight: 600;
    transition: gap .2s var(--apsik-ease), color .2s var(--apsik-ease);
}
.explore-btn:hover, .case-btn:hover, .reading-btn:hover {
    color: var(--apsik-gold-500) !important;
    gap: 14px;
}
.explore-btn i, .case-btn i, .reading-btn i { transition: transform .2s var(--apsik-ease); }
.explore-btn:hover i, .case-btn:hover i, .reading-btn:hover i { transform: translateX(2px); }

/* =====================================================================
   5. Section titles
   ===================================================================== */
.section-title-21 .subtitle {
    font-family: var(--apsik-font-sans) !important;
    color: var(--apsik-gold-500) !important;
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
    font-size: .82rem;
    margin-bottom: 14px !important;
    display: inline-block;
}
.section-title-21 .title {
    font-size: clamp(1.8rem, 2.6vw, 2.55rem);
}
.section-title-21 .title .section-shape {
    color: var(--apsik-gold-500);
    position: relative;
    background: linear-gradient(180deg, transparent 70%, rgba(201,162,39,.16) 70%);
    padding: 0 4px;
}

/* =====================================================================
   6. Service cards
   ===================================================================== */
.service-area.home-21 { background: var(--apsik-bg-soft); }
.service-area.home-21 .single-service.service-border {
    background: var(--apsik-white);
    border: 1px solid var(--apsik-line) !important;
    border-radius: var(--apsik-radius-md);
    padding: 32px 28px !important;
    transition: transform .25s var(--apsik-ease), box-shadow .25s var(--apsik-ease), border-color .25s var(--apsik-ease);
    box-shadow: var(--apsik-shadow-sm);
    height: 100%;
}
.service-area.home-21 .single-service.service-border:hover {
    transform: translateY(-4px);
    box-shadow: var(--apsik-shadow-lg);
    border-color: var(--apsik-gold-400) !important;
}
.service-area.home-21 .single-service .service-icon {
    width: 56px; height: 56px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--apsik-navy-100);
    color: var(--apsik-navy-900);
    border-radius: 12px;
    font-size: 24px;
    margin-bottom: 18px;
}
.service-area.home-21 .single-service .service-icon i { color: var(--apsik-navy-900); }
.service-area.home-21 .single-service .service-title {
    font-size: 1.2rem;
    margin-top: 10px !important;
}
.service-area.home-21 .single-service .service-title a { color: var(--apsik-navy-900); }
.service-area.home-21 .single-service .service-title a:hover { color: var(--apsik-gold-500); }

/* =====================================================================
   7. Work / Case-study slider
   ===================================================================== */
.work-area.home-21 { background: var(--apsik-white); }
.work-area.home-21 .single-work {
    background: var(--apsik-white);
    border: 1px solid var(--apsik-line);
    border-radius: var(--apsik-radius-md);
    overflow: hidden;
    transition: transform .25s var(--apsik-ease), box-shadow .25s var(--apsik-ease);
}
.work-area.home-21 .single-work:hover {
    transform: translateY(-4px);
    box-shadow: var(--apsik-shadow-lg);
}
.work-area.home-21 .work-thumb { overflow: hidden; }
.work-area.home-21 .work-thumb img {
    width: 100%;
    transition: transform .6s var(--apsik-ease);
}
.work-area.home-21 .single-work:hover .work-thumb img { transform: scale(1.05); }
.work-area.home-21 .work-contents { padding: 22px 24px 26px; }
.work-area.home-21 .work-subtitle a {
    color: var(--apsik-gold-500);
    font-size: .8rem;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
}
.work-area.home-21 .work-title {
    font-size: 1.25rem;
    margin-top: 10px;
}
.work-area.home-21 .prev-icon,
.work-area.home-21 .next-icon,
.blog-area.home-21 .prev-icon,
.blog-area.home-21 .next-icon {
    width: 44px; height: 44px;
    border-radius: 999px;
    background: var(--apsik-white);
    border: 1px solid var(--apsik-line);
    color: var(--apsik-navy-900);
    box-shadow: var(--apsik-shadow-sm);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-left: 8px;
    transition: background .2s var(--apsik-ease), color .2s var(--apsik-ease);
}
.work-area.home-21 .prev-icon:hover,
.work-area.home-21 .next-icon:hover,
.blog-area.home-21 .prev-icon:hover,
.blog-area.home-21 .next-icon:hover {
    background: var(--apsik-navy-900);
    color: var(--apsik-white);
    border-color: var(--apsik-navy-900);
}

/* =====================================================================
   8. Counter
   ===================================================================== */
.counter-area.home-21 {
    background: linear-gradient(180deg, var(--apsik-navy-900), var(--apsik-navy-800));
    color: var(--apsik-white);
}
.counter-area.home-21 .section-title-21 .title,
.counter-area.home-21 h2,
.counter-area.home-21 .count-title { color: var(--apsik-white); }
.counter-area.home-21 .counter-title-para,
.counter-area.home-21 .counter-para { color: rgba(255,255,255,.78); }
.counter-area.home-21 .single-counter.counter-border {
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.10) !important;
    border-radius: var(--apsik-radius-md);
    padding: 26px 24px !important;
}
.counter-area.home-21 .counter-count h2 {
    font-family: var(--apsik-font-serif);
    font-size: 2.6rem;
    color: var(--apsik-gold-400);
    line-height: 1;
}

/* =====================================================================
   9. Blog
   ===================================================================== */
.blog-area.home-21 { background: var(--apsik-bg-soft); }
.blog-area.home-21 .single-blog {
    background: var(--apsik-white);
    border-radius: var(--apsik-radius-md);
    overflow: hidden;
    border: 1px solid var(--apsik-line);
    box-shadow: var(--apsik-shadow-sm);
    transition: transform .25s var(--apsik-ease), box-shadow .25s var(--apsik-ease);
}
.blog-area.home-21 .single-blog:hover {
    transform: translateY(-4px);
    box-shadow: var(--apsik-shadow-lg);
}
.blog-area.home-21 .blog-thumb img {
    width: 100%;
    height: 240px;
    object-fit: cover;
}
.blog-area.home-21 .blog-contents { padding: 22px 24px 26px; }
.blog-area.home-21 .blog-title {
    font-size: 1.18rem;
    line-height: 1.35;
    margin-top: 0 !important;
}
.blog-area.home-21 .blog-title a { color: var(--apsik-navy-900); }
.blog-area.home-21 .blog-title a:hover { color: var(--apsik-gold-500); }

/* =====================================================================
   10. Testimonial
   ===================================================================== */
.feedback-area.home-21 {
    background: var(--apsik-white);
    border-top: 1px solid var(--apsik-line);
    border-bottom: 1px solid var(--apsik-line);
}
.feedback-area.home-21 .feedback-thumb img {
    border-radius: var(--apsik-radius-lg);
    box-shadow: var(--apsik-shadow-lg);
}
.feedback-area.home-21 .feedback-para {
    font-family: var(--apsik-font-serif);
    font-size: 1.4rem !important;
    line-height: 1.55 !important;
    color: var(--apsik-ink-700) !important;
    font-weight: 500;
}
.feedback-area.home-21 .client-title { font-size: 1.05rem; color: var(--apsik-navy-900); }
.feedback-area.home-21 .client-subtitle { color: var(--apsik-ink-400) !important; font-size: .9rem; }

/* =====================================================================
   11. Contact
   ===================================================================== */
.connects-area.home-21 { background: var(--apsik-bg-soft); }
.connects-area.home-21 .single-connects {
    background: var(--apsik-white);
    border: 1px solid var(--apsik-line);
    border-radius: var(--apsik-radius-md);
    padding: 22px;
    margin-bottom: 16px;
    display: flex;
    align-items: flex-start;
    gap: 16px;
    transition: transform .2s var(--apsik-ease), box-shadow .2s var(--apsik-ease);
}
.connects-area.home-21 .single-connects:hover {
    transform: translateY(-2px);
    box-shadow: var(--apsik-shadow-md);
}
.connects-area.home-21 .connect-icon {
    width: 52px; height: 52px;
    flex: 0 0 52px;
    background: var(--apsik-navy-100);
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.connects-area.home-21 .connect-icon img { max-width: 26px; }
.connects-area.home-21 .connect-title {
    font-size: 1rem;
    color: var(--apsik-navy-900);
    margin-bottom: 6px;
}
.connects-area.home-21 .connect-form-wrapper .connect-form {
    background: var(--apsik-white);
    border: 1px solid var(--apsik-line);
    border-radius: var(--apsik-radius-md);
    padding: 28px;
    box-shadow: var(--apsik-shadow-sm);
}
.connects-area.home-21 .connect-form input,
.connects-area.home-21 .connect-form textarea,
.connects-area.home-21 .connect-form select {
    border: 1px solid var(--apsik-line) !important;
    border-radius: var(--apsik-radius-sm) !important;
    padding: 12px 14px !important;
    font-size: .95rem;
    background: #FBFCFE !important;
    transition: border-color .2s var(--apsik-ease), box-shadow .2s var(--apsik-ease);
}
.connects-area.home-21 .connect-form input:focus,
.connects-area.home-21 .connect-form textarea:focus,
.connects-area.home-21 .connect-form select:focus {
    border-color: var(--apsik-gold-400) !important;
    box-shadow: 0 0 0 4px rgba(201,162,39,.15);
    outline: none;
}

/* =====================================================================
   12. Newsletter
   ===================================================================== */
.newsletter-area.home-21 {
    background: linear-gradient(135deg, var(--apsik-navy-900) 0%, var(--apsik-navy-700) 100%);
    color: var(--apsik-white);
    border-radius: 0;
}
.newsletter-area.home-21 .section-title-21 .subtitle { color: var(--apsik-gold-400) !important; }
.newsletter-area.home-21 .section-title-21 .title { color: var(--apsik-white); }
.newsletter-area.home-21 .newsletter-form {
    display: flex;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 999px;
    padding: 6px;
}
.newsletter-area.home-21 .newsletter-form .single-input { flex: 1; }
.newsletter-area.home-21 .newsletter-form input {
    width: 100%;
    background: transparent !important;
    border: none !important;
    color: var(--apsik-white) !important;
    padding: 14px 22px !important;
    font-size: 1rem;
}
.newsletter-area.home-21 .newsletter-form input::placeholder { color: rgba(255,255,255,.7); }
.newsletter-area.home-21 .newsletter-btn {
    background: var(--apsik-gold-500) !important;
    color: var(--apsik-navy-900) !important;
    border: none !important;
    border-radius: 999px !important;
    width: 52px; height: 52px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background .2s var(--apsik-ease), transform .2s var(--apsik-ease);
}
.newsletter-area.home-21 .newsletter-btn:hover {
    background: var(--apsik-gold-400) !important;
    transform: translateX(2px);
}

/* =====================================================================
   13. Footer (theme footer compatibility)
   ===================================================================== */
.footer-area, footer.footer-area { background: var(--apsik-navy-900); color: rgba(255,255,255,.78); }
.footer-area a { color: rgba(255,255,255,.78); }
.footer-area a:hover { color: var(--apsik-gold-400); }
.footer-area h2, .footer-area h3, .footer-area h4 { color: var(--apsik-white); }

/* =====================================================================
   14. Responsive tweaks
   ===================================================================== */
@media (max-width: 991px) {
    .banner-area.home-21 { padding: 70px 0 80px; }
    .banner-area.home-21 .banner-title { font-size: clamp(1.9rem, 6vw, 2.4rem); }
    .banner-area.home-21 .banner-btn-contents { gap: 14px; }
    .feedback-area.home-21 .feedback-para { font-size: 1.15rem !important; }
    .blog-area.home-21 .blog-thumb img { height: 200px; }
}
@media (max-width: 575px) {
    .banner-area.home-21 { padding: 56px 0 60px; }
    .cmn-btn, .btn-bg-heading, .btn-bg-5, .boxed-btn, .submit-btn {
        padding: 12px 22px !important;
        font-size: .95rem !important;
    }
    .section-title-21 .subtitle { font-size: .75rem; }
}

/* =====================================================================
   15. Small accessibility & polish
   ===================================================================== */
:focus-visible {
    outline: 3px solid rgba(201,162,39,.55);
    outline-offset: 3px;
    border-radius: 4px;
}
img { max-width: 100%; height: auto; }
.container, .container-three { max-width: 1240px; }

/* =====================================================================
   16. PAGE BUILDER section overrides (this site uses the addon page-builder
       so the variant blade does not run. We polish the actual sections.)
   ===================================================================== */

/* Top bar â€” only polish text/links, do NOT override background.
   The theme's top-bar already has its own admin-controlled background. */
.top-bar-area.header-variant-21 a:hover { color: var(--apsik-gold-400); }

/* Course-home / lawyer-home / industry-home banner â€” typography only.
   IMPORTANT: do NOT override background here. These sections may have
   admin-configured background images or YT video backgrounds; touching
   `background` would hide them. Only refine typography & spacing. */
.header-area.course-home .header-content h1,
.header-area.course-home .header-content .title,
.header-area.lawyer-home .header-content h1,
.header-area.lawyer-home .header-content .title,
.header-slider-wrapper.course-home .header-content h1,
.header-slider-wrapper.course-home .header-content .title {
    font-family: var(--apsik-font-serif);
    letter-spacing: -0.01em;
    line-height: 1.12;
}
.header-area.course-home .header-content p,
.header-area.lawyer-home .header-content p {
    line-height: 1.7;
}

/* Generic section title polish */
.section-title { margin-bottom: 56px; }
.section-title .title,
.section-title h2.title {
    font-family: var(--apsik-font-serif);
    color: var(--apsik-navy-900);
    font-size: clamp(1.8rem, 2.6vw, 2.55rem);
    letter-spacing: -0.01em;
    margin: 0;
}
.section-title.white .title,
.section-title.white h2.title { color: var(--apsik-white); }
.section-title .subtitle,
.section-title .sub-title {
    font-family: var(--apsik-font-sans);
    color: var(--apsik-gold-500);
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
    font-size: .82rem;
    margin-bottom: 14px !important;
    display: inline-block;
}
.section-title.white .subtitle,
.section-title.white .sub-title { color: var(--apsik-gold-400); }

/* Specialities â€” only polish individual cards, do NOT override section bg
   because admin may set a custom background image. */
.our-specialities-area .single-specialities,
.our-specialities-area .specialities-item {
    background: var(--apsik-white);
    border: 1px solid var(--apsik-line);
    border-radius: var(--apsik-radius-md);
    padding: 30px 26px;
    box-shadow: var(--apsik-shadow-sm);
    transition: transform .25s var(--apsik-ease), box-shadow .25s var(--apsik-ease), border-color .25s var(--apsik-ease);
    height: 100%;
}
.our-specialities-area .single-specialities:hover,
.our-specialities-area .specialities-item:hover {
    transform: translateY(-4px);
    box-shadow: var(--apsik-shadow-lg);
    border-color: var(--apsik-gold-400);
}
.our-specialities-area .single-specialities .title,
.our-specialities-area .specialities-item h3,
.our-specialities-area .specialities-item .title {
    font-family: var(--apsik-font-serif);
    color: var(--apsik-navy-900);
    font-size: 1.2rem;
}

/* Team carousel + grid (this is the dominant section on the homepage)
   Polish CARDS only â€” keep section background as-is so admin theme works. */
.team-section.team-member-style-01 {
    background: var(--apsik-white);
    border: 1px solid var(--apsik-line);
    border-radius: var(--apsik-radius-md);
    overflow: hidden;
    margin: 14px;
    box-shadow: var(--apsik-shadow-sm);
    transition: transform .25s var(--apsik-ease), box-shadow .25s var(--apsik-ease), border-color .25s var(--apsik-ease);
}
.team-section.team-member-style-01:hover {
    transform: translateY(-6px);
    box-shadow: var(--apsik-shadow-lg);
    border-color: var(--apsik-gold-400);
}
.team-section.team-member-style-01 .team-img-cont {
    position: relative;
    overflow: hidden;
    background: var(--apsik-navy-100);
    aspect-ratio: 1 / 1;
}
.team-section.team-member-style-01 .team-img-cont img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    transition: transform .6s var(--apsik-ease), filter .3s var(--apsik-ease);
    filter: saturate(.95);
}
.team-section.team-member-style-01:hover .team-img-cont img {
    transform: scale(1.06);
    filter: saturate(1.05);
}
.team-section.team-member-style-01 .team-img-cont .social-link {
    position: absolute;
    inset: auto 0 0 0;
    background: linear-gradient(180deg, transparent 0%, rgba(11,34,64,.85) 70%);
    padding: 30px 20px 18px;
    transform: translateY(100%);
    transition: transform .35s var(--apsik-ease);
}
.team-section.team-member-style-01:hover .team-img-cont .social-link {
    transform: translateY(0);
}
.team-section.team-member-style-01 .social-link .social-icons {
    display: flex;
    gap: 10px;
    list-style: none;
    margin: 0;
    padding: 0;
}
.team-section.team-member-style-01 .social-link .social-icons a {
    width: 36px; height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: rgba(255,255,255,.16);
    color: var(--apsik-white);
    backdrop-filter: blur(6px);
    transition: background .2s var(--apsik-ease), color .2s var(--apsik-ease), transform .2s var(--apsik-ease);
}
.team-section.team-member-style-01 .social-link .social-icons a:hover {
    background: var(--apsik-gold-500);
    color: var(--apsik-navy-900);
    transform: translateY(-2px);
}
.team-section.team-member-style-01 .team-text {
    padding: 18px 20px 22px;
    text-align: center;
    border-top: 1px solid var(--apsik-line);
}
.team-section.team-member-style-01 .team-text .title,
.team-section.team-member-style-01 .team-text h4.title {
    font-family: var(--apsik-font-serif);
    font-size: 1.05rem;
    line-height: 1.35;
    color: var(--apsik-navy-900);
    margin: 0 0 6px;
    min-height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.team-section.team-member-style-01 .team-text span {
    color: var(--apsik-gold-500);
    font-size: .78rem;
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
}

/* Portfolio / Blog area â€” only polish cards, keep admin section background.
   The section already uses `dark-section-bg-two` from theme; we don't override it. */
.portfolio-news-area .single-portfolio-blog-grid.portfolio-page {
    background: var(--apsik-white);
    border-radius: var(--apsik-radius-md);
    overflow: hidden;
    margin: 14px 12px;
    box-shadow: var(--apsik-shadow-md);
    transition: transform .25s var(--apsik-ease), box-shadow .25s var(--apsik-ease);
}
.portfolio-news-area .single-portfolio-blog-grid.portfolio-page:hover {
    transform: translateY(-6px);
    box-shadow: var(--apsik-shadow-lg);
}
.portfolio-news-area .single-portfolio-blog-grid .thumb {
    position: relative;
    overflow: hidden;
    aspect-ratio: 16 / 10;
    background: var(--apsik-navy-100);
}
.portfolio-news-area .single-portfolio-blog-grid .thumb img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .6s var(--apsik-ease);
}
.portfolio-news-area .single-portfolio-blog-grid:hover .thumb img { transform: scale(1.05); }
.portfolio-news-area .single-portfolio-blog-grid .thumb .time-wrap {
    position: absolute;
    top: 16px; left: 16px;
    background: var(--apsik-gold-500);
    color: var(--apsik-navy-900);
    border-radius: 12px;
    padding: 8px 14px;
    text-align: center;
    font-family: var(--apsik-font-sans);
    line-height: 1.05;
    box-shadow: var(--apsik-shadow-sm);
}
.portfolio-news-area .single-portfolio-blog-grid .thumb .time-wrap .date {
    font-size: 1.4rem;
    font-weight: 700;
    display: block;
}
.portfolio-news-area .single-portfolio-blog-grid .thumb .time-wrap .month {
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
}
.portfolio-news-area .single-portfolio-blog-grid .content {
    padding: 24px 26px 28px;
    background: var(--apsik-white);
}
.portfolio-news-area .single-portfolio-blog-grid .content .title,
.portfolio-news-area .single-portfolio-blog-grid .content h4.title {
    font-family: var(--apsik-font-serif);
    font-size: 1.25rem;
    color: var(--apsik-navy-900);
    line-height: 1.35;
    margin: 0 0 14px;
}
.portfolio-news-area .single-portfolio-blog-grid .content .title a { color: inherit; }
.portfolio-news-area .single-portfolio-blog-grid .content .title a:hover { color: var(--apsik-gold-500); }
.portfolio-news-area .single-portfolio-blog-grid .content .excerpt {
    color: var(--apsik-ink-500) !important;
    font-size: .95rem;
    line-height: 1.65;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Image gallery masonry â€” polish individual tiles only. */
.case-studies-masonry-wrapper .case-studies-masonry { display: flex; flex-wrap: wrap; }
.image-gallery-masonry-wrapper .single-gallery-image {
    position: relative;
    overflow: hidden;
    border-radius: var(--apsik-radius-md);
    margin: 12px;
    background: var(--apsik-navy-100);
    aspect-ratio: 4 / 3;
    box-shadow: var(--apsik-shadow-sm);
}
.image-gallery-masonry-wrapper .single-gallery-image img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .6s var(--apsik-ease), filter .3s var(--apsik-ease);
}
.image-gallery-masonry-wrapper .single-gallery-image:hover img {
    transform: scale(1.06);
    filter: brightness(.85);
}
.image-gallery-masonry-wrapper .img-hover {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(11,34,64,.0);
    opacity: 0;
    transition: opacity .3s var(--apsik-ease), background .3s var(--apsik-ease);
}
.image-gallery-masonry-wrapper .single-gallery-image:hover .img-hover {
    opacity: 1;
    background: rgba(11,34,64,.45);
}
.image-gallery-masonry-wrapper .img-hover a.image-popup {
    width: 56px; height: 56px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: var(--apsik-gold-500);
    color: var(--apsik-navy-900);
    box-shadow: var(--apsik-shadow-md);
    transition: transform .25s var(--apsik-ease);
}
.image-gallery-masonry-wrapper .img-hover a.image-popup:hover { transform: scale(1.08); }

/* Owl carousel dots polish */
.pcarousel-dots .owl-dots,
.global-carousel-init .owl-dots {
    margin-top: 36px;
    text-align: center;
}
.pcarousel-dots .owl-dot,
.global-carousel-init .owl-dot { display: inline-block; }
.pcarousel-dots .owl-dot span,
.global-carousel-init .owl-dot span {
    width: 10px; height: 10px;
    background: rgba(255,255,255,.4);
    border-radius: 999px;
    display: inline-block;
    margin: 0 4px;
    transition: width .25s var(--apsik-ease), background .25s var(--apsik-ease);
}
.pcarousel-dots .owl-dot.active span,
.global-carousel-init .owl-dot.active span {
    background: var(--apsik-gold-500);
    width: 28px;
}

/* =====================================================================
   FOOTER â€” clean, compact, professional
   Targets: footer-area.home-variant-21 / footer-color-five / generic
   ===================================================================== */
.footer-area.home-variant-21,
.footer-area.home-21,
.footer-area.footer-color-five,
.footer-area {
    background: var(--apsik-navy-900) !important;
    color: rgba(255, 255, 255, 0.78) !important;
    position: relative;
    overflow: hidden;
}
.footer-area::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(800px 360px at 100% 0%, rgba(201, 162, 39, 0.08), transparent 60%),
        radial-gradient(700px 320px at 0% 100%, rgba(15, 42, 74, 0.5), transparent 60%);
    pointer-events: none;
}
.footer-area > * { position: relative; z-index: 1; }

.footer-area .footer-top {
    padding: 72px 0 36px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.footer-area .footer-top .row { row-gap: 36px; }
.footer-area .footer-top .col-lg-3,
.footer-area .footer-top .col-md-6 {
    display: flex;
}
.footer-area .footer-top .col-lg-3 > .footer-widget,
.footer-area .footer-top .col-lg-3 > .sidebars-single-content,
.footer-area .footer-top .col-md-6 > .footer-widget,
.footer-area .footer-top .col-md-6 > .sidebars-single-content {
    width: 100%;
}
.footer-area .footer-widget,
.footer-area .footer-widget.widget {
    color: rgba(255, 255, 255, 0.78);
}

/* Make each footer column a visible panel/card so content stops blending
   into the dark background. This is the main visual fix requested. */
.footer-area .footer-top .footer-widget,
.footer-area .footer-top .sidebars-single-content,
.footer-area .footer-top .about_us_widget.style-01,
.footer-area .footer-top .widget_nav_menu {
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    border-radius: 18px !important;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
    padding: 26px 24px !important;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    height: 100%;
}

/* Flatten nested duplicate widget wrappers generated by the CMS so we don't
   get double cards/padding. */
.footer-area .footer-top .footer-widget > .footer-widget,
.footer-area .footer-top .footer-widget > .sidebars-single-content,
.footer-area .footer-top .footer-widget > .widget_nav_menu,
.footer-area .footer-top .footer-widget > .about_us_widget.style-01 {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
    border-radius: 0 !important;
}

/* Widget titles â€” uniform across all four columns */
.footer-area .widget-title,
.footer-area h4.widget-title,
.footer-area .widget-title.style-01 {
    font-family: var(--apsik-font-serif);
    font-size: 1.05rem !important;
    font-weight: 700;
    color: var(--apsik-white) !important;
    letter-spacing: .01em;
    margin: 0 0 22px !important;
    padding: 0 0 12px !important;
    position: relative;
    border-bottom: none;
}
.footer-area .widget-title::after,
.footer-area h4.widget-title::after,
.footer-area .widget-title.style-01::after {
    content: "";
    position: absolute;
    left: 0; bottom: 0;
    width: 32px; height: 2px;
    background: var(--apsik-gold-500);
    border-radius: 2px;
}

/* About column */
.footer-area .about_us_widget.style-01 .footer-logo {
    max-width: 120px;
    height: auto;
    margin: 0 0 18px;
    background: var(--apsik-white);
    padding: 10px 14px;
    border-radius: var(--apsik-radius-sm);
    box-shadow: var(--apsik-shadow-sm);
}
.footer-area .about_us_widget.style-01 p {
    color: #FFFFFF !important;
    font-size: .95rem;
    line-height: 1.7;
    margin: 0 0 6px;
    opacity: .92;
}
.footer-area .about_us_widget.style-01 p p { margin: 0 0 6px; }

/* Recent posts column */
.footer-area .recent_post_item {
    list-style: none;
    margin: 0;
    padding: 0;
}
.footer-area .recent_post_item .single-recent-post-item {
    display: flex !important;
    align-items: flex-start;
    gap: 14px;
    padding: 0 0 16px !important;
    margin: 0 0 16px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.footer-area .recent_post_item .single-recent-post-item:last-child {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
    border-bottom: none;
}
.footer-area .recent_post_item .thumb {
    flex: 0 0 60px;
    width: 60px; height: 60px;
    border-radius: 10px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
}
.footer-area .recent_post_item .thumb img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
}
.footer-area .recent_post_item .content { flex: 1; min-width: 0; }
.footer-area .recent_post_item .content .title,
.footer-area .recent_post_item .content h4.title {
    font-family: var(--apsik-font-sans);
    font-size: .92rem !important;
    line-height: 1.4 !important;
    color: #FFFFFF !important;
    margin: 0 0 6px !important;
    font-weight: 600 !important;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.footer-area .recent_post_item .content .title a,
.footer-area .recent_post_item .content h4.title a { color: #FFFFFF !important; }
.footer-area .recent_post_item .content .title a:hover,
.footer-area .recent_post_item .content h4.title a:hover { color: var(--apsik-gold-400) !important; }
.footer-area .recent_post_item .content .time {
    color: rgba(255, 255, 255, 0.55);
    font-size: .78rem;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.footer-area .recent_post_item .content .time i { color: var(--apsik-gold-400); }

/* Useful links column */
.footer-area .widget_nav_menu ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
.footer-area .widget_nav_menu ul li {
    padding: 8px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.footer-area .widget_nav_menu ul li:last-child { border-bottom: none; }
.footer-area .widget_nav_menu ul li a {
    color: #FFFFFF !important;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: .94rem;
    font-weight: 500;
    transition: color .2s var(--apsik-ease), transform .2s var(--apsik-ease);
}
.footer-area .widget_nav_menu ul li a::before {
    content: "â€º";
    color: var(--apsik-gold-500);
    font-size: 1.1em;
    line-height: 1;
}
.footer-area .widget_nav_menu ul li a:hover {
    color: var(--apsik-gold-400);
    transform: translateX(3px);
}

/* Contact info column */
.footer-area .contact_info_list {
    list-style: none;
    margin: 0;
    padding: 0;
}
.footer-area .contact_info_list .single-info-item {
    display: flex !important;
    align-items: flex-start;
    gap: 14px;
    margin: 0 0 14px !important;
    padding: 0 !important;
    color: rgba(255, 255, 255, 0.78);
}
.footer-area .contact_info_list .single-info-item:last-child { margin-bottom: 0 !important; }
.footer-area .contact_info_list .single-info-item .icon {
    flex: 0 0 36px;
    width: 36px; height: 36px;
    border-radius: 8px;
    background: rgba(201, 162, 39, 0.12);
    color: var(--apsik-gold-400);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
}
.footer-area .contact_info_list .single-info-item .icon i { color: var(--apsik-gold-400); }
.footer-area .contact_info_list .single-info-item .details {
    color: rgba(255, 255, 255, 0.92);
    font-size: .94rem;
    line-height: 1.5;
    padding-top: 7px;
}

/* Copyright bar */
.footer-area .copyright-area,
.footer-area .copyright-bg {
    background: rgba(0, 0, 0, 0.20) !important;
    padding: 18px 0 !important;
    color: rgba(255, 255, 255, 0.55);
    font-size: .82rem;
    text-align: center;
}
.footer-area .copyright-area a,
.footer-area .copyright-bg a { color: var(--apsik-gold-400); }
.footer-area .copyright-item .copyright-area-inner {
    text-align: center;
    color: rgba(255, 255, 255, 0.55);
}

/* =====================================================================
   FOOTER FORCED OVERRIDES
   `dynamic-style.css` (admin-generated, loaded later) repaints text in
   the footer with a low-contrast grey. We force-override here for ALL
   text elements inside the footer so contrast meets WCAG.
   ===================================================================== */

/* Theme uses color: var(--paragraph-color) which evaluates to #878a95
   (low-contrast grey on dark footer). Override the variable in scope so
   anything inheriting from it inside the footer becomes white. This also
   beats theme rules without specificity wars. */
.footer-area {
    --paragraph-color: #FFFFFF !important;
    --heading-color: #FFFFFF !important;
}
.footer-area,
.footer-area p,
.footer-area li,
.footer-area span,
.footer-area a,
.footer-area .footer-widget,
.footer-area .footer-widget *,
.footer-area .about_us_widget *,
.footer-area .recent_post_item *,
.footer-area .widget_nav_menu *,
.footer-area .contact_info_list *,
.footer-area .sidebars-single-content * {
    color: #FFFFFF !important;
}
.footer-area .recent_post_item .content .time,
.footer-area .recent_post_item .content .time * {
    color: rgba(255, 255, 255, 0.70) !important;
}
.footer-area .copyright-area,
.footer-area .copyright-bg,
.footer-area .copyright-area *,
.footer-area .copyright-bg *,
.footer-area .copyright-area-inner {
    color: rgba(255, 255, 255, 0.65) !important;
}
.footer-area .widget-title,
.footer-area h4.widget-title,
.footer-area .widget-title.style-01 {
    color: #FFFFFF !important;
    font-family: var(--apsik-font-serif) !important;
    font-weight: 700 !important;
}
.footer-area .recent_post_item .content .title,
.footer-area .recent_post_item .content h4.title,
.footer-area .recent_post_item .content .title a,
.footer-area .recent_post_item .content h4.title a {
    color: #FFFFFF !important;
    font-weight: 600 !important;
}
.footer-area .widget_nav_menu ul li a {
    color: #FFFFFF !important;
    font-weight: 500 !important;
}
.footer-area .widget_nav_menu ul li a:hover,
.footer-area .recent_post_item .content .title a:hover,
.footer-area .recent_post_item .content h4.title a:hover,
.footer-area .about_us_widget a:hover,
.footer-area .copyright-area a:hover {
    color: var(--apsik-gold-400) !important;
}
.footer-area .contact_info_list .single-info-item .icon,
.footer-area .contact_info_list .single-info-item .icon i {
    color: var(--apsik-gold-400) !important;
}
.footer-area .recent_post_item .content .time i,
.footer-area .widget_nav_menu ul li a::before,
.footer-area .widget-title::after,
.footer-area h4.widget-title::after {
    color: var(--apsik-gold-500) !important;
}
.footer-area .widget-title::after,
.footer-area h4.widget-title::after,
.footer-area .widget-title.style-01::after {
    background: var(--apsik-gold-500) !important;
}

/* Specificity-matched override against theme's .widget.footer-widget chain */
.footer-area .widget.footer-widget,
.footer-area .widget.footer-widget p,
.footer-area .widget.footer-widget li,
.footer-area .widget.footer-widget li a,
.footer-area .widget.footer-widget ul li,
.footer-area .widget.footer-widget ul li a,
.footer-area .widget.footer-widget .widget-title,
.footer-area .widget.footer-widget .recent_post_item .title,
.footer-area .widget.footer-widget .recent_post_item .title a,
.footer-area .widget.footer-widget .about_us_widget p,
.footer-area .widget.footer-widget .about_us_widget a,
.footer-area .sidebars-single-content .contact_info_list .single-info-item .details {
    color: #FFFFFF !important;
}
.footer-area .widget.footer-widget .recent_post_item .time,
.footer-area .widget.footer-widget .recent_post_item .time *,
.footer-area .copyright-area,
.footer-area .copyright-bg {
    color: rgba(255,255,255,0.70) !important;
}
.footer-area .widget.footer-widget ul li a:hover,
.footer-area .widget.footer-widget .recent_post_item .title a:hover,
.footer-area .widget.footer-widget .about_us_widget a:hover,
.footer-area .widget.footer-widget .widget_nav_menu li a:hover {
    color: var(--apsik-gold-400) !important;
}

/* Responsive */
@media (max-width: 991px) {
    .footer-area .footer-top { padding: 56px 0 24px !important; }
    .footer-area .footer-top .footer-widget,
    .footer-area .footer-top .sidebars-single-content,
    .footer-area .footer-top .about_us_widget.style-01,
    .footer-area .footer-top .widget_nav_menu {
        padding: 22px 20px !important;
    }
}
@media (max-width: 575px) {
    .footer-area .footer-top { padding: 44px 0 16px !important; }
    .footer-area .about_us_widget.style-01 .footer-logo { max-width: 100px; }
    .footer-area .copyright-area { padding: 14px 0 !important; font-size: .76rem; }
}

/* Back to top button */
.back-to-top .back-top {
    background: var(--apsik-navy-900);
    color: var(--apsik-white);
    width: 44px; height: 44px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--apsik-shadow-md);
    transition: background .2s var(--apsik-ease), transform .2s var(--apsik-ease);
}
.back-to-top .back-top:hover {
    background: var(--apsik-gold-500);
    color: var(--apsik-navy-900);
    transform: translateY(-2px);
}

/* Responsive */
@media (max-width: 991px) {
    .team-section.team-member-style-01 { margin: 8px; }
    .image-gallery-masonry-wrapper .single-gallery-image { aspect-ratio: 1 / 1; }
    .footer-area .footer-top { padding: 60px 0 30px; }
}
@media (max-width: 575px) {
    .team-section.team-member-style-01 .team-text .title,
    .team-section.team-member-style-01 .team-text h4.title { min-height: auto; font-size: 1rem; }
    .portfolio-news-area .single-portfolio-blog-grid .content { padding: 18px 20px 22px; }
    .portfolio-news-area .single-portfolio-blog-grid .content .title { font-size: 1.1rem; }
}

/* =====================================================================
   FINAL FOOTER REDESIGN v7 — light cards + dark professional typography
   This intentionally overrides all earlier footer rules. The goal is
   maximum contrast: dark text on light panels, never grey on dark.
   ===================================================================== */
.footer-area.home-variant-21,
.footer-area.home-21,
.footer-area.footer-color-five,
.footer-area {
    --paragraph-color: #203047 !important;
    --heading-color: #0B2240 !important;
    background: linear-gradient(180deg, #071A33 0%, #0B2240 100%) !important;
    color: #EAF0F8 !important;
}
.footer-area .footer-top {
    padding: 64px 0 40px !important;
    border-bottom: 1px solid rgba(255,255,255,.12) !important;
}
.footer-area .footer-top .row { row-gap: 28px !important; }
.footer-area .footer-top .col-lg-3,
.footer-area .footer-top .col-md-6 { display: flex !important; }
.footer-area .footer-top .col-lg-3 > .footer-widget,
.footer-area .footer-top .col-md-6 > .footer-widget,
.footer-area .footer-top .col-lg-3 > .sidebars-single-content,
.footer-area .footer-top .col-md-6 > .sidebars-single-content {
    width: 100% !important;
}
.footer-area .footer-top .footer-widget,
.footer-area .footer-top .sidebars-single-content,
.footer-area .footer-top .about_us_widget.style-01,
.footer-area .footer-top .widget_nav_menu {
    background: #F8FAFC !important;
    border: 1px solid #E2E8F0 !important;
    border-radius: 18px !important;
    box-shadow: 0 18px 36px rgba(0,0,0,.20) !important;
    padding: 28px 24px !important;
    height: 100% !important;
    color: #203047 !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}
.footer-area .footer-top .footer-widget > .footer-widget,
.footer-area .footer-top .footer-widget > .sidebars-single-content,
.footer-area .footer-top .footer-widget > .widget_nav_menu,
.footer-area .footer-top .footer-widget > .about_us_widget.style-01 {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
    border-radius: 0 !important;
}
.footer-area .footer-top .footer-widget *,
.footer-area .footer-top .sidebars-single-content *,
.footer-area .footer-top .about_us_widget *,
.footer-area .footer-top .widget_nav_menu *,
.footer-area .footer-top .recent_post_item *,
.footer-area .footer-top .contact_info_list * {
    color: #203047 !important;
}
.footer-area .widget-title,
.footer-area h4.widget-title,
.footer-area .widget-title.style-01,
.footer-area .footer-top .widget-title,
.footer-area .footer-top h4.widget-title {
    color: #0B2240 !important;
    font-family: var(--apsik-font-serif) !important;
    font-size: 1.12rem !important;
    font-weight: 800 !important;
    letter-spacing: -.01em !important;
    margin-bottom: 22px !important;
    padding-bottom: 12px !important;
    line-height: 1.25 !important;
}
.footer-area .widget-title::after,
.footer-area h4.widget-title::after,
.footer-area .widget-title.style-01::after {
    background: #C9A227 !important;
    height: 3px !important;
    width: 42px !important;
    border-radius: 4px !important;
}
.footer-area .about_us_widget.style-01 .footer-logo {
    max-width: 118px !important;
    background: #FFFFFF !important;
    border: 1px solid #E2E8F0 !important;
    box-shadow: 0 8px 20px rgba(11,34,64,.08) !important;
    padding: 10px 14px !important;
    border-radius: 12px !important;
}
.footer-area .about_us_widget.style-01 p,
.footer-area .about_us_widget.style-01 p p {
    color: #203047 !important;
    font-size: .96rem !important;
    line-height: 1.7 !important;
    font-weight: 500 !important;
    opacity: 1 !important;
}
.footer-area .recent_post_item .single-recent-post-item {
    border-bottom: 1px solid #E2E8F0 !important;
    padding-bottom: 16px !important;
    margin-bottom: 16px !important;
}
.footer-area .recent_post_item .single-recent-post-item:last-child {
    border-bottom: 0 !important;
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
}
.footer-area .recent_post_item .thumb {
    width: 64px !important;
    height: 64px !important;
    flex: 0 0 64px !important;
    border-radius: 12px !important;
    border: 1px solid #E2E8F0 !important;
    background: #EEF2F7 !important;
}
.footer-area .recent_post_item .content .title,
.footer-area .recent_post_item .content h4.title,
.footer-area .recent_post_item .content .title a,
.footer-area .recent_post_item .content h4.title a,
.footer-area .widget.footer-widget .recent_post_item .title,
.footer-area .widget.footer-widget .recent_post_item .title a {
    color: #0B2240 !important;
    font-family: var(--apsik-font-sans) !important;
    font-weight: 700 !important;
    font-size: .94rem !important;
    line-height: 1.35 !important;
}
.footer-area .recent_post_item .content .title a:hover,
.footer-area .recent_post_item .content h4.title a:hover {
    color: #9A761A !important;
}
.footer-area .recent_post_item .content .time,
.footer-area .recent_post_item .content .time * {
    color: #64748B !important;
    font-size: .78rem !important;
    font-weight: 600 !important;
}
.footer-area .recent_post_item .content .time i { color: #C9A227 !important; }
.footer-area .widget_nav_menu ul li {
    border-bottom: 1px solid #E2E8F0 !important;
    padding: 9px 0 !important;
}
.footer-area .widget_nav_menu ul li a,
.footer-area .widget.footer-widget ul li a {
    color: #203047 !important;
    font-weight: 650 !important;
    font-size: .96rem !important;
}
.footer-area .widget_nav_menu ul li a::before {
    color: #C9A227 !important;
    font-weight: 900 !important;
}
.footer-area .widget_nav_menu ul li a:hover,
.footer-area .widget.footer-widget ul li a:hover {
    color: #9A761A !important;
}
.footer-area .contact_info_list .single-info-item {
    margin-bottom: 16px !important;
}
.footer-area .contact_info_list .single-info-item .icon {
    background: #FFF7D6 !important;
    color: #9A761A !important;
    width: 40px !important;
    height: 40px !important;
    flex: 0 0 40px !important;
    border-radius: 12px !important;
    border: 1px solid #F0D98B !important;
}
.footer-area .contact_info_list .single-info-item .icon i { color: #9A761A !important; }
.footer-area .contact_info_list .single-info-item .details,
.footer-area .sidebars-single-content .contact_info_list .single-info-item .details {
    color: #203047 !important;
    font-size: .96rem !important;
    line-height: 1.55 !important;
    font-weight: 600 !important;
    padding-top: 8px !important;
}
.footer-area .copyright-area,
.footer-area .copyright-bg {
    background: rgba(0,0,0,.30) !important;
    padding: 18px 0 !important;
}
.footer-area .copyright-area,
.footer-area .copyright-bg,
.footer-area .copyright-area *,
.footer-area .copyright-bg *,
.footer-area .copyright-area-inner {
    color: #D8E1EE !important;
    font-size: .84rem !important;
    font-weight: 500 !important;
}
@media (max-width: 991px) {
    .footer-area .footer-top { padding: 52px 0 30px !important; }
    .footer-area .footer-top .footer-widget,
    .footer-area .footer-top .sidebars-single-content,
    .footer-area .footer-top .about_us_widget.style-01,
    .footer-area .footer-top .widget_nav_menu {
        padding: 24px 22px !important;
    }
}

/* =====================================================================
   FINAL FOOTER CONTRAST FIX v8 — specificity winners
   These rules beat older .widget.footer-widget rules that used white text.
   ===================================================================== */
.footer-area.home-variant-21 .footer-top .widget.footer-widget .about_us_widget p,
.footer-area.home-variant-21 .footer-top .widget.footer-widget .about_us_widget p *,
.footer-area.home-variant-21 .footer-top .widget.footer-widget p,
.footer-area.home-variant-21 .footer-top .widget.footer-widget p *,
.footer-area.home-variant-21 .footer-top .widget.footer-widget .widget_nav_menu ul li,
.footer-area.home-variant-21 .footer-top .widget.footer-widget .widget_nav_menu ul li a,
.footer-area.home-variant-21 .footer-top .widget.footer-widget .sidebars-single-content .details,
.footer-area.home-variant-21 .footer-top .sidebars-single-content .contact_info_list .details {
    color: #203047 !important;
}
.footer-area.home-variant-21 .footer-top .widget.footer-widget .widget-title,
.footer-area.home-variant-21 .footer-top .widget.footer-widget h4.widget-title,
.footer-area.home-variant-21 .footer-top .widget.footer-widget .widget-title.style-01,
.footer-area.home-variant-21 .footer-top .sidebars-single-content .widget-title,
.footer-area.home-variant-21 .footer-top .sidebars-single-content h4.widget-title {
    color: #0B2240 !important;
    font-family: var(--apsik-font-serif) !important;
    font-weight: 800 !important;
}
.footer-area.home-variant-21 .footer-top .widget.footer-widget .recent_post_item .content .title,
.footer-area.home-variant-21 .footer-top .widget.footer-widget .recent_post_item .content h4.title,
.footer-area.home-variant-21 .footer-top .widget.footer-widget .recent_post_item .content .title a,
.footer-area.home-variant-21 .footer-top .widget.footer-widget .recent_post_item .content h4.title a {
    color: #0B2240 !important;
    font-weight: 700 !important;
}
.footer-area.home-variant-21 .footer-top .widget.footer-widget .recent_post_item .content .time,
.footer-area.home-variant-21 .footer-top .widget.footer-widget .recent_post_item .content .time *,
.footer-area.home-variant-21 .footer-top .recent_post_item .content .time,
.footer-area.home-variant-21 .footer-top .recent_post_item .content .time * {
    color: #64748B !important;
}
.footer-area.home-variant-21 .footer-top .widget.footer-widget .recent_post_item .content .time i,
.footer-area.home-variant-21 .footer-top .recent_post_item .content .time i,
.footer-area.home-variant-21 .footer-top .widget_nav_menu ul li a::before,
.footer-area.home-variant-21 .footer-top .contact_info_list .icon,
.footer-area.home-variant-21 .footer-top .contact_info_list .icon i {
    color: #9A761A !important;
}
.footer-area.home-variant-21 .copyright-area,
.footer-area.home-variant-21 .copyright-bg,
.footer-area.home-21 .copyright-area,
.footer-area.home-21 .copyright-bg,
.footer-area .copyright-area.copyright-bg {
    background: rgba(0,0,0,.35) !important;
    color: #D8E1EE !important;
}
.footer-area.home-variant-21 .copyright-area *,
.footer-area.home-variant-21 .copyright-bg *,
.footer-area.home-21 .copyright-area *,
.footer-area.home-21 .copyright-bg *,
.footer-area .copyright-area.copyright-bg * {
    color: #D8E1EE !important;
}

/* Copyright specificity fix: beats .home-21.footer-area .copyright-area.copyright-bg from style-two.css */
.footer-area.home-variant-21.home-21 .copyright-area.copyright-bg,
.footer-area.home-21.footer-color-five .copyright-area.copyright-bg,
.home-21.footer-area.footer-color-five .copyright-area.copyright-bg {
    background: rgba(0,0,0,.38) !important;
    background-color: rgba(0,0,0,.38) !important;
}
.footer-area.home-variant-21.home-21 .copyright-area.copyright-bg *,
.footer-area.home-21.footer-color-five .copyright-area.copyright-bg *,
.home-21.footer-area.footer-color-five .copyright-area.copyright-bg * {
    color: #D8E1EE !important;
}

/* =====================================================================
   HOMEPAGE MODERNIZATION v9 — content-preserving polish
   Scope: page-builder sections actually used on APSIK homepage.
   No content hidden/removed. Only spacing, typography, cards, contrast.
   ===================================================================== */
body.home_variant_21 {
    background: #FFFFFF !important;
}
body.home_variant_21 .container {
    max-width: 1180px;
}
body.home_variant_21 .section-title,
body.home_variant_21 .section-title.left-align,
body.home_variant_21 .section-title.industry-home {
    margin-bottom: 42px !important;
}
body.home_variant_21 .section-title .title,
body.home_variant_21 .section-title h2.title {
    color: #0B2240 !important;
    font-family: var(--apsik-font-serif) !important;
    font-weight: 800 !important;
    letter-spacing: -.02em !important;
    line-height: 1.15 !important;
    font-size: clamp(2rem, 3vw, 2.8rem) !important;
}
body.home_variant_21 .section-title.white .title,
body.home_variant_21 .dark-section-bg-two .section-title .title {
    color: #FFFFFF !important;
}
body.home_variant_21 .section-title .subtitle,
body.home_variant_21 .section-title .sub-title {
    color: #C9A227 !important;
    font-family: var(--apsik-font-sans) !important;
    font-size: .82rem !important;
    font-weight: 800 !important;
    letter-spacing: .16em !important;
    text-transform: uppercase !important;
}

/* Hero and media sections: preserve admin images/video, add readable overlay only */
body.home_variant_21 .header-slider-wrapper.course-home,
body.home_variant_21 .header-slider-wrapper.video-bg-area,
body.home_variant_21 .header-area.course-home,
body.home_variant_21 .header-area.lawyer-home,
body.home_variant_21 .logistic-video-area-wrap {
    position: relative !important;
    overflow: hidden !important;
}
body.home_variant_21 .header-slider-wrapper.course-home::after,
body.home_variant_21 .header-slider-wrapper.video-bg-area::after,
body.home_variant_21 .header-area.course-home::after,
body.home_variant_21 .header-area.lawyer-home::after,
body.home_variant_21 .logistic-video-area-wrap::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(90deg, rgba(7,26,51,.72) 0%, rgba(7,26,51,.36) 52%, rgba(7,26,51,.12) 100%);
    z-index: 1;
}
body.home_variant_21 .header-slider-wrapper.course-home > *,
body.home_variant_21 .header-slider-wrapper.video-bg-area > *,
body.home_variant_21 .header-area.course-home > *,
body.home_variant_21 .header-area.lawyer-home > *,
body.home_variant_21 .logistic-video-area-wrap > * {
    position: relative;
    z-index: 2;
}
body.home_variant_21 .header-content,
body.home_variant_21 .header-inner,
body.home_variant_21 .header-area .content {
    max-width: 720px;
}
body.home_variant_21 .header-content .title,
body.home_variant_21 .header-content h1,
body.home_variant_21 .header-inner .title,
body.home_variant_21 .header-inner h1 {
    color: #FFFFFF !important;
    font-family: var(--apsik-font-serif) !important;
    font-weight: 800 !important;
    letter-spacing: -.025em !important;
    line-height: 1.08 !important;
    text-shadow: 0 4px 18px rgba(0,0,0,.28);
    font-size: clamp(2.3rem, 4.4vw, 4.6rem) !important;
}
body.home_variant_21 .header-content p,
body.home_variant_21 .header-inner p,
body.home_variant_21 .header-area p {
    color: rgba(255,255,255,.90) !important;
    font-size: 1.05rem !important;
    line-height: 1.75 !important;
    max-width: 620px !important;
}
body.home_variant_21 .btn-wrapper .boxed-btn,
body.home_variant_21 .btn-wrapper .boxed-btn.blank,
body.home_variant_21 .btn-wrapper .boxed-btn-02,
body.home_variant_21 .btn-wrapper a[class*="btn"] {
    border-radius: 12px !important;
    font-family: var(--apsik-font-sans) !important;
    font-weight: 750 !important;
    padding: 14px 26px !important;
    box-shadow: 0 12px 26px rgba(0,0,0,.18) !important;
}

/* Topbar + navbar polish while keeping menus intact */
body.home_variant_21 .top-bar-area.header-variant-21 {
    font-family: var(--apsik-font-sans) !important;
    font-size: .88rem !important;
}
body.home_variant_21 .navbar-area {
    box-shadow: 0 8px 22px rgba(11,34,64,.08) !important;
    border-bottom: 1px solid rgba(226,232,240,.9) !important;
}
body.home_variant_21 .navbar-area .nav-container .navbar-collapse .navbar-nav li a,
body.home_variant_21 .navbar-area .navbar-nav li a {
    font-family: var(--apsik-font-sans) !important;
    font-weight: 650 !important;
    color: #0B2240 !important;
}
body.home_variant_21 .navbar-area .navbar-nav li a:hover {
    color: #9A761A !important;
}

/* Specialities / feature cards — keep content */
body.home_variant_21 .our-specialities-area {
    background: #F8FAFC !important;
}
body.home_variant_21 .our-specialities-area [class*="single"],
body.home_variant_21 .our-specialities-area [class*="item"] {
    border-radius: 18px !important;
}
body.home_variant_21 .our-specialities-area .single-specialities,
body.home_variant_21 .our-specialities-area .specialities-item,
body.home_variant_21 .our-specialities-area .single-what-we-cover-item,
body.home_variant_21 .our-specialities-area .single-icon-box-01 {
    background: #FFFFFF !important;
    border: 1px solid #E2E8F0 !important;
    box-shadow: 0 16px 34px rgba(11,34,64,.08) !important;
    transition: transform .25s ease, box-shadow .25s ease !important;
}
body.home_variant_21 .our-specialities-area .single-specialities:hover,
body.home_variant_21 .our-specialities-area .specialities-item:hover,
body.home_variant_21 .our-specialities-area .single-what-we-cover-item:hover,
body.home_variant_21 .our-specialities-area .single-icon-box-01:hover {
    transform: translateY(-6px) !important;
    box-shadow: 0 24px 48px rgba(11,34,64,.13) !important;
}

/* Team/pengurus: clearer card hierarchy, image ratio, no content removal */
body.home_variant_21 .team-memeber-carousel-area {
    background: #FFFFFF !important;
}
body.home_variant_21 .team-section.team-member-style-01 {
    background: #FFFFFF !important;
    border: 1px solid #E2E8F0 !important;
    border-radius: 20px !important;
    overflow: hidden !important;
    box-shadow: 0 14px 30px rgba(11,34,64,.08) !important;
    transition: transform .25s ease, box-shadow .25s ease !important;
}
body.home_variant_21 .team-section.team-member-style-01:hover {
    transform: translateY(-7px) !important;
    box-shadow: 0 26px 54px rgba(11,34,64,.15) !important;
}
body.home_variant_21 .team-section.team-member-style-01 .team-img-cont {
    aspect-ratio: 1/1 !important;
    background: #E8EEF6 !important;
    overflow: hidden !important;
}
body.home_variant_21 .team-section.team-member-style-01 .team-img-cont img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center top !important;
}
body.home_variant_21 .team-section.team-member-style-01 .team-text {
    padding: 22px 18px 24px !important;
    text-align: center !important;
}
body.home_variant_21 .team-section.team-member-style-01 .team-text .title,
body.home_variant_21 .team-section.team-member-style-01 .team-text h4.title {
    color: #0B2240 !important;
    font-family: var(--apsik-font-serif) !important;
    font-size: 1.05rem !important;
    font-weight: 800 !important;
    line-height: 1.3 !important;
    margin-bottom: 10px !important;
}
body.home_variant_21 .team-section.team-member-style-01 .team-text span {
    color: #9A761A !important;
    background: #FFF7D6 !important;
    border: 1px solid #F0D98B !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    padding: 6px 12px !important;
    font-size: .72rem !important;
    font-weight: 800 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
}

/* Blog/news cards */
body.home_variant_21 .portfolio-news-area.dark-section-bg-two {
    background: linear-gradient(180deg, #071A33 0%, #0B2240 100%) !important;
}
body.home_variant_21 .single-portfolio-blog-grid.portfolio-page {
    background: #FFFFFF !important;
    border-radius: 20px !important;
    overflow: hidden !important;
    border: 1px solid rgba(255,255,255,.10) !important;
    box-shadow: 0 18px 42px rgba(0,0,0,.24) !important;
}
body.home_variant_21 .single-portfolio-blog-grid.portfolio-page .thumb {
    aspect-ratio: 16/10 !important;
    overflow: hidden !important;
}
body.home_variant_21 .single-portfolio-blog-grid.portfolio-page .thumb img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}
body.home_variant_21 .single-portfolio-blog-grid.portfolio-page .content {
    padding: 26px !important;
}
body.home_variant_21 .single-portfolio-blog-grid.portfolio-page .content .title,
body.home_variant_21 .single-portfolio-blog-grid.portfolio-page .content .title a {
    color: #0B2240 !important;
    font-family: var(--apsik-font-serif) !important;
    font-weight: 800 !important;
    line-height: 1.25 !important;
}
body.home_variant_21 .single-portfolio-blog-grid.portfolio-page .content .excerpt {
    color: #334155 !important;
    line-height: 1.68 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 4 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

/* Gallery */
body.home_variant_21 .image-gallery-masonry-wrapper {
    background: #F8FAFC !important;
}
body.home_variant_21 .image-gallery-masonry-wrapper .single-gallery-image {
    border-radius: 18px !important;
    overflow: hidden !important;
    box-shadow: 0 14px 30px rgba(11,34,64,.10) !important;
    border: 1px solid #E2E8F0 !important;
}
body.home_variant_21 .image-gallery-masonry-wrapper .single-gallery-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform .5s ease !important;
}
body.home_variant_21 .image-gallery-masonry-wrapper .single-gallery-image:hover img {
    transform: scale(1.06) !important;
}

@media (max-width: 991px) {
    body.home_variant_21 .header-content .title,
    body.home_variant_21 .header-content h1,
    body.home_variant_21 .header-inner .title,
    body.home_variant_21 .header-inner h1 {
        font-size: clamp(2rem, 7vw, 3rem) !important;
    }
    body.home_variant_21 .header-slider-wrapper.course-home::after,
    body.home_variant_21 .header-slider-wrapper.video-bg-area::after,
    body.home_variant_21 .header-area.course-home::after,
    body.home_variant_21 .header-area.lawyer-home::after,
    body.home_variant_21 .logistic-video-area-wrap::after {
        background: rgba(7,26,51,.62) !important;
    }
}

/* =====================================================================
   HERO HEIGHT FIX v11 — keep content, remove duplicate oversized hero feel
   Page builder sets data-padding-top=350 and bottom=500, creating a 1700px
   hero. Preserve background + text, reduce to one professional viewport.
   ===================================================================== */
body.home_variant_21 .header-slider-wrapper.course-home {
    min-height: 620px !important;
    height: auto !important;
    background-size: cover !important;
    background-position: center center !important;
    display: flex !important;
    align-items: center !important;
}
body.home_variant_21 .header-slider-wrapper.course-home > .header-area.course-home {
    padding: 118px 0 136px !important;
    min-height: 620px !important;
    height: auto !important;
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
}
body.home_variant_21 .header-slider-wrapper.course-home > .header-area.course-home::after {
    display: none !important;
}
body.home_variant_21 .header-slider-wrapper.course-home::after {
    background: linear-gradient(90deg, rgba(7,26,51,.76) 0%, rgba(7,26,51,.46) 54%, rgba(7,26,51,.16) 100%) !important;
}
@media (max-width: 991px) {
    body.home_variant_21 .header-slider-wrapper.course-home,
    body.home_variant_21 .header-slider-wrapper.course-home > .header-area.course-home {
        min-height: 520px !important;
    }
    body.home_variant_21 .header-slider-wrapper.course-home > .header-area.course-home {
        padding: 84px 0 92px !important;
    }
}

/* =====================================================================
   APSIK FINAL PROFESSIONAL DESIGN v12
   Content-preserving full homepage polish. No section/data is removed.
   ===================================================================== */
body.home_variant_21 {
    --apsik-page-bg: #F6F8FC;
    --apsik-card-bg: #FFFFFF;
    --apsik-dark: #071A33;
    --apsik-primary: #0B2240;
    --apsik-muted: #475569;
    --apsik-border: #E2E8F0;
    --apsik-gold-deep: #9A761A;
    font-family: var(--apsik-font-sans) !important;
    color: #203047 !important;
    background: var(--apsik-page-bg) !important;
}
body.home_variant_21 main,
body.home_variant_21 .page-content,
body.home_variant_21 #app {
    background: var(--apsik-page-bg) !important;
}
body.home_variant_21 section,
body.home_variant_21 [class*="-area"],
body.home_variant_21 [class*="-wrapper"] {
    box-sizing: border-box;
}
body.home_variant_21 [data-padding-top="110"] { padding-top: 86px !important; }
body.home_variant_21 [data-padding-bottom="110"] { padding-bottom: 86px !important; }

/* top bar/nav */
body.home_variant_21 .top-bar-area.header-variant-21 {
    background: #071A33 !important;
    color: #E8EEF6 !important;
    border-bottom: 1px solid rgba(255,255,255,.08) !important;
}
body.home_variant_21 .top-bar-area.header-variant-21 * { color: #E8EEF6 !important; }
body.home_variant_21 .navbar-area {
    background: rgba(255,255,255,.94) !important;
    backdrop-filter: blur(12px) saturate(145%) !important;
    -webkit-backdrop-filter: blur(12px) saturate(145%) !important;
    border-bottom: 1px solid rgba(226,232,240,.95) !important;
    box-shadow: 0 8px 24px rgba(11,34,64,.07) !important;
}
body.home_variant_21 .navbar-area .nav-container { min-height: 76px !important; }
body.home_variant_21 .logo-wrapper img { max-height: 54px !important; width: auto !important; }
body.home_variant_21 .navbar-area .navbar-nav li a {
    color: #0B2240 !important;
    font-family: var(--apsik-font-sans) !important;
    font-size: .96rem !important;
    font-weight: 700 !important;
    letter-spacing: .01em !important;
}
body.home_variant_21 .navbar-area .navbar-nav li a:hover,
body.home_variant_21 .navbar-area .navbar-nav li.current-menu-item > a {
    color: #9A761A !important;
}

/* Hero */
body.home_variant_21 .header-slider-wrapper.course-home {
    min-height: 660px !important;
    height: auto !important;
    background-size: cover !important;
    background-position: center center !important;
    border-bottom: 1px solid #E2E8F0 !important;
}
body.home_variant_21 .header-slider-wrapper.course-home::after {
    background:
      linear-gradient(90deg, rgba(7,26,51,.82) 0%, rgba(7,26,51,.55) 46%, rgba(7,26,51,.18) 100%),
      radial-gradient(650px 330px at 18% 35%, rgba(201,162,39,.16), transparent 62%) !important;
}
body.home_variant_21 .header-slider-wrapper.course-home > .header-area.course-home {
    min-height: 660px !important;
    padding: 126px 0 142px !important;
}
body.home_variant_21 .header-slider-wrapper.course-home .title,
body.home_variant_21 .header-slider-wrapper.course-home h1 {
    color: #FFFFFF !important;
    font-family: var(--apsik-font-serif) !important;
    font-size: clamp(2.8rem, 5.2vw, 5.15rem) !important;
    font-weight: 900 !important;
    letter-spacing: -.035em !important;
    line-height: 1.02 !important;
    max-width: 760px !important;
    text-shadow: 0 10px 28px rgba(0,0,0,.32) !important;
}
body.home_variant_21 .header-slider-wrapper.course-home p,
body.home_variant_21 .header-slider-wrapper.course-home .subtitle {
    color: rgba(255,255,255,.92) !important;
    max-width: 660px !important;
    font-size: 1.12rem !important;
    line-height: 1.75 !important;
}
body.home_variant_21 .header-slider-wrapper.course-home .btn-wrapper a,
body.home_variant_21 .header-slider-wrapper.course-home .boxed-btn {
    background: #C9A227 !important;
    color: #071A33 !important;
    border: 1px solid #C9A227 !important;
    border-radius: 999px !important;
    padding: 15px 30px !important;
    font-weight: 850 !important;
    letter-spacing: .01em !important;
    box-shadow: 0 16px 34px rgba(0,0,0,.28) !important;
}
body.home_variant_21 .header-slider-wrapper.course-home .btn-wrapper a:hover,
body.home_variant_21 .header-slider-wrapper.course-home .boxed-btn:hover {
    background: #E0BC4D !important;
    border-color: #E0BC4D !important;
    transform: translateY(-2px) !important;
}

/* Video / ketua media sections: preserve video/photo, professional sizing */
body.home_variant_21 .header-slider-wrapper.video-bg-area,
body.home_variant_21 .header-area.lawyer-home,
body.home_variant_21 .logistic-video-area-wrap {
    min-height: 520px !important;
    border-top: 1px solid rgba(226,232,240,.75) !important;
    border-bottom: 1px solid rgba(226,232,240,.75) !important;
}
body.home_variant_21 .header-slider-wrapper.video-bg-area::after,
body.home_variant_21 .header-area.lawyer-home::after,
body.home_variant_21 .logistic-video-area-wrap::after {
    background: linear-gradient(90deg, rgba(7,26,51,.68), rgba(7,26,51,.24)) !important;
}
body.home_variant_21 .header-slider-wrapper.video-bg-area .title,
body.home_variant_21 .header-area.lawyer-home .title,
body.home_variant_21 .logistic-video-area-wrap .title {
    color: #FFFFFF !important;
    font-family: var(--apsik-font-serif) !important;
    font-weight: 850 !important;
    letter-spacing: -.02em !important;
}

/* Section containers */
body.home_variant_21 .our-specialities-area,
body.home_variant_21 .team-memeber-carousel-area,
body.home_variant_21 .image-gallery-masonry-wrapper {
    background: #F6F8FC !important;
}
body.home_variant_21 .portfolio-news-area.dark-section-bg-two {
    background:
      radial-gradient(900px 420px at 95% 0%, rgba(201,162,39,.12), transparent 65%),
      linear-gradient(180deg, #071A33 0%, #0B2240 100%) !important;
}
body.home_variant_21 .section-title .title,
body.home_variant_21 .section-title h2.title {
    color: #0B2240 !important;
    font-family: var(--apsik-font-serif) !important;
    font-weight: 900 !important;
    letter-spacing: -.025em !important;
}
body.home_variant_21 .section-title.white .title,
body.home_variant_21 .portfolio-news-area .section-title .title {
    color: #FFFFFF !important;
}
body.home_variant_21 .section-title .subtitle,
body.home_variant_21 .section-title .sub-title {
    color: #9A761A !important;
    font-weight: 850 !important;
}
body.home_variant_21 .portfolio-news-area .section-title .subtitle,
body.home_variant_21 .portfolio-news-area .section-title .sub-title {
    color: #E0BC4D !important;
}

/* Generic cards */
body.home_variant_21 .single-specialities,
body.home_variant_21 .specialities-item,
body.home_variant_21 .single-icon-box-01,
body.home_variant_21 .single-what-we-cover-item,
body.home_variant_21 .team-section.team-member-style-01,
body.home_variant_21 .single-portfolio-blog-grid.portfolio-page,
body.home_variant_21 .single-gallery-image {
    border-radius: 22px !important;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease !important;
}
body.home_variant_21 .single-specialities:hover,
body.home_variant_21 .specialities-item:hover,
body.home_variant_21 .single-icon-box-01:hover,
body.home_variant_21 .single-what-we-cover-item:hover,
body.home_variant_21 .team-section.team-member-style-01:hover,
body.home_variant_21 .single-portfolio-blog-grid.portfolio-page:hover,
body.home_variant_21 .single-gallery-image:hover {
    transform: translateY(-6px) !important;
}

/* Team */
body.home_variant_21 .team-section.team-member-style-01 {
    background: #FFFFFF !important;
    border: 1px solid #E2E8F0 !important;
    box-shadow: 0 18px 36px rgba(11,34,64,.09) !important;
}
body.home_variant_21 .team-section.team-member-style-01:hover {
    border-color: rgba(201,162,39,.55) !important;
    box-shadow: 0 28px 58px rgba(11,34,64,.15) !important;
}
body.home_variant_21 .team-section.team-member-style-01 .team-img-cont {
    aspect-ratio: 1 / 1 !important;
}
body.home_variant_21 .team-section.team-member-style-01 .team-text .title {
    color: #071A33 !important;
    font-size: 1.08rem !important;
    min-height: 2.7em !important;
}
body.home_variant_21 .team-section.team-member-style-01 .team-text span {
    background: #FFF7D6 !important;
    color: #8A6817 !important;
    border: 1px solid #EED789 !important;
}

/* Blog */
body.home_variant_21 .single-portfolio-blog-grid.portfolio-page {
    box-shadow: 0 20px 44px rgba(0,0,0,.25) !important;
}
body.home_variant_21 .single-portfolio-blog-grid.portfolio-page .content .title a:hover {
    color: #9A761A !important;
}
body.home_variant_21 .single-portfolio-blog-grid.portfolio-page .time-wrap {
    background: #C9A227 !important;
    color: #071A33 !important;
    border-radius: 14px !important;
    box-shadow: 0 10px 22px rgba(0,0,0,.18) !important;
}

/* Gallery */
body.home_variant_21 .image-gallery-masonry-wrapper .single-gallery-image {
    border: 1px solid #E2E8F0 !important;
    box-shadow: 0 18px 38px rgba(11,34,64,.10) !important;
}
body.home_variant_21 .image-gallery-masonry-wrapper .img-hover {
    background: rgba(7,26,51,.48) !important;
}
body.home_variant_21 .image-gallery-masonry-wrapper .img-hover a,
body.home_variant_21 .image-gallery-masonry-wrapper .img-hover a.image-popup {
    background: #C9A227 !important;
    color: #071A33 !important;
}

@media (max-width: 767px) {
    body.home_variant_21 .header-slider-wrapper.course-home,
    body.home_variant_21 .header-slider-wrapper.course-home > .header-area.course-home {
        min-height: 540px !important;
    }
    body.home_variant_21 .header-slider-wrapper.course-home > .header-area.course-home {
        padding: 90px 0 96px !important;
    }
    body.home_variant_21 .header-slider-wrapper.course-home .title,
    body.home_variant_21 .header-slider-wrapper.course-home h1 {
        font-size: clamp(2.15rem, 10vw, 3rem) !important;
    }
}

/* =====================================================================
   INNER PAGES REDESIGN v13 — Gallery, Contact, About, Events
   Content-preserving. Styles existing template/page-builder structures only.
   ===================================================================== */
body:not(.home_variant_21) {
    background: #F6F8FC !important;
    font-family: var(--apsik-font-sans) !important;
    color: #203047 !important;
}
body:not(.home_variant_21) .breadcrumb-area.breadcrumb-bg {
    min-height: 320px !important;
    height: auto !important;
    padding: 92px 0 !important;
    background:
      linear-gradient(90deg, rgba(7,26,51,.84), rgba(7,26,51,.52)),
      var(--apsik-navy-900) !important;
    display: flex !important;
    align-items: center !important;
}
body:not(.home_variant_21) .breadcrumb-inner,
body:not(.home_variant_21) .breadcrumb-inner * {
    color: #FFFFFF !important;
}
body:not(.home_variant_21) .breadcrumb-inner .page-title,
body:not(.home_variant_21) .breadcrumb-inner h1,
body:not(.home_variant_21) .breadcrumb-inner .title {
    color: #FFFFFF !important;
    font-family: var(--apsik-font-serif) !important;
    font-size: clamp(2.4rem, 4vw, 4rem) !important;
    font-weight: 900 !important;
    letter-spacing: -.03em !important;
    line-height: 1.08 !important;
    text-shadow: 0 10px 28px rgba(0,0,0,.26) !important;
}
body:not(.home_variant_21) .breadcrumb-inner .page-list,
body:not(.home_variant_21) .breadcrumb-inner .page-list li,
body:not(.home_variant_21) .breadcrumb-inner .page-list li a {
    color: rgba(255,255,255,.88) !important;
    font-weight: 650 !important;
}

/* Gallery page */
.image-gallery-masonry-wrapper,
.case-studies-masonry-wrapper,
.gallery-page-content-area,
.gallery-masonry-wrapper {
    background: #F6F8FC !important;
}
.image-gallery-masonry-wrapper .container,
.case-studies-masonry-wrapper .container,
.gallery-page-content-area .container {
    max-width: 1180px !important;
}
.case-studies-masonry-wrapper .case-studies-menu,
.image-gallery-masonry-wrapper .case-studies-menu {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 10px !important;
    margin-bottom: 34px !important;
}
.case-studies-masonry-wrapper .case-studies-menu li,
.image-gallery-masonry-wrapper .case-studies-menu li,
.case-studies-menu li {
    background: #FFFFFF !important;
    color: #0B2240 !important;
    border: 1px solid #E2E8F0 !important;
    border-radius: 999px !important;
    padding: 10px 18px !important;
    font-weight: 750 !important;
    box-shadow: 0 8px 18px rgba(11,34,64,.06) !important;
    transition: .2s ease !important;
}
.case-studies-masonry-wrapper .case-studies-menu li.active,
.image-gallery-masonry-wrapper .case-studies-menu li.active,
.case-studies-menu li.active,
.case-studies-menu li:hover {
    background: #0B2240 !important;
    color: #FFFFFF !important;
    border-color: #0B2240 !important;
}
.image-gallery-masonry-wrapper .single-gallery-image,
.single-gallery-image {
    border-radius: 22px !important;
    overflow: hidden !important;
    border: 1px solid #E2E8F0 !important;
    box-shadow: 0 18px 40px rgba(11,34,64,.10) !important;
    background: #E8EEF6 !important;
}
.image-gallery-masonry-wrapper .single-gallery-image img,
.single-gallery-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform .55s ease !important;
}
.image-gallery-masonry-wrapper .single-gallery-image:hover img,
.single-gallery-image:hover img { transform: scale(1.06) !important; }
.image-gallery-masonry-wrapper .single-gallery-image .img-hover,
.single-gallery-image .img-hover {
    background: rgba(7,26,51,.48) !important;
    opacity: 0 !important;
    transition: opacity .25s ease !important;
}
.image-gallery-masonry-wrapper .single-gallery-image:hover .img-hover,
.single-gallery-image:hover .img-hover { opacity: 1 !important; }
.image-gallery-masonry-wrapper .img-hover a,
.single-gallery-image .img-hover a {
    background: #C9A227 !important;
    color: #071A33 !important;
    width: 56px !important;
    height: 56px !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-shadow: 0 12px 26px rgba(0,0,0,.24) !important;
}

/* Contact page */
.inner-contact-section,
.contact-section {
    background: #F6F8FC !important;
}
.inner-contact-section .single-contact-item {
    background: #FFFFFF !important;
    border: 1px solid #E2E8F0 !important;
    border-radius: 20px !important;
    box-shadow: 0 16px 34px rgba(11,34,64,.08) !important;
    padding: 28px 22px !important;
    height: 100% !important;
    transition: transform .25s ease, box-shadow .25s ease !important;
}
.inner-contact-section .single-contact-item:hover {
    transform: translateY(-6px) !important;
    box-shadow: 0 26px 54px rgba(11,34,64,.14) !important;
}
.inner-contact-section .single-contact-item .icon,
.inner-contact-section .single-contact-item .icon i {
    color: #9A761A !important;
}
.inner-contact-section .single-contact-item .title,
.inner-contact-section .single-contact-item h4 {
    color: #0B2240 !important;
    font-family: var(--apsik-font-serif) !important;
    font-weight: 850 !important;
}
.inner-contact-section .single-contact-item .details,
.inner-contact-section .single-contact-item p,
.inner-contact-section .single-contact-item span {
    color: #334155 !important;
    font-weight: 600 !important;
}
.contact-section .contact-info,
.contact-section .contact-form,
.contact-section form,
.contact-section .contact_map {
    border-radius: 22px !important;
}
.contact-section .contact-info,
.contact-section form {
    background: #FFFFFF !important;
    border: 1px solid #E2E8F0 !important;
    box-shadow: 0 18px 40px rgba(11,34,64,.09) !important;
    padding: 34px !important;
}
.contact-section .title,
.contact-section h2,
.contact-section h3 {
    color: #0B2240 !important;
    font-family: var(--apsik-font-serif) !important;
    font-weight: 850 !important;
}
.contact-section input,
.contact-section textarea,
.contact-section select,
.contact-page-form input,
.contact-page-form textarea {
    background: #F8FAFC !important;
    border: 1px solid #CBD5E1 !important;
    border-radius: 12px !important;
    color: #0B2240 !important;
    padding: 13px 15px !important;
    box-shadow: none !important;
}
.contact-section input:focus,
.contact-section textarea:focus {
    border-color: #C9A227 !important;
    box-shadow: 0 0 0 4px rgba(201,162,39,.17) !important;
    outline: none !important;
}
.contact-section button,
.contact-section .submit-btn,
.contact-section .boxed-btn {
    background: #0B2240 !important;
    color: #FFFFFF !important;
    border-radius: 999px !important;
    font-weight: 800 !important;
    padding: 14px 28px !important;
}
.contact-section button:hover,
.contact-section .submit-btn:hover,
.contact-section .boxed-btn:hover {
    background: #C9A227 !important;
    color: #071A33 !important;
}
.contact-section .contact_map,
.contact-section iframe {
    border: 1px solid #E2E8F0 !important;
    box-shadow: 0 18px 40px rgba(11,34,64,.09) !important;
    overflow: hidden !important;
}

/* About page — if page content exists, style it; if only breadcrumb/footer, nothing is hidden */
.about-page-content-area,
.about-section,
.about-us-area,
.about-us-page-content,
.about-widget-area {
    background: #F6F8FC !important;
}
.about-page-content-area .single-about-item,
.about-section .single-about-item,
.about-us-area .single-about-item,
.about-us-page-content .content,
.about-us-area .content,
.about-section .content {
    background: #FFFFFF !important;
    border: 1px solid #E2E8F0 !important;
    border-radius: 22px !important;
    box-shadow: 0 18px 40px rgba(11,34,64,.09) !important;
    padding: 32px !important;
}
.about-page-content-area h1,
.about-page-content-area h2,
.about-page-content-area h3,
.about-section h1,
.about-section h2,
.about-section h3,
.about-us-area h1,
.about-us-area h2,
.about-us-area h3 {
    color: #0B2240 !important;
    font-family: var(--apsik-font-serif) !important;
    font-weight: 850 !important;
}
.about-page-content-area p,
.about-section p,
.about-us-area p,
.about-us-page-content p {
    color: #334155 !important;
    line-height: 1.75 !important;
    font-size: 1rem !important;
}

/* Events page */
.event-page-content-area,
.events-page-content-area,
.event-area,
.event-grid-area,
.event-section {
    background: #F6F8FC !important;
}
.event-page-content-area .single-event-item,
.events-page-content-area .single-event-item,
.event-area .single-event-item,
.event-grid-area .single-event-item,
.event-section .single-event-item,
.single-events-item,
.single-event-grid,
.event-grid-item {
    background: #FFFFFF !important;
    border: 1px solid #E2E8F0 !important;
    border-radius: 22px !important;
    overflow: hidden !important;
    box-shadow: 0 18px 40px rgba(11,34,64,.09) !important;
    transition: transform .25s ease, box-shadow .25s ease !important;
}
.event-page-content-area .single-event-item:hover,
.events-page-content-area .single-event-item:hover,
.event-area .single-event-item:hover,
.event-grid-area .single-event-item:hover,
.event-section .single-event-item:hover,
.single-events-item:hover,
.single-event-grid:hover,
.event-grid-item:hover {
    transform: translateY(-6px) !important;
    box-shadow: 0 28px 58px rgba(11,34,64,.15) !important;
}
.event-page-content-area img,
.events-page-content-area img,
.event-area img,
.event-grid-area img,
.event-section img,
.single-events-item img,
.single-event-grid img {
    width: 100% !important;
    object-fit: cover !important;
}
.event-page-content-area .content,
.events-page-content-area .content,
.event-area .content,
.event-grid-area .content,
.event-section .content,
.single-events-item .content,
.single-event-grid .content {
    padding: 24px !important;
}
.event-page-content-area .title,
.events-page-content-area .title,
.event-area .title,
.event-grid-area .title,
.event-section .title,
.single-events-item .title,
.single-event-grid .title,
.event-grid-item .title {
    color: #0B2240 !important;
    font-family: var(--apsik-font-serif) !important;
    font-weight: 850 !important;
    line-height: 1.25 !important;
}
.event-page-content-area p,
.events-page-content-area p,
.event-area p,
.event-grid-area p,
.event-section p,
.single-events-item p,
.single-event-grid p,
.event-grid-item p {
    color: #334155 !important;
    line-height: 1.7 !important;
}
.event-page-content-area .date,
.events-page-content-area .date,
.event-area .date,
.event-grid-area .date,
.event-section .date,
.single-events-item .date,
.single-event-grid .date {
    background: #C9A227 !important;
    color: #071A33 !important;
    border-radius: 12px !important;
    font-weight: 850 !important;
}
