/* /Components/Layout/MainLayout.razor.rz.scp.css */
.page[b-fvbh1ch1jv] {
    position: relative;
    display: flex;
    flex-direction: column;
}

main[b-fvbh1ch1jv] {
    flex: 1;
}

/* Sidebar = a walnut cabinet side panel with brass edge */
.sidebar[b-fvbh1ch1jv] {
    background:
        repeating-linear-gradient(90deg, rgba(0,0,0,0.05) 0 2px, rgba(255,255,255,0.02) 2px 5px),
        linear-gradient(160deg, var(--walnut-light) 0%, var(--walnut) 45%, var(--walnut-dark) 100%);
    border-right: 3px solid var(--brass-dark);
    box-shadow: inset -8px 0 18px -10px rgba(0,0,0,0.6);
}

.top-row[b-fvbh1ch1jv] {
    background: linear-gradient(180deg, var(--paper-2), rgba(239,227,198,0.85));
    border-bottom: 1px solid var(--paper-edge);
    justify-content: flex-end;
    height: 3.5rem;
    display: flex;
    align-items: center;
    backdrop-filter: blur(2px);
}

    .top-row[b-fvbh1ch1jv]  a, .top-row[b-fvbh1ch1jv]  .btn-link {
        white-space: nowrap;
        margin-left: 1.5rem;
        text-decoration: none;
        color: var(--ink-soft);
        font-weight: 600;
        font-size: 0.9rem;
    }

    .top-row[b-fvbh1ch1jv]  a:hover, .top-row[b-fvbh1ch1jv]  .btn-link:hover {
        color: var(--walnut);
        text-decoration: underline;
    }

    .top-row[b-fvbh1ch1jv]  a:first-child {
        overflow: hidden;
        text-overflow: ellipsis;
    }

.top-row__tagline[b-fvbh1ch1jv] {
    font-family: 'Fraunces', serif;
    font-style: italic;
    color: var(--ink-soft);
    font-size: 0.95rem;
}

@media (max-width: 640.98px) {
    .top-row[b-fvbh1ch1jv] {
        justify-content: space-between;
    }

    .top-row[b-fvbh1ch1jv]  a, .top-row[b-fvbh1ch1jv]  .btn-link {
        margin-left: 0;
    }
}

@media (min-width: 641px) {
    .page[b-fvbh1ch1jv] {
        flex-direction: row;
    }

    .sidebar[b-fvbh1ch1jv] {
        width: 250px;
        height: 100vh;
        position: sticky;
        top: 0;
    }

    .top-row[b-fvbh1ch1jv] {
        position: sticky;
        top: 0;
        z-index: 1;
    }

    .top-row.auth[b-fvbh1ch1jv]  a:first-child {
        flex: 1;
        text-align: right;
        width: 0;
    }

    .top-row[b-fvbh1ch1jv], article[b-fvbh1ch1jv] {
        padding-left: 2rem !important;
        padding-right: 1.5rem !important;
    }
}

#blazor-error-ui[b-fvbh1ch1jv] {
    color-scheme: light only;
    background: var(--paper-2);
    color: var(--ink);
    border-top: 3px solid var(--rust);
    bottom: 0;
    box-shadow: 0 -1px 8px rgba(0, 0, 0, 0.25);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss[b-fvbh1ch1jv] {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }
/* /Components/Layout/NavMenu.razor.rz.scp.css */
.navbar-toggler[b-oqx1r2x85z] {
    appearance: none;
    cursor: pointer;
    width: 3.5rem;
    height: 2.5rem;
    color: white;
    position: absolute;
    top: 0.5rem;
    right: 1rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.55%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") no-repeat center/1.75rem rgba(255, 255, 255, 0.1);
}

.navbar-toggler:checked[b-oqx1r2x85z] {
    background-color: rgba(255, 255, 255, 0.5);
}

.top-row[b-oqx1r2x85z] {
    min-height: 4rem;
    background:
        linear-gradient(180deg, rgba(0,0,0,0.28), rgba(0,0,0,0.12));
    border-bottom: 2px solid var(--brass-dark);
}

