:root {
  --p-bg: #0a0c0f;
  --p-surface: #111418;
  --p-surface2: #181c22;
  --p-surface3: #1e232b;
  --p-border: #252b35;
  --p-gold: #e8b84b;
  --p-gold-dim: #a07e28;
  --p-gold-glow: rgba(232,184,75,0.12);
  --p-teal: #00c9a7;
  --p-teal-glow: rgba(0,201,167,0.12);
  --p-rose: #f06292;
  --p-blue: #5b9cf6;
  --p-blue-glow: rgba(91,156,246,0.12);
  --p-text: #e8edf5;
  --p-text-muted: #7a8499;
  --p-online: #22d1a0;
  --p-offline: #4a5260;
  --p-danger: #ef5350;
  --p-warn: #ffa726;
  --p-radius: 14px;
  --p-transition: .22s cubic-bezier(.4,0,.2,1);
}

.portal-body {
  font-family: 'Inter', sans-serif;
  background: radial-gradient(circle at top right, #1a2235 0%, #080a0d 100%);
  color: var(--p-text);
  display: flex;
  height: 100vh;
  overflow: hidden;
  position: relative;
}
.portal-body::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: linear-gradient(rgba(255, 255, 255, 0.02) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(255, 255, 255, 0.02) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
  z-index: 1;
}
.portal-body::after {
  content: '';
  position: absolute;
  top: -20vh; right: -10vw;
  width: 50vw; height: 50vh;
  background: radial-gradient(circle, rgba(91,156,246,0.15) 0%, transparent 70%);
  filter: blur(80px);
  z-index: 0;
  pointer-events: none;
}
.p-sidebar, .p-main {
  position: relative;
  z-index: 2;
}

/* Scrollbar Modernization */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}
::-webkit-scrollbar-track {
  background: transparent;
}
::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 10px;
}
::-webkit-scrollbar-thumb:hover {
  background: var(--p-gold);
}

/* ── Sidebar ── */
.p-sidebar {
  width: 260px;
  min-width: 260px;
  background: rgba(17, 20, 24, 0.4);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 24px;
  margin: 16px 0 16px 16px;
  display: flex;
  flex-direction: column;
  height: calc(100vh - 32px);
  position: sticky;
  top: 16px;
  z-index: 100;
  box-shadow: 0 16px 40px rgba(0,0,0,0.5);
}
.p-sidebar-brand {
  padding: 28px 24px 20px;
  border-bottom: 1px solid var(--p-border);
}
.p-brand-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 4px;
}
.p-brand-icon {
  width: 38px; height: 38px;
  background: linear-gradient(135deg, var(--p-gold), var(--p-gold-dim));
  border-radius: 10px;
  display: grid; place-items: center;
  font-size: 20px;
  box-shadow: 0 4px 16px var(--p-gold-glow);
}
.p-brand-name {
  font-family: 'Poppins', sans-serif;
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--p-text);
  letter-spacing: .02em;
}
.p-brand-role {
  font-size: .72rem;
  color: var(--p-gold);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 600;
}
.p-sidebar-nav {
  flex: 1;
  padding: 16px 12px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.p-nav-section-label {
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--p-text-muted);
  padding: 12px 12px 6px;
}
.p-nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 14px;
  border-radius: 10px;
  cursor: pointer;
  color: var(--p-text-muted);
  font-weight: 500;
  font-size: .88rem;
  transition: var(--p-transition);
  border: none;
  background: none;
  width: 100%;
  text-align: left;
  position: relative;
}
.p-nav-item:hover { background: var(--p-surface2); color: var(--p-text) }
.p-nav-item.active {
  background: rgba(232, 184, 75, 0.08);
  color: var(--p-gold);
  border: 1px solid rgba(232, 184, 75, 0.15);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2), inset 0 0 10px rgba(232, 184, 75, 0.05);
}
.p-nav-item.active::before {
  content: '';
  position: absolute;
  left: -12px;
  top: 50%;
  transform: translateY(-50%);
  width: 4px;
  height: 20px;
  background: var(--p-gold);
  border-radius: 0 4px 4px 0;
  box-shadow: 0 0 10px var(--p-gold);
}
.p-nav-item .icon { font-size: 1rem; min-width: 20px; text-align: center }
.p-nav-badge {
  margin-left: auto;
  background: var(--p-danger);
  color: #fff;
  font-size: .62rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 20px;
}
.p-live-indicator {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-left: auto;
  font-size: .65rem;
  font-weight: 700;
  color: var(--p-online);
  letter-spacing: .08em;
}
.p-live-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--p-online);
  animation: p-pulse 1.8s infinite;
}
@keyframes p-pulse { 0%,100% { opacity: 1; transform: scale(1) } 50% { opacity: .5; transform: scale(.8) } }

.p-sidebar-footer {
  padding: 16px 12px;
  border-top: 1px solid var(--p-border);
}
.p-user-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  cursor: pointer;
  transition: var(--p-transition);
}
.p-user-card:hover { background: var(--p-surface2) }
.p-user-avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--p-gold), var(--p-gold-dim));
  display: grid; place-items: center;
  font-weight: 700;
  font-size: .88rem;
  color: #0a0c0f;
  flex-shrink: 0;
}
.p-user-info { flex: 1; min-width: 0 }
.p-user-name { font-size: .82rem; font-weight: 600; color: var(--p-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis }
.p-user-email { font-size: .7rem; color: var(--p-text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis }

/* ── Main ── */
.p-main {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  height: 100vh;
  padding-bottom: 24px;
}
.p-topbar {
  position: sticky;
  top: 16px;
  z-index: 90;
  background: rgba(10, 12, 15, 0.6);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 20px;
  margin: 16px 28px 0;
  display: flex;
  align-items: center;
  padding: 0 24px;
  height: 68px;
  gap: 16px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}
.p-topbar-title {
  font-family: 'Poppins', sans-serif;
  font-size: 1.15rem;
  font-weight: 700;
  flex: 1;
}
.p-topbar-search {
  position: relative;
}
.p-topbar-search input {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  padding: 10px 16px 10px 42px;
  color: var(--p-text);
  font-size: .85rem;
  font-family: 'Inter', sans-serif;
  width: 280px;
  outline: none;
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  box-shadow: inset 0 2px 4px rgba(0,0,0,0.2);
}
.p-topbar-search input:focus { 
  border-color: var(--p-gold); 
  background: rgba(255, 255, 255, 0.06); 
  width: 320px;
  box-shadow: inset 0 2px 4px rgba(0,0,0,0.3), 0 0 15px rgba(232, 184, 75, 0.15);
}
.p-topbar-search .search-icon {
  position: absolute;
  left: 14px; top: 50%;
  transform: translateY(-50%);
  color: var(--p-text-muted);
  font-size: 1rem;
  opacity: 0.6;
}
.p-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  border-radius: 12px;
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: .85rem;
  cursor: pointer;
  border: none;
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}
.p-btn-gold { background: linear-gradient(135deg, var(--p-gold), var(--p-gold-dim)); color: #0a0c0f; border-top: 1px solid rgba(255,255,255,0.3); }
.p-btn-gold:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(232,184,75,0.3); }
.p-btn-ghost { background: rgba(255,255,255,0.05); color: var(--p-text); border: 1px solid rgba(255,255,255,0.1); }
.p-btn-ghost:hover { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.2); transform: translateY(-2px); }
.p-btn-danger { background: rgba(239,83,80,.15); color: var(--p-danger); border: 1px solid rgba(239,83,80,.3); }
.p-btn-danger:hover { background: rgba(239,83,80,.25); transform: translateY(-2px); box-shadow: 0 8px 20px rgba(239,83,80,0.2); }
.p-btn-sm { padding: 6px 14px; font-size: .78rem; border-radius: 8px; }
.p-btn-teal { background: linear-gradient(135deg, var(--p-teal), #008f78); color: #080b10; border-top: 1px solid rgba(255,255,255,0.3); }
.p-btn-teal:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(0,201,167,0.3); }
.p-btn-blue { background: linear-gradient(135deg, var(--p-blue), #2c6fdc); color: #fff; border-top: 1px solid rgba(255,255,255,0.3); }
.p-btn-blue:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(91,156,246,0.3); }

.p-content { padding: 28px; display: flex; flex-direction: column; gap: 24px }

/* ── Section routing ── */
.p-panel { display: none; }
.p-panel.active { 
  display: flex; 
  flex-direction: column; 
  gap: 24px;
  animation: p-panel-entrance 0.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes p-panel-entrance {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ── Stat cards ── */
.p-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 16px;
}
.p-stat-card {
  background: rgba(24, 28, 34, 0.4);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 24px;
  padding: 24px 22px;
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  cursor: default;
  position: relative;
  overflow: hidden;
  box-shadow: 0 10px 30px -5px rgba(0, 0, 0, 0.4), inset 0 2px 20px rgba(255,255,255,0.02);
}
.p-stat-card:hover { 
  border-color: rgba(91, 156, 246, 0.3); 
  transform: translateY(-4px);
  box-shadow: 0 12px 30px -4px rgba(91, 156, 246, 0.1);
}
.p-stat-icon {
  width: 42px; height: 42px;
  border-radius: 11px;
  display: grid; place-items: center;
  font-size: 1.2rem;
  margin-bottom: 14px;
}
.p-stat-icon.gold { background: var(--p-gold-glow); border: 1px solid rgba(232,184,75,.2); box-shadow: 0 0 12px rgba(232,184,75,0.1); }
.p-stat-icon.teal { background: rgba(0,201,167,.1); border: 1px solid rgba(0,201,167,.2); box-shadow: 0 0 12px rgba(0,201,167,0.1); }
.p-stat-icon.blue { background: rgba(91,156,246,.1); border: 1px solid rgba(91,156,246,.2); box-shadow: 0 0 12px rgba(91,156,246,0.1); }
.p-stat-icon.rose { background: rgba(240,98,146,.1); border: 1px solid rgba(240,98,146,.2); box-shadow: 0 0 12px rgba(240,98,146,0.1); }
.p-stat-val { font-size: 2rem; font-weight: 700; line-height: 1; color: var(--p-text); font-family: 'Poppins', sans-serif }
.p-stat-label { font-size: .75rem; color: var(--p-text-muted); margin-top: 6px; font-weight: 500; letter-spacing: .04em }
.p-stat-change {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: .72rem; font-weight: 600;
  margin-top: 8px;
  padding: 2px 8px; border-radius: 20px;
}
.p-stat-change.up { background: rgba(34,209,160,.12); color: var(--p-online) }
.p-stat-change.down { background: rgba(239,83,80,.12); color: var(--p-danger) }

/* ── Cards & Tables ── */
.p-card {
  background: rgba(17, 20, 24, 0.5);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 12px 40px 0 rgba(0, 0, 0, 0.4), inset 0 2px 20px rgba(255,255,255,0.02);
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.p-card:hover {
  border-color: rgba(232, 184, 75, 0.25);
  box-shadow: 0 12px 40px 0 rgba(232, 184, 75, 0.03);
}
.p-card-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 18px 22px;
  border-bottom: 1px solid var(--p-border);
}
.p-card-title {
  font-family: 'Poppins', sans-serif;
  font-size: 1rem;
  font-weight: 700;
  flex: 1;
}
.p-card-body { padding: 20px 22px }

.p-table { width: 100%; border-collapse: collapse }
.p-table thead tr { background: var(--p-surface2) }
.p-table thead th {
  padding: 11px 14px;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--p-text-muted);
  text-align: left;
  border-bottom: 1px solid var(--p-border);
}
.p-table tbody tr {
  border-bottom: 1px solid rgba(37,43,53,.7);
  transition: var(--p-transition);
}
.p-table tbody tr:hover { background: var(--p-surface2) }
.p-table tbody td { padding: 13px 14px; font-size: .83rem; color: var(--p-text) }
.p-table tbody tr:last-child { border-bottom: none }

.p-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 10px; border-radius: 20px;
  font-size: .7rem; font-weight: 700; letter-spacing: .04em;
}
.p-badge-green { background: rgba(34,209,160,.12); color: var(--p-online) }
.p-badge-yellow { background: rgba(255,167,38,.12); color: var(--p-warn) }
.p-badge-red { background: rgba(239,83,80,.12); color: var(--p-danger) }
.p-badge-blue { background: rgba(91,156,246,.12); color: var(--p-blue) }
.p-badge-gold { background: var(--p-gold-glow); color: var(--p-gold) }

.p-action-group { display: flex; gap: 6px; align-items: center }

/* ── Live tracking ── */
.p-live-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
}
.p-live-card {
  background: var(--p-surface2);
  border: 1px solid var(--p-border);
  border-radius: 12px;
  padding: 16px;
  display: flex;
  gap: 14px;
  align-items: flex-start;
  transition: var(--p-transition);
}
.p-live-card:hover { border-color: var(--p-gold-dim) }
.p-live-card.online { border-left: 3px solid var(--p-online) }
.p-live-card.away { border-left: 3px solid var(--p-warn) }
.p-live-card.offline { border-left: 3px solid var(--p-offline) }
.p-live-avatar {
  width: 42px; height: 42px;
  border-radius: 50%;
  display: grid; place-items: center;
  font-weight: 700;
  font-size: .9rem;
  flex-shrink: 0;
}
.p-live-info { flex: 1; min-width: 0 }
.p-live-name { font-weight: 600; font-size: .88rem; color: var(--p-text) }
.p-live-sub { font-size: .74rem; color: var(--p-text-muted); margin-top: 2px }
.p-live-status {
  display: flex; align-items: center; gap: 5px;
  margin-top: 6px; font-size: .72rem; font-weight: 600;
}
.p-status-dot { width: 7px; height: 7px; border-radius: 50% }
.p-status-dot.online { background: var(--p-online); animation: p-pulse 1.8s infinite }
.p-status-dot.away { background: var(--p-warn) }
.p-status-dot.offline { background: var(--p-offline) }

/* ── Charts ── */
.p-charts-row { display: grid; grid-template-columns: 2fr 1fr; gap: 16px }
.p-chart-wrap { position: relative; height: 260px }

/* ── Modal ── */
.p-modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.7);
  backdrop-filter: blur(8px);
  z-index: 200;
  display: none; place-items: center;
}
.p-modal-overlay.open { display: grid }
.p-modal {
  background: var(--p-surface);
  border: 1px solid var(--p-border);
  border-radius: 18px;
  width: min(520px, 92vw);
  max-height: 88vh;
  overflow-y: auto;
  animation: p-fadeUp .28s ease;
}
@keyframes p-fadeUp { from { opacity: 0; transform: translateY(18px) } to { opacity: 1; transform: translateY(0) } }
.p-modal-header {
  display: flex; align-items: center;
  padding: 22px 24px;
  border-bottom: 1px solid var(--p-border);
}
.p-modal-title { font-family: 'Poppins', sans-serif; font-size: 1.05rem; font-weight: 700; flex: 1 }
.p-modal-close {
  background: none; border: none; cursor: pointer;
  color: var(--p-text-muted); font-size: 1.2rem;
  transition: var(--p-transition); padding: 4px;
}
.p-modal-close:hover { color: var(--p-danger) }
.p-modal-body { padding: 24px }
.p-form-group { margin-bottom: 18px }
.p-form-label { display: block; font-size: .78rem; font-weight: 600; color: var(--p-text-muted); margin-bottom: 7px; letter-spacing: .04em }
.p-form-control {
  width: 100%;
  background: rgba(10, 12, 15, 0.6);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-top: 1px solid rgba(0, 0, 0, 0.6);
  box-shadow: inset 0 3px 8px rgba(0,0,0,0.4);
  border-radius: 12px;
  padding: 12px 16px;
  color: var(--p-text);
  font-family: 'Inter', sans-serif;
  font-size: .85rem;
  outline: none;
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}
.p-form-control:focus { 
  border-color: var(--p-gold); 
  background: rgba(10, 12, 15, 0.8);
  box-shadow: inset 0 3px 8px rgba(0,0,0,0.5), 0 0 15px rgba(232, 184, 75, 0.2);
}
.p-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px }
.p-modal-footer { display: flex; gap: 10px; justify-content: flex-end; padding: 16px 24px; border-top: 1px solid var(--p-border) }

/* ── Toast ── */
.p-toast {
  position: fixed; bottom: 24px; right: 24px;
  background: var(--p-surface);
  border: 1px solid var(--p-border);
  border-radius: 12px;
  padding: 14px 20px;
  font-size: .82rem;
  font-weight: 500;
  display: flex; align-items: center; gap: 10px;
  z-index: 300;
  transform: translateY(80px);
  opacity: 0;
  transition: .3s ease;
  max-width: 320px;
  box-shadow: 0 8px 32px rgba(0,0,0,.4);
}
.p-toast.show { transform: translateY(0); opacity: 1 }
.p-toast.success { border-color: var(--p-online); color: var(--p-online) }
.p-toast.error { border-color: var(--p-danger); color: var(--p-danger) }

/* ── Progress ── */
.p-progress-bar {
  background: var(--p-surface3);
  border-radius: 4px;
  height: 6px;
  overflow: hidden;
}
.p-progress-fill {
  height: 100%;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--p-gold), var(--p-teal));
  transition: width .6s ease;
}

.p-section-sep { height: 1px; background: var(--p-border); margin: 4px 0 }

