/* ClockWise - Global Time Zone Dashboard Styles */

@layer base {
    body {
        background: linear-gradient(135deg, #0f172a 0%, #1e1b4b 50%, #312e81 100%);
        background-attachment: fixed;
    }
}

.glass-panel {
    @apply bg-white/10 dark:bg-black/40 backdrop-blur-xl border border-white/10 shadow-2xl;
}

.glass-button {
    @apply bg-white/5 backdrop-blur-md border border-white/10 hover:bg-white/10 transition-all duration-300;
}

/* Custom Scrollbar */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(255, 255, 255, 0.15); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: rgba(255, 255, 255, 0.25); }

/* Range Slider Styling */
input[type=range] {
    -webkit-appearance: none; 
    background: transparent;
    touch-action: pan-y; 
    margin: 0;
    padding: 0;
    pointer-events: none;
}
input[type=range]::-webkit-slider-thumb {
    -webkit-appearance: none;
    height: 128px; 
    width: 40px;
    cursor: grab;
    background: transparent;
    border: none;
    pointer-events: auto;
}
input[type=range]::-moz-range-thumb {
    height: 128px;
    width: 40px;
    cursor: grab;
    background: transparent;
    border: none;
    pointer-events: auto;
}
input[type=range]:active::-webkit-slider-thumb {
    cursor: grabbing;
}
input[type=range]:active::-moz-range-thumb {
    cursor: grabbing;
}

/* Touch Device Styles */
@media (hover: none) {
    .delete-btn { opacity: 0.4 !important; }
}

.smooth-marker {
    will-change: transform; 
    transform: translateZ(0);
}

/* SortableJS Styles */
.sortable-ghost {
    opacity: 0.5;
    background: rgba(0, 0, 0, 0.2); 
    border: 1px dashed rgba(255,255,255,0.2);
}
.sortable-drag {
    opacity: 1 !important;
    background: #1e1b4b; 
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.5), 0 10px 10px -5px rgba(0, 0, 0, 0.4);
    cursor: grabbing;
    transform: scale(1.02);
    z-index: 9999;
}
.city-row {
    transition: background-color 0.3s ease;
}
.drag-handle {
    cursor: grab;
    touch-action: none; 
}
.drag-handle:active {
    cursor: grabbing;
}

/* Button Transition Classes */
.btn-enter {
    max-width: 150px;
    padding-left: 0;
    padding-right: 0;
    opacity: 1;
    transform: scale(1);
}
.btn-exit {
    max-width: 0;
    padding-left: 0;
    padding-right: 0;
    opacity: 0;
    transform: scale(0.95);
    margin: 0 !important;
}

/* Badge Animations */
@keyframes badge-in {
    0% { opacity: 0; transform: translateY(5px) scale(0.9); }
    100% { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes badge-out {
    0% { opacity: 1; transform: scale(1); }
    100% { opacity: 0; transform: scale(0.9); }
}

.badge-pop {
    animation: badge-in 0.3s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
    transform-origin: center left;
}
.badge-exit {
    animation: badge-out 0.2s ease-in forwards;
    transform-origin: center left;
    pointer-events: none;
}