/* ===== RESET & BASE ===== */
*, *::before, *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    font-size: 16px;
    overflow-x: hidden;
}

body {
    font-family: 'Montserrat', sans-serif;
    color: #3a2a4a;
    background: linear-gradient(180deg, #e8d5f5 0%, #d4b8e8 10%, #dcc5ed 30%, #e0caf0 50%, #d4b8e8 70%, #dcc5ed 90%, #c9a5e0 100%);
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}

/* Global bokeh / sparkle overlay - layer 1 (medium dots) */
body::before {
    content: '';
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background:
        radial-gradient(4px 4px at 1% 3%, rgba(255,255,255,0.9), transparent),
        radial-gradient(3px 3px at 2% 11%, rgba(255,255,255,0.8), transparent),
        radial-gradient(5px 5px at 1% 19%, rgba(255,255,255,0.7), transparent),
        radial-gradient(4px 4px at 3% 27%, rgba(255,255,255,0.85), transparent),
        radial-gradient(3px 3px at 2% 35%, rgba(255,255,255,0.75), transparent),
        radial-gradient(5px 5px at 4% 43%, rgba(255,255,255,0.65), transparent),
        radial-gradient(4px 4px at 1% 51%, rgba(255,255,255,0.8), transparent),
        radial-gradient(3px 3px at 3% 59%, rgba(255,255,255,0.7), transparent),
        radial-gradient(5px 5px at 2% 67%, rgba(255,255,255,0.85), transparent),
        radial-gradient(4px 4px at 4% 75%, rgba(255,255,255,0.75), transparent),
        radial-gradient(3px 3px at 1% 83%, rgba(255,255,255,0.65), transparent),
        radial-gradient(5px 5px at 3% 91%, rgba(255,255,255,0.8), transparent),
        radial-gradient(4px 4px at 6% 7%, rgba(255,255,255,0.85), transparent),
        radial-gradient(3px 3px at 7% 17%, rgba(255,255,255,0.75), transparent),
        radial-gradient(5px 5px at 8% 28%, rgba(255,255,255,0.9), transparent),
        radial-gradient(4px 4px at 6% 38%, rgba(255,255,255,0.7), transparent),
        radial-gradient(3px 3px at 9% 48%, rgba(255,255,255,0.8), transparent),
        radial-gradient(5px 5px at 7% 58%, rgba(255,255,255,0.65), transparent),
        radial-gradient(4px 4px at 8% 68%, rgba(255,255,255,0.85), transparent),
        radial-gradient(3px 3px at 6% 78%, rgba(255,255,255,0.75), transparent),
        radial-gradient(5px 5px at 9% 88%, rgba(255,255,255,0.7), transparent),
        radial-gradient(4px 4px at 7% 96%, rgba(255,255,255,0.8), transparent),
        radial-gradient(3px 3px at 11% 5%, rgba(255,255,255,0.9), transparent),
        radial-gradient(5px 5px at 13% 15%, rgba(255,255,255,0.7), transparent),
        radial-gradient(4px 4px at 12% 25%, rgba(255,255,255,0.85), transparent),
        radial-gradient(3px 3px at 14% 35%, rgba(255,255,255,0.75), transparent),
        radial-gradient(5px 5px at 11% 45%, rgba(255,255,255,0.8), transparent),
        radial-gradient(4px 4px at 13% 55%, rgba(255,255,255,0.65), transparent),
        radial-gradient(3px 3px at 12% 65%, rgba(255,255,255,0.9), transparent),
        radial-gradient(5px 5px at 14% 75%, rgba(255,255,255,0.7), transparent),
        radial-gradient(4px 4px at 11% 85%, rgba(255,255,255,0.8), transparent),
        radial-gradient(3px 3px at 13% 95%, rgba(255,255,255,0.75), transparent),
        radial-gradient(5px 5px at 16% 9%, rgba(255,255,255,0.85), transparent),
        radial-gradient(4px 4px at 18% 21%, rgba(255,255,255,0.7), transparent),
        radial-gradient(3px 3px at 17% 33%, rgba(255,255,255,0.9), transparent),
        radial-gradient(5px 5px at 19% 44%, rgba(255,255,255,0.75), transparent),
        radial-gradient(4px 4px at 16% 56%, rgba(255,255,255,0.8), transparent),
        radial-gradient(3px 3px at 18% 67%, rgba(255,255,255,0.65), transparent),
        radial-gradient(5px 5px at 17% 79%, rgba(255,255,255,0.85), transparent),
        radial-gradient(4px 4px at 19% 90%, rgba(255,255,255,0.7), transparent),
        radial-gradient(3px 3px at 21% 6%, rgba(255,255,255,0.9), transparent),
        radial-gradient(5px 5px at 23% 18%, rgba(255,255,255,0.75), transparent),
        radial-gradient(4px 4px at 22% 30%, rgba(255,255,255,0.8), transparent),
        radial-gradient(3px 3px at 24% 41%, rgba(255,255,255,0.65), transparent),
        radial-gradient(5px 5px at 21% 53%, rgba(255,255,255,0.85), transparent),
        radial-gradient(4px 4px at 23% 64%, rgba(255,255,255,0.7), transparent),
        radial-gradient(3px 3px at 22% 76%, rgba(255,255,255,0.9), transparent),
        radial-gradient(5px 5px at 24% 87%, rgba(255,255,255,0.75), transparent),
        radial-gradient(4px 4px at 26% 4%, rgba(255,255,255,0.8), transparent),
        radial-gradient(3px 3px at 28% 16%, rgba(255,255,255,0.85), transparent),
        radial-gradient(5px 5px at 27% 28%, rgba(255,255,255,0.65), transparent),
        radial-gradient(4px 4px at 29% 39%, rgba(255,255,255,0.9), transparent),
        radial-gradient(3px 3px at 26% 51%, rgba(255,255,255,0.7), transparent),
        radial-gradient(5px 5px at 28% 62%, rgba(255,255,255,0.8), transparent),
        radial-gradient(4px 4px at 27% 74%, rgba(255,255,255,0.75), transparent),
        radial-gradient(3px 3px at 29% 85%, rgba(255,255,255,0.85), transparent),
        radial-gradient(5px 5px at 26% 97%, rgba(255,255,255,0.65), transparent),
        radial-gradient(4px 4px at 31% 8%, rgba(255,255,255,0.9), transparent),
        radial-gradient(3px 3px at 33% 20%, rgba(255,255,255,0.7), transparent),
        radial-gradient(5px 5px at 32% 32%, rgba(255,255,255,0.85), transparent),
        radial-gradient(4px 4px at 34% 43%, rgba(255,255,255,0.75), transparent),
        radial-gradient(3px 3px at 31% 55%, rgba(255,255,255,0.8), transparent),
        radial-gradient(5px 5px at 33% 66%, rgba(255,255,255,0.65), transparent),
        radial-gradient(4px 4px at 32% 78%, rgba(255,255,255,0.9), transparent),
        radial-gradient(3px 3px at 34% 89%, rgba(255,255,255,0.7), transparent),
        radial-gradient(5px 5px at 36% 5%, rgba(255,255,255,0.8), transparent),
        radial-gradient(4px 4px at 38% 17%, rgba(255,255,255,0.85), transparent),
        radial-gradient(3px 3px at 37% 29%, rgba(255,255,255,0.75), transparent),
        radial-gradient(5px 5px at 39% 40%, rgba(255,255,255,0.65), transparent),
        radial-gradient(4px 4px at 36% 52%, rgba(255,255,255,0.9), transparent),
        radial-gradient(3px 3px at 38% 63%, rgba(255,255,255,0.7), transparent),
        radial-gradient(5px 5px at 37% 75%, rgba(255,255,255,0.85), transparent),
        radial-gradient(4px 4px at 39% 86%, rgba(255,255,255,0.75), transparent),
        radial-gradient(3px 3px at 36% 98%, rgba(255,255,255,0.8), transparent),
        radial-gradient(5px 5px at 41% 10%, rgba(255,255,255,0.9), transparent),
        radial-gradient(4px 4px at 43% 22%, rgba(255,255,255,0.65), transparent),
        radial-gradient(3px 3px at 42% 34%, rgba(255,255,255,0.85), transparent),
        radial-gradient(5px 5px at 44% 45%, rgba(255,255,255,0.7), transparent),
        radial-gradient(4px 4px at 41% 57%, rgba(255,255,255,0.8), transparent),
        radial-gradient(3px 3px at 43% 68%, rgba(255,255,255,0.75), transparent),
        radial-gradient(5px 5px at 42% 80%, rgba(255,255,255,0.9), transparent),
        radial-gradient(4px 4px at 44% 91%, rgba(255,255,255,0.65), transparent),
        radial-gradient(3px 3px at 46% 7%, rgba(255,255,255,0.85), transparent),
        radial-gradient(5px 5px at 48% 19%, rgba(255,255,255,0.7), transparent),
        radial-gradient(4px 4px at 47% 31%, rgba(255,255,255,0.9), transparent),
        radial-gradient(3px 3px at 49% 42%, rgba(255,255,255,0.75), transparent),
        radial-gradient(5px 5px at 46% 54%, rgba(255,255,255,0.8), transparent),
        radial-gradient(4px 4px at 48% 65%, rgba(255,255,255,0.65), transparent),
        radial-gradient(3px 3px at 47% 77%, rgba(255,255,255,0.85), transparent),
        radial-gradient(5px 5px at 49% 88%, rgba(255,255,255,0.7), transparent),
        radial-gradient(4px 4px at 51% 4%, rgba(255,255,255,0.9), transparent),
        radial-gradient(3px 3px at 53% 16%, rgba(255,255,255,0.8), transparent),
        radial-gradient(5px 5px at 52% 27%, rgba(255,255,255,0.65), transparent),
        radial-gradient(4px 4px at 54% 39%, rgba(255,255,255,0.85), transparent),
        radial-gradient(3px 3px at 51% 50%, rgba(255,255,255,0.7), transparent),
        radial-gradient(5px 5px at 53% 62%, rgba(255,255,255,0.9), transparent),
        radial-gradient(4px 4px at 52% 73%, rgba(255,255,255,0.75), transparent),
        radial-gradient(3px 3px at 54% 85%, rgba(255,255,255,0.8), transparent),
        radial-gradient(5px 5px at 51% 96%, rgba(255,255,255,0.65), transparent),
        radial-gradient(4px 4px at 56% 9%, rgba(255,255,255,0.85), transparent),
        radial-gradient(3px 3px at 58% 21%, rgba(255,255,255,0.9), transparent),
        radial-gradient(5px 5px at 57% 33%, rgba(255,255,255,0.7), transparent),
        radial-gradient(4px 4px at 59% 44%, rgba(255,255,255,0.8), transparent),
        radial-gradient(3px 3px at 56% 56%, rgba(255,255,255,0.75), transparent),
        radial-gradient(5px 5px at 58% 67%, rgba(255,255,255,0.85), transparent),
        radial-gradient(4px 4px at 57% 79%, rgba(255,255,255,0.65), transparent),
        radial-gradient(3px 3px at 59% 90%, rgba(255,255,255,0.9), transparent),
        radial-gradient(5px 5px at 61% 6%, rgba(255,255,255,0.7), transparent),
        radial-gradient(4px 4px at 63% 18%, rgba(255,255,255,0.85), transparent),
        radial-gradient(3px 3px at 62% 30%, rgba(255,255,255,0.8), transparent),
        radial-gradient(5px 5px at 64% 41%, rgba(255,255,255,0.65), transparent),
        radial-gradient(4px 4px at 61% 53%, rgba(255,255,255,0.9), transparent),
        radial-gradient(3px 3px at 63% 64%, rgba(255,255,255,0.75), transparent),
        radial-gradient(5px 5px at 62% 76%, rgba(255,255,255,0.8), transparent),
        radial-gradient(4px 4px at 64% 87%, rgba(255,255,255,0.7), transparent),
        radial-gradient(3px 3px at 66% 3%, rgba(255,255,255,0.9), transparent),
        radial-gradient(5px 5px at 68% 15%, rgba(255,255,255,0.85), transparent),
        radial-gradient(4px 4px at 67% 26%, rgba(255,255,255,0.65), transparent),
        radial-gradient(3px 3px at 69% 38%, rgba(255,255,255,0.8), transparent),
        radial-gradient(5px 5px at 66% 49%, rgba(255,255,255,0.7), transparent),
        radial-gradient(4px 4px at 68% 61%, rgba(255,255,255,0.9), transparent),
        radial-gradient(3px 3px at 67% 72%, rgba(255,255,255,0.75), transparent),
        radial-gradient(5px 5px at 69% 84%, rgba(255,255,255,0.85), transparent),
        radial-gradient(4px 4px at 66% 95%, rgba(255,255,255,0.65), transparent),
        radial-gradient(3px 3px at 71% 8%, rgba(255,255,255,0.8), transparent),
        radial-gradient(5px 5px at 73% 20%, rgba(255,255,255,0.9), transparent),
        radial-gradient(4px 4px at 72% 32%, rgba(255,255,255,0.7), transparent),
        radial-gradient(3px 3px at 74% 43%, rgba(255,255,255,0.85), transparent),
        radial-gradient(5px 5px at 71% 55%, rgba(255,255,255,0.75), transparent),
        radial-gradient(4px 4px at 73% 66%, rgba(255,255,255,0.65), transparent),
        radial-gradient(3px 3px at 72% 78%, rgba(255,255,255,0.9), transparent),
        radial-gradient(5px 5px at 74% 89%, rgba(255,255,255,0.8), transparent),
        radial-gradient(4px 4px at 76% 5%, rgba(255,255,255,0.85), transparent),
        radial-gradient(3px 3px at 78% 17%, rgba(255,255,255,0.65), transparent),
        radial-gradient(5px 5px at 77% 29%, rgba(255,255,255,0.9), transparent),
        radial-gradient(4px 4px at 79% 40%, rgba(255,255,255,0.7), transparent),
        radial-gradient(3px 3px at 76% 52%, rgba(255,255,255,0.8), transparent),
        radial-gradient(5px 5px at 78% 63%, rgba(255,255,255,0.75), transparent),
        radial-gradient(4px 4px at 77% 75%, rgba(255,255,255,0.85), transparent),
        radial-gradient(3px 3px at 79% 86%, rgba(255,255,255,0.65), transparent),
        radial-gradient(5px 5px at 76% 98%, rgba(255,255,255,0.9), transparent),
        radial-gradient(4px 4px at 81% 10%, rgba(255,255,255,0.7), transparent),
        radial-gradient(3px 3px at 83% 22%, rgba(255,255,255,0.85), transparent),
        radial-gradient(5px 5px at 82% 34%, rgba(255,255,255,0.8), transparent),
        radial-gradient(4px 4px at 84% 45%, rgba(255,255,255,0.65), transparent),
        radial-gradient(3px 3px at 81% 57%, rgba(255,255,255,0.9), transparent),
        radial-gradient(5px 5px at 83% 68%, rgba(255,255,255,0.75), transparent),
        radial-gradient(4px 4px at 82% 80%, rgba(255,255,255,0.8), transparent),
        radial-gradient(3px 3px at 84% 91%, rgba(255,255,255,0.7), transparent),
        radial-gradient(5px 5px at 86% 7%, rgba(255,255,255,0.85), transparent),
        radial-gradient(4px 4px at 88% 19%, rgba(255,255,255,0.9), transparent),
        radial-gradient(3px 3px at 87% 31%, rgba(255,255,255,0.65), transparent),
        radial-gradient(5px 5px at 89% 42%, rgba(255,255,255,0.8), transparent),
        radial-gradient(4px 4px at 86% 54%, rgba(255,255,255,0.75), transparent),
        radial-gradient(3px 3px at 88% 65%, rgba(255,255,255,0.85), transparent),
        radial-gradient(5px 5px at 87% 77%, rgba(255,255,255,0.7), transparent),
        radial-gradient(4px 4px at 89% 88%, rgba(255,255,255,0.9), transparent),
        radial-gradient(3px 3px at 91% 4%, rgba(255,255,255,0.8), transparent),
        radial-gradient(5px 5px at 93% 16%, rgba(255,255,255,0.65), transparent),
        radial-gradient(4px 4px at 92% 28%, rgba(255,255,255,0.85), transparent),
        radial-gradient(3px 3px at 94% 39%, rgba(255,255,255,0.9), transparent),
        radial-gradient(5px 5px at 91% 51%, rgba(255,255,255,0.7), transparent),
        radial-gradient(4px 4px at 93% 62%, rgba(255,255,255,0.8), transparent),
        radial-gradient(3px 3px at 92% 74%, rgba(255,255,255,0.75), transparent),
        radial-gradient(5px 5px at 94% 85%, rgba(255,255,255,0.85), transparent),
        radial-gradient(4px 4px at 96% 9%, rgba(255,255,255,0.65), transparent),
        radial-gradient(3px 3px at 98% 23%, rgba(255,255,255,0.9), transparent),
        radial-gradient(5px 5px at 97% 36%, rgba(255,255,255,0.8), transparent),
        radial-gradient(4px 4px at 99% 48%, rgba(255,255,255,0.7), transparent),
        radial-gradient(3px 3px at 96% 60%, rgba(255,255,255,0.85), transparent),
        radial-gradient(5px 5px at 98% 71%, rgba(255,255,255,0.75), transparent),
        radial-gradient(4px 4px at 97% 83%, rgba(255,255,255,0.9), transparent),
        radial-gradient(3px 3px at 99% 94%, rgba(255,255,255,0.65), transparent);
    animation: sparkle 4s ease-in-out infinite alternate;
}

/* Bokeh layer 2 (larger soft glows) */
body::after {
    content: '';
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background:
        radial-gradient(10px 10px at 1% 5%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 3% 18%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 2% 32%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 4% 46%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 1% 60%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 3% 74%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 2% 88%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 6% 11%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 8% 25%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 7% 39%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 9% 53%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 6% 67%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 8% 81%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 7% 95%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 11% 8%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 13% 22%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 12% 36%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 14% 50%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 11% 64%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 13% 78%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 12% 92%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 16% 14%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 18% 28%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 17% 42%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 19% 56%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 16% 70%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 18% 84%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 21% 4%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 23% 19%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 22% 33%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 24% 47%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 21% 61%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 23% 75%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 22% 89%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 26% 10%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 28% 24%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 27% 38%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 29% 52%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 26% 66%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 28% 80%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 27% 94%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 31% 7%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 33% 21%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 32% 35%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 34% 49%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 31% 63%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 33% 77%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 32% 91%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 36% 13%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 38% 27%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 37% 41%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 39% 55%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 36% 69%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 38% 83%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 41% 3%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 43% 17%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 42% 31%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 44% 45%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 41% 59%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 43% 73%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 42% 87%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 46% 9%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 48% 23%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 47% 37%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 49% 51%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 46% 65%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 48% 79%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 47% 93%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 51% 6%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 53% 20%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 52% 34%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 54% 48%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 51% 62%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 53% 76%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 52% 90%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 56% 12%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 58% 26%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 57% 40%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 59% 54%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 56% 68%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 58% 82%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 57% 96%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 61% 8%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 63% 22%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 62% 36%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 64% 50%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 61% 64%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 63% 78%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 62% 92%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 66% 4%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 68% 18%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 67% 32%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 69% 46%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 66% 60%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 68% 74%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 67% 88%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 71% 11%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 73% 25%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 72% 39%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 74% 53%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 71% 67%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 73% 81%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 72% 95%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 76% 7%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 78% 21%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 77% 35%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 79% 49%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 76% 63%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 78% 77%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 77% 91%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 81% 13%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 83% 27%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 82% 41%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 84% 55%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 81% 69%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 83% 83%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 82% 97%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 86% 9%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 88% 23%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 87% 37%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 89% 51%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 86% 65%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 88% 79%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 87% 93%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 91% 5%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 93% 19%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 92% 33%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 94% 47%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 91% 61%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 93% 75%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 92% 89%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 96% 15%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 98% 29%, rgba(255,255,255,0.3), transparent),
        radial-gradient(12px 12px at 97% 43%, rgba(255,255,255,0.25), transparent),
        radial-gradient(16px 16px at 99% 57%, rgba(255,255,255,0.2), transparent),
        radial-gradient(10px 10px at 96% 71%, rgba(255,255,255,0.28), transparent),
        radial-gradient(14px 14px at 98% 85%, rgba(255,255,255,0.22), transparent),
        radial-gradient(8px 8px at 97% 99%, rgba(255,255,255,0.3), transparent);
    animation: sparkle 6s ease-in-out infinite alternate-reverse;
}

.page-wrapper {
    overflow-x: hidden;
    width: 100%;
    position: relative;
}

img {
    max-width: 100%;
    height: auto;
}

a {
    text-decoration: none;
    color: inherit;
}

/* ===== FONTS ===== */
.hero-title,
.section-title,
.houppa-title,
.rsvp-title {
    font-family: 'Great Vibes', cursive;
}

.section-tag,
.parents-grid,
.invitation-text,
.suite-text,
.hommage {
    font-family: 'Cormorant Garamond', serif;
}

/* ===== NAVBAR ===== */
.navbar {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 30px;
    background: rgba(140, 90, 180, 0.9);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid rgba(180, 140, 200, 0.3);
    transform: translateY(0);
}

.nav-logo img {
    height: 55px;
    width: auto;
    transform: scale(1.3);
    transform-origin: center;
}

.nav-links {
    display: flex;
    gap: 24px;
}

.nav-links a {
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.5px;
    color: #c9a84c;
    transition: color 0.3s;
    text-transform: uppercase;
}

.nav-links a:hover {
    color: #e0c872;
}

.nav-toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 5px;
}

