/* ==========================================================================
   Goa Trip Theme — main stylesheet
   Premium Dark & Gold theme converted from the original Horizons React build.
   ========================================================================== */

:root {
    --goatrip-primary:        #92400E;
    --goatrip-primary-rgb:    212,175,55;
    --goatrip-bg:             #0B0B0B;
    --goatrip-card:           #121212;
    --goatrip-secondary:      #1A1A1A;
    --goatrip-foreground:     #F5E6B5;
    --goatrip-muted:          #ACA28A;
    --goatrip-border:         rgba(212,175,55,0.30);
    --goatrip-radius:         0.75rem;
    --goatrip-radius-lg:      1rem;
    --goatrip-shadow:         0 8px 30px rgba(0,0,0,0.50);
    --goatrip-glow:           0 0 25px rgba(var(--goatrip-primary-rgb),0.18);
    --goatrip-text-glow:      0 0 15px rgba(var(--goatrip-primary-rgb),0.55);
    --goatrip-whatsapp:       #25D366;
    --goatrip-whatsapp-hover: #20BD5A;

    --goatrip-font-display:   'Playfair Display', Georgia, serif;
    --goatrip-font-body:      'DM Sans', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

    --goatrip-container:      1280px;
}

/* ---------- Reset / base --------------------------------------------------*/
html { scroll-behavior: smooth; }
body {
    font-family: var(--goatrip-font-body);
    background: var(--goatrip-bg);
    color: var(--goatrip-foreground);
    line-height: 1.55;
    overflow-x: clip;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
a { color: var(--goatrip-primary); text-decoration: none; transition: color .25s ease; }
a:hover { color: #F97316; }
img { display: block; max-width: 100%; height: auto; }
button { font-family: inherit; }

h1, h2, h3, h4, h5, h6 {
    font-family: var(--goatrip-font-display);
    color: var(--goatrip-foreground);
    letter-spacing: -0.01em;
    margin: 0 0 0.6em;
    line-height: 1.2;
}

p { margin: 0 0 1em; }
ul, ol { padding-left: 1.25rem; }
hr { border: 0; border-top: 1px solid var(--goatrip-border); margin: 2rem 0; }

::selection { background: rgba(var(--goatrip-primary-rgb), 0.4); color: #000; }

/* ---------- Layout helpers ------------------------------------------------*/
.goatrip-container {
    width: 100%;
    max-width: var(--goatrip-container);
    margin: 0 auto;
    padding: 0 1.25rem;
}
@media (min-width: 768px) { .goatrip-container { padding: 0 2rem; } }

.goatrip-section { padding: 5rem 0; }
@media (min-width: 768px) { .goatrip-section { padding: 6rem 0; } }

.goatrip-text-center { text-align: center; }

.goatrip-section-head { text-align: center; max-width: 720px; margin: 0 auto 3rem; }
.goatrip-section-head h2 {
    font-size: clamp(2rem, 4vw, 3rem);
    margin-bottom: 1rem;
}
.goatrip-section-head p {
    color: var(--goatrip-muted);
    font-size: 1.0625rem;
}

.goatrip-text-glow { text-shadow: var(--goatrip-text-glow); }
.goatrip-text-balance { text-wrap: balance; }
.goatrip-divider { height: 1px; background: var(--goatrip-border); margin: 2.5rem 0; }

/* ---------- Buttons -------------------------------------------------------*/
.goatrip-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    font-weight: 600;
    padding: 0.75rem 1.5rem;
    border-radius: 999px;
    border: 2px solid transparent;
    cursor: pointer;
    transition: all .3s ease;
    text-align: center;
    line-height: 1.2;
    font-size: 0.9375rem;
}
.goatrip-btn:hover { transform: translateY(-1px); }
.goatrip-btn-primary {
    background: var(--goatrip-primary);
    color: #000;
    box-shadow: 0 0 15px rgba(var(--goatrip-primary-rgb),0.4);
}
.goatrip-btn-primary:hover {
    background: #e1bf45;
    color: #000;
    box-shadow: 0 0 25px rgba(var(--goatrip-primary-rgb),0.65);
}
.goatrip-btn-outline {
    background: transparent;
    color: var(--goatrip-primary);
    border-color: var(--goatrip-primary);
}
.goatrip-btn-outline:hover {
    background: rgba(var(--goatrip-primary-rgb), 0.1);
    color: var(--goatrip-primary);
}
.goatrip-btn-whatsapp {
    background: var(--goatrip-whatsapp);
    color: #fff;
    border-color: rgba(var(--goatrip-primary-rgb), 0.3);
    box-shadow: 0 6px 20px rgba(37, 211, 102, 0.25);
}
.goatrip-btn-whatsapp:hover {
    background: var(--goatrip-whatsapp-hover);
    color: #fff;
}
.goatrip-btn-lg { padding: 1.05rem 2.25rem; font-size: 1.125rem; }
.goatrip-btn-block { width: 100%; }

/* ---------- Icons ---------------------------------------------------------*/
.goatrip-icon {
    display: inline-flex;
    width: 1.125rem;
    height: 1.125rem;
    flex-shrink: 0;
}
.goatrip-icon svg { width: 100%; height: 100%; }
.goatrip-icon-lg { width: 1.5rem; height: 1.5rem; }

/* ---------- Header --------------------------------------------------------*/
.goatrip-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(11,11,11,0.92);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--goatrip-border);
    box-shadow: 0 4px 20px rgba(0,0,0,0.4);
}
.goatrip-header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 76px;
    gap: 1rem;
}
.goatrip-logo {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    text-decoration: none;
    color: inherit;
}
.goatrip-logo img {
    height: 50px;
    width: auto;
    border-radius: 6px;
    object-fit: contain;
}
.goatrip-logo-text { display: none; }
@media (min-width: 640px) { .goatrip-logo-text { display: block; } }
.goatrip-logo-text strong {
    display: block;
    color: var(--goatrip-primary);
    font-family: var(--goatrip-font-display);
    font-size: 1.35rem;
    font-weight: 700;
    line-height: 1.1;
}
.goatrip-logo-text span {
    color: var(--goatrip-muted);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-size: 0.625rem;
    font-weight: 500;
}
.goatrip-nav { display: none; align-items: center; gap: 0.25rem; }
@media (min-width: 1024px) { .goatrip-nav { display: flex; } }
.goatrip-nav a {
    padding: 0.5rem 1rem;
    border-radius: 8px;
    color: rgba(245,230,181,0.85);
    font-weight: 500;
    font-size: 0.9375rem;
    transition: all .3s ease;
}
.goatrip-nav a:hover, .goatrip-nav .current-menu-item > a, .goatrip-nav .current_page_item > a {
    color: var(--goatrip-primary);
    background: rgba(var(--goatrip-primary-rgb), 0.08);
}
.goatrip-nav .menu, .goatrip-nav ul { list-style: none; padding: 0; margin: 0; display: flex; gap: 0.25rem; }
.goatrip-header-cta { display: none; align-items: center; gap: 0.75rem; }
@media (min-width: 1024px) { .goatrip-header-cta { display: flex; } }

.goatrip-menu-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px; height: 44px;
    background: transparent;
    border: 1px solid var(--goatrip-border);
    border-radius: 8px;
    color: var(--goatrip-foreground);
    cursor: pointer;
}
@media (min-width: 1024px) { .goatrip-menu-toggle { display: none; } }

.goatrip-mobile-nav {
    display: none;
    border-top: 1px solid var(--goatrip-border);
    background: var(--goatrip-bg);
    padding: 1rem 0;
}
.goatrip-mobile-nav.is-open { display: block; }
.goatrip-mobile-nav ul { list-style: none; padding: 0; margin: 0; }
.goatrip-mobile-nav a {
    display: block;
    padding: 0.85rem 1.25rem;
    border-radius: 8px;
    color: var(--goatrip-foreground);
    font-weight: 500;
}
.goatrip-mobile-nav a:hover, .goatrip-mobile-nav .current-menu-item > a {
    color: var(--goatrip-primary);
    background: rgba(var(--goatrip-primary-rgb), 0.08);
}
.goatrip-mobile-cta { padding: 1rem 1.25rem 0; }

/* ---------- Hero ----------------------------------------------------------*/
.goatrip-hero {
    position: relative;
    min-height: 90vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    text-align: center;
}
.goatrip-hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    z-index: 0;
}
.goatrip-hero-bg::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(11,11,11,0.85) 0%, rgba(11,11,11,0.55) 50%, var(--goatrip-bg) 100%);
}
.goatrip-hero-inner {
    position: relative;
    z-index: 1;
    max-width: 900px;
    margin: 0 auto;
    padding: 6rem 1.25rem 5rem;
}
.goatrip-hero h1 {
    font-size: clamp(2.5rem, 6vw, 4.75rem);
    line-height: 1.1;
    margin-bottom: 1.25rem;
    text-shadow: 0 4px 12px rgba(0,0,0,0.85);
}
.goatrip-hero h1 .text-primary, .goatrip-hero h1 strong {
    color: var(--goatrip-primary);
    text-shadow: var(--goatrip-text-glow);
}
.goatrip-hero p.lead {
    font-size: clamp(1.05rem, 2vw, 1.4rem);
    color: rgba(245,230,181,0.92);
    margin-bottom: 2rem;
    text-shadow: 0 1px 3px rgba(0,0,0,0.6);
}
.goatrip-hero-actions { display: flex; gap: 0.75rem; justify-content: center; flex-wrap: wrap; }

/* Trust pill row */
.goatrip-trust {
    display: flex;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap;
    margin-top: 2rem;
}
.goatrip-trust span {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: rgba(0,0,0,0.55);
    border: 1px solid var(--goatrip-border);
    border-radius: 999px;
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    color: rgba(245,230,181,0.95);
    backdrop-filter: blur(6px);
}

/* ---------- Card grids ----------------------------------------------------*/
.goatrip-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}
@media (min-width: 640px) { .goatrip-grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 768px) { .goatrip-grid-2 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .goatrip-grid-4 { grid-template-columns: repeat(4, 1fr); } }

