/**
 * ╔═══════════════════════════════════════════════════════════════╗
 * ║  ANTBNB INDIVIDUAL SERVICES — SCOPED CSS v3.0.0             ║
 * ║  Overrides Impreza by UpSolution theme CSS within scope     ║
 * ║  .antbnb-ind-scope acts as CSS boundary                     ║
 * ║  Checkpoint: 2026-03-10 v3 · Bitghost.com                     ║
 * ╚═══════════════════════════════════════════════════════════════╝
 *
 * Color Tokens:
 * --sage:       #B9BAA3
 * --beige:      #D6D5C9
 * --forest:     #515B3A
 * --charcoal:   #433A3F
 * --terracotta: #C06E52
 */

/* ─── CSS RESET SCOPE ──────────────────────────────────────────────────── */
/* Override ALL Impreza theme styles within our container */
.antbnb-ind-scope,
.antbnb-ind-scope *,
.antbnb-ind-scope *::before,
.antbnb-ind-scope *::after {
    box-sizing: border-box !important;
    margin: 0;
    padding: 0;
}

.antbnb-ind-scope {
    font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    color: #433A3F !important;
    line-height: 1.5 !important;
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
    position: relative !important;
    z-index: 10 !important;
}

/* Override Impreza's aggressive selectors */
.antbnb-ind-scope h1,
.antbnb-ind-scope h2,
.antbnb-ind-scope h3,
.antbnb-ind-scope h4,
.antbnb-ind-scope h5,
.antbnb-ind-scope h6 {
    font-family: 'Inter', system-ui, sans-serif !important;
    color: #433A3F !important;
    margin: 0 !important;
    padding: 0 !important;
    letter-spacing: -0.02em !important;
    line-height: 1.2 !important;
}

.antbnb-ind-scope p {
    margin: 0 !important;
    font-family: 'Inter', system-ui, sans-serif !important;
}

.antbnb-ind-scope a {
    text-decoration: none !important;
    color: inherit !important;
}

.antbnb-ind-scope ul,
.antbnb-ind-scope ol {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ─── GOOGLE FONT IMPORT ───────────────────────────────────────────────── */

/* ─── CONTAINER ────────────────────────────────────────────────────────── */
.antbnb-ind-container {
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
}

/* ─── SECTION ──────────────────────────────────────────────────────────── */
.antbnb-ind-section {
    background: #FFFFFF !important;
    border-radius: 24px !important;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.1) !important;
    overflow: hidden !important;
}

.antbnb-ind-inner {
    padding: 24px 24px 64px 24px !important;
}

@media (min-width: 768px) {
    .antbnb-ind-inner {
        padding: 48px 24px 64px 24px !important;
    }
}

/* ─── HEADER ───────────────────────────────────────────────────────────── */
.antbnb-ind-header {
    text-align: center !important;
    margin-bottom: 48px !important;
}

@media (min-width: 768px) {
    .antbnb-ind-header {
        margin-bottom: 64px !important;
    }
}

.antbnb-ind-badge {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    background: #B9BAA3 !important;
    color: #515B3A !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 0.15em !important;
    padding: 8px 20px !important;
    border-radius: 24px !important;
    margin-bottom: 16px !important;
}

.antbnb-ind-title {
    font-size: 36px !important;
    font-weight: 700 !important;
    letter-spacing: -0.03em !important;
    margin-bottom: 16px !important;
    color: #433A3F !important;
    line-height: 1.1 !important;
}

@media (min-width: 768px) {
    .antbnb-ind-title {
        font-size: 48px !important;
    }
}

.antbnb-ind-subtitle {
    max-width: 680px !important;
    margin: 0 auto !important;
    font-size: 16px !important;
    color: #515B3A !important;
    line-height: 1.7 !important;
    text-align: center !important;
}

/* v3.0.3: Nuclear override — Impreza sets text-align:left on p globally */
.antbnb-ind-scope .antbnb-ind-header .antbnb-ind-subtitle,
.antbnb-ind-scope p.antbnb-ind-subtitle,
.antbnb-ind-jsx-root .antbnb-ind-subtitle {
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

@media (min-width: 768px) {
    .antbnb-ind-subtitle {
        font-size: 18px !important;
    }
}

/* ─── GRID ─────────────────────────────────────────────────────────────── */
.antbnb-ind-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 24px !important;
    padding: 0 16px !important;
}

