:root {
  --cp-font-display: 'Space Grotesk', 'Noto Sans SC', sans-serif;
  --cp-font-body: 'Noto Sans SC', 'Space Grotesk', sans-serif;
}

html,
body {
  min-height: 100%;
}

body {
  font-family: var(--cp-font-body);
  background:
    radial-gradient(circle at top left, color-mix(in oklab, var(--color-primary) 24%, transparent) 0, transparent 34%),
    radial-gradient(circle at right 20%, color-mix(in oklab, var(--color-secondary) 18%, transparent) 0, transparent 30%),
    linear-gradient(180deg, color-mix(in oklab, var(--color-base-200) 88%, transparent), var(--color-base-100));
}

.font-display {
  font-family: var(--cp-font-display);
}

[x-cloak] {
  display: none !important;
}

.home-shell {
  position: relative;
  isolation: isolate;
}

.home-shell::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: -2;
  background-image:
    linear-gradient(to right, color-mix(in oklab, var(--color-base-content) 8%, transparent) 1px, transparent 1px),
    linear-gradient(to bottom, color-mix(in oklab, var(--color-base-content) 8%, transparent) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.65), rgba(0, 0, 0, 0.08));
  pointer-events: none;
}

.home-shell::after {
  content: '';
  position: fixed;
  inset: 18% auto auto 8%;
  width: 22rem;
  height: 22rem;
  border-radius: 999px;
  background: color-mix(in oklab, var(--color-primary) 18%, transparent);
  filter: blur(80px);
  z-index: -1;
  pointer-events: none;
}

.brand-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.8rem;
  height: 2.8rem;
  border-radius: 1rem;
  font-family: var(--cp-font-display);
  font-weight: 700;
  letter-spacing: 0.12em;
  color: white;
  background:
    linear-gradient(135deg, color-mix(in oklab, var(--color-primary) 82%, white), color-mix(in oklab, var(--color-secondary) 78%, black));
  box-shadow: 0 18px 40px color-mix(in oklab, var(--color-primary) 30%, transparent);
}

.brand-logo {
  display: block;
  width: 2.8rem;
  height: 2.8rem;
  flex: none;
}

.toolbar-control {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 2.5rem;
  border: 1px solid color-mix(in oklab, var(--color-base-content) 10%, transparent);
  border-radius: 999px;
  background: color-mix(in oklab, var(--color-base-100) 78%, transparent);
  box-shadow: 0 10px 30px color-mix(in oklab, var(--color-base-content) 6%, transparent);
  backdrop-filter: blur(14px);
  cursor: pointer;
}

.toolbar-language-button {
  min-width: 7.25rem;
  padding: 0 0.85rem;
}

.toolbar-language-label {
  font-size: 0.84rem;
  font-weight: 500;
  color: var(--color-base-content);
}

.toolbar-caret {
  width: 0.9rem;
  height: 0.9rem;
  flex: none;
}

.toolbar-icon-button {
  width: 2.5rem;
  color: color-mix(in oklab, var(--color-base-content) 82%, transparent);
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    background-color 180ms ease;
}

.toolbar-icon-button:hover,
.toolbar-icon-button:focus-visible,
.toolbar-select:focus-within {
  border-color: color-mix(in oklab, var(--color-primary) 45%, transparent);
  background: color-mix(in oklab, var(--color-primary) 12%, var(--color-base-100));
}

.toolbar-icon-button:hover {
  transform: translateY(-1px);
}

.toolbar-icon {
  width: 1rem;
  height: 1rem;
  flex: none;
}

.toolbar-language-menu {
  position: absolute;
  right: 0;
  top: calc(100% + 0.55rem);
  display: flex;
  min-width: 10rem;
  flex-direction: column;
  gap: 0.25rem;
  padding: 0.45rem;
  border: 1px solid color-mix(in oklab, var(--color-base-content) 10%, transparent);
  border-radius: 1rem;
  background: color-mix(in oklab, var(--color-base-100) 88%, transparent);
  box-shadow: 0 20px 45px color-mix(in oklab, black 22%, transparent);
  backdrop-filter: blur(18px);
  z-index: 40;
}

.toolbar-language-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  width: 100%;
  padding: 0.7rem 0.85rem;
  border: 0;
  border-radius: 0.8rem;
  background: transparent;
  color: var(--color-base-content);
  font-size: 0.9rem;
  text-align: left;
  cursor: pointer;
  transition:
    background-color 180ms ease,
    transform 180ms ease,
    color 180ms ease;
}

