/**
 * Music Index Embed & Shortcode Styles — v2.3.0
 * Light/Dark theme support via [data-mi-theme]
 */

/* ═══════════════════════════════════════════
   CSS VARIABLES — LIGHT THEME (default)
   ═══════════════════════════════════════════ */
[data-mi-theme="light"], :root {
    --mi-bg:          #ffffff;
    --mi-bg-alt:      #f8f9fa;
    --mi-bg-hover:    #f0f1f3;
    --mi-border:      #e2e5e9;
    --mi-text:        #1a1d21;
    --mi-text-sec:    #616670;
    --mi-text-muted:  #9ca3af;
    --mi-accent:      #b87333;
    --mi-accent-soft: rgba(184, 115, 51, 0.12);
    --mi-green:       #22c55e;
    --mi-red:         #ef4444;
    --mi-blue:        #3b82f6;
    --mi-rank-bg:     #f59e0b;
    --mi-rank-text:   #ffffff;
    --mi-shadow:      0 1px 3px rgba(0,0,0,0.08);
    --mi-radius:      8px;
    --mi-radius-sm:   4px;
    --mi-font:        -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

/* ═══════════════════════════════════════════
   CSS VARIABLES — DARK THEME
   ═══════════════════════════════════════════ */
[data-mi-theme="dark"] {
    --mi-bg:          #1a1d21;
    --mi-bg-alt:      #22262b;
    --mi-bg-hover:    #2a2f35;
    --mi-border:      #363b42;
    --mi-text:        #e8eaed;
    --mi-text-sec:    #9ca3af;
    --mi-text-muted:  #6b7280;
    --mi-accent:      #d4956b;
    --mi-accent-soft: rgba(212, 149, 107, 0.15);
    --mi-shadow:      0 1px 3px rgba(0,0,0,0.3);
}

/* ═══════════════════════════════════════════
   BASE / RESET
   ═══════════════════════════════════════════ */
.mi-sc {
    font-family: var(--mi-font);
    color: var(--mi-text);
    background: var(--mi-bg);
    border: 1px solid var(--mi-border);
    border-radius: var(--mi-radius);
    padding: 16px;
    box-shadow: var(--mi-shadow);
    line-height: 1.5;
    box-sizing: border-box;
}
.mi-sc *, .mi-sc *::before, .mi-sc *::after {
    box-sizing: border-box;
}

/* Embed body */
body.mi-embed {
    margin: 0;
    padding: 8px;
    background: transparent;
    min-height: auto;
}
body.mi-embed .mi-sc {
    border: none;
    box-shadow: none;
    padding: 0;
}

/* ═══════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════ */
.mi-sc-header {
    display: flex;
    align-items: baseline;
    gap: 10px;
    margin-bottom: 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--mi-border);
}
.mi-sc-title {
    margin: 0;
    font-size: 16px;
    font-weight: 700;
    color: var(--mi-text);
}
.mi-sc-subtitle {
    font-size: 12px;
    color: var(--mi-text-muted);
    font-weight: 400;
}
.mi-sc-empty {
    text-align: center;
    color: var(--mi-text-muted);
    padding: 24px 12px;
    font-size: 14px;
    margin: 0;
}
.mi-sc-muted {
    color: var(--mi-text-muted);
    font-style: italic;
}

/* ═══════════════════════════════════════════
   COVER IMAGE
   ═══════════════════════════════════════════ */
.mi-sc-cover {
    border-radius: var(--mi-radius-sm);
    object-fit: cover;
    flex-shrink: 0;
}
.mi-sc-cover-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--mi-bg-alt);
    color: var(--mi-text-muted);
    border-radius: var(--mi-radius-sm);
}
.mi-sc-cover-placeholder svg {
    width: 50%;
    height: 50%;
}

/* ═══════════════════════════════════════════
   NOW PLAYING — LIST LAYOUT
   ═══════════════════════════════════════════ */
