html {
  font-family:
    system-ui,
    -apple-system,
    "Segoe UI",
    Roboto,
    "Helvetica Neue",
    Arial,
    "Noto Sans",
    "Liberation Sans",
    sans-serif;
  font-feature-settings: "cv11" 1, "ss01" 1;
}

body {
  font-family: inherit;
  font-size: 1.125rem;
  overflow-x: clip;
}

:where(h1, h2, h3, h4, h5, h6, .font-display, .site-emphasis, strong, b) {
  font-family:
        system-ui,
    -apple-system,
    "Segoe UI",
    Roboto,
    "Helvetica Neue",
    Arial,
    "Noto Sans",
    "Liberation Sans",
    sans-serif;
  font-feature-settings: "cv11" 1, "ss01" 1;
}

:root {
  --site-shell-max-width: 81rem;
  --site-shell-gutter: 0.5rem;
}

.site-shell {
  width: 100%;
  max-width: var(--site-shell-max-width);
  margin-inline: auto;
  padding-inline: var(--site-shell-gutter);
}

.site-full-bleed {
  width: auto;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

@supports (width: 100dvw) {
  .site-full-bleed {
    margin-left: calc(50% - 50dvw);
    margin-right: calc(50% - 50dvw);
  }
}

@media (min-width: 640px) {
  :root {
    --site-shell-gutter: 0.75rem;
  }
}

@media (min-width: 1024px) {
  :root {
    --site-shell-gutter: 1rem;
  }
}

@media (min-width: 1280px) {
  :root {
    --site-shell-gutter: 1.25rem;
  }
}

.article-content {
  word-break: break-word;
  font-size: 1.125rem;
  line-height: 1.5;
}

.article-content .table-scroll {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
}

.score-table-shell {
  width: 100%;
  border: 1px solid #e2e8f0;
  overflow-x: visible;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
}

.dark .score-table-shell {
  border-color: #27272a;
}

.score-table {
  width: 100%;
  border-collapse: collapse;
  text-align: left;
  font-size: 0.875rem;
  color: #334155;
  table-layout: auto;
}

.dark .score-table {
  color: #e2e8f0;
}

.score-table--lgs {
  min-width: 0;
}

.score-table--lgs-filter {
  min-width: 0;
}

.score-table--dgs-filter {
  min-width: 0;
}

.score-table--dgs-detail {
  min-width: 0;
}

.score-table thead {
  background: #f1f5f9;
}

.dark .score-table thead {
  background: #27272a;
}

.score-table thead th {
  padding: 0.7rem 0.75rem;
  vertical-align: middle;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #475569;
  white-space: normal;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}

.dark .score-table thead th {
  color: #cbd5e1;
}

.score-table tbody tr {
  border-top: 1px solid #e2e8f0;
}

.dark .score-table tbody tr {
  border-color: #27272a;
}

.score-table td {
  padding: 0.7rem 0.75rem;
  vertical-align: middle;
  white-space: normal;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}

.score-table-cell-strong {
  font-weight: 600;
  color: #0f172a;
}

.dark .score-table-cell-strong {
  color: #fff;
}

.score-table-cell-nowrap {
  white-space: normal;
}

.score-table-col-school {
  min-width: 0;
}

.score-table-col-wide {
  min-width: 0;
}

.score-table-col-department {
  min-width: 0;
}

.score-table--lgs :is(th:nth-child(5), th:nth-child(6), th:nth-child(7), th:nth-child(8), td:nth-child(5), td:nth-child(6), td:nth-child(7), td:nth-child(8)),
.score-table--lgs-filter :is(th:nth-child(5), th:nth-child(6), th:nth-child(7), th:nth-child(8), td:nth-child(5), td:nth-child(6), td:nth-child(7), td:nth-child(8)),
.score-table--dgs-detail :is(th:nth-child(4), th:nth-child(5), th:nth-child(6), th:nth-child(7), td:nth-child(4), td:nth-child(5), td:nth-child(6), td:nth-child(7)),
.score-table--dgs-filter :is(th:nth-child(6), th:nth-child(7), td:nth-child(6), td:nth-child(7)) {
  width: 1%;
  white-space: nowrap;
  overflow-wrap: normal;
}

.score-table--dgs-detail :is(th:nth-child(1), td:nth-child(1), th:nth-child(2), td:nth-child(2), th:nth-child(3), td:nth-child(3)),
.score-table--dgs-filter :is(th:nth-child(1), td:nth-child(1), th:nth-child(2), td:nth-child(2), th:nth-child(3), td:nth-child(3), th:nth-child(4), td:nth-child(4), th:nth-child(5), td:nth-child(5)),
.score-table--lgs :is(th:nth-child(1), td:nth-child(1), th:nth-child(2), td:nth-child(2), th:nth-child(3), td:nth-child(3), th:nth-child(4), td:nth-child(4)),
.score-table--lgs-filter :is(th:nth-child(1), td:nth-child(1), th:nth-child(2), td:nth-child(2), th:nth-child(3), td:nth-child(3), th:nth-child(4), td:nth-child(4)) {
  width: auto;
  white-space: normal;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}

@media (max-width: 1023px) {
  .score-table-shell {
    overflow-x: auto;
    overflow-y: hidden;
  }

  .score-table {
    table-layout: auto;
  }

  .score-table--lgs {
    min-width: 1180px;
  }

  .score-table--lgs-filter {
    min-width: 1040px;
  }

  .score-table--dgs-filter {
    min-width: 1080px;
  }

  .score-table--dgs-detail {
    min-width: 1240px;
  }

  .score-table thead th,
  .score-table td,
  .score-table-cell-nowrap {
    white-space: nowrap;
  }

  .score-table-col-school {
    min-width: 20rem;
  }

  .score-table-col-wide {
    min-width: 16rem;
  }

  .score-table-col-department {
    min-width: 18rem;
  }
}

.article-content :where(section) {
  margin-top: 0.75rem !important;
  margin-bottom: 0.75rem !important;
}

.article-content :where(section > :first-child) {
  margin-top: 0 !important;
}

.article-content :where(section > :last-child) {
  margin-bottom: 0 !important;
}

.article-content :where(section p, section li, section td, section th) {
  font-size: 1.06em;
  line-height: 1.58;
}

.article-content :where(.has-global-padding) {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.article-content
  :where(
    .is-layout-constrained,
    .is-layout-flow,
    .wp-block-group,
    .wp-block-columns,
    .wp-block-column,
    .wp-block-cover,
    .wp-block-media-text
  ) {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.content-unified {
  width: 100%;
  background: transparent;
  border: 0;
  padding: 0;
}

.dark .content-unified {
  border: 0;
}

.content-layout {
  display: grid;
  gap: 1.5rem;
  align-items: start;
}

.content-main {
  min-width: 0;
}

.content-sidebar {
  min-width: 0;
  content-visibility: auto;
  contain-intrinsic-size: 1200px;
}

@media (min-width: 1024px) {
  .content-layout {
    grid-template-columns: minmax(0, 1fr) 300px;
  }

  .content-layout.no-sidebar {
    grid-template-columns: minmax(0, 1fr);
  }

  .content-sidebar {
    width: 300px;
    min-width: 300px;
    max-width: 300px;
  }
}

.content-unified .content-sidebar .sidebar-panel {
  border-radius: 8px;
  padding: 1.1rem 1rem;
}

.sidebar-panel-title {
  margin: 0 0 0.95rem;
  font-size: 1.04rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  color: #111827;
}

.sidebar-empty {
  margin: 0;
  font-size: 0.95rem;
  color: #6b7280;
}

.sidebar-news-list,
.sidebar-comment-list {
    list-style: none;
    margin: 0;
    padding: 0;
    border-top: 1px solid #e2e8f0;
}

.sidebar-news-item,
.sidebar-comment-item {
    border-bottom: 1px solid #e2e8f0;
}

.sidebar-news-item:last-child,
.sidebar-comment-item:last-child {
  border-bottom: 0;
}

.sidebar-news-link {
  display: flex;
  align-items: flex-start;
  gap: 0.85rem;
  padding: 0.95rem 0;
  color: #111827;
}

.sidebar-news-link:hover .sidebar-news-text {
  color: #1e74e8;
}

.sidebar-thumb {
  display: inline-flex;
  width: 3rem;
  height: 3rem;
  align-items: center;
  justify-content: center;
  flex: none;
  border-radius: 10px;
  background: linear-gradient(135deg, #1e74e8, #2f8fff);
  color: #ffffff;
  font-size: 1.05rem;
  font-weight: 700;
}

.sidebar-thumb-image {
  width: 3rem;
  height: 3rem;
  aspect-ratio: 1 / 1;
  flex: none;
  border-radius: 10px;
  object-fit: cover;
  display: block;
  background: #d1d5db;
}

.sidebar-news-text {
  margin: 0;
  font-size: 1.01rem;
  line-height: 1.32;
  font-weight: 700;
  color: #111827;
}

.sidebar-comment-item {
  padding: 0.95rem 0;
  font-size: 1.01rem;
  line-height: 1.36;
  color: #6b7280;
}

.sidebar-comment-author {
  color: #6b7280;
}

.sidebar-comment-link {
  color: #111827;
  font-style: italic;
  font-weight: 600;
}

.sidebar-comment-link:hover {
  color: #1e74e8;
}

.sidebar-follow-head {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.sidebar-avatar {
  display: inline-flex;
  width: 2.6rem;
  height: 2.6rem;
  align-items: center;
  justify-content: center;
  flex: none;
  border-radius: 999px;
  background: #d1d5db;
  color: #1f2937;
  font-weight: 700;
  font-size: 0.88rem;
}

.sidebar-follow-name {
  margin: 0;
  font-size: 1.55rem;
  line-height: 1.2;
  font-weight: 700;
  color: #111827;
}

.sidebar-follow-meta {
  margin: 0.2rem 0 0;
  font-size: 1rem;
  color: #6b7280;
}

.sidebar-follow-description {
  margin: 0.9rem 0 1rem;
  font-size: 1.08rem;
  line-height: 1.45;
  color: #6b7280;
}

.sidebar-follow-btn {
  display: inline-flex;
  width: 100%;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: #3052cb;
  color: #ffffff;
  font-size: 1.05rem;
  font-weight: 700;
  padding: 0.7rem 0.9rem;
}

.sidebar-follow-btn:hover {
  background: #2747ba;
}

.content-unified .content-sidebar .sidebar-banner {
  border-radius: 8px;
  min-height: 10.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #9ca3af;
}

.dark .sidebar-panel-title,
.dark .sidebar-news-text,
.dark .sidebar-follow-name,
.dark .sidebar-comment-link {
  color: #f4f4f5;
}

.dark .sidebar-news-list,
.dark .sidebar-comment-list,
.dark .sidebar-news-item,
.dark .sidebar-comment-item {
  border-color: #3f3f46;
}

.dark .sidebar-empty,
.dark .sidebar-comment-item,
.dark .sidebar-comment-author,
.dark .sidebar-follow-meta,
.dark .sidebar-follow-description {
  color: #a1a1aa;
}

.dark .sidebar-thumb {
  background: linear-gradient(135deg, #3b82f6, #1d4ed8);
}

.dark .sidebar-thumb-image {
  background: #3f3f46;
}

.dark .sidebar-avatar {
  background: #3f3f46;
  color: #e4e4e7;
}

.dark .content-unified .content-sidebar .sidebar-banner {
  color: #71717a;
}

.article-content.prose :where(table):not(:where([class~="not-prose"] *)),
.article-content :where(table) {
  width: 100% !important;
  max-width: 100% !important;
  table-layout: auto !important;
  margin-top: 1.25rem;
  margin-bottom: 1.25rem;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid #dbe4f3;
  border-radius: 0;
  background: #ffffff;
}

.article-content.prose :where(colgroup, col):not(:where([class~="not-prose"] *)),
.article-content :where(colgroup),
.article-content :where(col) {
  width: auto !important;
}

.article-content :where(thead tr) {
  background: linear-gradient(180deg, #f3f9ff 0%, #eef4ff 100%);
}

.article-content.prose :where(th, td):not(:where([class~="not-prose"] *)),
.article-content :where(th),
.article-content :where(td) {
  border-right: 1px solid #e2e8f0;
  border-bottom: 1px solid #e2e8f0;
  padding: 0.75rem !important;
  font-size: 1rem;
  line-height: 1.25;
  vertical-align: middle !important;
  white-space: normal !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none !important;
  color: #1e293b;
}

.article-content.prose :where(th:first-child, td:first-child):not(:where([class~="not-prose"] *)),
.article-content :where(th:first-child),
.article-content :where(td:first-child) {
  padding-left: 0.75rem !important;
}

.article-content.prose :where(th:last-child, td:last-child):not(:where([class~="not-prose"] *)),
.article-content :where(th:last-child),
.article-content :where(td:last-child) {
  padding-right: 0.75rem !important;
  border-right: 0;
}

.article-content.prose :where(table *):not(:where([class~="not-prose"] *)),
.article-content :where(table *) {
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none !important;
}

.article-content :where(tbody tr:last-child td) {
  border-bottom: 0;
}

.article-content :where(th) {
  position: sticky;
  top: 0;
  z-index: 1;
  font-weight: 700;
  color: #0f2f74;
}

.article-content :where(tbody tr:nth-child(even)) {
  background: #f8fafc;
}

.article-content :where(tbody tr:hover) {
  background: #eef6ff;
}

.article-content :where(img) {
  max-width: 100%;
  height: auto;
  border-radius: 2px;
}

.article-content :where(figure) {
  margin-top: 1.25rem;
  margin-bottom: 1.25rem;
}

.article-content :where(ul),
.article-content :where(ol) {
  padding-left: 1.2rem;
}

.article-content :where(blockquote) {
  border-left: 4px solid #2f8fff;
  padding-left: 1rem;
  color: #334155;
  margin-top: 1.25rem;
  margin-bottom: 1.25rem;
}

.article-content :where(a) {
  color: #1e74e8;
}

.article-content :where(a:hover) {
  color: #2f8fff;
}

.dark .article-content :where(table) {
  border-color: #3f3f46;
  background: #09090b;
}

.dark .article-content :where(thead tr) {
  background: linear-gradient(180deg, #1f1f23 0%, #17171a 100%);
}

.dark .article-content :where(th),
.dark .article-content :where(td) {
  border-right-color: #3f3f46;
  border-bottom-color: #3f3f46;
  color: #e4e4e7;
}

.dark .article-content :where(th) {
  color: #f4f4f5;
}

.dark .article-content :where(tbody tr:nth-child(even)) {
  background: #18181b;
}

.dark .article-content :where(tbody tr:hover) {
  background: #27272a;
}

.dark .article-content :where(blockquote) {
  color: #d4d4d8;
}

.dark .article-content :where(a) {
  color: #93c5fd;
}

.dark .article-content :where(a:hover) {
  color: #bfdbfe;
}

@media (max-width: 768px) {
  .article-content {
    overflow-x: hidden;
  }

  .article-content .table-scroll > table {
    width: max-content !important;
    min-width: 100% !important;
    max-width: none !important;
    table-layout: auto !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }

  .article-content :where(th),
  .article-content :where(td) {
    font-size: 0.88rem;
    padding: 0.62rem !important;
    white-space: nowrap !important;
  }

  .article-content :where(th:first-child),
  .article-content :where(td:first-child),
  .article-content :where(th:last-child),
  .article-content :where(td:last-child) {
    padding-left: 0.62rem !important;
    padding-right: 0.62rem !important;
  }
}



