/* Vancouver Island — guide, parks, news */

.island-page { padding-bottom: 3rem; }

.island-hero {
    text-align: center;
    margin-bottom: 2.5rem;
    padding: 2.5rem 1rem;
    background: linear-gradient(135deg, var(--color-primary-light) 0%, var(--color-surface) 60%);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
}
.island-hero--compact { padding: 1.5rem 1rem; }
.island-hero__eyebrow {
    font-size: .85rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--color-primary);
    margin-bottom: .5rem;
}
.island-hero h1 {
    font-family: var(--font-display);
    font-size: clamp(1.75rem, 4vw, 2.75rem);
    margin-bottom: .75rem;
}
.island-hero p {
    color: var(--color-text-muted);
    max-width: 680px;
    margin: 0 auto 1.25rem;
    font-size: 1.05rem;
}
.island-hero__actions {
    display: flex;
    gap: .75rem;
    justify-content: center;
    flex-wrap: wrap;
}
.island-hero__stats-inline {
    display: flex;
    gap: 1.5rem;
    justify-content: center;
    flex-wrap: wrap;
    font-weight: 600;
    color: var(--color-primary);
    font-size: .9rem;
}

.island-breadcrumb {
    font-size: .85rem;
    color: var(--color-text-muted);
    margin-bottom: 1rem;
    text-align: left;
}
.island-breadcrumb a { color: var(--color-primary); }

.island-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1rem;
    margin-bottom: 2.5rem;
}
.island-stat {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1.25rem;
    text-align: center;
    box-shadow: var(--shadow);
}
.island-stat__value {
    font-family: var(--font-display);
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--color-primary);
    line-height: 1.1;
}
.island-stat__label { font-weight: 600; margin-top: .35rem; }
.island-stat__note { font-size: .8rem; color: var(--color-text-muted); margin-top: .2rem; }

.island-section { margin-bottom: 2.5rem; }
.island-section h2 {
    font-family: var(--font-display);
    font-size: 1.5rem;
    margin-bottom: .75rem;
}
.island-section__intro {
    color: var(--color-text-muted);
    max-width: 720px;
    margin-bottom: 1.25rem;
}
.island-section__cta {
    text-align: center;
    margin-top: 1.5rem;
    display: flex;
    gap: .75rem;
    justify-content: center;
    flex-wrap: wrap;
}

.island-facts {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}
.island-fact {
    display: flex;
    gap: .75rem;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1rem;
}
.island-fact__icon { flex-shrink: 0; display: flex; align-items: center; }
.island-fact strong { display: block; margin-bottom: .2rem; }
.island-fact p { font-size: .9rem; color: var(--color-text-muted); margin: 0; }

.island-dimensions {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 1rem;
}
.island-dimension {
    background: var(--color-primary-light);
    border-radius: var(--radius-sm);
    padding: 1rem;
    text-align: center;
}
.island-dimension__value { font-family: var(--font-display); font-size: 1.35rem; font-weight: 700; color: var(--color-primary); }
.island-dimension__label { font-weight: 600; font-size: .9rem; }
.island-dimension__note { font-size: .75rem; color: var(--color-text-muted); }

.island-centers {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1rem;
}
.island-center-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1.25rem;
    box-shadow: var(--shadow);
}
.island-center-card__head {
    display: flex;
    align-items: center;
    gap: .5rem;
    margin-bottom: .35rem;
}
.island-center-card__icon { display: flex; align-items: center; }
.island-center-card h3 { font-family: var(--font-display); font-size: 1.1rem; margin: 0; }
.island-center-card__tag { font-weight: 600; color: var(--color-primary); font-size: .85rem; margin-bottom: .25rem; }
.island-center-card__pop { font-size: .8rem; color: var(--color-text-muted); margin-bottom: .5rem; }
.island-center-card p:last-child { font-size: .9rem; color: var(--color-text-muted); margin: 0; }

.island-highlights {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
}
.island-highlight-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1.25rem;
}
.island-highlight-card h3 {
    font-family: var(--font-display);
    font-size: 1.05rem;
    margin-bottom: .75rem;
    display: flex;
    align-items: center;
    gap: .5rem;
}
.island-highlight-card ul { margin: 0; padding-left: 1.1rem; }
.island-highlight-card li { font-size: .9rem; color: var(--color-text-muted); margin-bottom: .35rem; }

.island-section--weather .island-seasons {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 1rem;
    margin-bottom: 1.25rem;
}
.island-season {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1.25rem 1rem;
    text-align: center;
}
.island-season__icon { display: flex; justify-content: center; margin-bottom: .35rem; }
.island-season h3 { font-size: 1rem; margin-bottom: .25rem; }
.island-season__temp { font-weight: 700; color: var(--color-primary); margin-bottom: .35rem; }
.island-season p { font-size: .8rem; color: var(--color-text-muted); margin: 0; }