.navbar-brand[b-oqx1r2x85z] {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 1.35rem;
    font-weight: 600;
    color: var(--brass-light);
    letter-spacing: -0.01em;
    text-shadow: 0 1px 2px rgba(0,0,0,0.5);
}
.navbar-brand:hover[b-oqx1r2x85z] { color: #f0dca8; }

.bi[b-oqx1r2x85z] {
    display: inline-block;
    position: relative;
    width: 1.25rem;
    height: 1.25rem;
    margin-right: 0.75rem;
    top: -1px;
    background-size: cover;
}

.bi-house-door-fill-nav-menu[b-oqx1r2x85z] {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-house-door-fill' viewBox='0 0 16 16'%3E%3Cpath d='M6.5 14.5v-3.505c0-.245.25-.495.5-.495h2c.25 0 .5.25.5.5v3.5a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5v-7a.5.5 0 0 0-.146-.354L13 5.793V2.5a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5v1.293L8.354 1.146a.5.5 0 0 0-.708 0l-6 6A.5.5 0 0 0 1.5 7.5v7a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5Z'/%3E%3C/svg%3E");
}

.bi-plus-square-fill-nav-menu[b-oqx1r2x85z] {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-plus-square-fill' viewBox='0 0 16 16'%3E%3Cpath d='M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm6.5 4.5v3h3a.5.5 0 0 1 0 1h-3v3a.5.5 0 0 1-1 0v-3h-3a.5.5 0 0 1 0-1h3v-3a.5.5 0 0 1 1 0z'/%3E%3C/svg%3E");
}

.bi-shuffle-nav-menu[b-oqx1r2x85z] {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M0 3.5A.5.5 0 0 1 .5 3H1c2.202 0 3.827 1.24 4.874 2.418.49.552.865 1.102 1.126 1.532.26-.43.636-.98 1.126-1.532C9.173 4.24 10.798 3 13 3v1c-1.798 0-3.173 1.01-4.126 2.082A9.6 9.6 0 0 0 7.556 8a9.6 9.6 0 0 0 1.316 1.918C9.828 10.99 11.204 12 13 12v1c-2.202 0-3.827-1.24-4.874-2.418A10.6 10.6 0 0 1 7 9.05c-.26.43-.636.98-1.126 1.532C4.827 11.76 3.202 13 1 13H.5a.5.5 0 0 1 0-1H1c1.798 0 3.173-1.01 4.126-2.082A9.6 9.6 0 0 0 6.444 8a9.6 9.6 0 0 0-1.316-1.918C4.172 5.01 2.796 4 1 4H.5a.5.5 0 0 1-.5-.5z'/%3E%3Cpath d='M13 5.466V1.534a.25.25 0 0 1 .41-.192l2.36 1.966c.12.1.12.284 0 .384l-2.36 1.966a.25.25 0 0 1-.41-.192zm0 9v-3.932a.25.25 0 0 1 .41-.192l2.36 1.966c.12.1.12.284 0 .384l-2.36 1.966a.25.25 0 0 1-.41-.192z'/%3E%3C/svg%3E");
}

.bi-gear-fill-nav-menu[b-oqx1r2x85z] {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' viewBox='0 0 16 16'%3E%3Cpath d='M9.405 1.05c-.413-1.4-2.397-1.4-2.81 0l-.1.34a1.464 1.464 0 0 1-2.105.872l-.31-.17c-1.283-.698-2.686.705-1.987 1.987l.169.311c.446.82.023 1.841-.872 2.105l-.34.1c-1.4.413-1.4 2.397 0 2.81l.34.1a1.464 1.464 0 0 1 .872 2.105l-.17.31c-.698 1.283.705 2.686 1.987 1.987l.311-.169a1.464 1.464 0 0 1 2.105.872l.1.34c.413 1.4 2.397 1.4 2.81 0l.1-.34a1.464 1.464 0 0 1 2.105-.872l.31.17c1.283.698 2.686-.705 1.987-1.987l-.169-.311a1.464 1.464 0 0 1 .872-2.105l.34-.1c1.4-.413 1.4-2.397 0-2.81l-.34-.1a1.464 1.464 0 0 1-.872-2.105l.17-.31c.698-1.283-.705-2.686-1.987-1.987l-.311.169a1.464 1.464 0 0 1-2.105-.872l-.1-.34zM8 10.93a2.929 2.929 0 1 1 0-5.858 2.929 2.929 0 0 1 0 5.858z'/%3E%3C/svg%3E");
}

.bi-bar-chart-fill-nav-menu[b-oqx1r2x85z] {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' viewBox='0 0 16 16'%3E%3Cpath d='M1 11a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1H2a1 1 0 0 1-1-1v-3zm5-4a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v7a1 1 0 0 1-1 1H7a1 1 0 0 1-1-1V7zm5-5a1 1 0 0 1 1-1h2a1 1 0 0 1 1 1v12a1 1 0 0 1-1 1h-2a1 1 0 0 1-1-1V2z'/%3E%3C/svg%3E");
}

.nav-item[b-oqx1r2x85z] {
    font-size: 0.9rem;
    padding-bottom: 0.5rem;
}

    .nav-item:first-of-type[b-oqx1r2x85z] {
        padding-top: 1rem;
    }

    .nav-item:last-of-type[b-oqx1r2x85z] {
        padding-bottom: 1rem;
    }

    .nav-item[b-oqx1r2x85z]  .nav-link {
        color: #ecd9b8;
        background: none;
        border: 1px solid transparent;
        border-radius: 8px;
        height: 3rem;
        display: flex;
        align-items: center;
        line-height: 3rem;
        width: 100%;
        font-weight: 600;
        transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
    }

.nav-item[b-oqx1r2x85z]  a.active {
    background: linear-gradient(180deg, rgba(226,201,135,0.95), rgba(200,168,94,0.9));
    color: #3a2d0c;
    border-color: var(--brass-dark);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.4), 0 2px 6px rgba(0,0,0,0.3);
}