.goatrip-card {
    position: relative;
    background: var(--goatrip-card);
    border: 1px solid rgba(212,175,55,0.18);
    border-radius: var(--goatrip-radius-lg);
    overflow: hidden;
    box-shadow: 0 4px 16px rgba(0,0,0,0.3);
    transition: all .3s ease;
    display: flex;
    flex-direction: column;
    height: 100%;
}
.goatrip-card:hover {
    border-color: rgba(212,175,55,0.6);
    box-shadow: 0 8px 30px rgba(var(--goatrip-primary-rgb),0.15);
    transform: translateY(-4px);
}
.goatrip-card-media {
    position: relative;
    aspect-ratio: 16 / 10;
    overflow: hidden;
}
.goatrip-card-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s ease;
}
.goatrip-card:hover .goatrip-card-image { transform: scale(1.06); }
.goatrip-card-media::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 30%, rgba(11,11,11,0.85) 100%);
    pointer-events: none;
}
.goatrip-badge {
    position: absolute;
    top: 1rem;
    left: 1rem;
    background: var(--goatrip-primary);
    color: #000;
    font-weight: 700;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    z-index: 2;
    box-shadow: 0 2px 8px rgba(0,0,0,0.3);
}
.goatrip-card-meta-row {
    position: absolute;
    bottom: 1rem;
    left: 1rem;
    right: 1rem;
    display: flex;
    justify-content: space-between;
    z-index: 2;
}
.goatrip-card-meta-row > span {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    background: rgba(11,11,11,0.78);
    border: 1px solid var(--goatrip-border);
    backdrop-filter: blur(6px);
    border-radius: 6px;
    padding: 0.25rem 0.5rem;
    font-size: 0.8rem;
    font-weight: 600;
}
.goatrip-card-body {
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.goatrip-card-body h3 {
    font-size: 1.4rem;
    margin-bottom: 0.5rem;
    line-height: 1.25;
}
.goatrip-card-body h3 a { color: inherit; }
.goatrip-card-body h3 a:hover { color: var(--goatrip-primary); }
.goatrip-card-desc {
    color: var(--goatrip-muted);
    font-size: 0.9rem;
    margin-bottom: 1rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.goatrip-card-features {
    list-style: none;
    padding: 0;
    margin: 0 0 1.25rem;
}
.goatrip-card-features li {
    display: flex;
    gap: 0.5rem;
    align-items: flex-start;
    font-size: 0.875rem;
    color: rgba(245,230,181,0.85);
    margin-bottom: 0.4rem;
}
.goatrip-card-features .goatrip-icon { color: var(--goatrip-primary); margin-top: 2px; }
.goatrip-card-info-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1rem;
    color: rgba(245,230,181,0.9);
    font-size: 0.875rem;
    margin-bottom: 1.25rem;
}
.goatrip-card-info-row span { display: inline-flex; align-items: center; gap: 0.4rem; }
.goatrip-card-info-row .goatrip-icon { color: var(--goatrip-primary); }
.goatrip-card-foot {
    margin-top: auto;
    padding-top: 1rem;
    border-top: 1px solid rgba(212,175,55,0.15);
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.goatrip-price-block .goatrip-price-label {
    color: var(--goatrip-muted);
    text-transform: uppercase;
    font-size: 0.7rem;
    letter-spacing: 0.08em;
    margin-bottom: 0.15rem;
}
.goatrip-price-block .goatrip-price {
    color: var(--goatrip-primary);
    font-size: 1.5rem;
    font-weight: 800;
    text-shadow: var(--goatrip-text-glow);
    font-family: var(--goatrip-font-display);
}
.goatrip-card-actions { display: flex; gap: 0.5rem; }
.goatrip-card-actions .goatrip-btn { flex: 1; }

/* ---------- Rating chip --------------------------------------------------*/
.goatrip-rating {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    color: var(--goatrip-foreground);
    font-size: 0.8rem;
}
.goatrip-rating .goatrip-star { color: var(--goatrip-primary); }
.goatrip-rating-count { color: var(--goatrip-muted); font-size: 0.75rem; }

/* ---------- Stats / Trust block -----------------------------------------*/
.goatrip-stats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
    text-align: center;
    margin-top: 2rem;
}
@media (min-width: 768px) { .goatrip-stats { grid-template-columns: repeat(4, 1fr); } }
.goatrip-stats > div { padding: 0 1rem; }
.goatrip-stats > div + div { border-left: 1px solid rgba(212,175,55,0.2); }
@media (max-width: 767px) {
    .goatrip-stats > div + div { border-left: 0; }
    .goatrip-stats > div:nth-child(odd) { border-right: 1px solid rgba(212,175,55,0.2); }
}
.goatrip-stat-value {
    font-family: var(--goatrip-font-display);
    font-size: clamp(1.8rem, 3.5vw, 3rem);
    font-weight: 800;
    color: var(--goatrip-primary);
    text-shadow: var(--goatrip-text-glow);
    margin-bottom: 0.25rem;
    line-height: 1;
}
.goatrip-stat-label {
    color: rgba(245,230,181,0.78);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-size: 0.75rem;
    font-weight: 500;
}

/* ---------- Testimonials --------------------------------------------------*/
.goatrip-testimonials {
    background: rgba(255,255,255,0.02);
    border-top: 1px solid rgba(212,175,55,0.15);
    border-bottom: 1px solid rgba(212,175,55,0.15);
}
.goatrip-testi-track {
    display: grid;
    gap: 1.5rem;
    grid-template-columns: 1fr;
}
@media (min-width: 768px) { .goatrip-testi-track { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .goatrip-testi-track { grid-template-columns: repeat(3, 1fr); } }
.goatrip-testi-card {
    background: var(--goatrip-card);
    border: 1px solid var(--goatrip-border);
    border-radius: var(--goatrip-radius);
    padding: 1.75rem;
    position: relative;
}
.goatrip-testi-card::before {
    content: '"';
    position: absolute;
    top: -10px;
    left: 1.25rem;
    font-family: var(--goatrip-font-display);
    color: var(--goatrip-primary);
    font-size: 4rem;
    line-height: 1;
}
.goatrip-testi-stars { color: var(--goatrip-primary); margin-bottom: 0.75rem; letter-spacing: 0.1em; }
.goatrip-testi-content { color: rgba(245,230,181,0.9); font-style: italic; margin-bottom: 1rem; }
.goatrip-testi-author { display: flex; flex-direction: column; }
.goatrip-testi-author strong { color: var(--goatrip-foreground); }
.goatrip-testi-author small { color: var(--goatrip-muted); font-size: 0.8rem; }

/* ---------- Forms ---------------------------------------------------------*/
.goatrip-form { display: flex; flex-direction: column; gap: 1rem; }
.goatrip-form label {
    display: block;
    color: var(--goatrip-foreground);
    font-weight: 500;
    margin-bottom: 0.4rem;
    font-size: 0.9rem;
}
.goatrip-form .req { color: #ff8a8a; }
.goatrip-form input[type="text"],
.goatrip-form input[type="email"],
.goatrip-form input[type="tel"],
.goatrip-form input[type="date"],
.goatrip-form input[type="search"],
.goatrip-form textarea,
.goatrip-form select {
    width: 100%;
    background: var(--goatrip-secondary);
    border: 1px solid var(--goatrip-border);
    border-radius: 8px;
    color: var(--goatrip-foreground);
    padding: 0.75rem 1rem;
    font-family: inherit;
    font-size: 0.95rem;
    transition: all .25s ease;
}
.goatrip-form input:focus,
.goatrip-form textarea:focus,
.goatrip-form select:focus {
    outline: none;
    border-color: var(--goatrip-primary);
    box-shadow: 0 0 0 3px rgba(var(--goatrip-primary-rgb), 0.18);
}
.goatrip-form textarea { min-height: 120px; resize: vertical; }
.goatrip-form .goatrip-honeypot { position: absolute; left: -9999px; visibility: hidden; }
.goatrip-form-message {
    margin-top: 0.75rem;
    padding: 0.75rem 1rem;
    border-radius: 8px;
    font-size: 0.9rem;
    display: none;
}
.goatrip-form-message.is-success {
    display: block;
    background: rgba(37, 211, 102, 0.12);
    border: 1px solid rgba(37, 211, 102, 0.4);
    color: #b9f5d2;
}
.goatrip-form-message.is-error {
    display: block;
    background: rgba(255, 80, 80, 0.12);
    border: 1px solid rgba(255, 80, 80, 0.4);
    color: #ffc4c4;
}

/* ---------- Newsletter inline form ---------------------------------------*/
.goatrip-newsletter {
    background: linear-gradient(135deg, rgba(212,175,55,0.08), rgba(11,11,11,0.6));
    border-top: 1px solid var(--goatrip-border);
    border-bottom: 1px solid var(--goatrip-border);
}
.goatrip-newsletter-inner { max-width: 640px; margin: 0 auto; text-align: center; }
.goatrip-newsletter h2 { font-size: clamp(1.75rem, 3vw, 2.5rem); margin-bottom: 0.75rem; }
.goatrip-newsletter p { color: var(--goatrip-muted); margin-bottom: 1.5rem; }
.goatrip-newsletter-form { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.goatrip-newsletter-form input[type="email"] {
    flex: 1;
    min-width: 220px;
}

/* ---------- Footer --------------------------------------------------------*/
.goatrip-footer {
    background: var(--goatrip-card);
    border-top: 1px solid var(--goatrip-border);
    color: var(--goatrip-foreground);
    padding: 4rem 0 1.5rem;
    margin-top: 0;
}
.goatrip-footer-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
    margin-bottom: 2.5rem;
}
@media (min-width: 640px) { .goatrip-footer-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .goatrip-footer-grid { grid-template-columns: repeat(4, 1fr); } }
.goatrip-footer h3 {
    font-size: 1.125rem;
    color: var(--goatrip-foreground);
    margin-bottom: 1.25rem;
}
.goatrip-footer ul { list-style: none; padding: 0; margin: 0; }
.goatrip-footer ul li { margin-bottom: 0.6rem; }
.goatrip-footer ul li a { color: var(--goatrip-muted); }
.goatrip-footer ul li a:hover { color: var(--goatrip-primary); }
.goatrip-footer-info li {
    display: flex;
    gap: 0.65rem;
    color: var(--goatrip-muted);
    align-items: flex-start;
}
.goatrip-footer-info .goatrip-icon { color: var(--goatrip-primary); margin-top: 2px; }
.goatrip-socials { display: flex; gap: 0.75rem; margin-top: 1.25rem; }
.goatrip-socials a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    background: var(--goatrip-secondary);
    border: 1px solid rgba(212,175,55,0.2);
    border-radius: 10px;
    color: var(--goatrip-foreground);
    transition: all .25s ease;
}
.goatrip-socials a:hover {
    background: var(--goatrip-primary);
    color: #000;
    border-color: var(--goatrip-primary);
}
.goatrip-footer-bar {
    border-top: 1px solid rgba(212,175,55,0.15);
    padding-top: 1.5rem;
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: space-between;
    align-items: center;
    color: var(--goatrip-muted);
    font-size: 0.875rem;
}

/* ---------- Sticky WhatsApp button ---------------------------------------*/
.goatrip-sticky-whatsapp {
    position: fixed;
    bottom: 1.25rem;
    right: 1.25rem;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--goatrip-whatsapp);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 24px rgba(37,211,102,0.4);
    z-index: 90;
    transition: transform .25s ease;
}
.goatrip-sticky-whatsapp:hover { transform: scale(1.08); color: #fff; }
.goatrip-sticky-whatsapp .goatrip-icon { width: 28px; height: 28px; }

/* Sticky bottom CTA on mobile */
.goatrip-sticky-mobile-cta {
    display: none;
    position: fixed;
    left: 1rem;
    right: 1rem;
    bottom: 1rem;
    z-index: 91;
}
@media (max-width: 767px) { .goatrip-sticky-mobile-cta { display: block; } }
@media (max-width: 767px) { .goatrip-sticky-whatsapp { bottom: 5.25rem; } }

/* ---------- Page hero (used on archives & static pages) ------------------*/
.goatrip-page-hero {
    position: relative;
    padding: 8rem 0 4rem;
    text-align: center;
    background-size: cover;
    background-position: center;
    overflow: hidden;
}
.goatrip-page-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(11,11,11,0.85), rgba(11,11,11,0.65) 60%, var(--goatrip-bg));
}
.goatrip-page-hero > * { position: relative; z-index: 1; }
.goatrip-page-hero h1 { font-size: clamp(2.25rem, 5vw, 3.75rem); }
.goatrip-page-hero p { color: rgba(245,230,181,0.9); max-width: 640px; margin: 0 auto; }

