/**
 * Housekeeping Reports Search sidebar panel + photo lightbox.
 * Loaded from _koto_head.html (all shells that include Koto tokens).
 * Uses Koto tokens from tokens.css — no legacy :root overrides.
 */

/* --- Panel shell --- */
.housekeeping-reports-dropdown {
    width: min(560px, calc(100vw - 1.5rem)) !important;
    min-width: min(560px, calc(100vw - 1.5rem)) !important;
    padding: 0 !important;
    position: relative;
    isolation: isolate;
    z-index: 1060;
    border: 1px solid color-mix(in srgb, var(--sky-200) 55%, var(--border)) !important;
    border-radius: var(--radius-lg) !important;
    background:
        linear-gradient(
            180deg,
            color-mix(in srgb, var(--neutral-0) 88%, var(--sky-50)) 0%,
            color-mix(in srgb, var(--neutral-0) 84%, var(--peri-50)) 100%
        ) !important;
    box-shadow:
        0 32px 72px color-mix(in srgb, var(--sky-900) 20%, transparent),
        0 12px 28px color-mix(in srgb, var(--sky-800) 14%, transparent),
        inset 0 1px 0 color-mix(in srgb, var(--neutral-0) 92%, transparent),
        inset 0 -1px 0 color-mix(in srgb, var(--sky-100) 44%, transparent) !important;
    backdrop-filter: blur(20px) saturate(150%);
    -webkit-backdrop-filter: blur(20px) saturate(150%);
    overflow: hidden;
}

.housekeeping-reports-dropdown::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(
            180deg,
            color-mix(in srgb, var(--neutral-0) 54%, transparent) 0%,
            transparent 32%,
            color-mix(in srgb, var(--sky-50) 34%, transparent) 100%
        );
    z-index: 0;
}

.housekeeping-reports-dropdown::after {
    content: "";
    position: absolute;
    inset: -24% 38% 46% -16%;
    pointer-events: none;
    background:
        radial-gradient(
            circle at center,
            color-mix(in srgb, var(--sky-200) 44%, transparent) 0%,
            transparent 72%
        );
    opacity: 0.85;
    z-index: 0;
}

.housekeeping-reports-dropdown .reports-dropdown-header {
    padding: 1rem 1.2rem 0.7rem;
    background:
        linear-gradient(
            180deg,
            color-mix(in srgb, var(--neutral-0) 90%, transparent) 0%,
            color-mix(in srgb, var(--sky-50) 40%, transparent) 100%
        );
    border-bottom: 1px solid var(--border);
    position: relative;
    z-index: 1;
}

.housekeeping-reports-dropdown .reports-dropdown-title-row {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: nowrap !important;
    gap: 0.75rem;
    margin-bottom: 0.65rem;
}

.housekeeping-reports-dropdown .reports-title-group {
    min-width: 0;
    flex: 1 1 auto;
    display: flex;
    align-items: center;
    gap: 0.55rem;
    overflow: hidden;
}

.housekeeping-reports-dropdown .reports-dropdown-title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--fg1);
    letter-spacing: -0.01em;
}

.housekeeping-reports-dropdown .report-count-text {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.85rem;
    height: 1.6rem;
    padding: 0 0.55rem;
    border-radius: var(--radius-pill);
    background: var(--sky-500);
    color: #fff;
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1;
    box-shadow:
        inset 0 1px 0 color-mix(in srgb, var(--neutral-0) 32%, transparent),
        0 10px 18px color-mix(in srgb, var(--sky-700) 24%, transparent);
}

.housekeeping-reports-dropdown .reports-close-btn {
    width: 2rem;
    height: 2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: none;
    border-radius: var(--radius-pill);
    color: var(--fg3);
    background: transparent;
    box-shadow: none;
    transition: background 0.15s ease, color 0.15s ease;
}

