/*
 Theme Name:   Divi Child - Doc2U
 Theme URI:    https://doc2u.com
 Description:  Divi Child Theme with Doc2U Interactive Scroll Experience
 Author:       Doc2U Team
 Author URI:   https://doc2u.com
 Template:     Divi
 Version:      1.0.0
 License:      GNU General Public License v2 or later
 License URI:  http://www.gnu.org/licenses/gpl-2.0.html
 Text Domain:  divi-child-doc2u
*/

/* Import parent theme styles */
/* Divi uses style.css for theme information only, actual styles loaded via functions.php */

/* ========================================
   FONT IMPORTS - Organic Neural Network Design System
   ======================================== */
@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400;1,500;1,600&display=swap');

/* ========================================
   CSS VARIABLES - Organic Neural Network Design System
   ======================================== */
:root {
    /* Color Palette - Organic Tones */
    --omm-bg-deep: #131313;
    --omm-bg-surface: #4F7348;
    --omm-accent-gold: #8CA464;
    --omm-accent-gold-dark: #7E8D77;
    --omm-text-heading: #E8E0E4;
    --omm-text-body: rgba(232, 224, 228, 0.85);
    --omm-text-muted: rgba(232, 224, 228, 0.6);

    /* Typography */
    --omm-font-heading: 'Poppins', sans-serif;
    --omm-font-body: 'Poppins', sans-serif;

    /* Spacing (8px base unit) */
    --omm-space-1: 8px;
    --omm-space-2: 16px;
    --omm-space-3: 24px;
    --omm-space-4: 32px;
    --omm-space-5: 40px;
    --omm-space-6: 48px;
    --omm-space-8: 64px;
    --omm-space-12: 96px;

    /* Transitions */
    --omm-transition-fast: 300ms ease-out;
    --omm-transition-base: 500ms ease-out;
    --omm-transition-slow: 800ms ease-out;

    /* Border Radius */
    --omm-radius-none: 0px;
    --omm-radius-sm: 2px;
    --omm-radius-md: 4px;
    --omm-radius-lg: 8px;

    /* Shadows */
    --omm-shadow-gold: 0 0 20px rgba(140, 164, 100, 0.3);
    --omm-shadow-elevation: 0 8px 32px rgba(0, 0, 0, 0.4);
}

/* ========================================
   1. CINEMATIC PRELOADER (Aperture Style)
   Z-Index Level: 2,147,483,647 (MAX)
   ======================================== */

/* Container Utama */
#omm-preloader {
    position: fixed !important;
    top: 0; left: 0; width: 100%; height: 100%;
    z-index: 2147483647 !important;
    background: transparent;
    display: flex; justify-content: center; align-items: center;
    pointer-events: auto;
}

/* --- BAGIAN TIRAI (PINTU) --- */
#omm-preloader .omm-aperture-top,
#omm-preloader .omm-aperture-bottom {
    position: absolute;
    left: 0;
    width: 100%;
    height: 51%;
    background-color: var(--omm-bg-deep);
    z-index: 1;

    /* LOGIKA WAKTU TIRAI: */
    /* Duration: 1.5s (Gerak lambat mewah) */
    /* Delay: 0.8s (MENUNGGU logo fade out 0.8s selesai dulu) */
    transition: transform 1.5s cubic-bezier(0.86, 0, 0.07, 1) 0.8s !important;

    will-change: transform;
}

#omm-preloader .omm-aperture-top {
    top: 0;
    transform-origin: top;
}

#omm-preloader .omm-aperture-bottom {
    bottom: 0;
    transform-origin: bottom;
}

/* --- BAGIAN LOGO --- */
#omm-preloader .omm-preloader-logo {
    position: relative;
    z-index: 10;

    /* STATE AWAL: Logo tidak terlihat (fade in nanti via animation) */
    opacity: 0;
    transform: scale(0.95);

    /* ANIMASI FADE IN OTOMATIS */
    /* Delay 0.3s: Beri waktu browser render */
    /* Duration 0.8s: Fade in smooth dan elegan */
    animation: logoFadeIn 0.8s ease-out 0.3s forwards;

    will-change: opacity, transform;
}

