:root {
    --korfu-blue: var(--color-primary, #1e73be);
    --korfu-blue-dark: var(--color-primary-dark, #073b5c);
    --korfu-sand: var(--color-sand, #f6efe3);
    --korfu-white: #fff;
}

.korfu-accommodations-grid {
    display: grid;
    gap: 1.6rem;
    margin: 2rem 0;
}

.korfu-columns-1 { grid-template-columns: 1fr; }
.korfu-columns-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.korfu-columns-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.korfu-columns-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.korfu-accommodation-card {
    display: grid;
    grid-template-columns: minmax(220px, 42%) 1fr;
    min-height: 320px;
    overflow: hidden;
    background: var(--korfu-white);
    border: 1px solid rgba(30,115,190,0.12);
    border-radius: 22px;
    box-shadow: 0 18px 44px rgba(7,59,92,0.1);
}

.korfu-card-media {
    display: block;
    min-height: 260px;
    background: linear-gradient(135deg, rgba(30,115,190,0.12), rgba(246,239,227,0.9));
}

.korfu-card-image {
    width: 100%;
    height: 100%;
    min-height: 260px;
    object-fit: cover;
    display: block;
}

.korfu-card-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--korfu-blue);
}

.korfu-card-placeholder svg {
    width: 80px;
    height: 80px;
}

.korfu-card-body {
    padding: 1.35rem;
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

.korfu-card-body h3 {
    margin: 0;
    font-size: clamp(1.45rem, 2.6vw, 2rem);
    line-height: 1.1;
}

.korfu-card-body h3 a {
    color: var(--korfu-blue-dark);
    text-decoration: none;
}

.korfu-card-subtitle,
.korfu-single-subtitle {
    margin: 0;
    color: #476170;
    font-size: 1.02rem;
    line-height: 1.55;
}

.korfu-facts-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.korfu-fact {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.75rem;
    border-radius: 14px;
    background: rgba(30,115,190,0.07);
}

.korfu-fact-icon {
    width: 34px;
    height: 34px;
    min-width: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--korfu-blue);
}

.korfu-fact-icon svg {
    width: 28px;
    height: 28px;
}

.korfu-fact strong {
    display: block;
    color: var(--korfu-blue-dark);
    font-weight: 700;
    line-height: 1.1;
}

.korfu-fact small {
    display: block;
    color: #66808e;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.korfu-feature-icons {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.korfu-feature-icon {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.55rem 0.7rem;
    border-radius: 999px;
    background: #fff;
    border: 1px solid rgba(30,115,190,0.14);
    color: var(--korfu-blue-dark);
    font-weight: 600;
    font-size: 0.92rem;
}

.korfu-feature-icon svg {
    width: 21px;
    height: 21px;
    color: var(--korfu-blue);
}

.korfu-card-button {
    align-self: flex-start;
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 1.1rem;
    border-radius: 999px;
    background: var(--korfu-blue);
    color: #fff !important;
    text-decoration: none;
    font-weight: 700;
    box-shadow: 0 12px 24px rgba(30,115,190,0.22);
}

.korfu-card-button:hover {
    filter: brightness(0.96);
    transform: translateY(-1px);
}

.korfu-card-button-large {
    padding: 0.9rem 1.35rem;
}

.korfu-single-detail {
    margin-top: 2rem;
}

.korfu-single-intro {
    margin-bottom: 1.5rem;
}

.korfu-single-location {
    color: var(--korfu-blue);
    font-weight: 700;
    margin: 0.3rem 0 0;
}

.korfu-detail-section {
    margin-top: 2.25rem;
    padding: 1.5rem;
    border-radius: 22px;
    background: linear-gradient(135deg, rgba(255,255,255,0.95), rgba(246,239,227,0.75));
    border: 1px solid rgba(30,115,190,0.12);
}

.korfu-detail-section h2,
.korfu-booking-cta h2 {
    margin-top: 0;
    color: var(--korfu-blue-dark);
}

.korfu-highlight-list {
    margin: 0;
    padding: 0;
    list-style: none;
    columns: 2;
    column-gap: 2rem;
}

.korfu-highlight-list li {
    break-inside: avoid;
    position: relative;
    padding: 0.35rem 0 0.35rem 1.45rem;
}

.korfu-highlight-list li::before {
    content: "✓";
    position: absolute;
    left: 0;
    top: 0.35rem;
    color: var(--korfu-blue);
    font-weight: 700;
}

.korfu-gallery-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
}

.korfu-gallery-grid img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    display: block;
    border-radius: 16px;
}

.korfu-booking-cta {
    margin-top: 2.5rem;
    padding: 2rem;
    border-radius: 24px;
    color: #fff;
    background: linear-gradient(135deg, var(--korfu-blue-dark), var(--korfu-blue));
    box-shadow: 0 20px 44px rgba(7,59,92,0.18);
}

.korfu-booking-cta h2,
.korfu-booking-cta p {
    color: #fff;
}

.korfu-booking-cta .korfu-card-button {
    background: #fff;
    color: var(--korfu-blue-dark) !important;
}

.korfu-empty {
    padding: 1rem;
    border-radius: 14px;
    background: rgba(30,115,190,0.08);
    color: var(--korfu-blue-dark);
}

