:root {
  color-scheme: dark;
  --bg: #0d0e13;
  --panel: #17151c;
  --panel-2: #211b21;
  --line: rgba(255, 255, 255, 0.12);
  --text: #f6f2eb;
  --muted: #b7a99d;
  --gold: #f3b84b;
  --gold-2: #ffe0a1;
  --violet: #8a6cff;
  --ember: #f06445;
  --green: #56c08d;
  --shadow: rgba(0, 0, 0, 0.45);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-width: 320px;
  background:
    radial-gradient(circle at 10% 0%, rgba(138, 108, 255, 0.18), transparent 30rem),
    linear-gradient(180deg, #111016 0%, var(--bg) 38rem, #0b0c10 100%);
  color: var(--text);
  font-family:
    Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.5;
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  max-width: 100%;
  display: block;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 1rem;
  padding: 0.75rem 1rem;
  background: rgba(13, 14, 19, 0.86);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(16px);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  font-weight: 800;
  white-space: nowrap;
}

.brand img {
  width: 2rem;
  height: 2rem;
  border-radius: 6px;
}

.site-header nav {
  display: flex;
  justify-content: center;
  gap: 1.2rem;
  color: var(--muted);
  font-size: 0.95rem;
}

.site-header nav a:hover,
.site-header nav a:focus-visible {
  color: var(--gold-2);
}

.header-cta,
.account-button,
.admin-header-link,
.primary-action,
.secondary-action {
  display: inline-flex;
  min-height: 2.75rem;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  font-weight: 800;
}

.header-actions {
  display: inline-flex;
  align-items: center;
  justify-content: end;
  gap: 0.55rem;
}

.header-order-lookup {
  display: inline-flex;
  min-height: 2.4rem;
  align-items: stretch;
  overflow: hidden;
  border: 1px solid rgba(246, 184, 75, 0.34);
  border-radius: 8px;
  background: rgba(12, 19, 32, 0.78);
}

.header-order-lookup input {
  width: 7.6rem;
  min-width: 0;
  border: 0;
  background: transparent;
  color: #fff;
  font: inherit;
  font-size: 0.9rem;
  font-weight: 900;
  padding: 0 0.75rem;
  outline: none;
}

.header-order-lookup input::placeholder {
  color: rgba(231, 235, 247, 0.62);
}

.header-order-lookup button {
  width: 2.35rem;
  border: 0;
  border-left: 1px solid rgba(246, 184, 75, 0.2);
  background: rgba(246, 184, 75, 0.16);
  color: var(--gold-2);
  cursor: pointer;
  font: inherit;
  font-weight: 950;
}

.header-account-summary {
  display: inline-grid;
  min-height: 2.4rem;
  min-width: 8.5rem;
  max-width: 16rem;
  align-content: center;
  gap: 0.05rem;
  padding: 0 0.85rem;
  border: 1px solid rgba(86, 192, 141, 0.32);
  border-radius: 8px;
  background: rgba(86, 192, 141, 0.08);
  color: var(--text);
  font: inherit;
  text-align: left;
  cursor: pointer;
}

.header-account-summary strong,
.header-account-summary span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.header-account-summary strong {
  font-size: 0.9rem;
  line-height: 1.1;
}

.header-account-summary span {
  color: var(--gold-2);
  font-size: 0.78rem;
  font-weight: 900;
  line-height: 1.1;
}

.header-cta {
  min-height: 2.4rem;
  padding: 0 1rem;
  background: var(--violet);
  white-space: nowrap;
}

.account-button {
  min-height: 2.4rem;
  padding: 0 0.9rem;
  border: 1px solid rgba(243, 184, 75, 0.38);
  background: rgba(243, 184, 75, 0.09);
  color: var(--gold-2);
  font: inherit;
  cursor: pointer;
}

.admin-header-link {
  min-height: 2.4rem;
  padding: 0 0.9rem;
  border: 1px solid rgba(86, 192, 141, 0.44);
  background: rgba(86, 192, 141, 0.1);
  color: #baf3d5;
}

.primary-action {
  padding: 0.8rem 1.1rem;
  background: linear-gradient(135deg, var(--gold), #d88a34 55%, var(--ember));
  color: #211307;
  box-shadow: 0 0.75rem 2rem rgba(240, 100, 69, 0.24);
}

.secondary-action {
  padding: 0.75rem 1rem;
  border: 1px solid rgba(255, 255, 255, 0.22);
  color: var(--text);
  background: rgba(255, 255, 255, 0.04);
}

.hero {
  position: relative;
  min-height: 38rem;
  display: flex;
  align-items: end;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}

.hero-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.05) contrast(1.05);
}

.hero-shade {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(10, 8, 10, 0.96), rgba(10, 8, 10, 0.68) 44%, rgba(10, 8, 10, 0.18)),
    linear-gradient(0deg, rgba(13, 14, 19, 0.96), rgba(13, 14, 19, 0.05) 45%);
}

.hero-content {
  position: relative;
  width: min(74rem, 100%);
  padding: 8rem 1rem 3.2rem;
  margin: 0 auto;
}

.eyebrow,
.section-kicker {
  margin: 0 0 0.5rem;
  color: var(--gold-2);
  font-size: 0.82rem;
  font-weight: 900;
  text-transform: uppercase;
}

.hero h1 {
  max-width: 46rem;
  margin: 0;
  font-size: 4.5rem;
  line-height: 0.98;
  letter-spacing: 0;
}

.hero-copy {
  max-width: 44rem;
  margin: 1.1rem 0 0;
  color: #efe1d0;
  font-size: 1.15rem;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.6rem;
}

.hero-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 12rem));
  gap: 0.75rem;
  padding: 0;
  margin: 2.5rem 0 0;
  list-style: none;
}

.hero-stats li {
  border-left: 2px solid var(--gold);
  padding-left: 0.8rem;
}

.hero-stats strong,
.hero-stats span {
  display: block;
}

.hero-stats span {
  color: var(--muted);
  font-size: 0.9rem;
}

.hot-strip,
.section,
.loot-section,
.site-order-section,
.order-section,
.final-cta {
  width: min(74rem, calc(100% - 2rem));
  margin: 0 auto;
}

.hot-strip {
  display: grid;
  grid-template-columns: minmax(14rem, 0.8fr) 1.6fr;
  gap: 1rem;
  align-items: center;
  padding: 1.2rem 0;
  border-bottom: 1px solid var(--line);
}

.hot-strip h2,
.section-heading h2,
.order-copy h2,
.final-cta h2 {
  margin: 0;
  font-size: 2rem;
  line-height: 1.1;
  letter-spacing: 0;
}

.hot-items {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
}

.hot-items span {
  min-height: 3rem;
  display: flex;
  align-items: center;
  padding: 0.7rem 0.8rem;
  border: 1px solid rgba(243, 184, 75, 0.32);
  border-radius: 8px;
  background: rgba(243, 184, 75, 0.08);
  color: var(--gold-2);
  font-weight: 800;
}

.section,
.loot-section,
.site-order-section {
  padding: 4rem 0 0;
}

.section-heading {
  max-width: 47rem;
  margin-bottom: 1.4rem;
}

.section-heading p,
.order-copy p,
.final-cta p {
  margin: 0.8rem 0 0;
  color: var(--muted);
}

.filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-bottom: 1rem;
}

.filter-button {
  min-height: 2.4rem;
  padding: 0 0.9rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
  color: var(--muted);
  font: inherit;
  font-weight: 800;
  cursor: pointer;
}

.filter-button.is-active {
  color: #160f07;
  background: var(--gold);
  border-color: var(--gold);
}

.order-tabs {
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 0.55rem;
  margin: 0 0 1rem;
}

.order-tab {
  min-height: 3.2rem;
  padding: 0.45rem 0.55rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
  color: var(--muted);
  font: inherit;
  font-weight: 900;
  cursor: pointer;
}

.order-tab span {
  display: block;
  margin-bottom: 0.1rem;
}

.order-tab.is-active {
  color: #160f07;
  background: var(--gold);
  border-color: var(--gold);
}

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

.service-card,
.loot-grid article,
.reviews-grid blockquote {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.025));
  box-shadow: 0 1rem 2.2rem var(--shadow);
}

.service-card {
  min-height: 26rem;
  display: flex;
  flex-direction: column;
  padding: 1rem;
}

.service-card.feature {
  background:
    linear-gradient(180deg, rgba(138, 108, 255, 0.2), rgba(255, 255, 255, 0.03)),
    var(--panel);
  border-color: rgba(138, 108, 255, 0.46);
}

.card-top {
  display: flex;
  justify-content: space-between;
  gap: 0.8rem;
  align-items: center;
  min-height: 2.35rem;
}

.service-icon {
  display: inline-flex;
  width: 2.35rem;
  height: 2.35rem;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.07);
}

.service-tag {
  color: var(--gold-2);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.service-card h3,
.loot-grid h3 {
  margin: 1rem 0 0.45rem;
  font-size: 1.22rem;
  line-height: 1.2;
}

.service-card p,
.loot-grid p {
  margin: 0;
  color: var(--muted);
  font-size: 0.94rem;
}

.price-list {
  display: grid;
  gap: 0.48rem;
  margin: auto 0 0;
  padding-top: 1.2rem;
}

.price-list div {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.75rem;
  align-items: center;
  min-height: 2.45rem;
  padding: 0.45rem 0.55rem;
  border-radius: 7px;
  background: rgba(0, 0, 0, 0.23);
}

.price-list dt {
  color: #eadccd;
  font-weight: 700;
}

.price-list dd {
  margin: 0;
  color: var(--gold-2);
  font-weight: 900;
  text-align: right;
}

.card-order-button {
  min-height: 2.65rem;
  margin-top: 0.8rem;
  border: 1px solid rgba(243, 184, 75, 0.52);
  border-radius: 8px;
  background: rgba(243, 184, 75, 0.12);
  color: var(--gold-2);
  font: inherit;
  font-weight: 900;
  cursor: pointer;
}

.card-order-button:hover,
.card-order-button:focus-visible {
  background: rgba(243, 184, 75, 0.2);
}

.loot-section {
  display: grid;
  grid-template-columns: 0.85fr 1.25fr;
  gap: 1rem;
  align-items: start;
}

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

.loot-grid article {
  min-height: 11rem;
  padding: 1rem;
}

.loot-grid article:nth-child(1) {
  border-color: rgba(86, 192, 141, 0.45);
}

.loot-grid article:nth-child(2) {
  border-color: rgba(243, 184, 75, 0.45);
}

.loot-grid article:nth-child(3) {
  border-color: rgba(138, 108, 255, 0.55);
}

.loot-grid article:nth-child(4) {
  border-color: rgba(240, 100, 69, 0.5);
}

.order-layout {
  display: grid;
  grid-template-columns: 1.35fr 0.65fr;
  gap: 1rem;
  align-items: start;
}

.account-strip {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 0.85rem;
  align-items: center;
  margin-bottom: 1rem;
  padding: 1rem;
  border: 1px solid rgba(243, 184, 75, 0.25);
  border-radius: 8px;
  background: rgba(243, 184, 75, 0.07);
}

.account-strip-main {
  display: flex;
  min-width: 0;
  gap: 0.8rem;
  align-items: center;
}

.account-strip h3 {
  margin: 0.7rem 0 0.25rem;
  font-size: 1.2rem;
}

.account-strip p {
  margin: 0;
  color: var(--muted);
}

.balance-toggle {
  min-height: 2.75rem;
  display: inline-flex !important;
  align-items: center;
  gap: 0.55rem !important;
  padding: 0 0.85rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.24);
  color: var(--text) !important;
  white-space: nowrap;
}

.balance-toggle input {
  position: relative;
  width: 1.05rem;
  height: 1.05rem;
  min-height: 1.05rem;
  flex: 0 0 auto;
  appearance: none;
  border: 1px solid rgba(246, 184, 75, 0.58);
  border-radius: 4px;
  background: rgba(12, 19, 32, 0.85);
  accent-color: var(--gold);
}

.balance-toggle input:checked {
  background: linear-gradient(135deg, var(--gold), #ff6b3d);
  border-color: transparent;
}

.balance-toggle input:checked::after {
  content: "";
  position: absolute;
  left: 0.32rem;
  top: 0.14rem;
  width: 0.28rem;
  height: 0.56rem;
  border: solid #140c06;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.balance-request-control {
  display: grid;
  min-width: 0;
  gap: 0.65rem;
  padding: 0.75rem;
  border: 1px solid rgba(246, 184, 75, 0.22);
  border-radius: 8px;
  background: rgba(246, 184, 75, 0.08);
}

.balance-request-control[hidden] {
  display: none !important;
}

.balance-request-control .balance-toggle {
  width: 100%;
  min-width: 0;
  justify-content: flex-start;
  background: rgba(0, 0, 0, 0.18);
}

.balance-request-control .balance-toggle input {
  width: 1.05rem;
  min-width: 1.05rem;
  max-width: 1.05rem;
  height: 1.05rem;
  min-height: 1.05rem;
  padding: 0;
}

.balance-request-control .balance-toggle span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.balance-amount-field {
  display: grid;
  min-width: 0;
  gap: 0.35rem;
  color: var(--muted);
  font-weight: 900;
}

.balance-amount-field input {
  width: 100%;
  min-height: 2.7rem;
  border: 1px solid rgba(246, 184, 75, 0.26);
  border-radius: 8px;
  background: #0c1320;
  color: #fff;
  font: inherit;
  font-weight: 900;
  padding: 0.65rem 0.75rem;
}

.balance-amount-field small {
  color: var(--muted);
  font-size: 0.82rem;
}

.order-form,
.order-summary {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.025));
  box-shadow: 0 1rem 2.2rem var(--shadow);
}

.order-form {
  padding: 1rem;
}

.flow-head {
  padding: 0 0 1rem;
  border-bottom: 1px solid var(--line);
  margin-bottom: 1rem;
}

.flow-head h3 {
  margin: 0.7rem 0 0.35rem;
  font-size: 1.45rem;
}

.flow-head p {
  margin: 0;
  color: var(--muted);
}

.service-fields {
  display: grid;
  gap: 0.8rem;
}

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

.order-form label {
  display: grid;
  gap: 0.35rem;
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 800;
}

.order-form input,
.order-form select,
.order-form textarea {
  width: 100%;
  min-height: 2.8rem;
  color-scheme: dark;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 8px;
  background-color: #0b0c10;
  color: var(--text);
  font: inherit;
  font-weight: 700;
  outline: none;
}

.order-form select {
  appearance: auto;
  background-color: #0b0c10;
}

.order-form option,
.order-form optgroup {
  background-color: #111016;
  color: #f6f2eb;
}

.order-form option:checked {
  background-color: #3a2a13;
  color: var(--gold-2);
}

.order-form option:hover {
  background-color: #211b21;
  color: var(--text);
}

.order-form input::placeholder,
.order-form textarea::placeholder {
  color: rgba(246, 242, 235, 0.5);
}

.order-form input,
.order-form select {
  padding: 0 0.75rem;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.order-form textarea {
  resize: vertical;
  padding: 0.75rem;
}

.order-form input:focus,
.order-form select:focus,
.order-form textarea:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(243, 184, 75, 0.16);
}

.wide-field {
  margin-top: 0.8rem;
}

.field-grid > .wide-field {
  grid-column: 1 / -1;
  margin-top: 0;
}

.service-fields .field-grid,
.lot-service-fields .field-grid {
  grid-template-columns: 1fr;
}

.common-fields {
  margin-top: 0.8rem;
}

.check-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.55rem;
}

.check-option {
  min-height: 3rem;
  display: flex !important;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 0.55rem !important;
  padding: 0.65rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.22);
  cursor: pointer;
}

.check-option input {
  width: 1rem;
  min-height: 1rem;
  accent-color: var(--gold);
}

.check-option span {
  color: #eadccd;
}

.form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1rem;
}

.form-submit {
  border: 0;
  cursor: pointer;
  font: inherit;
}

.order-summary {
  min-height: 25.6rem;
  padding: 1rem;
  position: sticky;
  top: 6rem;
}

.order-summary h3 {
  margin: 0.7rem 0 0.55rem;
  font-size: 1.35rem;
}

.order-summary p {
  margin: 0;
  color: var(--muted);
}

.summary-id {
  margin-top: 0.35rem !important;
  color: var(--gold-2) !important;
  font-weight: 900;
}

.summary-status {
  display: inline-flex;
  min-height: 2rem;
  align-items: center;
  padding: 0 0.65rem;
  border-radius: 999px;
  background: rgba(138, 108, 255, 0.16);
  color: var(--gold-2);
  font-size: 0.82rem;
  font-weight: 900;
}

.summary-list {
  display: grid;
  gap: 0.55rem;
  margin: 1rem 0;
  padding: 0;
  list-style: none;
}

.summary-list li {
  display: grid;
  grid-template-columns: 7.2rem 1fr;
  gap: 0.65rem;
  min-height: 2.25rem;
  align-items: center;
  padding: 0.45rem 0.55rem;
  border-radius: 7px;
  background: rgba(0, 0, 0, 0.22);
}

.summary-list span {
  color: var(--muted);
  font-size: 0.85rem;
  font-weight: 800;
}

.summary-message {
  width: 100%;
  min-height: 9rem;
  margin-top: 0.8rem;
  padding: 0.75rem;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.22);
  color: #efe2d6;
  font: inherit;
  resize: vertical;
}

.summary-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 0.8rem;
}

.copy-button {
  min-height: 2.6rem;
  padding: 0 0.9rem;
  border: 1px solid rgba(243, 184, 75, 0.5);
  border-radius: 8px;
  background: rgba(243, 184, 75, 0.11);
  color: var(--gold-2);
  font: inherit;
  font-weight: 900;
  cursor: pointer;
}

.copy-button:disabled {
  opacity: 0.55;
  cursor: default;
}

.danger-action {
  border-color: rgba(240, 100, 69, 0.55);
  background: rgba(240, 100, 69, 0.12);
  color: #ffb39f;
}

.range-control {
  display: grid;
  gap: 0.55rem;
  min-height: 4.5rem;
  padding: 0.7rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.22);
}

.range-meta {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  align-items: center;
}

.range-meta strong {
  color: var(--text);
  font-size: 1rem;
}

.range-meta span {
  color: var(--gold-2);
  font-weight: 900;
  text-align: right;
}

.range-control input[type="range"] {
  min-height: 1.8rem;
  padding: 0;
  accent-color: var(--gold);
  background: transparent;
}

.order-price-preview {
  display: grid;
  gap: 0.35rem;
  margin: 1rem 0;
  padding: 0.75rem;
  border: 1px solid rgba(243, 184, 75, 0.28);
  border-radius: 8px;
  background: rgba(243, 184, 75, 0.08);
}

.order-price-preview span {
  color: var(--muted);
  font-weight: 800;
}

.order-price-preview strong {
  color: var(--gold-2);
  font-size: 1.2rem;
}

.my-orders-list {
  display: grid;
  gap: 0.65rem;
}

.my-order-card {
  display: grid;
  gap: 0.45rem;
  padding: 0.75rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.24);
}

.my-order-card strong,
.my-order-card small {
  display: block;
}

.my-order-card p {
  margin: 0;
}

.my-order-card small {
  color: var(--gold-2);
  font-weight: 900;
}

.mini-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-top: 0.45rem;
}

.mini-actions button {
  min-height: 2rem;
  padding: 0 0.55rem;
  border: 1px solid rgba(243, 184, 75, 0.38);
  border-radius: 7px;
  background: rgba(243, 184, 75, 0.1);
  color: var(--gold-2);
  font: inherit;
  font-size: 0.78rem;
  font-weight: 900;
  cursor: pointer;
}

.client-chat {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--line);
}

.client-chat h4 {
  margin: 0 0 0.7rem;
  font-size: 1rem;
}

.chat-log {
  display: grid;
  gap: 0.55rem;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
  scrollbar-width: thin;
  scrollbar-color: rgba(243, 184, 75, 0.42) rgba(255, 255, 255, 0.04);
  padding-right: 0.35rem;
}

