/* Virgin Voyages hub — Alan Lekah (distinct from generic red-gradient cruise templates) */
:root {
    --vv-ink: #0f172a;
    --vv-indigo: #312e81;
    --vv-wine: #701a3b;
    --vv-rose: #e11d48;
    --vv-rose-soft: #fff1f2;
    --vv-sky: #0ea5e9;
    --vv-gold: #d97706;
    --vv-muted: #64748b;
    --vv-border: #e2e8f0;
    --vv-radius: 0.875rem;
    --vv-shadow: 0 10px 40px -12px rgba(15, 23, 42, 0.14);
}

/* ── Hero ── */
.vv-hero {
    position: relative;
    overflow: hidden;
    color: #fff;
    padding: 3.5rem 0 2.5rem;
    background:
        linear-gradient(148deg, var(--vv-ink) 0%, var(--vv-indigo) 48%, var(--vv-wine) 100%);
}
.vv-hero__pattern {
    position: absolute;
    inset: 0;
    opacity: 0.35;
    background-image:
        radial-gradient(circle at 12% 88%, rgba(225, 29, 72, 0.35) 0%, transparent 42%),
        radial-gradient(circle at 88% 12%, rgba(14, 165, 233, 0.2) 0%, transparent 38%),
        repeating-linear-gradient(
            -12deg,
            transparent,
            transparent 28px,
            rgba(255, 255, 255, 0.03) 28px,
            rgba(255, 255, 255, 0.03) 29px
        );
    pointer-events: none;
}
.vv-hero .container { position: relative; z-index: 1; }
.vv-hero__grid {
    display: grid;
    gap: 2rem;
    align-items: center;
}
@media (min-width: 900px) {
    .vv-hero__grid { grid-template-columns: 1.35fr 0.85fr; gap: 2.5rem; }
    .vv-hero { padding: 4.5rem 0 3rem; }
}
.vv-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.88);
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 9999px;
    padding: 0.4rem 0.9rem;
    margin-bottom: 1.25rem;
}
.vv-hero__title {
    font-family: Inter, system-ui, sans-serif;
    font-size: 2.35rem;
    font-weight: 800;
    line-height: 1.08;
    letter-spacing: -0.03em;
    margin-bottom: 1rem;
}
.vv-hero__title em {
    font-family: 'Playfair Display', Georgia, serif;
    font-style: italic;
    font-weight: 700;
    color: #fda4af;
}
@media (min-width: 768px) { .vv-hero__title { font-size: 3.25rem; } }
.vv-hero__sub {
    font-size: 1.05rem;
    line-height: 1.65;
    color: rgba(255, 255, 255, 0.86);
    max-width: 34rem;
    margin-bottom: 1.5rem;
}
.vv-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    align-items: center;
    margin-bottom: 1.25rem;
}
.vv-hero .cta-btn--virgin {
    background: linear-gradient(135deg, var(--vv-rose), #be123c);
    box-shadow: 0 8px 24px rgba(225, 29, 72, 0.35);
}
.vv-hero .cta-btn--virgin:hover {
    box-shadow: 0 10px 28px rgba(225, 29, 72, 0.45);
    color: #fff;
}
.vv-hero__secondary {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.8rem 1.35rem;
    border-radius: 9999px;
    border: 1px solid rgba(255, 255, 255, 0.35);
    color: #fff;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.2s, border-color 0.2s;
}
.vv-hero__secondary:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.55);
}
.vv-hero__aside {
    display: grid;
    gap: 0.75rem;
}
.vv-stat-pill {
    background: rgba(255, 255, 255, 0.07);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-left: 3px solid var(--vv-rose);
    border-radius: var(--vv-radius);
    padding: 0.9rem 1.1rem;
    backdrop-filter: blur(6px);
}
.vv-stat-pill__num {
    display: block;
    font-size: 1.35rem;
    font-weight: 800;
    line-height: 1.1;
    margin-bottom: 0.15rem;
}
.vv-stat-pill__label {
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.72);
}
.vv-hero__trust {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem 1.25rem;
    margin-top: 1.5rem;
    padding-top: 1.25rem;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
    font-size: 0.82rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.82);
}
.vv-hero__trust span {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}
.vv-hero__trust i { color: #fda4af; }
.vv-guarantee {
    font-size: 0.88rem;
    color: rgba(255, 255, 255, 0.75);
    margin-top: 0.75rem;
}
.vv-guarantee i { margin-right: 0.35rem; color: #fda4af; }

/* ── Sections ── */
.vv-section { padding: 3rem 0; }
.vv-section--alt { background: #f8fafc; }
.vv-section__head { margin-bottom: 1.75rem; max-width: 40rem; }
.vv-section__label {
    display: block;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--vv-rose);
    margin-bottom: 0.45rem;
}
.vv-section__title {
    font-family: Inter, system-ui, sans-serif;
    font-size: 1.65rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--vv-ink);
    margin-bottom: 0.5rem;
}
.vv-section__desc {
    color: var(--vv-muted);
    line-height: 1.6;
    font-size: 0.95rem;
}

/* ── Grids & cards ── */
.vv-tool-grid,
.vv-content-grid,
.vv-review-grid,
.vv-ship-grid {
    display: grid;
    gap: 1rem;
}
@media (min-width: 640px) {
    .vv-tool-grid { grid-template-columns: repeat(2, 1fr); }
    .vv-ship-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 900px) {
    .vv-content-grid { grid-template-columns: repeat(3, 1fr); }
    .vv-review-grid { grid-template-columns: repeat(2, 1fr); }
    .vv-ship-grid { grid-template-columns: repeat(4, 1fr); }
}

.vv-tool-card,
.vv-content-card,
.vv-ship-card {
    display: block;
    position: relative;
    background: #fff;
    border: 1px solid var(--vv-border);
    border-radius: var(--vv-radius);
    padding: 1.35rem 1.35rem 1.25rem;
    text-decoration: none;
    color: inherit;
    box-shadow: var(--vv-shadow);
    transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
    overflow: hidden;
}
.vv-tool-card::before,
.vv-content-card::before,
.vv-ship-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--vv-rose), var(--vv-sky));
}
.vv-tool-card:hover,
.vv-content-card:hover,
.vv-ship-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 16px 44px -14px rgba(15, 23, 42, 0.2);
    border-color: #fecdd3;
}
.vv-tool-card__num {
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--vv-rose);
    margin-bottom: 0.65rem;
}
.vv-tool-card__icon,
.vv-content-card__icon {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 0.65rem;
    background: var(--vv-rose-soft);
    color: var(--vv-rose);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    margin-bottom: 0.85rem;
}
.vv-tool-card__title,
.vv-content-card__title,
.vv-ship-card__title {
    font-family: Inter, system-ui, sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    margin-bottom: 0.4rem;
    color: var(--vv-ink);
}
.vv-tool-card__desc,
.vv-content-card__desc,
.vv-ship-card__desc {
    font-size: 0.88rem;
    color: var(--vv-muted);
    line-height: 1.55;
}
.vv-tool-card__cta {
    display: inline-block;
    margin-top: 0.85rem;
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--vv-rose);
}
.vv-ship-card__meta {
    margin-top: 0.65rem;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--vv-sky);
}

