/* ==========================================================================
   Page Scoped Utilities (safe with main.css)
   Everything is scoped under main.container to avoid collisions
   ========================================================================== */

main.container {
    --page-max: 1120px;
    --gap-xxs: .375rem;
    --gap-xs: .5rem;
    --gap-sm: .75rem;
    --gap-md: 1rem;
    --gap-lg: 1.5rem;
    --gap-xl: 2rem;
    --radius-sm: .5rem;
    --radius-md: .75rem;
    --radius-lg: 1rem;
    --chip-bg: #eef6ff;
    --chip-text: #2b4a66;
    --pill-bg: #eef4f7;
    --card-bg: #ffffff;
    --muted: #5b6671;
    --border: #e7edf2;
    --shadow-sm: 0 1px 2px rgba(16, 24, 40, .06);
    --shadow-md: 0 6px 20px rgba(16, 24, 40, .08);
    --brand: #1e66f5;        /* Buttons/links (adjust to your palette) */
    --brand-600: #1754c7;
}

main.container {
    max-width: var(--page-max);
    margin-inline: auto;
    padding: var(--gap-xl) var(--gap-md) var(--gap-xxl, 4rem);
}

/* Headings & text rhythm */
main.container h1 {
    line-height: 1.15;
    letter-spacing: -0.02em;
    margin: 0 0 var(--gap-lg);
}
main.container h2 {
    line-height: 1.2;
    letter-spacing: -0.01em;
    margin: 0 0 var(--gap-md);
}
main.container p {
    color: var(--muted);
    margin: 0 0 var(--gap-md);
}

/* ==========================================================================
   Reusable "media-card" section (image + text + actions)
   Use this for restaurants, places, guides, etc.
   ========================================================================== */

main.container .media-card {
    display: grid;
    grid-template-columns: 360px minmax(0, 1fr);
    gap: var(--gap-xl) var(--gap-xl);
    align-items: start;
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--gap-xl);
    margin: var(--gap-xl) 0;
    box-shadow: var(--shadow-sm);
}

/* Image – never stretches the full height */
main.container .media-card > img {
    width: 100%;
    height: auto;
    max-width: 560px;                 /* cap large images nicely */
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    display: block;
}

/* Place the first paragraph (subtitle) next to the image neatly */
main.container .media-card > p:first-of-type {
    grid-column: 2;
    margin-top: var(--gap-xs);
}

/* Chip row (your “⭐ … • 🌍 … • 💶 …” line works fine as a <ul>) */
main.container .media-card ul {
    grid-column: 2;
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap-xs) var(--gap-sm);
    list-style: none;
    padding: 0;
    margin: var(--gap-sm) 0 0;
    color: var(--muted);
}
main.container .media-card ul li::marker { content: ""; }

/* Small tags/pills under the list */
main.container .tag {
    display: inline-block;
    grid-column: 2;
    background: var(--chip-bg);
    color: var(--chip-text);
    font: 500 .85rem/1.1 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    padding: .5rem .75rem;
    border-radius: 999px;
    margin: var(--gap-sm) var(--gap-sm) 0 0;
}

/* Quote pill */
main.container blockquote {
    grid-column: 2;
    margin: var(--gap-md) 0 0;
    padding: .9rem 1rem;
    border-radius: var(--radius-md);
    background: var(--pill-bg);
    border: 1px solid var(--border);
    color: #1d2630;
    quotes: "“" "”";
}
main.container blockquote::before { content: open-quote; }
main.container blockquote::after { content: close-quote; }

/* Primary CTA */
main.container .button-link {
    grid-column: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: .9rem 1.2rem;
    width: min(540px, 100%);
    border-radius: .75rem;
    text-decoration: none;
    font-weight: 600;
    color: #fff;
    background: var(--brand);
    box-shadow: var(--shadow-sm);
    border: 1px solid color-mix(in oklab, var(--brand) 85%, #000 15%);
    margin-top: var(--gap-md);
    transition: transform .05s ease, background .15s ease;
}
main.container .button-link:hover { background: var(--brand-600); }
main.container .button-link:active { transform: translateY(1px); }

/* Long description paragraph at the end of the card */
main.container .media-card > p:last-of-type {
    grid-column: 2;
    margin-top: var(--gap-lg);
}

/* ==========================================================================
   Generic sections (intro, tables, FAQ, map, etc.)
   ========================================================================== */

main.container .intro {
    background: #f7fbff;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--gap-lg);
    margin-bottom: var(--gap-xl);
}

/* “Guide / comparison” tables */
main.container table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    margin: var(--gap-lg) 0;
}
main.container thead th {
    background: #f6f8fb;
    text-align: left;
    padding: .9rem 1rem;
    font-weight: 600;
    border-bottom: 1px solid var(--border);
}
main.container tbody td {
    padding: .9rem 1rem;
    border-top: 1px solid var(--border);
}

