/**
 * Custom Styles - Replica esatta del prototipo HTML
 *
 * @package Totaliweb_Bus_Tour
 * @since 1.0.0
 */

/* Font Family */
body {
    font-family: 'Poppins', sans-serif;
    background-color: #F0F4F6;
}

/* Hero Gradient */
.hero-gradient {
    background: linear-gradient(rgba(0,0,0,0.3), rgba(0,0,0,0.6));
}

/* Keep navbar pinned and respect WordPress admin bar */
#navbar {
    top: 0;
    left: 0;
    right: 0;
}

.admin-bar #navbar {
    top: 32px;
}

@media (max-width: 782px) {
    .admin-bar #navbar {
        top: 46px;
    }
}

/* Glass Panel Effect */
.glass-panel {
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
}

/* Hide Scrollbar for Gallery */
.hide-scrollbar::-webkit-scrollbar {
    display: none;
}
.hide-scrollbar {
    -ms-overflow-style: none;
    scrollbar-width: none;
}

/* CRITICAL: Remove ALL WordPress default link styles */
/* Exclude buttons with background colors from color inheritance */
a:not([class*="bg-"]) {
    text-decoration: none !important;
    border: none !important;
    color: inherit !important;
}

a {
    text-decoration: none !important;
    border: none !important;
}

a:hover,
a:focus,
a:active,
a:visited {
    text-decoration: none !important;
    border: none !important;
}

/* Remove WordPress default borders from images */
img {
    border: none !important;
}

/* Ensure smooth scrolling */
html {
    scroll-behavior: smooth;
}

/* Line Clamp Utilities */
.line-clamp-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/*
 * Safety reset: remove unexpected inline backgrounds injected by
 * editors/plugins so headings and text never show green rectangles.
 * Preserve intentional utility backgrounds (bg-*) used for badges/cards.
 */
:where(body) :is(h1, h2, h3, h4, h5, h6, p, li, span, small, strong, em, b, i, u, mark, a):not([class*="bg-"]) {
    background-color: transparent !important;
    background-image: none !important;
}

/* Extend safety reset to structural wrappers that may receive unwanted highlights */
/* IMPORTANT: Never remove backgrounds from elements with gradient classes or hero-gradient */
/* IMPORTANT: Exclude flatpickr calendar elements to preserve their backgrounds */
:where(body) :is(div, section, article, aside, header, footer, nav):not([class*="bg-"]):not([class*="has-"]):not([class*="gradient"]):not([class*="flatpickr"]):not(.flatpickr-calendar):not(.flatpickr-innerContainer):not(.flatpickr-rContainer):not(.flatpickr-days):not(.dayContainer):not(.glass-panel):not(.hero-gradient) {
    background-color: transparent !important;
    background-image: none !important;
}

/* Restore flatpickr calendar base surfaces to solid white so day cells sit on opaque panels */
/* CRITICAL: These rules must have !important to override the global reset at line 103 */
.flatpickr-calendar,
.flatpickr-innerContainer,
.flatpickr-rContainer,
.flatpickr-days,
.dayContainer,
.flatpickr-wrapper,
.flatpickr-month,
.flatpickr-current-month,
div.flatpickr-calendar,
.flatpickr-calendar > div,
.flatpickr-calendar div,
.flatpickr-innerContainer > div,
div.dayContainer {
    background-color: #ffffff !important;
    background-image: none !important;
    opacity: 1 !important;
}

/* Hide scroll-to-top button completely */
#scroll-to-top {
    display: none !important;
}

/* Button in CTA should be white with green text - prototype match */
.cta-button-white {
    background-color: #ffffff !important;
    color: #16a34a !important;
    border: 1px solid rgba(226, 232, 240, 0.9);
    box-shadow: 0 10px 30px rgba(22, 163, 74, 0.14);
    transition: background-color 200ms ease, color 200ms ease, transform 200ms ease;
}

.cta-button-white:hover {
    background-color: #f1f5f9 !important;
    color: #16a34a !important;
}

/* Footer visual refinements */
.footer-links a {
    position: relative;
    display: inline-block;
    color: inherit !important;
    transition: color 250ms ease, transform 250ms ease;
}