.housekeeping-reports-dropdown .reports-close-btn i,
.housekeeping-reports-dropdown .reports-search i,
.housekeeping-reports-dropdown .reports-sort-wrap i,
.housekeeping-reports-dropdown .report-card-time i,
.housekeeping-reports-dropdown .reports-view-all-btn i,
.housekeeping-reports-dropdown .empty-reports-icon i {
    width: 0.95rem;
    height: 0.95rem;
    flex-shrink: 0;
}

.housekeeping-reports-dropdown .reports-close-btn:hover {
    background: var(--neutral-100);
    color: var(--fg1);
}

.housekeeping-reports-dropdown .reports-toolbar {
    display: flex !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    gap: 0.5rem;
}

.housekeeping-reports-dropdown .reports-search {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.6rem 0.85rem;
    border-radius: var(--radius-pill);
    background: var(--neutral-100);
    background: color-mix(in srgb, var(--neutral-100) 82%, var(--neutral-0));
    border: 1px solid transparent;
    color: var(--fg3);
    min-width: 0;
    box-shadow: inset 0 1px 0 color-mix(in srgb, var(--neutral-0) 60%, transparent);
    transition: border-color 0.15s ease, background 0.15s ease;
}

.housekeeping-reports-dropdown .reports-search:focus-within {
    background: var(--bg-elevated);
    border-color: var(--sky-300);
    box-shadow: 0 0 0 3px var(--sky-100);
}

.housekeeping-reports-dropdown .reports-search-input {
    width: 100%;
    border: none;
    outline: none;
    background: transparent;
    color: var(--fg1);
    font-size: 0.92rem;
    min-width: 0;
}

.housekeeping-reports-dropdown .reports-search-input::placeholder {
    color: var(--fg3);
}

.housekeeping-reports-dropdown .reports-sort-wrap {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    white-space: nowrap;
    padding: 0.6rem 0.85rem;
    border-radius: var(--radius-pill);
    color: var(--fg2);
    font-size: 0.88rem;
    font-weight: 600;
    background: var(--neutral-100);
    background: color-mix(in srgb, var(--neutral-100) 78%, var(--neutral-0));
    box-shadow: inset 0 1px 0 color-mix(in srgb, var(--neutral-0) 56%, transparent);
    transition: background 0.15s ease;
}

.housekeeping-reports-dropdown .reports-sort-wrap:hover {
    background: var(--neutral-200);
}

.housekeeping-reports-dropdown .reports-sort-select {
    position: absolute !important;
    inset: 0 !important;
    opacity: 0 !important;
    cursor: pointer;
}

.housekeeping-reports-dropdown .reports-list {
    max-height: 26rem;
    overflow-y: auto;
    padding: 0.4rem 1rem 0.95rem;
    background:
        linear-gradient(
            180deg,
            color-mix(in srgb, var(--sky-50) 54%, var(--neutral-0)) 0%,
            color-mix(in srgb, var(--peri-50) 34%, var(--neutral-0)) 100%
        );
    position: relative;
    z-index: 1;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.housekeeping-reports-dropdown .reports-list::-webkit-scrollbar {
    display: none;
    width: 0;
    height: 0;
}

.housekeeping-reports-dropdown .empty-reports-message {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    padding: 3rem 1rem 2.5rem;
    text-align: center;
}

.housekeeping-reports-dropdown .empty-reports-icon {
    width: 3rem;
    height: 3rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--sky-100);
    color: var(--sky-500);
    font-size: 1.15rem;
}

.housekeeping-reports-dropdown .empty-reports-icon i {
    width: 1.25rem;
    height: 1.25rem;
}

