/* ===== FONT DECLARATIONS ===== */
@font-face {
    font-family: 'WeddingSignatureFont';
    src: url('../fonts/Aerotis.otf');
    font-display: swap; /* Better loading performance */
}

@font-face {
    font-family: 'WeddingFont';
    src: url('../fonts/Quicksand-VariableFont_wght.ttf');
    font-display: swap;
}

/* ===== CSS RESET & BASE STYLES ===== */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    height: 100%;
    scroll-behavior: smooth;
}

body {
    width: 100%;
    height: 100%;
    font-family: 'WeddingFont', Arial, sans-serif;
    line-height: 1.6;
    color: #3b4930;
}

/* ===== RESPONSIVE TYPOGRAPHY ===== */
:root {
    --signature-font-xl: clamp(45px, 8vw, 85px);
    --signature-font-lg: clamp(35px, 6vw, 65px);
    --signature-font-md: clamp(30px, 5vw, 50px);
    --body-font-xl: clamp(18px, 2.5vw, 24px);
    --body-font-lg: clamp(16px, 2vw, 20px);
    --body-font-md: clamp(14px, 1.8vw, 18px);
    --body-font-sm: clamp(12px, 1.5vw, 16px);
    
    --container-max: 1200px;
    --container-padding: clamp(20px, 5vw, 60px);
    --section-spacing: clamp(40px, 8vw, 80px);
    --element-spacing: clamp(15px, 3vw, 30px);
}

/* ===== LAYOUT CONTAINERS ===== */
.container {
    width: 100%;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--container-padding);
}

/* ===== NAVIGATION ===== */
.nav img {
    display: block;
    width: min(300px, 80%);
    height: auto;
    margin: 0 auto;
    fill: #3b4930;
}

.navbar {
    list-style-type: none;
    padding: var(--element-spacing);
    padding-bottom: calc(var(--element-spacing) * 1.5);
    text-align: center;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--element-spacing);
}

.navitem {
    font-family: "WeddingFont", Arial, sans-serif;
    font-weight: 400;
    font-size: var(--body-font-md);
    white-space: nowrap;
}

.navitem a {
    text-decoration: none;
    color: inherit;
    padding: 10px 15px;
    border-radius: 5px;
    transition: background-color 0.3s ease;
}

.navitem a:hover {
    background-color: rgba(244, 233, 252, 0.5);
}

.title{
    text-align: center;
    padding-top:2%;
    padding-bottom:2%;
    color: #3b4930;
}

.nav img{
    text-align: center;
    width: 80%;
    margin-left: 10%;
    font-family: 'WeddingSignatureFont';
    fill: #3b4930;
}

/* ===== SECTIONS & CONTENT ===== */
.content {
    text-align: center;
    font-family: "WeddingFont", Arial, sans-serif;
    font-weight: 400;
    padding-bottom: var(--section-spacing);
}

.lavender {
    background-color: rgb(244, 233, 252);
    padding: var(--section-spacing) 0;
}

.white {
}

.gradient {
    background-image: linear-gradient(white, rgb(234, 212, 247));
    padding: var(--section-spacing) 0;
}

/* ===== TYPOGRAPHY CLASSES ===== */
.welcome,
.detail_header {
    font-family: 'WeddingSignatureFont', cursive;
    font-size: var(--signature-font-lg);
    padding-bottom: var(--element-spacing);
    padding-top: var(--element-spacing);
    margin-bottom: 0;
    line-height: 1.2;
}

.detail_header_lg {
    font-size: var(--signature-font-xl);
}

.detail_header_sm {
    font-size: var(--signature-font-md);
}

.detail_item {
    font-size: var(--body-font-lg);
    margin-bottom: var(--element-spacing);
}

/* ===== EVENT DETAILS ===== */
.event_details {
    list-style-type: none;
    padding: var(--element-spacing) 5px var(--section-spacing) 5px;
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: var(--element-spacing);
}

.event_detail {
    font-family: "WeddingFont", Arial, sans-serif;
    font-weight: 400;
    font-size: var(--body-font-xl);
    padding: 10px;
}

/* ===== FAQ SECTION ===== */
.faq_hdr {
    font-family: 'WeddingFont', Arial, sans-serif;
    font-size: var(--signature-font-md);
}

.question,
.faq_q {
    font-family: 'WeddingFont', Arial, sans-serif;
    font-size: var(--body-font-lg);
    font-weight: 600;
    padding-top: var(--element-spacing);
    padding-bottom: calc(var(--element-spacing) / 2);
    margin-bottom: 0;
}

.answer,
.faq_a {
    font-family: "WeddingFont", Arial, sans-serif;
    font-weight: 400;
    font-size: var(--body-font-lg);
    padding: calc(var(--element-spacing) / 2);
    margin: 0 auto;
    max-width: 600px;
    text-align: center;
}

/* ===== TRAVEL SECTION ===== */
.travel_hdr {
    font-family: "WeddingFont", Arial, sans-serif;
    font-weight: 500;
    font-size: var(--body-font-xl);
    padding: calc(var(--element-spacing) / 2) var(--element-spacing) 0;
    margin: 0 auto;
    max-width: 600px;
}

.travel_detail {
    font-family: "WeddingFont", Arial, sans-serif;
    font-weight: 400;
    font-size: var(--body-font-lg);
    padding: calc(var(--element-spacing) / 2);
    margin: 0 auto;
    max-width: 600px;
}

