/*
Theme Name: Enfold Child
Description: A <a href='http://codex.wordpress.org/Child_Themes'>Child Theme</a> for the Enfold Wordpress Theme. If you plan to do a lot of file modifications we recommend to use this Theme instead of the original Theme. Updating wil be much easier then.
Version: 7.13
Author: Kriesi
Author URI: http://www.kriesi.at
Template: enfold
*/



/*Add your own styles here:*/

/* ── Viator Tour CPT ─────────────────────────────────────── */

/* Admin-only wrapper */
.viator-admin-only-wrap {
    border: 2px solid #e8a000 !important;
    border-radius: 0 8px 8px 8px !important;
    padding: 12px !important;
    margin: 30px 0 24px !important;
    background: #fffdf5 !important;
    position: relative !important;
    display: block !important;
    overflow: visible !important;
}
/* Label-Tab oben links — INNERHALB des Elements, kein overflow nötig */
.viator-admin-only-wrap::before {
    content: 'Nur für Admins sichtbar' !important;
    position: absolute !important;
    top: -24px !important;
    left: -2px !important;
    background: #e8a000 !important;
    color: #fff !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: .06em !important;
    text-transform: uppercase !important;
    padding: 3px 10px !important;
    border-radius: 4px 4px 0 0 !important;
    font-family: inherit !important;
    line-height: 1.6 !important;
    display: block !important;
    width: max-content !important;
}

/* Admin panel — höhere Spezifität durch Parent-Selektor */
.viator-admin-only-wrap .viator-admin-panel {
    border-radius: 4px !important;
    font-size: 12px !important;
    font-family: inherit !important;
    overflow: hidden !important;
}
.viator-admin-only-wrap .viator-admin-panel__head {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    background: #1d2327 !important;
    padding: 6px 12px !important;
    border-radius: 4px 4px 0 0 !important;
}
.viator-admin-only-wrap .viator-admin-panel__label {
    color: #e8a000 !important;
    font-weight: 700 !important;
    font-size: 11px !important;
    letter-spacing: .05em !important;
    text-transform: uppercase !important;
}
.viator-admin-only-wrap .viator-admin-panel__actions {
    display: flex !important;
    gap: 6px !important;
    flex-wrap: wrap !important;
}
.viator-admin-only-wrap .viator-admin-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    background: #2c3338 !important;
    color: #c3c4c7 !important;
    border: 1px solid #3c434a !important;
    border-radius: 4px !important;
    padding: 4px 10px !important;
    font-size: 11px !important;
    font-family: inherit !important;
    cursor: pointer !important;
    text-decoration: none !important;
    line-height: 1.4 !important;
}
.viator-admin-only-wrap .viator-admin-btn:hover {
    background: #3c434a !important;
    color: #fff !important;
    text-decoration: none !important;
}
.viator-admin-only-wrap .viator-admin-panel__body {
    padding: 10px 14px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
    background: #fff !important;
    border: 1px solid #e8a000 !important;
    border-top: none !important;
    border-radius: 0 0 4px 4px !important;
}
.viator-admin-only-wrap .viator-admin-row {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    min-height: 22px !important;
}
.viator-admin-only-wrap .viator-admin-row--top { align-items: flex-start !important; }
.viator-admin-only-wrap .viator-admin-key {
    width: 150px !important;
    flex-shrink: 0 !important;
    color: #666 !important;
    font-weight: 600 !important;
}
.viator-admin-only-wrap .viator-admin-val {
    color: #1d2327 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 4px !important;
}
.viator-admin-only-wrap .viator-admin-tag {
    background: #e5e7eb !important;
    border: 1px solid transparent !important;
    border-radius: 3px !important;
    padding: 1px 7px !important;
    font-size: 11px !important;
    color: #333 !important;
    white-space: nowrap !important;
}
.viator-admin-only-wrap .viator-admin-divider {
    font-size: 10px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .06em !important;
    color: #888 !important;
    border-top: 1px solid #e5e7eb !important;
    padding-top: 6px !important;
    margin-top: 4px !important;
}
.viator-admin-only-wrap .viator-admin-tag--missing {
    background: #fee2e2 !important;
    color: #b91c1c !important;
    border-color: #fca5a5 !important;
}
/* ── Veraltete Duplikate entfernt ── */