/* FAQ blocks */
main.container .faq {
    display: grid;
    gap: var(--gap-md);
    padding: var(--gap-lg);
    background: #f8fbfc;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
}

/* Map iframe */
main.container .map iframe {
    width: 100%;
    height: 420px;
    border: 0;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
}

/* Tighten vertical rhythm in generic sections */
main.container section {
    margin: var(--gap-xl) 0;
}

/* ==========================================================================
   Responsive
   ========================================================================== */

@media (max-width: 1024px) {
    main.container .media-card {
        grid-template-columns: 320px minmax(0, 1fr);
        gap: var(--gap-lg);
        padding: var(--gap-lg);
    }
}

@media (max-width: 780px) {
    main.container {
        padding-inline: var(--gap-md);
    }
    main.container .media-card {
        grid-template-columns: 1fr;
    }
    main.container .media-card > img,
    main.container .media-card > p,
    main.container .media-card ul,
    main.container .media-card .tag,
    main.container .media-card blockquote,
    main.container .media-card .button-link,
    main.container .media-card > p:last-of-type {
        grid-column: 1;
    }
    main.container .button-link {
        width: 100%;
    }
}

/* ================================
   Simple stacked card layout
   (matches the reference screenshot)
   Apply with: .media-card.stacked
   ================================ */

main.container .media-card.stacked{
    display: block;                   /* kill the two-column grid */
    gap: 0;
    padding: 1.25rem 1.25rem 1.5rem;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
    background: var(--card-bg);
    box-shadow: var(--shadow-sm);
    margin: var(--gap-xl) 0;
}

/* Heading spacing */
main.container .media-card.stacked > h2{
    margin: 0 0 .75rem;
}

/* Hero image full width */
main.container .media-card.stacked > img{
    display: block;
    width: 100%;
    height: auto;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    margin: .5rem 0 1rem;
}

/* Subtitle/intro paragraph under the image */
main.container .media-card.stacked > p:first-of-type{
    margin: 0 0 1rem;
    color: var(--muted);
}

/* Normal bullets, left-aligned */
main.container .media-card.stacked ul{
    display: block;
    list-style: disc;
    padding-left: 1.25rem;
    margin: 0 0 .75rem;
    color: var(--muted);
}
main.container .media-card.stacked ul li{ margin: .25rem 0; }

/* Small inline tags line */
main.container .media-card.stacked .tag{
    background: var(--chip-bg);
    color: var(--chip-text);
    font: 500 .85rem/1.1 system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
    padding: .4rem .65rem;
    border-radius: 999px;
    margin: .25rem .5rem 0 0;
}

/* Slim left-bar quote (clean, airy) */
main.container .media-card.stacked blockquote{
    background: #fff;
    border: 1px solid var(--border);
    border-left: 4px solid #e6eef7;
    border-radius: .5rem;
    padding: .85rem 1rem;
    margin: .85rem 0 1rem;
    color: #1d2630;
    quotes: "“" "”";
}
main.container .media-card.stacked blockquote::before{ content: open-quote; }
main.container .media-card.stacked blockquote::after{ content: close-quote; }

/* Compact primary button, left aligned */
main.container .media-card.stacked .button-link{
    display: inline-flex;
    width: auto;
    min-width: 8.5rem;
    padding: .6rem 1rem;
    border-radius: .5rem;
    margin: .25rem 0 1rem;
    background: var(--brand);
}
main.container .media-card.stacked .button-link:hover{
    background: var(--brand-600);
}

/* Closing/long paragraph */
main.container .media-card.stacked > p:last-of-type{
    margin: .75rem 0 0;
    color: var(--muted);
}

/* Tighten vertical rhythm between pieces inside stacked cards */
main.container .media-card.stacked > * + *{
    margin-top: .25rem;
}

/* Mobile – stacked already looks good; just ensure full width button if needed */
@media (max-width: 780px){
    main.container .media-card.stacked .button-link{ width: 100%; }
}
/* Accordion Styles */
.accordion {
    border-radius: var(--radius-md);
    overflow: hidden;
    border: 1px solid var(--border);
    background: var(--card-bg);
    box-shadow: var(--shadow-sm);
}