@media (min-width: 640px) {
    .antbnb-ind-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 28px !important;
    }
}

@media (min-width: 1024px) {
    .antbnb-ind-grid {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 32px !important;
    }
}

/* ─── SERVICE CARD ─────────────────────────────────────────────────────── */
.antbnb-ind-card {
    background: #FFFFFF !important;
    border: 1px solid #B9BAA3 !important;
    border-radius: 24px !important;
    overflow: hidden !important;
    cursor: pointer !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.antbnb-ind-card:hover {
    transform: translateY(-8px) !important;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1) !important;
}

.antbnb-ind-card-hero {
    height: 180px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: #FFFFFF !important;
    font-size: 56px !important;
}

@media (min-width: 768px) {
    .antbnb-ind-card-hero {
        height: 224px !important;
    }
}

.antbnb-ind-card-hero i {
    font-size: 56px !important;
    color: #FFFFFF !important;
}

@media (min-width: 768px) {
    .antbnb-ind-card-hero i {
        font-size: 64px !important;
    }
}

.antbnb-ind-card-body {
    padding: 24px !important;
}

@media (min-width: 768px) {
    .antbnb-ind-card-body {
        padding: 32px !important;
    }
}

.antbnb-ind-card-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: flex-start !important;
    margin-bottom: 16px !important;
    gap: 12px !important;
}

.antbnb-ind-card-header h3 {
    font-size: 20px !important;
    font-weight: 600 !important;
    color: #433A3F !important;
    line-height: 1.3 !important;
}

@media (min-width: 768px) {
    .antbnb-ind-card-header h3 {
        font-size: 24px !important;
    }
}

.antbnb-ind-price {
    color: #C06E52 !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    margin-top: 4px !important;
}

.antbnb-ind-seo-badge {
    flex-shrink: 0 !important;
    display: inline-block !important;
    padding: 4px 16px !important;
    background: #B9BAA3 !important;
    color: #515B3A !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    border-radius: 16px !important;
    white-space: nowrap !important;
}