.chat-log::-webkit-scrollbar {
  width: 6px;
}

.chat-log::-webkit-scrollbar-track {
  margin: 0.2rem 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
}

.chat-log::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: rgba(243, 184, 75, 0.42);
}

.chat-log::-webkit-scrollbar-thumb:hover {
  background: rgba(243, 184, 75, 0.62);
}

.chat-message {
  padding: 0.65rem;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.055);
}

.chat-message span {
  display: block;
  color: var(--gold-2);
  font-size: 0.8rem;
  font-weight: 900;
  margin-bottom: 0.25rem;
}

.chat-message p {
  color: #efe2d6;
}

.chat-message p .chat-review-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.15rem;
  margin-top: 0.55rem;
  padding: 0 0.85rem;
  border: 1px solid rgba(246, 184, 75, 0.58);
  border-radius: 7px;
  background: linear-gradient(135deg, var(--gold), var(--gold-2));
  color: #1f1609;
  font-weight: 950;
  text-decoration: none;
}

.chat-message p .chat-review-link:hover,
.chat-message p .chat-review-link:focus-visible {
  filter: brightness(1.05);
}

.chat-message.client {
  border-left: 2px solid var(--gold);
}

.chat-message.manager {
  border-left: 2px solid var(--green);
}

.chat-message.system {
  color: var(--muted);
  border-left: 2px solid var(--violet);
}

.chat-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.55rem;
  margin-top: 0.7rem;
}

.chat-form input,
.chat-form button {
  min-height: 2.7rem;
  border-radius: 8px;
  font: inherit;
}

.chat-form input {
  min-width: 0;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(0, 0, 0, 0.24);
  color: var(--text);
  padding: 0 0.7rem;
}

.chat-form button {
  border: 0;
  padding: 0 0.8rem;
  background: var(--green);
  color: #06150e;
  font-weight: 900;
  cursor: pointer;
}

.account-modal {
  position: fixed;
  inset: 0;
  z-index: 60;
  display: grid;
  place-items: center;
  padding: 1rem;
}

.account-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(5, 5, 8, 0.72);
  backdrop-filter: blur(10px);
}

.account-dialog {
  position: relative;
  width: min(52rem, 100%);
  max-height: min(48rem, calc(100vh - 2rem));
  overflow: auto;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #141218;
  box-shadow: 0 2rem 5rem rgba(0, 0, 0, 0.55);
}

.account-dialog h2 {
  margin: 0.8rem 2.5rem 1rem 0;
  line-height: 1.1;
}

.modal-close {
  position: absolute;
  top: 0.7rem;
  right: 0.7rem;
  width: 2.35rem;
  height: 2.35rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.06);
  color: var(--text);
  font: inherit;
  font-size: 1.4rem;
  line-height: 1;
  cursor: pointer;
}

.account-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(13rem, 1fr));
  gap: 1rem;
}

.account-form {
  display: grid;
  gap: 0.75rem;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.035);
}

.account-form h3 {
  margin: 0;
}

.account-form p {
  margin: 0;
  color: var(--muted);
  font-weight: 700;
}

.account-form label {
  display: grid;
  gap: 0.35rem;
  color: var(--muted);
  font-weight: 800;
}

.account-form input {
  min-height: 2.75rem;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 8px;
  background: #0b0c10;
  color: var(--text);
  font: inherit;
  padding: 0 0.75rem;
}

.account-notice {
  margin: 0 0 1rem;
  padding: 0.75rem;
  border: 1px solid rgba(243, 184, 75, 0.32);
  border-radius: 8px;
  background: rgba(243, 184, 75, 0.08);
  color: var(--gold-2);
  font-weight: 800;
}

.discord-real-panel {
  display: grid;
  gap: 0.9rem;
  margin-bottom: 1rem;
  padding: 1rem;
  border: 1px solid rgba(88, 101, 242, 0.42);
  border-radius: 8px;
  background: rgba(88, 101, 242, 0.12);
}

.discord-real-panel h3,
.discord-real-panel p {
  margin: 0;
}

.discord-real-panel p {
  color: var(--muted);
}

.discord-panel-top {
  display: flex;
  gap: 0.8rem;
  align-items: center;
}

.discord-mark {
  width: 2.35rem;
  height: 2.35rem;
  flex: 0 0 auto;
  display: inline-grid;
  place-items: center;
  border-radius: 9px;
  background: #5865f2;
  color: #fff;
  box-shadow: 0 0.7rem 1.4rem rgba(88, 101, 242, 0.26);
  overflow: hidden;
}

.discord-mark img,
.discord-mark svg {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  fill: currentColor;
}

.discord-login {
  display: inline-flex;
  min-height: 2.7rem;
  align-items: center;
  justify-content: center;
  gap: 0.65rem;
  padding: 0 1rem;
  border-radius: 8px;
  background: #5865f2;
  color: #fff;
  font-weight: 900;
  box-shadow: 0 1rem 2rem rgba(88, 101, 242, 0.24);
}

.discord-login .discord-mark {
  width: 1.8rem;
  height: 1.8rem;
  background: rgba(255, 255, 255, 0.14);
  box-shadow: none;
}

.discord-login .discord-mark img,
.discord-login .discord-mark svg {
  width: 100%;
  height: 100%;
}

.guest-path-card {
  display: grid;
  gap: 0.25rem;
  padding: 0.8rem;
  border: 1px solid rgba(243, 184, 75, 0.22);
  border-radius: 8px;
  background: rgba(243, 184, 75, 0.08);
}

.guest-path-card strong {
  color: var(--gold-2);
}

.guest-path-card span {
  color: var(--muted);
  font-weight: 700;
}

.guest-order-panel {
  display: grid;
  gap: 0.75rem;
  padding: 0.85rem;
  border: 1px solid rgba(213, 225, 255, 0.14);
  border-radius: 8px;
  background: rgba(12, 19, 32, 0.72);
}

.guest-order-panel strong,
.guest-order-panel span {
  display: block;
}

.guest-order-panel > div:first-child span,
.guest-order-message {
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.4;
}

.guest-order-panel label {
  display: grid;
  gap: 0.35rem;
  color: var(--muted);
  font-weight: 900;
}

.guest-order-panel input {
  width: 100%;
  min-height: 2.75rem;
  border: 1px solid rgba(246, 184, 75, 0.3);
  border-radius: 8px;
  background: #0c1320;
  color: #fff;
  font: inherit;
  font-weight: 900;
  letter-spacing: 0;
  padding: 0.68rem 0.75rem;
}

.guest-order-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.55rem;
}

.profile-avatar {
  width: 2.6rem;
  height: 2.6rem;
  flex: 0 0 auto;
  display: inline-grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid rgba(88, 101, 242, 0.45);
  border-radius: 10px;
  background: rgba(88, 101, 242, 0.18);
}

.profile-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.profile-avatar.is-large {
  width: 4rem;
  height: 4rem;
  border-radius: 14px;
}

.profile-hero-card {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 1rem;
  align-items: center;
  margin-bottom: 1rem;
  padding: 1rem;
  border: 1px solid rgba(88, 101, 242, 0.36);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(88, 101, 242, 0.17), rgba(243, 184, 75, 0.08));
}

.profile-hero-card h3,
.profile-hero-card p {
  margin: 0;
}

.profile-hero-card p {
  color: var(--muted);
  font-weight: 700;
}

.profile-balance-pill {
  display: grid;
  gap: 0.15rem;
  min-width: 8rem;
  padding: 0.7rem 0.85rem;
  border: 1px solid rgba(243, 184, 75, 0.34);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.24);
}

.profile-balance-pill span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.profile-balance-pill strong {
  color: var(--gold-2);
}

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

.profile-stat {
  min-height: 5rem;
  padding: 0.85rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.24);
}

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

.profile-stat span {
  color: var(--muted);
  font-weight: 800;
}

.profile-stat strong {
  margin-top: 0.35rem;
  color: var(--gold-2);
  font-size: 1.2rem;
}

.order-history-panel {
  display: grid;
  gap: 0.8rem;
  margin-bottom: 1rem;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.035);
}

.order-history-panel:not([open]) {
  gap: 0;
}

.order-history-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  min-height: 2.4rem;
  cursor: pointer;
  list-style: none;
}

.order-history-summary::-webkit-details-marker {
  display: none;
}

.order-history-summary::marker {
  content: "";
}

.order-history-summary:focus-visible {
  outline: 2px solid rgba(246, 184, 75, 0.65);
  outline-offset: 3px;
}

.order-history-summary::after {
  content: "›";
  color: var(--gold-2);
  font-size: 1.45rem;
  line-height: 1;
  transform: rotate(90deg);
  transition: transform 160ms ease;
}

.order-history-panel[open] .order-history-summary::after {
  transform: rotate(-90deg);
}

.order-history-summary strong {
  margin-left: auto;
  color: var(--gold-2);
  font-size: 0.9rem;
}

.order-history-panel p {
  margin: 0;
}

.order-history-list {
  display: grid;
  gap: 0.6rem;
}

.order-history-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1rem;
  align-items: center;
  min-height: 4.7rem;
  padding: 0.75rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.24);
}

.order-history-item strong,
.order-history-item span,
.order-history-item small {
  display: block;
}

.order-history-item span,
.order-history-item small,
.order-history-side span {
  color: var(--muted);
}

.order-history-item small {
  margin-top: 0.15rem;
}

.order-history-side {
  min-width: 7.5rem;
  text-align: right;
}

.order-history-side strong {
  color: var(--gold-2);
}

.floating-chat {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  z-index: 45;
  display: grid;
  gap: 0.65rem;
  justify-items: end;
}

.chat-launcher {
  min-width: 5.5rem;
  min-height: 2.85rem;
  padding: 0.65rem 1.1rem;
  border: 1px solid rgba(86, 192, 141, 0.45);
  border-radius: 999px;
  background: var(--green);
  color: #06150e;
  box-shadow: 0 1rem 2.2rem var(--shadow);
  font: inherit;
  font-size: 0.92rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
}

.chat-launcher.is-open {
  background: #45a87a;
}

.chat-popover {
  width: min(25rem, calc(100vw - 2rem));
  max-height: min(34rem, calc(100vh - 6rem));
  display: flex;
  flex-direction: column;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #141218;
  box-shadow: 0 2rem 5rem rgba(0, 0, 0, 0.55);
}

.chat-popover header {
  position: relative;
  padding-right: 2.7rem;
  margin-bottom: 0.75rem;
}

.chat-popover h3 {
  margin: 0.45rem 0 0;
}

.chat-popover-subtitle {
  margin: 0.35rem 0 0;
  color: var(--muted);
  font-size: 0.88rem;
  font-weight: 700;
}

.chat-popover .modal-close {
  top: 0;
  right: 0;
}

.chat-popover .chat-log {
  flex: 1 1 auto;
  min-height: 12rem;
  max-height: none;
  margin-bottom: 0.75rem;
}

.client-chat .chat-log {
  max-height: 18rem;
}

.order-section {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 1rem;
  align-items: center;
  padding: 4rem 0;
}

.order-steps {
  display: grid;
  gap: 0.7rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.order-steps li {
  display: grid;
  grid-template-columns: 2.4rem 1fr;
  gap: 0.8rem;
  align-items: center;
  min-height: 4rem;
  padding: 0.7rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel-2);
  color: #eadccd;
  font-weight: 800;
}

.order-steps span {
  display: inline-flex;
  width: 2.4rem;
  height: 2.4rem;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--gold);
  color: #1c1206;
}

.reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
}

.reviews-grid blockquote {
  min-height: 11rem;
  margin: 0;
  padding: 1rem;
}

.reviews-grid p {
  margin: 0;
  color: #efe2d6;
  font-size: 1rem;
}

.reviews-grid cite {
  display: block;
  margin-top: 1rem;
  color: var(--muted);
  font-style: normal;
  font-weight: 700;
}

.final-cta {
  margin-top: 4rem;
  padding: 3rem 1rem;
  text-align: center;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.final-cta .primary-action {
  margin-top: 1.2rem;
}

.final-discord {
  margin: 1.2rem 0 0 0.7rem;
}

footer {
  width: min(74rem, calc(100% - 2rem));
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  margin: 0 auto;
  padding: 1.8rem 0;
  color: var(--muted);
}

footer span {
  font-weight: 800;
  color: var(--text);
}

.footer-discord-link {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  min-height: 2.35rem;
  padding: 0.35rem 0.75rem 0.35rem 0.45rem;
  border: 1px solid rgba(88, 101, 242, 0.42);
  border-radius: 8px;
  background: rgba(88, 101, 242, 0.12);
  color: #fff;
  font-weight: 900;
  text-decoration: none;
  box-shadow: 0 0.75rem 1.6rem rgba(88, 101, 242, 0.16);
}

.footer-discord-link:hover {
  border-color: rgba(88, 101, 242, 0.7);
  background: rgba(88, 101, 242, 0.2);
}

.footer-discord-link .discord-mark {
  width: 1.75rem;
  height: 1.75rem;
  box-shadow: none;
}

.footer-discord-link .discord-mark img,
.footer-discord-link .discord-mark svg {
  width: 100%;
  height: 100%;
}

.admin-shell {
  width: min(74rem, calc(100% - 2rem));
  margin: 0 auto;
  padding: 3rem 0;
}

.admin-shell .section-heading h1 {
  margin: 0;
  font-size: 2.2rem;
  line-height: 1.1;
}

.admin-layout {
  display: grid;
  grid-template-columns: 22rem 1fr;
  gap: 1rem;
  align-items: start;
}

.admin-tools {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1rem;
  align-items: center;
  margin-bottom: 1rem;
  padding: 1rem;
  border: 1px solid rgba(88, 101, 242, 0.34);
  border-radius: 8px;
  background: rgba(88, 101, 242, 0.08);
}

.admin-help {
  margin-bottom: 1rem;
  padding: 1rem 1.1rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(243, 184, 75, 0.06);
}

.admin-help h2 {
  margin: 0 0 0.6rem;
  font-size: 1.05rem;
}

.admin-help ol {
  margin: 0;
  padding-left: 1.2rem;
  color: var(--muted);
}

.admin-help li + li {
  margin-top: 0.35rem;
}

.admin-help strong {
  color: var(--gold-2);
}

.admin-cashback-preview {
  margin: 0 0 0.75rem;
  padding: 0.65rem 0.75rem;
  border-radius: 8px;
  background: rgba(86, 192, 141, 0.1);
  border: 1px solid rgba(86, 192, 141, 0.28);
  color: #d8f5e8;
  font-size: 0.92rem;
}

.admin-order-item .order-id-muted {
  display: block;
  margin-top: 0.15rem;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 600;
  opacity: 0.75;
}

.admin-tools h2 {
  margin: 0.6rem 0 0.25rem;
}

.admin-tools p {
  margin: 0;
  color: var(--muted);
}

.admin-list,
.admin-detail {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.025));
  box-shadow: 0 1rem 2.2rem var(--shadow);
}

.admin-list {
  display: grid;
  gap: 0.5rem;
  padding: 0.65rem;
  max-height: calc(100vh - 10rem);
  overflow: auto;
}

.admin-detail {
  min-height: 32rem;
  padding: 1rem;
}

.admin-order-item {
  display: grid;
  gap: 0.15rem;
  min-height: 4.5rem;
  padding: 0.7rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.2);
  color: var(--text);
  text-align: left;
  font: inherit;
  cursor: pointer;
}

.admin-order-item.is-active {
  border-color: var(--gold);
  background: rgba(243, 184, 75, 0.12);
}

.admin-order-item span,
.admin-order-item small,
.muted-box {
  color: var(--muted);
}

.admin-refresh {
  border: 0;
  cursor: pointer;
}

.admin-edit-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--line);
}

.admin-edit-form label {
  display: grid;
  gap: 0.35rem;
  color: var(--muted);
  font-weight: 800;
}

.admin-edit-form input,
.admin-edit-form textarea,
.admin-edit-form select {
  width: 100%;
  min-height: 2.6rem;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.24);
  color: var(--text);
  font: inherit;
  padding: 0.65rem;
}

.admin-edit-form .wide-field,
.admin-edit-form button {
  grid-column: 1 / -1;
}

[hidden] {
  display: none !important;
}

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

  .order-tabs {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .hero h1 {
    font-size: 3.5rem;
  }
}

@media (max-width: 760px) {
  .site-header {
    grid-template-columns: 1fr auto;
  }

  .site-header nav {
    grid-row: 2;
    grid-column: 1 / -1;
    justify-content: start;
    overflow-x: auto;
    padding-bottom: 0.2rem;
  }

  .header-cta {
    grid-row: 1;
    grid-column: 2;
    min-height: 2.3rem;
  }

  .header-actions {
    grid-row: 1;
    grid-column: 2;
  }

  .header-account-summary {
    display: none;
  }

  .hero {
    min-height: 32rem;
  }

  .hero-content {
    padding: 4.2rem 1rem 1.4rem;
  }

  .hero h1 {
    font-size: 2.45rem;
  }

  .hero-copy {
    margin-top: 0.75rem;
    font-size: 0.98rem;
  }

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

  .hero-stats {
    gap: 0.45rem;
    margin-top: 1.1rem;
  }

  .hero-stats,
  .hot-strip,
  .loot-section,
  .order-layout,
  .order-section,
    .reviews-grid,
    .account-strip,
    .account-grid,
    .profile-hero-card,
    .profile-grid,
    .order-history-item {
    grid-template-columns: 1fr;
  }

  .account-strip .discord-login,
  .profile-balance-pill {
    width: 100%;
  }

  .hot-items,
  .service-grid,
  .loot-grid,
  .check-grid {
    grid-template-columns: 1fr;
  }

  .order-tabs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-card {
    min-height: auto;
  }

  .field-grid {
    grid-template-columns: 1fr;
  }

  .admin-edit-form {
    grid-template-columns: 1fr;
  }

  .order-summary {
    min-height: auto;
    position: static;
  }

  .summary-list li {
    grid-template-columns: 1fr;
    gap: 0.15rem;
  }

  .chat-form {
    grid-template-columns: 1fr;
  }

  .balance-toggle {
    justify-content: start;
    white-space: normal;
  }

  .order-history-side {
    min-width: 0;
    text-align: left;
  }

  .floating-chat {
    right: 0.75rem;
    bottom: 0.75rem;
    left: 0.75rem;
  }

  .chat-launcher,
  .chat-popover {
    width: 100%;
  }

  .final-discord {
    margin-left: 0;
  }

  .admin-layout {
    grid-template-columns: 1fr;
  }

  .admin-tools {
    grid-template-columns: 1fr;
  }

  footer {
    flex-direction: column;
  }
}

/* Storefront refresh */
:root {
  --bg: #080a0f;
  --panel: #12151e;
  --panel-2: #181b24;
  --line: rgba(255, 255, 255, 0.12);
  --text: #fbf7ef;
  --muted: #aeb6c2;
  --gold: #f5b73b;
  --gold-2: #ffe7ad;
  --violet: #7357ff;
  --ember: #f06445;
  --green: #56c08d;
  --cyan: #55c7e8;
  --red: #e65858;
  --shadow: rgba(0, 0, 0, 0.5);
}