.nav-item[b-oqx1r2x85z]  .nav-link:hover {
    background-color: rgba(255,255,255,0.08);
    border-color: rgba(226,201,135,0.4);
    color: #fbeed1;
}
.nav-item[b-oqx1r2x85z]  a.active:hover {
    color: #3a2d0c;
}

.nav-scrollable[b-oqx1r2x85z] {
    display: none;
}

.navbar-toggler:checked ~ .nav-scrollable[b-oqx1r2x85z] {
    display: block;
}

@media (min-width: 641px) {
    .navbar-toggler[b-oqx1r2x85z] {
        display: none;
    }

    .nav-scrollable[b-oqx1r2x85z] {
        /* Never collapse the sidebar for wide screens */
        display: block;

        /* Allow sidebar to scroll for tall menus */
        height: calc(100vh - 3.5rem);
        overflow-y: auto;
    }
}
/* /Components/Layout/ReconnectModal.razor.rz.scp.css */
.components-reconnect-first-attempt-visible[b-49xx23soo6],
.components-reconnect-repeated-attempt-visible[b-49xx23soo6],
.components-reconnect-failed-visible[b-49xx23soo6],
.components-pause-visible[b-49xx23soo6],
.components-resume-failed-visible[b-49xx23soo6],
.components-rejoining-animation[b-49xx23soo6] {
    display: none;
}

#components-reconnect-modal.components-reconnect-show .components-reconnect-first-attempt-visible[b-49xx23soo6],
#components-reconnect-modal.components-reconnect-show .components-rejoining-animation[b-49xx23soo6],
#components-reconnect-modal.components-reconnect-paused .components-pause-visible[b-49xx23soo6],
#components-reconnect-modal.components-reconnect-resume-failed .components-resume-failed-visible[b-49xx23soo6],
#components-reconnect-modal.components-reconnect-retrying[b-49xx23soo6],
#components-reconnect-modal.components-reconnect-retrying .components-reconnect-repeated-attempt-visible[b-49xx23soo6],
#components-reconnect-modal.components-reconnect-retrying .components-rejoining-animation[b-49xx23soo6],
#components-reconnect-modal.components-reconnect-failed[b-49xx23soo6],
#components-reconnect-modal.components-reconnect-failed .components-reconnect-failed-visible[b-49xx23soo6] {
    display: block;
}


