/* ============================================================
   Portal — mocked student dashboard
   ============================================================ */

.portal-banner {
  background: var(--sage-wash);
  border-bottom: 1px solid var(--sage-soft);
  padding: var(--s-3) var(--gutter);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-label);
  color: var(--sage-deep);
  text-align: center;
}

.portal-banner strong { font-weight: 600; }

/* The site-wide `.main { padding-top: var(--header-h) }` is dead weight on the
   portal — the nav is sticky (in flow), so that offset just opens a big empty
   gap above the hero. Drop it here and let the hero own its (tighter) top.
   NOTE: Astro inlines global.css as a <style> that lands AFTER this file's
   <link>, so a plain `.main` here loses the cascade (equal specificity, global
   comes later). `body .main` (0,2,0) beats `.main` (0,1,0) and wins regardless
   of source order — that's why this is scoped to `body`. */
body .main { padding-top: 0; }

.portal-hero {
  padding-top: var(--s-4);
  padding-bottom: clamp(var(--s-6), 7vw, var(--s-7));
  background:
    linear-gradient(180deg, var(--bg-sunk) 0%, var(--bg) 100%);
  border-bottom: 1px solid var(--line);
}

.portal-greet {
  display: flex;
  align-items: center;
  gap: var(--s-4);
  margin-bottom: var(--s-5);
}

.portal-avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--sage), var(--clay));
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 400;
  letter-spacing: -0.02em;
  font-variation-settings: 'opsz' 144, 'SOFT' 50;
  border: 2px solid var(--bg);
  box-shadow: var(--shadow-1);
}

.portal-greet h1 {
  font-size: clamp(1.75rem, 5vw, var(--fs-3xl));
  font-weight: 400;
  letter-spacing: -0.02em;
  font-variation-settings: 'opsz' 144, 'SOFT' 30;
  line-height: 1.1;
}
.portal-greet h1 em {
  font-style: italic;
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
  color: var(--sage-deep);
  margin-left: 0.1em;
}

.portal-greet p {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-top: var(--s-1);
}

/* Stats row */
.portal-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-4);
}

@media (min-width: 720px) {
  .portal-stats {
    grid-template-columns: repeat(4, 1fr);
  }
}

.portal-stat {
  padding: var(--s-5);
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.portal-stat.is-primary {
  background: var(--bg-deep);
  color: var(--ink-on-deep);
  border-color: var(--bg-deep);
}
.portal-stat.is-primary .stat-num { color: var(--ink-on-deep); }
.portal-stat.is-primary .stat-label { color: var(--ink-on-deep-soft); }
.portal-stat.is-primary .stat-detail { color: var(--ink-on-deep-soft); }
.portal-stat .stat-num {
  font-family: var(--font-display);
  font-size: var(--fs-3xl);
  font-weight: 400;
  letter-spacing: -0.028em;
  font-variation-settings: 'opsz' 144, 'SOFT' 30;
  line-height: 1;
}
.portal-stat .stat-num sup {
  font-family: var(--font-mono);
  font-size: 0.35em;
  font-weight: 500;
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-left: 0.15em;
  vertical-align: 0.8em;
}
.portal-stat .stat-label {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--ink-mute);
}
.portal-stat .stat-detail {
  font-size: var(--fs-xs);
  color: var(--ink-mute);
  margin-top: var(--s-1);
}

/* Portal sections */
.portal-section {
  padding-block: clamp(var(--s-6), 7vw, var(--s-8));
}

.portal-section + .portal-section {
  padding-top: 0;
}

.portal-section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-4);
  margin-bottom: var(--s-5);
  flex-wrap: wrap;
}
.portal-section-head h2 {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  font-weight: 400;
  font-variation-settings: 'opsz' 144, 'SOFT' 40;
  letter-spacing: -0.018em;
}

.upcoming-list {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}