body {
  background:
    linear-gradient(180deg, rgba(8, 10, 15, 0.22), rgba(8, 10, 15, 0.96) 34rem),
    radial-gradient(circle at 18% 8%, rgba(245, 183, 59, 0.13), transparent 25rem),
    radial-gradient(circle at 86% 18%, rgba(85, 199, 232, 0.12), transparent 24rem),
    linear-gradient(180deg, #0d111a 0%, #080a0f 55%, #0b0d12 100%);
}

.site-header {
  grid-template-columns: minmax(12rem, auto) 1fr auto;
  padding: 0.7rem clamp(1rem, 2vw, 1.6rem);
  background: rgba(8, 10, 15, 0.84);
  box-shadow: 0 0.8rem 2.2rem rgba(0, 0, 0, 0.28);
}

.brand span {
  font-size: 0.98rem;
  letter-spacing: 0;
}

.site-header nav {
  gap: clamp(0.65rem, 2vw, 1.45rem);
  font-size: 0.9rem;
  font-weight: 800;
}

.header-cta {
  background: linear-gradient(135deg, #5865f2, #7d6cff);
  box-shadow: 0 0.7rem 1.4rem rgba(88, 101, 242, 0.24);
}

.primary-action {
  border: 0;
  background: linear-gradient(135deg, #ffe09a 0%, var(--gold) 32%, #e98532 72%, var(--ember) 100%);
  color: #191006;
  box-shadow: 0 0.95rem 2.2rem rgba(245, 183, 59, 0.24);
}

.secondary-action {
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(255, 255, 255, 0.18);
}

.hero-store {
  min-height: min(46rem, calc(100vh - 1rem));
  align-items: stretch;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.hero-store .hero-bg {
  transform: scale(1.02);
  filter: saturate(1.18) contrast(1.08);
}

.hero-store .hero-shade {
  background:
    linear-gradient(90deg, rgba(8, 10, 15, 0.98) 0%, rgba(8, 10, 15, 0.84) 42%, rgba(8, 10, 15, 0.46) 72%, rgba(8, 10, 15, 0.18) 100%),
    linear-gradient(0deg, rgba(8, 10, 15, 0.98) 0%, rgba(8, 10, 15, 0.24) 58%);
}

.hero-store .hero-content {
  width: min(80rem, 100%);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(18rem, 25rem);
  gap: clamp(1rem, 4vw, 2rem);
  align-content: end;
  padding: clamp(7rem, 12vw, 10rem) 1rem clamp(1.5rem, 4vw, 3rem);
}

.hero-main {
  max-width: 51rem;
  align-self: end;
}

.eyebrow,
.section-kicker {
  color: var(--gold-2);
  letter-spacing: 0;
}

.hero-store h1 {
  max-width: 48rem;
  font-size: clamp(2.65rem, 6.2vw, 5.7rem);
  line-height: 0.95;
}

.hero-copy {
  max-width: 45rem;
  color: #dfe5ee;
}

.hero-panel {
  align-self: end;
  display: grid;
  gap: 0.9rem;
  padding: 1rem;
  border: 1px solid rgba(245, 183, 59, 0.28);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.035)),
    rgba(12, 14, 20, 0.84);
  box-shadow: 0 1.4rem 3.2rem rgba(0, 0, 0, 0.48);
  backdrop-filter: blur(14px);
}

.hero-panel h2 {
  margin: 0;
  font-size: 1.7rem;
  line-height: 1.05;
}

.hero-deal {
  display: grid;
  gap: 0.25rem;
  min-height: 4.8rem;
  padding: 0.85rem;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(245, 183, 59, 0.22), rgba(240, 100, 69, 0.1)),
    rgba(0, 0, 0, 0.24);
}

.hero-deal span,
.hero-panel li span,
.hot-items small {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.hero-deal strong {
  color: var(--gold-2);
  font-size: 1rem;
}

.hero-panel ul {
  display: grid;
  gap: 0.5rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.hero-panel li {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.75rem;
  align-items: center;
  padding: 0.55rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.09);
}

.hero-panel li strong {
  color: #f7efe2;
  text-align: right;
}

.panel-action {
  display: inline-flex;
  min-height: 2.7rem;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: rgba(245, 183, 59, 0.14);
  color: var(--gold-2);
  font-weight: 900;
}

.hero-stats {
  grid-column: 1 / -1;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  width: 100%;
  margin-top: 0.7rem;
}

.hero-stats li {
  min-height: 5.1rem;
  display: grid;
  align-content: center;
  padding: 0.75rem 0.9rem;
  border-left: 0;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.065);
  backdrop-filter: blur(10px);
}

.hero-stats li:nth-child(1) {
  border-top: 2px solid var(--gold);
}

.hero-stats li:nth-child(2) {
  border-top: 2px solid var(--cyan);
}

.hero-stats li:nth-child(3) {
  border-top: 2px solid var(--green);
}

.trust-band,
.game-shelf,
.hot-strip,
.section,
.loot-section,
.site-order-section,
.order-section,
.final-cta {
  width: min(80rem, calc(100% - 2rem));
}

.trust-band {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
  margin: -1.35rem auto 0;
  position: relative;
  z-index: 5;
}

.trust-band article {
  min-height: 5.4rem;
  display: grid;
  align-content: center;
  gap: 0.2rem;
  padding: 0.9rem 1rem;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 8px;
  background: #121722;
  box-shadow: 0 1rem 2.2rem rgba(0, 0, 0, 0.34);
}

.trust-band strong {
  color: var(--text);
  font-size: 1rem;
}

.trust-band span {
  color: var(--muted);
  font-size: 0.9rem;
}

.game-shelf {
  margin: 0 auto;
  padding: 4rem 0 0;
}

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

.game-tile {
  position: relative;
  min-height: 15rem;
  overflow: hidden;
  display: grid;
  align-content: end;
  gap: 0.4rem;
  padding: 1rem;
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: 8px;
  background: #151924;
  color: var(--text);
  font: inherit;
  text-align: left;
  cursor: pointer;
  box-shadow: 0 1rem 2.3rem rgba(0, 0, 0, 0.34);
}

.game-tile::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, transparent 0%, rgba(8, 10, 15, 0.18) 35%, rgba(8, 10, 15, 0.92) 100%),
    var(--tile-art);
  transform: scale(1.02);
  transition: transform 180ms ease, filter 180ms ease;
}

.game-tile:hover::before,
.game-tile:focus-visible::before {
  transform: scale(1.07);
  filter: saturate(1.14);
}

.game-tile:focus-visible {
  outline: 3px solid rgba(245, 183, 59, 0.48);
  outline-offset: 2px;
}

.game-tile span,
.game-tile h3,
.game-tile p {
  position: relative;
  z-index: 1;
}

.game-tile span {
  width: fit-content;
  padding: 0.25rem 0.5rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  color: var(--gold-2);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.game-tile h3 {
  margin: 0;
  font-size: 1.45rem;
  line-height: 1.05;
}

.game-tile p {
  margin: 0;
  color: #d9e0ea;
  font-size: 0.92rem;
}

.tile-retail {
  --tile-art: linear-gradient(135deg, rgba(245, 183, 59, 0.28), rgba(230, 88, 88, 0.16) 52%, rgba(255, 255, 255, 0.05));
}

.tile-keys {
  --tile-art: linear-gradient(135deg, rgba(85, 199, 232, 0.25), rgba(115, 87, 255, 0.18) 52%, rgba(255, 255, 255, 0.05));
}

.tile-classic {
  --tile-art: linear-gradient(135deg, rgba(86, 192, 141, 0.25), rgba(245, 183, 59, 0.15) 52%, rgba(255, 255, 255, 0.05));
}

.tile-pvp {
  --tile-art: linear-gradient(135deg, rgba(230, 88, 88, 0.26), rgba(115, 87, 255, 0.16) 52%, rgba(255, 255, 255, 0.05));
}

.hot-strip {
  grid-template-columns: minmax(16rem, 0.7fr) 1.3fr;
  margin-top: 1.2rem;
  padding: 1.25rem;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.045);
  box-shadow: 0 1rem 2.2rem rgba(0, 0, 0, 0.25);
}

.hot-items span {
  display: grid;
  align-content: center;
  gap: 0.15rem;
  min-height: 4.6rem;
  border-color: rgba(245, 183, 59, 0.25);
  background:
    linear-gradient(135deg, rgba(245, 183, 59, 0.14), rgba(240, 100, 69, 0.08)),
    rgba(0, 0, 0, 0.18);
}

.section,
.loot-section,
.site-order-section {
  padding-top: 4.4rem;
}

.section-heading {
  max-width: 54rem;
}

.section-heading h2,
.hot-strip h2,
.order-copy h2,
.final-cta h2 {
  font-size: clamp(1.75rem, 3.1vw, 2.65rem);
}

.filter-bar {
  position: sticky;
  top: 4.4rem;
  z-index: 10;
  padding: 0.6rem;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  background: rgba(13, 16, 24, 0.92);
  backdrop-filter: blur(14px);
}

.filter-button,
.order-tab {
  background: rgba(255, 255, 255, 0.055);
}

.filter-button.is-active,
.order-tab.is-active {
  background: linear-gradient(135deg, var(--gold), #ffcf72);
  border-color: rgba(255, 231, 173, 0.85);
}

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

.service-card {
  position: relative;
  overflow: hidden;
  min-height: 28rem;
  padding: 1rem;
  border-color: rgba(255, 255, 255, 0.12);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.03)),
    #111620;
  box-shadow: 0 1.2rem 2.6rem rgba(0, 0, 0, 0.36);
}

.service-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 8rem;
  background:
    linear-gradient(180deg, rgba(8, 10, 15, 0.05), rgba(8, 10, 15, 0.88)),
    var(--card-art, linear-gradient(135deg, rgba(245, 183, 59, 0.18), rgba(115, 87, 255, 0.12)));
}

.service-card > * {
  position: relative;
  z-index: 1;
}

.service-card:nth-child(1) {
  --card-art: linear-gradient(135deg, rgba(85, 199, 232, 0.28), rgba(115, 87, 255, 0.18));
}

.service-card:nth-child(2) {
  --card-art: linear-gradient(135deg, rgba(245, 183, 59, 0.28), rgba(230, 88, 88, 0.17));
}

.service-card:nth-child(3) {
  --card-art: linear-gradient(135deg, rgba(240, 100, 69, 0.3), rgba(245, 183, 59, 0.18));
}

.service-card:nth-child(4) {
  --card-art: linear-gradient(135deg, rgba(86, 192, 141, 0.24), rgba(85, 199, 232, 0.16));
}

.service-card:nth-child(5) {
  --card-art: linear-gradient(135deg, rgba(115, 87, 255, 0.27), rgba(85, 199, 232, 0.14));
}

.service-card:nth-child(6) {
  --card-art: linear-gradient(135deg, rgba(230, 88, 88, 0.28), rgba(115, 87, 255, 0.16));
}

.service-card:nth-child(7) {
  --card-art: linear-gradient(135deg, rgba(245, 183, 59, 0.23), rgba(86, 192, 141, 0.16));
}

.service-card:nth-child(8) {
  --card-art: linear-gradient(135deg, rgba(255, 231, 173, 0.24), rgba(245, 183, 59, 0.18));
}

.service-card.feature {
  border-color: rgba(245, 183, 59, 0.38);
  background:
    linear-gradient(180deg, rgba(245, 183, 59, 0.12), rgba(255, 255, 255, 0.03)),
    #111620;
}

.service-card .card-top {
  margin-top: 5.15rem;
}

.service-icon {
  background: rgba(8, 10, 15, 0.68);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.1);
}

.service-tag {
  color: var(--gold-2);
}

.service-card h3 {
  font-size: 1.2rem;
}

.price-list div,
.order-steps li,
.summary-list li,
.range-control,
.check-option {
  background: rgba(0, 0, 0, 0.28);
}

.card-order-button {
  background: rgba(245, 183, 59, 0.13);
  border-color: rgba(245, 183, 59, 0.42);
}

.loot-section {
  grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
}

.loot-grid article,
.reviews-grid blockquote,
.order-form,
.order-summary,
.account-strip,
.admin-list,
.admin-detail {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.065), rgba(255, 255, 255, 0.025)),
    #111620;
}

.site-order-section {
  position: relative;
}

.order-tabs {
  grid-template-columns: repeat(8, minmax(0, 1fr));
}

.account-strip {
  border-color: rgba(86, 192, 141, 0.24);
}

.order-layout {
  grid-template-columns: minmax(0, 1.25fr) minmax(20rem, 0.75fr);
}

.order-summary {
  top: 5.8rem;
}

.order-section {
  padding: 4.4rem 0;
}

.order-steps {
  counter-reset: step;
}

.order-steps li {
  min-height: 4.6rem;
  background:
    linear-gradient(90deg, rgba(245, 183, 59, 0.11), rgba(255, 255, 255, 0.035)),
    #121620;
}

.reviews-grid blockquote {
  border-color: rgba(255, 255, 255, 0.1);
}

.final-cta {
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(245, 183, 59, 0.12), rgba(85, 199, 232, 0.06)),
    #111620;
}

@media (max-width: 1100px) {
  .hero-store .hero-content {
    grid-template-columns: 1fr;
  }

  .hero-panel {
    max-width: 34rem;
  }

  .game-grid,
  .service-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .order-tabs {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .site-header {
    grid-template-columns: 1fr auto;
  }

  .brand span {
    max-width: 8.2rem;
    overflow: hidden;
    font-size: 0.9rem;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .header-actions {
    gap: 0.38rem;
  }

  .account-button,
  .header-cta {
    min-height: 2.45rem;
    padding: 0 0.72rem;
  }

  .hero-store {
    min-height: auto;
  }

  .hero-store .hero-shade {
    background:
      linear-gradient(180deg, rgba(8, 10, 15, 0.76), rgba(8, 10, 15, 0.98) 72%),
      linear-gradient(90deg, rgba(8, 10, 15, 0.8), rgba(8, 10, 15, 0.4));
  }

  .hero-store .hero-content {
    gap: 0.85rem;
    padding: 2.4rem 1rem 1rem;
  }

  .hero-store h1 {
    font-size: clamp(2.15rem, 10vw, 2.55rem);
  }

  .hero-copy {
    font-size: 0.95rem;
    line-height: 1.45;
  }

  .hero-actions {
    gap: 0.55rem;
    margin-top: 0.9rem;
  }

  .hero-actions .primary-action,
  .hero-actions .secondary-action {
    min-height: 2.85rem;
    padding: 0.65rem 0.9rem;
  }

  .hero-panel {
    gap: 0.65rem;
    max-width: none;
    padding: 0.85rem;
  }

  .hero-panel h2 {
    font-size: 1.45rem;
  }

  .hero-panel ul {
    display: none;
  }

  .hero-deal {
    min-height: 4rem;
    padding: 0.7rem;
  }

  .hero-stats {
    display: none;
  }

  .hero-stats,
  .trust-band,
  .game-grid,
  .hot-strip,
  .hot-items,
  .service-grid,
  .loot-section,
  .loot-grid,
  .order-layout,
  .order-section,
  .reviews-grid {
    grid-template-columns: 1fr;
  }

  .trust-band {
    margin-top: 0.75rem;
  }

  .game-shelf,
  .section,
  .loot-section,
  .site-order-section {
    padding-top: 3rem;
  }

  .game-tile {
    min-height: 12rem;
  }

  .hot-strip {
    padding: 1rem;
  }

  .filter-bar {
    position: static;
  }

  .service-card {
    min-height: 0;
  }

  .service-card .card-top {
    margin-top: 4.85rem;
  }

  .order-tabs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .order-layout {
    grid-template-columns: 1fr;
  }
}

/* WoW category page redesign */
.wow-category-hero {
  position: relative;
  min-height: 37.5rem;
  overflow: hidden;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.wow-category-hero .hero-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 31rem;
  object-fit: cover;
  filter: saturate(0.95) contrast(1.1);
  opacity: 0.46;
}

.wow-category-hero .hero-shade {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(9, 10, 17, 0.28) 0%, rgba(9, 10, 17, 0.92) 32rem, #090a11 100%),
    linear-gradient(90deg, rgba(9, 10, 17, 0.9), rgba(9, 10, 17, 0.56), rgba(9, 10, 17, 0.95));
}

.wow-hero-inner {
  position: relative;
  z-index: 1;
  width: min(85rem, calc(100% - 2rem));
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1rem;
  margin: 0 auto;
  padding: 4.2rem 0 2.3rem;
}

.breadcrumbs {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  color: #a9adbc;
  font-size: 0.9rem;
  font-weight: 800;
}

.breadcrumbs span:nth-child(2) {
  width: 1.35rem;
  height: 1.35rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
}

.how-chip {
  display: inline-grid;
  grid-template-columns: 5rem auto;
  gap: 0.75rem;
  align-items: center;
  min-height: 4rem;
  padding: 0.55rem 0.85rem;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.09);
  color: var(--text);
  font-weight: 900;
}

.how-thumb {
  display: inline-flex;
  min-height: 2.8rem;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: 4px;
  background:
    linear-gradient(135deg, rgba(245, 183, 59, 0.3), rgba(115, 87, 255, 0.28)),
    rgba(0, 0, 0, 0.25);
  color: var(--gold-2);
  font-size: 0.82rem;
}

.wow-title-row {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  align-items: center;
  margin-top: 4.3rem;
}

.wow-title-row h1 {
  margin: 0;
  color: #f4f2ff;
  font-size: clamp(2.4rem, 4.2vw, 4.2rem);
  line-height: 1.03;
}

.deal-count {
  display: inline-flex;
  min-height: 1.9rem;
  align-items: center;
  padding: 0 0.65rem;
  border-radius: 999px;
  background: rgba(42, 190, 95, 0.25);
  color: #32f27b;
  font-weight: 900;
}

.hero-rating {
  grid-column: 1 / -1;
  justify-self: end;
  color: #f1f3ff;
  font-size: 0.95rem;
  font-weight: 800;
}

.hero-offer {
  grid-column: 1 / -1;
  min-height: 10.4rem;
  display: grid;
  align-items: center;
  margin-top: 1rem;
  padding: 1.7rem min(10vw, 10rem);
  border-radius: 6px;
  background:
    linear-gradient(90deg, rgba(13, 14, 22, 0.98), rgba(13, 14, 22, 0.76)),
    linear-gradient(135deg, rgba(245, 183, 59, 0.1), rgba(115, 87, 255, 0.1));
  box-shadow: 0 1.2rem 2.5rem rgba(0, 0, 0, 0.24);
}

.hero-offer h2 {
  margin: 0;
  font-size: clamp(1.75rem, 3vw, 2.35rem);
  line-height: 1.08;
}

.hero-offer p {
  max-width: 54rem;
  margin: 0.5rem 0 1rem;
  color: #e5e8f4;
}

.wow-catalog {
  width: min(85rem, calc(100% - 2rem));
  padding-top: 2.4rem;
}

.catalog-head {
  display: grid;
  grid-template-columns: minmax(16rem, 26rem);
  gap: 1rem;
  justify-content: end;
  align-items: end;
  margin-bottom: 1rem;
}

.catalog-head h2 {
  margin: 0;
  font-size: clamp(1.8rem, 3vw, 2.5rem);
  line-height: 1.08;
}

.catalog-head > div {
  display: none;
}

.catalog-search {
  display: grid;
  gap: 0.35rem;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 900;
  text-transform: uppercase;
}

.catalog-search input {
  min-height: 3.35rem;
  width: 100%;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.12);
  color: var(--text);
  font: inherit;
  font-weight: 800;
  padding: 0 1rem;
  outline: none;
}

.catalog-search input:focus {
  border-color: rgba(245, 183, 59, 0.72);
  box-shadow: 0 0 0 3px rgba(245, 183, 59, 0.14);
}

.catalog-layout {
  display: grid;
  grid-template-columns: 18.5rem minmax(0, 1fr);
  gap: 1.5rem;
  align-items: start;
}

.category-sidebar {
  position: sticky;
  top: 5.25rem;
  display: grid;
  gap: 0.6rem;
  max-height: calc(100vh - 6rem);
  overflow: auto;
  padding-right: 0.2rem;
}

.category-title {
  margin: 0.7rem 0 0.1rem;
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 900;
  text-transform: uppercase;
}

.category-sidebar .filter-button {
  justify-content: start;
  width: 100%;
  min-height: 3.25rem;
  padding: 0 1rem;
  border-radius: 6px;
  background: #242632;
  color: #f1f2fb;
  font-size: 1rem;
  text-align: left;
}

.category-sidebar .filter-button.is-active {
  background: #f3f0eb;
  color: #11131a;
  border-color: #f3f0eb;
}

.product-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
}

.product-offer {
  min-height: 26rem;
  overflow: hidden;
  padding: 0;
  border: 0;
  border-radius: 6px;
  background: #111827;
  box-shadow: 0 1.2rem 2.8rem rgba(0, 0, 0, 0.34);
}

