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

html {
    scroll-behavior: smooth;
    image-rendering: pixelated;
}

body {
    background-color: #f5efe6;
    color: #3d3229;
    font-family: 'Libre Baskerville', serif;
    overflow-x: hidden;
    cursor: default;
}

/* === PIXEL ART BASE === */
.pixel-art {
    image-rendering: pixelated;
    image-rendering: crisp-edges;
}

/* === SECTION 1: OPENING VOID === */
#opening-void {
    width: 100%;
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    background-color: #f5efe6;
}

#candle-sprite {
    width: 4px;
    height: 4px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) translate(0, 20px);
    background: transparent;
    box-shadow:
        /* candle body - beeswax color */
        0px 0px 0 4px #f0e2b5,
        4px 0px 0 4px #f0e2b5,
        8px 0px 0 4px #f0e2b5,
        0px -4px 0 4px #f0e2b5,
        4px -4px 0 4px #f0e2b5,
        8px -4px 0 4px #f0e2b5,
        0px -8px 0 4px #f0e2b5,
        4px -8px 0 4px #f0e2b5,
        8px -8px 0 4px #f0e2b5,
        0px -12px 0 4px #f0e2b5,
        4px -12px 0 4px #f0e2b5,
        8px -12px 0 4px #f0e2b5,
        0px -16px 0 4px #f0e2b5,
        4px -16px 0 4px #f0e2b5,
        8px -16px 0 4px #f0e2b5,
        0px -20px 0 4px #e8b84b,
        4px -20px 0 4px #e8b84b,
        8px -20px 0 4px #e8b84b,
        /* wick */
        4px -24px 0 4px #3d3229;
}

#candle-flame {
    width: 4px;
    height: 4px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) translate(0, -24px);
    background: transparent;
    box-shadow:
        /* flame core */
        4px -28px 0 4px #e8b84b,
        0px -32px 0 4px #c17849,
        4px -32px 0 4px #e8b84b,
        8px -32px 0 4px #c17849,
        4px -36px 0 4px #c17849,
        4px -40px 0 4px #c17849;
    animation: flicker 0.8s infinite alternate ease-in-out;
}

#candle-glow {
    width: 120px;
    height: 120px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -70%);
    border-radius: 50%;
    background: radial-gradient(circle, rgba(232,184,75,0.15) 0%, rgba(232,184,75,0) 70%);
    animation: glow-pulse 3s infinite alternate ease-in-out;
    pointer-events: none;
}

@keyframes flicker {
    0% { opacity: 1; transform: translate(-50%, -50%) translate(0, -24px); }
    25% { opacity: 0.85; transform: translate(-50%, -50%) translate(-1px, -25px); }
    50% { opacity: 1; transform: translate(-50%, -50%) translate(1px, -24px); }
    75% { opacity: 0.9; transform: translate(-50%, -50%) translate(0, -26px); }
    100% { opacity: 1; transform: translate(-50%, -50%) translate(0, -24px); }
}

@keyframes glow-pulse {
    0% { opacity: 0.5; transform: translate(-50%, -70%) scale(1); }
    100% { opacity: 0.8; transform: translate(-50%, -70%) scale(1.15); }
}

/* === SECTION 2: PIXEL TITLE === */
#title-section {
    width: 100%;
    min-height: 60vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background-color: #f5efe6;
    padding: 80px 20px;
}