/* ── Why Alan band ── */
.vv-why-band {
    background: linear-gradient(135deg, #eff6ff 0%, #fff 55%, var(--vv-rose-soft) 100%);
    border: 1px solid #e0e7ff;
    border-radius: 1.25rem;
    padding: 1.75rem;
    display: grid;
    gap: 1.25rem;
}
@media (min-width: 768px) {
    .vv-why-band { grid-template-columns: 1.2fr 1fr; align-items: center; padding: 2rem 2.25rem; }
}
.vv-why-band__title {
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--vv-ink);
    margin-bottom: 0.5rem;
}
.vv-why-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.55rem;
}
.vv-why-list li {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    font-size: 0.9rem;
    color: #334155;
    line-height: 1.45;
}
.vv-why-list i {
    color: var(--vv-rose);
    margin-top: 0.15rem;
    flex-shrink: 0;
}

/* ── Tools (widgets) ── */
.vv-tool-widget {
    background: #fff;
    border: 1px solid var(--vv-border);
    border-radius: var(--vv-radius);
    padding: 1.5rem;
    min-height: 200px;
    box-shadow: var(--vv-shadow);
}
.vv-tool-step { margin-bottom: 1.5rem; }
.vv-tool-step h3 { font-weight: 700; margin-bottom: 0.75rem; color: var(--vv-ink); }
.vv-tool-options { display: flex; flex-direction: column; gap: 0.5rem; }
.vv-tool-option {
    display: block;
    width: 100%;
    text-align: left;
    padding: 0.85rem 1rem;
    border: 2px solid var(--vv-border);
    border-radius: 0.75rem;
    background: #fff;
    cursor: pointer;
    font-weight: 500;
    transition: border-color 0.15s, background 0.15s;
}
.vv-tool-option:hover,
.vv-tool-option--selected {
    border-color: var(--vv-rose);
    background: var(--vv-rose-soft);
}
.vv-tool-result {
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: var(--vv-radius);
    padding: 1.5rem;
    margin-top: 1rem;
}
.vv-tool-result h3 { font-size: 1.25rem; font-weight: 700; margin-bottom: 0.5rem; }
.vv-tool-cta { text-align: center; }

