/*
 * SWD Modern UI
 * Shared visual foundation for new screens.
 *
 * Include:
 * <link rel="stylesheet" href="/swd-modern.css">
 *
 * Recommended page class:
 * <body class="swd-modern-page">
 */

:root {
  --swd-blue: #1069ae;
  --swd-blue-strong: #0d6efd;
  --swd-ink: #1f2d3d;
  --swd-muted: #667085;
  --swd-line: #dbe4ee;
  --swd-soft: #f8fafc;
  --swd-success: #198754;
  --swd-danger: #dc3545;
  --swd-warning: #b7791f;
  --swd-radius: 8px;
  --swd-shadow-sm: 0 8px 18px rgba(31, 45, 61, 0.06);
  --swd-shadow-md: 0 12px 28px rgba(31, 45, 61, 0.08);
  --swd-shadow-lg: 0 24px 70px rgba(31, 45, 61, 0.14);
  --swd-scrollbar-track: #e7eef6;
  --swd-scrollbar-thumb: #8aa0b5;
  --swd-scrollbar-thumb-hover: #667f98;
  --swd-scrollbar-width: 12px;
  --swd-navbar-edge-space: 34px;
}

html {
  scrollbar-color: var(--swd-scrollbar-thumb) var(--swd-scrollbar-track);
  scrollbar-gutter: stable;
  scrollbar-width: thin;
}

html::-webkit-scrollbar {
  width: var(--swd-scrollbar-width);
  height: var(--swd-scrollbar-width);
}

html::-webkit-scrollbar-track {
  background: var(--swd-scrollbar-track);
}

html::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #a7b8c9 0%, var(--swd-scrollbar-thumb) 100%);
  border: 3px solid var(--swd-scrollbar-track);
  border-radius: 999px;
}

html::-webkit-scrollbar-thumb:hover {
  background: var(--swd-scrollbar-thumb-hover);
}

body.swd-modern-page,
body.swd-dashboard-page,
body.swd-events-page,
body.swd-auth-page {
  min-height: 100vh;
  color: var(--swd-ink);
  background: linear-gradient(135deg, #f0f2f5 0%, #d9e2ec 100%);
  font-family: "Inter", "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  overflow-x: hidden;
}

body.swd-modern-page > :not(.navbar):not(.modal):not(.modal-backdrop):not(.swal2-container),
body.swd-dashboard-page > :not(.navbar):not(.modal):not(.modal-backdrop):not(.swal2-container),
body.swd-events-page > :not(.navbar):not(.modal):not(.modal-backdrop):not(.swal2-container),
body.swd-auth-page > :not(.navbar):not(.modal):not(.modal-backdrop):not(.swal2-container) {
  position: relative;
  z-index: auto;
}

.swd-page-shell {
  width: min(1320px, calc(100% - 32px));
  margin: 0 auto;
  padding: 28px 0 48px;
}

.swd-rank-card-row {
  display: flex;
  flex-wrap: nowrap;
  gap: 14px;
  overflow-x: visible;
  width: min(100%, 1180px);
  margin-inline: auto;
  padding: 2px 2px 8px;
}

.swd-rank-card {
  flex: 1 1 0;
  width: auto;
  min-width: 0;
  min-height: 148px;
}

.swd-rank-card .card-body {
  display: flex;
  min-height: 148px;
  flex-direction: column;
  justify-content: center;
}

.swd-rank-card-eyebrow {
  color: var(--swd-muted);
  font-size: 0.82rem;
  font-weight: 800;
  text-transform: uppercase;
}

.swd-rank-card-title {
  color: var(--swd-blue-strong);
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.2;
  margin: 8px 0 10px;
  overflow-wrap: anywhere;
}

.swd-rank-card-count {
  color: var(--swd-ink);
  font-size: 2.2rem;
  font-weight: 900;
  line-height: 1;
}

.swd-rank-card-caption {
  color: var(--swd-muted);
  font-size: 0.88rem;
  font-weight: 700;
  margin-top: 6px;
}

.swd-page-head,
.swd-panel,
.swd-card,
.swd-action-strip,
.swd-filter-panel {
  border: 1px solid var(--swd-line);
  border-radius: var(--swd-radius);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: var(--swd-shadow-md);
}

.swd-page-head {
  padding: 18px;
}

.swd-heading,
.swd-section-heading {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.swd-heading-icon,
.swd-section-icon,
.swd-icon-box {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 44px;
  height: 44px;
  border-radius: var(--swd-radius);
  color: var(--swd-blue);
  background: rgba(13, 110, 253, 0.08);
  font-size: 1.25rem;
}

.swd-title {
  margin: 0;
  color: var(--swd-ink);
  font-size: 1.7rem;
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}

.swd-lead {
  margin: 6px 0 0;
  color: var(--swd-muted);
  line-height: 1.5;
}

.swd-panel {
  padding: 18px;
}

.swd-card {
  position: relative;
  overflow: hidden;
  height: 100%;
  background: rgba(255, 255, 255, 0.96);
  transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.swd-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: var(--swd-blue);
}

.swd-card:hover {
  transform: translateY(-2px);
  border-color: #c8d6e5;
  box-shadow: 0 16px 34px rgba(31, 45, 61, 0.13);
}

.swd-card-body {
  padding: 20px 20px 14px 24px;
}

.swd-card-title {
  margin: 0;
  color: var(--swd-ink);
  font-size: 1.18rem;
  font-weight: 800;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.swd-card-footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
  border-top: 1px solid var(--swd-line);
  background: #fff;
  padding: 12px 14px 12px 24px;
}

.swd-action-strip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 18px;
}

.swd-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.swd-filter-panel {
  padding: 18px;
}

.swd-filter-panel .form-label,
.swd-form .form-label {
  color: var(--swd-muted);
  font-size: 0.82rem;
  font-weight: 800;
}

.swd-filter-panel .form-control,
.swd-filter-panel .form-select,
.swd-form .form-control,
.swd-form .form-select {
  min-height: 44px;
  border-color: var(--swd-line);
  border-radius: var(--swd-radius);
  font-weight: 700;
}

.swd-filter-panel .form-control:focus,
.swd-filter-panel .form-select:focus,
.swd-form .form-control:focus,
.swd-form .form-select:focus {
  border-color: var(--swd-blue-strong);
  box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.14);
}