/* Pixel-art title using box-shadow: "memorial.wiki" */
#pixel-title {
    width: 5px;
    height: 5px;
    background: transparent;
    margin-bottom: 40px;
    box-shadow:
        /* M */
        0px 0px 0 5px #c17849,
        0px 5px 0 5px #c17849,
        0px 10px 0 5px #c17849,
        0px 15px 0 5px #c17849,
        0px 20px 0 5px #c17849,
        5px 5px 0 5px #c17849,
        10px 10px 0 5px #c17849,
        15px 5px 0 5px #c17849,
        20px 0px 0 5px #c17849,
        20px 5px 0 5px #c17849,
        20px 10px 0 5px #c17849,
        20px 15px 0 5px #c17849,
        20px 20px 0 5px #c17849,
        /* E */
        30px 0px 0 5px #c17849,
        30px 5px 0 5px #c17849,
        30px 10px 0 5px #c17849,
        30px 15px 0 5px #c17849,
        30px 20px 0 5px #c17849,
        35px 0px 0 5px #c17849,
        40px 0px 0 5px #c17849,
        35px 10px 0 5px #c17849,
        40px 10px 0 5px #c17849,
        35px 20px 0 5px #c17849,
        40px 20px 0 5px #c17849,
        /* M */
        50px 0px 0 5px #c17849,
        50px 5px 0 5px #c17849,
        50px 10px 0 5px #c17849,
        50px 15px 0 5px #c17849,
        50px 20px 0 5px #c17849,
        55px 5px 0 5px #c17849,
        60px 10px 0 5px #c17849,
        65px 5px 0 5px #c17849,
        70px 0px 0 5px #c17849,
        70px 5px 0 5px #c17849,
        70px 10px 0 5px #c17849,
        70px 15px 0 5px #c17849,
        70px 20px 0 5px #c17849,
        /* O */
        80px 0px 0 5px #c17849,
        80px 5px 0 5px #c17849,
        80px 10px 0 5px #c17849,
        80px 15px 0 5px #c17849,
        80px 20px 0 5px #c17849,
        85px 0px 0 5px #c17849,
        90px 0px 0 5px #c17849,
        95px 0px 0 5px #c17849,
        95px 5px 0 5px #c17849,
        95px 10px 0 5px #c17849,
        95px 15px 0 5px #c17849,
        95px 20px 0 5px #c17849,
        85px 20px 0 5px #c17849,
        90px 20px 0 5px #c17849,
        /* R */
        105px 0px 0 5px #c17849,
        105px 5px 0 5px #c17849,
        105px 10px 0 5px #c17849,
        105px 15px 0 5px #c17849,
        105px 20px 0 5px #c17849,
        110px 0px 0 5px #c17849,
        115px 0px 0 5px #c17849,
        115px 5px 0 5px #c17849,
        110px 10px 0 5px #c17849,
        115px 10px 0 5px #c17849,
        110px 15px 0 5px #c17849,
        115px 20px 0 5px #c17849,
        /* I */
        125px 0px 0 5px #c17849,
        125px 5px 0 5px #c17849,
        125px 10px 0 5px #c17849,
        125px 15px 0 5px #c17849,
        125px 20px 0 5px #c17849,
        /* A */
        135px 5px 0 5px #c17849,
        135px 10px 0 5px #c17849,
        135px 15px 0 5px #c17849,
        135px 20px 0 5px #c17849,
        140px 0px 0 5px #c17849,
        145px 0px 0 5px #c17849,
        150px 5px 0 5px #c17849,
        150px 10px 0 5px #c17849,
        150px 15px 0 5px #c17849,
        150px 20px 0 5px #c17849,
        140px 10px 0 5px #c17849,
        145px 10px 0 5px #c17849,
        /* L */
        160px 0px 0 5px #c17849,
        160px 5px 0 5px #c17849,
        160px 10px 0 5px #c17849,
        160px 15px 0 5px #c17849,
        160px 20px 0 5px #c17849,
        165px 20px 0 5px #c17849,
        170px 20px 0 5px #c17849,
        /* dot */
        180px 20px 0 5px #c17849,
        /* W */
        190px 0px 0 5px #c17849,
        190px 5px 0 5px #c17849,
        190px 10px 0 5px #c17849,
        190px 15px 0 5px #c17849,
        190px 20px 0 5px #c17849,
        195px 15px 0 5px #c17849,
        200px 10px 0 5px #c17849,
        205px 15px 0 5px #c17849,
        210px 0px 0 5px #c17849,
        210px 5px 0 5px #c17849,
        210px 10px 0 5px #c17849,
        210px 15px 0 5px #c17849,
        210px 20px 0 5px #c17849,
        /* I */
        220px 0px 0 5px #c17849,
        220px 5px 0 5px #c17849,
        220px 10px 0 5px #c17849,
        220px 15px 0 5px #c17849,
        220px 20px 0 5px #c17849,
        /* K */
        230px 0px 0 5px #c17849,
        230px 5px 0 5px #c17849,
        230px 10px 0 5px #c17849,
        230px 15px 0 5px #c17849,
        230px 20px 0 5px #c17849,
        235px 10px 0 5px #c17849,
        240px 5px 0 5px #c17849,
        240px 15px 0 5px #c17849,
        245px 0px 0 5px #c17849,
        245px 20px 0 5px #c17849,
        /* I */
        255px 0px 0 5px #c17849,
        255px 5px 0 5px #c17849,
        255px 10px 0 5px #c17849,
        255px 15px 0 5px #c17849,
        255px 20px 0 5px #c17849;
}