/* ---------- Single CPT layout --------------------------------------------*/
.goatrip-single {
    padding: 3rem 0 5rem;
}
.goatrip-single-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
}
@media (min-width: 1024px) { .goatrip-single-grid { grid-template-columns: 1.6fr 1fr; gap: 3rem; } }
.goatrip-single-cover {
    aspect-ratio: 16 / 10;
    border-radius: var(--goatrip-radius-lg);
    overflow: hidden;
    border: 1px solid var(--goatrip-border);
    margin-bottom: 2rem;
}
.goatrip-single-cover img { width: 100%; height: 100%; object-fit: cover; }
.goatrip-single h1 { font-size: clamp(2rem, 4vw, 3rem); margin-bottom: 1rem; }
.goatrip-single .goatrip-content { color: rgba(245,230,181,0.92); font-size: 1.05rem; line-height: 1.7; }
.goatrip-single .goatrip-content h2 { font-size: 1.6rem; margin-top: 2rem; }
.goatrip-single .goatrip-content ul { padding-left: 1.25rem; }
.goatrip-single .goatrip-content ul li { margin-bottom: 0.45rem; }

.goatrip-booking-card {
    background: var(--goatrip-card);
    border: 1px solid var(--goatrip-border);
    border-radius: var(--goatrip-radius-lg);
    padding: 1.75rem;
    position: sticky;
    top: 96px;
    box-shadow: var(--goatrip-glow);
}
.goatrip-booking-card .goatrip-price-block { margin-bottom: 1rem; padding-bottom: 1rem; border-bottom: 1px solid var(--goatrip-border); }
.goatrip-booking-card h2 { font-size: 1.25rem; }
.goatrip-booking-meta {
    list-style: none; padding: 0; margin: 0 0 1.5rem;
    display: flex; flex-direction: column; gap: 0.6rem;
    font-size: 0.9rem; color: rgba(245,230,181,0.9);
}
.goatrip-booking-meta li { display: flex; gap: 0.5rem; align-items: center; }
.goatrip-booking-meta .goatrip-icon { color: var(--goatrip-primary); }
.goatrip-booking-card .goatrip-btn { width: 100%; }
.goatrip-booking-card .goatrip-btn + .goatrip-btn { margin-top: 0.6rem; }

/* ---------- Inclusion cards (used on single) ----------------------------*/
.goatrip-inclusions {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.5rem;
}
@media (min-width: 640px) { .goatrip-inclusions { grid-template-columns: repeat(2, 1fr); } }
.goatrip-inclusions li {
    display: flex;
    gap: 0.5rem;
    align-items: flex-start;
    background: rgba(212,175,55,0.05);
    border: 1px solid rgba(212,175,55,0.15);
    border-radius: 8px;
    padding: 0.65rem 0.85rem;
    color: rgba(245,230,181,0.92);
    font-size: 0.9rem;
}
.goatrip-inclusions .goatrip-icon { color: var(--goatrip-primary); }

/* ---------- Final CTA section -------------------------------------------*/
.goatrip-cta-final {
    background: var(--goatrip-card);
    border-top: 1px solid var(--goatrip-border);
    text-align: center;
    position: relative;
    overflow: hidden;
}
.goatrip-cta-final::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle at 20% 20%, rgba(var(--goatrip-primary-rgb),0.08), transparent 50%),
                      radial-gradient(circle at 80% 80%, rgba(var(--goatrip-primary-rgb),0.08), transparent 50%);
}
.goatrip-cta-final > * { position: relative; }
.goatrip-cta-final h2 { font-size: clamp(2rem, 5vw, 3.5rem); margin-bottom: 1rem; }
.goatrip-cta-final p { color: var(--goatrip-muted); max-width: 640px; margin: 0 auto 2rem; font-size: 1.05rem; }

/* ---------- Pagination ---------------------------------------------------*/
.goatrip-pagination {
    margin-top: 3rem;
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}
.goatrip-pagination .page-numbers,
.goatrip-pagination a, .goatrip-pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 0.85rem;
    border-radius: 8px;
    border: 1px solid var(--goatrip-border);
    color: var(--goatrip-foreground);
    font-weight: 500;
    text-decoration: none;
}
.goatrip-pagination .current,
.goatrip-pagination a:hover {
    background: var(--goatrip-primary);
    color: #000;
    border-color: var(--goatrip-primary);
}

/* ---------- Misc / utility classes (referenced from PHP templates) -------*/
.text-primary { color: var(--goatrip-primary); }
.text-glow    { text-shadow: var(--goatrip-text-glow); }

/* Search results list */
.goatrip-search-list { display: flex; flex-direction: column; gap: 1.5rem; }
.goatrip-search-list article {
    background: var(--goatrip-card);
    border: 1px solid var(--goatrip-border);
    border-radius: var(--goatrip-radius);
    padding: 1.5rem;
}
.goatrip-search-list h2 { font-size: 1.25rem; margin-bottom: 0.5rem; }
.goatrip-search-list h2 a { color: var(--goatrip-foreground); }
.goatrip-search-list h2 a:hover { color: var(--goatrip-primary); }

/* 404 */
.goatrip-404 { text-align: center; padding: 8rem 1rem; }
.goatrip-404 h1 {
    font-size: clamp(4rem, 12vw, 8rem);
    color: var(--goatrip-primary);
    text-shadow: var(--goatrip-text-glow);
    line-height: 1;
}

/* Comments */
.goatrip-comments { margin-top: 3rem; }
.goatrip-comments .comment-list { list-style: none; padding: 0; }
.goatrip-comments .comment-body {
    background: var(--goatrip-card);
    border: 1px solid var(--goatrip-border);
    border-radius: var(--goatrip-radius);
    padding: 1.25rem;
    margin-bottom: 1rem;
}
.goatrip-comments .comment-meta { display: flex; gap: 0.75rem; align-items: center; margin-bottom: 0.5rem; }
.goatrip-comments .comment-meta img { border-radius: 50%; }

/* Elementor compatibility — when a page is built with Elementor, drop our
   own content padding so Elementor sections can be edge-to-edge. */
body.elementor-page-active .goatrip-default-content { padding: 0; }

/* Make content sit nicely on Elementor full-width templates. */
.goatrip-page { padding: 4rem 0; }
.goatrip-page .goatrip-page-content { max-width: 800px; margin: 0 auto; }

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
    * { animation: none !important; transition: none !important; }
    html { scroll-behavior: auto; }
}

/* WordPress core alignment classes (gallery, captions, etc.) */
.alignleft  { float: left;  margin: 0 1.5rem 1rem 0; }
.alignright { float: right; margin: 0 0 1rem 1.5rem; }
.aligncenter { display: block; margin-left: auto; margin-right: auto; }
.wp-caption  { max-width: 100%; }
.wp-caption-text { color: var(--goatrip-muted); font-size: 0.85rem; text-align: center; padding-top: 0.5rem; }
.screen-reader-text {
    border: 0; clip: rect(1px,1px,1px,1px); -webkit-clip-path: inset(50%); clip-path: inset(50%);
    height: 1px; width: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; word-wrap: normal !important;
}

/* ============================================================
   SUPPLEMENTAL STYLES (added to cover all template classes)
   ============================================================ */

/* Section utilities */
.goatrip-section-foot { margin-top: 2.5rem; text-align: center; }
.goatrip-section-title { font-size: clamp(1.75rem, 3.5vw, 2.5rem); margin: 0 0 .75rem 0; }
.goatrip-section-sub { color: rgba(245,230,181,.75); font-size: 1.05rem; margin: 0; }
.goatrip-section-alt { background: rgba(212,175,55,.03); }
.goatrip-section-stats { background: linear-gradient(180deg, rgba(212,175,55,.04), transparent); }

/* Hero pill + title + subtitle + trust list */
.goatrip-hero-pill {
    display: inline-flex; align-items: center; gap: .5rem;
    padding: .5rem 1rem; border: 1px solid rgba(212,175,55,.4);
    border-radius: 999px; background: rgba(212,175,55,.08);
    color: var(--goatrip-primary); font-size: .85rem; margin-bottom: 1.5rem;
    backdrop-filter: blur(8px);
}
.goatrip-hero-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(2.5rem, 6vw, 5rem); line-height: 1.05;
    margin: 0 0 1.25rem 0; letter-spacing: -.02em;
}
.goatrip-hero-title span { color: var(--goatrip-primary); }
.goatrip-hero-subtitle {
    font-size: clamp(1.05rem, 1.4vw, 1.25rem);
    color: rgba(245,230,181,.85); max-width: 640px;
    margin: 0 auto 2rem auto; line-height: 1.6;
}
.goatrip-hero-trust {
    list-style: none; padding: 0; margin: 2.5rem 0 0 0;
    display: flex; gap: 1.5rem; justify-content: center; flex-wrap: wrap;
    color: rgba(245,230,181,.75); font-size: .9rem;
}
.goatrip-hero-trust li { display: inline-flex; align-items: center; gap: .4rem; }
.goatrip-hero-trust .goatrip-icon { color: var(--goatrip-primary); width: 16px; height: 16px; }

/* Stats */
.goatrip-stats-grid {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
}
@media (max-width: 768px) { .goatrip-stats-grid { grid-template-columns: repeat(2, 1fr); } }
.goatrip-stat-card {
    background: var(--goatrip-card); border: 1px solid var(--goatrip-border);
    border-radius: 1rem; padding: 1.75rem 1.25rem; text-align: center;
    transition: transform .25s, border-color .25s;
}
.goatrip-stat-card:hover { transform: translateY(-2px); border-color: rgba(212,175,55,.4); }
.goatrip-stat-icon {
    width: 48px; height: 48px; margin: 0 auto 1rem auto;
    border-radius: 50%; background: rgba(212,175,55,.1);
    color: var(--goatrip-primary);
    display: flex; align-items: center; justify-content: center;
}
.goatrip-stat-icon svg { width: 24px; height: 24px; }
.goatrip-stat-value {
    font-family: 'Playfair Display', serif;
    font-size: 2.25rem; font-weight: 700; color: var(--goatrip-primary);
    line-height: 1; margin-bottom: .35rem;
}
.goatrip-stat-label { color: rgba(245,230,181,.75); font-size: .9rem; }

/* Form helpers */
.goatrip-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1rem; }
@media (max-width: 600px) { .goatrip-form-row { grid-template-columns: 1fr; } }
.goatrip-field { display: flex; flex-direction: column; gap: .4rem; margin-bottom: 1rem; }
.goatrip-field label { font-size: .85rem; color: rgba(245,230,181,.85); font-weight: 500; }
.goatrip-form-note {
    margin-top: 1rem; font-size: .85rem; color: rgba(245,230,181,.6);
    display: flex; align-items: center; gap: .5rem;
}
.goatrip-form-note .goatrip-icon { color: var(--goatrip-primary); width: 14px; height: 14px; flex-shrink: 0; }

/* Inquiry card */
.goatrip-inquiry-card {
    background: var(--goatrip-card); border: 1px solid var(--goatrip-border);
    border-radius: 1.25rem; padding: 2rem;
}
.goatrip-inquiry-head { margin-bottom: 1.5rem; }
.goatrip-inquiry-head h3 { font-size: 1.5rem; margin: 0 0 .5rem 0; }
.goatrip-inquiry-head p { color: rgba(245,230,181,.7); margin: 0; font-size: .95rem; }

/* Newsletter card */
.goatrip-newsletter-card {
    background: linear-gradient(135deg, rgba(212,175,55,.1), rgba(212,175,55,.02));
    border: 1px solid rgba(212,175,55,.2);
    border-radius: 1.5rem; padding: 3rem 2rem;
    display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; align-items: center;
}
@media (max-width: 768px) { .goatrip-newsletter-card { grid-template-columns: 1fr; padding: 2rem 1.5rem; } }
.goatrip-newsletter-card h2 { font-size: 1.75rem; margin: 0 0 .5rem 0; }
.goatrip-newsletter-card p { margin: 0; color: rgba(245,230,181,.75); }
.goatrip-newsletter-form { position: relative; }