.nav-toggle span {
    display: block;
    width: 24px;
    height: 2px;
    background: #c9a84c;
    border-radius: 2px;
    transition: 0.3s;
}

/* Mobile menu */
.mobile-menu {
    display: none;
    position: fixed;
    top: 60px;
    left: 0;
    right: 0;
    z-index: 999;
    background: rgba(245, 238, 248, 0.97);
    backdrop-filter: blur(20px);
    padding: 20px;
    flex-direction: column;
    gap: 16px;
    text-align: center;
    border-bottom: 1px solid rgba(180, 140, 200, 0.3);
}

.mobile-menu.open {
    display: flex;
}

.mobile-menu a {
    font-size: 1rem;
    font-weight: 500;
    color: #6b4a8a;
    padding: 8px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

@media (max-width: 768px) {
    .nav-links { display: none; }
    .nav-toggle { display: flex; }
}

/* ===== HERO SECTION ===== */
.hero {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    background: transparent;
    overflow: hidden;
    padding: 60px 20px 40px;
    z-index: 1;
}

/* בס״ד text */
.bsd-text {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.2rem;
    font-weight: 600;
    color: #5c3d7a;
    direction: rtl;
    text-align: center;
    margin-bottom: 5px;
    position: relative;
    z-index: 5;
    margin-top: 10px;
}

/* Sparkle/bokeh overlay */
.sparkles {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(2px 2px at 20% 30%, rgba(255,255,255,0.8), transparent),
        radial-gradient(3px 3px at 40% 70%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 60% 20%, rgba(255,255,255,0.7), transparent),
        radial-gradient(3px 3px at 80% 50%, rgba(255,255,255,0.5), transparent),
        radial-gradient(2px 2px at 10% 80%, rgba(255,255,255,0.8), transparent),
        radial-gradient(3px 3px at 70% 90%, rgba(255,255,255,0.6), transparent),
        radial-gradient(2px 2px at 90% 10%, rgba(255,255,255,0.7), transparent),
        radial-gradient(4px 4px at 50% 50%, rgba(255,255,255,0.4), transparent),
        radial-gradient(2px 2px at 30% 60%, rgba(255,255,255,0.6), transparent),
        radial-gradient(3px 3px at 85% 75%, rgba(255,255,255,0.5), transparent);
    animation: sparkle 4s ease-in-out infinite alternate;
    pointer-events: none;
}

@keyframes sparkle {
    0% { opacity: 0.6; }
    100% { opacity: 1; }
}

.hero-flowers {
    position: absolute;
    z-index: 1;
    pointer-events: none;
}

.hero-flowers img,
.section-flowers img {
    /* True PNG transparency, no blend needed */
}

/* Hero corners - 4 coins like mockup */
.hero-flowers-topleft {
    top: -10px;
    left: -10px;
    width: 200px;
}

.hero-flowers-topright {
    top: -10px;
    right: -10px;
    width: 200px;
}

.hero-flowers-bottomleft {
    bottom: -10px;
    left: -10px;
    width: 180px;
}

.hero-flowers-bottomright {
    bottom: -10px;
    right: -10px;
    width: 180px;
}

/* Section flowers - diagonal: top-left + bottom-right */
.fleur-topleft {
    top: -30px;
    left: -20px;
    width: 200px;
}

.fleur-bottomright {
    bottom: -30px;
    right: -20px;
    width: 200px;
}

.shabbat-fleur-rotate img {
    transform: rotate(90deg);
}

.shabbat-fleur-topleft {
    top: -200px;
}
.shabbat-fleur-topleft img {
    transform: rotate(-270deg);
}

.hero-content {
    position: relative;
    z-index: 2;
    text-align: center;
    max-width: 500px;
    width: 100%;
}

.hero-logo {
    width: 120px;
    height: 120px;
    margin-bottom: 5px;
    margin-top: 10px;
    mix-blend-mode: multiply;
}

.hero-title {
    font-size: 3.2rem;
    color: #5a3a7a;
    line-height: 1.2;
    margin-bottom: 8px;
    text-shadow: 0 2px 10px rgba(255,255,255,0.4);
}

.hero-subtitle {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.1rem;
    color: #6b4a8a;
    letter-spacing: 2px;
    margin-bottom: 30px;
    font-weight: 400;
}

/* ===== COUNTDOWN ===== */
.countdown {
    display: flex;
    justify-content: center;
    gap: 12px;
    margin-bottom: 30px;
}

.countdown-item {
    background: rgba(255, 255, 255, 0.25);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(200, 170, 100, 0.3);
    border-radius: 12px;
    padding: 12px 8px;
    min-width: 68px;
    text-align: center;
}

.countdown-number {
    display: block;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.8rem;
    font-weight: 700;
    background: linear-gradient(135deg, #c8a44e, #dab96a, #b8923c);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    line-height: 1;
}

.countdown-label {
    display: block;
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #8a6aaa;
    margin-top: 4px;
    font-weight: 500;
}

/* ===== HERO PHOTO ===== */
.hero-photo {
    margin: 0 auto 30px;
    max-width: 320px;
}

.couple-photo {
    width: 100%;
    height: auto;
    border-radius: 8px;
    border: 3px solid #8b5fbf;
    object-fit: cover;
    object-position: center bottom;
    aspect-ratio: 3/3.5;
    display: block;
    box-shadow:
        0 0 0 8px rgba(139, 95, 191, 0.12),
        0 0 0 16px rgba(139, 95, 191, 0.06),
        inset 0 0 30px rgba(107, 74, 138, 0.1);
}

.photo-placeholder span {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.1rem;
    color: #9a7aba;
    font-style: italic;
    text-transform: uppercase;
    letter-spacing: 2px;
}

/* ===== HERO BUTTONS ===== */
.hero-buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
}

.btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    border: none;
    font-family: 'Montserrat', sans-serif;
    transition: all 0.3s ease;
}