.subtitle {
    font-family: 'Space Mono', monospace;
    font-size: 14px;
    color: #c4b9a8;
    letter-spacing: 4px;
    text-transform: lowercase;
}

/* === SECTION 3: MEMORIAL GARDEN === */
#memorial-garden {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
    padding: 120px 40px;
    background-color: #f5efe6;
}

.garden-row {
    display: flex;
    justify-content: space-around;
    align-items: flex-start;
    margin-bottom: 160px;
    gap: 40px;
}

.memorial-entry {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    max-width: 240px;
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 1.2s ease, transform 1.2s ease;
    cursor: default;
}

.memorial-entry.visible {
    opacity: 1;
    transform: translateY(0);
}

.memorial-entry:hover .headstone-sprite {
    filter: brightness(1.1);
}

/* Headstone sprites via box-shadow */
.headstone-sprite {
    width: 4px;
    height: 4px;
    background: transparent;
    margin-bottom: 24px;
    transition: filter 0.3s ease;
}

.headstone-sprite[data-shape="cross"] {
    box-shadow:
        8px 0px 0 4px #c4b9a8,
        12px 0px 0 4px #c4b9a8,
        0px 4px 0 4px #c4b9a8,
        4px 4px 0 4px #c4b9a8,
        8px 4px 0 4px #c4b9a8,
        12px 4px 0 4px #c4b9a8,
        16px 4px 0 4px #c4b9a8,
        20px 4px 0 4px #c4b9a8,
        8px 8px 0 4px #c4b9a8,
        12px 8px 0 4px #c4b9a8,
        8px 12px 0 4px #c4b9a8,
        12px 12px 0 4px #c4b9a8,
        8px 16px 0 4px #c4b9a8,
        12px 16px 0 4px #c4b9a8,
        8px 20px 0 4px #c4b9a8,
        12px 20px 0 4px #c4b9a8,
        4px 24px 0 4px #c4b9a8,
        8px 24px 0 4px #c4b9a8,
        12px 24px 0 4px #c4b9a8,
        16px 24px 0 4px #c4b9a8;
}

.headstone-sprite[data-shape="arch"] {
    box-shadow:
        8px 0px 0 4px #a8b89c,
        12px 0px 0 4px #a8b89c,
        4px 4px 0 4px #a8b89c,
        16px 4px 0 4px #a8b89c,
        0px 8px 0 4px #a8b89c,
        20px 8px 0 4px #a8b89c,
        0px 12px 0 4px #a8b89c,
        20px 12px 0 4px #a8b89c,
        0px 16px 0 4px #a8b89c,
        20px 16px 0 4px #a8b89c,
        0px 20px 0 4px #a8b89c,
        4px 20px 0 4px #a8b89c,
        8px 20px 0 4px #a8b89c,
        12px 20px 0 4px #a8b89c,
        16px 20px 0 4px #a8b89c,
        20px 20px 0 4px #a8b89c,
        0px 24px 0 4px #a8b89c,
        4px 24px 0 4px #a8b89c,
        8px 24px 0 4px #a8b89c,
        12px 24px 0 4px #a8b89c,
        16px 24px 0 4px #a8b89c,
        20px 24px 0 4px #a8b89c;
}