.product-offer::before {
  display: none;
}

.product-media {
  position: relative;
  min-height: 13.5rem;
  background:
    linear-gradient(180deg, rgba(7, 9, 15, 0.05), rgba(7, 9, 15, 0.88)),
    var(--offer-art);
}

.product-media::after {
  content: "";
  position: absolute;
  inset: auto 1rem 1rem auto;
  width: 5.5rem;
  height: 5.5rem;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  filter: blur(0.1rem);
}

.offer-badge {
  position: relative;
  z-index: 1;
  display: inline-flex;
  min-height: 2rem;
  align-items: center;
  margin: 1rem 0 0 1rem;
  padding: 0 0.75rem;
  border: 1px solid rgba(255, 231, 173, 0.64);
  border-radius: 999px;
  background: rgba(20, 17, 28, 0.72);
  color: var(--gold-2);
  font-size: 0.82rem;
  font-weight: 900;
}

.offer-badge.hot::before {
  content: "";
  width: 0.46rem;
  height: 0.46rem;
  margin-right: 0.35rem;
  border-radius: 50%;
  background: #ff5d2d;
}

.offer-badge.sale {
  border-color: rgba(50, 242, 123, 0.65);
  color: #32f27b;
}

.product-body {
  display: grid;
  gap: 0.85rem;
  position: relative;
  z-index: 1;
  margin-top: -4.25rem;
  padding: 1rem 1.1rem 0;
}

.product-body h3 {
  margin: 0;
  font-size: 1.45rem;
  line-height: 1.1;
}

.product-perks {
  display: grid;
  gap: 0.38rem;
  min-height: 4.65rem;
  margin: 0;
  padding: 0;
  list-style: none;
  color: #e4e7f1;
  font-size: 0.94rem;
}

.product-perks li::before {
  content: "";
  display: inline-block;
  width: 0.32rem;
  height: 0.32rem;
  margin: 0 0.45rem 0.14rem 0;
  border-radius: 50%;
  background: #ff5d2d;
}

.product-price {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  align-items: baseline;
  padding-top: 0.35rem;
  border-top: 1px solid rgba(255, 255, 255, 0.09);
}

.product-price span {
  color: var(--muted);
  font-weight: 900;
}

.product-price strong {
  color: var(--gold-2);
  text-align: right;
}

.product-offer .card-order-button {
  width: calc(100% - 2.2rem);
  margin: auto 1.1rem 1.1rem;
  background: #ff5d2d;
  border-color: #ff5d2d;
  color: #fff;
}