/* Feature list */
.goatrip-feature-list {
    list-style: none; padding: 0; margin: 0 0 1.25rem 0;
    display: flex; flex-direction: column; gap: .55rem;
}
.goatrip-feature-list li {
    display: flex; align-items: center; gap: .55rem;
    color: rgba(245,230,181,.85); font-size: .9rem;
}
.goatrip-feature-list .goatrip-icon { color: var(--goatrip-primary); width: 16px; height: 16px; flex-shrink: 0; }

/* Grid 3 cols */
.goatrip-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
@media (max-width: 900px) { .goatrip-grid-3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .goatrip-grid-3 { grid-template-columns: 1fr; } }

/* CTA card */
.goatrip-section-cta { background: linear-gradient(135deg, rgba(212,175,55,.08), rgba(11,11,11,1) 60%); }
.goatrip-cta-card {
    text-align: center; padding: 4rem 2rem;
    border: 1px solid rgba(212,175,55,.3);
    border-radius: 1.5rem;
    background: linear-gradient(135deg, rgba(212,175,55,.12), rgba(11,11,11,.6));
}
.goatrip-cta-card h2 {
    font-family: 'Playfair Display', serif;
    font-size: clamp(2rem, 4vw, 3rem); margin: 0 0 1rem 0;
}
.goatrip-cta-card p { font-size: 1.1rem; color: rgba(245,230,181,.8); margin: 0 0 2rem 0; }
.goatrip-cta-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* Contact page */
.goatrip-contact-grid {
    display: grid; grid-template-columns: 1.4fr 1fr; gap: 3rem; align-items: start;
}
@media (max-width: 1024px) { .goatrip-contact-grid { grid-template-columns: 1fr; } }
.goatrip-contact-cards {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem;
    margin-top: 1.5rem;
}
@media (max-width: 600px) { .goatrip-contact-cards { grid-template-columns: 1fr; } }
.goatrip-contact-card {
    display: flex; gap: 1rem; align-items: flex-start;
    padding: 1.25rem; border: 1px solid var(--goatrip-border);
    border-radius: 1rem; background: var(--goatrip-card);
    color: inherit; text-decoration: none;
    transition: border-color .25s, transform .25s;
}
.goatrip-contact-card:hover { border-color: rgba(212,175,55,.5); transform: translateY(-2px); }
.goatrip-contact-card-wa:hover { border-color: var(--goatrip-whatsapp); }
.goatrip-contact-card strong { display: block; font-size: 1rem; margin-bottom: .15rem; }
.goatrip-contact-card span { display: block; color: rgba(245,230,181,.85); font-size: .9rem; margin-bottom: .15rem; }
.goatrip-contact-card small { color: rgba(245,230,181,.55); font-size: .75rem; }
.goatrip-contact-icon {
    width: 44px; height: 44px; flex-shrink: 0;
    background: rgba(212,175,55,.1); color: var(--goatrip-primary);
    border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
}
.goatrip-contact-icon svg { width: 22px; height: 22px; }
.goatrip-contact-card-wa .goatrip-contact-icon { background: rgba(37,211,102,.1); color: var(--goatrip-whatsapp); }
.goatrip-map-wrap {
    margin-top: 1.5rem; height: 320px;
    border-radius: 1rem; overflow: hidden;
    border: 1px solid var(--goatrip-border);
}

/* Single page extras */
.goatrip-content-narrow { max-width: 760px; margin: 0 auto; }
.goatrip-page-content { color: rgba(245,230,181,.9); line-height: 1.75; }
.goatrip-page-content h2, .goatrip-page-content h3, .goatrip-page-content h4 { color: var(--goatrip-foreground); margin-top: 1.75em; }
.goatrip-page-content a { color: var(--goatrip-primary); text-decoration: underline; text-underline-offset: 3px; }
.goatrip-page-content blockquote {
    border-left: 3px solid var(--goatrip-primary);
    padding-left: 1.25rem; margin: 1.5rem 0;
    font-style: italic; color: rgba(245,230,181,.8);
}
.goatrip-page-content img { border-radius: .75rem; }
.goatrip-page-links { margin-top: 1.5rem; padding-top: 1rem; border-top: 1px solid var(--goatrip-border); }

.goatrip-breadcrumb { color: rgba(245,230,181,.6); font-size: .85rem; margin-bottom: 1rem; display: flex; gap: .4rem; flex-wrap: wrap; align-items: center; }
.goatrip-breadcrumb a { color: rgba(245,230,181,.7); text-decoration: none; }
.goatrip-breadcrumb a:hover { color: var(--goatrip-primary); }
.goatrip-breadcrumb span:not(:last-child) { color: rgba(245,230,181,.4); }

.goatrip-page-hero-meta {
    display: flex; gap: 1.25rem; flex-wrap: wrap; justify-content: center;
    margin-top: 1rem; color: rgba(245,230,181,.85); font-size: .95rem;
}
.goatrip-page-hero-meta span { display: inline-flex; align-items: center; gap: .35rem; }
.goatrip-page-hero-meta .goatrip-icon { color: var(--goatrip-primary); width: 16px; height: 16px; }
.goatrip-post-meta { display: inline-flex; gap: .5rem; align-items: center; color: rgba(245,230,181,.7); margin-top: 1rem; }

/* Highlights / Inclusions / Gallery */
.goatrip-highlights, .goatrip-inclusions, .goatrip-gallery { margin: 2.5rem 0; }
.goatrip-highlights h2, .goatrip-inclusions h2, .goatrip-gallery h2 { font-size: 1.5rem; margin-bottom: 1rem; }
.goatrip-inclusions-grid {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: .75rem;
}
@media (max-width: 600px) { .goatrip-inclusions-grid { grid-template-columns: 1fr; } }
.goatrip-inclusion-item {
    display: flex; gap: .65rem; align-items: flex-start;
    padding: .75rem 1rem;
    background: rgba(212,175,55,.04);
    border: 1px solid rgba(212,175,55,.15);
    border-radius: .65rem;
    color: rgba(245,230,181,.9);
}
.goatrip-inclusion-item .goatrip-icon { color: var(--goatrip-primary); width: 18px; height: 18px; flex-shrink: 0; margin-top: 2px; }

.goatrip-gallery-item { display: block; border-radius: .75rem; overflow: hidden; aspect-ratio: 4/3; }
.goatrip-gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s; }
.goatrip-gallery-item:hover img { transform: scale(1.06); }

/* Booking sidebar extras */
.goatrip-booking-price { text-align: center; }
.goatrip-booking-price .goatrip-price { font-size: 2rem; }
.goatrip-booking-trust { color: rgba(245,230,181,.65); font-size: .8rem; text-align: center; margin-top: .75rem; display: inline-flex; align-items: center; gap: .35rem; width: 100%; justify-content: center; }
.goatrip-booking-trust .goatrip-icon { color: var(--goatrip-primary); width: 14px; height: 14px; }
.goatrip-savings { display: block; color: var(--goatrip-whatsapp); font-size: .85rem; font-weight: 600; margin-top: .25rem; }
.goatrip-mini-inquiry { margin-top: 1.5rem; }

/* Empty states */
.goatrip-empty { text-align: center; padding: 4rem 1rem; }
.goatrip-empty h2 { font-size: 1.5rem; margin-bottom: .5rem; }
.goatrip-empty p { color: rgba(245,230,181,.7); margin-bottom: 1.5rem; }
.goatrip-empty-mini { text-align: center; color: rgba(245,230,181,.6); padding: 2rem; }