/* Single */
.viator-cover-image { margin-bottom: 24px; }
.viator-cover-image img { width: 100%; height: auto; border-radius: 4px; }

.viator-meta-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 24px;
    align-items: center;
    background: #f7f7f7;
    border-left: 4px solid #e8a000;
    padding: 12px 16px;
    margin-bottom: 24px;
    border-radius: 0 4px 4px 0;
    font-size: 0.95em;
}
.viator-meta-item { display: flex; align-items: center; gap: 5px; }
.viator-icon { font-size: 1.1em; }
.viator-destinations a { color: inherit; text-decoration: underline; }
.viator-price { font-weight: 700; color: #e8a000; font-size: 1.1em; }
.viator-review-count { color: #666; font-size: 0.9em; }

.viator-book-action {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    margin: 32px 0 24px;
    width: 100%;
}
.viator-book-action .viator-book-btn {
    display: block !important;
    width: 100% !important;
    text-align: center !important;
    box-sizing: border-box;
}
.viator-price-note { color: #555; font-size: 0.9em; text-align: center; }

/* Archive Grid */
.viator-tour-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 28px;
    margin-bottom: 40px;
}

.viator-tour-card {
    background: #fff;
    border: 1px solid #e5e5e5;
    border-radius: 6px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: box-shadow 0.2s;
}
.viator-tour-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.12); }

.viator-card-image {
    display: block;
    position: relative;
    overflow: hidden;
    aspect-ratio: 4/3;
}
.viator-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.3s;
}
.viator-tour-card:hover .viator-card-image img { transform: scale(1.04); }

.viator-card-price-badge {
    position: absolute;
    bottom: 10px;
    right: 10px;
    background: #e8a000;
    color: #fff;
    font-weight: 700;
    font-size: 0.85em;
    padding: 4px 10px;
    border-radius: 3px;
}