/* Notification bell */
.p-topbar-actions { display: flex; align-items: center; gap: 10px }
.p-icon-btn {
  width: 38px; height: 38px;
  border-radius: 10px;
  background: var(--p-surface2);
  border: 1px solid var(--p-border);
  cursor: pointer;
  display: grid; place-items: center;
  font-size: 1rem;
  color: var(--p-text-muted);
  transition: var(--p-transition);
  position: relative;
}
.p-icon-btn:hover { background: var(--p-surface3); color: var(--p-text) }
.p-notif-dot {
  position: absolute; top: 7px; right: 7px;
  width: 7px; height: 7px;
  background: var(--p-danger);
  border-radius: 50%;
  border: 2px solid var(--p-surface2);
}

@media(max-width: 900px) {
  .p-sidebar { 
    width: 72px; 
    min-width: 72px; 
    margin: 12px 0 12px 12px;
    border-radius: 20px;
  }
  .p-sidebar-brand { padding: 20px 12px }
  .p-brand-name, .p-brand-role, .p-sidebar-footer .p-user-info, .p-nav-section-label, .p-nav-item span { display: none }
  .p-nav-item { justify-content: center; padding: 14px }
  .p-topbar { margin: 12px 12px 0; border-radius: 16px; padding: 0 16px; }
  .p-content { padding: 20px 12px; }
  .p-charts-row { grid-template-columns: 1fr }
}

@media(max-width: 600px) {
  .portal-body { flex-direction: column; }
  .p-sidebar {
    width: 100%;
    height: 60px;
    min-width: unset;
    flex-direction: row;
    margin: 0;
    order: 2;
    position: fixed;
    bottom: 0;
    left: 0;
    top: auto;
    z-index: 1000;
    background: var(--p-surface);
    border-top: 1px solid var(--p-border);
    border-radius: 0;
    box-shadow: 0 -4px 20px rgba(0,0,0,0.4);
  }
  .p-sidebar-brand, .p-sidebar-footer, .p-nav-section-label, .p-section-sep { display: none !important; }
  .p-sidebar-nav {
    display: flex;
    flex-direction: row;
    width: 100%;
    height: 100%;
    padding: 0;
    gap: 0;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    justify-content: flex-start;
    align-items: stretch;
  }
  .p-sidebar-nav::-webkit-scrollbar { display: none; }
  .p-nav-item {
    flex: 0 0 auto;
    width: 60px;
    min-width: 60px;
    height: 60px;
    padding: 6px 4px 4px;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border-radius: 0;
    border-left: none;
    gap: 3px;
  }
  .p-nav-item .icon { font-size: 1.4rem; line-height: 1; }
  /* Hide text labels — icon only on mobile */
  .p-nav-item > span:not(.icon):not(.p-nav-badge) { display: none !important; }
  .p-nav-item.active {
    border-left: none;
    border-top: 2px solid var(--p-gold);
    background: rgba(232,184,75,0.1);
  }
  .p-main { height: calc(100dvh - 60px); order: 1; overflow-y: auto; }
  .p-topbar { margin: 0; border-radius: 0; }
  .p-content { padding-bottom: 80px; }
}

/* Coach/Student specific variants */
.coach-portal-icon { background: linear-gradient(135deg, var(--p-teal), #008f78); }
.student-portal-icon { background: linear-gradient(135deg, var(--p-blue), #2c6fdc); }
.p-btn-teal { background: linear-gradient(135deg, var(--p-teal), #008f78); color: #080b10 }
.p-btn-blue { background: linear-gradient(135deg, var(--p-blue), #2c6fdc); color: #fff }

.rating-hero {
  background: linear-gradient(135deg, #0e1118, #111827);
  border: 1px solid rgba(91,156,246,0.2);
  border-radius: var(--p-radius);
  padding: 28px;
  position: relative;
  overflow: hidden;
}
.rating-hero::before { content: ''; position: absolute; top: -40px; right: -40px; width: 200px; height: 200px; background: radial-gradient(circle, rgba(91,156,246,0.12), transparent 70%); pointer-events: none }
.rating-num { font-family: 'Poppins', sans-serif; font-size: 3.5rem; font-weight: 900; color: var(--p-blue); line-height: 1 }

/* ══════════════════════════════════════════════════════════════════════════
   PORTAL 3D ANIMATION LAYER
   ══════════════════════════════════════════════════════════════════════════ */

/* ─── 3D Stat Cards ─── */
.p-stat-card {
  transform-style: preserve-3d;
  transition: all 0.45s cubic-bezier(0.23, 1, 0.32, 1);
}
.p-stat-card:hover {
  border-color: var(--p-gold-dim);
  transform: perspective(600px) rotateX(-3deg) translateY(-6px) translateZ(12px);
  box-shadow: 0 20px 40px rgba(0,0,0,0.3), 0 0 0 1px var(--p-gold-glow);
}
.p-stat-card .p-stat-icon {
  transition: all 0.45s cubic-bezier(0.23, 1, 0.32, 1);
}
.p-stat-card:hover .p-stat-icon {
  transform: translateZ(20px) scale(1.12) rotateY(8deg);
}

/* ─── 3D Live Student Cards ─── */
.p-live-card {
  transform-style: preserve-3d;
  transition: all 0.4s cubic-bezier(0.23, 1, 0.32, 1);
}
.p-live-card:hover {
  transform: perspective(700px) rotateY(-3deg) translateY(-4px) translateZ(10px);
  box-shadow: 0 12px 30px rgba(0,0,0,0.25);
}

/* ─── 3D Table Row Hover ─── */
.p-table tbody tr {
  transition: all 0.3s cubic-bezier(0.23, 1, 0.32, 1);
}
.p-table tbody tr:hover {
  background: var(--p-surface2);
  transform: translateX(4px);
  box-shadow: -4px 0 0 var(--p-gold);
}

/* ─── 3D Nav Items ─── */
.p-nav-item {
  transform-style: preserve-3d;
}
.p-nav-item:hover {
  transform: translateX(4px) translateZ(4px);
}
.p-nav-item.active {
  transform: translateX(2px);
  box-shadow: inset 3px 0 0 var(--p-gold);
}

/* ─── 3D Modal Entrance ─── */
.p-modal {
  transform-style: preserve-3d;
}
@keyframes p-fadeUp {
  from {
    opacity: 0;
    transform: perspective(800px) rotateX(6deg) translateY(30px) translateZ(-40px) scale(0.94);
  }
  to {
    opacity: 1;
    transform: perspective(800px) rotateX(0deg) translateY(0) translateZ(0) scale(1);
  }
}

/* ─── 3D Portal Card Hover ─── */
.p-card {
  transform-style: preserve-3d;
  transition: all 0.4s cubic-bezier(0.23, 1, 0.32, 1);
}
.p-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 30px rgba(0,0,0,0.2);
}

/* ─── 3D Button Pulse on Gold ─── */
.p-btn-gold {
  position: relative;
  overflow: hidden;
}
.p-btn-gold::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.25) 0%, transparent 50%);
  transform: translateX(-100%);
  transition: transform 0.4s ease;
}
.p-btn-gold:hover::after { transform: translateX(100%); }

/* ─── 3D Toast Notification ─── */
.p-toast.show {
  animation: toastSlide3D 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}
@keyframes toastSlide3D {
  from {
    opacity: 0;
    transform: perspective(400px) translateY(40px) rotateX(10deg) scale(0.9);
  }
  to {
    opacity: 1;
    transform: perspective(400px) translateY(0) rotateX(0deg) scale(1);
  }
}

/* ─── 3D Rating Hero Card ─── */
.rating-hero {
  transform-style: preserve-3d;
  transition: all 0.5s cubic-bezier(0.23, 1, 0.32, 1);
}
.rating-hero:hover {
  transform: perspective(800px) rotateX(-2deg) translateZ(10px);
  box-shadow: 0 20px 50px rgba(91,156,246,0.15);
}

/* ─── 3D Progress Bar ─── */
.p-progress-fill {
  position: relative;
  overflow: hidden;
}
.p-progress-fill::after {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.25), transparent);
  animation: progressShimmer 2.5s ease-in-out infinite;
}
@keyframes progressShimmer {
  from { left: -100%; }
  to   { left: 200%; }
}

/* ─── 3D Sidebar Brand Glow ─── */
.p-brand-icon {
  transition: all 0.4s cubic-bezier(0.23, 1, 0.32, 1);
  transform-style: preserve-3d;
}
.p-brand-icon:hover {
  transform: rotateY(15deg) scale(1.1);
  box-shadow: 0 8px 24px var(--p-gold-glow);
}

/* ==========================================================================
   OFFICIAL CHESSKIDOO PREMIUM STUDENT REPORT CARD
   ========================================================================== */
.report-card-wrapper {
  background: #FBF7EE;
  color: #1C1410;
  font-family: 'Outfit', sans-serif;
  padding: 40px;
  border: 12px solid #4A1019;
  outline: 4px solid #C5952B;
  outline-offset: -8px;
  border-radius: 4px;
  position: relative;
  max-width: 900px;
  margin: 0 auto;
  box-shadow: 0 25px 50px -12px rgba(0,0,0,0.5);
  text-align: left;
}

.report-card-wrapper::before,
.report-card-wrapper::after {
  content: '';
  position: absolute;
  width: 40px;
  height: 40px;
  border-color: #C5952B;
  border-style: solid;
  pointer-events: none;
}
.report-card-wrapper::before {
  top: 10px; left: 10px;
  border-width: 3px 0 0 3px;
}
.report-card-wrapper::after {
  bottom: 10px; right: 10px;
  border-width: 0 3px 3px 0;
}

.rc-crest {
  text-align: center;
  margin-bottom: 30px;
  position: relative;
}
.rc-crest-icon {
  font-size: 3.5rem;
  color: #6B1B2A;
  margin-bottom: 5px;
}
.rc-title {
  font-family: 'Playfair Display', serif;
  font-size: 2.8rem;
  font-weight: 900;
  color: #4A1019;
  margin: 0;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.rc-subtitle {
  font-size: 1rem;
  color: #C5952B;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 700;
  margin-top: 5px;
}

.rc-student-block {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #F3ECDC;
  border: 2px solid #EDE4D0;
  border-radius: 8px;
  padding: 24px 30px;
  margin-bottom: 35px;
  position: relative;
  overflow: hidden;
}
.rc-student-block::before {
  content: '♞';
  position: absolute;
  right: -20px;
  bottom: -30px;
  font-size: 10rem;
  opacity: 0.05;
  color: #6B1B2A;
  pointer-events: none;
}
.rc-student-info {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 15px 30px;
}
.rc-info-item {
  display: flex;
  flex-direction: column;
}
.rc-info-label {
  font-size: 0.75rem;
  text-transform: uppercase;
  color: #7A6B5A;
  letter-spacing: 0.1em;
  font-weight: 700;
  margin-bottom: 3px;
}
.rc-info-val {
  font-size: 1.15rem;
  font-weight: 700;
  color: #1C1410;
}

.rc-rating-badge {
  background: #6B1B2A;
  color: #fff;
  padding: 16px 24px;
  border-radius: 12px;
  text-align: center;
  border: 2px solid #C5952B;
  box-shadow: 0 10px 20px rgba(107,27,42,0.2);
}
.rc-rating-val {
  font-family: 'Poppins', monospace;
  font-size: 2rem;
  font-weight: 800;
  color: #E4B94A;
  line-height: 1;
}
.rc-rating-label {
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-top: 6px;
  color: #FBF7EE;
}

.rc-section-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.6rem;
  font-weight: 800;
  color: #4A1019;
  border-bottom: 2px solid #6B1B2A;
  padding-bottom: 8px;
  margin: 30px 0 20px 0;
  display: flex;
  align-items: center;
  gap: 10px;
}
.rc-section-title::before {
  content: '✦';
  color: #C5952B;
  font-size: 1.2rem;
}

.rc-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid rgba(28, 20, 16, 0.15);
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 30px;
}
.rc-table th {
  background: #6B1B2A;
  color: #fff;
  padding: 14px 18px;
  font-size: 0.85rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 700;
  text-align: left;
}
.rc-table td {
  padding: 14px 18px;
  border-bottom: 1px solid rgba(28, 20, 16, 0.15);
  background: #FBF7EE;
  color: #1C1410;
  font-size: 0.95rem;
  font-weight: 500;
}
.rc-table tr:last-child td {
  border-bottom: none;
}
.rc-table tr:nth-child(even) td {
  background: #F3ECDC;
}

.rc-bar-wrap {
  background: rgba(28, 20, 16, 0.1);
  height: 8px;
  border-radius: 4px;
  overflow: hidden;
  width: 100%;
  max-width: 180px;
}
.rc-bar-fill {
  background: #6B1B2A;
  height: 100%;
  border-radius: 4px;
}
.rc-grade {
  font-weight: 800;
  color: #4A1019;
  font-family: 'Poppins', monospace;
  font-size: 1.1rem;
}

.rc-remarks-box {
  background: #F3ECDC;
  border: 1px solid #C5952B;
  border-radius: 8px;
  padding: 25px;
  margin-bottom: 35px;
  position: relative;
}
.rc-remarks-content {
  font-family: 'Caveat', 'Dancing Script', cursive;
  font-size: 1.6rem;
  line-height: 1.5;
  color: #3D3028;
}

.rc-goals-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 15px;
  margin-bottom: 40px;
}
.rc-goal-item {
  display: flex;
  align-items: center;
  gap: 12px;
  background: #F3ECDC;
  padding: 14px 20px;
  border-radius: 8px;
  border-left: 4px solid #C5952B;
  font-weight: 600;
  color: #1C1410;
}
.rc-goal-check {
  font-size: 1.2rem;
  color: #2D6A30;
}

.rc-signatures {
  display: flex;
  justify-content: space-between;
  margin-top: 50px;
  padding-top: 30px;
  border-top: 2px dashed rgba(28, 20, 16, 0.15);
}
.rc-sig-box {
  text-align: center;
  width: 240px;
}
.rc-sig-line {
  border-bottom: 1px solid #1C1410;
  height: 40px;
  margin-bottom: 8px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  font-family: 'Caveat', 'Dancing Script', cursive;
  font-size: 1.8rem;
  color: #6B1B2A;
}
.rc-sig-title {
  font-size: 0.8rem;
  text-transform: uppercase;
  color: #7A6B5A;
  letter-spacing: 0.1em;
  font-weight: 700;
}



/* ==========================================================================
   WORLD-CLASS PORTAL ENHANCEMENT LAYER v2.0
   ========================================================================== */

/* Sidebar brand gradient glow */
.p-sidebar-brand {
  background: linear-gradient(135deg, rgba(232,184,75,.06) 0%, transparent 70%);
  position: relative;
}
.p-sidebar-brand::after {
  content: ''; position: absolute; bottom: 0; left: 16px; right: 16px; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(232,184,75,.3), transparent);
}

/* Sidebar brand icon pulse */
.p-brand-icon {
  box-shadow: 0 0 0 0 rgba(232,184,75,.4);
  animation: iconGlow 3s ease-in-out infinite;
}
@keyframes iconGlow {
  0%,100% { box-shadow: 0 4px 16px rgba(232,184,75,.2); }
  50% { box-shadow: 0 4px 24px rgba(232,184,75,.45), 0 0 0 4px rgba(232,184,75,.08); }
}

/* Nav item active gold indicator */
.p-nav-item.active {
  background: linear-gradient(90deg, rgba(232,184,75,.12), rgba(232,184,75,.04));
  color: var(--p-gold);
  border: 1px solid rgba(232,184,75,.2);
  box-shadow: inset 3px 0 0 var(--p-gold);
}
.p-nav-item.active .icon { filter: drop-shadow(0 0 6px rgba(232,184,75,.5)); }

/* Topbar glass enhancement */
.p-topbar {
  background: rgba(10,12,15,.96);
  backdrop-filter: blur(20px) saturate(180%);
  box-shadow: 0 1px 0 rgba(255,255,255,.05), 0 4px 24px rgba(0,0,0,.15);
}

/* Stat card gradient top border */
.p-stat-card {
  position: relative; overflow: hidden;
}
.p-stat-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--p-gold), var(--p-teal));
  transform: scaleX(0); transform-origin: left;
  transition: transform .6s cubic-bezier(.23,1,.32,1);
}
.p-stat-card:hover::before { transform: scaleX(1); }
.p-stat-card::after {
  content: ''; position: absolute; top: -60px; right: -60px;
  width: 140px; height: 140px;
  background: radial-gradient(circle, rgba(232,184,75,.04), transparent 70%);
  pointer-events: none;
}

/* Stat value big text glow on hover */
.p-stat-card:hover .p-stat-val {
  background: linear-gradient(135deg, var(--p-gold), var(--p-teal));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}

/* Better stat change badges */
.p-stat-change { border-radius: 8px; font-weight: 700; letter-spacing: .02em; }
.p-stat-change.up {
  background: linear-gradient(135deg, rgba(34,209,160,.15), rgba(34,209,160,.05));
  border: 1px solid rgba(34,209,160,.2); color: #22d1a0;
}
.p-stat-change.down {
  background: linear-gradient(135deg, rgba(239,83,80,.15), rgba(239,83,80,.05));
  border: 1px solid rgba(239,83,80,.2); color: var(--p-danger);
}

/* Card header gradient line */
.p-card-header {
  background: linear-gradient(90deg, rgba(255,255,255,.02), transparent);
  position: relative;
}
.p-card-header::after {
  content: ''; position: absolute; bottom: 0; left: 22px; right: 22px; height: 1px;
  background: linear-gradient(90deg, transparent, var(--p-border), transparent);
}

/* Table zebra stripes */
.p-table tbody tr:nth-child(even) { background: rgba(255,255,255,.012); }
.p-table tbody tr:hover {
  background: rgba(232,184,75,.05);
  transform: translateX(4px);
  box-shadow: -3px 0 0 var(--p-gold);
}

