:root {
  color-scheme: light;
  --font-body: "Geist Mono", monospace;
  --font-display: "Pixelify Sans", sans-serif;
  --color-primary: #ff5a3d;
  --color-primary-hover: #ff6b52;
  --color-primary-deep: #e7422e;
  --color-primary-soft: #ffe6e1;
  --color-background: #f7f8fa;
  --color-surface: #ffffff;
  --color-surface-alt: #eef1f4;
  --color-border: #d8dee6;
  --color-text: #121417;
  --color-text-secondary: #5f6b7a;
  --color-success: #22c55e;
  --color-warning: #f59e0b;
  --color-error: #ef4444;
  --color-info: #2563eb;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 20px;
  --shadow-sm: 0 1px 2px rgb(18 20 23 / 4%);
  --shadow-md: 0 8px 24px rgb(18 20 23 / 8%);
  --shadow-lg: 0 24px 64px rgb(18 20 23 / 12%);
  --bs-body-font-family: var(--font-body);
  --bs-body-bg: var(--color-background);
  --bs-body-color: var(--color-text);
  --bs-border-color: var(--color-border);
  --bs-primary: var(--color-primary);
  --bs-primary-rgb: 255, 90, 61;
  --bs-link-color: var(--color-text);
  --bs-link-hover-color: var(--color-primary);
}

[data-theme="dark"] {
  color-scheme: dark;
  --color-background: #08090b;
  --color-surface: #111318;
  --color-surface-alt: #171a20;
  --color-border: #2a2e35;
  --color-text: #f5f7fa;
  --color-text-secondary: #9ca3af;
  --color-primary-soft: #351713;
  --shadow-sm: 0 1px 2px rgb(0 0 0 / 30%);
  --shadow-md: 0 8px 24px rgb(0 0 0 / 40%);
  --shadow-lg: 0 24px 64px rgb(0 0 0 / 50%);
  --bs-body-bg: var(--color-background);
  --bs-body-color: var(--color-text);
  --bs-border-color: var(--color-border);
  --bs-secondary-color: var(--color-text-secondary);
  --bs-emphasis-color: var(--color-text);
  --bs-tertiary-bg: var(--color-surface-alt);
  --bs-link-color: var(--color-text);
  --bs-link-hover-color: var(--color-primary);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
  overflow-x: clip;
  background: var(--color-background);
  scroll-behavior: smooth;
}

body {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow-x: hidden;
  background:
    radial-gradient(circle at 15% 8%, rgb(255 90 61 / 4%), transparent 24rem),
    var(--color-background);
  color: var(--color-text);
  font-family: var(--font-body);
}

main {
  width: 100%;
  min-width: 0;
}

section,
.container,
.row,
.row > * {
  min-width: 0;
}

img,
svg,
video {
  max-width: 100%;
  height: auto;
}

a,
button,
.card {
  transition: color .2s ease, background-color .2s ease, border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

:focus-visible {
  outline: 3px solid rgb(255 90 61 / 35%);
  outline-offset: 3px;
}

.btn {
  --bs-btn-font-weight: 650;
  --bs-btn-border-radius: var(--radius-sm);
  min-height: 44px;
  font-family: var(--font-display);
}

.btn-primary {
  --bs-btn-bg: var(--color-primary);
  --bs-btn-border-color: var(--color-primary);
  --bs-btn-hover-bg: var(--color-primary-hover);
  --bs-btn-hover-border-color: var(--color-primary-hover);
  --bs-btn-active-bg: var(--color-primary-deep);
  --bs-btn-active-border-color: var(--color-primary-deep);
  --bs-btn-disabled-bg: var(--color-primary);
  --bs-btn-disabled-border-color: var(--color-primary);
  box-shadow: 0 8px 24px rgb(255 90 61 / 20%);
}

.btn-outline-secondary {
  --bs-btn-color: var(--color-text);
  --bs-btn-border-color: var(--color-border);
  --bs-btn-hover-color: var(--color-text);
  --bs-btn-hover-bg: var(--color-surface-alt);
  --bs-btn-hover-border-color: var(--color-primary);
  --bs-btn-active-bg: var(--color-surface-alt);
}

.card,
.dropdown-menu,
.offcanvas,
.form-control {
  background-color: var(--color-surface);
  border-color: var(--color-border);
  color: var(--color-text);
}

.card {
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}

.dropdown-menu {
  --bs-dropdown-link-color: var(--color-text);
  --bs-dropdown-link-hover-color: var(--color-text);
  --bs-dropdown-link-hover-bg: var(--color-surface-alt);
  --bs-dropdown-border-radius: var(--radius-sm);
  box-shadow: var(--shadow-md);
}

.form-control {
  min-height: 44px;
}

.form-control::placeholder {
  color: var(--color-text-secondary);
}

.form-control:focus {
  color: var(--color-text);
  background-color: var(--color-surface);
  border-color: var(--color-primary);
  box-shadow: 0 0 0 .25rem rgb(255 90 61 / 15%);
}

.site-header {
  z-index: 1030;
  margin-bottom: 0;
  background: color-mix(in srgb, var(--color-background) 88%, transparent);
  border-bottom: 1px solid var(--color-border);
  backdrop-filter: blur(18px);
}

.site-header .navbar {
  min-height: 72px;
}

.site-header .navbar > .container {
  position: relative;
}

.site-logo {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2vw, 1.7rem);
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
}

.site-logo:hover {
  color: var(--color-text);
}

.site-logo-mark {
  width: 38px;
  height: 38px;
  fill: none;
  stroke: var(--color-primary);
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.site-header .nav-link {
  display: inline-flex;
  align-items: center;
  gap: .42rem;
  color: var(--color-text-secondary);
  font-family: var(--font-display);
  font-size: .875rem;
  font-weight: 600;
  letter-spacing: .01em;
  border-radius: var(--radius-sm);
  transition: color .2s ease, background-color .2s ease;
}

.site-header .nav-link:hover,
.site-header .nav-link:focus {
  color: var(--color-primary);
  background: var(--color-primary-soft);
}

.site-nav-icon,
.site-dropdown-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: currentColor;
}

.site-nav-icon svg,
.site-dropdown-icon svg {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.site-nav-icon {
  width: 18px;
  height: 18px;
}

.site-nav-icon svg {
  width: 17px;
  height: 17px;
}

@media (min-width: 1200px) {
  .site-header .navbar-nav {
    margin-left: .45rem;
    margin-right: auto !important;
  }

  .site-header .navbar-collapse > .d-flex {
    margin-left: auto;
  }
}

.site-account-menu .dropdown-menu {
  min-width: 230px;
  padding: .55rem;
  border-color: var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
}

.site-account-menu .dropdown-item {
  display: flex;
  min-height: 48px;
  align-items: center;
  gap: .68rem;
  padding: .55rem .65rem;
  color: var(--color-text);
  border-radius: var(--radius-sm);
  font-family: var(--font-display);
  font-size: .88rem;
  font-weight: 600;
}

.site-account-menu .dropdown-item:hover,
.site-account-menu .dropdown-item:focus {
  color: var(--color-primary);
  background: var(--color-primary-soft);
}

.site-dropdown-icon {
  flex: 0 0 32px;
  width: 32px;
  height: 32px;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 18%);
  border-radius: 10px;
}

.site-dropdown-icon svg {
  width: 18px;
  height: 18px;
}

.site-dropdown-danger:hover,
.site-dropdown-danger:focus {
  color: var(--color-error) !important;
}

.site-login {
  color: var(--color-text);
  text-decoration: none;
}

.site-icon-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  color: var(--color-text);
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
}

.site-icon-button:hover {
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border-color: rgb(255 90 61 / 20%);
}

.site-icon-button svg {
  width: 22px;
  height: 22px;
  fill: currentColor;
}

.header-lang img {
  width: 22px;
  height: 22px;
  border-radius: 50%;
}

.header-lang .dropdown-item img {
  margin-right: .5rem;
}

.theme-icon-dark,
[data-theme="dark"] .theme-icon-light {
  display: none;
}

[data-theme="dark"] .theme-icon-dark {
  display: block;
}

.navbar-toggler {
  border: 1px solid var(--color-border);
}

[data-theme="dark"] .navbar-toggler-icon,
[data-theme="dark"] .btn-close {
  filter: invert(1) grayscale(1);
}

.site-mobile-menu {
  --bs-offcanvas-width: 360px;
  width: 360px !important;
  max-width: calc(100vw - 24px);
  height: 100vh;
  height: 100dvh;
  min-width: 0;
  flex: 0 0 auto;
  background-color: var(--color-surface);
  box-shadow: var(--shadow-lg);
}

.site-mobile-menu:not(.show):not(.showing):not(.hiding) {
  display: none;
}

.site-mobile-menu .offcanvas-header,
.site-mobile-menu .offcanvas-body {
  width: 100%;
  min-width: 0;
}

.site-mobile-menu .offcanvas-header {
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--color-border);
}

.site-mobile-menu .offcanvas-body {
  padding: 1.25rem 1.5rem 1.5rem;
  overflow-x: hidden;
  overflow-y: auto;
}

.site-mobile-menu .navbar-nav,
.site-mobile-menu .nav-link,
.site-mobile-menu .dropdown,
.site-mobile-menu .dropdown-menu {
  width: 100%;
}

.site-mobile-menu .nav-link {
  white-space: normal;
  overflow-wrap: anywhere;
}

.site-mobile-title {
  color: var(--color-primary);
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 700;
}

.mobile-menu-nav {
  display: grid;
  gap: .5rem;
}

.mobile-menu-row,
.mobile-account-row {
  position: relative;
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr);
  align-items: center;
  gap: .75rem;
  width: 100%;
  min-height: 48px;
  padding: .25rem .75rem .25rem .5rem;
  color: var(--color-text-secondary);
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: .875rem;
  font-weight: 650;
  line-height: 1.35;
  text-align: left;
  text-decoration: none;
}

.mobile-menu-row::before {
  position: absolute;
  top: 10px;
  bottom: 10px;
  left: 0;
  width: 3px;
  content: "";
  background: transparent;
  border-radius: 0 999px 999px 0;
}

.mobile-menu-row:hover,
.mobile-menu-row:focus-visible,
.mobile-account-row:hover,
.mobile-account-row:focus-visible {
  color: var(--color-text);
  background: var(--color-surface-alt);
  border-color: var(--color-border);
}

.mobile-menu-row.active {
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border-color: rgb(255 90 61 / 18%);
}

.mobile-menu-row.active::before {
  background: var(--color-primary);
}

.mobile-menu-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  color: currentColor;
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
}

.mobile-menu-row.active .mobile-menu-icon {
  color: var(--color-primary);
  background: color-mix(in srgb, var(--color-primary-soft) 72%, var(--color-surface));
  border-color: rgb(255 90 61 / 22%);
}

.mobile-menu-icon svg {
  width: 21px;
  height: 21px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.7;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.mobile-menu-settings,
.mobile-account {
  border-top: 1px solid var(--color-border);
}

.mobile-menu-control {
  appearance: none;
  cursor: pointer;
}

.mobile-menu-control.dropdown-toggle::after {
  position: absolute;
  right: 1rem;
  margin: 0;
}

.mobile-language {
  padding-right: 2.5rem;
}

.mobile-menu-heading {
  color: var(--color-text-secondary);
  font-family: var(--font-display);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.mobile-account {
  padding-top: 1.25rem;
}

.mobile-account-row {
  color: var(--color-text);
  background: var(--color-surface);
  border-color: var(--color-border);
  box-shadow: var(--shadow-sm);
}

.mobile-account-row .mobile-menu-icon {
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border-color: rgb(255 90 61 / 18%);
}

.mobile-account-primary {
  color: #fff;
  background: var(--color-primary);
  border-color: var(--color-primary);
  box-shadow: 0 8px 24px rgb(255 90 61 / 20%);
}

.mobile-account-primary:hover,
.mobile-account-primary:focus-visible {
  color: #fff;
  background: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
}

.mobile-account-primary .mobile-menu-icon {
  color: #fff;
  background: rgb(255 255 255 / 14%);
  border-color: rgb(255 255 255 / 24%);
}

.mobile-account-danger {
  color: var(--color-error);
  background: color-mix(in srgb, var(--color-error) 5%, var(--color-surface));
  border-color: color-mix(in srgb, var(--color-error) 28%, var(--color-border));
}

.mobile-account-danger:hover,
.mobile-account-danger:focus-visible {
  color: var(--color-error);
  background: color-mix(in srgb, var(--color-error) 10%, var(--color-surface));
  border-color: var(--color-error);
}

.mobile-account-danger .mobile-menu-icon {
  color: var(--color-error);
  background: color-mix(in srgb, var(--color-error) 10%, var(--color-surface));
  border-color: color-mix(in srgb, var(--color-error) 24%, var(--color-border));
}

/* Public mobile menu aligned with the account sidebar guide */
.site-mobile-menu {
  --bs-offcanvas-width: 286px;
  width: 286px !important;
  max-width: calc(100vw - 40px);
  color: var(--color-text);
  background:
    radial-gradient(circle at 0 0, rgb(255 90 61 / 7%), transparent 18rem),
    linear-gradient(180deg, var(--color-surface), var(--color-background));
  border-left: 1px solid var(--color-border);
}

.site-mobile-menu .offcanvas-header {
  min-height: 72px;
  padding: .95rem 1rem 1rem;
}

.site-mobile-menu .offcanvas-body {
  padding: 1rem;
}

.site-mobile-brand {
  display: inline-flex;
  min-width: 0;
  align-items: center;
  gap: .6rem;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: 1.08rem;
  font-weight: 700;
  letter-spacing: .02em;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;
}

.site-mobile-brand:hover {
  color: var(--color-text);
}

.site-mobile-brand > span:last-child {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.site-mobile-brand > span:last-child span {
  color: var(--color-primary);
}

.site-mobile-brand-mark {
  display: inline-flex;
  flex: 0 0 34px;
  width: 34px;
  height: 34px;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  border: 1.5px solid currentColor;
  border-radius: 10px;
}

.site-mobile-brand-mark svg {
  width: 22px;
  height: 22px;
  fill: currentColor;
}

.site-mobile-close {
  display: inline-flex;
  flex: 0 0 40px;
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  padding: 0;
  color: var(--color-text-secondary);
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
}

.site-mobile-close:hover,
.site-mobile-close:focus-visible {
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border-color: rgb(255 90 61 / 18%);
}

.site-mobile-close svg {
  width: 22px;
  height: 22px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
}

.site-mobile-account-card {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr) auto;
  align-items: center;
  gap: .65rem;
  margin-bottom: 1.1rem;
  padding: .75rem;
  background:
    linear-gradient(135deg, rgb(255 90 61 / 8%), transparent 38%),
    var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}

.site-mobile-avatar {
  display: inline-flex;
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  color: #fff;
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));
  border-radius: 11px;
}

.site-mobile-avatar svg {
  width: 21px;
  height: 21px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.site-mobile-account-copy {
  display: grid;
  min-width: 0;
  gap: .15rem;
}

.site-mobile-account-copy strong {
  overflow: hidden;
  color: var(--color-text);
  font-size: .86rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.site-mobile-account-copy small {
  color: var(--color-success);
  font-family: var(--font-display);
  font-size: .7rem;
}

.site-mobile-account-meta {
  padding: .28rem .5rem;
  color: var(--color-text);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  font-family: var(--font-display);
  font-size: .68rem;
}

.mobile-menu-nav {
  gap: .9rem;
  padding-bottom: 1rem;
}

.mobile-menu-group {
  display: grid;
  gap: .12rem;
}

.mobile-menu-heading {
  margin: 0 .2rem .4rem;
  color: var(--color-text-secondary);
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .08em;
}

.mobile-menu-row {
  display: flex;
  min-height: 38px;
  align-items: center;
  gap: .58rem;
  padding: .35rem .62rem;
  color: var(--color-text-secondary);
  background: transparent;
  border-color: transparent;
  box-shadow: none;
  font-family: var(--font-display);
  font-size: .94rem;
  letter-spacing: .01em;
}

.mobile-menu-row > span:last-child {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mobile-menu-row:hover,
.mobile-menu-row:focus-visible {
  color: var(--color-text);
  background: color-mix(in srgb, var(--color-surface-alt) 88%, transparent);
  border-color: rgb(255 90 61 / 14%);
}

.mobile-menu-row.active {
  color: var(--color-text);
  background: linear-gradient(90deg, rgb(255 90 61 / 28%), rgb(255 90 61 / 10%));
  border-color: rgb(255 90 61 / 24%);
  box-shadow: inset 3px 0 var(--color-primary);
}

.mobile-menu-row.active::before {
  display: none;
}

.mobile-menu-icon,
.mobile-menu-row.active .mobile-menu-icon {
  flex: 0 0 26px;
  width: 26px;
  min-width: 26px;
  height: 26px;
  color: currentColor;
  background: transparent;
  border: 0;
  border-radius: 0;
}

.mobile-menu-row.active .mobile-menu-icon {
  color: var(--color-primary);
}

.site-mobile-footer {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: .5rem;
  margin-top: auto;
  padding-top: .85rem;
  border-top: 1px solid var(--color-border);
}

.site-mobile-footer-button,
.site-mobile-footer-action {
  display: inline-flex;
  min-height: 46px;
  align-items: center;
  justify-content: center;
  color: var(--color-text);
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font-display);
  font-size: .94rem;
  font-weight: 700;
  text-decoration: none;
}

.site-mobile-footer-button {
  width: 54px;
  padding: 0;
}

.site-mobile-footer-action {
  gap: .45rem;
  padding: .45rem .6rem;
  color: var(--color-primary);
}

.site-mobile-footer-button:hover,
.site-mobile-footer-button:focus-visible,
.site-mobile-footer-action:hover,
.site-mobile-footer-action:focus-visible {
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border-color: rgb(255 90 61 / 24%);
}

.site-mobile-footer-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.site-mobile-footer-icon svg {
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.site-mobile-footer .dropdown-menu {
  width: 230px;
  min-width: 230px;
  padding: .45rem;
  background: var(--color-surface);
  border-color: var(--color-border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-md);
}

[data-theme="dark"] .site-mobile-menu {
  background:
    radial-gradient(circle at 0 0, rgb(255 90 61 / 10%), transparent 18rem),
    linear-gradient(180deg, #08090b, #111318);
  box-shadow: 18px 0 50px rgb(0 0 0 / 35%);
}

[data-theme="dark"] .site-mobile-account-meta {
  background: var(--color-background);
}

/* Public catalogue */
.catalogue-page {
  position: relative;
  isolation: isolate;
  min-height: calc(100vh - 72px);
  padding: 3.5rem 0 4.5rem;
  overflow: hidden;
}

.catalogue-page::before {
  position: absolute;
  inset: 0;
  z-index: -2;
  content: "";
  background:
    linear-gradient(rgb(95 107 122 / 7%) 1px, transparent 1px),
    linear-gradient(90deg, rgb(95 107 122 / 7%) 1px, transparent 1px),
    radial-gradient(circle at 82% 0, rgb(255 90 61 / 14%), transparent 24rem);
  background-size: 64px 64px, 64px 64px, auto;
  opacity: .9;
}

.catalogue-shell {
  position: relative;
  z-index: 1;
}

.catalogue-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 420px);
  gap: 2rem;
  align-items: stretch;
  margin-bottom: 2.25rem;
}

.catalogue-hero-copy,
.catalogue-search-card,
.catalogue-file-card {
  color: var(--color-text);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-sm);
}

.catalogue-hero-copy {
  display: flex;
  min-height: 340px;
  flex-direction: column;
  justify-content: center;
  padding: clamp(1.5rem, 4vw, 2.4rem);
  background:
    linear-gradient(135deg, rgb(255 90 61 / 8%), transparent 48%),
    var(--color-surface);
  border-radius: var(--radius-lg);
}

.catalogue-kicker {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  gap: .45rem;
  margin-bottom: 1rem;
  padding: .45rem .7rem;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 24%);
  border-radius: 999px;
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.catalogue-kicker svg,
.catalogue-search-submit svg,
.catalogue-add-button svg,
.catalogue-add-added svg,
.catalogue-file-icon svg,
.catalogue-format-icon svg,
.catalogue-file-meta svg {
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.catalogue-kicker svg {
  width: 16px;
  height: 16px;
  stroke-width: 1.8;
}

.catalogue-hero h1 {
  max-width: 10ch;
  margin: 0;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: clamp(3rem, 6vw, 5rem);
  font-weight: 700;
  line-height: .92;
}

.catalogue-hero h1 span {
  color: var(--color-primary);
}

.catalogue-hero-copy p {
  max-width: 60ch;
  margin: 1.1rem 0 0;
  color: var(--color-text-secondary);
  font-size: .9rem;
  line-height: 1.75;
}

.catalogue-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .65rem;
  margin-top: 1.6rem;
}

.catalogue-stat-card {
  min-width: 0;
  padding: .9rem;
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
}

.catalogue-stat-card.is-total-from-paging {
  background:
    linear-gradient(135deg, rgb(255 90 61 / 12%), transparent 64%),
    var(--color-surface-alt);
  border-color: rgb(255 90 61 / 22%);
}

.catalogue-stat-card strong,
.catalogue-stat-card span {
  display: block;
}

.catalogue-stat-card strong {
  color: var(--color-primary);
  font-family: var(--font-display);
  font-size: 1.35rem;
  line-height: 1;
}

.catalogue-stat-card.is-total-from-paging strong {
  display: flex;
  align-items: baseline;
  gap: .35rem;
  font-size: clamp(2rem, 4vw, 2.75rem);
  letter-spacing: .01em;
  text-shadow: 0 10px 24px rgb(255 90 61 / 18%);
}

.catalogue-stat-card.is-total-from-paging strong small {
  color: var(--color-primary);
  font-family: var(--font-mono);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.catalogue-stat-card span {
  margin-top: .35rem;
  color: var(--color-text-secondary);
  font-size: .64rem;
  font-weight: 700;
  text-transform: uppercase;
}

.catalogue-search-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 1.35rem;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.catalogue-search-heading h2 {
  margin: 0;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: 1.55rem;
  font-weight: 700;
}

.catalogue-search-heading p {
  margin: .45rem 0 1.1rem;
  color: var(--color-text-secondary);
  font-size: .76rem;
  line-height: 1.55;
}

.catalogue-search-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .65rem;
  margin-bottom: 1rem;
}

.catalogue-search-input,
.catalogue-search-card .form-select,
.catalogue-size-filter .form-control {
  color: var(--color-text);
  background-color: var(--color-surface-alt);
  border-color: var(--color-border);
  border-radius: var(--radius-sm);
  font-size: .78rem;
  font-weight: 650;
}

.catalogue-search-submit {
  min-width: 108px;
  gap: .45rem;
  font-size: .78rem;
  font-weight: 800;
}

.catalogue-search-submit svg {
  width: 16px;
  height: 16px;
  stroke-width: 1.9;
}

.catalogue-filter-grid {
  display: grid;
  gap: .85rem;
}

.catalogue-filter-field > span {
  display: block;
  margin-bottom: .45rem;
  color: var(--color-text-secondary);
  font-size: .64rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.catalogue-size-filter {
  display: grid;
  grid-template-columns: 1fr 1fr 76px 38px;
  gap: .5rem;
  align-items: center;
}

.catalogue-filter-chip,
.catalogue-size-filter small {
  display: inline-flex;
  min-height: 42px;
  align-items: center;
  justify-content: center;
  color: var(--color-text-secondary);
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: .7rem;
  font-weight: 800;
}

.catalogue-size-filter .btn-check:checked + .catalogue-filter-chip {
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border-color: rgb(255 90 61 / 28%);
}

.catalogue-list-section {
  margin-top: 2rem;
}

.catalogue-section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1.2rem;
  margin-bottom: 1.15rem;
}

.catalogue-section-head h2 {
  margin: 0;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 4vw, 2.4rem);
  font-weight: 700;
}

.catalogue-section-head p {
  margin: .35rem 0 0;
  color: var(--color-text-secondary);
  font-size: .78rem;
}

.catalogue-view-pills {
  display: inline-flex;
  flex: 0 0 auto;
  gap: .35rem;
  padding: .35rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.catalogue-view-pills button,
.catalogue-view-pills span {
  border: 0;
  padding: .55rem .8rem;
  color: var(--color-text-secondary);
  background: transparent;
  border-radius: var(--radius-sm);
  font-size: .68rem;
  font-weight: 800;
  line-height: 1;
  transition: color .18s ease, background .18s ease, box-shadow .18s ease, transform .18s ease;
  cursor: pointer;
}

.catalogue-view-pills button:hover {
  color: var(--color-primary);
  background: rgb(255 90 61 / 9%);
}

.catalogue-view-pills button.active,
.catalogue-view-pills span.active {
  color: #fff;
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));
  box-shadow: 0 10px 24px rgb(255 90 61 / 22%);
}

.catalogue-file-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.catalogue-file-card {
  overflow: hidden;
  border-radius: var(--radius-lg);
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.catalogue-file-card:hover {
  border-color: rgb(255 90 61 / 36%);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.catalogue-file-cover {
  position: relative;
  height: 160px;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgb(255 90 61 / 14%), transparent 54%),
    var(--color-surface-alt);
  border-bottom: 1px solid var(--color-border);
}

.catalogue-file-preview {
  display: flex;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  text-decoration: none;
}

.catalogue-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.catalogue-file-icon {
  display: inline-flex;
  width: 72px;
  height: 72px;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 24%);
  border-radius: 18px;
}