.viator-card-body {
    padding: 16px;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.viator-card-destination {
    font-size: 0.78em;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #888;
    margin-bottom: 6px;
    display: block;
}
.viator-card-title { font-size: 1em; margin: 0 0 8px; line-height: 1.35; }
.viator-card-title a { color: inherit; text-decoration: none; }
.viator-card-title a:hover { text-decoration: underline; }

.viator-card-meta {
    display: flex;
    gap: 14px;
    font-size: 0.85em;
    color: #555;
    margin-bottom: 10px;
    flex-wrap: wrap;
}
.viator-card-rating { color: #c07800; }

.viator-card-body .entry-summary { font-size: 0.88em; color: #555; margin-bottom: 14px; flex: 1; }

.viator-card-btn { margin-top: auto; align-self: flex-start; }

.viator-pagination { margin-top: 16px; }

/* ── Bildgalerie ─────────────────────────────────────────── */
.viator-gallery-wrap {
    margin-bottom: 28px;
}
.viator-gallery-main {
    position: relative;
    overflow: hidden;
    border-radius: 6px;
    background: #111;
    aspect-ratio: 16/9;
    max-height: 480px;
}
.viator-gallery-main img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: opacity .25s;
}
.viator-gallery-price-badge {
    position: absolute;
    bottom: 14px;
    right: 14px;
    background: #e8a000;
    color: #fff;
    font-weight: 700;
    font-size: 1em;
    padding: 6px 14px;
    border-radius: 4px;
    pointer-events: none;
}
.viator-gallery-thumbs {
    display: flex;
    gap: 6px;
    margin-top: 8px;
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: thin;
}
.viator-gallery-thumb {
    flex-shrink: 0;
    width: 72px;
    height: 52px;
    padding: 0;
    border: 2px solid transparent;
    border-radius: 4px;
    overflow: hidden;
    cursor: pointer;
    background: none;
    transition: border-color .15s, opacity .15s;
    opacity: .7;
}
.viator-gallery-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.viator-gallery-thumb:hover { opacity: 1; border-color: #e8a000; }
.viator-gallery-thumb.active { opacity: 1; border-color: #e8a000; }

/* ── Stornierungspill ───────────────────────────────────── */
.viator-cancel-pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 0.88em;
    font-weight: 600;
    white-space: nowrap;
}
.viator-cancel-free {
    background: #d4edda;
    color: #155724;
    border: 1px solid #b5dfc4;
}
.viator-cancel-no {
    background: #f8d7da;
    color: #721c24;
    border: 1px solid #f1aeb5;
}

/* ── Content-Sektionen (Inclusions, Itinerary etc.) ─────── */
.entry-content .viator-description p { margin-bottom: 1em; }

.entry-content h2 {
    margin-top: 1.6em;
    margin-bottom: .7em;
    font-size: 1.15em;
    border-bottom: 2px solid #e8a000;
    padding-bottom: 6px;
}
.entry-content ul.viator-highlights,
.entry-content ul {
    padding-left: 1.4em;
    margin-bottom: 1em;
}
.entry-content ul li { margin-bottom: .4em; }

.entry-content table.viator-attributes {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 1.2em;
    font-size: .95em;
}
.entry-content table.viator-attributes th,
.entry-content table.viator-attributes td {
    padding: 7px 12px;
    text-align: left;
    border-bottom: 1px solid #ebebeb;
}
.entry-content table.viator-attributes th {
    width: 38%;
    color: #555;
    font-weight: 600;
    background: #fafafa;
}

.entry-content ol.viator-stops {
    padding-left: 1.6em;
    margin-bottom: 1em;
}
.entry-content ol.viator-stops li {
    margin-bottom: .9em;
    line-height: 1.6;
}

/* ── Properties-Grid (Dauer, Privat, Skip, Ticket) ───────── */
.viator-props-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 0 0 28px;
}
.viator-prop-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    background: #f7f7f7;
    border: 1px solid #e5e5e5;
    border-radius: 6px;
    padding: 14px 12px;
    min-width: 110px;
    flex: 1 1 110px;
    gap: 5px;
}
.viator-prop-icon { font-size: 1.5em; line-height: 1; }
.viator-prop-label { font-size: 0.72em; text-transform: uppercase; letter-spacing: 0.05em; color: #888; font-weight: 600; }
.viator-prop-val { font-size: 0.88em; color: #333; line-height: 1.3; font-weight: 500; }

/* ── Inclusions / Exclusions Listen ─────────────────── */
.entry-content ul.viator-incexc-list {
    list-style: none;
    padding-left: 0;
    margin-bottom: 1em;
}
.entry-content ul.viator-incexc-list li {
    padding: 4px 0 4px 22px;
    position: relative;
    border-bottom: 1px solid #f0f0f0;
}
.entry-content ul.viator-incexc-list li:last-child { border-bottom: none; }
.entry-content ul.viator-inc li::before {
    content: '\2714';
    position: absolute;
    left: 2px;
    color: #1a7f37;
    font-weight: 700;
}
.entry-content ul.viator-exc li::before {
    content: '\2716';
    position: absolute;
    left: 2px;
    color: #b91c1c;
    font-weight: 700;
}

/* ── Stornierungstext ────────────────────────────── */
.viator-cancel-desc {
    background: #f0f9f4;
    border-left: 3px solid #1a7f37;
    padding: 10px 14px;
    border-radius: 0 4px 4px 0;
    font-size: 0.92em;
    color: #2d5a3d;
    margin-top: 8px;
}
.viator-cancel-weather { font-size: 0.88em; color: #555; margin-top: 4px; }

/* ── Bewertungs-Zusammenfassung ──────────────────── */
.viator-reviews-summary {
    margin: 32px 0 24px;
    padding: 24px;
    background: #fafafa;
    border: 1px solid #e5e5e5;
    border-radius: 6px;
}
.viator-reviews-summary h2 {
    margin-top: 0 !important;
    margin-bottom: 18px !important;
}
.viator-reviews-layout {
    display: flex;
    gap: 40px;
    align-items: flex-start;
    flex-wrap: wrap;
}
.viator-reviews-score {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 120px;
}
.viator-reviews-avg {
    font-size: 3em;
    font-weight: 700;
    color: #1d2327;
    line-height: 1;
    margin-bottom: 6px;
}
.viator-stars-wrap {
    position: relative;
    display: inline-block;
    font-size: 1.5em;
    line-height: 1;
    margin-bottom: 6px;
}
.viator-stars-bg { color: #ddd; }
.viator-stars-fg {
    position: absolute;
    top: 0;
    left: 0;
    overflow: hidden;
    white-space: nowrap;
    color: #e8a000;
}
.viator-reviews-total {
    font-size: 0.85em;
    color: #555;
    margin-bottom: 10px;
    text-align: center;
}
.viator-reviews-providers {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: center;
}
.viator-provider-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: #e5e7eb;
    border-radius: 3px;
    padding: 2px 8px;
    font-size: 0.8em;
    color: #333;
}
.viator-provider-badge em {
    font-style: normal;
    color: #666;
}
.viator-reviews-bars {
    flex: 1;
    min-width: 200px;
    display: flex;
    flex-direction: column;
    gap: 7px;
    justify-content: center;
}
.viator-bar-row {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.88em;
}
.viator-bar-label {
    width: 32px;
    flex-shrink: 0;
    text-align: right;
    color: #555;
}
.viator-bar-track {
    flex: 1;
    height: 10px;
    background: #e5e5e5;
    border-radius: 5px;
    overflow: hidden;
}
.viator-bar-fill {
    height: 100%;
    background: #e8a000;
    border-radius: 5px;
    transition: width 0.4s;
}
.viator-bar-count {
    width: 36px;
    flex-shrink: 0;
    color: #555;
    font-size: 0.9em;
}
.viator-reviews-cta {
    margin-top: 16px;
    font-size: 0.88em;
    color: #555;
}
.viator-reviews-cta a { color: #0073aa; }

/* ── Konzept v1.5: Block 02 Mobile Sticky CTA + Block 03 Buchungsbox-Sidebar + Block 15 Transparenz + Inaktiv ── */

/* Block 15 — Transparenzhinweis */
.viator-transparency-note {
    margin: 8px 0 0;
    font-size: 0.78em;
    color: #666;
    line-height: 1.35;
    text-align: center;
}
.viator-transparency-note--small { font-size: 0.72em; margin-top: 6px; }

/* Preis-Stand + Quelle (Konzept §6 + §7) */
.viator-price-stand {
    display: block;
    font-size: 0.7em;
    font-weight: 400;
    color: #888;
    margin-top: 2px;
    text-transform: none;
    letter-spacing: 0;
}
.viator-rating-source {
    display: inline-block;
    margin-left: 6px;
    font-size: 0.75em;
    color: #888;
    font-weight: 400;
}

/* Inaktive Tour */
.viator-inactive-badge .viator-cancel-pill { font-size: 0.95em; }
.viator-cta-inactive {
    background: #888 !important;
    color: #fff !important;
    pointer-events: auto;
    opacity: 0.92;
}
.viator-cta-inactive:hover { background: #666 !important; }

/* Block 03 — Buchungsbox-Sidebar */
.viator-booking-sidebar {
    background: #fff;
    border: 1px solid #e5e5e5;
    border-radius: 8px;
    padding: 18px 18px 16px;
    margin: 14px 0 22px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.04);
}
.viator-booking-status { margin-bottom: 12px; }
.viator-booking-price {
    font-size: 1.8em;
    font-weight: 700;
    color: #e8a000;
    line-height: 1.1;
}
.viator-booking-stand {
    font-size: 0.78em;
    color: #888;
    margin-top: 4px;
    margin-bottom: 12px;
}
.viator-booking-rating {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 12px;
    font-size: 0.95em;
}
.viator-booking-rating .viator-icon { color: #e8a000; font-size: 1.2em; }
.viator-booking-rating strong { font-size: 1.1em; }
.viator-booking-rating-count { color: #555; }
.viator-booking-rating small { color: #888; font-size: 0.78em; width: 100%; }
.viator-booking-facts {
    list-style: none;
    margin: 0 0 14px;
    padding: 0;
    font-size: 0.92em;
    line-height: 1.7;
    color: #444;
}
.viator-booking-facts li { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.viator-booking-facts li small { color: #888; }
.viator-booking-cta {
    display: block;
    width: 100%;
    text-align: center;
}

/* Block 02 — Mobile Sticky CTA */
.viator-sticky-cta {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9990;
    background: #fff;
    border-top: 1px solid #e0e0e0;
    box-shadow: 0 -2px 12px rgba(0,0,0,0.08);
    display: flex;            /* sichtbar auf allen Viewports; IntersectionObserver blendet bei Sidebar/Footer aus */
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 14px;
    /* Browser-Safe-Area (iOS Notch) */
    padding-bottom: calc(10px + env(safe-area-inset-bottom, 0px));
    transition: transform 0.25s ease;
}
.viator-sticky-cta--hidden { transform: translateY(110%); }
.viator-sticky-cta__price {
    font-weight: 700;
    color: #e8a000;
    font-size: 1.05em;
    flex: 1 1 auto;
    min-width: 0;
}
.viator-sticky-cta__price--inactive { color: #b91c1c; font-size: 0.9em; }
.viator-sticky-cta__btn {
    background: #e8a000;
    color: #fff !important;
    border-radius: 6px;
    padding: 10px 16px;
    font-weight: 600;
    text-decoration: none;
    white-space: nowrap;
    font-size: 0.95em;
    flex: 0 0 auto;
}
.viator-sticky-cta__btn:hover { background: #c98800; }

/* Responsive — Desktop: Sidebar zur rechten Spalte; Mobile: inline */
@media (max-width: 989px) {
    /* Block 03 mobile: Sidebar zwischen Hero und Content (Konzept §5) */
    .viator-booking-sidebar { margin-top: 14px; }
}

@media (min-width: 990px) {
    .viator-booking-sidebar {
        float: right;
        width: 320px;
        margin: 0 0 20px 24px;
        position: sticky;
        top: 90px;
        align-self: flex-start;
    }
    /* Top-CTA auf Desktop redundant zur Sidebar — ausblenden */
    .viator-book-action-top { display: none; }
}

/* Cookie/Consent-Banner Workaround (Konzept §4: Consent-Banner aktiv → CTA nach unten verschieben) */
body.cookie-notice-visible .viator-sticky-cta,
body.has-cookie-banner .viator-sticky-cta {
    bottom: 60px;
}

/* Konzept v1.6 — Block 15 finaler CTA + Block 16 Transparenzhinweis */
.viator-final-cta {
    background: #fafafa;
    border: 1px solid #e5e5e5;
    border-radius: 8px;
    padding: 20px;
    margin: 30px 0 20px;
    text-align: center;
}
.viator-final-cta .viator-book-btn { margin-bottom: 10px; }
.viator-final-cta .viator-price-note {
    font-size: 0.95em;
    color: #555;
    margin-top: 8px;
}
.viator-disclaimer {
    margin: 30px 0 10px;
    padding: 14px 16px;
    background: #fafafa;
    border-left: 3px solid #c9c9c9;
    border-radius: 0 4px 4px 0;
}
.viator-disclaimer p {
    margin: 0;
    font-size: 0.82em;
    color: #666;
    line-height: 1.5;
}

/* Konzept v1.6 — Block 06 redaktionelle Sektionen */
.viator-editorial {
    margin: 28px 0;
    padding: 18px 22px;
    background: #f9fafb;
    border-left: 4px solid #2271b1;
    border-radius: 0 6px 6px 0;
}
.viator-editorial h2 {
    margin-top: 0;
    margin-bottom: 12px;
    font-size: 1.35em;
    color: #1d2327;
}
.viator-editorial--fuer-wen { border-left-color: #1a7f37; }
.viator-editorial--hinweise { border-left-color: #b45309; }
.viator-editorial p:last-child { margin-bottom: 0; }

/* Konzept v1.6 — Block 13 FAQ-Akkordeon */
.viator-faq { margin: 30px 0; }
.viator-faq h2 { margin-bottom: 16px; }
.viator-faq-list { display: flex; flex-direction: column; gap: 8px; }
.viator-faq-item {
    background: #fff;
    border: 1px solid #e5e5e5;
    border-radius: 6px;
    padding: 0;
    overflow: hidden;
}
.viator-faq-item[open] { border-color: #2271b1; }
.viator-faq-q {
    cursor: pointer;
    padding: 14px 18px;
    font-weight: 600;
    background: #fafafa;
    list-style: none;
    position: relative;
    padding-right: 40px;
}
.viator-faq-q::-webkit-details-marker { display: none; }
.viator-faq-q::after {
    content: '+';
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.4em;
    color: #2271b1;
    transition: transform 0.2s;
}
.viator-faq-item[open] .viator-faq-q::after { content: '−'; }
.viator-faq-a { padding: 14px 18px; color: #333; line-height: 1.6; }

/* Konzept v1.6 — Block 14 Ähnliche Touren */
.viator-related { margin: 30px 0; }
.viator-related-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 16px;
}
.viator-related-card {
    display: flex;
    flex-direction: column;
    background: #fff;
    border: 1px solid #e5e5e5;
    border-radius: 6px;
    overflow: hidden;
    text-decoration: none;
    color: #1d2327;
    transition: box-shadow 0.15s, transform 0.15s;
}
.viator-related-card:hover {
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
    transform: translateY(-2px);
    text-decoration: none;
}
.viator-related-img {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    background-size: cover;
    background-position: center;
    background-color: #eee;
}
.viator-related-body { padding: 12px 14px; display: flex; flex-direction: column; gap: 5px; }
.viator-related-title { font-size: 0.95em; line-height: 1.3; }
.viator-related-rating { color: #e8a000; font-size: 0.88em; }
.viator-related-price { color: #555; font-size: 0.92em; font-weight: 600; }

/* Konzept v1.6 — Meta-Bar Badges (is_top / is_bestseller / is_budget / is_premium / is_highscore) */
.viator-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 9px;
    border-radius: 12px;
    font-size: 0.82em;
    font-weight: 600;
    line-height: 1.4;
    border: 1px solid transparent;
}
.viator-badge .viator-icon { font-size: 1em; }
.viator-badge--top        { background: #fff7ed; color: #b45309; border-color: #fde68a; }
.viator-badge--bestseller { background: #fef2f2; color: #b91c1c; border-color: #fecaca; }
.viator-badge--budget     { background: #ecfdf5; color: #047857; border-color: #a7f3d0; }
.viator-badge--premium    { background: #eef2ff; color: #4338ca; border-color: #c7d2fe; }
.viator-badge--highscore  { background: #fffbeb; color: #92400e; border-color: #fcd34d; }

/* Konzept v1.6 — Props-Grid: erste Zeile fix 3 Spalten, Sprachkachel full-width */
.viator-props-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}
.viator-prop-card--full {
    grid-column: 1 / -1;
}
@media (max-width: 640px) {
    .viator-props-grid { grid-template-columns: repeat(2, 1fr); }
    /* Mobile: Sprachkachel ist normale Kachel (nicht full-width), Grid zeigt 4 Kacheln in 2 Reihen */
    .viator-prop-card--full { grid-column: auto; }
}

/* PS: 2-Spalten-Layout (ersetzt Avia [av_one_half] in alten ps_content/Reisefuehrer-Posts) */
.ps-cols { display: flex; flex-wrap: wrap; gap: 30px; margin: 20px 0; clear: both; }
.ps-col-1-2 { flex: 1 1 calc(50% - 15px); min-width: 0; }
@media (max-width: 768px) {
    .ps-col-1-2 { flex: 1 1 100%; }
}