/* Badge glow variants */
.p-badge-green { box-shadow: 0 0 8px rgba(34,209,160,.2); }
.p-badge-gold { box-shadow: 0 0 8px rgba(232,184,75,.2); }
.p-badge-blue { box-shadow: 0 0 8px rgba(91,156,246,.2); }
.p-badge-red { box-shadow: 0 0 8px rgba(239,83,80,.2); }

/* Progress bar shimmer */
.p-progress-fill {
  position: relative; overflow: hidden;
}
.p-progress-fill::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.3), transparent);
  animation: progressShimmer 2s linear infinite;
}
@keyframes progressShimmer {
  from { transform: translateX(-100%); }
  to   { transform: translateX(100%); }
}

/* Better form controls */
.p-form-control {
  transition: all .22s cubic-bezier(.4,0,.2,1);
}
.p-form-control:focus {
  border-color: var(--p-gold);
  box-shadow: 0 0 0 3px rgba(232,184,75,.12);
  background: var(--p-surface3);
}

/* User card hover shimmer */
.p-user-card:hover {
  background: linear-gradient(90deg, rgba(232,184,75,.05), rgba(0,201,167,.03));
}

/* Live card online glow */
.p-live-card.online {
  border-left-color: var(--p-online);
  box-shadow: -3px 0 12px rgba(34,209,160,.15);
}

/* Better button states */
.p-btn-gold {
  background: linear-gradient(135deg, var(--p-gold) 0%, #c89328 100%);
  box-shadow: 0 4px 14px rgba(232,184,75,.3);
  transition: all .22s cubic-bezier(.4,0,.2,1);
}
.p-btn-gold:hover {
  box-shadow: 0 6px 20px rgba(232,184,75,.45);
  transform: translateY(-2px);
}
.p-btn-teal {
  box-shadow: 0 4px 14px rgba(0,201,167,.25);
}
.p-btn-teal:hover {
  box-shadow: 0 6px 20px rgba(0,201,167,.4);
}
.p-btn-blue {
  box-shadow: 0 4px 14px rgba(91,156,246,.25);
}
.p-btn-blue:hover {
  box-shadow: 0 6px 20px rgba(91,156,246,.4);
}

/* Portal welcome banner (new class) */
.p-welcome-banner {
  background: linear-gradient(135deg, rgba(232,184,75,.08) 0%, rgba(0,201,167,.04) 100%);
  border: 1px solid rgba(232,184,75,.15);
  border-radius: var(--p-radius);
  padding: 24px 28px;
  position: relative; overflow: hidden;
  display: flex; align-items: center; gap: 20px;
}
.p-welcome-banner::before {
  content: ''; position: absolute; top: -30px; right: -30px;
  width: 120px; height: 120px;
  background: radial-gradient(circle, rgba(232,184,75,.1), transparent 70%);
  pointer-events: none;
}
.p-welcome-icon { font-size: 3rem; flex-shrink: 0; }
.p-welcome-text h2 { font-family: Poppins,sans-serif; font-size: 1.4rem; font-weight: 700; color: var(--p-gold); margin: 0 0 4px; }
.p-welcome-text p { font-size: .88rem; color: var(--p-text-muted); margin: 0; }
.p-welcome-actions { margin-left: auto; display: flex; gap: 10px; flex-shrink: 0; }

/* Notification dot pulse */
.p-notif-dot {
  animation: notifPulse 2s ease-in-out infinite;
}
@keyframes notifPulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(239,83,80,0); }
  50% { box-shadow: 0 0 0 4px rgba(239,83,80,.2); }
}

/* Portal topbar search focus glow */
.p-topbar-search input:focus {
  box-shadow: 0 0 0 3px rgba(232,184,75,.12);
  border-color: var(--p-gold);
}

/* Card shimmer on load */
@keyframes cardFadeIn {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
.p-panel.active .p-stat-card { animation: cardFadeIn .4s cubic-bezier(.16,1,.3,1) both; }
.p-panel.active .p-stat-card:nth-child(1) { animation-delay: .05s; }
.p-panel.active .p-stat-card:nth-child(2) { animation-delay: .12s; }
.p-panel.active .p-stat-card:nth-child(3) { animation-delay: .19s; }
.p-panel.active .p-stat-card:nth-child(4) { animation-delay: .26s; }
.p-panel.active .p-card { animation: cardFadeIn .5s cubic-bezier(.16,1,.3,1) both; }

/* Better scrollbar */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,.08); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--p-gold); }

/* Section separator polish */
.p-section-sep {
  height: 1px; margin: 6px 0;
  background: linear-gradient(90deg, transparent, var(--p-border), transparent);
}

/* Chart wrap glow */
.p-chart-wrap canvas { border-radius: 8px; }

/* Live indicator enhanced */
.p-live-dot {
  box-shadow: 0 0 0 3px rgba(34,209,160,.2);
}

/* Topbar title gradient */
.p-topbar-title {
  background: linear-gradient(135deg, var(--p-text) 0%, var(--p-text-muted) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}

/* Sidebar nav overflow smoother */
.p-sidebar-nav { scrollbar-width: none; }
.p-sidebar-nav::-webkit-scrollbar { display: none; }

/* Modal blur backdrop */
.p-modal-overlay { backdrop-filter: blur(12px) saturate(150%); }

/* Rating hero card */
.rating-num {
  background: linear-gradient(135deg, var(--p-blue) 0%, #7ab4ff 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}

/* Toast enhanced */
.p-toast { box-shadow: 0 8px 32px rgba(0,0,0,.4), 0 0 0 1px rgba(255,255,255,.05); }
.p-toast.success { background: linear-gradient(135deg, var(--p-surface), rgba(34,209,160,.06)); }
.p-toast.error { background: linear-gradient(135deg, var(--p-surface), rgba(239,83,80,.06)); }

/* Icon buttons enhanced */
.p-icon-btn { transition: all .22s cubic-bezier(.4,0,.2,1); }
.p-icon-btn:hover { background: var(--p-surface3); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(0,0,0,.2); }

/* Panel active fade in */
.p-panel { transition: opacity .3s ease; }
.p-panel.active { animation: panelIn .35s cubic-bezier(.16,1,.3,1); }
@keyframes panelIn {
  from { opacity: 0; transform: translateX(8px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* ==========================================================================
   WORLD-CLASS PORTAL ENHANCEMENT LAYER v3.0
   ========================================================================== */

/* Achievement badge cards */
.p-achievement-card {
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.05);
  border-radius: 14px;
  padding: 16px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  transition: all .28s cubic-bezier(.4,0,.2,1);
  opacity: .4;
}
.p-achievement-card.unlocked {
  background: var(--p-surface2);
  border-color: rgba(232,184,75,.18);
  opacity: 1;
  box-shadow: 0 4px 16px rgba(0,0,0,.2);
}
.p-achievement-card.unlocked:hover {
  border-color: rgba(232,184,75,.38);
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(0,0,0,.28), 0 0 0 1px rgba(232,184,75,.15);
}
.p-achievement-icon {
  font-size: 2rem;
  flex-shrink: 0;
  width: 52px; height: 52px;
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.04);
  transition: all .28s;
}
.p-achievement-card.unlocked .p-achievement-icon {
  background: rgba(232,184,75,.1);
  box-shadow: 0 0 14px rgba(232,184,75,.18);
}
.p-achievement-title {
  font-weight: 700;
  font-size: .9rem;
  color: var(--p-text-muted);
}
.p-achievement-card.unlocked .p-achievement-title { color: var(--p-gold); }
.p-achievement-desc {
  font-size: .75rem;
  color: var(--p-text-muted);
  line-height: 1.4;
  margin-top: 3px;
  opacity: .75;
}

/* Coach review note card */
.p-review-note {
  background: var(--p-surface2);
  border: 1px solid rgba(255,255,255,.05);
  border-left: 4px solid var(--p-gold);
  border-radius: 12px;
  padding: 18px 20px;
  margin-bottom: 14px;
  transition: all .22s ease;
}
.p-review-note:hover {
  border-left-color: var(--p-teal);
  background: rgba(255,255,255,.025);
  transform: translateX(4px);
}
.p-review-note-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}
.p-review-note-coach {
  font-weight: 700;
  font-family: var(--font-display);
  color: var(--p-text);
  font-size: 1rem;
}
.p-review-note-date { font-size: .8rem; color: var(--p-text-muted); }
.p-review-note-text {
  margin: 0;
  font-size: .92rem;
  line-height: 1.65;
  color: rgba(255,255,255,.82);
  font-style: italic;
}

/* Resource item card */
.p-resource-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 15px 18px;
  background: var(--p-surface3);
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.05);
  margin-bottom: 10px;
  transition: all .22s ease;
}
.p-resource-item:hover {
  border-color: rgba(91,156,246,.28);
  background: rgba(91,156,246,.04);
  transform: translateX(3px);
}
.p-resource-name {
  font-weight: 600;
  color: var(--p-blue);
  display: flex;
  align-items: center;
  gap: 8px;
}
.p-resource-note { font-size: .85rem; color: var(--p-text-muted); margin-top: 4px; }

/* Puzzle list card */
.p-puzzle-card {
  background: var(--p-surface2);
  border: 1px solid rgba(255,255,255,.05);
  border-radius: 14px;
  padding: 18px;
  display: flex;
  align-items: center;
  gap: 14px;
  cursor: pointer;
  transition: all .25s cubic-bezier(.4,0,.2,1);
}
.p-puzzle-card:hover {
  background: var(--p-surface3);
  border-color: rgba(232,184,75,.22);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,.22);
}
.p-puzzle-icon {
  width: 50px; height: 50px;
  border-radius: 12px;
  background: rgba(232,184,75,.08);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem;
  flex-shrink: 0;
  transition: background .22s;
}
.p-puzzle-card:hover .p-puzzle-icon { background: rgba(232,184,75,.15); }
.p-puzzle-info { flex: 1; }
.p-puzzle-title { font-weight: 700; font-size: .95rem; color: var(--p-text); }
.p-puzzle-sub { font-size: .8rem; color: var(--p-text-muted); margin-top: 3px; }

/* Tournament card */
.p-tournament-card {
  border-radius: 14px;
  padding: 22px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  transition: all .25s ease;
}
.p-tournament-card.major {
  background: linear-gradient(135deg, rgba(212,175,55,.1), rgba(0,0,0,0));
  border: 1px solid rgba(212,175,55,.3);
}
.p-tournament-card.weekly {
  background: var(--p-surface3);
  border: 1px solid rgba(255,255,255,.05);
}
.p-tournament-card:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,0,0,.22); }
.p-tournament-title { font-family: var(--font-display); font-size: 1.35rem; margin-bottom: 5px; color: #fff; }
.p-tournament-meta { display: flex; gap: 16px; font-size: .88rem; color: var(--p-text-muted); flex-wrap: wrap; margin-top: 6px; }

/* Attendance calendar cells */
.p-cal-cell {
  border-radius: 8px;
  padding: 8px 4px;
  font-size: .88rem;
  text-align: center;
  border: 1px solid rgba(255,255,255,.05);
  background: var(--p-surface2);
  transition: all .18s ease;
  min-width: 36px;
}
.p-cal-cell.header {
  background: transparent;
  border: none;
  font-weight: 800;
  color: var(--p-text-muted);
  font-size: .75rem;
  padding-bottom: 4px;
}
.p-cal-cell.present {
  background: rgba(0,201,167,.15);
  border-color: var(--p-teal);
  color: var(--p-teal);
  font-weight: 700;
}
.p-cal-cell.absent {
  background: rgba(255,107,107,.15);
  border-color: var(--p-danger);
  color: var(--p-danger);
  font-weight: 700;
}
.p-cal-cell:not(.header):hover { border-color: rgba(232,184,75,.3); }

/* Extra stat card animation delays */
.p-panel.active .p-stat-card:nth-child(5) { animation-delay: .33s; }
.p-panel.active .p-stat-card:nth-child(6) { animation-delay: .40s; }

/* Section label bar */
.p-kpi-title {
  display: flex; align-items: center; gap: 10px;
  font-size: .76rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em;
  color: var(--p-text-muted); margin-bottom: 4px;
}
.p-kpi-title::after { content: ''; flex: 1; height: 1px; background: var(--p-border); }

/* Settings panel */
.p-settings-section {
  background: var(--p-surface2);
  border: 1px solid rgba(255,255,255,.05);
  border-radius: 14px;
  padding: 24px;
  margin-bottom: 20px;
  transition: border-color .22s;
}
.p-settings-section:hover { border-color: rgba(232,184,75,.12); }
.p-settings-title {
  font-family: var(--font-display);
  font-size: 1.05rem; font-weight: 700;
  color: var(--p-gold);
  margin-bottom: 16px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.p-settings-row {
  display: flex; align-items: center;
  justify-content: space-between;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
  gap: 16px;
}
.p-settings-row:last-child { border-bottom: none; }
.p-settings-label { font-size: .9rem; color: var(--p-text); }
.p-settings-desc { font-size: .78rem; color: var(--p-text-muted); margin-top: 2px; }
.p-toggle {
  width: 44px; height: 24px;
  background: rgba(255,255,255,.1);
  border-radius: 12px;
  cursor: pointer;
  position: relative;
  transition: background .22s;
  flex-shrink: 0;
  border: 1px solid rgba(255,255,255,.1);
}
.p-toggle.on { background: var(--p-teal); border-color: var(--p-teal); }
.p-toggle::after {
  content: '';
  position: absolute;
  width: 18px; height: 18px;
  background: #fff;
  border-radius: 50%;
  top: 2px; left: 2px;
  transition: transform .22s cubic-bezier(.4,0,.2,1);
  box-shadow: 0 1px 4px rgba(0,0,0,.3);
}
.p-toggle.on::after { transform: translateX(20px); }

/* Activity table row */
.p-activity-row { transition: all .2s ease; }
.p-activity-row:hover { background: rgba(232,184,75,.04); }
.p-activity-icon {
  width: 34px; height: 34px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; flex-shrink: 0;
}

/* Coach report card editor form */
.p-report-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 14px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(255,255,255,.05);
}
.p-report-row:last-child { border-bottom: none; }
.p-report-label { font-size: .88rem; color: var(--p-text); }
.p-report-score {
  width: 72px;
  background: var(--p-surface3);
  border: 1px solid var(--p-border);
  border-radius: 8px;
  color: var(--p-text);
  text-align: center;
  padding: 6px 8px;
  font-weight: 700;
  font-size: 1rem;
}
.p-report-score:focus {
  border-color: var(--p-gold);
  box-shadow: 0 0 0 3px rgba(232,184,75,.12);
  outline: none;
}
.p-report-grade {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: rgba(232,184,75,.12);
  border: 1px solid rgba(232,184,75,.2);
  color: var(--p-gold);
  font-weight: 800;
  font-size: .9rem;
  display: flex; align-items: center; justify-content: center;
}

/* =====================================================================
   PGN LAB v2.0 — Move List, Eval Bar, Board Container
   ===================================================================== */

.lab-board-container {
  width: 100%;
  aspect-ratio: 1 / 1;
  border: 3px solid var(--p-blue);
  border-radius: 8px;
  overflow: hidden;
  background: #111;
}

.lab-eval-panel {
  background: var(--p-surface3);
  padding: 14px 16px;
  border-radius: 12px;
  border: 1px solid rgba(91,156,246,0.15);
}

.lab-eval-bar-track {
  height: 9px;
  background: var(--p-surface2);
  border-radius: 5px;
  overflow: hidden;
  margin-bottom: 6px;
}

.lab-eval-bar-fill {
  height: 100%;
  background: var(--p-blue);
  border-radius: 5px;
  transition: width 0.45s cubic-bezier(.4,0,.2,1), background-color 0.3s;
}

.lab-move-list {
  background: var(--p-surface3);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px;
  padding: 10px 8px;
  max-height: 220px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,0.1) transparent;
}

.lab-ml-empty {
  color: rgba(255,255,255,0.25);
  text-align: center;
  padding: 20px;
  font-size: 0.83rem;
}

.lab-move-row {
  display: grid;
  grid-template-columns: 28px 1fr 1fr;
  align-items: center;
  border-radius: 6px;
  margin-bottom: 1px;
}

.lab-move-row:hover {
  background: rgba(255,255,255,0.03);
}

.lab-move-num {
  font-size: 0.75rem;
  color: rgba(255,255,255,0.28);
  font-weight: 600;
  padding: 4px 2px;
  text-align: right;
}

.lab-move-san {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.72);
  padding: 5px 8px;
  border-radius: 5px;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
  font-family: "Courier New", monospace;
  letter-spacing: 0.01em;
}

.lab-move-san:hover {
  background: rgba(255,255,255,0.08);
  color: #fff;
}

.lab-move-san.active {
  background: rgba(91,156,246,0.22);
  color: var(--p-blue);
  font-weight: 700;
  box-shadow: inset 0 0 0 1px rgba(91,156,246,0.3);
}

.lab-annot {
  font-size: 0.78rem;
  font-style: normal;
  margin-left: 2px;
  font-weight: 800;
  color: var(--p-gold);
}

/* =====================================================================
   PGN LAB v3.0 — Board-Centric Layout, Vertical Eval Bar, Mode Buttons
   ===================================================================== */

.lab-main-grid {
  display: grid;
  grid-template-columns: 1fr 262px;
  gap: 18px;
  align-items: start;
  margin-bottom: 22px;
}

.lab-board-section {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.lab-board-with-vbar {
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: 8px;
  align-items: stretch;
}

.lab-vbar-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
}

.lab-vbar-track {
  flex: 1;
  width: 14px;
  background: #1a1a2e;
  border-radius: 7px;
  overflow: hidden;
  position: relative;
  min-height: 60px;
}