.accordion-item + .accordion-item {
    border-top: 1px solid var(--border);
}

.accordion-header {
    width: 100%;
    padding: 1rem;
    background: #f8f9fa;
    border: none;
    outline: none;
    text-align: left;
    font-weight: 600;
    font-size: 1rem;
    cursor: pointer;
    transition: background 0.2s ease;
}

.accordion-header:hover {
    background: #eef1f4;
}

.accordion-header::after {
    content: '+';
    float: right;
    font-size: 1.2rem;
    transition: transform 0.2s ease;
}

.accordion-item.active .accordion-header::after {
    content: '−';
}

.accordion-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, padding 0.3s ease;
    background: #fff;
    padding: 0 1rem;
}

.accordion-item.active .accordion-content {
    max-height: 500px; /* large enough to fit text */
    padding: 1rem;
}
/* Media card wrapper */
.media-card.stacked {
    background: #fff;
    border: 1px solid #e8eff5;
    border-radius: 20px;
    padding: clamp(16px, 2vw, 24px);
}

/* Image wrapper: enforces consistent aspect ratio */
.media-card.stacked .card-image {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;       /* change to 4/3 or 3/2 if you want taller */
    overflow: hidden;
    border-radius: 16px;
    background: #f6f7f9;
    margin-bottom: 1rem;        /* space under the image */
}

/* Image: fills the wrapper cleanly */
.media-card.stacked .card-image img {
    position: absolute;
    inset: 0;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;          /* crops edges, no distortion */
    object-position: center;
    display: block;
    border-radius: 16px;
}

/* Fallback if aspect-ratio is unsupported */
@supports not (aspect-ratio: 16 / 9) {
    .media-card.stacked .card-image {
        height: 320px;            /* fixed height as backup */
    }
}
/* Wrapper for filters */
.filter-ui {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem;
    font-size: 1rem;
    margin: 1rem 0;
}

/* Label (e.g. "Filter by:") */
.filter-ui strong {
    margin-right: 0.5rem;
    color: #222;
    font-weight: 600;
}

/* Individual filter links */
.filter-ui a {
    display: inline-block;
    padding: 6px 12px;
    border-radius: 20px;
    background: #f6f7f9;
    color: #0056d6;
    text-decoration: none;
    font-weight: 500;
    transition: all 0.2s ease;
}

/* Hover effect */
.filter-ui a:hover {
    background: #0056d6;
    color: #fff;
}

/* Active/selected filter */
.filter-ui a.active {
    background: #0056d6;
    color: #fff;
    font-weight: 600;
}

/* Responsive tweaks */
@media (max-width: 600px) {
    .filter-ui {
        gap: 0.4rem;
        font-size: 0.9rem;
    }
    .filter-ui a {
        padding: 5px 10px;
    }
}

/* ===== Breadcrumbs ===== */
.breadcrumbs {
    font-size: clamp(.85rem, 1.6vw, .95rem);
    color: var(--frc-muted, #5b6775);
    margin: 1rem 0 1.25rem;
}

.breadcrumbs ol {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .5rem;
    list-style: none;
    padding: 0;
    margin: 0;
}

.breadcrumbs li {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
}


/* Links */
.breadcrumbs a {
    color: var(--frc-ink, #0f1720);
    text-decoration: none;
    font-weight: 600;
}
.breadcrumbs a:hover {
    text-decoration: underline;
}

/* Current page crumb (last) */
.breadcrumbs [aria-current="page"] {
    color: var(--frc-ink, #0f1720);
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: min(65vw, 720px);
}

/* Optional: subtle pill background on hover for better touch targets */
@media (hover:hover) {
    .breadcrumbs a {
        border-radius: 8px;
        padding: 2px 6px;
        transition: background-color .15s ease;
    }
    .breadcrumbs a:hover {
        background: rgba(15, 23, 32, .06);
    }
}
.breadcrumbs ol {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.breadcrumbs li::after {
    content: "›"; /* separator */
    margin: 0 0.1rem;
    color: #888;
}

.breadcrumbs li:last-child::after {
    content: ""; /* no separator after last item */
}

.breadcrumbs a {
    color: #007c91; /* link color */
    text-decoration: none;
}

.breadcrumbs a:hover {
    text-decoration: underline;
}

/* ✅ Special style for last breadcrumb */
.breadcrumbs li[aria-current="page"] {
    color: #ff6600;        /* your orange brand color */
    font-weight: bold;
}