.swd-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 26px 0 14px;
}

.swd-section-title {
  margin: 0;
  color: var(--swd-ink);
  font-size: 1.32rem;
  font-weight: 800;
  line-height: 1.2;
  overflow-wrap: anywhere;
}

.swd-pill,
.swd-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 11px;
  border: 1px solid var(--swd-line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.78);
  color: var(--swd-muted);
  font-size: 0.82rem;
  font-weight: 800;
  line-height: 1.1;
}

.swd-detail-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.swd-detail-list li {
  padding: 8px 10px;
  border-radius: var(--swd-radius);
  background: var(--swd-soft);
  color: var(--swd-muted);
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.swd-detail-list i {
  color: var(--swd-blue);
}

.swd-detail-list strong {
  color: var(--swd-ink);
}

.swd-empty {
  padding: 34px;
  color: var(--swd-muted);
  text-align: center;
  font-weight: 800;
}

.swd-alert {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 12px 14px;
  border: 1px solid #b6d4fe;
  border-left: 3px solid var(--swd-blue-strong);
  border-radius: var(--swd-radius);
  background: #f5faff;
  color: #1f4e79;
  line-height: 1.4;
}

.swd-modal .modal-content,
body.swd-modern-page .modal-content,
body.swd-dashboard-page .modal-content,
body.swd-events-page .modal-content,
body.swd-auth-page .modal-content {
  overflow: hidden;
  border: 1px solid var(--swd-line);
  border-radius: var(--swd-radius);
  box-shadow: 0 18px 48px rgba(31, 45, 61, 0.18);
}

.swd-modal .modal-header,
.swd-modal .modal-footer,
body.swd-modern-page .modal-header,
body.swd-modern-page .modal-footer,
body.swd-dashboard-page .modal-header,
body.swd-dashboard-page .modal-footer,
body.swd-events-page .modal-header,
body.swd-events-page .modal-footer,
body.swd-auth-page .modal-header,
body.swd-auth-page .modal-footer {
  border-color: var(--swd-line);
  background: #fff;
}

.swd-modal .modal-body,
body.swd-modern-page .modal-body,
body.swd-dashboard-page .modal-body,
body.swd-events-page .modal-body,
body.swd-auth-page .modal-body {
  background: var(--swd-soft);
}

body.swd-modern-page .modal,
body.swd-dashboard-page .modal,
body.swd-events-page .modal,
body.swd-auth-page .modal {
  z-index: 2400 !important;
}

body.swd-modern-page .modal-backdrop,
body.swd-dashboard-page .modal-backdrop,
body.swd-events-page .modal-backdrop,
body.swd-auth-page .modal-backdrop {
  z-index: 2390 !important;
}

.swd-choice-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(185px, 1fr));
  gap: 0.75rem;
}

.swd-choice-label {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  width: 100%;
  min-height: 82px;
  margin: 0;
  padding: 0.75rem 0.85rem 0.75rem 1rem;
  border: 1px solid var(--swd-line);
  border-radius: var(--swd-radius);
  background: #fff;
  box-shadow: var(--swd-shadow-sm);
  cursor: pointer;
  transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease, background-color 0.16s ease;
}

.swd-choice-label::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.75rem;
  bottom: 0.75rem;
  width: 3px;
  border-radius: 999px;
  background: var(--choice-color, var(--swd-blue-strong));
}

.swd-choice-label:hover {
  transform: translateY(-1px);
  border-color: var(--choice-color, var(--swd-blue-strong));
  box-shadow: 0 10px 24px rgba(31, 45, 61, 0.1);
}

.swd-choice-input:focus + .swd-choice-label {
  border-color: var(--choice-color, var(--swd-blue-strong));
  box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.16);
}