.labVBarFill {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: #f0ede8;
  transition: height 0.5s cubic-bezier(.4,0,.2,1);
  border-radius: 0 0 7px 7px;
}

.lab-vbar-score {
  font-size: 0.6rem;
  color: rgba(255,255,255,0.3);
  line-height: 1;
}

.lab-nav-row {
  display: flex;
  gap: 5px;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}

.lab-side-panel {
  display: flex;
  flex-direction: column;
}

.lab-mode-row {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  align-items: center;
}

.lab-mode-btn {
  padding: 5px 13px;
  border: 1px solid rgba(91,156,246,0.28);
  border-radius: 20px;
  background: transparent;
  color: rgba(255,255,255,0.5);
  font-size: 0.78rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
  font-family: inherit;
}

.lab-mode-btn:hover {
  background: rgba(91,156,246,0.1);
  color: #fff;
  border-color: rgba(91,156,246,0.5);
}

.lab-mode-btn.active {
  background: rgba(91,156,246,0.2);
  border-color: var(--p-blue);
  color: var(--p-blue);
}

.lab-mode-btn.active-guess {
  background: rgba(20,184,166,0.18);
  border-color: var(--p-teal);
  color: var(--p-teal);
}

.lab-mode-btn.active-spar {
  background: rgba(251,191,36,0.15);
  border-color: var(--p-gold);
  color: var(--p-gold);
}

.lab-mode-banner {
  padding: 10px 15px;
  border-radius: 10px;
  margin-bottom: 14px;
  font-size: 0.87rem;
  border: 1px solid;
  line-height: 1.5;
}

.lab-mode-banner-analysis {
  background: rgba(91,156,246,0.07);
  border-color: rgba(91,156,246,0.22);
  color: #a0c0f8;
}

.lab-mode-banner-guess {
  background: rgba(20,184,166,0.08);
  border-color: rgba(20,184,166,0.28);
  color: #5fd4c8;
}

.lab-mode-banner-spar {
  background: rgba(251,191,36,0.07);
  border-color: rgba(251,191,36,0.28);
  color: #f8d96a;
}

.lab-guess-highlight {
  box-shadow: inset 0 0 0 3px var(--p-teal) !important;
  background: rgba(20,184,166,0.3) !important;
}

.lab-guess-hint {
  box-shadow: inset 0 0 0 2px rgba(20,184,166,0.4) !important;
}

@media (max-width: 720px) {
  .lab-main-grid {
    grid-template-columns: 1fr;
  }
  .lab-vbar-wrap {
    display: none;
  }
  .lab-board-with-vbar {
    grid-template-columns: 1fr;
  }
}

/* =====================================================================
   CHESS-NATIVE CLASSROOM — Homework, Live Session, Grades, PGN Library
   ===================================================================== */

/* Tab buttons */
.sc-tab-btn, .cc-tab-btn {
  padding: 5px 14px;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 20px;
  background: transparent;
  color: rgba(255,255,255,0.45);
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  font-family: inherit;
}
.sc-tab-btn:hover, .cc-tab-btn:hover { background: rgba(255,255,255,0.07); color: #fff; }
.sc-tab-btn.active, .cc-tab-btn.active {
  background: rgba(91,156,246,0.2);
  border-color: var(--p-blue);
  color: var(--p-blue);
}

/* Homework list */
.cls-empty {
  text-align: center;
  padding: 48px 20px;
  color: rgba(255,255,255,0.45);
  font-size: 0.95rem;
  background: rgba(17, 20, 24, 0.3);
  border: 2px dashed rgba(255,255,255,0.08);
  border-radius: 20px;
  margin: 16px 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: all 0.3s ease;
}
.cls-empty:hover {
  border-color: rgba(255,255,255,0.15);
  background: rgba(17, 20, 24, 0.5);
}

.cls-hw-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: var(--p-surface3);
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.07);
  margin-bottom: 10px;
  transition: border-color 0.2s;
}
.cls-hw-card:hover { border-color: rgba(91,156,246,0.3); }
.cls-hw-card.cls-hw-done { border-color: rgba(20,184,166,0.25); background: rgba(20,184,166,0.04); }

.cls-hw-icon {
  font-size: 1.6rem;
  flex-shrink: 0;
  width: 38px;
  text-align: center;
}

.cls-hw-info { flex: 1; min-width: 0; }
.cls-hw-title { font-size: 0.97rem; font-weight: 700; color: #fff; margin-bottom: 2px; }
.cls-hw-meta  { font-size: 0.78rem; color: var(--p-text-muted); }
.cls-hw-desc  { font-size: 0.82rem; color: rgba(255,255,255,0.45); margin-top: 4px; }

.cls-hw-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 7px;
  flex-shrink: 0;
}

.cls-badge {
  font-size: 0.72rem;
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 20px;
  white-space: nowrap;
}
.cls-badge-done    { background: rgba(20,184,166,0.18); color: var(--p-teal); }
.cls-badge-pending { background: rgba(251,191,36,0.15); color: var(--p-gold); }

/* Guess mode banner */
.cls-guess-banner {
  padding: 9px 14px;
  border-radius: 9px;
  font-size: 0.87rem;
  margin-bottom: 14px;
  border: 1px solid;
}
.cls-guess-active { background: rgba(20,184,166,0.08); border-color: rgba(20,184,166,0.3); color: #5fd4c8; }
.cls-guess-done   { background: rgba(251,191,36,0.08);  border-color: rgba(251,191,36,0.3);  color: #f8d96a; }

/* Live dot */
.cls-live-dot {
  display: inline-block;
  width: 9px;
  height: 9px;
  background: #ef4444;
  border-radius: 50%;
  animation: livePulse 1.2s ease-in-out infinite;
  vertical-align: middle;
}
@keyframes livePulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.5; transform: scale(0.75); }
}

/* Assignment rows */
.cls-assign-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: var(--p-surface3);
  border-radius: 9px;
  border: 1px solid rgba(255,255,255,0.06);
  margin-bottom: 8px;
}
.cls-type-icon { font-size: 1.2rem; flex-shrink: 0; }
.cls-assign-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
  font-size: 0.87rem;
  color: #fff;
}
.cls-assign-info span { font-size: 0.76rem; color: var(--p-text-muted); }

/* Grades */
.cls-grade-section { margin-bottom: 22px; }
.cls-grade-title {
  font-size: 0.95rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 10px;
  padding-bottom: 7px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.cls-grade-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.84rem;
}
.cls-grade-table th {
  text-align: left;
  padding: 6px 10px;
  font-size: 0.73rem;
  font-weight: 700;
  color: rgba(255,255,255,0.35);
  letter-spacing: .05em;
  text-transform: uppercase;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.cls-grade-table td {
  padding: 8px 10px;
  color: rgba(255,255,255,0.75);
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.cls-grade-table tr:last-child td { border-bottom: none; }

/* PGN Library cards */
.cls-lib-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 14px;
  background: var(--p-surface3);
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.07);
  margin-bottom: 8px;
  transition: border-color 0.2s;
}
.cls-lib-card:hover { border-color: rgba(91,156,246,0.3); }
.cls-lib-icon { font-size: 1.4rem; flex-shrink: 0; }
.cls-lib-info { flex: 1; min-width: 0; }
.cls-lib-title { font-size: 0.9rem; font-weight: 700; color: #fff; }
.cls-lib-meta  { font-size: 0.76rem; color: var(--p-text-muted); margin-top: 2px; }

/* Live session board area */
#scLiveBoardWrap .lab-board-container { border-color: var(--p-teal); }

/* =====================================================================
   GAMES PAGE — Score Strip, Card Best Score, New Badge, Quiz Styles
   ===================================================================== */

.games-score-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-bottom: 28px;
  padding: 14px 20px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 14px;
}

.score-strip-item {
  display: flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 8px;
  padding: 6px 12px;
  font-size: 0.8rem;
}

.score-strip-icon { font-size: 1.1rem; }
.score-strip-label { color: rgba(255,255,255,0.5); }
.score-strip-val { color: #fbbf24; font-weight: 700; min-width: 20px; text-align: right; }

.card-best {
  margin-top: 10px;
  font-size: 0.77rem;
  color: rgba(255,255,255,0.35);
  border-top: 1px solid rgba(255,255,255,0.07);
  padding-top: 8px;
}

.card-best span { color: #fbbf24; font-weight: 700; }

.game-new-badge {
  position: absolute;
  top: 12px;
  right: 12px;
  background: linear-gradient(135deg, #f472b6, #a855f7);
  color: #fff;
  font-size: 0.65rem;
  font-weight: 800;
  padding: 3px 8px;
  border-radius: 20px;
  letter-spacing: .08em;
  animation: newBadgePulse 2s ease-in-out infinite;
}

@keyframes newBadgePulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(244,114,182,0.4); }
  50% { box-shadow: 0 0 0 6px rgba(244,114,182,0); }
}

.game-card { position: relative; }

/* Quiz game styles */
.quiz-wrapper {
  width: 100%;
  max-width: 680px;
  margin: 0 auto;
  padding: 20px;
}

.quiz-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.88rem;
  color: rgba(255,255,255,0.55);
  margin-bottom: 10px;
}

.quiz-timer-track {
  height: 6px;
  background: rgba(255,255,255,0.08);
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 20px;
}

.quiz-timer-bar {
  height: 100%;
  width: 100%;
  background: linear-gradient(90deg, #fbbf24, #f472b6);
  border-radius: 3px;
  transition: width 1s linear;
}

.quiz-question {
  font-size: 1.25rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.45;
  margin-bottom: 24px;
  font-family: "Poppins", sans-serif;
}

.quiz-options {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 16px;
}

.quiz-opt-btn {
  background: rgba(255,255,255,0.06);
  border: 1.5px solid rgba(255,255,255,0.12);
  color: #fff;
  font-size: 0.95rem;
  font-family: "Inter", sans-serif;
  padding: 14px 18px;
  border-radius: 10px;
  cursor: pointer;
  transition: background 0.18s, border-color 0.18s, transform 0.15s;
  text-align: left;
}

.quiz-opt-btn:hover:not(:disabled) {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.25);
  transform: translateY(-1px);
}

.quiz-opt-btn.correct {
  background: rgba(34,197,94,0.2);
  border-color: #22c55e;
  color: #22c55e;
  font-weight: 700;
}

.quiz-opt-btn.wrong {
  background: rgba(239,68,68,0.2);
  border-color: #ef4444;
  color: #ef4444;
}

.quiz-opt-btn:disabled { cursor: not-allowed; }

.quiz-explanation {
  background: rgba(255,255,255,0.04);
  border-left: 3px solid #22c55e;
  border-radius: 8px;
  padding: 12px 16px;
  font-size: 0.88rem;
  color: rgba(255,255,255,0.72);
  line-height: 1.55;
  animation: fadeInUp 0.3s ease;
}

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}


/* =====================================================================
   PORTAL-SPECIFIC FONTS — distinct identity for each portal
   ===================================================================== */

/* Student Portal — Outfit (modern, rounded, youth-energy) */
#student-page .p-brand-name,
#student-page .p-card-title,
#student-page .p-topbar-title,
#student-page .p-welcome-text h2,
#student-page .p-stat-val,
#student-page h1, #student-page h2, #student-page h3 {
  font-family: 'Outfit', sans-serif;
}
#student-page {
  --portal-accent: var(--p-blue);
  --portal-sidebar-font: 'Outfit', sans-serif;
}
#student-page .p-sidebar { font-family: 'Outfit', sans-serif; }
#student-page .p-nav-item { font-family: 'Outfit', sans-serif; font-weight: 500; }

/* Coach Portal — Plus Jakarta Sans (professional, confident, premium) */
#coach-page .p-brand-name,
#coach-page .p-card-title,
#coach-page .p-topbar-title,
#coach-page .p-welcome-text h2,
#coach-page .p-stat-val,
#coach-page h1, #coach-page h2, #coach-page h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
}
#coach-page {
  --portal-accent: var(--p-teal);
  --portal-sidebar-font: 'Plus Jakarta Sans', sans-serif;
}
#coach-page .p-sidebar { font-family: 'Plus Jakarta Sans', sans-serif; }
#coach-page .p-nav-item { font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 500; }

/* Admin Portal — Space Grotesk (technical, data-driven, authority) */
#admin-page .p-brand-name,
#admin-page .p-card-title,
#admin-page .p-topbar-title,
#admin-page .p-welcome-text h2,
#admin-page .p-stat-val,
#admin-page h1, #admin-page h2, #admin-page h3 {
  font-family: 'Space Grotesk', sans-serif;
}
#admin-page {
  --portal-accent: var(--p-gold);
  --portal-sidebar-font: 'Space Grotesk', sans-serif;
}
#admin-page .p-sidebar { font-family: 'Space Grotesk', sans-serif; }
#admin-page .p-nav-item { font-family: 'Space Grotesk', sans-serif; font-weight: 500; }

/* =====================================================================
   STUDENT DASHBOARD — Upcoming Session Card
   ===================================================================== */

.sd-session-card {
  position: relative;
  background: linear-gradient(135deg, rgba(91,156,246,0.12) 0%, rgba(45,212,191,0.08) 100%);
  border: 1px solid rgba(91,156,246,0.25);
  border-radius: 16px;
  padding: 20px 22px;
  overflow: hidden;
}

.sd-session-glow {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 20% 50%, rgba(91,156,246,0.08) 0%, transparent 60%);
  pointer-events: none;
}

.sd-session-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}

.sd-session-live-badge {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: .1em;
  color: #22c55e;
  background: rgba(34,197,94,0.12);
  border: 1px solid rgba(34,197,94,0.3);
  border-radius: 20px;
  padding: 4px 12px;
  animation: livePulse 2s ease-in-out infinite;
}

@keyframes livePulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.65; }
}

.sd-session-countdown-wrap {
  display: flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,0.05);
  border-radius: 8px;
  padding: 4px 12px;
}

.sd-session-countdown-label {
  font-size: 0.73rem;
  color: rgba(255,255,255,0.45);
}

.sd-session-countdown-val {
  font-size: 0.95rem;
  font-weight: 800;
  color: #fbbf24;
  font-family: 'Space Grotesk', 'Outfit', monospace;
}

.sd-session-body {
  display: flex;
  align-items: center;
  gap: 16px;
}

.sd-session-icon {
  font-size: 2.8rem;
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, rgba(91,156,246,0.2), rgba(45,212,191,0.1));
  border: 1px solid rgba(91,156,246,0.25);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.sd-session-info { flex: 1; min-width: 0; }

.sd-session-time {
  font-size: 1.5rem;
  font-weight: 800;
  color: #fff;
  line-height: 1;
  margin-bottom: 4px;
  font-family: 'Outfit', 'Space Grotesk', sans-serif;
}

.sd-session-name {
  font-size: 0.95rem;
  font-weight: 700;
  color: rgba(255,255,255,0.9);
  margin-bottom: 3px;
}

.sd-session-coach {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.5);
  margin-bottom: 10px;
}

.sd-session-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.sd-meta-chip {
  font-size: 0.72rem;
  padding: 3px 8px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 20px;
  color: rgba(255,255,255,0.6);
}

.sd-join-btn {
  background: linear-gradient(135deg, var(--p-blue), #2563eb);
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 12px 18px;
  font-size: 0.88rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: transform 0.2s, box-shadow 0.2s;
  box-shadow: 0 4px 16px rgba(91,156,246,0.3);
  font-family: 'Outfit', sans-serif;
}

.sd-join-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(91,156,246,0.45);
}

.sd-join-btn span {
  display: inline-block;
  transition: transform 0.2s;
}

.sd-join-btn:hover span { transform: translateX(3px); }

/* =====================================================================
   STUDENT DASHBOARD — Recommended Learning Cards
   ===================================================================== */

.sd-lesson-card {
  display: flex;
  align-items: center;
  gap: 14px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 12px;
  padding: 14px;
  transition: background 0.2s, border-color 0.2s, transform 0.2s;
}

.sd-lesson-card:hover {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.14);
  transform: translateX(3px);
}

.sd-lesson-icon {
  width: 46px;
  height: 46px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}

.sd-lesson-body { flex: 1; min-width: 0; }

.sd-lesson-name {
  font-size: 0.9rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 6px;
  font-family: 'Outfit', 'Plus Jakarta Sans', sans-serif;
}

.sd-lesson-tags {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}

.sd-lesson-tag {
  font-size: 0.7rem;
  padding: 2px 7px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 20px;
  color: rgba(255,255,255,0.6);
}

.sd-lesson-xp {
  font-size: 0.7rem;
  padding: 2px 7px;
  background: rgba(251,191,36,0.12);
  border: 1px solid rgba(251,191,36,0.25);
  border-radius: 20px;
  color: #fbbf24;
  font-weight: 700;
}

.sd-lesson-prog-track {
  height: 4px;
  background: rgba(255,255,255,0.08);
  border-radius: 2px;
  overflow: hidden;
  margin-bottom: 4px;
}

.sd-lesson-prog-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--p-gold), var(--p-teal));
  border-radius: 2px;
  transition: width 0.6s ease;
}

.sd-lesson-prog-label {
  font-size: 0.7rem;
  color: rgba(255,255,255,0.3);
}

.sd-lesson-btn {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.8);
  border-radius: 8px;
  padding: 8px 14px;
  font-size: 0.8rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.18s;
  flex-shrink: 0;
  font-family: 'Outfit', sans-serif;
}

.sd-lesson-btn.resume {
  background: rgba(251,191,36,0.12);
  border-color: rgba(251,191,36,0.3);
  color: #fbbf24;
}

