:root {
    --brand: #ff8f00;
    /* primary orange */
    --brand-2: #009fe3;
    /* blue accents */
    --ink: #1f2937;
    /* text */
    --muted: #6b7280;
    /* muted text */
    --bg: #fff7ef;
    /* warm paper */
    --chip: #f1f5f9;
    /* tag bg */
    --rounded-xxl: 2rem;
    --bg-gray: #fcf7f5;
}

body {
    font-family: "Roboto", sans-serif;
    color: var(--ink);
}

.bg-gray {
    background-color: var(--bg-gray);
}

/* Hero */
.hero {
    color: #fff;
    position: relative;
    overflow: hidden;
}

.container {
    max-width: 1440px;
}

.container_small {
    max-width: 1200px;
    margin: 0 auto;
}
img.wave {
    position: absolute;
    bottom: 0;
    width: 100%;
    left: 0;
}

header.hero {
    min-height: 788px;
    h1 {
        font-style: italic;
        font-weight: 700;
        font-size: 97.56px;
        line-height: 100%;
        font-family: "PT Serif", serif;
        color: #383838;
        margin-top: 10px;
        margin-bottom: 35px;
        @media (max-width: 991.98px) {
            font-size: 70px;
            line-height: 112%;
            margin-top: 21px;
            margin-bottom: 25px;
            text-align: left;
        }
    }

    p.lead {
        font-family: "Roboto", sans-serif;
        font-style: normal;
        font-weight: 700;
        font-size: 30.824px;
        line-height: 130%;
        color: #383838;
        max-width: 357px;

        @media (max-width: 991.98px) {
            font-size: 22px;
            line-height: 130%;
            text-align: left;
            max-width: 305px;
        }
    }
    ul.navbar-nav {
        border: 2px solid #fff;
        border-radius: 100px;
        padding: 1px 10px;
        margin-top: 10px !important;
        @media (max-width: 991.98px) {
            border: 0px;
        }
    }
    a.nav-link {
        font-size: 12.6px;
        color: #fff;
        font-weight: bold;
        text-transform: uppercase;
    }
    .delfi_logo {
        margin-right: 15px;
        margin-top: 10px;
        padding-bottom: 10px;
    }
}

/* Section bubbles */
section#apie {
    background: #fcf7f5;
    .bubble {
        background: #7ac5e4;
        border-radius: 999px;
        padding: 1.6rem 1.5rem 1.6rem;
        color: #0b3b57;
        max-width: 1200px;
        margin: 0 auto;
        h2 {
            font-style: normal;
            font-weight: 700;
            font-size: 40px;
            line-height: 110%;
            text-align: center;
            color: #ffffff;
            font-family: "Roboto", sans-serif;
        }
        p {
            font-style: normal;
            font-weight: 400;
            font-size: 18px;
            line-height: 130%;
            text-align: center;
            color: #fcf7f5;
            span {
                font-weight: 700;
            }
        }
        h5 {
            font-style: normal;
            font-weight: 400;
            font-size: 18px;
            line-height: 130%;
            text-align: center;
            color: #fcf7f5;
            max-width: 747px;
        }
    }

    .pill {
        gap: 0.35rem;
        padding: 4.5px 13px;
        border-radius: 999px;
        font-style: normal;
        font-weight: 700;
        font-size: 20px;
        line-height: 110%;
        display: flex;
        align-items: center;
        text-align: center;
        color: #ffffff;
        border: 1px solid #fff;
        position: relative;
    }

    .pill.last {
        border: 1px dashed #fff;
        color: #000;
        text-transform: uppercase;
    }

    span.pill:after {
        content: "";
        position: absolute;
        width: 46px;
        height: 1px;
        background: #fff;
        right: -48px;
    }

    .pill.last:after {
        content: none;
    }

    .pill .dot {
        width: 0.5rem;
        height: 0.5rem;
        border-radius: 999px;
        background: var(--brand);
    }
}

/* Card gallery */

