/* ============================================================
   VEEBO SHARED PAGE COMPONENTS v3.0
   Dipakai di semua halaman Fase 3 (dashboard, upload, laporan, dll).
   Di-load lewat <link> di base.html setelah veebo-sidebar.css.

   CATATAN — komponen yang SUDAH ada di veebo-components.css (Fase 1)
   tidak diduplikasi di sini:
     - .btn-v3, .btn-v3-gold, .btn-v3-ghost (pakai dual-class
       di markup: class="btn-v3 btn-v3-gold")
     - .score-chip-v3 + .score-v3-1..5 (untuk skor rubrik dinamis;
       tetap dipertahankan untuk laporan). Shared.css menambah alias
       singkat .chip + .chip-1..5 untuk konteks ringkas (mis. recording
       row di dashboard) — keputusan: skala 1-5 statis di alias ini OK
       karena dashboard hanya pakai untuk preview skor TEACH (skala 5);
       laporan komprehensif tetap pakai .score-chip-v3 dinamis.
   ============================================================ */

/* ---- PAGE HEADER ---- */
.ph-v3 {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--pad-lg);
  gap: var(--gap);
  flex-wrap: wrap;
}
.ph-eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--gold-dark);
  margin-bottom: 6px;
}
.ph-title-v3 {
  font-family: var(--font-display);
  font-size: 40px;
  color: var(--navy);
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-weight: 400;
}
.ph-sub-v3 {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--muted);
  margin-top: 4px;
}

/* ---- BENTO STAT TILES ---- */
.bento-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--gap);
  margin-bottom: var(--gap-lg);
}
.bento-tile {
  border-radius: var(--radius);
  padding: var(--pad);
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}
.bento-tile .tile-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  opacity: 0.7;
}
.bento-tile .tile-value {
  font-family: var(--font-display);
  font-size: 52px;
  line-height: 1;
  letter-spacing: -0.02em;
}
.bento-tile .tile-delta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  opacity: 0.6;
}
.tile-dark  { background: var(--navy);      color: #fff; }
.tile-gold  { background: var(--gold);      color: var(--navy-dark); }
.tile-light { background: var(--surface);   border: 1.5px solid var(--border); color: var(--ink); }
.tile-muted { background: var(--surface-2); color: var(--ink-2); }

@media (max-width: 900px) {
  .bento-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .bento-grid { grid-template-columns: 1fr; }
}

/* ---- PROGRAM BAR ---- */
.program-bar {
  background: var(--navy);
  color: #fff;
  border-radius: var(--radius);
  padding: 14px 20px;
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: var(--gap-lg);
  flex-wrap: wrap;
}
.program-bar .bar-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.5);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.program-bar .bar-name {
  font-family: var(--font-sans);
  font-weight: 700;
  color: var(--gold);
  font-size: var(--text-base);
}
.program-bar .bar-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.55);
  margin-left: auto;
}
.program-bar .bar-badge {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  padding: 3px 10px;
  border-radius: 999px;
  background: rgba(245,184,46,0.18);
  color: var(--gold);
  border: 1px solid rgba(245,184,46,0.35);
  letter-spacing: 0.02em;
}

/* ---- RECORDING ROW ---- */
.rec-row {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  gap: var(--gap);
  align-items: center;
  padding: var(--pad-sm) var(--pad);
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: 8px;
  transition: border-color 0.15s, box-shadow 0.15s;
  text-decoration: none;
  color: inherit;
}
.rec-row:hover {
  border-color: var(--navy);
  box-shadow: 0 2px 12px rgba(15,37,71,0.08);
}
.rec-row.clickable { cursor: pointer; }

.rec-row .rec-icon {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.rec-row .rec-icon svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
}

.rec-icon-ok      { background: var(--success-soft); color: var(--success); }
.rec-icon-error   { background: var(--danger-soft);  color: var(--danger);  }
.rec-icon-warn    { background: var(--warning-soft); color: var(--warning); }
.rec-icon-pending { background: var(--info-soft);    color: var(--navy);    }
.rec-icon-muted   { background: var(--surface-2);    color: var(--muted);   }

.rec-row .rec-content { min-width: 0; }
.rec-row .rec-title {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: var(--text-base);
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.rec-row .rec-meta {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--muted);
  margin-top: 2px;
}
.rec-row .rec-error-msg {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--danger);
  margin-top: 4px;
}
.rec-row .rec-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

