/* ЛЕБІГОЛЯНДІЯ — Platform v13 fixes */

/* Header layout: brand, search, user area and navigation never overlap. */
.header-inner {
    position: relative;
    min-height: 94px;
    display: grid !important;
    grid-template-columns:
        minmax(220px, 1fr)
        minmax(280px, 680px)
        minmax(200px, 1fr) !important;
    grid-template-rows: 48px 38px !important;
    grid-template-areas:
        "brand search user"
        "nav nav nav";
    align-items: center;
    gap: 8px 20px;
}

.header-brand {
    grid-area: brand;
    min-width: 0;
}

.header-brand .logo {
    margin: 0;
    display: flex;
    align-items: center;
    gap: 10px;
}

.header-nav {
    grid-area: nav !important;
    min-width: 0;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}

.header-center {
    position: relative;
    z-index: 30;
    grid-area: search !important;
    width: 100%;
    min-width: 0;
    max-width: none !important;
}

.header-center .search-section {
    position: relative;
    width: 100%;
    min-width: 0;
    margin: 0;
}

.header-center .search-section input {
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
}

.header-right {
    grid-area: user !important;
    min-width: 0;
    display: flex;
    justify-content: flex-end;
}

.industrial-logo {
    min-width: 0;
}

.global-search-results.hidden {
    display: none !important;
}