.catalogue-file-icon img {
  max-width: 44px;
  max-height: 44px;
}

.catalogue-file-icon svg {
  width: 38px;
  height: 38px;
  stroke-width: 1.7;
}

.catalogue-format-icon {
  position: relative;
  display: inline-flex;
  width: 78px;
  height: 78px;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  background:
    linear-gradient(135deg, rgb(255 90 61 / 18%), rgb(255 90 61 / 5%)),
    var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 24%);
  border-radius: 20px;
  box-shadow: 0 16px 36px rgb(255 90 61 / 12%);
}

.catalogue-format-icon::before {
  position: absolute;
  inset: -10px;
  content: "";
  border: 1px solid rgb(255 90 61 / 10%);
  border-radius: 26px;
}

.catalogue-format-icon svg {
  width: 42px;
  height: 42px;
  stroke-width: 1.55;
}

.catalogue-format-icon strong {
  position: absolute;
  right: 9px;
  bottom: 8px;
  min-width: 32px;
  padding: .15rem .25rem;
  color: #fff;
  background: var(--color-primary);
  border-radius: 7px;
  font-family: var(--font-mono);
  font-size: .54rem;
  font-weight: 900;
  line-height: 1;
  text-align: center;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.catalogue-format-icon.is-image { color: #2563eb; background: linear-gradient(135deg, rgb(37 99 235 / 14%), rgb(255 90 61 / 5%)), var(--color-surface); }
.catalogue-format-icon.is-image strong { background: #2563eb; }
.catalogue-format-icon.is-archive { color: #d97706; background: linear-gradient(135deg, rgb(217 119 6 / 15%), rgb(255 90 61 / 5%)), var(--color-surface); }
.catalogue-format-icon.is-archive strong { background: #d97706; }
.catalogue-format-icon.is-media { color: var(--color-primary); }
.catalogue-format-icon.is-audio { color: #7c3aed; background: linear-gradient(135deg, rgb(124 58 237 / 14%), rgb(255 90 61 / 5%)), var(--color-surface); }
.catalogue-format-icon.is-audio strong { background: #7c3aed; }
.catalogue-format-icon.is-document { color: #5f6b7a; background: linear-gradient(135deg, rgb(95 107 122 / 13%), rgb(255 90 61 / 5%)), var(--color-surface); }
.catalogue-format-icon.is-document strong { background: #5f6b7a; }
.catalogue-format-icon.is-code { color: #16a34a; background: linear-gradient(135deg, rgb(22 163 74 / 13%), rgb(255 90 61 / 5%)), var(--color-surface); }
.catalogue-format-icon.is-code strong { background: #16a34a; }
.catalogue-format-icon.is-application { color: #ef4444; background: linear-gradient(135deg, rgb(239 68 68 / 13%), rgb(255 90 61 / 5%)), var(--color-surface); }
.catalogue-format-icon.is-application strong { background: #ef4444; }

.catalogue-add-button,
.catalogue-add-added {
  position: absolute;
  top: .75rem;
  right: .75rem;
  display: inline-flex;
  width: 38px;
  height: 38px;
  align-items: center;
  justify-content: center;
  color: var(--color-text);
  background: color-mix(in srgb, var(--color-surface) 88%, transparent);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm);
}

.catalogue-add-button:hover,
.catalogue-add-button:focus-visible {
  color: #fff;
  background: var(--color-primary);
  border-color: var(--color-primary);
}

.catalogue-add-button svg,
.catalogue-add-added svg {
  width: 18px;
  height: 18px;
  stroke-width: 2;
}

.catalogue-add-added {
  color: #fff;
  background: var(--color-success);
  border-color: var(--color-success);
}

.catalogue-file-body {
  padding: .95rem;
}

.catalogue-file-title {
  margin: 0;
  font-size: .82rem;
  line-height: 1.45;
}

.catalogue-file-title a {
  display: -webkit-box;
  min-height: 2.9em;
  overflow: hidden;
  color: var(--color-text);
  font-weight: 800;
  text-decoration: none;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.catalogue-file-title a:hover {
  color: var(--color-primary);
}

.catalogue-file-date {
  margin-top: .55rem;
  color: var(--color-text-secondary);
  font-size: .68rem;
}

.catalogue-file-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  margin-top: .8rem;
}

.catalogue-file-meta span {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  min-height: 28px;
  padding: .25rem .5rem;
  color: var(--color-text-secondary);
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  font-size: .66rem;
  font-weight: 700;
}

.catalogue-file-meta svg {
  width: 13px;
  height: 13px;
  color: var(--color-primary);
  stroke-width: 1.9;
}

.catalogue-file-grid.is-compact {
  grid-template-columns: 1fr;
  gap: .7rem;
}

.catalogue-file-grid.is-compact .catalogue-file-card {
  display: grid;
  grid-template-columns: 112px minmax(0, 1fr);
  align-items: stretch;
  border-radius: var(--radius-md);
}

.catalogue-file-grid.is-compact .catalogue-file-cover {
  height: auto;
  min-height: 112px;
  border-right: 1px solid var(--color-border);
  border-bottom: 0;
}

.catalogue-file-grid.is-compact .catalogue-format-icon {
  width: 58px;
  height: 58px;
  border-radius: 16px;
}

.catalogue-file-grid.is-compact .catalogue-format-icon::before {
  inset: -7px;
  border-radius: 21px;
}

.catalogue-file-grid.is-compact .catalogue-format-icon svg {
  width: 32px;
  height: 32px;
}

.catalogue-file-grid.is-compact .catalogue-format-icon strong {
  right: 6px;
  bottom: 5px;
  min-width: 26px;
  font-size: .46rem;
}

.catalogue-file-grid.is-compact .catalogue-file-body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .35rem 1rem;
  align-content: center;
  padding: .85rem 1rem;
}

.catalogue-file-grid.is-compact .catalogue-file-title {
  grid-column: 1 / -1;
  font-size: .88rem;
}

.catalogue-file-grid.is-compact .catalogue-file-title a {
  min-height: 0;
  -webkit-line-clamp: 1;
}

.catalogue-file-grid.is-compact .catalogue-file-date {
  margin-top: 0;
}

.catalogue-file-grid.is-compact .catalogue-file-meta {
  justify-content: flex-end;
  margin-top: 0;
}

.catalogue-paging {
  display: flex;
  justify-content: center;
  margin-top: 2.25rem;
}

.catalogue-paging .pagination,
.catalogue-paging > * {
  margin-bottom: 0;
}

.catalogue-paging .paging {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  padding: .45rem;
  color: var(--color-text-secondary);
  background: color-mix(in srgb, var(--color-surface) 92%, transparent);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.catalogue-paging a,
.catalogue-paging span {
  display: inline-flex;
  min-width: 34px;
  height: 34px;
  align-items: center;
  justify-content: center;
  padding: 0 .7rem;
  color: var(--color-text-secondary) !important;
  background: var(--color-surface-alt) !important;
  border: 1px solid transparent !important;
  border-radius: var(--radius-sm) !important;
  font-size: .68rem;
  font-weight: 800;
  text-decoration: none !important;
}

.catalogue-paging a:hover {
  color: var(--color-primary) !important;
  background: rgb(255 90 61 / 9%) !important;
  border-color: rgb(255 90 61 / 22%) !important;
}

.catalogue-paging span {
  color: #fff !important;
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover)) !important;
  box-shadow: 0 10px 20px rgb(255 90 61 / 20%);
}

.catalogue-paging small {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 .45rem;
  color: var(--color-text-secondary);
  font-size: .66rem;
}

[data-theme="dark"] .catalogue-page::before {
  background:
    linear-gradient(rgb(245 247 250 / 4.5%) 1px, transparent 1px),
    linear-gradient(90deg, rgb(245 247 250 / 4.5%) 1px, transparent 1px),
    radial-gradient(circle at 82% 0, rgb(255 90 61 / 20%), transparent 24rem),
    radial-gradient(circle at 8% 20%, rgb(255 90 61 / 8%), transparent 24rem);
  background-size: 64px 64px, 64px 64px, auto, auto;
}

@media (max-width: 1199.98px) {
  .catalogue-hero { grid-template-columns: 1fr; }
  .catalogue-file-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 767.98px) {
  .catalogue-page { padding: 1.5rem 0 2.75rem; }
  .catalogue-hero { gap: 1rem; margin-bottom: 1.5rem; }
  .catalogue-hero-copy { min-height: 0; padding: 1.25rem; border-radius: var(--radius-md); }
  .catalogue-hero h1 { max-width: 9ch; font-size: clamp(2.8rem, 15vw, 4rem); }
  .catalogue-hero-copy p { font-size: .78rem; line-height: 1.65; }
  .catalogue-stats { grid-template-columns: 1fr; margin-top: 1rem; }
  .catalogue-search-card { padding: 1rem; border-radius: var(--radius-md); }
  .catalogue-search-row { grid-template-columns: 1fr; }
  .catalogue-search-submit { width: 100%; }
  .catalogue-size-filter { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .catalogue-size-filter .form-control,
  .catalogue-size-filter small { min-height: 42px; }
  .catalogue-section-head { align-items: stretch; flex-direction: column; gap: .8rem; }
  .catalogue-view-pills { width: 100%; }
  .catalogue-view-pills button,
  .catalogue-view-pills span { flex: 1; text-align: center; }
  .catalogue-file-grid { grid-template-columns: 1fr; gap: .75rem; }
  .catalogue-file-card,
  .catalogue-file-grid.is-compact .catalogue-file-card { display: grid; grid-template-columns: 96px minmax(0, 1fr); border-radius: var(--radius-md); }
  .catalogue-file-cover { height: auto; min-height: 132px; border-right: 1px solid var(--color-border); border-bottom: 0; }
  .catalogue-add-button,
  .catalogue-add-added { top: .5rem; right: .5rem; width: 32px; height: 32px; }
  .catalogue-file-icon { width: 54px; height: 54px; border-radius: 15px; }
  .catalogue-file-icon img { max-width: 34px; max-height: 34px; }
  .catalogue-file-icon svg { width: 30px; height: 30px; }
  .catalogue-format-icon { width: 54px; height: 54px; border-radius: 15px; }
  .catalogue-format-icon::before { inset: -7px; border-radius: 21px; }
  .catalogue-format-icon svg { width: 30px; height: 30px; }
  .catalogue-format-icon strong { right: 5px; bottom: 5px; min-width: 25px; font-size: .45rem; }
  .catalogue-file-body { min-width: 0; padding: .85rem; }
  .catalogue-file-grid.is-compact .catalogue-file-body { display: block; padding: .85rem; }
  .catalogue-file-title a { min-height: 0; }
  .catalogue-file-date { font-size: .64rem; }
  .catalogue-paging .paging { width: 100%; }
}

[dir="rtl"] .mobile-menu-row,
[dir="rtl"] .mobile-account-row {
  grid-template-columns: minmax(0, 1fr) 40px;
  padding-right: .5rem;
  padding-left: .75rem;
  text-align: right;
}

[dir="rtl"] .mobile-menu-row .mobile-menu-icon,
[dir="rtl"] .mobile-account-row .mobile-menu-icon {
  grid-column: 2;
  grid-row: 1;
}

[dir="rtl"] .mobile-menu-row::before {
  right: 0;
  left: auto;
  border-radius: 999px 0 0 999px;
}

[dir="rtl"] .mobile-menu-control.dropdown-toggle::after {
  right: auto;
  left: 1rem;
}

.home-hero {
  position: relative;
  overflow: hidden;
  overflow: clip;
  isolation: isolate;
}

.home-hero::before {
  position: absolute;
  z-index: -1;
  top: 0;
  right: -10%;
  width: 60%;
  height: 100%;
  content: "";
  background-image:
    linear-gradient(rgb(255 90 61 / 6%) 1px, transparent 1px),
    linear-gradient(90deg, rgb(255 90 61 / 6%) 1px, transparent 1px);
  background-size: 32px 32px;
  mask-image: radial-gradient(circle, #000, transparent 72%);
}

.hero-kicker {
  padding: .5rem .75rem;
  color: var(--color-text);
  background: var(--color-surface);
  border: 1px solid rgb(255 90 61 / 28%);
  border-radius: 999px;
  font-size: .75rem;
  font-weight: 700;
}

.hero-kicker svg,
.button-icon {
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.hero-kicker svg {
  color: var(--color-primary);
}

.hero-title {
  max-width: 12ch;
  color: var(--color-text);
  font-size: clamp(2.35rem, 5vw, 4.75rem);
  font-weight: 800;
  letter-spacing: -.055em;
  line-height: 1.02;
  overflow-wrap: break-word;
  font-family: var(--font-display);
}

.hero-title span,
.section-heading h2 span {
  color: var(--color-primary);
}

.hero-description {
  max-width: 620px;
  color: var(--color-text-secondary);
  font-size: clamp(1rem, 1.4vw, 1.125rem);
  line-height: 1.75;
}

.hero-trust span {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  color: var(--color-text-secondary);
  font-size: .75rem;
}

.hero-trust svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
}

.hero-visual {
  position: relative;
  min-height: 480px;
  overflow: hidden;
  overflow: clip;
}

.file-app {
  position: absolute;
  top: 1rem;
  right: 0;
  width: 88%;
  min-height: 380px;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}

.file-app::after {
  position: absolute;
  right: -20%;
  bottom: -45%;
  width: 70%;
  aspect-ratio: 1;
  content: "";
  background: radial-gradient(circle, rgb(255 90 61 / 13%), transparent 68%);
}

.app-dot {
  width: 8px;
  height: 8px;
  background: var(--color-primary);
  border-radius: 50%;
}

.app-search,
.app-action,
.app-sidebar,
.app-heading,
.app-file {
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: 6px;
}

.app-search {
  max-width: 240px;
  height: 32px;
}

.app-action {
  width: 82px;
  height: 32px;
  background: var(--color-primary);
  border-color: var(--color-primary);
}

.app-sidebar {
  height: 28px;
  margin-bottom: .75rem;
  border-color: transparent;
}

.app-sidebar.active {
  background: var(--color-primary-soft);
}

.app-heading {
  width: 30%;
  height: 16px;
  border: 0;
}

.app-folder {
  position: relative;
  width: 68px;
  height: 48px;
  margin: 0 auto;
  background: linear-gradient(135deg, var(--color-primary-hover), var(--color-primary));
  border-radius: 5px;
  box-shadow: 0 8px 18px rgb(255 90 61 / 18%);
}

.app-folder::before {
  position: absolute;
  top: -7px;
  left: 0;
  width: 32px;
  height: 12px;
  content: "";
  background: var(--color-primary-hover);
  border-radius: 4px 4px 0 0;
}

.app-file {
  height: 78px;
}

.upload-status {
  position: absolute;
  right: 6%;
  bottom: 1rem;
  z-index: 2;
  width: 58%;
  border-color: rgb(255 90 61 / 55%);
  box-shadow: var(--shadow-lg), 0 0 32px rgb(255 90 61 / 12%);
}

.upload-status-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  flex: 0 0 auto;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border-radius: var(--radius-sm);
}

.upload-status-icon svg {
  width: 28px;
  height: 28px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.7;
}

.upload-status span {
  color: var(--color-text-secondary);
}

.upload-status strong,
.stat-item strong,
.stat-item span,
.feature-card h3,
.feature-card p,
.process-card h3,
.process-card p,
.section-heading h2,
.section-heading p {
  overflow-wrap: anywhere;
}

.progress {
  height: 7px;
  background: var(--color-surface-alt);
}

.progress-bar {
  background: linear-gradient(90deg, var(--color-primary), var(--color-primary-hover));
}

.demo-progress {
  width: 24%;
}

.hero-orbit {
  position: absolute;
  border: 1px solid rgb(255 90 61 / 20%);
  border-radius: 50%;
}

.hero-orbit-one {
  top: 0;
  right: -10%;
  width: 380px;
  height: 380px;
}

.hero-orbit-two {
  top: 5%;
  right: -2%;
  width: 280px;
  height: 280px;
}

.stats-panel {
  overflow: hidden;
}

.stat-item {
  min-height: 64px;
  padding-inline: 1rem;
}

.home-stats .col-lg-3 + .col-lg-3 .stat-item {
  border-left: 1px solid var(--color-border);
}

.stat-item svg {
  width: 42px;
  height: 42px;
  flex: 0 0 auto;
  fill: none;
  stroke: var(--color-primary);
  stroke-width: 1.7;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.stat-item strong,
.stat-item span {
  display: block;
}

.stat-item strong {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2.3vw, 2rem);
  line-height: 1.1;
}

.stat-item span {
  margin-top: .25rem;
  color: var(--color-text-secondary);
  font-size: .75rem;
}

.home-section {
  scroll-margin-top: 72px;
}

.section-heading {
  max-width: 760px;
}

.section-heading h2 {
  color: var(--color-text);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 800;
  letter-spacing: -.035em;
  font-family: var(--font-display);
}

.section-heading p,
.feature-card p,
.process-card p {
  color: var(--color-text-secondary);
}

.feature-card:hover,
.process-card:hover {
  border-color: rgb(255 90 61 / 45%);
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}

.feature-card svg {
  width: 44px;
  height: 44px;
  flex: 0 0 auto;
  fill: none;
  stroke: var(--color-primary);
  stroke-width: 1.7;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.feature-card h3,
.process-card h3 {
  color: var(--color-text);
  font-size: 1rem;
  font-weight: 750;
  font-family: var(--font-display);
}

.feature-card p,
.process-card p {
  font-size: .8125rem;
  line-height: 1.65;
}

.process-card {
  position: relative;
  overflow: hidden;
}

.process-card svg {
  display: block;
  width: 48px;
  height: 48px;
  margin: 0 auto 1rem;
  fill: none;
  stroke: var(--color-text-secondary);
  stroke-width: 1.6;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.process-number {
  position: absolute;
  top: 1rem;
  left: 1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border-radius: 50%;
  font-weight: 800;
}

.cta-panel {
  position: relative;
  overflow: hidden;
  color: #fff;
  background:
    linear-gradient(115deg, rgb(255 255 255 / 8%) 25%, transparent 25%) 0 0 / 24px 24px,
    linear-gradient(100deg, var(--color-primary-deep), var(--color-primary));
  border-radius: var(--radius-lg);
  box-shadow: 0 20px 48px rgb(255 90 61 / 22%);
}

.cta-panel::after {
  position: absolute;
  right: -8%;
  bottom: -80%;
  width: 420px;
  aspect-ratio: 1;
  content: "";
  border: 1px solid rgb(255 255 255 / 18%);
  border-radius: 50%;
}

.cta-panel .row {
  position: relative;
  z-index: 1;
}

.cta-panel h2 {
  font-size: clamp(1.5rem, 3vw, 2.35rem);
  font-weight: 800;
  letter-spacing: -.03em;
  font-family: var(--font-display);
}

.cta-panel p {
  color: rgb(255 255 255 / 82%);
}

.cta-rocket {
  align-items: center;
  justify-content: center;
  width: 88px;
  height: 88px;
  flex: 0 0 auto;
  background: rgb(255 255 255 / 12%);
  border: 1px solid rgb(255 255 255 / 24%);
  border-radius: 50%;
}

.cta-rocket svg {
  width: 48px;
  height: 48px;
  fill: none;
  stroke: #fff;
  stroke-width: 1.6;
}

.site-footer {
  color: var(--color-text-secondary);
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  font-size: .8125rem;
}

.footer-copy {
  max-width: 440px;
  line-height: 1.7;
}

.footer-heading {
  color: var(--color-text);
  font-size: .875rem;
  font-weight: 800;
  font-family: var(--font-display);
}

.site-footer .nav-link {
  padding: .3rem 0;
  color: var(--color-text-secondary);
}

.site-footer .nav-link:hover {
  color: var(--color-primary);
}

.social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  color: var(--color-text-secondary);
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: 50%;
  font-size: .75rem;
  font-weight: 800;
  text-decoration: none;
}

.social-link:hover {
  color: #fff;
  background: var(--color-primary);
  border-color: var(--color-primary);
}

.social-link img {
  width: 18px;
  height: 18px;
  opacity: .75;
}

.social-link:hover img {
  filter: brightness(0) invert(1);
  opacity: 1;
}

.footer-newsletter,
.footer-bottom {
  border-top: 1px solid var(--color-border);
}

.footer-newsletter .btn svg {
  width: 20px;
  height: 20px;
  fill: currentColor;
}

.page-buffer {
  display: none;
}

.registration-page {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  overflow: clip;
  background:
    linear-gradient(rgb(255 90 61 / 4%) 1px, transparent 1px),
    linear-gradient(90deg, rgb(255 90 61 / 4%) 1px, transparent 1px);
  background-size: 48px 48px;
}

.registration-page::before {
  position: absolute;
  z-index: -1;
  top: -12rem;
  right: -10rem;
  width: 36rem;
  height: 36rem;
  background: radial-gradient(circle, rgb(255 90 61 / 13%), transparent 68%);
  border-radius: 50%;
  content: "";
  pointer-events: none;
}

.registration-intro {
  position: sticky;
  top: 104px;
  overflow: hidden;
  color: var(--color-text);
  background:
    radial-gradient(circle at 90% 10%, rgb(255 90 61 / 18%), transparent 11rem),
    var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
}

.registration-intro::after {
  position: absolute;
  right: -5rem;
  bottom: -6rem;
  width: 17rem;
  height: 17rem;
  border: 1px solid rgb(255 90 61 / 25%);
  border-radius: 50%;
  content: "";
}

.registration-kicker {
  position: relative;
  z-index: 1;
  padding: .5rem .75rem;
  color: var(--color-primary-deep);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 28%);
  border-radius: 999px;
  font-size: .75rem;
  font-weight: 750;
}

.registration-kicker svg {
  width: 17px;
  height: 17px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.registration-intro-title,
.registration-card-header h2 {
  position: relative;
  z-index: 1;
  color: var(--color-text);
  font-family: var(--font-display);
  font-weight: 700;
}

.registration-intro-title {
  max-width: 12ch;
  font-size: clamp(2.35rem, 5vw, 4rem);
  line-height: .98;
}

.registration-intro-copy,
.registration-card-header p,
.registration-benefit p,
.registration-login-link,
.registration-form .form-text {
  color: var(--color-text-secondary);
}

.registration-intro-copy {
  position: relative;
  z-index: 1;
  max-width: 42ch;
  line-height: 1.7;
}

.registration-benefits {
  position: relative;
  z-index: 1;
}

.registration-benefit {
  padding: 1rem;
  background: color-mix(in srgb, var(--color-surface-alt) 72%, transparent);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.registration-benefit-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 24%);
  border-radius: var(--radius-sm);
}

.registration-benefit-icon svg {
  width: 23px;
  height: 23px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.registration-benefit h2 {
  color: var(--color-text);
  font-size: .875rem;
  font-weight: 750;
}

.registration-benefit p {
  font-size: .75rem;
  line-height: 1.55;
}

.registration-card {
  overflow: hidden;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
}

.registration-card-header h2 {
  font-size: clamp(1.8rem, 4vw, 2.5rem);
}

.registration-card-header p {
  line-height: 1.65;
}

.registration-section-title {
  color: var(--color-text-secondary);
  font-size: .75rem;
  font-weight: 800;
  letter-spacing: .09em;
  text-transform: uppercase;
}

.registration-form .form-control,
.registration-form .form-select {
  min-height: 58px;
  color: var(--color-text);
  background-color: var(--color-surface);
  border-color: var(--color-border);
  border-radius: var(--radius-sm);
}

.registration-form .form-control:focus,
.registration-form .form-select:focus {
  color: var(--color-text);
  background-color: var(--color-surface);
  border-color: var(--color-primary);
  box-shadow: 0 0 0 .25rem rgb(255 90 61 / 15%);
}

.registration-form .form-floating > label {
  color: var(--color-text-secondary);
}

.registration-section-optional {
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.registration-optional-badge {
  padding: .25rem .5rem;
  color: var(--color-primary-deep);
  background: var(--color-primary-soft);
  border-radius: 999px;
  font-size: .65rem;
  font-weight: 750;
  text-transform: uppercase;
}

.registration-captcha {
  overflow-x: auto;
  padding: 1rem;
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.registration-submit {
  min-height: 52px;
}

.registration-divider {
  display: flex;
  align-items: center;
  gap: .75rem;
  color: var(--color-text-secondary);
  font-size: .75rem;
}

.registration-divider::before,
.registration-divider::after {
  flex: 1;
  height: 1px;
  background: var(--color-border);
  content: "";
}

.registration-social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: 50%;
}

.registration-social-link:hover {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 .2rem rgb(255 90 61 / 12%);
  transform: translateY(-2px);
}

.registration-social-link img {
  width: 20px;
  height: 20px;
}

.registration-login-link {
  font-size: .875rem;
}

.registration-login-link a {
  color: var(--color-primary);
  font-weight: 750;
}

.registration-trust {
  color: var(--color-text-secondary);
  font-size: .75rem;
  font-weight: 700;
}

.registration-trust span {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}

.registration-trust span::before {
  width: 8px;
  height: 8px;
  background: var(--color-success);
  border-radius: 50%;
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--color-success) 14%, transparent);
  content: "";
}

[data-theme="dark"] .registration-page {
  background:
    linear-gradient(rgb(255 255 255 / 2%) 1px, transparent 1px),
    linear-gradient(90deg, rgb(255 255 255 / 2%) 1px, transparent 1px);
  background-size: 48px 48px;
}

[data-theme="dark"] .registration-kicker,
[data-theme="dark"] .registration-optional-badge {
  color: var(--color-primary-hover);
}

[data-theme="dark"] .registration-social-link img {
  filter: brightness(0) invert(1);
  opacity: .8;
}

.login-page {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  overflow: clip;
  background:
    linear-gradient(rgb(255 90 61 / 4%) 1px, transparent 1px),
    linear-gradient(90deg, rgb(255 90 61 / 4%) 1px, transparent 1px);
  background-size: 48px 48px;
}

.login-page::before,
.login-page::after {
  position: absolute;
  z-index: -1;
  width: 30rem;
  height: 30rem;
  border-radius: 50%;
  content: "";
  pointer-events: none;
}

.login-page::before {
  top: -16rem;
  right: -10rem;
  background: radial-gradient(circle, rgb(255 90 61 / 13%), transparent 68%);
}

.login-page::after {
  bottom: -20rem;
  left: -16rem;
  border: 1px solid rgb(255 90 61 / 18%);
  box-shadow: 0 0 0 4rem rgb(255 90 61 / 2%), 0 0 0 8rem rgb(255 90 61 / 2%);
}

.login-intro {
  color: var(--color-text);
}

.login-kicker {
  padding: .5rem .75rem;
  color: var(--color-primary-deep);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 28%);
  border-radius: 999px;
  font-size: .75rem;
  font-weight: 750;
}

.login-kicker svg,
.login-benefit-icon svg,
.login-form .alert svg {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.login-kicker svg {
  width: 17px;
  height: 17px;
}

.login-intro-title,
.login-card-header h2 {
  color: var(--color-text);
  font-family: var(--font-display);
  font-weight: 700;
}

.login-intro-title {
  font-size: clamp(3rem, 6vw, 5rem);
  line-height: .95;
}

.login-intro-title span {
  color: var(--color-primary);
}

.login-intro-copy,
.login-card-header p,
.login-benefit p,
.login-register-link {
  color: var(--color-text-secondary);
}

.login-intro-copy {
  max-width: 42ch;
  font-size: 1rem;
  line-height: 1.7;
}

.login-visual {
  position: relative;
  min-height: 230px;
}

.login-visual-window {
  position: absolute;
  top: 0;
  left: 0;
  width: 76%;
  min-height: 205px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.login-visual-window > .d-flex i {
  width: 7px;
  height: 7px;
  background: var(--color-border);
  border-radius: 50%;
}

.login-visual-window > .d-flex i:first-child {
  background: var(--color-primary);
}

.login-visual-content {
  min-height: 145px;
  background:
    linear-gradient(rgb(255 90 61 / 5%) 1px, transparent 1px),
    linear-gradient(90deg, rgb(255 90 61 / 5%) 1px, transparent 1px),
    var(--color-surface-alt);
  background-size: 24px 24px;
  border: 1px dashed rgb(255 90 61 / 32%);
  border-radius: var(--radius-md);
}

.login-visual-content svg {
  width: 68px;
  height: 68px;
  fill: none;
  stroke: var(--color-primary);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.login-visual-files {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 48%;
  min-height: 150px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
}

.login-visual-files span {
  color: var(--color-text);
  font-size: .75rem;
  font-weight: 750;
}

.login-visual-files i {
  display: block;
  height: 12px;
  margin-bottom: 1rem;
  background: linear-gradient(90deg, var(--color-primary) 0 16%, var(--color-surface-alt) 16% 100%);
  border-radius: 999px;
}

.login-benefits {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.login-benefit {
  min-width: 0;
}

.login-benefit-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 22%);
  border-radius: var(--radius-sm);
}

.login-benefit-icon svg {
  width: 23px;
  height: 23px;
}

.login-benefit h2 {
  color: var(--color-text);
  font-size: .8rem;
  font-weight: 750;
}

.login-benefit p {
  font-size: .7rem;
  line-height: 1.5;
}

.login-card {
  max-width: 600px;
  overflow: hidden;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
}

.login-card-header h2 {
  font-size: clamp(1.8rem, 4vw, 2.5rem);
}

.login-card-header p {
  line-height: 1.65;
}

.login-form .form-control {
  min-height: 58px;
  color: var(--color-text);
  background: var(--color-surface);
  border-color: var(--color-border);
  border-radius: var(--radius-sm);
}

.login-form .form-control:focus {
  color: var(--color-text);
  background: var(--color-surface);
  border-color: var(--color-primary);
  box-shadow: 0 0 0 .25rem rgb(255 90 61 / 15%);
}

.login-form .form-floating > label {
  color: var(--color-text-secondary);
}

.login-form .alert {
  color: var(--color-error);
  background: color-mix(in srgb, var(--color-error) 8%, var(--color-surface));
  border-color: color-mix(in srgb, var(--color-error) 35%, var(--color-border));
  border-radius: var(--radius-md);
}

.login-form .alert svg {
  width: 22px;
  height: 22px;
}

.login-captcha {
  max-width: 100%;
  overflow-x: auto;
  padding: 1rem;
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.login-captcha:empty {
  display: none;
}

.login-forgot-link {
  color: var(--color-primary);
  font-size: .8rem;
  font-weight: 700;
  text-decoration: none;
}

.login-forgot-link:hover {
  color: var(--color-primary-hover);
}

.login-submit {
  min-height: 52px;
}

.login-divider {
  display: flex;
  align-items: center;
  gap: .75rem;
  color: var(--color-text-secondary);
  font-size: .75rem;
}

.login-divider::before,
.login-divider::after {
  flex: 1;
  height: 1px;
  background: var(--color-border);
  content: "";
}

.login-social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: 50%;
}

.login-social-link:hover {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 .2rem rgb(255 90 61 / 12%);
  transform: translateY(-2px);
}

.login-social-link img {
  width: 20px;
  height: 20px;
}

.login-register-link {
  font-size: .875rem;
}

.login-register-link a {
  color: var(--color-primary);
  font-weight: 750;
}

.login-trust {
  display: none;
  color: var(--color-text-secondary);
  font-size: .75rem;
  font-weight: 700;
}

.login-trust span {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}

.login-trust span::before {
  width: 8px;
  height: 8px;
  background: var(--color-primary);
  border-radius: 50%;
  box-shadow: 0 0 0 4px rgb(255 90 61 / 12%);
  content: "";
}

[data-theme="dark"] .login-page {
  background:
    linear-gradient(rgb(255 255 255 / 2%) 1px, transparent 1px),
    linear-gradient(90deg, rgb(255 255 255 / 2%) 1px, transparent 1px);
  background-size: 48px 48px;
}

[data-theme="dark"] .login-kicker {
  color: var(--color-primary-hover);
}

[data-theme="dark"] .login-social-link img {
  filter: brightness(0) invert(1);
  opacity: .82;
}

.money-page {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  overflow: clip;
  background: linear-gradient(rgb(255 90 61 / 4%) 1px, transparent 1px), linear-gradient(90deg, rgb(255 90 61 / 4%) 1px, transparent 1px);
  background-size: 48px 48px;
}

.money-page::before {
  position: absolute;
  z-index: -1;
  top: -14rem;
  right: -10rem;
  width: 38rem;
  height: 38rem;
  background: radial-gradient(circle, rgb(255 90 61 / 13%), transparent 68%);
  border-radius: 50%;
  content: "";
}

.money-kicker {
  padding: .5rem .75rem;
  color: var(--color-primary-deep);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 28%);
  border-radius: 999px;
  font-size: .75rem;
  font-weight: 750;
}

.money-kicker svg,
.money-icon svg {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.money-kicker svg { width: 17px; height: 17px; }

.money-title {
  max-width: 12ch;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: clamp(3rem, 6vw, 5rem);
  font-weight: 700;
  line-height: .95;
}

.money-title span { color: var(--color-primary); }
.money-lead { max-width: 52ch; color: var(--color-text-secondary); line-height: 1.7; }

.money-dashboard,
.money-summary,
.money-step,
.money-mode,
.money-tier,
.money-rule {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}

.money-dashboard { border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); }
.money-dashboard-label { color: var(--color-text-secondary); font-size: .75rem; font-weight: 700; }
.money-live { color: var(--color-success); font-size: .7rem; font-weight: 750; }
.money-live::before { display: inline-block; width: 7px; height: 7px; margin-right: .4rem; background: currentColor; border-radius: 50%; content: ""; }
.money-dashboard-total { color: var(--color-text); font-size: clamp(2.2rem, 5vw, 3.5rem); line-height: 1; }
.money-dashboard-change { color: var(--color-success); font-size: .75rem; font-weight: 750; }
.money-chart { height: 120px; border-bottom: 1px solid var(--color-border); }
.money-chart i { flex: 1; max-width: 42px; background: var(--color-primary-soft); border-radius: 8px 8px 0 0; }
.money-chart i:last-child { background: var(--color-primary); }
.money-dashboard-stats > div + div { border-left: 1px solid var(--color-border); }
.money-dashboard-stats strong { display: block; color: var(--color-text); font-size: 1.3rem; }
.money-dashboard-stats span { display: block; color: var(--color-text-secondary); font-size: .7rem; }

.money-summary strong,
.money-summary small { display: block; }
.money-summary strong { color: var(--color-text); font-size: .85rem; }
.money-summary small { color: var(--color-text-secondary); font-size: .7rem; }
.money-icon { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; color: var(--color-primary); background: var(--color-primary-soft); border-radius: 50%; }
.money-icon svg { width: 22px; height: 22px; }

.money-section-header > span { color: var(--color-primary); font-size: .7rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.money-section-header h2 { margin: .5rem 0 0; color: var(--color-text); font-family: var(--font-display); font-size: clamp(1.7rem, 4vw, 2.5rem); font-weight: 700; }
.money-section-header p { margin: .5rem 0 0; color: var(--color-text-secondary); font-size: .85rem; }

.money-step { position: relative; min-height: 150px; }
.money-step-number { position: absolute; top: 1rem; right: 1rem; display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; color: var(--color-primary); background: var(--color-primary-soft); border-radius: 50%; font-weight: 800; }
.money-step h3,
.money-mode h3,
.money-rule h3 { color: var(--color-text); font-size: 1rem; font-weight: 750; }
.money-step p,
.money-mode p,
.money-tier p,
.money-rule p,
.money-cta p { margin-bottom: 0; color: var(--color-text-secondary); font-size: .78rem; line-height: 1.6; }
.money-step h3 { max-width: calc(100% - 48px); margin-top: 1.6rem; }

.money-mode { position: relative; overflow: hidden; }
.money-mode.popular { border-color: var(--color-primary); box-shadow: 0 12px 30px rgb(255 90 61 / 10%); }
.money-popular { position: absolute; top: 0; right: 0; padding: .45rem .75rem; color: #fff; background: var(--color-primary); border-radius: 0 0 0 var(--radius-sm); font-size: .65rem; font-weight: 750; }
.money-mode > small { display: inline-block; margin-bottom: 1rem; padding: .25rem .5rem; color: var(--color-primary-deep); background: var(--color-primary-soft); border-radius: 999px; font-weight: 800; }
.money-mode strong { display: block; margin-bottom: .75rem; color: var(--color-primary); font-size: 2.4rem; line-height: 1; }

.money-table-wrap { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); box-shadow: var(--shadow-sm); }
.money-table-wrap .table { min-width: 760px; --bs-table-bg: transparent; --bs-table-color: var(--color-text); --bs-table-border-color: var(--color-border); }
.money-table-wrap th { color: var(--color-text-secondary); font-size: .7rem; white-space: nowrap; }
.money-table-wrap td { color: var(--color-text); font-size: .8rem; font-weight: 750; }
.money-table-wrap th,
.money-table-wrap td { padding: 1rem; }
.tier-dot { display: inline-block; width: 8px; height: 8px; margin-right: .5rem; border-radius: 50%; }
.tier-one { background: #22c55e; }.tier-two { background: #2563eb; }.tier-three { background: #7c3aed; }.tier-four { background: #9ca3af; }
.money-scroll-hint { display: none; color: var(--color-text-secondary); font-size: .7rem; }
.money-tier strong { color: var(--color-text); font-size: .8rem; }
.money-tier p { margin-top: 1rem; }
.tier-card-one { background: color-mix(in srgb, #22c55e 7%, var(--color-surface)); }
.tier-card-two { background: color-mix(in srgb, #2563eb 7%, var(--color-surface)); }
.tier-card-three { background: color-mix(in srgb, #7c3aed 7%, var(--color-surface)); }
.tier-card-four { background: color-mix(in srgb, #9ca3af 7%, var(--color-surface)); }

.money-rule { position: relative; padding-top: 3.5rem !important; }
.money-rule::before { position: absolute; top: 1rem; left: 1.5rem; width: 28px; height: 28px; background: var(--color-primary-soft); border: 1px solid rgb(255 90 61 / 20%); border-radius: 50%; content: ""; }

.money-cta { overflow: hidden; background: linear-gradient(115deg, var(--color-primary-soft), var(--color-surface)); border: 1px solid rgb(255 90 61 / 28%); border-radius: var(--radius-xl); }
.money-cta h2 { color: var(--color-text); font-family: var(--font-display); font-weight: 700; }

[data-theme="dark"] .money-page { background: linear-gradient(rgb(255 255 255 / 2%) 1px, transparent 1px), linear-gradient(90deg, rgb(255 255 255 / 2%) 1px, transparent 1px); background-size: 48px 48px; }
[data-theme="dark"] .money-kicker,
[data-theme="dark"] .money-mode > small { color: var(--color-primary-hover); }

.premium-page {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  overflow: clip;
  background: linear-gradient(rgb(255 90 61 / 4%) 1px, transparent 1px), linear-gradient(90deg, rgb(255 90 61 / 4%) 1px, transparent 1px);
  background-size: 48px 48px;
}

.premium-page::before {
  position: absolute;
  z-index: -1;
  top: -16rem;
  right: -12rem;
  width: 42rem;
  height: 42rem;
  background: radial-gradient(circle, rgb(255 90 61 / 13%), transparent 68%);
  border-radius: 50%;
  content: "";
}

.premium-kicker {
  padding: .5rem .75rem;
  color: var(--color-primary-deep);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 28%);
  border-radius: 999px;
  font-size: .75rem;
  font-weight: 750;
  text-transform: uppercase;
}

.premium-kicker svg,
.premium-expiry svg {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.premium-kicker svg { width: 17px; height: 17px; }
.premium-title { color: var(--color-text); font-family: var(--font-display); font-size: clamp(3rem, 6vw, 5rem); font-weight: 700; line-height: .95; }
.premium-title span { color: var(--color-primary); }
.premium-lead { max-width: 60ch; color: var(--color-text-secondary); line-height: 1.7; }

.premium-summary {
  max-width: 780px;
  overflow: hidden;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.premium-summary > div { padding: 1.25rem; }
.premium-summary > div + div { border-left: 1px solid var(--color-border); }
.premium-summary strong,
.premium-summary span { display: block; }
.premium-summary strong { color: var(--color-primary); font-size: 1.25rem; }
.premium-summary span { color: var(--color-text-secondary); font-size: .68rem; text-transform: uppercase; }

.premium-expiry { color: var(--color-primary-deep); background: color-mix(in srgb, var(--color-primary) 8%, var(--color-surface)); border-color: rgb(255 90 61 / 25%); border-radius: var(--radius-md); }
.premium-expiry svg { width: 26px; height: 26px; }

.premium-section-heading > span { color: var(--color-primary); font-size: .7rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.premium-section-heading h2 { margin: .5rem 0 0; color: var(--color-text); font-family: var(--font-display); font-size: clamp(1.8rem, 4vw, 2.6rem); font-weight: 700; }
.premium-section-heading p { margin: .5rem 0 0; color: var(--color-text-secondary); font-size: .82rem; }

.premium-tabs-scroll { overflow-x: auto; scrollbar-width: thin; }
.premium-tabs { width: min(100%, 720px); padding: .35rem; background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: var(--radius-md); }
.premium-tabs .nav-link { display: inline-flex; flex: 1 1 0; align-items: center; justify-content: center; min-width: 0; min-height: 52px; padding: .75rem 1.25rem; color: var(--color-text-secondary); border-radius: var(--radius-sm); font-size: .78rem; font-weight: 700; line-height: 1.2; text-align: center; white-space: nowrap; }
.premium-tabs .nav-link.active { color: #fff; background: var(--color-primary); box-shadow: 0 6px 18px rgb(255 90 61 / 20%); }

.premium-plan-card { position: relative; display: flex; flex-direction: column; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); }
.premium-plan-card:hover { border-color: var(--color-primary); box-shadow: var(--shadow-md); transform: translateY(-3px); }
.premium-best-value-badge { position: absolute; top: 0; right: 1.25rem; z-index: 2; display: none; align-items: center; min-height: 26px; padding: .25rem .7rem; color: #fff; background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover)); border-radius: 0 0 var(--radius-sm) var(--radius-sm); box-shadow: 0 6px 18px rgb(255 90 61 / 24%); font-size: .62rem; font-weight: 800; letter-spacing: .06em; line-height: 1; text-transform: uppercase; white-space: nowrap; }
#premium .premium-plan-days-120,
#premium_pro .premium-plan-days-365,
#Prem_traffic .premium-traffic-value-25 { border-color: var(--color-primary); background: linear-gradient(180deg, color-mix(in srgb, var(--color-primary) 7%, var(--color-surface)), var(--color-surface) 42%); box-shadow: 0 14px 34px rgb(255 90 61 / 16%); }
#premium .premium-plan-days-120 .premium-best-value-badge,
#premium_pro .premium-plan-days-365 .premium-best-value-badge,
#Prem_traffic .premium-traffic-value-25 .premium-best-value-badge { display: inline-flex; }
#premium .premium-plan-days-120 .premium-plan-duration,
#premium_pro .premium-plan-days-365 .premium-plan-duration,
#Prem_traffic .premium-traffic-value-25 .premium-plan-duration { padding-right: 5.5rem; }
.premium-plan-duration { color: var(--color-primary); font-size: .72rem; font-weight: 800; text-transform: uppercase; }
.premium-plan-price { color: var(--color-text); font-size: clamp(2rem, 4vw, 3rem); font-weight: 800; line-height: 1; }
.premium-plan-features { flex: 1; padding-top: 1rem; border-top: 1px solid var(--color-border); }
.premium-plan-features li { position: relative; padding: .35rem 0 .35rem 1.4rem; color: var(--color-text-secondary); font-size: .72rem; line-height: 1.45; }
.premium-plan-features li::before { position: absolute; top: .4rem; left: 0; color: var(--color-success); font-weight: 900; content: "\2713"; }
.premium-traffic-note { color: var(--color-text-secondary); font-size: .72rem; }

.premium-trust { color: var(--color-text-secondary); font-size: .72rem; font-weight: 700; }
.premium-trust span { display: inline-flex; align-items: center; gap: .5rem; }
.premium-trust span::before { width: 8px; height: 8px; background: var(--color-primary); border-radius: 50%; box-shadow: 0 0 0 4px rgb(255 90 61 / 12%); content: ""; }

.premium-payment-modal { --bs-modal-width: 860px; }
.premium-payment-modal .modal-content { overflow: hidden; color: var(--color-text); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); box-shadow: 0 24px 80px rgb(18 20 23 / 24%); }
.premium-payment-modal .modal-header { min-height: 92px; padding: 1.25rem 1.5rem; border-color: var(--color-border); }
.premium-payment-heading-icon { display: inline-flex; flex: 0 0 46px; align-items: center; justify-content: center; width: 46px; height: 46px; color: #fff; background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover)); border-radius: var(--radius-sm); box-shadow: 0 8px 22px rgb(255 90 61 / 24%); }
.premium-payment-heading-icon svg { width: 24px; height: 24px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.premium-payment-heading .modal-title { margin: 0 0 .35rem; color: var(--color-text); font-family: var(--font-display); font-size: 1.2rem; font-weight: 700; line-height: 1.2; }
.premium-payment-package { display: inline-flex; align-items: center; min-height: 24px; padding: .2rem .65rem; color: var(--color-primary-deep); background: var(--color-primary-soft); border: 1px solid rgb(255 90 61 / 22%); border-radius: 999px; font-size: .68rem; font-weight: 800; text-transform: uppercase; }
.premium-payment-modal .btn-close { flex: 0 0 auto; margin: 0; }
.premium-payment-assurance { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); padding: .85rem 1.5rem; background: var(--color-surface-alt); border-bottom: 1px solid var(--color-border); }
.premium-payment-assurance span { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; min-width: 0; color: var(--color-text-secondary); font-size: .68rem; font-weight: 700; text-align: center; }
.premium-payment-assurance span + span { border-left: 1px solid var(--color-border); }
.premium-payment-assurance svg { width: 17px; height: 17px; fill: none; stroke: var(--color-primary); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.premium-payment-modal .modal-body { padding: 1.5rem; }
.premium-payment-intro h3 { margin: 0 0 .4rem; color: var(--color-text); font-family: var(--font-display); font-size: 1rem; font-weight: 700; }
.premium-payment-intro p { margin: 0; color: var(--color-text-secondary); font-size: .75rem; }
.premium-payment-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; }
.premium-payment-option { position: relative; display: grid; grid-template-columns: 52px minmax(0, 1fr) 22px; align-items: center; gap: .75rem; min-width: 0; min-height: 98px; padding: 1rem; color: var(--color-text); background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: var(--radius-md); box-shadow: var(--shadow-sm); text-align: left; transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease; }
.premium-payment-option:hover,
.premium-payment-option:focus-visible { color: var(--color-text); border-color: var(--color-primary); box-shadow: 0 10px 26px rgb(255 90 61 / 14%); outline: 0; transform: translateY(-2px); }
.premium-payment-option .paysys { display: flex; align-items: center; justify-content: center; width: 52px; height: 52px; padding: .4rem; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-sm); }
.premium-payment-option img { width: auto; max-width: 100%; height: auto; max-height: 34px; object-fit: contain; }
.premium-payment-details { display: flex; min-width: 0; flex-direction: column; gap: .3rem; }
.premium-payment-details strong { overflow: hidden; color: var(--color-text); font-size: .76rem; font-weight: 800; text-overflow: ellipsis; white-space: nowrap; }
.premium-payment-details small { overflow: hidden; color: var(--color-text-secondary); font-size: .62rem; text-overflow: ellipsis; white-space: nowrap; }
.premium-payment-arrow { display: inline-flex; align-items: center; justify-content: center; width: 22px; height: 22px; color: var(--color-text-secondary); }
.premium-payment-arrow svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.premium-payment-option:hover .premium-payment-arrow { color: var(--color-primary); }
.premium-payment-popular { position: absolute; top: -1px; right: .75rem; display: none; padding: .25rem .55rem; color: #fff; background: var(--color-primary); border-radius: 0 0 var(--radius-xs) var(--radius-xs); font-size: .55rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; }
.premium-payment-option.payment-method-paypal { border-color: color-mix(in srgb, var(--color-primary) 50%, var(--color-border)); background: linear-gradient(135deg, color-mix(in srgb, var(--color-primary) 7%, var(--color-surface)), var(--color-surface-alt)); }
.premium-payment-option.payment-method-paypal .premium-payment-popular { display: inline-flex; }
.premium-payment-footer { justify-content: center; gap: .5rem; padding: .9rem 1.5rem; color: var(--color-text-secondary); background: var(--color-surface-alt); border-color: var(--color-border); font-size: .68rem; text-align: center; }
.premium-payment-footer svg { width: 18px; height: 18px; fill: none; stroke: var(--color-success); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }

.premium-comparison-scroll { max-width: 100%; overflow-x: auto; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); -webkit-overflow-scrolling: touch; overscroll-behavior-inline: contain; }
.premium-page .premiumTable { width: max-content; min-width: 0; overflow: visible; margin: 0; color: var(--color-text); background: transparent; border: 0; border-radius: 0; box-shadow: none; }
.premium-page .premiumTable .row { flex-wrap: nowrap; }
.premium-page .premiumTable .col { flex: 0 0 145px; width: 145px; min-width: 145px; max-width: 145px; padding: 1rem .75rem; color: var(--color-text-secondary); background: transparent; border-color: var(--color-border); font-size: .72rem; }
.premium-page .premiumTable .col:first-child { flex-basis: 220px; width: 220px; min-width: 220px; max-width: 220px; color: var(--color-text-secondary); }
.premium-page .premiumTable .premium-feature-cell { display: flex; align-items: center; text-align: left; }
.premium-feature-label { display: flex; align-items: center; gap: .75rem; width: 100%; min-width: 0; color: var(--color-text-secondary); font-weight: 600; line-height: 1.35; }
.premiumTable-heading .premium-feature-label { color: var(--color-text); }
.premium-feature-icon { display: inline-flex; flex: 0 0 34px; align-items: center; justify-content: center; width: 34px; height: 34px; color: var(--color-primary); background: color-mix(in srgb, var(--color-primary) 10%, var(--color-surface)); border: 1px solid color-mix(in srgb, var(--color-primary) 24%, var(--color-border)); border-radius: var(--radius-sm); }
.premium-page .premiumTable .premium-feature-icon svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.premium-page .premiumTable .col.premium { background: color-mix(in srgb, var(--color-primary) 6%, var(--color-surface)); }
.premium-page .premiumTable .row > .col:nth-child(4) { position: relative; background: color-mix(in srgb, var(--color-primary) 12%, var(--color-surface)); box-shadow: inset 1px 0 var(--color-primary), inset -1px 0 var(--color-primary); }
.premium-page .premiumTable .premiumTable-heading .col { color: var(--color-text); background: var(--color-surface-alt); }
.premium-page .premiumTable .premiumTable-heading .col.premium { color: var(--color-primary); background: color-mix(in srgb, var(--color-primary) 10%, var(--color-surface)); }
.premium-page .premiumTable .premiumTable-heading .col:nth-child(4) { padding-top: 2.15rem; background: color-mix(in srgb, var(--color-primary) 18%, var(--color-surface)); }
.premium-comparison-badge { top: 0; right: 50%; display: inline-flex; border-radius: 0 0 var(--radius-sm) var(--radius-sm); transform: translateX(50%); }
.premium-page .premiumTable svg { width: 19px; height: 19px; }

@media (min-width: 992px) {
  .premium-page .premiumTable {
    width: 100%;
    min-width: 0;
  }

  .premium-page .premiumTable .col {
    flex: 1 1 0;
    width: auto;
    min-width: 0;
    max-width: none;
  }

  .premium-page .premiumTable .col:first-child {
    flex: 1.5 1 0;
    width: auto;
    min-width: 0;
    max-width: none;
  }
}

[data-theme="dark"] .premium-page { background: linear-gradient(rgb(255 255 255 / 2%) 1px, transparent 1px), linear-gradient(90deg, rgb(255 255 255 / 2%) 1px, transparent 1px); background-size: 48px 48px; }
[data-theme="dark"] .premium-kicker,
[data-theme="dark"] .premium-expiry { color: var(--color-primary-hover); }
[data-theme="dark"] .premium-payment-modal .btn-close { filter: invert(1) grayscale(100%); }
[data-theme="dark"] .premium-payment-modal .modal-content { box-shadow: 0 28px 90px rgb(0 0 0 / 58%), 0 0 32px rgb(255 90 61 / 8%); }
[data-theme="dark"] .premium-payment-package { color: var(--color-primary-hover); }

@media (max-width: 1199.98px) {
  .hero-visual {
    min-height: 430px;
  }

  .file-app {
    width: 94%;
    min-height: 350px;
  }

  .upload-status {
    width: 68%;
  }
}

@media (max-width: 991.98px) {
  .premium-payment-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .site-header .navbar {
    min-height: 68px;
  }

  .money-title {
    max-width: 14ch;
  }

  .money-dashboard {
    max-width: 620px;
    margin-inline: auto;
  }

  .login-intro {
    text-align: center;
  }

  .login-intro-copy {
    max-width: 52ch;
    margin-inline: auto;
  }

  .login-visual {
    max-width: 620px;
    margin-inline: auto;
  }

  .login-benefits {
    max-width: 720px;
    margin-inline: auto;
    text-align: left;
  }

  .registration-intro {
    position: relative;
    top: auto;
  }

  .registration-intro-title {
    max-width: 18ch;
  }

  .registration-benefits {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .registration-benefit {
    display: block !important;
  }

  .registration-benefit-icon {
    margin-bottom: .75rem;
  }

  .home-hero::before {
    right: -20%;
    width: 100%;
  }

  .hero-title {
    max-width: 15ch;
  }

  .hero-visual {
    min-height: 460px;
  }

  .file-app {
    right: 4%;
    width: 92%;
  }

  .upload-status {
    right: 9%;
    width: 58%;
  }

  .home-stats .col-lg-3 + .col-lg-3 .stat-item {
    border-left: 0;
  }

  .home-stats .col-6:nth-child(even) .stat-item {
    border-left: 1px solid var(--color-border);
  }
}

@media (max-width: 767.98px) {
  .site-logo {
    font-size: 1.25rem;
  }

  .premium-page {
    background-size: 32px 32px;
  }

  .premium-summary > div:nth-child(3) {
    border-left: 0;
  }

  .premium-summary > div:nth-child(n+3) {
    border-top: 1px solid var(--color-border);
  }

  .premium-plan-card:hover {
    transform: none;
  }

  .money-page {
    background-size: 32px 32px;
  }

  .money-hero {
    text-align: center;
  }

  .money-title,
  .money-lead {
    max-width: none;
  }

  .money-chart {
    height: 100px;
  }

  .money-scroll-hint {
    display: block;
  }

  .login-page {
    background-size: 32px 32px;
  }

  .login-intro {
    padding-bottom: 0 !important;
  }

  .login-intro-title {
    font-size: clamp(2.6rem, 13vw, 4rem);
  }

  .login-intro-copy {
    font-size: .875rem;
  }

  .login-visual,
  .login-benefits {
    display: none !important;
  }

  .login-trust {
    display: flex;
  }

  .registration-page {
    background-size: 32px 32px;
  }

  .registration-intro {
    text-align: center;
  }

  .registration-intro-title,
  .registration-intro-copy {
    max-width: none;
  }

  .registration-benefits {
    grid-template-columns: 1fr;
    text-align: left;
  }

  .registration-benefit {
    display: flex !important;
  }

  .registration-benefit-icon {
    margin-bottom: 0;
  }

  .site-logo-mark {
    width: 34px;
    height: 34px;
  }

  .hero-visual {
    min-height: 390px;
  }

  .file-app {
    right: 2%;
    width: 96%;
    min-height: 310px;
  }

  .upload-status {
    right: 5%;
    width: 76%;
  }

  .app-file {
    height: 64px;
  }

  .stat-item {
    padding-inline: .5rem;
  }

  .stat-item svg {
    width: 34px;
    height: 34px;
  }
}

@media (max-width: 575.98px) {
  .premium-payment-modal .modal-dialog {
    margin: .75rem;
  }

  .premium-payment-modal .modal-header {
    min-height: 80px;
    padding: 1rem;
  }

  .premium-payment-heading {
    gap: .75rem !important;
  }

  .premium-payment-heading-icon {
    flex-basis: 40px;
    width: 40px;
    height: 40px;
  }

  .premium-payment-heading .modal-title {
    font-size: 1rem;
  }

  .premium-payment-assurance {
    grid-template-columns: 1fr;
    gap: .65rem;
    padding: .85rem 1rem;
  }

  .premium-payment-assurance span {
    justify-content: flex-start;
    text-align: left;
  }

  .premium-payment-assurance span + span {
    padding-top: .65rem;
    border-top: 1px solid var(--color-border);
    border-left: 0;
  }

  .premium-payment-modal .modal-body {
    padding: 1rem;
  }

  .premium-page > .container {
    padding-inline: 1rem;
  }

  .premium-title {
    font-size: clamp(2.6rem, 13vw, 4rem);
  }

  .premium-summary,
  .premium-plan-card,
  .premium-comparison-scroll {
    border-radius: var(--radius-md);
  }

  .premium-summary > div {
    padding: 1rem .5rem;
  }

  .premium-summary strong {
    font-size: 1.05rem;
  }

  .premium-feature-label {
    gap: .5rem;
    font-size: .68rem;
  }

  .premium-feature-icon {
    flex-basis: 30px;
    width: 30px;
    height: 30px;
  }

  .premium-page .premiumTable .premium-feature-icon svg {
    width: 16px;
    height: 16px;
  }

  .premium-tabs-scroll {
    margin-inline: -1rem;
    padding-inline: 1rem;
  }

  .premium-tabs {
    width: max-content;
    min-width: 100%;
  }

  .premium-tabs .nav-link {
    flex: 0 0 190px;
    min-width: 190px;
    min-height: 48px;
    padding-inline: 1rem;
  }

  .premium-plan-card {
    display: grid;
    grid-template-columns: minmax(110px, .75fr) minmax(0, 1.25fr);
    column-gap: 1rem;
  }

  .premium-plan-card .premium-plan-duration,
  .premium-plan-card .premium-plan-price,
  .premium-plan-card .premium-traffic-note,
  .premium-plan-card .btn {
    grid-column: 1;
  }

  .premium-plan-card .premium-plan-features {
    grid-column: 2;
    grid-row: 1 / span 4;
    padding-top: 0;
    padding-left: 1rem;
    border-top: 0;
    border-left: 1px solid var(--color-border);
  }

  .premium-plan-card .btn {
    align-self: end;
  }

  .premium-traffic-card {
    display: flex;
  }

  .premium-traffic-card .premium-plan-features {
    padding-top: 1rem;
    padding-left: 0;
    border-top: 1px solid var(--color-border);
    border-left: 0;
  }

  .premium-payment-grid {
    grid-template-columns: 1fr;
  }

  .premium-comparison-scroll {
    margin-inline: 0;
    padding-inline: 0;
  }

  .money-page > .container {
    padding-inline: 1rem;
  }

  .money-title {
    font-size: clamp(2.6rem, 13vw, 4rem);
  }

  .money-dashboard,
  .money-cta {
    border-radius: var(--radius-lg);
  }

  .money-dashboard-stats strong {
    font-size: 1.05rem;
  }

  .money-summary {
    min-height: 78px;
  }

  .money-step {
    min-height: 130px;
  }

  .money-mode strong {
    font-size: 2rem;
  }

  .money-table-wrap {
    margin-inline: -.25rem;
  }

  .money-cta {
    text-align: center;
  }

  .money-cta .btn {
    width: 100%;
  }

  .login-page > .container {
    padding-inline: 1rem;
  }

  .login-card {
    border-radius: var(--radius-lg);
  }

  .login-card-header {
    text-align: center;
  }

  .login-captcha {
    padding: .75rem;
  }

  .login-trust {
    font-size: .65rem;
  }

  .login-trust span {
    display: grid;
    justify-items: center;
    gap: .5rem;
  }

  .registration-page > .container {
    padding-inline: 1rem;
  }

  .registration-intro,
  .registration-card {
    border-radius: var(--radius-lg);
  }

  .registration-intro-title {
    font-size: clamp(2.15rem, 12vw, 3rem);
  }

  .registration-intro-copy {
    font-size: .875rem;
  }

  .registration-card-header {
    text-align: center;
  }

  .registration-section-optional {
    padding: 1rem !important;
  }

  .registration-trust {
    font-size: .65rem;
  }

  .registration-trust span {
    display: grid;
    justify-items: center;
    gap: .5rem;
  }

  .hero-title {
    max-width: none;
    font-size: clamp(2.2rem, 11vw, 3.25rem);
  }

  .hero-description {
    line-height: 1.65;
  }

  .hero-visual {
    min-height: 335px;
  }

  .file-app {
    top: 0;
    right: 0;
    width: 100%;
    min-height: 270px;
  }

  .upload-status {
    right: 4%;
    bottom: 0;
    width: 88%;
  }

  .app-folder {
    width: 50px;
    height: 38px;
  }

  .app-file {
    height: 50px;
  }

  .stat-item {
    align-items: flex-start !important;
    min-height: 76px;
  }

  .stat-item strong {
    font-size: 1.15rem;
  }

  .stat-item span {
    font-size: .675rem;
  }

  .feature-card .card-body {
    padding: 1rem !important;
  }

  .feature-card svg {
    width: 38px;
    height: 38px;
  }

  .cta-panel {
    text-align: center;
  }
}

@media (max-width: 389.98px) {
  .site-logo {
    font-size: 1.1rem;
  }

  .site-logo-mark {
    width: 30px;
    height: 30px;
  }

  .hero-trust {
    display: grid !important;
    gap: .75rem !important;
  }

  .hero-visual {
    min-height: 310px;
  }

  .upload-status {
    width: 94%;
    right: 3%;
  }

  .upload-status-icon {
    width: 40px;
    height: 40px;
  }

  .stat-item {
    display: block !important;
    text-align: center;
  }

  .stat-item svg {
    margin-bottom: .5rem;
  }
}

/* Upload workflow */
.upload-page { color: var(--color-text); background: linear-gradient(rgb(255 90 61 / 4%) 1px, transparent 1px), linear-gradient(90deg, rgb(255 90 61 / 4%) 1px, transparent 1px); background-size: 48px 48px; }
.upload-page-heading { max-width: 720px; margin-inline: auto; }
.upload-page-kicker { display: inline-flex; margin-bottom: .75rem; padding: .4rem .7rem; color: var(--color-primary-deep); background: var(--color-primary-soft); border: 1px solid rgb(255 90 61 / 24%); border-radius: 999px; font-size: .68rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.upload-page-heading h1 { margin: 0; color: var(--color-text); font-family: var(--font-display); font-size: clamp(2rem, 5vw, 3.4rem); font-weight: 700; }
.upload-page-heading p { margin: .75rem 0 0; color: var(--color-text-secondary); font-size: .82rem; }
.upload-page .upload-form { width: 100%; max-width: 1040px; }
.upload-workspace { overflow: hidden; color: var(--color-text); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); }
.upload-tabs-scroll { overflow-x: auto; background: var(--color-surface-alt); border-bottom: 1px solid var(--color-border); scrollbar-width: thin; }
.upload-page .upload-method-tabs { width: 100%; min-width: max-content; border: 0; }
.upload-page .upload-method-tabs .nav-link { display: inline-flex; flex: 1 0 176px; align-items: center; justify-content: center; gap: .55rem; min-height: 64px; padding: .75rem 1rem; color: var(--color-text-secondary); border-bottom: 3px solid transparent; font-size: .72rem; font-weight: 700; text-align: center; white-space: nowrap; }
.upload-page .upload-method-tabs .nav-link:hover { color: var(--color-primary); }
.upload-page .upload-method-tabs .nav-link.active { color: var(--color-primary); background: color-mix(in srgb, var(--color-primary) 7%, transparent); border-color: var(--color-primary); }
.upload-tab-icon { display: inline-flex; align-items: center; justify-content: center; min-width: 22px; height: 22px; color: currentColor; font-size: .72rem; font-weight: 900; }
.upload-steps { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); max-width: 660px; margin-inline: auto; }
.upload-steps span { position: relative; display: flex; align-items: center; justify-content: center; gap: .45rem; color: var(--color-text-secondary); font-size: .66rem; font-weight: 700; }
.upload-steps span::after { position: absolute; top: 50%; left: calc(50% + 32px); width: calc(100% - 64px); height: 1px; background: var(--color-border); content: ""; }
.upload-steps span:last-child::after { display: none; }
.upload-steps b { display: inline-flex; z-index: 1; align-items: center; justify-content: center; width: 28px; height: 28px; color: var(--color-text-secondary); background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: 50%; }
.upload-steps .active { color: var(--color-primary); }
.upload-steps .active b { color: #fff; background: var(--color-primary); border-color: var(--color-primary); box-shadow: 0 0 0 4px rgb(255 90 61 / 12%); }
.upload-steps .completed { color: var(--color-success); }
.upload-steps .completed b { color: #fff; background: var(--color-success); border-color: var(--color-success); }
.upload-steps .completed::after { background: var(--color-success); }
.upload-page .upload-dropzone { display: flex; min-height: 250px; flex-direction: column; align-items: center; justify-content: center; margin-bottom: 1.5rem; padding: 2rem; color: var(--color-text-secondary); background: color-mix(in srgb, var(--color-primary) 2%, var(--color-surface)); border: 2px dashed color-mix(in srgb, var(--color-primary) 35%, var(--color-border)); border-radius: var(--radius-md); }
.upload-page .upload-dropzone:hover,
.upload-page .upload-dropzone.active { color: var(--color-text); background: color-mix(in srgb, var(--color-primary) 7%, var(--color-surface)); border-color: var(--color-primary); }
.upload-dropzone-icon { display: inline-flex; align-items: center; justify-content: center; width: 64px; height: 64px; color: var(--color-primary); background: var(--color-primary-soft); border-radius: 50%; box-shadow: 0 0 0 8px rgb(255 90 61 / 7%); }
.upload-dropzone-icon svg { width: 32px; height: 32px; }
.upload-dropzone-icon path,
.upload-page .uploadItem-icon path { fill: currentColor !important; }
.upload-dropzone strong { color: var(--color-text); font-family: var(--font-display); font-size: 1rem; }
.upload-dropzone-copy { margin: .45rem 0; font-size: .72rem; }
.upload-choose-button { min-width: 160px; margin-bottom: .55rem; pointer-events: none; }
.upload-dropzone small { font-size: .65rem; }
.upload-page .uploadItem { margin-bottom: .7rem; padding: .75rem; color: var(--color-text); background: color-mix(in srgb, var(--color-surface-alt) 72%, var(--color-surface)); border: 1px solid var(--color-border); border-radius: var(--radius-md); box-shadow: var(--shadow-sm); }
.upload-item-head { display: grid; grid-template-columns: 36px minmax(0, 1fr) 36px; align-items: center; gap: .7rem; min-width: 0; }
.upload-item-icon-wrap { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; color: var(--color-primary); background: var(--color-primary-soft); border: 1px solid rgb(255 90 61 / 18%); border-radius: 10px; }
.upload-page .uploadItem-icon { width: 16px; height: 18px; color: inherit; }
.upload-item-meta { display: flex; min-width: 0; align-items: center; gap: .55rem; }
.upload-item-name { min-width: 0; overflow: hidden; color: var(--color-text); font-size: .76rem; font-weight: 650; line-height: 1.35; text-overflow: ellipsis; white-space: nowrap; }
.upload-item-size { flex: 0 0 auto; padding: .24rem .48rem; color: var(--color-text-secondary); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: 999px; font-size: .56rem; line-height: 1; white-space: nowrap; }
.upload-item-remove { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; color: var(--color-text-secondary); border: 1px solid transparent; border-radius: var(--radius-sm); }
.upload-item-remove:hover,
.upload-item-remove:focus-visible { color: var(--color-error); background: color-mix(in srgb, var(--color-error) 8%, var(--color-surface)); border-color: color-mix(in srgb, var(--color-error) 25%, var(--color-border)); }
.upload-item-config { display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: center; gap: .7rem; margin-top: .65rem; padding-left: 2.9rem; }
.upload-description-control { position: relative; min-width: 0; }
.upload-description-control .form-control { min-height: 40px; padding-left: 2.15rem; font-size: .68rem; }
.upload-description-icon { position: absolute; z-index: 1; top: 50%; left: .75rem; display: inline-flex; color: var(--color-text-secondary); pointer-events: none; transform: translateY(-50%); }
.upload-item-progress { padding: .7rem 0 0 2.9rem; }
.upload-page .uploadItem .form-control,
.upload-page .uploadItem .form-select { color: var(--color-text); background-color: var(--color-surface); border-color: var(--color-border); }
.upload-page .form-switcher { display: flex; align-items: center; }
.upload-public-control { min-width: 0; }
.upload-toggle-input,
.upload-consent-input { position: absolute; width: 1px; height: 1px; overflow: hidden; opacity: 0; pointer-events: none; }
.upload-toggle-label { display: flex; align-items: center; gap: .55rem; min-height: 40px; margin: 0; padding: .35rem .55rem; color: var(--color-text); background: transparent; border: 1px solid transparent; border-radius: var(--radius-sm); cursor: pointer; transition: border-color .2s ease, background-color .2s ease, box-shadow .2s ease; }
.upload-toggle-label:hover { border-color: color-mix(in srgb, var(--color-primary) 45%, var(--color-border)); }
.upload-toggle-track { position: relative; display: inline-flex; flex: 0 0 auto; width: 42px; height: 24px; padding: 3px; background: var(--color-border); border-radius: 999px; transition: background-color .2s ease; }
.upload-toggle-track span { width: 18px; height: 18px; background: var(--color-surface); border-radius: 50%; box-shadow: 0 1px 3px rgb(18 20 23 / 22%); transition: transform .2s ease; }
.upload-toggle-copy { display: grid; max-width: 150px; gap: .05rem; line-height: 1.15; }
.upload-toggle-copy strong { color: var(--color-text); font-size: .72rem; font-weight: 700; }
.upload-toggle-copy small { overflow: hidden; color: var(--color-text-secondary); font-size: .52rem; text-overflow: ellipsis; white-space: nowrap; }
.upload-toggle-input:checked + .upload-toggle-label { background: color-mix(in srgb, var(--color-primary) 5%, transparent); border-color: color-mix(in srgb, var(--color-primary) 24%, transparent); }
.upload-toggle-input:checked + .upload-toggle-label .upload-toggle-track { background: var(--color-primary); }
.upload-toggle-input:checked + .upload-toggle-label .upload-toggle-track span { transform: translateX(18px); }
.upload-toggle-input:focus-visible + .upload-toggle-label,
.upload-consent-input:focus-visible + .upload-consent-label { outline: 3px solid rgb(255 90 61 / 20%); outline-offset: 2px; }
.upload-consent { display: flex; justify-content: flex-start; }
.upload-consent-label { display: inline-flex; align-items: center; gap: .7rem; min-height: 48px; margin: 0; padding: .65rem .85rem; color: var(--color-text); background: color-mix(in srgb, var(--color-primary) 4%, var(--color-surface-alt)); border: 1px solid var(--color-border); border-radius: var(--radius-sm); cursor: pointer; font-size: .7rem; line-height: 1.45; transition: border-color .2s ease, background-color .2s ease; }
.upload-consent-check { position: relative; display: inline-flex; flex: 0 0 auto; align-items: center; justify-content: center; width: 21px; height: 21px; color: #fff; background: var(--color-surface); border: 1.5px solid color-mix(in srgb, var(--color-text-secondary) 45%, var(--color-border)); border-radius: 6px; }
.upload-consent-input:checked + .upload-consent-label { background: color-mix(in srgb, var(--color-primary) 7%, var(--color-surface)); border-color: color-mix(in srgb, var(--color-primary) 42%, var(--color-border)); }
.upload-consent-input:checked + .upload-consent-label .upload-consent-check { background: var(--color-primary); border-color: var(--color-primary); box-shadow: 0 0 0 4px rgb(255 90 61 / 9%); }
.upload-consent-input:checked + .upload-consent-label .upload-consent-check::after { width: 9px; height: 5px; border-bottom: 2px solid currentColor; border-left: 2px solid currentColor; content: ""; transform: translateY(-1px) rotate(-45deg); }
.upload-results-header { display: flex; align-items: center; gap: .75rem; margin-bottom: 1rem; }
.upload-results-icon { display: inline-flex; flex: 0 0 auto; align-items: center; justify-content: center; width: 42px; height: 42px; color: var(--color-primary); background: var(--color-primary-soft); border: 1px solid rgb(255 90 61 / 18%); border-radius: 12px; }
.upload-results-icon svg { width: 20px; height: 20px; }
.upload-results-copy { display: grid; min-width: 0; gap: .15rem; line-height: 1.25; }
.upload-results-copy strong { overflow: hidden; color: var(--color-text); font-family: var(--font-display); font-size: .85rem; font-weight: 700; text-overflow: ellipsis; white-space: nowrap; }
.upload-results-copy small { color: var(--color-text-secondary); font-size: .6rem; }
.upload-page .alert { padding: .85rem 1rem; border-radius: var(--radius-sm); font-size: .7rem; line-height: 1.5; }
.upload-page .progress { height: 12px; overflow: hidden; background: var(--color-border); border-radius: 999px; }
.upload-page .progress-bar { min-width: 2.5rem; background: linear-gradient(90deg, var(--color-primary), var(--color-primary-hover)); border-radius: 999px; font-size: .58rem; }
.upload-actions { margin-top: 1.5rem; }
.upload-actions .btn,
.upload-page .submit-btn { min-height: 48px; min-width: 150px; }
.upload-page .block-tabs:not(.upload-method-tabs) { display: flex; overflow-x: auto; flex-wrap: nowrap; border-bottom: 1px solid var(--color-border); scrollbar-width: thin; }
.upload-page .block-tabs:not(.upload-method-tabs) .nav-link { flex: 0 0 auto; min-height: 48px; padding: .75rem 1rem; color: var(--color-text-secondary); border-bottom: 2px solid transparent; font-size: .68rem; white-space: nowrap; }
.upload-page .block-tabs:not(.upload-method-tabs) .nav-link.active { color: var(--color-primary); border-color: var(--color-primary); }
.upload-page .codes-textarea { position: relative; padding: 1rem; }
.upload-page .codes-textarea textarea { min-height: 112px; padding-right: 4rem; color: var(--color-text); background: var(--color-surface); border-color: var(--color-border); border-radius: var(--radius-sm); font-size: .7rem; }
.upload-page .codes-textarea .icon-btn { position: absolute; top: 50%; right: 1.75rem; color: var(--color-primary); transform: translateY(-50%); }
.upload-page .servinfo { display: inline-flex; padding: .65rem 1rem; color: var(--color-text-secondary) !important; background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: 999px; }
.upload-page .modal-content { color: var(--color-text); background: var(--color-surface); border-color: var(--color-border); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }
.upload-page .modal-header,
.upload-page .modal-footer { border-color: var(--color-border); }
.upload-page .modal-title { color: var(--color-text); font-family: var(--font-display); font-weight: 700; }
.upload-results-heading { color: var(--color-text); font-family: var(--font-display); font-size: clamp(1.7rem, 4vw, 2.4rem); }
.upload-results-page .table { color: var(--color-text); background: var(--color-surface); border-color: var(--color-border); }
.upload-results-page .upload-results-card { overflow: hidden; }
[data-theme="dark"] .upload-page { background: linear-gradient(rgb(255 255 255 / 2%) 1px, transparent 1px), linear-gradient(90deg, rgb(255 255 255 / 2%) 1px, transparent 1px); background-size: 48px 48px; }
[data-theme="dark"] .upload-page .btn-close { filter: invert(1) grayscale(1); }

@media (max-width: 767.98px) {
  .upload-page { background-size: 32px 32px; }
  .upload-page .container { padding-inline: 1rem; }
  .upload-page .upload-method-tabs .nav-link { flex-basis: 158px; min-height: 56px; }
  .upload-workspace-body { padding: 1rem !important; }
  .upload-steps span { flex-direction: column; gap: .3rem; font-size: .58rem; }
  .upload-steps span::after { top: 14px; left: calc(50% + 20px); width: calc(100% - 40px); }
  .upload-page .upload-dropzone { min-height: 210px; padding: 1.5rem 1rem; }
  .upload-page .uploadItem { margin-bottom: .6rem; padding: .7rem; }
  .upload-item-head { grid-template-columns: 32px minmax(0, 1fr) 36px; gap: .55rem; }
  .upload-item-icon-wrap { width: 32px; height: 32px; border-radius: 9px; }
  .upload-item-meta { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: .25rem .4rem; }
  .upload-item-name { grid-column: 1 / -1; font-size: .64rem; }
  .upload-item-size { justify-self: start; padding: .2rem .4rem; font-size: .5rem; }
  .upload-item-config { grid-template-columns: minmax(0, 1fr) auto; gap: .35rem; margin-top: .55rem; padding-left: 0; }
  .upload-description-control .form-control { min-height: 38px; padding-right: .5rem; font-size: .6rem; }
  .upload-toggle-label { min-height: 38px; padding-inline: .35rem; }
  .upload-toggle-copy { display: none; }
  .upload-toggle-track { width: 38px; height: 22px; }
  .upload-toggle-track span { width: 16px; height: 16px; }
  .upload-toggle-input:checked + .upload-toggle-label .upload-toggle-track span { transform: translateX(16px); }
  .upload-item-progress { padding: .6rem 0 0; }
  .upload-consent-label { width: 100%; align-items: flex-start; }
  .upload-results-icon { width: 38px; height: 38px; border-radius: 10px; }
  .upload-results-copy strong { font-size: .78rem; }
  .upload-actions { flex-direction: column-reverse; }
  .upload-actions .btn,
  .upload-page .submit-btn { width: 100%; margin: 0 !important; }
  .upload-page .modal-dialog { align-items: flex-end; min-height: calc(100% - 1rem); margin: .5rem; }
  .upload-page .modal-content { max-height: 88vh; border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
  .upload-page .servinfo { border-radius: var(--radius-sm); line-height: 1.6; }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    transition-duration: .01ms !important;
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
  }
}

/* Account control panel navigation */
.navpanel {
  width: 280px;
  padding: 1.15rem 1rem;
  color: var(--color-text);
  background:
    radial-gradient(circle at 0 0, rgb(255 90 61 / 8%), transparent 26rem),
    linear-gradient(180deg, var(--color-surface), var(--color-background));
  border-right: 1px solid var(--color-border);
  box-shadow: 8px 0 30px rgb(18 20 23 / 5%);
}

.navpanel-brand-wrap {
  margin: -.15rem -1rem 1rem;
  padding: .95rem 1rem 1.15rem;
  border-bottom: 1px solid var(--color-border);
}

.navpanel-brand {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .02em;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;
}

.navpanel-brand:hover { color: var(--color-text); }
.navpanel-brand > span:last-child span { color: var(--color-primary); }
.navpanel-brand-mark { display: inline-flex; align-items: center; justify-content: center; width: 34px; height: 34px; color: var(--color-primary); background: transparent; border: 1.5px solid currentColor; border-radius: 10px; box-shadow: none; }
.navpanel-brand-mark svg { width: 22px; height: 22px; fill: currentColor; }

.navpanel-account {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr) auto;
  align-items: center;
  gap: .65rem;
  margin: .2rem 0 1.15rem;
  padding: .75rem;
  background:
    linear-gradient(135deg, rgb(255 90 61 / 8%), transparent 38%),
    var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}

.navpanel-avatar { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; overflow: hidden; color: #fff; background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover)); border-radius: 11px; }
.navpanel-avatar svg { width: 21px; height: 21px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.navpanel-account-copy { display: grid; min-width: 0; gap: .15rem; }
.navpanel-account-copy strong { overflow: hidden; color: var(--color-text); font-size: .86rem; font-weight: 700; text-overflow: ellipsis; white-space: nowrap; }
.navpanel-account-copy small { color: var(--color-success); font-family: var(--font-display); font-size: .7rem; }
.navpanel-account-meta { padding: .28rem .5rem; color: var(--color-text); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: 999px; font-family: var(--font-display); font-size: .68rem; }

.navpanel-section-label { margin: 0 .2rem .4rem; color: var(--color-text-secondary); font-family: var(--font-display); font-size: .7rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; }
.navpanel-section-label-inline { margin-top: .85rem; padding-top: .85rem; border-top: 1px solid var(--color-border); }
.navpanel-menu { margin: 0 0 1rem; }
.navpanel-user-menu { gap: .9rem; }
.navpanel-menu-group { display: grid; gap: .12rem; }
.navpanel-menu .nav-item { margin-bottom: .2rem; }
.navpanel-menu .nav-link {
  display: flex;
  min-height: 38px;
  align-items: center;
  gap: .58rem;
  padding: .35rem .62rem;
  color: var(--color-text-secondary);
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  font-family: var(--font-display);
  font-size: .8rem;
  font-weight: 650;
  letter-spacing: .01em;
}
.navpanel-menu .nav-link > span:last-child { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.navpanel-menu .nav-link:hover { color: var(--color-text); background: color-mix(in srgb, var(--color-surface-alt) 88%, transparent); border-color: rgb(255 90 61 / 14%); }
.navpanel-menu .nav-link.active { color: var(--color-text); background: linear-gradient(90deg, rgb(255 90 61 / 28%), rgb(255 90 61 / 10%)); border-color: rgb(255 90 61 / 24%); box-shadow: inset 3px 0 var(--color-primary); }
.navpanel-menu .nav-link.active .navpanel-icon { color: var(--color-primary); }
.navpanel-menu .nav-link.active svg path { fill: currentColor; }
.navpanel-icon { display: inline-flex; flex: 0 0 26px; width: 26px; min-width: 26px; height: 26px; align-items: center; justify-content: center; color: currentColor; background: transparent; border: 0; border-radius: 0; }
.navpanel-icon svg { width: 18px; height: 18px; }
.navpanel-user-menu .navpanel-icon svg,
.navpanel-user-menu .navpanel-icon svg path,
.navpanel-user-menu .nav-link.active svg path {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.navpanel-menu .nav-link.has-submenu { padding-right: 2.4rem; }
.navpanel-menu .nav-link.has-submenu::after { right: .8rem; width: 12px; height: 12px; margin-top: -6px; background-image: none; border-right: 1.5px solid currentColor; border-bottom: 1.5px solid currentColor; transform: rotate(45deg); }
.navpanel-menu .nav-link.has-submenu.active::after { transform: rotate(225deg); }
.navpanel-submenu { margin: .2rem 0 .4rem 1.15rem; padding: .15rem 0 .15rem .85rem; background: transparent; border-left: 1px solid var(--color-border); box-shadow: none; }
.navpanel-submenu .nav-link { min-height: 38px; padding: .3rem .5rem .3rem 1rem; color: var(--color-text-secondary); font-size: .8rem; }
.navpanel-submenu .nav-link::before { left: .15rem; width: 5px; height: 5px; margin-top: -2px; background: var(--color-border); }
.navpanel-submenu .nav-link:hover,
.navpanel-submenu .nav-link.text-white { color: var(--color-primary) !important; background: transparent; border-color: transparent; }

.navpanel-footer { display: grid; grid-template-columns: 64px minmax(0, 1fr); gap: .55rem; margin-top: auto; padding-top: .85rem; border-top: 1px solid var(--color-border); }
.navpanel-footer-action { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; min-height: 46px; padding: .45rem .7rem; color: var(--color-primary); background: transparent; border: 1px solid var(--color-border); border-radius: var(--radius-sm); font-family: var(--font-display); font-size: .8rem; font-weight: 700; text-decoration: none; }
.navpanel-footer-action:hover { color: var(--color-primary-hover); border-color: rgb(255 90 61 / 32%); background: var(--color-primary-soft); }
.navpanel-theme-button { display: inline-flex; align-items: center; justify-content: center; width: 64px; height: 46px; padding: 0; color: var(--color-text); background: transparent; border: 1px solid var(--color-border); border-radius: var(--radius-sm); }
.navpanel-theme-button:hover,
.navpanel-theme-button:focus-visible { color: var(--color-primary); background: var(--color-primary-soft); border-color: rgb(255 90 61 / 20%); }
.navpanel-footer-icon { display: inline-flex; }
.navpanel-footer-icon svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.navpanel-logout:hover { color: var(--color-error); }
.navpanel-close { top: .85rem; right: .85rem; z-index: 2; display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; padding: 0; color: var(--color-text); background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: var(--radius-sm); background-image: none; }
.navpanel-close svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; }

@media (min-width: 1200px) and (max-width: 1399.98px) {
  .navpanel + .header { left: 280px; }
  .navpanel + .header + main { padding-left: 280px; }
}

@media (min-width: 1400px) {
  .navpanel { width: 280px; }
  .navpanel + .header { left: 280px; }
  .navpanel + .header + main { padding-left: 280px; }
}

@media (max-width: 1199.98px) {
  .navpanel { width: 286px; max-width: calc(100vw - 40px); padding: 1.15rem 1rem; box-shadow: 18px 0 50px rgb(0 0 0 / 24%); }
  .navpanel-brand-wrap { padding-right: 3rem; }
  .navpanel-account { margin-top: .35rem; }
  .navpanel-backdrop { background: rgb(8 9 11 / 48%); backdrop-filter: blur(2px); }
}

[data-theme="dark"] .navpanel {
  background:
    radial-gradient(circle at 0 0, rgb(255 90 61 / 10%), transparent 18rem),
    linear-gradient(180deg, #08090b, #111318);
  box-shadow: 8px 0 32px rgb(0 0 0 / 35%);
}
[data-theme="dark"] .navpanel-account-meta { background: var(--color-background); }

/* Account control panel header */
.header {
  color: var(--color-text);
  background: color-mix(in srgb, var(--color-surface) 94%, transparent);
  border-bottom-color: var(--color-border);
  box-shadow: var(--shadow-sm);
  backdrop-filter: blur(18px);
}

.header-stats { color: var(--color-text-secondary); font-size: .78rem; }
.header-stats > svg path { fill: var(--color-primary) !important; }
.header-stats .text-dark,
.header .text-dark { color: var(--color-text) !important; }
.header-stats .border-end { border-color: var(--color-border) !important; }
.header .icon-btn { color: var(--color-text); }
.header .icon-btn:hover { color: var(--color-primary); background: var(--color-primary-soft); }
.header .dropdown-menu { color: var(--color-text); background: var(--color-surface); border-color: var(--color-border); }
.header .dropdown-item { color: var(--color-text-secondary); }
.header .dropdown-item:hover,
.header .dropdown-item:focus { color: var(--color-text); background: var(--color-surface-alt); }


.header .account-header-brand {
  display: inline-flex;
  min-width: 0;
  align-items: center;
  gap: .65rem;
  color: var(--color-text);
  text-decoration: none;
}

.header .account-header-brand:hover {
  color: var(--color-primary);
}

.account-header-brand-mark {
  display: inline-flex;
  flex: 0 0 40px;
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 22%);
  border-radius: 12px;
}

.account-header-brand-mark svg {
  width: 26px;
  height: 26px;
}

.account-header-brand-text {
  overflow: hidden;
  color: inherit;
  font-family: var(--font-display);
  font-size: 1.58rem;
  font-weight: 700;
  letter-spacing: -.02em;
  line-height: 1;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.header .account-header-icon-button {
  display: inline-flex;
  width: 44px;
  min-width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  padding: 0;
  color: var(--color-text);
  background: transparent;
  border: 1px solid transparent;
  border-radius: 12px;
}

.header .account-header-icon-button svg {
  width: 24px;
  height: 24px;
}

.header .account-header-icon-button:hover,
.header .account-header-icon-button:focus-visible,
.header .account-header-language-button[aria-expanded="true"] {
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border-color: rgb(255 90 61 / 22%);
}

.header .account-header-language-button img {
  width: 24px;
  height: 24px;
  border: 1px solid rgb(255 255 255 / 45%);
  border-radius: 50%;
  box-shadow: 0 0 0 1px rgb(18 20 23 / 8%);
}

[data-theme="dark"] .header .account-header-language-button img {
  border-color: rgb(245 247 250 / 18%);
  box-shadow: 0 0 0 1px rgb(0 0 0 / 35%);
}


@media (max-width: 1199.98px) {
  .header-row { height: 76px; }
  .header .container-fluid { padding-right: 1rem; padding-left: 1rem; }
  .header .account-header-brand { max-width: min(48vw, 220px); }
  .navpanel-menu .nav-link { font-size: .875rem; }
  .navpanel-submenu .nav-link { font-size: .8rem; }
}

@media (max-width: 575.98px) {
  .header .container-fluid { padding-right: .75rem; padding-left: .75rem; }
  .header .account-header-brand { gap: .5rem; max-width: 45vw; }
  .account-header-brand-mark { flex-basis: 36px; width: 36px; height: 36px; border-radius: 10px; }
  .account-header-brand-mark svg { width: 23px; height: 23px; }
  .account-header-brand-text { font-size: 1.32rem; }
  .header .account-header-icon-button { width: 40px; min-width: 40px; height: 40px; border-radius: 10px; }
  .header .account-header-icon-button svg { width: 22px; height: 22px; }
  .header .account-header-language-button img { width: 23px; height: 23px; }
}

/* Account settings */
.account-page {
  color: var(--color-text);
  font-size: .875rem;
}

.account-page-heading {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.25rem;
}

.account-page-kicker {
  display: inline-flex;
  margin-bottom: .55rem;
  padding: .35rem .65rem;
  color: var(--color-primary-deep);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 22%);
  border-radius: 999px;
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.account-page-heading h1 {
  margin: 0;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  line-height: 1;
}

.account-page-heading p {
  max-width: 680px;
  margin: .65rem 0 0;
  color: var(--color-text-secondary);
  font-size: .8rem;
  line-height: 1.65;
}

.account-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
  margin: 0 0 1.25rem;
}

.account-stats-grid > .col {
  width: auto;
  margin: 0 !important;
  padding: 0;
}

.account-stat-card,
.account-link-card,
.account-workspace,
.account-section-card {
  color: var(--color-text);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-sm);
}

.account-stat-card {
  min-height: 150px;
  padding: 1.2rem !important;
  border-radius: var(--radius-md);
}

.account-stat-card .row {
  height: 100%;
}

.account-stat-card > .row > .col-auto:last-child {
  display: flex;
  flex: 0 0 40px;
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 18%);
  border-radius: 11px;
}

.account-stat-card > .row > .col-auto:last-child > svg {
  display: block;
  width: 20px;
  height: 20px;
  padding: 0;
  overflow: visible;
}

.account-stat-card > .row > .col-auto:last-child > svg path {
  fill: currentColor !important;
}

.account-stat-card a {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
}

.account-stat-card a svg {
  display: block;
  flex: 0 0 14px;
  width: 14px;
  height: 14px;
  margin: 0 !important;
  padding: 0;
}

.account-stat-label,
.account-link-label {
  color: var(--color-text-secondary);
  font-size: .72rem;
  font-weight: 650;
}

.account-stat-value {
  margin: .35rem 0 .45rem;
  overflow: hidden;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: clamp(1.65rem, 2.4vw, 2.25rem);
  font-weight: 700;
  line-height: 1.05;
  text-overflow: ellipsis;
}

.account-stat-value small {
  color: var(--color-text-secondary);
  font-family: var(--font-body);
  font-size: .58rem;
}

.account-stat-card a {
  color: var(--color-primary);
  font-size: .72rem;
  font-weight: 700;
  text-decoration: none;
}

.account-stat-card .progress {
  overflow: hidden;
  background: var(--color-surface-alt);
  border-radius: 999px;
}

.account-stat-card .progress-bar {
  background: linear-gradient(90deg, var(--color-primary), var(--color-primary-hover));
}

.account-link-grid {
  --bs-gutter-x: 1rem;
}

.account-link-card {
  min-height: 112px;
  border-radius: var(--radius-md);
}

.account-link-control {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 42px;
  align-items: center;
  gap: .65rem;
  margin-top: .55rem;
}

.account-link-control > a {
  min-width: 0;
}

.account-link-card .copy-source {
  width: 100%;
  margin: 0;
  padding: .65rem .8rem;
  color: var(--color-text);
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: .76rem;
}

.account-copy-button {
  display: inline-flex;
  width: 42px;
  height: 42px;
  min-height: 42px;
  padding: 0;
  align-items: center;
  justify-content: center;
  color: var(--color-text-secondary);
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
}

.account-copy-button svg {
  display: block;
  width: 18px;
  height: 18px;
  margin: 0;
}

.account-copy-button:hover {
  color: var(--color-primary);
  border-color: rgb(255 90 61 / 35%);
}

.account-workspace {
  overflow: hidden;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.account-tabs-scroll {
  overflow-x: auto;
  background: var(--color-surface-alt);
  border-bottom: 1px solid var(--color-border);
  scrollbar-width: thin;
}

.account-tabs {
  width: max-content;
  min-width: 100%;
  flex-wrap: nowrap;
  border: 0;
}

.account-tabs .nav-link {
  flex: 0 0 auto;
  min-height: 58px;
  padding: .9rem 1.25rem;
  color: var(--color-text-secondary);
  border: 0;
  border-bottom: 3px solid transparent;
  font-size: .8rem;
  font-weight: 700;
  white-space: nowrap;
}

.account-tabs .nav-link:hover,
.account-tabs .nav-link.active {
  color: var(--color-primary);
  background: color-mix(in srgb, var(--color-primary) 6%, transparent);
  border-color: var(--color-primary);
}

.account-workspace-body {
  padding: 1.25rem;
}

.account-settings-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.account-section-card {
  padding: 1.25rem;
  border-radius: var(--radius-md);
}

.account-section-heading {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  margin-bottom: 1.15rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--color-border);
}

.account-section-icon {
  display: inline-flex;
  flex: 0 0 40px;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 20%);
  border-radius: 10px;
}

.account-section-icon svg {
  display: block;
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.account-section-heading h2 {
  margin: 0;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
}

.account-section-heading p {
  margin: .3rem 0 0;
  color: var(--color-text-secondary);
  font-size: .68rem;
  line-height: 1.5;
}

.account-section-fields .row {
  display: block;
  margin-bottom: .9rem !important;
}

.account-section-fields .col-lg-4,
.account-section-fields .col-lg-6 {
  width: 100%;
  padding-inline: 0 !important;
  text-align: left !important;
}

.account-page .col-form-label {
  padding: 0 0 .4rem;
  color: var(--color-text-secondary) !important;
  font-size: .72rem;
  font-weight: 650;
}

.account-page .form-control,
.account-page .form-select,
.account-page input[type="text"],
.account-page input[type="password"] {
  min-height: 44px;
  color: var(--color-text);
  background-color: var(--color-surface-alt);
  border-color: var(--color-border);
  border-radius: var(--radius-sm);
  font-size: .8rem;
}

.account-page .form-control:focus,
.account-page .form-select:focus,
.account-page input[type="text"]:focus,
.account-page input[type="password"]:focus {
  background-color: var(--color-surface);
  border-color: var(--color-primary);
  box-shadow: 0 0 0 .2rem rgb(255 90 61 / 12%);
}

.account-page .form-control-plaintext {
  width: 100%;
  color: var(--color-text);
  font-size: .76rem;
}

.account-api-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.account-api-button {
  display: inline-flex;
  min-width: 132px;
  min-height: 44px;
  align-items: center;
  justify-content: center;
  margin: 0 !important;
  padding: .65rem 1rem;
  border-radius: var(--radius-sm);
  font-size: .76rem;
}

/* Account operation result dialog */
.account-result-dialog .modal-dialog {
  width: min(440px, calc(100vw - 2rem));
  max-width: 440px;
}

.account-result-dialog .modal-content {
  overflow: hidden;
  color: var(--color-text);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
}

.account-result-dialog .modal-header {
  min-height: 82px;
  padding: 1.15rem 1.25rem;
  color: var(--color-text) !important;
  background: var(--color-surface) !important;
  border-bottom: 1px solid var(--color-border);
  border-radius: 0 !important;
}

.account-result-dialog .modal-title {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin: 0;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 1.3;
}

.account-result-dialog .modal-title::before {
  display: inline-flex;
  flex: 0 0 40px;
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  color: #fff;
  background-color: var(--color-primary);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m5 12 4 4L19 6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  border-radius: 11px;
  box-shadow: 0 8px 20px rgb(255 90 61 / 22%);
  content: "";
}

.account-result-dialog .modal-body {
  padding: 1.25rem;
  color: var(--color-text-secondary);
  background: var(--color-surface);
  font-size: .8rem;
  line-height: 1.65;
}

.account-result-dialog .modal-footer {
  padding: 1rem 1.25rem 1.25rem;
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
}

.account-result-dialog .modal-footer .btn {
  min-width: 120px;
  min-height: 44px;
  margin: 0;
  color: #fff;
  background: var(--color-primary);
  border-color: var(--color-primary);
  border-radius: var(--radius-sm);
  box-shadow: 0 8px 22px rgb(255 90 61 / 18%);
  font-size: .76rem;
}

.account-result-dialog .modal-footer .btn:hover,
.account-result-dialog .modal-footer .btn:focus {
  color: #fff;
  background: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
}

.account-result-dialog + .modal-backdrop.show {
  background-color: #08090b;
}

[data-theme="dark"] .account-result-dialog .modal-content {
  box-shadow: 0 28px 80px rgb(0 0 0 / 55%), 0 0 30px rgb(255 90 61 / 8%);
}

.account-page .table {
  --bs-table-color: var(--color-text);
  --bs-table-bg: var(--color-surface);
  --bs-table-border-color: var(--color-border);
}

.account-page .text-dark {
  color: var(--color-text) !important;
}

.account-page .tab-pane:not(#edit) {
  max-width: 940px;
  margin-inline: auto;
  padding: 1.25rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.account-page #profit {
  max-width: 760px;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.account-tab-header {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr);
  align-items: start;
  gap: .75rem;
  margin-bottom: 1.25rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--color-border);
}

.account-tab-header-icon {
  display: inline-flex;
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 20%);
  border-radius: 10px;
}

.account-tab-header-icon svg {
  display: block;
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.65;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.account-tab-header-copy { min-width: 0; }

.account-tab-header h2 {
  margin: 0;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.3;
}

.account-tab-header p {
  margin: .35rem 0 0;
  color: var(--color-text-secondary);
  font-size: .72rem;
  line-height: 1.6;
}

.account-profit-panel {
  padding: 1.25rem;
  color: var(--color-text);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}

.account-profit-header {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr);
  align-items: start;
  gap: .75rem;
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--color-border);
}

.account-profit-header-icon {
  display: inline-flex;
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 20%);
  border-radius: 10px;
}

.account-profit-header-icon svg {
  display: block;
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.account-profit-header-copy {
  min-width: 0;
}

.account-profit-header h2 {
  margin: 0;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.3;
}

.account-profit-notice {
  max-width: 620px;
  margin-top: .4rem !important;
  color: var(--color-text-secondary) !important;
  font-size: .72rem !important;
  line-height: 1.65 !important;
}

.account-profit-options {
  display: grid;
  gap: .7rem;
}

.account-page #profit .earn-mode {
  position: relative;
  margin: 0 !important;
}

.account-page #profit .earn-mode input {
  position: absolute;
  z-index: 2;
  top: 50%;
  left: 1rem;
  width: 20px;
  height: 20px;
  margin: 0;
  appearance: none;
  background: var(--color-surface);
  border: 1.5px solid var(--color-border);
  border-radius: 50%;
  cursor: pointer;
  transform: translateY(-50%);
}

.account-page #profit .earn-mode input::after {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 8px;
  height: 8px;
  background: var(--color-primary);
  border-radius: 50%;
  content: "";
  opacity: 0;
  transform: translate(-50%, -50%) scale(.5);
  transition: opacity .18s ease, transform .18s ease;
}

.account-page #profit .earn-mode input:checked {
  background: var(--color-surface);
  border-color: var(--color-primary);
  background-image: none;
  box-shadow: 0 0 0 4px rgb(255 90 61 / 10%);
}

.account-page #profit .earn-mode input:checked::after {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.account-page #profit .earn-mode label {
  display: flex;
  min-height: 58px;
  align-items: center;
  margin: 0;
  padding: .8rem 1rem .8rem 3.25rem;
  color: var(--color-text-secondary);
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-weight: 500;
  transition: color .2s ease, background-color .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.account-page #profit .earn-mode label:hover {
  color: var(--color-text);
  border-color: rgb(255 90 61 / 35%);
}

.account-page #profit .earn-mode label span {
  font-size: .8rem;
  line-height: 1.5;
}

.account-page #profit .earn-mode label strong {
  margin-right: .45rem;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: .9rem;
}

.account-page #profit .earn-mode input:checked ~ label {
  color: var(--color-primary);
  background: color-mix(in srgb, var(--color-primary) 8%, var(--color-surface));
  border-color: var(--color-primary);
  box-shadow: 0 5px 16px rgb(255 90 61 / 8%);
}

.account-page #profit .earn-mode input:checked ~ label strong {
  color: var(--color-primary);
}

.account-page #profit .earn-mode input:disabled,
.account-page #profit .earn-mode input:disabled ~ label {
  cursor: not-allowed;
  opacity: .58;
}

.account-profit-save {
  display: flex;
  justify-content: flex-end;
  padding-top: 1rem;
}

.account-save-row {
  display: flex;
  justify-content: flex-end;
  padding-top: 1rem;
}

.account-save-row .btn,
.account-page .submit-btn {
  min-width: 180px;
  min-height: 48px;
}

[data-theme="dark"] .account-page-kicker {
  color: var(--color-primary-hover);
}

[data-theme="dark"] .account-page .btn-close {
  filter: invert(1) grayscale(1);
}

@media (max-width: 1199.98px) {
  .account-stats-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 767.98px) {
  .account-page { font-size: .8rem; }
  .account-page-heading { margin-bottom: 1rem; }
  .account-page-heading h1 { font-size: 2.15rem; }
  .account-page-heading p { font-size: .75rem; }
  .account-stats-grid { gap: .65rem; }
  .account-stat-card { min-height: 132px; padding: .9rem !important; }
  .account-stat-card > .row > .col-auto:last-child { position: absolute; top: .8rem; right: .8rem; width: 36px; height: 36px; flex-basis: 36px; }
  .account-stat-card .row { position: relative; }
  .account-stat-card > .row > .col-auto:last-child > svg { width: 18px; height: 18px; }
  .account-stat-label { max-width: calc(100% - 34px); font-size: .64rem; white-space: normal; }
  .account-stat-value { margin-top: .65rem; font-size: 1.45rem; }
  .account-stat-card a { font-size: .64rem; white-space: normal; }
  .account-link-grid > div { margin-bottom: .65rem !important; }
  .account-link-card { min-height: 96px; padding: 1rem !important; }
  .account-link-card .copy-source { font-size: .68rem; }
  .account-tabs .nav-link { min-height: 52px; padding: .75rem .9rem; font-size: .72rem; }
  .account-workspace-body { padding: .75rem; }
  .account-settings-grid { grid-template-columns: minmax(0, 1fr); gap: .75rem; }
  .account-section-card { padding: 1rem; }
  .account-section-heading h2 { font-size: .95rem; }
  .account-page .tab-pane:not(#edit) { padding: 1rem; }
  .account-page #profit { padding: 0; }
  .account-tab-header { grid-template-columns: 36px minmax(0, 1fr); gap: .65rem; }
  .account-tab-header-icon { width: 36px; height: 36px; }
  .account-tab-header-icon svg { width: 18px; height: 18px; }
  .account-tab-header p { font-size: .68rem; }
  .account-profit-panel { padding: 1rem; }
  .account-profit-header { grid-template-columns: 36px minmax(0, 1fr); gap: .65rem; }
  .account-profit-header-icon { width: 36px; height: 36px; }
  .account-profit-header-icon svg { width: 18px; height: 18px; }
  .account-profit-notice { font-size: .68rem !important; }
  .account-page #profit .earn-mode label { min-height: 54px; padding-left: 3rem; }
  .account-page #profit .earn-mode label span { font-size: .72rem; }
  .account-profit-save .btn { width: 100%; }
  .account-api-actions { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .account-api-button { width: 100%; min-width: 0; }
  .account-result-dialog .modal-dialog { margin: .75rem auto; }
  .account-result-dialog .modal-header { min-height: 74px; padding: 1rem; }
  .account-result-dialog .modal-title { font-size: 1rem; }
  .account-result-dialog .modal-title::before { flex-basis: 36px; width: 36px; height: 36px; border-radius: 10px; background-size: 19px; }
  .account-result-dialog .modal-body { padding: 1rem; font-size: .74rem; }
  .account-result-dialog .modal-footer { padding: .85rem 1rem 1rem; }
  .account-result-dialog .modal-footer .btn { width: 100%; }
  .account-save-row .btn,
  .account-page .submit-btn { width: 100%; }
}

@media (max-width: 389.98px) {
  .account-stat-card { min-height: 124px; padding: .75rem !important; }
  .account-stat-value { font-size: 1.25rem; }
}

/* Payouts */
.payout-page {
  color: var(--color-text);
  font-size: .875rem;
}

.payout-page-heading {
  margin-bottom: 1.25rem;
}

.payout-page-kicker {
  display: inline-flex;
  margin-bottom: .55rem;
  padding: .35rem .65rem;
  color: var(--color-primary-deep);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 22%);
  border-radius: 999px;
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.payout-page-heading h1 {
  margin: 0;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  line-height: 1;
}

.payout-page-heading p {
  max-width: 720px;
  margin: .65rem 0 0;
  color: var(--color-text-secondary);
  font-size: .8rem;
  line-height: 1.65;
}

.payout-alert {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin-bottom: 1rem;
  padding: .85rem 1rem;
  color: var(--color-text);
  background: color-mix(in srgb, var(--color-success) 8%, var(--color-surface));
  border: 1px solid color-mix(in srgb, var(--color-success) 30%, var(--color-border));
  border-radius: var(--radius-sm);
  font-size: .74rem;
  line-height: 1.55;
}

.payout-alert-icon {
  display: inline-flex;
  flex: 0 0 32px;
  width: 32px;
  height: 32px;
  align-items: center;
  justify-content: center;
  color: #fff;
  background: var(--color-success);
  border-radius: 9px;
}

.payout-alert-icon svg,
.payout-card-icon svg,
.payout-section-icon svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.payout-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-bottom: 1rem;
}

.payout-summary-grid > :only-child {
  grid-column: 1 / -1;
}

.payout-balance-card,
.payout-pending-card,
.payout-action-card,
.payout-history-card {
  color: var(--color-text);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}

.payout-balance-card,
.payout-pending-card {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  align-items: center;
  gap: 1rem;
  min-height: 142px;
  padding: 1.25rem;
}

.payout-card-icon,
.payout-section-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 20%);
  border-radius: 11px;
}

.payout-card-icon {
  width: 48px;
  height: 48px;
}

.payout-balance-copy {
  display: grid;
  min-width: 0;
  gap: .25rem;
}

.payout-balance-copy > span {
  color: var(--color-text-secondary);
  font-size: .72rem;
  font-weight: 650;
}

.payout-balance-copy strong {
  overflow: hidden;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3vw, 2.5rem);
  line-height: 1.1;
  text-overflow: ellipsis;
}

.payout-balance-copy small {
  color: var(--color-text-secondary);
  font-size: .65rem;
  line-height: 1.5;
}

.payout-form {
  margin-bottom: 1rem;
}

.payout-action-card,
.payout-history-card {
  padding: 1.25rem;
}

.payout-section-header {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr);
  align-items: start;
  gap: .75rem;
  margin-bottom: 1.25rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--color-border);
}

.payout-section-icon {
  width: 40px;
  height: 40px;
}

.payout-section-header h2,
.payout-convert-heading h3 {
  margin: 0;
  color: var(--color-text);
  font-family: var(--font-display);
  font-weight: 700;
}

.payout-section-header h2 {
  font-size: 1rem;
}

.payout-section-header p,
.payout-convert-heading p {
  margin: .3rem 0 0;
  color: var(--color-text-secondary);
  font-size: .7rem;
  line-height: 1.55;
}

.payout-primary-action {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: .5rem 0 .25rem;
}

.payout-submit {
  min-width: 300px;
  min-height: 50px;
}

.payout-minimum-note {
  margin-top: .75rem;
  padding: .55rem .75rem;
  color: var(--color-text-secondary);
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: .7rem;
}

.payout-minimum-note strong {
  color: var(--color-primary);
}

.payout-convert-section {
  display: grid;
  grid-template-columns: minmax(220px, .7fr) minmax(0, 1.3fr);
  align-items: center;
  gap: 1rem;
  margin-top: 1.25rem;
  padding: 1rem;
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
}

.payout-convert-heading h3 {
  font-size: .88rem;
}

.payout-convert-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .65rem;
}

.payout-convert-button {
  width: 100%;
  min-height: 48px;
  padding: .65rem .8rem;
  white-space: normal;
  font-family: var(--font-body);
  font-size: .68rem;
  line-height: 1.45;
}

.payout-history-card {
  margin-bottom: 1.5rem;
}

.payout-table-wrap {
  max-width: 100%;
  overflow-x: auto;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
}

.payout-history-table {
  --bs-table-bg: var(--color-surface);
  --bs-table-color: var(--color-text);
  --bs-table-border-color: var(--color-border);
  min-width: 760px;
  margin: 0;
  vertical-align: middle;
}

.payout-history-table thead th {
  padding: .8rem 1rem;
  color: var(--color-text-secondary);
  background: var(--color-surface-alt);
  border-bottom-width: 1px;
  font-size: .66rem;
  font-weight: 750;
  letter-spacing: .03em;
  text-transform: uppercase;
  white-space: nowrap;
}

.payout-history-table tbody td {
  padding: .85rem 1rem;
  color: var(--color-text-secondary);
  font-size: .72rem;
}

.payout-history-table tbody tr:last-child td {
  border-bottom: 0;
}

.payout-history-table tbody tr:hover td {
  background: color-mix(in srgb, var(--color-primary) 3%, var(--color-surface));
}

.payout-history-table .payout-amount {
  color: var(--color-text);
  font-weight: 750;
}

.payout-status {
  display: inline-flex;
  padding: .3rem .55rem;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 18%);
  border-radius: 999px;
  font-size: .62rem;
  font-weight: 750;
  white-space: nowrap;
}

[data-theme="dark"] .payout-page-kicker {
  color: var(--color-primary-hover);
}

@media (max-width: 767.98px) {
  .payout-page { font-size: .8rem; }
  .payout-page-heading h1 { font-size: 2.15rem; }
  .payout-page-heading p { font-size: .75rem; }
  .payout-summary-grid { grid-template-columns: minmax(0, 1fr); gap: .75rem; }
  .payout-summary-grid > :only-child { grid-column: auto; }
  .payout-balance-card,
  .payout-pending-card { min-height: 124px; padding: 1rem; }
  .payout-action-card,
  .payout-history-card { padding: 1rem; }
  .payout-section-header { grid-template-columns: 36px minmax(0, 1fr); gap: .65rem; }
  .payout-section-icon { width: 36px; height: 36px; }
  .payout-section-header p { font-size: .66rem; }
  .payout-submit { width: 100%; min-width: 0; }
  .payout-convert-section { grid-template-columns: minmax(0, 1fr); }
  .payout-convert-actions { grid-template-columns: minmax(0, 1fr); }
  .payout-table-wrap { overflow: visible; border: 0; }
  .payout-history-table,
  .payout-history-table tbody,
  .payout-history-table tr,
  .payout-history-table td { display: block; width: 100%; min-width: 0; }
  .payout-history-table thead { display: none; }
  .payout-history-table tbody { display: grid; gap: .75rem; }
  .payout-history-table tbody tr { overflow: hidden; background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: var(--radius-sm); }
  .payout-history-table tbody td { display: grid; grid-template-columns: minmax(110px, .45fr) minmax(0, 1fr); gap: .75rem; padding: .65rem .75rem; border-bottom: 1px solid var(--color-border); text-align: right; overflow-wrap: anywhere; }
  .payout-history-table tbody td::before { color: var(--color-text-secondary); content: attr(data-label); font-size: .62rem; font-weight: 750; text-align: left; text-transform: uppercase; }
  .payout-history-table tbody tr:last-child td,
  .payout-history-table tbody td:last-child { border-bottom: 0; }
  .payout-status { justify-self: end; }
}

/* Referrals */
.referrals-page {
  color: var(--color-text);
  font-size: .875rem;
}

.referrals-page-heading {
  margin-bottom: 1.25rem;
}

.referrals-page-kicker {
  display: inline-flex;
  margin-bottom: .55rem;
  padding: .35rem .65rem;
  color: var(--color-primary-deep);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 22%);
  border-radius: 999px;
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.referrals-page-heading h1 {
  margin: 0;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  line-height: 1;
}

.referrals-page-heading p {
  max-width: 720px;
  margin: .65rem 0 0;
  color: var(--color-text-secondary);
  font-size: .8rem;
  line-height: 1.65;
}

.referrals-overview-card,
.referrals-list-card {
  color: var(--color-text);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}

.referrals-overview-card {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
  padding: 1.25rem;
  background: linear-gradient(135deg, color-mix(in srgb, var(--color-primary) 6%, var(--color-surface)), var(--color-surface));
}

.referrals-overview-icon,
.referrals-section-icon,
.referrals-empty-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 20%);
  border-radius: 11px;
}

.referrals-overview-icon {
  width: 48px;
  height: 48px;
}

.referrals-overview-icon svg,
.referrals-section-icon svg,
.referrals-empty-icon svg {
  width: 21px;
  height: 21px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.referrals-overview-card h2,
.referrals-section-header h2,
.referrals-empty h3 {
  margin: 0;
  color: var(--color-text);
  font-family: var(--font-display);
  font-weight: 700;
}

.referrals-overview-card h2,
.referrals-section-header h2 {
  font-size: 1rem;
}

.referrals-overview-card p,
.referrals-section-header p,
.referrals-empty p {
  margin: .3rem 0 0;
  color: var(--color-text-secondary);
  font-size: .7rem;
  line-height: 1.6;
}

.referrals-list-card {
  margin-bottom: 1.5rem;
  padding: 1.25rem;
}

.referrals-section-header {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr);
  align-items: start;
  gap: .75rem;
  margin-bottom: 1.25rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--color-border);
}

.referrals-section-icon {
  width: 40px;
  height: 40px;
}

.referrals-table-wrap {
  max-width: 100%;
  overflow-x: auto;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
}

.referrals-table {
  --bs-table-bg: var(--color-surface);
  --bs-table-color: var(--color-text);
  --bs-table-border-color: var(--color-border);
  min-width: 680px;
  margin: 0;
  vertical-align: middle;
}

.referrals-table thead th {
  padding: .8rem 1rem;
  color: var(--color-text-secondary);
  background: var(--color-surface-alt);
  border-bottom-width: 1px;
  font-size: .66rem;
  font-weight: 750;
  letter-spacing: .03em;
  text-transform: uppercase;
  white-space: nowrap;
}

.referrals-table tbody td {
  padding: .8rem 1rem;
  color: var(--color-text-secondary);
  font-size: .72rem;
}

.referrals-table tbody tr:last-child td {
  border-bottom: 0;
}

.referrals-table tbody tr:hover td {
  background: color-mix(in srgb, var(--color-primary) 3%, var(--color-surface));
}

.referrals-user {
  display: flex;
  min-width: 0;
  align-items: center;
  gap: .65rem;
}

.referrals-avatar {
  display: inline-flex;
  flex: 0 0 36px;
  width: 36px;
  height: 36px;
  overflow: hidden;
  align-items: center;
  justify-content: flex-start;
  padding-left: 11px;
  color: #fff;
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));
  border-radius: 10px;
  font-family: var(--font-display);
  font-size: .8rem;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
}

.referrals-user-copy {
  display: flex;
  min-width: 0;
  align-items: center;
  gap: .55rem;
}

.referrals-user-copy strong {
  overflow: hidden;
  color: var(--color-text);
  font-size: .75rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.referrals-premium-badge,
.referrals-money {
  font-weight: 750;
}

.referrals-premium-badge {
  display: inline-flex;
  padding: .24rem .48rem;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 18%);
  border-radius: 999px;
  font-size: .56rem;
  white-space: nowrap;
}

.referrals-money {
  color: var(--color-text) !important;
}

.referrals-paging {
  display: flex;
  justify-content: flex-end;
  color: var(--color-text-secondary);
  font-size: .68rem;
}

.referrals-paging:empty {
  display: none;
}

.referrals-paging-top {
  margin-bottom: .75rem;
}

.referrals-paging-bottom {
  margin-top: .75rem;
}

.referrals-paging a,
.referrals-paging span {
  color: inherit;
}

.referrals-paging a:hover {
  color: var(--color-primary);
}

.referrals-empty {
  display: flex;
  min-height: 260px;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  text-align: center;
}

.referrals-empty-icon {
  width: 52px;
  height: 52px;
  margin-bottom: .85rem;
}

.referrals-empty h3 {
  font-size: 1rem;
}

.referrals-empty p {
  max-width: 480px;
}

[data-theme="dark"] .referrals-page-kicker {
  color: var(--color-primary-hover);
}

@media (max-width: 767.98px) {
  .referrals-page { font-size: .8rem; }
  .referrals-page-heading h1 { font-size: 2.15rem; }
  .referrals-page-heading p { font-size: .75rem; }
  .referrals-overview-card { grid-template-columns: 42px minmax(0, 1fr); gap: .75rem; padding: 1rem; }
  .referrals-overview-icon { width: 42px; height: 42px; }
  .referrals-list-card { padding: 1rem; }
  .referrals-section-header { grid-template-columns: 36px minmax(0, 1fr); gap: .65rem; }
  .referrals-section-icon { width: 36px; height: 36px; }
  .referrals-section-header p { font-size: .66rem; }
  .referrals-table-wrap { overflow: visible; border: 0; }
  .referrals-table,
  .referrals-table tbody,
  .referrals-table tr,
  .referrals-table td { display: block; width: 100%; min-width: 0; }
  .referrals-table thead { display: none; }
  .referrals-table tbody { display: grid; gap: .75rem; }
  .referrals-table tbody tr { overflow: hidden; background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: var(--radius-sm); }
  .referrals-table tbody td { display: grid; grid-template-columns: minmax(100px, .4fr) minmax(0, 1fr); align-items: center; gap: .75rem; padding: .65rem .75rem; border-bottom: 1px solid var(--color-border); text-align: right; overflow-wrap: anywhere; }
  .referrals-table tbody td::before { color: var(--color-text-secondary); content: attr(data-label); font-size: .62rem; font-weight: 750; text-align: left; text-transform: uppercase; }
  .referrals-table tbody td:first-child { grid-template-columns: minmax(0, 1fr); }
  .referrals-table tbody td:first-child::before { display: none; }
  .referrals-table tbody td:last-child { border-bottom: 0; }
  .referrals-user { justify-content: flex-start; text-align: left; }
  .referrals-user-copy { flex-wrap: wrap; }
  .referrals-paging { justify-content: center; }
  .referrals-empty { min-height: 220px; padding: 1.5rem 1rem; }
}

/* File manager */
.file-manager-page {
  color: var(--color-text);
  font-size: .875rem;
}

.file-manager-heading { margin-bottom: 1.25rem; }
.file-manager-kicker { display: inline-flex; margin-bottom: .55rem; padding: .35rem .65rem; color: var(--color-primary-deep); background: var(--color-primary-soft); border: 1px solid rgb(255 90 61 / 22%); border-radius: 999px; font-size: .68rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.file-manager-heading h1 { margin: 0; color: var(--color-text); font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3rem); font-weight: 700; line-height: 1; }
.file-manager-heading p { max-width: 720px; margin: .65rem 0 0; color: var(--color-text-secondary); font-size: .8rem; line-height: 1.65; }

.file-manager-toolbar,
.file-manager-activity-card,
.file-manager-list-card {
  color: var(--color-text);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}

.file-manager-toolbar { margin-bottom: 1rem; padding: 1rem; }
.file-manager-search { position: relative; width: min(440px, 100%); }
.file-manager-search::before { position: absolute; z-index: 1; top: 50%; left: 1rem; width: 16px; height: 16px; border: 2px solid var(--color-text-secondary); border-radius: 50%; content: ""; opacity: .8; transform: translateY(-58%); pointer-events: none; }
.file-manager-search::after { position: absolute; z-index: 1; top: calc(50% + 5px); left: 27px; width: 7px; height: 2px; background: var(--color-text-secondary); content: ""; opacity: .8; transform: rotate(45deg); pointer-events: none; }
.file-manager-search .form-control { min-height: 44px; padding-left: 2.8rem; color: var(--color-text); background: var(--color-surface-alt); border-color: var(--color-border); }
.file-manager-new-folder,
.file-manager-publish { min-height: 44px; white-space: nowrap; }
.file-manager-publish { display: inline-flex; align-items: center; gap: .3rem; text-decoration: none; }
.file-manager-stats { display: inline-flex; align-items: center; gap: .25rem; padding: .55rem .75rem; color: var(--color-text-secondary); background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: var(--radius-sm); font-size: .68rem; white-space: nowrap; }

.file-manager-activity-card,
.file-manager-list-card { margin-bottom: 1rem; padding: 1.25rem; }
.file-manager-list-card.files { padding: 0; background: transparent; border: 0; box-shadow: none; }
.file-manager-section-header { margin-bottom: 1rem; padding-bottom: .9rem; border-bottom: 1px solid var(--color-border); }
.file-manager-section-header h2 { margin: 0; color: var(--color-text); font-family: var(--font-display); font-size: 1rem; font-weight: 700; }
.file-manager-section-header p { margin: .3rem 0 0; color: var(--color-text-secondary); font-size: .68rem; line-height: 1.55; }

.file-manager-folders-section,
.file-manager-files-section { padding: 1rem; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-sm); }
.file-manager-files-section { margin-top: 1rem; }
.file-manager-collection-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; margin-bottom: .9rem; }
.file-manager-collection-header h2 { margin: 0; color: var(--color-text); font-family: var(--font-display); font-size: 1rem; font-weight: 700; }
.file-manager-collection-header p { margin: .3rem 0 0; color: var(--color-text-secondary); font-size: .68rem; line-height: 1.55; }
.file-manager-title-row { display: flex; align-items: center; gap: .55rem; }
.file-manager-folder-count { display: inline-flex; min-width: 27px; height: 24px; align-items: center; justify-content: center; padding: 0 .45rem; color: var(--color-primary); background: var(--color-primary-soft); border: 1px solid rgb(255 90 61 / 18%); border-radius: 999px; font-size: .62rem; font-weight: 750; }
.file-manager-folders-toggle { display: inline-flex; min-height: 38px; align-items: center; gap: .45rem; padding: .45rem .7rem; color: var(--color-primary); background: transparent; border: 1px solid rgb(255 90 61 / 28%); border-radius: 9px; font-family: var(--font-body); font-size: .66rem; font-weight: 750; white-space: nowrap; }
.file-manager-folders-toggle:hover { background: var(--color-primary-soft); border-color: rgb(255 90 61 / 42%); }
.file-manager-folders-short .file-manager-folders-toggle { display: none; }
.file-manager-folders-toggle svg { transition: transform .2s ease; }
.file-manager-folders-toggle-less { display: none; }
.file-manager-folders-section.is-expanded .file-manager-folders-toggle-more { display: none; }
.file-manager-folders-section.is-expanded .file-manager-folders-toggle-less { display: inline; }
.file-manager-folders-section.is-expanded .file-manager-folders-toggle svg { transform: rotate(90deg); }
.file-manager-folder-viewport { overflow: hidden; }
.file-manager-folder-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: .75rem; max-height: 221px; overflow: hidden; }
.file-manager-folders-section.is-expanded .file-manager-folder-grid { max-height: none; }
.file-manager-folder-card { position: relative; display: grid; grid-template-columns: 40px minmax(0, 1fr) 40px; min-height: 104px; align-items: center; overflow: visible; background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: var(--radius-sm); transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease; }
.file-manager-folder-card:hover { border-color: rgb(255 90 61 / 28%); box-shadow: var(--shadow-sm); transform: translateY(-1px); }
.file-manager-folder-select { display: flex; align-items: center; justify-content: center; padding-left: .45rem; }
.file-manager-folder-main { display: flex; min-width: 0; align-items: center; gap: .7rem; padding: .75rem .25rem; color: var(--color-text); text-decoration: none; }
.file-manager-folder-main:hover { color: var(--color-primary); }
.file-manager-folder-card-icon { display: inline-flex; flex: 0 0 48px; width: 48px; height: 48px; align-items: center; justify-content: center; color: var(--color-primary); background: var(--color-primary-soft); border: 1px solid rgb(255 90 61 / 20%); border-radius: 12px; }
.file-manager-folder-card-icon svg { width: 24px; height: 22px; }
.file-manager-folder-copy { display: flex; min-width: 0; flex-direction: column; gap: .28rem; }
.file-manager-folder-copy strong { overflow: hidden; color: inherit; font-size: .72rem; font-weight: 750; text-overflow: ellipsis; white-space: nowrap; }
.file-manager-folder-copy small { color: var(--color-text-secondary); font-size: .62rem; }
.file-manager-folder-menu { display: flex; align-items: center; justify-content: center; }
.file-manager-folder-menu-button { display: inline-flex; width: 36px; height: 36px; align-items: center; justify-content: center; color: var(--color-text-secondary); background: transparent; border: 0; border-radius: 9px; }
.file-manager-folder-menu-button:hover,
.file-manager-folder-menu-button[aria-expanded="true"] { color: var(--color-primary); background: var(--color-primary-soft); }
.file-manager-folder-menu .dropdown-menu { min-width: 130px; padding: .35rem; background: var(--color-surface); border-color: var(--color-border); border-radius: 10px; box-shadow: var(--shadow-md); }
.file-manager-folder-menu .dropdown-item { padding: .5rem .6rem; color: var(--color-text); border-radius: 7px; font-size: .66rem; }
.file-manager-folder-menu .dropdown-item:hover { color: var(--color-primary); background: var(--color-primary-soft); }
.file-manager-parent-folder-card { grid-template-columns: minmax(0, 1fr); }
.file-manager-parent-folder-card .file-manager-folder-main { padding-inline: 1rem; }