.swd-choice-input:checked + .swd-choice-label {
  border-color: var(--choice-color, var(--swd-blue-strong));
  background: var(--choice-bg, #f6faff);
  box-shadow: 0 10px 24px rgba(31, 45, 61, 0.1);
}

.swd-choice-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 38px;
  height: 38px;
  border-radius: var(--swd-radius);
  background: var(--choice-soft, #e7f1ff);
  color: var(--choice-color, var(--swd-blue-strong));
  font-size: 1.2rem;
}

.swd-choice-copy strong {
  display: block;
  color: var(--swd-ink);
  font-size: 0.9rem;
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.15;
}

.swd-choice-copy small {
  display: block;
  margin-top: 0.2rem;
  color: var(--swd-muted);
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1.25;
}

.swd-choice-primary {
  --choice-color: var(--swd-blue-strong);
  --choice-soft: #e7f1ff;
  --choice-bg: #f6faff;
}

.swd-choice-success {
  --choice-color: var(--swd-success);
  --choice-soft: #e9f7ef;
  --choice-bg: #f7fcfa;
}

.swd-choice-warning {
  --choice-color: var(--swd-warning);
  --choice-soft: #fff6db;
  --choice-bg: #fffaf0;
}

body.swd-modern-page .btn,
body.swd-dashboard-page .btn,
body.swd-events-page .btn,
body.swd-auth-page .btn,
.swd-btn {
  border-radius: var(--swd-radius);
  font-weight: 800;
  letter-spacing: 0;
}

body.swd-modern-page .btn-group {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 6px;
  vertical-align: middle;
}

body.swd-modern-page .btn-group > .btn,
body.swd-modern-page .btn-group > .btn-group,
body.swd-modern-page .btn-group > form,
body.swd-modern-page .btn-group > form > .btn {
  border-radius: var(--swd-radius) !important;
  margin-left: 0 !important;
}

body.swd-modern-page .btn-group > form {
  display: inline-flex;
}

body.swd-modern-page .card {
  border: 1px solid var(--swd-line);
  border-radius: var(--swd-radius);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--swd-shadow-md);
  overflow: hidden;
}

body.swd-modern-page .card-header {
  border-bottom: 1px solid var(--swd-line);
  background: rgba(248, 250, 252, 0.96) !important;
}

body.swd-modern-page .table-responsive {
  border-radius: var(--swd-radius);
}

body.swd-modern-page .table {
  color: var(--swd-ink);
  vertical-align: middle;
}

body.swd-modern-page .table thead th {
  border-bottom-color: var(--swd-line);
  color: var(--swd-muted);
  font-size: 0.82rem;
  font-weight: 800;
}

body.swd-modern-page .form-control,
body.swd-modern-page .form-select {
  border-color: var(--swd-line);
  border-radius: var(--swd-radius);
}

body.swd-modern-page .form-control:focus,
body.swd-modern-page .form-select:focus {
  border-color: var(--swd-blue-strong);
  box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.14);
}

body.swd-modern-page .alert {
  border-radius: var(--swd-radius);
  box-shadow: var(--swd-shadow-sm);
}

body.swd-modern-page .btn-primary,
body.swd-dashboard-page .btn-primary,
body.swd-events-page .btn-primary,
body.swd-auth-page .btn-primary,
.swd-btn-primary {
  background: var(--swd-blue);
  border-color: var(--swd-blue);
  box-shadow: 0 8px 18px rgba(16, 105, 174, 0.16);
}

body.swd-modern-page .btn-primary:hover,
body.swd-dashboard-page .btn-primary:hover,
body.swd-events-page .btn-primary:hover,
body.swd-auth-page .btn-primary:hover,
.swd-btn-primary:hover {
  background: var(--swd-blue-strong);
  border-color: var(--swd-blue-strong);
}

body.swd-modern-page .swd-topnav,
body.swd-dashboard-page .swd-topnav,
body.swd-events-page .swd-topnav,
body.swd-auth-page .swd-topnav {
  box-sizing: border-box;
  min-height: 64px;
  padding-block: 7px;
  padding-inline-start: clamp(10px, 1.1vw, 18px);
  padding-inline-end: max(var(--swd-navbar-edge-space), calc(clamp(10px, 1.1vw, 18px) + var(--swd-scrollbar-width)));
  width: 100%;
}

body.swd-modern-page .swd-topnav-inner,
body.swd-dashboard-page .swd-topnav-inner,
body.swd-events-page .swd-topnav-inner,
body.swd-auth-page .swd-topnav-inner {
  box-sizing: border-box;
  width: 100%;
  max-width: 1560px;
  margin-inline: auto;
  gap: 8px;
  flex-wrap: nowrap;
}

body.swd-modern-page .swd-topnav-brand,
body.swd-dashboard-page .swd-topnav-brand,
body.swd-events-page .swd-topnav-brand,
body.swd-auth-page .swd-topnav-brand {
  flex: 0 0 auto;
  gap: 9px;
  margin-right: 4px;
  min-width: 0;
}

body.swd-modern-page .swd-topnav-logo,
body.swd-dashboard-page .swd-topnav-logo,
body.swd-events-page .swd-topnav-logo,
body.swd-auth-page .swd-topnav-logo {
  width: 40px;
  height: 40px;
}

body.swd-modern-page .swd-topnav-logo img,
body.swd-dashboard-page .swd-topnav-logo img,
body.swd-events-page .swd-topnav-logo img,
body.swd-auth-page .swd-topnav-logo img {
  width: 38px;
  height: 38px;
}

body.swd-modern-page .swd-topnav-brand-text strong,
body.swd-dashboard-page .swd-topnav-brand-text strong,
body.swd-events-page .swd-topnav-brand-text strong,
body.swd-auth-page .swd-topnav-brand-text strong {
  font-size: 1.04rem;
}

