/* ========== CSS Reset Styles ========== */
* {
    padding: 0;
    margin: 0;
    box-sizing: border-box;
}

/* ========== Geberal Styling ========== */
body {
    font-size: 1rem;
    font-family: "Poppins", sans-serif;
    background-color: #ffffff;
}

input, button, a {
    text-decoration: none;
    font-family: inherit;
    font-weight: 500;
}

h1, h2, h3,
h4, h5, h6 {
    font-family: "Roboto", sans-serif;
}

h1 {font-size: /*56px/3.5rem*/ 3.5rem;}
h2 {font-size: /*48px/3rem*/ 3rem;}
h3 {font-size: /*4px/2.5rem*/ 2.5rem;}
h4 {font-size: /*32px/2rem*/ 2rem;}
h5 {font-size: /*24px/1.5rem*/ 1.5rem;}
h6 {font-size: /*18px/1.125rem*/ 1.125rem;}

p {
    font-size: /*16px/1rem*/ 1rem;
    font-weight: 400;
    line-height: /*24px/1.5rem*/ 1.5rem;
}

img {
    width: 100%;
    height: auto;
}

/* section {
    padding: 32px 0px;
} */

/* ========== Header Styling ========== */
.header {
    padding: 16px 8%;
    background-color: #ffffff;
}

.header .first-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 48px;
    z-index: 10;
}

.header .first-nav .hamburger-menu {
    /* border: 1px solid #da1c8b ; */
    border-radius: 4px;
    color: #da1c8b;
    width: min(40px, 56px);
    height: min(40px, 56px);
    text-align: center;
    vertical-align: middle;
    font-size: 32px;
    cursor: pointer;
}

.header .first-nav .logo .kayleen {
    color: #222222;
    font-size: 40px;
    font-weight: 500;
}

.header .first-nav .search-bar {
    background-color: #da1c8b;
    color: #ffffff;
    border-radius: 100%;
    width: min(40px, 56px);
    height: min(40px, 56px);
    padding: 4px;
    text-align: center;
    vertical-align: middle;
    font-size: 20px;
    border: 1px solid #fff ;
    cursor: pointer;
    box-shadow: 0px 2px 15px 0px rgba(207, 207, 207, 0.2);
}

.header .second-nav {
    display: flex;
    justify-content: center;
    align-items: center;
}

.header .second-nav .nav-menu {
    display: flex;
    list-style-type: none;
    justify-content: center;
    align-items: center;
    gap: 20px;
}

.header .second-nav .nav-menu .close-btn {
    border-radius: 4px;
    width: min(40px, 48px);
    height: min(40px, 48px);
    padding: 4px;
    margin-right: auto;
    text-align: center;
    font-size: 20px;
    color: #da1c8b;
    cursor: pointer;
}

.header .second-nav .nav-menu li {
    display: inline-block;
    font-size: min(13px, 15px);
}

.header .second-nav .nav-menu li a {
    border-bottom: 2px solid transparent;
    padding: 9px;
}

.header .second-nav .nav-menu li a:any-link {
    color: #3d3d3d;
}

.header .second-nav .nav-menu li a:hover,
.header .second-nav .nav-menu li a:focus {
    border-bottom: 2px solid #ff3eaf;
    color: #ff3eaf;
    transition: all ease-in-out 250ms;

}

.header .second-nav .nav-menu li a:active {
    color: #da1c8b;
}

/* ========== Footer Styling  */
.footer {
    padding: 40px 2%;
}

.footer .container {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    gap: 32px;
}

.footer .logo .kayleen {
    font-size: min(28px, 32px);
}

.footer .container .footer-menu {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 32px;
}

.footer-menu .columns {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    gap: 16px;
    width: 20%;
    flex-grow: 1; 
}

.footer-menu .columns .heading {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    gap: 8px;
}

.footer-menu .columns .heading h6 {
    font-size: min(14px, 17px);
}

.footer-menu .columns .heading .divider {
    display: flex;
    justify-content: start;
    align-self: center;
    gap: 4px;
}

.footer-menu .columns .heading .divider .dash {
    width: 35px;
}

.footer-menu .columns p,
.copyright p {
    font-size: min(13px, 16px);
    font-weight: 400;
    color: rgba(153, 153, 153, 0.9);
    line-height: 2;
    margin-top: 8px;
}

.footer-menu .intro {
    width: 30%;
    flex-grow: 2;
}

.footer-menu .follow-us .links {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 4px;
}

.footer-menu .follow-us .links .s-btn {
    background-color: #1a1a1a;
    color: #fff;
    border-radius: 100%;
    width: min(40px, 56px);
    height: min(40px, 56px);
    padding: 4px;
    text-align: center;
    vertical-align: middle;
    font-size: 20px;
    font-weight: 600;
    border: 1px solid #fff ;
    cursor: pointer;
    box-shadow: 0px 2px 15px 0px rgba(207, 207, 207, 0.2);

}

/* ========== Utilities Class styling ========== */
.logo {
    display: flex;
    justify-content: center;
    align-items: baseline;
    gap: 4px;
    cursor: pointer;
}

.logo .kayleen {
    color: #222222;
    font-size: 40px;
    font-weight: 500;
}

.dot {
    background-color: #da1c8b;
    width: 6px;
    height: 6px;
    border-radius: 8px;
}

.special-headings {
    display: flex;
    justify-content: flex-start;
    align-items: baseline;
    gap: 4px;
}

@media only screen and (min-width: 100px) and (max-width: 768px) {
    .container {
        padding: 0px 16px;
    }
    #header {
        padding: 16px 0;
    }

    #header .first-nav {
        margin-bottom: 0;
    }

    #header .first-nav .logo .kayleen {
        color: #222222;
        font-size: 32px;
        font-weight: 500;
    }

    #header .second-nav {
        visibility: hidden;
        background: linear-gradient(90deg, rgba(32, 32, 32, 0.6),
        rgba(32, 32, 32, 0.6));
        position: absolute;
        left: -10000px;
        top: 0;
        width: 100%;
        height: 1000%;
        z-index: 1;
        transition: left 500ms ease-in-out;
    }

    #header .second-nav.show-nav {
        visibility: visible;
        left: 0;
    }

    #header .second-nav .nav-menu {
        display: flex;
        flex-direction: column;
        list-style-type: none;
        justify-content: flex-start;
        align-items: flex-start;
        gap: 0px;
        position: absolute;
        left: 0;
        background-color: #fff;
        width: 80%;
        height: 100%;
        padding: 20px;
    }

    
    #header .second-nav .nav-menu li {
        display: block;
        width: 100%;
    }

    #header .second-nav .nav-menu li a {
        display: block;
        padding: 12px 16px;
        font-size: 14px;
        width: 100%;
    }
}

@media only screen and (min-width: 100px) and (max-width: 768px) {

    .footer-menu #intro {
        width: 100%;
    }
    .footer .container .footer-menu .columns {
        width: 30%;
    } 
}