.file-manager-table-wrap { max-width: 100%; overflow-x: auto; border: 1px solid var(--color-border); border-radius: var(--radius-sm); scrollbar-width: thin; }
.file-manager-files-table,
.file-manager-activity-table { --bs-table-bg: var(--color-surface); --bs-table-color: var(--color-text); --bs-table-border-color: var(--color-border); min-width: 920px; margin: 0; vertical-align: middle; }
.file-manager-files-table thead th,
.file-manager-activity-table thead th { padding: .75rem .8rem; color: var(--color-text-secondary); background: var(--color-surface-alt); border-bottom-width: 1px; font-size: .62rem; font-weight: 750; letter-spacing: .02em; text-transform: uppercase; white-space: nowrap; }
.file-manager-files-table tbody td,
.file-manager-activity-table tbody td { padding: .72rem .8rem; color: var(--color-text-secondary); font-size: .7rem; }
.file-manager-files-table tbody tr:last-child td,
.file-manager-activity-table tbody tr:last-child td { border-bottom: 0; }
.file-manager-files-table tbody tr:hover td,
.file-manager-activity-table tbody tr:hover td { background: color-mix(in srgb, var(--color-primary) 3%, var(--color-surface)); }
.file-manager-files-table .link-dark,
.file-manager-files-table .text-dark { color: var(--color-text) !important; }
.file-manager-files-table .file-name a,
.file-manager-files-table .fld-name a { display: inline-flex; align-items: center; gap: .65rem; color: var(--color-text); text-decoration: none; }
.file-manager-files-table .file-name a:hover,
.file-manager-files-table .fld-name a:hover { color: var(--color-primary); }
.file-manager-remote-link { display: inline-block; max-width: 360px; overflow: hidden; color: var(--color-text); text-decoration: none; text-overflow: ellipsis; white-space: nowrap; }
.file-manager-remote-link:hover { color: var(--color-primary); }
.file-manager-item-icon { display: inline-flex; flex: 0 0 36px; width: 36px; height: 36px; align-items: center; justify-content: center; color: var(--color-primary); background: var(--color-primary-soft); border: 1px solid rgb(255 90 61 / 20%); border-radius: 10px; }
.file-manager-item-icon svg,
.file-manager-item-icon img { display: block; width: 18px; height: 18px; margin: 0 !important; object-fit: contain; }
.file-manager-item-icon svg path { fill: currentColor !important; }
.file-manager-locked-icon { color: var(--color-error); background: color-mix(in srgb, var(--color-error) 8%, var(--color-surface)); border-color: color-mix(in srgb, var(--color-error) 22%, var(--color-border)); }
.file-manager-files-table .files-total { display: inline-flex; min-width: 22px; height: 22px; align-items: center; justify-content: center; margin-left: .5rem; padding: 0 .35rem; color: var(--color-text-secondary); background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: 999px; font-size: .58rem; }
.file-manager-files-table .file-manager-action-button,
.file-manager-activity-table .link-danger { display: inline-flex; width: 32px; height: 32px; align-items: center; justify-content: center; margin: 0 .1rem !important; border: 1px solid transparent; border-radius: 8px; }
.file-manager-files-table .file-manager-action-button { width: 34px; height: 34px; padding: 0; color: var(--color-text-secondary); background: var(--color-surface-alt); border-color: var(--color-border); border-radius: 9px; }
.file-manager-files-table .file-manager-action-button svg { display: block; width: 15px; height: 15px; margin: 0 !important; }
.file-manager-files-table .file-manager-edit-button:hover { color: var(--color-primary); background: var(--color-primary-soft); border-color: rgb(255 90 61 / 25%); }
.file-manager-files-table .file-manager-delete-button:hover,
.file-manager-activity-table .link-danger:hover { color: var(--color-error); background: color-mix(in srgb, var(--color-error) 8%, var(--color-surface)); border-color: color-mix(in srgb, var(--color-error) 25%, var(--color-border)); }
.file-manager-files-table tbody td:last-child { white-space: nowrap; }
.file-manager-files-table .form-switcher { min-height: 34px; align-items: center; justify-content: center; }
.file-manager-page .file-manager-files-table .form-switcher input { width: 38px !important; min-width: 38px !important; height: 22px !important; margin: 0; cursor: pointer; background-color: var(--color-border) !important; background-position: 3px 50% !important; background-size: 16px 16px !important; border: 1px solid var(--color-border) !important; border-radius: 999px; box-shadow: none !important; transition: background-color .2s ease, background-position .2s ease, border-color .2s ease; }
.file-manager-page .file-manager-files-table .form-switcher input:checked { background-color: var(--color-primary) !important; background-position: calc(100% - 3px) 50% !important; border-color: var(--color-primary) !important; }
.file-manager-page .file-manager-files-table .form-switcher input:focus-visible { outline: 3px solid rgb(255 90 61 / 20%); outline-offset: 2px; }
.file-manager-page .check-radio { align-items: center; justify-content: center; }
.file-manager-page .check-radio input[type="checkbox"] { width: 20px; min-width: 20px; height: 20px; margin: 0; cursor: pointer; appearance: none; background-color: var(--color-surface); background-position: center; background-repeat: no-repeat; background-size: 12px 10px; border: 1.5px solid color-mix(in srgb, var(--color-text-secondary) 42%, var(--color-border)); border-radius: 5px; box-shadow: inset 0 0 0 1px rgb(255 255 255 / 2%); transition: background-color .18s ease, border-color .18s ease, box-shadow .18s ease, transform .18s ease; }
.file-manager-page .check-radio input[type="checkbox"]:hover { border-color: color-mix(in srgb, var(--color-primary) 55%, var(--color-border)); box-shadow: 0 0 0 3px rgb(255 90 61 / 8%); }
.file-manager-page .check-radio input[type="checkbox"]:checked { background-color: var(--color-primary); background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='10' viewBox='0 0 12 10' fill='none'%3E%3Cpath d='M10.667 1.5 4.583 7.583 1.333 4.333' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); border-color: var(--color-primary); box-shadow: none; }
.file-manager-page .check-radio input[type="checkbox"]:checked:hover { background-color: var(--color-primary-hover); border-color: var(--color-primary-hover); }
.file-manager-page .check-radio input[type="checkbox"]:focus-visible { outline: 3px solid rgb(255 90 61 / 24%); outline-offset: 2px; }
.file-manager-page .check-radio input[type="checkbox"]:disabled { cursor: not-allowed; opacity: .45; }
.file-manager-page .file-manager-folder-card:has(.file-manager-folder-select input[type="checkbox"]:checked) { border-color: color-mix(in srgb, var(--color-primary) 42%, var(--color-border)); box-shadow: 0 0 0 1px rgb(255 90 61 / 12%), var(--shadow-sm); }
.file-manager-page .file-manager-files-table tbody tr:has(.file-manager-item-select input[type="checkbox"]:checked) td { background: color-mix(in srgb, var(--color-primary) 4%, var(--color-surface)); }
.file-manager-empty-state { padding: 2rem !important; color: var(--color-text-secondary) !important; text-align: center; }
.file-manager-activity-table .progress { min-width: 140px; overflow: hidden; background: var(--color-surface-alt); border-radius: 999px; }
.file-manager-activity-table .progress-bar { background: linear-gradient(90deg, var(--color-primary), var(--color-primary-hover)); border-radius: 999px; font-size: .56rem; }