.art-gold {
  --offer-art: linear-gradient(135deg, #42351d, #846326 45%, #111827 100%);
}

.art-leveling {
  --offer-art: linear-gradient(135deg, #0f7775, #2854ad 45%, #111827 100%);
}

.art-voidspire {
  --offer-art: linear-gradient(135deg, #4a1f64, #7736d9 48%, #151827 100%);
}

.art-keys {
  --offer-art: linear-gradient(135deg, #174b66, #1d91b6 48%, #111827 100%);
}

.art-dreamrift {
  --offer-art: linear-gradient(135deg, #262c77, #6b3abd 48%, #101420 100%);
}

.art-pvp {
  --offer-art: linear-gradient(135deg, #6b2020, #a54638 48%, #111827 100%);
}

.art-delves {
  --offer-art: linear-gradient(135deg, #254b32, #487a54 48%, #111827 100%);
}

.art-collect {
  --offer-art: linear-gradient(135deg, #56401e, #80662e 48%, #111827 100%);
}

.wow-info-section {
  width: min(85rem, calc(100% - 2rem));
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: 1rem;
  align-items: start;
  margin: 0 auto;
  padding: 4rem 0 0;
}

.site-order-section {
  width: min(85rem, calc(100% - 2rem));
}

.product-page-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(24rem, 30rem);
  gap: 1.5rem;
  align-items: start;
}

.product-info-panel {
  min-width: 0;
}

.product-breadcrumbs {
  margin-bottom: 1.4rem;
}

.product-info-panel h2 {
  margin: 0;
  max-width: 46rem;
  font-size: clamp(2rem, 4vw, 3.5rem);
  line-height: 1.04;
}

.product-info-panel > p {
  max-width: 45rem;
  margin: 1rem 0 0;
  color: #dce1ed;
  font-size: 1.05rem;
}

.product-info-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1.4rem;
}

.product-info-card,
.product-faq {
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 6px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.025)),
    #111620;
  box-shadow: 0 1rem 2.2rem rgba(0, 0, 0, 0.24);
}

.product-info-card {
  min-height: 13rem;
  padding: 1rem;
}

.product-info-card h3,
.product-faq h3 {
  margin: 0 0 0.85rem;
  font-size: 1.18rem;
}

.product-info-card ul,
.product-info-card ol {
  display: grid;
  gap: 0.55rem;
  margin: 0;
  padding-left: 1.1rem;
  color: var(--muted);
}

.product-info-card li::marker {
  color: var(--gold);
}

.product-faq {
  margin-top: 1rem;
  padding: 1rem;
}

.product-faq details {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding: 0.8rem 0;
}

.product-faq details:last-child {
  padding-bottom: 0;
}

.product-faq summary {
  color: #f4f2ff;
  font-weight: 900;
  cursor: pointer;
}

.product-faq p {
  margin: 0.55rem 0 0;
  color: var(--muted);
}

.product-order-sidebar {
  position: sticky;
  top: 5rem;
  display: grid;
  gap: 0;
  border-radius: 6px;
  box-shadow: 0 1.5rem 3rem rgba(0, 0, 0, 0.36);
}

.product-order-art {
  min-height: 16rem;
  display: grid;
  align-content: end;
  gap: 0.35rem;
  padding: 1rem;
  border-radius: 6px 6px 0 0;
  background:
    linear-gradient(180deg, rgba(10, 12, 18, 0.08), rgba(10, 12, 18, 0.9)),
    linear-gradient(135deg, rgba(245, 183, 59, 0.27), rgba(115, 87, 255, 0.25)),
    #161925;
}

.product-order-art span {
  color: var(--gold-2);
  font-size: 0.82rem;
  font-weight: 900;
  text-transform: uppercase;
}

.product-order-art strong {
  font-size: 1.65rem;
  line-height: 1.08;
}

.product-order-sidebar .order-tabs {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.35rem;
  margin: 0;
  padding: 1rem 1rem 0;
  background: #111620;
}

.product-order-sidebar .order-tab {
  min-height: 3rem;
  padding: 0.38rem;
  font-size: 0.78rem;
}

.product-order-sidebar .account-strip {
  grid-template-columns: 1fr;
  margin: 0;
  padding: 1rem;
  border-width: 0;
  border-radius: 0;
  box-shadow: none;
}

.product-order-sidebar .account-strip h3 {
  margin-top: 0.45rem;
  font-size: 1rem;
}

.product-order-sidebar .account-strip p {
  font-size: 0.88rem;
}

.product-order-sidebar .account-strip .secondary-action {
  width: 100%;
}

.product-order-sidebar .order-form,
.product-order-sidebar .order-summary {
  border-radius: 0;
  border-width: 0;
  box-shadow: none;
  background: #111620;
}

.product-order-sidebar .order-form {
  padding: 1rem;
}

.product-order-sidebar .flow-head {
  padding-bottom: 0.8rem;
  margin-bottom: 0.8rem;
}

.product-order-sidebar .field-grid {
  grid-template-columns: 1fr;
}

.product-order-sidebar .check-grid {
  grid-template-columns: 1fr;
}

.product-order-sidebar .form-actions {
  display: grid;
}

.product-order-sidebar .form-actions .primary-action,
.product-order-sidebar .form-actions .secondary-action {
  width: 100%;
}

.product-order-sidebar .order-summary {
  min-height: auto;
  position: static;
  padding: 1rem;
  border-radius: 0 0 6px 6px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

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

  .catalog-layout {
    grid-template-columns: 15.5rem minmax(0, 1fr);
  }

  .product-page-layout {
    grid-template-columns: minmax(0, 1fr) minmax(21rem, 26rem);
  }

  .product-info-grid {
    grid-template-columns: 1fr;
  }
}

/* Light buyer-focused theme */
:root {
  color-scheme: light;
  --bg: #f5f7fb;
  --panel: #ffffff;
  --panel-2: #f0f3f8;
  --line: rgba(20, 30, 45, 0.12);
  --text: #152033;
  --muted: #657186;
  --gold: #f5a524;
  --gold-2: #8a580d;
  --violet: #635bff;
  --ember: #ee5b2e;
  --green: #16a36b;
  --cyan: #1f9fca;
  --shadow: rgba(19, 32, 54, 0.1);
}

body {
  background:
    radial-gradient(circle at 12% 0%, rgba(99, 91, 255, 0.1), transparent 25rem),
    radial-gradient(circle at 88% 4%, rgba(245, 165, 36, 0.12), transparent 23rem),
    linear-gradient(180deg, #fbfcff 0%, #f5f7fb 34rem, #eef2f8 100%);
  color: var(--text);
}

.site-header {
  background: rgba(255, 255, 255, 0.88);
  border-bottom: 1px solid rgba(20, 30, 45, 0.1);
  box-shadow: 0 0.8rem 2rem rgba(19, 32, 54, 0.08);
}

.brand,
.site-header nav,
.site-header nav a {
  color: var(--text);
}

.site-header nav a:hover,
.site-header nav a:focus-visible {
  color: var(--violet);
}

.account-button,
.admin-header-link {
  background: #fff;
  border-color: rgba(20, 30, 45, 0.14);
  color: var(--text);
}

.header-cta {
  background: #5865f2;
  color: #fff;
  box-shadow: none;
}

.primary-action {
  background: linear-gradient(135deg, #ffcf6c, #f5a524 45%, #ee5b2e 100%);
  color: #201100;
  box-shadow: 0 0.9rem 1.8rem rgba(238, 91, 46, 0.16);
}

.secondary-action {
  background: #fff;
  border-color: rgba(20, 30, 45, 0.14);
  color: var(--text);
}

.wow-category-hero {
  min-height: 36rem;
  border-bottom: 1px solid rgba(20, 30, 45, 0.1);
}

.wow-category-hero .hero-bg {
  opacity: 0.18;
  filter: saturate(0.9) contrast(1.02);
}

.wow-category-hero .hero-shade {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.78) 0%, rgba(245, 247, 251, 0.98) 31rem, #f5f7fb 100%),
    linear-gradient(90deg, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0.78), rgba(255, 255, 255, 0.96));
}

.wow-hero-inner {
  padding-top: 3.7rem;
  padding-bottom: 2rem;
}

.breadcrumbs,
.hero-rating,
.product-breadcrumbs {
  color: var(--muted);
}

.breadcrumbs span:nth-child(2) {
  background: rgba(99, 91, 255, 0.1);
  color: var(--violet);
}

.how-chip {
  background: #fff;
  border: 1px solid rgba(20, 30, 45, 0.1);
  color: var(--text);
  box-shadow: 0 0.8rem 1.7rem rgba(19, 32, 54, 0.08);
}

.how-thumb {
  background: linear-gradient(135deg, #f5a524, #635bff);
  color: #fff;
}

.wow-title-row h1 {
  color: #101827;
}

.deal-count,
.summary-status {
  background: rgba(22, 163, 107, 0.1);
  color: #08784d;
}

.hero-offer {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(240, 246, 255, 0.96)),
    #fff;
  border: 1px solid rgba(20, 30, 45, 0.1);
  box-shadow: 0 1rem 2.5rem rgba(19, 32, 54, 0.08);
}

.hero-offer h2,
.hot-strip h2,
.section-heading h2,
.product-info-panel h2,
.order-copy h2,
.final-cta h2 {
  color: #101827;
}

.hero-offer p,
.section-heading p,
.order-copy p,
.final-cta p,
.product-info-panel > p {
  color: var(--muted);
}

.hero-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  align-items: center;
}

.buyer-steps {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
}

.buyer-steps article {
  display: grid;
  grid-template-columns: 2.6rem 1fr;
  gap: 0.75rem;
  align-items: center;
  min-height: 4.5rem;
  padding: 0.8rem;
  border: 1px solid rgba(20, 30, 45, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 0.8rem 1.7rem rgba(19, 32, 54, 0.06);
}

.buyer-steps strong {
  display: inline-flex;
  width: 2.4rem;
  height: 2.4rem;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #edf0ff;
  color: var(--violet);
}

.buyer-steps span {
  color: var(--text);
  font-weight: 900;
}

.catalog-head > div {
  display: block;
}

.catalog-head {
  grid-template-columns: 1fr minmax(16rem, 26rem);
  align-items: end;
}

.section-kicker,
.eyebrow {
  color: var(--gold-2);
}

.catalog-search {
  color: var(--muted);
}

.catalog-search input,
.order-form input,
.order-form select,
.order-form textarea,
.account-form input,
.admin-edit-form input,
.admin-edit-form textarea,
.admin-edit-form select,
.chat-form input {
  background: #fff;
  border-color: rgba(20, 30, 45, 0.14);
  color: var(--text);
  color-scheme: light;
}

.order-form option,
.order-form optgroup {
  background: #fff;
  color: var(--text);
}

.category-sidebar .filter-button {
  background: #fff;
  border-color: rgba(20, 30, 45, 0.11);
  color: var(--text);
  box-shadow: 0 0.5rem 1.2rem rgba(19, 32, 54, 0.05);
}

.category-sidebar .filter-button.is-active,
.filter-button.is-active,
.order-tab.is-active {
  background: #101827;
  border-color: #101827;
  color: #fff;
}

.product-offer {
  background: #fff;
  border: 1px solid rgba(20, 30, 45, 0.1);
  box-shadow: 0 1rem 2.2rem rgba(19, 32, 54, 0.08);
}

.product-media {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(16, 24, 39, 0.72)),
    var(--offer-art);
}

.product-body h3 {
  color: #fff;
}

.product-perks {
  color: #eef3ff;
}

.product-price {
  border-color: rgba(255, 255, 255, 0.22);
}

.product-price span {
  color: rgba(255, 255, 255, 0.82);
}

.product-price strong {
  color: #fff2bf;
}

.product-offer .card-order-button {
  background: #101827;
  border-color: #101827;
  color: #fff;
}

.product-offer .card-order-button:hover,
.product-offer .card-order-button:focus-visible {
  background: var(--violet);
  border-color: var(--violet);
}

.wow-info-section,
.site-order-section,
.order-section,
.section,
.loot-section {
  color: var(--text);
}

.product-info-card,
.product-faq,
.loot-grid article,
.reviews-grid blockquote,
.order-form,
.order-summary,
.account-strip,
.admin-list,
.admin-detail,
.order-steps li {
  background: #fff;
  border-color: rgba(20, 30, 45, 0.1);
  box-shadow: 0 1rem 2.2rem rgba(19, 32, 54, 0.07);
}

.product-info-card h3,
.product-faq h3,
.product-faq summary,
.loot-grid h3,
.service-card h3,
.order-summary h3,
.flow-head h3,
.account-strip h3,
.reviews-grid p {
  color: var(--text);
}

.product-info-card ul,
.product-info-card ol,
.product-faq p,
.loot-grid p,
.service-card p,
.order-summary p,
.flow-head p,
.account-strip p,
.reviews-grid cite {
  color: var(--muted);
}

.product-faq details,
.flow-head,
.product-order-sidebar .order-summary {
  border-color: rgba(20, 30, 45, 0.1);
}

.product-order-sidebar {
  box-shadow: 0 1.5rem 3rem rgba(19, 32, 54, 0.12);
}

.product-order-art {
  background:
    linear-gradient(180deg, rgba(16, 24, 39, 0.05), rgba(16, 24, 39, 0.82)),
    linear-gradient(135deg, rgba(245, 165, 36, 0.76), rgba(99, 91, 255, 0.76)),
    #fff;
}

.product-order-art span {
  color: #fff2bf;
}

.product-order-art strong {
  color: #fff;
}

.product-order-sidebar .order-tabs,
.product-order-sidebar .order-form,
.product-order-sidebar .order-summary {
  background: #fff;
}

.product-order-sidebar .account-strip {
  background: #f4f7fb;
}

.order-tab,
.filter-button {
  background: #fff;
  border-color: rgba(20, 30, 45, 0.12);
  color: var(--text);
}

.range-control,
.check-option,
.price-list div,
.summary-list li,
.order-price-preview,
.my-order-card,
.profile-stat,
.order-history-item,
.chat-message {
  background: #f6f8fc;
  border-color: rgba(20, 30, 45, 0.1);
}

.price-list dt,
.check-option span,
.chat-message p {
  color: var(--text);
}

.price-list dd,
.order-price-preview strong,
.profile-stat strong,
.summary-id {
  color: var(--gold-2);
}

.copy-button,
.card-order-button {
  background: #fff;
  border-color: rgba(20, 30, 45, 0.16);
  color: var(--text);
}

.chat-form button,
.chat-launcher {
  background: var(--green);
  color: #fff;
}

.account-dialog,
.chat-popover {
  background: #fff;
  border-color: rgba(20, 30, 45, 0.12);
  color: var(--text);
}

.modal-close {
  background: #f6f8fc;
  border-color: rgba(20, 30, 45, 0.12);
  color: var(--text);
}

.final-cta {
  background: #fff;
  border-color: rgba(20, 30, 45, 0.1);
  box-shadow: 0 1rem 2.2rem rgba(19, 32, 54, 0.07);
}

footer {
  color: var(--muted);
}

footer span {
  color: var(--text);
}

@media (max-width: 760px) {
  .wow-category-hero .hero-bg {
    opacity: 0.14;
  }

  .wow-title-row h1 {
    font-size: clamp(2rem, 10vw, 2.75rem);
  }

  .hero-offer {
    padding: 1.1rem;
  }

  .hero-action-row {
    display: grid;
  }

  .buyer-steps {
    grid-template-columns: 1fr;
  }

  .catalog-head {
    display: grid !important;
    grid-template-columns: 1fr;
  }

  .catalog-head > div {
    display: block;
  }

  .catalog-search {
    display: none;
  }

  .product-body h3 {
    font-size: 1.28rem;
  }
}

@media (max-width: 760px) {
  .wow-category-hero {
    min-height: auto;
  }

  .wow-category-hero .hero-bg {
    height: 21rem;
  }

  .wow-hero-inner {
    grid-template-columns: 1fr;
    gap: 0.85rem;
    padding: 1.4rem 0 1.55rem;
  }

  .how-chip {
    grid-template-columns: 5rem 1fr;
    width: min(100%, 17rem);
  }

  .wow-title-row {
    margin-top: 2.3rem;
  }

  .hero-rating {
    display: none;
  }

  .hero-offer {
    min-height: 12rem;
    margin-top: 0.8rem;
    padding: 1.4rem 1.5rem;
  }

  .catalog-head,
  .catalog-layout,
  .wow-info-section,
  .product-page-layout {
    grid-template-columns: 1fr;
  }

  .catalog-head,
  .category-sidebar {
    display: none;
  }

  .category-sidebar {
    position: static;
    display: flex;
    gap: 0.5rem;
    max-height: none;
    overflow-x: auto;
    padding: 0 0 0.45rem;
  }

  .category-title {
    display: none;
  }

  .category-sidebar .filter-button {
    flex: 0 0 auto;
    width: auto;
    min-height: 2.75rem;
    white-space: nowrap;
  }

  .product-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .product-offer {
    min-height: 25rem;
  }

  .product-media {
    min-height: 12rem;
  }

  .catalog-head,
  .category-sidebar {
    display: none !important;
  }

  .product-order-sidebar {
    position: static;
  }

  .product-order-art {
    min-height: 12rem;
  }

  .product-order-sidebar .order-tabs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .product-info-grid {
    grid-template-columns: 1fr;
  }
}

/* Light theme product card polish */
.product-grid {
  gap: 1.25rem;
}

.product-offer {
  display: flex;
  min-height: 23rem;
  flex-direction: column;
  border-radius: 8px;
  background: #fff;
}

.product-media {
  min-height: 10.5rem;
  border-bottom: 1px solid rgba(20, 30, 45, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.02), rgba(16, 24, 39, 0.5)),
    linear-gradient(90deg, rgba(16, 24, 39, 0.08), rgba(16, 24, 39, 0.28)),
    var(--offer-image, none),
    var(--offer-art);
  background-position: center;
  background-size: cover;
}

.product-media::after {
  width: 4.25rem;
  height: 4.25rem;
  background: rgba(255, 255, 255, 0.1);
}

.product-body {
  flex: 1;
  gap: 0.6rem;
  margin-top: 0;
  padding: 1rem 1rem 0.75rem;
  background: #fff;
}

.product-body h3 {
  color: var(--text);
  font-size: 1.16rem;
  line-height: 1.18;
}

.product-perks {
  gap: 0.3rem;
  min-height: 0;
  color: var(--muted);
  font-size: 0.9rem;
}

.product-price {
  border-top: 1px solid rgba(20, 30, 45, 0.1);
}

.product-price span {
  color: var(--muted);
}

.product-price strong {
  color: var(--gold-2);
}

.product-offer .card-order-button {
  min-height: 2.75rem;
  margin: auto 1rem 1rem;
}

.art-gold {
  --offer-image: url("./assets/product-gold.webp?v=20260624");
}

.art-leveling {
  --offer-image: url("./assets/product-leveling.webp?v=20260624");
}

.art-voidspire,
.art-dreamrift {
  --offer-image: url("./assets/product-raid.webp?v=20260624");
}

.art-keys {
  --offer-image: url("./assets/product-keys.webp?v=20260624");
}

.art-collect {
  --offer-image: url("./assets/product-collect.webp?v=20260624");
}

.product-order-sidebar .order-tabs {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.range-control {
  gap: 0.85rem;
  min-height: 5.25rem;
  padding: 0.95rem;
  border-radius: 10px;
  background: #f8fafd;
}

.range-meta strong {
  font-size: 1.08rem;
}

.range-control input[type="range"] {
  width: 100%;
  min-height: 2rem;
  appearance: none;
  -webkit-appearance: none;
  cursor: grab;
  background: transparent;
  touch-action: pan-y;
}

.range-control input[type="range"]:active {
  cursor: grabbing;
}

.range-control input[type="range"]:disabled {
  cursor: default;
  opacity: 0.7;
}

.range-control input[type="range"]::-webkit-slider-runnable-track {
  height: 0.6rem;
  border-radius: 999px;
  background:
    linear-gradient(90deg, var(--violet) 0 var(--range-progress, 0%), #d9dee8 var(--range-progress, 0%) 100%);
}

.range-control input[type="range"]::-webkit-slider-thumb {
  width: 1.45rem;
  height: 1.45rem;
  margin-top: -0.425rem;
  border: 0.28rem solid #fff;
  border-radius: 50%;
  appearance: none;
  -webkit-appearance: none;
  background: var(--violet);
  box-shadow: 0 0.35rem 0.9rem rgba(99, 91, 255, 0.35), 0 0 0 1px rgba(20, 30, 45, 0.12);
}

.range-control input[type="range"]::-moz-range-track {
  height: 0.6rem;
  border-radius: 999px;
  background: #d9dee8;
}

.range-control input[type="range"]::-moz-range-progress {
  height: 0.6rem;
  border-radius: 999px;
  background: var(--violet);
}

.range-control input[type="range"]::-moz-range-thumb {
  width: 1rem;
  height: 1rem;
  border: 0.28rem solid #fff;
  border-radius: 50%;
  background: var(--violet);
  box-shadow: 0 0.35rem 0.9rem rgba(99, 91, 255, 0.35), 0 0 0 1px rgba(20, 30, 45, 0.12);
}

@media (max-width: 760px) {
  .catalog-head {
    display: grid !important;
    grid-template-columns: 1fr;
    margin-bottom: 0.9rem;
  }

  .catalog-search,
  .category-sidebar {
    display: none !important;
  }

  .product-offer {
    min-height: 21rem;
  }

  .product-media {
    min-height: 9.5rem;
  }

  .product-order-sidebar .order-tabs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Dark premium storefront theme */
:root {
  color-scheme: dark;
  --bg: #080d14;
  --panel: #111824;
  --panel-2: #162132;
  --line: rgba(213, 225, 255, 0.13);
  --text: #f5f7fb;
  --muted: #aeb9cc;
  --gold: #f6b84b;
  --gold-2: #ffd27a;
  --violet: #8a7cff;
  --ember: #ff6a3d;
  --green: #32d28f;
  --cyan: #31c6dd;
  --shadow: rgba(0, 0, 0, 0.42);
}

body {
  background:
    radial-gradient(circle at 18% -4%, rgba(138, 124, 255, 0.2), transparent 27rem),
    radial-gradient(circle at 88% 1%, rgba(246, 184, 75, 0.16), transparent 25rem),
    linear-gradient(180deg, #080d14 0%, #0c1420 38rem, #101825 100%);
  color: var(--text);
}

.site-header {
  background: rgba(8, 13, 20, 0.88);
  border-bottom: 1px solid rgba(213, 225, 255, 0.1);
  box-shadow: 0 1rem 2.3rem rgba(0, 0, 0, 0.32);
}

.brand,
.site-header nav,
.site-header nav a,
.wow-title-row h1,
.hero-offer h2,
.hot-strip h2,
.section-heading h2,
.product-info-panel h2,
.order-copy h2,
.final-cta h2,
.product-info-card h3,
.product-faq h3,
.product-faq summary,
.loot-grid h3,
.service-card h3,
.order-summary h3,
.flow-head h3,
.account-strip h3,
.reviews-grid p,
footer span {
  color: var(--text);
}

.site-header nav a:hover,
.site-header nav a:focus-visible {
  color: var(--gold-2);
}

.account-button,
.admin-header-link,
.secondary-action,
.copy-button,
.card-order-button {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(213, 225, 255, 0.14);
  color: var(--text);
}

.wow-category-hero {
  border-bottom: 1px solid rgba(213, 225, 255, 0.09);
}

.wow-category-hero .hero-bg {
  opacity: 0.28;
  filter: saturate(1.12) contrast(1.08);
}

.wow-category-hero .hero-shade {
  background:
    linear-gradient(180deg, rgba(8, 13, 20, 0.58) 0%, rgba(8, 13, 20, 0.92) 31rem, #0c1420 100%),
    linear-gradient(90deg, rgba(8, 13, 20, 0.94), rgba(8, 13, 20, 0.62), rgba(8, 13, 20, 0.92));
}

.breadcrumbs,
.hero-rating,
.product-breadcrumbs,
.catalog-search,
.hero-offer p,
.section-heading p,
.order-copy p,
.final-cta p,
.product-info-panel > p,
.product-info-card ul,
.product-info-card ol,
.product-faq p,
.loot-grid p,
.service-card p,
.order-summary p,
.flow-head p,
.account-strip p,
.reviews-grid cite,
footer {
  color: var(--muted);
}

.how-chip,
.hero-offer,
.buyer-steps article,
.final-cta {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.03)),
    rgba(17, 24, 36, 0.94);
  border-color: rgba(213, 225, 255, 0.12);
  box-shadow: 0 1.2rem 2.7rem rgba(0, 0, 0, 0.32);
}

.buyer-steps strong,
.deal-count,
.summary-status {
  background: rgba(246, 184, 75, 0.13);
  color: var(--gold-2);
}

.buyer-steps span,
.section-kicker,
.eyebrow {
  color: var(--gold-2);
}

.catalog-search input,
.order-form input,
.order-form select,
.order-form textarea,
.account-form input,
.admin-edit-form input,
.admin-edit-form textarea,
.admin-edit-form select,
.chat-form input {
  background: #0c1320;
  border-color: rgba(213, 225, 255, 0.14);
  color: var(--text);
  color-scheme: dark;
}

.order-form option,
.order-form optgroup {
  background: #0c1320;
  color: var(--text);
}

.category-sidebar .filter-button,
.filter-button,
.order-tab {
  background: rgba(255, 255, 255, 0.055);
  border-color: rgba(213, 225, 255, 0.12);
  color: var(--text);
  box-shadow: 0 0.6rem 1.4rem rgba(0, 0, 0, 0.16);
}

.category-sidebar .filter-button.is-active,
.filter-button.is-active,
.order-tab.is-active {
  background: linear-gradient(135deg, #f6b84b, #ff6a3d);
  border-color: rgba(255, 210, 122, 0.42);
  color: #160b05;
}

.product-offer {
  background: #101824;
  border: 1px solid rgba(213, 225, 255, 0.12);
  box-shadow: 0 1.2rem 2.8rem rgba(0, 0, 0, 0.36);
}

.product-media {
  border-bottom-color: rgba(213, 225, 255, 0.1);
  background:
    linear-gradient(180deg, rgba(8, 13, 20, 0.02), rgba(8, 13, 20, 0.62)),
    linear-gradient(90deg, rgba(8, 13, 20, 0.1), rgba(8, 13, 20, 0.36)),
    var(--offer-image, none),
    var(--offer-art);
  background-position: center;
  background-size: cover;
}

.product-body {
  background: #101824;
}

.product-body h3 {
  color: var(--text);
}

.product-perks,
.product-price span {
  color: var(--muted);
}

.product-price {
  border-color: rgba(213, 225, 255, 0.12);
}

.product-price strong,
.price-list dd,
.order-price-preview strong,
.profile-stat strong,
.summary-id {
  color: var(--gold-2);
}

.product-offer .card-order-button {
  background: #f6b84b;
  border-color: #f6b84b;
  color: #160b05;
}

.product-offer .card-order-button:hover,
.product-offer .card-order-button:focus-visible {
  background: #ff6a3d;
  border-color: #ff6a3d;
  color: #fff;
}

.wow-info-section,
.site-order-section,
.order-section,
.section,
.loot-section {
  color: var(--text);
}

.raid-format-panel,
.product-info-card,
.product-faq,
.loot-grid article,
.reviews-grid blockquote,
.order-form,
.order-summary,
.account-strip,
.admin-list,
.admin-detail,
.order-steps li {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.03)),
    #111824;
  border-color: rgba(213, 225, 255, 0.12);
  box-shadow: 0 1.2rem 2.8rem rgba(0, 0, 0, 0.28);
}

.raid-format-panel {
  display: grid;
  gap: 1.35rem;
  padding: 1.25rem;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 8px;
}

.raid-format-panel section {
  display: grid;
  gap: 0.45rem;
}

.raid-format-panel h3 {
  margin: 0;
  color: var(--text);
  font-size: 1.08rem;
  font-weight: 400;
}

.raid-format-panel h3 span {
  color: var(--text);
}

.raid-format-panel p,
.raid-format-panel ul {
  margin: 0;
  color: #d8deea;
  font-weight: 400;
}

.raid-format-panel ul {
  display: grid;
  gap: 0.28rem;
  padding: 0;
  list-style: none;
}

.raid-format-panel strong {
  color: inherit;
  font-weight: inherit;
}

.product-faq details,
.flow-head,
.product-order-sidebar .order-summary {
  border-color: rgba(213, 225, 255, 0.12);
}

.product-order-sidebar {
  position: sticky;
  top: 5.75rem;
  max-height: calc(100vh - 6.25rem);
  overflow: auto;
  overscroll-behavior: contain;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 8px;
  background: #101824;
  box-shadow: 0 1.6rem 3.4rem rgba(0, 0, 0, 0.46);
}

.product-order-art {
  --order-image: url("./assets/product-keys.webp?v=20260624");
  min-height: 15rem;
  background:
    linear-gradient(180deg, rgba(8, 13, 20, 0.1), rgba(8, 13, 20, 0.88)),
    linear-gradient(135deg, rgba(246, 184, 75, 0.22), rgba(138, 124, 255, 0.32)),
    var(--order-image),
    #101824;
  background-position: center;
  background-size: cover;
}

.product-order-art[data-service="keys"] {
  --order-image: url("./assets/product-keys.webp?v=20260624");
}

.product-order-art[data-service="raids"] {
  --order-image: url("./assets/product-raid.webp?v=20260624");
}

.product-order-art[data-service="leveling"] {
  --order-image: url("./assets/product-leveling.webp?v=20260624");
}

.product-order-art[data-service="collect"],
.product-order-art[data-service="other"] {
  --order-image: url("./assets/product-collect.webp?v=20260624");
}

.product-order-art[data-service="gold"] {
  --order-image: url("./assets/product-gold.webp?v=20260624");
}

.product-order-art span {
  color: var(--gold-2);
}

.product-order-art strong {
  color: #fff;
  text-shadow: 0 0.7rem 1.6rem rgba(0, 0, 0, 0.62);
}

.product-order-sidebar .order-tabs,
.product-order-sidebar .order-form,
.product-order-sidebar .order-summary,
.product-order-sidebar .account-strip {
  background: #101824;
}

.range-control,
.check-option,
.price-list div,
.summary-list li,
.order-price-preview,
.my-order-card,
.profile-stat,
.order-history-item,
.chat-message {
  background: #0c1320;
  border-color: rgba(213, 225, 255, 0.12);
}

.price-list dt,
.check-option span,
.chat-message p {
  color: var(--text);
}

.range-control input[type="range"]::-webkit-slider-runnable-track {
  background:
    linear-gradient(90deg, var(--gold) 0 var(--range-progress, 0%), #2b3444 var(--range-progress, 0%) 100%);
}

.range-control input[type="range"]::-webkit-slider-thumb {
  background: #ff6a3d;
  box-shadow: 0 0.35rem 0.9rem rgba(255, 106, 61, 0.38), 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.range-control input[type="range"]::-moz-range-track {
  background: #2b3444;
}

.range-control input[type="range"]::-moz-range-progress {
  background: var(--gold);
}

.range-control input[type="range"]::-moz-range-thumb {
  background: #ff6a3d;
  box-shadow: 0 0.35rem 0.9rem rgba(255, 106, 61, 0.38), 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.account-dialog,
.chat-popover,
.modal-close {
  background: #111824;
  border-color: rgba(213, 225, 255, 0.12);
  color: var(--text);
}

.chat-form button,
.chat-launcher {
  background: var(--green);
  color: #04100b;
}

@media (max-width: 1100px) {
  .wow-info-section {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .wow-category-hero .hero-bg {
    opacity: 0.2;
  }

  .product-order-sidebar {
    position: static;
    max-height: none;
    overflow: visible;
  }

  .raid-format-panel {
    padding: 1rem;
  }
}

/* Raid catalog and product pages */
.raid-catalog-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
  margin-bottom: 1rem;
  padding: 0.85rem 1rem;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 8px;
  background: rgba(12, 19, 32, 0.72);
}

.raid-catalog-toolbar div {
  display: grid;
  gap: 0.2rem;
}

.raid-catalog-toolbar strong {
  color: var(--gold-2);
  font-size: 1.15rem;
}

.raid-catalog-toolbar > span {
  color: var(--muted);
  font-size: 0.92rem;
  text-align: right;
}

.raid-lot-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.raid-lot-card {
  overflow: hidden;
  display: grid;
  min-width: 0;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 8px;
  background: #101824;
  box-shadow: 0 1.2rem 2.6rem rgba(0, 0, 0, 0.28);
  cursor: pointer;
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.raid-lot-card:hover,
.raid-lot-card:focus-within {
  transform: translateY(-3px);
  border-color: rgba(246, 184, 75, 0.48);
  box-shadow: 0 1.6rem 3rem rgba(0, 0, 0, 0.4);
}

.raid-lot-media {
  min-height: 10.8rem;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 0.75rem;
  background:
    linear-gradient(180deg, rgba(8, 13, 20, 0.06), rgba(8, 13, 20, 0.82)),
    linear-gradient(135deg, rgba(246, 184, 75, 0.18), rgba(138, 124, 255, 0.24)),
    url("./assets/product-raid.webp?v=20260624"),
    #111824;
  background-position: center;
  background-size: cover;
}

.raid-lot-media[data-combo="dreamrift"] {
  background-position: 55% center;
}

.raid-lot-media[data-combo="keldanas"] {
  background:
    linear-gradient(180deg, rgba(8, 13, 20, 0.08), rgba(8, 13, 20, 0.84)),
    linear-gradient(135deg, rgba(255, 106, 61, 0.22), rgba(86, 192, 141, 0.18)),
    url("./assets/product-raid.webp?v=20260624"),
    #111824;
  background-position: 42% center;
  background-size: cover;
}

.raid-lot-media[data-difficulty="mythic"] {
  background:
    linear-gradient(180deg, rgba(8, 13, 20, 0.04), rgba(8, 13, 20, 0.86)),
    linear-gradient(135deg, rgba(138, 124, 255, 0.3), rgba(246, 184, 75, 0.15)),
    url("./assets/product-raid.webp?v=20260624"),
    #111824;
  background-position: center;
  background-size: cover;
}

.lot-chip {
  display: inline-flex;
  align-items: center;
  min-height: 1.9rem;
  padding: 0.35rem 0.6rem;
  border: 1px solid rgba(246, 184, 75, 0.36);
  border-radius: 999px;
  background: rgba(246, 184, 75, 0.16);
  color: #ffe1a5;
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.lot-chip.muted {
  border-color: rgba(213, 225, 255, 0.16);
  background: rgba(12, 19, 32, 0.62);
  color: #d8deea;
}

.lot-badge-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.35rem;
  margin-left: auto;
}

.lot-badge-row span {
  display: inline-flex;
  align-items: center;
  min-height: 1.75rem;
  padding: 0.3rem 0.55rem;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(246, 184, 75, 0.92), rgba(145, 104, 255, 0.82));
  color: #0b0d13;
  box-shadow: 0 0.65rem 1.4rem rgba(0, 0, 0, 0.24);
  font-size: 0.72rem;
  font-weight: 950;
  text-transform: uppercase;
}

.raid-lot-body {
  display: grid;
  gap: 0.75rem;
  padding: 1rem;
}

.raid-lot-kicker {
  color: var(--gold-2);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.raid-lot-body h3 {
  margin: 0;
  font-size: 1.28rem;
  line-height: 1.16;
}

.raid-lot-body p {
  margin: 0;
  min-height: 3.35rem;
  color: var(--muted);
  font-size: 0.94rem;
}

.raid-mode-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.raid-mode-row span {
  padding: 0.32rem 0.5rem;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 999px;
  background: rgba(213, 225, 255, 0.06);
  color: #d8deea;
  font-size: 0.76rem;
  font-weight: 800;
}

.raid-lot-options {
  display: grid;
  gap: 0.35rem;
  min-height: 5.3rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.raid-lot-options li {
  color: #eef3fb;
  font-size: 0.9rem;
}

.raid-lot-options li::before {
  content: "";
  display: inline-block;
  width: 0.38rem;
  height: 0.38rem;
  margin-right: 0.45rem;
  border-radius: 50%;
  background: var(--green);
  vertical-align: middle;
}

.lot-card-bottom {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  align-items: center;
  padding-top: 0.75rem;
  border-top: 1px solid rgba(213, 225, 255, 0.12);
}

.lot-card-bottom div {
  display: grid;
  gap: 0.12rem;
}

.lot-card-bottom span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
}

.lot-card-bottom strong {
  color: var(--gold-2);
  font-size: 1.12rem;
}

.raid-empty {
  padding: 1rem;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 8px;
  background: #101824;
  color: var(--muted);
}

.lot-page-section {
  width: min(1180px, calc(100% - 2rem));
  margin: 0 auto;
  padding: 6.5rem 0 3rem;
}

.lot-page-section[hidden],
body:not(.lot-page-active) .lot-page-section {
  display: none !important;
}

body.lot-page-active .wow-category-hero,
body.lot-page-active .wow-catalog,
body.lot-page-active .wow-info-section,
body.lot-page-active .site-order-section,
body.lot-page-active .order-section,
body.lot-page-active #reviews,
body.lot-page-active .final-cta {
  display: none !important;
}

.lot-back {
  min-height: 2.55rem;
  margin-bottom: 1rem;
  padding: 0 0.85rem;
  border: 1px solid rgba(213, 225, 255, 0.14);
  border-radius: 8px;
  background: rgba(12, 19, 32, 0.78);
  color: var(--text);
  font: inherit;
  font-weight: 900;
  cursor: pointer;
}

.lot-page-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 25.5rem;
  gap: 1rem;
  align-items: start;
}

.lot-detail-panel,
.lot-buy-panel {
  min-width: 0;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.03)),
    #111824;
  box-shadow: 0 1.4rem 3rem rgba(0, 0, 0, 0.36);
}

.lot-detail-panel {
  display: grid;
  gap: 1rem;
  padding: 1rem;
}

.lot-detail-hero {
  display: grid;
  grid-template-columns: minmax(16rem, 0.75fr) minmax(0, 1fr);
  gap: 1rem;
  align-items: stretch;
}

.lot-hero-media {
  min-height: 19rem;
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(8, 13, 20, 0.08), rgba(8, 13, 20, 0.78)),
    linear-gradient(135deg, rgba(246, 184, 75, 0.18), rgba(138, 124, 255, 0.26)),
    url("./assets/product-raid.webp?v=20260624"),
    #101824;
  background-position: center;
  background-size: cover;
}

.lot-detail-copy {
  display: grid;
  align-content: center;
  gap: 0.85rem;
  min-width: 0;
}

.lot-detail-copy h2 {
  margin: 0;
  font-size: clamp(2rem, 4vw, 3.6rem);
  line-height: 0.98;
  letter-spacing: 0;
}

.lot-detail-copy p {
  margin: 0;
  color: #d8deea;
  font-size: 1rem;
}

.lot-meta-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.65rem;
}

.lot-meta-row span {
  min-width: 0;
  padding: 0.7rem;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 8px;
  background: #0c1320;
  color: var(--muted);
  font-size: 0.86rem;
}

.lot-meta-row strong {
  display: block;
  margin-top: 0.12rem;
  color: var(--text);
}

.lot-info-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
}

.lot-info-grid article {
  padding: 0.9rem;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 8px;
  background: #0c1320;
}

.lot-info-grid h3 {
  margin: 0 0 0.55rem;
  font-size: 1rem;
}

.lot-info-grid ul,
.lot-info-grid ol {
  display: grid;
  gap: 0.4rem;
  margin: 0;
  padding-left: 1.1rem;
  color: #d8deea;
}

.lot-buy-panel {
  position: sticky;
  top: 5.75rem;
  overflow: hidden;
}

.lot-buy-art {
  display: grid;
  align-content: end;
  min-height: 12rem;
  padding: 1rem;
  background:
    linear-gradient(180deg, rgba(8, 13, 20, 0.06), rgba(8, 13, 20, 0.9)),
    url("./assets/product-raid.webp?v=20260624"),
    #101824;
  background-position: center;
  background-size: cover;
}

.lot-buy-art span {
  color: var(--gold-2);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.lot-buy-art strong {
  margin-top: 0.25rem;
  color: #fff;
  font-size: 1.32rem;
  line-height: 1.1;
}

.lot-price-card,
.lot-buy-form,
.lot-cart-preview {
  min-width: 0;
  margin: 0.85rem;
}

.lot-price-card {
  display: grid;
  gap: 0.25rem;
  padding: 0.85rem;
  border: 1px solid rgba(246, 184, 75, 0.26);
  border-radius: 8px;
  background: rgba(246, 184, 75, 0.1);
}

.lot-price-card span,
.lot-price-card small {
  color: var(--muted);
}

.lot-price-card strong {
  color: var(--gold-2);
  font-size: 1.55rem;
}

.lot-buy-form {
  display: grid;
  min-width: 0;
  gap: 0.7rem;
}

.lot-service-fields {
  display: grid;
  gap: 0.75rem;
}

.lot-service-fields[hidden] {
  display: none !important;
}

.level-range-control .range-meta span:empty {
  display: none;
}

.range-number-control {
  min-height: auto;
  gap: 0.65rem;
  padding: 0.78rem;
}

.range-number-control .range-meta strong {
  color: var(--muted);
  font-size: 0.8rem;
  line-height: 1.15;
  text-transform: uppercase;
}

.range-number-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.65rem;
  align-items: stretch;
}

.range-number-input-row {
  display: flex;
  min-width: 0;
  align-items: center;
  gap: 0.55rem;
}

.range-number-input-row span {
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 900;
  white-space: nowrap;
}

.range-control .range-number-input {
  width: min(9.5rem, 100%);
  min-height: 2.45rem;
  border-color: rgba(246, 184, 75, 0.26);
  background: rgba(255, 255, 255, 0.055);
  color: #fff;
  text-align: center;
  font-weight: 950;
}

.range-control .range-number-input:focus {
  border-color: rgba(246, 184, 75, 0.62);
  box-shadow: 0 0 0 0.18rem rgba(246, 184, 75, 0.16);
  outline: none;
}

.lot-buy-form label {
  display: grid;
  min-width: 0;
  gap: 0.35rem;
  color: var(--muted);
  font-weight: 900;
}

.lot-buy-form input,
.lot-buy-form textarea,
.lot-buy-form select {
  width: 100%;
  min-width: 0;
  min-height: 2.75rem;
  border: 1px solid rgba(213, 225, 255, 0.14);
  border-radius: 8px;
  background: #0c1320;
  color: var(--text);
  font: inherit;
  padding: 0.68rem 0.75rem;
}

.lot-buy-form select {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.lot-buy-form .balance-toggle {
  display: flex !important;
  grid-template-columns: none;
  align-items: center;
}

.lot-buy-form .balance-toggle input {
  width: 1.05rem;
  min-width: 1.05rem;
  max-width: 1.05rem;
  height: 1.05rem;
  min-height: 1.05rem;
  padding: 0;
  flex: 0 0 1.05rem;
}

.lot-buy-form .balance-toggle span {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.lot-action-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.55rem;
}

.lot-action-row .primary-action,
.lot-action-row .secondary-action {
  width: 100%;
  justify-content: center;
  min-height: 2.9rem;
  padding: 0 0.8rem;
  font-size: 0.9rem;
}

.lot-buy-status {
  min-height: 1.2rem;
  margin: 0;
  color: var(--gold-2);
  font-weight: 800;
}

.lot-cart-preview {
  display: grid;
  gap: 0.65rem;
  padding: 0.85rem;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 8px;
  background: #0c1320;
}

.lot-cart-preview p {
  margin: 0;
  color: var(--muted);
}

.lot-cart-head,
.lot-cart-total {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  align-items: center;
}

.lot-cart-list {
  display: grid;
  gap: 0.45rem;
}

.lot-cart-list article {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.55rem;
  align-items: center;
  padding: 0.55rem;
  border: 1px solid rgba(213, 225, 255, 0.1);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.035);
}

.lot-cart-list strong,
.lot-cart-list span {
  display: block;
}

.lot-cart-list span {
  color: var(--muted);
  font-size: 0.82rem;
}

.lot-cart-list button {
  width: 1.8rem;
  height: 1.8rem;
  border: 1px solid rgba(213, 225, 255, 0.14);
  border-radius: 50%;
  background: transparent;
  color: var(--text);
  cursor: pointer;
}

.lot-cart-total strong {
  color: var(--gold-2);
}

.lot-cart-checkout {
  width: 100%;
  min-height: 2.8rem;
  padding: 0 0.85rem;
}

body.client-order-active main > section:not(.client-order-section) {
  display: none !important;
}

.client-order-section {
  min-height: calc(100vh - 5rem);
  padding: 7rem clamp(1rem, 3vw, 2rem) 3rem;
}

.client-order-shell {
  width: min(1040px, 100%);
  margin: 0 auto;
}

.client-order-card {
  display: grid;
  gap: 1rem;
  padding: clamp(1rem, 2vw, 1.35rem);
  border: 1px solid rgba(246, 184, 75, 0.24);
  border-radius: 10px;
  background:
    linear-gradient(180deg, rgba(28, 18, 48, 0.94), rgba(10, 14, 25, 0.94)),
    rgba(12, 19, 32, 0.92);
  box-shadow: 0 1.4rem 4rem rgba(0, 0, 0, 0.34);
}

.client-order-card header {
  display: flex;
  gap: 1rem;
  justify-content: space-between;
  align-items: start;
}

.client-order-card h1 {
  margin: 0.25rem 0;
  font-size: clamp(1.8rem, 3vw, 3rem);
  line-height: 1;
}

.client-order-card p {
  margin: 0;
  color: var(--muted);
}

.client-order-state,
.client-order-price {
  display: grid;
  gap: 0.2rem;
  min-width: 12rem;
  padding: 0.85rem;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.045);
}

.client-order-state strong,
.client-order-price strong {
  color: var(--gold-2);
  font-size: 1.2rem;
}

.client-order-state span,
.client-order-price span {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 900;
  text-transform: uppercase;
}

.client-order-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.55rem;
  margin: 0;
}