/* Keyframe untuk animasi FADE IN logo */
@keyframes logoFadeIn {
    from {
        opacity: 0;
        transform: scale(0.95);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

/* Keyframe untuk animasi FADE OUT logo */
@keyframes logoFadeOut {
    from {
        opacity: 1;
        transform: scale(1);
    }
    to {
        opacity: 0;
        transform: scale(1.05); /* Zoom out sedikit sekali agar elegan */
    }
}

/* --- ANIMASI SAAT CLASS 'REVEALING' DITAMBAHKAN JS --- */

/* 1. Logo FADE OUT (Memudar Halus dengan Animation) */
#omm-preloader.revealing .omm-preloader-logo {
    /* Ganti animation dari fade IN ke fade OUT */
    animation: logoFadeOut 0.8s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

/* 2. Tirai Terbuka (Delay 0.6s = menunggu fade out logo selesai) */
#omm-preloader.revealing .omm-aperture-top { transform: translateY(-100%); }
#omm-preloader.revealing .omm-aperture-bottom { transform: translateY(100%); }

/* State Akhir */
#omm-preloader.hidden { pointer-events: none; z-index: -1 !important; opacity: 0; }

/* ========================================
   SMOOTH SCROLL BEHAVIOR
   ======================================== */
html {
    scroll-behavior: smooth;
}

/* ========================================
   CUSTOM SCROLLBAR - Deep Green + Gold
   ======================================== */
/* Webkit browsers (Chrome, Safari, Edge) */
::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

::-webkit-scrollbar-track {
    background: var(--omm-bg-deep);
}

::-webkit-scrollbar-thumb {
    background: var(--omm-accent-gold);
    border-radius: 5px;
    border: 2px solid var(--omm-bg-deep);
}

::-webkit-scrollbar-thumb:hover {
    background: var(--omm-accent-gold-dark);
}

/* Firefox */
* {
    scrollbar-width: thin;
    scrollbar-color: var(--omm-accent-gold) var(--omm-bg-deep);
}

/* Global Overrides */
body {
    font-family: var(--omm-font-body);
    font-weight: 300;
    letter-spacing: 0.02em;
    position: relative;
}

/* ========================================
   ATMOSPHERIC OVERLAYS - Film Grain + Vignette
   ======================================== */

/* Film Grain/Noise Texture Overlay - Static */
body::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 9998;
    opacity: 0.05;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='2.5' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
    background-repeat: repeat;
}

/* Vignette Overlay - Darkens the corners */
body::after {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 9999;
    background: radial-gradient(
        ellipse at center,
        transparent 0%,
        transparent 40%,
        rgba(5, 38, 26, 0.3) 70%,
        rgba(5, 38, 26, 0.6) 100%
    );
}

/* Ensure content stays above overlays */
#page-container,
#et-main-area,
.et_builder_inner_content {
    position: relative;
    z-index: auto !important; 
    overflow: visible !important;
}

/* ========================================
   DIVI HEADER - TRANSPARENT & HIDE ON SCROLL
   ======================================== */

/* Target Divi Main Header - Old Money Medical (Lighter) */
#main-header,
#main-header.et-fixed-header {
    background: rgba(19, 19, 19, 0.95) !important;
    backdrop-filter: blur(20px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
    transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease !important;
    border-bottom: 0.5px solid rgb(255, 255, 255, 0.4) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.6) !important;
    pointer-events: auto !important; /* Enable interaction by default */
}

#main-header.nav-hidden {
    transform: translateY(-100%);
    opacity: 0;
    pointer-events: none !important; /* Disable interaction when hidden */
}

/* Ensure navigation items cannot be interacted with when header is hidden */
#main-header.nav-hidden * {
    pointer-events: none !important;
}

/* Divi Top Header (if exists) - Old Money Medical (Lighter) */
#top-header {
    background: rgba(19, 19, 19, 0.95) !important;
    backdrop-filter: blur(20px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
    border-bottom: 0.5px solid rgba(140, 164, 100, 0.3) !important;
}

/* Divi Navigation Links - Override all states with Gold */
#main-header #et-top-navigation nav > ul > li > a,
#main-header .et_mobile_menu li a,
#top-menu li a {
    color: rgba(243, 229, 171, 0.9) !important;
}

#main-header #et-top-navigation nav > ul > li > a:hover,
#main-header .et_mobile_menu li a:hover,
#top-menu li a:hover {
    color: #8CA464 !important;
    opacity: 1 !important;
}

/* Logo color if using text */
#logo,
.logo_container #logo {
    color: #ffffff !important;
}

/* ========================================
   DROPDOWN MENU STYLES
   ======================================== */