.btn-nav {
    padding: 10px 20px;
    border-radius: 25px;
    font-size: 0.78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    background: rgba(255, 255, 255, 0.7);
    color: #5a3a7a;
    border: 1.5px solid #c9a84c;
    backdrop-filter: blur(10px);
}

.btn-nav:hover {
    background: rgba(255, 255, 255, 0.9);
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(107, 74, 138, 0.2);
}

.btn-nav.btn-rsvp {
    background: linear-gradient(135deg, #8b5fbf, #6b4a8a);
    color: white;
    border-color: transparent;
}

.btn-nav.btn-rsvp:hover {
    background: linear-gradient(135deg, #9b6fd0, #7b5a9a);
    color: white;
}

/* ===== SECTIONS ===== */
.section {
    position: relative;
    padding: 80px 20px;
    overflow: visible;
    background: transparent;
    z-index: 1;
}

.section-alt {
    background: transparent;
}

#shabbat {
    padding-top: 120px;
}

#shabbat .section-content {
    padding-top: 0;
}

.section-flowers {
    position: absolute;
    z-index: 0;
    pointer-events: none;
}

/* Unified flower classes are defined above in hero section */

.section-content {
    position: relative;
    z-index: 1;
    max-width: 500px;
    margin: 0 auto;
    text-align: center;
}