.toolbar-language-option:hover,
.toolbar-language-option.is-active {
  background: color-mix(in oklab, var(--color-primary) 16%, var(--color-base-200));
  color: var(--color-base-content);
}

.toolbar-language-option:hover {
  transform: translateX(1px);
}

.toolbar-option-meta {
  font-size: 0.74rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--color-base-content) 45%, transparent);
}

.scroll-top-button {
  position: fixed;
  right: 1.25rem;
  bottom: 1.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.7rem;
  height: 3.7rem;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--color-base-content);
  box-shadow: 0 22px 44px color-mix(in oklab, black 16%, transparent);
  cursor: pointer;
  opacity: 0;
  transform: translateY(1rem) scale(0.92);
  pointer-events: none;
  transition:
    opacity 220ms ease,
    transform 220ms ease,
    box-shadow 220ms ease;
  z-index: 45;
}

.scroll-top-button.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.scroll-top-button:focus-visible {
  outline: 0;
}

.scroll-top-button__halo,
.scroll-top-button__inner {
  position: absolute;
  inset: 0;
  border-radius: inherit;
}

.scroll-top-button__halo {
  inset: -0.35rem;
  background: radial-gradient(circle, color-mix(in oklab, var(--color-primary) 18%, transparent) 0%, transparent 72%);
  opacity: 0.7;
  filter: blur(6px);
}

.scroll-top-button__inner {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid color-mix(in oklab, var(--color-primary) 18%, transparent);
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--color-base-100) 86%, transparent), color-mix(in oklab, var(--color-base-200) 72%, transparent));
  box-shadow:
    inset 0 1px 0 color-mix(in oklab, white 22%, transparent),
    0 14px 30px color-mix(in oklab, var(--color-primary) 10%, transparent);
  backdrop-filter: blur(16px);
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    background-color 180ms ease;
}

.scroll-top-button:hover .scroll-top-button__inner,
.scroll-top-button:focus-visible .scroll-top-button__inner {
  transform: translateY(-2px);
  border-color: color-mix(in oklab, var(--color-primary) 34%, transparent);
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--color-primary) 10%, var(--color-base-100)), color-mix(in oklab, var(--color-base-200) 84%, transparent));
}

.scroll-top-button:hover,
.scroll-top-button:focus-visible {
  box-shadow: 0 26px 54px color-mix(in oklab, var(--color-primary) 12%, transparent);
}

.scroll-top-button__icon {
  position: relative;
  width: 1.15rem;
  height: 1.15rem;
  flex: none;
  z-index: 1;
}

.stat-card {
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(12px);
}

.stat-card::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 0.18rem;
  background: linear-gradient(90deg, var(--color-primary), color-mix(in oklab, var(--color-secondary) 80%, white));
  opacity: 0.95;
}

.stat-card-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: 1rem;
  background: color-mix(in oklab, var(--color-primary) 16%, var(--color-base-100));
  color: color-mix(in oklab, var(--color-primary) 82%, white);
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--color-primary) 20%, transparent);
}

.stat-card-icon {
  width: 1.2rem;
  height: 1.2rem;
  flex: none;
}

.title-highlight {
  text-shadow:
    0 0 24px color-mix(in oklab, var(--color-primary) 18%, transparent),
    0 10px 30px color-mix(in oklab, black 18%, transparent);
}

.project-card {
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(14px);
}

.project-card::before {
  content: '';
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 0.22rem;
  background: linear-gradient(90deg, var(--color-primary), var(--color-secondary), var(--color-accent));
  opacity: 0.95;
}

.about-stage {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  border-radius: 2.5rem;
  background:
    radial-gradient(circle at 50% 0%, color-mix(in oklab, var(--color-primary) 14%, transparent), transparent 46%),
    linear-gradient(180deg, color-mix(in oklab, var(--color-base-100) 76%, transparent), color-mix(in oklab, var(--color-base-200) 44%, transparent));
}

.about-stage::before {
  content: '';
  position: absolute;
  inset: 1px;
  border-radius: calc(2.5rem - 1px);
  border: 1px solid color-mix(in oklab, var(--color-base-content) 8%, transparent);
  background: linear-gradient(180deg, color-mix(in oklab, white 5%, transparent), transparent 48%);
  z-index: -1;
}

.about-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
  position: relative;
  z-index: 1;
}

.about-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.9rem;
  width: min(100%, 20rem);
}