/* Search */
.goatrip-search-form { display: flex; gap: .5rem; }
.goatrip-search-input {
    flex: 1; padding: .85rem 1rem;
    background: var(--goatrip-card); border: 1px solid var(--goatrip-border);
    border-radius: .65rem; color: var(--goatrip-foreground);
    font-family: inherit; font-size: 1rem;
}
.goatrip-search-input:focus { outline: none; border-color: var(--goatrip-primary); box-shadow: 0 0 0 3px rgba(212,175,55,.15); }
.goatrip-search-submit { padding: .85rem 1.25rem; }
.goatrip-search-list { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
.goatrip-search-item {
    padding: 1.5rem; border: 1px solid var(--goatrip-border);
    border-radius: 1rem; background: var(--goatrip-card);
}
.goatrip-search-item h3 { margin: 0 0 .5rem 0; }
.goatrip-search-item h3 a { color: var(--goatrip-foreground); }
.goatrip-search-item h3 a:hover { color: var(--goatrip-primary); }
.goatrip-search-meta { color: rgba(245,230,181,.55); font-size: .85rem; margin: 0 0 .75rem 0; }

/* Comments */
.goatrip-comments-title { font-size: 1.5rem; margin-bottom: 1.5rem; }
.goatrip-comments-list { list-style: none; padding: 0; }
.goatrip-comments-closed { color: rgba(245,230,181,.6); font-style: italic; }

/* Archive desc */
.goatrip-archive-desc { color: rgba(245,230,181,.85); max-width: 640px; margin: 0 auto; }

/* Elementor widget wrapper */
.goatrip-elementor-grid { padding: 1rem 0; }

/* Section spacing on Elementor pages reduced */
.elementor-page-active .goatrip-section { padding: 0; }

/* ============================================================
   v1.1.0 — CONVERSION UI
   ============================================================ */

/* ----- Booking Modal ----- */
.goatrip-modal {
    position: fixed; inset: 0;
    z-index: 9999;
    display: none;
    align-items: center; justify-content: center;
    padding: 1rem;
}
.goatrip-modal.is-open { display: flex; }
body.goatrip-modal-open { overflow: hidden; }
.goatrip-modal-backdrop {
    position: absolute; inset: 0;
    background: rgba(0, 0, 0, .75);
    backdrop-filter: blur(6px);
}
.goatrip-modal-dialog {
    position: relative;
    width: 100%; max-width: 540px; max-height: 92vh;
    overflow-y: auto;
    background: linear-gradient(180deg, #1a1a1a, #0e0e0e);
    border: 1px solid rgba(212, 175, 55, .3);
    border-radius: 1.25rem;
    box-shadow: 0 30px 80px rgba(0, 0, 0, .8), 0 0 0 1px rgba(212, 175, 55, .15);
    padding: 1.75rem;
    animation: goatrip-modal-in .35s cubic-bezier(.2, .9, .3, 1.2);
}
@keyframes goatrip-modal-in {
    from { opacity: 0; transform: translateY(24px) scale(.96); }
    to   { opacity: 1; transform: none; }
}
.goatrip-modal-close {
    position: absolute; top: 14px; right: 14px;
    width: 36px; height: 36px;
    border: none; border-radius: 50%;
    background: rgba(255, 255, 255, .08);
    color: var(--goatrip-foreground);
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: background .2s, transform .2s;
}
.goatrip-modal-close:hover { background: rgba(212, 175, 55, .25); transform: rotate(90deg); }
.goatrip-modal-close svg { width: 18px; height: 18px; }

.goatrip-modal-head { margin-bottom: 1.25rem; }
.goatrip-modal-eyebrow {
    display: inline-flex; align-items: center; gap: .35rem;
    padding: .35rem .75rem;
    background: rgba(37, 211, 102, .12);
    border: 1px solid rgba(37, 211, 102, .3);
    border-radius: 999px;
    font-size: .75rem; font-weight: 600;
    color: var(--goatrip-whatsapp);
    margin-bottom: 1rem;
}
.goatrip-modal-eyebrow svg { width: 14px; height: 14px; }
.goatrip-modal-head h3 {
    font-family: 'Playfair Display', serif;
    font-size: 1.65rem; margin: 0 0 .35rem 0;
    color: var(--goatrip-foreground);
}
.goatrip-modal-head p { margin: 0; color: rgba(245, 230, 181, .7); font-size: .92rem; }

.goatrip-modal-form { margin-top: .25rem; }

.goatrip-field-pax { grid-column: span 2; }
@media (min-width: 600px) { .goatrip-field-pax { grid-column: auto; } }
.goatrip-pax-pair { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
.goatrip-pax-col label { font-size: .85rem; color: rgba(245, 230, 181, .85); display: block; margin-bottom: .35rem; }

.goatrip-stepper {
    display: grid; grid-template-columns: 36px 1fr 36px;
    background: var(--goatrip-card);
    border: 1px solid var(--goatrip-border);
    border-radius: .55rem;
    overflow: hidden;
}
.goatrip-stepper-btn {
    background: rgba(212, 175, 55, .08);
    color: var(--goatrip-primary);
    border: none; cursor: pointer;
    font-size: 1.25rem; font-weight: 700;
    transition: background .2s;
}
.goatrip-stepper-btn:hover { background: rgba(212, 175, 55, .2); }
.goatrip-stepper input {
    border: none !important; background: transparent !important;
    text-align: center; padding: .65rem 0 !important;
    color: var(--goatrip-foreground);
    font-weight: 600;
    -moz-appearance: textfield;
}
.goatrip-stepper input::-webkit-outer-spin-button,
.goatrip-stepper input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.goatrip-stepper input:focus { box-shadow: none !important; outline: none !important; }

.goatrip-modal-footer {
    display: flex; align-items: center; gap: 1rem;
    margin-top: 1.25rem;
}
.goatrip-modal-pricing {
    flex-shrink: 0;
    padding-right: 1rem;
    border-right: 1px solid var(--goatrip-border);
}
.goatrip-modal-pricing small {
    display: block;
    color: rgba(245, 230, 181, .55);
    font-size: .7rem; text-transform: uppercase; letter-spacing: .05em;
}
.goatrip-modal-pricing strong {
    color: var(--goatrip-primary);
    font-size: 1.35rem; font-weight: 700;
}
.goatrip-modal-footer .goatrip-btn { flex: 1; }

.goatrip-modal-trust {
    list-style: none; padding: 1rem 0 0 0; margin: 1rem 0 0 0;
    border-top: 1px solid var(--goatrip-border);
    display: flex; gap: 1rem; flex-wrap: wrap;
    color: rgba(245, 230, 181, .7); font-size: .8rem;
}
.goatrip-modal-trust li { display: inline-flex; align-items: center; gap: .35rem; }
.goatrip-modal-trust .goatrip-icon { color: var(--goatrip-primary); width: 14px; height: 14px; }

@media (max-width: 480px) {
    .goatrip-modal-dialog { padding: 1.25rem; border-radius: 1rem; max-height: 96vh; }
    .goatrip-modal-head h3 { font-size: 1.4rem; }
    .goatrip-modal-footer { flex-direction: column; align-items: stretch; }
    .goatrip-modal-pricing { border-right: none; border-bottom: 1px solid var(--goatrip-border); padding: 0 0 .75rem 0; }
}

/* ----- Urgency Badges ----- */
.goatrip-urgency {
    display: inline-flex; align-items: center; gap: .35rem;
    padding: .35rem .65rem;
    border-radius: 999px;
    font-size: .72rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: .04em;
    position: relative;
}
.goatrip-urgency-pulse {
    width: 6px; height: 6px; border-radius: 50%;
    flex-shrink: 0;
    animation: goatrip-pulse 1.6s ease-out infinite;
}
@keyframes goatrip-pulse {
    0%   { box-shadow: 0 0 0 0 currentColor; opacity: 1; }
    70%  { box-shadow: 0 0 0 8px transparent; opacity: .5; }
    100% { box-shadow: 0 0 0 0 transparent; opacity: 1; }
}
.goatrip-urgency-hot     { background: rgba(255, 68, 68, .12); color: #ff5e5e; border: 1px solid rgba(255, 68, 68, .35); }
.goatrip-urgency-hot     .goatrip-urgency-pulse { background: #ff5e5e; }
.goatrip-urgency-limited { background: rgba(255, 152, 0, .12); color: #ffb74d; border: 1px solid rgba(255, 152, 0, .35); }
.goatrip-urgency-limited .goatrip-urgency-pulse { background: #ffb74d; }
.goatrip-urgency-fast    { background: rgba(212, 175, 55, .12); color: var(--goatrip-primary); border: 1px solid rgba(212, 175, 55, .35); }
.goatrip-urgency-fast    .goatrip-urgency-pulse { background: var(--goatrip-primary); }
.goatrip-urgency-new     { background: rgba(37, 211, 102, .12); color: var(--goatrip-whatsapp); border: 1px solid rgba(37, 211, 102, .35); }
.goatrip-urgency-new     .goatrip-urgency-pulse { background: var(--goatrip-whatsapp); }

/* ----- Strike-through pricing & discount tag ----- */
.goatrip-strike-row {
    display: inline-flex; align-items: center; gap: .5rem;
    margin-top: .25rem;
    flex-wrap: wrap;
}
.goatrip-strike {
    color: rgba(245, 230, 181, .45);
    font-size: .85rem; font-weight: 500;
    text-decoration: line-through;
    text-decoration-color: rgba(212, 175, 55, .5);
    text-decoration-thickness: 2px;
}
.goatrip-discount-tag {
    background: linear-gradient(135deg, #ff5e5e, #ff8e53);
    color: #fff;
    padding: .15rem .5rem;
    border-radius: .35rem;
    font-size: .7rem; font-weight: 800;
    letter-spacing: .03em;
    box-shadow: 0 2px 8px rgba(255, 94, 94, .3);
}

/* "Starting from" label emphasis */
.goatrip-price-block .goatrip-price-label {
    color: rgba(245, 230, 181, .55);
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    font-weight: 600;
}
.goatrip-card-foot .goatrip-price {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--goatrip-primary);
    line-height: 1;
    font-family: 'Playfair Display', serif;
}

/* ----- Trust bar ----- */
.goatrip-trust-bar {
    background: linear-gradient(180deg, rgba(212, 175, 55, .04), transparent);
    border-bottom: 1px solid var(--goatrip-border);
    padding: 1.25rem 0;
}
.goatrip-trust-list {
    list-style: none; padding: 0; margin: 0;
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
}
@media (max-width: 900px) { .goatrip-trust-list { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .goatrip-trust-list { grid-template-columns: 1fr 1fr; gap: .75rem; } }
.goatrip-trust-item {
    display: flex; gap: .65rem; align-items: center;
    padding: .35rem 0;
}
.goatrip-trust-icon {
    flex-shrink: 0;
    width: 40px; height: 40px; border-radius: 50%;
    background: rgba(212, 175, 55, .1);
    color: var(--goatrip-primary);
    display: flex; align-items: center; justify-content: center;
}
.goatrip-trust-icon svg { width: 20px; height: 20px; }
.goatrip-trust-text { display: flex; flex-direction: column; line-height: 1.2; }
.goatrip-trust-text strong { color: var(--goatrip-foreground); font-size: .95rem; font-weight: 700; }
.goatrip-trust-text small { color: rgba(245, 230, 181, .6); font-size: .75rem; margin-top: .15rem; }
@media (max-width: 480px) {
    .goatrip-trust-icon { width: 32px; height: 32px; }
    .goatrip-trust-icon svg { width: 16px; height: 16px; }
    .goatrip-trust-text strong { font-size: .8rem; }
    .goatrip-trust-text small { font-size: .65rem; }
}

/* ----- Social-proof line ----- */
.goatrip-social-proof {
    display: inline-flex; align-items: center; gap: .35rem;
    padding: .35rem .65rem;
    background: rgba(37, 211, 102, .08);
    border: 1px solid rgba(37, 211, 102, .25);
    border-radius: .45rem;
    font-size: .75rem;
    color: var(--goatrip-whatsapp);
    margin-top: .65rem;
}
.goatrip-social-proof::before {
    content: '';
    width: 6px; height: 6px;
    background: var(--goatrip-whatsapp);
    border-radius: 50%;
    animation: goatrip-pulse 1.6s ease-out infinite;
}

/* ----- Card row tweaks for v1.1 ----- */
.goatrip-card-meta-top {
    display: flex; gap: .5rem; flex-wrap: wrap;
    align-items: center;
    margin-bottom: .75rem;
}
.goatrip-card-actions .goatrip-btn { flex: 1; min-width: 0; }

/* Make "Book" button visually dominant */
.goatrip-btn-whatsapp { font-weight: 700; }

/* Booking card sidebar — strike-row position */
.goatrip-booking-card .goatrip-strike-row { justify-content: center; margin-top: .5rem; }
.goatrip-booking-card .goatrip-urgency { display: inline-flex; margin-top: .75rem; }

/* Mobile bottom CTA — make it pulse a bit */
@media (max-width: 768px) {
    .goatrip-mobile-cta .goatrip-btn-whatsapp { animation: goatrip-cta-pulse 2.5s ease-in-out infinite; }
}
@keyframes goatrip-cta-pulse {
    0%, 100% { box-shadow: 0 4px 18px rgba(37, 211, 102, .35); }
    50%      { box-shadow: 0 4px 24px rgba(37, 211, 102, .65); }
}

/* WhatsApp FAB pulse ring */
.goatrip-whatsapp-fab { position: relative; }
.goatrip-whatsapp-fab::before {
    content: '';
    position: absolute; inset: -4px;
    border-radius: 50%;
    border: 2px solid var(--goatrip-whatsapp);
    animation: goatrip-fab-ring 1.8s ease-out infinite;
    pointer-events: none;
}
@keyframes goatrip-fab-ring {
    0%   { transform: scale(.85); opacity: .9; }
    80%  { transform: scale(1.4);  opacity: 0; }
    100% { transform: scale(1.4);  opacity: 0; }
}

/* ============================================================
   v2.0.0 — PLATFORM EDITION
   ============================================================ */

/* ----- SEO landing-page hero ----- */
.goatrip-seo-hero {
    padding: 5.5rem 0 4rem 0;
    text-align: center;
}
.goatrip-seo-hero h1 {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.85rem, 5vw, 3.4rem);
    line-height: 1.15;
    margin: 1rem 0 1.25rem 0;
    color: var(--goatrip-foreground);
    max-width: 22ch;
    margin-left: auto;
    margin-right: auto;
}
.goatrip-seo-hero p {
    color: rgba(245, 230, 181, .8);
    font-size: 1.05rem;
    line-height: 1.65;
    max-width: 56ch;
    margin: 0 auto;
}
.goatrip-seo-content { padding: 3.5rem 0; }
.goatrip-content-narrow { max-width: 760px; margin: 0 auto; }
.goatrip-page-content h2 {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.5rem, 3vw, 2.1rem);
    margin: 2.75rem 0 1rem 0;
    color: var(--goatrip-foreground);
    border-left: 3px solid var(--goatrip-primary);
    padding-left: 1rem;
}
.goatrip-page-content p,
.goatrip-page-content li {
    color: rgba(245, 230, 181, .82);
    font-size: 1.02rem;
    line-height: 1.8;
}
.goatrip-page-content p { margin: 0 0 1.15rem 0; }
.goatrip-page-content ul,
.goatrip-page-content ol { margin: 0 0 1.25rem 1.25rem; padding-left: .75rem; }
.goatrip-page-content li { margin-bottom: .55rem; }
.goatrip-page-content strong { color: var(--goatrip-foreground); font-weight: 700; }
.goatrip-page-content em { color: var(--goatrip-primary); font-style: italic; }

/* ----- Pricing Table ----- */
.goatrip-pricing-table-wrap {
    overflow-x: auto;
    border-radius: 1rem;
    border: 1px solid var(--goatrip-border);
    background: var(--goatrip-card);
    -webkit-overflow-scrolling: touch;
}
.goatrip-pricing-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .95rem;
    min-width: 640px;
}
.goatrip-pricing-table thead {
    background: linear-gradient(180deg, rgba(212, 175, 55, .12), rgba(212, 175, 55, .04));
    border-bottom: 2px solid var(--goatrip-primary);
}
.goatrip-pricing-table th {
    padding: 1rem 1.25rem;
    text-align: left;
    color: var(--goatrip-primary);
    font-weight: 700;
    text-transform: uppercase;
    font-size: .78rem;
    letter-spacing: .05em;
    white-space: nowrap;
}
.goatrip-pricing-table td {
    padding: .9rem 1.25rem;
    color: rgba(245, 230, 181, .85);
    border-bottom: 1px solid rgba(212, 175, 55, .08);
}
.goatrip-pricing-table tbody tr:nth-child(even) { background: rgba(212, 175, 55, .03); }
.goatrip-pricing-table tbody tr:hover { background: rgba(212, 175, 55, .08); }
.goatrip-pricing-table tbody tr:last-child td { border-bottom: none; }
.goatrip-pricing-table td:nth-child(3) { color: var(--goatrip-primary); font-weight: 600; white-space: nowrap; }

/* ----- FAQ Accordion ----- */
.goatrip-faq-list { display: flex; flex-direction: column; gap: .75rem; }
.goatrip-faq-item {
    background: var(--goatrip-card);
    border: 1px solid var(--goatrip-border);
    border-radius: .75rem;
    overflow: hidden;
    transition: border-color .2s, box-shadow .2s;
}
.goatrip-faq-item[open] {
    border-color: rgba(212, 175, 55, .4);
    box-shadow: 0 4px 18px rgba(0, 0, 0, .15);
}
.goatrip-faq-item summary {
    list-style: none;
    cursor: pointer;
    padding: 1.1rem 1.25rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    color: var(--goatrip-foreground);
    font-weight: 600;
    font-size: 1.02rem;
    user-select: none;
}
.goatrip-faq-item summary::-webkit-details-marker { display: none; }
.goatrip-faq-item summary:hover { color: var(--goatrip-primary); }
.goatrip-faq-toggle {
    flex-shrink: 0;
    width: 28px; height: 28px;
    border-radius: 50%;
    background: rgba(212, 175, 55, .12);
    color: var(--goatrip-primary);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.4rem; line-height: 1; font-weight: 300;
    transition: transform .25s, background .2s;
}
.goatrip-faq-item[open] .goatrip-faq-toggle { transform: rotate(45deg); background: var(--goatrip-primary); color: #0a0a0a; }
.goatrip-faq-answer {
    padding: 0 1.25rem 1.1rem 1.25rem;
    color: rgba(245, 230, 181, .78);
    line-height: 1.7;
    font-size: .96rem;
}
.goatrip-faq-answer p { margin: 0; }

/* ----- Related cards (internal-link grid) ----- */
.goatrip-related-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}
@media (max-width: 900px) { .goatrip-related-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .goatrip-related-grid { grid-template-columns: 1fr; } }
.goatrip-related-card {
    background: var(--goatrip-card);
    border: 1px solid var(--goatrip-border);
    border-radius: .85rem;
    padding: 1.1rem 1.25rem;
    text-decoration: none;
    transition: transform .2s, border-color .2s, background .2s;
    display: flex;
    flex-direction: column;
    gap: .25rem;
    position: relative;
}
.goatrip-related-card:hover {
    transform: translateY(-2px);
    border-color: var(--goatrip-primary);
    background: rgba(212, 175, 55, .04);
}
.goatrip-related-card strong {
    color: var(--goatrip-foreground);
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.3;
}
.goatrip-related-card span {
    color: rgba(245, 230, 181, .6);
    font-size: .85rem;
}
.goatrip-related-card .goatrip-icon {
    position: absolute;
    top: 1.1rem; right: 1.1rem;
    color: var(--goatrip-primary);
    width: 16px; height: 16px;
    opacity: .5;
    transition: opacity .2s, transform .2s;
}
.goatrip-related-card:hover .goatrip-icon { opacity: 1; transform: translateX(3px); }

/* ----- Search & Filter Bar ----- */
.goatrip-search-filter {
    background: var(--goatrip-card);
    border: 1px solid var(--goatrip-border);
    border-radius: 1rem;
    padding: 1.25rem;
    margin-bottom: 2rem;
    box-shadow: 0 4px 18px rgba(0, 0, 0, .08);
}
.goatrip-filter-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr auto;
    gap: .75rem;
    align-items: end;
}
@media (max-width: 900px) { .goatrip-filter-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .goatrip-filter-grid { grid-template-columns: 1fr; } }
.goatrip-filter-grid .goatrip-field { margin: 0; }
.goatrip-filter-grid label {
    display: block;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: rgba(245, 230, 181, .6);
    margin-bottom: .35rem;
    font-weight: 600;
}
.goatrip-filter-grid input,
.goatrip-filter-grid select {
    width: 100%;
    padding: .65rem .85rem;
    background: var(--goatrip-bg);
    border: 1px solid var(--goatrip-border);
    border-radius: .5rem;
    color: var(--goatrip-foreground);
    font-size: .95rem;
}
.goatrip-filter-grid input:focus,
.goatrip-filter-grid select:focus {
    outline: none;
    border-color: var(--goatrip-primary);
    box-shadow: 0 0 0 3px rgba(212, 175, 55, .15);
}
.goatrip-filter-input-group { position: relative; }
.goatrip-filter-input-group .goatrip-icon {
    position: absolute;
    left: .75rem; top: 50%;
    transform: translateY(calc(-50% + 11px));
    color: var(--goatrip-primary);
    width: 18px; height: 18px;
    pointer-events: none;
}
.goatrip-filter-input-group input { padding-left: 2.4rem; }
.goatrip-filter-actions {
    display: flex;
    gap: .5rem;
    align-items: end;
}
.goatrip-filter-clear {
    background: transparent;
    border: 1px solid var(--goatrip-border);
    color: rgba(245, 230, 181, .6);
    padding: .65rem 1rem;
    border-radius: .5rem;
    cursor: pointer;
    font-size: .9rem;
    transition: color .2s, border-color .2s;
}
.goatrip-filter-clear:hover { color: var(--goatrip-foreground); border-color: var(--goatrip-primary); }
.goatrip-filter-results-count {
    margin: 0 0 1rem 0;
    color: rgba(245, 230, 181, .65);
    font-size: .9rem;
}

/* ----- Mega navigation (8 category pills below nav) ----- */
.goatrip-mega-nav {
    background: rgba(11, 11, 11, .85);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--goatrip-border);
    padding: .65rem 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
}
.goatrip-mega-nav::-webkit-scrollbar { height: 4px; }
.goatrip-mega-nav::-webkit-scrollbar-thumb { background: rgba(212, 175, 55, .25); border-radius: 4px; }
.goatrip-mega-nav-list {
    list-style: none;
    margin: 0; padding: 0;
    display: flex;
    gap: .5rem;
    white-space: nowrap;
}
.goatrip-mega-nav-list li { flex-shrink: 0; }
.goatrip-mega-nav-list a {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .55rem 1rem;
    border-radius: 999px;
    color: rgba(245, 230, 181, .75);
    text-decoration: none;
    font-size: .92rem;
    font-weight: 500;
    border: 1px solid transparent;
    transition: background .2s, color .2s, border-color .2s;
}
.goatrip-mega-nav-list a:hover {
    background: rgba(212, 175, 55, .08);
    color: var(--goatrip-primary);
    border-color: rgba(212, 175, 55, .25);
}
.goatrip-mega-nav-list .goatrip-icon { width: 14px; height: 14px; }

/* ----- Empty mini ----- */
.goatrip-empty-mini {
    text-align: center;
    color: rgba(245, 230, 181, .55);
    font-size: .95rem;
    padding: 2rem 1rem;
    border: 1px dashed var(--goatrip-border);
    border-radius: .75rem;
}

/* ----- Performance: print-only / reduced-motion ----- */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
    }
}

/* ============================================================
   v2.1.0 — PREMIUM EDITION
   Refined visual polish — Airbnb / Apple grade.
   ============================================================ */

/* ----- Premium card refinement ----- */
.goatrip-card {
    position: relative;
    overflow: hidden;
    background: linear-gradient(180deg, #1a1a1a 0%, #0e0e0e 100%);
    border: 1px solid rgba(245, 230, 181, .07);
    border-radius: 1.1rem;
    transition: transform .45s cubic-bezier(.2, .9, .3, 1), border-color .35s, box-shadow .45s;
    box-shadow:
        0 1px 2px rgba(0, 0, 0, .15),
        0 4px 14px rgba(0, 0, 0, .15);
}
.goatrip-card:hover {
    transform: translateY(-6px);
    border-color: rgba(212, 175, 55, .35);
    box-shadow:
        0 1px 2px rgba(0, 0, 0, .15),
        0 24px 60px rgba(0, 0, 0, .35),
        0 0 0 1px rgba(212, 175, 55, .15) inset;
}

/* Card media — premium image-zoom + gradient overlay reveal */
.goatrip-card-media {
    position: relative;
    overflow: hidden;
    border-radius: 1.1rem 1.1rem 0 0;
    aspect-ratio: 16/10;
    background: #0a0a0a;
}
.goatrip-card-media::after {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 40%, rgba(0, 0, 0, .55) 100%);
    opacity: .6;
    transition: opacity .45s;
    pointer-events: none;
}
.goatrip-card:hover .goatrip-card-media::after { opacity: .9; }
.goatrip-card-media img,
.goatrip-card-media .wp-post-image {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .8s cubic-bezier(.2, .9, .3, 1), filter .6s;
    filter: saturate(.95) brightness(.96);
}
.goatrip-card:hover .goatrip-card-media img,
.goatrip-card:hover .goatrip-card-media .wp-post-image {
    transform: scale(1.07);
    filter: saturate(1.1) brightness(1);
}

/* Card title underline reveal on hover */
.goatrip-card h3 a {
    position: relative;
    background-image: linear-gradient(to right, var(--goatrip-primary), var(--goatrip-primary));
    background-position: 0 100%;
    background-repeat: no-repeat;
    background-size: 0% 1.5px;
    padding-bottom: 2px;
    transition: background-size .45s cubic-bezier(.2, .9, .3, 1);
}
.goatrip-card:hover h3 a { background-size: 100% 1.5px; }

/* Premium price block glow on hover */
.goatrip-card:hover .goatrip-price {
    text-shadow: 0 0 24px rgba(212, 175, 55, .25);
}

/* Refined badge — softer */
.goatrip-card-badge {
    backdrop-filter: blur(8px);
    background: rgba(212, 175, 55, .92);
    color: #0a0a0a;
    font-weight: 700;
    letter-spacing: .03em;
    box-shadow: 0 4px 12px rgba(212, 175, 55, .35);
}

/* ----- Premium hero refinement ----- */
.goatrip-page-hero,
.goatrip-seo-hero,
#goatrip-hero {
    position: relative;
    overflow: hidden;
}
.goatrip-page-hero::before,
.goatrip-seo-hero::before,
#goatrip-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 50% 30%, rgba(212, 175, 55, .12), transparent 55%);
    pointer-events: none;
    opacity: 0;
    animation: goatrip-hero-glow 3.5s ease-out .3s forwards;
}
@keyframes goatrip-hero-glow {
    to { opacity: 1; }
}
/* Subtle floating orbs in hero */
.goatrip-page-hero::after,
.goatrip-seo-hero::after,
#goatrip-hero::after {
    content: '';
    position: absolute;
    width: 320px; height: 320px;
    top: -120px; right: -120px;
    background: radial-gradient(circle, rgba(212, 175, 55, .12), transparent 70%);
    border-radius: 50%;
    pointer-events: none;
    animation: goatrip-orb-float 14s ease-in-out infinite;
}
@keyframes goatrip-orb-float {
    0%, 100% { transform: translate(0, 0); }
    50%      { transform: translate(-30px, 40px); }
}