.section-tag {
    font-size: 1.2rem;
    text-transform: uppercase;
    letter-spacing: 5px;
    color: #c9a84c;
    margin-bottom: 14px;
    font-weight: 700;
}

.section-title {
    font-size: 2.8rem;
    color: #5a3a7a;
    margin-bottom: 24px;
    line-height: 1.2;
}

.section-details {
    margin-bottom: 24px;
    line-height: 1.9;
    font-size: 1rem;
    color: #4a3a5a;
}

.section-details p {
    margin-bottom: 2px;
}

.detail-highlight {
    font-size: 1.15rem;
}

.section-image {
    margin: 8px auto;
    max-width: 340px;
    overflow: hidden;
}

.section-image img {
    display: block;
    width: 100%;
    height: auto;
    mix-blend-mode: multiply;
}

/* ===== ITINERARY BUTTON ===== */
.btn-itineraire {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 28px;
    border-radius: 30px;
    font-size: 0.9rem;
    font-weight: 600;
    background: linear-gradient(135deg, #8b5fbf, #6b4a8a);
    color: #c9a84c;
    margin-top: 16px;
    box-shadow: 0 4px 15px rgba(107, 74, 138, 0.3);
}

.btn-itineraire:hover {
    transform: translateY(-2px);
    background: linear-gradient(135deg, #9b6fd0, #7b5a9a);
    box-shadow: 0 6px 20px rgba(107, 74, 138, 0.4);
    color: #e0c872;
}

.waze-icon {
    width: 22px;
    height: 22px;
    flex-shrink: 0;
    filter: invert(75%) sepia(60%) saturate(400%) hue-rotate(5deg) brightness(0.9);
}

/* ===== HOUPPA SECTION ===== */
.section-houppa {
    background: transparent;
    padding: 80px 20px 60px;
}

.parents-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-bottom: 24px;
    font-size: 0.95rem;
    line-height: 1.7;
    color: #4a3a5a;
}

.parents-col {
    text-align: center;
}

.family-name {
    font-weight: 700;
    font-size: 1.05rem;
    color: #5a3a7a;
    margin-bottom: 6px;
}

.parents-small {
    font-size: 0.95rem;
    color: #4a3a5a;
}

.invitation-text {
    font-size: 1.1rem;
    font-style: italic;
    color: #5a3a7a;
    margin-bottom: 8px;
    line-height: 1.6;
}

.houppa-title {
    margin-bottom: 20px;
}

.suite-text {
    font-size: 1.05rem;
    color: #5a3a7a;
    margin: 16px 0;
    font-style: italic;
}

/* Hommage */
.hommage {
    margin-top: 40px;
    padding-top: 30px;
    border-top: 1px solid rgba(107, 74, 138, 0.15);
}

.hommage-text {
    font-style: italic;
    font-size: 1.2rem;
    font-weight: 800;
    color: #2a1540;
    margin-bottom: 20px;
    line-height: 1.6;
}

.hommage-grid {
    font-size: 1.1rem;
    font-weight: 800;
    color: #2a1540;
    font-style: italic;
}

/* ===== RSVP SECTION ===== */
.section-rsvp {
    background: transparent;
    padding: 80px 20px 40px;
}

.rsvp-title {
    font-size: 3rem;
    color: #5a3a7a;
    margin-bottom: 8px;
}

.rsvp-subtitle {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.1rem;
    color: #7a5a9a;
    margin-bottom: 36px;
}

.rsvp-form {
    max-width: 480px;
    margin: 0 auto;
    text-align: left;
}

.form-group {
    margin-bottom: 20px;
}

.form-group label {
    display: block;
    font-size: 0.85rem;
    font-weight: 600;
    color: #5a3a7a;
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.required {
    color: #c47abd;
}

.form-group input,
.form-group textarea {
    width: 100%;
    padding: 12px 16px;
    border: 1.5px solid rgba(180, 140, 200, 0.3);
    border-radius: 10px;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.95rem;
    background: rgba(255, 255, 255, 0.5);
    color: #3a2a4a;
    transition: border-color 0.3s, box-shadow 0.3s;
    outline: none;
}

.form-group input:focus,
.form-group textarea:focus {
    border-color: #9b6bc4;
    box-shadow: 0 0 0 3px rgba(155, 107, 196, 0.15);
}

.form-group textarea {
    resize: vertical;
}

/* RSVP Events */
.rsvp-events {
    margin: 30px 0;
}

.rsvp-event {
    background: rgba(255, 255, 255, 0.35);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.5);
    border-radius: 14px;
    padding: 20px;
    margin-bottom: 16px;
}

.rsvp-event h4 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.3rem;
    font-weight: 700;
    color: #5a3a7a;
    margin-bottom: 2px;
}

