body {
  background:
    radial-gradient(circle at 50% 0%, rgba(59, 130, 246, 0.08), transparent 34%),
    linear-gradient(180deg, #fbfdff 0%, #f2f6fd 100%);
}

.page-noise {
  opacity: 0.14;
  background-size: 24px 24px;
}

.home-main {
  padding: 14px;
  align-items: stretch;
}

.home-shell {
  display: flex;
  align-items: stretch;
}

.home-panel {
  width: 100%;
  min-height: calc(100vh - 28px);
  padding: 24px 18px 18px;
  border-radius: 28px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.home-title {
  font-size: 2.35rem;
  line-height: 0.96;
}

.home-subtitle {
  margin-top: 14px;
  max-width: none;
  font-size: 1rem;
  line-height: 1.58;
}

.home-actions {
  margin-top: 24px;
}

.home-upload-btn {
  width: 100%;
  min-width: 0;
  min-height: 68px;
  padding: 0 22px;
  border-radius: 22px;
}

.home-upload-btn__text {
  font-size: 1.05rem;
}

.home-stats {
  margin-top: 24px;
  grid-template-columns: 1fr;
  gap: 14px;
}

.home-stat-card {
  min-height: 112px;
  padding: 18px 18px 16px;
  border-radius: 22px;
}

.home-stat-card span {
  font-size: 0.94rem;
}

.home-stat-card strong {
  margin-top: 12px;
  font-size: 2.05rem;
}

.home-bg-orb {
  width: 240px;
  height: 240px;
  filter: blur(26px);
}

.glass-card,
.glass-inset,
.stat-card,
.feature-card {
  border-radius: 24px;
}

.nav-shell {
  padding: 1rem;
}

.brand-mark {
  width: 50px;
  height: 50px;
  border-radius: 18px;
  font-size: 1.05rem;
}

.hero-grid,
.session-grid,
.session-hero-grid {
  display: block !important;
}

.hero-copy {
  padding: 1.2rem !important;
}

.hero-copy h2 {
  font-size: 2.1rem !important;
  line-height: 1;
}

.hero-visual {
  margin-top: 1rem;
}

.hero-mockup__content {
  padding: 1rem;
}

.stat-card,
.feature-card {
  padding: 1rem;
}

.feature-pill {
  padding: 0.9rem;
}

.status-chip {
  display: none;
}

.share-strip {
  flex-direction: column;
  align-items: stretch;
  gap: 0.75rem;
}

.readonly-input {
  font-size: 0.95rem;
}

.primary-btn,
.secondary-btn,
.ghost-btn,
.danger-btn {
  width: 100%;
  min-height: 50px;
  border-radius: 16px;
}

.ghost-btn--small {
  width: auto;
  min-height: 40px;
}

.upload-zone {
  min-height: 216px;
  padding: 1.25rem;
  border-radius: 22px;
}

.upload-zone__icon {
  width: 64px;
  height: 64px;
  border-radius: 18px;
  font-size: 1.4rem;
}

.progress-shell {
  padding: 1rem;
  border-radius: 20px;
}

.countdown-value {
  font-size: 1.4rem;
}

.file-row {
  grid-template-columns: 1fr;
  padding: 0.92rem;
  border-radius: 20px;
}

.file-main {
  align-items: flex-start;
}

.file-actions {
  width: 100%;
  justify-content: stretch;
}

.file-actions .action-link {
  flex: 1 1 calc(50% - 0.35rem);
  min-height: 46px;
}

.file-icon {
  width: 52px;
  height: 52px;
  border-radius: 16px;
}

.preview-modal {
  padding: 0.5rem;
}

.preview-dialog {
  width: calc(100vw - 1rem);
  max-height: calc(100vh - 1rem);
  padding: 0.75rem;
  border-radius: 22px;
}

.preview-header {
  padding: 0.25rem 0.25rem 0.7rem;
}

.preview-body {
  padding: 0.6rem;
  border-radius: 18px;
}

.preview-body img,
.preview-body video,
.preview-body iframe {
  height: calc(100vh - 11rem);
  border-radius: 14px;
}

.toast-stack {
  left: 0.75rem;
  right: 0.75rem;
  bottom: 0.75rem;
  align-items: stretch;
}

.toast {
  min-width: auto;
  max-width: none;
}

@media (max-width: 380px) {
  .home-panel {
    padding: 20px 14px 16px;
  }

  .home-title {
    font-size: 2.05rem;
  }

  .home-upload-btn {
    min-height: 64px;
  }

  .home-stat-card strong {
    font-size: 1.9rem;
  }

  .file-actions .action-link {
    flex: 1 1 100%;
  }
}