/* Dropdown/Submenu Container - Old Money Medical (Lighter) */
#main-header #et-top-navigation nav > ul > li > ul.sub-menu,
#main-header .et_mobile_menu .sub-menu,
.et-menu-nav .sub-menu {
    background: rgba(19, 19, 19, 0.95) !important;
    backdrop-filter: blur(20px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
    border: 0.5px solid rgba(140, 164, 100, 0.3) !important;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.7) !important;
    border-radius: 8px !important;
    padding: 8px 0 !important;
    margin-top: 0 !important;
}

/* Create invisible bridge between menu item and dropdown to prevent gap issues */
#main-header #et-top-navigation nav > ul > li.menu-item-has-children > ul.sub-menu::before {
    content: '';
    position: absolute;
    top: -10px; /* Bridge extends above dropdown */
    left: 0;
    width: 100%;
    height: 10px;
    background: transparent;
    pointer-events: auto;
}

/* Dropdown Menu Items - Old Money Medical */
#main-header #et-top-navigation nav > ul > li > ul.sub-menu li a,
#main-header .et_mobile_menu .sub-menu li a,
.et-menu-nav .sub-menu li a {
    color: rgba(243, 229, 171, 0.9) !important;
    padding: 12px 20px !important;
    transition: all 0.3s cubic-bezier(0.28, 0, 0, 1) !important;
    border-bottom: 0.5px solid rgba(140, 164, 100, 0.1) !important;
}

/* Last dropdown item - remove border */
#main-header #et-top-navigation nav > ul > li > ul.sub-menu li:last-child a,
#main-header .et_mobile_menu .sub-menu li:last-child a,
.et-menu-nav .sub-menu li:last-child a {
    border-bottom: none !important;
}

/* Dropdown Menu Items - Hover State with Gold */
#main-header #et-top-navigation nav > ul > li > ul.sub-menu li a:hover,
#main-header .et_mobile_menu .sub-menu li a:hover,
.et-menu-nav .sub-menu li a:hover {
    color: #8CA464 !important;
    background: rgba(140, 164, 100, 0.1) !important;
    opacity: 1 !important;
}

/* Active/Current Dropdown Menu Item with Gold */
#main-header #et-top-navigation nav > ul > li > ul.sub-menu li.current-menu-item > a,
#main-header .et_mobile_menu .sub-menu li.current-menu-item > a,
.et-menu-nav .sub-menu li.current-menu-item > a {
    color: #8CA464 !important;
    background: rgba(140, 164, 100, 0.15) !important;
}

/* Nested Submenu (3rd level) - Lighter */
#main-header #et-top-navigation nav > ul > li > ul.sub-menu li > ul.sub-menu,
.et-menu-nav .sub-menu .sub-menu {
    background: rgba(18, 82, 58, 0.98) !important;
    margin-top: 0 !important;
    margin-left: 10px !important;
}

/* Override Divi default dropdown arrow color with Gold */
#main-header #et-top-navigation nav > ul > li > a:after,
.et-menu-nav > ul > li > a:after {
    color: rgba(140, 164, 100, 0.6) !important;
}

#main-header #et-top-navigation nav > ul > li:hover > a:after {
    color: #8CA464 !important;
}

/* ========================================
   MOBILE HAMBURGER MENU ICON
   ======================================== */

/* Override hamburger icon color - Gold sesuai tema */
.mobile_menu_bar:before {
    color: var(--omm-accent-gold) !important;
}

/* Hover state untuk hamburger icon */
.mobile_menu_bar:hover:before {
    color: var(--omm-accent-gold-dark) !important;
}

/* Override semua accent color ungu dengan gold */
#et_search_icon:hover,
.et_pb_sum,
.et_pb_pricing li a,
.et_pb_pricing_table_button,
.comment-reply-link,
.form-submit .et_pb_button,
.et_pb_bg_layout_light .et_pb_newsletter_button,
.et_pb_contact_submit,
.et_password_protected_form .et_submit_button,
.et_pb_bg_layout_light .et_pb_more_button,
.et_pb_bg_layout_light .et_pb_promo_button,
.et_overlay:before,
.entry-summary p.price ins,
#top-menu li.current-menu-ancestor>a,
#top-menu li.current-menu-item>a,
.bottom-nav li.current-menu-item>a {
    color: var(--omm-accent-gold) !important;
}

/* Override border color ungu dengan gold */
.et-search-form,
.nav li ul,
.et_mobile_menu,
.et_pb_pricing li:before {
    border-color: var(--omm-accent-gold) !important;
}

