@font-face {
    font-family: "Alegreya Sans";
    font-style: normal;
    font-display: swap;
    font-weight: 400;
    src: url("../fonts/alegreya-sans-latin-400-normal.woff2") format("woff2");
}
@font-face {
    font-family: "Alegreya Sans";
    font-style: normal;
    font-display: swap;
    font-weight: 700;
    src: url("../fonts/alegreya-sans-latin-700-normal.woff2") format("woff2");
}

:root {
    color-scheme: light dark;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    background: #f7f4ee;
    color: #2d2926;
}

/* Stable, progressive carousel: mounted slides remain loaded and only visual state changes. */
body.media-carousel-open{overflow:hidden}.golden-detail{gap:.75rem}.golden-detail>header{margin-bottom:.25rem}.golden-detail>section{margin:.65rem 0;padding:1.25rem}.golden-detail .golden-media-section{padding:1.25rem}.golden-media-section .section-heading{margin-bottom:1.25rem}.media-carousel{gap:0}.media-carousel__panel{position:relative;display:grid;gap:.75rem;width:100%}.media-carousel__stage{position:relative;display:block;width:100%;height:clamp(260px,56vw,580px);min-height:0;contain:layout paint;border-radius:16px;background:#111}.media-carousel__slide{position:absolute;inset:0;display:grid;place-items:center;width:100%;height:100%;opacity:0;visibility:hidden;pointer-events:none;animation:none;transition:opacity 220ms ease,transform 220ms cubic-bezier(.2,.7,.2,1),visibility 0s linear 220ms;will-change:opacity,transform}.media-carousel.moves-forward .media-carousel__slide{transform:translate3d(-8px,0,0)}.media-carousel.moves-backward .media-carousel__slide{transform:translate3d(8px,0,0)}.media-carousel__slide.is-active{z-index:1;opacity:1;visibility:visible;pointer-events:auto;transform:translate3d(0,0,0);transition-delay:0s}.media-carousel__photo,.media-carousel__video{display:grid;place-items:center;width:100%;height:100%;padding:0;border:0;background:transparent}.media-carousel__photo{cursor:zoom-in}.media-carousel__slide img,.media-carousel__slide video{display:block;width:100%;height:100%;max-height:none;object-fit:contain}.media-carousel__footer{display:grid;gap:.5rem}.media-carousel__expand{position:absolute;top:.75rem;right:.75rem;z-index:4;display:grid;place-items:center;width:44px;height:44px;border:0;border-radius:999px;background:#000a;color:#fff;cursor:pointer}.media-carousel__nav{z-index:4}.media-carousel__backdrop{position:fixed;inset:0;z-index:0;width:100%;height:100%;border:0;background:#050505f2}.media-carousel.is-fullscreen{position:fixed;inset:0;z-index:1800;display:grid;place-items:center;padding:clamp(.5rem,2vw,1.5rem);background:#050505f2}.media-carousel.is-fullscreen .media-carousel__panel{z-index:1;width:min(100%,1400px);height:100%;grid-template-rows:minmax(0,1fr) auto}.media-carousel.is-fullscreen .media-carousel__stage{height:100%;border-radius:12px}.media-carousel.is-fullscreen .media-carousel__footer{color:#fff}.media-carousel.is-fullscreen .media-carousel__counter{color:#fff}.media-carousel.is-fullscreen .media-carousel__photo{cursor:default}.media-carousel__close{position:fixed;top:max(.75rem,env(safe-area-inset-top));right:max(.75rem,env(safe-area-inset-right));z-index:6;width:48px;height:48px;border:0;border-radius:999px;background:#000b;color:#fff;font-size:2rem;line-height:1;cursor:pointer}
@media(max-width:600px){.golden-detail{gap:.5rem}.golden-detail>section,.golden-detail .golden-media-section{margin:.4rem 0;padding:1rem}.golden-media-section .section-heading{margin-bottom:1rem}.media-carousel__stage{height:clamp(220px,72vw,420px)}.media-carousel.is-fullscreen{padding:max(.4rem,env(safe-area-inset-top)) .4rem max(.4rem,env(safe-area-inset-bottom))}.media-carousel.is-fullscreen .media-carousel__panel{grid-template-rows:minmax(0,1fr) auto}.media-carousel.is-fullscreen .media-carousel__stage{height:100%}}
@media(prefers-reduced-motion:reduce){.media-carousel__slide{transition:none;transform:none!important}}

/* Final Chat authority: intentionally last so legacy phase styles cannot override it. */
.chat-page { gap: .75rem; }
.chat-tools { margin: 0; }
.chat-list { height: min(60dvh,640px); overflow-y: auto; padding: .75rem; border-radius: 14px 14px 0 0; scrollbar-gutter: stable; }
.chat-message { max-width: 78%; margin: .35rem 0; padding: .55rem .7rem; border-radius: .9rem .9rem .9rem .2rem; }
.chat-message.mine { margin-left: auto; border-radius: .9rem .9rem .2rem .9rem; }
.chat-message footer { gap: .15rem; margin-top: .25rem; }
.chat-message footer .mud-icon-button { width: 34px; height: 34px; padding: 5px; }
.chat-photo { display: block; width: 100%; max-height: 360px; object-fit: contain; border-radius: .75rem; background: #111; }
.chat-composer { position: sticky; bottom: 0; z-index: 5; display: grid; gap: .45rem; margin-top: -.75rem; padding: .65rem; border: 1px solid var(--mud-palette-lines-default); border-radius: 0 0 14px 14px; background: var(--mud-palette-surface); box-shadow: 0 -8px 24px #0001; }
.chat-compose-row { display: flex; align-items: flex-end; gap: .35rem; }
.chat-textarea { flex: 1; min-width: 0; min-height: 42px; max-height: 144px; resize: none; overflow-y: auto; padding: .65rem .85rem; border: 1px solid var(--mud-palette-lines-default); border-radius: 20px; outline: 0; background: var(--mud-palette-background); color: var(--mud-palette-text-primary); font: inherit; line-height: 1.35; }
.chat-textarea:focus { border-color: var(--mud-palette-primary); box-shadow: 0 0 0 2px color-mix(in srgb,var(--mud-palette-primary) 20%,transparent); }
.chat-icon-button { position: relative; display: grid; place-items: center; flex: 0 0 42px; width: 42px; height: 42px; border-radius: 50%; color: var(--mud-palette-text-secondary); cursor: pointer; }
.chat-icon-button.is-disabled { opacity: .45; pointer-events: none; }
.chat-file-input { position: absolute; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.composer-shortcuts { display: flex; align-items: center; gap: .3rem; min-width: 0; min-height: 28px; padding-inline-end: .75rem; }
.composer-shortcuts button { border: 0; border-radius: 999px; padding: .2rem .4rem; background: var(--mud-palette-background-gray); cursor: pointer; }
.composer-hint { margin-inline-start: auto; margin-inline-end: .25rem; color: var(--mud-palette-text-secondary); font-size: .72rem; white-space: nowrap; }
.chat-photo-preview { position: relative; width: 112px; height: 88px; overflow: hidden; border-radius: 10px; background: #111; }
.chat-photo-preview img { width: 100%; height: 100%; object-fit: cover; }
.chat-photo-preview .mud-icon-button { position: absolute; top: 2px; right: 2px; color: #fff; background: #0009; }
@media(max-width:600px){.chat-list{height:58dvh;padding:.45rem}.chat-message{max-width:92%}.composer-hint{display:none}}

/* Shared detail rhythm */
:root { --detail-gap: clamp(.75rem, 1.8vw, 1.15rem); --detail-padding: clamp(1rem, 2.5vw, 1.35rem); }
.recipe-detail, .memory-detail, .golden-detail, .detail-page { gap: var(--detail-gap); }
.recipe-detail > header, .memory-detail > header, .golden-detail > header, .detail-page > header { margin: 0; }
.recipe-detail > section, .memory-detail > section, .golden-detail > section,
.detail-page .profile-section, .detail-page .birthday-card { margin: 0; padding: var(--detail-padding); }
.recipe-detail > section, .memory-detail > section, .golden-detail > section { border-radius: 16px; background: var(--mud-palette-surface); }
.recipe-detail > section > :first-child, .memory-detail > section > :first-child, .golden-detail > section > :first-child,
.detail-page .profile-section > :first-child { margin-top: 0; }
.recipe-detail > section > :last-child, .memory-detail > section > :last-child, .golden-detail > section > :last-child,
.detail-page .profile-section > :last-child { margin-bottom: 0; }
.golden-detail .golden-media-section { padding: var(--detail-padding); }
.golden-media-section .section-heading { margin-bottom: var(--detail-gap); }
.admin-recipe-panel { width: 100%; margin: 0; }
.recipes-page > header { margin-bottom: 0; }
.meeting-hero .eyebrow, .meeting-hero .eyebrow--inverse { color: #fff; text-shadow: 0 1px 2px #0008; }

/* Authoritative carousel layout: media remains fully visible at every aspect ratio. */
body.media-carousel-open { overflow: hidden; }
.media-carousel { display: grid; gap: 0; outline: none; }
.media-carousel__panel { position: relative; display: grid; gap: .75rem; width: 100%; min-height: 0; }
.media-carousel__stage { position: relative; display: block; width: 100%; height: clamp(260px,56vw,580px); min-height: 0; overflow: hidden; contain: layout paint; border-radius: 16px; background: #111; }
.media-carousel__slide { position: absolute; inset: 0; display: grid; place-items: center; width: 100%; height: 100%; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 220ms ease, transform 220ms cubic-bezier(.2,.7,.2,1), visibility 0s linear 220ms; }
.media-carousel.moves-forward .media-carousel__slide { transform: translate3d(-8px,0,0); }
.media-carousel.moves-backward .media-carousel__slide { transform: translate3d(8px,0,0); }
.media-carousel__slide.is-active { z-index: 1; opacity: 1; visibility: visible; pointer-events: auto; transform: translate3d(0,0,0); transition-delay: 0s; }
.media-carousel__photo, .media-carousel__video { display: grid; place-items: center; width: 100%; height: 100%; min-width: 0; min-height: 0; padding: 0; border: 0; background: transparent; overflow: hidden; }
.media-carousel__photo img { display: block; width: 100%; height: 100%; object-fit: contain; }
.media-carousel__video video { display: block; width: auto; height: auto; max-width: 100%; max-height: 100%; object-fit: contain; }
.media-carousel.is-fullscreen { position: fixed; inset: 0; z-index: 1800; display: grid; place-items: center; height: 100dvh; padding: max(.75rem,env(safe-area-inset-top)) max(.75rem,env(safe-area-inset-right)) max(.75rem,env(safe-area-inset-bottom)) max(.75rem,env(safe-area-inset-left)); background: #050505f2; }
.media-carousel.is-fullscreen .media-carousel__panel { z-index: 1; width: min(100%,1400px); height: 100%; max-height: calc(100dvh - max(1.5rem, env(safe-area-inset-top) + env(safe-area-inset-bottom))); grid-template-rows: minmax(0,1fr) auto; overflow: hidden; }
.media-carousel.is-fullscreen .media-carousel__stage { height: 100%; min-height: 0; border-radius: 12px; }
.media-carousel.is-fullscreen .media-carousel__footer, .media-carousel.is-fullscreen .media-carousel__counter { color: #fff; }

/* Compact message flow and WhatsApp-like composer. */
.chat-page { gap: .75rem; }
.chat-tools { margin: 0; }
.chat-list { height: min(60dvh,640px); padding: .75rem; border-radius: 14px 14px 0 0; }
.chat-message { margin: .35rem 0; padding: .55rem .7rem; border-radius: .9rem .9rem .9rem .2rem; }
.chat-message.mine { border-radius: .9rem .9rem .2rem .9rem; }
.chat-message header { gap: .45rem; }
.chat-message footer { gap: .15rem; margin-top: .25rem; }
.chat-message footer .mud-icon-button { width: 34px; height: 34px; padding: 5px; }
.chat-reactions { gap: .2rem; }
.chat-reactions button { padding: .2rem .45rem; }
.chat-photo { max-height: 360px; object-fit: contain; background: #111; }
.chat-composer { position: sticky; bottom: 0; z-index: 5; display: grid; gap: .45rem; margin-top: -.75rem; padding: .65rem; border: 1px solid var(--mud-palette-lines-default); border-radius: 0 0 14px 14px; background: var(--mud-palette-surface); box-shadow: 0 -8px 24px #0001; }
.chat-compose-row { display: flex; align-items: flex-end; gap: .35rem; }
.chat-textarea { flex: 1; min-width: 0; min-height: 42px; max-height: 144px; resize: none; overflow-y: auto; padding: .65rem .85rem; border: 1px solid var(--mud-palette-lines-default); border-radius: 20px; outline: 0; background: var(--mud-palette-background); color: var(--mud-palette-text-primary); font: inherit; line-height: 1.35; }
.chat-textarea:focus { border-color: var(--mud-palette-primary); box-shadow: 0 0 0 2px color-mix(in srgb,var(--mud-palette-primary) 20%,transparent); }
.chat-icon-button { position: relative; display: grid; place-items: center; flex: 0 0 42px; width: 42px; height: 42px; border-radius: 50%; color: var(--mud-palette-text-secondary); cursor: pointer; }
.chat-icon-button.is-disabled { opacity: .45; pointer-events: none; }
.chat-file-input { position: absolute; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.composer-shortcuts { display: flex; align-items: center; gap: .3rem; min-height: 28px; }
.composer-shortcuts button { border: 0; border-radius: 999px; padding: .2rem .4rem; background: var(--mud-palette-background-gray); cursor: pointer; }
.composer-hint { margin-left: auto; color: var(--mud-palette-text-secondary); font-size: .72rem; }
.composer-status { display: inline-flex; align-items: center; gap: .35rem; color: var(--mud-palette-text-secondary); font-size: .78rem; }
.reply-preview { display: flex; align-items: center; justify-content: space-between; gap: .5rem; }
.chat-photo-preview { position: relative; width: 112px; height: 88px; overflow: hidden; border-radius: 10px; background: #111; }
.chat-photo-preview img { width: 100%; height: 100%; object-fit: cover; }
.chat-photo-preview .mud-icon-button { position: absolute; top: 2px; right: 2px; color: #fff; background: #0009; }

@media(max-width:600px) {
    :root { --detail-gap: .7rem; --detail-padding: 1rem; }
    .media-carousel__stage { height: clamp(220px,72vw,420px); }
    .media-carousel.is-fullscreen { padding: max(.4rem,env(safe-area-inset-top)) .4rem max(.4rem,env(safe-area-inset-bottom)); }
    .media-carousel.is-fullscreen .media-carousel__panel { max-height: calc(100dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom) - .8rem); }
    .chat-list { height: 58dvh; padding: .45rem; }
    .chat-message { max-width: 92%; }
    .composer-hint { display: none; }
}

/* La Mesa */
.chat-page{max-width:900px}.chat-title,.chat-toolbar,.composer-actions,.chat-message header,.chat-message footer,.chat-channels{display:flex;align-items:center;gap:.65rem}.chat-title{justify-content:space-between}.connection-state{font-size:.8rem;color:var(--mud-palette-success)}.chat-channels{padding:.5rem 0;overflow:auto}.chat-channels button{border:1px solid var(--mud-palette-lines-default);background:var(--mud-palette-surface);border-radius:999px;padding:.65rem 1rem;white-space:nowrap}.chat-channels button.selected{background:var(--mud-palette-primary);color:var(--mud-palette-primary-text)}.chat-toolbar{align-items:flex-end;flex-wrap:wrap;padding:.75rem 0}.chat-toolbar>*{min-width:145px;flex:1}.chat-list{height:min(58vh,620px);overflow-y:auto;padding:1rem;background:color-mix(in srgb,var(--mud-palette-background) 75%,transparent);border-radius:1rem;scrollbar-gutter:stable}.chat-message{max-width:78%;margin:.8rem 0;padding:.85rem 1rem;border-radius:1rem 1rem 1rem .25rem;background:var(--mud-palette-surface);box-shadow:0 2px 10px rgb(0 0 0/.06)}.chat-message.mine{margin-left:auto;border-radius:1rem 1rem .25rem 1rem;background:color-mix(in srgb,var(--mud-palette-primary) 12%,var(--mud-palette-surface))}.chat-message header time,.chat-message header small{font-size:.72rem;color:var(--mud-palette-text-secondary)}.chat-message p{white-space:pre-wrap;overflow-wrap:anywhere}.chat-photo{display:block;width:100%;max-height:340px;object-fit:cover;border-radius:.75rem}.chat-reactions{display:flex;gap:.3rem;flex-wrap:wrap}.chat-reactions button,.chat-message footer button,.composer-actions>button,.load-older,.new-message-indicator{border:0;border-radius:999px;padding:.35rem .65rem;background:var(--mud-palette-background-gray);color:inherit}.chat-reactions button.selected{outline:2px solid var(--mud-palette-primary)}.chat-message footer{margin-top:.6rem;flex-wrap:wrap}.chat-message.tombstone{opacity:.75;border:1px dashed var(--mud-palette-lines-default)}.chat-reply-context,.reply-preview{padding:.45rem .65rem;border-left:3px solid var(--mud-palette-primary);background:var(--mud-palette-background);font-size:.85rem}.chat-mentions{display:flex;gap:.3rem;flex-wrap:wrap}.chat-mentions span{color:var(--mud-palette-primary)}.chat-composer{position:relative;padding:1rem 0}.composer-actions{justify-content:flex-end;margin-top:.5rem}.new-message-indicator{position:sticky;display:block;bottom:1rem;margin:-3rem auto 1rem;background:var(--mud-palette-primary);color:var(--mud-palette-primary-text);z-index:2}
@media(max-width:600px){.chat-message{max-width:92%}.chat-list{height:55vh;padding:.5rem}.chat-toolbar{display:grid;grid-template-columns:1fr 1fr}.chat-toolbar>*{min-width:0}.chat-title h1{font-size:1.75rem}}

.media-carousel{display:grid;gap:.75rem;outline:none}.media-carousel:focus-visible{outline:3px solid var(--mud-palette-primary);outline-offset:4px;border-radius:16px}.media-carousel__stage{position:relative;display:grid;place-items:center;min-height:220px;overflow:hidden;border-radius:16px;background:#111}.media-carousel__slide{display:grid;place-items:center;width:100%;animation:media-crossfade 180ms ease-out}.media-carousel__slide img,.media-carousel__slide video{display:block;width:100%;max-height:70vh;object-fit:contain}.media-carousel__nav{position:absolute;top:50%;translate:0 -50%;z-index:2;width:44px;height:56px;border:0;border-radius:999px;background:#0009;color:#fff;font-size:2rem;cursor:pointer}.media-carousel__nav--previous{left:.5rem}.media-carousel__nav--next{right:.5rem}.media-carousel__counter{margin:0;text-align:center;color:var(--mud-palette-text-secondary)}.media-carousel__thumbnails{display:flex;gap:.5rem;overflow-x:auto;padding:.25rem;scroll-snap-type:x proximity}.media-carousel__thumbnail{flex:0 0 76px;width:76px;height:76px;padding:0;overflow:hidden;border:2px solid transparent;border-radius:10px;background:#111;scroll-snap-align:start;cursor:pointer}.media-carousel__thumbnail.is-active{border-color:var(--mud-palette-primary)}.media-carousel__thumbnail img,.media-carousel__thumbnail .video-thumb{width:100%;height:100%;aspect-ratio:1;object-fit:cover}@keyframes media-crossfade{from{opacity:.25}to{opacity:1}}@media(prefers-reduced-motion:reduce){.media-carousel__slide{animation:none}.media-carousel__thumbnails{scroll-behavior:auto}}@media(max-width:600px){.media-carousel__stage{min-height:180px}.media-carousel__nav{width:44px;height:48px}.media-carousel__thumbnail{flex-basis:64px;width:64px;height:64px}}

.phase6-toolbar{display:grid;grid-template-columns:minmax(220px,2fr) repeat(3,minmax(140px,1fr));gap:1rem;align-items:center;margin:1.5rem 0}.phase6-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1rem}.phase6-list{display:grid;gap:.75rem}.memory-card,.recipe-card,.album-card{display:block;overflow:hidden;color:inherit;text-decoration:none;background:var(--mud-palette-surface);border-radius:18px;box-shadow:0 8px 28px #0001}.memory-card img,.recipe-card img,.recipe-placeholder{width:100%;aspect-ratio:4/3;object-fit:cover}.memory-card>div,.recipe-card>div,.album-card{padding:1rem}.memory-card span{display:block;color:var(--mud-palette-text-secondary);margin-top:.35rem}.phase6-list .memory-card{display:grid;grid-template-columns:140px 1fr}.phase6-list .memory-card img{height:100%;aspect-ratio:1}.recipe-placeholder{display:grid;place-items:center;font-size:4rem;background:#c58b5a22}.recipe-card h2{margin:.65rem 0 .25rem}.upload-panel{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding:1rem;margin:1rem 0;border:1px dashed var(--mud-palette-lines-default);border-radius:16px}.memory-detail,.recipe-detail{max-width:920px}.memory-hero{display:block;width:100%;padding:0;border:0;background:#111;border-radius:18px;overflow:hidden}.memory-hero img,.memory-hero video{display:block;width:100%;max-height:72vh;object-fit:contain}.recipe-detail>section,.memory-detail>section{margin:1.5rem 0;padding:1.25rem;border-radius:16px;background:var(--mud-palette-surface)}.ingredient-list li,.preparation-list li{margin:.75rem 0;line-height:1.6}.preparation-list img{max-width:320px;border-radius:12px}.rating-buttons{display:flex}.rating-buttons .mud-icon-button{min-width:44px;min-height:44px}.meeting-link{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 0;border-bottom:1px solid var(--mud-palette-lines-default)}
@media(max-width:760px){.phase6-toolbar{grid-template-columns:1fr}.phase6-list .memory-card{grid-template-columns:100px 1fr}.phase6-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.upload-panel>*{width:100%}.meeting-link{align-items:flex-start;flex-direction:column}}

.golden-filters{display:grid;grid-template-columns:1fr;gap:1rem;margin:1.5rem 0}.golden-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem}.golden-card{overflow:hidden;border-radius:20px;background:var(--mud-palette-surface);box-shadow:0 8px 28px #0001}.golden-card>img,.golden-placeholder{width:100%;height:190px;object-fit:cover}.golden-placeholder{display:grid;place-items:center;font-size:4rem;background:#c58b5a22}.golden-card>div{padding:1.25rem}.golden-card .mud-button{margin-top:.75rem}.golden-detail{max-width:980px}.golden-detail>section{margin:2rem 0;padding:1.5rem;border-radius:18px;background:var(--mud-palette-surface)}.golden-detail .chronicle{font-family:Georgia,serif;font-size:1.15rem;line-height:1.8;white-space:pre-line}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem}.media-card{border:0;padding:0;border-radius:12px;overflow:hidden;cursor:pointer;background:#111}.media-card img,.video-thumb{display:block;width:100%;aspect-ratio:1;object-fit:cover}.video-thumb{display:grid;place-items:center;color:white}.media-viewer{position:fixed;inset:0;z-index:1500;background:#000e;display:grid;place-items:center}.media-viewer img,.media-viewer video{max-width:92vw;max-height:88vh}.media-viewer button{position:absolute;right:1rem;top:1rem;font-size:2rem;color:white;background:transparent;border:0}.golden-quote{border-left:4px solid #c58b5a;margin:1rem 0;padding:.75rem 1.25rem}.golden-quote>span{color:#b06f30}.reaction-bar,.participant-list,.menu-pills,.inline-form{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.participant-list span,.golden-comment{padding:.75rem 1rem;border-radius:999px;background:#c58b5a18}.golden-comment{border-radius:12px;margin:.75rem 0}.section-heading{display:flex;justify-content:space-between;align-items:center;gap:1rem}@media(min-width:720px){.golden-filters{grid-template-columns:repeat(4,minmax(0,1fr))}.golden-filter-search,.golden-filter-dish{grid-column:span 2}}@media(max-width:600px){.golden-detail>section{padding:1rem}.section-heading{align-items:flex-start;flex-direction:column}.golden-card>img,.golden-placeholder{height:160px}}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    min-width: 320px;
    min-height: 100vh;
    background: var(--mud-palette-background);
    color: var(--mud-palette-text-primary);
}

.app-shell {
    min-height: calc(100dvh - 64px);
    padding: 24px;
}

.login-page {
    min-height: calc(100dvh - 48px);
    display: grid;
    place-items: center;
}

.content-page {
    width: min(100%, 1180px);
    margin: 0 auto;
    display: grid;
    gap: 24px;
}

.page-heading {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 24px;
}

    .page-heading h1, .profile-header h1 {
        margin: 0;
    }

.eyebrow {
    margin: 0 0 4px;
    color: var(--mud-palette-primary);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .12em;
    font-size: .78rem;   
}

.eyebrow--inverse { color: var(--mud-palette-white); }

.member-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(235px, 1fr));
    gap: 18px;
}

.member-card {
    height: 100%;
    border-radius: 18px;
}

    .member-card .mud-card-content {
        display: grid;
        gap: 10px;
    }

    .member-card h2 {
        margin: 4px 0 0;
        font-size: 1.25rem;
    }

    .member-card p {
        margin: 0;
        color: var(--mud-palette-text-secondary);
    }

.stat-line {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    font-size: .9rem;
}

.member-avatar {
    flex: none;
    display: grid;
    place-items: center;
    overflow: hidden;
    border-radius: 50%;
    background: var(--mud-palette-primary);
    color: var(--mud-palette-primary-text);
    font-weight: 800;
}

    .member-avatar img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

.profile-header {
    display: flex;
    align-items: center;
    gap: 22px;
    padding-block: 12px;
}

    .profile-header p {
        margin: 6px 0 0;
        color: var(--mud-palette-text-secondary);
    }

.profile-section, .birthday-card {
    padding: clamp(18px, 4vw, 28px);
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 18px;
}

    .profile-section h2 {
        margin-top: 0;
    }

.birthday-card {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    background: color-mix(in srgb, var(--mud-palette-primary) 9%, transparent);
}

.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 16px;
}

    .stats-grid span {
        display: grid;
        gap: 2px;
    }

    .stats-grid strong {
        font-size: 1.6rem;
        color: var(--mud-palette-primary);
    }

.corner-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 2fr) minmax(260px, 1fr);
    align-items: start;
}

    .corner-grid > :first-child {
        grid-row: span 3;
    }

.avatar-editor, .member-cell {
    display: flex;
    align-items: center;
    gap: 16px;
}

.avatar-editor {
    margin-bottom: 22px;
}

.avatar-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}

.avatar-upload-button {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-radius: 8px;
    background: var(--mud-palette-primary);
    color: var(--mud-palette-primary-text);
    cursor: pointer;
    font-weight: 700;
}

    .avatar-upload-button:focus-within {
        outline: 3px solid var(--mud-palette-info);
        outline-offset: 2px;
    }

.avatar-file-input {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    opacity: 0;
}

.form-grid {
    display: grid;
    gap: 16px;
}

.admin-form {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.form-actions, .admin-filters {
    display: flex;
    gap: 12px;
    align-items: center;
}

    .admin-filters > * {
        min-width: 230px;
    }

.admin-create, .edit-panel {
    margin-bottom: 8px;
}

.muted {
    color: var(--mud-palette-text-secondary);
}

.empty-state {
    padding: 44px 20px;
    text-align: center;
    color: var(--mud-palette-text-secondary);
}

.session-bar {
    min-height: 56px;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 8px 20px;
    border-bottom: 1px solid color-mix(in srgb, currentColor 20%, transparent);
}

.session-brand {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: inherit;
    text-decoration: none;
    font-weight: 750;
}

    .session-brand img {
        width: 44px;
        height: 44px;
        object-fit: contain;
    }

.session-greeting {
    justify-self: start;
}

.session-bar nav {
    display: flex;
    align-items: center;
    gap: 14px;
}

.session-bar a, .session-bar button {
    color: inherit;
    font: inherit;
}

.session-bar button {
    min-height: 44px;
    border: 0;
    background: transparent;
    cursor: pointer;
}

.auth-card {
    width: min(100%, 430px);
    padding: clamp(24px, 6vw, 44px);
    border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
    border-radius: 20px;
    background: color-mix(in srgb, Canvas 96%, transparent);
    box-shadow: 0 18px 60px rgba(45, 41, 38, 0.12);
}

    .auth-card h1, .auth-slogan {
        text-align: center;
    }

.auth-logo {
    width: 112px;
    height: 112px;
    display: block;
    object-fit: contain;
    margin: 0 auto 18px;
}

.auth-slogan {
    margin: 0 0 28px;
    color: color-mix(in srgb, currentColor 72%, transparent);
}

.auth-form {
    display: grid;
    gap: 16px;
}

@media (max-width: 600px) {
    .session-bar {
        grid-template-columns: 1fr auto;
        align-items: center;
        padding: 8px 12px;
    }

    .session-brand span {
        display: none;
    }

    .session-greeting {
        justify-self: end;
        font-size: .9rem;
    }

    .session-bar nav {
        grid-column: 1 / -1;
        width: 100%;
        justify-content: space-between;
        gap: 8px;
        overflow-x: auto;
        padding-top: 6px;
    }

        .session-bar nav a, .session-bar nav button {
            white-space: nowrap;
            min-height: 44px;
            display: inline-flex;
            align-items: center;
        }

    .app-shell {
        min-height: calc(100dvh - 108px);
        padding: 12px;
    }

    .login-page {
        min-height: calc(100dvh - 24px);
    }

    .auth-card {
        border: 0;
        box-shadow: none;
    }

    .page-heading, .profile-header, .birthday-card {
        align-items: flex-start;
        flex-direction: column;
    }

    .corner-grid {
        grid-template-columns: 1fr;
    }

        .corner-grid > :first-child {
            grid-row: auto;
        }

    .admin-form {
        grid-template-columns: 1fr;
    }

    .admin-filters {
        align-items: stretch;
        flex-direction: column;
    }

        .admin-filters > * {
            min-width: 0;
        }

    .avatar-editor {
        flex-direction: column;
        text-align: center;
    }

    .avatar-actions {
        width: 100%;
        align-items: stretch;
        flex-direction: column;
    }

        .avatar-upload-button, .avatar-actions .mud-button-root, .profile-save {
            width: 100%;
            justify-content: center;
            min-height: 44px;
        }

    .profile-section {
        padding: 18px 14px;
    }
}

@media (min-width: 601px) and (max-width: 959px) {
    .corner-grid {
        grid-template-columns: 1fr;
    }

        .corner-grid > :first-child {
            grid-row: auto;
        }
}

.foundation-state {
    width: min(100%, 640px);
    padding: 32px;
    border-left: 4px solid #6f1d2a;
}

.home-logo {
    width: clamp(96px, 18vw, 150px);
    height: auto;
    display: block;
    margin-bottom: 20px;
}

/* Phase 11: Home and installed-app experience */
.home-page{max-width:1120px;margin:0 auto;padding:.5rem 0 2rem}.home-welcome{padding:1.4rem 1.1rem 1rem}.home-welcome p{margin:0 0 .35rem;color:var(--mud-palette-primary);font-weight:700}.home-welcome h1{margin:0;font-family:Georgia,serif;font-size:clamp(1.75rem,5vw,3.2rem);line-height:1.08}.home-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.home-card{background:var(--mud-palette-surface);border:1px solid var(--mud-palette-lines-default);border-radius:18px;padding:1rem;box-shadow:0 8px 28px rgb(45 41 38 / 7%);min-width:0}.home-card h2{display:flex;align-items:center;gap:.45rem;margin:0 0 .85rem;font-size:1.12rem}.home-card p{margin:.35rem 0}.home-emphasis{font-weight:750;font-size:1.05rem;text-transform:capitalize}.home-card-actions{display:flex;align-items:center;flex-wrap:wrap;gap:.45rem;margin-top:.8rem}.attendance-pill{display:inline-flex;align-items:center;min-height:44px;padding:.55rem .8rem;border-radius:999px;font-weight:700}.attendance-pill.confirmed{color:var(--mud-palette-success-darken);background:color-mix(in srgb,var(--mud-palette-success) 15%,transparent)}.attendance-pill.declined{color:var(--mud-palette-error);background:color-mix(in srgb,var(--mud-palette-error) 12%,transparent)}.home-empty,.home-meta{color:var(--mud-palette-text-secondary)}.home-menu-image{width:100%;height:145px;object-fit:cover;border-radius:12px}.home-menu ul{padding-left:1.25rem}.home-memory-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem}.home-memory-grid a{aspect-ratio:1;display:block;overflow:hidden;border-radius:10px}.home-memory-image{width:100%;height:100%;object-fit:cover}.home-plain-list,.home-timeline{list-style:none;padding:0;margin:0}.home-plain-list li{display:flex;justify-content:space-between;gap:1rem;padding:.55rem 0;border-bottom:1px solid var(--mud-palette-lines-default)}.home-plain-list span,.home-timeline time{color:var(--mud-palette-text-secondary);font-size:.86rem}.home-timeline li{display:flex;flex-direction:column;gap:.15rem;padding:.5rem 0 .5rem 1rem;border-left:2px solid var(--mud-palette-primary)}.home-quick>div{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem}.home-quick a{display:flex;align-items:center;gap:.5rem;min-height:52px;padding:.65rem;border:1px solid var(--mud-palette-lines-default);border-radius:12px;font-weight:700}.material-symbol{font-family:'Material Icons';font-size:1.35rem;color:var(--mud-palette-primary)}.home-loading,.home-error{min-height:50vh;display:grid;place-content:center;text-align:center;gap:.75rem}.connection-banner{position:sticky;top:0;z-index:1301;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.55rem 1rem;color:#fff;background:#6b4d2e}.install-banner{position:fixed;z-index:1300;right:1rem;bottom:1rem;max-width:420px;display:flex;align-items:center;gap:.7rem;padding:.8rem;background:var(--mud-palette-surface);border:1px solid var(--mud-palette-lines-default);border-radius:15px;box-shadow:0 10px 40px rgb(0 0 0 / 20%)}.install-banner div{display:flex;flex:1;flex-direction:column}.install-banner span{font-size:.86rem;color:var(--mud-palette-text-secondary)}
@media(max-width:700px){.home-page{padding:0 .75rem 5rem}.home-welcome{padding:1.1rem .25rem}.home-grid{grid-template-columns:1fr;gap:.75rem}.home-meeting{order:1}.home-menu{order:2}.home-memories{order:3}.home-card{padding:.9rem}.install-banner{left:.65rem;right:.65rem;bottom:.65rem}.home-memory-grid{grid-template-columns:repeat(3,1fr)}}

.home-quick-grid{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:.6rem;width:100%;min-width:0}.home-quick-grid a{display:flex;align-items:center;gap:.5rem;min-width:0;width:100%;min-height:52px;padding:.65rem;border:1px solid var(--mud-palette-lines-default);border-radius:12px;font-weight:700;overflow:hidden}.home-quick-grid a .mud-icon-root{flex:0 0 auto;color:var(--mud-palette-primary)}.home-quick-grid a span{min-width:0;overflow-wrap:anywhere}@media(max-width:360px){.home-quick-grid{grid-template-columns:1fr!important}}

.foundation-state__eyebrow {
    margin: 0 0 12px;
    color: #6f1d2a;
    font-size: 0.875rem;
    font-weight: 700;
    letter-spacing: 0.14em;
}

.foundation-state h1 {
    margin: 0 0 16px;
    font-size: clamp(2rem, 8vw, 4rem);
    line-height: 1.05;
}

.foundation-state p:last-child {
    margin: 0;
    font-size: 1.125rem;
    line-height: 1.6;
}

.loading-state {
    margin: 20vh auto;
    text-align: center;
}

.storage-diagnostics {
    width: min(100%, 880px);
}

.upload-area {
    display: grid;
    gap: 16px;
    margin-block: 24px;
}

.upload-area__dropzone {
    position: relative;
    display: grid;
    justify-items: center;
    gap: 8px;
    padding: 32px 20px;
    border: 2px dashed currentColor;
    border-radius: 16px;
    text-align: center;
}

    .upload-area__dropzone .upload-button {
        position: static;
    }

    .upload-area__dropzone .upload-button__input {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        cursor: pointer;
    }

    .upload-area__dropzone h2,
    .upload-area__dropzone p {
        margin: 0;
    }

.upload-button {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 44px;
    padding: 10px 18px;
    border-radius: 8px;
    background: var(--mud-palette-primary);
    color: var(--mud-palette-primary-text);
    cursor: pointer;
    font-weight: 700;
}

    .upload-button.is-disabled {
        opacity: .65;
        cursor: progress;
        pointer-events: none;
    }

    .upload-button:focus-within,
    .upload-button:focus-visible {
        outline: 3px solid var(--mud-palette-info);
        outline-offset: 3px;
    }

.upload-button__input {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    opacity: 0;
}

.upload-area__list {
    display: grid;
    gap: 12px;
}

.upload-preview {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    padding: 12px;
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 12px;
}

    .upload-preview img {
        width: 72px;
        height: 72px;
        border-radius: 8px;
        object-fit: cover;
    }

.upload-preview__details {
    display: grid;
    min-width: 0;
    gap: 4px;
}

    .upload-preview__details strong {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

.upload-preview__actions {
    grid-column: 1 / -1;
    display: flex;
    justify-content: flex-end;
}

.upload-progress {
    display: grid;
    gap: 4px;
    font-size: 0.875rem;
}

@media (min-width: 720px) {
    .upload-preview {
        grid-template-columns: 88px minmax(0, 1fr) auto;
    }

        .upload-preview img {
            width: 88px;
            height: 88px;
        }

    .upload-preview__actions {
        grid-column: auto;
    }
}

#blazor-error-ui {
    display: none;
    position: fixed;
    inset: auto 0 0;
    padding: 16px 56px 16px 20px;
    background: #8f1d2c;
    color: #fff;
}

    #blazor-error-ui a {
        margin-left: 8px;
        color: inherit;
        font-weight: 700;
    }

    #blazor-error-ui .dismiss {
        position: absolute;
        top: 8px;
        right: 12px;
        min-width: 44px;
        min-height: 44px;
        border: 0;
        background: transparent;
        color: inherit;
        font-size: 1.5rem;
    }

@media (prefers-color-scheme: dark) {
    .foundation-state {
        border-left-color: #c58b5a;
    }

    .foundation-state__eyebrow {
        color: #c58b5a;
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        scroll-behavior: auto !important;
        transition-duration: 0.01ms !important;
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
    }
}

.meeting-hero {
    padding: 2rem;
    border-radius: 1.25rem;
    background: linear-gradient(135deg,var(--mud-palette-primary),var(--mud-palette-secondary));
    color: white;
    margin-bottom: 1rem
}

    .meeting-hero h1 {
        margin: .25rem 0
    }

.attendance-actions {
    display: flex;
    gap: .75rem;
    margin: 1rem 0
}

.meeting-grid {
    display: grid;
    grid-template-columns: repeat(2,minmax(0,1fr));
    gap: 1rem
}

.meeting-panel {
    padding: 1.25rem
}

.attendee-row, .detail-heading {
    display: flex;
    align-items: center;
    gap: .75rem
}

    .attendee-row .mud-chip {
        margin-left: auto
    }

.meeting-comment {
    display: flex;
    flex-direction: column;
    padding: .6rem 0;
    border-bottom: 1px solid var(--mud-palette-lines-default)
}

.comment-compose {
    display: flex;
    align-items: flex-end;
    gap: .5rem;
    margin-top: 1rem
}

    .comment-compose .mud-input-control {
        flex: 1
    }

.meeting-calendar {
    display: grid;
    grid-template-columns: repeat(3,minmax(0,1fr));
    gap: 1rem
}

.calendar-month {
    padding: 1rem;
    min-height: 160px
}

    .calendar-month h2 {
        text-transform: capitalize
    }

.calendar-meeting {
    display: flex;
    width: 100%;
    flex-direction: column;
    text-align: left;
    border: 0;
    border-left: 4px solid var(--mud-palette-primary);
    background: var(--mud-palette-surface);
    padding: .6rem;
    margin: .4rem 0;
    cursor: pointer
}

    .calendar-meeting:hover {
        background: var(--mud-palette-action-default-hover)
    }

.meeting-detail {
    padding: 1.5rem;
    margin-top: 1.5rem
}

.meeting-detail-anchor {
    scroll-margin-top: 1rem;
    outline: none;
}

.editable-meeting-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .5rem;
}

.editable-meeting-item p {
    margin: .4rem 0;
}

.detail-heading {
    justify-content: space-between
}

.attendance-admin > div {
    display: grid;
    grid-template-columns: 1fr 180px;
    align-items: center;
    gap: 1rem;
    border-bottom: 1px solid var(--mud-palette-lines-default)
}

.meeting-date-input {
    display: block;
    width: 100%;
    padding: .8rem;
    border: 1px solid var(--mud-palette-lines-inputs);
    border-radius: 4px;
    background: var(--mud-palette-surface);
    color: inherit
}

@media(max-width:800px) {
    .meeting-grid, .meeting-calendar {
        grid-template-columns: 1fr
    }

    .meeting-hero {
        padding: 1.25rem
    }

    .comment-compose {
        align-items: stretch;
        flex-direction: column
    }

    .attendance-admin > div {
        grid-template-columns: 1fr 140px
    }
}

.golden-detail .media-grid {
    margin-top: 1.25rem;
}

.media-placeholder {
    width: 100%;
    aspect-ratio: 1;
    display: grid;
    place-content: center;
    justify-items: center;
    gap: .5rem;
    padding: .75rem;
    background: color-mix(in srgb, var(--mud-palette-surface) 75%, #111);
    color: var(--mud-palette-text-secondary);
    text-align: center;
}

.media-card > img,
.media-card > .media-placeholder {
    width: 100%;
    height: 100%;
    aspect-ratio: 1;
    object-fit: cover;
}

@media (max-width: 600px) {
    .golden-detail .section-heading,
    .golden-detail .section-heading .upload-button {
        width: 100%;
    }

    .golden-detail .section-heading .upload-button {
        justify-content: center;
    }

    .golden-detail .media-grid {
        margin-top: 1.5rem;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: .75rem;
    }
}

/* Final carousel overrides intentionally live after legacy gallery rules. */
.golden-detail{gap:.75rem}.golden-detail>header{margin-bottom:.25rem}.golden-detail>section{margin:.65rem 0;padding:1.25rem}.golden-detail .golden-media-section{padding:1.25rem}.golden-media-section .section-heading{margin-bottom:1.25rem}.media-carousel{gap:0}.media-carousel__stage{display:block;height:clamp(260px,56vw,580px);min-height:0;contain:layout paint}.media-carousel__slide{position:absolute;inset:0;width:100%;height:100%;opacity:0;visibility:hidden;pointer-events:none;animation:none;transition:opacity 220ms ease,transform 220ms cubic-bezier(.2,.7,.2,1),visibility 0s linear 220ms}.media-carousel.moves-forward .media-carousel__slide{transform:translate3d(-8px,0,0)}.media-carousel.moves-backward .media-carousel__slide{transform:translate3d(8px,0,0)}.media-carousel__slide.is-active{opacity:1;visibility:visible;pointer-events:auto;transform:translate3d(0,0,0);transition-delay:0s}.media-carousel__slide img,.media-carousel__slide video{height:100%;max-height:none}.media-carousel.is-fullscreen .media-carousel__stage{height:100%}
@media(max-width:600px){.golden-detail{gap:.5rem}.golden-detail>section,.golden-detail .golden-media-section{margin:.4rem 0;padding:1rem}.golden-media-section .section-heading{margin-bottom:1rem}.media-carousel__stage{height:clamp(220px,72vw,420px)}.media-carousel.is-fullscreen .media-carousel__stage{height:100%}}
@media(prefers-reduced-motion:reduce){.media-carousel__slide{transition:none;transform:none!important}}

.notification-bell{display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;color:inherit;text-decoration:none}.notification-list{display:grid;gap:.65rem}.notification-card{width:100%;border:1px solid var(--mud-palette-lines-default);border-radius:14px;background:var(--mud-palette-surface);color:inherit;padding:1rem;display:flex;gap:1rem;text-align:left;cursor:pointer}.notification-card.unread{border-left:4px solid var(--mud-palette-primary);background:color-mix(in srgb,var(--mud-palette-primary) 7%,var(--mud-palette-surface))}.notification-card span{display:grid;gap:.2rem}.notification-card small,.notification-card time{color:var(--mud-palette-text-secondary)}.notification-card time{font-size:.75rem}

/* Phase 11.5 — authoritative visual shell and shared polish */
:root {
    --font-ui: "Alegreya Sans", "Trebuchet MS", system-ui, sans-serif;
    --space-1: .25rem;
    --space-2: .5rem;
    --space-3: .75rem;
    --space-4: 1rem;
    --space-5: 1.5rem;
    --space-6: 2rem;
    --radius-sm: 10px;
    --radius-md: 16px;
    --radius-lg: 22px;
    --shadow-low: 0 2px 8px rgb(45 41 38 / 6%);
    --shadow-medium: 0 12px 32px rgb(45 41 38 / 10%);
    --shadow-high: 0 24px 64px rgb(24 21 20 / 20%);
    --topbar-height: 68px;
    --drawer-compact: 72px;
    --drawer-expanded: 240px;
    --bottom-nav-height: 72px;
}

html, body, button, input, textarea, select, .mud-typography { font-family: var(--font-ui); }
body { font-size: 1rem; line-height: 1.5; }
h1, h2, h3, .mud-typography-h1, .mud-typography-h2, .mud-typography-h3 {
    font-family: var(--font-ui);
    font-weight: 700;
    letter-spacing: -.025em;
    text-wrap: balance;
}
a { color: inherit; text-underline-offset: .2em; }
:focus-visible { outline: 3px solid color-mix(in srgb, var(--mud-palette-primary) 72%, white); outline-offset: 3px; }

.app-frame { min-height: 100dvh; }
.session-bar {
    position: sticky;
    inset-block-start: 0;
    z-index: 1200;
    min-height: var(--topbar-height);
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: var(--space-4);
    padding: var(--space-2) var(--space-5);
    border-bottom: 1px solid var(--mud-palette-lines-default);
    background: color-mix(in srgb, var(--mud-palette-appbar-background) 94%, transparent);
    box-shadow: var(--shadow-low);
    backdrop-filter: blur(16px);
}
.session-brand { min-width: 0; gap: var(--space-3); font-size: 1.08rem; letter-spacing: -.015em; }
.session-brand img { width: 48px; height: 48px; }
.session-account { display: flex; align-items: center; justify-content: flex-end; gap: var(--space-2); min-width: 0; }
.session-greeting { max-width: min(28vw, 260px); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 700; }
.notification-bell { border-radius: 50%; transition: color 180ms ease, background-color 180ms ease, transform 180ms ease; }
.notification-bell:hover { color: var(--mud-palette-primary); background: color-mix(in srgb, var(--mud-palette-primary) 9%, transparent); transform: translateY(-1px); }
.account-menu { position: relative; }
.account-menu summary { list-style: none; cursor: pointer; }
.account-menu summary::-webkit-details-marker { display: none; }
.account-menu summary > span { display: grid; place-items: center; width: 40px; height: 40px; border-radius: 50%; background: var(--mud-palette-primary); color: var(--mud-palette-primary-text); font-weight: 700; box-shadow: inset 0 0 0 2px color-mix(in srgb, white 35%, transparent); }
.account-menu-panel { position: absolute; inset-block-start: calc(100% + .65rem); inset-inline-end: 0; z-index: 5; width: 190px; display: grid; gap: var(--space-1); padding: var(--space-2); border: 1px solid var(--mud-palette-lines-default); border-radius: var(--radius-md); background: var(--mud-palette-surface); box-shadow: var(--shadow-high); }
.account-menu-panel a, .account-menu-panel button { display: flex; align-items: center; gap: var(--space-2); min-height: 44px; padding: var(--space-2) var(--space-3); border: 0; border-radius: var(--radius-sm); background: transparent; color: inherit; text-decoration: none; cursor: pointer; }
.account-menu-panel a:hover, .account-menu-panel button:hover { background: color-mix(in srgb, var(--mud-palette-primary) 9%, transparent); }
.nav-menu-button { display: none; width: 44px; height: 44px; place-items: center; padding: 0; border: 0; border-radius: 50%; background: transparent; color: inherit; cursor: pointer; }

.desktop-drawer {
    position: fixed;
    inset-block: var(--topbar-height) 0;
    inset-inline-start: 0;
    z-index: 1100;
    width: var(--drawer-compact);
    display: flex;
    flex-direction: column;
    padding: var(--space-3) var(--space-2);
    border-inline-end: 1px solid var(--mud-palette-lines-default);
    background: var(--mud-palette-drawer-background);
    transition: width 200ms ease;
}
.drawer-expanded .desktop-drawer { width: var(--drawer-expanded); }
.desktop-drawer .app-nav-links { flex: 1; overflow-x: hidden; overflow-y: auto; }
.app-nav-links { display: grid; align-content: start; gap: var(--space-1); }
.app-nav-link { position: relative; display: flex; align-items: center; gap: var(--space-3); min-width: 0; min-height: 48px; padding: 0 14px; border-radius: var(--radius-sm); color: var(--mud-palette-text-secondary); text-decoration: none; font-weight: 700; transition: color 180ms ease, background-color 180ms ease; }
.app-nav-link .mud-icon-root { flex: 0 0 24px; }
.app-nav-link span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.app-nav-link:hover { color: var(--mud-palette-text-primary); background: color-mix(in srgb, var(--mud-palette-primary) 7%, transparent); }
.app-nav-link.active { color: var(--mud-palette-primary); background: color-mix(in srgb, var(--mud-palette-primary) 12%, transparent); }
.app-nav-link.active::before { content: ""; position: absolute; inset-block: 12px; inset-inline-start: -8px; width: 3px; border-radius: 999px; background: var(--mud-palette-primary); }
.drawer-compact .desktop-drawer .app-nav-link span, .drawer-compact .drawer-toggle span { width: 0; opacity: 0; }
.drawer-toggle { display: flex; align-items: center; gap: var(--space-3); min-height: 44px; padding: 0 14px; overflow: hidden; border: 0; border-radius: var(--radius-sm); background: transparent; color: var(--mud-palette-text-secondary); cursor: pointer; }
.drawer-toggle:hover { background: color-mix(in srgb, var(--mud-palette-primary) 7%, transparent); color: var(--mud-palette-text-primary); }

.app-frame > .app-shell { min-height: calc(100dvh - var(--topbar-height)); margin-inline-start: var(--drawer-compact); padding: clamp(1rem, 2.5vw, 2rem); transition: margin-inline-start 200ms ease; }
.app-frame.drawer-expanded > .app-shell { margin-inline-start: var(--drawer-expanded); }
.app-shell--public { margin: 0; padding: 24px; }
.bottom-navigation { display: none; }
.nav-sheet, .nav-sheet-backdrop { display: none; }

.content-page, .home-page { gap: clamp(1rem, 2vw, 1.5rem); }
.page-heading { padding-block: var(--space-2); }
.page-heading h1 { font-size: clamp(2rem, 4vw, 3rem); line-height: 1.05; }
.home-welcome { position: relative; overflow: hidden; padding: clamp(1.25rem, 4vw, 2.5rem); border-radius: var(--radius-lg); background: color-mix(in srgb, var(--mud-palette-primary) 8%, var(--mud-palette-surface)); }
.home-welcome::after { content: "J"; position: absolute; inset-block-start: -3.6rem; inset-inline-end: 1rem; color: color-mix(in srgb, var(--mud-palette-primary) 8%, transparent); font-size: clamp(9rem, 24vw, 17rem); font-weight: 700; line-height: 1; pointer-events: none; }
.home-welcome > * { position: relative; z-index: 1; }
.home-welcome h1 { font-family: var(--font-ui); font-size: clamp(2.1rem, 5vw, 4.25rem); line-height: .98; letter-spacing: -.045em; }
.home-card, .member-card, .golden-card, .memory-card, .recipe-card, .profile-section, .birthday-card, .notification-card { border-radius: var(--radius-md); box-shadow: var(--shadow-low); transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease; }
.home-card:hover, .member-card:hover, .golden-card:hover, .memory-card:hover, .recipe-card:hover { border-color: color-mix(in srgb, var(--mud-palette-primary) 28%, var(--mud-palette-lines-default)); box-shadow: var(--shadow-medium); transform: translateY(-2px); }
.golden-detail .chronicle { font-family: var(--font-ui); font-size: 1.12rem; line-height: 1.75; }

@media (max-width: 959px) {
    .session-bar { grid-template-columns: auto minmax(0, 1fr) auto; padding-inline: var(--space-3); }
    .nav-menu-button { display: grid; }
    .desktop-drawer { display: none; }
    .app-frame > .app-shell, .app-frame.drawer-expanded > .app-shell { margin-inline-start: 0; }
    .nav-sheet-backdrop { display: block; position: fixed; inset: 0; z-index: 1290; border: 0; background: rgb(24 21 20 / 52%); backdrop-filter: blur(2px); }
    .nav-sheet { display: flex; position: fixed; inset-block: 0; inset-inline-start: 0; z-index: 1300; width: min(88vw, 340px); flex-direction: column; padding: var(--space-4); background: var(--mud-palette-surface); box-shadow: var(--shadow-high); animation: nav-sheet-in 180ms ease-out; }
    .nav-sheet header { display: flex; align-items: center; justify-content: space-between; min-height: 52px; padding-inline: var(--space-2); }
    .nav-sheet header strong { font-size: 1.2rem; }
    .nav-sheet header button { display: grid; place-items: center; width: 44px; height: 44px; border: 0; border-radius: 50%; background: transparent; color: inherit; cursor: pointer; }
    .nav-sheet .app-nav-links { margin-top: var(--space-3); overflow-y: auto; }
}

@media (max-width: 600px) {
    :root { --topbar-height: 64px; }
    .session-bar { min-height: var(--topbar-height); gap: var(--space-1); padding: var(--space-2); }
    .session-brand { gap: 0; }
    .session-brand img { width: 44px; height: 44px; }
    .session-brand span { position: absolute; width: 1px; height: 1px; overflow: hidden; clip-path: inset(50%); white-space: nowrap; }
    .session-account { gap: 0; }
    .session-greeting { max-width: clamp(72px, 25vw, 128px); font-size: .9rem; }
    .account-menu summary > span { width: 38px; height: 38px; }
    .app-frame > .app-shell { min-height: calc(100dvh - var(--topbar-height)); padding: var(--space-3) var(--space-3) calc(var(--bottom-nav-height) + env(safe-area-inset-bottom) + var(--space-4)); }
    .bottom-navigation { position: fixed; inset-inline: 0; inset-block-end: 0; z-index: 1180; display: block; min-height: calc(var(--bottom-nav-height) + env(safe-area-inset-bottom)); padding-block-end: env(safe-area-inset-bottom); border-top: 1px solid var(--mud-palette-lines-default); background: color-mix(in srgb, var(--mud-palette-surface) 96%, transparent); box-shadow: 0 -8px 24px rgb(45 41 38 / 8%); backdrop-filter: blur(16px); }
    .bottom-navigation .app-nav-links { height: var(--bottom-nav-height); grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 0; }
    .bottom-navigation .app-nav-link { min-height: var(--bottom-nav-height); flex-direction: column; justify-content: center; gap: 2px; padding: 5px 2px; border-radius: 0; font-size: clamp(.66rem, 2.8vw, .76rem); line-height: 1.1; text-align: center; }
    .bottom-navigation .app-nav-link span { width: 100%; white-space: normal; }
    .bottom-navigation .app-nav-link.active::before { inset: 0 auto auto 50%; width: 28px; height: 3px; transform: translateX(-50%); }
    .home-page { padding: 0; }
    .home-welcome { padding: 1.35rem 1rem; }
    .home-card:hover, .member-card:hover, .golden-card:hover, .memory-card:hover, .recipe-card:hover { transform: none; }
    .install-banner { bottom: calc(var(--bottom-nav-height) + env(safe-area-inset-bottom) + .65rem); }
}

@keyframes nav-sheet-in { from { transform: translateX(-100%); } to { transform: translateX(0); } }
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { scroll-behavior: auto !important; transition-duration: .01ms !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; }
}

/* Phase 11.5 polish — compact filters, detail rhythm and uncropped memories. */
.home-page {
    display: grid;
    gap: clamp(1rem, 2vw, 1.5rem);
}

.filter-tools { margin: 0; }
.filter-tools .mud-expand-panel {
    overflow: hidden;
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: var(--radius-md);
    background: var(--mud-palette-surface);
    box-shadow: var(--shadow-low);
}
.filter-tools .mud-expand-panel-header {
    min-height: 52px;
    font-weight: 700;
}
.filter-panel-content { padding-block: var(--space-2) var(--space-3); }
.filter-grid {
    display: grid;
    grid-template-columns: minmax(220px, 2fr) minmax(160px, 1fr) minmax(150px, auto);
    gap: var(--space-4);
    align-items: center;
}
.filter-grid--compact { grid-template-columns: minmax(160px, .65fr) minmax(240px, 1.35fr); }
.filter-grid--wide { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.filter-grid--wide .golden-filter-search,
.filter-grid--wide .golden-filter-dish { grid-column: auto; }
.memory-view-tools { display: flex; justify-content: flex-end; margin-top: calc(var(--space-2) * -1); }

.recipe-detail { gap: var(--detail-gap); }
.recipe-detail > section { margin: 0; }

.card-thumbnail {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    object-fit: cover;
    object-position: center;
    background: var(--mud-palette-background-gray);
}
.card-thumbnail.media-placeholder,
.card-thumbnail.golden-placeholder,
.card-thumbnail.recipe-placeholder,
.card-thumbnail.video-thumb { display: grid; place-items: center; }
.home-memory-grid a { aspect-ratio: 4 / 3; }
.home-memory-grid .card-thumbnail { height: 100%; aspect-ratio: auto; }
.memory-card > .card-thumbnail,
.recipe-card > .card-thumbnail,
.golden-card > .card-thumbnail { height: auto; aspect-ratio: 4 / 3; object-fit: cover; }
.phase6-list .memory-card > .card-thumbnail { height: 100%; min-height: 120px; aspect-ratio: auto; }

@media (max-width: 760px) {
    .filter-grid,
    .filter-grid--compact,
    .filter-grid--wide { grid-template-columns: 1fr; }
    .memory-view-tools { margin-top: calc(var(--space-1) * -1); }
}

/* Phase 9 administration */
.admin-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-top:1.5rem}.admin-nav-card{display:flex;flex-direction:column;justify-content:space-between;min-height:210px}.admin-nav-card h2{margin:.75rem 0 .35rem}.notification-category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:.25rem 1rem;margin:1rem 0 1.5rem}.moderation-list{display:grid;gap:.75rem}.moderation-item{display:grid;grid-template-columns:minmax(0,120px) 1fr auto;gap:1rem;padding:1rem;align-items:center}.moderation-item img,.moderation-item video{width:120px;height:90px;object-fit:cover;border-radius:.5rem}.audit-json{white-space:pre-wrap;overflow-wrap:anywhere;max-width:42rem}@media(max-width:600px){.moderation-item{grid-template-columns:1fr}.moderation-item img,.moderation-item video{width:100%;height:180px}}
.admin-icon-actions{display:flex;align-items:center;justify-content:flex-end;gap:.25rem}.admin-icon-actions .mud-icon-button{width:44px;height:44px}@media(max-width:600px){.admin-icon-actions{justify-content:flex-start}}

/* Phase 10 Truco */
.truco-page{width:min(100%,900px);margin:0 auto;padding:1rem;min-height:calc(100dvh - 90px)}.truco-page>header{text-align:center}.truco-setup{display:grid;gap:1rem}.truco-setup>label{display:grid;gap:.35rem;font-weight:600}.truco-setup select{min-height:44px;padding:.55rem;border:1px solid var(--mud-palette-lines-inputs);border-radius:6px;background:var(--mud-palette-surface);color:inherit}.truco-team-setup,.truco-board{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.truco-team-editor{position:relative;padding:1rem;display:grid;gap:.5rem}.team-color{width:44px;height:44px;padding:2px;border:0;background:transparent}.truco-heading{margin-bottom:.5rem}.truco-board{height:min(68dvh,680px)}.truco-team-card{border:4px solid;border-radius:20px;padding:clamp(.75rem,3vw,1.5rem);display:grid;grid-template-rows:auto auto 1fr auto;text-align:center;background:var(--mud-palette-surface);overflow:hidden}.truco-team-card h2{margin:.25rem 0}.truco-players{color:var(--mud-palette-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.truco-score{font-size:clamp(5rem,18vw,11rem);line-height:1;align-self:center}.score-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.score-buttons button{min-width:44px;min-height:56px;border:0;border-radius:12px;background:var(--mud-palette-primary);color:var(--mud-palette-primary-text);font-size:1.3rem;font-weight:700;cursor:pointer}.score-buttons button:disabled{opacity:.45}.truco-actions{display:flex;justify-content:center;gap:.5rem;margin-top:.75rem}.truco-winner-backdrop{position:fixed;inset:0;z-index:1300;background:#0009;display:grid;place-items:center;padding:1rem}.truco-winner{width:min(100%,420px);padding:2rem;text-align:center;display:grid;gap:.75rem}.truco-winner>span{font-size:4rem}.golden-truco-list{display:grid;gap:.75rem}.golden-truco-list article{display:flex;gap:1rem;align-items:center;padding:.75rem;border:1px solid var(--mud-palette-lines-default);border-radius:12px}.golden-truco-list article>span{font-size:2rem}.golden-truco-list p{margin:.2rem 0}
@media(max-width:600px){.truco-page{padding:.5rem}.truco-team-setup{grid-template-columns:1fr}.truco-board{gap:.5rem;height:68dvh}.truco-team-card{border-width:3px;padding:.5rem}.truco-score{font-size:clamp(4.5rem,24vw,8rem)}.truco-players{font-size:.8rem}.score-buttons{gap:.25rem}.score-buttons button{min-height:52px}.truco-actions{margin-top:.5rem}}

/* Traditional Truco table overrides */
.truco-page{position:relative;width:min(100%,1040px);padding:clamp(.5rem,2vw,1.25rem);color:#f4ecd9;border-radius:20px;background:radial-gradient(circle at 20% 10%,rgba(255,255,255,.045) 0 1px,transparent 2px),linear-gradient(135deg,#123c2d,#1b513d 55%,#103326);background-size:13px 13px,auto;box-shadow:inset 0 0 65px rgba(0,0,0,.28),0 12px 35px rgba(45,31,19,.15)}.truco-page::after{content:"";position:absolute;inset:0;border:clamp(5px,1vw,11px) solid #a8794f;border-radius:20px;box-shadow:inset 0 0 0 2px rgba(64,37,20,.35);pointer-events:none}.truco-page>header,.truco-page>.truco-setup,.truco-page>.truco-board,.truco-page>.truco-actions,.truco-page>.mud-alert{position:relative;z-index:1}.truco-heading{color:#f4ecd9}.truco-board{height:min(62dvh,590px);min-height:330px}.truco-team-card{display:grid;grid-template-rows:minmax(0,1fr) auto auto;gap:.5rem;min-width:0;padding:.65rem;border:0!important;border-radius:18px;background:rgba(21,25,23,.24);overflow:hidden}.truco-players{min-height:1.25rem;margin:0;color:#e8dfcc;text-align:center}.score-buttons button{border:1px solid rgba(244,236,217,.42);border-radius:9px;background:#343535;color:#f4ecd9;box-shadow:inset 0 -2px 0 rgba(0,0,0,.25);transition:background 120ms ease,transform 120ms ease}.score-buttons button:hover:not(:disabled){background:#454746}.score-buttons button:active:not(:disabled){transform:translateY(1px)}.score-buttons button:focus-visible{outline:3px solid #b4573f;outline-offset:2px}.truco-actions .mud-button-root{min-height:44px;color:#f4ecd9}.truco-winner{border:1px solid #d7c7aa;background:#f4ecd9;color:#333534;box-shadow:0 18px 60px #0007;animation:truco-winner-in 320ms ease-out}.truco-winner>span{filter:saturate(.65)}@keyframes truco-winner-in{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}
@media(max-width:600px){.truco-page{min-height:calc(100dvh - 74px);border-radius:14px}.truco-page::after{border-width:5px;border-radius:14px}.truco-heading h1{margin:.1rem 0;font-size:1.45rem}.truco-heading .eyebrow{margin:.15rem}.truco-board{height:min(67dvh,560px);min-height:300px;gap:.35rem}.truco-team-card{padding:.35rem;gap:.3rem;border-radius:13px}.truco-players{font-size:.72rem}.score-buttons{gap:.2rem}.score-buttons button{min-height:48px;padding:.25rem;font-size:1.05rem}.truco-actions{margin-top:.4rem}}
@media(prefers-reduced-motion:reduce){.score-buttons button,.truco-winner{transition:none;animation:none}}