.client-order-grid div {
  display: grid;
  gap: 0.28rem;
  padding: 0.75rem;
  border: 1px solid rgba(213, 225, 255, 0.1);
  border-radius: 8px;
  background: rgba(12, 19, 32, 0.62);
}

.client-order-grid dt {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.client-order-grid dd {
  margin: 0;
  color: #fff;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.client-order-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.chat-order-card {
  padding: 0.65rem 0.9rem 0;
}

.chat-order-card[hidden] {
  display: none !important;
}

.chat-order-card button {
  width: 100%;
  display: grid;
  gap: 0.2rem;
  padding: 0.7rem;
  border: 1px solid rgba(246, 184, 75, 0.26);
  border-radius: 8px;
  background: rgba(246, 184, 75, 0.1);
  color: inherit;
  font: inherit;
  text-align: left;
  cursor: pointer;
}

.chat-order-card span {
  color: var(--gold-2);
  font-weight: 950;
}

.chat-order-card strong {
  overflow: hidden;
  color: #fff;
  font-size: 0.86rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.chat-order-card .chat-order-complete {
  justify-content: center;
  margin-top: 0.45rem;
  border-color: rgba(246, 184, 75, 0.58);
  background: linear-gradient(135deg, var(--gold), var(--gold-2));
  color: #1f1609;
  font-weight: 950;
  text-align: center;
}

@media (max-width: 760px) {
  .header-order-lookup {
    order: -1;
    width: 100%;
  }

  .header-order-lookup input {
    width: 100%;
  }

  .client-order-card header {
    display: grid;
  }

  .client-order-state,
  .client-order-price {
    min-width: 0;
  }

  .client-order-grid {
    grid-template-columns: 1fr;
  }
}

/* Modern client chat */
.chat-launcher {
  display: grid;
  min-width: 7.2rem;
  min-height: 3.25rem;
  gap: 0.05rem;
  justify-items: start;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--green), #f6b84b);
  color: #06150e;
  text-transform: none;
  letter-spacing: 0;
}

.chat-launcher span {
  font-size: 0.95rem;
  line-height: 1;
}

.chat-launcher small {
  font-size: 0.72rem;
  font-weight: 900;
  opacity: 0.78;
}

.chat-popover {
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03)),
    #101824;
}

.chat-popover header,
.admin-chat-panel header {
  display: flex;
  gap: 0.7rem;
  align-items: center;
}

.chat-agent-avatar {
  display: grid;
  flex: 0 0 auto;
  place-items: center;
  width: 2.45rem;
  height: 2.45rem;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--gold), #ff6a3d);
  color: #140805;
  font-weight: 1000;
}

.chat-quick-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-bottom: 0.7rem;
}

.chat-quick-actions button {
  min-height: 2rem;
  padding: 0 0.58rem;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 999px;
  background: #0c1320;
  color: #d8deea;
  font: inherit;
  font-size: 0.78rem;
  font-weight: 900;
  cursor: pointer;
}

.chat-message {
  width: fit-content;
  max-width: min(86%, 25rem);
  border: 1px solid rgba(213, 225, 255, 0.12);
}

.chat-message.client {
  justify-self: end;
  border-left: 1px solid rgba(86, 192, 141, 0.42);
  background: rgba(86, 192, 141, 0.12);
}

.chat-message.manager {
  justify-self: start;
  border-left: 1px solid rgba(246, 184, 75, 0.42);
  background: rgba(246, 184, 75, 0.1);
}

.chat-message.system {
  justify-self: center;
  max-width: 100%;
  border-left: 1px solid rgba(138, 124, 255, 0.42);
  background: rgba(138, 124, 255, 0.1);
}

.chat-message p {
  margin: 0;
}

.chat-form input {
  border-radius: 10px;
  background: #0c1320;
}

.chat-form button {
  border-radius: 10px;
}

/* Manager order workspace */
.admin-shell {
  width: min(92rem, calc(100% - 2rem));
}

.admin-layout {
  grid-template-columns: minmax(18rem, 22rem) minmax(0, 1fr);
}

.admin-detail {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.admin-order-workspace {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(22rem, 0.85fr);
  gap: 1rem;
  align-items: start;
}

.admin-order-main,
.admin-chat-panel {
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.03)),
    #111824;
  box-shadow: 0 1.2rem 2.8rem rgba(0, 0, 0, 0.28);
}

.admin-order-main {
  padding: 1rem;
}

.admin-chat-panel {
  position: sticky;
  top: 5.75rem;
  display: flex;
  flex-direction: column;
  min-height: 36rem;
  max-height: calc(100vh - 6.25rem);
  padding: 1rem;
}

.admin-chat-panel h3,
.admin-chat-panel p {
  margin: 0;
}

.admin-chat-panel p {
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 700;
}

.admin-chat-panel .chat-log {
  flex: 1 1 auto;
  min-height: 18rem;
  max-height: none;
}

.admin-detail-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
  margin-bottom: 1rem;
}

.admin-detail-head h2 {
  margin: 0.35rem 0 0.25rem;
  font-size: 1.7rem;
}

.admin-detail-head p {
  margin: 0;
  color: var(--muted);
}

.admin-detail-head > strong {
  flex: 0 0 auto;
  color: var(--gold-2);
  font-size: 1.25rem;
}

.admin-kpi-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.65rem;
  margin-bottom: 0.8rem;
}

.admin-kpi-row article {
  min-width: 0;
  padding: 0.7rem;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 8px;
  background: #0c1320;
}

.admin-kpi-row span {
  display: block;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-kpi-row strong {
  display: block;
  overflow-wrap: anywhere;
  margin-top: 0.15rem;
  color: var(--text);
}

.admin-summary-list {
  margin-top: 0.8rem;
}

.admin-order-top {
  display: flex;
  justify-content: space-between;
  gap: 0.5rem;
  align-items: center;
}

.admin-order-item em {
  padding: 0.2rem 0.45rem;
  border-radius: 999px;
  background: rgba(86, 192, 141, 0.12);
  color: #d8f5e8;
  font-size: 0.68rem;
  font-style: normal;
  font-weight: 900;
}

.admin-order-item b {
  color: var(--gold-2);
  font-size: 0.92rem;
}

@media (max-width: 1180px) {
  .raid-lot-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .lot-page-layout,
  .admin-order-workspace {
    grid-template-columns: 1fr;
  }

  .lot-buy-panel,
  .admin-chat-panel {
    position: static;
    max-height: none;
  }
}

@media (max-width: 760px) {
  .raid-catalog-toolbar,
  .lot-card-bottom,
  .admin-detail-head {
    align-items: stretch;
    flex-direction: column;
  }

  .raid-catalog-toolbar > span {
    text-align: left;
  }

  .raid-lot-grid,
  .lot-detail-hero,
  .lot-info-grid,
  .lot-meta-row,
  .lot-action-row,
  .admin-kpi-row {
    grid-template-columns: 1fr;
  }

  .lot-page-section {
    padding-top: 5.5rem;
  }

  .lot-detail-copy h2 {
    font-size: 2rem;
  }

  .admin-layout {
    grid-template-columns: 1fr;
  }

  .catalog-layout {
    grid-template-columns: 1fr;
  }

  .category-sidebar {
    position: static;
    display: flex !important;
    gap: 0.45rem;
    overflow-x: auto;
    padding: 0.6rem;
    scrollbar-width: none;
  }

  .category-sidebar::-webkit-scrollbar {
    display: none;
  }

  .category-sidebar .category-title {
    display: none;
  }

  .category-sidebar .filter-button {
    flex: 0 0 auto;
    min-height: 2.35rem;
    white-space: nowrap;
  }
}

/* Current storefront adjustments */
.service-offer-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
  margin-bottom: 1rem;
}