/* Hero H1 enter animation */
.goatrip-page-hero h1,
.goatrip-seo-hero h1,
#goatrip-hero h1 {
    animation: goatrip-fade-up 1.1s cubic-bezier(.2, .9, .3, 1) .1s both;
    background: linear-gradient(180deg, #ffffff 30%, rgba(245, 230, 181, .85));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    letter-spacing: -.02em;
}
.goatrip-page-hero p,
.goatrip-seo-hero p,
#goatrip-hero p {
    animation: goatrip-fade-up 1.1s cubic-bezier(.2, .9, .3, 1) .35s both;
}
@keyframes goatrip-fade-up {
    from { opacity: 0; transform: translateY(28px); }
    to   { opacity: 1; transform: none; }
}

/* Hero pill — frosted glass */
.goatrip-hero-pill {
    backdrop-filter: blur(12px);
    background: rgba(255, 255, 255, .07);
    border: 1px solid rgba(245, 230, 181, .15);
    transition: transform .3s, background .3s;
    animation: goatrip-fade-up 1.1s cubic-bezier(.2, .9, .3, 1) both;
}
.goatrip-hero-pill:hover { transform: translateY(-2px); background: rgba(245, 230, 181, .12); }

/* ----- Premium buttons ----- */
.goatrip-btn {
    position: relative;
    overflow: hidden;
    transition:
        transform .25s cubic-bezier(.2, .9, .3, 1),
        box-shadow .35s,
        background .35s,
        border-color .25s;
    letter-spacing: .005em;
}
.goatrip-btn:active { transform: translateY(1px) scale(.98); }
/* Subtle shimmer on primary buttons */
.goatrip-btn-primary,
.goatrip-btn-whatsapp {
    background-size: 200% auto;
    background-image: linear-gradient(135deg, var(--goatrip-primary) 0%, #e9c468 50%, var(--goatrip-primary) 100%);
    transition: background-position .6s ease, transform .25s, box-shadow .35s;
}
.goatrip-btn-whatsapp {
    background-image: linear-gradient(135deg, var(--goatrip-whatsapp) 0%, #45e57b 50%, var(--goatrip-whatsapp) 100%);
}
.goatrip-btn-primary:hover,
.goatrip-btn-whatsapp:hover {
    background-position: right center;
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(212, 175, 55, .35);
}
.goatrip-btn-whatsapp:hover {
    box-shadow: 0 12px 28px rgba(37, 211, 102, .35);
}

/* Outline button refinement */
.goatrip-btn-outline {
    border-width: 1.5px;
    background: rgba(255, 255, 255, .02);
    backdrop-filter: blur(4px);
}
.goatrip-btn-outline:hover {
    border-color: var(--goatrip-primary);
    background: rgba(212, 175, 55, .08);
    color: var(--goatrip-primary);
}

/* ----- Premium scroll-reveal animation ----- */
.goatrip-reveal {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity .9s cubic-bezier(.2, .9, .3, 1), transform .9s cubic-bezier(.2, .9, .3, 1);
    will-change: opacity, transform;
}
.goatrip-reveal.is-visible {
    opacity: 1;
    transform: none;
}
/* Stagger children */
.goatrip-grid > .goatrip-reveal:nth-child(1) { transition-delay: 0s; }
.goatrip-grid > .goatrip-reveal:nth-child(2) { transition-delay: .08s; }
.goatrip-grid > .goatrip-reveal:nth-child(3) { transition-delay: .16s; }
.goatrip-grid > .goatrip-reveal:nth-child(4) { transition-delay: .24s; }
.goatrip-grid > .goatrip-reveal:nth-child(5) { transition-delay: .32s; }
.goatrip-grid > .goatrip-reveal:nth-child(6) { transition-delay: .40s; }

/* ----- Premium image lazy-load shimmer ----- */
.goatrip-card-media {
    background: linear-gradient(105deg,
        rgba(255, 255, 255, .02) 0%,
        rgba(245, 230, 181, .04) 30%,
        rgba(212, 175, 55, .08) 50%,
        rgba(245, 230, 181, .04) 70%,
        rgba(255, 255, 255, .02) 100%);
    background-size: 200% 100%;
    animation: goatrip-shimmer 2.4s ease-in-out infinite;
}
.goatrip-card-media img.wp-post-image,
.goatrip-card-media img {
    animation: goatrip-fade-in .6s ease-out;
}
@keyframes goatrip-shimmer {
    from { background-position: 200% 0; }
    to   { background-position: -200% 0; }
}
@keyframes goatrip-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* ----- Animated counter ----- */
.goatrip-counter {
    display: inline-block;
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum";
}

/* ----- Premium stats refinement ----- */
.goatrip-stats-section {
    background: linear-gradient(135deg, rgba(212, 175, 55, .03), rgba(245, 230, 181, .02));
    border-top: 1px solid var(--goatrip-border);
    border-bottom: 1px solid var(--goatrip-border);
    position: relative;
}
.goatrip-stat-num {
    background: linear-gradient(180deg, var(--goatrip-primary), #e9c468);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    font-family: 'Playfair Display', serif;
    font-weight: 700;
    letter-spacing: -.02em;
}

/* ----- Premium modal refinement ----- */
.goatrip-modal-dialog {
    background: linear-gradient(180deg, rgba(26, 26, 26, .95), rgba(14, 14, 14, .98));
    backdrop-filter: blur(20px);
    border: 1px solid rgba(245, 230, 181, .12);
    box-shadow:
        0 30px 80px rgba(0, 0, 0, .85),
        0 0 0 1px rgba(212, 175, 55, .08) inset,
        0 0 80px rgba(212, 175, 55, .08);
}

/* ----- Premium form fields — floating-feel ----- */
.goatrip-modal-form .goatrip-field input,
.goatrip-modal-form .goatrip-field select,
.goatrip-modal-form .goatrip-field textarea {
    background: rgba(255, 255, 255, .03);
    border: 1.5px solid rgba(245, 230, 181, .1);
    transition: border-color .25s, background .25s, box-shadow .25s;
}
.goatrip-modal-form .goatrip-field input:focus,
.goatrip-modal-form .goatrip-field select:focus {
    background: rgba(255, 255, 255, .06);
    border-color: var(--goatrip-primary);
    box-shadow: 0 0 0 4px rgba(212, 175, 55, .12);
    outline: none;
}

/* ----- Currency switcher ----- */
.goatrip-currency-switcher {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .35rem .75rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, .04);
    border: 1px solid var(--goatrip-border);
    color: rgba(245, 230, 181, .8);
    font-size: .85rem;
    cursor: pointer;
    transition: background .2s, border-color .2s;
}
.goatrip-currency-switcher:hover {
    background: rgba(212, 175, 55, .08);
    border-color: rgba(212, 175, 55, .3);
}
.goatrip-currency-switcher select {
    background: transparent;
    border: none;
    color: inherit;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    padding-right: 1rem;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="10" height="10" viewBox="0 0 10 10"><path d="M5 7L1 3h8z" fill="%23d4af37"/></svg>');
    background-repeat: no-repeat;
    background-position: right center;
    background-size: 8px;
}

/* ----- Premium link underline animation ----- */
.goatrip-section-head h2 {
    position: relative;
    display: inline-block;
    background: linear-gradient(180deg, #ffffff 30%, rgba(245, 230, 181, .85));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    letter-spacing: -.015em;
}
.goatrip-section-head h2::after {
    content: '';
    display: block;
    width: 48px; height: 3px;
    margin: .85rem auto 0 auto;
    background: linear-gradient(90deg, var(--goatrip-primary), transparent);
    border-radius: 3px;
}

/* ----- Premium typography ----- */
body {
    font-feature-settings: "kern" 1, "liga" 1, "calt" 1;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
h1, h2, h3, h4 {
    letter-spacing: -.015em;
}

/* ----- Premium scrollbar ----- */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: #0a0a0a; }
::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, rgba(212, 175, 55, .3), rgba(212, 175, 55, .15));
    border-radius: 999px;
    border: 2px solid #0a0a0a;
}
::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, var(--goatrip-primary), rgba(212, 175, 55, .5)); }