.mi-sc-np-list .mi-sc-np-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--mi-border);
}
.mi-sc-np-list .mi-sc-np-item:last-child {
    border-bottom: none;
}
.mi-sc-np-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.mi-sc-np-station {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--mi-accent);
}
.mi-sc-np-song {
    font-size: 14px;
    font-weight: 600;
    color: var(--mi-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.mi-sc-np-artist {
    font-size: 13px;
    color: var(--mi-text-sec);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.mi-sc-np-time {
    font-size: 11px;
    color: var(--mi-text-muted);
    white-space: nowrap;
    flex-shrink: 0;
}

/* ═══════════════════════════════════════════
   NOW PLAYING — GRID LAYOUT
   ═══════════════════════════════════════════ */
.mi-sc-np-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 12px;
}
.mi-sc-np-grid .mi-sc-np-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px;
    background: var(--mi-bg-alt);
    border-radius: var(--mi-radius);
    border: 1px solid var(--mi-border);
}

/* ═══════════════════════════════════════════
   NOW PLAYING — COMPACT LAYOUT
   ═══════════════════════════════════════════ */
.mi-sc-np-compact .mi-sc-np-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 0;
    border-bottom: 1px solid var(--mi-border);
}
.mi-sc-np-compact .mi-sc-np-item:last-child {
    border-bottom: none;
}
.mi-sc-np-compact .mi-sc-np-station {
    font-size: 10px;
}
.mi-sc-np-compact .mi-sc-np-song {
    font-size: 13px;
}
.mi-sc-np-compact .mi-sc-np-artist {
    font-size: 12px;
}

/* ═══════════════════════════════════════════
   TOP SONGS
   ═══════════════════════════════════════════ */