.service-offer-card {
  overflow: hidden;
  display: grid;
  min-width: 0;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 8px;
  background: #101824;
  box-shadow: 0 1.2rem 2.6rem rgba(0, 0, 0, 0.28);
  cursor: pointer;
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.service-offer-card:hover,
.service-offer-card:focus-within {
  transform: translateY(-3px);
  border-color: rgba(246, 184, 75, 0.48);
  box-shadow: 0 1.6rem 3rem rgba(0, 0, 0, 0.4);
}

.service-offer-media {
  min-height: 9rem;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 0.75rem;
  background:
    linear-gradient(180deg, rgba(8, 13, 20, 0.05), rgba(8, 13, 20, 0.78)),
    var(--service-image, url("./assets/product-raid.webp?v=20260624")),
    #111824;
  background-position: center;
  background-size: cover;
}

.service-offer-body {
  display: grid;
  gap: 0.75rem;
  padding: 1rem;
}

.service-offer-body h3 {
  margin: 0;
  font-size: 1.28rem;
  line-height: 1.16;
}

.service-offer-body p {
  min-height: 3.35rem;
  margin: 0;
  color: var(--muted);
  font-size: 0.94rem;
}

.service-offer-body ul {
  display: grid;
  gap: 0.35rem;
  min-height: 5rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.service-offer-body li {
  color: #eef3fb;
  font-size: 0.9rem;
}

.service-offer-body li::before {
  content: "";
  display: inline-block;
  width: 0.38rem;
  height: 0.38rem;
  margin-right: 0.45rem;
  border-radius: 50%;
  background: var(--gold);
  vertical-align: middle;
}

.raid-lot-media {
  background:
    linear-gradient(180deg, rgba(8, 13, 20, 0.06), rgba(8, 13, 20, 0.82)),
    linear-gradient(135deg, rgba(246, 184, 75, 0.12), rgba(138, 124, 255, 0.18)),
    var(--raid-image, url("./assets/product-raid.webp?v=20260624")),
    #111824;
  background-position: center;
  background-size: cover;
}

.raid-lot-media[data-combo="keldanas"],
.raid-lot-media[data-difficulty="mythic"] {
  background:
    linear-gradient(180deg, rgba(8, 13, 20, 0.05), rgba(8, 13, 20, 0.84)),
    var(--raid-image, url("./assets/product-raid.webp?v=20260624")),
    #111824;
  background-position: center;
  background-size: cover;
}

.lot-hero-media,
.lot-buy-art {
  background:
    linear-gradient(180deg, rgba(8, 13, 20, 0.08), rgba(8, 13, 20, 0.78)),
    var(--raid-image, url("./assets/product-raid.webp?v=20260624")),
    #101824;
  background-position: center;
  background-size: cover;
}

.lot-buy-art {
  background:
    linear-gradient(180deg, rgba(8, 13, 20, 0.06), rgba(8, 13, 20, 0.9)),
    var(--raid-image, url("./assets/product-raid.webp?v=20260624")),
    #101824;
}

.raid-difficulty-card[data-difficulty="mythic"] {
  border-color: rgba(190, 111, 255, 0.36);
  box-shadow: 0 1.45rem 3.2rem rgba(81, 22, 160, 0.44), 0 0 0 1px rgba(248, 200, 78, 0.12) inset;
}

.raid-difficulty-card[data-difficulty="heroic"] {
  border-color: rgba(248, 200, 78, 0.24);
  box-shadow: 0 1.25rem 2.7rem rgba(9, 49, 96, 0.35);
}

.raid-difficulty-card[data-difficulty="normal"] {
  border-color: rgba(185, 196, 214, 0.12);
  box-shadow: 0 1rem 2.2rem rgba(0, 0, 0, 0.28);
}

.raid-lot-card.raid-featured-boss-card[data-difficulty="mythic"] {
  border-color: rgba(104, 218, 125, 0.44);
  box-shadow: 0 1.5rem 3.2rem rgba(19, 80, 44, 0.42), 0 0 0 1px rgba(248, 200, 78, 0.14) inset;
}

.raid-featured-boss-media[data-featured-boss],
.lot-hero-media[data-featured-boss][data-difficulty],
.lot-buy-art[data-featured-boss][data-difficulty] {
  background:
    radial-gradient(circle at 70% 18%, rgba(212, 255, 100, 0.26), transparent 28%),
    linear-gradient(180deg, rgba(4, 10, 9, 0.04), rgba(4, 10, 9, 0.82)),
    var(--raid-image, url("./assets/raid-gnilotop-sporefall.webp?v=20260628")),
    #08110d;
  background-position: center;
  background-size: cover;
}

.raid-difficulty-media[data-difficulty="mythic"],
.lot-hero-media[data-difficulty="mythic"],
.lot-buy-art[data-difficulty="mythic"] {
  background:
    radial-gradient(circle at 76% 16%, rgba(248, 200, 78, 0.36), transparent 30%),
    radial-gradient(circle at 20% 22%, rgba(188, 70, 255, 0.55), transparent 38%),
    linear-gradient(180deg, rgba(7, 8, 18, 0.02), rgba(7, 8, 18, 0.72)),
    var(--raid-image, url("./assets/raid-all-distinct.webp?v=20260624")),
    #10111f;
  background-position: center;
  background-size: cover;
}

.raid-difficulty-media[data-difficulty="heroic"],
.lot-hero-media[data-difficulty="heroic"],
.lot-buy-art[data-difficulty="heroic"] {
  background:
    radial-gradient(circle at 72% 18%, rgba(248, 200, 78, 0.28), transparent 32%),
    linear-gradient(135deg, rgba(52, 125, 207, 0.2), rgba(248, 200, 78, 0.18)),
    linear-gradient(180deg, rgba(8, 13, 20, 0.08), rgba(8, 13, 20, 0.8)),
    var(--raid-image, url("./assets/raid-keldanas-distinct.webp?v=20260624")),
    #111824;
  background-position: center;
  background-size: cover;
}

.raid-difficulty-media[data-difficulty="normal"],
.lot-hero-media[data-difficulty="normal"],
.lot-buy-art[data-difficulty="normal"] {
  background:
    linear-gradient(180deg, rgba(12, 15, 24, 0.28), rgba(12, 15, 24, 0.88)),
    linear-gradient(135deg, rgba(126, 138, 156, 0.34), rgba(32, 42, 58, 0.48)),
    var(--raid-image, url("./assets/raid-dreamrift-distinct.webp?v=20260624")),
    #101824;
  background-position: center;
  background-size: cover;
}

.difficulty-chip.difficulty-mythic,
.lot-chip[data-difficulty="mythic"] {
  border-color: rgba(248, 200, 78, 0.72);
  background: linear-gradient(135deg, rgba(248, 200, 78, 0.92), rgba(177, 66, 255, 0.9));
  color: #070812;
  box-shadow: 0 0 1.1rem rgba(177, 66, 255, 0.42), 0 0 1.5rem rgba(248, 200, 78, 0.18);
}

.difficulty-chip.difficulty-heroic,
.lot-chip[data-difficulty="heroic"] {
  border-color: rgba(248, 200, 78, 0.42);
  background: linear-gradient(135deg, rgba(248, 200, 78, 0.72), rgba(55, 126, 215, 0.52));
  color: #0c1019;
}

.difficulty-chip.difficulty-normal,
.lot-chip[data-difficulty="normal"] {
  border-color: rgba(190, 201, 219, 0.2);
  background: rgba(130, 142, 160, 0.18);
  color: #c8d0dd;
}

.raid-difficulty-card[data-difficulty="normal"] .raid-lot-body h3,
.raid-difficulty-card[data-difficulty="normal"] .lot-card-bottom strong {
  color: #d5dae3;
}

.card-more {
  justify-self: end;
  align-self: center;
  color: var(--gold-2);
  font-size: 0.9rem;
  font-weight: 900;
}

.loot-distribution-card {
  display: grid;
  gap: 0.45rem;
  margin: 0.85rem;
  padding: 0.85rem;
  border: 1px solid rgba(86, 192, 141, 0.28);
  border-radius: 8px;
  background: rgba(86, 192, 141, 0.08);
}

.loot-distribution-card[data-mode="vip"],
.loot-distribution-card[data-mode="vip_armor"],
.loot-distribution-card[data-mode="one_client_priority"] {
  border-color: rgba(246, 184, 75, 0.38);
  background: rgba(246, 184, 75, 0.11);
}

.loot-distribution-card h3,
.loot-distribution-card p,
.loot-distribution-card ul {
  margin: 0;
}

.loot-distribution-card h3 {
  color: var(--text);
  font-size: 1rem;
}

.loot-distribution-card p,
.loot-distribution-card li {
  color: #d8deea;
  font-size: 0.9rem;
}

.loot-distribution-card ul {
  display: grid;
  gap: 0.35rem;
  padding-left: 1.05rem;
}

.chat-launcher {
  position: relative;
  min-width: 8.4rem;
  min-height: 3.45rem;
  box-shadow: 0 1rem 2.4rem rgba(0, 0, 0, 0.38), 0 0 0 1px rgba(255, 255, 255, 0.12) inset;
}

.chat-launcher::after {
  content: "";
  position: absolute;
  top: 0.55rem;
  right: 0.7rem;
  width: 0.62rem;
  height: 0.62rem;
  border: 2px solid #06150e;
  border-radius: 50%;
  background: #ff4f55;
}

.floating-chat {
  z-index: 80;
}

.admin-help,
.admin-tools {
  display: none !important;
}

.admin-shell {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  width: min(96rem, calc(100% - 1.5rem));
  height: calc(100vh - 4.7rem);
  padding: 1rem 0;
  overflow: hidden;
}

.admin-shell .section-heading {
  margin-bottom: 0.75rem;
}

.admin-shell .section-heading h1 {
  font-size: 1.65rem;
}

.admin-shell .section-heading p {
  margin: 0.35rem 0 0;
  max-width: none;
  font-size: 0.92rem;
}

.admin-layout,
.admin-order-workspace {
  min-height: 0;
  height: 100%;
  align-items: stretch;
}

.admin-list {
  max-height: none;
  min-height: 0;
}

.admin-order-main,
.admin-chat-panel {
  min-height: 0;
  max-height: 100%;
  overflow: auto;
}

.admin-chat-panel {
  position: static;
}

.admin-summary-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.45rem;
}

.admin-summary-list li {
  min-height: 2.6rem;
  padding: 0.55rem;
}

.admin-edit-form {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.55rem;
  margin-top: 0.75rem;
  padding-top: 0.75rem;
}

.admin-edit-form input,
.admin-edit-form textarea,
.admin-edit-form select {
  min-height: 2.25rem;
  padding: 0.5rem 0.6rem;
}

.admin-edit-form label span {
  font-size: 0.78rem;
}

@media (max-width: 1180px) {
  .service-offer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-shell {
    height: auto;
    overflow: visible;
  }
}

@media (max-width: 760px) {
  .service-offer-grid {
    grid-template-columns: 1fr;
  }

  .admin-summary-list,
  .admin-edit-form {
    grid-template-columns: 1fr;
  }
}

/* Admin screen should behave like an app workspace, not a long document. */
html.admin-root,
body.admin-page {
  overflow: hidden;
}

body.admin-page .admin-shell {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  height: calc(100vh - 4.6rem);
  overflow: hidden;
}

body.admin-page .admin-layout,
body.admin-page .admin-order-workspace {
  min-height: 0;
  height: 100%;
  overflow: hidden;
}

body.admin-page .admin-list,
body.admin-page .admin-order-main,
body.admin-page .admin-chat-panel {
  min-height: 0;
  max-height: 100%;
  overflow: auto;
}

@media (max-width: 1180px) {
  body.admin-page .admin-shell {
    height: calc(100vh - 4.6rem);
    overflow: hidden;
  }

  body.admin-page .admin-layout {
    grid-template-columns: minmax(14rem, 18rem) minmax(0, 1fr);
  }

  body.admin-page .admin-order-workspace {
    grid-template-columns: 1fr;
    grid-template-rows: minmax(0, 1fr) minmax(14rem, 0.72fr);
  }
}

@media (max-width: 760px) {
  body.admin-page .admin-layout {
    grid-template-columns: 1fr;
    grid-template-rows: 12rem minmax(0, 1fr);
  }

  body.admin-page .admin-order-workspace {
    grid-template-columns: 1fr;
    grid-template-rows: minmax(0, 1fr) minmax(12rem, 0.7fr);
  }
}

/* Header, admin alerts, and proactive chat */
.site-header nav {
  justify-self: center;
  gap: 0.35rem;
  padding: 0.28rem;
  border: 1px solid rgba(213, 225, 255, 0.1);
  border-radius: 999px;
  background: rgba(12, 19, 32, 0.58);
}

.site-header nav a {
  min-height: 2rem;
  padding: 0.38rem 0.78rem;
  border-radius: 999px;
  color: #d8deea;
  font-weight: 850;
}

.site-header nav a:hover,
.site-header nav a:focus-visible {
  background: rgba(246, 184, 75, 0.12);
  color: var(--gold-2);
}

.admin-topbar {
  display: grid;
  grid-template-columns: 8.5rem 8.5rem minmax(0, 1fr);
  gap: 0.75rem;
  align-items: stretch;
  margin: 0 0 0.85rem;
}

body.admin-page .admin-shell {
  grid-template-rows: auto auto minmax(0, 1fr);
}

.admin-alert-card {
  display: grid;
  align-content: center;
  gap: 0.1rem;
  min-height: 4.25rem;
  padding: 0.75rem 0.85rem;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 8px;
  background: #111824;
}

.admin-alert-card span {
  color: var(--muted);
  font-size: 0.75rem;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-alert-card strong {
  color: var(--gold-2);
  font-size: 1.55rem;
  line-height: 1;
}

.admin-online-strip {
  display: flex;
  min-width: 0;
  gap: 0.55rem;
  align-items: stretch;
  overflow-x: auto;
  padding: 0.2rem;
  scrollbar-width: thin;
}

.admin-online-user {
  display: grid;
  grid-template-columns: minmax(8rem, 1fr) auto;
  gap: 0.7rem;
  align-items: center;
  min-width: 16rem;
  max-width: 22rem;
  padding: 0.65rem 0.75rem;
  border: 1px solid rgba(86, 192, 141, 0.22);
  border-radius: 8px;
  background: rgba(86, 192, 141, 0.08);
  color: var(--text);
  font: inherit;
  text-align: left;
}

.admin-online-user.is-closed {
  opacity: 0.68;
  border-color: rgba(160, 166, 181, 0.22);
  background: rgba(160, 166, 181, 0.08);
}

.admin-online-user strong,
.admin-online-user small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-online-user small {
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 750;
}

.admin-online-user em {
  padding: 0.32rem 0.5rem;
  border-radius: 999px;
  background: rgba(246, 184, 75, 0.14);
  color: var(--gold-2);
  font-size: 0.72rem;
  font-style: normal;
  font-weight: 900;
}

.admin-online-actions {
  display: grid;
  gap: 0.35rem;
}

.admin-online-actions button {
  min-height: 1.95rem;
  padding: 0 0.55rem;
  border: 1px solid rgba(246, 184, 75, 0.28);
  border-radius: 999px;
  background: rgba(246, 184, 75, 0.14);
  color: var(--gold-2);
  font: inherit;
  font-size: 0.72rem;
  font-weight: 900;
  cursor: pointer;
}

.admin-online-actions button.danger-action {
  border-color: rgba(240, 100, 69, 0.45);
  background: rgba(240, 100, 69, 0.13);
  color: #ffb39f;
}

.admin-online-actions button:disabled {
  opacity: 0.55;
  cursor: default;
}

.admin-order-item.needs-reply {
  border-color: rgba(246, 184, 75, 0.5);
  background: rgba(246, 184, 75, 0.09);
}

.chat-launcher.has-unread {
  box-shadow: 0 0 0 3px rgba(246, 184, 75, 0.22), 0 1rem 2.3rem rgba(0, 0, 0, 0.3);
}

.chat-launcher {
  align-content: center;
  justify-items: center;
}

.chat-launcher::after {
  display: none;
}

.chat-launcher.has-unread::after {
  content: "";
  display: block;
  position: absolute;
  top: 0.45rem;
  right: 0.45rem;
  width: 0.62rem;
  height: 0.62rem;
  border: 2px solid #06150e;
  border-radius: 50%;
  background: #ff4f3d;
}

@media (max-width: 760px) {
  .admin-topbar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-online-strip {
    grid-column: 1 / -1;
  }

  .site-header nav {
    justify-content: flex-start;
    overflow-x: auto;
  }
}

/* Compact manager workspace */
body.admin-page .admin-shell {
  width: min(104rem, calc(100% - 1.25rem));
  padding: 0.7rem 0;
}

body.admin-page .admin-layout {
  grid-template-columns: minmax(13.75rem, 16.5rem) minmax(0, 1fr);
  gap: 0.75rem;
}

.admin-topbar {
  grid-template-columns: 7.25rem 7.25rem minmax(10rem, 1fr) minmax(9.5rem, auto) minmax(11rem, 1fr) auto;
  gap: 0.55rem;
  margin-bottom: 0.65rem;
}

.admin-alert-card {
  min-height: 3.65rem;
  padding: 0.6rem 0.7rem;
}

.admin-catalog-status {
  min-width: 0;
}

.admin-catalog-status strong,
.admin-catalog-status small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-catalog-refresh {
  align-self: stretch;
  min-height: 3.65rem;
  white-space: nowrap;
}

@media (max-width: 68rem) {
  .admin-topbar {
    grid-template-columns: repeat(2, minmax(7.25rem, 1fr));
  }

  .admin-visitors-trigger,
  .admin-reviews-trigger,
  .admin-catalog-status,
  .admin-catalog-refresh {
    grid-column: span 2;
  }
}

.admin-visitors-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  min-width: 0;
  padding: 0.6rem 0.8rem;
  border: 1px solid rgba(86, 192, 141, 0.3);
  border-radius: 8px;
  background: rgba(86, 192, 141, 0.09);
  color: var(--text);
  font: inherit;
  cursor: pointer;
}

.admin-visitors-trigger > span,
.admin-visitors-trigger small {
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 850;
}

.admin-visitors-trigger strong {
  display: grid;
  justify-items: end;
  gap: 0.08rem;
  color: #d8f5e8;
  font-size: 1.25rem;
}

.admin-visitors-trigger strong small {
  color: #a8cfbe;
  font-size: 0.7rem;
  font-weight: 800;
}

.admin-reviews-trigger {
  border-color: rgba(188, 70, 255, 0.34);
  background: rgba(188, 70, 255, 0.1);
}

.admin-reviews-trigger strong {
  color: #ead8ff;
}

.admin-reviews-trigger strong small {
  color: #d4b8f5;
}

.admin-list {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 0.55rem;
  padding: 0.55rem;
  overflow: hidden !important;
}

.admin-list-toolbar {
  display: grid;
  gap: 0.45rem;
}

.admin-list-toolbar input,
.admin-visitors-panel > input {
  width: 100%;
  min-height: 2.3rem;
  padding: 0 0.65rem;
  border: 1px solid rgba(213, 225, 255, 0.14);
  border-radius: 7px;
  background: #0c1320;
  color: var(--text);
  font: inherit;
  outline: none;
}

.admin-list-toolbar input:focus,
.admin-visitors-panel > input:focus {
  border-color: rgba(248, 200, 78, 0.62);
  box-shadow: 0 0 0 0.16rem rgba(248, 200, 78, 0.14);
}

.admin-list-filters {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.3rem;
}

.admin-list-filters button {
  min-height: 1.85rem;
  padding: 0 0.25rem;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.045);
  color: var(--muted);
  font: inherit;
  font-size: 0.68rem;
  font-weight: 900;
  cursor: pointer;
}

.admin-list-filters button.is-active {
  border-color: rgba(248, 200, 78, 0.52);
  background: rgba(248, 200, 78, 0.16);
  color: var(--gold-2);
}

.admin-order-list {
  min-height: 0;
  overflow: auto;
  scrollbar-width: thin;
}

.admin-order-item {
  min-height: 0;
  gap: 0.28rem;
  margin-bottom: 0.4rem;
  padding: 0.5rem 0.55rem;
}

.admin-order-item .admin-order-copy {
  overflow: hidden;
  color: var(--muted);
  font-size: 0.77rem;
  line-height: 1.25;
  text-align: left;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-order-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.4rem;
  min-width: 0;
}

.admin-order-bottom small {
  min-width: 0;
  overflow: hidden;
  text-align: left;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-order-bottom b {
  flex: 0 0 auto;
  font-size: 0.76rem;
}

.admin-order-workspace {
  grid-template-columns: minmax(0, 1fr) minmax(20rem, 0.72fr);
  gap: 0.75rem;
}

.admin-order-main {
  padding: 0.85rem;
}

.admin-detail-head {
  margin-bottom: 0.7rem;
}

.admin-detail-head h2 {
  font-size: 1.35rem;
}

.admin-price-block {
  display: grid;
  justify-items: end;
  gap: 0.18rem;
  text-align: right;
}

.admin-price-block small {
  color: var(--muted);
  font-size: 0.7rem;
  font-weight: 750;
}

.admin-client-strip {
  display: grid;
  grid-template-columns: 1fr 1.15fr 0.9fr 0.95fr;
  gap: 0.5rem;
  margin-bottom: 0.7rem;
  padding: 0.6rem;
  border: 1px solid rgba(213, 225, 255, 0.1);
  border-radius: 7px;
  background: rgba(9, 14, 26, 0.58);
}

.admin-client-strip span {
  min-width: 0;
}

.admin-client-strip small,
.admin-client-strip strong {
  display: block;
}

.admin-client-strip small {
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-client-strip strong {
  margin-top: 0.15rem;
  overflow-wrap: anywhere;
  font-size: 0.84rem;
}

.admin-summary-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 0;
}

.admin-summary-list li {
  min-height: 2.25rem;
  padding: 0.45rem 0.5rem;
}

.admin-summary-list li.is-wide {
  grid-column: 1 / -1;
}

.admin-summary-list strong {
  overflow-wrap: anywhere;
  font-size: 0.82rem;
}

.admin-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.7rem;
}

.admin-action-row .copy-button {
  min-height: 2.2rem;
  font-size: 0.78rem;
}

.admin-edit-disclosure {
  margin-top: 0.7rem;
  border-top: 1px solid rgba(213, 225, 255, 0.1);
}

.admin-edit-disclosure summary {
  padding: 0.7rem 0;
  color: var(--gold-2);
  font-size: 0.84rem;
  font-weight: 900;
  cursor: pointer;
}

.admin-edit-disclosure .admin-edit-form {
  margin-top: 0;
}

.admin-visitors-panel {
  position: fixed;
  z-index: 130;
  top: 5.15rem;
  right: 0.7rem;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 0.65rem;
  width: min(34rem, calc(100vw - 1.4rem));
  height: min(44rem, calc(100vh - 6rem));
  padding: 0.8rem;
  border: 1px solid rgba(248, 200, 78, 0.26);
  border-radius: 8px;
  background: #10111f;
  box-shadow: 0 1.5rem 4rem rgba(0, 0, 0, 0.52);
}

.admin-visitors-panel[hidden] {
  display: none;
}

.admin-reviews-panel {
  grid-template-rows: auto minmax(0, 1fr);
  width: min(42rem, calc(100vw - 1.4rem));
}

