/* Event Booking — Front-end Booking Form Styles (Dark Theme) */

/* ============================
   Elementor Kit Override
   Targeted reset: only override typography + spacing properties
   that .elementor-kit-* sets on h1-h6, button, label, a, p, etc.
   Keeps display, position, and layout intact.
   ============================ */
.ttt-eb-form-wrapper,
.ttt-eb-form-wrapper h1,
.ttt-eb-form-wrapper h2,
.ttt-eb-form-wrapper h3,
.ttt-eb-form-wrapper h4,
.ttt-eb-form-wrapper h5,
.ttt-eb-form-wrapper h6,
.ttt-eb-form-wrapper p,
.ttt-eb-form-wrapper span,
.ttt-eb-form-wrapper label,
.ttt-eb-form-wrapper a,
.ttt-eb-form-wrapper div,
.ttt-eb-form-wrapper button,
.ttt-eb-form-wrapper input,
.ttt-eb-form-wrapper textarea,
.ttt-eb-form-wrapper select { font-family: 'Montserrat', sans-serif; box-sizing: border-box; -webkit-font-smoothing: antialiased; }
.ttt-eb-form-wrapper h1,
.ttt-eb-form-wrapper h2,
.ttt-eb-form-wrapper h3,
.ttt-eb-form-wrapper h4,
.ttt-eb-form-wrapper h5,
.ttt-eb-form-wrapper h6 { color: #fff; font-size: inherit; font-weight: inherit; line-height: inherit; letter-spacing: normal; margin: 0; padding: 0; text-transform: none; }
.ttt-eb-form-wrapper p { color: inherit; font-size: inherit; font-weight: inherit; line-height: inherit; letter-spacing: normal; margin: 0; padding: 0; }
.ttt-eb-form-wrapper a { color: inherit; text-decoration: none; }
.ttt-eb-form-wrapper label { color: inherit; font-size: inherit; font-weight: inherit; line-height: inherit; letter-spacing: normal; }
.ttt-eb-form-wrapper button { padding: 0; margin: 0; border: none; background: none; color: inherit; font-size: inherit; font-weight: inherit; line-height: inherit; letter-spacing: normal; cursor: pointer; }
.ttt-eb-form-wrapper input,
.ttt-eb-form-wrapper textarea,
.ttt-eb-form-wrapper select { letter-spacing: normal; }

/* ============================
   Base / Wrapper
   ============================ */
.ttt-eb-form-wrapper { max-width: 720px; margin: 0 auto; font-family: 'Montserrat', sans-serif; color: #fff; font-size: 14px; line-height: 1.5; }

/* ============================
   Notice Messages
   ============================ */
.ttt-eb-form-wrapper .ttt-eb-notice { padding: 14px 18px; border-radius: 8px; font-size: 14px; line-height: 1.5; }
.ttt-eb-form-wrapper .ttt-eb-notice--error { background: rgba(220, 38, 38, 0.12); color: #fca5a5; border: 1px solid rgba(220, 38, 38, 0.25); }
.ttt-eb-form-wrapper .ttt-eb-notice--info { background: rgba(59, 130, 246, 0.12); color: #93c5fd; border: 1px solid rgba(59, 130, 246, 0.25); }
.ttt-eb-form-wrapper .ttt-eb-notice--success { background: rgba(22, 163, 74, 0.12); color: #86efac; border: 1px solid rgba(22, 163, 74, 0.25); }

/* ============================
   Form
   ============================ */
.ttt-eb-form-wrapper .ttt-eb-form { display: flex; flex-direction: column; gap: 24px; }

/* ============================
   Sections & Cards
   ============================ */
.ttt-eb-form-wrapper .ttt-eb-section { padding: 0; }
.ttt-eb-form-wrapper .ttt-eb-section-heading { display: block; font-size: 15px; font-weight: 600; margin: 0 0 16px; padding: 0; color: #fff; line-height: 1.3; }
.ttt-eb-form-wrapper .ttt-eb-card { background: #2a2a2a; border-radius: 12px; padding: 24px; display: flex; flex-direction: column; gap: 20px; }

/* ============================
   Event Info
   ============================ */
.ttt-eb-form-wrapper .ttt-eb-event-title { display: block; font-size: 16px; font-weight: 700; margin: 0 0 12px; padding: 0; color: #fff; text-transform: uppercase; letter-spacing: 0.3px; line-height: 1.4; }
.ttt-eb-form-wrapper .ttt-eb-event-meta { display: flex; flex-wrap: wrap; gap: 6px 14px; font-size: 13px; color: #888; margin-bottom: 4px; }
.ttt-eb-form-wrapper .ttt-eb-meta-item { display: inline-flex; align-items: center; gap: 4px; }

/* ============================
   Pass Selector
   ============================ */
.ttt-eb-form-wrapper .ttt-eb-pass-options { display: flex; flex-direction: column; gap: 10px; }
.ttt-eb-form-wrapper .ttt-eb-pass-option { position: relative; display: flex; align-items: center; gap: 12px; padding: 16px 18px; border: 2px solid #444; border-radius: 10px; cursor: pointer; transition: border-color 0.2s, background 0.2s; background: transparent; }
.ttt-eb-form-wrapper .ttt-eb-pass-option:hover { border-color: #EE6F57; }
.ttt-eb-form-wrapper .ttt-eb-pass-option--selected { border-color: #EE6F57; background: rgba(238, 111, 87, 0.06); }
.ttt-eb-form-wrapper .ttt-eb-pass-option input[type="radio"] { accent-color: #EE6F57; width: 18px; height: 18px; flex-shrink: 0; }
.ttt-eb-form-wrapper .ttt-eb-pass-option-content { flex: 1; display: flex; flex-direction: column; gap: 3px; }
.ttt-eb-form-wrapper .ttt-eb-pass-option-title { font-weight: 600; font-size: 14px; color: #fff; }
.ttt-eb-form-wrapper .ttt-eb-pass-option-desc { font-size: 12px; color: #888; line-height: 1.4; }
.ttt-eb-form-wrapper .ttt-eb-pass-option-price { font-weight: 700; font-size: 16px; color: #fff; white-space: nowrap; }
.ttt-eb-form-wrapper .ttt-eb-original-price { text-decoration: line-through; color: #666; font-weight: 400; font-size: 13px; margin-right: 4px; }
.ttt-eb-form-wrapper .ttt-eb-offer-badge { display: inline-block; background: #EE6F57; color: #fff; font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: 4px; margin-bottom: 4px; }

/* ============================
   Day Selector
   ============================ */
.ttt-eb-form-wrapper .ttt-eb-day-options { display: flex; flex-wrap: wrap; gap: 8px; }
.ttt-eb-form-wrapper .ttt-eb-day-option { display: flex; align-items: center; gap: 6px; padding: 8px 14px; border: 1px solid #444; border-radius: 6px; cursor: pointer; font-size: 14px; color: #ccc; background: transparent; transition: border-color 0.2s; }
.ttt-eb-form-wrapper .ttt-eb-day-option:hover { border-color: #EE6F57; }
.ttt-eb-form-wrapper .ttt-eb-day-option input[type="checkbox"] { accent-color: #EE6F57; }
.ttt-eb-form-wrapper .ttt-eb-day-option input:checked + span { font-weight: 600; color: #fff; }
.ttt-eb-form-wrapper .ttt-eb-day-option--full { background: rgba(238, 111, 87, 0.08); border-color: rgba(238, 111, 87, 0.4); }

/* ============================
   Attendee Count
   ============================ */
.ttt-eb-form-wrapper .ttt-eb-attendee-count-control { display: inline-flex; align-items: center; gap: 0; }
.ttt-eb-form-wrapper button.ttt-eb-qty-btn { width: 40px; height: 40px; padding: 0; margin: 0; border: none; background: #EE6F57; color: #fff; font-size: 20px; font-weight: 600; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background 0.15s; line-height: 1; border-radius: 0; }
.ttt-eb-form-wrapper button.ttt-eb-qty-btn:hover { background: #e55a40; }
.ttt-eb-form-wrapper button.ttt-eb-qty-minus { border-radius: 8px 0 0 8px; }
.ttt-eb-form-wrapper button.ttt-eb-qty-plus { border-radius: 0 8px 8px 0; }
.ttt-eb-form-wrapper .ttt-eb-attendee-count-input { width: 48px; height: 40px; text-align: center; border: none; background: #3a3a3a; color: #fff; font-size: 16px; font-weight: 600; font-family: 'Montserrat', sans-serif; -moz-appearance: textfield; border-radius: 0; padding: 0; }
.ttt-eb-form-wrapper .ttt-eb-attendee-count-input::-webkit-inner-spin-button,
.ttt-eb-form-wrapper .ttt-eb-attendee-count-input::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
.ttt-eb-form-wrapper .ttt-eb-field-hint { display: block; font-size: 12px; color: #666; margin-top: 6px; }

/* ============================
   Attendee Form Blocks
   ============================ */
.ttt-eb-form-wrapper .ttt-eb-attendee-block { padding: 24px; border: 1px solid #333; border-radius: 12px; margin-bottom: 12px; background: #2a2a2a; }
.ttt-eb-form-wrapper .ttt-eb-attendee-block + .ttt-eb-attendee-block { margin-top: 12px; }
.ttt-eb-form-wrapper .ttt-eb-attendee-block .ttt-eb-section-heading { font-size: 14px; margin: 0; color: #ccc; }

/* Attendee toggle header */
.ttt-eb-form-wrapper .ttt-eb-attendee-header { display: flex; align-items: center; justify-content: space-between; cursor: pointer; user-select: none; padding: 2px 0; }
.ttt-eb-form-wrapper .ttt-eb-toggle-icon { width: 28px; height: 28px; border-radius: 50%; background: #EE6F57; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: transform 0.2s; }
.ttt-eb-form-wrapper .ttt-eb-toggle-icon::after { content: ''; display: block; width: 10px; height: 10px; border-right: 2px solid #fff; border-bottom: 2px solid #fff; transform: rotate(45deg); margin-top: -3px; transition: transform 0.2s; }
.ttt-eb-form-wrapper .ttt-eb-attendee-block--collapsed .ttt-eb-toggle-icon::after { transform: rotate(-45deg); margin-top: 3px; }

/* Attendee body collapse */
.ttt-eb-form-wrapper .ttt-eb-attendee-body { overflow: hidden; transition: max-height 0.3s ease, opacity 0.2s ease, margin-top 0.3s ease; max-height: 2000px; opacity: 1; margin-top: 20px; }
.ttt-eb-form-wrapper .ttt-eb-attendee-block--collapsed .ttt-eb-attendee-body { max-height: 0; opacity: 0; margin-top: 0; }
.ttt-eb-form-wrapper .ttt-eb-fields-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.ttt-eb-form-wrapper .ttt-eb-field { display: flex; flex-direction: column; gap: 6px; }
.ttt-eb-form-wrapper .ttt-eb-field--half { grid-column: span 1; }
.ttt-eb-form-wrapper .ttt-eb-field--full { grid-column: span 2; }
.ttt-eb-form-wrapper .ttt-eb-field label { display: block; font-size: 13px; font-weight: 500; color: #aaa; line-height: 1.3; margin: 0; padding: 0; }
.ttt-eb-form-wrapper .ttt-eb-field input[type="text"],
.ttt-eb-form-wrapper .ttt-eb-field input[type="email"],
.ttt-eb-form-wrapper .ttt-eb-field input[type="tel"],
.ttt-eb-form-wrapper .ttt-eb-field input[type="number"],
.ttt-eb-form-wrapper .ttt-eb-field textarea,
.ttt-eb-form-wrapper .ttt-eb-field select { padding: 12px 14px; border: 1px solid #555; border-radius: 8px; font-size: 14px; font-family: 'Montserrat', sans-serif; background: #3a3a3a; color: #fff; transition: border-color 0.2s, box-shadow 0.2s; width: 100%; }
.ttt-eb-form-wrapper .ttt-eb-field input::placeholder,
.ttt-eb-form-wrapper .ttt-eb-field textarea::placeholder { color: #666; }
.ttt-eb-form-wrapper .ttt-eb-field input:focus,
.ttt-eb-form-wrapper .ttt-eb-field textarea:focus,
.ttt-eb-form-wrapper .ttt-eb-field select:focus { outline: none; border-color: #EE6F57; box-shadow: 0 0 0 2px rgba(238, 111, 87, 0.15); }
.ttt-eb-form-wrapper .ttt-eb-field textarea { resize: vertical; min-height: 60px; }
.ttt-eb-form-wrapper .ttt-eb-field select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' fill='none' stroke='%23888' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }
.ttt-eb-form-wrapper .ttt-eb-required { color: #EE6F57; }
.ttt-eb-form-wrapper .ttt-eb-checkbox-label { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; cursor: pointer; font-weight: 400; color: #ccc; line-height: 1.5; }
.ttt-eb-form-wrapper .ttt-eb-checkbox-label input[type="checkbox"] { margin-top: 3px; accent-color: #EE6F57; width: 16px; height: 16px; flex-shrink: 0; }
.ttt-eb-form-wrapper .ttt-eb-checkbox-text { display: inline; font-size: 14px; color: #ccc; line-height: 1.5; }

/* WhatsApp icon */
.ttt-eb-form-wrapper .ttt-eb-whatsapp-icon { flex-shrink: 0; margin-top: 1px; }

/* Booking-level fields */
.ttt-eb-form-wrapper .ttt-eb-booking-fields { padding: 20px 24px; border: 1px solid #333; border-radius: 12px; background: #2a2a2a; margin-top: 12px; }

/* ============================
   Coupon
   ============================ */
.ttt-eb-form-wrapper .ttt-eb-coupon-row { display: flex; flex-wrap: wrap; gap: 8px; }
.ttt-eb-form-wrapper .ttt-eb-coupon-input { flex: 1; padding: 12px 14px; border: 1px solid #555; border-radius: 8px; font-size: 14px; font-family: 'Montserrat', sans-serif; background: #3a3a3a; color: #fff; }
.ttt-eb-form-wrapper .ttt-eb-coupon-input::placeholder { color: #666; }
.ttt-eb-form-wrapper .ttt-eb-coupon-input:focus { outline: none; border-color: #EE6F57; box-shadow: 0 0 0 2px rgba(238, 111, 87, 0.15); }
.ttt-eb-form-wrapper .ttt-eb-coupon-message { display: block; margin-top: 8px; font-size: 13px; padding: 8px 12px; border-radius: 6px; }
.ttt-eb-form-wrapper .ttt-eb-coupon-hint { display: block; font-size: 12px; color: #666; margin-top: 10px; line-height: 1.5; }

/* ============================
   Price Summary
   ============================ */
.ttt-eb-form-wrapper .ttt-eb-price-summary-table { border: none; border-radius: 0; overflow: hidden; }
.ttt-eb-form-wrapper .ttt-eb-price-row { display: flex; justify-content: space-between; padding: 10px 0; font-size: 14px; border-bottom: 1px solid #333; }
.ttt-eb-form-wrapper .ttt-eb-price-row:last-child { border-bottom: none; }
.ttt-eb-form-wrapper .ttt-eb-price-label { color: #ccc; }
.ttt-eb-form-wrapper .ttt-eb-price-value { font-weight: 600; color: #fff; }
.ttt-eb-form-wrapper .ttt-eb-price-value--discount { color: #86efac; }
.ttt-eb-form-wrapper .ttt-eb-price-value--offer { color: #EE6F57; }
.ttt-eb-form-wrapper .ttt-eb-price-row--subtotal { border-bottom: none; }
.ttt-eb-form-wrapper .ttt-eb-price-row--total { background: transparent; border-bottom: none; border-top: 1px solid #444; padding-top: 14px; margin-top: 4px; }
.ttt-eb-form-wrapper .ttt-eb-price-row--total .ttt-eb-price-label { color: #EE6F57; font-weight: 600; font-size: 15px; }
.ttt-eb-form-wrapper .ttt-eb-price-row--total .ttt-eb-price-value { color: #EE6F57; font-size: 18px; font-weight: 700; }
.ttt-eb-form-wrapper .ttt-eb-free-badge { display: inline-block; padding: 10px 20px; background: #16a34a; color: #fff; font-weight: 700; border-radius: 8px; font-size: 16px; }

/* ============================
   Terms
   ============================ */
.ttt-eb-form-wrapper .ttt-eb-terms-label { font-size: 13px; line-height: 1.6; color: #ccc; }
.ttt-eb-form-wrapper .ttt-eb-terms-label a { color: #EE6F57; text-decoration: none; }
.ttt-eb-form-wrapper .ttt-eb-terms-label a:hover { text-decoration: underline; color: #ff8a75; }

/* ============================
   Buttons
   ============================ */
.ttt-eb-form-wrapper .ttt-eb-btn { display: inline-flex; align-items: center; justify-content: center; padding: 14px 24px; border-radius: 8px; font-size: 15px; font-weight: 600; cursor: pointer; border: none; background: none; font-family: 'Montserrat', sans-serif; transition: background 0.2s, opacity 0.2s; line-height: 1; }
.ttt-eb-form-wrapper .ttt-eb-btn--primary { background: #EE6F57; color: #fff; width: 100%; }
.ttt-eb-form-wrapper .ttt-eb-btn--primary:hover { background: #e55a40; }
.ttt-eb-form-wrapper .ttt-eb-btn--primary:disabled { opacity: 0.45; cursor: not-allowed; }
.ttt-eb-form-wrapper .ttt-eb-btn--secondary { background: transparent; color: #ccc; border: 1px solid #555; }
.ttt-eb-form-wrapper .ttt-eb-btn--secondary:hover { background: rgba(255, 255, 255, 0.05); border-color: #888; }
.ttt-eb-form-wrapper .ttt-eb-submit-btn { margin-top: 4px; }
.ttt-eb-form-wrapper .ttt-eb-submit-hint { display: block; font-size: 12px; color: #666; text-align: center; margin-top: 8px; }
.ttt-eb-form-wrapper .ttt-eb-form-message { display: block; margin-top: 8px; font-size: 14px; padding: 12px 16px; border-radius: 8px; }

/* Stripe Payment Element */
#ttt-eb-stripe-element { background: #3a3a3a; border-radius: 8px; padding: 16px; border: 1px solid #555; }

/* ============================
   Payment Modal
   ============================ */
.ttt-eb-payment-modal { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 999999; display: flex; align-items: center; justify-content: center; }
.ttt-eb-payment-modal__backdrop { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.7); backdrop-filter: blur(4px); }
.ttt-eb-payment-modal__dialog { position: relative; background: #2a2a2a; border-radius: 14px; width: 100%; max-width: 440px; margin: 20px; box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5); font-family: 'Montserrat', sans-serif; color: #fff; }
.ttt-eb-payment-modal__header { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px 0; }
.ttt-eb-payment-modal__title { font-size: 17px; font-weight: 700; color: #fff; margin: 0; }
.ttt-eb-payment-modal__close { width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; font-size: 22px; color: #888; background: none; border: none; cursor: pointer; border-radius: 6px; transition: background 0.15s, color 0.15s; padding: 0; line-height: 1; }
.ttt-eb-payment-modal__close:hover { background: #3a3a3a; color: #fff; }
.ttt-eb-payment-modal__body { padding: 20px 24px; }
.ttt-eb-payment-modal__message { font-size: 14px; padding: 12px 16px; border-radius: 8px; margin-top: 14px; }
.ttt-eb-payment-modal__footer { padding: 0 24px 24px; }
.ttt-eb-payment-modal__pay-btn { width: 100%; }

/* ============================
   Template 2: Two-Column
   ============================ */
.ttt-eb-form-wrapper:has(.ttt-eb-form--template-2) { max-width: 1100px; }
.ttt-eb-form-wrapper .ttt-eb-two-col { display: grid; grid-template-columns: 1fr 340px; gap: 28px; align-items: start; }
.ttt-eb-form-wrapper .ttt-eb-two-col__form { display: flex; flex-direction: column; gap: 20px; }
.ttt-eb-form-wrapper .ttt-eb-two-col__sidebar { position: sticky; top: 32px; display: flex; flex-direction: column; gap: 20px; }
.ttt-eb-form-wrapper .ttt-eb-two-col__sidebar > .ttt-eb-section { background: #2a2a2a; border-radius: 12px; padding: 20px; }
.ttt-eb-form-wrapper .ttt-eb-two-col__sidebar .ttt-eb-section-heading { font-size: 16px; font-weight: 700; margin-bottom: 14px; }
.ttt-eb-form-wrapper .ttt-eb-two-col__sidebar [data-ttt-eb-coupon-apply] { background: #EE6F57; color: #fff; border: none; padding: 12px 20px; border-radius: 8px; }
.ttt-eb-form-wrapper .ttt-eb-two-col__sidebar [data-ttt-eb-coupon-apply]:hover { background: #e55a40; }
.ttt-eb-form-wrapper .ttt-eb-two-col__sidebar [data-ttt-eb-coupon-apply]:disabled { background: #444; color: #888; cursor: not-allowed; }
.ttt-eb-form-wrapper [data-ttt-eb-coupon-remove] { background: transparent; color: #fca5a5; border: 1px solid #fca5a5; padding: 12px 20px; border-radius: 8px; white-space: nowrap; }
.ttt-eb-form-wrapper [data-ttt-eb-coupon-remove]:hover { background: rgba(220, 38, 38, 0.1); color: #fca5a5; }
.ttt-eb-form-wrapper .ttt-eb-two-col__sidebar [data-ttt-eb-section="terms"] { background: transparent; padding: 0; }
.ttt-eb-form-wrapper .ttt-eb-two-col__sidebar [data-ttt-eb-section="payment-button"] { background: transparent; padding: 0; }

@media (max-width: 860px) {
	.ttt-eb-form-wrapper .ttt-eb-two-col { grid-template-columns: 1fr; }
	.ttt-eb-form-wrapper .ttt-eb-two-col__sidebar { position: static; }
	.ttt-eb-form-wrapper:has(.ttt-eb-form--template-2) { max-width: 720px; }
}

/* ============================
   Template 3: Compact
   ============================ */
.ttt-eb-form-wrapper .ttt-eb-form--template-3 { gap: 16px; }
.ttt-eb-form-wrapper .ttt-eb-form--template-3 .ttt-eb-section-heading { font-size: 14px; margin-bottom: 10px; }
.ttt-eb-form-wrapper .ttt-eb-form--template-3 .ttt-eb-compact-footer { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; padding-top: 12px; border-top: 1px solid #333; }
.ttt-eb-form-wrapper .ttt-eb-form--template-3 .ttt-eb-compact-footer [data-ttt-eb-section="terms"],
.ttt-eb-form-wrapper .ttt-eb-form--template-3 .ttt-eb-compact-footer [data-ttt-eb-section="payment-button"] { grid-column: 1 / -1; }
.ttt-eb-form-wrapper:has(.ttt-eb-form--template-3) { max-width: 600px; }

@media (max-width: 600px) {
	.ttt-eb-form-wrapper .ttt-eb-form--template-3 .ttt-eb-compact-footer { grid-template-columns: 1fr; }
}

/* ============================
   Booking Success Page
   ============================ */
.ttt-eb-form-wrapper .ttt-eb-success-card { background: #2a2a2a; border-radius: 14px; padding: 40px 32px; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 12px; }
.ttt-eb-form-wrapper .ttt-eb-success-icon { margin-bottom: 8px; }
.ttt-eb-form-wrapper .ttt-eb-success-title { font-size: 22px; font-weight: 700; color: #86efac; margin: 0; }
.ttt-eb-form-wrapper .ttt-eb-success-icon--error + .ttt-eb-success-title { color: #fca5a5; }
.ttt-eb-form-wrapper .ttt-eb-success-subtitle { font-size: 14px; color: #999; line-height: 1.6; max-width: 460px; margin: 0; }
.ttt-eb-form-wrapper .ttt-eb-success-details { width: 100%; max-width: 420px; margin-top: 20px; text-align: left; border-top: 1px solid #3a3a3a; padding-top: 16px; }
.ttt-eb-form-wrapper .ttt-eb-success-row { display: flex; justify-content: space-between; align-items: baseline; padding: 10px 0; border-bottom: 1px solid #333; font-size: 14px; }
.ttt-eb-form-wrapper .ttt-eb-success-row:last-child { border-bottom: none; }
.ttt-eb-form-wrapper .ttt-eb-success-label { color: #888; }
.ttt-eb-form-wrapper .ttt-eb-success-value { color: #fff; font-weight: 500; text-align: right; }
.ttt-eb-form-wrapper .ttt-eb-success-value--highlight { color: #EE6F57; font-weight: 700; font-size: 15px; letter-spacing: 0.3px; }
.ttt-eb-form-wrapper .ttt-eb-success-row--total { border-top: 1px solid #444; border-bottom: none; margin-top: 4px; padding-top: 14px; }
.ttt-eb-form-wrapper .ttt-eb-success-value--total { color: #EE6F57; font-weight: 700; font-size: 18px; }

/* ============================
   Payment Processing Loader
   ============================ */
.ttt-eb-payment-loader { position: fixed; inset: 0; background: rgba(0,0,0,0.78); z-index: 99999; display: flex; align-items: center; justify-content: center; }
.ttt-eb-payment-loader-box { background: #252525; border-radius: 14px; padding: 38px 44px; text-align: center; min-width: 230px; box-shadow: 0 8px 40px rgba(0,0,0,0.5); }
.ttt-eb-loader-spinner { width: 46px; height: 46px; border: 4px solid rgba(238,111,87,0.2); border-top-color: #EE6F57; border-radius: 50%; animation: ttt-eb-spin 0.75s linear infinite; margin: 0 auto 18px; }
@keyframes ttt-eb-spin { to { transform: rotate(360deg); } }
.ttt-eb-payment-loader-title { color: #ffffff; font-size: 16px; font-weight: 700; margin: 0 0 6px; font-family: 'Montserrat', sans-serif; }
.ttt-eb-payment-loader-msg { color: #999; font-size: 13px; margin: 0; font-family: 'Montserrat', sans-serif; }

/* ============================
   Responsive
   ============================ */
@media (max-width: 600px) {
	.ttt-eb-form-wrapper .ttt-eb-fields-grid { grid-template-columns: 1fr; }
	.ttt-eb-form-wrapper .ttt-eb-field--half { grid-column: span 1; }
	.ttt-eb-form-wrapper .ttt-eb-field--full { grid-column: span 1; }
	.ttt-eb-form-wrapper { padding: 0 12px; }
	.ttt-eb-form-wrapper .ttt-eb-card { padding: 18px; }
	.ttt-eb-form-wrapper .ttt-eb-attendee-block { padding: 18px; }
	.ttt-eb-form-wrapper .ttt-eb-success-card { padding: 28px 20px; }
}
