/**
 * BOOKING FORM - PANEL & COUPON IMPROVEMENTS V2
 * Clean, professional, no emojis, no yellow in panels
 */

/* ========== OPTION PANEL - PROFESSIONAL REDESIGN ========== */
.option-panel {
    background: var(--white) !important;
    border: 2px solid var(--gray-200) !important;
    border-radius: var(--radius-lg) !important;
    margin: 24px 0 !important;
    box-shadow: var(--shadow-sm) !important;
    overflow: hidden !important;
    transition: all 0.3s ease !important;
}

/* HIDDEN STATE for option-panel */
.option-panel.hidden {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    max-height: 0 !important;
    margin: 0 !important;
}

.option-panel:hover {
    border-color: var(--gray-300) !important;
    box-shadow: var(--shadow-md) !important;
}

.option-panel.active {
    border-color: var(--dark) !important;
    box-shadow: 0 8px 32px rgba(26, 26, 46, 0.15) !important;
    transform: translateY(-2px) !important;
}

/* Header - Clean Dark Design */
.option-panel__header {
    background: linear-gradient(135deg, var(--dark) 0%, var(--dark-light) 100%) !important;
    padding: 20px 28px !important;
    border-radius: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    position: relative !important;
    overflow: hidden !important;
    border-bottom: 3px solid rgba(255, 255, 255, 0.1) !important;
}

.option-panel.active .option-panel__header {
    background: linear-gradient(135deg, var(--dark) 0%, #0f0f1e 100%) !important;
    border-bottom-color: var(--primary) !important;
}

/* Override any blue colors for all panels - use dark theme consistently */
#return-trip-container .option-panel__header,
#commentCard .option-panel__header,
#stopoverCard .option-panel__header,
#couponCard .option-panel__header {
    background: linear-gradient(135deg, var(--dark) 0%, var(--dark-light) 100%) !important;
    color: var(--white) !important;
}

#return-trip-container.active .option-panel__header,
#commentCard.active .option-panel__header,
#stopoverCard.active .option-panel__header,
#couponCard.active .option-panel__header {
    background: linear-gradient(135deg, var(--dark) 0%, #0f0f1e 100%) !important;
    border-bottom-color: var(--primary) !important;
}

/* Remove any blue background from return container */
#return-trip-container,
#return-trip-container.active {
    background: var(--white) !important;
}

/* Subtle pattern overlay */
.option-panel__header::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: repeating-linear-gradient(
        45deg,
        transparent,
        transparent 10px,
        rgba(255, 255, 255, 0.02) 10px,
        rgba(255, 255, 255, 0.02) 20px
    ) !important;
    pointer-events: none !important;
    z-index: 1 !important;
    display: block !important;
}

.option-panel__header::after {
    display: none !important;
}

/* Title */
.option-panel__title {
    color: var(--white) !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    position: relative !important;
    z-index: 2 !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    letter-spacing: -0.01em !important;
}

.option-panel__title::before {
    content: '' !important;
    width: 4px !important;
    height: 20px !important;
    background: var(--white) !important;
    border-radius: 2px !important;
    opacity: 0.4 !important;
    transition: all 0.3s ease !important;
}

.option-panel.active .option-panel__title::before {
    background: var(--primary) !important;
    opacity: 1 !important;
    height: 24px !important;
}

/* Close Button */
.option-panel__close {
    background: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 6px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    z-index: 2 !important;
    position: relative !important;
    padding: 0 !important;
    font-size: 18px !important;
}

/* Add × symbol if no image */
.option-panel__close:empty::before {
    content: '×' !important;
    color: var(--white) !important;
    font-size: 22px !important;
    font-weight: 300 !important;
    line-height: 1 !important;
}

.option-panel__close:hover {
    background: rgba(255, 255, 255, 0.2) !important;
    border-color: rgba(255, 255, 255, 0.4) !important;
    transform: rotate(90deg) !important;
}

.option-panel.active .option-panel__close {
    background: rgba(255, 193, 7, 0.2) !important;
    border-color: var(--primary) !important;
}

.option-panel.active .option-panel__close:hover {
    background: var(--primary) !important;
    border-color: var(--primary) !important;
}

.option-panel__close img,
.option-panel__close svg {
    width: 14px !important;
    height: 14px !important;
    filter: brightness(10) !important;
}

/* If img is missing, use icon */
.option-panel__close img[src=""],
.option-panel__close img:not([src]) {
    display: none !important;
}