.event-date {
    font-size: 0.8rem;
    color: #7a5a9a;
    margin-bottom: 14px;
}

.event-date em {
    font-style: italic;
}

.rsvp-row {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 8px 0;
    border-bottom: 1px solid rgba(180, 140, 200, 0.1);
}

.rsvp-row:last-of-type {
    border-bottom: none;
}

.rsvp-person {
    flex: 1;
    font-size: 0.9rem;
    font-weight: 500;
    color: #4a3a5a;
}

.radio-label {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 0.9rem;
    color: #5a3a7a;
    cursor: pointer;
    font-weight: 500;
}

.radio-label input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    width: 20px;
    height: 20px;
    border: 2px solid rgba(180, 140, 200, 0.4);
    border-radius: 50%;
    cursor: pointer;
    transition: 0.3s;
    position: relative;
}

.radio-label input[type="radio"]:checked {
    border-color: #9b6bc4;
    background: #9b6bc4;
}

.radio-label input[type="radio"]:checked::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: white;
}

.event-note {
    font-size: 0.8rem;
    font-style: italic;
    color: #7a5a9a;
    margin-top: 12px;
    line-height: 1.4;
}

/* Submit button */
.btn-submit {
    width: 100%;
    padding: 16px;
    border-radius: 30px;
    font-size: 1rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    background: linear-gradient(135deg, #9b6bc4, #7b4fa8);
    color: white;
    border: none;
    cursor: pointer;
    margin-top: 10px;
    box-shadow: 0 4px 20px rgba(123, 79, 168, 0.3);
    transition: all 0.3s;
}

.btn-submit:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 25px rgba(123, 79, 168, 0.4);
}