@media (max-width: 900px) {
    .korfu-columns-2,
    .korfu-columns-3,
    .korfu-columns-4 {
        grid-template-columns: 1fr;
    }

    .korfu-accommodation-card {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .korfu-facts-grid,
    .korfu-gallery-grid {
        grid-template-columns: 1fr;
    }

    .korfu-highlight-list {
        columns: 1;
    }

    .korfu-card-body {
        padding: 1.1rem;
    }

    .korfu-feature-icon {
        width: 100%;
        border-radius: 14px;
    }
}

.korfu-single-hero-image { margin: 0 0 2rem; border-radius: 24px; overflow: hidden; box-shadow: 0 18px 44px rgba(7,59,92,0.12); }
.korfu-single-hero-image img { width: 100%; max-height: 520px; object-fit: cover; display: block; }


.korfu-accommodations-grid + .korfu-accommodations-grid {
    margin-top: 1.5rem;
}

.content-area .korfu-accommodations-grid {
    margin-top: 0;
}


/* v1.2.0 – spacious accommodation cards */
.korfu-accommodations-grid {
    gap: clamp(1.5rem, 3vw, 2.4rem);
}

.korfu-accommodation-card {
    grid-template-columns: minmax(320px, 42%) minmax(0, 1fr);
    min-height: unset;
    align-items: stretch;
}

.korfu-card-media {
    min-height: 360px;
    height: auto;
}

.korfu-card-image {
    min-height: 360px;
    height: 100%;
}

.korfu-card-body {
    padding: clamp(1.4rem, 2.6vw, 2.2rem);
    gap: 1.1rem;
}

.korfu-card-body h3 {
    font-size: clamp(1.65rem, 3vw, 2.35rem);
}

.korfu-card-subtitle {
    max-width: 62ch;
}

.korfu-facts-grid {
    grid-template-columns: repeat(auto-fit, minmax(155px, 1fr));
    gap: 0.85rem;
}

.korfu-fact {
    min-height: 76px;
    padding: 0.85rem 0.95rem;
}

.korfu-feature-icons {
    gap: 0.7rem;
}

.korfu-feature-icon {
    min-height: 42px;
    padding: 0.55rem 0.8rem;
}

@media (max-width: 1100px) {
    .korfu-accommodation-card {
        grid-template-columns: 1fr;
    }

    .korfu-card-media,
    .korfu-card-image {
        min-height: 340px;
    }
}

@media (max-width: 640px) {
    .korfu-card-media,
    .korfu-card-image {
        min-height: 260px;
    }

    .korfu-facts-grid {
        grid-template-columns: 1fr;
    }

    .korfu-feature-icon {
        width: auto;
        flex: 1 1 calc(50% - 0.7rem);
        justify-content: flex-start;
    }
}


/* v1.3.0 – correct layouts for 1 vs. multiple columns */
.korfu-card-placeholder {
    flex-direction: column;
    gap: 0.75rem;
    min-height: inherit;
    font-weight: 700;
}

.korfu-card-placeholder span {
    color: var(--korfu-blue-dark);
}

/* 1 column: spacious horizontal layout */
.korfu-columns-1 .korfu-accommodation-card {
    grid-template-columns: minmax(340px, 42%) minmax(0, 1fr);
}

.korfu-columns-1 .korfu-card-media,
.korfu-columns-1 .korfu-card-image {
    min-height: 360px;
}

/* 2+ columns: proper vertical cards, otherwise they look squeezed */
.korfu-columns-2 .korfu-accommodation-card,
.korfu-columns-3 .korfu-accommodation-card,
.korfu-columns-4 .korfu-accommodation-card {
    grid-template-columns: 1fr;
    min-height: 0;
}

.korfu-columns-2 .korfu-card-media,
.korfu-columns-3 .korfu-card-media,
.korfu-columns-4 .korfu-card-media {
    min-height: 0;
    aspect-ratio: 4 / 3;
}

.korfu-columns-2 .korfu-card-image,
.korfu-columns-3 .korfu-card-image,
.korfu-columns-4 .korfu-card-image {
    min-height: 0;
    height: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
}

.korfu-columns-2 .korfu-card-body,
.korfu-columns-3 .korfu-card-body,
.korfu-columns-4 .korfu-card-body {
    padding: 1.25rem;
}

.korfu-columns-2 .korfu-card-body h3,
.korfu-columns-3 .korfu-card-body h3,
.korfu-columns-4 .korfu-card-body h3 {
    font-size: clamp(1.35rem, 2vw, 1.75rem);
}

.korfu-columns-2 .korfu-facts-grid,
.korfu-columns-3 .korfu-facts-grid,
.korfu-columns-4 .korfu-facts-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.korfu-columns-2 .korfu-fact,
.korfu-columns-3 .korfu-fact,
.korfu-columns-4 .korfu-fact {
    min-height: 68px;
    padding: 0.72rem;
}

.korfu-columns-2 .korfu-fact-icon,
.korfu-columns-3 .korfu-fact-icon,
.korfu-columns-4 .korfu-fact-icon {
    width: 30px;
    height: 30px;
    min-width: 30px;
}

.korfu-columns-2 .korfu-fact-icon svg,
.korfu-columns-3 .korfu-fact-icon svg,
.korfu-columns-4 .korfu-fact-icon svg {
    width: 24px;
    height: 24px;
}

.korfu-columns-3 .korfu-facts-grid,
.korfu-columns-4 .korfu-facts-grid {
    grid-template-columns: 1fr;
}

.korfu-columns-2 .korfu-feature-icon,
.korfu-columns-3 .korfu-feature-icon,
.korfu-columns-4 .korfu-feature-icon {
    font-size: 0.86rem;
    padding: 0.5rem 0.62rem;
}

@media (max-width: 1100px) {
    .korfu-columns-1 .korfu-accommodation-card {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .korfu-columns-1 .korfu-card-media,
    .korfu-columns-1 .korfu-card-image,
    .korfu-columns-2 .korfu-card-media,
    .korfu-columns-2 .korfu-card-image,
    .korfu-columns-3 .korfu-card-media,
    .korfu-columns-3 .korfu-card-image,
    .korfu-columns-4 .korfu-card-media,
    .korfu-columns-4 .korfu-card-image {
        min-height: 0;
        aspect-ratio: 4 / 3;
    }

    .korfu-columns-2 .korfu-facts-grid,
    .korfu-columns-3 .korfu-facts-grid,
    .korfu-columns-4 .korfu-facts-grid {
        grid-template-columns: 1fr;
    }
}


/* v1.4.0 – filters and final card polish */
.korfu-accommodations-wrap {
    display: grid;
    gap: 1.4rem;
}

.korfu-filter-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    padding: 1rem;
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(255,255,255,0.96), rgba(246,239,227,0.72));
    border: 1px solid rgba(30,115,190,0.13);
    box-shadow: 0 12px 30px rgba(7,59,92,0.07);
}