.file-manager-list-card .paging { display: flex; justify-content: center; margin-top: .85rem; color: var(--color-text-secondary); font-size: .68rem; }
.file-manager-list-card .paging:empty { display: none; }
.file-manager-list-card .bottom-space { display: none; }

.deleted-files-hero { display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; }
.deleted-files-hide-button { display: inline-flex; min-height: 42px; align-items: center; justify-content: center; white-space: nowrap; }
.deleted-files-section { box-shadow: var(--shadow-sm); }
.deleted-files-table-wrap { background: var(--color-surface); }
.deleted-files-table { min-width: 720px; }
.deleted-files-table tbody tr { transition: background-color .18s ease; }
.deleted-files-table tbody tr:hover td { background: color-mix(in srgb, var(--color-primary) 3%, var(--color-surface)); }
.deleted-files-name { min-width: 280px; }
.deleted-files-name,
.deleted-files-code-cell,
.deleted-files-age-cell { vertical-align: middle; }
.deleted-files-name { display: flex; align-items: center; gap: .75rem; color: var(--color-text) !important; }
.deleted-files-item-icon { color: var(--color-error); background: color-mix(in srgb, var(--color-error) 9%, var(--color-surface)); border-color: color-mix(in srgb, var(--color-error) 24%, var(--color-border)); }
.deleted-files-name-copy { display: block; min-width: 0; }
.deleted-files-name-copy strong { display: block; overflow: hidden; color: var(--color-text); font-size: .72rem; font-weight: 750; text-overflow: ellipsis; white-space: nowrap; }
.deleted-files-code { display: inline-flex; align-items: center; min-height: 28px; padding: .25rem .45rem; color: var(--color-primary); background: var(--color-primary-soft); border: 1px solid rgb(255 90 61 / 18%); border-radius: 7px; font-family: var(--font-body); font-size: .66rem; font-weight: 750; }
.deleted-files-age { display: inline-flex; align-items: center; min-height: 28px; padding: .25rem .5rem; color: var(--color-text-secondary); background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: 999px; font-size: .64rem; font-weight: 700; }
.deleted-files-empty { padding: 2.5rem 1rem !important; }
.deleted-files-empty,
.deleted-files-empty-icon { align-items: center; justify-content: center; }
.deleted-files-empty { display: flex; flex-direction: column; gap: .45rem; color: var(--color-text-secondary) !important; }
.deleted-files-empty-icon { display: inline-flex; width: 56px; height: 56px; margin-bottom: .35rem; color: var(--color-primary); background: var(--color-primary-soft); border: 1px solid rgb(255 90 61 / 18%); border-radius: 16px; }
.deleted-files-empty strong { color: var(--color-text); font-family: var(--font-display); font-size: 1rem; }
.deleted-files-empty span:not(.deleted-files-empty-icon) { max-width: 420px; line-height: 1.55; }