body.swd-modern-page .swd-topnav-collapse,
body.swd-dashboard-page .swd-topnav-collapse,
body.swd-events-page .swd-topnav-collapse,
body.swd-auth-page .swd-topnav-collapse,
body.swd-modern-page .swd-topnav-menu,
body.swd-dashboard-page .swd-topnav-menu,
body.swd-events-page .swd-topnav-menu,
body.swd-auth-page .swd-topnav-menu {
  min-width: 0;
}

body.swd-modern-page .swd-topnav-menu,
body.swd-dashboard-page .swd-topnav-menu,
body.swd-events-page .swd-topnav-menu,
body.swd-auth-page .swd-topnav-menu {
  gap: 2px;
}

body.swd-modern-page .swd-topnav .nav-link,
body.swd-dashboard-page .swd-topnav .nav-link,
body.swd-events-page .swd-topnav .nav-link,
body.swd-auth-page .swd-topnav .nav-link {
  min-height: 34px;
  padding: 7px 7px !important;
  font-size: 0.82rem;
}

body.swd-modern-page .swd-topnav .dropdown-toggle-split,
body.swd-dashboard-page .swd-topnav .dropdown-toggle-split,
body.swd-events-page .swd-topnav .dropdown-toggle-split,
body.swd-auth-page .swd-topnav .dropdown-toggle-split {
  min-width: 24px;
  padding-left: 3px !important;
  padding-right: 3px !important;
}

body.swd-modern-page .swd-session-list,
body.swd-dashboard-page .swd-session-list,
body.swd-events-page .swd-session-list,
body.swd-auth-page .swd-session-list {
  gap: 7px;
}

body.swd-modern-page .swd-session-panel,
body.swd-dashboard-page .swd-session-panel,
body.swd-events-page .swd-session-panel,
body.swd-auth-page .swd-session-panel {
  flex: 0 1 210px;
  width: 210px;
  min-height: 42px;
  padding: 5px 7px 5px 6px;
}

body.swd-modern-page .swd-session-name,
body.swd-dashboard-page .swd-session-name,
body.swd-events-page .swd-session-name,
body.swd-auth-page .swd-session-name {
  max-width: 158px;
  font-size: 0.82rem;
}

body.swd-modern-page .swd-session-time,
body.swd-dashboard-page .swd-session-time,
body.swd-events-page .swd-session-time,
body.swd-auth-page .swd-session-time {
  font-size: 0.74rem;
}

body.swd-modern-page .swd-nav-icon-btn,
body.swd-dashboard-page .swd-nav-icon-btn,
body.swd-events-page .swd-nav-icon-btn,
body.swd-auth-page .swd-nav-icon-btn,
body.swd-modern-page .swd-nav-text-btn,
body.swd-dashboard-page .swd-nav-text-btn,
body.swd-events-page .swd-nav-text-btn,
body.swd-auth-page .swd-nav-text-btn {
  min-height: 34px;
}

body.swd-modern-page .swd-nav-icon-btn,
body.swd-dashboard-page .swd-nav-icon-btn,
body.swd-events-page .swd-nav-icon-btn,
body.swd-auth-page .swd-nav-icon-btn {
  width: 34px;
}

body.swd-modern-page .swd-nav-text-btn,
body.swd-dashboard-page .swd-nav-text-btn,
body.swd-events-page .swd-nav-text-btn,
body.swd-auth-page .swd-nav-text-btn {
  padding: 7px 10px;
  font-size: 0.82rem;
}

@media (max-width: 1599.98px) {
  body.swd-modern-page .swd-topnav .nav-link,
  body.swd-dashboard-page .swd-topnav .nav-link,
  body.swd-events-page .swd-topnav .nav-link,
  body.swd-auth-page .swd-topnav .nav-link {
    padding-left: 6px !important;
    padding-right: 6px !important;
    font-size: 0.8rem;
  }

  body.swd-modern-page .swd-session-panel,
  body.swd-dashboard-page .swd-session-panel,
  body.swd-events-page .swd-session-panel,
  body.swd-auth-page .swd-session-panel {
    flex-basis: 185px;
    width: 185px;
  }

  body.swd-modern-page .swd-session-name,
  body.swd-dashboard-page .swd-session-name,
  body.swd-events-page .swd-session-name,
  body.swd-auth-page .swd-session-name {
    max-width: 132px;
  }

  body.swd-modern-page .swd-session-time > span,
  body.swd-dashboard-page .swd-session-time > span,
  body.swd-events-page .swd-session-time > span,
  body.swd-auth-page .swd-session-time > span {
    display: none;
  }
}