.upcoming-row {
  display: grid;
  grid-template-columns: 60px 60px 1fr auto;
  gap: var(--s-4);
  align-items: center;
  padding: var(--s-4) var(--s-5);
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
}

.upcoming-day {
  text-align: center;
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--ink-mute);
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.upcoming-day strong {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  font-weight: 400;
  font-variation-settings: 'opsz' 144, 'SOFT' 30;
  letter-spacing: -0.02em;
  color: var(--ink);
  line-height: 1;
}

.upcoming-time {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 400;
  font-variant-numeric: tabular-nums;
  color: var(--ink);
}

.upcoming-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.upcoming-info .upcoming-name {
  font-weight: 500;
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.upcoming-info .upcoming-meta {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--ink-mute);
}

.upcoming-actions {
  display: flex;
  gap: var(--s-2);
}
.upcoming-actions .btn { height: 36px; padding: 0 var(--s-3); font-size: 0.6875rem; }

/* Mobile — stack the booking card so the meta + buttons stop colliding. Date +
   time on the left, class name + meta beside, actions on their own row below. */
@media (max-width: 560px) {
  .upcoming-row {
    grid-template-columns: auto 1fr;
    grid-template-areas:
      "day  info"
      "time info"
      "actions actions";
    column-gap: var(--s-4);
    row-gap: var(--s-1);
    align-items: start;
    padding: var(--s-4);
  }
  .upcoming-day  { grid-area: day; text-align: left; }
  .upcoming-time { grid-area: time; text-align: left; margin-top: 2px; }
  .upcoming-info { grid-area: info; }
  .upcoming-info .upcoming-name { white-space: normal; overflow: visible; text-overflow: clip; }
  .upcoming-actions {
    grid-area: actions; flex-wrap: wrap;
    margin-top: var(--s-3); padding-top: var(--s-3); border-top: 1px solid var(--line);
  }
  .upcoming-actions .btn { flex: 1 1 auto; min-width: 130px; height: 40px; }
}

/* History */
.history-list {
  display: flex;
  flex-direction: column;
}
.history-item {
  display: grid;
  grid-template-columns: 90px 1fr auto;
  gap: var(--s-4);
  align-items: center;
  padding: var(--s-4) 0;
  border-bottom: 1px solid var(--line);
}
.history-item:last-child { border-bottom: 0; }
.history-date {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-label);
  color: var(--ink-mute);
}
.history-class {
  font-weight: 500;
  color: var(--ink);
}
.history-class small {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: 400;
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-top: 2px;
}
.history-status {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--success);
}

/* Recommended */
.recommended-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-4);
}
@media (min-width: 720px) {
  .recommended-grid { grid-template-columns: repeat(2, 1fr); }
}

.rec-card {
  display: flex;
  gap: var(--s-4);
  padding: var(--s-5);
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  align-items: center;
}
.rec-card-media {
  flex-shrink: 0;
  width: 80px;
  height: 80px;
  border-radius: var(--r-2);
  overflow: hidden;
  background: var(--bg-sunk);
}
.rec-card-media img { width: 100%; height: 100%; object-fit: cover; }
.rec-card-body { flex: 1; min-width: 0; }
.rec-card-body h4 {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 400;
  font-variation-settings: 'opsz' 144, 'SOFT' 30;
  margin-bottom: var(--s-1);
}
.rec-card-body p {
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  line-height: var(--lh-snug);
}

/* Settings */
.settings-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-4);
}
@media (min-width: 720px) {
  .settings-grid { grid-template-columns: repeat(2, 1fr); }
}

.settings-card {
  padding: var(--s-5);
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.settings-card h4 {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--ink-mute);
}
.settings-card .value {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 400;
  font-variation-settings: 'opsz' 144, 'SOFT' 40;
}
.settings-card .sub {
  font-size: var(--fs-xs);
  color: var(--ink-mute);
  font-family: var(--font-mono);
  letter-spacing: var(--tracking-label);
}
