/* ═══════════════════════════════════════
   DASHBOARD — Page Header
═══════════════════════════════════════ */
.page-header { margin-bottom: 26px; animation: fadeUp .4s ease both; }
.page-title  { font-size: 21px; font-weight: 800; letter-spacing: -.6px; }
.page-sub    { font-size: 13.5px; color: var(--txt2); margin-top: 4px; }

/* ═══════════════════════════════════════
   SUMMARY CARDS ROW (3-col grid)
═══════════════════════════════════════ */
.cards-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
    margin-bottom: 24px;
}

.summary-card {
    background: var(--card); border: 1px solid var(--border);
    border-radius: var(--r); padding: 22px; position: relative;
    overflow: hidden; transition: var(--t); cursor: default;
    animation: fadeUp .4s ease both;
}
.summary-card:first-child  { animation-delay: .08s; }
.summary-card:nth-child(2) { animation-delay: .14s; }
.summary-card:nth-child(3) { animation-delay: .20s; }

.summary-card::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
}
.summary-card:first-child::before  { background: linear-gradient(90deg, #4F46E5, #818CF8); }
.summary-card:nth-child(2)::before { background: linear-gradient(90deg, #F59E0B, #FCD34D); }
.summary-card:nth-child(3)::before { background: linear-gradient(90deg, #F97316, #FDBA74); }

.summary-card:hover { box-shadow: var(--shadow); transform: translateY(-2px); }

.sc-top   { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 14px; }
.sc-label { font-size: 11.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .7px; color: var(--txt2); }
.sc-icon  {
    width: 38px; height: 38px; border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
}
.sc-icon-indigo { background: var(--primary-light); color: var(--primary); }
.sc-icon-yellow { background: #FEF3C7; color: #D97706; }
.sc-icon-orange { background: #FFF7ED; color: #EA580C; }

.sc-value { font-size: 36px; font-weight: 800; letter-spacing: -2px; line-height: 1; margin-bottom: 8px; }

.sc-stars   { display: flex; gap: 2px; margin-bottom: 8px; }
.star       { font-size: 14px; color: var(--yellow); }
.star.off   { color: #D1D5DB; }

.sc-note  { font-size: 12px; color: var(--txt3); display: flex; align-items: center; gap: 4px; }
.pos-txt  { color: var(--green); font-weight: 600; }
.warn-txt { color: var(--orange); font-weight: 600; }

/* ═══════════════════════════════════════
   MAIN GRID (2-col: content + right col)
═══════════════════════════════════════ */
.main-grid {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 20px;
}

.right-col { display: flex; flex-direction: column; gap: 18px; }

/* ─── Chart ─── */
.chart-wrap   { padding: 18px 22px 14px; }
.chart-legend { display: flex; gap: 16px; margin-bottom: 14px; }
.legend-item  { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--txt2); font-weight: 500; }
.leg-dot      { width: 8px; height: 8px; border-radius: 50%; }
.chart-svg-wrap { width: 100%; height: 130px; }

/* ─── Rating breakdown ─── */
.breakdown-wrap  { padding: 4px 22px 20px; }
.breakdown-title {
    font-size: 12px; font-weight: 700; text-transform: uppercase;
    letter-spacing: .7px; color: var(--txt3); margin-bottom: 12px; padding-top: 14px;
}
.br-row   { display: flex; align-items: center; gap: 10px; margin-bottom: 11px; }
.br-label {
    display: flex; align-items: center; gap: 3px;
    width: 36px; font-size: 11px; color: var(--txt2); font-weight: 600; flex-shrink: 0;
}
.br-track { flex: 1; height: 6px; background: var(--border-faint); border-radius: 3px; overflow: hidden; }
.br-fill  { height: 100%; border-radius: 3px; transition: width .9s cubic-bezier(.4,0,.2,1); }
.br-count { font-size: 11.5px; font-weight: 600; color: var(--txt2); width: 26px; text-align: right; }

/* ─── Quick stats ─── */
.quick-stats {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 10px; padding: 0 22px 20px;
}
.qs-item {
    background: var(--bg); border-radius: 10px; padding: 12px;
    border: 1px solid var(--border-faint);
}
.qs-label { font-size: 10.5px; font-weight: 600; text-transform: uppercase; letter-spacing: .7px; color: var(--txt3); margin-bottom: 6px; }
.qs-value { font-size: 20px; font-weight: 800; letter-spacing: -1px; }
.qs-sub   { font-size: 11px; color: var(--txt3); margin-top: 2px; }

/* ═══════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════ */
@media (max-width: 1100px) {
    .main-grid { grid-template-columns: 1fr; }
}
@media (max-width: 860px) {
    .cards-row { grid-template-columns: 1fr 1fr; }
    .cards-row .summary-card:nth-child(3) { grid-column: 1 / -1; }
}
@media (max-width: 640px) {
    .cards-row { grid-template-columns: 1fr; }
    .cards-row .summary-card:nth-child(3) { grid-column: auto; }
}