/* Content */
.option-panel__content {
    padding: 28px !important;
    background: var(--white) !important;
}

.option-panel.active .option-panel__content {
    background: linear-gradient(to bottom, rgba(255, 193, 7, 0.02), var(--white)) !important;
}

/* Footer */
.option-panel__footer {
    background: var(--gray-50) !important;
    padding: 18px 28px !important;
    border-top: 1px solid var(--gray-200) !important;
    border-radius: 0 !important;
}

.option-panel.active .option-panel__footer {
    background: linear-gradient(to top, rgba(255, 193, 7, 0.03), var(--gray-50)) !important;
    border-top-color: rgba(255, 193, 7, 0.2) !important;
}

.helper-text {
    font-size: 13px !important;
    color: var(--text-light) !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    line-height: 1.5 !important;
}

.helper-text::before {
    content: 'ⓘ' !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--primary) !important;
}

/* ========== COUPON SECTION - CLEAN REDESIGN ========== */
#couponCard {
    background: var(--white) !important;
    border: 2px solid var(--gray-200) !important;
    border-radius: var(--radius-lg) !important;
    padding: 0 !important;
    margin: 16px 0 !important;
    overflow: hidden !important;
    box-shadow: var(--shadow-sm) !important;
    transition: all 0.3s ease !important;
}

#couponCard:hover {
    border-color: var(--primary) !important;
    box-shadow: var(--shadow-md) !important;
}

#couponCard.active {
    border-color: var(--success) !important;
    background: linear-gradient(to bottom, rgba(72, 187, 120, 0.02), var(--white)) !important;
    box-shadow: 0 4px 20px rgba(72, 187, 120, 0.15) !important;
}

#couponCard .option-card__content {
    padding: 24px 28px !important;
    display: flex !important;
    align-items: flex-start !important;
    gap: 16px !important;
}

/* Coupon Icon */
#couponCard .option-card__content::before {
    content: '' !important;
    flex-shrink: 0 !important;
    width: 48px !important;
    height: 48px !important;
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%) !important;
    border-radius: var(--radius-sm) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-shadow: 0 4px 12px rgba(251, 191, 36, 0.3) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%231A1A2E' viewBox='0 0 24 24'%3E%3Cpath d='M21.41 11.58l-9-9C12.05 2.22 11.55 2 11 2H4c-1.1 0-2 .9-2 2v7c0 .55.22 1.05.59 1.42l9 9c.36.36.86.58 1.41.58.55 0 1.05-.22 1.41-.59l7-7c.37-.36.59-.86.59-1.41 0-.55-.23-1.06-.59-1.42zM5.5 7C4.67 7 4 6.33 4 5.5S4.67 4 5.5 4 7 4.67 7 5.5 6.33 7 5.5 7z'/%3E%3C/svg%3E") !important;
    background-size: 24px !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}

#couponCard.active .option-card__content::before {
    background: linear-gradient(135deg, var(--success) 0%, #38A169 100%) !important;
    box-shadow: 0 4px 12px rgba(72, 187, 120, 0.3) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='white' viewBox='0 0 24 24'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/%3E%3C/svg%3E") !important;
}

#couponCard .option-card__title {
    font-size: 17px !important;
    font-weight: 700 !important;
    color: var(--text-dark) !important;
    margin-bottom: 4px !important;
    letter-spacing: -0.01em !important;
}

#couponCard.active .option-card__title {
    color: var(--success) !important;
}

#couponCard .option-card__description {
    font-size: 14px !important;
    color: var(--text-light) !important;
    line-height: 1.5 !important;
}

/* Coupon Input Container */
.coupon-input-wrapper {
    margin-top: 20px !important;
    padding: 20px !important;
    background: var(--gray-50) !important;
    border-radius: var(--radius-md) !important;
    border: 1px solid var(--gray-200) !important;
}

.coupon-input-group {
    display: flex !important;
    gap: 12px !important;
    margin-bottom: 16px !important;
    align-items: stretch !important;
}

/* Input Field - BIGGER */
.coupon-input-group input {
    flex: 1 !important;
    height: 52px !important;
    padding: 0 20px !important;
    border: 2px solid var(--gray-300) !important;
    border-radius: var(--radius-sm) !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    letter-spacing: 1.5px !important;
    text-transform: uppercase !important;
    background: var(--white) !important;
    transition: all 0.2s ease !important;
    color: var(--text-dark) !important;
}