.about-divider-line {
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in oklab, var(--color-base-content) 22%, transparent), transparent);
}

.about-divider-dot {
  width: 0.65rem;
  height: 0.65rem;
  border-radius: 999px;
  background: linear-gradient(135deg, color-mix(in oklab, var(--color-primary) 82%, white), color-mix(in oklab, var(--color-secondary) 72%, white));
  box-shadow: 0 0 22px color-mix(in oklab, var(--color-primary) 28%, transparent);
}

.about-orbit {
  position: absolute;
  width: 15rem;
  height: 15rem;
  border-radius: 999px;
  border: 1px solid color-mix(in oklab, var(--color-base-content) 8%, transparent);
  pointer-events: none;
  opacity: 0.7;
}

.about-orbit::before {
  content: '';
  position: absolute;
  inset: 18%;
  border-radius: 999px;
  border: 1px dashed color-mix(in oklab, var(--color-base-content) 10%, transparent);
}

.about-orbit-left {
  left: -5rem;
  top: 50%;
  transform: translateY(-50%);
}

.about-orbit-right {
  right: -5rem;
  top: 50%;
  transform: translateY(-50%);
}

.about-email-chip {
  display: inline-grid;
  grid-auto-flow: column;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  padding: 0.95rem 1.35rem;
  border: 1px solid color-mix(in oklab, var(--color-primary) 18%, transparent);
  border-radius: 999px;
  background: color-mix(in oklab, var(--color-base-100) 78%, transparent);
  box-shadow:
    0 18px 40px color-mix(in oklab, var(--color-base-content) 6%, transparent),
    inset 0 1px 0 color-mix(in oklab, white 18%, transparent);
  backdrop-filter: blur(14px);
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease,
    background-color 180ms ease;
}

.about-email-chip:hover {
  transform: translateY(-2px);
  border-color: color-mix(in oklab, var(--color-primary) 30%, transparent);
  box-shadow:
    0 22px 48px color-mix(in oklab, var(--color-primary) 10%, transparent),
    inset 0 1px 0 color-mix(in oklab, white 24%, transparent);
}

.about-email-label {
  display: inline-flex;
  align-items: center;
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--color-base-content) 52%, transparent);
}

.about-email-address {
  display: inline-flex;
  align-items: center;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1;
  color: color-mix(in oklab, var(--color-primary) 78%, var(--color-base-content));
}

.project-hero {
  position: relative;
  isolation: isolate;
  backdrop-filter: blur(14px);
}

.project-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at top left, color-mix(in oklab, var(--color-primary) 18%, transparent), transparent 44%),
    radial-gradient(circle at right 18%, color-mix(in oklab, var(--color-secondary) 18%, transparent), transparent 38%);
}

.hero-link-card,
.detail-card,
.metric-panel {
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease,
    background-color 180ms ease;
}

.hero-link-card:hover,
.detail-card:hover,
.metric-panel:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 40px color-mix(in oklab, var(--color-base-content) 8%, transparent);
}

.detail-chip {
  min-height: 2rem;
  padding-inline: 0.8rem;
}

.compare-form-shell,
.compare-link-card,
.compare-cell-content {
  position: relative;
}

.compare-select {
  min-height: 3.5rem;
  padding-right: 3rem;
  border-color: color-mix(in oklab, var(--color-base-content) 12%, transparent);
  background: color-mix(in oklab, var(--color-base-100) 92%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in oklab, white 22%, transparent);
}

.compare-hero-title {
  background: linear-gradient(90deg, color-mix(in oklab, var(--color-primary) 76%, white), color-mix(in oklab, var(--color-secondary) 62%, var(--color-base-content)));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: 0 10px 28px color-mix(in oklab, var(--color-primary) 12%, transparent);
}

.compare-hero-simple {
  background: transparent;
  border: 0;
  box-shadow: none;
}

.compare-field-label {
  display: inline-block;
  margin-bottom: 0.7rem;
}

.compare-combobox-shell {
  position: relative;
}

.compare-clear-button {
  position: absolute;
  top: 50%;
  right: 0.8rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.9rem;
  height: 1.9rem;
  border: 0;
  border-radius: 999px;
  background: color-mix(in oklab, var(--color-base-200) 80%, transparent);
  color: color-mix(in oklab, var(--color-base-content) 60%, transparent);
  transform: translateY(-50%);
  cursor: pointer;
  transition:
    background-color 160ms ease,
    color 160ms ease,
    transform 160ms ease;
}