section.miestai {
    background: url(../images/registracija.svg) no-repeat center top / cover;
    padding: 85px 0px;
    h2 {
        font-style: normal;
        font-weight: 700;
        font-size: 40px;
        line-height: 100%;
        text-align: center;
        text-transform: uppercase;
        color: #383838;
        margin-bottom: 30px;
    }
    h4 {
        font-style: normal;
        font-weight: 400;
        font-size: 18px;
        line-height: 140%;
        text-align: center;
        color: #383838;
        margin-bottom: 15px;
    }
    p {
        font-style: normal;
        font-weight: 400;
        font-size: 12px;
        line-height: 70%;
        text-align: center;
        color: #383838;
        @media (max-width: 991.98px) {
            line-height: 1.5;
        }
    }
    .card-body {
        padding: 10px;
    }
}

.city-card {
    border: none;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 8px 24px rgba(2, 8, 23, 0.08);
}

.city-card img {
    aspect-ratio: 4/3;
    object-fit: cover;
}

.city-card .like {
    position: absolute;
    left: 0;
    top: 0;
    background: rgb(255, 255, 255);
    color: rgb(249, 115, 22);
    border-radius: 0px;
    padding: 0.5rem 0.7rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 0.35rem;
    width: 100%;
    font-size: 20px;
}

.city-card .city {
    font-weight: 700;
    color: #383838;
    text-align: center;
    width: 100%;
    font-size: 18px;
}

.city-card .fav {
    position: absolute;
    right: 0.75rem;
    bottom: 0.5rem;
    border-radius: 999px;
    padding: 0.35rem;
    font-size: 11px;
    border: 0px;
    width: 100%;
    max-width: 87px;
    height: 29px;
    color: #fff;
    background: #f68d21;
    font-weight: 500;
}
a.fb_share {
    font-family: "Roboto", sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 14.0845px;
    line-height: 10px;
    display: flex;
    align-items: center;
    text-align: center;
    color: #383838;
    text-decoration: none;
    position: absolute;
    right: 10px;
    top: 10px;
    border: 1px solid #000;
    border-radius: 24px;
    padding: 0px 10px;
    max-width: 87px;
    height: 29px;
    gap: 4px;
}
a.fb_share img {
    max-width: 7px;
    width: 100%;
    aspect-ratio: auto;
}
img.partner {
    max-width: 187px;
}
/* Search form */
.suggest {
    margin-top: 30px;
    margin-bottom: 50px !important;
    button#suggestBtn {
        max-width: 186px;
        margin: 0 auto;
        background: #fff;
        color: #383838;
        border-radius: 32px;
        height: 45px;
        font-size: 15px;
        padding: 11px;
        width: 100%;
        margin-top: 16px;
    }
    select#city {
        background: transparent;
        border: 1px solid #000;
        max-width: 387px;
        margin: 0 auto;
    }
}

/* Map mock */
#zemelapis {
    background: #ecf5ff;
    padding: 80px 0px;
    h2 {
        font-style: normal;
        font-size: 40px;
        line-height: 100%;
        text-align: center;
        text-transform: uppercase;
        color: #383838;
        @media (max-width: 991.98px) {
            font-size: 16px;
        }
    }
    .warning {
        color: #f68d21;
    }
    img.zemlapis {
        margin: 100px auto;
        display: block;
        @media (max-width: 991.98px) {
            max-width: 100%;
        }
    }
}