.sd-lesson-btn.resume:hover {
  background: rgba(251,191,36,0.22);
  transform: scale(1.04);
}

.sd-lesson-btn.start {
  background: rgba(91,156,246,0.12);
  border-color: rgba(91,156,246,0.3);
  color: var(--p-blue);
}

.sd-lesson-btn.start:hover {
  background: rgba(91,156,246,0.22);
  transform: scale(1.04);
}

/* =====================================================================
   MY PUZZLES — Two-Column Layout
   ===================================================================== */

.pz-stats-bar {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  background: var(--p-surface2);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: 14px 20px;
  margin-bottom: 16px;
}

.pz-stat {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  min-width: 100px;
}

.pz-stat-icon {
  font-size: 1.6rem;
}

.pz-stat-val {
  font-size: 1.1rem;
  font-weight: 800;
  color: #fff;
  font-family: 'Outfit', 'Space Grotesk', sans-serif;
  line-height: 1;
}

.pz-stat-lbl {
  font-size: 0.72rem;
  color: rgba(255,255,255,0.4);
  margin-top: 2px;
}

.pz-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 16px;
  align-items: start;
}

.pz-list-col {
  background: var(--p-surface2);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  overflow: hidden;
}

.pz-list-hdr {
  padding: 14px 16px;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: .07em;
  color: rgba(255,255,255,0.4);
  border-bottom: 1px solid rgba(255,255,255,0.05);
  background: rgba(255,255,255,0.02);
  font-family: 'Space Grotesk', 'Outfit', sans-serif;
}

.pz-list-scroll {
  padding: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-height: 600px;
  overflow-y: auto;
}

.pz-board-col {
  background: var(--p-surface2);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: 24px;
  min-height: 420px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.pz-placeholder {
  text-align: center;
  padding: 40px 20px;
}

.pz-placeholder-piece {
  font-size: 4rem;
  margin-bottom: 16px;
  opacity: 0.25;
  animation: pieceBob 3s ease-in-out infinite;
}

@keyframes pieceBob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

.pz-placeholder h3 {
  font-size: 1.15rem;
  font-weight: 700;
  color: rgba(255,255,255,0.5);
  margin-bottom: 8px;
  font-family: 'Outfit', sans-serif;
}

.pz-placeholder p {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.25);
  line-height: 1.6;
}

#pzActiveArea { display: flex; flex-direction: column; gap: 14px; width: 100%; }

.pz-active-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}

.pz-active-title {
  font-size: 1.2rem;
  font-weight: 800;
  color: #fff;
  font-family: 'Outfit', 'Plus Jakarta Sans', sans-serif;
  margin-bottom: 4px;
}

.pz-active-instructions {
  font-size: 0.88rem;
  color: rgba(255,255,255,0.65);
  line-height: 1.55;
}

.pz-board-wrap {
  display: flex;
  justify-content: center;
}

.pz-board-inner {
  width: 100%;
  max-width: 400px;
}

.pz-action-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.pz-feedback {
  padding: 12px 16px;
  border-radius: 10px;
  font-size: 0.9rem;
  font-weight: 600;
  line-height: 1.5;
  animation: fadeInUp 0.3s ease;
}

.pz-feedback.success {
  background: rgba(34,197,94,0.12);
  border: 1px solid rgba(34,197,94,0.3);
  color: #22c55e;
}

.pz-feedback.error {
  background: rgba(239,68,68,0.1);
  border: 1px solid rgba(239,68,68,0.25);
  color: #f87171;
}

.pz-feedback.hint {
  background: rgba(251,191,36,0.1);
  border: 1px solid rgba(251,191,36,0.25);
  color: #fbbf24;
}

/* Override p-puzzle-card in puzzles list context */
.pz-list-scroll .p-puzzle-card {
  cursor: pointer;
  border-radius: 10px;
  transition: all 0.18s;
}

.pz-list-scroll .p-puzzle-card:hover {
  border-color: rgba(91,156,246,0.4);
  transform: translateX(2px);
}

.pz-list-scroll .p-puzzle-card.active {
  border-color: var(--p-blue);
  background: rgba(91,156,246,0.1);
}

/* =====================================================================
   PAYMENT GATEWAY — Professional Razorpay Design
   ===================================================================== */

/* ══════════════════════════════════════════════════════════
   PAYMENT GATEWAY — Premium Fintech UI
   ══════════════════════════════════════════════════════════ */

.pay-gateway-wrap {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 24px;
  align-items: start;
  max-width: 920px;
  margin: 0 auto;
}

/* ── Order Summary Card (Left) ── */
.pay-order-card {
  background: linear-gradient(145deg, #1a1f2e, #151a27);
  border: 1px solid rgba(232,184,75,0.18);
  border-radius: 20px;
  padding: 26px;
  position: relative;
  overflow: hidden;
}
.pay-order-card::before {
  content: '';
  position: absolute;
  top: -40px;
  right: -40px;
  width: 120px;
  height: 120px;
  background: radial-gradient(circle, rgba(232,184,75,0.12) 0%, transparent 70%);
  pointer-events: none;
}

.pay-order-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
}

.pay-academy-logo {
  width: 46px;
  height: 46px;
  background: linear-gradient(135deg, #d97706, #92400e);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  box-shadow: 0 4px 16px rgba(217,119,6,0.35);
}

.pay-academy-name {
  font-size: 0.98rem;
  font-weight: 800;
  color: #fff;
  font-family: 'Space Grotesk', sans-serif;
}

.pay-academy-sub {
  font-size: 0.72rem;
  color: rgba(255,255,255,0.38);
  margin-top: 2px;
}

.pay-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.08), transparent);
  margin: 16px 0;
}

.pay-order-title {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: .12em;
  color: var(--p-gold);
  text-transform: uppercase;
  margin-bottom: 3px;
}

.pay-order-student {
  font-size: 0.88rem;
  color: rgba(255,255,255,0.65);
  margin-bottom: 16px;
  font-weight: 600;
}

.pay-line-items { display: flex; flex-direction: column; gap: 10px; }

.pay-line {
  display: flex;
  justify-content: space-between;
  font-size: 0.86rem;
  color: rgba(255,255,255,0.5);
}

.pay-line span:last-child {
  font-weight: 600;
  color: rgba(255,255,255,0.85);
}

.pay-total-line {
  font-weight: 800;
  font-size: 0.95rem !important;
}

.pay-total-amount {
  color: var(--p-gold) !important;
  font-size: 1.2rem !important;
  font-family: 'Space Grotesk', sans-serif;
  text-shadow: 0 0 20px rgba(232,184,75,0.3);
}

.pay-status-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.83rem;
  color: rgba(255,255,255,0.45);
  margin-top: 4px;
}

.pay-status-badge {
  font-size: 0.72rem;
  font-weight: 700;
  padding: 3px 11px;
  border-radius: 20px;
  letter-spacing: 0.03em;
}

.pay-status-badge.pending {
  background: rgba(251,191,36,0.12);
  border: 1px solid rgba(251,191,36,0.3);
  color: #fbbf24;
}

.pay-status-badge.paid {
  background: rgba(34,197,94,0.12);
  border: 1px solid rgba(34,197,94,0.3);
  color: #22c55e;
}

.pay-security-note {
  margin-top: 20px;
  font-size: 0.7rem;
  color: rgba(255,255,255,0.25);
  text-align: center;
  line-height: 1.7;
  letter-spacing: 0.02em;
}

/* ── Payment Form Card (Right) — Premium Redesign ── */
.pay-form-card {
  background: linear-gradient(145deg, #1e2436, #181d2e);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 20px;
  padding: 28px 26px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: relative;
  overflow: hidden;
}
.pay-form-card::after {
  content: '';
  position: absolute;
  bottom: -60px;
  right: -60px;
  width: 160px;
  height: 160px;
  background: radial-gradient(circle, rgba(16,185,129,0.06) 0%, transparent 70%);
  pointer-events: none;
}

.pay-form-header { border-bottom: 1px solid rgba(255,255,255,0.06); padding-bottom: 16px; }

.pay-form-title {
  font-size: 1.18rem;
  font-weight: 800;
  color: #f1f5f9;
  font-family: 'Space Grotesk', sans-serif;
  letter-spacing: -0.02em;
}

.pay-form-sub {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.38);
  margin-top: 4px;
  letter-spacing: 0.01em;
}

/* ── Method Selector ── */
.pay-methods-section { display: flex; flex-direction: column; gap: 10px; }

.pay-methods-label {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(255,255,255,0.35);
}

.pay-methods {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.pay-method {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 13px;
  background: rgba(255,255,255,0.03);
  border: 1.5px solid rgba(255,255,255,0.07);
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.2s cubic-bezier(.4,0,.2,1);
  position: relative;
  overflow: hidden;
}

.pay-method:hover {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.14);
}

.pay-method.active {
  background: rgba(232,184,75,0.08);
  border-color: rgba(232,184,75,0.45);
  box-shadow: 0 0 0 1px rgba(232,184,75,0.15) inset;
}

.pay-method-icon-pill {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
  transition: transform 0.2s;
}
.pay-method:hover .pay-method-icon-pill { transform: scale(1.1); }

.upi-pill  { background: rgba(16,185,129,0.15); color: #10b981; }
.card-pill { background: rgba(91,156,246,0.15); color: #5b9cf6; }
.nb-pill   { background: rgba(232,184,75,0.15); color: #d97706; }
.emi-pill  { background: rgba(244,114,182,0.15); color: #f472b6; }

.pay-method.active .upi-pill  { background: rgba(16,185,129,0.25); }
.pay-method.active .card-pill { background: rgba(91,156,246,0.25); }
.pay-method.active .nb-pill   { background: rgba(232,184,75,0.25); }
.pay-method.active .emi-pill  { background: rgba(244,114,182,0.25); }

.pay-method-body { flex: 1; min-width: 0; }

.pay-method-name {
  font-size: 0.84rem;
  font-weight: 700;
  color: rgba(255,255,255,0.7);
  line-height: 1.2;
  transition: color 0.2s;
}
.pay-method.active .pay-method-name { color: var(--p-gold); }

.pay-method-desc {
  font-size: 0.68rem;
  color: rgba(255,255,255,0.35);
  margin-top: 1px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.pay-method-checkmark {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.6rem;
  color: transparent;
  flex-shrink: 0;
  transition: all 0.2s;
}
.pay-method.active .pay-method-checkmark {
  background: var(--p-gold);
  border-color: var(--p-gold);
  color: #1a1a2e;
  font-weight: 900;
}

/* ── Amount Card ── */
.pay-amount-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: linear-gradient(135deg, rgba(232,184,75,0.08), rgba(232,184,75,0.04));
  border: 1px solid rgba(232,184,75,0.22);
  border-radius: 14px;
  padding: 16px 20px;
  position: relative;
  overflow: hidden;
}
.pay-amount-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(232,184,75,0.4), transparent);
}

.pay-amount-left { flex: 1; }

.pay-amount-label {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(255,255,255,0.4);
  margin-bottom: 4px;
}

.pay-amount-val {
  font-size: 2rem;
  font-weight: 900;
  color: #f1f5f9;
  font-family: 'Space Grotesk', sans-serif;
  letter-spacing: -0.03em;
  line-height: 1;
}

.pay-amount-note {
  font-size: 0.68rem;
  color: rgba(255,255,255,0.3);
  margin-top: 4px;
}

.pay-amount-right {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 10px 14px;
  background: rgba(34,197,94,0.08);
  border: 1px solid rgba(34,197,94,0.2);
  border-radius: 10px;
}

.pay-amount-lock-ring { line-height: 0; }

.pay-amount-secure-text {
  font-size: 0.65rem;
  font-weight: 700;
  color: #22c55e;
  letter-spacing: .04em;
  text-transform: uppercase;
}

/* ── UPI Payee Card ── */
.pay-upi-payee-card {
  display: flex;
  align-items: center;
  gap: 14px;
  background: linear-gradient(135deg, rgba(16,185,129,0.07), rgba(16,185,129,0.03));
  border: 1px solid rgba(16,185,129,0.22);
  border-radius: 14px;
  padding: 14px 16px;
  position: relative;
  overflow: hidden;
}
.pay-upi-payee-card::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, #10b981, #059669);
  border-radius: 3px 0 0 3px;
}

.pay-upi-payee-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, #10b981, #059669);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  font-weight: 900;
  color: #fff;
  flex-shrink: 0;
  box-shadow: 0 4px 14px rgba(16,185,129,0.35);
  font-family: 'Space Grotesk', sans-serif;
}

.pay-upi-payee-info { flex: 1; min-width: 0; }

.pay-upi-payee-name {
  font-size: 0.92rem;
  font-weight: 700;
  color: #f1f5f9;
  line-height: 1.2;
}

.pay-upi-payee-id {
  font-size: 0.76rem;
  color: #10b981;
  font-family: monospace;
  margin-top: 2px;
  letter-spacing: 0.02em;
}

.pay-upi-payee-phone {
  font-size: 0.71rem;
  color: rgba(255,255,255,0.38);
  margin-top: 2px;
}

.pay-upi-payee-verified {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  flex-shrink: 0;
}

.pay-upi-tick {
  width: 26px;
  height: 26px;
  background: rgba(16,185,129,0.15);
  border: 1.5px solid rgba(16,185,129,0.4);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  color: #10b981;
  font-weight: 900;
}

.pay-upi-payee-verified span:last-child {
  font-size: 0.6rem;
  font-weight: 700;
  color: #10b981;
  text-transform: uppercase;
  letter-spacing: .06em;
}

/* ── Terms row ── */
.pay-terms-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.45);
  cursor: pointer;
  line-height: 1.55;
}