/* Unified page action bars. */
.page-action-bar,
.feed-page-header.feed-page-header-actions-only,
#donatesPage .donates-header.donates-header-actions-only,
.giveaways-toolbar,
.winners-toolbar {
    min-height: 58px !important;
    margin: 0 0 18px !important;
    padding: 8px 0 14px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 10px;
    color: inherit !important;
    background: transparent !important;
    border: 0 !important;
    border-bottom: 1px solid var(--border-soft) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.giveaways-toolbar,
.winners-toolbar {
    justify-content: space-between !important;
}

.winners-toolbar > div {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.winners-toolbar small {
    color: var(--text-muted);
}

.feed-drafts-count {
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    background: var(--accent);
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 900;
}

/* Page transition keeps the current page mounted until the next one is ready. */
.container {
    position: relative;
}

.page-transition-overlay {
    position: fixed;
    z-index: 1250;
    inset: var(--header-height, 92px) 0 0;
    display: grid;
    place-items: start center;
    padding-top: 22px;
    pointer-events: none;
    background: linear-gradient(
        180deg,
        rgba(12, 14, 16, 0.12),
        transparent 130px
    );
    opacity: 1;
    transition: opacity 0.16s ease;
}

.page-transition-overlay.hidden {
    display: none !important;
}

.page-transition-indicator {
    padding: 8px 13px 8px 9px;
    display: inline-flex;
    align-items: center;
    gap: 9px;
    color: var(--text-primary);
    background: rgba(18, 21, 23, 0.94);
    border: 1px solid var(--border-soft);
    border-left: 3px solid var(--accent);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.28);
    font-size: 0.8rem;
    font-weight: 800;
}

.page-transition-indicator img {
    width: 34px;
    height: 34px;
    object-fit: cover;
    border: 2px solid #70757a;
    border-radius: 50%;
    animation: platformLoaderPulse 1s ease-in-out infinite;
}

@keyframes platformLoaderPulse {
    50% {
        transform: scale(0.92);
        opacity: 0.72;
    }
}

/* Shared video ratings. */
.video-card-footer .star-rating {
    min-width: 0;
    display: inline-flex;
    align-items: center;
    gap: 2px;
}

.video-card-footer .rating-star {
    width: 25px;
    height: 28px;
    padding: 0;
    display: inline-grid;
    place-items: center;
    color: #555b61 !important;
    background: transparent;
    border: 0;
    cursor: pointer;
    opacity: 0.62;
    transform: none;
    transition:
        color 0.15s ease,
        opacity 0.15s ease,
        transform 0.15s ease,
        filter 0.15s ease;
}

.video-card-footer .rating-star i {
    color: currentColor !important;
    font-size: 0.94rem;
}

.video-card-footer .rating-star.active {
    color: #f4bd43 !important;
    opacity: 1;
    filter: drop-shadow(0 0 4px rgba(244, 189, 67, 0.34));
}

.video-card-footer .rating-star:hover,
.video-card-footer .rating-star:focus-visible {
    color: #ffd76c !important;
    opacity: 1;
    transform: translateY(-1px) scale(1.08);
}

.video-card-footer .rating-star:disabled {
    cursor: wait;
    opacity: 0.45;
}

.video-card-footer .rating-value {
    min-width: 50px;
    margin-left: 5px;
    display: inline-flex;
    align-items: baseline;
    gap: 3px;
    color: var(--text-muted);
}

.video-card-footer .rating-value strong {
    color: #f4bd43;
    font-size: 0.86rem;
}

.video-card-footer .rating-value small {
    color: var(--text-muted);
    font-size: 0.67rem;
}

/* Emoji picker: isolated grid so buttons never stack over each other. */
.comment-composer-card {
    overflow: visible !important;
}

.comment-composer-toolbar {
    position: relative !important;
    z-index: 30 !important;
    min-height: 36px;
    overflow: visible !important;
}

.emoji-picker-panel {
    position: absolute !important;
    z-index: 8000 !important;
    left: 0 !important;
    right: auto !important;
    bottom: calc(100% + 8px) !important;
    width: min(340px, calc(100vw - 48px)) !important;
    max-height: 320px;
    overflow-y: auto;
    box-sizing: border-box;
    contain: layout paint;
}

.emoji-picker-panel.hidden {
    display: none !important;
}

.emoji-picker-grid {
    position: static !important;
    display: grid !important;
    grid-template-columns: repeat(8, minmax(32px, 1fr)) !important;
    grid-auto-rows: minmax(34px, auto) !important;
    gap: 5px !important;
    width: 100%;
}

.emoji-picker-item {
    position: static !important;
    inset: auto !important;
    width: 100% !important;
    min-width: 0 !important;
    height: 36px !important;
    min-height: 36px !important;
    margin: 0 !important;
    padding: 0 !important;
    display: grid !important;
    place-items: center !important;
    line-height: 1 !important;
    transform: none;
}

.emoji-picker-item:hover {
    transform: scale(1.06) !important;
}

/* Drafts and schedule. */
.feed-publication-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.feed-publication-grid label {
    display: flex;
    flex-direction: column;
    gap: 7px;
}

.feed-composer-note {
    padding: 11px 12px;
    display: flex;
    align-items: flex-start;
    gap: 8px;
    color: var(--text-muted);
    background: color-mix(in srgb, var(--bg-secondary) 90%, var(--accent) 10%);
    border: 1px solid var(--border-soft);
    border-left: 3px solid var(--accent);
    font-size: 0.8rem;
    line-height: 1.4;
}

.feed-drafts-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.feed-draft-item {
    padding: 12px;
    display: grid;
    grid-template-columns: 90px minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    background: var(--bg-primary);
    border: 1px solid var(--border-soft);
    border-radius: 5px;
}

.feed-draft-preview {
    width: 90px;
    aspect-ratio: 16 / 10;
    display: grid;
    place-items: center;
    overflow: hidden;
    color: var(--text-muted);
    background: var(--bg-secondary);
    border: 1px solid var(--border-soft);
}

.feed-draft-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.feed-draft-copy {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.feed-draft-copy strong,
.feed-draft-copy p {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.feed-draft-copy p,
.feed-draft-copy small {
    margin: 0;
    color: var(--text-muted);
}

.feed-draft-status {
    width: fit-content;
    padding: 3px 7px;
    color: #d9e2e8;
    background: #31373c;
    border-radius: 3px;
    font-size: 0.68rem;
    font-weight: 900;
    text-transform: uppercase;
}

.feed-draft-status.is-scheduled {
    color: #ffe6a1;
    background: #594316;
}

.feed-draft-actions {
    display: flex;
    gap: 7px;
}

/* Notification center deep links. */
.notification-item {
    width: 100%;
    text-align: left;
}

button.notification-item {
    font: inherit;
    cursor: default;
}

.notification-item.is-actionable {
    cursor: pointer;
}

.notification-item.is-actionable:hover {
    background: color-mix(in srgb, var(--bg-secondary) 82%, var(--accent) 18%);
    border-color: color-mix(in srgb, var(--border-soft) 55%, var(--accent) 45%);
}

.notification-open-icon {
    align-self: center;
    margin-left: auto;
    color: var(--text-muted);
}

/* Giveaway conditions and transparent draw. */
.giveaway-conditions {
    margin: 0 0 11px;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.giveaway-conditions > span {
    padding: 5px 8px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #d9dde0;
    background: #252a2e;
    border: 1px solid #454b50;
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 750;
}

.giveaway-transparency {
    margin: 10px 0 13px;
    color: var(--text-muted);
    background: var(--bg-primary);
    border: 1px solid var(--border-soft);
}

.giveaway-transparency summary {
    padding: 9px 10px;
    cursor: pointer;
    font-size: 0.76rem;
    font-weight: 850;
}

.giveaway-transparency > div {
    padding: 0 10px 10px;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.giveaway-transparency code,
.winner-proof dd {
    overflow-wrap: anywhere;
    word-break: break-word;
}

/* Winners history. */
.winners-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.winner-history-card {
    overflow: hidden;
    background: var(--bg-secondary);
    border: 1px solid var(--border-soft);
    border-radius: 5px;
    box-shadow: 5px 5px 0 rgba(0, 0, 0, 0.2);
}

.winner-history-preview {
    position: relative;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: #0e1012;
}

.winner-history-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.winner-history-badge {
    position: absolute;
    left: 10px;
    bottom: 10px;
    padding: 6px 9px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #211903;
    background: #f4bd43;
    border-radius: 3px;
    font-size: 0.72rem;
    font-weight: 950;
    text-transform: uppercase;
}

.winner-history-body {
    padding: 15px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.winner-history-title {
    padding: 0;
    overflow: hidden;
    color: var(--text-primary);
    background: none;
    border: 0;
    cursor: pointer;
    font: inherit;
    font-size: 1.08rem;
    font-weight: 900;
    text-align: left;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.winner-history-user {
    padding: 10px;
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--text-primary);
    background: var(--bg-primary);
    border: 1px solid var(--border-soft);
    cursor: pointer;
    text-align: left;
}

.winner-history-user img {
    width: 48px;
    height: 48px;
    object-fit: cover;
    border: 2px solid #f4bd43;
    border-radius: 50%;
}

.winner-history-user span {
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.winner-history-user small,
.winner-history-user em {
    color: var(--text-muted);
    font-size: 0.72rem;
    font-style: normal;
}

.winner-history-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    color: var(--text-muted);
    font-size: 0.76rem;
}

.winner-proof {
    background: var(--bg-primary);
    border: 1px solid var(--border-soft);
}

.winner-proof summary {
    padding: 9px 10px;
    cursor: pointer;
    font-size: 0.76rem;
    font-weight: 850;
}

.winner-proof dl {
    margin: 0;
    padding: 0 10px 10px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.winner-proof dl > div {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr);
    gap: 8px;
}

.winner-proof dt {
    color: var(--text-muted);
    font-size: 0.7rem;
}

.winner-proof dd {
    margin: 0;
    color: var(--text-primary);
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.68rem;
}

.winner-proof p {
    margin: 0;
    padding: 0 10px 10px;
    color: var(--text-muted);
    font-size: 0.76rem;
}

.winner-open-button {
    width: 100%;
}

.winners-empty-state {
    grid-column: 1 / -1;
    min-height: 260px;
    padding: 30px;
    display: grid;
    place-items: center;
    align-content: center;
    gap: 8px;
    color: var(--text-muted);
    background: var(--bg-secondary);
    border: 1px dashed var(--border-soft);
    text-align: center;
}

.winners-empty-state h2,
.winners-empty-state p {
    margin: 0;
}

.winners-empty-state > i {
    color: #f4bd43;
    font-size: 2rem;
}

.winner-history-card.is-loading {
    padding-bottom: 15px;
}

.winner-history-skeleton {
    height: 12px;
    margin: 12px 15px 0;
    background: linear-gradient(
        90deg,
        var(--bg-primary),
        rgba(255, 255, 255, 0.08),
        var(--bg-primary)
    );
    background-size: 200% 100%;
    animation: winnerSkeleton 1.4s linear infinite;
}

.winner-history-skeleton.preview {
    height: auto;
    aspect-ratio: 16 / 9;
    margin: 0;
}

.winner-history-skeleton.title {
    width: 68%;
    height: 18px;
}

@keyframes winnerSkeleton {
    to {
        background-position: -200% 0;
    }
}

/* Mobile and narrow-screen protection. */
@media (max-width: 1180px) {
    .header-inner {
        min-height: 132px;
        grid-template-columns: minmax(220px, 1fr) auto !important;
        grid-template-rows: 44px 44px 36px !important;
        grid-template-areas:
            "brand user"
            "search search"
            "nav nav";
    }

    .header-nav {
        justify-content: flex-start;
        overflow-x: auto;
        scrollbar-width: thin;
    }
}

@media (max-width: 980px) {
    .winners-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 700px) {
    .header-inner {
        padding-inline: 10px;
        gap: 7px;
    }

    .industrial-logo-copy {
        display: none;
    }

    .header-right {
        max-width: calc(100vw - 90px);
    }

    .header-nav .nav-tab {
        min-width: 98px;
        flex: 0 0 auto;
    }

    .page-action-bar,
    .feed-page-header.feed-page-header-actions-only,
    #donatesPage .donates-header.donates-header-actions-only,
    .giveaways-toolbar,
    .winners-toolbar {
        min-height: 54px !important;
        align-items: stretch !important;
        flex-wrap: wrap;
    }

    .feed-page-header .btn,
    #donatesPage .donates-header .btn,
    #donatesPage .donates-header .add-video-btn {
        flex: 1 1 auto;
    }

    .feed-publication-grid,
    .winners-grid {
        grid-template-columns: 1fr;
    }

    .feed-draft-item {
        grid-template-columns: 70px minmax(0, 1fr);
    }

    .feed-draft-preview {
        width: 70px;
    }

    .feed-draft-actions {
        grid-column: 1 / -1;
        justify-content: flex-end;
    }

    .emoji-picker-grid {
        grid-template-columns: repeat(6, minmax(32px, 1fr)) !important;
    }
}

@media (max-width: 460px) {
    .video-card-footer .rating-star {
        width: 22px;
    }

    .winner-proof dl > div {
        grid-template-columns: 1fr;
        gap: 2px;
    }
}