/*Below map*/
#naujienos {
    padding: 120px 0px 40px 0;
    /* display: none; */
    .container_small {
        max-width: 1200px;
        margin: 0 auto;
        h2 {
            font-style: normal;
            font-size: 40px;
            line-height: 100%;
            text-align: center;
            text-transform: uppercase;
            color: #383838;
            margin-bottom: 45px;
        }
        .news-card {
            border: none;
            border-radius: 0rem;
            overflow: hidden;
            background: transparent;
            transition: opacity 0.3s ease, transform 0.3s ease;
            cursor: pointer;
            .card-body {
                padding: 10px 0;
                p {
                    font-style: normal;
                    font-weight: 500;
                    font-size: 15px;
                    line-height: 130%;
                    color: #383838;
                }
            }
            img {
                aspect-ratio: 16/9;
                object-fit: cover;
            }
            &:hover {
                opacity: 0.85;
                transform: translateY(-2px);
            }
        }
    }
    .below_map {
        background: transparent;
        position: absolute;
        top: -90px;
        margin: 0 auto;
        left: 0;
        right: 0;
        .bubble {
            background: #7ac5e4;
            border-radius: 999px;
            padding: 1.6rem 1.5rem 1.6rem;
            color: #0b3b57;
            max-width: 1200px;
            margin: 0 auto;
            h2 {
                font-style: normal;
                font-weight: 700;
                font-size: 40px;
                line-height: 110%;
                text-align: center;
                color: #ffffff;
                font-family: "Roboto", sans-serif;
            }
            p {
                font-style: normal;
                font-weight: 400;
                font-size: 18px;
                line-height: 130%;
                text-align: center;
                color: #fcf7f5;
                span {
                    font-weight: 700;
                }
            }
            h5 {
                font-style: normal;
                font-weight: 400;
                font-size: 18px;
                line-height: 130%;
                text-align: center;
                color: #fcf7f5;
                max-width: 747px;
            }
        }
        .full_pill {
            display: flex;
            flex-direction: column;
            gap: 8px;
        }
        .pill {
            gap: 0.35rem;
            border-radius: 999px;
            font-style: normal;
            font-weight: 700;
            line-height: 110%;
            display: flex;
            align-items: center;
            text-align: center;
            color: #ffffff;
            border: 1px solid #fff;
            position: relative;
            font-size: 25.3px;
            padding: 6px 24.3px;
            justify-content: center;
        }
        .pill.no:after {
            content: none;
        }
        span.pill_below {
            max-width: 195px;
            width: auto;
            font-style: normal;
            font-weight: 700;
            font-size: 15px;
            line-height: 155%;
            text-align: center;
            letter-spacing: -0.01em;
            color: #383838;
        }
        span.pill:after {
            content: "";
            position: absolute;
            width: 46px;
            height: 1px;
            background: #fff;
            right: -48px;
        }
    }
}

a.load_more {
    color: #383838;
    font-size: 15px;
    font-weight: 500;
    margin-top: 50px;
}

.map_area {
    position: relative;
    img.car_icon {
        position: absolute;
        width: 40px; /* adjust size if needed */
        height: auto;
        transition: all 0.4s ease;
        margin: 0 auto;
    }
}

/*Promo*/
#promos {
    .container {
        max-width: 879px;
    }
    h2 {
        font-style: normal;
        font-weight: 700;
        font-size: 40px;
        line-height: 100%;
        text-align: center;
        text-transform: uppercase;
        color: #383838;
        margin-bottom: 30px;
    }
    span.badge-chip {
        font-style: normal;
        font-weight: 700;
        font-size: 20px;
        line-height: 110%;
        display: flex;
        align-items: center;
        color: #383838;
        border: 1px solid #f68d21;
        border-radius: 23px;
        padding: 4px 10px 4px 40px;
        position: relative;
        span.circle {
            background: #f68d21;
            width: 32.46px;
            height: 32.46px;
            border-radius: 100px;
            position: absolute;
            left: 0;
        }
    }
}

/* Partners */
#partner {
    background: url(../images/partneriai.svg) no-repeat center top / cover;
    h3 {
        font-style: normal;
        font-weight: 700;
        font-size: 40px;
        line-height: 100%;
        text-align: center;
        text-transform: uppercase;
        color: #ffffff;
        padding-top: 40px;
    }
    .partner_logo {
        margin-top: 40px;
    }
}

/* Footer */
.site-footer {
    background: #dff2ff;
    border-top: 6px solid #bfe6ff;
}

/* Small helpers */
.section-divider {
    height: 20px;
    background: repeating-linear-gradient(
        90deg,
        #bfe6ff 0 16px,
        #a9defd 16px 32px
    );
    opacity: 0.4;
}

