/**
 * OM Archive · Luxury Travel Marketplace v2
 * Paleta OM: #29108F (morado oscuro) #5C1F9E (morado medio) #C33FBC (magenta) #EC199C (fucsia)
 */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

:root {
    --omc1: #29108F;
    --omc2: #5C1F9E;
    --omc3: #C33FBC;
    --omc4: #EC199C;
    --omgradcta: linear-gradient(135deg, #29108F, #C33FBC);
    --omgradpink: linear-gradient(135deg, #EC199C, #C33FBC);
}

.om-arch, .om-arch * { box-sizing: border-box; }
.om-arch {
    font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif;
    color: #1A1A2E;
    max-width: 1320px;
    margin: 0 auto;
    padding: 0 0 80px;
}

/* HERO */
.om-arch__hero {
    position: relative;
    min-height: 340px;
    background-size: cover;
    background-position: center;
    margin: 0 20px;
    border-radius: 24px;
    overflow: hidden;
    isolation: isolate;
}
.om-arch__hero::before {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(26,8,87,.72) 0%, rgba(41,16,143,.58) 35%, rgba(92,31,158,.42) 65%, rgba(195,63,188,.45) 100%);
    z-index: 1;
}
.om-arch__hero::after {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 0%, transparent 50%, rgba(26,8,87,.35) 100%);
    z-index: 1;
}
.om-arch__hero-inner {
    position: relative;
    z-index: 2;
    padding: 36px 40px;
}
.om-arch__hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 14px;
    background: rgba(255,255,255,.18);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,.32);
    border-radius: 999px;
    color: #fff;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .5px;
    text-transform: uppercase;
    margin-bottom: 14px;
    text-shadow: 0 1px 3px rgba(0,0,0,.35);
}
.om-arch__hero-eyebrow svg { width: 14px; height: 14px; }
.om-arch__title {
    margin: 0 0 8px;
    font-size: 36px;
    font-weight: 800;
    color: #fff;
    letter-spacing: -.5px;
    line-height: 1.1;
    text-shadow: 0 2px 12px rgba(0,0,0,.45);
    max-width: 720px;
}
.om-arch__subtitle {
    margin: 0 0 24px;
    font-size: 16px;
    color: rgba(255,255,255,.95);
    font-weight: 500;
    text-shadow: 0 1px 6px rgba(0,0,0,.5);
    max-width: 600px;
}

