.elementor-245 .elementor-element.elementor-element-30ccb1d{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-245 .elementor-element.elementor-element-3dbe3bd{--display:flex;}/* Start custom CSS for html, class: .elementor-element-2165906 *//*====================================================
REPUBLIK VANNAMEI HEADER V2
FOUNDATION
====================================================*/

:root{

    --rv-primary:#0B3D91;
    --rv-primary-light:#2E86FF;
    --rv-dark:#062A5A;
    --rv-white:#FFFFFF;
    --rv-gray:#F5F8FC;

}

/*====================================================
RESET
====================================================*/

.rv-header *,
.rv-topbar *{

    box-sizing:border-box;

}

.rv-header a,
.rv-topbar a{

    text-decoration:none;

}

/*====================================================
TOPBAR
====================================================*/

.rv-topbar{

    position:fixed;

    top:0;
    left:0;

    width:100%;
    height:42px;

    background:#062A5A;

    color:#FFFFFF;

    z-index:9998;

    font-size:12px;

}

.rv-topbar .container{

    max-width:1280px;

    height:100%;

    margin:0 auto;

    padding:0 24px;

    display:flex;

    align-items:center;

    justify-content:space-between;

}

.topbar-left,
.topbar-right{

    display:flex;

    align-items:center;

    gap:24px;

}

.rv-topbar i{

    margin-right:6px;

    color:#FFD54A;

}

/*====================================================
TOPBAR SOCIAL
====================================================*/

.rv-topbar-socials{

    display:flex;

    align-items:center;

    gap:8px;

    margin-left:10px;

}

.rv-topbar-socials a{

    width:30px;
    height:30px;

    display:flex;

    align-items:center;

    justify-content:center;

    border-radius:50%;

    background:rgba(255,255,255,.08);

    transition:.25s ease;

}

.rv-topbar-socials a i{

    margin:0 !important;

    color:#FFFFFF !important;

    font-size:14px;

}

.rv-topbar-socials a:hover{

    background:#2E86FF;

    transform:translateY(-2px);

    box-shadow:0 0 15px rgba(46,134,255,.45);

}

/*====================================================
HEADER
====================================================*/

.rv-header{

    position:fixed;

    top:42px;
    left:0;

    width:100%;

    z-index:9999;

    background:linear-gradient(
        90deg,
        #0B3D91 0%,
        #0D4AA8 50%,
        #0B3D91 100%
    );

    transition:all .35s ease;

}

.rv-header.scrolled{

    background:rgba(11,61,145,.97);

    backdrop-filter:blur(12px);

    box-shadow:0 10px 30px rgba(0,0,0,.15);

}

.rv-header .rv-container{

    max-width:1280px;

    margin:0 auto;

    padding:0 24px;

    min-height:90px;

    display:grid;

    grid-template-columns:220px 1fr auto;

    align-items:center;

    gap:40px;

}

/*====================================================
LOGO
====================================================*/

.rv-logo img{

    height:72px;

    display:block;

    transition:all .35s ease;

}

.rv-header.scrolled .rv-logo img{

    transform:scale(.92);

}

/*====================================================
TOPBAR TABLET
====================================================*/

@media(max-width:1024px){

    .rv-topbar{

        display:none;

    }

    .rv-header{

        top:0;

    }

}

/*====================================================
NAVIGATION
====================================================*/

.rv-nav{

    display:flex;

    justify-content:center;

}

.rv-nav ul{

    display:flex;

    align-items:center;

    gap:40px;

    margin:0;

    padding:0;

    list-style:none;

}

.rv-nav li{

    position:relative;

}

.rv-nav a,
.rv-nav a:visited{

    position:relative;

    color:#FFFFFF !important;

    font-size:15px;

    font-weight:600;

}

.rv-nav a:hover{

    color:#8EC5FF !important;

}

.rv-nav a::after{

    content:"";

    position:absolute;

    left:50%;

    bottom:-8px;

    width:0;

    height:2px;

    background:#5AA9FF;

    transform:translateX(-50%);

    transition:.3s ease;

}

.rv-nav a:hover::after{

    width:70%;

}

.rv-nav i{

    margin-left:6px;

    font-size:11px;

}

/*====================================================
DROPDOWN
====================================================*/

.has-dropdown{

    position:relative;

}

.has-dropdown > a{

    display:flex;

    align-items:center;

    gap:6px;

    height:90px;

}

.dropdown{

    position:absolute;

    top:100%;

    left:0;

    margin-top:14px;

    min-width:300px;

    padding:10px 0;

    background:#FFFFFF;

    border:1px solid #EEF2F7;

    border-radius:16px;

    box-shadow:
        0 20px 40px rgba(0,0,0,.15);

    opacity:0;

    visibility:hidden;

    transform:translateY(10px);

    pointer-events:none;

    transition:
        opacity .25s ease,
        transform .25s ease,
        visibility .25s ease;

    display:block !important;

    z-index:9999;

}

.has-dropdown:hover .dropdown{

    opacity:1;

    visibility:visible;

    transform:translateY(0);

    pointer-events:auto;

}

/*====================================================
DROPDOWN ITEM
====================================================*/

.dropdown li{

    display:block;

    width:100%;

    margin:0;

}

.dropdown li:not(:last-child){

    border-bottom:1px solid #EEF2F7;

}

.dropdown li:first-child{

    background:#F8FAFC;

    border-bottom:1px solid #E5E7EB;

}

.dropdown li:first-child a{

    color:#0F47AF !important;

    font-weight:700 !important;

}

.dropdown li a,
.dropdown li a:visited{

    display:block;

    width:100%;

    padding:14px 20px !important;

    background:transparent !important;

    color:#1F2937 !important;

    font-size:14px !important;

    font-weight:600 !important;

    line-height:1.5 !important;

    text-decoration:none;

    text-indent:0 !important;

    white-space:normal !important;

    transition:.2s ease;

}

.dropdown li a:hover{

    padding-left:26px !important;

    background:#F5F8FC !important;

    color:#0F47AF !important;

}

/*====================================================
CTA
====================================================*/

.rv-btn-wa{

    display:flex;

    align-items:center;

    justify-content:center;

    gap:10px;

    min-width:145px;

    padding:12px 20px;

    border-radius:14px;

    background:#FFFFFF;

    color:#0B3D91;

    font-weight:700;

}

.rv-btn-wa .fa-whatsapp{

    color:#25D366;

    font-size:20px;

}

/*====================================================
HAMBURGER
====================================================*/

.rv-menu-toggle{

    display:none;

    width:44px;

    height:44px;

    border:none;

    background:none;

    color:#FFFFFF;

    cursor:pointer;

}

.rv-menu-toggle i{

    font-size:34px;

}

/*====================================================
OFFCANVAS
====================================================*/

.rv-mobile-menu{

    position:fixed;

    top:0;
    right:-320px;

    width:300px;

    max-width:85%;

    height:100vh;

    padding:28px 24px;

    background:#FFFFFF;

    transition:.35s ease;

    z-index:10001;

}

.rv-mobile-menu.active{

    right:0;

}

/*====================================================
OVERLAY
====================================================*/

.rv-mobile-overlay{

    position:fixed;

    inset:0;

    background:rgba(0,0,0,.45);

    opacity:0;

    visibility:hidden;

    transition:.30s ease;

    z-index:10000;

}

.rv-mobile-overlay.active{

    opacity:1;

    visibility:visible;

}

/*====================================================
MOBILE HEADER
====================================================*/

.rv-mobile-header{

    display:flex;

    align-items:center;

    justify-content:space-between;

    margin-bottom:30px;

}

.rv-close-menu{

    width:42px;

    height:42px;

    border:none;

    border-radius:12px;

    background:#0B3D91;

}

/*====================================================
MOBILE MENU
====================================================*/

.rv-mobile-menu ul{

    margin:0;

    padding:0;

    list-style:none;

}

.rv-mobile-menu li{

    border-bottom:1px solid #EEEEEE;

}

.rv-mobile-menu a{

    display:block;

    padding:14px 0;

    color:#062A5A;

    font-weight:600;

    text-decoration:none;

}

/*====================================================
MOBILE PARENT
====================================================*/

.rv-mobile-parent{

    padding:12px 0;

    border-bottom:1px solid #E5E7EB;

}

.rv-mobile-parent span{

    display:flex;

    align-items:center;

    justify-content:space-between;

    cursor:pointer;

    font-size:16px;

    font-weight:600;

    color:#0D2345;

}

.rv-mobile-parent i{

    transition:.3s ease;

}

.rv-mobile-parent.active i{

    transform:rotate(180deg);

}

/*====================================================
MOBILE SUBMENU
====================================================*/

.rv-mobile-submenu{

    display:none;

    margin-top:18px;

    margin-left:12px;

    padding:6px 0 6px 14px;

    background:rgba(11,61,145,.03);

    border-radius:10px;

}

.rv-mobile-parent.active .rv-mobile-submenu{

    display:block;

    padding-top:8px;

}

.rv-mobile-submenu li{

    margin:0 !important;

    border:none !important;

}

.rv-mobile-submenu a{

    display:block;

    padding:10px 0 !important;

    color:#667085 !important;

    font-size:15px !important;

    font-weight:500 !important;

    line-height:1.5;

}

.rv-mobile-submenu a:hover{

    color:#0B3D91 !important;

}

/*====================================================
MOBILE WHATSAPP
====================================================*/

.rv-mobile-wa{

    display:flex;

    align-items:center;

    justify-content:center;

    width:100%;

    margin-top:24px;

    padding:14px;

    border-radius:12px;

    background:#0B3D91;

    color:#FFFFFF !important;

    font-weight:700;

    text-align:center;

    transition:.25s ease;

}

.rv-mobile-wa:hover{

    transform:translateY(-2px);

}

/*====================================================
RESPONSIVE
TABLET
====================================================*/

@media(max-width:1024px){

    /* TOPBAR */

    .rv-topbar{

        display:none;

    }

    /* HEADER */

    .rv-header{

        top:0;

    }

    .rv-header .rv-container{

        display:flex;

        align-items:center;

        justify-content:space-between;

        min-height:78px;

        padding:0 18px;

    }

    /* LOGO */

    .rv-logo img{

        height:58px;

    }

    /* DESKTOP MENU */

    .rv-nav,
    .rv-header-action{

        display:none;

    }

    /* HAMBURGER */

    .rv-menu-toggle{

        display:flex;

        align-items:center;

        justify-content:center;

    }

    /* TOPBAR SOCIAL */

    .rv-topbar-socials{

        display:none;

    }

}

/*====================================================
RESPONSIVE
MOBILE
====================================================*/

@media(max-width:767px){

    .rv-header .rv-container{

        min-height:72px;

        padding:0 14px;

    }

    .rv-logo img{

        height:58px;

    }

}

/*====================================================
HERO
====================================================*/

.rv-hero{

    position:relative;

    display:flex;

    align-items:center;

    min-height:calc(100vh - 120px);

    background-image:
        linear-gradient(
            rgba(6,42,90,.72),
            rgba(6,42,90,.82)
        ),
        url("https://repve.com/wp-content/uploads/2026/06/1.Foto-Latar-belakang-utama-1.png");

    background-repeat:no-repeat;

    background-position:center;

    background-size:cover;

    overflow:hidden;

}

/*====================================================
HERO CONTAINER
====================================================*/

.rv-hero-container{

    width:100%;

    max-width:1280px;

    margin:0 auto;

    padding:80px 24px;

}

/*====================================================
HERO CONTENT
====================================================*/

.rv-hero-content{

    max-width:760px;

    padding-top:10px;

}

/*====================================================
BADGE
====================================================*/

.hero-badges{

    display:flex;

    flex-wrap:wrap;

    gap:10px;

    margin-bottom:20px;

}

.hero-badge{

    display:inline-flex;

    align-items:center;

    gap:8px;

    padding:10px 18px;

    border:1px solid rgba(255,255,255,.12);

    border-radius:999px;

    background:rgba(255,255,255,.10);

    backdrop-filter:blur(10px);

    color:#FFFFFF;

    font-size:14px;

    font-weight:600;

    line-height:1;

}

/*====================================================
TITLE
====================================================*/

.rv-hero h1{

    margin:0 0 20px;

    color:#FFFFFF;

    font-size:68px;

    font-weight:800;

    line-height:1.05;

}

.rv-hero p{

    max-width:620px;

    color:rgba(255,255,255,.88);

    font-size:20px;

    line-height:1.8;

}

/*====================================================
BUTTON
====================================================*/

.rv-hero-buttons{

    display:flex;

    gap:18px;

    margin-top:40px;

}

.rv-btn-primary{

    padding:16px 30px;

    border-radius:14px;

    background:#FFFFFF;

    color:#0B3D91;

    font-weight:700;

}

.rv-btn-secondary{

    padding:16px 30px;

    border:1px solid rgba(255,255,255,.35);

    border-radius:14px;

    background:transparent;

    backdrop-filter:blur(8px);

    color:#FFFFFF;

    transition:.3s ease;

}

.rv-btn-secondary:hover{

    background:#FFFFFF;

    color:#0B3D91 !important;

    border-color:#FFFFFF;

    box-shadow:0 10px 30px rgba(255,255,255,.15);

}

/*====================================================
HERO STATS
====================================================*/

.rv-hero-stats{

    display:flex;

    gap:60px;

    margin-top:60px;

}

.rv-hero-stats strong{

    display:block;

    color:#FFFFFF;

    font-size:34px;

    font-weight:800;

}

.rv-hero-stats span{

    color:rgba(255,255,255,.75);

}

/*====================================================
MOBILE SOCIAL
====================================================*/

.rv-mobile-social-label{

    position:relative;

    margin-top:18px;

    margin-bottom:12px;

    padding-top:18px;

    color:#98A2B3;

    font-size:11px;

    font-weight:700;

    letter-spacing:2px;

    text-align:center;

    text-transform:uppercase;

}

.rv-mobile-social-label::before{

    content:"";

    position:absolute;

    top:0;

    left:50%;

    transform:translateX(-50%);

    width:120px;

    height:1px;

    background:#E6EDF7;

}

.rv-mobile-socials{

    display:flex;

    justify-content:center;

    gap:14px;

    margin-top:22px;

    padding-top:22px;

    border-top:none;

}

.rv-mobile-socials a{

    display:flex;

    align-items:center;

    justify-content:center;

    width:46px;

    height:46px;

    border-radius:14px;

    background:#F5F8FC;

    color:#0B3D91;

    transition:.25s ease;

}

.rv-mobile-socials a i{

    font-size:18px;

}

.rv-mobile-socials a:hover{

    background:#0B3D91;

    color:#FFFFFF;

    transform:translateY(-2px);

}

/*====================================================
HERO ANIMATION
====================================================*/

.hero-badges{

    animation:fadeDown .8s ease forwards;

}

.rv-hero h1{

    opacity:0;

    animation:fadeLeft 1s ease forwards;

    animation-delay:.2s;

}

.rv-hero p{

    opacity:0;

    animation:fadeUp 1s ease forwards;

    animation-delay:.5s;

}

.rv-hero-buttons{

    opacity:0;

    animation:fadeUp 1s ease forwards;

    animation-delay:.8s;

}

.rv-hero-stats{

    opacity:0;

    animation:fadeUp 1s ease forwards;

    animation-delay:1.1s;

}

/*====================================================
KEYFRAMES
====================================================*/

@keyframes fadeLeft{

    from{

        opacity:0;

        transform:translateX(-50px);

    }

    to{

        opacity:1;

        transform:translateX(0);

    }

}

@keyframes fadeUp{

    from{

        opacity:0;

        transform:translateY(40px);

    }

    to{

        opacity:1;

        transform:translateY(0);

    }

}

@keyframes fadeDown{

    from{

        opacity:0;

        transform:translateY(-25px);

    }

    to{

        opacity:1;

        transform:translateY(0);

    }

}

/*====================================================
HERO RESPONSIVE
====================================================*/

@media(max-width:767px){

    /* HERO */

    .rv-hero{

        min-height:auto;

        padding-top:10px;

        padding-bottom:50px;

    }

    .rv-hero-container{

        padding:75px 24px 0;

    }

    .rv-hero-content{

        padding-top:0;

    }

    /* BADGE */

    .hero-badges{

        margin-top:-30px;

    }

    .hero-badge{

        padding:10px 16px;

        font-size:13px;

    }

    /* TITLE */

    .rv-hero h1{

        font-size:32px;

        line-height:1.15;

    }

    .rv-hero p{

        margin-bottom:0;

        font-size:16px;

        line-height:1.6;

    }

    /* BUTTON */

    .rv-hero-buttons{

        display:flex;

        flex-direction:column;

        align-items:center;

        gap:14px;

    }

    .rv-btn-primary,
    .rv-btn-secondary{

        width:280px;

        max-width:100%;

        text-align:center;

        justify-content:center;

    }

    /* STATS */

    .rv-hero-stats{

        gap:12px;

        justify-content:space-between;

        width:100%;

    }

    .rv-hero-stats strong{

        font-size:22px;

    }

    .rv-hero-stats span{

        font-size:13px;

    }

}

html,
body{

    overflow-x:hidden;

}/* End custom CSS */