/* TailwindCSS Configuration - Extracted from inline config */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

/* CSS Custom Properties for Theme Colors */
:root {
    --color-charcoal: #1A1A1A;
    --color-electric-blue: #00B0F0;
    --color-cool-gray: #D1D5DB;
    --color-steel-gray: #2C2C2C;
    --color-cyan-tint: #00CFFF;
    --color-dark-gray: #111111;
    --color-darker-gray: #0A0A0A;
    
    /* Animation durations */
    --duration-fast: 0.2s;
    --duration-normal: 0.3s;
    --duration-slow: 0.8s;
    
    /* Z-index layers */
    --z-header: 1000;
    --z-modal-overlay: 1500;
    --z-glofox-modal: 2000;
    --z-mobile-menu-overlay: 9998;
    --z-mobile-menu: 9999;
}

/* Cross-browser font loading */
@font-face {
    font-family: 'BebasNeue';
    src: url('../BebasNeue-Regular.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Inter';
    font-display: swap;
    src: local('Inter');
}

/* Base styles with cross-browser support */
html {
    scroll-behavior: smooth;
    font-family: 'BebasNeue', 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: transparent;
}

body {
    font-family: 'BebasNeue', 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    letter-spacing: 0.025em; /* Slight letter spacing for BebasNeue readability */
}

/* Custom TailwindCSS-like utility classes */
.text-charcoal { color: var(--color-charcoal); }
.text-electric-blue { color: var(--color-electric-blue); }
.text-cool-gray { color: var(--color-cool-gray); }
.text-steel-gray { color: var(--color-steel-gray); }
.text-cyan-tint { color: var(--color-cyan-tint); }
.text-dark-gray { color: var(--color-dark-gray); }

.bg-charcoal { background-color: var(--color-charcoal); }
.bg-electric-blue { background-color: var(--color-electric-blue); }
.bg-cool-gray { background-color: var(--color-cool-gray); }
.bg-steel-gray { background-color: var(--color-steel-gray); }
.bg-cyan-tint { background-color: var(--color-cyan-tint); }
.bg-dark-gray { background-color: var(--color-dark-gray); }

.border-electric-blue { border-color: var(--color-electric-blue); }
.border-cool-gray { border-color: var(--color-cool-gray); }

/* Gradient utilities */
.gradient-bg {
    background: linear-gradient(135deg, var(--color-charcoal) 0%, var(--color-steel-gray) 100%);
}

.gradient-text {
    background: linear-gradient(135deg, var(--color-electric-blue), var(--color-cyan-tint));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    /* Fallback for browsers that don't support background-clip */
    color: var(--color-electric-blue);
}

.gradient-primary {
    background: linear-gradient(to right, var(--color-electric-blue), var(--color-cyan-tint)) !important;
    border: none !important;
    color: white !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
    overflow: hidden !important;
    -webkit-user-select: none !important;
    -moz-user-select: none !important;
    user-select: none !important;
    cursor: pointer !important;
    touch-action: manipulation !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
}

/* Enhanced button styling - FIXED TRANSPARENT BUTTONS */
.join-btn,
.gradient-primary,
button.gradient-primary,
.mobile-book-btn {
    background: linear-gradient(to right, var(--color-electric-blue), var(--color-cyan-tint)) !important;
    border: none !important;
    color: white !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
    overflow: hidden !important;
    cursor: pointer !important;
    transition: all var(--duration-normal) ease !important;
    box-shadow: 0 4px 15px rgba(0, 176, 240, 0.3) !important;
    -webkit-user-select: none !important;
    -moz-user-select: none !important;
    user-select: none !important;
    touch-action: manipulation !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    min-height: 44px !important; /* Touch-friendly size */
}

.join-btn:hover,
.gradient-primary:hover,
button.gradient-primary:hover,
.mobile-book-btn:hover {
    transform: scale(1.05) !important;
    box-shadow: 0 6px 20px rgba(0, 176, 240, 0.4) !important;
    background: linear-gradient(to right, var(--color-cyan-tint), var(--color-electric-blue)) !important;
}

.join-btn:active,
.gradient-primary:active,
button.gradient-primary:active,
.mobile-book-btn:active {
    transform: scale(0.98) !important;
    transition: transform 0.1s ease !important;
}

/* Cross-browser button focus states */
.join-btn:focus,
.gradient-primary:focus,
button.gradient-primary:focus,
.mobile-book-btn:focus {
    outline: 2px solid var(--color-electric-blue) !important;
    outline-offset: 2px !important;
}

/* Transition utilities */
.transition-fast { transition: all var(--duration-fast) ease; }
.transition-normal { transition: all var(--duration-normal) ease; }
.transition-slow { transition: all var(--duration-slow) ease; }

/* Animation keyframes */
@keyframes fadeIn {
    0% { opacity: 0; transform: translateY(20px); }
    100% { opacity: 1; transform: translateY(0); }
}

@keyframes slideUp {
    0% { opacity: 0; transform: translateY(40px); }
    100% { opacity: 1; transform: translateY(0); }
}

@keyframes float {
    0%, 100% { transform: translateY(0px); }
    50% { transform: translateY(-20px); }
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Animation utility classes */
.animate-fade-in {
    animation: fadeIn 0.6s ease-out forwards;
}

.animate-slide-up {
    animation: slideUp 0.8s ease-out forwards;
}

.animate-float {
    animation: float 6s ease-in-out infinite;
}

.animate-pulse-slow {
    animation: pulse 3s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

.animate-spin {
    animation: spin 1s linear infinite;
}

/* Cross-browser compatibility fixes */

/* iOS Safari fixes */
@supports (-webkit-touch-callout: none) {
    .join-btn,
    .gradient-primary,
    .mobile-book-btn {
        -webkit-tap-highlight-color: transparent !important;
        -webkit-user-select: none !important;
        -webkit-appearance: none !important;
    }
}

/* Firefox fixes */
@-moz-document url-prefix() {
    .join-btn,
    .gradient-primary,
    .mobile-book-btn {
        -moz-appearance: none !important;
    }
}

/* Edge/IE fixes */
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
    .join-btn,
    .gradient-primary,
    .mobile-book-btn {
        background: var(--color-electric-blue) !important;
    }
} 