.housekeeping-reports-dropdown .report-item {
    display: block;
    width: 100%;
    margin-bottom: 0.75rem;
    position: relative;
    isolation: isolate;
    overflow: hidden;
    padding: 0.95rem 1rem 0.9rem 1.2rem;
    border: 1px solid color-mix(in srgb, var(--border) 82%, var(--neutral-0));
    border-radius: calc(var(--radius-md) + 2px);
    background:
        linear-gradient(
            180deg,
            color-mix(in srgb, var(--neutral-0) 94%, var(--sky-50)) 0%,
            color-mix(in srgb, var(--neutral-0) 88%, var(--sky-50)) 100%
        );
    box-shadow:
        inset 0 1px 0 color-mix(in srgb, var(--neutral-0) 88%, transparent),
        0 18px 30px color-mix(in srgb, var(--sky-900) 10%, transparent),
        0 6px 12px color-mix(in srgb, var(--sky-800) 8%, transparent);
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease, background 0.22s ease;
}

.housekeeping-reports-dropdown .report-item::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(
            180deg,
            color-mix(in srgb, var(--neutral-0) 72%, transparent) 0%,
            transparent 42%
        );
    z-index: 0;
}

.housekeeping-reports-dropdown .report-item::after {
    content: "";
    position: absolute;
    left: 0.55rem;
    top: 0.7rem;
    bottom: 0.7rem;
    width: 4px;
    border-radius: 999px;
    background: linear-gradient(180deg, var(--sky-300) 0%, var(--sky-600) 100%);
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--neutral-0) 40%, transparent),
        0 10px 16px color-mix(in srgb, var(--sky-700) 18%, transparent);
    z-index: 1;
}

.housekeeping-reports-dropdown .report-item:last-child {
    margin-bottom: 0;
}

.housekeeping-reports-dropdown .report-item:hover {
    transform: translateY(-4px);
    border-color: color-mix(in srgb, var(--sky-300) 78%, var(--border));
    box-shadow:
        inset 0 1px 0 color-mix(in srgb, var(--neutral-0) 92%, transparent),
        0 24px 38px color-mix(in srgb, var(--sky-900) 16%, transparent),
        0 8px 16px color-mix(in srgb, var(--sky-800) 12%, transparent);
}

.housekeeping-reports-dropdown .report-item[data-report-variant="critical"] {
    background:
        linear-gradient(
            180deg,
            color-mix(in srgb, var(--neutral-0) 94%, var(--coral-50)) 0%,
            color-mix(in srgb, var(--neutral-0) 86%, var(--coral-50)) 100%
        );
}

.housekeeping-reports-dropdown .report-item[data-report-variant="critical"]::after {
    background: linear-gradient(180deg, var(--coral-300) 0%, var(--coral-700) 100%);
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--coral-100) 80%, transparent),
        0 10px 18px color-mix(in srgb, var(--coral-700) 26%, transparent);
}

.housekeeping-reports-dropdown .report-item[data-report-variant="warning"] {
    background:
        linear-gradient(
            180deg,
            color-mix(in srgb, var(--neutral-0) 94%, var(--amber-100)) 0%,
            color-mix(in srgb, var(--neutral-0) 88%, var(--amber-100)) 100%
        );
}

.housekeeping-reports-dropdown .report-item[data-report-variant="warning"]::after {
    background: linear-gradient(180deg, var(--amber-300) 0%, var(--amber-700) 100%);
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--amber-100) 76%, transparent),
        0 10px 18px color-mix(in srgb, var(--amber-700) 22%, transparent);
}

.housekeeping-reports-dropdown .report-item[data-report-variant="inventory"] {
    background:
        linear-gradient(
            180deg,
            color-mix(in srgb, var(--neutral-0) 94%, var(--butter-50)) 0%,
            color-mix(in srgb, var(--neutral-0) 88%, var(--butter-100)) 100%
        );
}

.housekeeping-reports-dropdown .report-item[data-report-variant="inventory"]::after {
    background: linear-gradient(180deg, var(--butter-300) 0%, var(--butter-700) 100%);
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--butter-100) 76%, transparent),
        0 10px 18px color-mix(in srgb, var(--amber-700) 18%, transparent);
}

