.elementor-2347 .elementor-element.elementor-element-8e9842e{--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;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2347 .elementor-element.elementor-element-d084b69{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2347 .elementor-element.elementor-element-c4f40ae{--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;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2347 .elementor-element.elementor-element-c23a005{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2347 .elementor-element.elementor-element-3ed3e50{--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;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2347 .elementor-element.elementor-element-e414e6a{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}/* Start custom CSS for html, class: .elementor-element-b0df46b */:root{

--rv-primary:#0A2F73;
--rv-secondary:#174AAE;
--rv-gold:#D4A017;
--rv-green:#22C55E;
--rv-dark:#1F2937;
--rv-text:#4B5563;
--rv-bg:#F8FAFC;
--rv-border:#E5E7EB;
--rv-white:#FFFFFF;

}

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

.rtve-hero{
position:relative;
height:85vh;
min-height:900px;
overflow:hidden;
display:flex;
align-items:center;
justify-content:center;
}

.rtve-hero video{
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
object-fit:cover;
}

.rtve-overlay{
position:absolute;
inset:0;
background:rgba(10,47,115,.70);
}

.rtve-content{
position:relative;
z-index:2;
max-width:900px;
text-align:center;
padding:0 20px;
color:#fff;
}

.rtve-badge{
display:inline-block;
padding:10px 22px;
border-radius:50px;
background:rgba(255,255,255,.15);
backdrop-filter:blur(10px);
border:1px solid rgba(255,255,255,.25);
font-size:13px;
font-weight:600;
letter-spacing:1px;
margin-bottom:25px;
}

.rtve-subtitle{
display:block;
font-size:16px;
margin-bottom:30px;
opacity:.9;
}

.rtve-content h1{
font-size:64px;
line-height:1.1;
font-weight:700;
margin-bottom:25px;
color:#fff;
}

.rtve-content p{
font-size:22px;
line-height:1.8;
opacity:.95;
max-width:850px;
margin:auto;
}

.rtve-buttons{
display:flex;
gap:15px;
justify-content:center;
margin-top:40px;
flex-wrap:wrap;
}

.rtve-btn-primary{
background:var(--rv-gold);
color:#fff;
padding:16px 32px;
border-radius:50px;
text-decoration:none;
font-weight:600;
}

.rtve-btn-outline{
border:1px solid rgba(255,255,255,.4);
padding:16px 32px;
border-radius:50px;
color:#fff;
text-decoration:none;
font-weight:600;
}

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

@media(max-width:768px){

.rtve-hero{
height:auto;
min-height:700px;
padding:120px 0 80px;
}

.rtve-content h1{
font-size:42px;
}

.rtve-content p{
font-size:18px;
line-height:1.7;
}

.rtve-buttons{
flex-direction:column;
align-items:center;
}

.rtve-btn-primary,
.rtve-btn-outline{
width:100%;
max-width:280px;
text-align:center;
}

}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-10ecace *//* =====================================
RTVE INTRO
===================================== */

.rtve-intro{
padding:120px 20px;
background:#fff;
}

.rtve-wrap{
max-width:1280px;
margin:auto;
display:grid;
grid-template-columns:480px 1fr;
gap:100px;
align-items:start;
}

/* LEFT */

.rtve-left{
display:flex;
flex-direction:column;
align-items:center;
}

.rtve-year{
font-size:100px;
font-weight:800;
line-height:1;
color:var(--rv-gold);
margin-bottom:25px;
}

.rtve-logo-circle{
width:180px;
height:180px;
border-radius:50%;
display:flex;
align-items:center;
justify-content:center;
font-size:72px;
font-weight:700;
color:#fff;

background:linear-gradient(
135deg,
#35C8FF,
#0095FF
);

box-shadow:
0 25px 60px rgba(0,149,255,.25);

margin-bottom:40px;
}

.rtve-revitalisasi{
background:#fff;
padding:40px;
border-radius:24px;

width:100%;

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

.rtve-revitalisasi h3{
font-size:34px;
font-weight:700;
color:var(--rv-primary);
margin-bottom:25px;
}

.rtve-revitalisasi p{
font-size:18px;
line-height:1.9;
color:var(--rv-text);
margin-bottom:18px;
}

/* RIGHT */

.rtve-right{
padding-top:30px;
}

.rtve-badge{
display:inline-block;
padding:10px 24px;
border-radius:999px;

background:#EEF3FF;
color:var(--rv-primary);

font-size:13px;
font-weight:700;
letter-spacing:1px;

margin-bottom:25px;
}

.rtve-right h2{
font-size:64px;
line-height:1.15;
font-weight:700;
color:var(--rv-primary);

margin-bottom:30px;
}

.rtve-right p{
font-size:22px;
line-height:2;
color:var(--rv-text);
}

/* ======================================
RTVE PREMIUM QUOTE
====================================== */

.rtve-quote{

    position:relative;

    margin-top:55px;

    padding:60px 50px;

    background:linear-gradient(
        180deg,
        #FFFDF8,
        #FFFFFF
    );

    border:1px solid rgba(212,160,23,.25);

    border-radius:24px;

    box-shadow:
        0 20px 50px rgba(0,0,0,.06);

    overflow:hidden;

    text-align:center;

}

.rtve-quote::before{

    content:"❝";

    position:absolute;

    top:18px;
    left:28px;

    font-size:90px;

    color:rgba(212,160,23,.18);

    line-height:1;

}

.rtve-quote::after{

    content:"❞";

    position:absolute;

    right:28px;
    bottom:0;

    font-size:90px;

    color:rgba(212,160,23,.18);

    line-height:1;

}

.rtve-quote p{

    margin:0;

    font-size:34px;

    line-height:1.55;

    font-weight:700;

    color:#D4A017;

}

.rtve-quote .quote-line{

    width:90px;

    height:4px;

    background:#D4A017;

    border-radius:99px;

    margin:0 auto 35px;

}

.rtve-quote .quote-line.bottom{

    margin:35px auto 0;

}

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

@media(max-width:1024px){

.rtve-wrap{
grid-template-columns:1fr;
gap:70px;
}

.rtve-left{
max-width:600px;
margin:auto;
}

.rtve-right{
padding-top:0;
text-align:center;
}

.rtve-right h2{
font-size:52px;
}

.rtve-quote span{
font-size:34px;
}

}

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

@media(max-width:767px){

.rtve-intro{
padding:80px 20px;
}

.rtve-year{
font-size:70px;
}

.rtve-logo-circle{
width:170px;
height:170px;
font-size:52px;
}

.rtve-revitalisasi{
padding:25px;
}

.rtve-revitalisasi h3{
font-size:26px;
}

.rtve-revitalisasi p{
font-size:16px;
line-height:1.8;
}

.rtve-right h2{
font-size:36px;
}

.rtve-right p{
font-size:17px;
line-height:1.8;
}

.rtve-quote{
padding:25px;
}

.rtve-quote span{
font-size:24px;
line-height:1.5;
}

}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-c790764 *//* ===================================
TIMELINE RTVE
=================================== */

.rtve-timeline{
    position:relative;
    padding:120px 20px;
    background:#F5F7FB;
    overflow:hidden;
}

.rtve-container{
    max-width:1400px;
    margin:auto;
    position:relative;
}

/* GARIS DASAR */

.timeline-line{
    position:absolute;
    left:50%;
    top:0;
    bottom:0;
    width:3px;
    background:#D8E1F2;
    transform:translateX(-50%);
    z-index:1;
}

/* GARIS AKTIF */

.timeline-progress{

    position:absolute;
    left:50%;
    top:0;
    width:4px;
    height:0;

    background:linear-gradient(
        180deg,
        #1f57c3,
        #4D8BFF
    );

    transform:translateX(-50%);
    z-index:5;

}

/* =====================================
MOVING DOT
===================================== */

.timeline-scroll-dot{

    position:absolute;

    left:50%;

    top:0;

    width:22px;

    height:22px;

    background:#1f57c3;

    border-radius:50%;

    transform:translateX(-50%);

    z-index:20;

    box-shadow:
    0 0 0 12px rgba(31,87,195,.15),
    0 0 0 24px rgba(31,87,195,.08);

    transition:top .08s linear;

}

/* ITEM */

.timeline-item{
    display:grid;
    grid-template-columns:1fr 120px 1fr;
    align-items:flex-start;
    position:relative;
    margin-bottom:140px;
}

.timeline-left{
    padding-right:40px;
}

.timeline-right{
    padding-left:40px;
}



/* CARD */

.timeline-card{
    background:#fff;
    padding:45px;
    border-radius:28px;
    box-shadow:
    0 20px 60px rgba(0,0,0,.08);

    height:100%;
}

.timeline-card:hover{
    transform:translateY(-8px);
    box-shadow:
    0 30px 70px rgba(0,0,0,.12);
}

.timeline-card h3{
    font-size:18px;
    line-height:1.35;
    color:#062A5A;
    margin-bottom:25px;
}

.timeline-card p{
    font-size:18px;
    line-height:1.9;
    color:#4B5563;
}

/* IMAGE */

.timeline-image + .timeline-image{
    margin-top:25px;
}

.timeline-image img{
    width:100%;
    border-radius:18px;
    display:block;
    object-fit:cover;
}

/* ===================================
TIMELINE GALLERY
=================================== */

.timeline-gallery{

    display:grid;

    gap:15px;

    margin-top:25px;

}

.gallery-2{

    grid-template-columns:repeat(2,1fr);

}

.gallery-3{

    grid-template-columns:repeat(3,1fr);

}

.timeline-gallery img{

    width:100%;

    display:block;

    border-radius:18px;

    object-fit:cover;

}

.rtve-caption{
    text-align:center;
    margin-top:18px;
    font-size:15px;
    color:#64748B;
    font-style:italic;
}

.timeline-video{
    margin-top:20px;
    border-radius:18px;
    overflow:hidden;
}

.timeline-video video{
    width:100%;
    display:block;
    border-radius:18px;
}

.timeline-date{

    font-size:42px;

    font-weight:800;

    color:var(--rv-primary);

    line-height:1;

    margin-bottom:24px;

}

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

.timeline-left,
.timeline-right{

    display:flex;
    flex-direction:column;

}

.timeline-badge{

    display:inline-flex;
    align-items:center;
    justify-content:center;

    width:max-content;

    padding:11px 24px;

    border-radius:999px;

    font-size:13px;
    font-weight:700;
    letter-spacing:1px;
    text-transform:uppercase;

    margin-bottom:22px;

    box-shadow:
        0 10px 25px rgba(0,0,0,.08);

    transition:all .3s ease;

}

/* posisi badge */

.timeline-left .timeline-badge,
.timeline-right .timeline-badge{

    align-self:flex-start;

}

/* hover */

.timeline-badge:hover{

    transform:translateY(-2px);

    box-shadow:
        0 18px 35px rgba(0,0,0,.12);

}

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

.badge-blue{

    background:#EEF4FF !important;
    color:#0A2F73 !important;

}

.badge-green{

    background:#ECFDF5 !important;
    color:#15803D !important;

}

.badge-purple{

    background:#F3E8FF !important;
    color:#7C3AED !important;

}

.badge-red{

    background:#FEF2F2 !important;
    color:#DC2626 !important;

}

.badge-gold{

    background:#FFF8E1 !important;
    color:#B7791F !important;

}

/* RESPONSIVE */

@media(max-width:991px){

    .timeline-line,
    .timeline-progress{
        left:20px;
    }

    .timeline-scroll-dot{
        left:20px;
        transform:translateX(-50%);
    }

    .timeline-item{
        grid-template-columns:50px 1fr;
        gap:20px;
    }

    .timeline-left,
    .timeline-right{
        grid-column:2;
        padding:0;
    }

}

@media(max-width:768px){

.timeline-date{
    font-size:34px;
}

.timeline-card p{
    font-size:18px;
}

}

/* =========================
SLIDE 18 - MILESTONE
========================= */

.cpve-badge{
    width:280px;
    height:280px;
    border-radius:50%;
    margin:0 auto 30px;
    background:linear-gradient(
        135deg,
        #18B9F3,
        #0095D9
    );
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:72px;
    font-weight:800;
}

.milestone-year{
    font-size:72px;
    font-weight:800;
    color:#6B3FB5;
    line-height:1;
    margin-bottom:25px;
}

.milestone-card h3{
    color:#6B3FB5;
}

/* ======================================
PREMIUM QUOTE
====================================== */

.milestone-quote{

    position:relative;

    margin-top:55px;

    padding:60px 50px;

    background:linear-gradient(
        180deg,
        #FFFDF8,
        #FFFFFF
    );

    border:1px solid rgba(212,160,23,.25);

    border-radius:24px;

    box-shadow:
        0 20px 50px rgba(0,0,0,.06);

    overflow:hidden;

    text-align:center;

}

.milestone-quote::before{

    content:"❝";

    position:absolute;

    top:18px;
    left:28px;

    font-size:90px;

    color:rgba(212,160,23,.18);

    font-family:serif;

    line-height:1;

}

.milestone-quote::after{

    content:"❞";

    position:absolute;

    right:28px;
    bottom:0;

    font-size:90px;

    color:rgba(212,160,23,.18);

    font-family:serif;

    line-height:1;

}

.milestone-quote p{

    margin:0;

    font-size:30px;

    line-height:1.55;

    font-weight:700;

    color:#D4A017;

    max-width:680px;

    margin-inline:auto;

}

.milestone-quote .quote-line{

    width:90px;
    height:4px;

    background:#D4A017;

    border-radius:99px;

    margin:0 auto 35px;

}

.milestone-quote .quote-line.bottom{

    margin:35px auto 0;

}

.timeline-video iframe{
    width:100%;
    aspect-ratio:16/9;
    border:none;
    border-radius:16px;
    display:block;
}/* End custom CSS */