.antbnb-ind-card-desc {
    color: #515B3A !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.antbnb-ind-card-link {
    margin-top: 20px !important;
    color: #C06E52 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

.antbnb-ind-card-link i {
    font-size: 12px !important;
    color: #C06E52 !important;
    transition: transform 0.2s ease !important;
}

.antbnb-ind-card:hover .antbnb-ind-card-link i {
    transform: translateX(4px) !important;
}

/* ─── FOOTER NOTE ──────────────────────────────────────────────────────── */
.antbnb-ind-footer-note {
    text-align: center !important;
    margin-top: 48px !important;
}

.antbnb-ind-footer-note p {
    font-size: 13px !important;
    color: #515B3A !important;
    margin-bottom: 12px !important;
}

.antbnb-ind-url-badge {
    display: inline-flex !important;
    background: #433A3F !important;
    color: #FFFFFF !important;
    font-size: 13px !important;
    padding: 12px 20px !important;
    border-radius: 16px !important;
    font-family: monospace !important;
}

.antbnb-ind-url-badge em {
    color: #C06E52 !important;
    font-style: italic !important;
}

/* ─── MODAL OVERLAY ────────────────────────────────────────────────────── */
.antbnb-ind-modal-overlay {
    position: fixed !important;
    inset: 0 !important;
    background: rgba(0, 0, 0, 0.7) !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 999999 !important;
    padding: 16px !important;
}

/* v3.0.0 FIX: Class-toggle controls visibility — prevents auto-open bug */
.antbnb-ind-modal-overlay.antbnb-ind-modal-visible {
    display: flex !important;
}

.antbnb-ind-modal {
    background: #FFFFFF !important;
    max-width: 640px !important;
    width: 100% !important;
    border-radius: 24px !important;
    overflow: hidden !important;
    max-height: 90vh !important;
    overflow-y: auto !important;
    animation: antbnb-modal-pop 0.3s ease forwards !important;
}

.antbnb-ind-modal-sm {
    max-width: 520px !important;
}

@keyframes antbnb-modal-pop {
    0% { transform: scale(0.95); opacity: 0; }
    100% { transform: scale(1); opacity: 1; }
}

.antbnb-ind-modal-body {
    padding: 32px !important;
}

@media (min-width: 768px) {
    .antbnb-ind-modal-body {
        padding: 40px !important;
    }
}

/* ─── SERVICE DETAIL MODAL ─────────────────────────────────────────────── */
.antbnb-ind-detail-top {
    display: flex !important;
    justify-content: space-between !important;
    align-items: flex-start !important;
    margin-bottom: 16px !important;
}

.antbnb-ind-detail-emoji {
    font-size: 56px !important;
    line-height: 1 !important;
}

.antbnb-ind-close-service,
.antbnb-ind-close-booking {
    background: none !important;
    border: none !important;
    font-size: 32px !important;
    color: #999 !important;
    cursor: pointer !important;
    padding: 0 !important;
    line-height: 1 !important;
    transition: color 0.2s ease !important;
}

.antbnb-ind-close-service:hover,
.antbnb-ind-close-booking:hover {
    color: #000 !important;
}

.antbnb-ind-detail h2 {
    font-size: 28px !important;
    font-weight: 700 !important;
    margin-bottom: 8px !important;
}

@media (min-width: 768px) {
    .antbnb-ind-detail h2 {
        font-size: 36px !important;
    }
}

.antbnb-ind-detail-price {
    color: #C06E52 !important;
    font-weight: 500 !important;
    font-size: 18px !important;
    margin-bottom: 24px !important;
}

@media (min-width: 768px) {
    .antbnb-ind-detail-price {
        font-size: 20px !important;
    }
}

.antbnb-ind-detail-desc {
    color: #515B3A !important;
}

.antbnb-ind-detail-desc p {
    font-size: 16px !important;
    line-height: 1.7 !important;
    margin-bottom: 20px !important;
    color: #515B3A !important;
}

.antbnb-ind-detail-features {
    background: #F8F7F3 !important;
    padding: 20px 24px !important;
    border-radius: 16px !important;
    margin: 24px 0 !important;
}

.antbnb-ind-detail-features-title {
    font-weight: 600 !important;
    color: #515B3A !important;
    font-size: 14px !important;
    margin-bottom: 12px !important;
}

.antbnb-ind-feature-list {
    padding-left: 20px !important;
}

.antbnb-ind-feature-list li {
    position: relative !important;
    padding: 4px 0 !important;
    padding-left: 12px !important;
    font-size: 14px !important;
    color: #515B3A !important;
    line-height: 1.6 !important;
    list-style: disc !important;
}

.antbnb-ind-detail-benefit {
    font-weight: 600 !important;
    color: #C06E52 !important;
    font-size: 20px !important;
    margin-top: 16px !important;
}

@media (min-width: 768px) {
    .antbnb-ind-detail-benefit {
        font-size: 24px !important;
    }
}

.antbnb-ind-detail-url {
    text-align: center !important;
    font-size: 12px !important;
    color: #999 !important;
    margin-top: 20px !important;
    font-family: monospace !important;
}

/* ─── BOOKING MODAL ────────────────────────────────────────────────────── */
.antbnb-ind-modal-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 28px !important;
}

.antbnb-ind-modal-header h3 {
    font-size: 24px !important;
    font-weight: 600 !important;
}

@media (min-width: 768px) {
    .antbnb-ind-modal-header h3 {
        font-size: 28px !important;
    }
}

.antbnb-ind-booking-form {
    display: flex !important;
    flex-direction: column !important;
    gap: 20px !important;
}

.antbnb-ind-form-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
}

.antbnb-ind-form-group label {
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 0.05em !important;
    color: #433A3F !important;
    text-transform: uppercase !important;
}

.antbnb-ind-form-group select,
.antbnb-ind-form-group input[type="date"] {
    width: 100% !important;
    border: 1px solid #B9BAA3 !important;
    border-radius: 16px !important;
    padding: 14px 18px !important;
    font-size: 15px !important;
    font-family: 'Inter', system-ui, sans-serif !important;
    color: #433A3F !important;
    background: #FFFFFF !important;
    outline: none !important;
    transition: border-color 0.2s ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}

.antbnb-ind-form-group select {
    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='M6 8L1 3h10z' fill='%23515B3A'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 16px center !important;
    padding-right: 40px !important;
}