.delete-file-page {
  position: relative;
  isolation: isolate;
  min-height: calc(100vh - 72px);
  padding: 3.5rem 0 4.5rem;
  color: var(--color-text);
  overflow: hidden;
}

.delete-file-page::before {
  position: absolute;
  z-index: -2;
  inset: 0;
  content: "";
  background:
    linear-gradient(rgb(18 20 23 / 4%) 1px, transparent 1px),
    linear-gradient(90deg, rgb(18 20 23 / 4%) 1px, transparent 1px),
    radial-gradient(circle at 78% 6%, rgb(255 90 61 / 14%), transparent 24rem);
  background-size: 64px 64px, 64px 64px, auto;
  opacity: .95;
}

.delete-file-shell {
  width: min(720px, calc(100% - 2rem));
  margin: 0 auto;
}

.delete-file-hero {
  margin-bottom: 1.15rem;
  text-align: center;
}

.delete-file-kicker {
  display: inline-flex;
  margin-bottom: .65rem;
  padding: .35rem .65rem;
  color: var(--color-primary-deep);
  background: var(--color-primary-soft);
  border: 1px solid rgb(255 90 61 / 22%);
  border-radius: 999px;
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.delete-file-hero h1 {
  margin: 0;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: clamp(2.7rem, 8vw, 5rem);
  font-weight: 700;
  line-height: .92;
}

.delete-file-hero p {
  max-width: 520px;
  margin: .8rem auto 0;
  color: var(--color-text-secondary);
  font-size: .84rem;
  line-height: 1.65;
}

.delete-file-status,
.delete-file-card {
  color: var(--color-text);
  background: color-mix(in srgb, var(--color-surface) 94%, transparent);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-md);
}

