/* ============================================================
   Hotel Offers Theme — main.css
   ============================================================ */

/* ── Variables ────────────────────────────────────────────── */
:root {
    --color-primary:    #0057b8;
    --color-primary-dk: #00409a;
    --color-accent:     #e8572a;
    --color-accent-dk:  #c44520;
    --color-success:    #2e7d32;
    --color-warning:    #e65100;
    --color-error:      #c62828;
    --color-bg:         #f5f7fa;
    --color-surface:    #ffffff;
    --color-border:     #dde3ec;
    --color-text:       #1a1e2e;
    --color-muted:      #6b7280;
    --color-verified:   #1565c0;

    --radius-sm:  4px;
    --radius-md:  8px;
    --radius-lg:  16px;

    --shadow-sm:  0 1px 3px rgba(0,0,0,.08);
    --shadow-md:  0 4px 12px rgba(0,0,0,.10);
    --shadow-lg:  0 8px 24px rgba(0,0,0,.12);

    --font-sans:  -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --font-size-base: 16px;
    --line-height: 1.6;

    --container-max: 1200px;
    --container-pad: 1.25rem;
    --header-h: 62px;
}

/* ── Reset ────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html  { font-size: var(--font-size-base); scroll-behavior: smooth; }
body  { font-family: var(--font-sans); color: var(--color-text); background: var(--color-bg); line-height: var(--line-height); }
img   { max-width: 100%; height: auto; display: block; }
a     { color: var(--color-primary); text-decoration: none; }
a:hover { text-decoration: underline; }
ul, ol { list-style: none; }

/* ── Layout ───────────────────────────────────────────────── */
.container {
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-pad);
}

.site-main { padding-block: 2rem; }

/* ── Buttons ──────────────────────────────────────────────── */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .4em;
    padding: .6rem 1.25rem;
    border-radius: var(--radius-sm);
    font-size: .9rem;
    font-weight: 600;
    cursor: pointer;
    border: 2px solid transparent;
    transition: background .15s, color .15s, border-color .15s;
    text-decoration: none;
    white-space: nowrap;
}
.btn:hover { text-decoration: none; }