.korfu-filter-group {
    display: flex;
    align-items: center;
    gap: 0.7rem;
}

.korfu-filter-group label {
    color: var(--korfu-blue-dark);
    font-weight: 700;
}

.korfu-filter-group select {
    min-height: 42px;
    padding: 0.55rem 2rem 0.55rem 0.8rem;
    border: 1px solid rgba(30,115,190,0.22);
    border-radius: 999px;
    background: #fff;
    color: var(--korfu-blue-dark);
    font-weight: 600;
}

.korfu-filter-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.korfu-filter-chip,
.korfu-filter-reset {
    border: 1px solid rgba(30,115,190,0.22);
    border-radius: 999px;
    padding: 0.6rem 0.85rem;
    background: #fff;
    color: var(--korfu-blue-dark);
    font-weight: 700;
    cursor: pointer;
    transition: transform .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
}

.korfu-filter-chip:hover,
.korfu-filter-reset:hover {
    transform: translateY(-1px);
}

.korfu-filter-chip.is-active {
    background: var(--korfu-blue);
    border-color: var(--korfu-blue);
    color: #fff;
}

.korfu-filter-reset {
    background: rgba(30,115,190,0.08);
}

.korfu-filter-empty {
    padding: 1rem 1.2rem;
    border-radius: 16px;
    background: rgba(30,115,190,0.08);
    color: var(--korfu-blue-dark);
    font-weight: 700;
}

.korfu-accommodation-card[hidden] {
    display: none !important;
}

.korfu-card-placeholder {
    flex-direction: column;
    gap: 0.75rem;
    min-height: inherit;
    font-weight: 700;
}

.korfu-card-placeholder span {
    color: var(--korfu-blue-dark);
}

/* 1 column remains spacious/horizontal */
.korfu-columns-1 .korfu-accommodation-card {
    grid-template-columns: minmax(340px, 42%) minmax(0, 1fr);
}

.korfu-columns-1 .korfu-card-media,
.korfu-columns-1 .korfu-card-image {
    min-height: 360px;
}

/* 2+ columns are vertical cards */
.korfu-columns-2 .korfu-accommodation-card,
.korfu-columns-3 .korfu-accommodation-card,
.korfu-columns-4 .korfu-accommodation-card {
    grid-template-columns: 1fr;
    min-height: 0;
}

.korfu-columns-2 .korfu-card-media,
.korfu-columns-3 .korfu-card-media,
.korfu-columns-4 .korfu-card-media {
    min-height: 0;
    aspect-ratio: 4 / 3;
}

.korfu-columns-2 .korfu-card-image,
.korfu-columns-3 .korfu-card-image,
.korfu-columns-4 .korfu-card-image {
    min-height: 0;
    height: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
}

.korfu-columns-2 .korfu-card-body,
.korfu-columns-3 .korfu-card-body,
.korfu-columns-4 .korfu-card-body {
    padding: 1.25rem;
}

.korfu-columns-2 .korfu-card-body {
    min-height: 420px;
}

.korfu-columns-3 .korfu-card-body,
.korfu-columns-4 .korfu-card-body {
    min-height: 390px;
}