.delete-file-status {
  display: flex;
  align-items: center;
  gap: .65rem;
  margin-bottom: 1rem;
  padding: .85rem 1rem;
  border-radius: var(--radius-md);
  color: var(--color-success);
  font-size: .78rem;
  font-weight: 750;
}

.delete-file-status-icon {
  display: inline-flex;
  width: 34px;
  height: 34px;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, var(--color-success) 12%, var(--color-surface));
  border: 1px solid color-mix(in srgb, var(--color-success) 30%, var(--color-border));
  border-radius: 10px;
}

.delete-file-status svg,
.delete-file-icon svg,
.delete-file-warning svg,
.delete-file-submit svg {
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.delete-file-status svg { width: 18px; height: 18px; stroke-width: 2.2; }

.delete-file-card {
  position: relative;
  overflow: hidden;
  padding: 1.35rem;
  border-radius: var(--radius-lg);
}

.delete-file-card-glow {
  position: absolute;
  top: -90px;
  right: -90px;
  width: 220px;
  height: 220px;
  background: radial-gradient(circle, rgb(255 90 61 / 24%), transparent 66%);
  pointer-events: none;
}

.delete-file-icon {
  display: inline-flex;
  width: 72px;
  height: 72px;
  align-items: center;
  justify-content: center;
  color: var(--color-error);
  background: color-mix(in srgb, var(--color-error) 9%, var(--color-surface));
  border: 1px solid color-mix(in srgb, var(--color-error) 28%, var(--color-border));
  border-radius: 20px;
  box-shadow: 0 18px 40px rgb(239 68 68 / 12%);
}

.delete-file-icon svg {
  width: 36px;
  height: 36px;
  stroke-width: 1.65;
}

.delete-file-copy {
  margin-top: 1.05rem;
}

.delete-file-copy h2 {
  margin: 0;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: clamp(1.7rem, 5vw, 2.6rem);
  font-weight: 700;
  line-height: 1;
}

.delete-file-copy p {
  margin: .55rem 0 0;
  color: var(--color-text-secondary);
  font-size: .8rem;
  line-height: 1.6;
}

.delete-file-target {
  margin-top: 1.05rem;
  padding: 1rem;
  background:
    linear-gradient(135deg, rgb(255 90 61 / 8%), transparent 66%),
    var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.delete-file-target-label {
  display: block;
  margin-bottom: .45rem;
  color: var(--color-text-secondary);
  font-size: .64rem;
  font-weight: 850;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.delete-file-target strong {
  display: block;
  overflow-wrap: anywhere;
  color: var(--color-text);
  font-family: var(--font-mono);
  font-size: clamp(.96rem, 3vw, 1.2rem);
  font-weight: 800;
  line-height: 1.35;
}

.delete-file-warning {
  display: flex;
  align-items: flex-start;
  gap: .65rem;
  margin-top: 1rem;
  padding: .85rem;
  color: var(--color-error);
  background: color-mix(in srgb, var(--color-error) 7%, var(--color-surface));
  border: 1px solid color-mix(in srgb, var(--color-error) 26%, var(--color-border));
  border-radius: var(--radius-sm);
  font-size: .74rem;
  font-weight: 700;
  line-height: 1.55;
}

.delete-file-warning svg {
  flex: 0 0 18px;
  width: 18px;
  height: 18px;
  margin-top: .08rem;
  stroke-width: 1.9;
}

.delete-file-extra {
  margin-top: 1rem;
  padding: .85rem;
  color: var(--color-text-secondary);
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: .74rem;
}

.delete-file-actions {
  display: flex;
  gap: .65rem;
  margin-top: 1.1rem;
}

.delete-file-actions .btn {
  display: inline-flex;
  min-height: 46px;
  align-items: center;
  justify-content: center;
  gap: .45rem;
  border-radius: var(--radius-sm);
  font-size: .76rem;
  font-weight: 850;
}

.delete-file-submit {
  flex: 1 1 auto;
  --bs-btn-bg: var(--color-error);
  --bs-btn-border-color: var(--color-error);
  --bs-btn-hover-bg: #d73535;
  --bs-btn-hover-border-color: #d73535;
}

.delete-file-submit svg {
  width: 17px;
  height: 17px;
  stroke-width: 1.9;
}

.delete-file-cancel {
  flex: 0 0 auto;
  min-width: 132px;
  color: var(--color-text-secondary);
  background: transparent;
  border-color: var(--color-border);
}

.delete-file-cancel:hover {
  color: var(--color-text);
  background: var(--color-surface-alt);
  border-color: var(--color-border);
}

[data-theme="dark"] .delete-file-page::before {
  background:
    linear-gradient(rgb(245 247 250 / 4.5%) 1px, transparent 1px),
    linear-gradient(90deg, rgb(245 247 250 / 4.5%) 1px, transparent 1px),
    radial-gradient(circle at 78% 6%, rgb(255 90 61 / 20%), transparent 24rem);
  background-size: 64px 64px, 64px 64px, auto;
}

.removed-file-page {
  position: relative;
  isolation: isolate;
  display: grid;
  min-height: calc(100vh - 72px);
  place-items: center;
  padding: 4rem 1rem;
  color: var(--color-text);
  overflow: hidden;
}

.removed-file-page::before {
  position: absolute;
  z-index: -2;
  inset: 0;
  content: "";
  background:
    linear-gradient(rgb(18 20 23 / 4%) 1px, transparent 1px),
    linear-gradient(90deg, rgb(18 20 23 / 4%) 1px, transparent 1px),
    radial-gradient(circle at 50% 18%, rgb(255 90 61 / 14%), transparent 28rem);
  background-size: 64px 64px, 64px 64px, auto;
}

.removed-file-alert {
  position: relative;
  width: min(920px, 100%);
  overflow: hidden;
  padding: clamp(1.25rem, 4vw, 2rem);
  color: var(--color-text);
  background:
    linear-gradient(135deg, rgb(255 90 61 / 10%), transparent 54%),
    color-mix(in srgb, var(--color-surface) 95%, transparent);
  border: 1px solid color-mix(in srgb, var(--color-error) 34%, var(--color-border));
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  text-align: center;
}

.removed-file-alert::before {
  position: absolute;
  top: -120px;
  left: 50%;
  width: 320px;
  height: 320px;
  content: "";
  background: radial-gradient(circle, rgb(255 90 61 / 22%), transparent 68%);
  transform: translateX(-50%);
  pointer-events: none;
}

.removed-file-icon {
  position: relative;
  z-index: 1;
  display: inline-flex;
  width: 94px;
  height: 94px;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  background:
    linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));
  border: 1px solid rgb(255 90 61 / 34%);
  border-radius: 24px;
  box-shadow: 0 24px 50px rgb(255 90 61 / 24%);
}

.removed-file-icon::after {
  position: absolute;
  right: -10px;
  bottom: -10px;
  display: inline-flex;
  width: 34px;
  height: 34px;
  align-items: center;
  justify-content: center;
  color: #fff;
  background: var(--color-error);
  border: 4px solid var(--color-surface);
  border-radius: 999px;
  content: "×";
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 700;
  content: "\00d7";
  line-height: 1;
}

.removed-file-icon svg,
.removed-file-reason svg {
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.removed-file-icon svg {
  width: 48px;
  height: 48px;
  color: #fff;
  stroke-width: 1.65;
}

.missing-file-icon {
  background:
    linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));
}