.vv-cabin-score {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    background: var(--vv-rose-soft);
    border: 2px solid #fecdd3;
    border-radius: var(--vv-radius);
    padding: 1rem 1.5rem;
    margin-bottom: 1rem;
}
.vv-cabin-score--inline { flex-direction: row; gap: 0.75rem; align-items: center; }
.vv-cabin-score__num { font-size: 2.5rem; font-weight: 800; color: var(--vv-rose); line-height: 1; }
.vv-cabin-score__label { font-size: 0.75rem; font-weight: 600; text-transform: uppercase; color: var(--vv-muted); }

.vv-stat-box {
    background: #fff;
    border: 1px solid var(--vv-border);
    border-radius: 0.75rem;
    padding: 1rem;
    text-align: center;
}
.vv-stat-box__label {
    display: block;
    font-size: 0.75rem;
    color: var(--vv-muted);
    text-transform: uppercase;
    margin-bottom: 0.25rem;
}
.vv-stat-box__value { font-size: 1.125rem; font-weight: 700; }

.vv-review-card {
    background: #fff;
    border: 1px solid var(--vv-border);
    border-radius: var(--vv-radius);
    padding: 1.5rem;
    box-shadow: var(--vv-shadow);
}
.vv-review-card__stars { color: var(--vv-gold); font-size: 1.15rem; margin-bottom: 0.75rem; }
.vv-review-card__text { font-style: italic; color: #334155; line-height: 1.6; margin-bottom: 1rem; }
.vv-review-card__meta { font-size: 0.875rem; color: var(--vv-muted); }

.vv-cabin-lookup-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.vv-cabin-lookup-table th,
.vv-cabin-lookup-table td { padding: 0.75rem; border-bottom: 1px solid var(--vv-border); text-align: left; }
.vv-cabin-lookup-table th { background: #f8fafc; font-weight: 600; }

.vv-bar-input {
    width: 100%;
    max-width: 120px;
    padding: 0.5rem;
    border: 1px solid var(--vv-border);
    border-radius: 0.5rem;
}
.vv-compare-table { width: 100%; font-size: 0.875rem; }
.vv-compare-table th,
.vv-compare-table td { padding: 0.65rem; border: 1px solid var(--vv-border); }
.vv-compare-table th { background: #f8fafc; }

.cabin-page-hero { margin-bottom: 0; }
.cabin-faq { margin-top: 2rem; }
.cabin-faq details {
    border: 1px solid var(--vv-border);
    border-radius: 0.75rem;
    margin-bottom: 0.5rem;
    padding: 0.75rem 1rem;
    background: #fff;
}
.cabin-faq summary { font-weight: 600; cursor: pointer; }
.cabin-faq p { margin-top: 0.5rem; color: var(--vv-muted); font-size: 0.9rem; }

.vv-line-hub-banner {
    background: linear-gradient(135deg, var(--vv-ink), var(--vv-indigo));
    color: #fff;
    border-radius: var(--vv-radius);
    padding: 1.25rem 1.5rem;
    margin-bottom: 1.5rem;
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: center;
    justify-content: space-between;
    border-left: 4px solid var(--vv-rose);
}
.vv-line-hub-banner a {
    color: #fff;
    font-weight: 600;
    text-decoration: none;
    padding: 0.5rem 1rem;
    border: 1px solid rgba(255, 255, 255, 0.35);
    border-radius: 9999px;
    transition: background 0.2s;
}
.vv-line-hub-banner a:hover { background: rgba(255, 255, 255, 0.1); }

.vv-link {
    color: #0369a1;
    font-weight: 600;
    text-decoration: none;
}
.vv-link:hover { text-decoration: underline; }