.korfu-columns-2 .korfu-card-subtitle,
.korfu-columns-3 .korfu-card-subtitle,
.korfu-columns-4 .korfu-card-subtitle {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* keep facts readable in multi column */
.korfu-columns-2 .korfu-facts-grid,
.korfu-columns-3 .korfu-facts-grid,
.korfu-columns-4 .korfu-facts-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.korfu-columns-3 .korfu-facts-grid,
.korfu-columns-4 .korfu-facts-grid {
    grid-template-columns: 1fr;
}

.korfu-columns-2 .korfu-feature-icon,
.korfu-columns-3 .korfu-feature-icon,
.korfu-columns-4 .korfu-feature-icon {
    font-size: 0.86rem;
    padding: 0.5rem 0.62rem;
}

@media (max-width: 1100px) {
    .korfu-columns-1 .korfu-accommodation-card {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .korfu-filter-bar {
        align-items: stretch;
    }

    .korfu-filter-group,
    .korfu-filter-buttons {
        width: 100%;
    }

    .korfu-filter-group {
        justify-content: space-between;
    }

    .korfu-filter-group select {
        flex: 1;
    }

    .korfu-filter-chip,
    .korfu-filter-reset {
        flex: 1 1 calc(50% - 0.55rem);
    }

    .korfu-columns-2 .korfu-card-body,
    .korfu-columns-3 .korfu-card-body,
    .korfu-columns-4 .korfu-card-body {
        min-height: 0;
    }
}

@media (max-width: 640px) {
    .korfu-columns-1 .korfu-card-media,
    .korfu-columns-1 .korfu-card-image,
    .korfu-columns-2 .korfu-card-media,
    .korfu-columns-2 .korfu-card-image,
    .korfu-columns-3 .korfu-card-media,
    .korfu-columns-3 .korfu-card-image,
    .korfu-columns-4 .korfu-card-media,
    .korfu-columns-4 .korfu-card-image {
        min-height: 0;
        aspect-ratio: 4 / 3;
    }

    .korfu-columns-2 .korfu-facts-grid,
    .korfu-columns-3 .korfu-facts-grid,
    .korfu-columns-4 .korfu-facts-grid {
        grid-template-columns: 1fr;
    }
}


/* v1.5.0 – refined basis data, location and lightbox */
.korfu-basis-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 34%);
    gap: 1rem;
    align-items: stretch;
    margin: 0 0 1.4rem;
}

.korfu-basis-copy,
.korfu-location-card {
    padding: 1.3rem;
    border-radius: 20px;
    background: linear-gradient(135deg, rgba(255,255,255,0.96), rgba(246,239,227,0.68));
    border: 1px solid rgba(30,115,190,0.13);
    box-shadow: 0 12px 30px rgba(7,59,92,0.07);
}