.btn-submit:active {
    transform: translateY(0);
}

/* Confirmation */
.rsvp-confirmation {
    text-align: center;
    padding: 40px 20px;
}

.confirmation-icon {
    width: 70px;
    height: 70px;
    border-radius: 50%;
    background: linear-gradient(135deg, #7bc67b, #5aad5a);
    color: white;
    font-size: 2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px;
}

.rsvp-confirmation h3 {
    font-family: 'Great Vibes', cursive;
    font-size: 2.5rem;
    color: #5a3a7a;
    margin-bottom: 10px;
}

.rsvp-confirmation p {
    color: #7a5a9a;
    font-size: 1rem;
    line-height: 1.6;
}

/* ===== FOOTER ===== */
.footer {
    background: transparent;
    position: relative;
    z-index: 1;
    text-align: center;
    padding: 20px 20px 50px;
}

.footer-logo {
    width: 160px;
    height: 160px;
    margin-bottom: 20px;
    opacity: 0.8;
    mix-blend-mode: multiply;
}

.footer-text {
    font-family: 'Great Vibes', cursive;
    font-size: 3rem;
    color: #5a3a7a;
    margin-bottom: 6px;
}

.footer-date {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.2rem;
    color: #7a5a9a;
    letter-spacing: 3px;
    letter-spacing: 2px;
    margin-top: 4px;
}

/* ===== FADE-IN ANIMATION ===== */
.fade-in {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.8s ease, transform 0.8s ease;
}

.fade-in.visible {
    opacity: 1;
    transform: translateY(0);
}

/* ===== RESPONSIVE: MOBILE (max 480px) ===== */
@media (max-width: 480px) {
    .hero {
        padding: 50px 16px 30px;
    }

    .hero-title {
        font-size: 2.4rem;
    }

    .hero-subtitle {
        font-size: 0.95rem;
        margin-bottom: 20px;
    }

    .hero-logo {
        width: 55px;
        height: 55px;
    }

    .countdown {
        gap: 6px;
        margin-bottom: 20px;
    }

    .countdown-item {
        min-width: 55px;
        padding: 10px 5px;
    }

    .countdown-number {
        font-size: 1.4rem;
    }

    .countdown-label {
        font-size: 0.6rem;
    }

    .hero-photo {
        max-width: 260px;
        margin-bottom: 20px;
    }

    .hero-buttons {
        gap: 7px;
    }

    .btn-nav {
        padding: 8px 13px;
        font-size: 0.68rem;
    }

    .hero-flowers-top {
        width: 180px;
        top: -10px;
        right: -20px;
    }

    .hero-flowers-topleft,
    .hero-flowers-topright,
    .hero-flowers-bottomleft,
    .hero-flowers-bottomright {
        width: 180px;
    }

    .fleur-topleft {
        width: 160px;
        top: -25px;
        left: -15px;
    }

    .fleur-bottomright {
        width: 160px;
        bottom: -25px;
        right: -15px;
    }

    .shabbat-fleur-topleft {
        top: -35px;
    }

    .section-tag,
    .section-title,
    .houppa-title,
    .rsvp-title {
        text-shadow: 0 0 8px rgba(228, 210, 245, 0.95), 0 0 16px rgba(228, 210, 245, 0.9), 0 0 24px rgba(228, 210, 245, 0.8);
    }

    .section {
        padding: 40px 16px 60px;
    }

    .section-content {
        padding-top: 60px;
    }

    .section-content {
        max-width: 100%;
    }

    .section-tag {
        font-size: 0.85rem;
        letter-spacing: 3px;
    }

    .section-title {
        font-size: 2rem;
        margin-bottom: 18px;
    }

    .section-details {
        font-size: 0.9rem;
        line-height: 1.8;
    }

    .section-image {
        max-width: 280px;
    }

    .parents-grid {
        gap: 10px;
        font-size: 0.8rem;
    }

    .family-name {
        font-size: 0.95rem;
    }

    .invitation-text {
        font-size: 0.95rem;
    }

    .rsvp-title {
        font-size: 2.2rem;
    }

    .rsvp-subtitle {
        font-size: 0.95rem;
        margin-bottom: 24px;
    }

    .rsvp-form {
        max-width: 100%;
    }

    .rsvp-event {
        padding: 14px;
    }

    .rsvp-row {
        gap: 10px;
    }

    .rsvp-person {
        font-size: 0.8rem;
    }

    .radio-label {
        font-size: 0.8rem;
    }

    /* Flowers mobile */
    /* mobile flower sizes handled by base classes */
}

/* ===== RESPONSIVE: TABLET (481-768px) ===== */
@media (min-width: 481px) and (max-width: 768px) {
    .hero-title {
        font-size: 3rem;
    }

    .hero-flowers-top {
        width: 240px;
    }

    .hero-flowers-bottom {
        width: 210px;
    }

    .section-title {
        font-size: 2.6rem;
    }

    .section-content {
        max-width: 520px;
    }

    .section-image {
        max-width: 360px;
    }

    .rsvp-form {
        max-width: 460px;
    }

    /* Flowers tablet */
    .fleur-topleft {
        width: 180px;
        top: -25px;
        left: -15px;
    }

    .fleur-bottomright {
        width: 180px;
        bottom: -25px;
        right: -15px;
    }
}

/* ===== RESPONSIVE: DESKTOP (769px+) ===== */
@media (min-width: 769px) {
    .hero {
        padding: 80px 60px 80px;
    }

    .bsd-text {
        font-size: 1.4rem;
    }

    .hero-title {
        font-size: 5.5rem;
    }

    .hero-subtitle {
        font-size: 1.4rem;
    }

    .hero-photo {
        max-width: 500px;
    }

    .hero-flowers-topleft,
    .hero-flowers-topright,
    .hero-flowers-bottomleft,
    .hero-flowers-bottomright {
        width: 300px;
    }

    .fleur-topleft {
        width: 300px;
    }

    .fleur-bottomright {
        width: 300px;
    }

    .section {
        padding: 140px 60px;
    }

    .section-content {
        max-width: 900px;
    }

    .section-tag {
        font-size: 1.5rem;
        letter-spacing: 6px;
    }

    .section-title {
        font-size: 4.2rem;
    }

    .section-details {
        font-size: 1.25rem;
        line-height: 2;
    }

    .section-image {
        max-width: 620px;
    }

    .countdown-item {
        min-width: 100px;
        padding: 20px 16px;
    }

    .countdown-number {
        font-size: 2.8rem;
    }

    .countdown-label {
        font-size: 0.85rem;
    }

    .btn-nav {
        padding: 14px 32px;
        font-size: 0.95rem;
    }

    .parents-grid {
        font-size: 1.2rem;
        gap: 50px;
    }

    .rsvp-title {
        font-size: 4.2rem;
    }

    .rsvp-form {
        max-width: 650px;
    }

    .rsvp-form label {
        font-size: 1.1rem;
    }

    .rsvp-form input,
    .rsvp-form textarea {
        font-size: 1.05rem;
        padding: 14px 16px;
    }

    .btn-itineraire {
        font-size: 1.1rem;
        padding: 16px 40px;
    }

    /* Flowers desktop - large and bold */
    /* desktop flower sizes - unified */
}

/* ===== RESPONSIVE: LARGE DESKTOP (1200px+) ===== */
@media (min-width: 1200px) {
    .hero {
        padding: 80px 80px 100px;
    }

    .hero-content {
        max-width: 750px;
    }

    .bsd-text {
        font-size: 1.6rem;
    }

    .hero-title {
        font-size: 6.5rem;
    }

    .hero-subtitle {
        font-size: 1.6rem;
    }

    .hero-photo {
        max-width: 580px;
    }

    .section {
        padding: 160px 80px;
    }

    .section-content {
        max-width: 1100px;
    }

    .section-tag {
        font-size: 1.7rem;
        letter-spacing: 8px;
    }

    .section-title {
        font-size: 5rem;
    }

    .section-details {
        font-size: 1.35rem;
        line-height: 2.1;
    }

    .section-image {
        max-width: 780px;
    }

    .countdown-item {
        min-width: 110px;
        padding: 24px 18px;
    }

    .countdown-number {
        font-size: 3.2rem;
    }

    .countdown-label {
        font-size: 0.9rem;
    }

    .btn-nav {
        padding: 16px 36px;
        font-size: 1rem;
    }

    .parents-grid {
        font-size: 1.3rem;
        gap: 60px;
    }

    .rsvp-title {
        font-size: 5rem;
    }

    .rsvp-form {
        max-width: 800px;
    }

    .rsvp-form label {
        font-size: 1.15rem;
    }

    .rsvp-form input,
    .rsvp-form textarea {
        font-size: 1.1rem;
        padding: 16px 18px;
    }

    .btn-itineraire {
        font-size: 1.2rem;
        padding: 18px 46px;
    }

    .hero-flowers-top {
        width: 520px;
        top: -30px;
        right: -10px;
    }

    .hero-flowers-bottom {
        width: 450px;
        bottom: -30px;
        left: -30px;
    }

    .hero-flowers-midleft {
        width: 280px;
        left: -80px;
        top: 28%;
    }

    .hero-flowers-midright {
        width: 240px;
        right: -60px;
        bottom: 12%;
    }

    .hero-flowers-topleft {
        width: 200px;
        left: -50px;
        top: 0%;
    }

    .hero-flowers-topleft,
    .hero-flowers-topright,
    .hero-flowers-bottomleft,
    .hero-flowers-bottomright {
        width: 420px;
    }

    .fleur-topleft {
        width: 420px;
    }

    .fleur-bottomright {
        width: 420px;
    }
}

/* ===== AUDIO PLAYER ===== */
.audio-player {
    position: fixed;
    bottom: 20px;
    left: 20px;
    z-index: 1000;
}

.audio-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    background: rgba(139, 95, 191, 0.85);
    color: white;
    border: 1.5px solid rgba(201, 168, 76, 0.6);
    border-radius: 25px;
    padding: 8px 16px;
    cursor: pointer;
    font-family: Montserrat, sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.5px;
    backdrop-filter: blur(10px);
    transition: all 0.3s;
    box-shadow: 0 2px 12px rgba(107, 74, 138, 0.3);
}