@media (max-width: 1399.98px) {
  body.swd-modern-page .swd-topnav,
  body.swd-dashboard-page .swd-topnav,
  body.swd-events-page .swd-topnav,
  body.swd-auth-page .swd-topnav {
    padding-block: 8px;
    padding-inline-start: 12px;
    padding-inline-end: max(28px, calc(12px + var(--swd-scrollbar-width)));
  }

  body.swd-modern-page .swd-topnav-inner,
  body.swd-dashboard-page .swd-topnav-inner,
  body.swd-events-page .swd-topnav-inner,
  body.swd-auth-page .swd-topnav-inner {
    flex-wrap: wrap;
  }

  body.swd-modern-page .swd-topnav-collapse,
  body.swd-dashboard-page .swd-topnav-collapse,
  body.swd-events-page .swd-topnav-collapse,
  body.swd-auth-page .swd-topnav-collapse {
    width: 100%;
    max-height: calc(100vh - 82px);
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-color: rgba(255, 255, 255, 0.48) rgba(255, 255, 255, 0.08);
    scrollbar-width: thin;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--swd-radius);
    margin-top: 10px;
    padding: 10px;
  }

  body.swd-modern-page .swd-topnav-collapse::-webkit-scrollbar,
  body.swd-dashboard-page .swd-topnav-collapse::-webkit-scrollbar,
  body.swd-events-page .swd-topnav-collapse::-webkit-scrollbar,
  body.swd-auth-page .swd-topnav-collapse::-webkit-scrollbar {
    width: 10px;
  }

  body.swd-modern-page .swd-topnav-collapse::-webkit-scrollbar-track,
  body.swd-dashboard-page .swd-topnav-collapse::-webkit-scrollbar-track,
  body.swd-events-page .swd-topnav-collapse::-webkit-scrollbar-track,
  body.swd-auth-page .swd-topnav-collapse::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.08);
    border-radius: 999px;
  }

  body.swd-modern-page .swd-topnav-collapse::-webkit-scrollbar-thumb,
  body.swd-dashboard-page .swd-topnav-collapse::-webkit-scrollbar-thumb,
  body.swd-events-page .swd-topnav-collapse::-webkit-scrollbar-thumb,
  body.swd-auth-page .swd-topnav-collapse::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.42);
    border: 2px solid rgba(255, 255, 255, 0.08);
    border-radius: 999px;
  }

  body.swd-modern-page .swd-topnav-menu,
  body.swd-dashboard-page .swd-topnav-menu,
  body.swd-events-page .swd-topnav-menu,
  body.swd-auth-page .swd-topnav-menu,
  body.swd-modern-page .swd-session-list,
  body.swd-dashboard-page .swd-session-list,
  body.swd-events-page .swd-session-list,
  body.swd-auth-page .swd-session-list {
    align-items: stretch;
    gap: 6px;
  }

  body.swd-modern-page .swd-topnav .nav-item.dropdown,
  body.swd-dashboard-page .swd-topnav .nav-item.dropdown,
  body.swd-events-page .swd-topnav .nav-item.dropdown,
  body.swd-auth-page .swd-topnav .nav-item.dropdown {
    align-items: stretch;
    display: block;
  }

  body.swd-modern-page .swd-topnav .nav-item.dropdown::after,
  body.swd-dashboard-page .swd-topnav .nav-item.dropdown::after,
  body.swd-events-page .swd-topnav .nav-item.dropdown::after,
  body.swd-auth-page .swd-topnav .nav-item.dropdown::after {
    display: none;
  }

  body.swd-modern-page .swd-topnav .nav-link,
  body.swd-dashboard-page .swd-topnav .nav-link,
  body.swd-events-page .swd-topnav .nav-link,
  body.swd-auth-page .swd-topnav .nav-link {
    display: flex;
    justify-content: space-between;
    width: 100%;
    min-height: 38px;
    padding: 9px 10px !important;
    font-size: 0.9rem;
  }

  body.swd-modern-page .swd-topnav .dropdown-toggle-split,
  body.swd-dashboard-page .swd-topnav .dropdown-toggle-split,
  body.swd-events-page .swd-topnav .dropdown-toggle-split,
  body.swd-auth-page .swd-topnav .dropdown-toggle-split {
    display: inline-flex;
    justify-content: center;
    width: 42px;
    margin-left: 0;
  }

  body.swd-modern-page .swd-topnav .dropdown-menu,
  body.swd-dashboard-page .swd-topnav .dropdown-menu,
  body.swd-events-page .swd-topnav .dropdown-menu,
  body.swd-auth-page .swd-topnav .dropdown-menu {
    position: static;
    width: 100%;
    margin: 5px 0 8px;
  }

  body.swd-modern-page .swd-session-panel,
  body.swd-dashboard-page .swd-session-panel,
  body.swd-events-page .swd-session-panel,
  body.swd-auth-page .swd-session-panel {
    flex: 1 1 auto;
    width: 100%;
    margin-top: 8px;
    justify-content: flex-start;
  }

  body.swd-modern-page .swd-session-name,
  body.swd-dashboard-page .swd-session-name,
  body.swd-events-page .swd-session-name,
  body.swd-auth-page .swd-session-name {
    max-width: 100%;
  }

  body.swd-modern-page .swd-session-time > span,
  body.swd-dashboard-page .swd-session-time > span,
  body.swd-events-page .swd-session-time > span,
  body.swd-auth-page .swd-session-time > span {
    display: inline;
  }

  body.swd-modern-page .swd-session-actions,
  body.swd-dashboard-page .swd-session-actions,
  body.swd-events-page .swd-session-actions,
  body.swd-auth-page .swd-session-actions {
    width: 100%;
  }

  body.swd-modern-page .swd-nav-text-btn,
  body.swd-dashboard-page .swd-nav-text-btn,
  body.swd-events-page .swd-nav-text-btn,
  body.swd-auth-page .swd-nav-text-btn {
    flex: 1 1 auto;
  }
}