/* ---- SECTION CARD ---- */
.section-card {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  padding: var(--pad);
  margin-bottom: var(--gap);
}
.section-card-title {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: var(--text-base);
  color: var(--navy);
  margin-bottom: var(--gap-sm);
  letter-spacing: -0.005em;
}
.section-card-sub {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--muted);
  margin-top: -4px;
  margin-bottom: var(--gap);
}

/* ---- TALK TIME BAR ---- */
.talk-bar {
  height: 40px;
  border-radius: var(--radius-sm);
  overflow: hidden;
  display: flex;
  margin: var(--gap-sm) 0;
  background: var(--surface-2);
}
.talk-bar-guru {
  background: var(--navy);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: var(--text-sm);
}
.talk-bar-siswa {
  background: var(--gold);
  color: var(--navy-dark);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: var(--text-sm);
}

/* ---- SCORE CHIP ALIAS — ringkas, untuk konteks skala 5 (TEACH) ----
   Untuk skor dinamis skala_max ≠ 5, pakai .score-chip-v3 + helper di
   veebo-components.css. */
.chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: 12px;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  flex-shrink: 0;
}
.chip-1 { background: var(--danger-soft);  color: var(--danger-ink);  }
.chip-2 { background: var(--warning-soft); color: var(--warning-ink); }
.chip-3 { background: var(--info-soft);    color: var(--navy);        }
.chip-4 { background: var(--success-soft); color: var(--success-ink); }
.chip-5 { background: var(--success);      color: #fff;               }
.chip-neutral { background: var(--surface-2); color: var(--muted); }

/* ---- FILTER TABS ---- */
.filter-tabs {
  display: flex;
  gap: 6px;
  margin-bottom: var(--gap-lg);
  flex-wrap: wrap;
}
.filter-tab {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  padding: 7px 16px;
  border-radius: var(--radius-sm);
  border: 1.5px solid var(--border);
  background: var(--surface);
  color: var(--muted);
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.filter-tab:hover {
  border-color: var(--navy);
  color: var(--navy);
}
.filter-tab.active {
  background: var(--navy);
  border-color: var(--navy);
  color: #fff;
}
.filter-tab .filter-tab-count {
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 600;
  padding: 1px 7px;
  border-radius: 999px;
  background: rgba(0,0,0,0.08);
}
.filter-tab.active .filter-tab-count {
  background: var(--gold);
  color: var(--navy-dark);
}

/* ---- FORM FIELDS V3 ---- */
.field-v3 {
  margin-bottom: var(--gap);
}
.field-label-v3 {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-2);
  display: block;
  margin-bottom: 6px;
}
.field-label-v3 .req {
  color: var(--danger);
  margin-left: 2px;
}
.field-input-v3 {
  width: 100%;
  padding: 10px 14px;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: var(--text-base);
  font-family: var(--font-sans);
  color: var(--ink);
  transition: border-color 0.15s, box-shadow 0.15s;
  outline: none;
  appearance: none;
}
.field-input-v3:focus {
  border-color: var(--navy);
  box-shadow: 0 0 0 3px rgba(15,37,71,0.07);
}
.field-input-v3::placeholder { color: var(--muted-2); }
.field-input-v3[readonly],
.field-input-v3[disabled] {
  background: var(--surface-2);
  color: var(--muted);
  cursor: not-allowed;
}
textarea.field-input-v3 {
  min-height: 90px;
  line-height: 1.55;
  resize: vertical;
}
.field-help-v3 {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--muted);
  margin-top: 4px;
}

/* ---- FORM GRID 2-COL (utility, dipakai upload + profil + admin) ---- */
.form-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gap);
}
.form-grid-2 .full-width { grid-column: 1 / -1; }
@media (max-width: 640px) {
  .form-grid-2 { grid-template-columns: 1fr; }
}

/* ---- ALERT V3 (refresh look untuk alert.alert-* existing) ----
   Tidak override class alert lama — class baru .alert-v3-* */
.alert-v3 {
  font-family: var(--font-sans);
  padding: 12px 16px;
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  line-height: 1.55;
  margin-bottom: var(--gap);
  border: 1.5px solid transparent;
}
.alert-v3-success { background: var(--success-soft); color: var(--success-ink); border-color: var(--success); }
.alert-v3-warning { background: var(--warning-soft); color: var(--warning-ink); border-color: var(--warning); }
.alert-v3-danger  { background: var(--danger-soft);  color: var(--danger-ink);  border-color: var(--danger);  }
.alert-v3-info    { background: var(--info-soft);    color: var(--navy);        border-color: var(--navy-mid); }