.audio-btn:hover {
    background: rgba(139, 95, 191, 1);
    transform: translateY(-2px);
    box-shadow: 0 4px 18px rgba(107, 74, 138, 0.4);
}

.audio-note {
    font-size: 1rem;
    animation: pulse-note 1.8s ease-in-out infinite;
}

@keyframes pulse-note {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.7; transform: scale(1.2); }
}

.audio-btn.playing .audio-note {
    animation: spin-note 1s linear infinite;
}

@keyframes spin-note {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

@media (max-width: 480px) {
    .audio-player {
        bottom: 15px;
        left: 15px;
    }
    .audio-btn {
        font-size: 0.7rem;
        padding: 7px 12px;
    }
}

/* ===== ENTER OVERLAY ===== */
.enter-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: linear-gradient(135deg, #3d1a5e 0%, #6b3a9f 40%, #8b5fbf 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.6s ease;
}
.enter-overlay-content {
    text-align: center;
    color: white;
    padding: 40px;
}
.overlay-logo {
    width: 120px;
    height: 120px;
    margin-bottom: 20px;
    filter: brightness(1.5) drop-shadow(0 0 20px rgba(201,168,76,0.5));
}
.overlay-title {
    font-family: "Great Vibes", cursive;
    font-size: 3rem;
    color: #f0d880;
    margin-bottom: 8px;
}
.overlay-subtitle {
    font-family: "Cormorant Garamond", serif;
    font-size: 1.1rem;
    color: rgba(255,255,255,0.8);
    letter-spacing: 3px;
    margin-bottom: 40px;
}
.enter-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 16px 40px;
    background: linear-gradient(135deg, #c9a84c, #e0c872);
    color: #3d1a5e;
    border: none;
    border-radius: 50px;
    font-family: "Montserrat", sans-serif;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    cursor: pointer;
    transition: all 0.3s;
    box-shadow: 0 8px 30px rgba(201, 168, 76, 0.4);
}
.enter-btn:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 40px rgba(201, 168, 76, 0.6);
}
.enter-icon { font-size: 1.3rem; }