.korfu-mini-label,
.korfu-location-card small {
    display: block;
    margin-bottom: 0.35rem;
    color: var(--korfu-blue);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.korfu-location-card {
    display: flex;
    gap: 0.85rem;
    align-items: center;
}

.korfu-location-icon {
    width: 46px;
    height: 46px;
    min-width: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 15px;
    color: var(--korfu-blue);
    background: rgba(30,115,190,0.09);
}

.korfu-location-icon svg {
    width: 30px;
    height: 30px;
}

.korfu-location-card strong {
    display: block;
    color: var(--korfu-blue-dark);
    line-height: 1.25;
}

.korfu-gallery-grid a {
    position: relative;
    cursor: zoom-in;
}

.korfu-gallery-grid a::after {
    content: "＋";
    position: absolute;
    right: 0.7rem;
    bottom: 0.7rem;
    width: 34px;
    height: 34px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: rgba(255,255,255,0.92);
    color: var(--korfu-blue-dark);
    font-weight: 800;
    box-shadow: 0 6px 16px rgba(7,59,92,0.18);
}

.korfu-lightbox {
    position: fixed;
    inset: 0;
    z-index: 99999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: clamp(1rem, 4vw, 3rem);
    background: rgba(3, 25, 40, 0.86);
}

.korfu-lightbox[aria-hidden="false"] {
    display: flex;
}

body.korfu-lightbox-open {
    overflow: hidden;
}

.korfu-lightbox figure {
    margin: 0;
    max-width: min(1100px, 92vw);
    max-height: 88vh;
    display: grid;
    gap: 0.75rem;
    justify-items: center;
}

.korfu-lightbox img {
    max-width: 100%;
    max-height: 78vh;
    object-fit: contain;
    border-radius: 18px;
    box-shadow: 0 24px 70px rgba(0,0,0,0.35);
    background: #fff;
}

.korfu-lightbox figcaption {
    color: #fff;
    text-align: center;
    font-weight: 600;
}

.korfu-lightbox-close,
.korfu-lightbox-prev,
.korfu-lightbox-next {
    position: absolute;
    border: 0;
    border-radius: 999px;
    background: rgba(255,255,255,0.94);
    color: var(--korfu-blue-dark);
    cursor: pointer;
    box-shadow: 0 12px 26px rgba(0,0,0,0.22);
}

.korfu-lightbox-close {
    top: 1.2rem;
    right: 1.2rem;
    width: 46px;
    height: 46px;
    font-size: 2rem;
    line-height: 1;
}

.korfu-lightbox-prev,
.korfu-lightbox-next {
    top: 50%;
    width: 52px;
    height: 52px;
    transform: translateY(-50%);
    font-size: 2.4rem;
    line-height: 1;
}

.korfu-lightbox-prev { left: 1.2rem; }
.korfu-lightbox-next { right: 1.2rem; }

/* Settings page */
.korfu-settings-grid {
    display: grid;
    gap: 18px;
    max-width: 1100px;
    margin-top: 18px;
}

.korfu-settings-card {
    padding: 18px 20px;
    border: 1px solid #dcdcde;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 1px 2px rgba(0,0,0,.04);
}

.korfu-shortcode-list {
    display: grid;
    gap: 12px;
}

.korfu-shortcode-row {
    padding: 12px;
    border-radius: 10px;
    background: #f6f7f7;
    border: 1px solid #dcdcde;
}

.korfu-shortcode-row code {
    display: inline-block;
    margin-bottom: 4px;
    font-size: 13px;
}

.korfu-shortcode-row p {
    margin: 0;
}

@media (max-width: 800px) {
    .korfu-basis-panel {
        grid-template-columns: 1fr;
    }

    .korfu-lightbox-prev,
    .korfu-lightbox-next {
        bottom: 1.2rem;
        top: auto;
        transform: none;
    }
}


/* v1.5.2 – improved compact layout for 3+ columns */
.korfu-columns-3,
.korfu-columns-4 {
    align-items: stretch;
}

/* Let 3/4 column grids breathe and avoid overly narrow cards */
.korfu-columns-3 {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.korfu-columns-4 {
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

/* 3+ columns: compact card style */
.korfu-columns-3 .korfu-accommodation-card,
.korfu-columns-4 .korfu-accommodation-card {
    border-radius: 20px;
    min-height: 0;
    box-shadow: 0 14px 34px rgba(7,59,92,0.09);
}

.korfu-columns-3 .korfu-card-media,
.korfu-columns-4 .korfu-card-media,
.korfu-columns-3 .korfu-card-image,
.korfu-columns-4 .korfu-card-image {
    aspect-ratio: 16 / 10;
}

.korfu-columns-3 .korfu-card-body,
.korfu-columns-4 .korfu-card-body {
    min-height: 0 !important;
    padding: 1rem;
    gap: 0.75rem;
}

.korfu-columns-3 .korfu-card-body h3,
.korfu-columns-4 .korfu-card-body h3 {
    font-size: clamp(1.2rem, 1.7vw, 1.45rem);
    line-height: 1.15;
}

/* Shorter text in compact cards */
.korfu-columns-3 .korfu-card-subtitle,
.korfu-columns-4 .korfu-card-subtitle {
    font-size: 0.92rem;
    line-height: 1.45;
    -webkit-line-clamp: 2;
}

/* Facts become compact badges in 3/4 columns */
.korfu-columns-3 .korfu-facts-grid,
.korfu-columns-4 .korfu-facts-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 0.42rem;
}

.korfu-columns-3 .korfu-fact,
.korfu-columns-4 .korfu-fact {
    min-height: 0 !important;
    flex: 0 1 auto;
    gap: 0.38rem;
    padding: 0.42rem 0.55rem;
    border-radius: 999px;
    background: rgba(30,115,190,0.075);
}

.korfu-columns-3 .korfu-fact-icon,
.korfu-columns-4 .korfu-fact-icon {
    width: 22px;
    height: 22px;
    min-width: 22px;
}

.korfu-columns-3 .korfu-fact-icon svg,
.korfu-columns-4 .korfu-fact-icon svg {
    width: 18px;
    height: 18px;
}

.korfu-columns-3 .korfu-fact strong,
.korfu-columns-4 .korfu-fact strong {
    display: inline;
    font-size: 0.82rem;
    line-height: 1;
}

.korfu-columns-3 .korfu-fact small,
.korfu-columns-4 .korfu-fact small {
    display: none;
}

/* Equipment chips become smaller in compact views */
.korfu-columns-3 .korfu-feature-icons,
.korfu-columns-4 .korfu-feature-icons {
    gap: 0.4rem;
}

.korfu-columns-3 .korfu-feature-icon,
.korfu-columns-4 .korfu-feature-icon {
    min-height: 0;
    gap: 0.3rem;
    padding: 0.4rem 0.52rem;
    font-size: 0.78rem;
    border-radius: 999px;
}

.korfu-columns-3 .korfu-feature-icon svg,
.korfu-columns-4 .korfu-feature-icon svg {
    width: 17px;
    height: 17px;
}

/* Keep CTA button compact but clear */
.korfu-columns-3 .korfu-card-button,
.korfu-columns-4 .korfu-card-button {
    width: 100%;
    margin-top: 0.25rem;
    padding: 0.65rem 0.85rem;
    font-size: 0.9rem;
}

/* On narrower screens, 3/4 column views naturally become 2/1 columns */
@media (max-width: 980px) {
    .korfu-columns-3,
    .korfu-columns-4 {
        grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    }
}

@media (max-width: 640px) {
    .korfu-columns-3,
    .korfu-columns-4 {
        grid-template-columns: 1fr;
    }

    .korfu-columns-3 .korfu-card-body,
    .korfu-columns-4 .korfu-card-body {
        padding: 1.1rem;
    }

    .korfu-columns-3 .korfu-fact small,
    .korfu-columns-4 .korfu-fact small {
        display: block;
    }

    .korfu-columns-3 .korfu-fact,
    .korfu-columns-4 .korfu-fact {
        border-radius: 14px;
    }
}


/* v1.5.3 – fixed real width for 3/4 columns
   Previous auto-fit made a single card stretch full width. */
.korfu-accommodations-grid.korfu-columns-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

.korfu-accommodations-grid.korfu-columns-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

/* If only one accommodation exists, keep it card-sized instead of full width. */
.korfu-accommodations-grid.korfu-columns-3:has(.korfu-accommodation-card:first-child:last-child) {
    grid-template-columns: minmax(280px, 360px) !important;
    justify-content: start;
}

.korfu-accommodations-grid.korfu-columns-4:has(.korfu-accommodation-card:first-child:last-child) {
    grid-template-columns: minmax(250px, 340px) !important;
    justify-content: start;
}

/* If two cards are shown in a 3/4-column shortcode, don't stretch them full width. */
.korfu-accommodations-grid.korfu-columns-3:has(.korfu-accommodation-card:nth-child(2):last-child),
.korfu-accommodations-grid.korfu-columns-4:has(.korfu-accommodation-card:nth-child(2):last-child) {
    grid-template-columns: repeat(2, minmax(260px, 360px)) !important;
    justify-content: start;
}

@media (max-width: 1180px) {
    .korfu-accommodations-grid.korfu-columns-4 {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 980px) {
    .korfu-accommodations-grid.korfu-columns-3,
    .korfu-accommodations-grid.korfu-columns-4 {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .korfu-accommodations-grid.korfu-columns-3:has(.korfu-accommodation-card:first-child:last-child),
    .korfu-accommodations-grid.korfu-columns-4:has(.korfu-accommodation-card:first-child:last-child) {
        grid-template-columns: minmax(280px, 420px) !important;
    }
}

@media (max-width: 640px) {
    .korfu-accommodations-grid.korfu-columns-3,
    .korfu-accommodations-grid.korfu-columns-4,
    .korfu-accommodations-grid.korfu-columns-3:has(.korfu-accommodation-card:first-child:last-child),
    .korfu-accommodations-grid.korfu-columns-4:has(.korfu-accommodation-card:first-child:last-child),
    .korfu-accommodations-grid.korfu-columns-3:has(.korfu-accommodation-card:nth-child(2):last-child),
    .korfu-accommodations-grid.korfu-columns-4:has(.korfu-accommodation-card:nth-child(2):last-child) {
        grid-template-columns: 1fr !important;
    }
}


/* v1.6.1 – final robust column layout override
   1 column = wide horizontal card
   2 columns = balanced card grid
   3/4 columns = compact card grid, never full-width-looking */
.korfu-accommodations-wrap .korfu-accommodations-grid {
    width: 100%;
}

/* remove inherited oversized min-heights in compact views */
.korfu-accommodations-wrap .korfu-accommodations-grid.korfu-columns-3,
.korfu-accommodations-wrap .korfu-accommodations-grid.korfu-columns-4 {
    display: grid !important;
    align-items: start !important;
    justify-items: stretch !important;
    gap: 1.15rem !important;
}

/* Fixed real columns on desktop */
@media (min-width: 1181px) {
    .korfu-accommodations-wrap .korfu-accommodations-grid.korfu-columns-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }

    .korfu-accommodations-wrap .korfu-accommodations-grid.korfu-columns-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    }
}

/* Medium desktop/tablet */
@media (min-width: 821px) and (max-width: 1180px) {
    .korfu-accommodations-wrap .korfu-accommodations-grid.korfu-columns-3,
    .korfu-accommodations-wrap .korfu-accommodations-grid.korfu-columns-4 {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

/* Mobile */
@media (max-width: 820px) {
    .korfu-accommodations-wrap .korfu-accommodations-grid.korfu-columns-3,
    .korfu-accommodations-wrap .korfu-accommodations-grid.korfu-columns-4 {
        grid-template-columns: 1fr !important;
    }
}

/* Compact card base for 3/4 column views */
.korfu-accommodations-wrap .korfu-columns-3 .korfu-accommodation-card,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-accommodation-card {
    width: 100% !important;
    max-width: none !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    min-height: 0 !important;
    border-radius: 18px !important;
    overflow: hidden !important;
}

/* Image ratio more compact in 3/4 */
.korfu-accommodations-wrap .korfu-columns-3 .korfu-card-media,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-card-media {
    width: 100% !important;
    min-height: 0 !important;
    height: auto !important;
    aspect-ratio: 16 / 10 !important;
}

.korfu-accommodations-wrap .korfu-columns-3 .korfu-card-image,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-card-image {
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    aspect-ratio: 16 / 10 !important;
    object-fit: cover !important;
}

/* Compact body */
.korfu-accommodations-wrap .korfu-columns-3 .korfu-card-body,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-card-body {
    min-height: 0 !important;
    padding: 0.95rem !important;
    gap: 0.65rem !important;
}

.korfu-accommodations-wrap .korfu-columns-3 .korfu-card-body h3,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-card-body h3 {
    margin: 0 !important;
    font-size: 1.22rem !important;
    line-height: 1.15 !important;
}

/* Hide long intro in 4 columns, shorter intro in 3 */
.korfu-accommodations-wrap .korfu-columns-3 .korfu-card-subtitle {
    margin: 0 !important;
    font-size: 0.9rem !important;
    line-height: 1.4 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.korfu-accommodations-wrap .korfu-columns-4 .korfu-card-subtitle {
    display: none !important;
}

/* Facts as ultra-compact chips */
.korfu-accommodations-wrap .korfu-columns-3 .korfu-facts-grid,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-facts-grid {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 0.35rem !important;
    margin: 0 !important;
}

.korfu-accommodations-wrap .korfu-columns-3 .korfu-fact,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-fact {
    display: inline-flex !important;
    align-items: center !important;
    flex: 0 1 auto !important;
    width: auto !important;
    min-height: 0 !important;
    gap: 0.32rem !important;
    padding: 0.35rem 0.48rem !important;
    border-radius: 999px !important;
    background: rgba(30,115,190,0.075) !important;
}

.korfu-accommodations-wrap .korfu-columns-3 .korfu-fact-icon,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-fact-icon {
    width: 19px !important;
    height: 19px !important;
    min-width: 19px !important;
}

.korfu-accommodations-wrap .korfu-columns-3 .korfu-fact-icon svg,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-fact-icon svg {
    width: 16px !important;
    height: 16px !important;
}

.korfu-accommodations-wrap .korfu-columns-3 .korfu-fact strong,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-fact strong {
    display: inline !important;
    font-size: 0.78rem !important;
    line-height: 1 !important;
}

.korfu-accommodations-wrap .korfu-columns-3 .korfu-fact small,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-fact small {
    display: none !important;
}

/* Equipment chips: show fewer visual weight */
.korfu-accommodations-wrap .korfu-columns-3 .korfu-feature-icons,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-feature-icons {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 0.32rem !important;
    margin: 0 !important;
}

.korfu-accommodations-wrap .korfu-columns-3 .korfu-feature-icon,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-feature-icon {
    width: auto !important;
    min-height: 0 !important;
    flex: 0 1 auto !important;
    gap: 0.25rem !important;
    padding: 0.34rem 0.46rem !important;
    font-size: 0.74rem !important;
    border-radius: 999px !important;
}

.korfu-accommodations-wrap .korfu-columns-3 .korfu-feature-icon svg,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-feature-icon svg {
    width: 15px !important;
    height: 15px !important;
}

/* In 4 columns, reduce equipment list text pressure */
@media (min-width: 1181px) {
    .korfu-accommodations-wrap .korfu-columns-4 .korfu-feature-icon:nth-child(n+5) {
        display: none !important;
    }
}

/* Button */
.korfu-accommodations-wrap .korfu-columns-3 .korfu-card-button,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-card-button {
    width: 100% !important;
    margin-top: 0.15rem !important;
    padding: 0.62rem 0.75rem !important;
    font-size: 0.88rem !important;
}

/* Avoid lonely 1/2 results stretching after filter in compact views */
.korfu-accommodations-wrap .korfu-columns-3 .korfu-accommodation-card:not([hidden]),
.korfu-accommodations-wrap .korfu-columns-4 .korfu-accommodation-card:not([hidden]) {
    max-width: 100% !important;
}


/* v1.6.2 – equal-height accommodation cards */
.korfu-accommodations-wrap .korfu-accommodations-grid {
    align-items: stretch !important;
}

.korfu-accommodations-wrap .korfu-accommodation-card {
    height: 100% !important;
    align-self: stretch !important;
}

/* Vertical card layouts: same row height + button aligned at bottom */
.korfu-accommodations-wrap .korfu-columns-2 .korfu-accommodation-card,
.korfu-accommodations-wrap .korfu-columns-3 .korfu-accommodation-card,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-accommodation-card {
    display: grid !important;
    grid-template-rows: auto 1fr !important;
}

.korfu-accommodations-wrap .korfu-columns-2 .korfu-card-body,
.korfu-accommodations-wrap .korfu-columns-3 .korfu-card-body,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-card-body {
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
}

.korfu-accommodations-wrap .korfu-columns-2 .korfu-card-button,
.korfu-accommodations-wrap .korfu-columns-3 .korfu-card-button,
.korfu-accommodations-wrap .korfu-columns-4 .korfu-card-button {
    margin-top: auto !important;
}

/* Give compact layouts a stable base height so rows look calmer */
@media (min-width: 981px) {
    .korfu-accommodations-wrap .korfu-columns-3 .korfu-card-body {
        min-height: 315px !important;
    }

    .korfu-accommodations-wrap .korfu-columns-4 .korfu-card-body {
        min-height: 285px !important;
    }
}

/* 2-column cards can be slightly taller because there is more room */
@media (min-width: 821px) {
    .korfu-accommodations-wrap .korfu-columns-2 .korfu-card-body {
        min-height: 400px !important;
    }
}

/* On mobile, avoid artificial height */
@media (max-width: 820px) {
    .korfu-accommodations-wrap .korfu-columns-2 .korfu-card-body,
    .korfu-accommodations-wrap .korfu-columns-3 .korfu-card-body,
    .korfu-accommodations-wrap .korfu-columns-4 .korfu-card-body {
        min-height: 0 !important;
    }
}


/* v1.7.0 – booking request form */
.korfu-booking-form-wrap {
    margin: 2rem 0;
}

.korfu-booking-message {
    margin-bottom: 1.2rem;
    padding: 1rem 1.15rem;
    border-radius: 16px;
    font-weight: 700;
}

.korfu-booking-message-success {
    background: rgba(46, 125, 50, 0.11);
    color: #1b5e20;
}

.korfu-booking-message-missing,
.korfu-booking-message-captcha,
.korfu-booking-message-spam,
.korfu-booking-message-mail {
    background: rgba(198, 40, 40, 0.1);
    color: #8f1d1d;
}

.korfu-booking-form {
    display: grid;
    gap: 1.4rem;
}

.korfu-booking-section {
    padding: clamp(1.1rem, 2vw, 1.6rem);
    border-radius: 22px;
    background: linear-gradient(135deg, rgba(255,255,255,0.97), rgba(246,239,227,0.72));
    border: 1px solid rgba(30,115,190,0.13);
    box-shadow: 0 14px 34px rgba(7,59,92,0.08);
}

.korfu-booking-section h2 {
    margin-top: 0;
    color: var(--korfu-blue-dark);
}

.korfu-booking-section h3 {
    margin: 1.1rem 0 0.7rem;
    color: var(--korfu-blue-dark);
}

.korfu-booking-grid,
.korfu-settings-fields {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.95rem;
}

.korfu-booking-form label,
.korfu-settings-fields label {
    display: grid;
    gap: 0.35rem;
    color: var(--korfu-blue-dark);
    font-weight: 700;
}

.korfu-booking-form input,
.korfu-booking-form select,
.korfu-booking-form textarea,
.korfu-settings-fields input,
.korfu-settings-fields textarea {
    width: 100%;
    min-height: 46px;
    padding: 0.78rem 0.9rem;
    border: 1px solid rgba(30,115,190,0.22);
    border-radius: 14px;
    background: #fff;
    color: var(--korfu-blue-dark);
    font: inherit;
}

.korfu-booking-form textarea,
.korfu-settings-fields textarea {
    min-height: 120px;
}

.korfu-booking-full,
.korfu-settings-full {
    grid-column: 1 / -1;
}

.korfu-booking-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 0.9rem;
}

.korfu-booking-accommodation-card {
    position: relative;
    display: grid !important;
    gap: 0;
    overflow: hidden;
    border: 2px solid rgba(30,115,190,0.14);
    border-radius: 18px;
    background: #fff;
    cursor: pointer;
    transition: border-color .18s ease, transform .18s ease, box-shadow .18s ease;
}

.korfu-booking-accommodation-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(7,59,92,0.12);
}

.korfu-booking-accommodation-card input {
    position: absolute;
    opacity: 0;
    inset: 0;
    pointer-events: none;
}

.korfu-booking-accommodation-card:has(input:checked) {
    border-color: var(--korfu-blue);
    box-shadow: 0 0 0 4px rgba(30,115,190,0.10);
}

.korfu-booking-card-image {
    display: block;
    aspect-ratio: 4 / 3;
    background: rgba(30,115,190,0.08);
}

.korfu-booking-card-image img,
.korfu-booking-accommodation-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    min-height: 0;
}

.korfu-booking-card-copy {
    display: grid;
    gap: 0.25rem;
    padding: 0.85rem;
}

.korfu-booking-card-copy strong {
    color: var(--korfu-blue-dark);
}

.korfu-booking-card-copy small {
    color: #5f7887;
    font-weight: 500;
    line-height: 1.35;
}

.korfu-booking-interests {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin: 0 0 1rem;
    padding: 0;
    border: 0;
}

.korfu-booking-interests legend {
    width: 100%;
    margin-bottom: 0.35rem;
    color: var(--korfu-blue-dark);
    font-weight: 800;
}

.korfu-booking-interests label,
.korfu-consent {
    display: flex !important;
    align-items: flex-start;
    gap: 0.55rem;
    padding: 0.65rem 0.8rem;
    border-radius: 14px;
    background: #fff;
    border: 1px solid rgba(30,115,190,0.12);
    font-weight: 600 !important;
}

.korfu-booking-interests input,
.korfu-consent input {
    width: auto;
    min-height: 0;
    margin-top: 0.2rem;
}

.korfu-captcha {
    max-width: 280px;
    margin-bottom: 1rem;
}

.korfu-booking-privacy-note {
    color: #647887;
    font-size: 0.92rem;
    margin: 0;
}

.korfu-booking-submit {
    justify-self: start;
    border: 0;
    border-radius: 999px;
    padding: 0.9rem 1.35rem;
    background: var(--korfu-blue);
    color: #fff;
    font-weight: 800;
    cursor: pointer;
    box-shadow: 0 14px 28px rgba(30,115,190,0.22);
}

.korfu-hp-fields {
    position: absolute;
    left: -10000px;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.korfu-admin-status {
    display: inline-block;
    padding: 0.25rem 0.55rem;
    border-radius: 999px;
    font-weight: 700;
    font-size: 12px;
}

.korfu-admin-status.is-active {
    background: #e7f7ed;
    color: #176c35;
}

.korfu-admin-status.is-inactive {
    background: #f5e8e8;
    color: #9b2525;
}

@media (max-width: 720px) {
    .korfu-booking-grid,
    .korfu-settings-fields {
        grid-template-columns: 1fr;
    }

    .korfu-booking-submit {
        width: 100%;
    }
}