.coupon-input-group input::placeholder {
    text-transform: none !important;
    letter-spacing: normal !important;
    font-weight: 400 !important;
    color: var(--text-light) !important;
}

.coupon-input-group input:focus {
    border-color: var(--primary) !important;
    box-shadow: 0 0 0 3px rgba(251, 191, 36, 0.15) !important;
    outline: none !important;
}

/* Apply Button - SMALLER & CLEANER */
.coupon-input-group button,
.apply-coupon-btn {
    height: 52px !important;
    padding: 0 24px !important;
    background: var(--primary) !important;
    color: var(--dark) !important;
    border: none !important;
    border-radius: var(--radius-sm) !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    white-space: nowrap !important;
    min-width: auto !important;
    flex: 0 0 auto !important;
}

.coupon-input-group button:hover,
.apply-coupon-btn:hover {
    background: var(--primary-dark) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(251, 191, 36, 0.4) !important;
}

.coupon-input-group button:active,
.apply-coupon-btn:active {
    transform: translateY(0) !important;
}

/* Messages */
.coupon-message {
    padding: 12px 16px !important;
    border-radius: var(--radius-sm) !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
}

.coupon-message.success {
    background: rgba(72, 187, 120, 0.1) !important;
    color: var(--success) !important;
    border: 1px solid var(--success) !important;
}

.coupon-message.success::before {
    content: '✓' !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    background: var(--success) !important;
    color: var(--white) !important;
    width: 20px !important;
    height: 20px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.coupon-message.error {
    background: rgba(245, 101, 101, 0.1) !important;
    color: var(--danger) !important;
    border: 1px solid var(--danger) !important;
}

.coupon-message.error::before {
    content: '✕' !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    background: var(--danger) !important;
    color: var(--white) !important;
    width: 20px !important;
    height: 20px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* Applied Coupon Display */
.coupon-applied {
    margin-top: 16px !important;
    padding: 16px 20px !important;
    background: linear-gradient(135deg, rgba(72, 187, 120, 0.08) 0%, rgba(72, 187, 120, 0.03) 100%) !important;
    border: 2px solid var(--success) !important;
    border-radius: var(--radius-md) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
}

.coupon-applied-text {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    color: var(--success) !important;
    font-weight: 600 !important;
    font-size: 14px !important;
}

.coupon-applied-text::before {
    content: '✓' !important;
    background: var(--success) !important;
    color: var(--white) !important;
    width: 24px !important;
    height: 24px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-weight: 700 !important;
}

.coupon-discount-value {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--success) !important;
}

.remove-coupon-btn {
    background: rgba(245, 101, 101, 0.1) !important;
    color: var(--danger) !important;
    border: 1px solid rgba(245, 101, 101, 0.3) !important;
    padding: 6px 14px !important;
    border-radius: 6px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
}

.remove-coupon-btn:hover {
    background: var(--danger) !important;
    color: var(--white) !important;
    border-color: var(--danger) !important;
}

/* ========== STOPOVER BUTTON - MODERN DESIGN ========== */
.add-this-stopover-btn,
.opt-btn--outline-primary,
button[class*="stopover"][class*="add"],
button[onclick*="stopover"] {
    width: 100% !important;
    height: 52px !important;
    padding: 0 24px !important;
    background: transparent !important;
    color: var(--primary-dark) !important;
    border: 2px dashed var(--primary) !important;
    border-radius: var(--radius-sm) !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
}

.add-this-stopover-btn:hover,
.opt-btn--outline-primary:hover,
button[class*="stopover"][class*="add"]:hover,
button[onclick*="stopover"]:hover {
    background: rgba(251, 191, 36, 0.1) !important;
    border-color: var(--primary) !important;
    border-style: solid !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(251, 191, 36, 0.2) !important;
}

.add-this-stopover-btn::before,
.opt-btn--outline-primary::before {
    content: '+' !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    display: inline-block !important;
}

/* Active/Pressed State */
.add-this-stopover-btn:active,
.opt-btn--outline-primary:active {
    transform: translateY(0) !important;
    box-shadow: 0 2px 6px rgba(30, 136, 229, 0.1) !important;
}

/* ========== FORM ACTIONS PRICE - BETTER POSITIONING ========== */
.form-actions__price {
    background: var(--gray-50) !important;
    padding: 20px 28px !important;
    border-radius: var(--radius-md) !important;
    box-shadow: none !important;
    border-left: 4px solid var(--primary) !important;
    min-width: 220px !important;
    flex: 0 0 auto !important;
    margin-right: 24px !important;
}