#components-reconnect-modal[b-49xx23soo6] {
    background-color: white;
    width: 20rem;
    margin: 20vh auto;
    padding: 2rem;
    border: 0;
    border-radius: 0.5rem;
    box-shadow: 0 3px 6px 2px rgba(0, 0, 0, 0.3);
    opacity: 0;
    transition: display 0.5s allow-discrete, overlay 0.5s allow-discrete;
    animation: components-reconnect-modal-fadeOutOpacity-b-49xx23soo6 0.5s both;
    &[open]

{
    animation: components-reconnect-modal-slideUp-b-49xx23soo6 1.5s cubic-bezier(.05, .89, .25, 1.02) 0.3s, components-reconnect-modal-fadeInOpacity-b-49xx23soo6 0.5s ease-in-out 0.3s;
    animation-fill-mode: both;
}

}

#components-reconnect-modal[b-49xx23soo6]::backdrop {
    background-color: rgba(0, 0, 0, 0.4);
    animation: components-reconnect-modal-fadeInOpacity-b-49xx23soo6 0.5s ease-in-out;
    opacity: 1;
}

@keyframes components-reconnect-modal-slideUp-b-49xx23soo6 {
    0% {
        transform: translateY(30px) scale(0.95);
    }

    100% {
        transform: translateY(0);
    }
}

@keyframes components-reconnect-modal-fadeInOpacity-b-49xx23soo6 {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes components-reconnect-modal-fadeOutOpacity-b-49xx23soo6 {
    0% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

.components-reconnect-container[b-49xx23soo6] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

#components-reconnect-modal p[b-49xx23soo6] {
    margin: 0;
    text-align: center;
}

#components-reconnect-modal button[b-49xx23soo6] {
    border: 0;
    background-color: #6b9ed2;
    color: white;
    padding: 4px 24px;
    border-radius: 4px;
}

    #components-reconnect-modal button:hover[b-49xx23soo6] {
        background-color: #3b6ea2;
    }

    #components-reconnect-modal button:active[b-49xx23soo6] {
        background-color: #6b9ed2;
    }

.components-rejoining-animation[b-49xx23soo6] {
    position: relative;
    width: 80px;
    height: 80px;
}

    .components-rejoining-animation div[b-49xx23soo6] {
        position: absolute;
        border: 3px solid #0087ff;
        opacity: 1;
        border-radius: 50%;
        animation: components-rejoining-animation-b-49xx23soo6 1.5s cubic-bezier(0, 0.2, 0.8, 1) infinite;
    }

        .components-rejoining-animation div:nth-child(2)[b-49xx23soo6] {
            animation-delay: -0.5s;
        }

@keyframes components-rejoining-animation-b-49xx23soo6 {
    0% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 0;
    }

    4.9% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 0;
    }

    5% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 1;
    }

    100% {
        top: 0px;
        left: 0px;
        width: 80px;
        height: 80px;
        opacity: 0;
    }
}
/* /Components/Pages/Home.razor.rz.scp.css */
.draw-page[b-edb5xyj9ow] {
    max-width: 560px;
    margin: 0 auto;
    padding: 1rem 1rem 3rem;
    text-align: center;
}

.draw-head[b-edb5xyj9ow] {
    margin-bottom: 0.5rem;
}

.draw-title[b-edb5xyj9ow] {
    font-family: 'Fraunces', Georgia, serif;
    font-size: clamp(2rem, 5vw, 2.8rem);
    font-weight: 600;
    color: var(--walnut-dark);
    margin: 0;
}

.draw-sub[b-edb5xyj9ow] {
    font-family: 'Fraunces', serif;
    font-style: italic;
    color: var(--ink-soft);
    margin-top: 0.35rem;
    font-size: 1.05rem;
}

.draw-filters[b-edb5xyj9ow] {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem 1.25rem;
    margin: 0 auto 1rem;
}

.draw-filter[b-edb5xyj9ow] {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
    color: var(--ink);
    font-weight: 600;
    user-select: none;
}

.draw-filter input[b-edb5xyj9ow] {
    width: 1.1rem;
    height: 1.1rem;
    accent-color: var(--brass-dark);
    cursor: pointer;
}

.draw-filter small[b-edb5xyj9ow] {
    color: var(--ink-faint);
    font-weight: 400;
}

/* ---------------- The wall of accepted chores ---------------- */

