/* Summary Page — Market Analysis */

.summary-container {
    height: calc(100vh - 52px);
    overflow-y: auto;
    padding: 24px 32px;
    background: var(--bg-body);
}

/* Hero Stats Banner */
.summary-hero { display: flex; gap: 16px; margin-bottom: 32px; }

.hero-card {
    flex: 1; background: var(--bg-panel);
    border: 1px solid var(--border-color); border-radius: 10px;
    padding: 20px 16px; text-align: center;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.hero-card.accent {
    background: linear-gradient(135deg, #ede9fe, #f3e8ff);
    border-color: var(--gh-purple);
}
.hero-value { font-size: 28px; font-weight: 800; color: var(--text-primary); margin-bottom: 4px; }
.hero-card.accent .hero-value { color: var(--gh-purple); }
.hero-label {
    font-size: 11px; color: var(--text-muted);
    text-transform: uppercase; letter-spacing: 0.5px; font-weight: 600;
}

/* Table Sections */
.table-section {
    background: var(--bg-panel); border: 1px solid var(--border-color);
    border-radius: 10px; margin-bottom: 32px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04); overflow: hidden;
}
.table-header { padding: 20px 24px 12px; border-bottom: 1px solid var(--border-color); }
.table-header h2 { font-size: 16px; font-weight: 700; color: var(--text-primary); margin-bottom: 4px; }
.table-header p { font-size: 12px; color: var(--text-muted); margin: 0; }
.table-scroll { overflow-x: auto; max-height: 70vh; position: relative; }

/* Summary Tables */
.summary-table { width: 100%; border-collapse: collapse; font-size: 11px; white-space: nowrap; }
.summary-table thead { position: sticky; top: 0; z-index: 20; }
.summary-table th {
    padding: 8px 10px; background: #f1f0fb; border: 1px solid var(--border-color);
    font-size: 10px; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.3px; color: #4338ca; text-align: left;
}
.summary-table td { padding: 6px 10px; border: 1px solid var(--border-color); vertical-align: middle; }
.summary-table tbody tr:hover { background: var(--bg-card-hover); }
.summary-table .num { text-align: right; font-variant-numeric: tabular-nums; }
.summary-table .rent { color: var(--competitor-green); font-weight: 600; }
.summary-table .na { color: var(--text-muted); font-size: 10px; }

.sticky-col {
    position: sticky; left: 0; z-index: 10;
    background: var(--bg-panel);
    border-right: 2px solid var(--border-color) !important;
}
thead .sticky-col { background: #f1f0fb; z-index: 30; }
tfoot .sticky-col { background: #faf9fe; z-index: 10; }

.name-cell { font-weight: 600; max-width: 200px; overflow: hidden; text-overflow: ellipsis; }
.submarket-cell, .dev-cell {
    max-width: 160px; overflow: hidden; text-overflow: ellipsis;
    font-size: 10px; color: var(--text-secondary);
}
.score-cell { font-weight: 700; color: var(--gh-purple) !important; }

/* Tier dots */
.tier-dot {
    display: inline-block; font-size: 9px; font-weight: 700;
    padding: 1px 6px; border-radius: 3px; text-transform: uppercase;
}
.tier-dot.t1 { background: rgba(220,38,38,0.1); color: #dc2626; }
.tier-dot.t2 { background: rgba(217,119,6,0.1); color: #d97706; }
.tier-dot.t3 { background: rgba(156,163,175,0.15); color: #6b7280; }
.tier-dot.hp { background: var(--gh-purple-bg); color: var(--gh-purple); font-weight: 800; }

/* Status dots */
.status-dot {
    font-size: 9px; font-weight: 600; padding: 1px 6px;
    border-radius: 10px; text-transform: capitalize;
}
.status-dot.st-delivered { background: rgba(5,150,105,0.1); color: #059669; }
.status-dot.st-construction { background: rgba(217,119,6,0.1); color: #d97706; }
.status-dot.st-planned { background: rgba(156,163,175,0.15); color: #6b7280; }

/* GH rows */
.hp-summary-row { border-top: 3px solid var(--gh-purple) !important; }
.hp-summary-row td { background: #faf5ff !important; }
.hp-summary-row .sticky-col { background: #faf5ff !important; }
.hp-name { color: var(--gh-purple); font-weight: 700; }
.hp-val { color: var(--gh-purple) !important; font-weight: 700 !important; }

/* Totals */
.totals-row td { background: #faf9fe; font-size: 12px; border-top: 2px solid var(--gh-purple); }
.cumulative-row td { background: #f5f3ff; font-size: 11px; color: var(--text-secondary); }

/* Statistical Analysis Panels */
.stats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; padding: 24px; }
.stat-panel {
    background: var(--bg-panel); border: 1px solid var(--border-color);
    border-radius: 8px; overflow: hidden;
}
.stat-panel-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 12px 16px; background: #f8f7fe; border-bottom: 1px solid var(--border-color);
}
.stat-panel-header h3 { font-size: 14px; font-weight: 700; color: var(--gh-purple); margin: 0; }
.stat-panel-header h4 { font-size: 12px; font-weight: 700; color: var(--text-secondary); margin: 0; }
.data-count {
    font-size: 10px; color: var(--text-muted);
    background: var(--bg-card); padding: 2px 8px; border-radius: 10px;
}

.stat-summary-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 1px;
    background: var(--border-color); border-bottom: 1px solid var(--border-color);
}
.mini-stat { background: var(--bg-panel); padding: 12px 16px; text-align: center; }
.mini-label {
    font-size: 9px; text-transform: uppercase; letter-spacing: 0.5px;
    color: var(--text-muted); margin-bottom: 4px; font-weight: 600;
}
.mini-value { font-size: 18px; font-weight: 800; color: var(--text-primary); }

.stat-detail-table { width: 100%; border-collapse: collapse; font-size: 11px; }
.stat-detail-table th {
    padding: 6px 12px; background: var(--bg-card); border: 1px solid var(--border-color);
    font-size: 9px; font-weight: 700; text-transform: uppercase; color: var(--text-muted); text-align: left;
}
.stat-detail-table td { padding: 5px 12px; border: 1px solid var(--border-color); }
.stat-detail-table .num { text-align: right; font-variant-numeric: tabular-nums; }
.stat-detail-table .rent { color: var(--competitor-green); font-weight: 600; }
.hp-stat-row td { background: #faf5ff; color: var(--gh-purple); font-weight: 600; }

.property-list-table { max-height: 300px; display: block; overflow-y: auto; }
.property-list-table thead, .property-list-table tbody, .property-list-table tr {
    display: table; width: 100%; table-layout: fixed;
}
.property-list-table thead { position: sticky; top: 0; z-index: 5; }

/* Timeline Table */
.timeline-table th.year-col { text-align: center; min-width: 70px; }
.timeline-table .hp-year { background: rgba(124,58,237,0.06) !important; }
thead .hp-year { background: rgba(124,58,237,0.15) !important; color: var(--gh-purple) !important; }
.timeline-cell { text-align: center; }
.timeline-cell.filled { background: rgba(5,150,105,0.06); font-weight: 600; }
.hp-summary-row .timeline-cell.filled { background: rgba(124,58,237,0.12) !important; }

/* Footer */
.summary-footer {
    text-align: center; padding: 16px; font-size: 11px;
    color: var(--text-muted); font-style: italic;
}

/* Scrollbar */
.summary-container::-webkit-scrollbar, .table-scroll::-webkit-scrollbar, .property-list-table::-webkit-scrollbar { width: 6px; height: 6px; }
.summary-container::-webkit-scrollbar-track, .table-scroll::-webkit-scrollbar-track { background: transparent; }
.summary-container::-webkit-scrollbar-thumb, .table-scroll::-webkit-scrollbar-thumb { background: #d1d5db; border-radius: 3px; }

/* Sortable Headers */
.sortable-th { cursor: pointer; user-select: none; transition: background 0.15s; }
.sortable-th:hover { background: #e0dff5 !important; }

/* CSV Export Button (summary page) */
.table-header .csv-btn {
    background: var(--bg-card); color: var(--text-secondary);
    border: 1px solid var(--border-color); border-radius: 4px;
    padding: 6px 14px; font-size: 11px; font-weight: 700;
    cursor: pointer; font-family: inherit;
    text-transform: uppercase; letter-spacing: 0.5px;
    transition: all 0.15s; white-space: nowrap; flex-shrink: 0;
}
.table-header .csv-btn:hover {
    background: var(--gh-purple-bg); color: var(--gh-purple); border-color: var(--gh-purple);
}

/* Source links in summary tables */
.summary-table a.src-link, .stat-detail-table a.src-link { color: inherit; }

@media (max-width: 1200px) {
    .stats-grid { grid-template-columns: 1fr; }
    .summary-hero { flex-wrap: wrap; }
    .hero-card { min-width: 150px; }
}