/* ===== STORY SECTION ===== */
.story_body {
    max-width: 600px;
    margin: 0 auto;
    padding: 0 var(--element-spacing);
}

.story_p {
    font-family: 'WeddingFont', Arial, sans-serif;
    font-size: var(--body-font-lg);
    font-weight: 400;
    padding-bottom: calc(var(--element-spacing) / 2);
    padding-top: var(--element-spacing);
    margin-bottom: 0;
    text-align: left;
}

/* ===== GALLERY STYLES ===== */
.gallery_container {
    column-count: 4;
    column-gap: 15px;
    width: 100%;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: var(--element-spacing) 0;
}

figure {
    display: inline-block;
    width: 100%;
    margin-bottom: 15px;
    break-inside: avoid;
    background: white;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

figure:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(0,0,0,0.15);
}

.gallery_img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 0.3s ease;
    opacity: 0;
    animation: fadeIn 0.6s ease forwards;
}

figure:hover .gallery_img {
    transform: scale(1.05);
}

@keyframes fadeIn {
    to {
        opacity: 1;
    }
}

/* Stagger gallery animations */
figure:nth-child(1) .gallery_img { animation-delay: 0.1s; }
figure:nth-child(2) .gallery_img { animation-delay: 0.2s; }
figure:nth-child(3) .gallery_img { animation-delay: 0.3s; }
figure:nth-child(4) .gallery_img { animation-delay: 0.4s; }
figure:nth-child(5) .gallery_img { animation-delay: 0.5s; }
figure:nth-child(6) .gallery_img { animation-delay: 0.6s; }
figure:nth-child(7) .gallery_img { animation-delay: 0.7s; }
figure:nth-child(8) .gallery_img { animation-delay: 0.8s; }
figure:nth-child(9) .gallery_img { animation-delay: 0.9s; }
figure:nth-child(10) .gallery_img { animation-delay: 1.0s; }
figure:nth-child(n+11) .gallery_img { animation-delay: 1.1s; }

figcaption {
    background-color: rgba(255,255,255,.5);
    padding: .2em .5em;
    font-size: var(--body-font-sm);
}

/* ===== UTILITY CLASSES ===== */
.banner {
    max-width: 100%;
}

.banner img {
    width: 100%;
    height: auto;
    object-fit: cover;
}

.logo {
    width: clamp(200px, 20vw, 400px); /* scales between 200px and 400px based on viewport width */
    height: auto;
}

.sprig {
    width: min(50px, 10vw);
    height: auto;
}

.footer {
    width: 100%;
    text-align: center;
    font-family: "WeddingFont", Arial, sans-serif;
    padding: var(--element-spacing);
    margin-top: auto;
}

.thumbnail {
    display: inline-block;
    width: fit-content;
    /* For older browser support: */
    width: -moz-fit-content;
    width: -webkit-fit-content;
    padding: 0; /* Optional: remove extra padding */
    margin: 0 auto; /* Optional: center if needed */
}

/* ===== RESPONSIVE BREAKPOINTS ===== */

/* Large Desktop */
@media (min-width: 1200px) {
    .container {
        padding: 0 60px;
    }
}

/* Desktop */
@media (max-width: 1024px) {
    .gallery_container {
        column-count: 3;
    }
    
    .navbar {
        gap: calc(var(--element-spacing) / 1.5);
    }
}

/* Tablet */
@media (max-width: 768px) {
    .gallery_container {
        column-count: 2;
        column-gap: 10px;
    }
    
    .navbar {
        flex-direction: column;
        gap: calc(var(--element-spacing) / 2);
    }
    
    .event_details {
        padding: var(--element-spacing) 10px var(--section-spacing) 10px;
    }
    
    .faq_a,
    .travel_hdr,
    .travel_detail {
        margin-left: var(--element-spacing);
        margin-right: var(--element-spacing);
        max-width: none;
    }
    
    .story_body {
        width: calc(100% - (var(--element-spacing) * 2));
        margin-left: var(--element-spacing);
        margin-right: var(--element-spacing);
    }
}

/* Mobile */
@media (max-width: 480px) {
    .gallery_container {
        column-count: 1;
    }
    
    .navbar {
        padding: calc(var(--element-spacing) / 2);
    }
    
    .navitem a {
        padding: 8px 12px;
        font-size: var(--body-font-sm);
    }
    
    .container {
        padding: 0 20px;
    }
    
    .event_details {
        padding: var(--element-spacing) 5px calc(var(--section-spacing) * 0.75) 5px;
    }
}

/* Extra Small Mobile */
@media (max-width: 320px) {
    .navbar {
        gap: 5px;
    }
    
    .navitem a {
        padding: 6px 8px;
        font-size: 14px;
    }
    
    .container {
        padding: 0 15px;
    }
}

/* ===== ACCESSIBILITY & PERFORMANCE ===== */
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Focus states for keyboard navigation */
a:focus,
button:focus {
    outline: 2px solid #3b4930;
    outline-offset: 2px;
}

/* Print styles */
@media print {
    .navbar,
    .footer {
        display: none;
    }
    
    body {
        font-size: 12pt;
        line-height: 1.4;
    }
    
    .gallery_container {
        column-count: 2;
    }
}