.antbnb-ind-form-group select:focus,
.antbnb-ind-form-group input[type="date"]:focus {
    border-color: #515B3A !important;
    box-shadow: 0 0 0 3px rgba(81, 91, 58, 0.1) !important;
}

.antbnb-ind-form-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
}

@media (max-width: 480px) {
    .antbnb-ind-form-row {
        grid-template-columns: 1fr !important;
    }
}

/* ─── PRIMARY BUTTON ───────────────────────────────────────────────────── */
.antbnb-ind-btn-primary {
    width: 100% !important;
    background: #515B3A !important;
    color: #FFFFFF !important;
    border: none !important;
    padding: 20px 24px !important;
    border-radius: 24px !important;
    font-size: 17px !important;
    font-weight: 600 !important;
    font-family: 'Inter', system-ui, sans-serif !important;
    cursor: pointer !important;
    transition: background 0.2s ease !important;
    text-transform: uppercase !important;
    letter-spacing: 0.02em !important;
    margin-top: 8px !important;
}

@media (min-width: 768px) {
    .antbnb-ind-btn-primary {
        font-size: 18px !important;
        padding: 22px 24px !important;
    }
}

.antbnb-ind-btn-primary:hover {
    background: #433A3F !important;
}

.antbnb-ind-btn-primary:disabled {
    background: #B9BAA3 !important;
    cursor: not-allowed !important;
}

/* ─── BOOKING STATUS ───────────────────────────────────────────────────── */
.antbnb-ind-booking-status {
    padding: 12px 16px !important;
    border-radius: 12px !important;
    font-size: 14px !important;
    text-align: center !important;
    font-weight: 500 !important;
}

.antbnb-ind-status-success {
    background: #ecfdf5 !important;
    color: #065f46 !important;
    border: 1px solid #a7f3d0 !important;
}

.antbnb-ind-status-error {
    background: #fef2f2 !important;
    color: #991b1b !important;
    border: 1px solid #fecaca !important;
}

.antbnb-ind-status-info {
    background: #eff6ff !important;
    color: #1e40af !important;
    border: 1px solid #bfdbfe !important;
}

/* ─── IMPREZA OVERRIDE LAYER ───────────────────────────────────────────── */
/* Kill Impreza's aggressive global styles inside our scope */
.antbnb-ind-scope .w-btn,
.antbnb-ind-scope .us_custom_,
.antbnb-ind-scope .vc_custom_ {
    all: unset !important;
}

.antbnb-ind-scope .wpb_wrapper {
    padding: 0 !important;
    margin: 0 !important;
}

/* Ensure our modals are above Impreza's z-index stack */
.antbnb-ind-scope .antbnb-ind-modal-overlay {
    z-index: 999999 !important;
}

/* Override Impreza button styles */
.antbnb-ind-scope button {
    font-family: 'Inter', system-ui, sans-serif !important;
}

/* Override Impreza's input styles */
.antbnb-ind-scope input,
.antbnb-ind-scope select,
.antbnb-ind-scope textarea {
    font-family: 'Inter', system-ui, sans-serif !important;
}

/* ─── ANIMATIONS ───────────────────────────────────────────────────────── */
@keyframes antbnb-spin {
    to { transform: rotate(360deg); }
}

@keyframes antbnb-fade-in {
    from { opacity: 0; transform: translateY(12px); }
    to { opacity: 1; transform: translateY(0); }
}

.antbnb-ind-card {
    animation: antbnb-fade-in 0.5s ease both !important;
}

.antbnb-ind-card:nth-child(1) { animation-delay: 0.05s !important; }
.antbnb-ind-card:nth-child(2) { animation-delay: 0.1s !important; }
.antbnb-ind-card:nth-child(3) { animation-delay: 0.15s !important; }
.antbnb-ind-card:nth-child(4) { animation-delay: 0.2s !important; }
.antbnb-ind-card:nth-child(5) { animation-delay: 0.25s !important; }
.antbnb-ind-card:nth-child(6) { animation-delay: 0.3s !important; }

/* ─── PRINT ────────────────────────────────────────────────────────────── */
@media print {
    .antbnb-ind-modal-overlay { display: none !important; }
    .antbnb-ind-card { break-inside: avoid !important; }
}