/* ----- Premium selection ----- */
::selection {
    background: rgba(212, 175, 55, .35);
    color: #fff;
}

/* ----- Card date-range picker (hotel mode) ----- */
.goatrip-modal-form[data-mode="hotel"] .goatrip-field-pax,
.goatrip-modal-form[data-mode="rental"] .goatrip-field-pax {
    grid-column: span 2;
}
.goatrip-mode-pill {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .35rem .75rem;
    background: rgba(212, 175, 55, .12);
    border: 1px solid rgba(212, 175, 55, .3);
    border-radius: 999px;
    color: var(--goatrip-primary);
    font-size: .72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: .75rem;
}

/* ----- Loading state for buttons ----- */
.goatrip-btn.is-loading {
    pointer-events: none;
    opacity: .85;
    color: transparent !important;
}
.goatrip-btn.is-loading::after {
    content: '';
    position: absolute;
    inset: 0;
    margin: auto;
    width: 20px; height: 20px;
    border: 2px solid rgba(0, 0, 0, .25);
    border-top-color: rgba(0, 0, 0, .85);
    border-radius: 50%;
    animation: goatrip-spin .65s linear infinite;
}
@keyframes goatrip-spin { to { transform: rotate(360deg); } }

/* ----- Premium FAB refinement ----- */
.goatrip-whatsapp-fab {
    background: linear-gradient(135deg, var(--goatrip-whatsapp), #1eb755);
    box-shadow:
        0 12px 32px rgba(37, 211, 102, .4),
        0 0 0 0 rgba(37, 211, 102, .4);
    transition: transform .3s, box-shadow .3s;
}
.goatrip-whatsapp-fab:hover {
    transform: scale(1.08);
    box-shadow:
        0 16px 40px rgba(37, 211, 102, .55),
        0 0 0 4px rgba(37, 211, 102, .15);
}

/* ----- Mobile bottom CTA refinement ----- */
@media (max-width: 768px) {
    .goatrip-mobile-cta {
        background: linear-gradient(180deg, rgba(11, 11, 11, .92), rgba(11, 11, 11, .98));
        backdrop-filter: blur(16px);
        border-top: 1px solid rgba(212, 175, 55, .15);
    }
}

/* ============================================================
   v2.2.1 — LUXURY CARD REWORK
   Aman / Belmond / Mr&Mrs Smith aesthetic.
   3-col grid, taller portrait images, frosted-glass details,
   refined Playfair typography, gold-accent dividers.
   ============================================================ */

/* ----- Grid: 3-col on archive pages ----- */
.goatrip-grid-3 {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.75rem;
}
@media (min-width: 700px) {
    .goatrip-grid-3 { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
}
@media (min-width: 1100px) {
    .goatrip-grid-3 { grid-template-columns: repeat(3, 1fr); gap: 2rem; }
}

/* Tighten max-width on archive container so 3-col cards aren't cartoonishly wide on huge screens */
.goatrip-archive .goatrip-container,
body.archive .goatrip-container,
body.post-type-archive .goatrip-container {
    max-width: 1320px;
}

/* ----- Card shell — refined ----- */
.goatrip-card {
    position: relative;
    overflow: hidden;
    background: #0a0a0a;
    border: 1px solid rgba(245, 230, 181, 0.06);
    border-radius: 1.25rem;
    box-shadow:
        0 1px 2px rgba(0, 0, 0, 0.2),
        0 8px 28px rgba(0, 0, 0, 0.18);
    transition:
        transform 0.5s cubic-bezier(0.2, 0.9, 0.3, 1),
        border-color 0.5s,
        box-shadow 0.5s;
    display: flex;
    flex-direction: column;
}

.goatrip-card:hover {
    transform: translateY(-4px);
    border-color: rgba(212, 175, 55, 0.42);
    box-shadow:
        0 1px 2px rgba(0, 0, 0, 0.2),
        0 24px 60px rgba(0, 0, 0, 0.45),
        0 0 0 1px rgba(212, 175, 55, 0.18) inset,
        0 0 60px -12px rgba(212, 175, 55, 0.25);
}

/* ----- Card media — taller, more cinematic ----- */
.goatrip-card-media {
    position: relative;
    overflow: hidden;
    aspect-ratio: 4 / 5;
    border-radius: 0;
    background: #0a0a0a;
}

/* Soft shimmer keeps showing during image load — no change */

/* Override the previous gradient — luxury wants a deeper one */
.goatrip-card-media::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, transparent 35%, rgba(0, 0, 0, 0.35) 75%, rgba(0, 0, 0, 0.7) 100%);
    opacity: 0.95;
    transition: opacity 0.5s;
    pointer-events: none;
    z-index: 1;
}
.goatrip-card:hover .goatrip-card-media::after { opacity: 1; }