.wall[b-edb5xyj9ow] {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: clamp(0.5rem, 4vw, 1.75rem);
    min-height: 158px;
    margin: 0.75rem auto 0.25rem;
    padding-top: 0.5rem;
}

.pin-slot[b-edb5xyj9ow] {
    position: relative;
    width: clamp(96px, 30vw, 150px);
    display: flex;
    justify-content: center;
}

/* the brass tack at the top of every slot — shows the 3 available spots */
.wall-nail[b-edb5xyj9ow] {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: radial-gradient(circle at 35% 30%, var(--brass-light), var(--brass) 55%, var(--brass-dark));
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.45), inset 0 1px 1px rgba(255, 255, 255, 0.6);
    z-index: 3;
}

/* empty slot: hint a faint hole where a slip could hang */
.pin-slot:has(.wall-nail:only-child)[b-edb5xyj9ow]::before {
    content: "";
    position: absolute;
    top: 26px;
    left: 50%;
    transform: translateX(-50%);
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: rgba(58, 36, 19, 0.18);
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.3);
}

.wall-slip[b-edb5xyj9ow] {
    position: relative;
    margin-top: 7px;
    width: 100%;
    transform-origin: top center;
    transform: rotate(var(--tilt, 0deg));
    transition: transform 0.5s cubic-bezier(0.34, 1.3, 0.5, 1), box-shadow 0.2s ease;
    cursor: grab;
    touch-action: none;
    z-index: 1;
    animation: pin-in-b-edb5xyj9ow 0.5s cubic-bezier(0.34, 1.3, 0.5, 1) both;
}