.mi-sc-top-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 0;
    border-bottom: 1px solid var(--mi-border);
}
.mi-sc-top-item:last-child {
    border-bottom: none;
}
.mi-sc-rank {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 700;
    color: var(--mi-text-sec);
    background: var(--mi-bg-alt);
    border-radius: 50%;
    flex-shrink: 0;
}
.mi-sc-rank-top {
    background: var(--mi-rank-bg);
    color: var(--mi-rank-text);
}
.mi-sc-top-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.mi-sc-top-song {
    font-size: 14px;
    font-weight: 600;
    color: var(--mi-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.mi-sc-top-artist {
    font-size: 13px;
    color: var(--mi-text-sec);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.mi-sc-top-count {
    font-size: 14px;
    font-weight: 700;
    color: var(--mi-accent);
    white-space: nowrap;
    flex-shrink: 0;
}
.mi-sc-top-count small {
    font-weight: 400;
    font-size: 11px;
    color: var(--mi-text-muted);
}

/* ═══════════════════════════════════════════
   WEEKLY CHART
   ═══════════════════════════════════════════ */
.mi-sc-chart-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 0;
    border-bottom: 1px solid var(--mi-border);
}
.mi-sc-chart-item:last-child {
    border-bottom: none;
}
.mi-sc-pos {
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 700;
    color: var(--mi-text-sec);
    background: var(--mi-bg-alt);
    border-radius: var(--mi-radius-sm);
    flex-shrink: 0;
}
.mi-sc-pos-top {
    background: var(--mi-accent);
    color: #fff;
}
.mi-sc-move {
    font-size: 11px;
    width: 38px;
    text-align: center;
    flex-shrink: 0;
    font-weight: 600;
}
.mi-sc-move-up    { color: var(--mi-green); }
.mi-sc-move-down  { color: var(--mi-red); }
.mi-sc-move-new   { color: var(--mi-blue); font-size: 10px; }
.mi-sc-move-same  { color: var(--mi-text-muted); }

.mi-sc-chart-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.mi-sc-chart-song {
    font-size: 14px;
    font-weight: 600;
    color: var(--mi-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.mi-sc-chart-artist {
    font-size: 13px;
    color: var(--mi-text-sec);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.mi-sc-chart-plays {
    font-size: 13px;
    font-weight: 600;
    color: var(--mi-text-muted);
    flex-shrink: 0;
}

/* ═══════════════════════════════════════════
   SONG DETAIL
   ═══════════════════════════════════════════ */
.mi-sc-detail-card {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.mi-sc-detail-header {
    display: flex;
    gap: 16px;
    align-items: flex-start;
}
.mi-sc-detail-meta {
    flex: 1;
    min-width: 0;
}
.mi-sc-detail-title {
    margin: 0 0 4px;
    font-size: 18px;
    font-weight: 700;
    color: var(--mi-text);
}
.mi-sc-detail-artist {
    margin: 0 0 8px;
    font-size: 14px;
    color: var(--mi-text-sec);
}
.mi-sc-detail-stats {
    display: flex;
    gap: 16px;
    font-size: 13px;
    color: var(--mi-text-sec);
}
.mi-sc-detail-stats strong {
    color: var(--mi-accent);
}

/* Station breakdown */
.mi-sc-detail-stations h4 {
    margin: 0 0 8px;
    font-size: 13px;
    font-weight: 600;
    color: var(--mi-text-sec);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.mi-sc-detail-st-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 6px;
}
.mi-sc-detail-st-name {
    width: 120px;
    font-size: 13px;
    color: var(--mi-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex-shrink: 0;
}
.mi-sc-detail-st-bar {
    flex: 1;
    height: 6px;
    background: var(--mi-bg-alt);
    border-radius: 3px;
    overflow: hidden;
}
.mi-sc-detail-st-fill {
    height: 100%;
    background: var(--mi-accent);
    border-radius: 3px;
    transition: width 0.4s ease;
}
.mi-sc-detail-st-count {
    width: 36px;
    font-size: 12px;
    font-weight: 600;
    color: var(--mi-text-sec);
    text-align: right;
    flex-shrink: 0;
}

/* Daily timeline */
.mi-sc-detail-timeline h4 {
    margin: 0 0 8px;
    font-size: 13px;
    font-weight: 600;
    color: var(--mi-text-sec);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.mi-sc-detail-tl-chart {
    display: flex;
    align-items: flex-end;
    gap: 2px;
    height: 60px;
}
.mi-sc-detail-tl-bar {
    flex: 1;
    display: flex;
    align-items: flex-end;
    height: 100%;
    min-width: 4px;
}
.mi-sc-detail-tl-fill {
    width: 100%;
    background: var(--mi-accent);
    border-radius: 2px 2px 0 0;
    min-height: 2px;
    transition: height 0.4s ease;
}

/* ═══════════════════════════════════════════
   STATION STATUS
   ═══════════════════════════════════════════ */
.mi-sc-station-card {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.mi-sc-station-header {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.mi-sc-station-name-row {
    display: flex;
    align-items: center;
    gap: 10px;
}
.mi-sc-station-name {
    margin: 0;
    font-size: 18px;
    font-weight: 700;
    color: var(--mi-text);
}
.mi-sc-status-badge {
    font-size: 11px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 10px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.mi-sc-status-active {
    background: rgba(34, 197, 94, 0.12);
    color: var(--mi-green);
}
.mi-sc-status-inactive {
    background: rgba(239, 68, 68, 0.12);
    color: var(--mi-red);
}
.mi-sc-station-meta {
    margin: 0;
    font-size: 13px;
    color: var(--mi-text-sec);
}

/* Station current song */
.mi-sc-station-current h4,
.mi-sc-station-recent h4 {
    margin: 0 0 8px;
    font-size: 13px;
    font-weight: 600;
    color: var(--mi-text-sec);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.mi-sc-station-current-song {
    display: flex;
    align-items: center;
    gap: 12px;
}

/* Station recent */
.mi-sc-station-recent-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 5px 0;
    border-bottom: 1px solid var(--mi-border);
    font-size: 13px;
}
.mi-sc-station-recent-item:last-child {
    border-bottom: none;
}
.mi-sc-station-recent-time {
    font-size: 12px;
    color: var(--mi-text-muted);
    font-variant-numeric: tabular-nums;
    width: 42px;
    flex-shrink: 0;
}
.mi-sc-station-recent-song {
    font-weight: 600;
    color: var(--mi-text);
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.mi-sc-station-recent-artist {
    color: var(--mi-text-sec);
    white-space: nowrap;
    flex-shrink: 0;
}

/* Station stats */
.mi-sc-station-stats {
    font-size: 12px;
    color: var(--mi-text-muted);
    padding-top: 8px;
    border-top: 1px solid var(--mi-border);
}

/* ═══════════════════════════════════════════
   LIVE COUNTER
   ═══════════════════════════════════════════ */
.mi-sc-counter-row {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
}
.mi-sc-counter-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    min-width: 64px;
    padding: 8px 12px;
    background: var(--mi-bg-alt);
    border-radius: 8px;
}
.mi-sc-counter-value {
    font-size: 22px;
    font-weight: 700;
    color: var(--mi-accent);
    line-height: 1.2;
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.3px;
}
.mi-sc-counter-label {
    font-size: 11px;
    color: var(--mi-text-sec);
    font-weight: 500;
}

/* Compact counter */
.mi-sc-counter-compact {
    gap: 10px;
}
.mi-sc-counter-compact .mi-sc-counter-item {
    flex-direction: row;
    gap: 6px;
    min-width: auto;
    padding: 6px 10px;
}
.mi-sc-counter-compact .mi-sc-counter-value {
    font-size: 16px;
}
.mi-sc-counter-compact .mi-sc-counter-label {
    font-size: 11px;
}

/* ═══════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════ */
@media (max-width: 480px) {
    .mi-sc {
        padding: 12px;
    }
    .mi-sc-np-grid {
        grid-template-columns: 1fr;
    }
    .mi-sc-counter-row:not(.mi-sc-counter-compact) {
        flex-direction: column;
        align-items: center;
        gap: 12px;
    }
    .mi-sc-detail-header {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }
    .mi-sc-detail-stats {
        justify-content: center;
    }
    .mi-sc-detail-st-name {
        width: 80px;
        font-size: 12px;
    }
}

/* ═══════════════════════════════════════════
   LOADING / REFRESH INDICATOR
   ═══════════════════════════════════════════ */
.mi-sc-refreshing::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--mi-accent);
    animation: mi-loading 1.2s ease-in-out infinite;
}
.mi-sc {
    position: relative;
    overflow: hidden;
}

@keyframes mi-loading {
    0%   { transform: translateX(-100%); }
    50%  { transform: translateX(0); }
    100% { transform: translateX(100%); }
}

/* ═══════════════════════════════════════════════════════
   PORTAL APP — Phase 33: Premium Polish
   ═══════════════════════════════════════════════════════ */

/* Portal shell */
.mi-portal { font-family: var(--mi-font); color: var(--mi-text); }

/* Header */
.mi-portal-header-logo { height: 24px; width: auto; }
.mi-portal-header-brand { font-weight: 600; font-size: 15px; }
.mi-portal-header-user { font-size: 12px; color: var(--mi-text-sec); }
.mi-portal-header-logout { font-size: 12px; color: var(--mi-accent); text-decoration: none; }
.mi-portal-header-logout:hover { text-decoration: underline; }

/* KPI Grid — compact & smart */
.mi-portal-kpi-grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
    gap: 8px; margin-bottom: 16px;
}
.mi-portal-kpi {
    background: var(--mi-bg-alt);
    border-radius: 8px; padding: 10px 12px;
    border: 1px solid transparent;
}
.mi-portal-kpi-value { font-size: 20px; font-weight: 700; color: var(--mi-text); line-height: 1.2; letter-spacing: -0.3px; }
.mi-portal-kpi-label {
    font-size: 11px; color: var(--mi-text-sec);
    margin-top: 2px; font-weight: 500;
}

/* Status Bar */
.mi-portal-status-bar { display: flex; gap: 12px; margin-bottom: 16px; flex-wrap: wrap; }
.mi-portal-status-item {
    flex: 1; min-width: 200px; background: var(--mi-bg-alt);
    border-radius: var(--mi-radius); padding: 12px 16px;
    display: flex; align-items: center; gap: 10px;
}
.mi-portal-status-dot {
    width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0;
}
.mi-portal-status-label { font-size: 12px; font-weight: 600; }
.mi-portal-status-sub { font-size: 11px; color: var(--mi-text-muted); }

/* Cards */
.mi-portal-card {
    background: var(--mi-bg); border: 1px solid var(--mi-border);
    border-radius: var(--mi-radius); padding: 16px; margin-bottom: 16px;
}
.mi-portal-card-title {
    font-size: 14px; font-weight: 600; margin: 0 0 12px; color: var(--mi-text);
}

/* Station Health Grid */
.mi-portal-health-grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 8px;
}
.mi-portal-health-item {
    display: flex; align-items: center; gap: 8px;
    padding: 8px; background: var(--mi-bg-alt); border-radius: 6px;
}
.mi-portal-health-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.mi-portal-health-name {
    font-size: 12px; font-weight: 600;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.mi-portal-health-pct { font-size: 11px; color: var(--mi-text-muted); }

/* Tables */
.mi-portal-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.mi-portal-table thead tr { border-bottom: 1px solid var(--mi-border); }
.mi-portal-table th {
    text-align: left; padding: 6px 8px; font-size: 10px;
    color: var(--mi-text-muted); font-weight: 600;
}
.mi-portal-table td { padding: 8px; border-bottom: 1px solid var(--mi-bg-alt); }
.mi-portal-table-muted { color: var(--mi-text-sec); }
.mi-portal-table-bold { font-weight: 600; }

/* Section Titles */
.mi-portal-section-title {
    font-size: 14px; font-weight: 600; margin: 0 0 12px; color: var(--mi-text);
}
.mi-portal-help { font-size: 12px; color: var(--mi-text-muted); margin: -8px 0 16px; }

/* Station Page */
.mi-portal-station-grid { display: grid; grid-template-columns: 1fr; gap: 12px; }
.mi-portal-station-header { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.mi-portal-station-name { font-size: 15px; font-weight: 600; }
.mi-portal-station-freq { font-size: 12px; color: var(--mi-text-muted); }
.mi-portal-station-meta { font-size: 12px; color: var(--mi-text-muted); margin-left: auto; }
.mi-portal-station-kpis {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
    gap: 8px; margin-bottom: 10px;
}
.mi-portal-station-kpi {
    text-align: center; padding: 8px;
    background: var(--mi-bg-alt); border-radius: 6px;
}
.mi-portal-station-kpi-val { font-size: 18px; font-weight: 700; }
.mi-portal-station-kpi-lbl { font-size: 10px; color: var(--mi-text-muted); }
.mi-portal-station-songs-label { font-size: 11px; color: var(--mi-text-muted); margin-bottom: 4px; }
.mi-portal-station-song-row {
    padding: 3px 0; display: flex; justify-content: space-between;
    border-bottom: 1px solid var(--mi-bg-alt); font-size: 12px;
}
.mi-portal-station-song-plays { color: var(--mi-text-muted); }

/* Billing Banners */
.mi-portal-banner {
    border-radius: var(--mi-radius); padding: 14px 16px; margin-bottom: 16px;
    display: flex; align-items: flex-start; gap: 10px;
}
.mi-portal-banner-danger { background: #fee2e2; border: 1px solid #fecaca; }
.mi-portal-banner-warning { background: #fef3c7; border: 1px solid #fde68a; }
.mi-portal-banner-info { background: #dbeafe; border: 1px solid #bfdbfe; }
.mi-portal-banner-icon { font-size: 18px; flex-shrink: 0; }
.mi-portal-banner-title { font-weight: 600; font-size: 13px; }
.mi-portal-banner-desc { font-size: 12px; color: var(--mi-text-sec); }

/* Billing Plan Card */
.mi-portal-plan-card {
    background: var(--mi-bg-alt); border-radius: var(--mi-radius);
    padding: 20px; margin-bottom: 16px;
}
.mi-portal-plan-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.mi-portal-plan-label { font-size: 14px; font-weight: 600; }
.mi-portal-status-pill {
    display: inline-block; padding: 3px 10px; border-radius: 12px;
    font-size: 11px; font-weight: 600;
}
.mi-portal-progress-track { background: #e2e8f0; border-radius: 4px; height: 8px; overflow: hidden; }
.mi-portal-progress-fill { height: 100%; border-radius: 4px; transition: width 0.3s; }

/* Activity Toolbar & Filters */
.mi-portal-toolbar {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 16px; flex-wrap: wrap; gap: 8px;
}
.mi-portal-filters {
    display: flex; gap: 8px; margin-bottom: 12px; flex-wrap: wrap; align-items: center;
}
.mi-portal-select, .mi-portal-input {
    font-size: 12px; padding: 4px 8px;
    border: 1px solid var(--mi-border); border-radius: var(--mi-radius-sm);
    background: var(--mi-bg);
}
.mi-portal-input { width: 180px; }
.mi-portal-btn-filter {
    font-size: 12px; padding: 4px 12px;
    background: var(--mi-accent); color: #fff; border: none;
    border-radius: var(--mi-radius-sm); cursor: pointer;
}
.mi-portal-btn-filter:hover { opacity: 0.9; }
.mi-portal-link-clear { font-size: 12px; color: var(--mi-text-sec); text-decoration: none; }
.mi-portal-link-export {
    font-size: 12px; color: var(--mi-accent); text-decoration: none;
    display: inline-flex; align-items: center; gap: 4px;
}

/* Locked / Upgrade Sections */
.mi-portal-locked {
    text-align: center; padding: 40px 20px;
    background: var(--mi-bg-alt); border-radius: var(--mi-radius);
}
.mi-portal-locked-icon { margin-bottom: 12px; opacity: 0.4; }
.mi-portal-locked h4 { margin: 0 0 8px; font-size: 16px; }
.mi-portal-locked-desc { font-size: 13px; color: var(--mi-text-sec); margin: 0 0 16px; }
.mi-portal-btn-upgrade {
    display: inline-block; padding: 8px 20px;
    background: var(--mi-accent); color: #fff; text-decoration: none;
    border-radius: 6px; font-size: 13px; font-weight: 500; cursor: pointer; border: none;
}
.mi-portal-btn-upgrade:hover { opacity: 0.9; }
.mi-portal-upgrade-cta {
    text-align: center; padding: 20px;
    border: 1px dashed var(--mi-border); border-radius: var(--mi-radius);
}
.mi-portal-upgrade-cta p { font-size: 13px; color: var(--mi-text-sec); margin: 0 0 12px; }

/* Audit severity dot */
.mi-portal-sev-dot {
    display: inline-block; width: 8px; height: 8px;
    border-radius: 50%; margin-right: 6px;
}

/* Empty States */
.mi-portal-empty {
    display: flex; flex-direction: column; align-items: center;
    padding: 40px 20px; text-align: center; color: var(--mi-text-muted);
}
.mi-portal-empty-icon { opacity: 0.3; margin-bottom: 12px; }
.mi-portal-empty-title { font-size: 16px; font-weight: 600; color: var(--mi-text); margin-bottom: 6px; }
.mi-portal-empty-desc { font-size: 13px; max-width: 360px; }

/* Coming Soon Stubs */
.mi-portal-coming-soon {
    text-align: center; padding: 48px 20px;
    background: var(--mi-bg-alt); border-radius: var(--mi-radius);
}
.mi-portal-coming-soon-icon { opacity: 0.25; margin-bottom: 16px; }
.mi-portal-coming-soon-title { font-size: 16px; font-weight: 600; margin-bottom: 8px; color: var(--mi-text); }
.mi-portal-coming-soon-desc { font-size: 13px; color: var(--mi-text-sec); }

/* Onboarding Modal */
.mi-portal-onboarding-overlay {
    position: fixed; inset: 0; z-index: 9999;
    background: rgba(0,0,0,0.5);
    display: flex; align-items: center; justify-content: center;
}
.mi-portal-onboarding-modal {
    background: var(--mi-bg); border-radius: var(--mi-radius);
    max-width: 480px; width: 90%; padding: 32px;
    box-shadow: var(--mi-shadow); position: relative;
    text-align: center;
}
.mi-portal-onboarding-modal h3 { font-size: 18px; font-weight: 700; margin: 0 0 8px; }
.mi-portal-onboarding-modal p { font-size: 14px; color: var(--mi-text-sec); margin: 0; line-height: 1.6; }
.mi-portal-onboarding-step { display: none; }
.mi-portal-onboarding-step.active { display: block; }
.mi-portal-onboarding-progress {
    display: flex; gap: 6px; justify-content: center; margin-bottom: 24px;
}
.mi-portal-onboarding-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--mi-border); transition: background 0.2s;
}
.mi-portal-onboarding-dot.active { background: var(--mi-accent); }
.mi-portal-onboarding-actions {
    display: flex; justify-content: space-between; margin-top: 24px;
}
.mi-portal-onboarding-skip {
    position: absolute; top: 12px; right: 12px;
    background: none; border: none; color: var(--mi-text-muted);
    cursor: pointer; font-size: 12px;
}
.mi-portal-onboarding-skip:hover { color: var(--mi-text); }

/* Responsive */
@media (max-width: 480px) {
    .mi-portal-kpi-grid { grid-template-columns: 1fr 1fr; }
    .mi-portal-status-bar { flex-direction: column; }
    .mi-portal-toolbar { flex-direction: column; }
    .mi-portal-health-grid { grid-template-columns: 1fr; }
    .mi-portal-station-kpis { grid-template-columns: 1fr 1fr; }
    .mi-portal-onboarding-modal { padding: 20px; }
}
