/* =========================================================
   notfound.css — the "Oopsie Doopsie!" 404 page
   ========================================================= */

.notfound-body {
    background-color: var(--header-teal);
    background-image:
        radial-gradient(circle at 25% 25%, rgba(255,192,203,0.30), transparent 45%),
        radial-gradient(circle at 75% 75%, rgba(129,223,154,0.30), transparent 45%);
    min-height: 100vh;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--page-top-pad) 1.5rem 3rem;
    box-sizing: border-box;
}

.oops-card {
    max-width: 540px;
    text-align: center;
    background: var(--paper);
    border: 3px solid var(--title-color);
    border-radius: 12px;
    box-shadow: 6px 8px 0 var(--shadow-color);
    padding: 2.5rem 2rem 2rem;
    position: relative;
}

.oops-boat {
    width: 110px; height: 110px;
    margin: 0 auto 0.5rem;
    display: block;
    filter: drop-shadow(2px 3px 3px rgba(0,77,64,0.4));
    animation: oops-bob 4s ease-in-out infinite;
}
@keyframes oops-bob {
    0%,100% { transform: translateY(0) rotate(-3deg); }
    50%     { transform: translateY(-8px) rotate(3deg); }
}

.oops-title {
    font-family: var(--font-display);
    font-size: 3.4rem;
    color: var(--link-hover);
    margin: 0;
    line-height: 1;
    text-shadow: 3px 3px 0 var(--mango);
}

.oops-code {
    font-family: var(--font-western);
    font-size: 1.1rem;
    color: var(--header-teal);
    letter-spacing: 2px;
    margin: 0.6rem 0 1.2rem;
    text-transform: uppercase;
}

.oops-note {
    font-size: 1.2rem;
    color: var(--text-color);
    margin: 0 0 1.6rem;
}
.oops-note strong { color: var(--burnt); }

.oops-actions {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}
.oops-btn {
    font-family: var(--font-western);
    font-size: 1.05rem;
    text-decoration: none;
    padding: 0.6rem 1.4rem;
    border-radius: 6px;
    border: 2px solid var(--title-color);
    background: var(--header-teal);
    color: #fff;
    box-shadow: 2px 2px 0 var(--shadow-color);
    transition: transform 0.12s ease;
}
.oops-btn:hover { transform: translate(-1px,-1px); color: #fff; }
.oops-btn.pink { background: var(--link-color); box-shadow: 2px 2px 0 var(--link-hover); }

@media (prefers-reduced-motion: reduce) {
    .oops-boat { animation: none !important; }
}

@media (max-width: 480px) {
    .oops-title { font-size: 2.4rem; }
}
