/**
 * PopRate Custom Scrollbar Theme
 * OverlayScrollbars styling to match app design
 */

/* ========================================
   OVERLAYSCROLLBARS CUSTOM THEME
   ======================================== */

/* Main scrollbar container */
.os-theme-poprate > .os-scrollbar {
    --os-size: 12px;
    --os-padding-perpendicular: 0px;
    --os-padding-axis: 0px;
    --os-track-border-radius: 10px;
    --os-track-bg: rgba(0, 0, 0, 0.2);
    --os-track-bg-hover: rgba(0, 0, 0, 0.25);
    --os-track-bg-active: rgba(0, 0, 0, 0.3);
    --os-handle-border-radius: 10px;
    --os-handle-bg: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    --os-handle-bg-hover: linear-gradient(135deg, #7c8ef7 0%, #8b5fc2 100%);
    --os-handle-bg-active: linear-gradient(135deg, #8c9df9 0%, #9b6fd2 100%);
    --os-handle-min-size: 40px;
    --os-handle-max-size: none;
    --os-handle-perpendicular-size: 100%;
    --os-handle-perpendicular-size-hover: 100%;
    --os-handle-perpendicular-size-active: 100%;
    --os-handle-interactive-area-offset: 0px;
}

/* Vertical scrollbar positioning */
.os-theme-poprate > .os-scrollbar-vertical {
    right: 0;
    width: var(--os-size);
    padding: var(--os-padding-perpendicular) var(--os-padding-axis);
}

/* Horizontal scrollbar positioning */
.os-theme-poprate > .os-scrollbar-horizontal {
    bottom: 0;
    height: var(--os-size);
    padding: var(--os-padding-axis) var(--os-padding-perpendicular);
}

/* Scrollbar track */
.os-theme-poprate > .os-scrollbar > .os-scrollbar-track {
    background: var(--os-track-bg);
    border-radius: var(--os-track-border-radius);
    transition: background 0.3s ease;
}

.os-theme-poprate > .os-scrollbar:hover > .os-scrollbar-track {
    background: var(--os-track-bg-hover);
}

/* Scrollbar handle (thumb) */
.os-theme-poprate > .os-scrollbar > .os-scrollbar-track > .os-scrollbar-handle {
    background: var(--os-handle-bg);
    border-radius: var(--os-handle-border-radius);
    min-height: var(--os-handle-min-size);
    min-width: var(--os-handle-min-size);
    border: 2px solid rgba(0, 0, 0, 0.2);
    transition: background 0.3s ease, transform 0.2s ease;
}

.os-theme-poprate > .os-scrollbar > .os-scrollbar-track > .os-scrollbar-handle:hover {
    background: var(--os-handle-bg-hover);
    transform: scale(1.05);
}

.os-theme-poprate > .os-scrollbar > .os-scrollbar-track > .os-scrollbar-handle:active {
    background: var(--os-handle-bg-active);
    transform: scale(1.1);
}

/* Hide scrollbar when not needed */
.os-theme-poprate.os-scrollbar-auto-hidden > .os-scrollbar {
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}

.os-theme-poprate.os-scrollbar-auto-hidden:hover > .os-scrollbar {
    opacity: 1;
    pointer-events: auto;
}

/* Scrollbar corner (when both scrollbars are visible) */
.os-theme-poprate > .os-scrollbar-corner {
    background: rgba(0, 0, 0, 0.2);
    border-radius: 0 0 10px 0;
}

/* ========================================
   OVERLAYSCROLLBARS VIEWPORT ADJUSTMENTS
   ======================================== */

/* Ensure content isn't clipped */
.os-content {
    min-height: 100vh;
}

/* Fix body padding when OverlayScrollbars is active */
body.os-host {
    padding-top: 70px !important;
}

/* Modern page wrapper shouldn't add extra padding when scrollbar is active */
body.os-host .modern-page-wrapper {
    padding-top: 0 !important;
}

/* Ensure main content area has proper top spacing */
body.os-host main {
    padding-top: 0;
}

/* Fix for Livewire/Jetstream layouts */
body.os-host .min-h-screen {
    padding-top: 0;
}

/* Fix for pages with welcome section after navbar */
body.os-host #welcome {
    margin-top: 0 !important;
}

body.os-host .welcome {
    margin-top: 0 !important;
}

/* ========================================
   REMOVE OLD SCROLLBAR STYLES
   ======================================== */

/* Remove native scrollbar styles when OverlayScrollbars is active */
.os-host {
    overflow: hidden !important;
}

/* Disable native scrollbars */
.os-host::-webkit-scrollbar {
    display: none !important;
}

.os-host {
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
}

/* ========================================
   RESPONSIVE ADJUSTMENTS
   ======================================== */

/* Mobile - thinner scrollbar */
@media (max-width: 768px) {
    .os-theme-poprate > .os-scrollbar {
        --os-size: 8px;
        --os-handle-min-size: 30px;
    }
    
    /* Hide scrollbar on mobile by default, show on scroll */
    .os-theme-poprate > .os-scrollbar {
        opacity: 0;
        transition: opacity 0.3s ease;
    }
    
    .os-theme-poprate.os-host-scrollbar-vertical-visible > .os-scrollbar-vertical,
    .os-theme-poprate.os-host-scrollbar-horizontal-visible > .os-scrollbar-horizontal {
        opacity: 0.5;
    }
    
    .os-theme-poprate:hover > .os-scrollbar {
        opacity: 1;
    }
}

/* Tablet and up - normal scrollbar */
@media (min-width: 769px) {
    .os-theme-poprate > .os-scrollbar {
        --os-size: 12px;
    }
}

/* Desktop - wider scrollbar on hover */
@media (min-width: 1024px) {
    .os-theme-poprate > .os-scrollbar:hover {
        --os-size: 14px;
    }
}

/* ========================================
   ANIMATION & TRANSITIONS
   ======================================== */

/* Smooth scrollbar appearance */
.os-theme-poprate > .os-scrollbar {
    transition: opacity 0.3s ease, width 0.2s ease, height 0.2s ease;
}

/* Smooth handle movement */
.os-theme-poprate > .os-scrollbar > .os-scrollbar-track > .os-scrollbar-handle {
    transition: background 0.3s ease, transform 0.2s ease;
}

/* ========================================
   ACCESSIBILITY
   ======================================== */

/* Ensure scrollbar is visible for keyboard navigation */
.os-theme-poprate:focus-within > .os-scrollbar {
    opacity: 1 !important;
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    .os-theme-poprate > .os-scrollbar > .os-scrollbar-track {
        background: rgba(255, 255, 255, 0.2);
    }
    
    .os-theme-poprate > .os-scrollbar > .os-scrollbar-track > .os-scrollbar-handle {
        background: linear-gradient(135deg, #8899ff 0%, #9966dd 100%);
        border: 3px solid rgba(255, 255, 255, 0.4);
    }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
    .os-theme-poprate > .os-scrollbar,
    .os-theme-poprate > .os-scrollbar > .os-scrollbar-track > .os-scrollbar-handle {
        transition: none !important;
    }
}

/* ========================================
   DARK MODE ADJUSTMENTS
   ======================================== */

@media (prefers-color-scheme: dark) {
    .os-theme-poprate > .os-scrollbar > .os-scrollbar-track {
        background: rgba(0, 0, 0, 0.4);
    }
    
    .os-theme-poprate > .os-scrollbar > .os-scrollbar-track > .os-scrollbar-handle {
        border-color: rgba(0, 0, 0, 0.3);
    }
}
