body {
    
    background: linear-gradient(135deg,#FFFCFA,#FFF6F8,#FAF8FF);
    font-family: "Quicksand", serif;

    padding: 0 120px;

    overflow-x: hidden;


}

main {

    overflow-x: hidden;

}

body::before,
body::after {

    content: "";

    position: fixed;

    top: 0;

    height: 100%;

    width: 40px;

    background-color: #BDE0FE;

    z-index: 0;

}

body::before {

    left: 40px;

}

body::after {

    right: 40px;

}

html::before,
html::after {

    content: "";

    position: fixed;

    top: 0;

    height: 100%;

    width: 3px;

    background-color: #F4B183;

    z-index: 0;

}

html::before {

    left: 95px;

}

html::after {

    right: 95px;

}

.guard-title {

    font-family: "Emilys Candy", serif;

    font-size: 60px;

    letter-spacing: 5px;

    color: #5E5873;

    text-align: center;

    margin: 0;

    text-shadow: 0px 3px 8px rgba(0,0,0,0.12);

}
h2 {

    font-family: "Emilys Candy", serif;
    font-weight: bold;
    text-align: center;
}

p {

    text-align: center;
    font-size: 24px;
    color: #5E5873;
}

img {

    width: 500px;
    border-radius: 20px;
    box-shadow: black;

}

nav a {

    color:#5C374C;
    text-decoration: none;
    display: block;
    text-align: center;
    transition: 0.3s;
    font-weight: bold;
    white-space: nowrap;
    padding: 10px 18px;
    

}




nav a:hover { 

    color:#D4A5C7;
    transform: scale(1.1);
}

nav {

    display:flex;
    justify-content:space-around;
    gap:0px;
    min-width: 140px;
    padding: 40px 0px;
    margin:-20 auto 0 auto;
    flex-wrap: wrap;

    background-color: #fbe4f7;

border: 2px solid #BDE0FE;

border-radius: 999px;

padding: 20px 40px;

width: 1000px;

margin: 30px auto;

box-shadow: 0px 0px 15px rgba(180,160,220,0.15);
}

.hero {

    text-align: center;
    padding-top: 10px;
    animation: fadeIn 2s;
}

@keyframes fadeIn {

    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

button {

    background-color: black;
    color: white;
    padding: 15px 30px;
    border: none;
    border-radius: 10px;
    transition: 0.3s;
    display: inline-block;
}

button:hover {

    transform: scale(1.1);
}

.guard-card {

    background-color: #fbe4f7;
    width: 400px;
    margin:0;
    padding: 30px;
    color: #5E5873;
    border-radius: 20px;
    box-shadow: 0px 0px 18px rgba(180,160,220,0.25);
    transition: 0.3s;
    min-height: 300px;
    display: flex;
    flex-direction: column;
    
    position: relative;

    outline: 3px dotted #D4A5C7;

    outline-offset: -12px;

    z-index: 2;

    isolation: isolate;

    padding-top: 390px;


    flex-shrink: 0;

    overflow: visible;

    align-items: center;

    padding-bottom: 10px;


}

.guard-card-container::-webkit-scrollbar {

    display: none;

}

.guard-card:hover {

    transform: translateY(-10px);
    box-shadow: 0px 0px 35px rgba(189,224,254,0.55);

}

.carousel-wrapper {

    overflow-x: auto;

    overflow-y: visible;

    scrollbar-width: none;

    width: 100%;

}

.carousel-wrapper::-webkit-scrollbar {

    display: none;

}

.guard-card-container {

    display: flex;

    gap: 50px;

    width: max-content;

    padding: 40px 120px;

}

.carousel-section {

    width: 100vw;

    margin-left: calc(-120px);

}

.title-box {

    background-color: #F7D774;
    width: 40%;
    margin: 30px auto;
    padding: 30px 20px;
    border-radius: 999px;

    box-shadow:

    inset 4px 4px 8px rgba(255,255,255,0.6),

    inset -4px -4px 8px rgba(210,180,70,0.25),

    0px 4px 12px rgba(0,0,0,0.08);

    outline: 3px dotted #D4A5C7;

    outline-offset: -10px;

}

.guard-card p {

    font-weight: 300;
    text-align: center;

    font-size: 18px;
}

.guard-card ul {

    list-style-type: none!important;
    list-style: none!important;
    padding-left: 0;
    margin-left: 0;

    text-align: center;
}

.guard-card li {

    list-style-type: none!important;
    list-style: none!important;



    margin-bottom: 10px;

}

.guard-card li::before {

    content: "♡ ";
    color: #D4A5C7;

}


.title-box p {

    font-size: 20px;

    margin-top: 4px;

    margin-bottom: 0;

    color: #5E5873;

}

.guard-card h2 {

    margin-top:0px;
    margin-bottom: 20px;
    text-align: center;
}

.floating-photo {

    width: 340px;

    height: 340px;

    border-radius: 20px;

    box-shadow: 0px 0px 20px rgba(0,0,0,0.2);


    z-index: 3;

    

    background-color: white;

    padding: 12px 12px 55px 12px;

    border-radius: 12px;

    box-shadow: 0px 0px 25px rgba(0,0,0,0.12);

    object-fit: cover;

    object-position: center;
}

.photo-wrapper {

    position: absolute;

    top: 25px;
   

    left: 28px;

    z-index: 3;

}

.photo-caption {

    text-align: center;

    margin-top: -38px;

    font-family: "Emilys Candy", serif;

    font-size: 20px;

    color: #B88DAF;

}

.guard-card a {

    text-decoration: none;
    color: inherit;

}



footer {

    margin-top: 10px;

    padding: 40px 20px;

    text-align: center;

    color: #5E5873;

    opacity: 1;

}

footer p {

    font-size: 18px;

    margin: 8px 0;

}

.footer-quote {

    font-style: italic;

    color: #A06C98;

    font-weight: 600;

}


.cinematic-section {

    display: flex;

    justify-content: center;

    align-items: center;

    gap: 80px;

    margin: 100px 0;
    margin-bottom: 80px;

}

.cinematic-video {

    width: 500px;

    height: 450px;

    object-fit: cover;

    background-color: white;

    padding: 12px;

    border-radius: 25px;

    border: 3px solid #FBE4F7;

    box-shadow:
    0px 0px 25px rgba(180,160,220,0.25),
    0px 0px 0px 8px white,
    0px 0px 0px 12px #BDE0FE;

    transform: rotate(-1deg);

    object-fit: cover;

    object-position: top;

}

.hero-button-container {

    text-align: center;

    margin-top: -10px;

    margin-bottom: 70px;

}

.hero-button {

    background-color: #FBE4F7;

    color: #5E5873;

    border: 2px solid #BDE0FE;

    border-radius: 999px;

    padding: 14px 34px;

    font-size: 18px;

    font-weight: 600;

    box-shadow: 0px 4px 12px rgba(180,160,220,0.18);

    transition: 0.3s;

}

.hero-button:hover {

    transform: translateY(-3px) scale(1.03);

    background-color: #FFF8FB;

    box-shadow: 0px 8px 18px rgba(180,160,220,0.28);

}

.poetic-line {

    font-family: "Emilys Candy", serif;

    font-size: 42px;

    color: #5E5873;

    text-align: center;

    line-height: 1.6;

    opacity: 0.85;

    letter-spacing: 1px;

}

.encouragement-box {

    background-color: #FFF8FB;

    max-width: 1000px;

    margin: 70px auto 40px auto;

    padding: 15px 40px;

    border-radius: 50px;

    box-shadow: 0px 0px 18px rgba(180,160,220,0.25);

    outline: 3px solid #D4A5C7;

    outline-offset: -12px;

    text-align: center;

}


.encouragement-box p {

    font-size: 18px;

    line-height: 2;

    color: #5E5873;

    font-style: italic;

    max-width: 800px;

    margin: 20px auto;

}

.final-quote {

    margin-top: 45px;
    
    max-width: 500px;

    margin: 80px auto 20px auto;

    font-size: 24px;

    line-height: 1.8;

    color:  #5E5873;

    font-family: "Emilys Candy", serif;

}

.carousel-section {

    position: relative;

    display: flex;

    align-items: center;

}

.dropdown {

    position: relative;

}

.dropdown-content {

    position: absolute;

    top: 120%;

    left: 50%;

    transform: translateX(-50%) translateY(0px);

    background-color: #FFF8FB;

    min-width: 200px;

    border-radius: 20px;

    padding: 8px 0;

    box-shadow: 0px 8px 20px rgba(180,160,220,0.18);

    border: 2px solid #BDE0FE;

    z-index: 100;

    opacity: 0;

    visibility: hidden;

    transition: 0.3s;

}

.dropdown:hover .dropdown-content {

    opacity: 1;

    visibility: visible;

    transform: translateX(-50%) translateY(10px);

}

.dropdown-content a {

    display: block;

    padding: 10px 18px;

    color: #5E5873;

    text-decoration: none;

    transition: 0.3s;

    font-size: 16px;

}

.dropdown-content a:hover {

    background-color: #FBE4F7;

    color: #B88DAF;

}