.wall-slip .slip__body[b-edb5xyj9ow] {
    position: relative;
    background:
        linear-gradient(180deg, #fdf8ec, var(--paper));
    border: 1px solid var(--paper-edge);
    border-radius: 4px;
    padding: 0.85rem 0.65rem 0.7rem;
    box-shadow: 0 10px 20px -10px rgba(58, 36, 19, 0.55);
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    text-align: center;
}

/* the tack appears to pierce the top of the slip */
.wall-slip .slip__body[b-edb5xyj9ow]::before {
    content: "";
    position: absolute;
    top: -5px;
    left: 50%;
    transform: translateX(-50%);
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: rgba(58, 36, 19, 0.4);
}

.wall-slip .slip__eyebrow[b-edb5xyj9ow] {
    font-family: 'Hanken Grotesk', sans-serif;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    font-size: 0.56rem;
    font-weight: 700;
    color: var(--brass-dark);
}

.wall-slip .slip__chore[b-edb5xyj9ow] {
    font-family: 'Caveat', cursive;
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 1;
    color: var(--ink);
}

.wall-slip .slip__note[b-edb5xyj9ow] {
    font-family: 'Hanken Grotesk', sans-serif;
    font-size: 0.6rem;
    color: var(--ink-faint);
    margin-top: 0.2rem;
}

.wall-slip:hover[b-edb5xyj9ow] {
    transform: rotate(var(--tilt, 0deg)) translateY(2px);
    box-shadow: 0 16px 26px -12px rgba(58, 36, 19, 0.6);
}

/* while being dragged: JS owns the transform, so kill the spring transition */
.wall-slip.is-grabbed[b-edb5xyj9ow] {
    cursor: grabbing;
    transition: none;
    z-index: 20;
    box-shadow: 0 22px 34px -14px rgba(40, 24, 12, 0.7);
}

/* floating off-screen: JS animation drives it, stay on top and ignore input */
.wall-slip.is-flying[b-edb5xyj9ow] {
    transition: none;
    pointer-events: none;
    z-index: 20;
}

.wall-note[b-edb5xyj9ow] {
    font-family: 'Fraunces', serif;
    font-style: italic;
    color: var(--rust);
    margin: 0.4rem 0 0;
    flex-basis: 100%;
}

@keyframes pin-in-b-edb5xyj9ow {
    0%   { transform: translateY(-22px) rotate(calc(var(--tilt, 0deg) - 6deg)); opacity: 0; }
    100% { transform: rotate(var(--tilt, 0deg)); opacity: 1; }
}

/* ---------------- The cabinet scene ---------------- */

.cabinet-scene[b-edb5xyj9ow] {
    position: relative;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    min-height: 440px;
    margin: 0.5rem auto 0;
    perspective: 1200px;
}

/* ---- the paper slip (rises from behind the cabinet) ---- */

.slip[b-edb5xyj9ow] {
    position: absolute;
    left: 50%;
    bottom: 96px;
    width: 240px;
    z-index: 1;
    transform: translateX(-50%) translateY(48px);
    opacity: 0;
    transition: transform 0.7s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.4s ease;
    pointer-events: none;
}

.cabinet-scene.is-open .slip[b-edb5xyj9ow] {
    transform: translateX(-50%) translateY(-168px) rotate(-1.6deg);
    opacity: 1;
    animation: slip-bob-b-edb5xyj9ow 4.5s ease-in-out 0.75s infinite;
}

.slip__body[b-edb5xyj9ow] {
    position: relative;
    background:
        linear-gradient(180deg, #fdf8ec, var(--paper));
    border: 1px solid var(--paper-edge);
    border-radius: 4px;
    padding: 1.5rem 1.25rem 1.4rem;
    box-shadow: 0 14px 28px -10px rgba(58, 36, 19, 0.55);
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    /* faint ruled line under the chore */
    background-image:
        linear-gradient(180deg, #fdf8ec, var(--paper)),
        repeating-linear-gradient(180deg, transparent 0 31px, rgba(124,82,48,0.08) 31px 32px);
}

.slip__body[b-edb5xyj9ow]::after {
    /* torn-ish bottom edge shadow */
    content: "";
    position: absolute;
    left: 8px; right: 8px; bottom: -3px;
    height: 6px;
    background: rgba(58, 36, 19, 0.12);
    filter: blur(3px);
    border-radius: 50%;
}

.slip__pin[b-edb5xyj9ow] {
    position: absolute;
    top: -9px; left: 50%;
    width: 16px; height: 16px;
    transform: translateX(-50%);
    border-radius: 50%;
    background: radial-gradient(circle at 35% 30%, var(--brass-light), var(--brass) 55%, var(--brass-dark));
    box-shadow: 0 2px 4px rgba(0,0,0,0.4);
    z-index: 2;
}

.slip__eyebrow[b-edb5xyj9ow] {
    font-family: 'Hanken Grotesk', sans-serif;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 0.68rem;
    font-weight: 700;
    color: var(--brass-dark);
}

.slip__chore[b-edb5xyj9ow] {
    font-family: 'Caveat', cursive;
    font-size: 2.1rem;
    font-weight: 700;
    line-height: 1.05;
    color: var(--ink);
}

.slip__desc[b-edb5xyj9ow] {
    font-family: 'Caveat', cursive;
    font-size: 1.35rem;
    color: var(--ink-soft);
    line-height: 1.1;
}

.slip__note[b-edb5xyj9ow] {
    font-family: 'Hanken Grotesk', sans-serif;
    font-size: 0.8rem;
    color: var(--ink-faint);
    margin-top: 0.2rem;
}

/* ---- the wooden cabinet / drawer ---- */

.cabinet[b-edb5xyj9ow] {
    position: relative;
    z-index: 2;
    width: 320px;
    height: 214px;
    padding: 0;
    border: none;
    border-radius: 12px;
    overflow: hidden;
    cursor: pointer;
    background:
        repeating-linear-gradient(92deg, rgba(0,0,0,0.06) 0 3px, rgba(255,255,255,0.025) 3px 7px),
        linear-gradient(165deg, var(--walnut-light), var(--walnut) 55%, var(--walnut-dark));
    box-shadow:
        inset 0 2px 0 rgba(255,255,255,0.15),
        var(--shadow-deep);
    transition: transform 0.45s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.45s ease;
}

.cabinet__top[b-edb5xyj9ow] {
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 14px;
    background: linear-gradient(180deg, rgba(255,255,255,0.18), rgba(0,0,0,0.05));
    border-bottom: 1px solid rgba(0,0,0,0.25);
}

/* the dark slot the slip emerges from */
.cabinet__slot[b-edb5xyj9ow] {
    position: absolute;
    top: 22px; left: 26px; right: 26px;
    height: 10px;
    border-radius: 6px;
    background: linear-gradient(180deg, var(--walnut-dark), #1f130a);
    box-shadow: inset 0 3px 5px rgba(0,0,0,0.7);
}

/* the pull-out drawer face */
.drawer-front[b-edb5xyj9ow] {
    position: absolute;
    left: 14px; right: 14px; bottom: 14px;
    height: 150px;
    border-radius: 10px;
    background:
        repeating-linear-gradient(90deg, rgba(0,0,0,0.05) 0 4px, rgba(255,255,255,0.03) 4px 9px),
        linear-gradient(180deg, var(--walnut-light), var(--walnut) 70%, var(--walnut-dark));
    border: 1px solid rgba(0,0,0,0.3);
    box-shadow:
        inset 0 2px 0 rgba(255,255,255,0.2),
        inset 0 -10px 18px -8px rgba(0,0,0,0.5);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 14px;
    transform-origin: bottom center;
    transition: transform 0.5s cubic-bezier(0.34, 1.3, 0.5, 1);
}

.drawer-front__plate[b-edb5xyj9ow] {
    font-family: 'Fraunces', serif;
    font-weight: 600;
    letter-spacing: 0.32em;
    font-size: 0.82rem;
    color: #2a1c0e;
    padding: 0.2rem 0.9rem;
    border-radius: 4px;
    background: linear-gradient(180deg, var(--brass-light), var(--brass));
    border: 1px solid var(--brass-dark);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.5), 0 1px 2px rgba(0,0,0,0.3);
    text-indent: 0.32em;
}

.drawer-pull[b-edb5xyj9ow] {
    width: 84px;
    height: 26px;
    border-radius: 0 0 40px 40px / 0 0 26px 26px;
    background: linear-gradient(180deg, var(--brass-light), var(--brass) 50%, var(--brass-dark));
    border: 1px solid var(--brass-dark);
    box-shadow:
        inset 0 2px 2px rgba(255,255,255,0.5),
        0 4px 8px -2px rgba(0,0,0,0.5);
}

/* hover affordance on the closed drawer */
.cabinet-scene.is-closed .cabinet:hover[b-edb5xyj9ow] {
    transform: translateY(2px);
    box-shadow: inset 0 2px 0 rgba(255,255,255,0.15), 0 30px 64px -22px rgba(40,24,12,0.7);
}
.cabinet-scene.is-closed .cabinet:hover .drawer-front[b-edb5xyj9ow] {
    transform: translateY(4px);
}

/* open state: drawer slides down + tilts as if pulled out */
.cabinet-scene.is-open .cabinet[b-edb5xyj9ow] {
    transform: translateY(6px);
    box-shadow: inset 0 2px 0 rgba(255,255,255,0.12), 0 34px 70px -22px rgba(40,24,12,0.72);
}
.cabinet-scene.is-open .drawer-front[b-edb5xyj9ow] {
    transform: translateY(120px) rotateX(34deg);
}

/* ---- actions ---- */

.draw-actions[b-edb5xyj9ow] {
    margin-top: 1.5rem;
    display: flex;
    gap: 0.75rem;
    justify-content: center;
    flex-wrap: wrap;
    min-height: 3rem;
}

.draw-hint[b-edb5xyj9ow] {
    font-family: 'Fraunces', serif;
    font-style: italic;
    color: var(--ink-faint);
    margin: 0.6rem 0 0;
}

@keyframes slip-bob-b-edb5xyj9ow {
    0%, 100% { transform: translateX(-50%) translateY(-168px) rotate(-1.6deg); }
    50%      { transform: translateX(-50%) translateY(-174px) rotate(-1.1deg); }
}

@media (prefers-reduced-motion: reduce) {
    .slip[b-edb5xyj9ow], .cabinet[b-edb5xyj9ow], .drawer-front[b-edb5xyj9ow] { transition: opacity 0.2s ease; }
    .cabinet-scene.is-open .slip[b-edb5xyj9ow] {
        transform: translateX(-50%) translateY(-168px) rotate(-1.6deg);
        animation: none;
    }
    .cabinet-scene.is-open .drawer-front[b-edb5xyj9ow] { transform: translateY(120px); }
    .wall-slip[b-edb5xyj9ow] { animation: none; }
}