.footer-links a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -2px;
    width: 0;
    height: 1px;
    background: #16a34a;
    transition: width 250ms ease, opacity 250ms ease;
    opacity: 0.7;
}

.footer-links a:hover {
    color: #16a34a !important;
}

.footer-links a:hover::after {
    width: 100%;
    opacity: 1;
}

.footer-social {
    justify-content: center;
    gap: 12px;
}

.footer-social a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 8px;
    color: rgba(226, 232, 240, 0.8) !important;
    transition: transform 220ms ease, color 250ms ease, filter 250ms ease;
}

.footer-social a:hover {
    transform: translateY(-3px);
    color: #e2e8f0 !important;
    filter: drop-shadow(0 8px 18px rgba(52, 211, 153, 0.16));
}

.footer-social svg {
    width: 24px;
    height: 24px;
}

@media (max-width: 640px) {
    .footer-social {
        gap: 10px;
    }
}

/* ====================================================
   Flatpickr Custom Styling for Booking Calendar
   ==================================================== */

/* Flatpickr container styling */
.flatpickr-calendar {
    background: #ffffff !important;
    background-color: #ffffff !important;
    background-image: none !important;
    border-radius: 1rem;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
    border: 1px solid #e2e8f0;
    font-family: 'Poppins', sans-serif;
    padding: 0.5rem;
    z-index: 9999 !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* Ensure calendar is always visible when open */
.flatpickr-calendar.open {
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* Ensure calendar has proper positioning */
.flatpickr-calendar.inline {
    position: relative;
    top: auto !important;
    left: auto !important;
}

.flatpickr-calendar:not(.inline) {
    position: absolute !important;
}

/* Month header styling */
.flatpickr-months {
    background: #f8fafc !important;
    background-color: #f8fafc !important;
    background-image: none !important;
    border-radius: 0.75rem 0.75rem 0 0;
    padding: 0.75rem 0.5rem;
}

.flatpickr-current-month {
    color: #1e293b;
    font-weight: 600;
    font-size: 1.1rem;
}

/* Navigation arrows */
.flatpickr-prev-month,
.flatpickr-next-month {
    fill: #64748b;
    transition: fill 0.2s ease;
}

.flatpickr-prev-month:hover,
.flatpickr-next-month:hover {
    fill: #16a34a;
}

/* Weekdays */
.flatpickr-weekdays {
    background: #f8fafc !important;
    background-color: #f8fafc !important;
    background-image: none !important;
    margin-top: 0.5rem;
}

.flatpickr-weekday {
    color: #64748b;
    font-weight: 600;
    font-size: 0.875rem;
}

/* Day cells */
.flatpickr-day {
    border-radius: 0.5rem;
    font-weight: 500;
    border: none;
    transition: all 0.2s ease;
}

/* Hover effect for available dates */
.flatpickr-day:hover:not(.flatpickr-disabled) {
    transform: scale(1.1);
    box-shadow: 0 4px 12px rgba(22, 163, 74, 0.3);
}

/* Selected date */
.flatpickr-day.selected {
    background: #16a34a !important;
    color: #ffffff !important;
    font-weight: 700;
    border: 2px solid #15803d;
    box-shadow: 0 4px 16px rgba(22, 163, 74, 0.4);
}

/* Today's date */
.flatpickr-day.today {
    border: 2px solid #16a34a;
}

/* Disabled dates (past dates) */
.flatpickr-day.flatpickr-disabled {
    background-color: #f1f5f9;
    color: #cbd5e1;
    cursor: not-allowed;
    opacity: 0.5;
}

/* Input field styling when flatpickr is active */
#booking-date.flatpickr-input {
    display: none !important;
}

/* AltInput styling (visible input field created by flatpickr) */
/* IMPORTANT: Must use white background to ensure proper visibility */
.flatpickr-input[readonly].form-control.input,
input.flatpickr-input.form-control[readonly],
input[readonly].flatpickr-input,
input.flatpickr-input[readonly],
.flatpickr-input.form-control.input,
input[type="text"].flatpickr-input {
    cursor: pointer !important;
    background-color: #ffffff !important;
    user-select: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    border: 1px solid #e2e8f0 !important;
    border-radius: 0.75rem !important;
    padding: 0.75rem 1rem !important;
    color: #334155 !important;
    font-weight: 500 !important;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05) !important;
    transition: all 0.2s ease !important;
}