.w-40ch {
    max-width: 40ch;
}

@media (max-width: 575.98px) {
    .bubble {
        border-radius: 1.25rem;
    }
}

/* Burger lines */
.navbar-toggler {
    border: none;
    padding: 0.25rem 0.5rem;
}

.navbar-toggler:focus {
    box-shadow: none;
}

.navbar-toggler .toggler-line {
    display: block;
    width: 38px;
    height: 3px;
    margin: 8px 0;
    background-color: #fff; /* dark ink, change if needed */
    transition: transform 0.25s ease, opacity 0.25s ease;
}

/* Optional: nicer mobile dropdown */
.hero-nav {
    background: transparent;
}

.fixed-nav {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 9999;
    background: #eb8c2e; /* your orange or white */
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}
.kelione_logo {
    display: none;
}
.fixed-nav .kelione_logo {
    display: block;
}

.delfi_logo.sp {
    display: none;
}

/* new map hover */
/* MAP WRAPPER */
.kk-map-wrapper {
    display: flex;
    justify-content: center;
}

.kk-map-inner {
    position: relative;
    max-width: 980px; /* adjust to taste */
    width: 100%;
    margin-bottom: 45px;
    margin-top: 40px;
}

.kk-map-img {
    width: 100%;
    height: auto;
    display: block;
    max-width: 923px;
}

.kk-city-hotspot {
    position: absolute;
    width: 100px; /* radius of clickable area */
    height: 100px;
    transform: translate(-50%, -50%);
    cursor: pointer;
    z-index: 5; /* above SVG */
}

/* You can tweak these % so they sit exactly on top of your city pins */
.kk-city-hotspot--klaipeda {
    top: 29%; /* vertical on map */
    left: 5.5%; /* horizontal on map */
}

.kk-city-hotspot--siauliai {
    top: 21%;
    left: 37%;
}

.kk-city-hotspot--panevezys {
    top: 28%;
    left: 52%;
}

.kk-city-hotspot--marijampole {
    top: 70%;
    left: 37%;
}

.kk-city-hotspot--alytus {
    top: 76%;
    left: 50%;
}

/* POPUP BOX */
.kk-city-popup {
    position: absolute;
    left: 50%;
    top: 220px;
    transform: translate(-50%, -110%);
    background: #6ac0ee; /* blue like your design */
    color: #ffffff;
    padding: 20px 28px;
    border-radius: 10px;
    min-width: 260px;
    max-width: 320px;
    text-align: center;
    box-shadow: 0 14px 25px rgba(0, 0, 0, 0.18);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.15s ease, transform 0.15s ease;
}

/* close icon (optional – mostly for mobile aesthetics) */
.kk-popup-close {
    position: absolute;
    top: 6px;
    right: 10px;
    border: none;
    background: transparent;
    color: #ffffff;
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
}

.kk-city-popup h3 {
    margin: 0 0 8px;
    font-size: 25px;
    font-weight: 800;
    letter-spacing: 0.04em;
}

.kk-city-popup p {
    margin: 0;
    font-size: 17px;
    font-weight: 800;
    color: #383838;
}

.kk-city-popup .time {
    margin-top: 6px;
    font-weight: 700;
    color: #383838;
}

.kk-city-hotspot.active .kk-city-popup {
    opacity: 1;
    pointer-events: auto;
    transform: translate(-50%, -125%);
}
a.apie_ele {
    font-family: "Roboto", sans-serif;
    font-style: normal;
    font-weight: 700;
    font-size: 12px;
    line-height: 23px;
    text-align: right;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #ffffff;
    margin-right: 7px;
    margin-top: 10px;
    padding-bottom: 0px;
    text-decoration: none;
}
#naujienos .below_map span.pill:after {
    content: none;
}
a.nav-link.sp {
    display: none;
}

.hero {
    position: relative;
    min-height: 100vh;
    overflow: hidden;
}

/* Video background */
.hero-bg-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 0;
}

.sp {
    display: none;
}

/* Left orange image */
.hero-left-img {
    position: absolute;
    top: 0;
    left: 0;
}