@media (max-width: 575.98px) {
  body.swd-modern-page .swd-topnav-brand-text strong,
  body.swd-dashboard-page .swd-topnav-brand-text strong,
  body.swd-events-page .swd-topnav-brand-text strong,
  body.swd-auth-page .swd-topnav-brand-text strong {
    font-size: 1rem;
  }

  body.swd-modern-page .swd-topnav-logo,
  body.swd-dashboard-page .swd-topnav-logo,
  body.swd-events-page .swd-topnav-logo,
  body.swd-auth-page .swd-topnav-logo {
    width: 38px;
    height: 38px;
  }

  body.swd-modern-page .swd-topnav-logo img,
  body.swd-dashboard-page .swd-topnav-logo img,
  body.swd-events-page .swd-topnav-logo img,
  body.swd-auth-page .swd-topnav-logo img {
    width: 36px;
    height: 36px;
  }

  body.swd-modern-page .swd-session-time,
  body.swd-dashboard-page .swd-session-time,
  body.swd-events-page .swd-session-time,
  body.swd-auth-page .swd-session-time {
    flex-wrap: wrap;
    white-space: normal;
  }
}

@media (max-width: 767.98px) {
  .swd-page-shell {
    width: min(100% - 20px, 1320px);
    padding: 16px 0 40px;
  }

  .swd-rank-card-row {
    overflow-x: auto;
  }

  .swd-rank-card {
    flex: 0 0 190px;
  }

  .swd-action-strip,
  .swd-section-header {
    align-items: flex-start;
    flex-direction: column;
  }

  .swd-actions,
  .swd-actions .btn {
    width: 100%;
  }

  .swd-title {
    font-size: 1.45rem;
  }

  .swd-heading,
  .swd-section-heading {
    align-items: flex-start;
  }
}

.swd-register-shell {
  width: min(1420px, calc(100% - 32px));
}

.swd-register-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  margin-bottom: 20px;
}

.swd-register-hero .swd-lead {
  max-width: 820px;
}

.swd-register-status {
  display: grid;
  gap: 8px;
  min-width: min(100%, 260px);
}

.swd-register-status .swd-pill {
  justify-content: center;
}

.swd-register-grid {
  display: grid;
  grid-template-columns: minmax(360px, 0.9fr) minmax(420px, 1.1fr);
  gap: 20px;
  align-items: start;
}

.swd-register-panel-head {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 20px;
}

.swd-register-panel-head .swd-section-title {
  font-size: 1.28rem;
}

.swd-register-panel-head .swd-lead {
  font-size: 0.92rem;
}

.swd-register-form-panel,
.swd-register-info-panel,
.swd-register-admin-panel,
.swd-privacy-panel {
  background: rgba(255, 255, 255, 0.95);
}

.swd-register-info-panel {
  display: grid;
  gap: 16px;
}

.swd-register-form-panel .swd-alert {
  flex-wrap: wrap;
}

.swd-register-info-panel p {
  color: var(--swd-muted);
  line-height: 1.6;
  margin-bottom: 0;
}

.swd-register-info-panel .list-group {
  gap: 8px;
}

.swd-register-info-panel .list-group-item,
.swd-privacy-panel .list-group-item {
  border: 1px solid var(--swd-line);
  border-radius: var(--swd-radius);
  background: #fff;
  color: var(--swd-muted);
  line-height: 1.45;
}

.swd-register-info-panel .list-group-flush {
  gap: 6px;
  margin-top: 10px;
}

.swd-register-info-panel .list-group-flush .list-group-item {
  border-color: transparent;
  background: var(--swd-soft);
}

.swd-register-downloads .list-group-item {
  gap: 12px;
}

.swd-register-downloads span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.file-required-notice,
.swd-register-notice {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin: 0 0 22px !important;
  padding: 12px 14px;
  border: 1px solid #ffe0a3;
  border-left: 3px solid var(--swd-warning);
  border-radius: var(--swd-radius);
  background: #fffaf0;
  color: #7a5a16;
  font-size: 0.92rem;
  line-height: 1.45;
}

.required-file-label {
  color: var(--swd-danger);
  font-weight: 800;
}

.file-upload-area {
  display: grid;
  gap: 12px;
  justify-items: center;
  width: 100%;
  margin-top: 12px;
  padding: 22px;
  border: 2px dashed #e3b5bc;
  border-radius: var(--swd-radius);
  text-align: center;
  cursor: pointer;
  background: #fff7f8;
  transition: background-color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.file-upload-area:hover,
.file-upload-area:focus-within {
  border-color: var(--swd-danger);
  background: #fff1f3;
  box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.08);
}

.file-upload-area.file-selected {
  border-color: var(--swd-success);
  background: #f7fcfa;
}

.file-upload-area.file-selected:hover,
.file-upload-area.file-selected:focus-within {
  border-color: var(--swd-success);
  background: #eefaf4;
  box-shadow: 0 0 0 0.2rem rgba(25, 135, 84, 0.1);
}

.file-upload-area input[type="file"] {
  display: none;
}

.file-upload-area p {
  margin: 0;
  color: var(--swd-muted);
  font-weight: 700;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.file-upload-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 42px;
  padding: 9px 14px;
  border-radius: var(--swd-radius);
  background: var(--swd-blue);
  color: #fff;
  font-weight: 800;
  text-decoration: none;
  box-shadow: 0 8px 18px rgba(16, 105, 174, 0.16);
  transition: background-color 0.18s ease, transform 0.18s ease;
}

