@import url("https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap");

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: "Poppins";
    font-weight: 400;
}

strong {
    font-weight: bold;
}

ul,
ol {
    margin: 0;
    padding: 0;
    list-style-type: none;
}

a {
    text-decoration: none;
    color: #000;
}

h1,
h2,
h3,
h4,
h5,
h6,
p {
    margin: 0;
}

/* ! copyright end */

.dotmap {
    position: absolute;
    width: max-content;
    left: 8vw;
    overflow: hidden;

    .row {
        &:after {
            content: "";
            display: table;
            clear: both;
        }
    }


    /* ⬅️ Limit height */
    z-index: -1;
}

@media (max-width: 1100px) {
    .dotmap {
        left: 8vw;
    }
}

@media (max-width: 900px) {
    .dotmap {
        left: 4vw;
    }
}

@media (max-width: 700px) {
    .dotmap {
        max-height: 0vh;
    }
}


.paragraph-section {
    padding: 3vh;
    background-color: rgba(242, 242, 242, 0.5);
    width: 75vw;
    margin: 5vh auto;
    min-height: 30vh;
    /* space between groups */
    /* wrap to next line if not enough space */
}

@media (max-width: 1100px) {
    .paragraph-section {
        padding: 2vh;
        margin: 4vh auto;
        min-height: 20vh;
        width: 78vw;
    }
}

@media (max-width: 900px) {
    .paragraph-section {
        padding: 1vh;
        margin: 2vh auto;
        min-height: 10vh;
        width: 80vw;
    }
}

@media (max-width: 700px) {
    .paragraph-section {
        padding: 0.75vh;
        margin: 1.5vh auto;
        min-height: 5vh;
        width: 82vw;
    }
}

.paragraph {
    margin-bottom: 2vh;
    line-height: 3.5vh;
    font-size: 1.1vw;
    text-align: justify;
}

@media (max-width: 1100px) {
    .paragraph {
        margin-bottom: 1.5vh;
        line-height: 3vh;
        font-size: 1.3vw;
    }
}

@media (max-width: 900px) {
    .paragraph {
        margin-bottom: 1vh;
        line-height: 2vh;
        font-size: 1.5vw;
    }
}

@media (max-width: 700px) {
    .paragraph {
        margin-bottom: 0.8vh;
        line-height: 1.75vh;
        font-size: 2.25vw;
    }
}


.heading {
    font-size: 1.25vw;
    font-weight: bold;
    margin-top: 1vh;
    margin-bottom: 1vh;
    color: #b31917;
}

@media (max-width: 1100px) {
    .heading {
        font-size: 1.5vw;
        margin-top: 0.75vh;
        margin-bottom: 0.75vh;
    }
}

@media (max-width: 900px) {
    .heading {
        font-size: 1.75vw;
        margin-top: 0.5vh;
        margin-bottom: 0.5vh;
    }
}

@media (max-width: 700px) {
    .heading {
        font-size: 3.5vw;
        margin-top: 0.25vh;
        margin-bottom: 0.25vh;
    }
}

.paragraph-list {
    list-style-type: disc;
    list-style: outside;
    padding-left: 2vw;
    font-size: 1.1vw;
    line-height: 4vh;
    text-align: justify;
}

@media (max-width: 1100px) {
    .paragraph-list {
        padding-left: 2.25vw;
        font-size: 1.2vw;
        line-height: 3.5vh;
    }
}

@media (max-width: 900px) {
    .paragraph-list {
        padding-left: 2.5vw;
        font-size: 1.3vw;
        line-height: 2.5vh;
    }
}

@media (max-width: 700px) {
    .paragraph-list {
        padding-left: 2.75vw;
        font-size: 2.25vw;
        line-height: 2vh;
    }
}

.paragraph-list-below {
    list-style: circle;
    padding-left: 2vw;
    font-size: 1.1vw;
    line-height: 4vh;
    text-align: justify;
}

@media (max-width: 1100px) {
    .paragraph-list-below {
        padding-left: 2.25vw;
        font-size: 1.2vw;
        line-height: 3.5vh;
    }
}

@media (max-width: 900px) {
    .paragraph-list-below {
        padding-left: 2.5vw;
        font-size: 1.3vw;
        line-height: 2.5vh;
    }
}

@media (max-width: 700px) {
    .paragraph-list-below {
        padding-left: 2.75vw;
        font-size: 2.25vw;
        line-height: 2.25vh;
    }
}

.paragraph-image {
    float: right;
    width: 20vw;
    /* adjust as needed */
    height: auto;
    margin: 0 0.5vw 2vh 0;
    margin-left: 1vw;
    cursor: pointer;
    /* spacing: right & bottom */

    /* optional rounded corners */
}

@media (max-width: 1100px) {

    .paragraph-image {
        width: 25vw;
        /* adjust as needed */
        margin: 0 0.75vw 1.5vh 0;
        margin-left: 1.25vw;
        /* spacing: right & bottom */
        /* optional rounded corners */
    }
}

@media (max-width: 900px) {
    .paragraph-image {
        width: 30vw;
        /* adjust as needed */
        margin: 0 1vw 1vh 0;
        margin-left: 1.5vw;
        /* spacing: right & bottom */
        /* optional rounded corners */
    }
}

@media (max-width: 700px) {
    .paragraph-image {
        width: 34vw;
        /* adjust as needed */
        margin: 0 2vw 0.5vh 0;
        margin-left: 2vw;
        /* spacing: right & bottom */
        /* optional rounded corners */
    }
}

.popup {
    display: none;
    position: fixed;
    z-index: 9999;
    inset: 0;
    background: rgba(0, 0, 0, 0.8);
    justify-content: center;
    align-items: center;
}

.popup-content {
    position: relative;
    max-width: 90%;
    max-height: 90%;
    cursor: zoom-in;
    transition: transform 0.2s;

}

.popup-content:active {
    cursor: zoom-out;
}

.popup-content.zoomed {
    cursor: zoom-out;

}


.close {
    position: absolute;
    top: 0.75vh;
    right: 1.25vw;
    color: white;
    font-size: 4vw;
    cursor: pointer;
    transition: color 0.2s;
}

@media (max-width: 1100px) {
    .close {
        font-size: 4.5vw;
        top: 0.6vh;
        right: 1.5vw;
    }
}

@media (max-width: 900px) {
    .close {
        font-size: 5.25vw;
        top: 0.5vh;
        right: 2vw;
    }
}

@media (max-width: 700px) {
    .close {
        font-size: 9vw;
        top: 0.25vh;
        right: 2.5vw;
    }
}

.close:hover {
    color: #ccc;
}

.dot {
    display: inline-block;
    border-radius: 100%;
    width: 0.7vw;
    height: 0.7vw;
    background: #ccc;
    margin: 0.15vw;
}

@media (max-width: 1100px) {
    .dot {
        width: 0.6vw;
        height: 0.6vw;
        margin: 0.1vw;
    }
}

@media (max-width: 900px) {
    .dot {
        width: 0.5vw;
        height: 0.5vw;
        margin: 0.1vw;
    }
}

@media (max-width: 700px) {
    .dot {
        width: 0vw;
        height: 0vw;
        margin: 0px;
    }
}

.minimal {
    .water {
        background: transparent;
    }

    .north-america,
    .south-america,
    .europe,
    .africa,
    .asia,
    .australia {
        background: #eee;
    }
}

@keyframes water {
    0% {
        background: lightcyan;
    }

    50% {
        background: paleturquoise;
    }

    100% {
        background: lightcyan;
    }
}