/* Hardening: keep the booking date field opaque even when global resets run */
.booking-date-input.flatpickr-input,
.flatpickr-wrapper .booking-date-input,
.flatpickr-wrapper input.booking-date-input,
.flatpickr-wrapper input.flatpickr-input.booking-date-input,
#booking-date,
input#booking-date,
.booking-date-input,
input.booking-date-input {
    background-color: #ffffff !important;
    background-image: none !important;
    border: 1px solid #e2e8f0 !important;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05) !important;
    color: #334155 !important;
    opacity: 1 !important;
}

.booking-date-input.flatpickr-input::placeholder {
    color: #94a3b8 !important;
    opacity: 1;
}

.booking-date-input.flatpickr-input:disabled {
    background-color: #f8fafc !important;
    color: #94a3b8 !important;
}

/* Hover state for better UX */
input.flatpickr-input[readonly]:hover,
input[type="text"].flatpickr-input:hover {
    border-color: #16a34a !important;
    box-shadow: 0 0 0 2px rgba(22, 163, 74, 0.1) !important;
}

/* Focus state */
input.flatpickr-input[readonly]:focus,
input[type="text"].flatpickr-input:focus {
    outline: none !important;
    border-color: #16a34a !important;
    box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.15) !important;
}

/* Additional styling for the wrapper */
.flatpickr-wrapper {
    display: block !important;
    width: 100%;
}

.flatpickr-wrapper input[readonly] {
    cursor: pointer !important;
}

/* Mobile responsiveness improvements */
@media (max-width: 768px) {
    /* Ensure altInput is properly sized on mobile */
    input.flatpickr-input[readonly],
    input[type="text"].flatpickr-input {
        font-size: 16px !important; /* Prevent zoom on iOS */
        min-height: 48px !important; /* Better touch target */
        padding: 0.875rem 1rem !important;
    }

    .flatpickr-calendar {
        width: 90vw !important;
        max-width: 340px;
        left: 50% !important;
        transform: translateX(-50%);
        margin-top: 0.5rem;
    }

    .flatpickr-day {
        height: 40px !important;
        line-height: 40px !important;
        max-width: 40px !important;
    }

    .flatpickr-months {
        padding: 0.5rem;
    }

    .flatpickr-current-month {
        font-size: 1rem;
    }
}

/* Tablet responsiveness */
@media (min-width: 768px) and (max-width: 1024px) {
    input.flatpickr-input[readonly],
    input[type="text"].flatpickr-input {
        font-size: 15px !important;
        padding: 0.75rem 1rem !important;
    }
}

/* Prevent body scroll when calendar is open on mobile */
body.flatpickr-mobile-active {
    overflow: hidden;
}

/* Ensure proper stacking context */
.flatpickr-wrapper {
    position: relative;
    display: block;
}

/* Fix for calendar appearing behind modal or overlay elements */
.flatpickr-calendar.arrowTop::before,
.flatpickr-calendar.arrowTop::after {
    border-bottom-color: #ffffff !important;
}

/* Comprehensive catch-all: ensure NO flatpickr element has transparent background */
[class*="flatpickr"]:not(.flatpickr-day):not(.flatpickr-prev-month):not(.flatpickr-next-month):not(.flatpickr-weekday),
.flatpickr-calendar *:not(.flatpickr-day):not(.flatpickr-prev-month):not(.flatpickr-next-month):not(.flatpickr-weekday):not(svg):not(path):not(span.flatpickr-weekday):not(.numInputWrapper) {
    background-image: none !important;
}

/* Ensure the main calendar container and all major sections have solid backgrounds */
.flatpickr-calendar,
.flatpickr-calendar .flatpickr-innerContainer,
.flatpickr-calendar .flatpickr-rContainer {
    background: #ffffff !important;
    background-color: #ffffff !important;
}

/* Improve touch targets for mobile */
@media (hover: none) and (pointer: coarse) {
    .flatpickr-day {
        min-height: 44px;
        min-width: 44px;
        line-height: 44px;
    }

    .flatpickr-prev-month,
    .flatpickr-next-month {
        padding: 12px;
    }
}