.file-upload-button:hover,
.file-upload-button:focus {
  transform: translateY(-1px);
  background: var(--swd-blue-strong);
  color: #fff;
}

.swd-consent-panel {
  position: relative;
}

.swd-consent-card {
  position: relative;
  display: grid;
  grid-template-columns: 60px minmax(0, 1fr);
  gap: 16px;
  align-items: start;
  width: 100%;
  margin: 0;
  padding: 16px;
  border: 2px solid #9ec5fe;
  border-radius: var(--swd-radius);
  background: linear-gradient(180deg, #f7fbff 0%, #eef6ff 100%);
  box-shadow: var(--swd-shadow-sm), inset 0 0 0 1px rgba(13, 110, 253, 0.05);
  cursor: pointer;
  transition: background-color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.swd-consent-card:hover {
  border-color: var(--swd-blue-strong);
  box-shadow: 0 12px 28px rgba(16, 105, 174, 0.14);
}

.swd-consent-input {
  position: absolute;
  left: 16px;
  top: 16px;
  z-index: 2;
  width: 50px;
  height: 50px;
  margin: 0;
  opacity: 0;
  cursor: pointer;
}

.swd-consent-control {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  border: 3px solid var(--swd-blue);
  border-radius: var(--swd-radius);
  background: #ffffff;
  color: #ffffff;
  font-size: 1.65rem;
  box-shadow: 0 0 0 5px rgba(13, 110, 253, 0.12);
  transition: background-color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.swd-consent-control i {
  opacity: 0;
  transform: scale(0.7);
  transition: opacity 0.18s ease, transform 0.18s ease;
}

.swd-consent-content {
  display: grid;
  min-width: 0;
}

.swd-consent-text {
  display: block;
  padding: 12px;
  border: 1px solid var(--swd-line);
  border-radius: var(--swd-radius);
  background: rgba(255, 255, 255, 0.82);
  color: var(--swd-muted);
  line-height: 1.5;
  scrollbar-color: var(--swd-scrollbar-thumb) var(--swd-scrollbar-track);
  scrollbar-width: thin;
}

.swd-consent-input:focus + .swd-consent-control {
  box-shadow: 0 0 0 0.24rem rgba(13, 110, 253, 0.24);
}

.swd-consent-input:checked + .swd-consent-control {
  border-color: var(--swd-success);
  background: var(--swd-success);
  box-shadow: 0 0 0 5px rgba(25, 135, 84, 0.15);
  transform: translateY(-1px);
}

.swd-consent-input:checked + .swd-consent-control i {
  opacity: 1;
  transform: scale(1);
}

.swd-consent-card:has(.swd-consent-input:checked) {
  border-color: var(--swd-success);
  background: linear-gradient(180deg, #f7fcfa 0%, #edf9f3 100%);
}

body.swd-register-page input[readonly] {
  background-color: #eef2f6;
}

body.swd-register-page .phone-valid {
  border-color: var(--swd-success) !important;
  box-shadow: 0 0 0 0.2rem rgba(25, 135, 84, 0.16) !important;
}

body.swd-register-page .phone-invalid,
body.swd-register-page .is-invalid {
  border-color: var(--swd-danger) !important;
  box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.14) !important;
}

.spinner-overlay {
  position: fixed;
  inset: 0;
  z-index: 2500;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 18px;
  background: rgba(15, 23, 42, 0.68);
  backdrop-filter: blur(6px);
}

.spinner-content {
  width: min(100%, 420px);
  padding: 28px;
  border: 1px solid var(--swd-line);
  border-radius: var(--swd-radius);
  background: #fff;
  text-align: center;
  box-shadow: var(--swd-shadow-lg);
}

.spinner-content .spinner-border {
  width: 3rem;
  height: 3rem;
}

.swd-register-admin-grid {
  display: grid;
  grid-template-columns: minmax(300px, 0.85fr) minmax(420px, 1.15fr);
  gap: 20px;
  align-items: start;
}

.swd-register-file-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.swd-register-file-list .list-group-item {
  border: 1px solid var(--swd-line);
  border-radius: var(--swd-radius);
  background: #fff;
}

.swd-privacy-shell {
  width: min(1040px, calc(100% - 32px));
}

.swd-privacy-logo {
  width: 108px;
  height: auto;
  object-fit: contain;
}

.swd-privacy-panel {
  overflow: hidden;
  border: 1px solid var(--swd-line);
  border-radius: var(--swd-radius);
  background: rgba(255, 255, 255, 0.95);
  box-shadow: var(--swd-shadow-md);
  margin-bottom: 16px;
}

.swd-privacy-panel .card-body {
  padding: 22px;
}

.swd-privacy-panel .card-title {
  color: var(--swd-blue);
  font-size: 1.18rem;
  font-weight: 800;
  letter-spacing: 0;
}

.swd-privacy-panel p,
.swd-privacy-panel li {
  color: var(--swd-muted);
  line-height: 1.62;
}

@media (max-width: 991.98px) {
  .swd-register-hero,
  .swd-register-grid,
  .swd-register-admin-grid {
    grid-template-columns: 1fr;
  }

  .swd-register-status {
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  }
}

@media (max-width: 575.98px) {
  .swd-register-shell,
  .swd-privacy-shell {
    width: min(100% - 20px, 1320px);
  }

  .swd-register-form-panel,
  .swd-register-info-panel,
  .swd-register-admin-panel,
  .swd-privacy-panel .card-body {
    padding: 16px;
  }

  .swd-register-panel-head {
    align-items: flex-start;
  }

  .swd-register-form-panel .swd-alert .btn {
    width: 100%;
    margin-left: 0 !important;
  }

  .swd-consent-card {
    grid-template-columns: 1fr;
  }

  .swd-consent-input {
    left: 18px;
    top: 18px;
    width: 52px;
    height: 52px;
  }

  .swd-consent-control {
    width: 52px;
    height: 52px;
  }
}

.swd-orders-shell {
  width: min(1480px, calc(100% - 32px));
}

.swd-orders-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.swd-orders-tabs {
  gap: 8px;
  margin-bottom: 22px;
}

.swd-orders-tabs .nav-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  border: 1px solid var(--swd-line);
  border-radius: var(--swd-radius);
  background: rgba(255, 255, 255, 0.76);
  color: var(--swd-muted);
  font-weight: 800;
}

.swd-orders-tabs .nav-link.active {
  border-color: var(--swd-blue);
  background: var(--swd-blue);
  color: #fff;
  box-shadow: 0 8px 18px rgba(16, 105, 174, 0.16);
}

.swd-orders-tabs .nav-link span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  height: 24px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(16, 105, 174, 0.1);
  color: inherit;
  font-size: 0.8rem;
}

.swd-orders-tabs .nav-link.active span {
  background: rgba(255, 255, 255, 0.2);
}

.swd-orders-section + .swd-orders-section {
  margin-top: 26px;
}

.swd-orders-table-wrap {
  overflow: hidden;
  padding: 0;
}

.swd-orders-table th,
.swd-orders-table td {
  vertical-align: middle;
}

.swd-orders-table thead th {
  white-space: nowrap;
  background: rgba(248, 250, 252, 0.94);
}

.swd-order-title-cell {
  min-width: 220px;
  font-weight: 800;
  overflow-wrap: anywhere;
}

.swd-table-actions {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 6px;
}

.swd-order-preview-frame {
  display: block;
  width: 100%;
  height: min(76vh, 760px);
  border: 0;
  background: #fff;
}

.swd-orders-form-shell {
  width: min(980px, calc(100% - 32px));
}

.swd-orders-form-panel {
  background: rgba(255, 255, 255, 0.96);
}

.swd-form-actions {
  justify-content: flex-start;
}

.swd-token-box {
  padding: 16px;
  border: 1px solid var(--swd-line);
  border-radius: var(--swd-radius);
  background: var(--swd-soft);
}

.file-upload-area.hover {
  border-color: var(--swd-blue);
  background: #f6faff;
  box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.1);
}