.compare-clear-button:hover {
  background: color-mix(in oklab, var(--color-primary) 14%, var(--color-base-200));
  color: var(--color-base-content);
  transform: translateY(-50%) scale(1.04);
}

.compare-dropdown {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 0.7rem);
  z-index: 35;
  border: 1px solid color-mix(in oklab, var(--color-base-content) 10%, transparent);
  border-radius: 1.2rem;
  background: color-mix(in oklab, var(--color-base-100) 94%, transparent);
  box-shadow: 0 24px 48px color-mix(in oklab, black 18%, transparent);
  backdrop-filter: blur(18px);
  overflow: hidden;
}

.compare-dropdown-list {
  max-height: 18rem;
  overflow-y: auto;
  padding: 0.45rem;
}

.compare-dropdown-option {
  display: flex;
  width: 100%;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0.85rem 0.95rem;
  border: 0;
  border-radius: 0.95rem;
  background: transparent;
  text-align: left;
  transition:
    background-color 160ms ease,
    transform 160ms ease;
  cursor: pointer;
}

.compare-dropdown-option:hover,
.compare-dropdown-option.is-active {
  background: color-mix(in oklab, var(--color-primary) 14%, var(--color-base-200));
}

.compare-dropdown-option:hover {
  transform: translateX(1px);
}

.compare-dropdown-title {
  font-size: 0.98rem;
  font-weight: 600;
  color: var(--color-base-content);
}

.compare-dropdown-meta {
  font-size: 0.83rem;
  color: color-mix(in oklab, var(--color-base-content) 58%, transparent);
}

.compare-dropdown-empty {
  padding: 1rem 1.1rem;
  font-size: 0.9rem;
  color: color-mix(in oklab, var(--color-base-content) 55%, transparent);
}

.compare-table {
  width: 100%;
  min-width: 58rem;
  border-collapse: separate;
  border-spacing: 0;
}

.compare-table th,
.compare-table td {
  padding: 1.1rem 1.25rem;
  border-bottom: 1px solid color-mix(in oklab, var(--color-base-content) 8%, transparent);
  vertical-align: top;
}

.compare-table thead th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: color-mix(in oklab, var(--color-base-100) 94%, transparent);
}

.compare-table thead th:first-child {
  min-width: 14rem;
}

.compare-table tbody th {
  width: 14rem;
  background: color-mix(in oklab, var(--color-base-200) 66%, transparent);
  color: color-mix(in oklab, var(--color-base-content) 78%, transparent);
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.compare-table td {
  min-width: 22rem;
  background: color-mix(in oklab, var(--color-base-100) 95%, transparent);
  color: var(--color-base-content);
  font-size: 0.98rem;
  line-height: 1.8;
}

.compare-table tbody tr:last-child th,
.compare-table tbody tr:last-child td {
  border-bottom: 0;
}

.compare-cell-content {
  display: flex;
  min-height: 100%;
  flex-direction: column;
  gap: 0.75rem;
}

.compare-link-card {
  display: inline-flex;
  flex-direction: column;
  gap: 0.4rem;
  padding: 0.95rem 1rem;
  border: 1px solid color-mix(in oklab, var(--color-primary) 18%, transparent);
  border-radius: 1.15rem;
  background: linear-gradient(180deg, color-mix(in oklab, var(--color-primary) 10%, transparent), color-mix(in oklab, var(--color-base-100) 94%, transparent));
  box-shadow: 0 14px 30px color-mix(in oklab, var(--color-primary) 10%, transparent);
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease;
}

.compare-link-card:hover {
  transform: translateY(-1px);
  border-color: color-mix(in oklab, var(--color-primary) 34%, transparent);
  box-shadow: 0 18px 34px color-mix(in oklab, var(--color-primary) 15%, transparent);
}

.compare-link-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--color-primary) 78%, black);
}

.compare-link-url {
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.6;
  color: var(--color-base-content);
  word-break: break-all;
}