.housekeeping-reports-dropdown .report-item[data-report-variant="info"] {
    background:
        linear-gradient(
            180deg,
            color-mix(in srgb, var(--neutral-0) 94%, var(--peri-50)) 0%,
            color-mix(in srgb, var(--neutral-0) 88%, var(--sky-50)) 100%
        );
}

.housekeeping-reports-dropdown .report-item[data-report-variant="info"]::after {
    background: linear-gradient(180deg, var(--peri-300) 0%, var(--peri-700) 100%);
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--peri-100) 76%, transparent),
        0 10px 18px color-mix(in srgb, var(--peri-700) 22%, transparent);
}

.housekeeping-reports-dropdown .report-card-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: nowrap !important;
    gap: 0.6rem;
    margin-bottom: 0.5rem;
    position: relative;
    z-index: 2;
}

.housekeeping-reports-dropdown .report-card-body {
    display: flex;
    align-items: stretch;
    gap: 0.75rem;
    position: relative;
    z-index: 2;
}

.housekeeping-reports-dropdown .report-card-content {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.08rem;
}

.housekeeping-reports-dropdown .report-room {
    margin: 0;
    color: var(--fg1);
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: -0.01em;
    flex: 1;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.housekeeping-reports-dropdown .report-type-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.28rem 0.58rem;
    border: 1px solid transparent;
    border-radius: calc(var(--radius-sm) + 2px);
    background: var(--neutral-100);
    color: var(--fg2);
    font-size: 0.67rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    white-space: nowrap;
    box-shadow: inset 0 1px 0 color-mix(in srgb, var(--neutral-0) 60%, transparent);
}

.housekeeping-reports-dropdown .report-type-pill[data-report-variant="critical"] {
    background: color-mix(in srgb, var(--coral-100) 92%, var(--neutral-0));
    border-color: color-mix(in srgb, var(--coral-200) 72%, transparent);
    color: var(--coral-700);
}

.housekeeping-reports-dropdown .report-type-pill[data-report-variant="warning"] {
    background: color-mix(in srgb, var(--amber-100) 94%, var(--neutral-0));
    border-color: color-mix(in srgb, var(--amber-300) 62%, transparent);
    color: var(--amber-700);
}

.housekeeping-reports-dropdown .report-type-pill[data-report-variant="inventory"] {
    background: color-mix(in srgb, var(--butter-100) 96%, var(--neutral-0));
    border-color: color-mix(in srgb, var(--butter-300) 66%, transparent);
    color: var(--butter-700);
}

.housekeeping-reports-dropdown .report-type-pill[data-report-variant="info"] {
    background: color-mix(in srgb, var(--peri-100) 92%, var(--neutral-0));
    border-color: color-mix(in srgb, var(--peri-200) 74%, transparent);
    color: var(--peri-700);
}

.housekeeping-reports-dropdown .report-card-meta {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--fg2);
    font-size: 0.85rem;
    font-weight: 500;
    margin-bottom: 0.35rem;
}

.housekeeping-reports-dropdown .report-card-avatar {
    width: 1.75rem;
    height: 1.75rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-sm);
    color: var(--neutral-0);
    font-size: 0.7rem;
    font-weight: 700;
    flex-shrink: 0;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    border: 1px solid color-mix(in srgb, var(--neutral-0) 22%, transparent);
    box-shadow: none;
    background: var(--sky-700);
}

.housekeeping-reports-dropdown .report-card-avatar[data-avatar-tone="coral"] {
    background: var(--coral-700);
}

.housekeeping-reports-dropdown .report-card-avatar[data-avatar-tone="sky"] {
    background: var(--sky-700);
}

.housekeeping-reports-dropdown .report-card-avatar[data-avatar-tone="peri"] {
    background: var(--peri-700);
}

.housekeeping-reports-dropdown .report-card-avatar[data-avatar-tone="amber"] {
    background: var(--amber-700);
}

.housekeeping-reports-dropdown .report-card-avatar[data-avatar-tone="mint"] {
    background: var(--mint-700);
}