/* Image — gentler zoom (less aggressive than v2.1's 1.07) */
.goatrip-card-media img,
.goatrip-card-media .wp-post-image,
.goatrip-card-media .goatrip-card-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 1.2s cubic-bezier(0.2, 0.9, 0.3, 1), filter 0.6s;
    filter: saturate(0.92) brightness(0.96);
}
.goatrip-card:hover .goatrip-card-media img,
.goatrip-card:hover .goatrip-card-media .wp-post-image,
.goatrip-card:hover .goatrip-card-media .goatrip-card-image {
    transform: scale(1.045);
    filter: saturate(1.05) brightness(1);
}

/* ----- Top-left badge — refined editorial style ----- */
.goatrip-card-badge {
    position: absolute;
    top: 1rem;
    left: 1rem;
    z-index: 3;
    padding: 0.4rem 0.85rem;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    background: rgba(212, 175, 55, 0.92);
    color: #0a0a0a;
    font-size: 0.65rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.35);
    line-height: 1;
}

/* Urgency badge — top-right, refined */
.goatrip-urgency-badge {
    position: absolute;
    top: 1rem;
    right: 1rem;
    z-index: 3;
    padding: 0.4rem 0.85rem;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    background: rgba(239, 68, 68, 0.92);
    color: #fff;
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.35);
    line-height: 1;
    animation: goatrip-urgency-pulse 2.4s ease-in-out infinite;
}
@keyframes goatrip-urgency-pulse {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(1.04); }
}

/* ----- Meta row → frosted-glass pill at bottom-left of image ----- */
.goatrip-card-meta-row {
    position: absolute;
    bottom: 1rem;
    left: 1rem;
    right: auto;
    z-index: 3;
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.45rem 0.95rem;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    background: rgba(10, 10, 10, 0.55);
    border: 1px solid rgba(245, 230, 181, 0.18);
    border-radius: 999px;
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.45);
    width: auto;
    max-width: calc(100% - 2rem);
}
.goatrip-card-meta-row > span {
    color: rgba(245, 230, 181, 0.95);
    font-size: 0.78rem;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    line-height: 1;
}
.goatrip-card-meta-row > span strong {
    color: #fff;
    font-weight: 700;
}
.goatrip-card-meta-row > span small {
    color: rgba(245, 230, 181, 0.65) !important;
    font-weight: 400;
    font-size: 0.72rem;
}
.goatrip-card-meta-row > span svg,
.goatrip-card-meta-row > span .goatrip-icon {
    width: 14px;
    height: 14px;
    color: var(--goatrip-primary);
    flex-shrink: 0;
}
/* Gold-dot separator between meta items */
.goatrip-card-meta-row > span:not(:last-child)::after {
    content: '';
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: var(--goatrip-primary);
    margin-left: 0.75rem;
    opacity: 0.7;
}

/* ----- Card body — more breathing room ----- */
.goatrip-card-body {
    padding: 1.5rem 1.5rem 1.4rem;
    flex: 1;
    display: flex;
    flex-direction: column;
    background: linear-gradient(180deg, #0d0d0d 0%, #080808 100%);
}

/* ----- Title — Playfair, larger, refined letter-spacing ----- */
.goatrip-card-body h3 {
    font-family: 'Playfair Display', serif;
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: -0.018em;
    margin: 0 0 0.6rem 0;
    color: #374151;
}
.goatrip-card-body h3 a {
    color: inherit;
    text-decoration: none;
    background-image: linear-gradient(90deg, var(--goatrip-primary), var(--goatrip-primary));
    background-position: 0 100%;
    background-repeat: no-repeat;
    background-size: 0% 1px;
    padding-bottom: 2px;
    transition: background-size 0.5s cubic-bezier(0.2, 0.9, 0.3, 1), color 0.3s;
}
.goatrip-card:hover .goatrip-card-body h3 a {
    background-size: 100% 1px;
    color: #fff;
}

/* ----- Description — refined ----- */
.goatrip-card-desc {
    color: rgba(245, 230, 181, 0.65);
    font-size: 0.88rem;
    line-height: 1.6;
    margin: 0 0 1rem 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-weight: 400;
}

/* ----- Features list → inline dot-separated style ----- */
.goatrip-card-features {
    list-style: none;
    padding: 0;
    margin: 0 0 1.1rem 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem 0;
    border-top: 1px solid rgba(245, 230, 181, 0.06);
    border-bottom: 1px solid rgba(245, 230, 181, 0.06);
    padding: 0.85rem 0;
}
.goatrip-card-features li {
    color: rgba(245, 230, 181, 0.7);
    font-size: 0.74rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    line-height: 1.2;
    padding: 0;
}
.goatrip-card-features li:not(:last-child)::after {
    content: '';
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: rgba(212, 175, 55, 0.55);
    margin: 0 0.7rem;
    flex-shrink: 0;
}
/* Hide the check icons inside features list — too busy for the luxe look */
.goatrip-card-features .goatrip-icon,
.goatrip-card-features li svg {
    display: none;
}
.goatrip-card-features li span {
    color: inherit;
}

/* ----- Card foot — price + CTA ----- */
.goatrip-card-foot {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-top: auto;
    padding-top: 0.25rem;
}

/* Price block — Playfair display, refined */
.goatrip-price-block {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}
.goatrip-price-block .goatrip-price-label {
    font-size: 0.62rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgba(245, 230, 181, 0.5);
    margin: 0;
}
.goatrip-price-block .goatrip-price,
.goatrip-card-foot .goatrip-price {
    font-family: 'Playfair Display', serif;
    font-size: 1.65rem;
    font-weight: 700;
    color: var(--goatrip-primary);
    line-height: 1.1;
    letter-spacing: -0.015em;
    transition: text-shadow 0.4s, color 0.3s;
    background: linear-gradient(180deg, #f5e6b5 0%, #d4af37 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.goatrip-card:hover .goatrip-price-block .goatrip-price,
.goatrip-card:hover .goatrip-card-foot .goatrip-price {
    text-shadow: 0 0 32px rgba(212, 175, 55, 0.4);
}
.goatrip-strike,
.goatrip-price-block .goatrip-strike {
    color: rgba(245, 230, 181, 0.35);
    font-size: 0.85rem;
    text-decoration: line-through;
    margin-left: 0.4rem;
    font-family: 'Inter', sans-serif;
    font-weight: 400;
}
.goatrip-price-block .goatrip-price small,
.goatrip-card-foot .goatrip-price small {
    font-family: 'Inter', sans-serif;
    font-size: 0.7rem;
    font-weight: 500;
    color: rgba(245, 230, 181, 0.55);
    -webkit-text-fill-color: rgba(245, 230, 181, 0.55);
    margin-left: 0.25rem;
    letter-spacing: 0;
}

/* ----- Card button — refined "View" arrow style ----- */
.goatrip-card-foot .goatrip-btn,
.goatrip-card .goatrip-btn-primary,
.goatrip-card .goatrip-btn-outline {
    padding: 0.65rem 1.15rem;
    font-size: 0.78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    border-radius: 999px;
    flex-shrink: 0;
    white-space: nowrap;
}
.goatrip-card .goatrip-btn-outline {
    background: transparent;
    border: 1px solid rgba(212, 175, 55, 0.4);
    color: var(--goatrip-primary);
}
.goatrip-card:hover .goatrip-btn-outline {
    background: var(--goatrip-primary);
    color: #0a0a0a;
    border-color: var(--goatrip-primary);
}
.goatrip-card .goatrip-btn-primary {
    background: linear-gradient(135deg, #d4af37 0%, #e9c468 50%, #d4af37 100%);
    background-size: 200% auto;
    color: #0a0a0a;
    border: none;
    box-shadow: 0 4px 14px rgba(212, 175, 55, 0.25);
    transition: background-position 0.5s, box-shadow 0.4s, transform 0.25s;
}
.goatrip-card:hover .goatrip-btn-primary {
    background-position: right center;
    box-shadow: 0 8px 22px rgba(212, 175, 55, 0.45);
}

/* If both buttons are present in the foot, stack tightly */
.goatrip-card-foot .goatrip-btn-group {
    display: flex;
    gap: 0.4rem;
    flex-direction: column;
    align-items: flex-end;
}
@media (min-width: 1200px) {
    .goatrip-card-foot .goatrip-btn-group { flex-direction: row; }
}

/* ----- Override the older v2.0 card padding/styles that are duplicated ----- */
.goatrip-card-body { padding: 1.5rem 1.5rem 1.4rem !important; }
.goatrip-card-body h3 { font-size: 1.4rem !important; }

/* ----- Typography refinement: section heading on archive pages ----- */
body.archive .goatrip-page-hero h1,
body.post-type-archive .goatrip-page-hero h1 {
    font-size: clamp(2rem, 5vw, 3.5rem);
    letter-spacing: -0.025em;
}

/* ----- Force the same luxury treatment on related cards too ----- */
.goatrip-related-grid { gap: 1.75rem; }

/* ----- Dark-mode form: special handling on light bg sections (rare) ----- */
@media (prefers-reduced-motion: reduce) {
    .goatrip-urgency-badge { animation: none; }
    .goatrip-card-media img { transition: none; }
}
