@tailwind base;
@tailwind components;
@tailwind utilities;

body {
    margin: 0;
    font-family:
        -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen",
        "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue",
        sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

code {
    font-family:
        source-code-pro, Menlo, Monaco, Consolas, "Courier New", monospace;
}

@layer base {
    :root {
        --background: 0 0% 100%;
        --foreground: 0 0% 3.9%;
        --card: 0 0% 100%;
        --card-foreground: 0 0% 3.9%;
        --popover: 0 0% 100%;
        --popover-foreground: 0 0% 3.9%;
        --primary: 0 0% 9%;
        --primary-foreground: 0 0% 98%;
        --secondary: 0 0% 96.1%;
        --secondary-foreground: 0 0% 9%;
        --muted: 0 0% 96.1%;
        --muted-foreground: 0 0% 45.1%;
        --accent: 0 0% 96.1%;
        --accent-foreground: 0 0% 9%;
        --destructive: 0 84.2% 60.2%;
        --destructive-foreground: 0 0% 98%;
        --border: 0 0% 89.8%;
        --input: 0 0% 89.8%;
        --ring: 0 0% 3.9%;
        --chart-1: 12 76% 61%;
        --chart-2: 173 58% 39%;
        --chart-3: 197 37% 24%;
        --chart-4: 43 74% 66%;
        --chart-5: 27 87% 67%;
        --radius: 0.5rem;
    }
    .dark {
        --background: 0 0% 3.9%;
        --foreground: 0 0% 98%;
        --card: 0 0% 3.9%;
        --card-foreground: 0 0% 98%;
        --popover: 0 0% 3.9%;
        --popover-foreground: 0 0% 98%;
        --primary: 0 0% 98%;
        --primary-foreground: 0 0% 9%;
        --secondary: 0 0% 14.9%;
        --secondary-foreground: 0 0% 98%;
        --muted: 0 0% 14.9%;
        --muted-foreground: 0 0% 63.9%;
        --accent: 0 0% 14.9%;
        --accent-foreground: 0 0% 98%;
        --destructive: 0 62.8% 30.6%;
        --destructive-foreground: 0 0% 98%;
        --border: 0 0% 14.9%;
        --input: 0 0% 14.9%;
        --ring: 0 0% 83.1%;
        --chart-1: 220 70% 50%;
        --chart-2: 160 60% 45%;
        --chart-3: 30 80% 55%;
        --chart-4: 280 65% 60%;
        --chart-5: 340 75% 55%;
    }
}

@layer base {
    * {
        @apply border-border;
    }
    body {
        @apply bg-background text-foreground;
    }
    
    /* Consistent Typography System */
    h1 {
        @apply text-4xl md:text-5xl lg:text-6xl font-bold leading-tight;
    }
    
    h2 {
        @apply text-3xl md:text-4xl lg:text-5xl font-bold leading-tight;
    }
    
    h3 {
        @apply text-2xl md:text-3xl font-bold leading-snug;
    }
    
    h4 {
        @apply text-xl md:text-2xl font-bold leading-snug;
    }
    
    h5 {
        @apply text-lg md:text-xl font-bold leading-normal;
    }
    
    h6 {
        @apply text-base md:text-lg font-bold leading-normal;
    }
    
    p {
        @apply text-base md:text-lg leading-relaxed;
    }
    
    /* Small text */
    .text-small {
        @apply text-sm md:text-base;
    }
}

@layer base {
    [data-debug-wrapper="true"] {
        display: contents !important;
    }

    [data-debug-wrapper="true"] > * {
        margin-left: inherit;
        margin-right: inherit;
        margin-top: inherit;
        margin-bottom: inherit;
        padding-left: inherit;
        padding-right: inherit;
        padding-top: inherit;
        padding-bottom: inherit;
        column-gap: inherit;
        row-gap: inherit;
        gap: inherit;
        border-left-width: inherit;
        border-right-width: inherit;
        border-top-width: inherit;
        border-bottom-width: inherit;
        border-left-style: inherit;
        border-right-style: inherit;
        border-top-style: inherit;
        border-bottom-style: inherit;
        border-left-color: inherit;
        border-right-color: inherit;
        border-top-color: inherit;
        border-bottom-color: inherit;
    }
}


/* Custom scrollbar styles for pricing boxes */
.pricing-scrollbar::-webkit-scrollbar {
    width: 8px;
}

.pricing-scrollbar::-webkit-scrollbar-track {
    background: transparent;
}

.pricing-scrollbar::-webkit-scrollbar-thumb {
    background-color: rgba(192, 57, 43, 0.2);
    border-radius: 4px;
}

.pricing-scrollbar::-webkit-scrollbar-thumb:hover {
    background-color: rgba(192, 57, 43, 0.4);
}

/* Firefox scrollbar */
.pricing-scrollbar {
    scrollbar-width: thin;
    scrollbar-color: rgba(192, 57, 43, 0.2) transparent;
}


/* Swiper Pagination Styles */
.swiper-pagination-bullet {
    background: #7F8C8D !important;
    opacity: 0.5 !important;
}

.swiper-pagination-bullet-active {
    background: #C0392B !important;
    opacity: 1 !important;
}

/* ====================================== */
/* Slider Styles */
/* ====================================== */

/* Benefits Slider */
.benefits-slider-wrapper {
    position: relative;
    width: 100%;
}

.benefits-slider-track {
    display: flex;
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    cursor: grab;
    user-select: none;
}

.benefits-slider-track:active {
    cursor: grabbing;
}

.benefit-slide {
    flex-shrink: 0;
    box-sizing: border-box;
}

/* Testimonial Slider */
.testimonial-slider-wrapper {
    position: relative;
    width: 100%;
}

.testimonial-slider-track {
    display: flex;
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    cursor: grab;
    user-select: none;
}

.testimonial-slider-track:active {
    cursor: grabbing;
}

.testimonial-slide {
    flex-shrink: 0;
    width: 100%;
    box-sizing: border-box;
}

/* Navigation Buttons */
.benefits-prev,
.benefits-next,
.testimonial-prev,
.testimonial-next {
    transition: all 0.3s ease;
    z-index: 10;
}

.benefits-prev:hover,
.benefits-next:hover,
.testimonial-prev:hover,
.testimonial-next:hover {
    transform: scale(1.1) !important;
    box-shadow: 0 10px 25px rgba(192, 57, 43, 0.3);
}

.benefits-prev:active,
.benefits-next:active,
.testimonial-prev:active,
.testimonial-next:active {
    transform: scale(0.95) !important;
}

/* Dots Navigation */
.benefits-dots,
.testimonial-dots {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.5rem;
    margin-top: 2rem;
}

.slider-dot {
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    border: none;
    outline: none;
}

.slider-dot:hover {
    transform: scale(1.2);
}

.slider-dot:focus {
    outline: 2px solid rgba(192, 57, 43, 0.5);
    outline-offset: 2px;
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .benefit-slide {
        margin-bottom: 1rem;
    }
    
    /* Hide navigation arrows on mobile for cleaner look */
    .benefits-prev,
    .benefits-next {
        display: none !important;
    }
    
    /* Keep testimonial arrows on mobile */
    .testimonial-prev,
    .testimonial-next {
        transform: translateY(-50%) translateX(0) !important;
        position: absolute;
    }
    
    .testimonial-prev {
        left: 0.5rem;
    }
    
    .testimonial-next {
        right: 0.5rem;
    }
}

@media (min-width: 769px) {
    /* Show navigation arrows on desktop */
    .benefits-prev,
    .benefits-next {
        display: flex !important;
    }
}

/* Smooth touch scrolling */
.benefits-slider-track,
.testimonial-slider-track {
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
}

/* Disable text selection while dragging */
.benefits-slider-track *,
.testimonial-slider-track * {
    user-select: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
}