.headstone-sprite[data-shape="flat"] {
    box-shadow:
        0px 8px 0 4px #6b5b8a,
        4px 8px 0 4px #6b5b8a,
        8px 8px 0 4px #6b5b8a,
        12px 8px 0 4px #6b5b8a,
        16px 8px 0 4px #6b5b8a,
        20px 8px 0 4px #6b5b8a,
        0px 12px 0 4px #6b5b8a,
        4px 12px 0 4px #6b5b8a,
        8px 12px 0 4px #6b5b8a,
        12px 12px 0 4px #6b5b8a,
        16px 12px 0 4px #6b5b8a,
        20px 12px 0 4px #6b5b8a,
        0px 16px 0 4px #6b5b8a,
        4px 16px 0 4px #6b5b8a,
        8px 16px 0 4px #6b5b8a,
        12px 16px 0 4px #6b5b8a,
        16px 16px 0 4px #6b5b8a,
        20px 16px 0 4px #6b5b8a,
        0px 20px 0 4px #6b5b8a,
        4px 20px 0 4px #6b5b8a,
        8px 20px 0 4px #6b5b8a,
        12px 20px 0 4px #6b5b8a,
        16px 20px 0 4px #6b5b8a,
        20px 20px 0 4px #6b5b8a,
        0px 24px 0 4px #6b5b8a,
        4px 24px 0 4px #6b5b8a,
        8px 24px 0 4px #6b5b8a,
        12px 24px 0 4px #6b5b8a,
        16px 24px 0 4px #6b5b8a,
        20px 24px 0 4px #6b5b8a;
}

.headstone-sprite[data-shape="round"] {
    box-shadow:
        4px 0px 0 4px #c17849,
        8px 0px 0 4px #c17849,
        12px 0px 0 4px #c17849,
        16px 0px 0 4px #c17849,
        0px 4px 0 4px #c17849,
        4px 4px 0 4px #c17849,
        16px 4px 0 4px #c17849,
        20px 4px 0 4px #c17849,
        0px 8px 0 4px #c17849,
        20px 8px 0 4px #c17849,
        0px 12px 0 4px #c17849,
        20px 12px 0 4px #c17849,
        0px 16px 0 4px #c17849,
        20px 16px 0 4px #c17849,
        0px 20px 0 4px #c17849,
        4px 20px 0 4px #c17849,
        8px 20px 0 4px #c17849,
        12px 20px 0 4px #c17849,
        16px 20px 0 4px #c17849,
        20px 20px 0 4px #c17849,
        0px 24px 0 4px #c17849,
        4px 24px 0 4px #c17849,
        8px 24px 0 4px #c17849,
        12px 24px 0 4px #c17849,
        16px 24px 0 4px #c17849,
        20px 24px 0 4px #c17849;
}

.memorial-name {
    font-family: 'Libre Baskerville', serif;
    font-size: 18px;
    font-weight: 700;
    color: #3d3229;
    margin-bottom: 4px;
}

.memorial-dates {
    font-family: 'Space Mono', monospace;
    font-size: 12px;
    color: #c4b9a8;
    letter-spacing: 2px;
    margin-bottom: 12px;
}

.memorial-epitaph {
    font-family: 'Libre Baskerville', serif;
    font-style: italic;
    font-size: 14px;
    color: #6b5b8a;
    line-height: 1.7;
    max-width: 200px;
}

/* === SECTION 4: OFFERING === */
#offering-section {
    width: 100%;
    min-height: 80vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background-color: #f0ebe2;
    padding: 80px 20px;
    position: relative;
}