.missing-file-icon::after {
  background: #2563eb;
  content: "?";
  font-size: 1.1rem;
}

.removed-file-name {
  position: relative;
  z-index: 1;
  max-width: 100%;
  margin: 1.45rem auto .95rem;
  overflow-wrap: anywhere;
  color: var(--color-primary);
  font-family: var(--font-mono);
  font-size: clamp(.82rem, 2vw, 1rem);
  font-weight: 750;
  line-height: 1.45;
}

.removed-file-alert h1 {
  position: relative;
  z-index: 1;
  max-width: 780px;
  margin: 0 auto;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: clamp(2rem, 6vw, 4.2rem);
  font-weight: 700;
  line-height: .96;
  letter-spacing: .01em;
}

.missing-file-intro {
  position: relative;
  z-index: 1;
  max-width: 620px;
  margin: 1rem auto 0;
  color: var(--color-text-secondary);
  font-size: clamp(.82rem, 2vw, .95rem);
  font-weight: 650;
  line-height: 1.65;
}

.removed-file-reason {
  position: relative;
  z-index: 1;
  margin-top: clamp(1.5rem, 5vw, 2.25rem);
  padding: 1rem;
  color: var(--color-error);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--color-error) 10%, transparent), transparent 58%),
    color-mix(in srgb, var(--color-error) 5%, var(--color-surface));
  border: 1px solid color-mix(in srgb, var(--color-error) 48%, var(--color-border));
  border-radius: var(--radius-md);
  text-align: left;
}

.removed-file-reason-label {
  display: flex;
  align-items: center;
  gap: .55rem;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: clamp(1rem, 2.6vw, 1.35rem);
  font-weight: 700;
  line-height: 1.1;
}

.removed-file-reason-label svg {
  flex: 0 0 20px;
  width: 20px;
  height: 20px;
  color: var(--color-error);
  stroke-width: 1.9;
}

.removed-file-reason-text {
  margin-top: .65rem;
  overflow-wrap: anywhere;
  color: var(--color-error);
  font-family: var(--font-mono);
  font-size: clamp(.92rem, 2.3vw, 1.1rem);
  font-weight: 700;
  line-height: 1.45;
}

.missing-file-reasons {
  color: var(--color-primary);
  background:
    linear-gradient(135deg, rgb(255 90 61 / 9%), transparent 58%),
    color-mix(in srgb, var(--color-primary) 5%, var(--color-surface));
  border-color: color-mix(in srgb, var(--color-primary) 40%, var(--color-border));
}

.missing-file-list {
  display: grid;
  gap: .55rem;
  margin: .75rem 0 0;
  padding: 0;
  list-style: none;
}

.missing-file-list li {
  position: relative;
  padding-left: 1.15rem;
  overflow-wrap: anywhere;
  color: var(--color-text-secondary);
  font-family: var(--font-mono);
  font-size: clamp(.82rem, 2vw, .95rem);
  font-weight: 750;
  line-height: 1.45;
}

.missing-file-list li::before {
  position: absolute;
  top: .45em;
  left: 0;
  width: 7px;
  height: 7px;
  background: var(--color-primary);
  border-radius: 999px;
  box-shadow: 0 0 0 4px rgb(255 90 61 / 10%);
  content: "";
}

[data-theme="dark"] .delete-file-page::before {
  background:
    linear-gradient(rgb(245 247 250 / 4.5%) 1px, transparent 1px),
    linear-gradient(90deg, rgb(245 247 250 / 4.5%) 1px, transparent 1px),
    radial-gradient(circle at 78% 6%, rgb(255 90 61 / 20%), transparent 24rem);
  background-size: 64px 64px, 64px 64px, auto;
}

[data-theme="dark"] .removed-file-page::before {
  background:
    linear-gradient(rgb(245 247 250 / 4.5%) 1px, transparent 1px),
    linear-gradient(90deg, rgb(245 247 250 / 4.5%) 1px, transparent 1px),
    radial-gradient(circle at 50% 18%, rgb(255 90 61 / 20%), transparent 28rem);
  background-size: 64px 64px, 64px 64px, auto;
}

[data-theme="dark"] .removed-file-icon::after {
  border-color: var(--color-surface);
}

