/* ============================================================
   MO:ST Social Media Dashboard - Custom Styles
   ============================================================ */

/* Branding CSS Custom Properties */
:root {
    --brand-primary: #de1200;
    --brand-secondary: #b50f00;
    --brand-light: #f03020;
    --brand-gray: #f8f9fa;
    --brand-text: #0c0c0c;
    --brand-light-gray: #e9ecef;
}

/* Tailwind-kompatible Branding-Farben */
.bg-brand-primary { background-color: var(--brand-primary); }
.bg-brand-secondary { background-color: var(--brand-secondary); }
.text-brand-primary { color: var(--brand-primary); }
.text-brand-secondary { color: var(--brand-secondary); }
.border-brand-primary { border-color: var(--brand-primary); }
.border-brand-secondary { border-color: var(--brand-secondary); }
.ring-brand-primary { --tw-ring-color: var(--brand-primary); }
.hover\:bg-brand-primary:hover { background-color: var(--brand-primary); }
.hover\:bg-brand-secondary:hover { background-color: var(--brand-secondary); }
.hover\:text-brand-primary:hover { color: var(--brand-primary); }
.hover\:text-brand-secondary:hover { color: var(--brand-secondary); }
.hover\:border-brand-primary:hover { border-color: var(--brand-primary); }
.bg-brand-primary\/5 { background-color: color-mix(in srgb, var(--brand-primary) 5%, transparent); }
.bg-brand-primary\/10 { background-color: color-mix(in srgb, var(--brand-primary) 10%, transparent); }
.bg-brand-primary\/15 { background-color: color-mix(in srgb, var(--brand-primary) 15%, transparent); }
.bg-brand-secondary\/10 { background-color: color-mix(in srgb, var(--brand-secondary) 10%, transparent); }
.ring-brand-primary\/30 { --tw-ring-color: color-mix(in srgb, var(--brand-primary) 30%, transparent); }

/* Text-Selection in Brand-Farbe */
::selection {
    background-color: var(--brand-primary);
    color: #fff;
}

/* Custom Scrollbar in Brand-Farbe */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--brand-gray); }
::-webkit-scrollbar-thumb { background: color-mix(in srgb, var(--brand-primary) 40%, transparent); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--brand-primary); }

/* Header-Akzentlinie oben */
#main-header::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--brand-primary), var(--brand-secondary));
}

/* Login-Hintergrund mit Brand-Gradient */
#login-section {
    background: linear-gradient(135deg, color-mix(in srgb, var(--brand-primary) 8%, #f8f9fa), color-mix(in srgb, var(--brand-secondary) 5%, #f8f9fa));
}
#login-section .bg-white {
    border-top: 3px solid var(--brand-primary);
}

/* Video-Cards */
.video-card {
    transition: all 0.3s ease;
    height: 100%;
    display: flex;
    flex-direction: column;
    border: 2px solid transparent;
}
.video-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 20px 25px -5px color-mix(in srgb, var(--brand-primary) 15%, transparent),
                0 10px 10px -5px color-mix(in srgb, var(--brand-primary) 8%, transparent);
    border-color: color-mix(in srgb, var(--brand-primary) 30%, transparent);
}

/* Section-Überschriften mit Brand-Akzent */
[data-section] > h2 {
    padding-bottom: 0.75rem;
    border-bottom: 2px solid color-mix(in srgb, var(--brand-primary) 20%, transparent);
}

/* Video-Container */
.video-container {
    position: relative;
    background: #000;
    border-radius: 12px;
    overflow: hidden;
    flex-shrink: 0;
}
.video-container img,
.video-container video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    vertical-align: top;
}

/* Status-Badges */
.status-approved { background: linear-gradient(135deg, #22c55e, #16a34a); }
.status-pending { background: linear-gradient(135deg, var(--brand-primary), var(--brand-secondary)); }
.status-rejected { background: linear-gradient(135deg, #ef4444, #dc2626); }

/* Card-Content */
.card-content {
    padding: 1rem;
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

/* Smooth Scroll */
.smooth-scroll { scroll-behavior: smooth; }

/* Caption-Truncation */
.line-clamp-1 {
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.line-clamp-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.line-clamp-3 {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.caption-full {
    white-space: pre-wrap;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

/* Grid Alignment */
#posts-grid {
    align-items: start;
}
#posts-grid > div {
    align-self: stretch;
    vertical-align: top;
}

/* Welcome-Gradient (GSAP-Animation Target) */
.welcome-gradient {
    background: linear-gradient(135deg, var(--brand-primary), var(--brand-secondary));
}

/* Mobile Optimizations */
@media (max-width: 768px) {
    .video-card:hover {
        transform: none;
    }
    .video-card:active {
        transform: scale(0.98);
    }
    button:active {
        transform: scale(0.95);
    }
    /* Client-Switcher auf Mobil verstecken (ist im Mobile-Menu separat) */
    #client-switcher {
        display: none !important;
    }
}

/* Modal Overlay */
.modal-overlay {
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(4px);
}

/* Active Navigation */
[data-nav].active {
    font-weight: 700;
    border-bottom: 3px solid var(--brand-primary);
    padding-bottom: 4px;
}

/* Mobile Menu Brand-Akzent */
#mobile-menu {
    border-top: 2px solid var(--brand-primary);
}
#mobile-menu a.active {
    background-color: color-mix(in srgb, var(--brand-primary) 10%, transparent);
    border-radius: 0.5rem;
    padding: 0.5rem 0.75rem;
}

/* Sort-Modus Drag-Hover */
.drag-over {
    ring: 2px;
    ring-color: var(--brand-primary);
}