.admin-visitors-panel header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 0.75rem;
}

.admin-visitors-panel h2 {
  margin: 0.2rem 0 0;
  font-size: 1.2rem;
}

.admin-panel-close,
.admin-visitor-close {
  display: inline-grid;
  width: 2rem;
  min-width: 2rem;
  height: 2rem;
  place-items: center;
  border: 1px solid rgba(240, 100, 69, 0.42);
  border-radius: 6px;
  background: rgba(240, 100, 69, 0.1);
  color: #ffb39f;
  font: inherit;
  font-weight: 900;
  cursor: pointer;
}

.admin-visitor-reopen {
  display: inline-grid;
  width: 2rem;
  min-width: 2rem;
  height: 2rem;
  place-items: center;
  border: 1px solid rgba(86, 192, 141, 0.45);
  border-radius: 6px;
  background: rgba(86, 192, 141, 0.12);
  color: #8ff0bd;
  font: inherit;
  font-weight: 900;
  cursor: pointer;
}

.admin-visitors-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-content: start;
  gap: 0.45rem;
  min-height: 0;
  overflow: auto;
  padding-right: 0.15rem;
}

.admin-reviews-list {
  display: grid;
  align-content: start;
  gap: 0.55rem;
  min-height: 0;
  overflow: auto;
  padding-right: 0.15rem;
}

.admin-review-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.65rem;
  padding: 0.75rem;
  border: 1px solid rgba(213, 225, 255, 0.13);
  border-radius: 7px;
  background: rgba(7, 8, 18, 0.46);
}

.admin-review-item header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.7rem;
}

.admin-review-item header strong {
  color: var(--aws-gold-2);
}

.admin-review-item header span,
.admin-review-item small {
  color: var(--muted);
  font-size: 0.76rem;
}

.admin-review-item p {
  margin: 0.45rem 0;
  color: #e6e9f2;
  line-height: 1.42;
  white-space: pre-wrap;
}

.admin-review-rating {
  margin: 0.45rem 0 0;
}

.admin-review-author {
  display: block;
  margin-bottom: 0.35rem;
  word-break: break-word;
}

.admin-review-delete {
  align-self: start;
  display: grid;
  width: 2rem;
  min-width: 2rem;
  height: 2rem;
  place-items: center;
  border: 1px solid rgba(240, 100, 69, 0.42);
  border-radius: 6px;
  background: rgba(240, 100, 69, 0.1);
  color: #ffb39f;
  font: inherit;
  font-weight: 900;
  cursor: pointer;
}

.admin-online-user {
  display: flex;
  min-width: 0;
  max-width: none;
  min-height: 3.35rem;
  padding: 0.35rem;
  border-radius: 7px;
}

.admin-visitor-open {
  display: grid;
  flex: 1 1 auto;
  min-width: 0;
  gap: 0.15rem;
  padding: 0.2rem 0.35rem;
  border: 0;
  background: transparent;
  color: var(--text);
  font: inherit;
  text-align: left;
  cursor: pointer;
}

.admin-visitor-open:disabled,
.admin-visitor-close:disabled,
.admin-visitor-reopen:disabled {
  cursor: default;
  opacity: 0.55;
}

.admin-visitor-open strong,
.admin-visitor-open small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-visitor-open small {
  color: var(--muted);
  font-size: 0.7rem;
  font-weight: 750;
}

.admin-online-user .admin-visitor-close,
.admin-online-user .admin-visitor-reopen {
  align-self: center;
}

.admin-visitor-workspace {
  display: grid;
  align-content: start;
  gap: 0.75rem;
  max-width: 42rem;
  padding: 1rem;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 8px;
  background: #10111f;
}

.admin-visitor-workspace h2,
.admin-visitor-workspace p {
  margin: 0;
}

.admin-visitor-workspace p {
  color: var(--muted);
}

.admin-visitor-compose {
  display: grid;
  gap: 0.55rem;
}

.admin-visitor-compose label {
  display: grid;
  gap: 0.35rem;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 850;
}

.admin-visitor-compose textarea {
  width: 100%;
  min-height: 7rem;
  padding: 0.7rem;
  border: 1px solid rgba(213, 225, 255, 0.14);
  border-radius: 7px;
  background: #0c1320;
  color: var(--text);
  font: inherit;
  resize: vertical;
}

@media (max-width: 1180px) {
  body.admin-page .admin-layout {
    grid-template-columns: minmax(12.5rem, 14.5rem) minmax(0, 1fr);
  }

  .admin-order-workspace {
    grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.66fr);
  }
}

@media (max-width: 760px) {
  .admin-topbar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-visitors-trigger {
    grid-column: 1 / -1;
  }

  .admin-reviews-trigger {
    grid-column: 1 / -1;
  }

  .admin-visitors-list,
  .admin-client-strip,
  .admin-summary-list {
    grid-template-columns: 1fr;
  }

  .admin-order-workspace {
    grid-template-columns: 1fr;
  }
}

/* Typography and option-card polish */
body,
button,
input,
select,
textarea {
  font-family: "Segoe UI", Arial, "Noto Sans", sans-serif;
  font-variant-ligatures: none;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}

h1,
h2,
h3,
h4,
.brand,
.primary-action,
.secondary-action,
.filter-button,
.card-more,
.summary-status {
  letter-spacing: 0;
  font-family: "Segoe UI", Arial, "Noto Sans", sans-serif;
}

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

.check-option {
  position: relative;
  display: grid !important;
  grid-template-columns: auto 1fr;
  gap: 0.75rem !important;
  align-items: center;
  min-height: 4.05rem;
  padding: 0.85rem;
  border: 1px solid rgba(213, 225, 255, 0.14);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.02)),
    #0c1320;
  cursor: pointer;
  transition: border-color 160ms ease, background 160ms ease, transform 160ms ease, box-shadow 160ms ease;
}

.check-option:hover,
.check-option:focus-within {
  transform: translateY(-1px);
  border-color: rgba(246, 184, 75, 0.42);
  box-shadow: 0 0.8rem 1.8rem rgba(0, 0, 0, 0.26);
}

.check-option input {
  position: absolute;
  inline-size: 1px;
  block-size: 1px;
  opacity: 0;
  pointer-events: none;
}

.check-option-mark {
  display: grid;
  place-items: center;
  width: 2rem;
  height: 2rem;
  border: 1px solid rgba(213, 225, 255, 0.18);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.04);
}

.check-option-mark::after {
  content: "";
  width: 0.62rem;
  height: 0.62rem;
  border-radius: 50%;
  background: transparent;
  transition: background 160ms ease, transform 160ms ease;
}

.check-option input:checked + .check-option-mark {
  border-color: var(--gold);
  background: rgba(246, 184, 75, 0.14);
}

.check-option input:checked + .check-option-mark::after {
  background: linear-gradient(135deg, var(--gold), #ff6a3d);
  transform: scale(1.1);
}

.check-option:has(input:checked) {
  border-color: rgba(246, 184, 75, 0.58);
  background:
    linear-gradient(180deg, rgba(246, 184, 75, 0.16), rgba(246, 184, 75, 0.06)),
    #0c1320;
}

.check-option-copy {
  display: grid;
  gap: 0.15rem;
  min-width: 0;
}

.check-option-copy strong {
  color: var(--text);
  font-size: 0.96rem;
  line-height: 1.15;
}

.check-option-copy small {
  color: var(--gold-2);
  font-size: 0.82rem;
  font-weight: 900;
}

@media (max-width: 760px) {
  .check-grid {
    grid-template-columns: 1fr;
  }
}

/* AWS logo visual pass */
:root {
  --aws-purple: #a42cff;
  --aws-purple-2: #6d37ff;
  --aws-gold: #f8c84e;
  --aws-gold-2: #ffe7a3;
  --aws-ink: #070812;
}

body {
  background:
    radial-gradient(circle at 50% -8rem, rgba(164, 44, 255, 0.28), transparent 34rem),
    radial-gradient(circle at 8% 18rem, rgba(248, 200, 78, 0.12), transparent 24rem),
    linear-gradient(180deg, #080913 0%, #0d0e17 34rem, #070812 100%);
}

.site-header {
  border-bottom-color: rgba(248, 200, 78, 0.18);
  background: rgba(7, 8, 18, 0.88);
  box-shadow: 0 0.75rem 2.2rem rgba(7, 8, 18, 0.38);
}

.brand img {
  width: 2.45rem;
  height: 2.45rem;
  object-fit: cover;
  border: 1px solid rgba(248, 200, 78, 0.42);
  border-radius: 10px;
  box-shadow: 0 0 1rem rgba(164, 44, 255, 0.35);
}

.brand span {
  color: var(--aws-gold-2);
  text-shadow: 0 0 1rem rgba(164, 44, 255, 0.35);
}

.site-header nav {
  border-color: rgba(248, 200, 78, 0.14);
  background: rgba(10, 11, 24, 0.72);
}

.site-header nav a:hover,
.site-header nav a:focus-visible {
  background: rgba(164, 44, 255, 0.18);
  color: var(--aws-gold-2);
}

.primary-action,
.header-cta {
  background: linear-gradient(135deg, var(--aws-purple), var(--aws-gold));
  color: #080913;
}

.service-offer-card,
.raid-lot-card,
.lot-buy-panel,
.product-order-sidebar,
.admin-order-main,
.admin-chat-panel {
  border-color: rgba(248, 200, 78, 0.16);
  background:
    linear-gradient(180deg, rgba(164, 44, 255, 0.1), rgba(255, 255, 255, 0.025)),
    #10111f;
}

.service-offer-media::after,
.raid-lot-media::after,
.lot-hero-media::after {
  background:
    linear-gradient(180deg, rgba(7, 8, 18, 0.02), rgba(7, 8, 18, 0.76)),
    radial-gradient(circle at 50% 18%, rgba(164, 44, 255, 0.16), transparent 48%);
}

.lot-card-bottom {
  align-items: stretch;
}

.card-price-only {
  display: grid;
  width: 100%;
  min-height: 3rem;
  place-items: center;
  gap: 0.08rem;
  padding: 0.55rem 0.7rem;
  border: 1px solid rgba(248, 200, 78, 0.2);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(248, 200, 78, 0.13), rgba(164, 44, 255, 0.12));
}

.card-price-only span {
  color: rgba(255, 231, 163, 0.78);
  font-size: 0.7rem;
  font-weight: 900;
  line-height: 1;
}

.card-price-only strong {
  color: var(--aws-gold-2);
  font-size: 1.05rem;
  line-height: 1.15;
  text-align: center;
}

.card-more {
  display: none !important;
}

.chat-popover {
  width: min(31.5rem, calc(100vw - 1.25rem));
  max-height: min(42rem, calc(100vh - 2rem));
  border: 1px solid rgba(248, 200, 78, 0.18);
  background:
    radial-gradient(circle at 18% 0%, rgba(164, 44, 255, 0.22), transparent 16rem),
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03)),
    #0d0f1d;
  box-shadow: 0 1.6rem 3.5rem rgba(0, 0, 0, 0.5), 0 0 2rem rgba(164, 44, 255, 0.18);
}

.chat-popover header,
.admin-chat-panel header {
  align-items: flex-start;
}

.chat-popover h3 {
  margin: 0;
  color: var(--aws-gold-2);
  font-size: 1.08rem;
}

.chat-intro {
  margin: 0.12rem 0 0;
  color: #d9d3e8;
  font-size: 0.9rem;
  font-weight: 700;
}

.chat-agent-avatar {
  overflow: hidden;
  width: 3.1rem;
  height: 3.1rem;
  border: 1px solid rgba(248, 200, 78, 0.36);
  background: #080913;
  box-shadow: 0 0 1.4rem rgba(164, 44, 255, 0.34);
}

.chat-agent-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.chat-popover .chat-log {
  min-height: 20rem;
  align-content: start;
}

.chat-message {
  align-self: start;
}

.chat-message.system {
  color: #d8deea;
}

.chat-message.system.is-intro {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  justify-self: stretch;
  width: auto;
  max-width: none;
  min-height: 3.65rem;
  padding: 0.78rem 0.9rem;
  border: 1px solid rgba(248, 200, 78, 0.22);
  border-left: 1px solid rgba(248, 200, 78, 0.22);
  background:
    linear-gradient(135deg, rgba(248, 200, 78, 0.16), rgba(164, 44, 255, 0.16)),
    rgba(255, 255, 255, 0.035);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08), 0 0.8rem 1.8rem rgba(0, 0, 0, 0.18);
}

.chat-message.system.is-intro::before {
  content: "?";
  display: grid;
  place-items: center;
  width: 2rem;
  height: 2rem;
  margin-right: 0.72rem;
  border-radius: 8px;
  background: linear-gradient(135deg, #51c88c, var(--aws-gold));
  color: #06150e;
  font-weight: 1000;
  line-height: 1;
}

.chat-message.system.is-intro p {
  color: #fff3c8;
  font-weight: 900;
  line-height: 1.25;
}

.chat-form input {
  min-height: 2.85rem;
}

.chat-form button,
.chat-launcher {
  background: linear-gradient(135deg, #51c88c, var(--aws-gold));
  color: #06150e;
}

.chat-launcher {
  min-width: 6.8rem;
  min-height: 3.2rem;
}

@media (max-width: 760px) {
  .chat-popover {
    width: calc(100vw - 1rem);
  }
}

/* Fixed Midnight background and reviews */
html {
  background: #070812;
}

body {
  position: relative;
  isolation: isolate;
  background: transparent;
}

body::before,
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
}

body::before {
  z-index: -3;
  background:
    linear-gradient(180deg, rgba(7, 8, 18, 0.72), rgba(7, 8, 18, 0.88)),
    radial-gradient(circle at 50% 16%, rgba(22, 40, 92, 0.18), transparent 36rem),
    url("./assets/aws-midnight-bg.webp?v=20260624") center / cover no-repeat;
}

body::after {
  z-index: -2;
  opacity: 0.34;
  mix-blend-mode: screen;
  background:
    radial-gradient(circle at 25% 18%, rgba(74, 179, 255, 0.24), transparent 16rem),
    radial-gradient(circle at 72% 28%, rgba(255, 164, 45, 0.2), transparent 17rem),
    linear-gradient(115deg, transparent 0 42%, rgba(92, 190, 255, 0.18) 44%, transparent 47% 100%);
  animation: awsBackdropGlow 7.5s ease-in-out infinite;
}

@keyframes awsBackdropGlow {
  0%,
  100% {
    opacity: 0.22;
    filter: saturate(1) brightness(0.95);
  }

  45% {
    opacity: 0.42;
    filter: saturate(1.22) brightness(1.12);
  }

  58% {
    opacity: 0.28;
    filter: saturate(1.08) brightness(1);
  }
}

.wow-category-hero,
.wow-catalog,
.lot-page-section,
.wow-info-section,
.site-order-section,
.order-section,
.section,
.final-cta {
  position: relative;
  z-index: 0;
}

.review-login-panel,
.review-submit-panel {
  display: grid;
  grid-template-columns: minmax(14rem, 22rem) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
  margin-top: 1rem;
  padding: 1rem;
  border: 1px solid rgba(248, 200, 78, 0.18);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(9, 11, 24, 0.86), rgba(9, 11, 24, 0.72)),
    rgba(7, 8, 18, 0.78);
  box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.22);
  backdrop-filter: blur(10px);
}

.review-login-panel {
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
}

.review-login-panel .discord-mark {
  width: 3.8rem;
  height: 3.8rem;
}

.review-login-panel .discord-mark img,
.review-login-panel .discord-mark svg {
  width: 100%;
  height: 100%;
}

.review-login-panel h3,
.review-login-panel p {
  margin: 0;
}

.review-login-panel p {
  margin-top: 0.25rem;
  color: var(--muted);
  line-height: 1.45;
}

.review-login-panel .discord-login {
  white-space: nowrap;
}

.review-submit-panel h3 {
  margin: 0;
  color: var(--aws-gold-2);
  font-size: 1.25rem;
}

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

.review-form label {
  display: grid;
  gap: 0.35rem;
  color: var(--muted);
  font-weight: 900;
}

.review-author-card,
.review-form .wide-field,
.review-rating-field,
.review-form > button,
.review-status {
  grid-column: 1 / -1;
}

.review-author-card {
  display: grid;
  gap: 0.15rem;
  padding: 0.75rem 0.85rem;
  border: 1px solid rgba(88, 101, 242, 0.28);
  border-radius: 8px;
  background: rgba(88, 101, 242, 0.1);
}

.review-author-card span,
.review-author-card small {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 850;
}

.review-author-card strong {
  color: var(--text);
  font-size: 1rem;
}

.review-form input,
.review-form textarea {
  width: 100%;
  min-height: 2.75rem;
  border: 1px solid rgba(213, 225, 255, 0.16);
  border-radius: 8px;
  background: rgba(7, 8, 18, 0.8);
  color: var(--text);
  font: inherit;
  padding: 0.7rem 0.8rem;
}

.review-form textarea {
  resize: vertical;
}

.review-rating-field {
  align-content: start;
}

.review-star-picker {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

.review-star-picker button {
  width: 2.2rem;
  height: 2.2rem;
  min-height: 2.2rem;
  border: 1px solid rgba(248, 200, 78, 0.24);
  border-radius: 8px;
  background: rgba(7, 8, 18, 0.74);
  color: rgba(213, 225, 255, 0.45);
  font-size: 1.35rem;
  line-height: 1;
  padding: 0;
  cursor: pointer;
}

.review-star-picker button:hover,
.review-star-picker button:focus-visible,
.review-star-picker button.is-selected {
  border-color: rgba(248, 200, 78, 0.74);
  background: rgba(248, 200, 78, 0.12);
  color: var(--aws-gold-2);
}

.review-star-picker button:focus-visible {
  outline: 2px solid rgba(248, 200, 78, 0.5);
  outline-offset: 2px;
}

.review-stars-readonly {
  display: inline-flex;
  gap: 0.12rem;
  margin-bottom: 0.45rem;
  color: rgba(213, 225, 255, 0.28);
  font-size: 1.05rem;
  line-height: 1;
}

.review-stars-readonly .is-filled {
  color: var(--aws-gold-2);
}

.review-empty-text {
  color: var(--muted);
  font-style: italic;
}

.review-status {
  min-height: 1.25rem;
  margin: 0;
  color: var(--aws-gold-2);
  font-weight: 850;
}

.user-reviews-grid {
  margin-top: 1rem;
}

@media (max-width: 760px) {
  .review-login-panel,
  .review-submit-panel,
  .review-form {
    grid-template-columns: 1fr;
  }

  .review-login-panel .discord-login {
    width: 100%;
  }
}

/* Catalog card alignment */
.service-offer-grid,
.raid-lot-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-auto-rows: 1fr;
}

.service-offer-card,
.raid-lot-card {
  grid-template-rows: 10.8rem minmax(0, 1fr);
  min-height: 24rem;
}

.service-offer-media,
.raid-lot-media {
  min-height: 0;
  height: 10.8rem;
}

.service-offer-body {
  grid-template-rows: auto minmax(3.35rem, 1fr) auto;
}

.raid-lot-body {
  grid-template-rows: auto auto minmax(3.35rem, 1fr) auto;
}

.lot-card-bottom {
  align-self: end;
  margin-top: auto;
}

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

.raid-format-grid span {
  display: grid;
  min-width: 0;
  gap: 0.12rem;
  padding: 0.45rem 0.5rem;
  border: 1px solid rgba(213, 225, 255, 0.12);
  border-radius: 6px;
  background: rgba(7, 8, 18, 0.38);
}

.raid-format-grid strong {
  color: var(--gold-2);
  font-size: 0.78rem;
  line-height: 1.15;
}

.raid-format-grid small {
  color: #d6dbe7;
  font-size: 0.7rem;
  line-height: 1.25;
}

@media (max-width: 1180px) {
  .service-offer-grid,
  .raid-lot-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .service-offer-grid,
  .raid-lot-grid {
    grid-template-columns: 1fr;
  }

}