/* Pills tipo */
.om-arch-tipos { display: flex; flex-wrap: nowrap; gap: 6px; overflow-x: auto; padding-bottom: 4px; }
.om-arch-tipos::-webkit-scrollbar { height: 4px; }
.om-arch-tipos::-webkit-scrollbar-thumb { background: rgba(255,255,255,.3); border-radius: 2px; }
.om-arch-pill {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 6px 10px;
    background: rgba(255,255,255,.18);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    color: #fff;
    border: 1px solid rgba(255,255,255,.3);
    border-radius: 999px;
    text-decoration: none;
    font-weight: 600;
    font-size: 11.5px;
    transition: all .2s;
    cursor: pointer;
    text-shadow: 0 1px 3px rgba(0,0,0,.25);
    white-space: nowrap;
    flex-shrink: 0;
}
.om-arch-pill:hover { background: rgba(255,255,255,.28); transform: translateY(-1px); }
.om-arch-pill.is-active {
    background: #fff;
    color: var(--omc1);
    border-color: transparent;
    box-shadow: 0 6px 18px rgba(0,0,0,.2);
    text-shadow: none;
}
.om-arch-pill.is-disabled { opacity: .45; cursor: not-allowed; }
.om-arch-pill__icon svg { width: 12px; height: 12px; }
.om-arch-pill__count {
    display: inline-block;
    background: rgba(255,255,255,.22);
    padding: 1px 5px;
    border-radius: 999px;
    font-size: 9px;
    font-weight: 800;
    min-width: 16px;
    text-align: center;
}
.om-arch-pill.is-active .om-arch-pill__count { background: var(--omc1); color: #fff; }

/* Pill Especiales: variante destacada con icono de fuego */
.om-arch-pill--especiales {
    background: linear-gradient(135deg, rgba(245,158,11,.45) 0%, rgba(236,72,153,.45) 100%);
    border-color: rgba(245,158,11,.5);
}
.om-arch-pill--especiales:hover {
    background: linear-gradient(135deg, rgba(245,158,11,.6) 0%, rgba(236,72,153,.6) 100%);
}
.om-arch-pill--especiales .om-arch-pill__icon svg { color: #FCD34D; }
.om-arch-pill--especiales.is-active {
    background: linear-gradient(135deg, #F59E0B 0%, #EC4899 100%);
    color: #fff;
    border-color: transparent;
    box-shadow: 0 6px 20px rgba(245,158,11,.4);
}
.om-arch-pill--especiales.is-active .om-arch-pill__icon svg { color: #fff; }
.om-arch-pill--especiales.is-active .om-arch-pill__count { background: #fff; color: #EC4899; }

/* Filterbar glass */
.om-arch__filterbar-wrap { margin: -36px 36px 24px; position: relative; z-index: 5; }
.om-arch-filterbar {
    background: rgba(255,255,255,.97);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid rgba(255,255,255,.7);
    border-radius: 20px;
    padding: 16px;
    box-shadow: 0 16px 44px rgba(26,8,87,.16), 0 2px 6px rgba(26,8,87,.05);
    display: flex;
    gap: 12px;
    align-items: flex-end;
    flex-wrap: wrap;
}
.om-arch-filter {
    flex: 1 1 140px;
    min-width: 130px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    position: relative;
}
.om-arch-filter--search {
    flex: 2 1 280px;
    min-width: 260px;
    flex-direction: row;
    align-items: center;
    gap: 0;
    padding: 0 14px;
    background: #F5F3FF;
    border: 1.5px solid transparent;
    border-radius: 12px;
    height: 48px;
}
.om-arch-filter--search:focus-within { border-color: var(--omc2); background: #fff; }
.om-arch-filter__icon { color: var(--omc2); margin-right: 10px; flex-shrink: 0; display: flex; }
.om-arch-filter__icon svg { width: 18px; height: 18px; }
.om-arch-filter--search .om-arch-input {
    border: none;
    background: transparent;
    flex: 1;
    height: 100%;
    padding: 0;
    font-size: 14px;
    font-weight: 500;
}
.om-arch-filter__label {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: #6B7280;
    font-weight: 700;
}
.om-arch-input, .om-arch-select {
    height: 42px;
    border: 1.5px solid #E5E7EB;
    border-radius: 10px;
    padding: 0 12px;
    font-family: inherit;
    font-size: 13px;
    font-weight: 600;
    color: #1A1A2E;
    background: #fff;
    outline: none;
    width: 100%;
    transition: border-color .15s;
}
.om-arch-input:focus, .om-arch-select:focus { border-color: var(--omc2); }
.om-arch-input--small { width: 70px; text-align: center; padding: 0 4px; }
.om-arch-filter--price .om-arch-price-inputs {
    display: flex;
    align-items: center;
    gap: 4px;
    height: 42px;
    border: 1.5px solid #E5E7EB;
    border-radius: 10px;
    padding: 0 8px;
    background: #fff;
}
.om-arch-filter--price .om-arch-price-inputs input { border: none; background: transparent; }
.om-arch-price-sep { color: #D1D5DB; }
.om-arch-filterbar__actions { display: flex; gap: 8px; align-items: flex-end; }
.om-arch-btn {
    height: 48px;
    padding: 0 22px;
    border-radius: 12px;
    font-family: inherit;
    font-weight: 700;
    font-size: 13px;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    cursor: pointer;
    border: none;
    transition: all .2s;
    letter-spacing: .3px;
}
.om-arch-btn--primary {
    background: var(--omgradcta);
    color: #fff;
    box-shadow: 0 6px 16px rgba(195,63,188,.35);
}
.om-arch-btn--primary:hover { transform: translateY(-1px); box-shadow: 0 8px 20px rgba(195,63,188,.45); }
.om-arch-btn--ghost { background: transparent; color: #6B7280; border: 1.5px solid #E5E7EB; }
.om-arch-btn--ghost:hover { border-color: var(--omc2); color: var(--omc2); }
.om-arch-btn svg { width: 16px; height: 16px; }

/* Multi-select */
.om-arch-multi-toggle {
    height: 42px;
    padding: 0 12px;
    border: 1.5px solid #E5E7EB;
    border-radius: 10px;
    background: #fff;
    cursor: pointer;
    font-family: inherit;
    font-size: 13px;
    color: #1A1A2E;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    width: 100%;
    font-weight: 600;
}
.om-arch-multi-toggle:hover { border-color: var(--omc2); }
.om-arch-multi-caret { color: #9CA3AF; font-size: 10px; }
.om-arch-multi-panel {
    position: absolute;
    top: calc(100% + 4px);
    left: 0; right: 0;
    background: #fff;
    border: 1.5px solid #E5E7EB;
    border-radius: 10px;
    box-shadow: 0 8px 24px rgba(0,0,0,.1);
    padding: 8px;
    max-height: 240px;
    overflow-y: auto;
    z-index: 10;
}
.om-arch-multi-option {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 13px;
}
.om-arch-multi-option:hover { background: #F9F5FF; }
.om-arch-multi-option input { accent-color: var(--omc2); }

/* Results */
.om-arch__results { padding: 0 36px 18px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; }
.om-arch-results-count { color: #4B5563; font-size: 14px; }
.om-arch-results-count strong { color: #1A1A2E; font-weight: 800; }
.om-arch-results-order { display: flex; align-items: center; gap: 10px; }
.om-arch-results-order label { font-size: 12px; color: #9CA3AF; font-weight: 500; }
.om-arch-order-select {
    height: 36px;
    border: 1.5px solid #E5E7EB;
    border-radius: 8px;
    padding: 0 28px 0 10px;
    font-family: inherit;
    font-size: 12px;
    font-weight: 600;
    background: #fff;
    cursor: pointer;
}

/* Cards */
.om-arch__products { display: flex; flex-direction: column; gap: 16px; padding: 0 36px; }
.om-arch-card {
    background: #fff;
    border: 1px solid #EEE;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,.04);
    transition: all .25s ease;
    position: relative;
}
.om-arch-card__main {
    display: grid;
    grid-template-columns: 300px 1fr 270px;
}
.om-arch-card:hover {
    border-color: rgba(195,63,188,.4);
    box-shadow: 0 12px 32px rgba(26,8,87,.1);
    transform: translateY(-2px);
}

/* Carrusel */
.om-arch-car { position: relative; overflow: hidden; min-height: 300px; }
.om-arch-car__track { display: flex; height: 100%; transition: transform .35s cubic-bezier(.4,0,.2,1); }
.om-arch-car__slide {
    flex: 0 0 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    cursor: zoom-in;
    min-height: 300px;
}
.om-arch-car__btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 32px; height: 32px;
    border-radius: 50%;
    background: rgba(255,255,255,.95);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--omc1);
    box-shadow: 0 4px 12px rgba(0,0,0,.18);
    opacity: 0;
    transition: all .2s;
    z-index: 3;
}
.om-arch-car__btn svg { width: 16px; height: 16px; }
.om-arch-card:hover .om-arch-car__btn { opacity: 1; }
.om-arch-car__btn:hover { background: #fff; transform: translateY(-50%) scale(1.08); }
.om-arch-car__btn--prev { left: 8px; }
.om-arch-car__btn--next { right: 8px; }
.om-arch-car__dots {
    position: absolute;
    bottom: 44px;
    left: 0; right: 0;
    display: flex;
    justify-content: center;
    gap: 4px;
    z-index: 2;
}
.om-arch-car__dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: rgba(255,255,255,.55);
    border: none;
    cursor: pointer;
    padding: 0;
    transition: all .2s;
    box-shadow: 0 1px 2px rgba(0,0,0,.3);
}
.om-arch-car__dot.is-active { background: #fff; width: 18px; border-radius: 3px; }

/* Overlays sobre la imagen */
.om-arch-card__tipo {
    position: absolute;
    top: 12px; left: 12px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 11px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    color: #fff;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .5px;
    text-transform: uppercase;
    z-index: 2;
}
.om-arch-card__tipo svg { width: 12px; height: 12px; }
.om-arch-card__tipo--grupos { background: rgba(41,16,143,.92); }
.om-arch-card__tipo--individuales { background: rgba(236,25,156,.92); }
.om-arch-card__tipo--tours { background: rgba(195,63,188,.92); }
.om-arch-card__tipo--charter { background: rgba(92,31,158,.92); }
.om-arch-card__tipo--paquetes { background: rgba(245,158,11,.92); }
.om-arch-card__tipo--circuitos { background: rgba(16,185,129,.92); }
.om-arch-card__photos {
    position: absolute;
    bottom: 12px; left: 12px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 9px;
    background: rgba(0,0,0,.55);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    color: #fff;
    border-radius: 6px;
    font-size: 11px;
    font-weight: 600;
    z-index: 2;
}
.om-arch-card__photos svg { width: 13px; height: 13px; }
.om-arch-card__clave-badge {
    position: absolute;
    bottom: 12px; right: 12px;
    padding: 3px 8px;
    background: rgba(255,255,255,.92);
    color: var(--omc1);
    border-radius: 6px;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .5px;
    z-index: 2;
}

/* Info */
.om-arch-card__info {
    padding: 18px 22px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-width: 0;
}
.om-arch-card__stars { display: flex; align-items: center; gap: 2px; margin-bottom: 5px; color: #F59E0B; }
.om-arch-card__stars svg { width: 12px; height: 12px; }
.om-arch-card__stars-label { margin-left: 4px; font-size: 10px; color: #9CA3AF; font-weight: 600; }
.om-arch-card__title-link { text-decoration: none; color: inherit; }
.om-arch-card__title {
    margin: 0 0 4px;
    font-size: 18px;
    font-weight: 700;
    color: #1A1A2E;
    line-height: 1.25;
    transition: color .15s;
}
.om-arch-card__title-link:hover .om-arch-card__title { color: var(--omc2); }
.om-arch-card__subtitle { margin: 0 0 8px; font-size: 13px; color: #6B7280; font-weight: 500; }
.om-arch-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    font-size: 12px;
    color: #6B7280;
    font-weight: 500;
    margin-bottom: 10px;
}
.om-arch-card__meta-item { display: inline-flex; align-items: center; gap: 4px; }
.om-arch-card__meta-item svg { width: 13px; height: 13px; flex-shrink: 0; }
.om-arch-card__chips { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 10px; }
.om-arch-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 9px;
    border-radius: 6px;
    font-size: 11px;
    font-weight: 600;
}
.om-arch-chip svg { width: 13px; height: 13px; }
.om-arch-chip--gold { background: linear-gradient(135deg,#FEF3C7,#FDE68A); color: #92400E; font-weight: 700; }
.om-arch-chip--purple { background: #F3E8FF; color: var(--omc2); }
.om-arch-chip--green { background: #ECFDF5; color: #065F46; }
.om-arch-chip--blue { background: #EFF6FF; color: #1E40AF; }
.om-arch-chip--pink { background: #FCE7F3; color: #9F1239; }
.om-arch-card__fechas {
    padding: 0;
    background: transparent;
    border: none;
    font-size: 11px;
    color: #4C1D95;
}
.om-arch-card__fechas--unica { color: #92400E; }
.om-arch-card__fechas--multi { color: #5C1F9E; }
.om-arch-card__fechas-head {
    display: flex;
    align-items: center;
    gap: 5px;
    font-weight: 700;
    text-transform: uppercase;
    font-size: 9.5px;
    letter-spacing: .06em;
    margin-bottom: 6px;
    opacity: .75;
    color: #6B7280;
}
.om-arch-card__fechas-head svg { width: 12px; height: 12px; flex-shrink: 0; color: var(--omc2); }
.om-arch-card__fechas-label { font-weight: 700; }
.om-arch-card__fechas-value {
    display: inline-block;
    background: linear-gradient(135deg, #F5F3FF 0%, #FCE7F3 100%);
    color: #5C1F9E;
    padding: 5px 12px;
    border-radius: 999px;
    font-weight: 700;
    font-size: 11px;
    border: 1px solid rgba(120,53,232,.12);
}
.om-arch-card__fechas--unica .om-arch-card__fechas-value {
    background: linear-gradient(135deg, #FEF3C7 0%, #FFFBEB 100%);
    color: #92400E;
    border-color: rgba(245,158,11,.2);
}
.om-arch-card__fechas-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}
.om-arch-card__fechas-list li {
    background: linear-gradient(135deg, #F5F3FF 0%, #FCE7F3 100%);
    color: #5C1F9E;
    padding: 5px 12px;
    border-radius: 999px;
    font-weight: 700;
    font-size: 11px;
    line-height: 1.3;
    border: 1px solid rgba(120,53,232,.12);
    white-space: nowrap;
}

/* Tabs microexploracion */
.om-arch-card__tabs {
    display: flex;
    gap: 4px;
    margin-top: 12px;
    border-top: 1px dashed #E5E7EB;
    padding-top: 10px;
    flex-wrap: wrap;
}
.om-arch-tab {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 11px;
    background: transparent;
    border: 1px solid #E5E7EB;
    border-radius: 7px;
    font-size: 11px;
    font-weight: 600;
    color: #4B5563;
    cursor: pointer;
    font-family: inherit;
    transition: all .15s;
}
.om-arch-tab svg { width: 13px; height: 13px; }
.om-arch-tab:hover { border-color: var(--omc2); color: var(--omc2); }
.om-arch-tab.is-active { background: var(--omc1); border-color: var(--omc1); color: #fff; }

/* Tab Cotizar: link directo al cotizador del single, estilo CTA */
.om-arch-tab--cotizar {
    background: linear-gradient(135deg, #C33FBC 0%, #7835E8 100%);
    border-color: transparent;
    color: #fff !important;
    text-decoration: none;
    margin-left: auto;
    box-shadow: 0 2px 6px rgba(195,63,188,.28);
}
.om-arch-tab--cotizar:hover {
    background: linear-gradient(135deg, #7835E8 0%, #5C1F9E 100%);
    border-color: transparent;
    color: #fff !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 10px rgba(195,63,188,.4);
}
.om-arch-tab--cotizar svg { color: #fff; }

/* Pricing */
.om-arch-card__pricing {
    background: linear-gradient(180deg, #FAF7FF 0%, #F3E8FF 100%);
    padding: 16px 14px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    border-left: 1px solid #F3F0FA;
    min-width: 0;
}
.om-arch-card__pricing-label {
    font-size: 9px;
    font-weight: 800;
    color: #9CA3AF;
    letter-spacing: .6px;
    text-transform: uppercase;
    margin-bottom: 8px;
}
.om-arch-rates { display: flex; flex-direction: column; gap: 6px; }
.om-arch-rate {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #fff;
    border-radius: 8px;
    padding: 7px 11px;
    border: 1px solid rgba(195,63,188,.15);
    box-shadow: 0 1px 2px rgba(26,8,87,.04);
}
.om-arch-rate__lbl {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 10px;
    font-weight: 700;
    color: #6B7280;
    letter-spacing: .5px;
}
.om-arch-rate__lbl svg { width: 11px; height: 11px; color: var(--omc2); }
.om-arch-rate__val { font-size: 15px; font-weight: 800; color: var(--omc1); }
.om-arch-rate.is-empty { opacity: .4; }
.om-arch-rate.is-empty .om-arch-rate__val { color: #9CA3AF; font-weight: 600; font-size: 13px; }

.om-arch-card__price-simple { text-align: center; }
.om-arch-card__price-value {
    display: block;
    font-size: 30px;
    font-weight: 800;
    color: var(--omc1);
    line-height: 1;
    letter-spacing: -.5px;
}
.om-arch-card__price-unit { display: block; font-size: 10px; color: #6B7280; margin-top: 4px; font-weight: 500; }

.om-arch-card__price-ind { text-align: center; margin-bottom: 8px; }
.om-arch-card__price-ind .om-arch-card__price-value { font-size: 26px; }
.om-arch-card__menor {
    background: rgba(16,185,129,.1);
    border: 1px solid rgba(16,185,129,.25);
    border-radius: 8px;
    padding: 5px 8px;
    text-align: center;
}
.om-arch-card__menor-label {
    display: block;
    font-size: 9px;
    font-weight: 700;
    color: #065F46;
    letter-spacing: .3px;
    text-transform: uppercase;
}
.om-arch-card__menor-value { display: block; font-size: 14px; font-weight: 800; color: #065F46; }

.om-arch-card__cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    margin-top: 12px;
    background: var(--omgradcta);
    color: #fff;
    padding: 11px;
    border-radius: 10px;
    text-decoration: none;
    font-weight: 700;
    font-size: 12px;
    letter-spacing: .3px;
    box-shadow: 0 4px 12px rgba(195,63,188,.32);
    transition: all .2s;
}
.om-arch-card__cta svg { width: 14px; height: 14px; }
.om-arch-card__cta:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(195,63,188,.45); }
.om-arch-card__cta--pink { background: var(--omgradpink); box-shadow: 0 4px 12px rgba(236,25,156,.35); }
.om-arch-card__cta--pink:hover { box-shadow: 0 6px 16px rgba(236,25,156,.45); }

/* Drawer */
.om-arch-drawer {
    display: none;
    background: #FAFAFC;
    border-top: 1px solid #F3E8FF;
    padding: 16px 24px;
    animation: omArchDrawerIn .25s ease;
}
.om-arch-drawer.is-open { display: block; }
@keyframes omArchDrawerIn {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
}
.om-arch-drawer__head { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.om-arch-drawer__head svg { width: 16px; height: 16px; color: var(--omc2); }
.om-arch-drawer__title { font-size: 12px; font-weight: 800; color: #1A1A2E; letter-spacing: .5px; text-transform: uppercase; }
.om-arch-drawer__list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px 18px;
    font-size: 12px;
    color: #374151;
    margin: 0;
    padding: 0;
    list-style: none;
}
.om-arch-drawer__item { display: flex; align-items: flex-start; gap: 6px; }
.om-arch-drawer__item svg { width: 14px; height: 14px; color: #10B981; margin-top: 1px; flex-shrink: 0; }
.om-arch-drawer__empty { font-size: 12px; color: #9CA3AF; font-style: italic; }
.om-arch-drawer__hotel-name { font-weight: 700; color: #1A1A2E; margin: 0 0 4px; font-size: 14px; }
.om-arch-drawer__hotel-loc { font-size: 12px; color: #6B7280; margin: 0 0 8px; display: inline-flex; align-items: center; gap: 4px; }
.om-arch-drawer__hotel-loc svg { width: 13px; height: 13px; color: #C33FBC; }
.om-arch-drawer__hotel-stars { color: #F59E0B; margin-bottom: 6px; }
.om-arch-drawer__hotel-stars svg { width: 13px; height: 13px; vertical-align: -2px; }
.om-arch-drawer__subtitle {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #5C1F9E;
    margin: 10px 0 6px;
}
.om-arch-drawer__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin: 0;
    padding: 0;
    list-style: none;
}
.om-arch-drawer__chip {
    font-size: 11px;
    background: #F3F0FA;
    color: #4B2D80;
    padding: 4px 9px;
    border-radius: 12px;
    border: 1px solid rgba(92,31,158,.12);
    line-height: 1.3;
}
.om-arch-drawer__avisos {
    font-size: 12px;
    line-height: 1.55;
    color: #374151;
    background: #FFF8EC;
    border-left: 3px solid #F59E0B;
    padding: 10px 12px;
    border-radius: 6px;
}
.om-arch-drawer__avisos p { margin: 0 0 6px; }
.om-arch-drawer__avisos p:last-child { margin-bottom: 0; }
.om-arch-drawer__pdf {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--omgradcta);
    color: #fff;
    text-decoration: none;
    padding: 9px 16px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 700;
    box-shadow: 0 4px 10px rgba(195,63,188,.3);
}
.om-arch-drawer__pdf svg { width: 14px; height: 14px; }
.om-arch-drawer__map {
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,.08);
}
.om-arch-drawer__map iframe {
    display: block;
    width: 100%;
    border: 0;
}
.om-arch-drawer__cotizar {
    text-align: center;
    padding: 6px 0;
}
.om-arch-drawer__cotizar-msg {
    font-size: 12px;
    color: #4B5563;
    margin: 0 0 12px;
    line-height: 1.5;
}
.om-arch-drawer__cotizar-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: linear-gradient(135deg, #7835E8 0%, #5C1F9E 100%);
    color: #fff;
    text-decoration: none;
    padding: 11px 22px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 700;
    box-shadow: 0 4px 14px rgba(120,53,232,.35);
    transition: transform .15s, box-shadow .15s;
}
.om-arch-drawer__cotizar-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(120,53,232,.45);
    color: #fff;
}
.om-arch-drawer__cotizar-btn svg { width: 16px; height: 16px; }

/* Lightbox */
.om-arch-lb {
    position: fixed;
    inset: 0;
    background: rgba(10,5,40,.94);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 999999;
    padding: 24px;
}
.om-arch-lb.is-open { display: flex; }
.om-arch-lb__img { max-width: 92vw; max-height: 84vh; border-radius: 12px; box-shadow: 0 24px 60px rgba(0,0,0,.5); }
.om-arch-lb__close,
.om-arch-lb__nav {
    position: absolute;
    width: 44px; height: 44px;
    border-radius: 50%;
    background: rgba(255,255,255,.14);
    border: 1px solid rgba(255,255,255,.25);
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}
.om-arch-lb__close svg, .om-arch-lb__nav svg { width: 22px; height: 22px; }
.om-arch-lb__close { top: 20px; right: 20px; }
.om-arch-lb__nav { top: 50%; transform: translateY(-50%); }
.om-arch-lb__nav--prev { left: 24px; }
.om-arch-lb__nav--next { right: 24px; }
.om-arch-lb__counter {
    position: absolute;
    top: 24px; left: 24px;
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: .5px;
    padding: 8px 16px;
    background: rgba(255,255,255,.14);
    border: 1px solid rgba(255,255,255,.25);
    border-radius: 999px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    font-family: 'Plus Jakarta Sans', sans-serif;
}

/* Empty */
.om-arch-empty {
    text-align: center;
    padding: 60px 20px;
    background: #FAFAFC;
    border-radius: 16px;
    border: 1px dashed #E5E7EB;
    margin: 0 36px;
}
.om-arch-empty__icon { width: 56px; height: 56px; margin: 0 auto 14px; color: #C4B5FD; }
.om-arch-empty__icon svg { width: 100%; height: 100%; }
.om-arch-empty__title { margin: 0 0 8px; font-size: 18px; color: #1A1A2E; font-weight: 700; }
.om-arch-empty__text { margin: 0 0 20px; color: #6B7280; }

/* Paginacion */
.om-arch-pagination { display: flex; gap: 6px; justify-content: center; margin-top: 32px; }
.om-arch-page {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 14px;
    border-radius: 10px;
    border: 1.5px solid #E5E7EB;
    background: #fff;
    color: #4B5563;
    text-decoration: none;
    font-weight: 700;
    font-size: 14px;
    transition: all .15s;
}
.om-arch-page:hover { border-color: var(--omc2); color: var(--omc2); }
.om-arch-page.is-active {
    background: var(--omgradcta);
    color: #fff;
    border-color: transparent;
    box-shadow: 0 4px 12px rgba(195,63,188,.3);
}

/* Responsive */
@media (max-width: 1024px) {
    .om-arch-card__main { grid-template-columns: 220px 1fr; }
    .om-arch-card__pricing {
        grid-column: 1 / -1;
        border-left: none;
        border-top: 1px solid #F3F0FA;
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        padding: 14px 18px;
        gap: 12px;
    }
    .om-arch-rates { flex-direction: row; flex-wrap: wrap; flex: 1; }
    .om-arch-rate { flex: 1 1 100px; }
    .om-arch-card__price-simple, .om-arch-card__price-ind { text-align: left; }
    .om-arch-card__cta { margin-top: 0; min-width: 140px; }
    .om-arch__hero { margin: 0 16px; }
    .om-arch__filterbar-wrap { margin: -32px 28px 24px; }
}
@media (max-width: 700px) {
    .om-arch__hero { margin: 0; border-radius: 0; min-height: 280px; }
    .om-arch__hero-inner { padding: 24px 20px; }
    .om-arch__title { font-size: 26px; }
    .om-arch__filterbar-wrap { margin: -28px 16px 20px; }
    .om-arch-filterbar { padding: 12px; }
    .om-arch-filter { flex: 1 1 100%; }
    .om-arch__results, .om-arch__products { padding-left: 16px; padding-right: 16px; }
    .om-arch-card__main { grid-template-columns: 1fr; }
    .om-arch-car, .om-arch-car__slide { min-height: 220px; }
    .om-arch-car__slide { aspect-ratio: 16/9; }
    .om-arch-card__pricing { flex-direction: column; align-items: stretch; }
    .om-arch-drawer__list { grid-template-columns: 1fr; }
    .om-arch-empty { margin: 0 16px; }
}


/* === Drawer card de paquete: grid de servicios del hotel (3 cols) + descripción === */
.om-arch-drawer__list--grid {
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)) !important;
    gap: 6px 14px !important;
    max-height: 320px;
    overflow-y: auto;
    padding-right: 4px !important;
}
.om-arch-drawer__list--grid .om-arch-drawer__item {
    font-size: 11.5px;
    line-height: 1.35;
}
.om-arch-drawer__hotel-desc {
    margin-top: 10px;
    font-size: 12.5px;
    line-height: 1.55;
    color: #374151;
    max-height: 280px;
    overflow-y: auto;
    padding-right: 4px;
}
.om-arch-drawer__hotel-desc p {
    margin: 0 0 8px 0;
}
.om-arch-drawer__hotel-desc p:last-child {
    margin-bottom: 0;
}


/* ============================================================
 * BADGE DE DISPONIBILIDAD (mensaje informativo estático)
 * Aparece en: card del archive (al pie) y single del producto (después de info-card)
 * ============================================================ */
.om-arch-disponibilidad {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    padding: 12px 18px;
    background: linear-gradient(135deg, #faf7ff 0%, #f4ecff 100%);
    border-top: 1px solid #ece5f7;
    border-radius: 0 0 12px 12px;
    font-size: 12.5px;
    font-weight: 600;
    color: #5a4d7a;
    flex-wrap: wrap;
    margin-top: 0;
}
.om-arch-disponibilidad__lbl {
    font-weight: 700;
    color: #29108F;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 11px;
}
.om-arch-disponibilidad__item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #3a2b66;
}
.om-arch-disponibilidad__item svg {
    width: 16px;
    height: 16px;
    color: #7835E8;
    flex-shrink: 0;
}
.om-arch-disponibilidad__sep {
    color: #b5a8d4;
    font-weight: 700;
    user-select: none;
}

/* En single del producto: separar del info-card con más espacio + mismo estilo */
.om-info-card .om-arch-disponibilidad {
    margin-top: 12px;
    border-radius: 12px;
    border: 1px solid #ece5f7;
    border-top: 1px solid #ece5f7;
}

/* Responsive: en móvil apilar verticalmente */
@media (max-width: 640px) {
    .om-arch-disponibilidad {
        flex-direction: column;
        gap: 8px;
        align-items: center;
        text-align: center;
    }
    .om-arch-disponibilidad__sep {
        display: none;
    }
}


/* === FIX iconos del badge en single — forzar tamaño pequeño === */
.om-info-card .om-arch-disponibilidad svg,
.om-info-card + .om-arch-disponibilidad svg,
.om-hero .om-arch-disponibilidad svg,
.om-arch-disponibilidad__item svg {
    width: 16px !important;
    height: 16px !important;
    max-width: 16px !important;
    max-height: 16px !important;
    flex-shrink: 0;
}