/* Mobile Menu Dropdown - Old Money Medical (Lighter) */
@media (max-width: 980px) {
    /* Fix mobile header position */
    html,
    html.js,
    body {
        margin-top: 0 !important;
        padding-top: 0 !important;
    }

    #main-header,
    #main-header.et-fixed-header,
    body #main-header,
    body #main-header.et-fixed-header,
    body.et_fixed_nav #main-header,
    body.et_fixed_nav #main-header.et-fixed-header,
    #page-container #main-header,
    #page-container #main-header.et-fixed-header {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        margin: 0 !important;
        margin-top: 0 !important;
        padding: 0 !important;
        transform: none !important;
        -webkit-transform: none !important;
        background: rgba(19, 19, 19, 0.95) !important;
        z-index: 999999 !important;
        box-sizing: border-box !important;
    }

    #main-header .container,
    #main-header .et_menu_container {
        padding-top: 15px !important;
        padding-bottom: 15px !important;
    }

    #main-header .et_mobile_menu {
        background: rgba(19, 19, 19, 0.95) !important;
        backdrop-filter: blur(20px) saturate(180%) !important;
        -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
    }

    #main-header .et_mobile_menu li a {
        color: rgba(243, 229, 171, 0.9) !important;
        border-bottom: 0.5px solid rgba(140, 164, 100, 0.1) !important;
    }

    #main-header .et_mobile_menu li a:hover {
        background: rgba(140, 164, 100, 0.1) !important;
        color: #8CA464 !important;
    }
}

/* ========================================
   DROPDOWN BLUR OVERLAY EFFECT
   ======================================== */

/* Blur overlay that covers the entire page when dropdown is open */
.dropdown-blur-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.3);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s cubic-bezier(0.28, 0, 0, 1), visibility 0.3s cubic-bezier(0.28, 0, 0, 1);
    z-index: 99; /* Below header (header is typically 100+) */
    pointer-events: none;
}

/* Active state - when dropdown is open */
.dropdown-blur-overlay.active {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

/* Ensure header stays above the blur overlay */
#main-header,
#main-header.et-fixed-header {
    z-index: 999999 !important;
}

/* Overlay Blur di bawah Header (9,998) */
.dropdown-blur-overlay {
    z-index: 9998 !important; 
}

/* Ensure dropdown menus stay above the blur overlay */
#main-header #et-top-navigation nav > ul > li > ul.sub-menu,
#main-header .et_mobile_menu .sub-menu,
.et-menu-nav .sub-menu {
    z-index: 1000000 !important;
}

/* Prevent body scroll when dropdown is open (optional) */
body.dropdown-open {
    /* Uncomment if you want to prevent scrolling when dropdown is open */
    /* overflow: hidden; */
}

/* ========================================
   DIVI FOOTER - DARK THEME
   ======================================== */

/* Main Footer Background - Old Money Medical Gradient (Lighter) */
#main-footer,
.et_pb_section.et_pb_footer_columns,
#footer-widgets,
.footer-widget,
body #main-footer,
body .et_pb_section.et_pb_footer_columns {
    background: rgba(19, 19, 19, 0.95) !important;
    border-top: 0.5px solid rgb(255, 255, 255, 0.4) !important;
    position: relative;
}

/* Force override any Divi Builder background colors */
.et_pb_section_0_tb_footer,
.et_pb_row_0_tb_footer,
#main-footer .et_pb_section,
#main-footer .et_pb_row,
#main-footer .et_pb_column {
    background: transparent !important;
}

/* Override Divi default teal/cyan colors */
#main-footer .footer-widget h4,
#main-footer .widget_block h1,
#main-footer .widget_block h2,
#main-footer .widget_block h3,
#main-footer .widget_block h4,
#main-footer .widget_block h5,
#main-footer .widget_block h6 {
    color: #ffffff !important;
}

#main-footer .footer-widget li:before {
    border-color: rgba(140, 164, 100, 0.5) !important;
}

#main-footer .bottom-nav li.current-menu-item > a {
    color: #8CA464 !important;
}

/* Footer Headings */
#main-footer h4,
#main-footer .footer-widget h4,
#main-footer .widget-title {
    color: #ffffff !important;
}

/* Footer Text Content */
#main-footer,
#main-footer p,
#main-footer .footer-widget p,
#main-footer li,
#main-footer .textwidget {
    color: rgba(255, 255, 255, 0.7) !important;
}

/* Footer Links - Override all states with Gold */
#main-footer a,
#main-footer .footer-widget a,
#main-footer nav a,
#main-footer .widget a {
    color: rgba(224, 224, 224, 0.7) !important;
    transition: color 0.3s ease-out !important;
}