.file-manager-page .control-buttons { position: static; z-index: 20; display: block; overflow: visible; margin-top: .85rem; padding: .75rem; background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: var(--radius-sm); box-shadow: none; backdrop-filter: none; }
.file-manager-bulk-actions { align-items: center; overflow: visible; flex-wrap: wrap; }
.file-manager-selection-status { display: inline-flex; min-height: 40px; align-items: center; gap: .35rem; padding: 0 .75rem; color: var(--color-text); border-right: 1px solid var(--color-border); font-size: .68rem; white-space: nowrap; }
.file-manager-selection-count { font-family: var(--font-display); font-size: .8rem; font-weight: 700; }
.file-manager-bulk-actions .btn,
.file-manager-bulk-actions .form-select { min-height: 40px; }
.file-manager-bulk-actions .btn { display: inline-flex; align-items: center; justify-content: center; white-space: nowrap; font-size: .7rem; }
.file-manager-bulk-actions .form-select { min-width: 180px; color: var(--color-text); background-color: var(--color-surface-alt); border-color: var(--color-border); font-size: .7rem; }
.file-manager-bulk-actions .btn-danger { --bs-btn-bg: var(--color-error); --bs-btn-border-color: var(--color-error); }
.file-manager-bulk-actions .dropdown { position: relative; }
.file-manager-bulk-actions .dropdown-menu { z-index: 1080; min-width: 190px; max-height: min(420px, 70vh); overflow-y: auto; background: var(--color-surface); border-color: var(--color-border); box-shadow: var(--shadow-md); }
.file-manager-bulk-actions .dropdown-item { color: var(--color-text); font-size: .66rem; }
.file-manager-bulk-actions .dropdown-item:hover { color: var(--color-primary); background: var(--color-primary-soft); }

.file-manager-modal .modal-content { overflow: hidden; color: var(--color-text); background: var(--color-surface); border: 1px solid var(--color-border) !important; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }
.file-manager-modal .modal-header,
.file-manager-modal .modal-footer { background: var(--color-surface); border-color: var(--color-border); }
.file-manager-modal .modal-title { color: var(--color-text); font-family: var(--font-display); font-size: 1rem !important; font-weight: 700; }
.file-manager-modal .modal-body { color: var(--color-text-secondary); background: var(--color-surface); }
.file-manager-modal .form-control,
.file-manager-modal textarea { color: var(--color-text); background: var(--color-surface-alt); border-color: var(--color-border); }
[data-theme="dark"] .file-manager-modal .btn-close { filter: invert(1) grayscale(1); }
[data-theme="dark"] .file-manager-kicker { color: var(--color-primary-hover); }

.ui-autocomplete { z-index: 2100 !important; color: var(--color-text); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-sm); box-shadow: var(--shadow-md); }
.ui-menu .ui-menu-item-wrapper { padding: .55rem .75rem; color: var(--color-text-secondary); font-family: var(--font-body); font-size: .7rem; }
.ui-menu .ui-state-active { margin: 0; color: var(--color-text); background: var(--color-surface-alt); border-color: transparent; }


/* Reports */
.reports-page { color: var(--color-text); font-size: .875rem; }
.reports-hero { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 1.5rem; align-items: end; margin-bottom: 1.5rem; }
.reports-kicker { display: inline-flex; margin-bottom: .55rem; padding: .35rem .65rem; color: var(--color-primary-deep); background: var(--color-primary-soft); border: 1px solid rgb(255 90 61 / 22%); border-radius: 999px; font-size: .68rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.reports-hero h1 { margin: 0; color: var(--color-text); font-family: var(--font-display); font-size: clamp(2.15rem, 4vw, 3.15rem); font-weight: 700; line-height: 1; }
.reports-hero p { max-width: 720px; margin: .65rem 0 0; color: var(--color-text-secondary); font-size: .8rem; line-height: 1.65; }
.reports-range-card,
.reports-metric-card,
.reports-panel { color: var(--color-text); background: var(--color-surface); border: 1px solid var(--color-border); box-shadow: var(--shadow-sm); }
.reports-range-card { min-width: min(440px, 100%); padding: .85rem; border-radius: var(--radius-lg); }
.reports-range-form { display: grid; grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr) auto; gap: .65rem; align-items: end; }
.reports-date-field { display: grid; gap: .35rem; margin: 0; }
.reports-date-field span { color: var(--color-text-secondary); font-size: .58rem; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; }
.reports-date-field .form-control { min-height: 42px; color: var(--color-text); background: var(--color-surface-alt); border-color: var(--color-border); border-radius: var(--radius-sm); font-size: .7rem; }
.reports-date-field .form-control:focus { color: var(--color-text); background: var(--color-surface-alt); border-color: var(--color-primary); box-shadow: 0 0 0 3px rgb(255 90 61 / 16%); }
.reports-range-separator { width: 14px; height: 1px; margin-bottom: 21px; background: var(--color-text-secondary); opacity: .65; }
.reports-show-button { min-height: 42px; align-self: end; gap: .4rem; white-space: nowrap; }
.reports-metrics-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 1rem; margin-bottom: 1.5rem; }
.reports-metric-card { min-width: 0; padding: 1rem; border-radius: var(--radius-lg); transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease; }
.reports-metric-card:hover { border-color: rgb(255 90 61 / 28%); box-shadow: var(--shadow-md); transform: translateY(-1px); }
.reports-metric-label { display: flex; align-items: center; justify-content: space-between; gap: .75rem; color: var(--color-text-secondary); font-size: .64rem; font-weight: 750; }
.reports-metric-icon { display: inline-flex; flex: 0 0 32px; width: 32px; height: 32px; align-items: center; justify-content: center; color: var(--color-primary); background: var(--color-primary-soft); border: 1px solid rgb(255 90 61 / 22%); border-radius: 10px; font-size: .62rem; font-weight: 900; }
.reports-metric-card strong { display: block; margin-top: .8rem; overflow: hidden; color: var(--color-text); font-family: var(--font-display); font-size: clamp(1.25rem, 2.4vw, 1.75rem); font-weight: 700; line-height: 1; text-overflow: ellipsis; white-space: nowrap; }
.reports-metric-card small { display: block; margin-top: .55rem; overflow: hidden; color: var(--color-success); font-size: .6rem; font-weight: 800; text-overflow: ellipsis; white-space: nowrap; }
.reports-content-grid { display: grid; grid-template-columns: minmax(0, 1.45fr) minmax(300px, .55fr); gap: 1.5rem; margin-bottom: 1.5rem; }
.reports-panel { overflow: hidden; border-radius: var(--radius-lg); }
.reports-panel-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; padding: 1.1rem 1.1rem 0; }
.reports-panel-header h2 { margin: 0; color: var(--color-text); font-family: var(--font-display); font-size: 1rem; font-weight: 700; line-height: 1.15; }
.reports-panel-header p { margin: .35rem 0 0; color: var(--color-text-secondary); font-size: .68rem; line-height: 1.55; }
.reports-chart-legend { display: flex; flex-wrap: wrap; gap: .5rem; padding: 1rem 1.1rem 0; }
.reports-chart-legend span { display: inline-flex; min-height: 28px; align-items: center; gap: .4rem; padding: 0 .6rem; color: var(--color-text-secondary); background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: 999px; font-size: .6rem; font-weight: 750; }
.reports-swatch { width: 9px; height: 9px; border-radius: 999px; }
.reports-swatch-total { background: var(--color-primary); }
.reports-swatch-downloads { background: #60a5fa; }
.reports-swatch-sales { background: var(--color-success); }
.reports-swatch-rebills { background: var(--color-warning); }
.reports-swatch-websites { background: #a78bfa; }
.reports-chart-wrap { height: 330px; padding: 1.25rem 1.1rem 1.1rem; }
.reports-chart-wrap canvas { width: 100% !important; height: 100% !important; }
.reports-empty-state { display: flex; min-height: 330px; flex-direction: column; align-items: center; justify-content: center; gap: .45rem; padding: 2rem; color: var(--color-text-secondary); text-align: center; }
.reports-empty-icon { display: inline-flex; width: 58px; height: 58px; align-items: center; justify-content: center; margin-bottom: .4rem; color: var(--color-primary); background: var(--color-primary-soft); border: 1px solid rgb(255 90 61 / 18%); border-radius: 16px; }
.reports-empty-state strong { color: var(--color-text); font-family: var(--font-display); font-size: 1.05rem; }
.reports-empty-state span:not(.reports-empty-icon) { max-width: 430px; line-height: 1.55; }
.reports-breakdown-list { display: grid; gap: .75rem; padding: 1.1rem; }
.reports-breakdown-item { display: grid; grid-template-columns: 38px minmax(0, 1fr) auto; gap: .75rem; align-items: center; padding: .75rem; background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: var(--radius-md); }
.reports-breakdown-icon { display: inline-flex; width: 38px; height: 38px; align-items: center; justify-content: center; color: var(--color-primary); background: var(--color-primary-soft); border: 1px solid rgb(255 90 61 / 22%); border-radius: 12px; font-size: .64rem; font-weight: 900; }
.reports-breakdown-item strong { display: block; overflow: hidden; color: var(--color-text); font-size: .68rem; font-weight: 850; text-overflow: ellipsis; white-space: nowrap; }
.reports-breakdown-item small { display: block; margin-top: .2rem; overflow: hidden; color: var(--color-text-secondary); font-size: .58rem; text-overflow: ellipsis; white-space: nowrap; }
.reports-breakdown-item b { color: var(--color-text); font-size: .68rem; white-space: nowrap; }
.reports-table-panel { margin-bottom: 1rem; }
.reports-table-wrap { max-width: 100%; overflow-x: auto; margin-top: 1rem; border-top: 1px solid var(--color-border); scrollbar-width: thin; }
.reports-table { --bs-table-bg: var(--color-surface); --bs-table-color: var(--color-text); --bs-table-border-color: var(--color-border); min-width: 1060px; margin: 0; vertical-align: middle; }
.reports-table thead th { padding: .75rem .85rem; color: var(--color-text-secondary); background: var(--color-surface-alt); border-bottom-width: 1px; font-size: .6rem; font-weight: 800; letter-spacing: .03em; text-transform: uppercase; white-space: nowrap; }
.reports-table tbody td,
.reports-table tfoot td { padding: .78rem .85rem; color: var(--color-text-secondary); border-color: var(--color-border); font-size: .68rem; white-space: nowrap; }
.reports-table tbody tr:hover td { background: color-mix(in srgb, var(--color-primary) 3%, var(--color-surface)); }
.reports-table tfoot td { color: var(--color-text); background: color-mix(in srgb, var(--color-primary) 5%, var(--color-surface)); font-weight: 850; }
.reports-date-pill { display: inline-flex; min-height: 27px; align-items: center; padding: 0 .55rem; color: var(--color-text); background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: 999px; font-weight: 800; }
.reports-money-link { color: var(--color-primary); font-weight: 800; text-decoration: none; }
.reports-money-link:hover { color: var(--color-primary-hover); text-decoration: underline; text-underline-offset: 3px; }
.reports-refund-link { color: var(--color-error); }
.reports-total-cell { color: var(--color-text) !important; font-weight: 900; }
.reports-empty-row { padding: 1.75rem !important; color: var(--color-text-secondary) !important; text-align: center; }
.reports-page .ui-datepicker,
#ui-datepicker-div { color: var(--color-text); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); box-shadow: var(--shadow-md); }
.reports-page .ui-datepicker-header,
#ui-datepicker-div .ui-datepicker-header { color: var(--color-text); background: var(--color-surface-alt); border: 0; border-radius: var(--radius-sm); }
#ui-datepicker-div .ui-state-default { color: var(--color-text); background: var(--color-surface-alt); border-color: var(--color-border); }
#ui-datepicker-div .ui-state-active,
#ui-datepicker-div .ui-state-hover { color: #fff; background: var(--color-primary); border-color: var(--color-primary); }
[data-theme="dark"] .reports-kicker { color: var(--color-primary-hover); }


@media (max-width: 1199.98px) {
  .file-manager-folder-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .file-manager-bulk-actions .btn { width: auto !important; min-width: 40px; height: 40px; padding: .45rem .65rem !important; font-size: .68rem !important; }
  .file-manager-bulk-actions .btn svg { margin-right: .35rem !important; }
  .reports-hero { grid-template-columns: 1fr; align-items: stretch; }
  .reports-range-card { min-width: 0; }
  .reports-metrics-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .reports-content-grid { grid-template-columns: 1fr; }
}

@media (max-width: 767.98px) {
  .file-manager-page { font-size: .8rem; }
  .reports-page { font-size: .8rem; }
  .reports-hero { gap: 1rem; margin-bottom: 1rem; }
  .reports-hero h1 { font-size: 2.15rem; }
  .reports-hero p { font-size: .75rem; }
  .reports-range-card { padding: .75rem; border-radius: var(--radius-md); }
  .reports-range-form { grid-template-columns: 1fr; gap: .65rem; }
  .reports-range-separator { width: 100%; margin: 0; }
  .reports-show-button { width: 100%; }
  .reports-metrics-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .75rem; margin-bottom: 1rem; }
  .reports-metric-card { padding: .85rem; }
  .reports-metric-card strong { font-size: 1.35rem; }
  .reports-metric-total { grid-column: 1 / -1; }
  .reports-content-grid { gap: 1rem; margin-bottom: 1rem; }
  .reports-panel-header { padding: .9rem .9rem 0; }
  .reports-panel-header p { font-size: .64rem; }
  .reports-chart-legend { padding: .8rem .9rem 0; }
  .reports-chart-wrap { height: 250px; padding: 1rem .9rem .9rem; }
  .reports-breakdown-list { padding: .9rem; }
  .reports-table-panel { overflow: visible; background: transparent; border: 0; box-shadow: none; }
  .reports-table-panel .reports-panel-header { padding: 0 0 .75rem; }
  .reports-table-wrap { overflow: visible; margin-top: 0; border-top: 0; }
  .reports-table,
  .reports-table tbody { display: block; width: 100%; min-width: 0; }
  .reports-table thead,
  .reports-table tfoot { display: none; }
  .reports-table tbody { display: grid; gap: .75rem; }
  .reports-table tbody tr { display: grid; gap: .45rem; padding: .85rem; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); box-shadow: var(--shadow-sm); }
  .reports-table tbody td { display: flex; align-items: center; justify-content: space-between; gap: .85rem; min-width: 0; padding: .45rem 0; background: transparent !important; border: 0; border-bottom: 1px solid var(--color-border); font-size: .68rem; white-space: normal; }
  .reports-table tbody td:last-child { border-bottom: 0; }
  .reports-table tbody td::before { flex: 0 0 auto; color: var(--color-text-secondary); content: attr(data-label); font-size: .58rem; font-weight: 800; letter-spacing: .02em; text-transform: uppercase; }
  .reports-date-pill { padding: 0; background: transparent; border: 0; }
  .reports-empty-row { display: block !important; padding: 1.5rem !important; }
  .file-manager-heading { margin-bottom: 1rem; }
  .file-manager-heading h1 { font-size: 2.15rem; }
  .file-manager-heading p { font-size: .75rem; }
  .file-manager-toolbar { padding: .85rem; border-radius: var(--radius-md); }
  .file-manager-toolbar > .row { align-items: stretch !important; }
  .file-manager-toolbar > .row > * { width: 100%; }
  .file-manager-toolbar .row.flex-nowrap { flex-wrap: wrap !important; }
  .file-manager-toolbar .row.flex-nowrap > * { width: 100%; }
  .file-manager-new-folder,
  .file-manager-publish,
  .file-manager-search { width: 100%; }
  .file-manager-new-folder { justify-content: center; }
  .file-manager-publish { justify-content: center; }
  .file-manager-stats { display: flex; width: 100%; justify-content: center; white-space: normal; text-align: center; }
  .file-manager-activity-card,
  .file-manager-list-card { padding: .75rem; }
  .file-manager-section-header { padding: .25rem .25rem .8rem; }
  .file-manager-section-header p { font-size: .64rem; }
  .file-manager-folders-section,
  .file-manager-files-section { padding: .75rem; }
  .file-manager-collection-header { align-items: center; margin-bottom: .75rem; }
  .file-manager-collection-header p { font-size: .64rem; }
  .file-manager-folders-toggle { min-height: 34px; padding: .35rem .55rem; border: 0; }
  .file-manager-folder-viewport { margin-right: -.75rem; overflow-x: auto; scroll-padding-inline: 0; scrollbar-width: none; scroll-snap-type: x mandatory; }
  .file-manager-folder-viewport::-webkit-scrollbar { display: none; }
  .file-manager-folder-grid { display: flex; width: max-content; max-height: none; gap: .65rem; padding-right: .75rem; overflow: visible; }
  .file-manager-folder-card { width: min(72vw, 270px); min-height: 150px; grid-template-columns: 34px minmax(0, 1fr) 40px; align-content: start; scroll-snap-align: start; }
  .file-manager-folder-select { align-self: start; padding-top: .85rem; }
  .file-manager-folder-main { flex-direction: column; justify-content: center; gap: .65rem; padding: 1.05rem .25rem .85rem; text-align: center; }
  .file-manager-folder-card-icon { flex-basis: 56px; width: 56px; height: 56px; }
  .file-manager-folder-card-icon svg { width: 30px; height: 28px; }
  .file-manager-folder-copy { align-items: center; }
  .file-manager-folder-copy strong { max-width: 150px; font-size: .76rem; }
  .file-manager-folder-copy small { font-size: .66rem; }
  .file-manager-folder-menu { align-self: start; padding-top: .55rem; }
  .file-manager-parent-folder-card { width: min(72vw, 270px); grid-template-columns: minmax(0, 1fr); }
  .file-manager-parent-folder-card .file-manager-folder-main { min-height: 148px; }
  .file-manager-folders-section.is-expanded .file-manager-folder-viewport { margin-right: 0; overflow: visible; }
  .file-manager-folders-section.is-expanded .file-manager-folder-grid { display: grid; width: 100%; grid-template-columns: repeat(2, minmax(0, 1fr)); padding-right: 0; }
  .file-manager-folders-section.is-expanded .file-manager-folder-card { width: auto; min-width: 0; }
  .file-manager-activity-table { min-width: 680px; }
  .deleted-files-hero { align-items: stretch; flex-direction: column; }
  .deleted-files-hide-button { width: 100%; }
  .deleted-files-table-wrap { overflow: visible; border: 0; border-radius: 0; }
  .deleted-files-table,
  .deleted-files-table tbody { display: block; width: 100%; min-width: 0; }
  .deleted-files-table thead { display: none; }
  .deleted-files-table tbody { display: grid; gap: .7rem; }
  .deleted-files-table tbody tr { display: grid; gap: .65rem; padding: .75rem; background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: var(--radius-sm); }
  .deleted-files-table tbody td { display: block; min-width: 0; padding: 0; background: transparent !important; border: 0; }
  .deleted-files-name { min-width: 0; }
  .deleted-files-code-cell,
  .deleted-files-age-cell { display: flex !important; align-items: center; justify-content: space-between; gap: .75rem; color: var(--color-text-secondary); }
  .deleted-files-code-cell::before,
  .deleted-files-age-cell::before { content: attr(data-label); font-size: .58rem; font-weight: 750; letter-spacing: .02em; text-transform: uppercase; }
  .deleted-files-empty { display: flex !important; padding: 1.5rem !important; }
  .delete-file-page { min-height: auto; padding: 1.5rem 0 2.75rem; }
  .delete-file-shell { width: min(100% - 1rem, 720px); }
  .delete-file-hero { margin-bottom: 1rem; text-align: left; }
  .delete-file-hero h1 { font-size: clamp(2.4rem, 15vw, 3.8rem); }
  .delete-file-hero p { margin-left: 0; font-size: .76rem; }
  .delete-file-card { padding: 1rem; border-radius: var(--radius-md); }
  .delete-file-icon { width: 60px; height: 60px; border-radius: 16px; }
  .delete-file-icon svg { width: 30px; height: 30px; }
  .delete-file-copy h2 { font-size: 1.8rem; }
  .delete-file-target { padding: .85rem; }
  .delete-file-actions { flex-direction: column; }
  .delete-file-actions .btn,
  .delete-file-cancel { width: 100%; min-width: 0; }
  .removed-file-page { min-height: auto; padding: 1.5rem .5rem 2.75rem; place-items: start center; }
  .removed-file-alert { padding: 1rem; border-radius: var(--radius-md); }
  .removed-file-icon { width: 72px; height: 72px; border-radius: 18px; }
  .removed-file-icon::after { right: -8px; bottom: -8px; width: 28px; height: 28px; border-width: 3px; font-size: 1.05rem; }
  .removed-file-icon svg { width: 38px; height: 38px; }
  .removed-file-name { margin: 1.15rem auto .8rem; font-size: .78rem; }
  .removed-file-alert h1 { font-size: clamp(2rem, 12vw, 3rem); }
  .missing-file-intro { font-size: .76rem; }
  .removed-file-reason { margin-top: 1.25rem; padding: .85rem; border-radius: var(--radius-sm); }
  .removed-file-reason-label { font-size: 1rem; }
  .removed-file-reason-text { font-size: .86rem; }
  .missing-file-list li { font-size: .78rem; }
  .file-manager-files-section .file-manager-table-wrap { overflow: visible; border: 0; border-radius: 0; }
  .file-manager-files-table,
  .file-manager-files-table tbody { display: block; width: 100%; min-width: 0; }
  .file-manager-files-table thead { display: none; }
  .file-manager-files-table tbody { display: grid; gap: .7rem; }
  .file-manager-files-table tbody tr { display: grid; grid-template-columns: 36px minmax(0, 1fr) auto auto; gap: .55rem .7rem; align-items: center; padding: .75rem; background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: var(--radius-sm); }
  .file-manager-files-table tbody td { display: block; min-width: 0; padding: 0; background: transparent !important; border: 0; font-size: .68rem; }
  .file-manager-files-table .file-manager-item-select { grid-column: 1; grid-row: 1 / span 2; align-self: center; }
  .file-manager-files-table .file-manager-item-name { grid-column: 2 / 4; grid-row: 1; }
  .file-manager-files-table .file-manager-item-name a { width: 100%; min-width: 0; }
  .file-manager-files-table .file-manager-item-name .text-truncate { min-width: 0; }
  .file-manager-files-table .file-manager-item-icon { flex-basis: 42px; width: 42px; height: 42px; border-radius: 11px; }
  .file-manager-files-table .file-manager-item-actions { grid-column: 4; grid-row: 1; display: flex; align-items: center; justify-content: flex-end; }
  .file-manager-files-table .file-manager-action-button { width: 36px; height: 36px; }
  .file-manager-files-table .file-manager-folder-spacer { display: none; }
  .file-manager-files-table .file-manager-item-meta { display: inline-flex; grid-column: 2; align-items: center; gap: .35rem; color: var(--color-text-secondary); }
  .file-manager-files-table .file-manager-item-meta::before { color: var(--color-text-secondary); content: attr(data-label) ":"; font-size: .58rem; font-weight: 750; text-transform: uppercase; }
  .file-manager-files-table .file-manager-item-size { grid-row: 2; }
  .file-manager-files-table .file-manager-item-upload { grid-row: 3; }
  .file-manager-files-table .file-manager-item-downloads { grid-row: 4; }
  .file-manager-files-table .file-manager-item-comments { grid-row: 5; }
  .file-manager-files-table .file-manager-item-price { grid-row: 6; }
  .file-manager-files-table .file-manager-item-flag { display: grid; grid-template-columns: auto auto; align-items: center; gap: .35rem; color: var(--color-text-secondary); }
  .file-manager-files-table .file-manager-item-flag::before { content: attr(data-label); font-size: .6rem; }
  .file-manager-files-table .file-manager-item-premium { grid-column: 3; grid-row: 2; }
  .file-manager-files-table .file-manager-item-public { grid-column: 4; grid-row: 2; }
  .file-manager-files-table .form-switcher { min-height: 30px; }
  .file-manager-files-table .file-manager-parent-row .file-manager-item-select { visibility: hidden; }
  .file-manager-files-table .file-manager-empty-state { display: block; grid-column: 1 / -1; padding: 1.5rem !important; }
  .file-manager-page .control-buttons { position: sticky; z-index: 20; bottom: .5rem; overflow: visible; margin: .85rem 0 0; padding: .55rem; background: color-mix(in srgb, var(--color-surface) 96%, transparent); box-shadow: var(--shadow-md); backdrop-filter: blur(14px); }
  .file-manager-bulk-actions { display: grid; grid-template-columns: auto minmax(96px, 1fr) 44px 44px 44px; gap: .35rem !important; overflow: visible; }
  .file-manager-bulk-actions > * { width: auto; padding: 0; }
  .file-manager-selection-status { min-height: 44px; padding: 0 .5rem; border-right: 1px solid var(--color-border); }
  .file-manager-bulk-actions .form-select { width: 100%; min-width: 112px; height: 44px; }
  .file-manager-bulk-actions .btn { width: 44px !important; min-width: 44px; height: 44px; padding: 0 !important; font-size: 0 !important; border-radius: 9px; }
  .file-manager-bulk-actions .btn svg { width: 16px; height: 16px; margin: 0 !important; }
  .file-manager-bulk-copy,
  .file-manager-bulk-export,
  .file-manager-bulk-zip { display: none !important; }
  .file-manager-bulk-actions .ms-auto { margin-left: 0 !important; }
  .file-manager-bulk-more { grid-column: 5; }
  .file-manager-bulk-more .dropdown-menu { position: absolute !important; right: 0 !important; bottom: calc(100% + .45rem) !important; left: auto !important; margin: 0 !important; transform: none !important; }
  .file-manager-modal .modal-dialog { margin: .75rem; }
  .file-manager-modal .modal-footer { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .file-manager-modal .modal-footer .btn,
  .file-manager-modal .modal-footer input { width: 100%; margin: 0; }
}