.swd-orders-public-shell {
  width: min(1280px, calc(100% - 32px));
}

.swd-orders-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
}

.swd-order-public-card {
  display: flex;
  min-height: 210px;
  flex-direction: column;
  cursor: pointer;
}

.swd-order-public-card .swd-card-body {
  flex: 1 1 auto;
}

.swd-order-card-subtitle {
  margin: 10px 0 14px;
  color: var(--swd-muted);
  line-height: 1.4;
  overflow-wrap: anywhere;
}

.swd-public-filter-panel {
  background: rgba(255, 255, 255, 0.96);
}

.swd-public-filter-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 8px;
}

.swd-public-filter-grid .btn {
  white-space: normal;
  overflow-wrap: anywhere;
}

.swd-orders-preview-shell {
  width: min(1640px, calc(100% - 32px));
  padding-top: 20px;
  padding-bottom: 32px;
}

.swd-orders-preview-layout {
  display: grid;
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
  gap: 18px;
  align-items: stretch;
  min-height: calc(100vh - 72px);
}

.swd-orders-preview-info {
  align-self: start;
}

.swd-orders-pdf-panel {
  overflow: hidden;
  min-height: calc(100vh - 72px);
  padding: 0;
}

.swd-pdf-viewer {
  height: calc(100vh - 72px);
  min-height: 640px;
  background: #fff;
}

.swd-pdf-viewer iframe {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
}

@media (max-width: 991.98px) {
  .swd-orders-hero {
    align-items: flex-start;
    flex-direction: column;
  }

  .swd-orders-preview-layout {
    grid-template-columns: 1fr;
    min-height: 0;
  }

  .swd-orders-pdf-panel,
  .swd-pdf-viewer {
    min-height: 70vh;
  }

  .swd-pdf-viewer {
    height: 70vh;
  }
}

@media (max-width: 575.98px) {
  .swd-orders-shell,
  .swd-orders-form-shell,
  .swd-orders-public-shell,
  .swd-orders-preview-shell {
    width: min(100% - 20px, 1320px);
  }

  .swd-orders-tabs,
  .swd-orders-tabs .nav-item,
  .swd-orders-tabs .nav-link {
    width: 100%;
  }

  .swd-orders-tabs .nav-link {
    justify-content: space-between;
  }

  .swd-token-box {
    padding: 12px;
  }
}