#offering-candle-sprite {
    width: 4px;
    height: 4px;
    background: transparent;
    margin-bottom: 30px;
    cursor: pointer;
    transition: transform 0.3s ease;
    box-shadow:
        4px 0px 0 4px #f0e2b5,
        8px 0px 0 4px #f0e2b5,
        4px -4px 0 4px #f0e2b5,
        8px -4px 0 4px #f0e2b5,
        4px -8px 0 4px #f0e2b5,
        8px -8px 0 4px #f0e2b5,
        4px -12px 0 4px #e8b84b,
        8px -12px 0 4px #e8b84b,
        /* wick */
        6px -16px 0 4px #3d3229,
        /* flame */
        6px -20px 0 4px #e8b84b,
        4px -24px 0 4px #c17849,
        6px -24px 0 4px #e8b84b,
        8px -24px 0 4px #c17849,
        6px -28px 0 4px #c17849;
}

#offering-candle-sprite:hover {
    transform: scale(1.2);
}

.offering-text {
    font-family: 'Space Mono', monospace;
    font-size: 14px;
    color: #c4b9a8;
    letter-spacing: 3px;
    text-transform: lowercase;
    margin-bottom: 40px;
    cursor: pointer;
}

#offering-field {
    width: 100%;
    max-width: 600px;
    min-height: 80px;
    position: relative;
}

.lit-candles-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px;
    padding: 20px;
}

.mini-candle {
    width: 3px;
    height: 3px;
    background: transparent;
    box-shadow:
        0px 0px 0 3px #f0e2b5,
        3px 0px 0 3px #f0e2b5,
        0px -3px 0 3px #f0e2b5,
        3px -3px 0 3px #f0e2b5,
        1px -6px 0 3px #3d3229,
        1px -9px 0 3px #e8b84b,
        0px -12px 0 3px #c17849,
        1px -12px 0 3px #e8b84b,
        3px -12px 0 3px #c17849;
    animation: mini-flicker 1.2s infinite alternate ease-in-out;
    opacity: 0;
    transition: opacity 0.6s ease;
}

.mini-candle.lit {
    opacity: 1;
}

@keyframes mini-flicker {
    0% { filter: brightness(1); }
    50% { filter: brightness(0.85); }
    100% { filter: brightness(1.05); }
}

.offering-count {
    font-family: 'Space Mono', monospace;
    font-size: 12px;
    color: #c4b9a8;
    letter-spacing: 2px;
    margin-top: 30px;
}

/* === SECTION 5: CLOSING VOID === */
#closing-void {
    width: 100%;
    height: 60vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background-color: #f5efe6;
    padding: 80px 20px;
}

#flower-sprite {
    width: 4px;
    height: 4px;
    background: transparent;
    margin-bottom: 40px;
    box-shadow:
        /* stem */
        8px 8px 0 4px #a8b89c,
        8px 12px 0 4px #a8b89c,
        8px 16px 0 4px #a8b89c,
        8px 20px 0 4px #a8b89c,
        8px 24px 0 4px #a8b89c,
        /* leaves */
        4px 16px 0 4px #a8b89c,
        12px 20px 0 4px #a8b89c,
        /* petals */
        8px 0px 0 4px #6b5b8a,
        4px 4px 0 4px #6b5b8a,
        12px 4px 0 4px #6b5b8a,
        0px 8px 0 4px #6b5b8a,
        16px 8px 0 4px #6b5b8a,
        /* center */
        8px 4px 0 4px #e8b84b;
}

.closing-text {
    font-family: 'Space Mono', monospace;
    font-size: 12px;
    color: #c4b9a8;
    letter-spacing: 3px;
    text-transform: lowercase;
    opacity: 0;
    transition: opacity 2s ease;
}

.closing-text.visible {
    opacity: 1;
}

/* === RESPONSIVE === */
@media (max-width: 768px) {
    .garden-row {
        flex-direction: column;
        align-items: center;
        gap: 80px;
        margin-bottom: 80px;
    }

    #pixel-title {
        transform: scale(0.7);
        transform-origin: center center;
    }

    .memorial-entry {
        max-width: 280px;
    }
}

@media (max-width: 480px) {
    #pixel-title {
        transform: scale(0.5);
        transform-origin: center center;
    }

    .subtitle {
        font-size: 11px;
    }
}