.btn-primary   { background: var(--color-primary);    color: #fff; }
.btn-primary:hover { background: var(--color-primary-dk); color: #fff; }

.btn-accent    { background: var(--color-accent);     color: #fff; }
.btn-accent:hover { background: var(--color-accent-dk); color: #fff; }

.btn-outline   { background: transparent; border-color: var(--color-primary); color: var(--color-primary); }
.btn-outline:hover { background: var(--color-primary); color: #fff; }

.btn-ghost     { background: transparent; border-color: var(--color-border); color: var(--color-text); }
.btn-ghost:hover { background: var(--color-border); }

.btn-pdf { background: #f5f5f5; border-color: #d0d5dd; color: #374151; }
.btn-pdf:hover { background: #e8f0fe; border-color: var(--color-primary); color: var(--color-primary); text-decoration: none; }

.btn-sm  { padding: .4rem .85rem; font-size: .8rem; }
.btn-lg  { padding: .75rem 1.75rem; font-size: 1rem; }
.btn-block { width: 100%; display: flex; }
.btn:disabled { opacity: .6; cursor: not-allowed; }

/* ── Header ───────────────────────────────────────────────── */
.site-header {
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border);
    position: sticky;
    top: 0;
    z-index: 100;
    box-shadow: 0 1px 6px rgba(0,0,0,.07);
}

.site-header__inner {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    padding-block: .7rem;
    min-height: var(--header-h);
}

/* ── Branding ─────────────────────────────────────────────── */
.site-brand {
    display: flex;
    align-items: center;
    gap: .6rem;
    text-decoration: none;
    flex-shrink: 0;
}
.site-brand:hover { text-decoration: none; }
.site-logo svg { display: block; }
.site-name {
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--color-text);
    letter-spacing: -.02em;
    white-space: nowrap;
    line-height: 1.2;
}
.site-name span {
    display: block;
    font-size: .65rem;
    font-weight: 500;
    color: var(--color-muted);
    letter-spacing: .02em;
}

/* ── Primary nav ──────────────────────────────────────────── */
.primary-nav { display: flex; }

.nav-menu {
    display: flex;
    gap: .15rem;
    align-items: center;
    list-style: none;
    margin: 0;
    padding: 0;
}

.nav-menu > li { position: relative; }

.nav-menu > li > a {
    display: block;
    padding: .45rem .9rem;
    font-size: .9rem;
    font-weight: 500;
    color: var(--color-text);
    border-radius: var(--radius-sm);
    transition: background .15s, color .15s;
}
.nav-menu > li > a:hover { background: var(--color-bg); color: var(--color-primary); text-decoration: none; }

/* Dropdown trigger */
.nav-dropdown-toggle {
    display: flex;
    align-items: center;
    gap: .3em;
    padding: .45rem .9rem;
    font-size: .9rem;
    font-weight: 500;
    color: var(--color-text);
    background: none;
    border: none;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background .15s, color .15s;
    white-space: nowrap;
    font-family: inherit;
}
.nav-dropdown-toggle:hover,
.nav-item--dropdown.is-open .nav-dropdown-toggle {
    background: var(--color-bg);
    color: var(--color-primary);
}

.nav-chevron { transition: transform .2s; flex-shrink: 0; }
.nav-item--dropdown.is-open .nav-chevron { transform: rotate(180deg); }

/* Dropdown panel */
.nav-dropdown {
    display: none;
    position: absolute;
    top: calc(100% + .5rem);
    left: 0;
    min-width: 230px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    z-index: 200;
    overflow: hidden;
}
.nav-item--dropdown.is-open .nav-dropdown { display: block; }

.nav-dropdown__inner { padding: .5rem; }

.nav-dropdown__label {
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .09em;
    text-transform: uppercase;
    color: var(--color-muted);
    padding: .4rem .75rem .3rem;
    display: block;
}

.nav-dropdown__item {
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: .55rem .75rem;
    border-radius: var(--radius-md);
    font-size: .875rem;
    font-weight: 500;
    color: var(--color-text);
    text-decoration: none;
    transition: background .15s, color .15s;
}
.nav-dropdown__item:hover { background: var(--color-bg); color: var(--color-primary); text-decoration: none; }
.nav-dropdown__item--all { font-weight: 600; border-bottom: 1px solid var(--color-border); margin-bottom: .3rem; padding-bottom: .7rem; }

.nav-dropdown__icon {
    width: 1.3rem;
    font-size: .82rem;
    flex-shrink: 0;
    color: var(--color-muted);
    text-align: center;
}
.nav-dropdown__count {
    margin-left: auto;
    font-size: .7rem;
    background: var(--color-bg);
    border-radius: 100px;
    padding: .1em .5em;
    color: var(--color-muted);
    flex-shrink: 0;
}

/* ── Header actions ───────────────────────────────────────── */
.header-actions { margin-left: auto; display: flex; gap: .5rem; align-items: center; flex-shrink: 0; }

/* ── Hamburger (mobile) ───────────────────────────────────── */
.nav-hamburger {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    background: none;
    border: 1px solid var(--color-border);
    cursor: pointer;
    padding: .45rem .5rem;
    border-radius: var(--radius-sm);
    flex-shrink: 0;
}
.nav-hamburger span {
    display: block;
    width: 20px;
    height: 2px;
    background: var(--color-text);
    border-radius: 2px;
    transition: transform .25s, opacity .25s;
}
.nav-hamburger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-hamburger.is-open span:nth-child(2) { opacity: 0; }
.nav-hamburger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile nav panel */
.mobile-nav {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--color-surface);
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    box-shadow: var(--shadow-lg);
    z-index: 99;
    padding: 1rem;
}
.mobile-nav.is-open { display: block; }
.mobile-nav__links { display: flex; flex-direction: column; gap: .25rem; margin-bottom: .75rem; }
.mobile-nav__links a,
.mobile-nav__links button {
    display: block;
    width: 100%;
    text-align: left;
    padding: .65rem .85rem;
    font-size: .95rem;
    font-weight: 500;
    color: var(--color-text);
    border-radius: var(--radius-md);
    text-decoration: none;
    background: none;
    border: none;
    cursor: pointer;
    font-family: inherit;
    transition: background .15s;
}
.mobile-nav__links a:hover,
.mobile-nav__links button:hover { background: var(--color-bg); color: var(--color-primary); }
.mobile-nav__cats { padding-left: 1.25rem; display: flex; flex-direction: column; gap: .15rem; margin-top: .15rem; }
.mobile-nav__cats a { font-size: .88rem; color: var(--color-muted); padding: .4rem .85rem; }
.mobile-nav__actions { display: flex; gap: .5rem; flex-wrap: wrap; padding-top: .75rem; border-top: 1px solid var(--color-border); }
.mobile-nav__actions .btn { flex: 1; justify-content: center; }

@media ( max-width: 880px ) {
    .primary-nav { display: none; }
    .header-actions { display: none; }
    .nav-hamburger { display: flex; }
}

/* ── Footer ───────────────────────────────────────────────── */
.site-footer {
    background: #0c1427;
    color: rgba(255,255,255,.7);
    margin-top: 5rem;
}
.site-footer a { color: rgba(255,255,255,.65); text-decoration: none; transition: color .15s; }
.site-footer a:hover { color: #fff; text-decoration: none; }

/* Main grid */
.footer-main { padding: 4rem 0 3rem; border-bottom: 1px solid rgba(255,255,255,.08); }
.footer-grid {
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr 1.1fr;
    gap: 3rem;
}
@media (max-width: 960px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: 2.5rem; } }
@media (max-width: 560px) { .footer-grid { grid-template-columns: 1fr; gap: 2rem; } }

/* Brand col */
.footer-brand-col {}
.footer-brand-link {
    display: inline-flex;
    align-items: center;
    gap: .65rem;
    margin-bottom: 1rem;
    text-decoration: none;
}
.footer-brand-name {
    font-size: 1.15rem;
    font-weight: 800;
    color: #fff;
    letter-spacing: -.01em;
}
.footer-tagline {
    font-size: .875rem;
    line-height: 1.65;
    color: rgba(255,255,255,.55);
    margin-bottom: 1.5rem;
    max-width: 280px;
}

/* Social */
.footer-social { display: flex; gap: .5rem; flex-wrap: wrap; }
.footer-social__link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    background: rgba(255,255,255,.07);
    color: rgba(255,255,255,.6);
    transition: background .18s, color .18s;
}
.footer-social__link:hover { background: var(--color-primary); color: #fff; }

/* Link columns */
.footer-col {}
.footer-col__heading {
    font-size: .7rem;
    font-weight: 800;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: rgba(255,255,255,.35);
    margin-bottom: 1.1rem;
}
.footer-col__links {
    display: flex;
    flex-direction: column;
    gap: .55rem;
    list-style: none;
    padding: 0;
    margin: 0;
}
.footer-col__links li a {
    font-size: .875rem;
    color: rgba(255,255,255,.6);
}
.footer-col__links li a:hover { color: #fff; }
.footer-col__see-all {
    color: var(--color-primary) !important;
    font-weight: 600;
    font-size: .8rem !important;
    margin-top: .25rem;
}

/* Mini CTA pill in footer */
.footer-cta-pill {
    margin-top: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: .4rem;
    background: rgba(0,87,184,.25);
    border: 1px solid rgba(0,87,184,.4);
    border-radius: 10px;
    padding: .85rem 1rem;
    font-size: .8rem;
}
.footer-cta-pill span { color: rgba(255,255,255,.7); }
.footer-cta-pill a {
    color: #93c5fd !important;
    font-weight: 700;
    font-size: .82rem;
}
.footer-cta-pill a:hover { color: #fff !important; }

/* Bottom bar */
.footer-bottom {
    padding: 1.1rem 0;
    background: rgba(0,0,0,.25);
}
.footer-bottom__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: .75rem;
}
.footer-copy { font-size: .78rem; color: rgba(255,255,255,.4); margin: 0; }
.footer-legal { display: flex; gap: 1.25rem; }
.footer-legal a { font-size: .78rem; color: rgba(255,255,255,.4); }
.footer-legal a:hover { color: rgba(255,255,255,.7); }

/* ── Badges ───────────────────────────────────────────────── */
.offer-badge {
    display: inline-block;
    padding: .25em .65em;
    border-radius: var(--radius-sm);
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    background: var(--color-primary);
    color: #fff;
}
.offer-badge--featured    { background: var(--color-accent); }
.offer-badge--last_minute { background: #d32f2f; }
.offer-badge--early_bird  { background: #388e3c; }
.offer-badge--flash_sale  { background: #f57c00; }
.offer-badge--honeymoon   { background: #c2185b; }

.verified-badge {
    display: inline-flex;
    align-items: center;
    gap: .2em;
    background: var(--color-verified);
    color: #fff;
    font-size: .7rem;
    font-weight: 600;
    padding: .2em .5em;
    border-radius: var(--radius-sm);
}

.star-rating { color: #f59e0b; letter-spacing: -.05em; }

/* ── Offer Card ───────────────────────────────────────────── */
.offer-grid {
    display: grid;
    grid-template-columns: repeat( auto-fill, minmax( 300px, 1fr ) );
    gap: 1.25rem;
}

.offer-card {
    background: var(--color-surface);
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border);
    transition: box-shadow .2s, transform .2s;
    display: flex;
    flex-direction: column;
}
.offer-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.offer-card--featured { border-color: var(--color-accent); }

.offer-card__image-wrap {
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
    display: block;
}
.offer-card__image-wrap .offer-badge {
    position: absolute;
    top: .75rem;
    left: .75rem;
    z-index: 1;
}
.offer-card__image     { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.offer-card:hover .offer-card__image { transform: scale(1.03); }
.offer-card__image--placeholder { background: var(--color-bg); width: 100%; height: 100%; }

.offer-card__body   { padding: 1rem; display: flex; flex-direction: column; flex: 1; }
.offer-card__hotel  { font-size: .78rem; color: var(--color-muted); margin-bottom: .25rem; display: flex; align-items: center; gap: .35rem; flex-wrap: wrap; }
.offer-card__title  { font-size: 1rem; font-weight: 700; margin-bottom: .5rem; }
.offer-card__title a { color: var(--color-text); }
.offer-card__title a:hover { color: var(--color-primary); text-decoration: none; }

.offer-card__meta   { display: flex; gap: .5rem; flex-wrap: wrap; font-size: .8rem; margin-bottom: .75rem; }
.offer-value        { background: #e8f5e9; color: #2e7d32; font-weight: 700; padding: .15em .5em; border-radius: var(--radius-sm); }
.offer-meal, .offer-dest { background: var(--color-bg); color: var(--color-muted); padding: .15em .5em; border-radius: var(--radius-sm); }

.offer-card__footer { margin-top: auto; display: flex; justify-content: space-between; align-items: center; gap: .5rem; flex-wrap: wrap; }
.offer-deadline     { font-size: .8rem; color: var(--color-muted); }
.offer-deadline strong { color: var(--color-warning); }

/* Loading state */
.offer-grid.is-loading { opacity: .5; pointer-events: none; }

/* ── Browse page layout ───────────────────────────────────── */
.browse-offers {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 2rem;
    align-items: start;
}
@media ( max-width: 768px ) {
    .browse-offers { grid-template-columns: 1fr; }
}

.browse-filters {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 1.25rem;
    position: sticky;
    top: 70px;
}

.filter-form { display: flex; flex-direction: column; gap: .85rem; }
.filter-group label { display: block; font-size: .82rem; font-weight: 600; margin-bottom: .3rem; color: var(--color-muted); text-transform: uppercase; letter-spacing: .04em; }
.filter-group select,
.filter-group input[type="date"],
.filter-group input[type="text"] {
    width: 100%;
    padding: .5rem .75rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: .9rem;
    background: var(--color-surface);
    color: var(--color-text);
}
.filter-group--checkbox label { display: flex; align-items: center; gap: .5rem; text-transform: none; letter-spacing: 0; font-weight: 500; color: var(--color-text); }

.results-header { margin-bottom: 1rem; }
.results-count  { font-size: .9rem; color: var(--color-muted); }

.pagination { text-align: center; margin-top: 2rem; }

/* ── Offer single — hero ──────────────────────────────────── */
.offer-single__hero {
    position: relative;
    min-height: 420px;
    background: #111;
    overflow: hidden;
}
.offer-single__hero-img {
    width: 100%;
    height: 420px;
    object-fit: cover;
    opacity: .6;
    display: block;
}
.offer-single__hero-img--placeholder {
    height: 420px;
    background: linear-gradient(135deg, #00204a 0%, #0057b8 100%);
}
.offer-single__hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.25) 55%, transparent 100%);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
}
.offer-single__hero-inner {
    padding-bottom: 2.5rem;
    padding-top: 2rem;
    display: flex;
    flex-direction: column;
    gap: .7rem;
}
.offer-single__badges { display: flex; gap: .5rem; flex-wrap: wrap; }
.offer-single__title {
    font-size: clamp(1.55rem, 3.5vw, 2.3rem);
    font-weight: 900;
    color: #fff;
    line-height: 1.2;
    max-width: 760px;
    letter-spacing: -.02em;
}
.offer-single__hotel-line {
    display: flex;
    align-items: center;
    gap: .6rem;
    flex-wrap: wrap;
    font-size: .95rem;
    color: rgba(255,255,255,.8);
}
.offer-single__hotel-link {
    color: #fff;
    font-weight: 700;
    text-decoration: none;
}
.offer-single__hotel-link:hover { text-decoration: underline; color: #fff; }
.offer-single__dest {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    color: rgba(255,255,255,.65);
    font-size: .88rem;
}
.offer-single__hero-stats { display: flex; gap: .85rem; flex-wrap: wrap; align-items: center; margin-top: .2rem; }
.offer-single__hero-value {
    font-size: 1.65rem;
    font-weight: 900;
    color: #fff;
    letter-spacing: -.025em;
}
.offer-single__urgency {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    background: rgba(255,255,255,.15);
    backdrop-filter: blur(6px);
    border: 1px solid rgba(255,255,255,.25);
    color: #fff;
    padding: .35em .9em;
    border-radius: 100px;
    font-size: .82rem;
    font-weight: 600;
}
.offer-single__urgency--hot {
    background: var(--color-accent);
    border-color: transparent;
}
.offer-single__closed {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    background: rgba(180,30,30,.8);
    color: #fff;
    padding: .35em .9em;
    border-radius: 100px;
    font-size: .82rem;
    font-weight: 600;
}

/* ── Offer single — two-column layout ────────────────────── */
.offer-single__body {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 2.25rem;
    align-items: start;
    padding-top: 2rem;
    padding-bottom: 4rem;
}
.offer-single__main  { min-width: 0; }
.offer-single__sidebar { position: sticky; top: 80px; }

/* ── Offer sections ──────────────────────────────────────── */
.offer-section {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 1.75rem;
    margin-bottom: 1.25rem;
}
.offer-section__title {
    font-size: .78rem;
    font-weight: 800;
    color: var(--color-muted);
    text-transform: uppercase;
    letter-spacing: .09em;
    margin-bottom: 1.25rem;
    padding-bottom: .85rem;
    border-bottom: 1px solid var(--color-border);
}
.offer-description { line-height: 1.8; color: var(--color-text); }
.offer-description p { margin-bottom: .75rem; }
.offer-description p:last-child { margin-bottom: 0; }

/* ── Details grid ────────────────────────────────────────── */
.offer-details-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: .75rem;
}
.offer-detail-item {
    display: flex;
    align-items: flex-start;
    gap: .85rem;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 1rem 1.1rem;
    transition: border-color .15s, box-shadow .15s;
}
.offer-detail-item:hover {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(0,87,184,.06);
}
.offer-detail-item__icon {
    flex-shrink: 0;
    width: 34px;
    height: 34px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
    margin-top: .1rem;
}
.offer-detail-item__content { min-width: 0; }
.offer-detail-item__label {
    display: block;
    font-size: .7rem;
    font-weight: 700;
    color: var(--color-muted);
    text-transform: uppercase;
    letter-spacing: .07em;
    margin-bottom: .25rem;
}
.offer-detail-item__value {
    display: block;
    font-size: .95rem;
    font-weight: 600;
    color: var(--color-text);
    line-height: 1.35;
}
.promo-code {
    display: inline-block;
    background: #fff8e1;
    border: 1px dashed #f59e0b;
    color: #92400e;
    padding: .1em .5em;
    border-radius: var(--radius-sm);
    font-family: monospace;
    font-size: .88em;
    letter-spacing: .1em;
    font-style: normal;
}

/* ── What's included ─────────────────────────────────────── */
.offer-included { display: flex; flex-direction: column; gap: .65rem; }
.offer-included__item {
    display: flex;
    align-items: flex-start;
    gap: .75rem;
    font-size: .95rem;
    line-height: 1.55;
}
.offer-included__icon {
    flex-shrink: 0;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .8rem;
    font-weight: 700;
    margin-top: .15rem;
    background: #e8f5e9;
    color: var(--color-success);
}
.offer-included__item--highlight .offer-included__icon {
    background: #fff8e1;
    color: #d97706;
}
.offer-included__item--no .offer-included__icon {
    background: #ffebee;
    color: var(--color-error);
}

/* ── Terms accordion ─────────────────────────────────────── */
.offer-accordion { display: flex; flex-direction: column; gap: .5rem; }
.offer-accordion__item {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
}
.offer-accordion__item[open] { border-color: rgba(0,87,184,.35); }
.offer-accordion__summary {
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: .95rem 1.2rem;
    font-weight: 700;
    font-size: .92rem;
    cursor: pointer;
    list-style: none;
    color: var(--color-text);
    background: var(--color-surface);
    transition: background .15s;
    user-select: none;
}
.offer-accordion__summary::-webkit-details-marker { display: none; }
.offer-accordion__summary::after {
    content: '+';
    margin-left: auto;
    font-size: 1.3rem;
    font-weight: 300;
    color: var(--color-muted);
    line-height: 1;
}
.offer-accordion__item[open] .offer-accordion__summary::after { content: '\2013'; }
.offer-accordion__summary:hover { background: var(--color-bg); }
.offer-accordion__summary svg { color: var(--color-primary); flex-shrink: 0; }
.offer-accordion__body {
    padding: 1rem 1.2rem 1.25rem;
    border-top: 1px solid var(--color-border);
    font-size: .9rem;
    line-height: 1.75;
    color: var(--color-text);
    background: var(--color-surface);
}
.offer-accordion__body--terms { max-height: 300px; overflow-y: auto; }

/* ── Hotel card on offer page ────────────────────────────── */
.offer-hotel-card {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: 1.5rem;
    align-items: start;
}
.offer-hotel-card__image-wrap { display: block; }
.offer-hotel-card__image {
    width: 200px;
    height: 148px;
    object-fit: cover;
    border-radius: var(--radius-md);
    display: block;
}
.offer-hotel-card__body { min-width: 0; }
.offer-hotel-card__top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: .75rem;
    margin-bottom: .6rem;
}
.offer-hotel-card__name { font-size: 1.1rem; font-weight: 800; margin-bottom: .3rem; }
.offer-hotel-card__name a { color: var(--color-text); text-decoration: none; }
.offer-hotel-card__name a:hover { color: var(--color-primary); }
.offer-hotel-card__meta {
    display: flex;
    align-items: center;
    gap: .5rem;
    flex-wrap: wrap;
    font-size: .85rem;
}
.offer-hotel-card__dest {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    color: var(--color-muted);
}
.offer-hotel-card__excerpt { font-size: .88rem; color: var(--color-muted); line-height: 1.6; margin-bottom: .4rem; }
.offer-hotel-card__more { font-size: .83rem; color: var(--color-muted); }

/* ── Sidebar booking card ────────────────────────────────── */
.offer-sidebar-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    box-shadow: var(--shadow-md);
}
.offer-sidebar-card__value {
    font-size: 2.1rem;
    font-weight: 900;
    color: var(--color-accent);
    letter-spacing: -.03em;
    line-height: 1;
    margin-bottom: .85rem;
}
.offer-sidebar-card__urgency {
    display: flex;
    align-items: center;
    gap: .4rem;
    background: #fff8e1;
    color: #b45309;
    border: 1px solid #fde68a;
    padding: .5rem .9rem;
    border-radius: var(--radius-md);
    font-size: .83rem;
    font-weight: 600;
    margin-bottom: 1rem;
}
.offer-sidebar-card__urgency--hot {
    background: #fff1f0;
    border-color: #fca5a5;
    color: var(--color-error);
}
.offer-sidebar-card__closed {
    background: var(--color-bg);
    color: var(--color-muted);
    border: 1px solid var(--color-border);
    padding: .5rem .9rem;
    border-radius: var(--radius-md);
    font-size: .83rem;
    font-weight: 600;
    text-align: center;
    margin-bottom: 1rem;
}
.offer-sidebar-card__ctas {
    display: flex;
    flex-direction: column;
    gap: .6rem;
    margin-bottom: 1.25rem;
}
.offer-sidebar-card__notice {
    font-size: .8rem;
    color: var(--color-muted);
    margin-bottom: 1rem;
    line-height: 1.5;
    padding: .75rem;
    background: var(--color-bg);
    border-radius: var(--radius-sm);
}
.offer-sidebar-card__facts {
    display: flex;
    flex-direction: column;
    gap: .55rem;
    padding: 1rem 0;
    border-top: 1px solid var(--color-border);
    margin-bottom: .85rem;
}
.offer-fact {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .85rem;
    color: var(--color-text);
    line-height: 1.4;
}
.offer-fact svg { color: var(--color-muted); flex-shrink: 0; }
.offer-fact--promo code {
    background: #fff8e1;
    border: 1px dashed #f59e0b;
    color: #92400e;
    padding: .1em .45em;
    border-radius: var(--radius-sm);
    font-size: .85em;
    letter-spacing: .07em;
}
.offer-sidebar-card__trust {
    display: flex;
    align-items: center;
    gap: .4rem;
    font-size: .77rem;
    color: var(--color-muted);
    padding-top: .85rem;
    border-top: 1px solid var(--color-border);
}
.offer-sidebar-card__trust svg { color: var(--color-success); flex-shrink: 0; }

.offer-back-link {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    margin-top: 1rem;
    font-size: .84rem;
    color: var(--color-muted);
    text-decoration: none;
    transition: color .15s;
}
.offer-back-link:hover { color: var(--color-primary); text-decoration: none; }

/* Shared — also used on offer cards / homepage */
.offer-value       { font-size: 1.1rem; font-weight: 800; }
.booking-deadline  { background: rgba(0,0,0,.4); color: #fff; padding: .25em .65em; border-radius: var(--radius-sm); font-size: .85rem; }
.booking-closed    { background: #d32f2f; color: #fff; padding: .25em .65em; border-radius: var(--radius-sm); font-size: .85rem; }
.offer-destination { color: rgba(255,255,255,.8); font-size: .9rem; }

/* ── Hotel header ─────────────────────────────────────────── */
.hotel-header {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: 2rem;
    background: var(--color-text);
}
.hotel-header__image { width: 100%; max-height: 420px; object-fit: cover; opacity: .65; }
.hotel-header__info {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 2rem;
    background: linear-gradient(to top, rgba(0,0,0,.75) 0%, transparent 55%);
    gap: .6rem;
}
.hotel-header__info h1 { color: #fff; font-size: 2rem; font-weight: 800; }
.hotel-header__meta { display: flex; gap: .5rem; align-items: center; flex-wrap: wrap; }
.hotel-header__actions { display: flex; gap: .75rem; flex-wrap: wrap; }

/* Buttons on dark image overlay */
.hotel-header__actions .btn-outline {
    border-color: rgba(255,255,255,.6);
    color: #fff;
}
.hotel-header__actions .btn-outline:hover {
    background: rgba(255,255,255,.15);
    border-color: #fff;
    color: #fff;
}
.hotel-header__actions .btn-ghost {
    background: rgba(255,255,255,.12);
    border-color: rgba(255,255,255,.4);
    color: #fff;
}
.hotel-header__actions .btn-ghost:hover {
    background: rgba(255,255,255,.22);
    border-color: rgba(255,255,255,.7);
}

/* Verified badge + star on dark BG */
.hotel-header__meta .star-rating { color: #fbbf24; }

/* ── Tab navigation ────────────────────────────────────────── */
.offer-tabs {
    display: flex;
    gap: 0;
    border-bottom: 2px solid var(--color-border);
    margin-bottom: 2rem;
    overflow-x: auto;
    scrollbar-width: none;
}
.offer-tabs::-webkit-scrollbar { display: none; }

.tab-btn {
    display: inline-flex;
    align-items: center;
    padding: .8rem 1.4rem;
    border: none;
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    background: none;
    color: var(--color-muted);
    font-size: .9rem;
    font-weight: 500;
    font-family: var(--font-sans);
    cursor: pointer;
    white-space: nowrap;
    transition: color .15s, border-color .15s;
}
.tab-btn:hover { color: var(--color-primary); }
.tab-btn--active {
    color: var(--color-primary);
    font-weight: 700;
    border-bottom-color: var(--color-primary);
}

/* Force correct tab panel visibility — overrides WP block-library [hidden] reset */
.tab-panel         { display: block; }
.tab-panel[hidden] { display: none !important; }

.offer-tab-content { padding-bottom: 3rem; }

/* ── Hotel single — section helpers ───────────────────────── */
.hotel-section-label {
    font-size: .78rem;
    font-weight: 700;
    color: var(--color-muted);
    text-transform: uppercase;
    letter-spacing: .06em;
    margin-bottom: .6rem;
}
.hotel-trip-types { margin-bottom: 2rem; }

.facilities-summary {
    background: var(--color-bg);
    border-radius: var(--radius-md);
    padding: 1.25rem 1.5rem;
    font-size: .93rem;
    line-height: 1.7;
    margin-bottom: 1.5rem;
    white-space: pre-wrap;
}

/* ── Contact list ─────────────────────────────────────────── */
.contact-list { display: grid; gap: .25rem; }
.contact-list dt { font-weight: 600; font-size: .78rem; color: var(--color-muted); text-transform: uppercase; letter-spacing: .06em; margin-top: 1.1rem; }
.contact-list dt:first-child { margin-top: 0; }
.contact-list dd { margin: 0; font-size: .95rem; }

/* ── Forms ────────────────────────────────────────────────── */
.offer-form, .submit-offer-wrap { max-width: 760px; }

.form-section {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 1.5rem;
    margin-bottom: 1.25rem;
}
.form-section h3 { font-size: 1rem; font-weight: 700; margin-bottom: 1rem; color: var(--color-text); }

.form-row { margin-bottom: .9rem; }
.form-row label { display: block; font-size: .85rem; font-weight: 600; margin-bottom: .3rem; }
.form-row input[type="text"],
.form-row input[type="url"],
.form-row input[type="email"],
.form-row input[type="password"],
.form-row input[type="tel"],
.form-row input[type="date"],
.form-row input[type="number"],
.form-row select,
.form-row textarea {
    width: 100%;
    padding: .55rem .85rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: .9rem;
    font-family: var(--font-sans);
    background: var(--color-surface);
    color: var(--color-text);
    transition: border-color .15s, box-shadow .15s;
}
.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(0,87,184,.12);
}
.form-row small { display: block; margin-top: .25rem; font-size: .78rem; color: var(--color-muted); }
.form-row--required label::after { content: ' *'; color: var(--color-error); }

.form-row-group { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media ( max-width: 540px ) { .form-row-group { grid-template-columns: 1fr; } }

.form-submit { padding-top: .5rem; }
.form-note   { font-size: .82rem; color: var(--color-muted); margin-top: .5rem; }
.form-message { color: var(--color-error); font-size: .88rem; margin-top: .5rem; min-height: 1.2em; }
.wide-input   { width: 100%; }

.plan-info {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: .6rem 1rem;
    margin-bottom: 1.25rem;
    font-size: .88rem;
}

/* ── Notice boxes ─────────────────────────────────────────── */
.notice-box {
    border-radius: var(--radius-md);
    padding: 1rem 1.25rem;
    margin-bottom: 1.25rem;
    font-size: .9rem;
}
.notice-box--info    { background: #e3f2fd; border-left: 4px solid var(--color-primary); }
.notice-box--warning { background: #fff3e0; border-left: 4px solid #f57c00; }
.notice-box--success { background: #e8f5e9; border-left: 4px solid #388e3c; }
.success-message     { color: var(--color-success); font-weight: 600; }

/* ── Dashboard ────────────────────────────────────────────── */
.dashboard { max-width: 900px; }
.dashboard-header { margin-bottom: 1.5rem; }
.dashboard-header h2 { font-size: 1.4rem; font-weight: 800; }

.dashboard-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 1.25rem;
    margin-bottom: 1.25rem;
}
.plan-name { font-size: 1.1rem; font-weight: 700; color: var(--color-primary); margin-bottom: .3rem; }

.dashboard-actions { display: flex; gap: .75rem; flex-wrap: wrap; margin-bottom: 2rem; }

.dashboard-section { margin-bottom: 2rem; }
.dashboard-section h3 { font-size: 1rem; font-weight: 700; margin-bottom: .75rem; }

.dashboard-table { width: 100%; border-collapse: collapse; font-size: .88rem; }
.dashboard-table th, .dashboard-table td { padding: .65rem .85rem; text-align: left; border-bottom: 1px solid var(--color-border); }
.dashboard-table th { font-weight: 700; color: var(--color-muted); font-size: .78rem; text-transform: uppercase; letter-spacing: .04em; }
.dashboard-table tr:last-child td { border-bottom: none; }

.status-badge { display: inline-block; padding: .2em .6em; border-radius: var(--radius-sm); font-size: .75rem; font-weight: 700; }
.status-badge--pending  { background: #fff8e1; color: #f57c00; }
.status-badge--approved { background: #e8f5e9; color: var(--color-success); }
.status-badge--rejected { background: #ffebee; color: var(--color-error); }

/* ── Modal ────────────────────────────────────────────────── */
.modal {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.5);
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}
.modal[hidden] { display: none; }
.modal__inner {
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    padding: 2rem;
    max-width: 480px;
    width: 100%;
    position: relative;
    box-shadow: var(--shadow-lg);
}
.modal__close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    background: none;
    border: none;
    font-size: 1.5rem;
    cursor: pointer;
    color: var(--color-muted);
    line-height: 1;
}
.modal__inner h2 { margin-bottom: .5rem; }
.modal__inner p  { color: var(--color-muted); margin-bottom: 1rem; font-size: .9rem; }
.modal__inner label { display: block; font-size: .85rem; font-weight: 600; margin-bottom: .3rem; }
.modal__inner textarea { width: 100%; padding: .55rem .75rem; border: 1px solid var(--color-border); border-radius: var(--radius-sm); font-family: var(--font-sans); margin-bottom: .75rem; }

/* ── Responsive ───────────────────────────────────────────── */
@media ( max-width: 900px ) {
    .site-header .container { flex-wrap: wrap; }
    .primary-nav            { order: 3; width: 100%; }
    .header-actions         { margin-left: auto; }
}
@media ( max-width: 960px ) {
    .offer-single__body { grid-template-columns: 1fr; }
    .offer-single__sidebar { position: static; }
    .offer-sidebar-card__ctas { flex-direction: row; flex-wrap: wrap; }
    .offer-sidebar-card__ctas .btn { flex: 1; min-width: 140px; }
}
@media ( max-width: 640px ) {
    .hotel-header__info h1 { font-size: 1.5rem; }
    .offer-single__hero-img { height: 280px; }
    .offer-single__hero-img--placeholder { height: 280px; }
    .offer-hotel-card { grid-template-columns: 1fr; }
    .offer-hotel-card__image { width: 100%; height: 180px; }
    .offer-hotel-card__top { flex-wrap: wrap; }
    .offer-details-grid { grid-template-columns: 1fr 1fr; }
}

/* ============================================================
   Homepage styles
   ============================================================ */

/* ── Utility ──────────────────────────────────────────────── */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border-width: 0; }

/* ── Section base ─────────────────────────────────────────── */
.section { padding-block: 5rem; }
.section--tight { padding-block: 1.25rem 1.5rem; }

.section-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 2.5rem;
    flex-wrap: wrap;
    gap: 1rem;
}
.section-header--center { justify-content: center; text-align: center; flex-direction: column; align-items: center; }

.section-title    { font-size: clamp(1.5rem, 2.5vw, 2rem); font-weight: 800; line-height: 1.2; margin-bottom: .4rem; letter-spacing: -.02em; }
.section-subtitle { color: var(--color-muted); font-size: .95rem; }

/* ── Hero ─────────────────────────────────────────────────── */
.hero {
    position: relative;
    min-height: 680px;
    display: flex;
    flex-direction: column;
    justify-content: stretch;
    overflow: hidden;
}

.hero__bg {
    position: absolute;
    inset: 0;
    background:
        url('https://images.unsplash.com/photo-1573843981267-be1999ff37cd?w=1600&q=80')
        center/cover no-repeat;
    transform: scale(1.03);
    z-index: 0;
}

.hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        160deg,
        rgba(0, 18, 65, .90) 0%,
        rgba(0, 45, 120, .65) 50%,
        rgba(0, 90, 170, .30) 100%
    );
    z-index: 1;
}

.hero__inner {
    position: relative;
    z-index: 2;
    padding-block: 6.5rem 3.5rem;
    flex: 1;
}

.hero__content { max-width: 680px; }

.hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .55em;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.25);
    color: rgba(255,255,255,.92);
    font-size: .73rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    padding: .42em 1em;
    border-radius: 100px;
    margin-bottom: 1.3rem;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.hero__eyebrow::before {
    content: '';
    width: 7px;
    height: 7px;
    background: #4ade80;
    border-radius: 50%;
    box-shadow: 0 0 0 3px rgba(74, 222, 128, .25);
    flex-shrink: 0;
}

.hero__title {
    font-size: clamp(2.2rem, 5vw, 3.75rem);
    font-weight: 900;
    color: #fff;
    line-height: 1.08;
    letter-spacing: -.03em;
    margin-bottom: 1.15rem;
}

.hero__subtitle {
    font-size: 1.1rem;
    color: rgba(255,255,255,.8);
    margin-bottom: 2.25rem;
    max-width: 510px;
    line-height: 1.65;
}

/* Search bar */
.hero__search { width: 100%; max-width: 620px; }
.hero__search-inner {
    display: flex;
    gap: .4rem;
    background: rgba(255,255,255,.1);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 14px;
    padding: .45rem;
    flex-wrap: wrap;
    box-shadow: 0 10px 40px rgba(0,0,0,.25);
}

.hero__search-field { flex: 1; min-width: 150px; }

.hero__select {
    width: 100%;
    height: 50px;
    padding: 0 1rem;
    background: rgba(255,255,255,.97);
    border: none;
    border-radius: 10px;
    font-size: .93rem;
    color: var(--color-text);
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right .75rem center;
    padding-right: 2.5rem;
    font-weight: 500;
}

.hero__search-btn {
    height: 50px;
    padding-inline: 1.75rem;
    border-radius: 10px;
    white-space: nowrap;
    flex-shrink: 0;
    font-weight: 700;
    box-shadow: 0 4px 14px rgba(232, 87, 42, .45);
}

/* Stats bar */
.hero__stats {
    position: relative;
    z-index: 2;
    background: rgba(0, 12, 45, .92);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-top: 1px solid rgba(255,255,255,.07);
}

.stats-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    padding-block: 1.35rem;
    flex-wrap: wrap;
}

.stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-inline: 3rem;
}

.stat__number {
    font-size: 1.65rem;
    font-weight: 800;
    line-height: 1;
    background: linear-gradient(135deg, #fff 30%, rgba(100, 185, 255, .85) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.stat__label {
    font-size: .7rem;
    color: rgba(255,255,255,.48);
    text-transform: uppercase;
    letter-spacing: .08em;
    margin-top: .28rem;
}

.stat-divider {
    width: 1px;
    height: 34px;
    background: rgba(255,255,255,.1);
}

/* ── Offer type pills ─────────────────────────────────────── */
.type-pills-section {
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border);
    position: sticky;
    top: var(--header-h);
    z-index: 50;
    box-shadow: 0 2px 10px rgba(0,0,0,.07);
}

.type-pills {
    display: flex;
    gap: .5rem;
    flex-wrap: nowrap;
    align-items: center;
    overflow-x: auto;
    padding-block: .8rem;
    scrollbar-width: none;
    -ms-overflow-style: none;
}
.type-pills::-webkit-scrollbar { display: none; }

.type-pill {
    display: inline-flex;
    align-items: center;
    gap: .4em;
    padding: .5em 1.15em;
    border-radius: 100px;
    font-size: .82rem;
    font-weight: 600;
    background: var(--color-bg);
    color: var(--color-text);
    border: 1.5px solid var(--color-border);
    text-decoration: none;
    transition: background .18s, color .18s, border-color .18s, box-shadow .18s, transform .12s;
    white-space: nowrap;
    flex-shrink: 0;
}

.type-pill:hover {
    transform: translateY(-1px);
    box-shadow: 0 3px 8px rgba(0,0,0,.1);
    text-decoration: none;
}

.type-pill--active,
.type-pill--all {
    background: var(--color-primary);
    color: #fff;
    border-color: var(--color-primary);
    text-decoration: none;
    box-shadow: 0 3px 10px rgba(0, 87, 184, .3);
}
.type-pill--active { cursor: default; }
.type-pill__count { background: rgba(255,255,255,.28); border-radius: 100px; padding: .1em .45em; font-size: .72rem; }

/* Pill colours per offer type (hover + active) */
.type-pill--early-bird:hover,   .type-pill--early-bird.type-pill--active   { background: #2e7d32; border-color: #2e7d32; color: #fff; box-shadow: 0 3px 10px rgba(46, 125, 50, .35); }
.type-pill--last-minute:hover,  .type-pill--last-minute.type-pill--active  { background: #c62828; border-color: #c62828; color: #fff; box-shadow: 0 3px 10px rgba(198, 40, 40, .35); }
.type-pill--flash-sale:hover,   .type-pill--flash-sale.type-pill--active   { background: #e65100; border-color: #e65100; color: #fff; box-shadow: 0 3px 10px rgba(230, 81, 0, .35); }
.type-pill--honeymoon:hover,    .type-pill--honeymoon.type-pill--active    { background: #ad1457; border-color: #ad1457; color: #fff; box-shadow: 0 3px 10px rgba(173, 20, 87, .35); }
.type-pill--family-offer:hover, .type-pill--family-offer.type-pill--active { background: #0277bd; border-color: #0277bd; color: #fff; box-shadow: 0 3px 10px rgba(2, 119, 189, .35); }

/* Grid loading state */
#homepage-offers-grid.is-loading {
    opacity: .3;
    pointer-events: none;
    transition: opacity .25s;
}

/* ── Featured / latest offer grids ───────────────────────── */
.featured-section {
    background: var(--color-bg);
    position: relative;
}
.featured-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
}

.latest-section {
    background: var(--color-surface);
    border-top: 1px solid var(--color-border);
}

/* First card in featured grid spans 2 columns on wide screens */
@media ( min-width: 900px ) {
    .offer-grid--featured .offer-card:first-child {
        grid-column: span 2;
        display: grid;
        grid-template-columns: 1.3fr 1fr;
    }
    .offer-grid--featured .offer-card:first-child .offer-card__image-wrap {
        aspect-ratio: auto;
        min-height: 310px;
    }
}

/* ── Destination grid ─────────────────────────────────────── */
.dest-section {
    background: linear-gradient(180deg, #edf2f9 0%, var(--color-bg) 100%);
}

.dest-grid {
    display: grid;
    grid-template-columns: repeat( auto-fill, minmax( 200px, 1fr ) );
    gap: 1rem;
}

.dest-card {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    aspect-ratio: 3/4;
    display: block;
    text-decoration: none;
    cursor: pointer;
    box-shadow: var(--shadow-md);
    transition: transform .25s, box-shadow .25s;
}
.dest-card:hover { transform: translateY(-6px) scale(1.01); box-shadow: 0 18px 44px rgba(0,0,0,.18); text-decoration: none; }

.dest-card__image {
    position: absolute;
    inset: 0;
    background: var(--color-primary) center/cover no-repeat;
    transition: transform .4s ease;
}
.dest-card:hover .dest-card__image { transform: scale(1.07); }

/* Wave SVG decoration on gradient-only cards */
.dest-card__wave {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 60px;
    pointer-events: none;
}
.dest-card__wave svg { width: 100%; height: 100%; display: block; }

.dest-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.82) 0%, rgba(0,0,0,.2) 50%, rgba(0,0,0,0) 100%);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 1.1rem;
}

.dest-card__name {
    color: #fff;
    font-size: 1rem;
    font-weight: 800;
    line-height: 1.3;
    display: block;
    text-shadow: 0 1px 4px rgba(0,0,0,.4);
}

.dest-card__count {
    color: rgba(255,255,255,.7);
    font-size: .78rem;
    display: block;
    margin-top: .2rem;
}

/* ── How it works ─────────────────────────────────────────── */
.how-section {
    background: linear-gradient(180deg, #f0f6ff 0%, var(--color-surface) 100%);
    position: relative;
    overflow: hidden;
}
.how-section::after {
    content: '';
    position: absolute;
    bottom: -120px; left: -120px;
    width: 480px; height: 480px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(0,87,184,.06) 0%, transparent 65%);
    pointer-events: none;
}

/* Header block */
.how-header {
    text-align: center;
    margin-bottom: 3.5rem;
}
.how-header .section-title  { margin-bottom: .4rem; }
.how-header .section-subtitle { margin-bottom: 1.75rem; }

/* Toggle pill */
.how-toggle {
    display: inline-flex;
    gap: .25rem;
    background: #e8eef8;
    border-radius: 100px;
    padding: .28rem;
    border: 1px solid #d0dcf0;
}
.how-toggle__btn {
    background: none;
    border: none;
    padding: .55rem 1.6rem;
    border-radius: 100px;
    font-size: .88rem;
    font-weight: 600;
    color: var(--color-muted);
    cursor: pointer;
    font-family: var(--font-sans);
    transition: background .18s, color .18s, box-shadow .18s;
}
.how-toggle__btn--active {
    background: #fff;
    color: var(--color-primary);
    box-shadow: 0 2px 8px rgba(0,87,184,.18);
}

/* Steps row */
.how-steps[hidden] { display: none !important; }
.how-steps {
    display: grid;
    grid-template-columns: 1fr 40px 1fr 40px 1fr;
    align-items: start;
    gap: 0;
}

/* Arrow connector */
.how-step__arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 3.25rem;
    color: #b8cde8;
}

/* Step card */
.how-step {
    background: var(--color-surface);
    border: 1px solid #dce8f8;
    border-radius: var(--radius-lg);
    padding: 2rem 1.75rem 1.75rem;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .5rem;
    transition: box-shadow .22s, transform .22s, border-color .22s;
    position: relative;
}
.how-step:hover {
    box-shadow: 0 8px 32px rgba(0,87,184,.12);
    border-color: #93c5fd;
    transform: translateY(-4px);
}

/* Icon circle */
.how-step__icon {
    width: 64px; height: 64px;
    border-radius: 50%;
    background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%);
    border: 2px solid #bfdbfe;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
    margin-bottom: .25rem;
    transition: background .22s, border-color .22s;
}
.how-step:hover .how-step__icon {
    background: linear-gradient(135deg, var(--color-primary) 0%, #0080cc 100%);
    border-color: transparent;
    color: #fff;
}

/* Step number */
.how-step__num {
    font-size: .7rem;
    font-weight: 800;
    letter-spacing: .12em;
    color: #93c5fd;
    text-transform: uppercase;
}

/* Title / desc */
.how-step__title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--color-text);
    margin: 0;
    line-height: 1.3;
}
.how-step__desc {
    font-size: .875rem;
    color: var(--color-muted);
    line-height: 1.65;
    margin: 0;
}
.how-step__link {
    display: inline-block;
    margin-top: .5rem;
    font-size: .82rem;
    font-weight: 700;
    color: var(--color-primary);
}
.how-step__link:hover { text-decoration: underline; }

/* Mobile — stack vertically */
@media (max-width: 760px) {
    .how-steps {
        grid-template-columns: 1fr;
        gap: 1rem;
    }
    .how-step__arrow { display: none; }
    .how-step { text-align: left; flex-direction: row; align-items: flex-start; padding: 1.25rem; }
    .how-step__icon { width: 52px; height: 52px; flex-shrink: 0; }
    .how-step > .how-step__num,
    .how-step > .how-step__title,
    .how-step > .how-step__desc,
    .how-step > .how-step__link { }
    .how-step { display: grid; grid-template-columns: 52px 1fr; column-gap: 1rem; }
    .how-step__icon { grid-row: span 4; }
}

/* ── Partner CTA ──────────────────────────────────────────── */
.partner-cta {
    background: linear-gradient(150deg, #001235 0%, #002b80 55%, #004ec0 100%);
    color: #fff;
    position: relative;
    overflow: hidden;
}

.partner-cta::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(255,255,255,.055) 1px, transparent 1px);
    background-size: 26px 26px;
    pointer-events: none;
}

.partner-cta::after {
    content: '';
    position: absolute;
    top: -120px;
    right: 180px;
    width: 520px;
    height: 520px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(30, 130, 255, .18) 0%, transparent 65%);
    pointer-events: none;
}

.partner-cta__inner {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 4rem;
    align-items: center;
    position: relative;
    z-index: 1;
}

.partner-cta__text h2 { font-size: clamp(1.65rem, 3vw, 2.25rem); font-weight: 800; margin-bottom: .8rem; color: #fff; letter-spacing: -.02em; }
.partner-cta__text p  { color: rgba(255,255,255,.76); margin-bottom: 1.5rem; font-size: 1rem; max-width: 500px; line-height: 1.65; }

.partner-cta__perks {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: .65rem;
    margin-bottom: 2rem;
}
.partner-cta__perks li {
    color: rgba(255,255,255,.85);
    font-size: .93rem;
    padding-left: 1.8rem;
    position: relative;
    line-height: 1.5;
}
.partner-cta__perks li::before {
    content: '✓';
    position: absolute;
    left: 0;
    top: 0;
    width: 1.15rem;
    height: 1.15rem;
    border-radius: 50%;
    background: rgba(74, 222, 128, .18);
    border: 1.5px solid rgba(74, 222, 128, .6);
    color: #4ade80;
    font-weight: 800;
    font-size: .62rem;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1.15rem;
    text-align: center;
}

.partner-cta__actions { display: flex; gap: 1rem; flex-wrap: wrap; }
.partner-cta .btn-outline { border-color: rgba(255,255,255,.35); color: rgba(255,255,255,.9); }
.partner-cta .btn-outline:hover { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.6); }

/* Mock offer card for CTA visual */
.partner-cta__visual { flex-shrink: 0; }

.partner-cta__card {
    background: #fff;
    border-radius: var(--radius-lg);
    width: 230px;
    box-shadow: 0 28px 56px rgba(0,0,0,.38), 0 8px 18px rgba(0,0,0,.2);
    transform: rotate(3deg);
    overflow: hidden;
    transition: transform .35s;
}
.partner-cta__card:hover { transform: rotate(0deg) scale(1.03); }

.pcard__img {
    height: 108px;
    background: linear-gradient(135deg, #0057b8 0%, #0099cc 100%);
    position: relative;
    overflow: hidden;
}
.pcard__img::after {
    content: '🌊';
    position: absolute;
    bottom: -8px;
    right: -8px;
    font-size: 3.5rem;
    opacity: .2;
}

.pcard__body    { padding: 1rem 1.1rem 1.15rem; }
.pcard__icon    { display: none; }
.pcard__line    { height: .55rem; border-radius: 100px; background: #e4eaf4; margin-bottom: .45rem; }
.pcard__line--title { width: 80%; height: .65rem; background: #cdd6e8; }
.pcard__line--sub   { width: 50%; }
.pcard__badges  { display: flex; gap: .35rem; flex-wrap: wrap; margin-block: .75rem .5rem; }
.pcard__meta    { display: flex; gap: .5rem; align-items: center; }

@media ( max-width: 768px ) {
    .section { padding-block: 3.5rem; }

    .partner-cta__inner { grid-template-columns: 1fr; gap: 0; }
    .partner-cta__visual { display: none; }

    .stat { padding-inline: 1.5rem; }
    .stat__number { font-size: 1.3rem; }

    .dest-grid { grid-template-columns: repeat( auto-fill, minmax( 150px, 1fr ) ); gap: .75rem; }

    .hero__search-inner { flex-direction: column; }
    .hero__search-field { min-width: 100%; }
    .hero__search-btn   { width: 100%; }
}

/* ============================================================
   Pin & Preferred styles
   ============================================================ */

/* Badges */
.offer-badge--pinned    { background: #e8572a; }
.offer-badge--preferred { background: #0057b8; }
.offer-badge--secondary { position: absolute; top: .75rem; right: .75rem; left: auto; }

/* ── Offer source / attribution badges ────────────────────────────────────── */
.offer-card__source { margin: 0 0 .35rem; }
.offer-source {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    font-size: .7rem;
    font-weight: 600;
    letter-spacing: .02em;
    text-transform: uppercase;
    padding: .15rem .5rem;
    border-radius: 20px;
    line-height: 1.4;
}
.offer-source--direct {
    background: #e6f4ec;
    color: #1a6e38;
    border: 1px solid #a8d5b5;
}
.offer-source--agent {
    background: #e8f0fb;
    color: #1a47a8;
    border: 1px solid #a8c0ef;
}
/* On the dark hero overlay of single-offer.php */
.offer-source--hero {
    background: rgba(255,255,255,.18);
    color: #fff;
    border-color: rgba(255,255,255,.35);
}

/* Card border treatments */
.offer-card--pinned {
    border: 2px solid #e8572a;
    box-shadow: 0 0 0 1px rgba(232,87,42,.15), var(--shadow-md);
}
.offer-card--pinned .offer-card__image-wrap::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    box-shadow: inset 0 0 0 2px rgba(232,87,42,.3);
    pointer-events: none;
}

.offer-card--preferred {
    border: 2px solid var(--color-primary);
    box-shadow: 0 0 0 1px rgba(0,87,184,.12), var(--shadow-sm);
}

/* Pin indicator strip at top of pinned card */
.offer-card--pinned::before {
    content: '';
    display: block;
    height: 3px;
    background: linear-gradient(90deg, #e8572a, #f59e0b);
    margin: -1px -1px 0;
}

/* Preferred indicator strip */
.offer-card--preferred::before {
    content: '';
    display: block;
    height: 3px;
    background: linear-gradient(90deg, var(--color-primary), #60a5fa);
    margin: -1px -1px 0;
}

/* ============================================================
   Pricing page
   ============================================================ */

/* ── Header ───────────────────────────────────────────────── */
.pricing-header {
    background: linear-gradient(135deg, #00204a 0%, #0057b8 100%);
    padding-block: 3.5rem 2rem;
    text-align: center;
}
.pricing-header__title {
    font-size: clamp(1.6rem, 3.5vw, 2.4rem);
    font-weight: 900;
    color: #fff;
    margin-bottom: .6rem;
}
.pricing-header__sub {
    color: rgba(255,255,255,.75);
    font-size: 1rem;
    margin-bottom: 1.75rem;
}

/* Billing toggle */
.billing-toggle {
    display: inline-flex;
    align-items: center;
    gap: .75rem;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 100px;
    padding: .4rem .9rem;
}
.billing-toggle__label {
    font-size: .85rem;
    font-weight: 600;
    color: rgba(255,255,255,.55);
    transition: color .15s;
    display: flex;
    align-items: center;
    gap: .4rem;
}
.billing-toggle__label--active { color: #fff; }

.billing-save-badge {
    background: #4ade80;
    color: #14532d;
    font-size: .68rem;
    font-weight: 700;
    padding: .15em .55em;
    border-radius: 100px;
    letter-spacing: .03em;
}

.billing-toggle__btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    display: flex;
    align-items: center;
}
.billing-toggle__track {
    display: flex;
    align-items: center;
    width: 40px;
    height: 22px;
    background: rgba(255,255,255,.3);
    border-radius: 100px;
    padding: 2px;
    transition: background .2s;
}
.billing-toggle__btn.is-annual .billing-toggle__track { background: #4ade80; }
.billing-toggle__thumb {
    width: 18px;
    height: 18px;
    background: #fff;
    border-radius: 50%;
    transition: transform .2s;
    flex-shrink: 0;
}
.billing-toggle__btn.is-annual .billing-toggle__thumb { transform: translateX(18px); }

/* ── Plans grid ───────────────────────────────────────────── */
.plans-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    margin-top: -1px;
    padding-block: 2.5rem 1.5rem;
    align-items: start;
}
@media (max-width: 860px) { .plans-grid { grid-template-columns: 1fr; max-width: 420px; margin-inline: auto; } }

/* Plan card */
.plan-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 1.75rem;
    position: relative;
    transition: box-shadow .2s;
}
.plan-card:hover { box-shadow: var(--shadow-md); }

.plan-card--popular {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px var(--color-primary), var(--shadow-md);
    transform: translateY(-6px);
}
@media (max-width: 860px) { .plan-card--popular { transform: none; } }

.plan-card--current { border-color: #4ade80; box-shadow: 0 0 0 2px #4ade80; }

.plan-card__badge {
    position: absolute;
    top: -13px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--color-primary);
    color: #fff;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    padding: .3em 1em;
    border-radius: 100px;
    white-space: nowrap;
}

.plan-card__header { margin-bottom: 1.25rem; }
.plan-card__name {
    display: block;
    font-size: .82rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--color-muted);
    margin-bottom: .65rem;
}
.plan-card--popular .plan-card__name { color: var(--color-primary); }

.plan-card__price { display: flex; align-items: baseline; gap: .25rem; margin-bottom: .65rem; }
.plan-price__amount { font-size: 2.6rem; font-weight: 900; color: var(--color-text); line-height: 1; }
.plan-price__period { font-size: .82rem; color: var(--color-muted); }
.plan-card__desc { font-size: .88rem; color: var(--color-muted); line-height: 1.5; }

.plan-card__cta { margin-bottom: 1.5rem; }

/* Feature list */
.plan-card__features {
    display: flex;
    flex-direction: column;
    gap: .6rem;
    border-top: 1px solid var(--color-border);
    padding-top: 1.25rem;
}

.feature {
    display: flex;
    align-items: center;
    gap: .6rem;
    font-size: .875rem;
}
.feature::before {
    content: '';
    flex-shrink: 0;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.feature--yes {
    color: var(--color-text);
}
.feature--yes::before {
    content: '✓';
    background: #dcfce7;
    color: #16a34a;
    font-size: .65rem;
    font-weight: 900;
    display: flex;
    align-items: center;
    justify-content: center;
}
.feature--no {
    color: var(--color-muted);
    text-decoration: line-through;
    opacity: .6;
}
.feature--no::before {
    content: '—';
    background: var(--color-bg);
    color: var(--color-muted);
    font-size: .7rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ── Add-on strip ─────────────────────────────────────────── */
.addon-strip {
    background: #fff8f5;
    border: 1px solid #fcd9c8;
    border-radius: var(--radius-md);
    padding: 1.25rem 1.5rem;
    margin-bottom: 3rem;
}
.addon-strip__inner {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    flex-wrap: wrap;
}
.addon-strip__icon { font-size: 1.8rem; flex-shrink: 0; }
.addon-strip__text { flex: 1; min-width: 200px; }
.addon-strip__text strong { display: block; font-size: .95rem; margin-bottom: .2rem; }
.addon-strip__text p { font-size: .85rem; color: var(--color-muted); margin: 0; }
.addon-strip__pricing { display: flex; gap: 1rem; align-items: center; flex-shrink: 0; }
.addon-price { font-size: 1rem; font-weight: 700; color: var(--color-accent); }
.addon-price small { font-size: .75rem; font-weight: 400; color: var(--color-muted); }

/* ── Comparison table ─────────────────────────────────────── */
.comparison-wrap { margin-bottom: 3.5rem; }
.comparison-title {
    font-size: 1.3rem;
    font-weight: 800;
    margin-bottom: 1.25rem;
    text-align: center;
}

.comparison-table-wrap { overflow-x: auto; border-radius: var(--radius-md); border: 1px solid var(--color-border); }

.comparison-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .875rem;
}
.comparison-table thead th {
    background: var(--color-bg);
    padding: .85rem 1rem;
    font-weight: 700;
    text-align: center;
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--color-muted);
}
.comparison-table thead th:first-child { text-align: left; }
.comparison-table thead .col-popular { background: #eff6ff; color: var(--color-primary); }

.comparison-table tbody tr:nth-child(even) { background: var(--color-bg); }
.comparison-table td {
    padding: .75rem 1rem;
    border-top: 1px solid var(--color-border);
    text-align: center;
    color: var(--color-muted);
}
.comparison-table td:first-child { text-align: left; font-weight: 500; color: var(--color-text); }
.comparison-table .col-popular { background: #f0f7ff; }

.cell-yes { color: #16a34a; font-weight: 700; }
.cell-no  { color: var(--color-border); }

/* ── FAQ ──────────────────────────────────────────────────── */
.pricing-faq { margin-bottom: 3.5rem; }
.faq-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 1.25rem;
}
.faq-item {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 1.25rem;
}
.faq-item__q { font-size: .95rem; font-weight: 700; margin-bottom: .5rem; }
.faq-item__a { font-size: .875rem; color: var(--color-muted); line-height: 1.6; margin: 0; }

/* ── Bottom CTA ───────────────────────────────────────────── */
.pricing-bottom-cta {
    text-align: center;
    background: var(--color-bg);
    border-radius: var(--radius-lg);
    padding: 3rem 2rem;
    margin-bottom: 3rem;
}
.pricing-bottom-cta h2 { font-size: 1.5rem; font-weight: 800; margin-bottom: .4rem; }
.pricing-bottom-cta p  { color: var(--color-muted); margin-bottom: 1.5rem; }
.pricing-bottom-cta__actions { display: flex; gap: .85rem; justify-content: center; flex-wrap: wrap; }

/* ============================================================
   Checkout trust & WooCommerce overrides
   ============================================================ */

/* ── Checkout trust bar (above form) ──────────────────────── */
.checkout-trust-bar {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem 2rem;
    background: #f0f7ff;
    border: 1px solid #bfdbfe;
    border-radius: var(--radius-md);
    padding: .85rem 1.25rem;
    margin-bottom: 1.5rem;
    font-size: .82rem;
    font-weight: 600;
    color: var(--color-primary);
}
.ctb-item { display: flex; align-items: center; gap: .4rem; }
.ctb-icon { font-size: 1rem; }

/* ── Checkout trust footer (below Pay button) ─────────────── */
.checkout-trust-footer {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--color-border);
}
.ctf-badges {
    display: flex;
    gap: .6rem;
    align-items: center;
    margin-bottom: .6rem;
    flex-wrap: wrap;
}
.ctf-badge {
    display: inline-flex;
    align-items: center;
    gap: .3em;
    padding: .3em .75em;
    border-radius: var(--radius-sm);
    font-size: .75rem;
    font-weight: 700;
    border: 1px solid var(--color-border);
    background: var(--color-surface);
    color: var(--color-muted);
}
.ctf-badge--paypal { border-color: #003087; }
.ctf-badge--secure { color: var(--color-success); border-color: var(--color-success); }
.ctf-badge--ssl    { background: var(--color-success); color: #fff; border-color: var(--color-success); }
.ctf-copy { font-size: .78rem; color: var(--color-muted); line-height: 1.5; margin: 0; }
.ctf-copy a { color: var(--color-primary); }

/* ── Order success box (thank-you page) ───────────────────── */
.order-success-box {
    background: #f0fdf4;
    border: 1px solid #86efac;
    border-radius: var(--radius-md);
    padding: 1.25rem;
    margin-bottom: 1.25rem;
}
.order-success-box__title { font-size: 1rem; font-weight: 700; margin-bottom: .5rem; color: var(--color-success); }
.order-success-box p { margin-bottom: .6rem; font-size: .9rem; }
.order-success-box p:last-child { margin-bottom: 0; display: flex; gap: .5rem; flex-wrap: wrap; }

/* ── WooCommerce general overrides ────────────────────────── */
.woocommerce-page .container { max-width: var(--container-max); margin-inline: auto; padding-inline: var(--container-pad); }

.woocommerce form .form-row label { font-size: .85rem; font-weight: 600; }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: .55rem .85rem;
    font-size: .9rem;
    width: 100%;
    color: var(--color-text);
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(0,87,184,.1);
    outline: none;
}

.woocommerce #payment { background: var(--color-bg); border-radius: var(--radius-md); border: 1px solid var(--color-border); }
.woocommerce #payment .payment_methods { border-bottom: 1px solid var(--color-border); }
.woocommerce #payment div.payment_box { background: #f8faff; }

.woocommerce #place_order,
.woocommerce-cart .checkout-button {
    background: var(--color-primary) !important;
    border-color: var(--color-primary) !important;
    border-radius: var(--radius-sm) !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    padding: .75rem 2rem !important;
    width: 100% !important;
    transition: background .15s !important;
}
.woocommerce #place_order:hover,
.woocommerce-cart .checkout-button:hover { background: var(--color-primary-dk) !important; }

.woocommerce-message,
.woocommerce-info { border-top-color: var(--color-primary) !important; }
.woocommerce-message::before { color: var(--color-primary) !important; }

/* ── Pricing trust strip (below pricing page FAQ) ─────────── */
.pricing-trust-strip {
    background: var(--color-text);
    color: rgba(255,255,255,.85);
    padding-block: 3rem;
    margin-top: 1rem;
}
.pts-inner {
    display: grid;
    grid-template-columns: repeat( auto-fill, minmax( 220px, 1fr ) );
    gap: 2rem;
}
.pts-item { display: flex; gap: 1rem; align-items: flex-start; }
.pts-icon { font-size: 1.75rem; flex-shrink: 0; }
.pts-item strong { display: block; color: #fff; font-size: .9rem; margin-bottom: .3rem; }
.pts-item p { font-size: .82rem; color: rgba(255,255,255,.6); line-height: 1.5; margin: 0; }

/* ============================================================
   Partner Hub
   ============================================================ */

/* ── Hero strip ───────────────────────────────────────────── */
.partner-hub__hero {
    background: linear-gradient(135deg, #00204a 0%, #0057b8 100%);
    padding-block: 3rem 2.5rem;
    color: #fff;
}
.partner-hub__hero h1 {
    font-size: clamp(1.4rem, 3vw, 2rem);
    font-weight: 900;
    max-width: 600px;
    margin-bottom: .6rem;
    color: #fff;
}
.partner-hub__hero p { color: rgba(255,255,255,.75); max-width: 500px; }

.partner-hub__stats {
    display: flex;
    gap: 2rem;
    margin-top: 1.25rem;
    flex-wrap: wrap;
}
.partner-hub__stat strong {
    display: block;
    font-size: 1.5rem;
    font-weight: 900;
    color: #fff;
}
.partner-hub__stat span {
    font-size: .78rem;
    color: rgba(255,255,255,.6);
    text-transform: uppercase;
    letter-spacing: .06em;
}

/* ── Auth grid ────────────────────────────────────────────── */
.partner-auth-grid {
    display: grid;
    grid-template-columns: 1fr 32px 1fr;
    gap: 0;
    align-items: start;
    padding-block: 2.5rem 1rem;
    max-width: 100%;
    overflow: visible;
}
@media (max-width: 960px) {
    .partner-auth-grid {
        grid-template-columns: 1fr;
        max-width: 520px;
        margin-inline: auto;
        gap: 1.5rem;
    }
    .auth-divider { display: none; }
}

/* ── Auth panel ───────────────────────────────────────────── */
.auth-panel {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 2rem;
    box-sizing: border-box;
    min-width: 0;
    overflow: hidden;
}
.auth-panel--signup { border-color: var(--color-primary); box-shadow: 0 0 0 2px rgba(0,87,184,.1); }

/* Ensure inputs don't overflow */
.auth-panel input[type="text"],
.auth-panel input[type="email"],
.auth-panel input[type="password"],
.auth-panel input[type="tel"],
.auth-panel select,
.auth-panel textarea {
    max-width: 100%;
    box-sizing: border-box;
}

/* Password field with toggle */
.password-field-wrap {
    position: relative;
    display: flex;
    align-items: center;
}
.password-field-wrap input {
    flex: 1;
    padding-right: 2.5rem;
    width: 100%;
}
.toggle-password {
    position: absolute;
    right: 0.5rem;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.25rem;
    color: var(--color-text-muted, #6b7280);
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}
.toggle-password:hover {
    color: var(--color-text, #1f2937);
}
.toggle-password svg {
    width: 18px;
    height: 18px;
}
.toggle-password img.emoji {
    width: 18px !important;
    height: 18px !important;
    margin: 0 !important;
    vertical-align: middle;
}

/* Fix form-row-group overflow in auth panels */
.auth-panel .form-row-group {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    min-width: 0;
}
.auth-panel .form-row-group > .form-row {
    min-width: 0;
    overflow: hidden;
}
.auth-panel .form-row-group select,
.auth-panel .form-row-group input {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    min-width: 0;
}
@media (max-width: 480px) {
    .auth-panel .form-row-group {
        grid-template-columns: 1fr;
    }
}

.auth-panel__header { margin-bottom: 1.5rem; }
.auth-panel__header h2 { font-size: 1.2rem; font-weight: 800; margin-bottom: .3rem; }
.auth-panel__header p  { color: var(--color-muted); font-size: .88rem; }

/* ── Divider ──────────────────────────────────────────────── */
.auth-divider {
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 6rem;
}
.auth-divider span {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 50%;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .75rem;
    color: var(--color-muted);
    font-weight: 600;
    flex-shrink: 0;
}

/* ── Form elements ────────────────────────────────────────── */
.auth-form { display: flex; flex-direction: column; gap: .85rem; }

.auth-form .form-row label {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    font-size: .85rem;
    font-weight: 600;
    margin-bottom: .3rem;
}
.forgot-link { font-size: .78rem; font-weight: 400; color: var(--color-primary); }

.password-field-wrap { position: relative; }
.password-field-wrap input { padding-right: 2.5rem; width: 100%; }
.toggle-password {
    position: absolute;
    right: .6rem;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    font-size: .9rem;
    line-height: 1;
    padding: 0;
    color: var(--color-muted);
}

.password-strength { margin-top: 2px; min-height: 22px; }
.field-hint { font-weight: 400; font-size: .75rem; color: var(--color-muted); }

.checkbox-label {
    display: flex !important;
    align-items: flex-start;
    gap: .5rem;
    font-size: .85rem;
    font-weight: 400 !important;
    cursor: pointer;
}
.checkbox-label input { margin-top: 2px; flex-shrink: 0; }

.auth-form__message {
    font-size: .85rem;
    min-height: 1.2em;
    margin-top: .25rem;
}
.auth-form__message.is-error { color: var(--color-error); }

/* ── Trust row ────────────────────────────────────────────── */
.auth-trust {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    margin-top: 1rem;
    padding-top: .85rem;
    border-top: 1px solid var(--color-border);
    font-size: .75rem;
    color: var(--color-muted);
}
.auth-trust span { display: flex; align-items: center; gap: .3em; }

/* ── Partner onboarding steps ─────────────────────────────── */
.partner-steps {
    padding-block: 3rem;
    border-top: 1px solid var(--color-border);
    margin-top: 1rem;
}
.partner-steps h2 {
    font-size: 1.3rem;
    font-weight: 800;
    margin-bottom: 1.75rem;
    text-align: center;
}
.partner-steps__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 1.5rem;
}
.partner-step { text-align: center; }
.partner-step__num {
    width: 3rem;
    height: 3rem;
    border-radius: 50%;
    background: var(--color-primary);
    color: #fff;
    font-size: 1.1rem;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto .85rem;
}
.partner-step h3 { font-size: .95rem; font-weight: 700; margin-bottom: .35rem; }
.partner-step p  { font-size: .85rem; color: var(--color-muted); }
.partner-steps__track + .partner-steps__track { margin-top: 2rem; }
.partner-steps__label {
    font-size: .75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--color-muted);
    margin-bottom: 1rem;
}

/* ── Account type toggle (partner signup form) ────────────────────────────── */
.account-type-toggle {
    display: inline-flex;
    background: #f0f2f5;
    border-radius: 8px;
    padding: 3px;
    gap: 3px;
    margin-top: .35rem;
}
.type-btn {
    padding: .45rem 1rem;
    border: none;
    background: transparent;
    border-radius: 6px;
    font-size: .85rem;
    font-weight: 600;
    color: var(--color-muted);
    cursor: pointer;
    transition: background .15s, color .15s, box-shadow .15s;
    white-space: nowrap;
}
.type-btn--active {
    background: #fff;
    color: var(--color-primary, #0057b8);
    box-shadow: 0 1px 4px rgba(0,0,0,.12);
}
.type-btn:not(.type-btn--active):hover { color: var(--color-body); }
.account-type-hint { margin: .4rem 0 0; font-size: .8rem; }

/* ── Invite welcome banner ───────────────────────────────────────────────── */
.invite-welcome-banner {
    background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%);
    border: 1px solid #93c5fd;
    border-radius: 12px;
    padding: 1.25rem 1.5rem;
    margin-bottom: 2rem;
}
.invite-welcome-banner__inner {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
}
.invite-welcome-banner__icon {
    font-size: 2rem;
    line-height: 1;
    flex-shrink: 0;
}
.invite-welcome-banner__body strong {
    font-size: 1rem;
    font-weight: 800;
    color: #1e40af;
    display: block;
    margin-bottom: .4rem;
}
.invite-welcome-banner__body p {
    margin: 0 0 .4rem;
    font-size: .9rem;
    color: #374151;
    line-height: 1.5;
}
.invite-welcome-banner__hotel {
    font-size: .875rem;
    color: #1e40af;
    background: rgba(255,255,255,.6);
    border-radius: 6px;
    padding: .35rem .75rem;
    display: inline-block;
    margin-top: .25rem !important;
}

/* ============================================================
   Blog page
   ============================================================ */

/* ── Blog hero ────────────────────────────────────────────── */
.blog-hero {
    background: linear-gradient(150deg, #001235 0%, #002b80 55%, #004ec0 100%);
    padding-block: 4rem 3rem;
    position: relative;
    overflow: hidden;
}
.blog-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px);
    background-size: 24px 24px;
    pointer-events: none;
}
.blog-hero__inner { position: relative; z-index: 1; max-width: 700px; }
.blog-hero__eyebrow {
    display: inline-block;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.22);
    color: rgba(255,255,255,.88);
    font-size: .73rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    padding: .35em 1em;
    border-radius: 100px;
    margin-bottom: 1.1rem;
}
.blog-hero__title {
    font-size: clamp(1.75rem, 4vw, 2.75rem);
    font-weight: 900;
    color: #fff;
    line-height: 1.1;
    letter-spacing: -.03em;
    margin-bottom: .85rem;
}
.blog-hero__subtitle { font-size: 1rem; color: rgba(255,255,255,.75); line-height: 1.65; max-width: 560px; }

/* ── Category bar ─────────────────────────────────────────── */
.blog-cat-bar {
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border);
    position: sticky;
    top: var(--header-h);
    z-index: 40;
    box-shadow: 0 2px 8px rgba(0,0,0,.05);
}
.blog-cat-pills {
    display: flex;
    gap: .45rem;
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-block: .75rem;
    scrollbar-width: none;
    -ms-overflow-style: none;
}
.blog-cat-pills::-webkit-scrollbar { display: none; }

.blog-cat-pill {
    display: inline-flex;
    align-items: center;
    gap: .4em;
    padding: .45em 1.1em;
    border-radius: 100px;
    font-size: .82rem;
    font-weight: 600;
    background: var(--color-bg);
    color: var(--color-text);
    border: 1.5px solid var(--color-border);
    text-decoration: none;
    white-space: nowrap;
    flex-shrink: 0;
    transition: background .15s, color .15s, border-color .15s;
}
.blog-cat-pill:hover { background: var(--color-primary); color: #fff; border-color: var(--color-primary); text-decoration: none; }
.blog-cat-pill--active { background: var(--color-primary); color: #fff; border-color: var(--color-primary); cursor: default; }
.blog-cat-pill__count { background: rgba(255,255,255,.25); border-radius: 100px; padding: .1em .45em; font-size: .72rem; }

/* ── Blog section ─────────────────────────────────────────── */
.blog-section { background: var(--color-bg); }

/* ── Blog grid ────────────────────────────────────────────── */
.blog-grid {
    display: grid;
    grid-template-columns: repeat( auto-fill, minmax( 320px, 1fr ) );
    gap: 1.5rem;
}

@media ( min-width: 900px ) {
    .blog-grid .blog-card--hero {
        grid-column: 1 / -1;
        display: grid;
        grid-template-columns: 1.4fr 1fr;
    }
    .blog-grid .blog-card--hero .blog-card__image-wrap {
        aspect-ratio: 16/9;
    }
}

/* ── Blog card ────────────────────────────────────────────── */
.blog-card {
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    transition: box-shadow .2s, transform .2s;
    display: flex;
    flex-direction: column;
}
.blog-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }

.blog-card__image-wrap {
    display: block;
    aspect-ratio: 16/9;
    overflow: hidden;
}
.blog-card__image-wrap--placeholder .blog-card__placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #e8edf4 0%, #d0d8e8 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 200px;
}
.blog-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .35s;
    display: block;
}
.blog-card:hover .blog-card__image { transform: scale(1.04); }

.blog-card__body {
    padding: 1.35rem 1.5rem 1.5rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.blog-card__cat {
    display: inline-block;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--color-primary);
    margin-bottom: .65rem;
    text-decoration: none;
}
.blog-card__cat:hover { text-decoration: underline; }

.blog-card__title {
    font-size: 1.1rem;
    font-weight: 800;
    line-height: 1.3;
    margin-bottom: .6rem;
    letter-spacing: -.01em;
}
.blog-card__title a { color: var(--color-text); }
.blog-card__title a:hover { color: var(--color-primary); text-decoration: none; }

.blog-card--hero .blog-card__title { font-size: clamp(1.25rem, 2vw, 1.6rem); }

.blog-card__excerpt {
    font-size: .9rem;
    color: var(--color-muted);
    line-height: 1.6;
    margin-bottom: 1rem;
    flex: 1;
}

.blog-card__meta {
    display: flex;
    align-items: center;
    gap: .4rem;
    font-size: .78rem;
    color: var(--color-muted);
    flex-wrap: wrap;
    margin-top: auto;
}
.blog-card__author { display: flex; align-items: center; gap: .35rem; font-weight: 500; color: var(--color-text); }
.blog-card__avatar { width: 22px; height: 22px; border-radius: 50%; }
.blog-card__sep { color: var(--color-border); }
.blog-card__read-time { color: var(--color-muted); }

/* Pagination */
.blog-pagination {
    margin-top: 3rem;
    display: flex;
    justify-content: center;
    gap: .4rem;
    flex-wrap: wrap;
}
.blog-pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: var(--radius-md);
    font-size: .9rem;
    font-weight: 600;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    text-decoration: none;
    transition: background .15s, color .15s;
}
.blog-pagination .page-numbers:hover { background: var(--color-primary); color: #fff; border-color: var(--color-primary); text-decoration: none; }
.blog-pagination .current { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
.blog-pagination .prev,
.blog-pagination .next { width: auto; padding-inline: 1rem; font-size: .85rem; }

.blog-empty { text-align: center; padding: 4rem 1rem; display: flex; flex-direction: column; align-items: center; gap: 1rem; }

/* ============================================================
   About page
   ============================================================ */

/* Shared eyebrow */
.about-eyebrow {
    display: inline-block;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--color-primary);
    margin-bottom: .85rem;
}

/* ── About hero ───────────────────────────────────────────── */
.about-hero { background: var(--color-bg); padding-bottom: 0; }

.about-hero__inner {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 4rem;
    align-items: start;
    padding-bottom: 4rem;
}

.about-hero__title {
    font-size: clamp(1.7rem, 3.5vw, 2.5rem);
    font-weight: 900;
    letter-spacing: -.03em;
    line-height: 1.15;
    margin-bottom: 1rem;
}

.about-hero__lead {
    font-size: 1.05rem;
    line-height: 1.7;
    color: var(--color-muted);
    margin-bottom: 1rem;
    font-weight: 500;
}

/* Stat cards grid */
.about-stat-cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .75rem;
    min-width: 260px;
}

.about-stat-card {
    border-radius: var(--radius-lg);
    padding: 1.25rem 1rem;
    text-align: center;
    box-shadow: var(--shadow-sm);
}
.about-stat-card--blue   { background: #eff6ff; }
.about-stat-card--green  { background: #f0fdf4; }
.about-stat-card--orange { background: #fff7ed; }
.about-stat-card--purple { background: #faf5ff; }

.about-stat-card__num {
    display: block;
    font-size: 1.75rem;
    font-weight: 900;
    line-height: 1;
    letter-spacing: -.03em;
    margin-bottom: .3rem;
}
.about-stat-card--blue   .about-stat-card__num { color: var(--color-primary); }
.about-stat-card--green  .about-stat-card__num { color: #16a34a; }
.about-stat-card--orange .about-stat-card__num { color: #ea580c; }
.about-stat-card--purple .about-stat-card__num { color: #7c3aed; }

.about-stat-card__label { font-size: .75rem; font-weight: 600; color: var(--color-muted); }

/* ── Mission / values ─────────────────────────────────────── */
.about-mission { background: var(--color-surface); }

.about-mission__grid {
    display: grid;
    grid-template-columns: repeat( auto-fit, minmax( 220px, 1fr ) );
    gap: 1.5rem;
}

.about-value-card {
    background: var(--color-bg);
    border-radius: var(--radius-lg);
    padding: 1.75rem 1.5rem;
    border: 1px solid var(--color-border);
    transition: box-shadow .2s, transform .2s;
}
.about-value-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.about-value-card__icon { font-size: 2rem; margin-bottom: .85rem; }
.about-value-card h3 { font-size: 1rem; font-weight: 800; margin-bottom: .45rem; }
.about-value-card p { font-size: .9rem; color: var(--color-muted); line-height: 1.6; }

/* ── Contact ──────────────────────────────────────────────── */
.about-contact { background: var(--color-bg); }

.contact-grid {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 3rem;
    align-items: start;
}

.contact-info { display: flex; flex-direction: column; gap: 1rem; }

.contact-card {
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    padding: 1.35rem 1.5rem;
    border: 1px solid var(--color-border);
}
.contact-card__icon { font-size: 1.5rem; margin-bottom: .5rem; }
.contact-card h3 { font-size: .95rem; font-weight: 700; margin-bottom: .3rem; }
.contact-card p { font-size: .88rem; color: var(--color-muted); line-height: 1.5; margin-bottom: .5rem; }
.contact-card__link { font-size: .9rem; font-weight: 600; color: var(--color-primary); }
.contact-card__link:hover { text-decoration: underline; }

.contact-form-wrap {
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    padding: 2rem;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
}
.contact-form-wrap__title { font-size: 1.1rem; font-weight: 700; margin-bottom: 1.5rem; }

.contact-form .form-row { margin-bottom: 1rem; }
.contact-form .form-row--half { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.contact-form label { display: block; font-size: .85rem; font-weight: 600; margin-bottom: .35rem; }
.contact-form input,
.contact-form select,
.contact-form textarea {
    width: 100%;
    padding: .65rem .9rem;
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: .92rem;
    font-family: inherit;
    color: var(--color-text);
    background: var(--color-bg);
    transition: border-color .15s;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus { outline: none; border-color: var(--color-primary); }
.contact-form textarea { resize: vertical; }

/* ── Partner listing guide ────────────────────────────────── */
.listing-guide { background: var(--color-surface); }

.listing-guide__header {
    text-align: center;
    margin-bottom: 3rem;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.listing-steps {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    max-width: 860px;
    margin-inline: auto;
}

.listing-step {
    display: grid;
    grid-template-columns: 3rem 1fr;
    gap: 1.5rem;
    background: var(--color-bg);
    border-radius: var(--radius-lg);
    padding: 2rem 2rem 2rem 1.75rem;
    border: 1px solid var(--color-border);
    transition: box-shadow .2s;
}
.listing-step:hover { box-shadow: var(--shadow-md); }

.listing-step__num {
    width: 3rem;
    height: 3rem;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-primary) 0%, #0080cc 100%);
    color: #fff;
    font-size: 1.1rem;
    font-weight: 900;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    box-shadow: 0 4px 12px rgba(0, 87, 184, .3);
    align-self: flex-start;
}

.listing-step__head {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: .65rem;
}
.listing-step__head h3 { font-size: 1.1rem; font-weight: 800; margin: 0; }
.listing-step__time {
    font-size: .75rem;
    font-weight: 600;
    background: #e8f0fe;
    color: var(--color-primary);
    padding: .2em .7em;
    border-radius: 100px;
    white-space: nowrap;
}

.listing-step__content > p {
    font-size: .95rem;
    color: var(--color-muted);
    line-height: 1.7;
    margin-bottom: 1rem;
}

.listing-step__tips {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: .4rem;
    margin-bottom: 1.25rem;
}
.listing-step__tips li {
    font-size: .87rem;
    color: var(--color-muted);
    padding-left: 1.5rem;
    position: relative;
    line-height: 1.5;
}
.listing-step__tips li::before {
    content: '→';
    position: absolute;
    left: 0;
    color: var(--color-primary);
    font-weight: 700;
}

.listing-step__cta { align-self: flex-start; }

/* Listing guide CTA */
.listing-guide__cta {
    margin-top: 3rem;
    background: linear-gradient(135deg, #001235 0%, #002b80 55%, #004ec0 100%);
    border-radius: var(--radius-lg);
    padding: 3rem;
    text-align: center;
    color: #fff;
    position: relative;
    overflow: hidden;
}
.listing-guide__cta::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px);
    background-size: 22px 22px;
    pointer-events: none;
}
.listing-guide__cta h3 { font-size: clamp(1.4rem, 3vw, 2rem); font-weight: 900; margin-bottom: .75rem; position: relative; }
.listing-guide__cta p { color: rgba(255,255,255,.75); font-size: 1rem; margin-bottom: 1.75rem; max-width: 520px; margin-inline: auto; position: relative; }
.listing-guide__cta-actions { display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap; position: relative; }
.listing-guide__cta .btn-outline { border-color: rgba(255,255,255,.35); color: rgba(255,255,255,.9); }
.listing-guide__cta .btn-outline:hover { background: rgba(255,255,255,.12); }

/* ── Responsive: About + Blog ─────────────────────────────── */
@media ( max-width: 900px ) {
    .about-hero__inner { grid-template-columns: 1fr; gap: 2rem; }
    .about-stat-cards { min-width: auto; }
    .contact-grid { grid-template-columns: 1fr; }
    .listing-step { grid-template-columns: 2.5rem 1fr; gap: 1rem; padding: 1.5rem 1.25rem; }
}

@media ( max-width: 640px ) {
    .blog-grid { grid-template-columns: 1fr; }
    .contact-form .form-row--half { grid-template-columns: 1fr; }
    .listing-guide__cta { padding: 2rem 1.5rem; }
}

/* ============================================================
   Hotel card — enhanced
   ============================================================ */

.hotel-grid {
    display: grid;
    grid-template-columns: repeat( auto-fill, minmax( 300px, 1fr ) );
    gap: 1.25rem;
}

.hotel-card {
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    transition: box-shadow .2s, transform .2s;
    display: flex;
    flex-direction: column;
}
.hotel-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }

/* Image */
.hotel-card__img-wrap {
    position: relative;
    display: block;
    aspect-ratio: 4/3;
    overflow: hidden;
}
.hotel-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .35s;
    display: block;
}
.hotel-card:hover .hotel-card__img { transform: scale(1.04); }
.hotel-card__img--placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #e8edf4 0%, #ccd4e4 100%);
}

/* Badges */
.hotel-badge {
    position: absolute;
    top: .65rem;
    left: .65rem;
    padding: .25em .7em;
    border-radius: var(--radius-sm);
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    z-index: 1;
}
.hotel-badge--verified { background: var(--color-primary); color: #fff; }
.hotel-badge--adults   { background: #7c3aed; color: #fff; }
.hotel-badge--right    { left: auto; right: .65rem; }

/* Price tag overlay */
.hotel-card__price-tag {
    position: absolute;
    bottom: .65rem;
    right: .65rem;
    background: rgba(0,0,0,.72);
    color: #fff;
    font-size: .82rem;
    font-weight: 700;
    padding: .3em .75em;
    border-radius: var(--radius-sm);
    backdrop-filter: blur(4px);
    z-index: 1;
}
.hotel-card__price-tag small { font-size: .68rem; font-weight: 400; opacity: .85; }

/* Body */
.hotel-card__body { padding: 1rem 1.15rem .75rem; display: flex; flex-direction: column; flex: 1; }

.hotel-card__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: .4rem;
    margin-bottom: .35rem;
}
.hotel-card__stars { color: #f59e0b; font-size: .85rem; letter-spacing: -.05em; }
.hotel-card__dest  { font-size: .75rem; color: var(--color-muted); }

.hotel-card__name { font-size: 1rem; font-weight: 800; line-height: 1.3; margin-bottom: .6rem; }
.hotel-card__name a { color: var(--color-text); }
.hotel-card__name a:hover { color: var(--color-primary); text-decoration: none; }

/* Trip type chips */
.hotel-card__chips {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
    margin-bottom: .7rem;
}
.hotel-card__chips--large .hotel-chip { font-size: .85rem; padding: .4em .9em; }

.hotel-chip {
    display: inline-block;
    padding: .25em .65em;
    border-radius: 100px;
    font-size: .72rem;
    font-weight: 600;
    background: var(--color-bg);
    color: var(--color-muted);
    border: 1px solid var(--color-border);
}
.hotel-chip--honeymoon   { background: #fce7f3; color: #9d174d; border-color: #f9a8d4; }
.hotel-chip--couples     { background: #fdf4ff; color: #7e22ce; border-color: #e9d5ff; }
.hotel-chip--family      { background: #eff6ff; color: #1d4ed8; border-color: #bfdbfe; }
.hotel-chip--adults-only { background: #f5f3ff; color: #6d28d9; border-color: #ddd6fe; }
.hotel-chip--luxury      { background: #fefce8; color: #854d0e; border-color: #fde68a; }
.hotel-chip--wellness    { background: #f0fdf4; color: #166534; border-color: #bbf7d0; }
.hotel-chip--diving      { background: #ecfeff; color: #164e63; border-color: #a5f3fc; }
.hotel-chip--all-inclusive { background: #fff7ed; color: #9a3412; border-color: #fed7aa; }
.hotel-chip--solo-travel { background: #f0f9ff; color: #0369a1; border-color: #bae6fd; }
.hotel-chip--adventure   { background: #fef2f2; color: #991b1b; border-color: #fecaca; }
.hotel-chip--transfer    { background: #f0f9ff; color: #0369a1; border-color: #bae6fd; }

/* Attribute row */
.hotel-card__attrs {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem;
    margin-bottom: .6rem;
}

.hotel-attr {
    display: inline-flex;
    align-items: center;
    gap: .3em;
    font-size: .73rem;
    color: var(--color-muted);
    background: var(--color-bg);
    padding: .22em .6em;
    border-radius: var(--radius-sm);
    border: 1px solid var(--color-border);
}
.hotel-attr svg { flex-shrink: 0; opacity: .7; }

/* Footer */
.hotel-card__footer {
    margin-top: auto;
    padding: .75rem 1.15rem;
    border-top: 1px solid var(--color-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: .5rem;
}
.hotel-card__offer-count { font-size: .78rem; color: var(--color-muted); }

/* ============================================================
   Hotels browse page
   ============================================================ */

/* Hero */
.hotels-hero {
    background: linear-gradient(150deg, #001235 0%, #002b80 55%, #004ec0 100%);
    padding-block: 2.5rem;
    border-bottom: 1px solid rgba(255,255,255,.06);
}
.hotels-hero__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    flex-wrap: wrap;
}
.hotels-hero__title {
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 900;
    color: #fff;
    letter-spacing: -.02em;
    margin-bottom: .35rem;
}
.hotels-hero__sub { font-size: .92rem; color: rgba(255,255,255,.65); }

/* Browse layout */
.browse-hotels-layout {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 2rem;
    align-items: start;
}

/* Filter panel */
.hotels-filter-panel {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 1.25rem;
    position: sticky;
    top: calc( var(--header-h) + 1rem );
}

.hotels-filter-panel__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.25rem;
    padding-bottom: .75rem;
    border-bottom: 1px solid var(--color-border);
}
.hotels-filter-panel__header h2 { font-size: 1rem; font-weight: 700; margin: 0; }
.filter-clear-link { font-size: .8rem; color: var(--color-muted); }
.filter-clear-link:hover { color: var(--color-accent); }

.filter-group { margin-bottom: 1.25rem; padding-bottom: 1.25rem; border-bottom: 1px solid var(--color-border); }
.filter-group:last-of-type { border-bottom: 0; margin-bottom: .75rem; padding-bottom: 0; }

.filter-group__label {
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
    color: var(--color-muted);
    margin-bottom: .6rem;
}

.filter-checkbox-label {
    display: flex;
    align-items: center;
    gap: .45rem;
    font-size: .875rem;
    padding: .2rem 0;
    cursor: pointer;
    color: var(--color-text);
}
.filter-checkbox-label input { cursor: pointer; accent-color: var(--color-primary); }
.filter-checkbox-label:hover { color: var(--color-primary); }

.filter-select {
    width: 100%;
    padding: .55rem .8rem;
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: .875rem;
    font-family: inherit;
    color: var(--color-text);
    background: var(--color-bg);
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right .65rem center;
    padding-right: 2rem;
}
.filter-price-range { display: flex; gap: .5rem; align-items: center; }

/* Active filters bar */
.active-filters-bar {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .4rem;
    margin-bottom: 1.25rem;
    padding: .65rem .85rem;
    background: #eff6ff;
    border-radius: var(--radius-md);
    border: 1px solid #bfdbfe;
}
.active-filters-bar__label { font-size: .78rem; font-weight: 600; color: #1d4ed8; white-space: nowrap; }
.active-filter-tag {
    display: inline-flex;
    align-items: center;
    gap: .3em;
    background: #fff;
    border: 1px solid #bfdbfe;
    border-radius: 100px;
    padding: .18em .6em;
    font-size: .75rem;
    font-weight: 500;
    color: var(--color-text);
}
.active-filter-tag a { color: var(--color-muted); text-decoration: none; font-weight: 700; }
.active-filter-tag a:hover { color: var(--color-accent); }

/* No results */
.no-results { text-align: center; padding: 4rem 1rem; }
.no-results p { color: var(--color-muted); margin-bottom: 1.25rem; }

/* ── Single hotel quick facts ─────────────────────────────── */
.hotel-quick-facts {
    display: grid;
    grid-template-columns: repeat( auto-fill, minmax( 180px, 1fr ) );
    gap: 1rem;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 1.25rem;
    margin-bottom: 1.75rem;
}
.hotel-fact__label {
    display: block;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
    color: var(--color-muted);
    margin-bottom: .2rem;
}
.hotel-fact__value { font-size: .95rem; font-weight: 600; color: var(--color-text); }
.hotel-fact__value--price { font-size: 1.2rem; font-weight: 800; color: var(--color-primary); }
.hotel-fact__value--price small { font-size: .72rem; font-weight: 400; color: var(--color-muted); }

.hotel-trip-types { margin-bottom: 1.5rem; }
.hotel-section-label { font-size: .75rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; color: var(--color-muted); margin-bottom: .6rem; }

/* Responsive hotels */
@media ( max-width: 900px ) {
    .browse-hotels-layout { grid-template-columns: 1fr; }
    .hotels-filter-panel { position: static; }
}
@media ( max-width: 600px ) {
    .hotel-grid { grid-template-columns: 1fr; }
    .hotel-quick-facts { grid-template-columns: 1fr 1fr; }
}

/* ══════════════════════════════════════════════════════════════════════════════
   RESPONSIVE — TABLET & MOBILE COMPREHENSIVE FIXES
   ══════════════════════════════════════════════════════════════════════════════ */

/* ── Mobile filter toggle button ─────────────────────────────────────────────
   Base styles — hidden on desktop, revealed via breakpoint rules below.      */
.mobile-filter-toggle {
    display: none;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    width: 100%;
    padding: .65rem 1.1rem;
    border: 1.5px solid var(--color-border, #dde0e6);
    border-radius: 8px;
    background: #fff;
    font-size: .875rem;
    font-weight: 600;
    color: var(--color-body, #1a2233);
    cursor: pointer;
    margin-bottom: 1rem;
    transition: border-color .15s, background .15s;
}
.mobile-filter-toggle:hover {
    border-color: var(--color-primary, #0057b8);
    background: #f5f8ff;
}
.mobile-filter-toggle .filter-toggle-chevron {
    margin-left: auto;
    transition: transform .2s;
}
.mobile-filter-toggle.is-active .filter-toggle-chevron { transform: rotate(180deg); }
.mobile-filter-toggle .filter-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--color-primary, #0057b8);
    color: #fff;
    font-size: .7rem;
    font-weight: 700;
    min-width: 1.25rem;
    height: 1.25rem;
    padding: 0 .3rem;
    border-radius: 10px;
    margin-left: .15rem;
}

/* ── Hotels archive: filter toggle + collapsible panel (≤ 900px) ─────────────*/
@media ( max-width: 900px ) {
    .mobile-filter-toggle--hotels { display: flex; }

    .hotels-filter-panel {
        display: none;
        margin-bottom: 1.5rem;
        border-radius: 12px;
        border: 1.5px solid var(--color-border, #dde0e6);
        background: #fff;
        padding: 1.25rem;
    }
    .hotels-filter-panel.is-open { display: block; }
}

/* ── Browse offers: filter toggle + collapsible panel (≤ 768px) ──────────────*/
@media ( max-width: 768px ) {
    .mobile-filter-toggle--offers { display: flex; }

    .browse-filters {
        display: none;
        margin-bottom: 1.5rem;
        border-radius: 12px;
        border: 1.5px solid var(--color-border, #dde0e6);
        background: #fff;
        padding: 1.25rem;
    }
    .browse-filters.is-open { display: block; }
}

/* ── FAQ grid: no mobile breakpoint existed ──────────────────────────────────*/
@media ( max-width: 640px ) {
    .faq-grid { grid-template-columns: 1fr; }
}

/* ── Tablet (≤ 768px): layout & spacing improvements ────────────────────────*/
@media ( max-width: 768px ) {
    /* Offer cards: full-width CTA so it doesn't get squeezed */
    .offer-card__footer { flex-direction: column; align-items: stretch; gap: .5rem; }
    .offer-card__footer .btn { text-align: center; }

    /* Hotel quick facts: slightly smaller min on mid-tablets */
    .hotel-quick-facts { grid-template-columns: repeat( auto-fill, minmax( 150px, 1fr ) ); }

    /* Partner steps: 2-col on tablet */
    .partner-steps__grid { grid-template-columns: repeat( 2, 1fr ); }

    /* Archive hotel hero: stack clear-filters link below heading */
    .hotels-hero__inner { flex-direction: column; align-items: flex-start; gap: .75rem; }

    /* How-section header: stop cramping the toggle pill */
    .how-header { flex-direction: column; align-items: flex-start; gap: .75rem; }

    /* Partner hub hero: centre copy on narrow screens */
    .partner-hub__hero-inner { text-align: center; }
    .partner-hub__hero p     { margin-inline: auto; }
    .partner-hub__stats      { justify-content: center; }

    /* Offer single: details grid can be 2-col on tablets */
    .offer-details-grid { grid-template-columns: 1fr 1fr; }
}

/* ── Small phone (≤ 540px): tighten everything ───────────────────────────────*/
@media ( max-width: 540px ) {
    /* Tighter container edges */
    .container { padding-inline: 1rem; }

    /* Destination grid: 2-col max on small phones */
    .dest-grid { grid-template-columns: repeat( 2, 1fr ); }
    .dest-card { aspect-ratio: 4/3; }

    /* Partner steps: single column */
    .partner-steps__grid { grid-template-columns: 1fr; }

    /* Partner hub stats: wrap gracefully */
    .partner-hub__stats  { flex-wrap: wrap; justify-content: center; gap: 1rem; }
    .partner-hub__stat   { min-width: 80px; }

    /* Hero: tighten */
    .hero           { padding-block: 3rem 2rem; }
    .hero__title    { font-size: clamp( 1.6rem, 7vw, 2.2rem ); }
    .hero__sub      { font-size: .95rem; }

    /* Stats strip */
    .stat { padding-inline: 1rem; }

    /* Offer grid: be explicit about 1-col (auto-fill handles ~580px, belt+braces) */
    .offer-grid { grid-template-columns: 1fr; }

    /* Section padding */
    .section { padding-block: 2.5rem; }

    /* Active filter tags: wrap neatly */
    .active-filters { flex-wrap: wrap; gap: .35rem; }

    /* Auth panel: less padding */
    .auth-panel { padding: 1.5rem 1.25rem; }
    .partner-hub__hero { padding-block: 2.5rem; }

    /* Offer single sidebar card CTAs: already stacked at 960px */

    /* Breadcrumb: truncate so it doesn't push layout */
    .breadcrumb { font-size: .75rem; }
}

/* ── Extra small phone (≤ 400px) ─────────────────────────────────────────────*/
@media ( max-width: 400px ) {
    /* How-it-works toggle: stack buttons vertically */
    .how-toggle            { flex-direction: column; width: 100%; }
    .how-toggle__btn       { width: 100%; justify-content: center; text-align: center; }

    /* Offer hero: save vertical space */
    .offer-single__hero-img,
    .offer-single__hero-img--placeholder { height: 220px; }

    /* Hotel header */
    .hotel-header__info h1 { font-size: 1.3rem; }

    /* Destination cards: slightly more square */
    .dest-card { aspect-ratio: 1/1; }

    /* Filter toggle: tighter padding */
    .mobile-filter-toggle { font-size: .8rem; padding: .55rem .9rem; }

    /* Footer social icons: centre */
    .footer-social { justify-content: center; }

    /* Account type toggle (partner signup): stack on very small phones */
    .account-type-toggle      { flex-direction: column; width: 100%; }
    .type-btn                 { width: 100%; justify-content: center; }
}