/* Mobile tweaks */
@media (max-width: 767.98px) {
    .hero {
        min-height: auto;
    }

    .hero-inner {
        padding-top: 110px;
        padding-bottom: 80px;
        text-align: center;
    }
}

@media (max-width: 991.98px) {
    a.apie_ele.pc {
        display: none;
    }
    a.nav-link.sp {
        display: block;
    }
    img.elektrum_logo_2,
    .delfi_logo.pc {
        display: none !important;
    }
    .delfi_logo.sp {
        display: block !important;
    }

    .hero-nav .navbar-collapse {
        padding-top: 0.75rem;
        padding-bottom: 0.75rem;
        position: fixed;
        top: 85px;
        background: #f68d21;
        width: 100%;
        left: 0;
    }

    .hero-nav .nav-link {
        padding: 0.5rem 0;
        text-align: center;
    }
    li.nav-item {
        width: 100%;
    }
    .header_bar {
        flex-direction: column-reverse;
        padding: 0px !important;
        .col-lg-7 {
            padding: 0px !important;
        }
        a.nav-link {
            font-size: 20px !important;
            color: #fff !important;
            font-weight: bold;
            text-transform: uppercase;
            text-align: center !important;
        }
    }
    header.hero {
        min-height: 182vw;
    }
    .bubble {
        border-radius: 20px !important;
    }
    h2,
    h3 {
        font-size: 25px !important;
        line-height: 36px !important;
    }
    section.miestai {
        padding: 125px 0px;
    }
    .below_map {
        position: relative !important;
        top: 20px !important;
        padding-left: 15px;
        padding-right: 15px;
        margin-bottom: 100px !important;
    }
    .full_pill {
        margin-bottom: 24px !important;
    }
    #zemelapis {
        padding: 70px 0px 1px !important;
    }
    #naujienos {
        padding: 10px 0px 40px 0 !important;
    }
    .container_small {
        padding-left: 15px !important;
        padding-right: 15px !important;
    }
    .partner {
        max-width: 100% !important;
    }
    img.program {
        max-width: 100% !important;
    }
    #promos span.badge-chip {
        font-size: 16px;
    }
    img.elektrum_logo {
        max-width: 160px;
    }
    .kk-city-popup h3 {
        font-size: 18px !important;
    }
    .kk-city-popup p {
        font-size: 14px;
    }
    .kk-city-popup {
        top: 205px;
        min-width: 225px;
    }
    .kk-city-hotspot--klaipeda {
        top: 29%; /* vertical on map */
        left: 5.5%; /* horizontal on map */
    }

    .kk-city-hotspot--siauliai {
        top: 21%;
        left: 39%;
    }

    .kk-city-hotspot--panevezys {
        top: 28%;
        left: 55%;
    }

    .kk-city-hotspot--marijampole {
        top: 71%;
        left: 39%;
    }

    .kk-city-hotspot--alytus {
        top: 70%;
        left: 53%;
    }
    .kk-city-hotspot {
        width: 40px;
        height: 40px;
    }
    .kk-city-hotspot .kk-city-popup {
        left: 175%;
    }
    .energy_part .pill {
        margin: 10px auto;
        display: block !important;
        &:nth-child(1) {
            max-width: 142px;
        }
        &:nth-child(2) {
            max-width: 167px;
        }
        &:nth-child(3) {
            max-width: 120px;
        }
        &:nth-child(4) {
            max-width: 114px;
        }
        &:nth-child(5) {
            max-width: 132px;
        }
        &:nth-child(6) {
            max-width: 294px;
        }
    }
    section#apie span.pill:after {
        content: "";
        position: absolute;
        width: 1.4px;
        height: 28px;
        background: #fff;
        right: 50%;
        top: 32px;
    }

    section#apie .bubble h2 {
        font-size: 30px !important;
    }
    .sp {
        display: block;
    }
    .pc {
        display: none;
    }
    img.wave {
        bottom: -2px;
    }
    .hero-left-img {
        width: 100%;
    }
}