/* ===== GUEST COUNT SELECTOR ===== */
.guest-count-selector {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    margin: 12px 0;
}
.count-btn {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 2px solid #8b5fbf;
    background: rgba(139, 95, 191, 0.1);
    color: #5a3a7a;
    font-size: 1.3rem;
    cursor: pointer;
    transition: all 0.2s;
    line-height: 1;
    font-family: "Montserrat", sans-serif;
}
.count-btn:hover { background: #8b5fbf; color: white; }
#guestCountDisplay {
    font-family: "Cormorant Garamond", serif;
    font-size: 2rem;
    font-weight: 700;
    color: #5a3a7a;
    min-width: 30px;
    text-align: center;
}

/* ===== RSVP TABLE ===== */
.rsvp-table {
    width: 100%;
    overflow-x: auto;
    margin: 20px 0;
    border-radius: 12px;
    border: 1px solid rgba(139, 95, 191, 0.2);
    text-align: left;
}
.rsvp-table-header {
    display: flex;
    background: rgba(139, 95, 191, 0.15);
    padding: 10px 8px;
    border-radius: 12px 12px 0 0;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #5a3a7a;
    align-items: center;
}
.rsvp-table-row {
    display: flex;
    align-items: center;
    padding: 10px 8px;
    border-top: 1px solid rgba(139, 95, 191, 0.1);
    gap: 4px;
}
.rsvp-table-row:nth-child(even) { background: rgba(255,255,255,0.3); }
.rsvp-col-name {
    flex: 0 0 180px;
    min-width: 150px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding-right: 8px;
}
.rsvp-col-name input {
    width: 100%;
    padding: 6px 10px;
    border: 1px solid rgba(139, 95, 191, 0.3);
    border-radius: 6px;
    font-family: "Montserrat", sans-serif;
    font-size: 0.8rem;
    background: white;
    color: #3a2a4a;
}
.rsvp-col-event {
    flex: 1;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
}
.radio-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 1.5px solid #8b5fbf;
    cursor: pointer;
    font-size: 0.85rem;
    background: rgba(139, 95, 191, 0.08);
    transition: all 0.2s;
    color: #8b5fbf;
    user-select: none;
}
.radio-toggle input { display: none; }
.radio-toggle:has(input:checked) { background: #8b5fbf; color: white; border-color: #8b5fbf; }
.radio-toggle.radio-no { border-color: #d97070; color: #d97070; background: rgba(217,112,112,0.08); }
.radio-toggle.radio-no:has(input:checked) { background: #d97070; color: white; border-color: #d97070; }

@media (max-width: 600px) {
    .rsvp-col-name { flex: 0 0 120px; min-width: 110px; }
    .radio-toggle { width: 24px; height: 24px; font-size: 0.75rem; }
    .rsvp-table-header { font-size: 0.62rem; }
}

/* ===== AUDIO PLAYER ===== */
.audio-player {
    display: flex;
    justify-content: center;
    margin-top: 16px;
}
.audio-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    background: rgba(255,255,255,0.5);
    color: #5a3a7a;
    border: 1.5px solid rgba(201, 168, 76, 0.5);
    border-radius: 25px;
    padding: 8px 18px;
    cursor: pointer;
    font-family: Montserrat, sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.5px;
    backdrop-filter: blur(10px);
    transition: all 0.3s;
}
.audio-btn:hover, .audio-btn.playing {
    background: rgba(139, 95, 191, 0.8);
    color: white;
    border-color: transparent;
}
.audio-note {
    font-size: 1rem;
    animation: pulse-note 1.8s ease-in-out infinite;
}
@keyframes pulse-note {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.6; transform: scale(1.2); }
}