.housekeeping-reports-dropdown .report-card-avatar[data-avatar-tone="lilac"] {
    background: var(--lilac-700);
}

.housekeeping-reports-dropdown .report-card-avatar img {
    width: 100%;
    height: 100%;
    border-radius: var(--radius-sm);
    object-fit: cover;
}

.housekeeping-reports-dropdown .report-card-time {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    color: var(--fg3);
    font-size: 0.85rem;
    font-weight: 500;
    margin-top: auto;
    padding-top: 0.3rem;
}

.housekeeping-reports-dropdown .report-card-time i {
    color: color-mix(in srgb, var(--fg3) 82%, var(--sky-500));
}

.housekeeping-reports-dropdown .report-card-photo-link {
    display: flex;
    align-self: stretch;
    flex-shrink: 0;
    background: none;
    border: none;
    padding: 0;
    cursor: zoom-in;
}

.housekeeping-reports-dropdown .report-card-photo {
    width: 5rem;
    border-radius: var(--radius-sm);
    object-fit: cover;
    border: 1px solid var(--border);
    flex-shrink: 0;
    display: block;
    align-self: stretch;
    box-shadow:
        0 8px 16px color-mix(in srgb, var(--sky-900) 9%, transparent);
    transition: border-color 0.18s ease, box-shadow 0.18s ease, opacity 0.18s ease;
}

.housekeeping-reports-dropdown .report-card-photo-link:hover .report-card-photo {
    border-color: var(--sky-300);
    box-shadow:
        0 12px 22px color-mix(in srgb, var(--sky-900) 12%, transparent);
    opacity: 0.92;
}

/* Report photo lightbox (appended to body by base-main.js) */
.report-photo-lightbox {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: rgba(0, 0, 0, 0.82);
    backdrop-filter: blur(6px);
    align-items: center;
    justify-content: center;
    cursor: zoom-out;
}

.report-photo-lightbox.active {
    display: flex;
}

.report-photo-lightbox-img {
    max-width: min(90vw, 600px);
    max-height: 85vh;
    border-radius: 16px;
    box-shadow: 0 32px 80px rgba(0, 0, 0, 0.6);
    object-fit: contain;
    pointer-events: none;
}

.housekeeping-reports-dropdown .reports-dropdown-footer {
    padding: 0.85rem 1.2rem 1rem;
    background:
        linear-gradient(
            180deg,
            color-mix(in srgb, var(--neutral-0) 74%, transparent) 0%,
            color-mix(in srgb, var(--sky-50) 42%, transparent) 100%
        );
    border-top: 1px solid var(--border);
    position: relative;
    z-index: 1;
}

.housekeeping-reports-dropdown .reports-view-all-btn {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.75rem 1.1rem;
    border: 1px solid color-mix(in srgb, var(--sky-300) 68%, transparent);
    border-radius: var(--radius-lg);
    background: linear-gradient(180deg, var(--sky-400) 0%, var(--sky-600) 100%);
    color: #fff;
    font-size: 0.95rem;
    font-weight: 600;
    letter-spacing: 0.01em;
    text-decoration: none;
    box-shadow:
        inset 0 1px 0 color-mix(in srgb, var(--neutral-0) 42%, transparent),
        0 14px 28px color-mix(in srgb, var(--sky-700) 26%, transparent);
    transition: background 0.15s ease, transform 0.1s ease, box-shadow 0.15s ease;
}

.housekeeping-reports-dropdown .reports-view-all-btn:hover {
    background: linear-gradient(180deg, var(--sky-500) 0%, var(--sky-700) 100%);
    color: #fff;
    box-shadow:
        inset 0 1px 0 color-mix(in srgb, var(--neutral-0) 46%, transparent),
        0 18px 34px color-mix(in srgb, var(--sky-700) 30%, transparent);
    transform: translateY(-2px);
}

.housekeeping-reports-dropdown .reports-view-all-btn:active {
    transform: translateY(0);
    box-shadow: var(--shadow-sm);
}