#main-footer a:hover,
#main-footer .footer-widget a:hover,
#main-footer nav a:hover,
#main-footer .widget a:hover {
    color: #8CA464 !important;
}

/* ========================================
   SINGLE UNIFIED FOOTER SECTION
   ======================================== */

/* Hide footer-bottom completely - use only et-footer-nav */
#footer-bottom {
    display: none !important;
}

/* Single Footer Section - Contains Navigation + Copyright (Lighter) */
#et-footer-nav {
    background: #131313 !important;
    border-top: 0.5px solid rgb(255, 255, 255, 0.4) !important;
    padding: 40px 0 !important;
    text-align: center;
}

/* Footer Navigation Menu */
.bottom-nav {
    text-align: center;
    padding: 0 0 25px 0 !important;
    margin: 0;
}

.bottom-nav li {
    display: inline-block;
    margin: 0 20px;
    padding: 0;
}

.bottom-nav a {
    color: rgba(243, 229, 171, 0.7) !important;
    font-weight: 500;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    transition: color 0.3s ease-out !important;
}

.bottom-nav a:hover,
.bottom-nav li.current-menu-item > a {
    color: #8CA464 !important;
}

/* Footer Info (Copyright) - Below navigation */
#et-footer-nav #footer-info {
    text-align: center !important;
    float: none !important;
    width: 100%;
    padding: 20px 0 0 0 !important;
    margin: 0 !important;
    border-top: 0.5px solid rgba(255, 255, 255, 0.05);
    color: rgba(255, 255, 255, 0.5) !important;
    font-size: 13px;
}

#et-footer-nav #footer-info a {
    color: rgba(224, 224, 224, 0.5) !important;
}

#et-footer-nav #footer-info a:hover {
    color: #8CA464 !important;
}

/* Responsive Footer */
@media (max-width: 768px) {
    .bottom-nav li {
        display: block;
        margin: 10px 0;
    }

    #et-footer-nav {
        padding: 30px 0 !important;
    }

    .bottom-nav {
        padding: 0 0 20px 0 !important;
    }
}

/* ========================================
   FORCE OVERRIDE DIVI BUILDER FOOTER COLORS
   ======================================== */

/* Target all possible footer background elements - Old Money Medical (Warmer) */
.et_pb_section.et_pb_section_0_tb_footer,
.et_pb_section.et_pb_section_1_tb_footer,
.et_pb_section.et_pb_section_2_tb_footer,
.et_builder_inner_content #et-boc .et-l.et-l--footer,
#et-boc .et-l.et-l--footer .et_pb_section,
body #main-footer,
body #main-footer .et_pb_section,
body #main-footer .et_pb_row,
body #main-footer .et_pb_column,
body.et_divi_builder #main-footer,
body.et_divi_theme #main-footer {
    background-color: #131313 !important;
}

/* Override any module backgrounds in footer */
#main-footer .et_pb_module,
#main-footer .et_pb_text,
#main-footer .et_pb_blurb,
body #main-footer > *,
body #main-footer .et_pb_section > *,
body #main-footer .et_pb_row > * {
    background: transparent !important;
}

/* Override footer text colors to white/light */
#main-footer,
#main-footer *:not(a) {
    color: rgba(255, 255, 255, 0.7) !important;
}

#main-footer h1,
#main-footer h2,
#main-footer h3,
#main-footer h4,
#main-footer h5,
#main-footer h6 {
    color: #ffffff !important;
}

/* NUCLEAR OPTION: Override the #2EA3F2 teal color from Divi cache */
body .footer-widget h4,
body #main-footer .widget_block h1,
body #main-footer .widget_block h2,
body #main-footer .widget_block h3,
body #main-footer .widget_block h4,
body #main-footer .widget_block h5,
body #main-footer .widget_block h6 {
    color: #ffffff !important;
}

body .footer-widget li:before,
body #main-footer .footer-widget li:before {
    border-color: rgba(140, 164, 100, 0.5) !important;
}

body .bottom-nav li.current-menu-item > a,
body #main-footer .bottom-nav li.current-menu-item > a {
    color: #8CA464 !important;
}

/* Override any green/teal Divi Builder sections in footer */
body #main-footer [style*="background"],
body #main-footer [data-background-color],
body #main-footer .et_pb_section[style*="background"],
body #main-footer .et_pb_row[style*="background"] {
    background: transparent !important;
}