.compare-metric {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 5.5rem;
  padding: 0.5rem 0.9rem;
  border-radius: 999px;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.compare-metric-primary {
  background: color-mix(in oklab, var(--color-primary) 14%, transparent);
  color: color-mix(in oklab, var(--color-primary) 88%, black);
}

.compare-metric-secondary {
  background: color-mix(in oklab, var(--color-secondary) 14%, transparent);
  color: color-mix(in oklab, var(--color-secondary) 88%, black);
}

.compare-winner-wrap {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  flex-wrap: wrap;
}

.compare-winner-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  background: color-mix(in oklab, #f7c948 84%, white);
  color: #7a4b00;
  box-shadow:
    0 10px 24px color-mix(in oklab, #f7c948 28%, transparent),
    inset 0 1px 0 color-mix(in oklab, white 55%, transparent);
}

.compare-trophy {
  width: 1rem;
  height: 1rem;
  flex: none;
}

.compare-github-link {
  color: color-mix(in oklab, var(--color-primary) 72%, var(--color-base-content));
}

.compare-github-link:hover {
  color: color-mix(in oklab, var(--color-primary) 88%, black);
}

.compare-github-icon {
  width: 1rem;
  height: 1rem;
  flex: none;
}

.project-meta-badge {
  border: 1px solid color-mix(in oklab, var(--color-base-content) 16%, transparent);
  background: color-mix(in oklab, var(--color-base-100) 62%, var(--color-base-200));
  color: color-mix(in oklab, var(--color-base-content) 92%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in oklab, white 10%, transparent);
}

.trend-chart-image {
  border-radius: 1.75rem;
  box-shadow:
    0 24px 56px color-mix(in oklab, var(--color-base-content) 8%, transparent),
    0 0 0 1px color-mix(in oklab, var(--color-base-content) 8%, transparent);
}

.project-table-wrap {
  width: 100%;
  border: 1px solid color-mix(in oklab, var(--color-base-content) 12%, transparent);
  border-radius: 1.75rem;
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--color-base-100) 94%, transparent), color-mix(in oklab, var(--color-base-100) 86%, transparent));
  box-shadow:
    0 24px 60px color-mix(in oklab, var(--color-base-content) 6%, transparent),
    inset 0 1px 0 color-mix(in oklab, white 26%, transparent);
  position: relative;
  overflow: auto;
}

.project-table-wrap::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 0.2rem;
  background: linear-gradient(90deg, var(--color-primary), var(--color-secondary), var(--color-accent));
  opacity: 0.95;
  pointer-events: none;
}

.project-table {
  width: 100%;
  min-width: 42rem;
  border-collapse: separate;
  border-spacing: 0;
}

.project-table th,
.project-table td {
  padding: 1.1rem 1.25rem;
  border-bottom: 1px solid color-mix(in oklab, var(--color-base-content) 8%, transparent);
  vertical-align: top;
}

.project-table tr:last-child th,
.project-table tr:last-child td {
  border-bottom: 0;
}

.project-table th {
  width: 15rem;
  background: color-mix(in oklab, var(--color-base-200) 66%, transparent);
  color: color-mix(in oklab, var(--color-base-content) 78%, transparent);
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.project-table td {
  background: color-mix(in oklab, var(--color-base-100) 95%, transparent);
  color: var(--color-base-content);
  font-size: 0.98rem;
  line-height: 1.8;
}

.project-table tr:first-child th {
  border-top-left-radius: 1.7rem;
}

.project-table tr:first-child td {
  border-top-right-radius: 1.7rem;
}

.project-table tr:last-child th {
  border-bottom-left-radius: 1.7rem;
}

.project-table tr:last-child td {
  border-bottom-right-radius: 1.7rem;
}

.clamp-3 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

@media (max-width: 768px) {
  .home-shell::before,
  .home-shell::after,
  .hero-panel::after {
    opacity: 0.75;
  }

  .project-hero {
    border-radius: 1.5rem;
  }

  .project-table {
    min-width: 36rem;
  }

  .compare-table {
    min-width: 48rem;
  }

  .about-stage {
    border-radius: 2rem;
  }

  .about-orbit {
    width: 10rem;
    height: 10rem;
    opacity: 0.42;
  }

  .about-orbit-left {
    left: -4.75rem;
    top: 1.8rem;
    transform: none;
  }

  .about-orbit-right {
    right: -4.75rem;
    bottom: 1.8rem;
    top: auto;
    transform: none;
  }

  .about-content {
    gap: 1.2rem;
  }

  .about-email-chip {
    grid-auto-flow: row;
    width: 100%;
    border-radius: 1.25rem;
    padding: 1rem 1.1rem;
  }

  .about-email-label,
  .about-email-address {
    width: 100%;
  }

  .scroll-top-button {
    right: 1rem;
    bottom: 1rem;
    width: 3.35rem;
    height: 3.35rem;
  }
}