/* ── CTA Submit Button ── */
.pay-submit-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 15px 20px;
  background: linear-gradient(135deg, #16a34a, #15803d);
  color: #fff;
  border: none;
  border-radius: 14px;
  font-size: 1rem;
  font-weight: 800;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(.4,0,.2,1);
  box-shadow: 0 6px 28px rgba(22,163,74,0.4), 0 0 0 0 rgba(22,163,74,0.3);
  font-family: 'Space Grotesk', sans-serif;
  letter-spacing: -0.01em;
  animation: pay-btn-breathe 3s ease-in-out infinite;
  position: relative;
  overflow: hidden;
}
.pay-submit-btn::before {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 60%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
  transition: left 0.5s ease;
}
.pay-submit-btn:hover::before { left: 160%; }
.pay-submit-btn:hover {
  background: linear-gradient(135deg, #22c55e, #16a34a);
  transform: translateY(-2px);
  box-shadow: 0 10px 36px rgba(22,163,74,0.55), 0 0 0 3px rgba(22,163,74,0.15);
  animation: none;
}
.pay-submit-btn:active { transform: translateY(0); }

/* When UPI is not the selected method, use gold colour */
.pay-submit-btn.razorpay-mode {
  background: linear-gradient(135deg, #d97706, #b45309);
  box-shadow: 0 6px 28px rgba(217,119,6,0.4);
  animation: pay-btn-breathe-gold 3s ease-in-out infinite;
}
.pay-submit-btn.razorpay-mode:hover {
  background: linear-gradient(135deg, #f59e0b, #d97706);
  box-shadow: 0 10px 36px rgba(217,119,6,0.55);
}

@keyframes pay-btn-breathe {
  0%, 100% { box-shadow: 0 6px 28px rgba(22,163,74,0.4), 0 0 0 0 rgba(22,163,74,0.3); }
  50%       { box-shadow: 0 8px 32px rgba(22,163,74,0.5), 0 0 0 6px rgba(22,163,74,0.1); }
}
@keyframes pay-btn-breathe-gold {
  0%, 100% { box-shadow: 0 6px 28px rgba(217,119,6,0.4), 0 0 0 0 rgba(217,119,6,0.3); }
  50%       { box-shadow: 0 8px 32px rgba(217,119,6,0.5), 0 0 0 6px rgba(217,119,6,0.1); }
}

.pay-btn-icon  { font-size: 1.2rem; }
.pay-btn-text  { flex: 1; text-align: center; }
.pay-btn-arrow {
  font-size: 1.1rem;
  opacity: 0.7;
  transition: transform 0.2s, opacity 0.2s;
}
.pay-submit-btn:hover .pay-btn-arrow { transform: translateX(4px); opacity: 1; }

/* ── Trust strip ── */
.pay-trust-strip {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px;
}

.pay-trust-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 20px;
  padding: 4px 10px;
  font-size: 0.68rem;
  font-weight: 600;
  color: rgba(255,255,255,0.38);
  white-space: nowrap;
}
.pay-trust-chip svg { opacity: 0.5; flex-shrink: 0; }

/* ── Success Card ── */
.pay-success-card {
  grid-column: 1 / -1;
  text-align: center;
  padding: 52px 32px;
  background: linear-gradient(145deg, #1a1f2e, #151a27);
  border: 1px solid rgba(34,197,94,0.22);
  border-radius: 20px;
  animation: fadeInUp 0.5s ease;
}

.pay-success-icon {
  font-size: 4.5rem;
  margin-bottom: 18px;
  display: block;
  animation: successPop 0.6s cubic-bezier(.17,.67,.83,.67);
}

@keyframes successPop {
  0%   { transform: scale(0.3); opacity: 0; }
  70%  { transform: scale(1.15); }
  100% { transform: scale(1); opacity: 1; }
}

.pay-success-title {
  font-size: 1.9rem;
  font-weight: 900;
  color: #22c55e;
  margin-bottom: 12px;
  font-family: 'Space Grotesk', sans-serif;
  letter-spacing: -0.03em;
}

.pay-success-sub {
  color: rgba(255,255,255,0.5);
  font-size: 0.92rem;
  margin-bottom: 28px;
  max-width: 460px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.65;
}

.pay-receipt-box {
  background: rgba(34,197,94,0.05);
  border: 1px solid rgba(34,197,94,0.18);
  border-radius: 14px;
  padding: 20px 24px;
  max-width: 440px;
  margin: 0 auto;
  text-align: left;
  font-size: 0.86rem;
  line-height: 2.1;
  color: rgba(255,255,255,0.65);
  font-family: 'Space Grotesk', monospace;
}

/* ── Responsive ── */
@media (max-width: 860px) {
  .pay-gateway-wrap { grid-template-columns: 1fr; }
  .pay-order-card   { order: 2; }
  .pay-form-card    { order: 1; }
}

/* Portal Multi-Device Auto-Size Layer */
@media (min-width: 1600px) {
  .p-content { max-width: 1550px; margin: 0 auto; width: 100%; }
}
@media (max-width: 1024px) and (min-width: 769px) {
  .p-sidebar { width: 220px; min-width: 220px; }
  .p-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .p-charts-row, .p-form-row { grid-template-columns: 1fr; }
}

/* ==========================================================================
   PORTAL MOBILE ENHANCEMENT LAYER
   ========================================================================== */
@media (max-width: 768px) {
  .portal-body {
    flex-direction: column !important;
    overflow-y: auto !important;
    height: auto !important;
    min-height: 100vh;
  }
  .p-sidebar {
    width: 100% !important;
    min-width: 100% !important;
    height: auto !important;
    position: relative !important;
    border-right: none !important;
    border-bottom: 1px solid var(--p-border);
  }
  .p-main {
    height: auto !important;
    overflow-y: visible !important;
  }
  .p-topbar {
    padding: 0 16px !important;
    height: 56px !important;
  }
  .p-topbar-search input {
    width: 160px !important;
  }
  .p-content {
    padding: 16px !important;
    gap: 16px !important;
  }
  .p-stats-grid {
    grid-template-columns: 1fr !important;
  }
  .report-card-wrapper {
    padding: 20px !important;
    border-width: 6px !important;
    outline-width: 2px !important;
  }
  .rc-title {
    font-size: 1.8rem !important;
  }
}


/* ── Missing utility classes ── */
.p-badge-ghost { background: rgba(255,255,255,.06); color: var(--p-text-muted); }
.p-badge-rose  { background: rgba(244,114,182,.12); color: #f472b6; }
.p-btn-green   { background: linear-gradient(135deg, #10b981, #059669); color: #fff; }
.p-btn-green:hover { opacity:.88; transform:translateY(-1px); }

/* ══════════════════════════════════════════════════════════════════
   UPI PAYMENT GATEWAY — Fee gateway UPI strip + Modal
   ══════════════════════════════════════════════════════════════════ */

/* UPI info strip inside payment form */
.pay-upi-strip {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: rgba(16,185,129,0.08);
  border: 1px solid rgba(16,185,129,0.25);
  border-radius: 10px;
  padding: 10px 14px;
  margin-bottom: 14px;
  font-size: 0.8rem;
}
.pay-upi-strip-icon { font-size: 1.4rem; line-height: 1; }
.pay-upi-strip-line { color: #94a3b8; line-height: 1.5; }
.pay-upi-strip-id   { color: #e2e8f0; margin-top: 2px; }
.pay-upi-strip-id strong { color: #10b981; }

/* ── UPI Modal Overlay ── */
.upi-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 10000;
  background: rgba(0, 0, 0, 0.78);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 16px;
  backdrop-filter: blur(8px);
}
.upi-modal-overlay[style*="flex"] { display: flex !important; }

/* ── Modal Card ── */
.upi-modal-card {
  background: linear-gradient(145deg, #1a1a2e, #16213e);
  border: 1px solid rgba(217,119,6,0.3);
  border-radius: 22px;
  padding: 28px 24px 22px;
  width: 100%;
  max-width: 400px;
  max-height: 92vh;
  overflow-y: auto;
  position: relative;
  box-shadow: 0 32px 80px rgba(0,0,0,0.75), 0 0 0 1px rgba(255,255,255,0.05);
  scrollbar-width: thin;
  scrollbar-color: rgba(217,119,6,0.3) transparent;
}
.upi-modal-close {
  position: absolute;
  top: 14px;
  right: 14px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.1);
  color: #94a3b8;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 13px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}
.upi-modal-close:hover { background: rgba(255,255,255,0.15); color: #e2e8f0; }

/* ── Header ── */
.upi-modal-header { text-align: center; margin-bottom: 16px; }
.upi-modal-logo   { font-size: 2rem; margin-bottom: 6px; }
.upi-modal-title  { font-size: 1.25rem; font-weight: 700; color: #f1f5f9; margin: 0 0 4px; }
.upi-modal-sub    { font-size: 0.75rem; color: #64748b; }

/* ── Amount badge ── */
.upi-amount-badge {
  text-align: center;
  font-size: 2.1rem;
  font-weight: 800;
  color: #d97706;
  background: rgba(217,119,6,0.09);
  border: 1px solid rgba(217,119,6,0.28);
  border-radius: 14px;
  padding: 10px 20px;
  margin-bottom: 20px;
  letter-spacing: 1px;
}

/* ── QR Code section ── */
.upi-qr-section { text-align: center; margin-bottom: 12px; }
.upi-qr-label   { font-size: 0.77rem; color: #94a3b8; margin-bottom: 12px; }
.upi-qr-frame   {
  display: inline-block;
  padding: 12px;
  background: #fff;
  border-radius: 14px;
  margin-bottom: 12px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.3);
}
.upi-qr-inner { line-height: 0; }
.upi-qr-inner img,
.upi-qr-inner canvas { display: block; border-radius: 4px; }

.upi-vpa-row {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  padding: 7px 12px;
  margin-bottom: 6px;
}
.upi-vpa-label { font-size: 0.7rem; color: #64748b; }
.upi-vpa-val   { font-family: monospace; font-size: 0.88rem; color: #e2e8f0; font-weight: 600; }
.upi-copy-btn  {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 1rem;
  padding: 0;
  line-height: 1;
  opacity: 0.8;
}
.upi-copy-btn:hover { opacity: 1; }
.upi-payee-row { font-size: 0.75rem; color: #64748b; }
.upi-payee-row strong { color: #94a3b8; }

/* ── OR Divider ── */
.upi-or-divider {
  position: relative;
  text-align: center;
  margin: 14px 0;
  font-size: 0.72rem;
  color: #475569;
}
.upi-or-divider::before,
.upi-or-divider::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 30%;
  height: 1px;
  background: rgba(255,255,255,0.08);
}
.upi-or-divider::before { left: 0; }
.upi-or-divider::after  { right: 0; }
.upi-or-divider span    { background: #16213e; padding: 0 10px; }

/* ── App Buttons ── */
.upi-app-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 18px;
}
.upi-app-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 10px 4px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.09);
  background: rgba(255,255,255,0.04);
  cursor: pointer;
  color: #cbd5e1;
  font-size: 0.68rem;
  font-weight: 600;
  transition: all 0.2s;
  line-height: 1.2;
}
.upi-app-btn:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.2);
  transform: translateY(-2px);
}
.upi-app-icon {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  font-weight: 900;
  letter-spacing: -0.5px;
}
.gpay-icon    { background: #fff; color: #4285f4; font-family: sans-serif; }
.phonepe-icon { background: #5f259f; color: #fff; font-size: 0.75rem; }
.paytm-icon   { background: #00bad0; color: #fff; }
.any-icon     { background: #d97706; color: #fff; font-size: 0.6rem; }

/* ── UTR Entry Box ── */
.upi-utr-box {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.09);
  border-radius: 14px;
  padding: 16px;
  margin-bottom: 12px;
}
.upi-utr-heading {
  font-size: 0.82rem;
  font-weight: 600;
  color: #cbd5e1;
  margin-bottom: 10px;
}
.upi-utr-input {
  width: 100%;
  box-sizing: border-box;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.14);
  color: #f1f5f9;
  border-radius: 10px;
  padding: 12px 14px;
  font-size: 0.9rem;
  font-family: monospace;
  letter-spacing: 1px;
  outline: none;
  transition: border-color 0.2s;
}
.upi-utr-input:focus { border-color: rgba(217,119,6,0.65); }
.upi-utr-input::placeholder { color: #475569; letter-spacing: 0; }
.upi-utr-hint {
  font-size: 0.7rem;
  color: #475569;
  margin: 6px 0 12px;
  line-height: 1.4;
}
.upi-confirm-btn {
  width: 100%;
  padding: 13px;
  background: linear-gradient(135deg, #d97706, #b45309);
  color: #fff;
  border: none;
  border-radius: 12px;
  font-size: 0.95rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
  letter-spacing: 0.3px;
}
.upi-confirm-btn:hover:not(:disabled) {
  background: linear-gradient(135deg, #f59e0b, #d97706);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(217,119,6,0.35);
}
.upi-confirm-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  transform: none;
}

/* ── Footer ── */
.upi-secure-footer {
  text-align: center;
  font-size: 0.68rem;
  color: #475569;
  margin-top: 8px;
  line-height: 1.5;
}

/* Mobile: stack app buttons 2×2 on very small screens */
@media (max-width: 380px) {
  .upi-app-grid { grid-template-columns: repeat(2, 1fr); }
  .upi-modal-card { padding: 22px 16px 18px; }
  .upi-amount-badge { font-size: 1.7rem; }
}

/* =====================================================================
   PGN VIEWER + PUZZLE SYSTEM — ENHANCED COMPONENTS
   ===================================================================== */

/* Puzzle timer badge */
.pz-timer-badge {
  font-family: 'Courier New', monospace;
  font-size: 1rem;
  font-weight: 800;
  color: var(--p-gold);
  background: rgba(232,184,75,.12);
  border: 1px solid rgba(232,184,75,.25);
  border-radius: 8px;
  padding: 6px 14px;
  letter-spacing: .06em;
  flex-shrink: 0;
  align-self: flex-start;
}

/* XP float-up animation */
.pz-xp-popup {
  position: absolute;
  top: 8px; right: 12px;
  background: linear-gradient(135deg,#f59e0b,#d97706);
  color: #fff;
  font-size: 1.1rem;
  font-weight: 900;
  padding: 5px 16px;
  border-radius: 20px;
  pointer-events: none;
  animation: pzXpRise 1.6s ease forwards;
  z-index: 10;
  box-shadow: 0 4px 20px rgba(232,184,75,.5);
}
@keyframes pzXpRise {
  0%   { opacity:1; transform:translateY(0) scale(1); }
  60%  { opacity:1; transform:translateY(-44px) scale(1.12); }
  100% { opacity:0; transform:translateY(-90px) scale(.9); }
}

/* Daily puzzle quick-card in Student Home */
.pz-daily-card {
  background: linear-gradient(135deg,rgba(232,184,75,.1),rgba(91,156,246,.06));
  border: 1px solid rgba(232,184,75,.22);
  border-radius: 14px;
  padding: 18px 20px;
  display: flex; align-items: center; gap: 16px;
  cursor: pointer;
  transition: all .2s;
}
.pz-daily-card:hover {
  border-color: rgba(232,184,75,.45);
  background: linear-gradient(135deg,rgba(232,184,75,.16),rgba(91,156,246,.1));
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(232,184,75,.12);
}
.pz-daily-icon { font-size: 2.4rem; flex-shrink:0; line-height:1; }
.pz-daily-body { flex:1; min-width:0; }
.pz-daily-label {
  font-size:.68rem; font-weight:800; letter-spacing:.1em;
  color:var(--p-gold); text-transform:uppercase; margin-bottom:4px;
}
.pz-daily-title { font-size:1rem; font-weight:700; color:#fff; }
.pz-daily-sub { font-size:.78rem; color:rgba(255,255,255,.38); margin-top:3px; }
.pz-daily-meta { text-align:center; flex-shrink:0; }
.pz-daily-fire { font-size:1.8rem; line-height:1; }
.pz-daily-fire-lbl { font-size:.65rem; color:rgba(255,255,255,.35); margin-top:2px; }

/* Leaderboard modal overlay */
.pz-lb-overlay {
  position:fixed; inset:0;
  background:rgba(0,0,0,.72);
  z-index:9100;
  display:flex; align-items:center; justify-content:center;
  backdrop-filter:blur(6px);
}
.pz-lb-modal {
  background:var(--p-surface1);
  border:1px solid rgba(232,184,75,.22);
  border-radius:18px;
  padding:28px 26px;
  width:100%; max-width:460px;
  max-height:80vh; overflow-y:auto;
  box-shadow:0 30px 80px rgba(0,0,0,.55);
}
.pz-lb-header {
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom:20px;
}
.pz-lb-title { font-size:1.2rem; font-weight:800; color:var(--p-gold); }
.pz-lb-row {
  display:flex; align-items:center; gap:12px;
  padding:11px 14px; border-radius:10px;
  border:1px solid rgba(255,255,255,.05);
  background:var(--p-surface2);
  margin-bottom:7px; transition:background .2s;
}
.pz-lb-row--me {
  border-color:rgba(232,184,75,.35);
  background:rgba(232,184,75,.08);
}
.pz-lb-rank { font-size:1.2rem; width:34px; text-align:center; flex-shrink:0; }
.pz-lb-name { flex:1; font-weight:600; font-size:.9rem; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.pz-lb-val { font-size:.8rem; color:rgba(255,255,255,.5); font-weight:600; flex-shrink:0; }

/* Coach Puzzle Creator form */
.pgn-creator-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:14px;
}
@media (max-width:540px) {
  .pgn-creator-grid { grid-template-columns:1fr; }
  .pz-lb-modal { margin:16px; }
  .pz-daily-card { gap:10px; }
}

/* Famous Games Library — card strip */
.pgn-lib-header {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 14px;
}
.pgn-lib-header-title {
  font-size: .82rem; font-weight: 800; letter-spacing: .08em;
  color: var(--p-gold); text-transform: uppercase;
}
.pgn-lib-header-sub {
  font-size: .75rem; color: rgba(255,255,255,.35); margin-top: 1px;
}
.pgn-lib-strip {
  display: flex; gap: 12px;
  overflow-x: auto; padding-bottom: 8px;
  scrollbar-width: thin;
  scrollbar-color: rgba(232,184,75,.3) transparent;
}
.pgn-lib-strip::-webkit-scrollbar { height: 4px; }
.pgn-lib-strip::-webkit-scrollbar-thumb { background: rgba(232,184,75,.3); border-radius: 4px; }

.pgn-lib-card {
  flex-shrink: 0;
  width: 260px;
  background: var(--p-surface2);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 12px;
  padding: 14px 14px 12px;
  cursor: pointer;
  transition: all .22s;
  display: flex; flex-direction: column; gap: 8px;
  position: relative;
}
.pgn-lib-card:hover {
  border-color: rgba(232,184,75,.3);
  background: var(--p-surface3);
  transform: translateY(-3px);
  box-shadow: 0 10px 30px rgba(0,0,0,.3);
}
.pgn-lib-card-icon {
  font-size: 1.8rem; line-height: 1;
}
.pgn-lib-card-body { flex: 1; }
.pgn-lib-card-title {
  font-size: .9rem; font-weight: 800; color: #fff;
  margin-bottom: 3px;
}
.pgn-lib-card-players {
  font-size: .72rem; color: rgba(255,255,255,.45);
  margin-bottom: 5px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.pgn-lib-card-meta {
  display: flex; align-items: center; gap: 6px; margin-bottom: 6px;
}
.pgn-lib-year {
  font-size: .7rem; font-weight: 700; color: rgba(255,255,255,.3);
}
.pgn-lib-card-why {
  font-size: .71rem; color: rgba(255,255,255,.35); line-height: 1.45;
  display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.pgn-lib-load-btn {
  align-self: flex-start;
  background: rgba(232,184,75,.12);
  border: 1px solid rgba(232,184,75,.25);
  color: var(--p-gold);
  font-size: .75rem; font-weight: 700;
  padding: 4px 12px; border-radius: 6px;
  cursor: pointer; transition: all .18s;
  white-space: nowrap;
}
.pgn-lib-load-btn:hover {
  background: rgba(232,184,75,.25);
  border-color: rgba(232,184,75,.5);
}
.pgn-lib-section {
  border-top: 1px solid rgba(255,255,255,.06);
  padding-top: 18px;
  margin-top: 18px;
}

/* PGN upload button area */
.lab-upload-strip {
  display:flex; align-items:center; gap:8px;
  padding:10px 14px;
  background:rgba(91,156,246,.07);
  border:1px dashed rgba(91,156,246,.25);
  border-radius:10px;
  margin-bottom:11px;
  cursor:pointer;
  transition:all .2s;
}
.lab-upload-strip:hover {
  border-color:rgba(91,156,246,.5);
  background:rgba(91,156,246,.12);
}
.lab-upload-strip-icon { font-size:1.4rem; }
.lab-upload-strip-text { flex:1; font-size:.82rem; color:rgba(255,255,255,.55); }

/* ── Daily Goal Tracker ── */
.dg-section { background:var(--p-surface2); border:1px solid rgba(255,255,255,.06); border-radius:14px; padding:16px 20px; margin-bottom:16px; }
.dg-section-title { font-size:.75rem; text-transform:uppercase; letter-spacing:.08em; color:var(--p-gold); font-weight:700; margin-bottom:12px; }
.dg-grid { display:flex; gap:10px; flex-wrap:wrap; }
.dg-item { flex:1; min-width:140px; display:flex; align-items:center; gap:10px; background:var(--p-surface3); border-radius:10px; padding:10px 12px; border:1px solid rgba(255,255,255,.05); transition:border-color .2s; }
.dg-item.dg-done { border-color:rgba(20,184,166,.35); }
.dg-icon { font-size:1.4rem; }
.dg-body { flex:1; }
.dg-label { font-size:.76rem; color:rgba(255,255,255,.55); margin-bottom:4px; }
.dg-bar-wrap { background:rgba(255,255,255,.08); border-radius:99px; height:5px; overflow:hidden; }
.dg-bar { height:100%; border-radius:99px; transition:width .5s cubic-bezier(.4,0,.2,1); }
.dg-count { font-size:.72rem; color:rgba(255,255,255,.4); margin-top:3px; }
.dg-item.dg-done .dg-count { color:var(--p-teal); }

/* ── Spaced Repetition Queue ── */
.srs-section { background:var(--p-surface2); border:1px solid rgba(255,255,255,.06); border-radius:14px; padding:14px 18px; }
.srs-section-title { font-size:.75rem; text-transform:uppercase; letter-spacing:.08em; color:var(--p-blue); font-weight:700; margin-bottom:10px; display:flex; align-items:center; gap:8px; }
.srs-badge { background:var(--p-danger); color:#fff; border-radius:99px; padding:1px 7px; font-size:.68rem; font-weight:700; }
.srs-card { display:flex; align-items:center; gap:10px; background:var(--p-surface3); border-radius:9px; padding:10px 12px; margin-bottom:6px; cursor:pointer; border:1px solid transparent; transition:border-color .15s; }
.srs-card:hover { border-color:rgba(91,156,246,.4); }
.srs-icon { font-size:1.3rem; }
.srs-info { flex:1; }
.srs-title { font-weight:600; font-size:.88rem; color:#fff; }
.srs-meta  { font-size:.74rem; color:var(--p-text-muted); }

/* ── Skill Radar Heatmap ── */
.radar-wrap { display:flex; justify-content:center; align-items:center; padding:10px; }
.radar-wrap canvas { max-width:380px; width:100%; }

/* ════════════════════════════════════════════════
   CLASS SYSTEM — coach class cards & attendance
   ════════════════════════════════════════════════ */
.cls-class-card { background:var(--p-surface2); border:1px solid rgba(255,255,255,.07); border-radius:14px; overflow:hidden; transition:border-color .2s,box-shadow .2s; }
.cls-class-card:hover { border-color:rgba(45,212,191,.3); box-shadow:0 4px 20px rgba(0,0,0,.3); }
.cls-class-card.cls-class-attended { border-color:rgba(45,212,191,.45); }
.cls-class-header { padding:14px 16px 10px; display:flex; justify-content:space-between; align-items:flex-start; gap:10px; }
.cls-class-title { font-size:.97rem; font-weight:700; color:#fff; }
.cls-class-body { padding:0 16px 12px; font-size:.82rem; color:var(--p-text-muted); line-height:1.6; }
.cls-class-link { display:block; margin:10px 16px; padding:8px 12px; background:rgba(45,212,191,.08); border:1px solid rgba(45,212,191,.25); border-radius:8px; color:var(--p-teal); font-size:.82rem; text-decoration:none; text-align:center; cursor:pointer; transition:background .2s; }
.cls-class-link:hover { background:rgba(45,212,191,.18); }
.cls-class-footer { padding:10px 16px; border-top:1px solid rgba(255,255,255,.05); display:flex; gap:8px; justify-content:flex-end; }

/* attendance marker */
.cls-attn-section { margin-bottom:16px; }
.cls-attn-title { font-size:.8rem; font-weight:700; color:var(--p-gold); letter-spacing:.05em; margin-bottom:8px; }
.cls-attn-row { display:flex; align-items:center; gap:10px; padding:8px 12px; background:var(--p-surface3); border-radius:8px; margin-bottom:6px; }
.cls-attn-name { flex:1; font-size:.88rem; color:#fff; }
.cls-attn-btn { padding:4px 10px; border-radius:6px; font-size:.75rem; font-weight:600; cursor:pointer; border:1px solid transparent; transition:all .15s; }
.cls-attn-present { background:rgba(20,184,166,.15); border-color:rgba(20,184,166,.4); color:var(--p-teal); }
.cls-attn-present.active,.cls-attn-present:hover { background:rgba(20,184,166,.35); }
.cls-attn-absent { background:rgba(239,68,68,.12); border-color:rgba(239,68,68,.3); color:#f87171; }
.cls-attn-absent.active,.cls-attn-absent:hover { background:rgba(239,68,68,.3); }
.cls-attn-late { background:rgba(245,158,11,.12); border-color:rgba(245,158,11,.3); color:#fbbf24; }
.cls-attn-late.active,.cls-attn-late:hover { background:rgba(245,158,11,.3); }

/* cls modal */
.cls-modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.75); display:flex; align-items:center; justify-content:center; z-index:9000; padding:20px; }
.cls-modal { background:var(--p-surface1); border:1px solid rgba(255,255,255,.1); border-radius:16px; width:100%; max-width:520px; max-height:90vh; overflow-y:auto; }
.cls-modal-header { padding:20px 24px 0; display:flex; justify-content:space-between; align-items:center; }
.cls-modal-header h3 { font-size:1.1rem; font-weight:700; color:#fff; }
.cls-modal-footer { padding:16px 24px; border-top:1px solid rgba(255,255,255,.07); display:flex; gap:10px; justify-content:flex-end; }
.cls-form-row { padding:0 24px; margin-bottom:14px; }
.cls-form-2col { display:grid; grid-template-columns:1fr 1fr; gap:12px; padding:0 24px; margin-bottom:14px; }
.cls-day-check { display:flex; align-items:center; gap:6px; font-size:.82rem; color:rgba(255,255,255,.7); cursor:pointer; }
.cls-day-check input { accent-color:var(--p-teal); }

/* ════════════════════════════════════════════════
   SCHEDULE PRO — meeting cards
   ════════════════════════════════════════════════ */
.sched-section-title { font-size:.78rem; font-weight:700; color:var(--p-teal); letter-spacing:.05em; text-transform:uppercase; margin:0 0 10px; }
.sched-card { background:var(--p-surface2); border:1px solid rgba(255,255,255,.07); border-radius:12px; padding:14px 16px; margin-bottom:10px; display:flex; align-items:flex-start; gap:14px; transition:border-color .2s; }
.sched-card:hover { border-color:rgba(91,156,246,.3); }
.sched-card-today { border-color:rgba(45,212,191,.4); background:rgba(45,212,191,.04); }
.sched-card-past { opacity:.55; }
.sched-date-badge { min-width:52px; text-align:center; background:var(--p-surface3); border-radius:10px; padding:8px 6px; }
.sched-date-today .sched-date-badge { background:rgba(45,212,191,.18); }
.sched-date-day { font-size:.68rem; color:var(--p-text-muted); text-transform:uppercase; letter-spacing:.05em; }
.sched-date-num { font-size:1.4rem; font-weight:800; color:#fff; line-height:1; }
.sched-date-mon { font-size:.65rem; color:var(--p-text-muted); }
.sched-info { flex:1; }
.sched-title { font-size:.95rem; font-weight:700; color:#fff; margin-bottom:4px; }
.sched-meta { font-size:.78rem; color:var(--p-text-muted); margin-bottom:8px; }
.sched-join-btn { padding:5px 14px; border-radius:8px; font-size:.8rem; font-weight:600; background:var(--p-teal); color:#000; border:none; cursor:pointer; text-decoration:none; display:inline-block; transition:opacity .15s; }
.sched-join-btn:hover { opacity:.85; }

/* ════════════════════════════════════════════════
   PUZZLES PRO — 60-puzzle bank & leaderboard
   ════════════════════════════════════════════════ */
/* Leaderboard */
.ldb-header { display:grid; grid-template-columns:40px 1fr 80px 70px 70px; gap:8px; padding:8px 12px; font-size:.7rem; color:rgba(255,255,255,.35); font-weight:700; text-transform:uppercase; letter-spacing:.06em; border-bottom:1px solid rgba(255,255,255,.06); }
.ldb-row { display:grid; grid-template-columns:40px 1fr 80px 70px 70px; gap:8px; padding:10px 12px; border-radius:8px; align-items:center; transition:background .15s; }
.ldb-row:hover { background:rgba(255,255,255,.03); }
.ldb-top { background:linear-gradient(90deg,rgba(212,175,55,.1),transparent); border-left:3px solid var(--p-gold); }
.ldb-rank { font-size:1rem; text-align:center; }
.ldb-name { font-size:.88rem; color:#fff; font-weight:600; }
.ldb-xp { font-size:.88rem; color:var(--p-gold); font-weight:700; }
.ldb-time,.ldb-solved { font-size:.82rem; color:var(--p-text-muted); }

/* Puzzle cards */
.pzp-card { background:var(--p-surface2); border:1px solid rgba(255,255,255,.07); border-radius:12px; padding:14px 16px; display:flex; flex-direction:column; gap:10px; transition:border-color .2s,transform .15s; cursor:pointer; }
.pzp-card:hover { border-color:rgba(91,156,246,.35); transform:translateY(-2px); }
.pzp-card.pzp-solved { border-color:rgba(20,184,166,.35); background:rgba(20,184,166,.04); }
.pzp-title { font-size:.92rem; font-weight:700; color:#fff; margin-bottom:4px; }
.pzp-meta { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.pzp-theme { padding:2px 8px; border-radius:20px; font-size:.7rem; font-weight:600; background:rgba(91,156,246,.15); color:var(--p-blue); text-transform:capitalize; }
.pzp-rating { font-size:.72rem; color:var(--p-text-muted); }
.pzp-actions { display:flex; gap:8px; }

/* Puzzle modal */
.pzp-modal { position:fixed; inset:0; background:rgba(0,0,0,.85); display:flex; align-items:center; justify-content:center; z-index:9100; padding:16px; }
.pz-modal { background:var(--p-surface1); border:1px solid rgba(255,255,255,.12); border-radius:18px; width:100%; max-width:840px; max-height:95vh; overflow-y:auto; }
.pz-modal-body { display:grid; grid-template-columns:1fr 280px; gap:20px; padding:20px; align-items:start; }
.pz-info-panel { display:flex; flex-direction:column; gap:14px; }
.pz-hint-box { background:var(--p-surface2); border-radius:10px; padding:12px 14px; font-size:.85rem; color:var(--p-text-muted); line-height:1.6; }
.pz-status { text-align:center; font-size:.9rem; font-weight:600; padding:8px; border-radius:8px; min-height:36px; background:rgba(255,255,255,.05); color:rgba(255,255,255,.6); }
.pz-success { background:rgba(20,184,166,.15); color:var(--p-teal); }
.pz-correct { background:rgba(20,184,166,.1); color:var(--p-teal); }
.pz-wrong { background:rgba(239,68,68,.1); color:#f87171; }
.pz-controls { display:flex; gap:8px; flex-wrap:wrap; }

/* ════════════════════════════════════════════════
   CERTIFICATES
   ════════════════════════════════════════════════ */
.cert-section { margin-bottom:18px; }
.cert-progress-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:14px; }
.cert-card { background:var(--p-surface2); border:1px solid rgba(255,255,255,.08); border-radius:14px; padding:18px; display:flex; align-items:flex-start; gap:14px; transition:border-color .2s; }
.cert-card.cert-earned { border-color:rgba(212,175,55,.4); background:linear-gradient(135deg,rgba(212,175,55,.06),transparent); }
.cert-badge { font-size:2rem; flex-shrink:0; }
.cert-info { flex:1; }
.cert-level { font-size:.72rem; text-transform:uppercase; letter-spacing:.07em; color:var(--p-gold); font-weight:700; margin-bottom:4px; }
.cert-name { font-size:.95rem; font-weight:700; color:#fff; margin-bottom:4px; }
.cert-date,.cert-num { font-size:.75rem; color:var(--p-text-muted); }
.cert-next-target { font-size:.82rem; color:var(--p-text-muted); margin-top:6px; font-style:italic; }
.cert-req { display:flex; align-items:center; gap:6px; font-size:.78rem; color:rgba(255,255,255,.5); margin-top:4px; }
.cert-req-done { color:var(--p-teal); }
.cert-req-icon { font-size:.7rem; }

/* ════════════════════════════════════════════════
   REPORTS SYSTEM
   ════════════════════════════════════════════════ */
.rpt-coach-hdr { font-size:.8rem; font-weight:700; color:var(--p-teal); letter-spacing:.05em; text-transform:uppercase; margin-bottom:10px; }
.rpt-student-row { display:flex; align-items:center; gap:12px; padding:12px 16px; background:var(--p-surface2); border:1px solid rgba(255,255,255,.06); border-radius:10px; margin-bottom:8px; transition:border-color .15s; }
.rpt-student-row:hover { border-color:rgba(45,212,191,.25); }
.rpt-student-name { flex:1; font-size:.92rem; color:#fff; font-weight:600; }
.rpt-student-status { font-size:.75rem; color:var(--p-text-muted); }
.rpt-student-status.rpt-done { color:var(--p-teal); }
.rpt-view-card { background:var(--p-surface2); border:1px solid rgba(255,255,255,.07); border-radius:12px; padding:16px 20px; margin-bottom:12px; }
.rpt-view-month { font-size:.8rem; font-weight:700; color:var(--p-gold); margin-bottom:8px; }
.rpt-view-stars { letter-spacing:2px; margin-bottom:6px; }
.rpt-view-notes { font-size:.87rem; color:rgba(255,255,255,.7); line-height:1.65; }
.rpt-auto-stats { display:flex; gap:12px; margin-bottom:10px; flex-wrap:wrap; }
.rpt-stat-pill { background:var(--p-surface3); border-radius:20px; padding:4px 10px; font-size:.75rem; color:rgba(255,255,255,.6); }

/* ════════════════════════════════════════════════
   ACCESS MANAGER
   ════════════════════════════════════════════════ */
.acc-search-row { display:flex; gap:10px; align-items:center; margin-bottom:12px; flex-wrap:wrap; }
.acc-bulk-row { display:flex; gap:8px; margin-bottom:14px; flex-wrap:wrap; }
.acc-table-wrap { overflow-x:auto; }
.acc-table { width:100%; border-collapse:collapse; font-size:.84rem; }
.acc-table th { padding:8px 12px; background:rgba(255,255,255,.04); color:rgba(255,255,255,.45); font-weight:700; font-size:.72rem; text-transform:uppercase; letter-spacing:.05em; text-align:left; }
.acc-table td { padding:10px 12px; border-bottom:1px solid rgba(255,255,255,.04); color:rgba(255,255,255,.8); }
.acc-table tr:hover td { background:rgba(255,255,255,.02); }
.acc-badge-access { background:rgba(20,184,166,.15); color:var(--p-teal); border-radius:20px; padding:2px 8px; font-size:.72rem; font-weight:700; }
.acc-badge-none { background:rgba(255,255,255,.06); color:rgba(255,255,255,.35); border-radius:20px; padding:2px 8px; font-size:.72rem; }

/* ════════════════════════════════════════════════
   FEEDBACK STARS
   ════════════════════════════════════════════════ */
.fb-star { cursor:pointer; transition:color .15s; color:rgba(255,255,255,.25); }
.fb-star.active,.fb-star:hover { color:var(--p-gold); }

/* feedback card */
.fb-card { background:var(--p-surface2); border:1px solid rgba(255,255,255,.07); border-radius:12px; padding:14px 16px; margin-bottom:10px; }
.fb-card-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:6px; }
.fb-card-who { font-size:.82rem; font-weight:600; color:#fff; }
.fb-card-stars { color:var(--p-gold); font-size:.85rem; letter-spacing:1px; }
.fb-card-body { font-size:.85rem; color:rgba(255,255,255,.65); line-height:1.6; }
.fb-card-reply { margin-top:10px; padding-top:10px; border-top:1px solid rgba(255,255,255,.06); font-size:.8rem; color:var(--p-teal); font-style:italic; }
.fb-reply-row { display:flex; gap:8px; margin-top:10px; }
.fb-reply-row input { flex:1; }

/* ════════════════════════════════════════════════
   LIVE TRACKING — admin
   ════════════════════════════════════════════════ */
.live-section-title { font-size:.78rem; font-weight:700; color:var(--p-gold); letter-spacing:.07em; text-transform:uppercase; margin-bottom:10px; padding-bottom:6px; border-bottom:1px solid rgba(255,255,255,.06); }
.live-coach-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:12px; }
.live-coach-card { background:var(--p-surface3); border:1px solid rgba(255,255,255,.07); border-radius:12px; padding:12px 14px; display:flex; align-items:center; gap:12px; }
.live-coach-card.live-present { border-color:rgba(20,184,166,.4); background:rgba(20,184,166,.05); }
.live-coach-card.live-absent { opacity:.6; }
.live-coach-name { font-size:.88rem; font-weight:700; color:#fff; }
.live-coach-status { font-size:.73rem; color:var(--p-text-muted); margin-top:2px; }
.live-coach-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.live-coach-dot.dot-present { background:var(--p-teal); box-shadow:0 0 8px var(--p-teal); }
.live-coach-dot.dot-absent { background:rgba(255,255,255,.2); }

/* ════════════════════════════════════════════════
   PARENTS PORTAL
   ════════════════════════════════════════════════ */
.par-child-card { background:var(--p-surface2); border:1px solid rgba(244,114,182,.2); border-radius:14px; padding:20px 24px; margin-bottom:16px; }
.par-stat-mini { text-align:center; }
.par-stat-mini-val { font-size:1.3rem; font-weight:800; }
.par-stat-mini-lbl { font-size:.7rem; color:var(--p-text-muted); }
.par-cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:4px; margin-top:12px; }
.par-cal-cell { aspect-ratio:1; border-radius:6px; display:flex; align-items:center; justify-content:center; font-size:.72rem; font-weight:600; background:var(--p-surface3); color:rgba(255,255,255,.3); }
.par-cal-cell.par-present { background:rgba(20,184,166,.3); color:var(--p-teal); }
.par-cal-cell.par-absent { background:rgba(239,68,68,.2); color:#f87171; }
.par-cal-cell.par-late { background:rgba(245,158,11,.2); color:#fbbf24; }
.par-cal-day { font-size:.65rem; color:rgba(255,255,255,.35); text-align:center; font-weight:700; padding-bottom:4px; }
.par-ring-wrap { display:flex; align-items:center; gap:20px; margin-bottom:16px; }
.par-breakdown { flex:1; display:flex; flex-direction:column; gap:8px; }
.par-bar-row { display:flex; align-items:center; gap:8px; font-size:.78rem; }
.par-bar-label { width:120px; color:rgba(255,255,255,.6); flex-shrink:0; }
.par-bar-track { flex:1; height:6px; background:rgba(255,255,255,.08); border-radius:3px; overflow:hidden; }
.par-bar-fill { height:100%; border-radius:3px; transition:width .8s ease; }
.par-bar-pct { width:36px; text-align:right; color:rgba(255,255,255,.5); font-size:.72rem; }
.par-report-card { background:var(--p-surface2); border:1px solid rgba(255,255,255,.07); border-radius:12px; padding:16px 20px; margin-bottom:12px; }
.par-report-month { font-size:.8rem; font-weight:700; color:var(--p-gold); margin-bottom:6px; }
.par-report-stars { margin-bottom:4px; color:var(--p-gold); letter-spacing:2px; }
.par-report-text { font-size:.87rem; color:rgba(255,255,255,.7); line-height:1.65; }
.par-alert-banner { background:rgba(239,68,68,.1); border:1px solid rgba(239,68,68,.3); border-radius:10px; padding:12px 16px; font-size:.85rem; color:#f87171; margin-bottom:14px; }
.par-nav { display:flex; gap:8px; margin-bottom:16px; flex-wrap:wrap; }

/* ════════════════════════════════════════════════
   PLAY VS COMPUTER — lab mode
   ════════════════════════════════════════════════ */
.pv-diff-btn.active { background:rgba(45,212,191,.2); border-color:var(--p-teal); color:var(--p-teal); }
.pv-color-btn.active { background:rgba(91,156,246,.2); border-color:var(--p-blue); color:var(--p-blue); }
#pvBoard .board-b72b1 { border-radius:6px; overflow:hidden; box-shadow:0 0 30px rgba(0,0,0,.5); }

/* ════════════════════════════════════════════════
   RESPONSIVE ADJUSTMENTS (new modules)
   ════════════════════════════════════════════════ */
@media (max-width:768px) {
  .pz-modal-body { grid-template-columns:1fr; }
  .cls-form-2col { grid-template-columns:1fr; }
  .live-coach-grid { grid-template-columns:1fr 1fr; }
  .par-ring-wrap { flex-direction:column; align-items:flex-start; }
  .ldb-header,.ldb-row { grid-template-columns:40px 1fr 70px; }
  .ldb-header > *:nth-child(n+4),.ldb-row > *:nth-child(n+4) { display:none; }
}
@media (max-width:480px) {
  .live-coach-grid { grid-template-columns:1fr; }
  .cert-progress-grid { grid-template-columns:1fr; }
  .pzp-card { padding:12px; }
}

/* ════════════════════════════════════════════════════════════════
   NOTIFICATION DRAWER
   ════════════════════════════════════════════════════════════════ */
.notif-drawer {
  position: fixed; top: 0; right: -400px; width: 380px; height: 100vh;
  background: var(--p-card-bg);
  border-left: 1px solid rgba(255,255,255,.08);
  z-index: 2000;
  display: flex; flex-direction: column;
  transition: right .28s cubic-bezier(.4,0,.2,1);
  box-shadow: -8px 0 32px rgba(0,0,0,.5);
}
.notif-drawer.notif-open { right: 0; }
.notif-backdrop {
  position: fixed; inset: 0; background: rgba(0,0,0,.45);
  z-index: 1999; display: none; backdrop-filter: blur(2px);
}

.notif-drawer-inner { display: flex; flex-direction: column; height: 100%; }
.notif-drawer-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 20px 14px;
  border-bottom: 1px solid rgba(255,255,255,.07);
  flex-shrink: 0;
}
.notif-drawer-title { font-size: 1.05rem; font-weight: 700; color: #fff; }
.notif-close-btn {
  background: rgba(255,255,255,.06); border: none; color: rgba(255,255,255,.6);
  width: 30px; height: 30px; border-radius: 50%; cursor: pointer;
  font-size: 0.9rem; display: flex; align-items: center; justify-content: center;
  transition: background .15s;
}
.notif-close-btn:hover { background: rgba(255,255,255,.12); color: #fff; }
.notif-panel-body { flex: 1; overflow-y: auto; padding: 8px 0; }
.notif-panel-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 18px 10px; font-size: 0.83rem; color: rgba(255,255,255,.5);
}
.notif-panel-header b { color: var(--p-gold); }
.notif-empty {
  padding: 40px 20px; text-align: center;
  color: rgba(255,255,255,.35); font-size: 0.9rem; line-height: 1.7;
}
.notif-empty span { display: block; font-size: 0.78rem; margin-top: 6px; }
.notif-item {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 12px 18px; cursor: pointer;
  transition: background .12s; position: relative;
}
.notif-item:hover { background: rgba(255,255,255,.04); }
.notif-unread { background: rgba(232,184,75,.04); }
.notif-icon { font-size: 1.3rem; line-height: 1; margin-top: 2px; flex-shrink: 0; }
.notif-body { flex: 1; min-width: 0; }
.notif-title { font-size: 0.87rem; font-weight: 700; color: #fff; margin-bottom: 3px; }
.notif-text { font-size: 0.81rem; color: rgba(255,255,255,.55); line-height: 1.5; }
.notif-age { font-size: 0.72rem; color: rgba(255,255,255,.3); margin-top: 5px; }
.notif-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--p-teal); flex-shrink: 0; margin-top: 6px;
}
.notif-bell-wrap { position: relative; }
.notif-bell-badge {
  position: absolute; top: -4px; right: -4px;
  background: var(--p-danger); color: #fff;
  font-size: 0.62rem; font-weight: 800;
  min-width: 16px; height: 16px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  padding: 0 4px; line-height: 1; pointer-events: none;
}

/* ════════════════════════════════════════════════════════════════
   GAME TRACKER
   ════════════════════════════════════════════════════════════════ */
.gt-stats-banner {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 12px; margin-bottom: 4px;
}
.gt-stat-cell {
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.07);
  border-radius: 10px; padding: 14px 16px; text-align: center;
}
.gt-stat-val { font-size: 1.7rem; font-weight: 800; color: var(--p-teal); line-height: 1; }
.gt-stat-lbl { font-size: 0.73rem; color: rgba(255,255,255,.45); margin-top: 5px; }
.gt-form {
  background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.07);
  border-radius: 12px; padding: 18px 20px;
}
.gt-form-title { font-size: 0.85rem; font-weight: 700; color: var(--p-gold); margin-bottom: 14px; }
.gt-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 12px; }
.gt-game-card {
  background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px; padding: 14px 16px;
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 8px; transition: background .12s;
}
.gt-game-card:hover { background: rgba(255,255,255,.06); }
.gt-result-badge {
  width: 36px; height: 36px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 0.78rem; flex-shrink: 0;
}
.gt-result-win  { background: rgba(0,201,167,.15); color: var(--p-teal); }
.gt-result-loss { background: rgba(239,68,68,.15);  color: var(--p-danger); }
.gt-result-draw { background: rgba(232,184,75,.15); color: var(--p-gold); }
.gt-game-info { flex: 1; min-width: 0; }
.gt-game-opp  { font-size: 0.9rem; font-weight: 700; color: #fff; }
.gt-game-meta { font-size: 0.75rem; color: rgba(255,255,255,.4); margin-top: 3px; }
.gt-game-acc  { font-size: 0.82rem; font-weight: 700; color: var(--p-blue); }
.gt-import-section {
  margin-top: 14px; padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.06);
}
.gt-import-row { display: flex; gap: 8px; align-items: center; }

/* ════════════════════════════════════════════════════════════════
   OPENING TRAINER
   ════════════════════════════════════════════════════════════════ */
.ot-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 14px;
}
.ot-card {
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px; padding: 16px 18px; cursor: pointer;
  transition: transform .15s, box-shadow .15s, border-color .15s;
  position: relative; overflow: hidden;
}
.ot-card:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,.3); border-color: rgba(255,255,255,.15); }
.ot-card-accent {
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  border-radius: 12px 12px 0 0;
}
.ot-card-top { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 10px; }
.ot-card-emoji { font-size: 1.6rem; line-height: 1; }
.ot-eco { font-size: 0.68rem; font-weight: 700; color: rgba(255,255,255,.35); letter-spacing: .06em; }
.ot-card-name { font-size: 0.92rem; font-weight: 700; color: #fff; margin-bottom: 4px; }
.ot-card-side { font-size: 0.73rem; color: rgba(255,255,255,.4); margin-bottom: 10px; }
.ot-mastery-bar-wrap { background: rgba(255,255,255,.06); border-radius: 4px; height: 5px; overflow: hidden; margin-bottom: 6px; }
.ot-mastery-bar { height: 5px; border-radius: 4px; transition: width .5s ease; }
.ot-mastery-row { display: flex; justify-content: space-between; font-size: 0.7rem; }
.ot-mastery-pct { color: rgba(255,255,255,.5); }
.ot-stars { color: var(--p-gold); letter-spacing: 1px; }
.ot-drill-btn {
  width: 100%; margin-top: 10px;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.75); padding: 7px; border-radius: 7px;
  cursor: pointer; font-size: 0.8rem; font-weight: 600;
  transition: background .14s, color .14s;
}
.ot-drill-btn:hover { background: var(--p-teal); color: #fff; border-color: var(--p-teal); }
/* drill modal */
.ot-modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.75);
  z-index: 3000; display: flex; align-items: center; justify-content: center;
  backdrop-filter: blur(6px);
}
.ot-modal {
  background: var(--p-card-bg); border: 1px solid rgba(255,255,255,.1);
  border-radius: 16px; padding: 28px 30px; width: min(650px, 95vw);
  max-height: 92vh; overflow-y: auto;
  box-shadow: 0 24px 80px rgba(0,0,0,.7);
}
.ot-modal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.ot-modal-title { font-size: 1.15rem; font-weight: 800; color: var(--p-gold); }
.ot-drill-board { margin: 0 auto; }
.ot-drill-status {
  text-align: center; font-size: 0.88rem;
  color: rgba(255,255,255,.65); margin-top: 12px; min-height: 24px;
}
.ot-step-counter { font-size: 0.78rem; color: rgba(255,255,255,.38); margin-top: 6px; text-align: center; }
.ot-result-card {
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px; padding: 20px; text-align: center; margin-top: 16px;
}
.ot-mastery-overview, .ot-overview {
  display: flex; gap: 16px; flex-wrap: wrap;
  margin-bottom: 4px;
}
.ot-overview-stat, .ot-ov-stat {
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.07);
  border-radius: 10px; padding: 12px 18px; text-align: center; flex: 1; min-width: 100px;
}
.ot-overview-val, .ot-ov-val { font-size: 1.5rem; font-weight: 800; color: var(--p-teal); line-height: 1; }
.ot-overview-lbl, .ot-ov-lbl { font-size: 0.72rem; color: rgba(255,255,255,.4); margin-top: 4px; }
.ot-filter-bar { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }
.ot-filter-btn {
  padding: 5px 14px; border-radius: 20px;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.6); font-size: 0.8rem; cursor: pointer;
  transition: background .14s, color .14s;
}
.ot-filter-btn.active { background: var(--p-gold); color: #1a1f2b; border-color: var(--p-gold); font-weight: 700; }

/* ════════════════════════════════════════════════════════════════
   CHESS CLOCK (Play vs Computer)
   ════════════════════════════════════════════════════════════════ */
.pv-clock-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 6px 4px;
}
.pv-clock-label { font-size: 0.75rem; font-weight: 600; color: rgba(255,255,255,.45); }
.pv-clock {
  font-size: 1.4rem; font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: rgba(255,255,255,.35);
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.07);
  border-radius: 8px; padding: 4px 14px;
  transition: background .2s, color .2s, border-color .2s;
  min-width: 80px; text-align: center; letter-spacing: .03em;
}
.pv-clock.pv-clock-active {
  color: #fff; background: rgba(0,201,167,.12);
  border-color: var(--p-teal);
  box-shadow: 0 0 12px rgba(0,201,167,.2);
}
.pv-clock.pv-clock-low {
  color: var(--p-danger); background: rgba(239,68,68,.12);
  border-color: var(--p-danger);
  animation: pv-tick .5s ease-in-out infinite alternate;
}
@keyframes pv-tick { from { box-shadow: 0 0 6px rgba(239,68,68,.15); } to { box-shadow: 0 0 18px rgba(239,68,68,.45); } }

/* Time control selector buttons */
.pv-tc-btn {
  padding: 5px 11px; border-radius: 6px;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.55); font-size: 0.75rem; cursor: pointer;
  transition: background .14s, color .14s, border-color .14s;
}
.pv-tc-btn:hover { background: rgba(255,255,255,.1); color: rgba(255,255,255,.85); }
.pv-tc-btn.active {
  background: var(--p-teal); color: #fff;
  border-color: var(--p-teal); font-weight: 700;
}

/* ════════════════════════════════════════════════════════════════
   STUDENT STREAK BADGE
   ════════════════════════════════════════════════════════════════ */
.student-streak-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(249,115,22,.12); border: 1px solid rgba(249,115,22,.25);
  border-radius: 20px; padding: 4px 12px;
  font-size: 0.8rem; font-weight: 700; color: #f97316;
}
.student-streak-fire { font-size: 1rem; }

/* ════════════════════════════════════════════════════════════════
   ADMIN COACH SCORECARDS
   ════════════════════════════════════════════════════════════════ */
.adm-coach-grid { display: flex; flex-direction: column; gap: 10px; }
.adm-coach-card {
  display: flex; align-items: center; gap: 16px;
  background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.06);
  border-radius: 12px; padding: 14px 18px;
  transition: background .12s;
}
.adm-coach-card:hover { background: rgba(255,255,255,.06); }
.adm-coach-avatar {
  width: 44px; height: 44px; border-radius: 50%;
  background: linear-gradient(135deg, var(--p-blue), var(--p-teal));
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; font-weight: 800; color: #fff; flex-shrink: 0;
}
.adm-coach-info { flex: 1; min-width: 0; }
.adm-coach-name { font-size: 0.95rem; font-weight: 700; color: #fff; }
.adm-coach-sub  { font-size: 0.77rem; color: rgba(255,255,255,.4); margin-top: 2px; }
.adm-coach-stats { display: flex; gap: 20px; flex-shrink: 0; }
.adm-coach-stat { text-align: center; }
.adm-coach-stat-val { font-size: 1.1rem; font-weight: 800; }
.adm-coach-stat-lbl { font-size: 0.68rem; color: rgba(255,255,255,.38); margin-top: 2px; }

/* ════════════════════════════════════════════════════════════════
   RESPONSIVE ADDITIONS
   ════════════════════════════════════════════════════════════════ */
@media (max-width:768px) {
  .notif-drawer { width: 100vw; right: -100vw; }
  .ot-grid { grid-template-columns: 1fr 1fr; }
  .gt-form-grid { grid-template-columns: 1fr; }
  .adm-coach-stats { gap: 12px; }
}
@media (max-width:480px) {
  .ot-grid { grid-template-columns: 1fr; }
  .gt-stats-banner { grid-template-columns: repeat(3, 1fr); }
  .pv-clock { font-size: 1.1rem; padding: 3px 10px; min-width: 64px; }
  .adm-coach-card { flex-wrap: wrap; }
  .adm-coach-stats { width: 100%; justify-content: space-around; }
}

/* ════════════════════════════════════════════════
   CHESSBOARD.JS LIBRARY — Green/White Color Override
   Overrides the default brown/beige squares used by
   @chrisoakman/chessboardjs in PGN Lab & Play vs AI
   ════════════════════════════════════════════════ */
.white-1 { background-color: #ffffff !important; }
.black-3 { background-color: #4a7c40 !important; }
/* Highlight squares keep a translucent overlay */
.highlight1-32417 { box-shadow: inset 0 0 3px 3px rgba(255,255,100,0.6) !important; }
.highlight2-9c5d2 { box-shadow: inset 0 0 3px 3px rgba(255,255,100,0.6) !important; }

/* ════════════════════════════════════════════════
   PUZZLE SECTION — Responsive Layout Fixes
   ════════════════════════════════════════════════ */
.pz-board-col {
  align-items: flex-start !important;
}
#pzActiveArea {
  width: 100%;
}
@media (max-width: 900px) {
  .pz-layout {
    grid-template-columns: 240px 1fr;
  }
}
@media (max-width: 768px) {
  .pz-layout {
    grid-template-columns: 1fr;
  }
  .pz-list-col {
    max-height: 280px;
  }
  .pz-board-col {
    min-height: unset;
  }
}