.island-climate-bar {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1rem;
    background: linear-gradient(135deg, var(--color-primary) 0%, #5b4bb7 100%);
    color: #fff;
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    text-align: center;
}
.island-climate-bar__value { font-family: var(--font-display); font-size: 1.5rem; font-weight: 700; }
.island-climate-bar p { font-size: .8rem; opacity: .9; margin: .25rem 0 0; }

.island-regions {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1rem;
}
.island-region-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1.25rem;
}
.island-region-card h3 {
    font-family: var(--font-display);
    margin-bottom: .5rem;
    display: flex;
    align-items: center;
    gap: .5rem;
}
.island-region-card > p { font-size: .9rem; color: var(--color-text-muted); margin-bottom: 1rem; }
.island-region-card__cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    font-size: .85rem;
    margin-bottom: 1rem;
}
.island-region-card ul { margin: .35rem 0 0; padding-left: 1rem; color: var(--color-text-muted); }

.island-park-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 1rem;
}
.island-park-card {
    display: block;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1.25rem;
    box-shadow: var(--shadow);
    transition: border-color .15s, box-shadow .15s, transform .15s;
}
.island-park-card:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
}
.island-park-card__icon { display: flex; margin-bottom: .5rem; }
.island-park-card h3 {
    font-family: var(--font-display);
    font-size: 1rem;
    color: var(--color-text);
    margin-bottom: .35rem;
}
.island-park-card p { font-size: .85rem; color: var(--color-text-muted); margin: 0; line-height: 1.45; }
.island-park-card__region {
    display: inline-block;
    margin-top: .65rem;
    font-size: .7rem;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--color-primary);
    background: var(--color-primary-light);
    padding: .2rem .5rem;
    border-radius: 999px;
}

.island-fun-facts__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: .75rem;
}
.island-fun-facts__list li {
    background: var(--color-primary-light);
    border-radius: var(--radius-sm);
    padding: .85rem 1rem;
    font-size: .95rem;
    font-weight: 500;
}

/* News */
.island-news-filters {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-bottom: 1.5rem;
}
.island-news-filters .btn { display: inline-flex; align-items: center; gap: .35rem; }
.island-news-list { display: grid; gap: 1rem; margin-bottom: 2.5rem; }
.island-news-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1.25rem;
    box-shadow: var(--shadow);
}
.island-news-card__meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: .5rem;
    font-size: .8rem;
    color: var(--color-text-muted);
    margin-bottom: .5rem;
}
.island-news-card__source { font-weight: 600; color: var(--color-primary); display: inline-flex; align-items: center; gap: .35rem; }
.island-news-card h2 { font-family: var(--font-display); font-size: 1.15rem; margin-bottom: .5rem; }
.island-news-card h2 a { color: var(--color-text); }
.island-news-card h2 a:hover { color: var(--color-primary); }
.island-news-card p { font-size: .9rem; color: var(--color-text-muted); margin-bottom: .75rem; }
.island-news-card__read { font-size: .85rem; font-weight: 600; color: var(--color-primary); }

.island-news-sources h2 { font-family: var(--font-display); margin-bottom: 1rem; }
.island-sources-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 1rem;
}
.island-source-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 1rem;
    text-align: center;
}
.island-source-card__icon { display: flex; justify-content: center; margin-bottom: .35rem; }
.island-source-card h3 { font-size: .95rem; margin-bottom: .25rem; }
.island-source-card p { font-size: .8rem; color: var(--color-text-muted); margin: 0; }

/* Park detail */
.island-park-hero {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.5rem;
}
.island-park-hero__icon { display: flex; align-items: center; flex-shrink: 0; }
.island-park-hero__region {
    font-size: .8rem;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--color-primary);
    margin-bottom: .25rem;
}
.island-park-hero h1 { font-family: var(--font-display); font-size: clamp(1.5rem, 3vw, 2.25rem); margin-bottom: .35rem; }
.island-park-hero__tagline { color: var(--color-text-muted); font-size: 1.05rem; margin: 0; }

.island-park-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-bottom: 2rem;
}
.island-park-stat {
    background: var(--color-primary-light);
    border-radius: var(--radius-sm);
    padding: .75rem 1.25rem;
    text-align: center;
    min-width: 100px;
}
.island-park-stat__value { font-family: var(--font-display); font-weight: 700; color: var(--color-primary); }
.island-park-stat__label { font-size: .75rem; color: var(--color-text-muted); }

.island-park-content {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 2rem;
    align-items: start;
}
@media (max-width: 768px) {
    .island-park-content { grid-template-columns: 1fr; }
}
.island-park-main h2 { font-family: var(--font-display); font-size: 1.35rem; margin-bottom: .75rem; }
.island-park-main h3 { font-family: var(--font-display); font-size: 1.1rem; margin: 1.5rem 0 .75rem; }
.island-park-main p { color: var(--color-text-muted); line-height: 1.65; margin-bottom: 1rem; }

.island-activities {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 1rem;
}
.island-activity {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 1rem;
}
.island-activity h4 { font-size: .95rem; margin-bottom: .35rem; }
.island-activity p { font-size: .85rem; color: var(--color-text-muted); margin: 0; }

.island-sidebar-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1.25rem;
    margin-bottom: 1rem;
}
.island-sidebar-card h3 { font-family: var(--font-display); font-size: 1rem; margin-bottom: .75rem; }
.island-sidebar-card p { font-size: .9rem; color: var(--color-text-muted); margin-bottom: .75rem; }
.btn--block { display: block; width: 100%; text-align: center; margin-bottom: .5rem; }
