/* =============================================
   holyrood-seat-proj.css - Holyrood Seat Projections
   Scoped under body.holyrood-seat-proj, prefix: hsp-
   Requires: editorial-base.css + polls-editorial.css
   ============================================= */

body.holyrood-seat-proj {
    background: var(--ed-color-surface);
    font-family: var(--ed-font-sans);
    color: var(--ed-color-body);
    -webkit-font-smoothing: antialiased;
}

.hsp-wrap {
    padding: 48px 32px 64px;
}

/* ---- Masthead ---- */
.hsp-masthead { margin-bottom: 32px; max-width: 700px; }
.hsp-kicker {
    font-family: var(--ed-font-sans);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ed-color-text);
    margin: 0 0 8px 0;
}
.hsp-masthead-rule {
    border: none;
    border-top: 3px solid var(--ed-color-text);
    margin: 0 0 16px 0;
}
.hsp-headline {
    font-family: var(--ed-font-serif);
    font-size: 32px;
    font-weight: 700;
    color: var(--ed-color-text);
    line-height: 1.15;
    margin: 0 0 6px 0;
}
.hsp-subtitle {
    font-family: var(--ed-font-sans);
    font-size: 14px;
    color: var(--ed-color-secondary);
    margin: 0;
    line-height: 1.5;
}

/* ---- Section dividers ---- */
.hsp-rule {
    border: none;
    border-top: 1px solid var(--ed-color-border);
    margin: 40px 0;
}

.hsp-section-label {
    font-family: var(--ed-font-sans);
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--ed-color-meta);
    margin: 0 0 16px 0;
}

/* ---- Links ---- */
.hsp-wrap a {
    color: var(--ed-color-text);
    text-decoration: underline;
    text-decoration-color: #CCCCCC;
    text-underline-offset: 2px;
    transition: text-decoration-color 0.15s;
}
.hsp-wrap a:hover { text-decoration-color: var(--ed-color-text); }

/* ---- Holyrood Hub Navigation ---- */
.hsp-hub-nav {
    display: flex;
    gap: 0;
    margin-bottom: 24px;
    border-bottom: 2px solid var(--ed-color-border);
}
.hsp-hub-nav a {
    padding: 10px 20px;
    font-family: var(--ed-font-sans);
    font-size: 13px;
    font-weight: 500;
    color: var(--ed-color-meta);
    text-decoration: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: all 0.15s;
}
.hsp-hub-nav a:hover {
    color: var(--ed-color-body);
    text-decoration: none;
}
.hsp-hub-nav a.is-active {
    color: var(--ed-color-text);
    font-weight: 700;
    border-bottom: 2px solid var(--ed-color-text);
}

/* ---- Tabs (editorial restyle) ---- */
body.holyrood-seat-proj .tab-buttons {
    display: flex;
    gap: 0;
    margin-bottom: 16px;
    border-bottom: 2px solid var(--ed-color-primary);
}
body.holyrood-seat-proj .tab-btn {
    padding: 8px 16px;
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    cursor: pointer;
    font-family: var(--ed-font-sans);
    font-size: 12px;
    font-weight: 500;
    color: var(--ed-color-meta);
    transition: all 0.15s;
    margin-bottom: -2px;
}
body.holyrood-seat-proj .tab-btn:hover {
    color: var(--ed-color-body);
}
body.holyrood-seat-proj .tab-btn.active {
    color: var(--ed-color-text);
    border-bottom-color: var(--ed-color-text);
    font-weight: 700;
}
body.holyrood-seat-proj .tab-content {
    display: none;
}
body.holyrood-seat-proj .tab-content.active {
    display: block;
}

/* ---- Chart container (editorial restyle) ---- */
body.holyrood-seat-proj .chart-container {
    background: var(--ed-color-surface);
    border: 1px solid var(--ed-color-border);
    padding: 2rem;
    margin-bottom: 2rem;
    position: relative;
    border-radius: 0;
    box-shadow: none;
}
body.holyrood-seat-proj .chart-container canvas {
    display: block;
    width: 100% !important;
    height: auto !important;
}

/* ---- Selected poll card (editorial restyle) ---- */
body.holyrood-seat-proj .recent-poll-card.selected {
    outline: 2px solid var(--ed-color-text);
    box-shadow: none;
}

/* ---- Snapshot bar (trend summary - editorial restyle) ---- */
body.holyrood-seat-proj .snapshot-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    margin-bottom: 4px;
    padding: 0;
    border: none;
    background: transparent;
    box-shadow: none;
    border-radius: 0;
}

/* ---- Majority / Coalition boxes (editorial restyle) ---- */
body.holyrood-seat-proj #hrsp-majority-box {
    border-radius: 0 !important;
    background: var(--ed-color-bg) !important;
    border: none !important;
    border-left: 3px solid var(--ed-color-positive) !important;
    padding: 12px 20px !important;
    font-family: var(--ed-font-sans) !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--ed-color-text) !important;
}
body.holyrood-seat-proj #hrsp-coalition {
    border-radius: 0 !important;
    background: var(--ed-color-bg) !important;
    border: 1px solid var(--ed-color-border) !important;
    padding: 16px 20px !important;
}
body.holyrood-seat-proj #hrsp-coalition > div:first-child {
    font-family: var(--ed-font-sans) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    color: var(--ed-color-meta) !important;
}

/* ---- Map iframes (editorial restyle) ---- */
body.holyrood-seat-proj .hsp-map-frame {
    height: 600px;
    border: 1px solid var(--ed-color-border);
    overflow: hidden;
}

/* ---- Map legend (editorial restyle) ---- */
.hsp-map-legend {
    margin-top: 12px;
    font-family: var(--ed-font-sans);
    font-size: 12px;
    color: var(--ed-color-secondary);
    text-align: center;
}
.hsp-map-legend-items {
    display: inline-flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
    justify-content: center;
}
.hsp-map-legend-label {
    font-weight: 600;
    margin-right: 4px;
    color: var(--ed-color-meta);
}
.hsp-map-legend-item {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.hsp-map-legend-swatch {
    display: inline-block;
    width: 14px;
    height: 14px;
    border: 1px solid var(--ed-color-border);
}

/* ---- Share section (editorial restyle) ---- */
body.holyrood-seat-proj #hrsp-share-section {
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid var(--ed-color-border);
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}
body.holyrood-seat-proj #hrsp-share-section > span:first-child {
    font-family: var(--ed-font-sans);
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--ed-color-meta);
}

/* ---- Latest Projection heading ---- */
body.holyrood-seat-proj .hsp-latest-heading {
    font-family: var(--ed-font-sans);
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--ed-color-meta);
    margin: 18px 0 16px 0;
}

/* ---- Responsive ---- */
@media (max-width: 768px) {
    .hsp-wrap { padding: 32px 16px 48px; }
    .hsp-headline { font-size: 26px; }
    .hsp-rule { margin: 32px 0; }
    .hsp-hub-nav a { font-size: 12px; padding: 8px 14px; }
    body.holyrood-seat-proj .hsp-map-frame { height: 450px; }
}

@media (max-width: 480px) {
    .hsp-headline { font-size: 24px; }
    .hsp-rule { margin: 24px 0; }
    .hsp-hub-nav a { font-size: 11px; padding: 8px 10px; }
    body.holyrood-seat-proj .hsp-map-frame { height: 350px; }
}
