:root {
  --bg: #0d0d10;
  --surface: #111116;
  --surface-2: #15151b;
  --line: rgba(255,255,255,.12);
  --line-soft: rgba(255,255,255,.075);
  --text: #f7f7f8;
  --muted: rgba(247,247,248,.66);
  --soft: rgba(247,247,248,.46);
  --purple: #8b5cf6;
  --purple-light: #b79cff;
  --shadow: 0 34px 110px rgba(0,0,0,.46);
  --max: 1560px;
}

/* =========================================================
   Respawn PCs Support page
========================================================= */

.respawn-support-page {
  --rp-support-bg: #171922;
  --rp-support-panel: #20232d;
  --rp-support-shell: min(1320px, calc(100% - 64px));
  --rp-support-text: #f5f7fb;
  --rp-support-muted: rgba(245,247,251,.70);
  --rp-support-line: rgba(255,255,255,.10);
  --rp-support-line-soft: rgba(255,255,255,.08);
  --rp-support-purple: #8b5cf6;
  --rp-support-purple-hover: #9b6cff;
  min-height: 100vh;
  background: var(--rp-support-bg);
  color: var(--rp-support-text);
}

.respawn-support-page *,
.respawn-support-page *::before,
.respawn-support-page *::after {
  box-sizing: border-box;
}

.respawn-support-page svg {
  width: 1em;
  height: 1em;
  display: block;
}

.respawn-support-page svg path,
.respawn-support-page svg circle {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.rp-support-shell {
  width: var(--rp-support-shell);
  margin-inline: auto;
}

.rp-support-hero {
  padding: clamp(78px, 7vw, 116px) 0 clamp(48px, 5vw, 72px);
  border-bottom: 1px solid var(--rp-support-line-soft);
  background:
    radial-gradient(circle at 28% 6%, rgba(139,92,246,.10), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,.012), transparent 100%),
    var(--rp-support-bg);
}

.rp-support-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, .86fr) minmax(420px, .74fr);
  gap: clamp(42px, 8vw, 120px);
  align-items: center;
}

.rp-support-eyebrow,
.rp-support-section-kicker,
.rp-support-panel-kicker {
  margin: 0;
  color: #a78bfa;
  text-transform: uppercase;
  letter-spacing: .24em;
  font-size: 11px;
  font-weight: 950;
}

.rp-support-hero-copy h1 {
  margin: 16px 0 0;
  color: var(--rp-support-text);
  font-size: clamp(64px, 7vw, 112px);
  line-height: .86;
  letter-spacing: -.095em;
  font-weight: 650;
}

.rp-support-hero-copy > p:not(.rp-support-eyebrow) {
  max-width: 560px;
  margin: 28px 0 0;
  color: var(--rp-support-muted);
  font-size: clamp(18px, 1.35vw, 22px);
  line-height: 1.55;
}

.rp-support-contact-card,
.rp-support-category-card,
.rp-support-panel,
.rp-support-faq-panel {
  border: 1px solid var(--rp-support-line);
  border-radius: 14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.012)),
    var(--rp-support-panel);
  box-shadow: 0 22px 70px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.035);
}

.rp-support-contact-card {
  padding: clamp(24px, 2.4vw, 34px);
}

.rp-support-card-head h2,
.rp-support-panel h2,
.rp-support-faq-head h2 {
  margin: 0;
  color: var(--rp-support-text);
  font-size: 22px;
  line-height: 1.15;
  letter-spacing: -.035em;
}

.rp-support-card-head p {
  margin: 8px 0 0;
  color: var(--rp-support-muted);
  font-size: 15px;
  line-height: 1.55;
}

.rp-support-contact-list {
  display: grid;
  gap: 0;
  margin-top: 22px;
}

.rp-support-contact-row {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  padding: 16px 0;
  border-top: 1px solid var(--rp-support-line-soft);
  color: var(--rp-support-text);
  text-decoration: none;
}

.rp-support-contact-row:first-child {
  border-top: 0;
  padding-top: 0;
}

.rp-support-contact-row small,
.rp-support-reach-row small,
.rp-support-link-list small {
  display: block;
  color: rgba(245,247,251,.62);
  font-size: 13px;
  font-weight: 800;
}

.rp-support-contact-row strong,
.rp-support-reach-row strong {
  display: block;
  margin-top: 4px;
  color: #fff;
  font-size: clamp(19px, 1.5vw, 24px);
  line-height: 1.1;
  letter-spacing: -.035em;
}

.rp-support-icon,
.rp-support-line-icon,
.rp-support-link-icon {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(183,156,255,.20);
  border-radius: 999px;
  background: rgba(139,92,246,.16);
  color: #b79cff;
  font-size: 22px;
  flex: 0 0 auto;
}

.rp-support-icon-large {
  width: 58px;
  height: 58px;
  font-size: 28px;
}

.rp-support-contact-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 18px;
}

.rp-support-button,
.rp-support-reach-row em {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(183,156,255,.38);
  border-radius: 10px;
  background: rgba(139,92,246,.08);
  color: #d8cbff;
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
  transition: background .18s ease, border-color .18s ease, color .18s ease;
}

.rp-support-button-primary {
  border-color: transparent;
  background: var(--rp-support-purple);
  color: #fff;
}

.rp-support-button:hover,
.rp-support-reach-row:hover em {
  border-color: rgba(183,156,255,.58);
  background: rgba(139,92,246,.14);
  color: #fff;
}

.rp-support-button-primary:hover {
  background: var(--rp-support-purple-hover);
}

.rp-support-categories {
  padding: 34px 0 26px;
  background: var(--rp-support-bg);
}

.rp-support-category-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-top: 16px;
}

.rp-support-category-card {
  min-height: 126px;
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr) 18px;
  gap: 17px;
  align-items: center;
  padding: 20px;
  color: var(--rp-support-text);
  text-decoration: none;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}

.rp-support-category-card:hover {
  transform: translateY(-2px);
  border-color: rgba(139,92,246,.34);
  background:
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.015)),
    var(--rp-support-panel);
}

.rp-support-category-copy strong,
.rp-support-link-list strong {
  display: block;
  color: #fff;
  font-size: 17px;
  line-height: 1.2;
}

.rp-support-category-copy small {
  display: block;
  margin-top: 8px;
  color: var(--rp-support-muted);
  font-size: 13px;
  line-height: 1.55;
}

.rp-support-arrow {
  color: #c8adff;
  font-size: 19px;
}

.rp-support-main {
  padding: 0 0 26px;
  background: var(--rp-support-bg);
}

.rp-support-main-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.06fr) minmax(0, 1.1fr) minmax(320px, .96fr);
  gap: 16px;
  align-items: stretch;
}

.rp-support-panel {
  padding: clamp(22px, 2vw, 28px);
}

.rp-support-panel h2 {
  margin-top: 12px;
  font-size: 18px;
  line-height: 1.35;
  letter-spacing: 0;
}

.rp-support-reach-list {
  display: grid;
  gap: 12px;
  margin-top: 22px;
}

.rp-support-reach-row {
  min-height: 76px;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 10px 14px;
  align-items: center;
  padding: 14px;
  border: 1px solid var(--rp-support-line-soft);
  border-radius: 12px;
  background: rgba(255,255,255,.018);
  color: var(--rp-support-text);
  text-decoration: none;
}

.rp-support-reach-row em {
  grid-column: 2;
  justify-self: start;
  min-height: 36px;
  padding: 0 14px;
  font-style: normal;
}

.rp-support-reach-row strong {
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
  font-size: clamp(18px, 1.25vw, 21px);
  line-height: 1.15;
}

.rp-support-response-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--rp-support-line-soft);
}

.rp-support-response-grid div {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}

.rp-support-line-icon {
  width: 38px;
  height: 38px;
  background: transparent;
  border-color: rgba(255,255,255,.16);
  color: rgba(245,247,251,.86);
  font-size: 20px;
}

.rp-support-response-grid p {
  margin: 0;
  color: var(--rp-support-muted);
  font-size: 13px;
  line-height: 1.35;
}

.rp-support-response-grid strong {
  display: block;
  color: #fff;
  font-size: 13px;
}

.rp-support-note {
  margin: 20px 0 0;
  padding: 13px 14px;
  border: 1px solid rgba(139,92,246,.26);
  border-radius: 10px;
  background: rgba(139,92,246,.08);
  color: #d8cbff;
  font-size: 13px;
  line-height: 1.45;
}

.rp-support-check-list {
  display: grid;
  gap: 22px;
  margin-top: 24px;
}

.rp-support-check-row {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.rp-support-check-row > span {
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(139,92,246,.58);
  border-radius: 999px;
  color: #a78bfa;
  font-size: 16px;
}

.rp-support-check-row strong {
  display: block;
  color: #fff;
  font-size: 15px;
  line-height: 1.35;
}

.rp-support-check-row p {
  margin: 6px 0 0;
  color: var(--rp-support-muted);
  font-size: 13px;
  line-height: 1.55;
}

.rp-support-link-list {
  display: grid;
  margin-top: 18px;
}

.rp-support-link-list a {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) 18px;
  gap: 14px;
  align-items: center;
  padding: 14px 0;
  border-top: 1px solid var(--rp-support-line-soft);
  color: var(--rp-support-text);
  text-decoration: none;
}

.rp-support-link-list a:first-child {
  border-top: 0;
}

.rp-support-link-icon {
  width: 34px;
  height: 34px;
  font-size: 17px;
}

.rp-support-link-list small {
  margin-top: 4px;
  line-height: 1.35;
}

.rp-support-faq-section {
  padding: 0 0 clamp(78px, 7vw, 112px);
  background: var(--rp-support-bg);
}

.rp-support-faq-panel {
  padding: clamp(22px, 2.2vw, 30px);
}

.rp-support-faq-head {
  display: grid;
  gap: 12px;
}

.rp-support-faq-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 22px;
}

.rp-support-faq-grid article {
  min-height: 150px;
  padding: 18px;
  border: 1px solid var(--rp-support-line-soft);
  border-radius: 12px;
  background: rgba(255,255,255,.018);
}

.rp-support-faq-grid h3 {
  margin: 0;
  color: #fff;
  font-size: 16px;
  line-height: 1.3;
}

.rp-support-faq-grid p {
  margin: 10px 0 0;
  color: var(--rp-support-muted);
  font-size: 13px;
  line-height: 1.55;
}

@media (max-width: 1180px) {
  .rp-support-hero-grid,
  .rp-support-main-grid {
    grid-template-columns: 1fr;
  }

  .rp-support-category-grid,
  .rp-support-faq-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .respawn-support-page {
    --rp-support-shell: min(100% - 28px, 540px);
  }

  .rp-support-hero {
    padding: 62px 0 42px;
  }

  .rp-support-hero-copy h1 {
    font-size: clamp(54px, 18vw, 78px);
  }

  .rp-support-contact-card,
  .rp-support-panel,
  .rp-support-faq-panel {
    border-radius: 12px;
  }

  .rp-support-contact-actions,
  .rp-support-category-grid,
  .rp-support-response-grid,
  .rp-support-faq-grid {
    grid-template-columns: 1fr;
  }

  .rp-support-category-card,
  .rp-support-reach-row {
    grid-template-columns: 48px minmax(0, 1fr);
  }

  .rp-support-category-card .rp-support-arrow,
  .rp-support-reach-row em {
    display: none;
  }

  .rp-support-contact-row,
  .rp-support-reach-row {
    align-items: start;
  }

  .rp-support-contact-row strong,
  .rp-support-reach-row strong {
    font-size: 18px;
    overflow-wrap: anywhere;
  }
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

body {
  min-height: 100vh;
  background: var(--bg);
  color: var(--text);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  overflow-x: hidden;
}

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

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

.shell {
  width: min(var(--max), calc(100% - 44px));
  margin-inline: auto;
}

/* NAV */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  border-bottom: 1px solid var(--line-soft);
  background: rgba(13,13,16,.84);
  backdrop-filter: blur(18px);
}

.nav {
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
}

.brand {
  display: inline-flex;
  align-items: center;
  min-width: max-content;
}

.brand-logo {
  height: 42px;
  width: auto;
  max-width: 210px;
  object-fit: contain;
  display: block;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 32px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 750;
}

.nav-links a:hover {
  color: #fff;
}

.nav-actions,
.hero-actions-main {
  display: flex;
  gap: 12px;
  align-items: center;
}

/* BUTTONS */
.btn {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 20px;
  border-radius: 999px;
  border: 1px solid transparent;
  font-size: 13px;
  font-weight: 850;
  letter-spacing: -.01em;
  transition: .18s ease;
  white-space: nowrap;
}

.btn-primary {
  background: var(--purple);
  color: #fff;
  box-shadow: 0 18px 46px rgba(139,92,246,.23);
}

.btn-primary:hover {
  background: #7c3aed;
  transform: translateY(-1px);
}

.btn-ghost {
  background: rgba(255,255,255,.045);
  border-color: var(--line);
  color: #fff;
}

.btn-ghost:hover {
  background: rgba(255,255,255,.075);
}

/* HERO */
.hero {
  min-height: calc(100vh - 72px);
  padding: 42px 0 56px;
  background: var(--bg);
  display: flex;
  align-items: center;
}

.hero-shell {
  display: grid;
  grid-template-columns: .88fr 1.12fr;
  gap: clamp(46px, 5vw, 92px);
  align-items: center;
}

.hero-copy {
  max-width: 660px;
}

.eyebrow {
  color: var(--purple-light);
  text-transform: uppercase;
  letter-spacing: .25em;
  font-size: 11px;
  font-weight: 950;
  margin-bottom: 20px;
}

h1 {
  font-size: clamp(58px, 7vw, 100px);
  line-height: .84;
  letter-spacing: -.095em;
}

.hero-kicker {
  margin-top: 26px;
  color: var(--muted);
  font-size: 19px;
  line-height: 1.7;
  max-width: 575px;
}

.price-row {
  display: flex;
  align-items: end;
  gap: 18px;
  flex-wrap: wrap;
  margin-top: 28px;
}

.price-label {
  display: block;
  color: var(--soft);
  font-size: 12px;
  font-weight: 800;
  margin-bottom: 3px;
}

.price {
  display: block;
  font-size: clamp(34px, 4vw, 48px);
  letter-spacing: -.055em;
  line-height: 1;
}

.finance-box {
  position: relative;
  align-self: stretch;
  min-width: 154px;
  padding: 14px 17px;
  border-radius: 18px;
  border: 1px solid rgba(167,139,250,.36);
  background: rgba(255,255,255,.045);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}

.finance-box::before {
  content: "";
  position: absolute;
  left: 14px;
  right: 14px;
  top: 0;
  height: 1px;
  background: rgba(183,156,255,.42);
}

.finance-box span {
  display: block;
  color: var(--soft);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 7px;
}

.finance-box strong {
  display: block;
  color: #fff;
  font-size: 17px;
  letter-spacing: -.035em;
  line-height: 1;
}

.hero-actions-main {
  margin-top: 28px;
}

.integrated-specs {
  margin-top: 30px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
}

.integrated-spec {
  padding: 17px 0;
  border-bottom: 1px solid var(--line-soft);
}

.integrated-spec:nth-child(odd) {
  padding-right: 24px;
}

.integrated-spec:nth-child(even) {
  padding-left: 24px;
  border-left: 1px solid var(--line-soft);
}

.integrated-spec:nth-last-child(-n+2) {
  border-bottom: 0;
}

.integrated-spec span {
  display: block;
  color: var(--purple-light);
  text-transform: uppercase;
  letter-spacing: .17em;
  font-size: 10px;
  font-weight: 950;
  margin-bottom: 7px;
}

.integrated-spec strong {
  font-size: 15px;
  letter-spacing: -.02em;
  line-height: 1.35;
}

.finance-note {
  margin-top: 13px;
  color: var(--soft);
  font-size: 12px;
}

.hero-media {
  position: relative;
  border-radius: 26px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.13);
  box-shadow: var(--shadow);
  background: #15151b;
  cursor: pointer;
}

.hero-media::before {
  content: "";
  position: absolute;
  inset: -1px;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(180deg, transparent 55%, rgba(0,0,0,.36));
}

.hero-media > img {
  width: 100%;
  height: min(74vh, 760px);
  min-height: 560px;
  object-fit: cover;
  background: #15151b;
  filter: brightness(.82) saturate(.9) contrast(1.04);
  transition: transform .32s ease, filter .32s ease;
}

.hero-media:hover > img {
  transform: scale(1.035);
  filter: brightness(.56) saturate(.78) contrast(1.06);
}

.image-hint {
  position: absolute;
  z-index: 3;
  right: 22px;
  bottom: 22px;
  border: 1px solid rgba(255,255,255,.13);
  background: rgba(5,7,10,.74);
  backdrop-filter: blur(16px);
  color: #fff;
  border-radius: 999px;
  padding: 10px 14px;
  font-size: 12px;
  font-weight: 900;
  transition: opacity .22s ease, transform .22s ease;
}

.hero-media:hover .image-hint {
  opacity: 0;
  transform: translateY(10px);
}

.fps-overlay {
  position: absolute;
  z-index: 4;
  inset: auto 22px 22px 22px;
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .26s ease, transform .26s ease;
  pointer-events: none;
}

.hero-media:hover .fps-overlay {
  opacity: 1;
  transform: translateY(0);
}

.fps-head {
  margin-bottom: 12px;
}

.fps-head span {
  display: block;
  color: var(--purple-light);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: 10px;
  font-weight: 950;
  margin-bottom: 4px;
}

.fps-head strong {
  font-size: 22px;
  letter-spacing: -.04em;
}

.fps-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.fps-card {
  position: relative;
  min-height: 108px;
  overflow: hidden;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.5);
}

.fps-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  min-height: auto;
  object-fit: cover;
  filter: brightness(.48) saturate(.9);
  transform: none !important;
}

.fps-card div {
  position: absolute;
  inset: auto 10px 10px 10px;
  z-index: 2;
}

.fps-card strong {
  display: block;
  font-size: 20px;
  line-height: 1;
  letter-spacing: -.04em;
}

.fps-card span {
  display: block;
  margin-top: 4px;
  color: rgba(255,255,255,.72);
  font-size: 11px;
  font-weight: 750;
}

.fps-overlay p {
  margin-top: 10px;
  color: rgba(255,255,255,.58);
  font-size: 12px;
}

/* PERFORMANCE TILES */
.performance-section {
  padding: 86px 0 110px;
  background: var(--bg);
  border-top: 1px solid var(--line-soft);
}

.performance-showcase {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: 310px 160px;
  gap: 14px;
}

.performance-tile {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background: #15151b;
  border: 1px solid rgba(255,255,255,.09);
  transition: transform .22s ease, border-color .22s ease;
}

.performance-tile:hover {
  transform: translateY(-3px);
  border-color: rgba(139,92,246,.42);
}

.performance-tile-large {
  grid-column: span 1;
  grid-row: span 1;
}

.performance-tile-wide {
  grid-column: span 3;
}

.performance-tile img {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(.64) saturate(.82) contrast(1.02);
  transform: scale(1.01);
  transition: transform .42s ease, filter .42s ease;
}

.performance-tile:hover img {
  transform: scale(1.055);
  filter: brightness(.74) saturate(.9) contrast(1.04);
}

.performance-tile-small img {
  object-position: center 38%;
}

.performance-tile-large img {
  object-position: center center;
}

.performance-tile .tile-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(0,0,0,.72), rgba(0,0,0,.18) 42%, rgba(0,0,0,.78)),
    linear-gradient(90deg, rgba(0,0,0,.58), rgba(0,0,0,.08) 58%);
}

.performance-tile-content {
  position: relative;
  z-index: 3;
  height: 100%;
  padding: clamp(26px, 2.2vw, 42px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 18px;
}

.performance-tile-content span {
  color: var(--purple-light);
  text-transform: uppercase;
  letter-spacing: .22em;
  font-size: 11px;
  font-weight: 950;
  margin-bottom: 14px;
}

.performance-tile-content h2 {
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
  color: #fff;
  font-size: clamp(34px, 3.35vw, 58px);
  line-height: .9;
  letter-spacing: -.075em;
}

.performance-tile-small .performance-tile-content h2 {
  font-size: clamp(27px, 2.1vw, 38px);
}

.performance-tile-content p {
  margin: 0 auto;
  max-width: 370px;
  color: rgba(247,247,248,.74);
  font-size: 15px;
  line-height: 1.55;
}

.performance-tile-featured {
  border-color: rgba(139,92,246,.32);
}

.performance-tile-custom {
  background: #8b5cf6;
  border-color: rgba(183,156,255,.46);
}

.performance-tile-custom::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(circle at 82% 24%, rgba(255,255,255,.18), transparent 28%),
    linear-gradient(135deg, #8b5cf6, #6d28d9 68%, #4c1d95);
}

.performance-tile-custom .performance-tile-content {
  flex-direction: row;
  align-items: center;
  gap: 32px;
}

.performance-tile-custom .performance-tile-content span,
.performance-tile-custom .performance-tile-content p {
  color: rgba(255,255,255,.78);
}

.performance-tile-custom .performance-tile-content h2 {
  font-size: clamp(28px, 3vw, 46px);
  white-space: nowrap;
}

.performance-tile-custom .performance-tile-content p {
  margin-top: 0;
  max-width: 380px;
}

.custom-lines {
  position: absolute;
  inset: 0;
  z-index: 1;
  opacity: .32;
  background:
    linear-gradient(150deg, transparent 0 42%, rgba(255,255,255,.8) 42.2% 42.6%, transparent 42.8%),
    linear-gradient(162deg, transparent 0 57%, rgba(255,255,255,.52) 57.2% 57.6%, transparent 57.8%),
    repeating-linear-gradient(90deg, transparent 0 88px, rgba(255,255,255,.25) 89px, transparent 90px);
}

.custom-pc-outline {
  position: absolute;
  z-index: 2;
  right: 7%;
  bottom: -16%;
  width: min(44%, 380px);
  aspect-ratio: 1 / 1.15;
  border: 2px solid rgba(255,255,255,.42);
  transform: skewY(-7deg) rotate(-2deg);
  opacity: .62;
}

.custom-pc-outline span {
  position: absolute;
  border: 2px solid rgba(255,255,255,.42);
}

.custom-pc-outline span:nth-child(1) {
  inset: 12% 12% auto 12%;
  height: 20%;
}

.custom-pc-outline span:nth-child(2) {
  left: 12%;
  bottom: 13%;
  width: 22%;
  aspect-ratio: 1;
  border-radius: 999px;
}

.custom-pc-outline span:nth-child(3) {
  right: 12%;
  bottom: 14%;
  width: 38%;
  height: 4px;
}

.custom-pc-outline span:nth-child(4) {
  right: 12%;
  top: 38%;
  width: 28%;
  height: 28%;
}
/* SHOP GRID */
.shop-grid-section {
  padding: 32px 0 96px;
  background: #0d0d10;
}

.shop-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: 270px 270px;
  gap: 18px;
}

.shop-tile {
  position: relative;
  overflow: hidden;
  background: #0b0b0d;
  min-height: 220px;
  isolation: isolate;
  border: 1px solid rgba(255,255,255,.06);
}

.shop-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .45s ease, filter .45s ease;
  filter: brightness(.78) saturate(.9);
}

.shop-tile:hover img {
  transform: scale(1.045);
  filter: brightness(.9) saturate(1);
}

.tile-large {
  grid-row: span 2;
}

.tile-wide {
  grid-column: span 2;
  background:
    linear-gradient(135deg, #8b5cf6 0%, #6d28d9 100%);
}

.tile-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(0,0,0,.56), transparent 46%),
    linear-gradient(90deg, rgba(0,0,0,.36), transparent 58%);
}

.tile-content {
  position: absolute;
  inset: 0;
  z-index: 2;
  padding: 32px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.tile-content span {
  color: rgba(255,255,255,.58);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .18em;
  margin-bottom: 16px;
}

.tile-content h3 {
  max-width: 520px;
  font-size: clamp(26px, 3.1vw, 48px);
  line-height: .9;
  letter-spacing: -.06em;
  text-transform: uppercase;
}

.tile-content p {
  margin-top: auto;
  max-width: 360px;
  color: rgba(255,255,255,.68);
  font-size: 14px;
  line-height: 1.55;
}

.config-lines {
  position: absolute;
  inset: 0;
  opacity: .42;
  background:
    linear-gradient(145deg, transparent 0 44%, rgba(255,255,255,.36) 44.2% 44.8%, transparent 45%),
    linear-gradient(160deg, transparent 0 58%, rgba(255,255,255,.22) 58.2% 58.8%, transparent 59%),
    repeating-linear-gradient(90deg, transparent 0 90px, rgba(255,255,255,.12) 91px, transparent 92px);
}

/* QUALITY */
.quality-section {
  padding: 96px 0 120px;
  background: #060607;
}

.quality-grid {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 56px;
  align-items: start;
}

.quality-grid h2 {
  font-size: clamp(44px, 6vw, 78px);
  line-height: .9;
  letter-spacing: -.08em;
}

.quality-cards {
  display: grid;
  gap: 14px;
}

.quality-cards article {
  padding: 24px;
  border: 1px solid var(--line-soft);
  background: rgba(255,255,255,.035);
}

.quality-cards span {
  color: var(--purple-light);
  font-size: 12px;
  font-weight: 950;
}

.quality-cards h3 {
  margin-top: 24px;
  font-size: 22px;
  letter-spacing: -.04em;
}

.quality-cards p {
  margin-top: 10px;
  color: var(--muted);
  line-height: 1.65;
}

/* MOBILE */
@media (max-width: 1050px) {
  .hero-shell {
    grid-template-columns: 1fr;
  }

  .hero-copy {
    max-width: 780px;
  }

  .hero-media > img {
    height: 560px;
    min-height: auto;
  }

  .tier-grid {
    grid-template-columns: repeat(2, 1fr);
  }

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

  .tile-large {
    grid-column: span 2;
  }
}

@media (max-width: 760px) {
  .shell {
    width: min(100% - 28px, var(--max));
  }

  .nav-links {
    display: none;
  }

  .nav-actions .btn-ghost {
    display: none;
  }

  .brand-logo {
    height: 36px;
    max-width: 170px;
  }

  .hero {
    min-height: auto;
    padding-top: 32px;
  }

  h1 {
    font-size: clamp(56px, 18vw, 82px);
  }

  .hero-kicker {
    font-size: 17px;
  }

  .hero-actions-main {
    flex-direction: column;
    align-items: stretch;
  }

  .btn {
    width: 100%;
  }

  .integrated-specs {
    grid-template-columns: 1fr;
  }

  .integrated-spec,
  .integrated-spec:nth-child(odd),
  .integrated-spec:nth-child(even) {
    padding: 16px 0;
    border-left: 0;
    border-bottom: 1px solid var(--line-soft);
  }

  .integrated-spec:last-child {
    border-bottom: 0;
  }

  .hero-media {
    border-radius: 22px;
  }

  .hero-media > img {
    height: 430px;
  }

  .fps-overlay {
    position: static;
    opacity: 1;
    transform: none;
    padding: 12px;
    pointer-events: auto;
  }

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

  .image-hint {
    display: none;
  }

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

  .shop-grid {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
  }

  .shop-tile,
  .tile-large,
  .tile-wide {
    grid-column: span 1;
    grid-row: span 1;
    height: 320px;
  }

  .tile-content {
    padding: 24px;
  }

}


@media (max-width: 1050px) {
  .performance-showcase {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 280px 280px 160px;
  }

  .performance-tile-large {
    grid-column: span 2;
  }

  .performance-tile-wide {
    grid-column: span 2;
  }
}

@media (max-width: 760px) {
  .performance-section {
    padding: 42px 0 64px;
  }

  .performance-showcase {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
  }

  .performance-tile,
  .performance-tile-large,
  .performance-tile-wide {
    grid-column: span 1;
    min-height: 260px;
  }

  .performance-tile-custom .performance-tile-content {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
  }

  .performance-tile-custom .performance-tile-content p {
    margin-top: auto;
  }

  .custom-pc-outline {
    width: 64%;
    right: -8%;
  }
}

/* WHY CHOOSE US */
.respawn-why-section {
  padding: 96px 0 110px;
  background: var(--bg);
  border-top: 1px solid var(--line-soft);
}

.respawn-why-grid {
  display: grid;
  grid-template-columns: .72fr 1.28fr;
  gap: clamp(48px, 6vw, 96px);
  align-items: start;
}

.respawn-why-header {
  position: sticky;
  top: 96px;
}

.respawn-why-heading {
  font-size: clamp(36px, 4.2vw, 62px);
  line-height: .92;
  letter-spacing: -.08em;
  font-weight: 600;
  margin-bottom: 22px;
}

.respawn-why-intro {
  color: var(--muted);
  font-size: 16px;
  line-height: 1.7;
  max-width: 420px;
}

/* STATS */
.why-stats {
  margin-top: 40px;
  border-top: 1px solid var(--line-soft);
}

.why-stat {
  padding: 20px 0;
  border-bottom: 1px solid var(--line-soft);
}

.why-stat strong {
  display: block;
  font-size: 38px;
  letter-spacing: -.08em;
  line-height: 1;
  margin-bottom: 5px;
}

.why-stat span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 600;
}

/* TAB PANEL POINTS */
.why-panel-points {
  margin-top: 24px;
  list-style: none;
  border-top: 1px solid var(--line-soft);
}

.why-panel-points li {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 15px 0;
  border-bottom: 1px solid var(--line-soft);
  color: var(--muted);
  font-size: 14px;
  line-height: 1.55;
}

.why-panel-points li::before {
  content: "→";
  color: var(--purple-light);
  flex-shrink: 0;
  font-size: 13px;
  font-weight: 900;
  margin-top: 1px;
}

@media (max-width: 1050px) {
  .respawn-why-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .respawn-why-header {
    position: static;
  }
}

.respawn-why-lines {
  border-top: 1px solid var(--line);
}

.respawn-why-line {
  padding: 28px 0;
  border-bottom: 1px solid var(--line-soft);
}

.respawn-why-line h3 {
  color: rgba(255,255,255,.34);
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.06;
  letter-spacing: -.06em;
  font-weight: 500;
  transition: color .18s ease;
}

.respawn-why-line p {
  display: none;
  max-width: 620px;
  margin-top: 10px;
  color: var(--muted);
  line-height: 1.7;
}

.respawn-why-line.active h3,
.respawn-why-line:hover h3 {
  color: #fff;
}

.respawn-why-line.active p,
.respawn-why-line:hover p {
  display: block;
}

/* WHY TABS */
.why-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--line);
  margin-top: 28px;
  list-style: none;
}

.why-tab {
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  padding: 11px 16px;
  color: var(--muted);
  font-family: inherit;
  font-size: 13px;
  font-weight: 750;
  letter-spacing: -.01em;
  cursor: pointer;
  transition: color .18s ease, border-color .18s ease;
  white-space: nowrap;
}

.why-tab:hover {
  color: #fff;
}

.why-tab.active {
  color: #fff;
  border-bottom-color: #fff;
}

.why-panels {
  min-height: 360px;
}

.why-panel {
  display: none;
  padding-top: 30px;
}

.why-panel.active {
  display: block;
}

.why-panel-title {
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.06;
  letter-spacing: -.065em;
  font-weight: 500;
  color: #fff;
  margin-bottom: 14px;
}

.why-panel-text {
  color: var(--muted);
  line-height: 1.7;
  max-width: 560px;
  font-size: 16px;
}

/* TEAM INSIDE TAB */
.why-team-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
  list-style: none;
}

.why-team-card {
  display: flex;
  gap: 18px;
  align-items: flex-start;
  padding: 18px;
  border: 1px solid rgba(255,255,255,.09);
  background: #15151b;
  transition: border-color .18s ease;
}

.why-team-card:hover {
  border-color: rgba(139,92,246,.38);
}

.why-team-photo {
  width: 68px;
  height: 68px;
  flex-shrink: 0;
  overflow: hidden;
  background: #111116;
}

.why-team-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(.86) saturate(.9);
}

.why-team-body {
  flex: 1;
  min-width: 0;
}

.why-team-body span {
  display: block;
  color: var(--purple-light);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: 10px;
  font-weight: 950;
  margin-bottom: 4px;
}

.why-team-body h3 {
  font-size: 20px;
  letter-spacing: -.045em;
  line-height: 1;
  margin-bottom: 6px;
}

.why-team-body p {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.6;
}

/* STANDALONE TEAM SECTION (kept for legacy compat) */
.respawn-team-section {
  padding: 52px 0 110px;
  background: var(--bg);
}

.respawn-team-heading {
  margin-bottom: 28px;
}

.respawn-team-heading h2 {
  max-width: 760px;
  font-size: clamp(38px, 5vw, 72px);
  line-height: 1.04;
  letter-spacing: -.065em;
  font-weight: 600;
}

.respawn-team-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.respawn-team-card {
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.09);
  background: #15151b;
  transition: transform .22s ease, border-color .22s ease, background .22s ease;
}

.respawn-team-card:hover {
  transform: translateY(-4px);
  border-color: rgba(139,92,246,.38);
  background: rgba(255,255,255,.045);
}

.respawn-team-photo {
  height: 350px;
  background:
    radial-gradient(circle at 50% 38%, rgba(139,92,246,.2), transparent 32%),
    #111116;
}

.respawn-team-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(.86) saturate(.9);
}

.respawn-team-info {
  padding: 26px;
}

.respawn-team-info span {
  display: block;
  color: var(--purple-light);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: 10px;
  font-weight: 950;
  margin-bottom: 14px;
}

.respawn-team-info h3 {
  font-size: 30px;
  line-height: 1;
  letter-spacing: -.055em;
}

.respawn-team-info p {
  margin-top: 12px;
  color: var(--muted);
  line-height: 1.65;
}

@media (max-width: 760px) {
  .why-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .why-tab {
    padding: 11px 13px;
    font-size: 12px;
  }
}


/* =========================================================
   HOMEPAGE SECTION RESTORE PATCH
   Fixes: Featured PCs, social carousel, footer on homepage,
   and Custom PCs strip alignment/colour.
========================================================= */

/* neutral dark grey, not blue */
:root {
  --bg: #0d0d10;
  --surface: #111116;
  --surface-2: #15151b;
  --purple: #8b5cf6;
  --purple-light: #b79cff;
}

/* READY TO SHIP / FEATURED PC CARDS */
.featured-builds-section {
  padding: 34px 0 104px;
  background: var(--bg);
  border-top: 1px solid var(--line-soft);
}

.featured-builds-head {
  display: grid;
  grid-template-columns: 1fr .82fr;
  gap: clamp(28px, 5vw, 78px);
  align-items: end;
  margin-bottom: 28px;
}

.featured-builds-head h2 {
  max-width: 760px;
  font-size: clamp(42px, 5.6vw, 78px);
  line-height: .9;
  letter-spacing: -.08em;
  font-weight: 600;
}

.featured-builds-head > p {
  color: var(--muted);
  line-height: 1.7;
  max-width: 560px;
}

.build-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.build-card {
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.09);
  background: var(--surface);
  transition: transform .22s ease, border-color .22s ease, background .22s ease;
}

.build-card:hover {
  transform: translateY(-4px);
  border-color: rgba(139,92,246,.42);
  background: rgba(255,255,255,.045);
}

.build-card-featured {
  border-color: rgba(183,156,255,.34);
  box-shadow: 0 0 0 1px rgba(139,92,246,.12), 0 22px 70px rgba(139,92,246,.12);
}

.build-card-banner {
  position: relative;
  min-height: 82px;
  padding: 19px 22px;
  border-bottom: 1px solid rgba(255,255,255,.075);
  background: linear-gradient(90deg, rgba(139,92,246,.28), rgba(139,92,246,.04)), var(--surface-2);
}

.build-card-banner span {
  display: block;
  color: var(--purple-light);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: 10px;
  font-weight: 950;
  margin-bottom: 8px;
}

.build-card-banner strong {
  display: block;
  font-size: 25px;
  line-height: 1;
  letter-spacing: -.045em;
}

.build-card-banner em {
  position: absolute;
  right: 18px;
  top: 18px;
  padding: 7px 10px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.8);
  font-style: normal;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.build-card-featured .build-card-banner em {
  background: rgba(139,92,246,.26);
  color: #fff;
  border-color: rgba(183,156,255,.34);
}

.build-card-media {
  position: relative;
  height: 370px;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 25%, rgba(139,92,246,.18), transparent 38%),
    #151515;
}

.build-card-media::before {
  content: "";
  position: absolute;
  inset: -1px;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(13,13,16,.02), rgba(13,13,16,.2) 62%, rgba(13,13,16,.58));
}

.build-card-media > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(.82) saturate(.9) contrast(1.02);
  transition: transform .34s ease, filter .34s ease;
}

.build-card:hover .build-card-media > img {
  transform: scale(1.035);
  filter: brightness(.5) saturate(.82) contrast(1.05);
}

.build-fps-overlay {
  position: absolute;
  z-index: 4;
  inset: auto 16px 16px 16px;
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .26s ease, transform .26s ease;
  pointer-events: none;
}

.build-card:hover .build-fps-overlay {
  opacity: 1;
  transform: translateY(0);
}

.build-fps-overlay .fps-head {
  margin-bottom: 10px;
}

.build-fps-overlay .fps-head strong {
  font-size: 20px;
}

.build-fps-overlay .fps-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}

.build-fps-overlay .fps-card {
  min-height: 88px;
  border-radius: 14px;
}

.build-fps-overlay .fps-card strong {
  font-size: 17px;
}

.build-fps-overlay p {
  margin-top: 10px;
  color: rgba(255,255,255,.58);
  font-size: 12px;
}

.build-hint {
  z-index: 5;
}

.build-card:hover .build-hint {
  opacity: 0;
  transform: translateY(8px);
}

.build-card-body {
  padding: 24px;
}

.build-card-fit {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.6;
}

.build-trust-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}

.build-trust-row span {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 10px;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 999px;
  background: rgba(255,255,255,.035);
  color: rgba(247,247,248,.72);
  font-size: 11px;
  font-weight: 850;
}

.build-spec-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  margin-top: 22px;
  background: rgba(255,255,255,.075);
  border: 1px solid rgba(255,255,255,.075);
}

.build-spec-grid div {
  padding: 14px;
  background: var(--surface);
}

.build-spec-grid span {
  display: block;
  color: var(--purple-light);
  text-transform: uppercase;
  letter-spacing: .15em;
  font-size: 9px;
  font-weight: 950;
  margin-bottom: 6px;
}

.build-spec-grid strong {
  font-size: 13px;
  line-height: 1.35;
}

.build-card-bottom {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 16px;
  margin-top: 24px;
}

.build-card-bottom span {
  display: block;
  color: var(--soft);
  font-size: 11px;
  font-weight: 800;
  margin-bottom: 4px;
}

.build-card-bottom strong {
  font-size: 32px;
  line-height: 1;
  letter-spacing: -.06em;
}

.build-card-bottom p {
  color: var(--muted);
  font-size: 14px;
  font-weight: 750;
  text-align: right;
}

.build-card-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 22px;
}

/* CUSTOM PC STRIP */
.performance-tile-custom {
  background: #9b6dff !important;
  border-color: rgba(205,188,255,.46) !important;
}

.performance-tile-custom::before {
  background:
    radial-gradient(circle at 82% 24%, rgba(255,255,255,.18), transparent 28%),
    linear-gradient(135deg, #a978ff 0%, #925cf7 55%, #7c3aed 100%) !important;
}

.performance-tile-custom .performance-tile-content {
  height: 100%;
  width: 100%;
  padding: clamp(26px, 2.2vw, 42px);
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  gap: 10px !important;
}

.performance-tile-custom .performance-tile-content span,
.performance-tile-custom .performance-tile-content h2,
.performance-tile-custom .performance-tile-content p {
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.performance-tile-custom .performance-tile-content span {
  margin-bottom: 0 !important;
  color: rgba(255,255,255,.82) !important;
}

.performance-tile-custom .performance-tile-content h2 {
  max-width: 760px !important;
  white-space: normal !important;
}

.performance-tile-custom .performance-tile-content p {
  margin-top: 0 !important;
  max-width: 620px !important;
  color: rgba(255,255,255,.82) !important;
}

/* EXPERT CTA */
.expert-section {
  padding: 26px 0 96px;
  background: var(--bg);
  border-top: 1px solid var(--line-soft);
}

.expert-card {
  display: grid;
  grid-template-columns: 1.12fr .88fr;
  gap: clamp(28px, 5vw, 78px);
  align-items: center;
  padding: clamp(34px, 4.4vw, 64px) 0;
  border-bottom: 1px solid var(--line-soft);
}

.expert-copy h2 {
  max-width: 820px;
  font-size: clamp(42px, 5.4vw, 78px);
  line-height: .9;
  letter-spacing: -.08em;
  font-weight: 600;
}

.expert-copy p:last-child {
  max-width: 620px;
  margin-top: 18px;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.7;
}

.expert-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  align-items: center;
}

/* SOCIAL MEDIA CAROUSEL */
.social-section {
  padding: 88px 0 118px;
  background: var(--bg);
  border-top: 1px solid var(--line-soft);
}

.social-top {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 28px;
  margin-bottom: 28px;
}

.social-heading-block h2 {
  max-width: 760px;
  font-size: clamp(42px, 5vw, 72px);
  line-height: .9;
  letter-spacing: -.08em;
  font-weight: 600;
}

.social-heading-block p:last-of-type {
  max-width: 620px;
  margin-top: 18px;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.7;
}

.social-marquee {
  position: relative;
  overflow: hidden;
  padding: 8px 0;
  border-top: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.social-marquee::before,
.social-marquee::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 84px;
  z-index: 4;
  pointer-events: none;
}

.social-marquee::before {
  left: 0;
  background: linear-gradient(90deg, var(--bg), rgba(13,13,16,0));
}

.social-marquee::after {
  right: 0;
  background: linear-gradient(270deg, var(--bg), rgba(13,13,16,0));
}

.social-track {
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch;
  gap: 18px;
  width: max-content;
  animation: socialMarquee 28s linear infinite;
}

.social-marquee:hover .social-track {
  animation-play-state: paused;
}

.social-video-card {
  width: 260px !important;
  flex: 0 0 260px !important;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.09);
  background: var(--surface);
  transition: transform .22s ease, border-color .22s ease, background .22s ease;
}

.social-video-card:hover {
  transform: translateY(-4px);
  border-color: rgba(139,92,246,.42);
  background: rgba(255,255,255,.045);
}

.social-video-thumb {
  position: relative;
  aspect-ratio: 9 / 16;
  overflow: hidden;
  background: #151515;
}

.social-video-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(.76) saturate(1.02);
  transition: transform .3s ease, filter .3s ease;
}

.social-video-card:hover .social-video-thumb img {
  transform: scale(1.035);
  filter: brightness(.84) saturate(1.06);
}

.social-video-thumb::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(13,13,16,.06), rgba(13,13,16,.08) 48%, rgba(13,13,16,.72));
}

.social-play {
  position: absolute;
  left: 16px;
  bottom: 16px;
  z-index: 2;
  width: 48px;
  height: 48px;
  border-radius: 999px;
  background: rgba(9,10,15,.74);
  border: 1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(10px);
}

.social-play::before {
  content: "";
  position: absolute;
  left: 18px;
  top: 14px;
  width: 0;
  height: 0;
  border-top: 9px solid transparent;
  border-bottom: 9px solid transparent;
  border-left: 14px solid #fff;
}

.social-video-meta {
  padding: 16px;
}

.social-video-meta span {
  display: block;
  color: var(--purple-light);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: 10px;
  font-weight: 950;
  margin-bottom: 10px;
}

.social-video-meta h3 {
  font-size: 18px;
  line-height: 1.3;
  letter-spacing: -.03em;
}

@keyframes socialMarquee {
  from { transform: translateX(0); }
  to { transform: translateX(calc(-50% - 9px)); }
}

@media (prefers-reduced-motion: reduce) {
  .social-track {
    animation: none;
  }
}

/* FOOTER RESTORE */
.site-footer {
  display: block !important;
  width: 100%;
  background: var(--bg);
  border-top: 1px solid var(--line-soft);
  padding: 72px 0 28px;
  margin-top: 0;
  color: var(--text);
}

.site-footer .footer-shell {
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: clamp(42px, 6vw, 96px);
  align-items: start;
}

.site-footer .footer-brand {
  max-width: 460px;
}

.site-footer .footer-logo {
  display: inline-flex;
  align-items: center;
  margin-bottom: 22px;
}

.site-footer .footer-logo img {
  display: block !important;
  height: 42px !important;
  width: auto !important;
  max-width: 210px !important;
  object-fit: contain !important;
}

.site-footer .footer-brand p {
  color: var(--muted);
  font-size: 15px;
  line-height: 1.75;
  max-width: 430px;
  margin: 0;
}

.site-footer .footer-links {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
}

.site-footer .footer-links h3 {
  color: #fff;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .18em;
  text-transform: uppercase;
  margin: 0 0 18px;
  line-height: 1;
}

.site-footer .footer-links a {
  display: block;
  width: max-content;
  max-width: 100%;
  color: var(--muted);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.35;
  margin: 0 0 12px;
  text-decoration: none;
  transition: color .18s ease, transform .18s ease;
}

.site-footer .footer-links a:hover {
  color: #fff;
  transform: translateX(2px);
}

.site-footer .footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-top: 58px;
  padding-top: 22px;
  border-top: 1px solid var(--line-soft);
  color: var(--soft);
  font-size: 12px;
  font-weight: 700;
}

.site-footer .footer-bottom p {
  margin: 0;
  color: var(--soft);
}

@media (max-width: 1050px) {
  .featured-builds-head,
  .build-card-grid,
  .expert-card {
    grid-template-columns: 1fr;
  }

  .expert-actions {
    justify-content: flex-start;
  }

  .social-top {
    flex-direction: column;
    align-items: flex-start;
  }

  .site-footer .footer-shell {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .featured-builds-section {
    padding: 26px 0 74px;
  }

  .build-card-media {
    height: auto;
  }

  .build-card-media > img {
    height: 320px;
  }

  .build-fps-overlay {
    position: static;
    opacity: 1;
    transform: none;
    padding: 0 14px 14px;
    pointer-events: auto;
  }

  .build-fps-overlay .fps-grid,
  .build-card-actions,
  .build-spec-grid {
    grid-template-columns: 1fr;
  }

  .build-hint {
    display: none;
  }

  .expert-section {
    padding: 18px 0 66px;
  }

  .expert-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .social-section {
    padding: 66px 0 82px;
  }

  .social-video-card {
    width: 220px !important;
    flex-basis: 220px !important;
  }

  .social-marquee::before,
  .social-marquee::after {
    width: 36px;
  }

  .site-footer {
    padding: 54px 0 24px;
  }

  .site-footer .footer-links {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .site-footer .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
    margin-top: 42px;
  }
}


/* =========================================================
   READY TO SHIP FINAL OVERRIDE
   Goal: match the larger screenshot mockup without changing the site colour scheme.
   This is intentionally loaded last.
========================================================= */

.featured-builds-section {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding: 92px 0 104px !important;
  background:
    radial-gradient(circle at 50% 36%, rgba(139,92,246,.10), transparent 34%),
    var(--bg) !important;
  border-top: 1px solid var(--line-soft) !important;
  border-bottom: 1px solid var(--line-soft) !important;
}

.featured-builds-section::before {
  content: none !important;
}

/* Make this section wide like the generated mockup, not tiny/narrow */
.featured-builds-section > .shell {
  width: min(1760px, calc(100% - 72px)) !important;
  max-width: 1760px !important;
}

.featured-builds-head {
  display: grid !important;
  grid-template-columns: 1.05fr .95fr !important;
  gap: clamp(42px, 8vw, 170px) !important;
  align-items: end !important;
  margin-bottom: 36px !important;
}

.featured-builds-head .eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: 9px !important;
  color: var(--purple-light) !important;
  letter-spacing: .22em !important;
}

.featured-builds-head .eyebrow::after {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--purple-light);
  box-shadow: 0 0 18px rgba(183,156,255,.62);
}

.featured-builds-head h2 {
  max-width: 760px !important;
  margin-top: 12px !important;
  color: #fff !important;
  font-size: clamp(64px, 6.15vw, 116px) !important;
  line-height: .88 !important;
  letter-spacing: -.108em !important;
  font-weight: 500 !important;
}

.featured-builds-head > p {
  justify-self: end !important;
  max-width: 610px !important;
  margin: 0 0 20px !important;
  color: var(--muted) !important;
  font-size: clamp(17px, 1.15vw, 22px) !important;
  line-height: 1.68 !important;
}

/* Cards: large, elegant, screenshot style */
.build-card-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 30px !important;
}

.build-card {
  display: block !important;
  position: relative !important;
  overflow: hidden !important;
  min-width: 0 !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.014)),
    var(--surface) !important;
  box-shadow:
    0 30px 86px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.035) !important;
  transform: none !important;
}

.build-card:hover {
  transform: translateY(-6px) !important;
  border-color: rgba(183,156,255,.38) !important;
  background:
    linear-gradient(180deg, rgba(139,92,246,.055), rgba(255,255,255,.012)),
    var(--surface) !important;
  box-shadow:
    0 36px 96px rgba(0,0,0,.36),
    0 0 0 1px rgba(139,92,246,.09),
    inset 0 1px 0 rgba(255,255,255,.05) !important;
}

.build-card-featured {
  border-color: rgba(183,156,255,.52) !important;
  box-shadow:
    0 34px 100px rgba(139,92,246,.14),
    0 0 0 1px rgba(139,92,246,.20),
    inset 0 1px 0 rgba(255,255,255,.05) !important;
}

.build-card-banner {
  position: relative !important;
  min-height: 116px !important;
  padding: 30px 74px 20px 28px !important;
  border-bottom: 0 !important;
  background:
    linear-gradient(180deg, rgba(139,92,246,.09), rgba(139,92,246,0)),
    transparent !important;
}

.build-card-banner::after {
  content: "→" !important;
  position: absolute !important;
  right: 24px !important;
  top: 25px !important;
  width: 48px !important;
  height: 48px !important;
  display: grid !important;
  place-items: center !important;
  border: 1px solid rgba(255,255,255,.22) !important;
  border-radius: 999px !important;
  color: rgba(255,255,255,.86) !important;
  font-size: 28px !important;
  line-height: 1 !important;
  background: rgba(255,255,255,.025) !important;
  transition: transform .2s ease, border-color .2s ease, color .2s ease;
}

.build-card:hover .build-card-banner::after {
  transform: translateX(3px);
  border-color: rgba(183,156,255,.5) !important;
  color: #fff !important;
}

.build-card-banner span {
  display: block !important;
  color: var(--purple-light) !important;
  letter-spacing: .22em !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  margin-bottom: 12px !important;
  text-transform: uppercase !important;
}

.build-card-banner strong {
  display: block !important;
  color: #fff !important;
  font-size: clamp(31px, 2.15vw, 42px) !important;
  line-height: 1 !important;
  letter-spacing: -.062em !important;
}

.build-card-banner em {
  position: absolute !important;
  right: 20px !important;
  top: 142px !important;
  z-index: 7 !important;
  min-height: 34px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  padding: 0 14px !important;
  border: 1px solid rgba(183,156,255,.24) !important;
  border-radius: 999px !important;
  background: rgba(18,18,25,.72) !important;
  color: rgba(255,255,255,.88) !important;
  font-style: normal !important;
  font-size: 11px !important;
  font-weight: 950 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  backdrop-filter: blur(12px) !important;
}

.build-card-featured .build-card-banner em::before {
  content: "★";
  color: var(--purple-light);
}

/* Bigger media area like screenshot 2 */
.build-card-media {
  position: relative !important;
  height: 385px !important;
  margin: 0 !important;
  overflow: hidden !important;
  border-radius: 0 !important;
  background:
    radial-gradient(circle at 50% 70%, rgba(139,92,246,.20), transparent 44%),
    #151515 !important;
}

.build-card-media::before {
  content: "" !important;
  position: absolute !important;
  inset: -1px !important;
  z-index: 1 !important;
  pointer-events: none !important;
  background:
    linear-gradient(180deg, rgba(13,13,16,0) 35%, rgba(13,13,16,.70) 100%),
    linear-gradient(90deg, rgba(139,92,246,.08), transparent 42%) !important;
}

.build-card-media > img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  filter: brightness(.78) saturate(.92) contrast(1.04) !important;
  transform: scale(1.01) !important;
  transition: transform .34s ease, filter .34s ease !important;
}

.build-card:hover .build-card-media > img {
  transform: scale(1.045) !important;
  filter: brightness(.52) saturate(.82) contrast(1.06) !important;
}

.image-hint.build-hint {
  right: 20px !important;
  bottom: 20px !important;
  z-index: 7 !important;
}

.image-hint.build-hint span {
  min-height: 40px !important;
  padding: 0 16px !important;
  border-radius: 999px !important;
  background: rgba(10,10,13,.72) !important;
  border: 1px solid rgba(255,255,255,.13) !important;
  color: #fff !important;
  font-weight: 950 !important;
  backdrop-filter: blur(12px) !important;
}

.build-fps-overlay {
  position: absolute !important;
  z-index: 6 !important;
  inset: auto 18px 18px 18px !important;
  opacity: 0 !important;
  transform: translateY(16px) !important;
  padding: 15px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 16px !important;
  background: rgba(15,15,20,.72) !important;
  backdrop-filter: blur(18px) !important;
  pointer-events: none !important;
  transition: opacity .26s ease, transform .26s ease !important;
}

.build-card:hover .build-fps-overlay {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

.build-card:hover .build-hint {
  opacity: 0 !important;
  transform: translateY(8px) !important;
}

.build-card-body {
  padding: 26px 28px 28px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.01)),
    rgba(17,17,22,.96) !important;
}

.build-card-fit {
  min-height: 54px !important;
  color: rgba(247,247,248,.78) !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
}

.build-trust-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  margin-top: 15px !important;
}

.build-trust-row span {
  min-height: 38px !important;
  display: inline-flex !important;
  align-items: center !important;
  padding: 0 14px !important;
  border: 1px solid rgba(255,255,255,.11) !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.035) !important;
  color: rgba(247,247,248,.82) !important;
  font-size: 13px !important;
  font-weight: 850 !important;
}

.build-trust-row span::before {
  content: "✦";
  color: var(--purple-light);
  margin-right: 8px;
  font-size: 12px;
}

.build-spec-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 1px !important;
  overflow: hidden !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 14px !important;
  margin-top: 24px !important;
  background: rgba(255,255,255,.075) !important;
}

.build-spec-grid div {
  min-height: 82px !important;
  padding: 18px 17px !important;
  background: rgba(255,255,255,.018) !important;
}

.build-spec-grid span {
  color: var(--purple-light) !important;
  letter-spacing: .18em !important;
  font-size: 10px !important;
  margin-bottom: 8px !important;
}

.build-spec-grid strong {
  color: #fff !important;
  font-size: 15px !important;
  line-height: 1.35 !important;
}

.build-card-bottom {
  display: flex !important;
  justify-content: space-between !important;
  align-items: end !important;
  gap: 16px !important;
  margin-top: 28px !important;
}

.build-card-bottom span {
  display: block !important;
  color: var(--soft) !important;
  font-size: 13px !important;
  margin-bottom: 5px !important;
}

.build-card-bottom strong {
  display: block !important;
  color: #fff !important;
  font-size: clamp(40px, 3vw, 54px) !important;
  font-weight: 650 !important;
  line-height: 1 !important;
  letter-spacing: -.078em !important;
}

.build-card-bottom p {
  color: rgba(247,247,248,.72) !important;
  font-size: 16px !important;
  font-weight: 750 !important;
  text-align: right !important;
}

.build-card-actions {
  display: grid !important;
  grid-template-columns: 1.2fr .95fr !important;
  gap: 14px !important;
  margin-top: 24px !important;
}

.build-card-actions .btn {
  min-height: 52px !important;
  border-radius: 999px !important;
  font-size: 14px !important;
}

.build-card-actions .btn-primary {
  background: linear-gradient(135deg, #a978ff, var(--purple)) !important;
  box-shadow: 0 18px 46px rgba(139,92,246,.26) !important;
}

.build-card-actions .btn-primary::after {
  content: "▱";
  margin-left: 10px;
  opacity: .8;
}

.build-card-actions .btn-ghost {
  background: rgba(255,255,255,.035) !important;
  border-color: rgba(255,255,255,.16) !important;
}

.build-card-actions .btn-ghost::after {
  content: "☷";
  margin-left: 10px;
  color: rgba(255,255,255,.72);
}

/* Bottom assurance row, matching screenshot 2 */
.build-assurance-row {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: clamp(24px, 5vw, 86px) !important;
  width: min(980px, 100%) !important;
  margin: 52px auto 0 !important;
  padding-top: 30px !important;
  border-top: 1px solid rgba(255,255,255,.075) !important;
}

.build-assurance-item {
  display: grid !important;
  grid-template-columns: 48px 1fr !important;
  gap: 16px !important;
  align-items: center !important;
  color: rgba(247,247,248,.70) !important;
}

.build-assurance-icon {
  width: 48px !important;
  height: 48px !important;
  display: grid !important;
  place-items: center !important;
  border: 1px solid rgba(183,156,255,.22) !important;
  border-radius: 999px !important;
  color: var(--purple-light) !important;
  background: rgba(139,92,246,.07) !important;
  font-size: 22px !important;
}

.build-assurance-item strong {
  display: block !important;
  color: #fff !important;
  font-size: 20px !important;
  line-height: 1.2 !important;
}

.build-assurance-item p {
  margin-top: 3px !important;
  color: var(--muted) !important;
  font-size: 15px !important;
}

/* Keep the rest of the page colour scheme exactly on-brand */
.performance-tile-custom {
  background: #9b6dff !important;
  border-color: rgba(205,188,255,.46) !important;
}

.performance-tile-custom::before {
  background:
    radial-gradient(circle at 82% 24%, rgba(255,255,255,.18), transparent 28%),
    linear-gradient(135deg, #a978ff 0%, #925cf7 55%, #7c3aed 100%) !important;
}

.performance-tile-custom .performance-tile-content {
  height: 100%;
  width: 100%;
  padding: clamp(26px, 2.2vw, 42px);
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  gap: 10px !important;
}

.performance-tile-custom .performance-tile-content span,
.performance-tile-custom .performance-tile-content h2,
.performance-tile-custom .performance-tile-content p {
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.performance-tile-custom .performance-tile-content span {
  margin-bottom: 0 !important;
  color: rgba(255,255,255,.82) !important;
}

.performance-tile-custom .performance-tile-content h2 {
  max-width: 760px !important;
  white-space: normal !important;
}

.performance-tile-custom .performance-tile-content p {
  margin-top: 0 !important;
  max-width: 620px !important;
  color: rgba(255,255,255,.82) !important;
}

@media (max-width: 1280px) {
  .featured-builds-section > .shell {
    width: min(1180px, calc(100% - 42px)) !important;
  }

  .build-card-grid {
    gap: 18px !important;
  }

  .build-card-media {
    height: 315px !important;
  }

  .featured-builds-head h2 {
    font-size: clamp(58px, 6.4vw, 88px) !important;
  }
}

@media (max-width: 1050px) {
  .featured-builds-head,
  .build-card-grid,
  .build-assurance-row {
    grid-template-columns: 1fr !important;
  }

  .featured-builds-head > p {
    justify-self: start !important;
  }

  .build-card {
    max-width: 760px !important;
    margin: 0 auto !important;
  }
}

@media (max-width: 700px) {
  .featured-builds-section {
    padding: 62px 0 76px !important;
  }

  .featured-builds-section > .shell {
    width: min(100% - 28px, 560px) !important;
  }

  .featured-builds-head h2 {
    font-size: clamp(46px, 13vw, 68px) !important;
  }

  .build-card-media {
    height: 300px !important;
  }

  .build-card-actions,
  .build-spec-grid {
    grid-template-columns: 1fr !important;
  }

  .build-card-bottom {
    display: block !important;
  }

  .build-card-bottom p {
    text-align: left !important;
    margin-top: 8px !important;
  }
}


/* =========================================================
   READY TO SHIP RESPONSIVE FINAL
   Compact premium layout for 1920x1080, 4K ultrawide, tablet and mobile.
   Keeps existing Respawn colours.
========================================================= */

.featured-builds-section {
  padding: clamp(64px, 6vw, 88px) 0 clamp(72px, 7vw, 96px) !important;
  background:
    radial-gradient(circle at 52% 38%, rgba(139,92,246,.075), transparent 34%),
    var(--bg) !important;
}

/* Keep it premium but stop it becoming monster-wide on ultrawide */
.featured-builds-section > .shell {
  width: min(1440px, calc(100% - 56px)) !important;
  max-width: 1440px !important;
}

/* Match the mockup: headline left, copy right, balanced */
.featured-builds-head {
  display: grid !important;
  grid-template-columns: minmax(0, .98fr) minmax(300px, .72fr) !important;
  gap: clamp(34px, 7vw, 110px) !important;
  align-items: end !important;
  margin-bottom: 28px !important;
}

.featured-builds-head h2 {
  max-width: 660px !important;
  font-size: clamp(54px, 5.1vw, 82px) !important;
  line-height: .88 !important;
  letter-spacing: -.102em !important;
  font-weight: 520 !important;
}

.featured-builds-head > p {
  justify-self: end !important;
  max-width: 500px !important;
  margin: 0 0 15px !important;
  color: var(--muted) !important;
  font-size: clamp(15px, 1vw, 18px) !important;
  line-height: 1.62 !important;
}

/* 3 cards in one clean row at desktop, but controlled size */
.build-card-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 22px !important;
  align-items: start !important;
}

.build-card {
  border-radius: 16px !important;
  border-color: rgba(255,255,255,.105) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.012)),
    var(--surface) !important;
  box-shadow:
    0 22px 64px rgba(0,0,0,.26),
    inset 0 1px 0 rgba(255,255,255,.035) !important;
}

.build-card:hover {
  transform: translateY(-4px) !important;
  box-shadow:
    0 28px 76px rgba(0,0,0,.34),
    0 0 0 1px rgba(139,92,246,.08),
    inset 0 1px 0 rgba(255,255,255,.05) !important;
}

.build-card-featured {
  border-color: rgba(183,156,255,.43) !important;
  box-shadow:
    0 26px 78px rgba(139,92,246,.10),
    0 0 0 1px rgba(139,92,246,.15),
    inset 0 1px 0 rgba(255,255,255,.05) !important;
}

/* Smaller header area like mockup */
.build-card-banner {
  min-height: 82px !important;
  padding: 20px 58px 15px 22px !important;
}

.build-card-banner::after {
  right: 18px !important;
  top: 20px !important;
  width: 36px !important;
  height: 36px !important;
  font-size: 22px !important;
}

.build-card-banner span {
  font-size: 10px !important;
  letter-spacing: .2em !important;
  margin-bottom: 8px !important;
}

.build-card-banner strong {
  font-size: clamp(24px, 1.55vw, 30px) !important;
  line-height: 1 !important;
}

/* Badge should sit neatly over image, not huge */
.build-card-banner em {
  top: 108px !important;
  right: 16px !important;
  min-height: 28px !important;
  padding: 0 11px !important;
  font-size: 9px !important;
}

/* Important: stop images/cards being too tall */
.build-card-media {
  height: clamp(235px, 17.2vw, 290px) !important;
  background:
    radial-gradient(circle at 50% 72%, rgba(139,92,246,.18), transparent 43%),
    #151515 !important;
}

.build-card-media > img {
  object-fit: cover !important;
  object-position: center center !important;
}

.build-card-body {
  padding: 18px 22px 22px !important;
}

/* Text/content compact, still premium */
.build-card-fit {
  min-height: 42px !important;
  font-size: 14px !important;
  line-height: 1.52 !important;
}

.build-trust-row {
  gap: 8px !important;
  margin-top: 13px !important;
}

.build-trust-row span {
  min-height: 31px !important;
  padding: 0 11px !important;
  font-size: 11px !important;
}

/* Specs grid compact and cleaner */
.build-spec-grid {
  margin-top: 18px !important;
  border-radius: 12px !important;
}

.build-spec-grid div {
  min-height: 64px !important;
  padding: 13px 14px !important;
}

.build-spec-grid span {
  font-size: 9px !important;
  letter-spacing: .16em !important;
  margin-bottom: 6px !important;
}

.build-spec-grid strong {
  font-size: 13px !important;
  line-height: 1.32 !important;
}

/* Pricing more like mockup but not massive */
.build-card-bottom {
  margin-top: 20px !important;
}

.build-card-bottom span {
  font-size: 11px !important;
}

.build-card-bottom strong {
  font-size: clamp(30px, 2.35vw, 40px) !important;
  letter-spacing: -.07em !important;
}

.build-card-bottom p {
  font-size: 13px !important;
}

/* Buttons smaller, cleaner */
.build-card-actions {
  gap: 10px !important;
  margin-top: 18px !important;
  grid-template-columns: 1.15fr .95fr !important;
}

.build-card-actions .btn {
  min-height: 44px !important;
  font-size: 12px !important;
  padding: 0 15px !important;
}

/* FPS hover fits within compact image */
.build-fps-overlay {
  inset: auto 13px 13px 13px !important;
  padding: 12px !important;
  border-radius: 14px !important;
}

.build-fps-overlay .fps-grid {
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 7px !important;
}

.build-fps-overlay .fps-card {
  min-height: 74px !important;
  border-radius: 12px !important;
}

.build-fps-overlay .fps-card strong {
  font-size: 14px !important;
}

.build-fps-overlay .fps-card span {
  font-size: 10px !important;
}

.image-hint.build-hint {
  right: 15px !important;
  bottom: 15px !important;
}

.image-hint.build-hint span {
  min-height: 34px !important;
  padding: 0 13px !important;
  font-size: 11px !important;
}

/* Assurance row should not push the section too tall */
.build-assurance-row {
  width: min(860px, 100%) !important;
  margin: 34px auto 0 !important;
  padding-top: 24px !important;
  gap: clamp(18px, 4vw, 58px) !important;
}

.build-assurance-item {
  grid-template-columns: 38px 1fr !important;
  gap: 13px !important;
}

.build-assurance-icon {
  width: 38px !important;
  height: 38px !important;
  font-size: 18px !important;
}

.build-assurance-item strong {
  font-size: 16px !important;
}

.build-assurance-item p {
  font-size: 13px !important;
}

/* 4K / ultrawide: keep section centered and readable, do not stretch forever */
@media (min-width: 1800px) {
  .featured-builds-section > .shell {
    width: min(1480px, calc(100% - 96px)) !important;
    max-width: 1480px !important;
  }

  .build-card-media {
    height: 300px !important;
  }
}

/* 1920x1080 friendly: full section feels balanced, cards not skyscrapers */
@media (min-width: 1200px) and (max-width: 1700px) {
  .featured-builds-section > .shell {
    width: min(1360px, calc(100% - 52px)) !important;
  }

  .featured-builds-head h2 {
    font-size: clamp(58px, 4.8vw, 76px) !important;
  }

  .build-card-media {
    height: 255px !important;
  }

  .build-card-banner {
    min-height: 78px !important;
  }

  .build-card-body {
    padding: 17px 20px 20px !important;
  }
}

/* Tablet: 2 columns */
@media (max-width: 1100px) {
  .featured-builds-section > .shell {
    width: min(940px, calc(100% - 38px)) !important;
  }

  .featured-builds-head {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }

  .featured-builds-head > p {
    justify-self: start !important;
    max-width: 680px !important;
  }

  .build-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .build-card {
    max-width: none !important;
    margin: 0 !important;
    display: block !important;
  }

  .build-card-media {
    height: 260px !important;
    min-height: 0 !important;
  }

  .build-assurance-row {
    grid-template-columns: 1fr 1fr 1fr !important;
  }
}

/* Mobile: 1 column, no hover-only hidden info */
@media (max-width: 760px) {
  .featured-builds-section {
    padding: 56px 0 70px !important;
  }

  .featured-builds-section > .shell {
    width: min(100% - 28px, 520px) !important;
  }

  .featured-builds-head h2 {
    font-size: clamp(44px, 13vw, 62px) !important;
  }

  .build-card-grid {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }

  .build-card-banner {
    min-height: 78px !important;
    padding: 19px 56px 14px 20px !important;
  }

  .build-card-banner em {
    top: 104px !important;
  }

  .build-card-media {
    height: 250px !important;
  }

  .build-fps-overlay {
    position: static !important;
    opacity: 1 !important;
    transform: none !important;
    pointer-events: auto !important;
    margin: 12px;
  }

  .build-fps-overlay .fps-grid,
  .build-card-actions,
  .build-spec-grid,
  .build-assurance-row {
    grid-template-columns: 1fr !important;
  }

  .build-hint {
    display: none !important;
  }

  .build-card-bottom {
    display: block !important;
  }

  .build-card-bottom p {
    text-align: left !important;
    margin-top: 8px !important;
  }
}


/* =========================================================
   READY TO SHIP COMPACT EQUAL CARD FIX
   Fix: cards were too tall/wide and different heights.
   Loaded last so it wins.
========================================================= */

.featured-builds-section {
  padding: 64px 0 78px !important;
}

.featured-builds-section > .shell {
  width: min(1240px, calc(100% - 48px)) !important;
  max-width: 1240px !important;
}

.featured-builds-head {
  grid-template-columns: minmax(0, 1fr) minmax(320px, .72fr) !important;
  gap: clamp(28px, 6vw, 86px) !important;
  margin-bottom: 24px !important;
}

.featured-builds-head h2 {
  max-width: 600px !important;
  font-size: clamp(48px, 4.3vw, 70px) !important;
  line-height: .88 !important;
}

.featured-builds-head > p {
  max-width: 460px !important;
  font-size: 15px !important;
  line-height: 1.55 !important;
}

/* Equal compact grid */
.build-card-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
  align-items: stretch !important;
}

.build-card {
  height: 100% !important;
  min-height: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  border-radius: 14px !important;
  box-shadow: 0 18px 52px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.035) !important;
}

.build-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 24px 64px rgba(0,0,0,.32), inset 0 1px 0 rgba(255,255,255,.04) !important;
}

/* Smaller top title bar */
.build-card-banner {
  flex: 0 0 auto !important;
  min-height: 66px !important;
  padding: 15px 50px 12px 18px !important;
}

.build-card-banner::after {
  right: 16px !important;
  top: 17px !important;
  width: 30px !important;
  height: 30px !important;
  font-size: 18px !important;
}

.build-card-banner span {
  font-size: 9px !important;
  letter-spacing: .18em !important;
  margin-bottom: 6px !important;
}

.build-card-banner strong {
  font-size: clamp(21px, 1.45vw, 26px) !important;
  letter-spacing: -.055em !important;
}

/* Do not let badges push/crop weirdly */
.build-card-banner em {
  top: 92px !important;
  right: 14px !important;
  min-height: 25px !important;
  padding: 0 9px !important;
  font-size: 8px !important;
}

/* Same image height for all three */
.build-card-media {
  flex: 0 0 auto !important;
  height: 205px !important;
  min-height: 205px !important;
  max-height: 205px !important;
}

.build-card-media > img {
  width: 100% !important;
  height: 205px !important;
  object-fit: cover !important;
  object-position: center center !important;
}

/* Body uses grid/flex to keep all cards same size */
.build-card-body {
  flex: 1 1 auto !important;
  display: grid !important;
  grid-template-rows: 44px 34px 118px auto 44px !important;
  gap: 12px !important;
  padding: 17px 18px 18px !important;
}

.build-card-fit {
  min-height: 0 !important;
  height: auto !important;
  overflow: hidden !important;
  font-size: 13px !important;
  line-height: 1.4 !important;
  margin: 0 !important;
}

.build-trust-row {
  align-content: start !important;
  gap: 7px !important;
  margin: 0 !important;
}

.build-trust-row span {
  min-height: 27px !important;
  padding: 0 9px !important;
  font-size: 10px !important;
}

/* Specs are same size and text cannot grow card */
.build-spec-grid {
  margin: 0 !important;
  height: 118px !important;
  min-height: 118px !important;
  border-radius: 10px !important;
}

.build-spec-grid div {
  min-height: 0 !important;
  height: 58px !important;
  padding: 10px 11px !important;
  overflow: hidden !important;
}

.build-spec-grid span {
  font-size: 8px !important;
  letter-spacing: .15em !important;
  margin-bottom: 5px !important;
}

.build-spec-grid strong {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
}

/* Price row consistent */
.build-card-bottom {
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  align-items: end !important;
  gap: 10px !important;
  margin: 0 !important;
}

.build-card-bottom span {
  font-size: 10px !important;
  margin-bottom: 3px !important;
}

.build-card-bottom strong {
  font-size: clamp(28px, 2vw, 34px) !important;
  letter-spacing: -.07em !important;
}

.build-card-bottom p {
  font-size: 11px !important;
  white-space: nowrap !important;
}

/* Buttons equal and smaller */
.build-card-actions {
  display: grid !important;
  grid-template-columns: 1.1fr .9fr !important;
  gap: 9px !important;
  margin: 0 !important;
  align-self: end !important;
}

.build-card-actions .btn {
  min-height: 40px !important;
  height: 40px !important;
  padding: 0 12px !important;
  font-size: 11px !important;
}

/* Hover overlay also compact */
.build-fps-overlay {
  inset: auto 10px 10px 10px !important;
  padding: 10px !important;
  border-radius: 12px !important;
}

.build-fps-overlay .fps-grid {
  gap: 6px !important;
}

.build-fps-overlay .fps-card {
  min-height: 62px !important;
}

.build-fps-overlay .fps-card strong {
  font-size: 12px !important;
}

.build-fps-overlay .fps-card span {
  font-size: 9px !important;
}

.image-hint.build-hint {
  right: 12px !important;
  bottom: 12px !important;
}

.image-hint.build-hint span {
  min-height: 30px !important;
  padding: 0 11px !important;
  font-size: 10px !important;
}

/* Assurance row compact */
.build-assurance-row {
  width: min(780px, 100%) !important;
  margin: 30px auto 0 !important;
  padding-top: 22px !important;
  gap: 28px !important;
}

.build-assurance-item {
  grid-template-columns: 34px 1fr !important;
  gap: 11px !important;
}

.build-assurance-icon {
  width: 34px !important;
  height: 34px !important;
  font-size: 16px !important;
}

.build-assurance-item strong {
  font-size: 15px !important;
}

.build-assurance-item p {
  font-size: 12px !important;
}

/* 1920x1080: this is the target */
@media (min-width: 1200px) and (max-width: 1920px) {
  .featured-builds-section > .shell {
    width: min(1200px, calc(100% - 48px)) !important;
  }

  .build-card-media,
  .build-card-media > img {
    height: 195px !important;
    min-height: 195px !important;
    max-height: 195px !important;
  }

  .build-card-body {
    grid-template-rows: 42px 32px 112px auto 40px !important;
    padding: 16px 17px 17px !important;
  }

  .build-spec-grid {
    height: 112px !important;
    min-height: 112px !important;
  }

  .build-spec-grid div {
    height: 55px !important;
  }
}

/* 4K / ultrawide: do not stretch cards across the moon */
@media (min-width: 1921px) {
  .featured-builds-section > .shell {
    width: 1280px !important;
    max-width: 1280px !important;
  }

  .build-card-media,
  .build-card-media > img {
    height: 215px !important;
  }
}

/* Tablet: 2 columns, equal */
@media (max-width: 1050px) {
  .featured-builds-section > .shell {
    width: min(900px, calc(100% - 36px)) !important;
  }

  .featured-builds-head {
    grid-template-columns: 1fr !important;
  }

  .featured-builds-head > p {
    justify-self: start !important;
  }

  .build-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* Mobile: stacked and readable */
@media (max-width: 720px) {
  .featured-builds-section {
    padding: 52px 0 64px !important;
  }

  .featured-builds-section > .shell {
    width: min(100% - 28px, 520px) !important;
  }

  .featured-builds-head h2 {
    font-size: clamp(42px, 12vw, 58px) !important;
  }

  .build-card-grid {
    grid-template-columns: 1fr !important;
  }

  .build-card-media,
  .build-card-media > img {
    height: 225px !important;
    min-height: 225px !important;
    max-height: 225px !important;
  }

  .build-card-body {
    display: block !important;
    padding: 17px !important;
  }

  .build-card-fit,
  .build-trust-row,
  .build-spec-grid,
  .build-card-bottom,
  .build-card-actions {
    margin-top: 14px !important;
  }

  .build-card-fit {
    height: auto !important;
    overflow: visible !important;
  }

  .build-spec-grid {
    height: auto !important;
    min-height: 0 !important;
  }

  .build-spec-grid div {
    height: auto !important;
    min-height: 54px !important;
  }

  .build-card-bottom {
    display: block !important;
  }

  .build-card-bottom p {
    margin-top: 6px !important;
    text-align: left !important;
  }

  .build-card-actions {
    grid-template-columns: 1fr !important;
  }

  .build-fps-overlay {
    position: static !important;
    opacity: 1 !important;
    transform: none !important;
    margin: 10px !important;
    pointer-events: auto !important;
  }

  .build-fps-overlay .fps-grid,
  .build-assurance-row {
    grid-template-columns: 1fr !important;
  }

  .build-hint {
    display: none !important;
  }
}

/* =========================================================
   Homepage featured builds final polish
   Loaded after older homepage card attempts so this section is predictable.
========================================================= */

.featured-builds-section {
  padding: clamp(72px, 7vw, 104px) 0 clamp(82px, 8vw, 112px) !important;
  background: #171922 !important;
  border-top: 1px solid rgba(255,255,255,.08) !important;
}

.featured-builds-section > .shell {
  width: min(1240px, calc(100% - 56px)) !important;
  max-width: 1240px !important;
}

.featured-builds-head {
  display: grid !important;
  grid-template-columns: 1fr !important;
  justify-items: center !important;
  gap: 14px !important;
  margin: 0 auto 36px !important;
  text-align: center !important;
}

.featured-builds-head h2 {
  max-width: 780px !important;
  margin: 0 auto !important;
  font-size: clamp(42px, 4.1vw, 66px) !important;
  line-height: .96 !important;
  letter-spacing: -.065em !important;
  font-weight: 720 !important;
}

.featured-builds-head > p {
  justify-self: center !important;
  max-width: 650px !important;
  margin: 0 auto !important;
  color: rgba(245,247,251,.72) !important;
  font-size: 16px !important;
  line-height: 1.65 !important;
}

.build-card-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 20px !important;
  align-items: stretch !important;
}

.build-card {
  height: 100% !important;
  overflow: hidden !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 14px !important;
  background: #20232d !important;
  box-shadow: 0 18px 54px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.035) !important;
}

.build-card-featured {
  border-color: rgba(139,92,246,.38) !important;
  box-shadow: 0 20px 60px rgba(0,0,0,.28), 0 0 0 1px rgba(139,92,246,.12), inset 0 1px 0 rgba(255,255,255,.04) !important;
}

.build-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 24px 66px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.045) !important;
}

.build-card-shell {
  min-height: 100% !important;
  display: flex !important;
  flex-direction: column !important;
}

.build-card-media {
  position: relative !important;
  flex: 0 0 auto !important;
  height: 190px !important;
  min-height: 190px !important;
  max-height: 190px !important;
  border-bottom: 1px solid rgba(255,255,255,.07) !important;
  background: #0f1117 !important;
}

.build-card-media::before {
  background: linear-gradient(180deg, rgba(15,17,23,.08), rgba(15,17,23,.12) 42%, rgba(15,17,23,.48)) !important;
}

.build-card-media > img {
  width: 100% !important;
  height: 190px !important;
  object-fit: cover !important;
  object-position: center center !important;
  filter: brightness(.72) saturate(.9) contrast(1.04) !important;
}

.build-card:hover .build-card-media > img {
  transform: scale(1.035) !important;
  filter: brightness(.78) saturate(.94) contrast(1.04) !important;
}

.build-card-tag {
  position: absolute !important;
  z-index: 5 !important;
  top: 14px !important;
  left: 14px !important;
  min-height: 28px !important;
  display: inline-flex !important;
  align-items: center !important;
  padding: 0 11px !important;
  border: 1px solid rgba(183,156,255,.26) !important;
  border-radius: 999px !important;
  background: rgba(15,17,23,.72) !important;
  color: #d8cbff !important;
  font-size: 10px !important;
  font-weight: 900 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  backdrop-filter: blur(10px) !important;
}

.build-card-heart {
  display: none !important;
}

.build-card-body {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 17px !important;
  padding: 22px !important;
  background: #20232d !important;
}

.build-card-title-row {
  min-height: 76px !important;
}

.build-card-title-row h3 {
  margin: 0 !important;
  color: #f5f7fb !important;
  font-size: 22px !important;
  line-height: 1.08 !important;
  letter-spacing: -.035em !important;
}

.build-card-title-row p {
  margin: 7px 0 0 !important;
  color: rgba(245,247,251,.74) !important;
  font-size: 14px !important;
  line-height: 1.45 !important;
}

.build-spec-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  height: auto !important;
  min-height: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 10px !important;
  background: rgba(255,255,255,.08) !important;
}

.build-spec-grid div {
  min-height: 66px !important;
  height: auto !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  padding: 12px 13px !important;
  overflow: hidden !important;
  background: rgba(15,17,23,.36) !important;
}

.build-spec-grid span {
  order: -1 !important;
  margin: 0 0 6px !important;
  color: #a78bfa !important;
  font-size: 9px !important;
  font-weight: 950 !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
}

.build-spec-grid strong {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  color: #f5f7fb !important;
  font-size: 13px !important;
  line-height: 1.28 !important;
}

.build-card-bottom {
  display: flex !important;
  align-items: flex-end !important;
  justify-content: space-between !important;
  gap: 14px !important;
  margin: 3px 0 0 !important;
}

.build-card-bottom span {
  display: block !important;
  margin: 0 0 4px !important;
  color: rgba(245,247,251,.58) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
}

.build-card-bottom strong {
  color: #fff !important;
  font-size: clamp(31px, 2.2vw, 38px) !important;
  font-weight: 760 !important;
  line-height: 1 !important;
  letter-spacing: -.055em !important;
}

.build-card-bottom p {
  min-height: 30px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  white-space: nowrap !important;
  margin: 0 0 2px !important;
  padding: 0 10px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 999px !important;
  background: rgba(15,17,23,.34) !important;
  color: rgba(245,247,251,.72) !important;
  font-size: 11px !important;
  font-weight: 850 !important;
}

.build-card-actions {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 0 !important;
  margin: 0 !important;
}

.build-card-actions .btn {
  width: 100% !important;
  min-height: 46px !important;
  height: 46px !important;
  border-radius: 10px !important;
  font-size: 13px !important;
}

.build-card-actions .btn-primary::after {
  content: none !important;
}

.build-card-perks {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 8px !important;
  margin: 0 !important;
}

.build-card-perks span {
  min-height: 36px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 8px !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 8px !important;
  background: rgba(15,17,23,.26) !important;
  color: rgba(245,247,251,.70) !important;
  font-size: 11px !important;
  font-weight: 820 !important;
  line-height: 1.2 !important;
  text-align: center !important;
}

.build-assurance-row {
  width: min(920px, 100%) !important;
  margin: 38px auto 0 !important;
  padding-top: 26px !important;
  border-top: 1px solid rgba(255,255,255,.075) !important;
  gap: clamp(18px, 4vw, 52px) !important;
}

.build-assurance-item {
  grid-template-columns: 38px 1fr !important;
  gap: 12px !important;
  align-items: center !important;
}

.build-assurance-icon {
  width: 38px !important;
  height: 38px !important;
  border-radius: 999px !important;
  background: rgba(139,92,246,.09) !important;
  border-color: rgba(183,156,255,.22) !important;
  color: #a78bfa !important;
  font-size: 16px !important;
}

.build-assurance-item strong {
  font-size: 16px !important;
}

.build-assurance-item p {
  margin-top: 3px !important;
  font-size: 13px !important;
  line-height: 1.35 !important;
}

@media (max-width: 1050px) {
  .featured-builds-section > .shell {
    width: min(900px, calc(100% - 36px)) !important;
  }

  .build-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 720px) {
  .featured-builds-section {
    padding: 58px 0 70px !important;
  }

  .featured-builds-section > .shell {
    width: min(100% - 28px, 520px) !important;
  }

  .featured-builds-head h2 {
    font-size: clamp(40px, 12vw, 56px) !important;
  }

  .build-card-grid,
  .build-assurance-row {
    grid-template-columns: 1fr !important;
  }

  .build-card-media,
  .build-card-media > img {
    height: 218px !important;
    min-height: 218px !important;
    max-height: 218px !important;
  }

  .build-card-title-row {
    min-height: 0 !important;
  }

  .build-card-bottom {
    display: grid !important;
    gap: 10px !important;
  }

  .build-card-bottom p {
    justify-self: start !important;
  }

  .build-card-perks {
    grid-template-columns: 1fr !important;
  }
}

/* =========================================================
   RESPAWN PCs HARD RESET: SHOP + PRODUCT PAGES
   Scoped to new template classes so old Woo styles cannot leak in.
========================================================= */

.rp-shop-page-new,
.rp-single-product-page {
  min-height: 100vh;
  background:
    radial-gradient(circle at 50% -120px, rgba(139,92,246,.16), transparent 420px),
    #09090b;
  color: var(--text);
}

.rp-shop-shell-new,
.rp-single-shell {
  width: min(1420px, calc(100% - 56px));
  margin-inline: auto;
}

.rp-shop-hero-new {
  padding: 68px 0 46px;
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.rp-shop-eyebrow-new,
.rp-single-eyebrow {
  display: block;
  margin-bottom: 14px;
  color: var(--purple-light);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .22em;
  text-transform: uppercase;
}

.rp-shop-hero-new h1 {
  max-width: 760px;
  margin: 0;
  color: #fff;
  font-size: clamp(58px, 6vw, 94px);
  font-weight: 720;
  line-height: .9;
  letter-spacing: -.095em;
}

.rp-shop-hero-new p {
  max-width: 680px;
  margin: 18px 0 0;
  color: rgba(247,247,248,.74);
  font-size: 17px;
  line-height: 1.65;
}

.rp-shop-filter-new {
  position: sticky;
  top: 72px;
  z-index: 20;
  padding: 18px 0;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: rgba(13,13,16,.86);
  backdrop-filter: blur(18px);
}

.rp-shop-filter-inner-new {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.rp-shop-filter-left-new,
.rp-shop-filter-right-new {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.rp-shop-filter-left-new strong {
  margin-right: 8px;
  color: #fff;
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
}

.rp-shop-filter-left-new a,
.rp-shop-filter-right-new span,
.rp-shop-meta-new select {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  padding: 0 15px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  background: rgba(255,255,255,.035);
  color: rgba(247,247,248,.78);
  font-size: 12px;
  font-weight: 850;
}

.rp-shop-filter-left-new a:hover,
.rp-shop-filter-left-new a.active {
  border-color: rgba(183,156,255,.48);
  background: var(--purple);
  color: #fff;
}

.rp-shop-products-new {
  padding: 38px 0 110px;
}

.rp-shop-meta-new {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 22px;
}

.rp-shop-meta-new p {
  color: rgba(247,247,248,.66);
  font-size: 13px;
  font-weight: 850;
}

.rp-shop-meta-new .woocommerce-ordering {
  float: none;
  margin: 0;
}

.rp-shop-meta-new select {
  min-width: 220px;
  outline: 0;
}

.rp-shop-grid-new {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.rp-shop-card-new {
  overflow: hidden;
  min-width: 0;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.012)),
    #121216;
  box-shadow: 0 22px 70px rgba(0,0,0,.26);
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.rp-shop-card-new:hover {
  transform: translateY(-4px);
  border-color: rgba(183,156,255,.34);
  box-shadow: 0 30px 86px rgba(0,0,0,.34);
}

.rp-shop-card-image-new {
  position: relative;
  height: 235px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, #f4f4f6, #e5e5eb);
}

.rp-shop-card-image-new span {
  position: absolute;
  left: 14px;
  top: 14px;
  z-index: 2;
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border-radius: 999px;
  background: var(--purple);
  color: #fff;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.rp-shop-card-image-new img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  transition: transform .2s ease;
}

.rp-shop-card-new:hover .rp-shop-card-image-new img {
  transform: scale(1.025);
}

.rp-shop-card-body-new {
  padding: 20px;
}

.rp-shop-card-body-new small {
  color: var(--purple-light);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.rp-shop-card-body-new h2 {
  margin: 8px 0 10px;
  color: #fff;
  font-size: 24px;
  line-height: 1.05;
  letter-spacing: -.055em;
}

.rp-shop-card-body-new p {
  min-height: 58px;
  color: rgba(247,247,248,.70);
  font-size: 13px;
  line-height: 1.55;
}

.rp-shop-card-specs-new {
  display: grid;
  gap: 0;
  overflow: hidden;
  margin: 16px 0 0;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
}

.rp-shop-card-specs-new div {
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 10px;
  padding: 9px 11px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.018);
}

.rp-shop-card-specs-new div:last-child {
  border-bottom: 0;
}

.rp-shop-card-specs-new dt {
  color: rgba(221,184,255,.76);
  font-size: 9px;
  font-weight: 950;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.rp-shop-card-specs-new dd {
  margin: 0;
  color: #fff;
  font-size: 12px;
  font-weight: 780;
  line-height: 1.35;
}

.rp-shop-card-chips-new {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.rp-shop-card-chips-new span {
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 7px;
  color: rgba(247,247,248,.76);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.rp-shop-card-bottom-new {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 12px;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.08);
}

.rp-shop-card-bottom-new span {
  display: block;
  margin-bottom: 4px;
  color: rgba(247,247,248,.48);
  font-size: 11px;
  font-weight: 850;
}

.rp-shop-card-bottom-new strong,
.rp-shop-card-bottom-new .amount,
.rp-shop-card-bottom-new bdi {
  color: #fff;
  font-size: 24px;
  font-weight: 820;
  line-height: 1;
  letter-spacing: -.055em;
}

.rp-shop-card-bottom-new a {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 18px;
  border-radius: 999px;
  background: var(--purple);
  color: #fff;
  font-size: 12px;
  font-weight: 950;
}

.rp-shop-empty-new {
  padding: 34px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  background: #121216;
}

/* Product page */
.rp-single-product-page {
  padding: 54px 0 110px;
}

.rp-single-hero {
  display: grid;
  grid-template-columns: minmax(0, 620px) minmax(0, 1fr);
  gap: 56px;
  align-items: start;
}

.rp-single-gallery {
  position: sticky;
  top: 110px;
}

.rp-single-main-image {
  min-height: 575px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 22px;
  background: linear-gradient(180deg, #f5f5f7, #e8e8ee);
  box-shadow: 0 32px 90px rgba(0,0,0,.34);
}

.rp-single-main-image img {
  width: 100%;
  max-height: 575px;
  object-fit: contain;
  padding: 30px;
}

.rp-single-thumbs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-top: 14px;
}

.rp-single-thumb {
  height: 104px;
  padding: 8px;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 12px;
  background: linear-gradient(180deg, #f5f5f7, #e8e8ee);
  cursor: pointer;
}

.rp-single-thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.rp-gallery-note {
  margin: 14px 0 0;
  padding: 14px 16px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  background: rgba(255,255,255,.024);
  color: rgba(247,247,248,.68);
  font-size: 13px;
  line-height: 1.55;
}

.rp-gallery-note strong {
  color: #fff;
}

.rp-single-summary h1 {
  max-width: 760px;
  margin: 0 0 12px;
  color: #fff;
  font-size: clamp(54px, 5.6vw, 92px);
  line-height: .88;
  letter-spacing: -.105em;
}

.rp-single-price {
  margin-bottom: 16px;
}

.rp-single-price .amount,
.rp-single-price bdi {
  color: #fff;
  font-size: 42px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -.065em;
}

.rp-single-price del .amount,
.rp-single-price del bdi {
  color: rgba(247,247,248,.45);
  font-size: 20px;
}

.rp-single-short {
  max-width: 700px;
  color: rgba(247,247,248,.74);
  font-size: 16px;
  line-height: 1.7;
}

.rp-single-trust {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin: 18px 0 20px;
}

.rp-single-trust span {
  min-height: 32px;
  display: inline-flex;
  align-items: center;
  padding: 0 11px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 999px;
  background: rgba(255,255,255,.03);
  color: rgba(247,247,248,.74);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.rp-single-spec-card,
.rp-upgrade-card,
.rp-single-panel {
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.016)), #111116;
}

.rp-single-spec-head {
  min-height: 46px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 16px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.rp-single-spec-head span,
.rp-upgrade-card span {
  color: var(--purple-light);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .17em;
  text-transform: uppercase;
}

.rp-single-spec-head small {
  color: rgba(247,247,248,.52);
  font-size: 11px;
  font-weight: 850;
}

.rp-single-spec-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  margin: 0;
  padding: 0;
  background: rgba(255,255,255,.08);
}

.rp-single-spec-grid div {
  min-height: 68px;
  padding: 14px 16px;
  background: rgba(255,255,255,.018);
}

.rp-single-spec-grid dt {
  margin-bottom: 7px;
  color: rgba(221,184,255,.82);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.rp-single-spec-grid dd {
  margin: 0;
  color: #fff;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.45;
}

.rp-single-empty-specs {
  margin: 0;
  padding: 16px;
  color: var(--muted);
}

.rp-upgrade-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-top: 16px;
  padding: 18px;
}

.rp-upgrade-card p {
  margin-top: 6px;
  color: rgba(247,247,248,.68);
  font-size: 13px;
  line-height: 1.55;
}

.rp-upgrade-card a {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 16px;
  border-radius: 999px;
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.12);
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.rp-single-cart {
  display: flex;
  gap: 12px;
  align-items: center;
  margin: 20px 0 16px;
}

.rp-single-cart .quantity input {
  width: 84px;
  min-height: 48px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  background: rgba(255,255,255,.035);
  color: #fff;
  text-align: center;
}

.rp-single-cart .single_add_to_cart_button {
  min-height: 50px;
  padding: 0 26px;
  border: 0;
  border-radius: 999px;
  background: var(--purple);
  color: #fff;
  font-size: 13px;
  font-weight: 950;
}

.rp-single-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  color: rgba(247,247,248,.54);
  font-size: 12px;
}

.rp-single-details {
  margin-top: 52px;
}

.rp-single-tabs-clean {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 16px;
}

.rp-single-tabs-clean a {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  padding: 0 16px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  background: rgba(255,255,255,.03);
  color: rgba(247,247,248,.76);
  font-size: 12px;
  font-weight: 850;
}

.rp-single-panel {
  margin-top: 14px;
  padding: 26px;
}

.rp-single-panel h2 {
  margin: 0 0 14px;
  color: #fff;
  font-size: 28px;
  letter-spacing: -.045em;
}

.rp-single-panel p,
.rp-single-panel li {
  color: rgba(247,247,248,.74);
  font-size: 15px;
  line-height: 1.75;
}

.rp-full-spec-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  background: rgba(255,255,255,.08);
}

.rp-full-spec-list div {
  padding: 14px 16px;
  background: rgba(255,255,255,.018);
}

.rp-full-spec-list dt {
  color: var(--purple-light);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.rp-full-spec-list dd {
  margin: 6px 0 0;
  color: #fff;
  font-size: 14px;
  font-weight: 760;
}

@media (max-width: 1250px) {
  .rp-shop-grid-new { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .rp-single-hero { grid-template-columns: 1fr; }
  .rp-single-gallery { position: relative; top: auto; }
}

@media (max-width: 980px) {
  .rp-shop-shell-new,
  .rp-single-shell { width: min(100% - 34px, 760px); }
  .rp-shop-filter-inner-new,
  .rp-shop-meta-new { align-items: flex-start; flex-direction: column; }
  .rp-shop-grid-new { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 680px) {
  .rp-shop-shell-new,
  .rp-single-shell { width: min(100% - 24px, 540px); }
  .rp-shop-hero-new h1,
  .rp-single-summary h1 { font-size: clamp(44px, 16vw, 64px); }
  .rp-shop-grid-new { grid-template-columns: 1fr; }
  .rp-shop-card-image-new { height: 230px; }
  .rp-single-main-image { min-height: 360px; }
  .rp-single-main-image img { max-height: 360px; padding: 18px; }
  .rp-single-spec-grid,
  .rp-full-spec-list { grid-template-columns: 1fr; }
  .rp-upgrade-card,
  .rp-single-cart { align-items: stretch; flex-direction: column; }
  .rp-single-cart .single_add_to_cart_button { width: 100%; }
}

/* =========================================================
   PRODUCT PAGE PRICE + CUSTOMISE TAB FIX
   Shows one base price and styles upgrade/add-on fields.
========================================================= */

.rp-single-price {
  display: grid !important;
  gap: 6px !important;
  margin: 0 0 18px !important;
}

.rp-single-price > span {
  color: rgba(247,247,248,.50) !important;
  font-size: 11px !important;
  font-weight: 950 !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
}

.rp-single-price > strong,
.rp-single-price > strong .amount,
.rp-single-price > strong bdi {
  color: #fff !important;
  font-size: clamp(36px, 3.2vw, 52px) !important;
  font-weight: 820 !important;
  line-height: .95 !important;
  letter-spacing: -.075em !important;
}

.rp-shop-card-bottom-new strong del,
.rp-shop-card-bottom-new strong ins,
.rp-single-price del,
.rp-single-price ins {
  text-decoration: none !important;
}

.rp-shop-card-bottom-new strong del,
.rp-single-price del {
  display: none !important;
}

.rp-shop-card-bottom-new strong ins,
.rp-single-price ins {
  background: transparent !important;
}

.rp-upgrade-card {
  align-items: center !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(139,92,246,.16), transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.016)),
    #111116 !important;
}

.rp-upgrade-card a {
  background: var(--purple) !important;
  border-color: rgba(183,156,255,.38) !important;
  box-shadow: 0 18px 40px rgba(139,92,246,.20) !important;
}

.rp-single-cart {
  display: block !important;
  margin: 18px 0 16px !important;
}

.rp-single-cart-row {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  margin-top: 16px !important;
}

.rp-customize-card {
  overflow: hidden !important;
  margin: 0 0 18px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.016)),
    #111116 !important;
}

.rp-customize-head {
  min-height: 46px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  padding: 0 16px !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
  background: rgba(255,255,255,.024) !important;
}

.rp-customize-head span {
  color: var(--purple-light) !important;
  font-size: 10px !important;
  font-weight: 950 !important;
  letter-spacing: .17em !important;
  text-transform: uppercase !important;
}

.rp-customize-head small {
  color: rgba(247,247,248,.54) !important;
  font-size: 11px !important;
  font-weight: 850 !important;
}

.rp-customize-copy {
  padding: 14px 16px 0 !important;
}

.rp-customize-copy p {
  margin: 0 0 14px !important;
  color: rgba(247,247,248,.66) !important;
  font-size: 13px !important;
  line-height: 1.6 !important;
}

/* Advanced Product Fields / Product Add-Ons / PPOM friendly styling */
.rp-customize-card .wapf,
.rp-customize-card .wapf-wrapper,
.rp-customize-card .wc-pao-addons-container,
.rp-customize-card .ppom-wrapper,
.rp-customize-card .tm-extra-product-options {
  padding: 0 16px 16px !important;
}

.rp-customize-card .wapf-field-container,
.rp-customize-card .wc-pao-addon,
.rp-customize-card .ppom-field-wrapper,
.rp-customize-card .cpf-section {
  margin: 0 0 12px !important;
  padding: 14px !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 14px !important;
  background: rgba(255,255,255,.024) !important;
}

.rp-customize-card label,
.rp-customize-card .wapf-field-label,
.rp-customize-card .wc-pao-addon-name,
.rp-customize-card .form-row label {
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  line-height: 1.35 !important;
}

.rp-customize-card select,
.rp-customize-card input[type="text"],
.rp-customize-card input[type="number"],
.rp-customize-card textarea {
  width: 100% !important;
  min-height: 42px !important;
  margin-top: 8px !important;
  padding: 0 12px !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 12px !important;
  background: rgba(0,0,0,.22) !important;
  color: #fff !important;
  font: inherit !important;
}

.rp-customize-card input[type="radio"],
.rp-customize-card input[type="checkbox"] {
  accent-color: var(--purple) !important;
}

.rp-customize-card .amount,
.rp-customize-card bdi {
  color: var(--purple-light) !important;
  font-weight: 850 !important;
}

.rp-single-tabs-clean a[href="#rp-customise-info"] {
  border-color: rgba(183,156,255,.32) !important;
  background: rgba(139,92,246,.12) !important;
  color: #fff !important;
}

@media (max-width: 680px) {
  .rp-single-cart-row {
    align-items: stretch !important;
    flex-direction: column !important;
  }

  .rp-single-cart-row .quantity,
  .rp-single-cart-row .single_add_to_cart_button {
    width: 100% !important;
  }
}

/* =========================================================
   PRODUCT PAGE REAL TAB + UPGRADE TREE FIX
========================================================= */

.rp-single-details [hidden] {
  display: none !important;
}

.rp-single-tabs-clean {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  margin: 34px 0 18px !important;
}

.rp-single-tabs-clean a {
  display: none !important;
}

.rp-single-tabs-clean button {
  min-height: 44px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 18px !important;
  border: 1px solid rgba(255,255,255,.13) !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.035) !important;
  color: rgba(247,247,248,.76) !important;
  font: inherit !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  cursor: pointer !important;
  transition: border-color .18s ease, background .18s ease, color .18s ease, transform .18s ease !important;
}

.rp-single-tabs-clean button:hover,
.rp-single-tabs-clean button.is-active {
  border-color: rgba(183,156,255,.42) !important;
  background: rgba(139,92,246,.18) !important;
  color: #fff !important;
  transform: translateY(-1px) !important;
}

.rp-single-panel {
  display: none !important;
}

.rp-single-panel.is-active {
  display: block !important;
}

.rp-panel-heading-row {
  display: flex !important;
  justify-content: space-between !important;
  gap: 24px !important;
  align-items: flex-start !important;
  margin-bottom: 22px !important;
}

.rp-panel-heading-row h2 {
  margin-bottom: 8px !important;
}

.rp-panel-heading-row p {
  max-width: 760px !important;
  margin: 0 !important;
}

.rp-panel-heading-row > span {
  display: inline-flex !important;
  min-height: 34px !important;
  align-items: center !important;
  padding: 0 12px !important;
  border: 1px solid rgba(183,156,255,.28) !important;
  border-radius: 999px !important;
  color: var(--purple-light) !important;
  font-size: 10px !important;
  font-weight: 950 !important;
  letter-spacing: .13em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}

.rp-upgrade-tree {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 16px !important;
}

.rp-upgrade-group {
  overflow: hidden !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 18px !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(139,92,246,.10), transparent 48%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.016)),
    #111116 !important;
}

.rp-upgrade-group-head {
  min-height: 68px !important;
  padding: 16px 18px !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
  background: rgba(255,255,255,.025) !important;
}

.rp-upgrade-group-head span {
  display: block !important;
  color: #fff !important;
  font-size: 18px !important;
  font-weight: 850 !important;
  line-height: 1.1 !important;
  letter-spacing: -.035em !important;
}

.rp-upgrade-group-head small {
  display: block !important;
  margin-top: 6px !important;
  color: rgba(247,247,248,.58) !important;
  font-size: 12px !important;
  line-height: 1.45 !important;
}

.rp-upgrade-options {
  display: grid !important;
  gap: 0 !important;
}

.rp-upgrade-option {
  display: grid !important;
  grid-template-columns: 22px minmax(0, 1fr) auto !important;
  gap: 12px !important;
  align-items: center !important;
  min-height: 70px !important;
  margin: 0 !important;
  padding: 14px 18px !important;
  border-bottom: 1px solid rgba(255,255,255,.065) !important;
  color: #fff !important;
  cursor: pointer !important;
  transition: background .16s ease !important;
}

.rp-upgrade-option:last-child {
  border-bottom: 0 !important;
}

.rp-upgrade-option:hover {
  background: rgba(255,255,255,.035) !important;
}

.rp-upgrade-option input {
  width: 16px !important;
  height: 16px !important;
  accent-color: var(--purple) !important;
}

.rp-upgrade-option span {
  display: block !important;
  min-width: 0 !important;
}

.rp-upgrade-option strong {
  display: block !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1.25 !important;
}

.rp-upgrade-option small {
  display: block !important;
  margin-top: 4px !important;
  color: rgba(247,247,248,.55) !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
}

.rp-upgrade-option em {
  justify-self: end !important;
  color: var(--purple-light) !important;
  font-style: normal !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  white-space: nowrap !important;
}

.rp-upgrade-summary-bar {
  display: flex !important;
  justify-content: space-between !important;
  gap: 18px !important;
  align-items: center !important;
  margin-top: 18px !important;
  padding: 18px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,.024) !important;
}

.rp-upgrade-summary-bar p {
  margin: 0 !important;
  color: rgba(247,247,248,.74) !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
}

.rp-upgrade-summary-bar p strong {
  color: #fff !important;
}

.rp-upgrade-summary-bar p span {
  display: block !important;
  margin-top: 3px !important;
  color: rgba(247,247,248,.50) !important;
  font-size: 12px !important;
}

.rp-upgrade-summary-bar > div {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-shrink: 0 !important;
}

.rp-upgrade-summary-bar .quantity input,
.rp-base-cart .quantity input {
  width: 62px !important;
  min-height: 48px !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.035) !important;
  color: #fff !important;
  text-align: center !important;
  font-weight: 850 !important;
}

.rp-upgrade-summary-bar .single_add_to_cart_button,
.rp-base-cart .single_add_to_cart_button {
  min-height: 50px !important;
  padding: 0 22px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: var(--purple) !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 950 !important;
  box-shadow: 0 18px 40px rgba(139,92,246,.22) !important;
}

.rp-customize-card,
.rp-customize-copy {
  display: none !important;
}

@media (max-width: 980px) {
  .rp-upgrade-tree {
    grid-template-columns: 1fr !important;
  }

  .rp-upgrade-summary-bar {
    align-items: stretch !important;
    flex-direction: column !important;
  }

  .rp-upgrade-summary-bar > div {
    width: 100% !important;
    align-items: stretch !important;
    flex-direction: column !important;
  }

  .rp-upgrade-summary-bar .single_add_to_cart_button {
    width: 100% !important;
  }
}

@media (max-width: 680px) {
  .rp-panel-heading-row {
    flex-direction: column !important;
  }

  .rp-upgrade-option {
    grid-template-columns: 22px minmax(0, 1fr) !important;
  }

  .rp-upgrade-option em {
    grid-column: 2 !important;
    justify-self: start !important;
  }
}

/* =========================================================
   RESPAWN PCs SINGLE PRODUCT FPS TEMPLATE
========================================================= */

.rp-fps-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 16px !important;
}

.rp-fps-game {
  overflow: hidden !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 18px !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(139,92,246,.12), transparent 46%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.016)),
    #111116 !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04) !important;
}

.rp-fps-image {
  position: relative !important;
  height: 155px !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 50% 45%, rgba(139,92,246,.22), transparent 44%),
    linear-gradient(135deg, #181820, #0f0f13) !important;
}

.rp-fps-image::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.62)) !important;
  pointer-events: none !important;
}

.rp-fps-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  filter: brightness(.78) saturate(.95) contrast(1.04) !important;
  transform: scale(1.01) !important;
}

.rp-fps-image span {
  position: absolute !important;
  z-index: 2 !important;
  left: 14px !important;
  bottom: 12px !important;
  color: #fff !important;
  font-size: 18px !important;
  font-weight: 900 !important;
  letter-spacing: -.04em !important;
  text-shadow: 0 8px 24px rgba(0,0,0,.55) !important;
}

.rp-fps-no-image .rp-fps-image {
  display: grid !important;
  place-items: center !important;
}

.rp-fps-no-image .rp-fps-image span {
  position: static !important;
  text-align: center !important;
  padding: 18px !important;
  text-shadow: none !important;
}

.rp-fps-content {
  padding: 16px !important;
}

.rp-fps-content strong {
  display: block !important;
  color: #fff !important;
  font-size: 28px !important;
  font-weight: 850 !important;
  line-height: 1 !important;
  letter-spacing: -.06em !important;
}

.rp-fps-content p {
  margin: 8px 0 0 !important;
  color: rgba(247,247,248,.62) !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}

.rp-fps-note {
  margin: 18px 0 0 !important;
  padding: 15px 16px !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 16px !important;
  background: rgba(255,255,255,.025) !important;
  color: rgba(247,247,248,.66) !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
}

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

@media (max-width: 640px) {
  .rp-fps-grid {
    grid-template-columns: 1fr !important;
  }

  .rp-fps-image {
    height: 180px !important;
  }
}

/* =========================================================
   Respawn navbar final restore
   Matches current header.php classes. No basket layout changes.
========================================================= */

.rsp-clean-header,
.rsp-clean-header * {
  box-sizing: border-box;
}

.rsp-clean-header {
  --nav-bg: rgba(13, 13, 16, .92);
  --nav-panel: #111116;
  --nav-line: rgba(255,255,255,.095);
  --nav-line-soft: rgba(255,255,255,.065);
  --nav-muted: rgba(247,247,248,.66);
  --nav-purple: #8b5cf6;
  --nav-purple-light: #b79cff;

  position: sticky;
  top: 0;
  z-index: 99999;
  width: 100%;
  background: var(--nav-bg);
  border-bottom: 1px solid var(--nav-line-soft);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.admin-bar .rsp-clean-header {
  top: 32px;
}

.rsp-clean-header .shell,
.rsp-clean-nav.shell {
  width: min(var(--max, 1560px), calc(100% - 44px));
  margin-inline: auto;
}

.rsp-clean-nav {
  height: 72px;
  display: grid;
  grid-template-columns: 210px minmax(0, 1fr) auto;
  align-items: center;
  gap: 28px;
}

.rsp-clean-brand {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  text-decoration: none;
}

.rsp-clean-brand img {
  display: block !important;
  width: auto !important;
  height: 42px !important;
  max-width: 210px !important;
  object-fit: contain !important;
}

.rsp-clean-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 26px;
  min-width: 0;
}

.rsp-clean-link {
  position: relative;
  min-height: 72px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border: 0;
  padding: 0;
  background: transparent;
  color: var(--nav-muted);
  font-family: inherit;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: -.01em;
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
  transition: color .18s ease;
}

.rsp-clean-link::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 2px;
  background: var(--nav-purple);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .18s ease;
}

.rsp-clean-link:hover,
.rsp-clean-dropdown:hover > .rsp-clean-link,
.rsp-clean-dropdown:focus-within > .rsp-clean-link {
  color: #fff;
}

.rsp-clean-link:hover::after,
.rsp-clean-dropdown:hover > .rsp-clean-link::after,
.rsp-clean-dropdown:focus-within > .rsp-clean-link::after {
  transform: scaleX(1);
}

.rsp-clean-link svg {
  width: 13px;
  height: 13px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: transform .18s ease;
}

.rsp-clean-dropdown {
  position: relative;
  padding-bottom: 18px;
  margin-bottom: -18px;
}

.rsp-clean-menu-panel {
  position: absolute;
  top: calc(100% - 1px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  border: 1px solid var(--nav-line);
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.018)),
    var(--nav-panel);
  box-shadow: 0 28px 80px rgba(0,0,0,.42);
  transition: opacity .14s ease, visibility .14s ease, transform .14s ease;
}

.rsp-clean-menu-panel::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -18px;
  height: 18px;
  background: transparent;
}

.rsp-clean-dropdown:hover > .rsp-clean-menu-panel,
.rsp-clean-dropdown:focus-within > .rsp-clean-menu-panel {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

.rsp-clean-dropdown:hover > .rsp-clean-link svg,
.rsp-clean-dropdown:focus-within > .rsp-clean-link svg {
  transform: rotate(180deg);
}

.rsp-clean-shop-panel {
  left: 50%;
  width: 292px;
  padding: 10px;
  border-radius: 18px;
  transform: translateX(-50%) translateY(4px);
}

.rsp-clean-dropdown:hover > .rsp-clean-shop-panel,
.rsp-clean-dropdown:focus-within > .rsp-clean-shop-panel {
  transform: translateX(-50%) translateY(0) !important;
}

.rsp-clean-shop-panel a {
  display: block;
  padding: 13px 14px;
  border-radius: 13px;
  text-decoration: none;
  border: 1px solid transparent;
  transition: background .16s ease, border-color .16s ease;
}

.rsp-clean-shop-panel a + a {
  margin-top: 3px;
}

.rsp-clean-shop-panel a:hover {
  background: rgba(255,255,255,.045);
  border-color: var(--nav-line-soft);
}

.rsp-clean-shop-panel strong {
  display: block;
  color: #fff;
  font-size: 14px;
  line-height: 1.15;
  font-weight: 900;
  letter-spacing: -.02em;
}

.rsp-clean-shop-panel span {
  display: block;
  margin-top: 4px;
  color: var(--nav-muted);
  font-size: 12px;
  line-height: 1.35;
  font-weight: 650;
}

.rsp-clean-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px !important;
  min-width: 0;
}

.rsp-clean-action {
  position: relative;
  min-height: 44px !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border-radius: 999px !important;
  border: 1px solid rgba(255,255,255,.105) !important;
  padding: 0 15px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.062), rgba(255,255,255,.026)) !important;
  color: rgba(247,247,248,.88) !important;
  text-decoration: none;
  font-family: inherit;
  font-size: 13px;
  font-weight: 900;
  white-space: nowrap;
  line-height: 1;
  cursor: pointer;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.04),
    0 10px 26px rgba(0,0,0,.18);
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}

.rsp-clean-action:hover,
.rsp-clean-account:hover .rsp-clean-action,
.rsp-clean-account:focus-within .rsp-clean-action {
  color: #fff !important;
  border-color: rgba(139,92,246,.34) !important;
  background:
    radial-gradient(circle at 20% 0%, rgba(139,92,246,.14), transparent 35%),
    linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.032)) !important;
  transform: translateY(-1px);
}

.rsp-clean-action svg {
  position: relative;
  z-index: 2;
  width: 17px !important;
  height: 17px !important;
  color: #cbb6ff;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.rsp-clean-action span {
  position: relative;
  z-index: 2;
  font-weight: 950;
  letter-spacing: -.015em;
}

.rsp-clean-basket {
  position: relative;
}

.rsp-clean-basket b {
  position: absolute;
  top: -7px !important;
  right: -7px !important;
  min-width: 20px !important;
  height: 20px !important;
  padding: 0 5px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  border: 2px solid #0d0d10;
  background: linear-gradient(135deg, #8b5cf6, #a855f7) !important;
  color: #fff;
  font-size: 10px;
  font-weight: 950;
  line-height: 1;
  box-shadow: 0 10px 20px rgba(139,92,246,.26);
  z-index: 4;
}

.rsp-clean-account-panel {
  right: 0;
  width: 260px;
  padding: 18px !important;
  border-radius: 18px;
  transform: translateY(4px);
  background:
    radial-gradient(circle at 18% 0%, rgba(139,92,246,.13), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.018)),
    #111116 !important;
}

.rsp-clean-account:hover > .rsp-clean-account-panel,
.rsp-clean-account:focus-within > .rsp-clean-account-panel {
  transform: translateY(0) !important;
}

.rsp-clean-account-panel p {
  margin: 0 0 6px;
  color: var(--nav-purple-light);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.rsp-clean-account-panel strong {
  display: block;
  color: #fff;
  font-size: 16px !important;
  line-height: 1.35;
  letter-spacing: -.02em;
  margin-bottom: 16px !important;
}

.rsp-clean-account-panel > div {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.rsp-clean-register,
.rsp-clean-login {
  min-height: 42px !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}

.rsp-clean-register {
  background: var(--nav-purple);
  color: #fff;
}

.rsp-clean-login {
  border: 1px solid var(--nav-line);
  background: rgba(255,255,255,.035);
  color: #fff;
}

.rsp-clean-register:hover,
.rsp-clean-login:hover {
  transform: translateY(-1px);
}

.rsp-clean-login:hover {
  border-color: rgba(139,92,246,.34) !important;
  background: rgba(139,92,246,.09) !important;
}

.rsp-clean-toggle {
  display: none;
  width: 44px;
  height: 44px;
  border: 1px solid var(--nav-line);
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  padding: 0;
  cursor: pointer;
}

.rsp-clean-toggle span {
  display: block;
  width: 17px;
  height: 2px;
  margin: 4px auto;
  border-radius: 999px;
  background: #fff;
  transition: transform .18s ease, opacity .18s ease;
}

.rsp-clean-header.is-open .rsp-clean-toggle span:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}

.rsp-clean-header.is-open .rsp-clean-toggle span:nth-child(2) {
  opacity: 0;
}

.rsp-clean-header.is-open .rsp-clean-toggle span:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}

@media (max-width: 1180px) {
  .rsp-clean-nav {
    grid-template-columns: 1fr auto;
    gap: 14px;
  }

  .rsp-clean-toggle {
    display: block;
    grid-column: 2;
    grid-row: 1;
  }

  .rsp-clean-links {
    display: none;
    position: absolute;
    top: calc(100% + 10px);
    left: 22px;
    right: 22px;
    padding: 12px;
    border: 1px solid var(--nav-line);
    border-radius: 20px;
    background: var(--nav-panel);
    box-shadow: 0 24px 80px rgba(0,0,0,.45);
    flex-direction: column;
    align-items: stretch;
    gap: 4px;
  }

  .rsp-clean-header.is-open .rsp-clean-links {
    display: flex;
  }

  .rsp-clean-link {
    min-height: 44px;
    width: 100%;
    justify-content: space-between;
    padding: 0 12px;
  }

  .rsp-clean-link::after {
    display: none;
  }

  .rsp-clean-dropdown {
    padding-bottom: 0;
    margin-bottom: 0;
  }

  .rsp-clean-shop-panel {
    position: static;
    width: 100%;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    display: none;
    transform: none !important;
    margin-top: 4px;
    box-shadow: none;
  }

  .rsp-clean-dropdown.is-dropdown-open .rsp-clean-shop-panel,
  .rsp-clean-dropdown:hover .rsp-clean-shop-panel,
  .rsp-clean-dropdown:focus-within .rsp-clean-shop-panel {
    display: block;
    transform: none !important;
  }

  .rsp-clean-actions {
    grid-column: 1 / -1;
    justify-content: flex-end;
    padding-bottom: 10px;
  }
}

@media (max-width: 680px) {
  .rsp-clean-nav {
    height: auto;
    min-height: 72px;
    padding: 12px 0 0;
  }

  .rsp-clean-brand img {
    height: 36px !important;
    max-width: 176px !important;
  }

  .rsp-clean-actions {
    display: grid;
    grid-template-columns: 1fr 1fr !important;
    width: 100%;
  }

  .rsp-clean-action {
    width: 100%;
  }

  .rsp-clean-account-panel {
    left: 0;
    right: auto;
    width: min(280px, calc(100vw - 34px));
  }
}

/* =========================================================
   Respawn cart emergency final fix
   Hides WooCommerce empty cart block and restores custom basket.
   Does not touch navbar/header/footer.
========================================================= */

body.woocommerce-cart .wp-block-woocommerce-empty-cart-block,
body.woocommerce-cart .wc-block-cart__empty-cart,
body.woocommerce-cart .wc-block-cart__empty-cart__title,
body.woocommerce-cart .wc-block-cart__empty-cart__title::before,
body.woocommerce-cart .wc-block-cart__empty-cart__title::after,
body.woocommerce-cart .cart-empty,
body.woocommerce-cart .return-to-shop,
body.woocommerce-cart .wp-block-woocommerce-empty-cart-block * {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  max-width: 0 !important;
  max-height: 0 !important;
  min-width: 0 !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
}

.rp-basket-empty-page {
  width: 100% !important;
  min-height: auto !important;
  padding: 58px 0 96px !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(139,92,246,.10), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.012), transparent 34%),
    var(--bg) !important;
  color: var(--text) !important;
  border-top: 1px solid var(--line-soft) !important;
  border-bottom: 1px solid var(--line-soft) !important;
}

.rp-basket-empty-page,
.rp-basket-empty-page * {
  box-sizing: border-box !important;
}

.rp-basket-shell {
  width: min(var(--max), calc(100% - 44px)) !important;
  max-width: var(--max) !important;
  margin: 0 auto !important;
  padding: 0 !important;
}

.rp-basket-crumbs {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 9px !important;
  margin: 0 0 58px !important;
  padding: 0 !important;
  color: var(--soft) !important;
  font-size: 13px !important;
  font-weight: 750 !important;
  line-height: 1 !important;
}

.rp-basket-crumbs a {
  color: var(--muted) !important;
  text-decoration: none !important;
}

.rp-basket-crumbs strong {
  color: var(--purple-light) !important;
}

.rp-basket-empty-hero {
  width: min(1180px, 100%) !important;
  max-width: 1180px !important;
  margin: 0 auto 76px !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: 220px minmax(0, 1fr) !important;
  align-items: center !important;
  gap: clamp(44px, 6vw, 86px) !important;
  text-align: left !important;
}

.rp-basket-empty-icon {
  position: relative !important;
  width: 200px !important;
  height: 200px !important;
  min-width: 200px !important;
  max-width: 200px !important;
  min-height: 200px !important;
  max-height: 200px !important;
  margin: 0 !important;
  padding: 0 !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 999px !important;
  border: 0 !important;
  background:
    radial-gradient(circle at 50% 50%, rgba(139,92,246,.20), rgba(139,92,246,.055) 50%, transparent 72%) !important;
  box-shadow: 0 26px 90px rgba(139,92,246,.12) !important;
  transform: none !important;
  overflow: visible !important;
}

.rp-basket-empty-icon::before,
.rp-basket-empty-icon::after {
  content: "" !important;
  position: absolute !important;
  display: block !important;
  border-radius: 999px !important;
  background: var(--purple) !important;
  box-shadow: 0 0 18px rgba(183,156,255,.52) !important;
  opacity: .75 !important;
}

.rp-basket-empty-icon::before {
  width: 8px !important;
  height: 8px !important;
  right: 18px !important;
  top: 42px !important;
}

.rp-basket-empty-icon::after {
  width: 6px !important;
  height: 6px !important;
  left: -7px !important;
  bottom: 66px !important;
}

.rp-basket-empty-icon svg {
  width: 124px !important;
  height: 124px !important;
  max-width: 124px !important;
  max-height: 124px !important;
  min-width: 0 !important;
  min-height: 0 !important;
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  fill: none !important;
  stroke: var(--purple-light) !important;
  stroke-width: 3.2 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
  filter: drop-shadow(0 0 16px rgba(139,92,246,.62)) !important;
  transform: none !important;
}

.rp-basket-empty-icon svg path {
  fill: none !important;
  stroke: inherit !important;
  stroke-width: inherit !important;
}

.rp-basket-empty-copy {
  width: 100% !important;
  max-width: 820px !important;
  margin: 0 !important;
  padding: 0 !important;
  text-align: left !important;
}

.rp-basket-empty-copy h1 {
  max-width: 820px !important;
  margin: 0 !important;
  padding: 0 !important;
  color: var(--text) !important;
  font-size: clamp(54px, 5.7vw, 88px) !important;
  line-height: .9 !important;
  letter-spacing: -.095em !important;
  font-weight: 600 !important;
  text-align: left !important;
}

.rp-basket-empty-copy p {
  max-width: 760px !important;
  margin: 24px 0 0 !important;
  padding: 0 !important;
  color: var(--muted) !important;
  font-size: clamp(17px, 1.15vw, 21px) !important;
  line-height: 1.58 !important;
  font-weight: 650 !important;
  text-align: left !important;
}

.rp-basket-empty-actions {
  margin: 30px 0 0 !important;
  padding: 0 !important;
  display: flex !important;
  justify-content: flex-start !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
}

.rp-basket-btn {
  min-width: 210px !important;
  min-height: 48px !important;
  width: auto !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 12px !important;
  border-radius: 999px !important;
  padding: 0 22px !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  line-height: 1 !important;
  text-decoration: none !important;
}

.rp-basket-btn-primary {
  border: 1px solid transparent !important;
  background: var(--purple) !important;
  box-shadow: 0 18px 46px rgba(139,92,246,.23) !important;
}

.rp-basket-btn-secondary {
  border: 1px solid var(--line) !important;
  background: rgba(255,255,255,.045) !important;
}

.rp-basket-recs {
  width: 100% !important;
  margin: 0 !important;
  padding: 32px 0 0 !important;
  border-top: 1px solid var(--line-soft) !important;
}

.rp-basket-recs-head {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-end !important;
  gap: 24px !important;
  margin: 0 0 26px !important;
  padding: 0 !important;
}

.rp-basket-recs-head h2 {
  margin: 0 !important;
  color: var(--text) !important;
  font-size: clamp(34px, 4.2vw, 62px) !important;
  line-height: .92 !important;
  letter-spacing: -.08em !important;
  font-weight: 600 !important;
}

.rp-basket-recs-head p {
  margin: 12px 0 0 !important;
  max-width: 620px !important;
  color: var(--muted) !important;
  font-size: 16px !important;
  line-height: 1.7 !important;
}

.rp-basket-recs-head > a {
  min-height: 44px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid var(--line) !important;
  border-radius: 999px !important;
  padding: 0 16px !important;
  background: rgba(255,255,255,.045) !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  text-decoration: none !important;
}

.rp-basket-recs-grid {
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 16px !important;
  width: 100% !important;
}

.rp-basket-rec-card {
  position: relative !important;
  min-width: 0 !important;
  overflow: hidden !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.014)),
    var(--surface) !important;
  box-shadow:
    0 30px 86px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.035) !important;
}

.rp-basket-rec-media {
  display: block !important;
  width: 100% !important;
  height: 230px !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 50% 25%, rgba(139,92,246,.18), transparent 38%),
    var(--surface-2) !important;
}

.rp-basket-rec-media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  padding: 18px !important;
  display: block !important;
}

.rp-basket-rec-body {
  padding: 18px !important;
}

.rp-basket-rec-badge {
  position: absolute !important;
  left: 18px !important;
  top: 18px !important;
  min-height: 25px !important;
  display: inline-flex !important;
  align-items: center !important;
  padding: 0 10px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(183,156,255,.34) !important;
  background: rgba(139,92,246,.26) !important;
  color: #fff !important;
  font-size: 11px !important;
  font-weight: 900 !important;
}

.rp-basket-rec-body h3 {
  margin: 0 !important;
  color: var(--text) !important;
  font-size: 17px !important;
  line-height: 1.2 !important;
}

.rp-basket-rec-body h3 a {
  color: inherit !important;
  text-decoration: none !important;
}

.rp-basket-rec-body p {
  min-height: 38px !important;
  margin: 8px 0 0 !important;
  color: var(--muted) !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}

.rp-basket-rec-price {
  display: block !important;
  margin: 16px 0 0 !important;
  color: var(--text) !important;
  font-size: 20px !important;
}

.rp-basket-rec-button {
  min-height: 44px !important;
  margin-top: 18px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  border: 1px solid var(--line) !important;
  border-radius: 999px !important;
  padding: 0 14px !important;
  color: #fff !important;
  text-decoration: none !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  background: rgba(255,255,255,.045) !important;
}

@media (max-width: 1240px) {
  .rp-basket-empty-hero {
    grid-template-columns: 190px minmax(0, 1fr) !important;
  }

  .rp-basket-empty-icon {
    width: 170px !important;
    height: 170px !important;
    min-width: 170px !important;
    max-width: 170px !important;
    min-height: 170px !important;
    max-height: 170px !important;
  }

  .rp-basket-empty-icon svg {
    width: 106px !important;
    height: 106px !important;
    max-width: 106px !important;
    max-height: 106px !important;
  }

  .rp-basket-recs-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 840px) {
  .rp-basket-empty-page {
    padding: 34px 0 74px !important;
  }

  .rp-basket-shell {
    width: min(100% - 28px, var(--max)) !important;
  }

  .rp-basket-empty-hero {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
    text-align: center !important;
    margin-bottom: 52px !important;
  }

  .rp-basket-empty-icon {
    margin: 0 auto !important;
    width: 150px !important;
    height: 150px !important;
    min-width: 150px !important;
    max-width: 150px !important;
    min-height: 150px !important;
    max-height: 150px !important;
  }

  .rp-basket-empty-icon svg {
    width: 92px !important;
    height: 92px !important;
    max-width: 92px !important;
    max-height: 92px !important;
  }

  .rp-basket-empty-copy,
  .rp-basket-empty-copy h1,
  .rp-basket-empty-copy p {
    text-align: center !important;
  }

  .rp-basket-empty-actions {
    justify-content: center !important;
    flex-direction: column !important;
  }

  .rp-basket-btn {
    width: 100% !important;
  }

  .rp-basket-recs-head {
    align-items: flex-start !important;
    flex-direction: column !important;
  }

  .rp-basket-recs-grid {
    grid-template-columns: 1fr !important;
  }
}

/* =========================================================
   Respawn account/login page rescue final
   Fixes account page spacing and crushed dashboard cards only.
========================================================= */

.respawn-account-page {
  background:
    radial-gradient(circle at 50% 0%, rgba(139,92,246,.10), transparent 32%),
    var(--bg) !important;
}

.respawn-account-page .respawn-page-hero {
  padding: 120px 0 46px !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(139,92,246,.12), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.012), transparent 100%),
    var(--bg) !important;
  border-bottom: 1px solid var(--line-soft) !important;
}

.respawn-account-page .respawn-page-shell {
  width: min(var(--max), calc(100% - 44px)) !important;
  margin-inline: auto !important;
}

.respawn-account-page .respawn-page-eyebrow,
.respawn-account-kicker {
  color: var(--purple-light) !important;
  text-transform: uppercase !important;
  letter-spacing: .23em !important;
  font-size: 11px !important;
  font-weight: 950 !important;
}

.respawn-account-page .respawn-page-hero h1 {
  max-width: 960px !important;
  margin: 14px 0 0 !important;
  color: var(--text) !important;
  font-size: clamp(58px, 6.4vw, 104px) !important;
  line-height: .86 !important;
  letter-spacing: -.105em !important;
  font-weight: 600 !important;
  overflow: visible !important;
}

.respawn-account-page .respawn-page-subtitle {
  max-width: 720px !important;
  margin: 22px 0 0 !important;
  color: var(--muted) !important;
  font-size: 18px !important;
  line-height: 1.7 !important;
}

.respawn-account-page .respawn-page-content-section {
  padding: 46px 0 110px !important;
  background: var(--bg) !important;
}

.respawn-account-layout {
  display: grid !important;
  grid-template-columns: minmax(420px, .72fr) minmax(0, 1.28fr) !important;
  gap: clamp(22px, 3vw, 34px) !important;
  align-items: start !important;
}

.respawn-account-intro,
.respawn-account-card {
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 28px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.014)),
    var(--surface) !important;
  box-shadow:
    0 30px 86px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.035) !important;
}

.respawn-account-intro {
  position: sticky !important;
  top: 104px !important;
  overflow: hidden !important;
  padding: clamp(28px, 3vw, 42px) !important;
  isolation: isolate !important;
}

.respawn-account-intro::before {
  content: "" !important;
  position: absolute !important;
  inset: -1px !important;
  z-index: -1 !important;
  background:
    radial-gradient(circle at 15% 8%, rgba(139,92,246,.20), transparent 30%),
    radial-gradient(circle at 92% 18%, rgba(183,156,255,.10), transparent 28%) !important;
}

.respawn-account-intro h2 {
  max-width: 560px !important;
  margin: 14px 0 0 !important;
  color: var(--text) !important;
  font-size: clamp(36px, 3vw, 54px) !important;
  line-height: .96 !important;
  letter-spacing: -.08em !important;
  font-weight: 600 !important;
}

.respawn-account-intro > p:not(.respawn-account-kicker) {
  max-width: 560px !important;
  margin: 18px 0 0 !important;
  color: var(--muted) !important;
  font-size: 16px !important;
  line-height: 1.7 !important;
}

.respawn-account-benefits {
  display: grid !important;
  gap: 12px !important;
  margin-top: 34px !important;
}

.respawn-account-benefits article {
  display: grid !important;
  grid-template-columns: 52px minmax(0, 1fr) !important;
  gap: 16px !important;
  align-items: center !important;
  min-height: 98px !important;
  padding: 18px !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,.025) !important;
  transition: border-color .18s ease, background .18s ease, transform .18s ease !important;
}

.respawn-account-benefits article:hover {
  transform: translateY(-2px) !important;
  border-color: rgba(139,92,246,.38) !important;
  background: rgba(255,255,255,.04) !important;
}

.respawn-account-benefits span {
  width: 46px !important;
  height: 46px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 999px !important;
  border: 1px solid rgba(183,156,255,.28) !important;
  background: rgba(139,92,246,.08) !important;
  color: var(--purple-light) !important;
  font-size: 12px !important;
  font-weight: 950 !important;
}

.respawn-account-benefits div {
  min-width: 0 !important;
}

.respawn-account-benefits strong {
  display: block !important;
  color: #fff !important;
  font-size: 17px !important;
  line-height: 1.2 !important;
  letter-spacing: -.025em !important;
  white-space: normal !important;
}

.respawn-account-benefits p {
  display: block !important;
  margin: 6px 0 0 !important;
  color: var(--muted) !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
  white-space: normal !important;
  max-width: 100% !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
}

.respawn-account-card {
  padding: clamp(22px, 2.4vw, 34px) !important;
  min-width: 0 !important;
}

.respawn-account-card .woocommerce {
  color: var(--muted) !important;
}

/* Logged-in dashboard: make WooCommerce account look premium, not cramped */
.respawn-account-page .woocommerce-MyAccount-navigation {
  float: none !important;
  width: 100% !important;
  margin: 0 0 22px !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation li {
  margin: 0 !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation a {
  min-height: 44px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 999px !important;
  padding: 0 16px !important;
  background: rgba(255,255,255,.035) !important;
  color: rgba(247,247,248,.76) !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  text-decoration: none !important;
  line-height: 1 !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation a:hover {
  border-color: rgba(139,92,246,.34) !important;
  background: rgba(255,255,255,.055) !important;
  color: #fff !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation .is-active a {
  border-color: rgba(139,92,246,.50) !important;
  background: var(--purple) !important;
  color: #fff !important;
  box-shadow: 0 18px 46px rgba(139,92,246,.18) !important;
}

.respawn-account-page .woocommerce-MyAccount-content {
  float: none !important;
  width: 100% !important;
  min-height: 360px !important;
  padding: 28px !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 22px !important;
  background:
    radial-gradient(circle at 12% 0%, rgba(139,92,246,.08), transparent 32%),
    rgba(255,255,255,.025) !important;
  color: var(--muted) !important;
}

.respawn-account-page .woocommerce-MyAccount-content p {
  max-width: 760px !important;
  margin: 0 0 14px !important;
  color: var(--muted) !important;
  font-size: 15px !important;
  line-height: 1.8 !important;
}

.respawn-account-page .woocommerce-MyAccount-content a {
  color: var(--purple-light) !important;
  font-weight: 750 !important;
}

.respawn-account-page .woocommerce-MyAccount-content a:hover {
  color: #fff !important;
}

.respawn-account-page .woocommerce-MyAccount-content mark {
  padding: 2px 7px !important;
  border-radius: 999px !important;
  background: rgba(139,92,246,.16) !important;
  color: #fff !important;
}

/* Login/register form styling */
.respawn-account-page .woocommerce .u-columns {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px !important;
  margin: 0 !important;
}

.respawn-account-page .woocommerce .u-column1,
.respawn-account-page .woocommerce .u-column2 {
  width: auto !important;
  float: none !important;
  margin: 0 !important;
}

.respawn-account-page .woocommerce h2 {
  margin: 0 0 18px !important;
  color: var(--text) !important;
  font-size: clamp(26px, 2.2vw, 36px) !important;
  line-height: 1 !important;
  letter-spacing: -.06em !important;
  font-weight: 650 !important;
}

.respawn-account-page .woocommerce form.login,
.respawn-account-page .woocommerce form.register {
  min-height: 100% !important;
  margin: 0 !important;
  padding: 24px !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 22px !important;
  background:
    radial-gradient(circle at 20% 0%, rgba(139,92,246,.08), transparent 38%),
    rgba(255,255,255,.025) !important;
  color: var(--muted) !important;
}

.respawn-account-page .woocommerce form .form-row {
  margin: 0 0 16px !important;
  padding: 0 !important;
}

.respawn-account-page .woocommerce label {
  display: block !important;
  margin-bottom: 8px !important;
  color: rgba(247,247,248,.76) !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  line-height: 1.35 !important;
}

.respawn-account-page .woocommerce input.input-text,
.respawn-account-page .woocommerce input[type="text"],
.respawn-account-page .woocommerce input[type="email"],
.respawn-account-page .woocommerce input[type="password"],
.respawn-account-page .woocommerce input[type="tel"],
.respawn-account-page .woocommerce textarea,
.respawn-account-page .woocommerce select {
  width: 100% !important;
  min-height: 52px !important;
  border: 1px solid rgba(255,255,255,.11) !important;
  border-radius: 16px !important;
  padding: 0 16px !important;
  background: rgba(255,255,255,.04) !important;
  color: #fff !important;
  font: inherit !important;
  font-size: 14px !important;
  font-weight: 650 !important;
  outline: none !important;
  box-shadow: none !important;
}

.respawn-account-page .woocommerce input.input-text:focus,
.respawn-account-page .woocommerce input[type="text"]:focus,
.respawn-account-page .woocommerce input[type="email"]:focus,
.respawn-account-page .woocommerce input[type="password"]:focus,
.respawn-account-page .woocommerce input[type="tel"]:focus,
.respawn-account-page .woocommerce textarea:focus,
.respawn-account-page .woocommerce select:focus {
  border-color: rgba(183,156,255,.52) !important;
  background: rgba(255,255,255,.055) !important;
  box-shadow: 0 0 0 4px rgba(139,92,246,.10) !important;
}

.respawn-account-page .woocommerce button.button,
.respawn-account-page .woocommerce a.button,
.respawn-account-page .woocommerce .button {
  min-height: 50px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid transparent !important;
  border-radius: 999px !important;
  padding: 0 22px !important;
  background: var(--purple) !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  box-shadow: 0 18px 46px rgba(139,92,246,.23) !important;
}

.respawn-account-page .woocommerce button.button:hover,
.respawn-account-page .woocommerce a.button:hover,
.respawn-account-page .woocommerce .button:hover {
  background: #7c3aed !important;
}

/* Notices */
.respawn-account-page .woocommerce-error,
.respawn-account-page .woocommerce-message,
.respawn-account-page .woocommerce-info {
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 18px !important;
  padding: 16px 18px 16px 48px !important;
  margin: 0 0 18px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.018)),
    var(--surface-2) !important;
  color: rgba(247,247,248,.78) !important;
  box-shadow: none !important;
}

/* Tables / addresses */
.respawn-account-page .woocommerce table.shop_table {
  overflow: hidden !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,.025) !important;
  color: var(--muted) !important;
}

.respawn-account-page .woocommerce table.shop_table td,
.respawn-account-page .woocommerce table.shop_table th {
  border-color: rgba(255,255,255,.075) !important;
}

.respawn-account-page .woocommerce table.shop_table th {
  color: #fff !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: .12em !important;
}

.respawn-account-page .woocommerce .woocommerce-Address {
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 18px !important;
  padding: 20px !important;
  background: rgba(255,255,255,.025) !important;
}

/* Stop WooCommerce floats from creating strange narrow columns */
.respawn-account-page .woocommerce::after,
.respawn-account-page .woocommerce-MyAccount-content::after,
.respawn-account-page .woocommerce-MyAccount-navigation::after {
  content: "" !important;
  display: table !important;
  clear: both !important;
}

@media (max-width: 1180px) {
  .respawn-account-layout {
    grid-template-columns: 1fr !important;
  }

  .respawn-account-intro {
    position: relative !important;
    top: auto !important;
  }

  .respawn-account-benefits {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .respawn-account-benefits article {
    grid-template-columns: 1fr !important;
    align-items: start !important;
  }
}

@media (max-width: 900px) {
  .respawn-account-page .woocommerce .u-columns {
    grid-template-columns: 1fr !important;
  }

  .respawn-account-benefits {
    grid-template-columns: 1fr !important;
  }

  .respawn-account-benefits article {
    grid-template-columns: 52px minmax(0, 1fr) !important;
  }

  .respawn-account-page .respawn-page-hero {
    padding: 96px 0 28px !important;
  }

  .respawn-account-page .respawn-page-content-section {
    padding: 28px 0 74px !important;
  }
}

@media (max-width: 640px) {
  .respawn-account-page .respawn-page-shell {
    width: min(100% - 28px, var(--max)) !important;
  }

  .respawn-account-card,
  .respawn-account-intro {
    padding: 18px !important;
    border-radius: 20px !important;
  }

  .respawn-account-benefits article {
    grid-template-columns: 42px 1fr !important;
    min-height: auto !important;
    padding: 15px !important;
  }

  .respawn-account-benefits span {
    width: 40px !important;
    height: 40px !important;
  }

  .respawn-account-page .woocommerce form.login,
  .respawn-account-page .woocommerce form.register,
  .respawn-account-page .woocommerce-MyAccount-content {
    padding: 18px !important;
  }

  .respawn-account-page .woocommerce button.button,
  .respawn-account-page .woocommerce a.button,
  .respawn-account-page .woocommerce .button {
    width: 100% !important;
  }

  .respawn-account-page .woocommerce-MyAccount-navigation ul {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
  }

  .respawn-account-page .woocommerce-MyAccount-navigation a {
    width: 100% !important;
    text-align: center !important;
  }
}

/* =========================================================
   Respawn account dashboard final polish
   Removes WooCommerce downloads nav and makes dashboard match site.
========================================================= */

/* Downloads are not used for built-to-order PCs */
.respawn-account-page .woocommerce-MyAccount-navigation-link--downloads {
  display: none !important;
}

/* Calm the account hero so it matches the premium site rhythm */
.respawn-account-page .respawn-page-hero {
  padding: 96px 0 48px !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(139,92,246,.085), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,.01), transparent 100%),
    var(--bg) !important;
}

.respawn-account-page .respawn-page-hero h1 {
  font-size: clamp(54px, 5.2vw, 86px) !important;
  letter-spacing: -.095em !important;
}

.respawn-account-page .respawn-page-subtitle {
  color: rgba(247,247,248,.62) !important;
  font-size: 16px !important;
}

/* Account content should feel like the shop/listing pages, not a random plugin panel */
.respawn-account-page .respawn-page-content-section {
  padding: 42px 0 96px !important;
}

.respawn-account-page .respawn-page-shell {
  width: min(1220px, calc(100% - 44px)) !important;
}

.respawn-account-card {
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.respawn-account-page .woocommerce {
  display: grid !important;
  gap: 18px !important;
}

/* Dashboard nav: cleaner, quieter, site-consistent */
.respawn-account-page .woocommerce-MyAccount-navigation {
  float: none !important;
  width: 100% !important;
  margin: 0 !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation ul {
  list-style: none !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  margin: 0 !important;
  padding: 0 !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation li {
  margin: 0 !important;
  padding: 0 !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation a {
  min-height: 42px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid rgba(255,255,255,.105) !important;
  border-radius: 999px !important;
  padding: 0 15px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02)) !important;
  color: rgba(247,247,248,.70) !important;
  font-size: 12px !important;
  font-weight: 850 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation a:hover {
  border-color: rgba(183,156,255,.30) !important;
  background: rgba(255,255,255,.045) !important;
  color: #fff !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation .is-active a {
  border-color: rgba(183,156,255,.34) !important;
  background:
    linear-gradient(180deg, rgba(139,92,246,.18), rgba(139,92,246,.075)) !important;
  color: #fff !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.045) !important;
}

/* Main account panel: remove huge empty void */
.respawn-account-page .woocommerce-MyAccount-content {
  float: none !important;
  width: 100% !important;
  min-height: 0 !important;
  padding: clamp(24px, 2.6vw, 34px) !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 24px !important;
  background:
    radial-gradient(circle at 16% 0%, rgba(139,92,246,.065), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.014)),
    var(--surface) !important;
  box-shadow:
    0 30px 86px rgba(0,0,0,.26),
    inset 0 1px 0 rgba(255,255,255,.035) !important;
  color: var(--muted) !important;
}

/* Dashboard text */
.respawn-account-page .woocommerce-MyAccount-content p {
  max-width: 760px !important;
  margin: 0 0 12px !important;
  color: rgba(247,247,248,.68) !important;
  font-size: 15px !important;
  line-height: 1.75 !important;
}

.respawn-account-page .woocommerce-MyAccount-content p:last-child {
  margin-bottom: 0 !important;
}

.respawn-account-page .woocommerce-MyAccount-content strong {
  color: #fff !important;
}

.respawn-account-page .woocommerce-MyAccount-content a {
  color: var(--purple-light) !important;
  font-weight: 800 !important;
  text-decoration: none !important;
}

.respawn-account-page .woocommerce-MyAccount-content a:hover {
  color: #fff !important;
}

/* Subtle account chips inside default dashboard copy */
.respawn-account-page .woocommerce-MyAccount-content mark {
  padding: 2px 8px !important;
  border-radius: 999px !important;
  background: rgba(139,92,246,.14) !important;
  color: #fff !important;
}

/* Logged-in area should not look cramped or plugin-default */
.respawn-account-page .woocommerce-MyAccount-content h2,
.respawn-account-page .woocommerce-MyAccount-content h3,
.respawn-account-page .woocommerce-MyAccount-content legend {
  color: #fff !important;
  font-size: clamp(24px, 2vw, 34px) !important;
  line-height: 1 !important;
  letter-spacing: -.055em !important;
  font-weight: 650 !important;
  margin: 0 0 18px !important;
}

/* Tables, orders, addresses */
.respawn-account-page .woocommerce table.shop_table {
  overflow: hidden !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,.018) !important;
  color: var(--muted) !important;
}

.respawn-account-page .woocommerce table.shop_table th {
  color: #fff !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: .12em !important;
}

.respawn-account-page .woocommerce table.shop_table td,
.respawn-account-page .woocommerce table.shop_table th {
  border-color: rgba(255,255,255,.075) !important;
  padding: 16px !important;
}

.respawn-account-page .woocommerce .woocommerce-Address {
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 18px !important;
  padding: 20px !important;
  background: rgba(255,255,255,.02) !important;
}

.respawn-account-page .woocommerce .woocommerce-Address-title h3 {
  color: #fff !important;
  font-size: 22px !important;
  letter-spacing: -.04em !important;
}

.respawn-account-page .woocommerce .woocommerce-Address address {
  color: rgba(247,247,248,.66) !important;
  line-height: 1.7 !important;
}

/* Login/register state, same calmer style */
.respawn-account-page .woocommerce .u-columns {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px !important;
  margin: 0 !important;
}

.respawn-account-page .woocommerce .u-column1,
.respawn-account-page .woocommerce .u-column2 {
  width: auto !important;
  float: none !important;
  margin: 0 !important;
}

.respawn-account-page .woocommerce h2 {
  color: #fff !important;
  font-size: clamp(28px, 2.3vw, 38px) !important;
  line-height: 1 !important;
  letter-spacing: -.065em !important;
  font-weight: 650 !important;
  margin: 0 0 18px !important;
}

.respawn-account-page .woocommerce form.login,
.respawn-account-page .woocommerce form.register,
.respawn-account-page .woocommerce form.edit-account,
.respawn-account-page .woocommerce form.woocommerce-EditAccountForm,
.respawn-account-page .woocommerce form.woocommerce-address-fields {
  margin: 0 !important;
  padding: clamp(22px, 2.2vw, 30px) !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 24px !important;
  background:
    radial-gradient(circle at 16% 0%, rgba(139,92,246,.065), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.014)),
    var(--surface) !important;
  box-shadow:
    0 30px 86px rgba(0,0,0,.24),
    inset 0 1px 0 rgba(255,255,255,.035) !important;
}

.respawn-account-page .woocommerce form .form-row {
  margin: 0 0 16px !important;
  padding: 0 !important;
}

.respawn-account-page .woocommerce label {
  display: block !important;
  margin-bottom: 8px !important;
  color: rgba(247,247,248,.72) !important;
  font-size: 13px !important;
  font-weight: 850 !important;
}

.respawn-account-page .woocommerce input.input-text,
.respawn-account-page .woocommerce input[type="text"],
.respawn-account-page .woocommerce input[type="email"],
.respawn-account-page .woocommerce input[type="password"],
.respawn-account-page .woocommerce input[type="tel"],
.respawn-account-page .woocommerce textarea,
.respawn-account-page .woocommerce select {
  width: 100% !important;
  min-height: 52px !important;
  border: 1px solid rgba(255,255,255,.11) !important;
  border-radius: 16px !important;
  padding: 0 16px !important;
  background: rgba(255,255,255,.04) !important;
  color: #fff !important;
  font: inherit !important;
  font-size: 14px !important;
  font-weight: 650 !important;
  outline: none !important;
  box-shadow: none !important;
}

.respawn-account-page .woocommerce textarea {
  min-height: 112px !important;
  padding-top: 14px !important;
  padding-bottom: 14px !important;
}

.respawn-account-page .woocommerce input.input-text:focus,
.respawn-account-page .woocommerce input[type="text"]:focus,
.respawn-account-page .woocommerce input[type="email"]:focus,
.respawn-account-page .woocommerce input[type="password"]:focus,
.respawn-account-page .woocommerce input[type="tel"]:focus,
.respawn-account-page .woocommerce textarea:focus,
.respawn-account-page .woocommerce select:focus {
  border-color: rgba(183,156,255,.42) !important;
  background: rgba(255,255,255,.055) !important;
  box-shadow: 0 0 0 4px rgba(139,92,246,.08) !important;
}

.respawn-account-page .woocommerce button.button,
.respawn-account-page .woocommerce a.button,
.respawn-account-page .woocommerce .button {
  min-height: 48px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid transparent !important;
  border-radius: 999px !important;
  padding: 0 22px !important;
  background: var(--purple) !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  box-shadow: 0 16px 38px rgba(139,92,246,.18) !important;
}

.respawn-account-page .woocommerce button.button:hover,
.respawn-account-page .woocommerce a.button:hover,
.respawn-account-page .woocommerce .button:hover {
  background: #7c3aed !important;
}

/* WooCommerce notices */
.respawn-account-page .woocommerce-error,
.respawn-account-page .woocommerce-message,
.respawn-account-page .woocommerce-info {
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 18px !important;
  padding: 16px 18px 16px 48px !important;
  margin: 0 0 18px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.016)),
    var(--surface-2) !important;
  color: rgba(247,247,248,.72) !important;
  box-shadow: none !important;
}

.respawn-account-page .woocommerce-error {
  border-color: rgba(251,113,133,.28) !important;
}

.respawn-account-page .woocommerce-info::before,
.respawn-account-page .woocommerce-message::before {
  color: var(--purple-light) !important;
}

.respawn-account-page .woocommerce-error::before {
  color: #fb7185 !important;
}

/* Stop WooCommerce floats from causing odd plugin layouts */
.respawn-account-page .woocommerce::after,
.respawn-account-page .woocommerce-MyAccount-content::after,
.respawn-account-page .woocommerce-MyAccount-navigation::after {
  content: "" !important;
  display: table !important;
  clear: both !important;
}

@media (max-width: 900px) {
  .respawn-account-page .woocommerce .u-columns {
    grid-template-columns: 1fr !important;
  }

  .respawn-account-page .respawn-page-hero {
    padding: 86px 0 34px !important;
  }
}

@media (max-width: 640px) {
  .respawn-account-page .respawn-page-shell {
    width: min(100% - 28px, var(--max)) !important;
  }

  .respawn-account-page .woocommerce-MyAccount-navigation ul {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
  }

  .respawn-account-page .woocommerce-MyAccount-navigation a {
    width: 100% !important;
  }

  .respawn-account-page .woocommerce-MyAccount-content,
  .respawn-account-page .woocommerce form.login,
  .respawn-account-page .woocommerce form.register,
  .respawn-account-page .woocommerce form.edit-account,
  .respawn-account-page .woocommerce form.woocommerce-EditAccountForm,
  .respawn-account-page .woocommerce form.woocommerce-address-fields {
    padding: 18px !important;
    border-radius: 20px !important;
  }

  .respawn-account-page .woocommerce button.button,
  .respawn-account-page .woocommerce a.button,
  .respawn-account-page .woocommerce .button {
    width: 100% !important;
  }
}

/* =========================================================
   Respawn account pages premium cleanup
   Makes My Account feel like a proper customer portal.
========================================================= */

.respawn-account-page .respawn-page-hero {
  padding: 92px 0 42px !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(139,92,246,.075), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,.008), transparent 100%),
    var(--bg) !important;
}

.respawn-account-page .respawn-page-hero h1 {
  font-size: clamp(52px, 4.8vw, 78px) !important;
  line-height: .9 !important;
  letter-spacing: -.09em !important;
}

.respawn-account-page .respawn-page-subtitle {
  max-width: 610px !important;
  color: rgba(247,247,248,.58) !important;
  font-size: 15px !important;
  line-height: 1.7 !important;
}

.respawn-account-page .respawn-page-content-section {
  padding: 38px 0 96px !important;
}

.respawn-account-page .respawn-page-shell {
  width: min(1160px, calc(100% - 44px)) !important;
}

.respawn-account-page .woocommerce {
  display: block !important;
}

/* Remove unused WooCommerce default downloads tab */
.respawn-account-page .woocommerce-MyAccount-navigation-link--downloads {
  display: none !important;
}

/* Professional account nav, not bubble/pill overload */
.respawn-account-page .woocommerce-MyAccount-navigation {
  width: 100% !important;
  float: none !important;
  margin: 0 0 24px !important;
  padding: 0 !important;
  border-bottom: 1px solid rgba(255,255,255,.09) !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation ul {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation li {
  margin: 0 !important;
  padding: 0 !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation a {
  position: relative !important;
  min-height: 48px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 18px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: rgba(247,247,248,.58) !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  transition: color .18s ease !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation a::after {
  content: "" !important;
  position: absolute !important;
  left: 18px !important;
  right: 18px !important;
  bottom: -1px !important;
  height: 2px !important;
  border-radius: 999px !important;
  background: var(--purple-light) !important;
  transform: scaleX(0) !important;
  transform-origin: center !important;
  transition: transform .18s ease !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation a:hover {
  color: #fff !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation .is-active a {
  color: #fff !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation .is-active a::after,
.respawn-account-page .woocommerce-MyAccount-navigation a:hover::after {
  transform: scaleX(1) !important;
}

/* Main content panel */
.respawn-account-page .woocommerce-MyAccount-content {
  width: 100% !important;
  float: none !important;
  min-height: 0 !important;
  padding: clamp(26px, 2.6vw, 38px) !important;
  border: 1px solid rgba(255,255,255,.085) !important;
  border-radius: 24px !important;
  background:
    radial-gradient(circle at 14% 0%, rgba(139,92,246,.055), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.012)),
    var(--surface) !important;
  box-shadow:
    0 28px 80px rgba(0,0,0,.25),
    inset 0 1px 0 rgba(255,255,255,.032) !important;
  color: rgba(247,247,248,.66) !important;
}

/* Dashboard copy */
.respawn-account-page .woocommerce-MyAccount-content > p {
  max-width: 820px !important;
  margin: 0 0 14px !important;
  color: rgba(247,247,248,.66) !important;
  font-size: 15px !important;
  line-height: 1.78 !important;
}

.respawn-account-page .woocommerce-MyAccount-content > p:first-child {
  color: rgba(247,247,248,.76) !important;
}

.respawn-account-page .woocommerce-MyAccount-content a {
  color: var(--purple-light) !important;
  font-weight: 800 !important;
  text-decoration: none !important;
}

.respawn-account-page .woocommerce-MyAccount-content a:hover {
  color: #fff !important;
}

/* Address page, cleaner cards */
.respawn-account-page .woocommerce-Addresses {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px !important;
  margin-top: 24px !important;
}

.respawn-account-page .woocommerce-Address,
.respawn-account-page .woocommerce .woocommerce-Address {
  width: 100% !important;
  float: none !important;
  min-height: 170px !important;
  padding: 24px !important;
  border: 1px solid rgba(255,255,255,.085) !important;
  border-radius: 20px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.028), rgba(255,255,255,.012)),
    rgba(255,255,255,.012) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.025) !important;
}

.respawn-account-page .woocommerce-Address-title {
  display: flex !important;
  align-items: start !important;
  justify-content: space-between !important;
  gap: 16px !important;
  margin: 0 0 18px !important;
}

.respawn-account-page .woocommerce-Address-title h3 {
  margin: 0 !important;
  color: #fff !important;
  font-size: clamp(24px, 2vw, 34px) !important;
  line-height: .95 !important;
  letter-spacing: -.06em !important;
  font-weight: 650 !important;
}

.respawn-account-page .woocommerce-Address-title a {
  min-height: 36px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  white-space: nowrap !important;
  padding: 0 13px !important;
  border: 1px solid rgba(183,156,255,.22) !important;
  border-radius: 999px !important;
  background: rgba(139,92,246,.06) !important;
  color: var(--purple-light) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
}

.respawn-account-page .woocommerce-Address-title a:hover {
  border-color: rgba(183,156,255,.4) !important;
  background: rgba(139,92,246,.10) !important;
  color: #fff !important;
}

.respawn-account-page .woocommerce-Address address {
  margin: 0 !important;
  color: rgba(247,247,248,.56) !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
  font-style: normal !important;
}

/* Account details form */
.respawn-account-page .woocommerce-EditAccountForm,
.respawn-account-page form.edit-account {
  max-width: 100% !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.respawn-account-page .woocommerce-EditAccountForm .form-row,
.respawn-account-page form.edit-account .form-row {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.respawn-account-page .woocommerce-EditAccountForm .form-row-wide,
.respawn-account-page form.edit-account .form-row-wide,
.respawn-account-page .woocommerce-EditAccountForm fieldset,
.respawn-account-page form.edit-account fieldset,
.respawn-account-page .woocommerce-EditAccountForm p:last-child,
.respawn-account-page form.edit-account p:last-child {
  grid-column: 1 / -1 !important;
}

/* Kill the silly white box around password change */
.respawn-account-page .woocommerce-EditAccountForm fieldset,
.respawn-account-page form.edit-account fieldset {
  margin: 10px 0 0 !important;
  padding: 24px !important;
  border: 1px solid rgba(255,255,255,.085) !important;
  border-radius: 20px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.022), rgba(255,255,255,.01)),
    rgba(255,255,255,.012) !important;
}

.respawn-account-page .woocommerce-EditAccountForm legend,
.respawn-account-page form.edit-account legend {
  width: 100% !important;
  margin: 0 0 18px !important;
  padding: 0 !important;
  color: #fff !important;
  font-size: clamp(24px, 2vw, 34px) !important;
  line-height: 1 !important;
  letter-spacing: -.06em !important;
  font-weight: 650 !important;
}

.respawn-account-page .woocommerce-EditAccountForm em,
.respawn-account-page form.edit-account em {
  display: block !important;
  margin-top: 7px !important;
  color: rgba(247,247,248,.42) !important;
  font-size: 12px !important;
  line-height: 1.5 !important;
}

/* Inputs */
.respawn-account-page .woocommerce label {
  display: block !important;
  margin-bottom: 9px !important;
  color: rgba(247,247,248,.70) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1.35 !important;
}

.respawn-account-page .woocommerce .required {
  color: var(--purple-light) !important;
}

.respawn-account-page .woocommerce input.input-text,
.respawn-account-page .woocommerce input[type="text"],
.respawn-account-page .woocommerce input[type="email"],
.respawn-account-page .woocommerce input[type="password"],
.respawn-account-page .woocommerce input[type="tel"],
.respawn-account-page .woocommerce textarea,
.respawn-account-page .woocommerce select {
  width: 100% !important;
  min-height: 52px !important;
  border: 1px solid rgba(255,255,255,.105) !important;
  border-radius: 14px !important;
  padding: 0 15px !important;
  background: rgba(255,255,255,.035) !important;
  color: #fff !important;
  font: inherit !important;
  font-size: 14px !important;
  font-weight: 650 !important;
  outline: none !important;
  box-shadow: none !important;
}

.respawn-account-page .woocommerce textarea {
  min-height: 120px !important;
  padding-top: 14px !important;
  padding-bottom: 14px !important;
}

.respawn-account-page .woocommerce input.input-text:focus,
.respawn-account-page .woocommerce input[type="text"]:focus,
.respawn-account-page .woocommerce input[type="email"]:focus,
.respawn-account-page .woocommerce input[type="password"]:focus,
.respawn-account-page .woocommerce input[type="tel"]:focus,
.respawn-account-page .woocommerce textarea:focus,
.respawn-account-page .woocommerce select:focus {
  border-color: rgba(183,156,255,.42) !important;
  background: rgba(255,255,255,.052) !important;
  box-shadow: 0 0 0 4px rgba(139,92,246,.075) !important;
}

.respawn-account-page .woocommerce .password-input {
  display: block !important;
  width: 100% !important;
}

/* Save / action buttons */
.respawn-account-page .woocommerce button.button,
.respawn-account-page .woocommerce a.button,
.respawn-account-page .woocommerce .button {
  min-height: 48px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid transparent !important;
  border-radius: 999px !important;
  padding: 0 22px !important;
  background: var(--purple) !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  box-shadow: 0 16px 38px rgba(139,92,246,.18) !important;
}

.respawn-account-page .woocommerce button.button:hover,
.respawn-account-page .woocommerce a.button:hover,
.respawn-account-page .woocommerce .button:hover {
  background: #7c3aed !important;
}

/* Notices */
.respawn-account-page .woocommerce-error,
.respawn-account-page .woocommerce-message,
.respawn-account-page .woocommerce-info {
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 18px !important;
  padding: 16px 18px 16px 48px !important;
  margin: 0 0 18px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.016)),
    var(--surface-2) !important;
  color: rgba(247,247,248,.72) !important;
  box-shadow: none !important;
}

.respawn-account-page .woocommerce-info::before,
.respawn-account-page .woocommerce-message::before {
  color: var(--purple-light) !important;
}

.respawn-account-page .woocommerce-error::before {
  color: #fb7185 !important;
}

/* Tables/orders */
.respawn-account-page .woocommerce table.shop_table {
  overflow: hidden !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,.018) !important;
  color: var(--muted) !important;
}

.respawn-account-page .woocommerce table.shop_table th {
  color: #fff !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: .12em !important;
}

.respawn-account-page .woocommerce table.shop_table td,
.respawn-account-page .woocommerce table.shop_table th {
  border-color: rgba(255,255,255,.075) !important;
  padding: 16px !important;
}

@media (max-width: 900px) {
  .respawn-account-page .woocommerce-Addresses,
  .respawn-account-page .woocommerce-EditAccountForm,
  .respawn-account-page form.edit-account {
    grid-template-columns: 1fr !important;
  }

  .respawn-account-page .woocommerce-MyAccount-navigation ul {
    gap: 0 !important;
    overflow-x: auto !important;
    flex-wrap: nowrap !important;
  }

  .respawn-account-page .woocommerce-MyAccount-navigation a {
    white-space: nowrap !important;
  }
}

@media (max-width: 640px) {
  .respawn-account-page .respawn-page-shell {
    width: min(100% - 28px, var(--max)) !important;
  }

  .respawn-account-page .woocommerce-MyAccount-content {
    padding: 18px !important;
    border-radius: 20px !important;
  }

  .respawn-account-page .woocommerce-Address,
  .respawn-account-page .woocommerce .woocommerce-Address,
  .respawn-account-page .woocommerce-EditAccountForm fieldset,
  .respawn-account-page form.edit-account fieldset {
    padding: 18px !important;
    border-radius: 18px !important;
  }

  .respawn-account-page .woocommerce button.button,
  .respawn-account-page .woocommerce a.button,
  .respawn-account-page .woocommerce .button {
    width: 100% !important;
  }
}

/* =========================================
   Respawn Account - Address page cleanup
   Final override loaded last.
========================================= */

.respawn-account-page .woocommerce-MyAccount-content {
  min-height: auto !important;
  padding: 32px !important;
}

/* Address intro text */
.respawn-account-page .woocommerce-Addresses + p,
.respawn-account-page .woocommerce-MyAccount-content > p {
  color: rgba(247, 247, 248, 0.72) !important;
  font-size: 15px !important;
  line-height: 1.7 !important;
  margin-bottom: 22px !important;
}

/* Force clean 2-column grid */
.respawn-account-page .woocommerce-Addresses {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 24px !important;
  align-items: stretch !important;
  margin-top: 24px !important;
}

/* Kill WooCommerce float nonsense */
.respawn-account-page .woocommerce-Addresses .col-1,
.respawn-account-page .woocommerce-Addresses .col-2,
.respawn-account-page .woocommerce-Address,
.respawn-account-page .woocommerce .woocommerce-Address {
  float: none !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
}

/* Individual address cards */
.respawn-account-page .woocommerce-Addresses .woocommerce-Address,
.respawn-account-page .woocommerce .woocommerce-Address {
  min-height: 220px !important;
  padding: 28px !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  border-radius: 22px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.01)),
    rgba(18, 18, 24, 0.92) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.03),
    0 18px 50px rgba(0,0,0,0.18) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
}

/* Top row */
.respawn-account-page .woocommerce-Address-title {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 18px !important;
  margin: 0 0 22px !important;
}

/* Address headings */
.respawn-account-page .woocommerce-Address-title h3 {
  margin: 0 !important;
  color: #ffffff !important;
  font-size: clamp(28px, 2.2vw, 42px) !important;
  line-height: 0.95 !important;
  letter-spacing: -0.06em !important;
  font-weight: 700 !important;
  max-width: 70% !important;
}

/* Buttons */
.respawn-account-page .woocommerce-Address-title a,
.respawn-account-page .woocommerce-Address a.edit {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 42px !important;
  padding: 0 16px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(167, 139, 250, 0.26) !important;
  background: rgba(139, 92, 246, 0.08) !important;
  color: #b995ff !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  box-shadow: none !important;
}

.respawn-account-page .woocommerce-Address-title a:hover,
.respawn-account-page .woocommerce-Address a.edit:hover {
  background: rgba(139, 92, 246, 0.16) !important;
  border-color: rgba(167, 139, 250, 0.44) !important;
  color: #ffffff !important;
}

/* Address text */
.respawn-account-page .woocommerce-Address address {
  margin: 0 !important;
  color: rgba(247, 247, 248, 0.62) !important;
  font-size: 15px !important;
  line-height: 1.75 !important;
  font-style: normal !important;
}

/* Empty-state text inside cards */
.respawn-account-page .woocommerce-Address address:empty,
.respawn-account-page .woocommerce-Address p {
  color: rgba(247, 247, 248, 0.58) !important;
  font-size: 15px !important;
  line-height: 1.7 !important;
  margin: 0 !important;
}

/* Mobile */
@media (max-width: 900px) {
  .respawn-account-page .woocommerce-Addresses {
    grid-template-columns: 1fr !important;
  }

  .respawn-account-page .woocommerce-Address-title {
    flex-direction: column !important;
    align-items: flex-start !important;
  }

  .respawn-account-page .woocommerce-Address-title h3 {
    max-width: 100% !important;
    font-size: 34px !important;
  }

  .respawn-account-page .woocommerce-Addresses .woocommerce-Address,
  .respawn-account-page .woocommerce .woocommerce-Address {
    min-height: auto !important;
  }
}

@media (max-width: 640px) {
  .respawn-account-page .woocommerce-MyAccount-content {
    padding: 18px !important;
  }

  .respawn-account-page .woocommerce-Addresses .woocommerce-Address,
  .respawn-account-page .woocommerce .woocommerce-Address {
    padding: 20px !important;
  }
}

/* =========================================
   Respawn Account - Address level alignment fix
   Forces Billing + Shipping cards onto the same row.
========================================= */

.respawn-account-page .woocommerce-MyAccount-content .addresses,
.respawn-account-page .woocommerce-MyAccount-content .woocommerce-Addresses,
.respawn-account-page .woocommerce-MyAccount-content .col2-set.addresses {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  grid-auto-flow: column !important;
  grid-auto-rows: 1fr !important;
  gap: 24px !important;
  align-items: stretch !important;
  margin: 26px 0 0 !important;
  padding: 0 !important;
  width: 100% !important;
}

/* Nuke old WooCommerce float/width positioning */
.respawn-account-page .woocommerce-MyAccount-content .addresses::before,
.respawn-account-page .woocommerce-MyAccount-content .addresses::after,
.respawn-account-page .woocommerce-MyAccount-content .woocommerce-Addresses::before,
.respawn-account-page .woocommerce-MyAccount-content .woocommerce-Addresses::after,
.respawn-account-page .woocommerce-MyAccount-content .col2-set.addresses::before,
.respawn-account-page .woocommerce-MyAccount-content .col2-set.addresses::after {
  content: none !important;
  display: none !important;
}

.respawn-account-page .woocommerce-MyAccount-content .addresses .col-1,
.respawn-account-page .woocommerce-MyAccount-content .addresses .col-2,
.respawn-account-page .woocommerce-MyAccount-content .woocommerce-Addresses .col-1,
.respawn-account-page .woocommerce-MyAccount-content .woocommerce-Addresses .col-2,
.respawn-account-page .woocommerce-MyAccount-content .col2-set.addresses .col-1,
.respawn-account-page .woocommerce-MyAccount-content .col2-set.addresses .col-2,
.respawn-account-page .woocommerce-MyAccount-content .woocommerce-Address {
  float: none !important;
  clear: none !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  align-self: stretch !important;
}

/* Billing left, Shipping right. Keeps them perfectly level. */
.respawn-account-page .woocommerce-MyAccount-content .addresses .col-1,
.respawn-account-page .woocommerce-MyAccount-content .woocommerce-Addresses .col-1,
.respawn-account-page .woocommerce-MyAccount-content .col2-set.addresses .col-1 {
  grid-column: 1 !important;
  grid-row: 1 !important;
}

.respawn-account-page .woocommerce-MyAccount-content .addresses .col-2,
.respawn-account-page .woocommerce-MyAccount-content .woocommerce-Addresses .col-2,
.respawn-account-page .woocommerce-MyAccount-content .col2-set.addresses .col-2 {
  grid-column: 2 !important;
  grid-row: 1 !important;
}

/* Card shape */
.respawn-account-page .woocommerce-MyAccount-content .woocommerce-Address {
  min-height: 210px !important;
  height: 100% !important;
  padding: 28px !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  border-radius: 22px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.01)),
    rgba(18,18,24,0.92) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.03),
    0 18px 50px rgba(0,0,0,0.18) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
}

/* Make title row sane */
.respawn-account-page .woocommerce-MyAccount-content .woocommerce-Address-title {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 18px !important;
  margin: 0 0 22px !important;
}

.respawn-account-page .woocommerce-MyAccount-content .woocommerce-Address-title h3 {
  margin: 0 !important;
  max-width: 68% !important;
  color: #fff !important;
  font-size: clamp(28px, 2.05vw, 38px) !important;
  line-height: .95 !important;
  letter-spacing: -.06em !important;
  font-weight: 700 !important;
}

.respawn-account-page .woocommerce-MyAccount-content .woocommerce-Address-title a,
.respawn-account-page .woocommerce-MyAccount-content .woocommerce-Address a.edit {
  flex: 0 0 auto !important;
  min-height: 40px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 15px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(167,139,250,.26) !important;
  background: rgba(139,92,246,.08) !important;
  color: #b995ff !important;
  font-size: 12px !important;
  font-weight: 850 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.respawn-account-page .woocommerce-MyAccount-content .woocommerce-Address address {
  margin: 0 !important;
  color: rgba(247,247,248,.62) !important;
  font-size: 15px !important;
  line-height: 1.75 !important;
  font-style: normal !important;
}

/* Mobile stacks cleanly */
@media (max-width: 900px) {
  .respawn-account-page .woocommerce-MyAccount-content .addresses,
  .respawn-account-page .woocommerce-MyAccount-content .woocommerce-Addresses,
  .respawn-account-page .woocommerce-MyAccount-content .col2-set.addresses {
    grid-template-columns: 1fr !important;
    grid-auto-flow: row !important;
  }

  .respawn-account-page .woocommerce-MyAccount-content .addresses .col-1,
  .respawn-account-page .woocommerce-MyAccount-content .addresses .col-2,
  .respawn-account-page .woocommerce-MyAccount-content .woocommerce-Addresses .col-1,
  .respawn-account-page .woocommerce-MyAccount-content .woocommerce-Addresses .col-2,
  .respawn-account-page .woocommerce-MyAccount-content .col2-set.addresses .col-1,
  .respawn-account-page .woocommerce-MyAccount-content .col2-set.addresses .col-2 {
    grid-column: 1 !important;
    grid-row: auto !important;
  }

  .respawn-account-page .woocommerce-MyAccount-content .woocommerce-Address {
    min-height: auto !important;
  }

  .respawn-account-page .woocommerce-MyAccount-content .woocommerce-Address-title {
    flex-direction: column !important;
    align-items: flex-start !important;
  }

  .respawn-account-page .woocommerce-MyAccount-content .woocommerce-Address-title h3 {
    max-width: 100% !important;
  }
}

/* =========================================
   Respawn Account - Dashboard padded portal
   Turns the empty default dashboard into a customer hub.
========================================= */

.respawn-account-dashboard {
  display: grid;
  gap: 22px;
}

.respawn-account-welcome {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  align-items: end;
  padding: clamp(26px, 3vw, 40px);
  border: 1px solid rgba(255,255,255,.085);
  border-radius: 24px;
  background:
    radial-gradient(circle at 12% 0%, rgba(139,92,246,.13), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.012)),
    rgba(18,18,24,.92);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.035),
    0 22px 70px rgba(0,0,0,.22);
}

.respawn-account-welcome::after {
  content: "";
  position: absolute;
  right: -80px;
  top: -90px;
  width: 240px;
  height: 240px;
  border-radius: 999px;
  border: 1px solid rgba(183,156,255,.16);
  background: radial-gradient(circle, rgba(139,92,246,.12), transparent 62%);
  pointer-events: none;
}

.respawn-account-welcome-kicker,
.respawn-account-mini-kicker {
  display: block;
  color: var(--purple-light);
  text-transform: uppercase;
  letter-spacing: .22em;
  font-size: 10px;
  font-weight: 950;
  margin-bottom: 12px;
}

.respawn-account-welcome h2 {
  max-width: 720px;
  margin: 0;
  color: #fff;
  font-size: clamp(34px, 3.4vw, 56px);
  line-height: .94;
  letter-spacing: -.08em;
  font-weight: 650;
}

.respawn-account-welcome p {
  max-width: 680px !important;
  margin: 16px 0 0 !important;
  color: rgba(247,247,248,.66) !important;
  font-size: 15px !important;
  line-height: 1.75 !important;
}

.respawn-account-welcome-actions {
  position: relative;
  z-index: 2;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.respawn-account-dashboard .respawn-account-btn {
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.035);
  color: #fff !important;
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-decoration: none !important;
  white-space: nowrap;
  transition: border-color .18s ease, background .18s ease, transform .18s ease;
}

.respawn-account-dashboard .respawn-account-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(183,156,255,.34);
  background: rgba(255,255,255,.055);
}

.respawn-account-dashboard .respawn-account-btn-primary {
  border-color: transparent;
  background: var(--purple);
  box-shadow: 0 16px 38px rgba(139,92,246,.20);
}

.respawn-account-dashboard .respawn-account-btn-primary:hover {
  background: #7c3aed;
}

.respawn-account-overview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.respawn-account-overview-card {
  position: relative;
  min-height: 210px;
  display: flex;
  flex-direction: column;
  padding: 24px;
  border: 1px solid rgba(255,255,255,.085);
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.026), rgba(255,255,255,.010)),
    rgba(18,18,24,.92);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
}

.respawn-account-overview-card::before {
  content: "";
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(183,156,255,.22);
  background: rgba(139,92,246,.075);
  margin-bottom: 22px;
}

.respawn-account-overview-card::after {
  position: absolute;
  left: 41px;
  top: 37px;
  color: var(--purple-light);
  font-size: 18px;
  line-height: 1;
}

.respawn-account-overview-card-orders::after {
  content: "▱";
}

.respawn-account-overview-card-addresses::after {
  content: "⌂";
}

.respawn-account-overview-card-support::after {
  content: "?";
  font-weight: 950;
}

.respawn-account-overview-card h3 {
  margin: 0;
  color: #fff;
  font-size: clamp(24px, 2vw, 32px);
  line-height: .96;
  letter-spacing: -.06em;
  font-weight: 650;
}

.respawn-account-overview-card p {
  margin: 12px 0 22px !important;
  color: rgba(247,247,248,.60) !important;
  font-size: 14px !important;
  line-height: 1.65 !important;
}

.respawn-account-overview-card a {
  margin-top: auto;
  color: var(--purple-light) !important;
  font-size: 13px;
  font-weight: 900;
  text-decoration: none !important;
}

.respawn-account-overview-card a:hover {
  color: #fff !important;
}

.respawn-account-process {
  padding: clamp(24px, 2.6vw, 34px);
  border: 1px solid rgba(255,255,255,.085);
  border-radius: 24px;
  background:
    radial-gradient(circle at 88% 0%, rgba(139,92,246,.075), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,.026), rgba(255,255,255,.010)),
    rgba(18,18,24,.92);
}

.respawn-account-process-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  align-items: end;
  margin-bottom: 26px;
}

.respawn-account-process h3 {
  margin: 0;
  color: #fff;
  font-size: clamp(28px, 2.6vw, 44px);
  line-height: .95;
  letter-spacing: -.07em;
  font-weight: 650;
}

.respawn-account-process-head p {
  max-width: 470px !important;
  margin: 0 !important;
  color: rgba(247,247,248,.60) !important;
  font-size: 14px !important;
  line-height: 1.65 !important;
}

.respawn-account-steps {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 1px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.075);
  border-radius: 18px;
  background: rgba(255,255,255,.075);
}

.respawn-account-step {
  min-height: 128px;
  padding: 18px;
  background: rgba(13,13,16,.60);
}

.respawn-account-step span {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  border: 1px solid rgba(183,156,255,.20);
  background: rgba(139,92,246,.07);
  color: var(--purple-light);
  font-size: 11px;
  font-weight: 950;
  margin-bottom: 18px;
}

.respawn-account-step strong {
  display: block;
  color: #fff;
  font-size: 15px;
  line-height: 1.25;
  letter-spacing: -.02em;
}

.respawn-account-step p {
  margin: 7px 0 0 !important;
  color: rgba(247,247,248,.52) !important;
  font-size: 12px !important;
  line-height: 1.5 !important;
}

.respawn-account-shop-strip {
  display: grid;
  grid-template-columns: .9fr repeat(3, 1fr);
  gap: 12px;
  align-items: stretch;
}

.respawn-account-shop-copy {
  padding: 22px;
  border: 1px solid rgba(255,255,255,.085);
  border-radius: 20px;
  background: rgba(255,255,255,.018);
}

.respawn-account-shop-copy h3 {
  margin: 0;
  color: #fff;
  font-size: 26px;
  line-height: .98;
  letter-spacing: -.055em;
  font-weight: 650;
}

.respawn-account-shop-copy p {
  margin: 10px 0 0 !important;
  color: rgba(247,247,248,.56) !important;
  font-size: 13px !important;
  line-height: 1.6 !important;
}

.respawn-account-shop-link {
  min-height: 136px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 22px;
  border: 1px solid rgba(255,255,255,.085);
  border-radius: 20px;
  background:
    radial-gradient(circle at 80% 0%, rgba(139,92,246,.10), transparent 38%),
    rgba(255,255,255,.018);
  color: #fff !important;
  text-decoration: none !important;
  transition: border-color .18s ease, background .18s ease, transform .18s ease;
}

.respawn-account-shop-link:hover {
  transform: translateY(-2px);
  border-color: rgba(183,156,255,.30);
  background:
    radial-gradient(circle at 80% 0%, rgba(139,92,246,.16), transparent 38%),
    rgba(255,255,255,.030);
}

.respawn-account-shop-link span {
  color: var(--purple-light);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: 10px;
  font-weight: 950;
  margin-bottom: 10px;
}

.respawn-account-shop-link strong {
  color: #fff;
  font-size: 20px;
  line-height: 1.05;
  letter-spacing: -.045em;
}

@media (max-width: 1050px) {
  .respawn-account-welcome,
  .respawn-account-process-head,
  .respawn-account-shop-strip {
    grid-template-columns: 1fr;
  }

  .respawn-account-welcome-actions {
    justify-content: flex-start;
  }

  .respawn-account-overview-grid {
    grid-template-columns: 1fr;
  }

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

  .respawn-account-step {
    min-height: auto;
  }
}

@media (max-width: 640px) {
  .respawn-account-welcome,
  .respawn-account-process,
  .respawn-account-overview-card,
  .respawn-account-shop-copy,
  .respawn-account-shop-link {
    border-radius: 18px;
    padding: 20px;
  }

  .respawn-account-welcome-actions {
    flex-direction: column;
  }

  .respawn-account-dashboard .respawn-account-btn {
    width: 100%;
  }
}

/* =========================================
   Respawn Account - Final premium dashboard refinement
   Final polish pass for My Account dashboard only.
========================================= */

.respawn-account-page .respawn-page-content-section {
  padding: 42px 0 104px !important;
}

/* Wider customer portal */
.respawn-account-page .respawn-page-shell {
  width: min(1420px, calc(100% - 64px)) !important;
}

/* Account nav: premium segmented underline */
.respawn-account-page .woocommerce-MyAccount-navigation {
  width: 100% !important;
  float: none !important;
  margin: 0 0 28px !important;
  padding: 0 !important;
  border-bottom: 1px solid rgba(255,255,255,.09) !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation ul {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 8px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation a {
  position: relative !important;
  min-height: 54px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 20px !important;
  border: 0 !important;
  border-radius: 16px 16px 0 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: rgba(247,247,248,.56) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  letter-spacing: -.01em !important;
  text-decoration: none !important;
  transition: color .18s ease, background .18s ease !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation a::after {
  content: "" !important;
  position: absolute !important;
  left: 20px !important;
  right: 20px !important;
  bottom: -1px !important;
  height: 2px !important;
  border-radius: 999px !important;
  background: linear-gradient(90deg, var(--purple), var(--purple-light)) !important;
  transform: scaleX(0) !important;
  transform-origin: center !important;
  transition: transform .18s ease !important;
  box-shadow: 0 0 18px rgba(183,156,255,.32) !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation a:hover {
  color: #fff !important;
  background: rgba(255,255,255,.025) !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation .is-active a {
  color: #fff !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(139,92,246,.18), transparent 60%),
    rgba(255,255,255,.025) !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation .is-active a::after,
.respawn-account-page .woocommerce-MyAccount-navigation a:hover::after {
  transform: scaleX(1) !important;
}

/* Portal panel: wider and calmer */
.respawn-account-page .woocommerce-MyAccount-content {
  width: 100% !important;
  float: none !important;
  padding: clamp(24px, 2vw, 34px) !important;
  border: 1px solid rgba(255,255,255,.085) !important;
  border-radius: 28px !important;
  background:
    radial-gradient(circle at 14% 0%, rgba(139,92,246,.055), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.028), rgba(255,255,255,.010)),
    var(--surface) !important;
  box-shadow:
    0 32px 90px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.03) !important;
}

/* Dashboard wrapper */
.respawn-account-dashboard {
  display: grid !important;
  gap: 24px !important;
}

/* Welcome card */
.respawn-account-welcome {
  position: relative !important;
  overflow: hidden !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 30px !important;
  align-items: end !important;
  min-height: 270px !important;
  padding: clamp(34px, 3.4vw, 56px) !important;
  border: 1px solid rgba(255,255,255,.085) !important;
  border-radius: 26px !important;
  background:
    radial-gradient(circle at 12% 0%, rgba(139,92,246,.16), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.012) 48%, rgba(139,92,246,.045)),
    rgba(18,18,24,.96) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.04),
    0 24px 76px rgba(0,0,0,.24) !important;
}

.respawn-account-welcome::before {
  content: "" !important;
  position: absolute !important;
  right: 52px !important;
  top: 34px !important;
  width: 190px !important;
  height: 190px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(183,156,255,.16) !important;
  background:
    radial-gradient(circle, rgba(139,92,246,.14), transparent 62%) !important;
  pointer-events: none !important;
}

.respawn-account-welcome::after {
  content: "" !important;
  position: absolute !important;
  right: -78px !important;
  bottom: -100px !important;
  width: 300px !important;
  height: 300px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(183,156,255,.10) !important;
  background: radial-gradient(circle, rgba(139,92,246,.10), transparent 66%) !important;
  pointer-events: none !important;
}

.respawn-account-welcome > div {
  position: relative !important;
  z-index: 2 !important;
}

.respawn-account-welcome-kicker,
.respawn-account-mini-kicker {
  display: block !important;
  color: var(--purple-light) !important;
  text-transform: uppercase !important;
  letter-spacing: .23em !important;
  font-size: 10px !important;
  font-weight: 950 !important;
  margin-bottom: 14px !important;
}

.respawn-account-welcome h2 {
  max-width: 760px !important;
  margin: 0 !important;
  color: #fff !important;
  font-size: clamp(42px, 4.1vw, 72px) !important;
  line-height: .88 !important;
  letter-spacing: -.095em !important;
  font-weight: 650 !important;
}

.respawn-account-welcome p {
  max-width: 720px !important;
  margin: 20px 0 0 !important;
  color: rgba(247,247,248,.66) !important;
  font-size: 16px !important;
  line-height: 1.75 !important;
}

.respawn-account-welcome-actions {
  position: relative !important;
  z-index: 3 !important;
  display: flex !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
}

/* Buttons */
.respawn-account-dashboard .respawn-account-btn {
  min-height: 50px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 20px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025)) !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  transition: border-color .18s ease, background .18s ease, transform .18s ease !important;
}

.respawn-account-dashboard .respawn-account-btn:hover {
  transform: translateY(-1px) !important;
  border-color: rgba(183,156,255,.34) !important;
  background: rgba(255,255,255,.06) !important;
}

.respawn-account-dashboard .respawn-account-btn-primary {
  border-color: transparent !important;
  background: linear-gradient(135deg, #a978ff, var(--purple)) !important;
  box-shadow: 0 16px 40px rgba(139,92,246,.23) !important;
}

.respawn-account-dashboard .respawn-account-btn-primary:hover {
  background: linear-gradient(135deg, #b78cff, #7c3aed) !important;
}

/* Three overview cards */
.respawn-account-overview-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

.respawn-account-overview-card {
  position: relative !important;
  min-height: 260px !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 28px !important;
  border: 1px solid rgba(255,255,255,.085) !important;
  border-radius: 24px !important;
  background:
    radial-gradient(circle at 82% 0%, rgba(139,92,246,.075), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,.028), rgba(255,255,255,.010)),
    rgba(18,18,24,.94) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.03),
    0 18px 54px rgba(0,0,0,.18) !important;
  transition: transform .2s ease, border-color .2s ease, background .2s ease !important;
}

.respawn-account-overview-card:hover {
  transform: translateY(-3px) !important;
  border-color: rgba(183,156,255,.28) !important;
  background:
    radial-gradient(circle at 82% 0%, rgba(139,92,246,.12), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,.036), rgba(255,255,255,.012)),
    rgba(18,18,24,.96) !important;
}

.respawn-account-overview-card::before {
  content: "" !important;
  width: 54px !important;
  height: 54px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(183,156,255,.24) !important;
  background: rgba(139,92,246,.08) !important;
  margin-bottom: 30px !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.035) !important;
}

.respawn-account-overview-card::after {
  position: absolute !important;
  left: 47px !important;
  top: 43px !important;
  color: var(--purple-light) !important;
  font-size: 21px !important;
  line-height: 1 !important;
}

.respawn-account-overview-card h3 {
  margin: 0 !important;
  color: #fff !important;
  font-size: clamp(27px, 2.2vw, 38px) !important;
  line-height: .92 !important;
  letter-spacing: -.072em !important;
  font-weight: 650 !important;
}

.respawn-account-overview-card p {
  margin: 14px 0 24px !important;
  color: rgba(247,247,248,.60) !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
}

.respawn-account-overview-card a {
  margin-top: auto !important;
  display: inline-flex !important;
  align-items: center !important;
  width: max-content !important;
  color: var(--purple-light) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  text-decoration: none !important;
}

.respawn-account-overview-card a::after {
  content: "→" !important;
  margin-left: 8px !important;
  transition: transform .18s ease !important;
}

.respawn-account-overview-card a:hover {
  color: #fff !important;
}

.respawn-account-overview-card a:hover::after {
  transform: translateX(3px) !important;
}

/* Process */
.respawn-account-process {
  padding: clamp(30px, 3vw, 44px) !important;
  border: 1px solid rgba(255,255,255,.085) !important;
  border-radius: 26px !important;
  background:
    radial-gradient(circle at 88% 0%, rgba(139,92,246,.085), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,.028), rgba(255,255,255,.010)),
    rgba(18,18,24,.94) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03) !important;
}

.respawn-account-process-head {
  display: grid !important;
  grid-template-columns: minmax(0, .9fr) minmax(360px, .72fr) !important;
  gap: 42px !important;
  align-items: end !important;
  margin-bottom: 34px !important;
}

.respawn-account-process h3 {
  max-width: 560px !important;
  margin: 0 !important;
  color: #fff !important;
  font-size: clamp(36px, 3.2vw, 58px) !important;
  line-height: .88 !important;
  letter-spacing: -.09em !important;
  font-weight: 650 !important;
}

.respawn-account-process-head p {
  max-width: 520px !important;
  margin: 0 !important;
  color: rgba(247,247,248,.61) !important;
  font-size: 15px !important;
  line-height: 1.75 !important;
}

.respawn-account-steps {
  position: relative !important;
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 12px !important;
  overflow: visible !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
}

.respawn-account-step {
  position: relative !important;
  min-height: 165px !important;
  padding: 22px !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 20px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.028), rgba(255,255,255,.010)),
    rgba(13,13,16,.44) !important;
}

.respawn-account-step::after {
  content: "" !important;
  position: absolute !important;
  top: 39px !important;
  left: calc(100% - 8px) !important;
  width: 28px !important;
  height: 1px !important;
  background: linear-gradient(90deg, rgba(183,156,255,.26), transparent) !important;
  pointer-events: none !important;
}

.respawn-account-step:last-child::after {
  content: none !important;
}

.respawn-account-step span {
  width: 36px !important;
  height: 36px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 999px !important;
  border: 1px solid rgba(183,156,255,.22) !important;
  background: rgba(139,92,246,.08) !important;
  color: var(--purple-light) !important;
  font-size: 11px !important;
  font-weight: 950 !important;
  margin-bottom: 22px !important;
}

.respawn-account-step strong {
  display: block !important;
  color: #fff !important;
  font-size: 16px !important;
  line-height: 1.25 !important;
  letter-spacing: -.025em !important;
}

.respawn-account-step p {
  margin: 8px 0 0 !important;
  color: rgba(247,247,248,.52) !important;
  font-size: 12px !important;
  line-height: 1.55 !important;
}

/* Bottom shop strip: more intentional */
.respawn-account-shop-strip {
  display: grid !important;
  grid-template-columns: minmax(240px, .85fr) repeat(3, minmax(0, 1fr)) !important;
  gap: 16px !important;
  align-items: stretch !important;
}

.respawn-account-shop-copy,
.respawn-account-shop-link {
  border: 1px solid rgba(255,255,255,.085) !important;
  border-radius: 24px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.026), rgba(255,255,255,.010)),
    rgba(18,18,24,.94) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03) !important;
}

.respawn-account-shop-copy {
  min-height: 190px !important;
  padding: 28px !important;
}

.respawn-account-shop-copy h3 {
  margin: 0 !important;
  color: #fff !important;
  font-size: clamp(30px, 2.4vw, 42px) !important;
  line-height: .9 !important;
  letter-spacing: -.075em !important;
  font-weight: 650 !important;
}

.respawn-account-shop-copy p {
  margin: 14px 0 0 !important;
  color: rgba(247,247,248,.58) !important;
  font-size: 14px !important;
  line-height: 1.65 !important;
}

.respawn-account-shop-link {
  position: relative !important;
  overflow: hidden !important;
  min-height: 190px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  padding: 28px !important;
  color: #fff !important;
  text-decoration: none !important;
  transition: transform .2s ease, border-color .2s ease, background .2s ease !important;
}

.respawn-account-shop-link::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background:
    radial-gradient(circle at 80% 8%, rgba(139,92,246,.16), transparent 38%),
    linear-gradient(135deg, transparent 0 58%, rgba(139,92,246,.055)) !important;
  pointer-events: none !important;
}

.respawn-account-shop-link::after {
  content: "→" !important;
  position: absolute !important;
  right: 24px !important;
  top: 24px !important;
  width: 42px !important;
  height: 42px !important;
  display: grid !important;
  place-items: center !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 999px !important;
  color: rgba(255,255,255,.74) !important;
  background: rgba(255,255,255,.025) !important;
  transition: transform .2s ease, border-color .2s ease, color .2s ease !important;
}

.respawn-account-shop-link:hover {
  transform: translateY(-3px) !important;
  border-color: rgba(183,156,255,.30) !important;
  background:
    linear-gradient(180deg, rgba(139,92,246,.05), rgba(255,255,255,.012)),
    rgba(18,18,24,.98) !important;
}

.respawn-account-shop-link:hover::after {
  transform: translateX(3px) !important;
  border-color: rgba(183,156,255,.34) !important;
  color: #fff !important;
}

.respawn-account-shop-link span,
.respawn-account-shop-link strong,
.respawn-account-shop-link small {
  position: relative !important;
  z-index: 2 !important;
}

.respawn-account-shop-link span {
  color: var(--purple-light) !important;
  text-transform: uppercase !important;
  letter-spacing: .18em !important;
  font-size: 10px !important;
  font-weight: 950 !important;
  margin-bottom: 12px !important;
}

.respawn-account-shop-link strong {
  color: #fff !important;
  font-size: clamp(24px, 2vw, 34px) !important;
  line-height: .95 !important;
  letter-spacing: -.06em !important;
}

.respawn-account-shop-link small {
  display: block !important;
  max-width: 230px !important;
  margin-top: 10px !important;
  color: rgba(247,247,248,.55) !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
}

/* Keep address alignment fix strong */
.respawn-account-page .woocommerce-MyAccount-content .addresses,
.respawn-account-page .woocommerce-MyAccount-content .woocommerce-Addresses,
.respawn-account-page .woocommerce-MyAccount-content .col2-set.addresses {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 24px !important;
  align-items: stretch !important;
  margin: 26px 0 0 !important;
  padding: 0 !important;
  width: 100% !important;
}

.respawn-account-page .woocommerce-MyAccount-content .addresses .col-1,
.respawn-account-page .woocommerce-MyAccount-content .woocommerce-Addresses .col-1,
.respawn-account-page .woocommerce-MyAccount-content .col2-set.addresses .col-1 {
  grid-column: 1 !important;
  grid-row: 1 !important;
}

.respawn-account-page .woocommerce-MyAccount-content .addresses .col-2,
.respawn-account-page .woocommerce-MyAccount-content .woocommerce-Addresses .col-2,
.respawn-account-page .woocommerce-MyAccount-content .col2-set.addresses .col-2 {
  grid-column: 2 !important;
  grid-row: 1 !important;
}

@media (max-width: 1200px) {
  .respawn-account-page .respawn-page-shell {
    width: min(1180px, calc(100% - 44px)) !important;
  }

  .respawn-account-welcome,
  .respawn-account-process-head,
  .respawn-account-shop-strip {
    grid-template-columns: 1fr !important;
  }

  .respawn-account-welcome-actions {
    justify-content: flex-start !important;
  }

  .respawn-account-steps {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .respawn-account-step::after {
    content: none !important;
  }
}

@media (max-width: 900px) {
  .respawn-account-page .respawn-page-shell {
    width: min(100% - 32px, var(--max)) !important;
  }

  .respawn-account-overview-grid,
  .respawn-account-steps {
    grid-template-columns: 1fr !important;
  }

  .respawn-account-page .woocommerce-MyAccount-navigation ul {
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .respawn-account-page .woocommerce-MyAccount-navigation a {
    white-space: nowrap !important;
  }

  .respawn-account-page .woocommerce-MyAccount-content .addresses,
  .respawn-account-page .woocommerce-MyAccount-content .woocommerce-Addresses,
  .respawn-account-page .woocommerce-MyAccount-content .col2-set.addresses {
    grid-template-columns: 1fr !important;
  }

  .respawn-account-page .woocommerce-MyAccount-content .addresses .col-1,
  .respawn-account-page .woocommerce-MyAccount-content .addresses .col-2,
  .respawn-account-page .woocommerce-MyAccount-content .woocommerce-Addresses .col-1,
  .respawn-account-page .woocommerce-MyAccount-content .woocommerce-Addresses .col-2,
  .respawn-account-page .woocommerce-MyAccount-content .col2-set.addresses .col-1,
  .respawn-account-page .woocommerce-MyAccount-content .col2-set.addresses .col-2 {
    grid-column: 1 !important;
    grid-row: auto !important;
  }
}

@media (max-width: 640px) {
  .respawn-account-page .woocommerce-MyAccount-content {
    padding: 18px !important;
    border-radius: 20px !important;
  }

  .respawn-account-welcome,
  .respawn-account-process,
  .respawn-account-overview-card,
  .respawn-account-shop-copy,
  .respawn-account-shop-link {
    border-radius: 18px !important;
    padding: 20px !important;
  }

  .respawn-account-welcome {
    min-height: auto !important;
  }

  .respawn-account-welcome-actions {
    flex-direction: column !important;
  }

  .respawn-account-dashboard .respawn-account-btn {
    width: 100% !important;
  }
}

/* =========================================
   Respawn Navbar - Logged in/out account state
   Cleaner logged-in / logged-out account dropdowns
========================================= */

.rsp-clean-account-trigger.is-logged-in {
  border-color: rgba(183,156,255,.24) !important;
  background:
    radial-gradient(circle at 20% 0%, rgba(139,92,246,.18), transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.025)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05), 0 10px 26px rgba(0,0,0,.18) !important;
}

.rsp-clean-account-panel {
  overflow: hidden !important;
}

.rsp-clean-account-panel--logged-in {
  width: 360px !important;
  padding: 16px !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  background:
    radial-gradient(circle at top left, rgba(139,92,246,.14), transparent 36%),
    linear-gradient(180deg, rgba(24,24,30,.98), rgba(14,14,18,.98)) !important;
  box-shadow: 0 26px 60px rgba(0,0,0,.42) !important;
}

.rsp-clean-account-top {
  display: grid !important;
  grid-template-columns: 52px minmax(0,1fr) !important;
  gap: 12px !important;
  align-items: center !important;
  padding: 0 0 14px !important;
  margin: 0 0 12px !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
}

.rsp-clean-account-avatar {
  width: 52px !important;
  height: 52px !important;
  border-radius: 16px !important;
  display: grid !important;
  place-items: center !important;
  font-size: 18px !important;
  font-weight: 900 !important;
  color: #fff !important;
  background:
    radial-gradient(circle at 35% 28%, rgba(255,255,255,.22), transparent 34%),
    linear-gradient(135deg, rgba(147,100,255,.96), rgba(108,62,214,.9)) !important;
  box-shadow: 0 10px 26px rgba(111,76,214,.28) !important;
}

.rsp-clean-account-heading {
  min-width: 0 !important;
}

.rsp-clean-account-panel--logged-in > .rsp-clean-account-top .rsp-clean-account-heading p {
  margin: 0 0 3px !important;
  color: rgba(183,156,255,.92) !important;
  font-size: 10px !important;
  font-weight: 900 !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
}

.rsp-clean-account-panel--logged-in > .rsp-clean-account-top .rsp-clean-account-heading strong {
  display: block !important;
  margin: 0 !important;
  color: #fff !important;
  font-size: 18px !important;
  font-weight: 900 !important;
  line-height: 1.15 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.rsp-clean-account-heading span {
  display: block !important;
  margin-top: 4px !important;
  color: rgba(247,247,248,.62) !important;
  font-size: 11px !important;
  line-height: 1.45 !important;
}

.rsp-clean-account-links {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 8px !important;
}

.rsp-clean-account-link {
  display: grid !important;
  grid-template-columns: 36px minmax(0,1fr) 18px !important;
  gap: 12px !important;
  align-items: center !important;
  min-height: 62px !important;
  padding: 12px !important;
  border: 1px solid rgba(255,255,255,.06) !important;
  border-radius: 16px !important;
  background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.02)) !important;
  color: #fff !important;
  text-decoration: none !important;
  transition: transform .16s ease, border-color .16s ease, background .16s ease, box-shadow .16s ease !important;
}

.rsp-clean-account-link:hover {
  transform: translateY(-1px) !important;
  border-color: rgba(183,156,255,.18) !important;
  background:
    radial-gradient(circle at left top, rgba(139,92,246,.10), transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.028)) !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.18) !important;
}

.rsp-clean-account-link-icon {
  width: 36px !important;
  height: 36px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 12px !important;
  color: rgba(196,176,255,.94) !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  background: rgba(139,92,246,.12) !important;
  border: 1px solid rgba(183,156,255,.14) !important;
}

.rsp-clean-account-link-copy {
  display: block !important;
  min-width: 0 !important;
}

.rsp-clean-account-link-copy strong {
  display: block !important;
  margin: 0 !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1.15 !important;
  letter-spacing: -.015em !important;
}

.rsp-clean-account-link-copy small {
  display: block !important;
  margin-top: 4px !important;
  color: rgba(247,247,248,.58) !important;
  font-size: 11px !important;
  line-height: 1.35 !important;
  font-weight: 700 !important;
}

.rsp-clean-account-link-arrow {
  color: rgba(183,156,255,.78) !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  transition: transform .16s ease, color .16s ease !important;
}

.rsp-clean-account-link:hover .rsp-clean-account-link-arrow {
  transform: translateX(2px) !important;
  color: #fff !important;
}

.rsp-clean-account-link--logout {
  margin-top: 4px !important;
  border-color: rgba(255,120,120,.08) !important;
}

.rsp-clean-account-link--logout .rsp-clean-account-link-icon {
  color: rgba(255,185,185,.95) !important;
  background: rgba(255,120,120,.08) !important;
  border-color: rgba(255,120,120,.16) !important;
}

.rsp-clean-account-link--logout .rsp-clean-account-link-copy strong,
.rsp-clean-account-link--logout .rsp-clean-account-link-arrow {
  color: rgba(255,185,185,.92) !important;
}

.rsp-clean-account-link--logout:hover {
  border-color: rgba(255,120,120,.20) !important;
  background: rgba(255,120,120,.05) !important;
}

.rsp-clean-account-panel--logged-out {
  width: 300px !important;
}

.rsp-clean-auth-buttons {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 8px !important;
}

@media (max-width: 1180px) {
  .rsp-clean-account-panel {
    position: absolute !important;
    right: 0 !important;
    left: auto !important;
    top: calc(100% + 10px) !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transform: translateY(4px) !important;
  }

  .rsp-clean-account.is-dropdown-open > .rsp-clean-account-panel,
  .rsp-clean-account:hover > .rsp-clean-account-panel,
  .rsp-clean-account:focus-within > .rsp-clean-account-panel {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: translateY(0) !important;
    display: block !important;
  }
}

@media (max-width: 680px) {
  .rsp-clean-account-panel,
  .rsp-clean-account-panel--logged-in {
    left: 0 !important;
    right: auto !important;
    width: min(360px, calc(100vw - 34px)) !important;
  }

  .rsp-clean-account-trigger span {
    max-width: 110px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .rsp-clean-auth-buttons {
    grid-template-columns: 1fr !important;
  }

  .rsp-clean-account-link {
    grid-template-columns: 34px minmax(0,1fr) 16px !important;
    min-height: 58px !important;
  }
}

/* =========================================================
   Respawn Account v3
   Rebuilds My Account to match the approved cleaner dashboard
   direction while using only real account/order data.
========================================================= */

.respawn-account-page .respawn-page-hero {
  padding: 54px 0 28px !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(139,92,246,.06), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,.01), transparent 100%),
    var(--bg) !important;
}

.respawn-account-page .respawn-page-shell {
  width: min(1320px, calc(100% - 64px)) !important;
}

.respawn-account-page .respawn-page-content-section {
  padding: 28px 0 88px !important;
}

.respawn-account-page .respawn-page-content-card,
.respawn-account-page .woocommerce-MyAccount-content {
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.respawn-account-page .woocommerce-MyAccount-content > p {
  display: none !important;
}

.respawn-account-page .respawn-account-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(380px, 690px);
  gap: 34px;
  align-items: end;
}

.respawn-account-page .respawn-page-hero h1 {
  font-size: clamp(56px, 5.6vw, 86px) !important;
  line-height: .9 !important;
  letter-spacing: -.095em !important;
  margin: 0 0 18px !important;
}

.respawn-account-page .respawn-page-subtitle {
  max-width: 560px !important;
  margin: 0 !important;
  color: rgba(245,247,251,.66) !important;
  font-size: 15px !important;
  line-height: 1.68 !important;
}

.respawn-account-hero-summary {
  min-height: 164px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 180px;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015)), rgba(23,25,34,.92);
  overflow: hidden;
}

.respawn-account-hero-summary-main {
  padding: 28px 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.respawn-account-hero-summary-label {
  color: rgba(245,247,251,.72);
  font-size: 16px;
}

.respawn-account-hero-summary-main strong {
  color: #fff;
  font-size: 54px;
  line-height: .9;
  letter-spacing: -.07em;
  font-weight: 700;
}

.respawn-account-hero-summary-badge {
  display: inline-flex;
  width: fit-content;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(139,92,246,.14);
  color: #cfb6ff;
  font-size: 12px;
  font-weight: 800;
}

.respawn-account-hero-summary-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  margin-top: 10px;
  color: rgba(245,247,251,.66);
  font-size: 15px;
}

.respawn-account-hero-summary-meta a {
  color: #c7a9ff;
  text-decoration: none;
}

.respawn-account-hero-summary-side {
  border-left: 1px solid rgba(255,255,255,.08);
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 10px;
  text-align: center;
}

.respawn-account-hero-summary-icon {
  width: 62px;
  height: 62px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(139,92,246,.3);
  background: rgba(139,92,246,.09);
  color: #c8adff;
  font-size: 24px;
}

.respawn-account-hero-summary-side span {
  color: rgba(245,247,251,.62);
  font-size: 14px;
}

.respawn-account-hero-summary-side strong {
  color: #fff;
  font-size: 24px;
  line-height: 1.1;
  letter-spacing: -.04em;
}

.respawn-account-page .woocommerce-MyAccount-navigation {
  margin: 0 0 22px !important;
  border-bottom: 1px solid rgba(255,255,255,.09) !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation ul {
  gap: 0 !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation a {
  min-height: 46px !important;
  padding: 0 16px !important;
  color: rgba(245,247,251,.7) !important;
  font-size: 13px !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation .is-active a,
.respawn-account-page .woocommerce-MyAccount-navigation a:hover {
  color: #fff !important;
}

.respawn-account-page .rp-account-dashboard-v2 {
  display: grid;
  gap: 16px;
}

.respawn-account-page .rp-account-kicker {
  display: inline-block;
  margin-bottom: 8px;
  color: #b78bff;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .22em;
  text-transform: uppercase;
}

.respawn-account-page .rp-account-stat-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.respawn-account-page .rp-account-stat-card,
.respawn-account-page .rp-account-panel {
  border: 1px solid rgba(255,255,255,.085);
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255,255,255,.028), rgba(255,255,255,.012)), rgba(23,25,34,.94);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.025);
}

.respawn-account-page .rp-account-stat-card {
  min-height: 126px;
  padding: 22px 24px;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) auto;
  grid-template-areas:
    "icon copy value"
    "icon copy value"
    "link link link";
  gap: 8px 16px;
  align-items: start;
}

.respawn-account-page .rp-account-stat-icon {
  grid-area: icon;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(139,92,246,.26);
  background: rgba(139,92,246,.08);
  color: #bc9aff;
  font-size: 10px;
}

.respawn-account-page .rp-account-stat-card h3,
.respawn-account-page .rp-account-panel h2 {
  margin: 0;
  color: #fff;
  font-size: 18px;
  line-height: 1.15;
  letter-spacing: -.04em;
  font-weight: 700;
}

.respawn-account-page .rp-account-stat-card p,
.respawn-account-page .rp-account-panel p {
  margin: 6px 0 0;
  color: rgba(245,247,251,.62);
  font-size: 14px;
  line-height: 1.5;
}

.respawn-account-page .rp-account-stat-card > div:nth-child(2) {
  grid-area: copy;
}

.respawn-account-page .rp-account-stat-card > strong {
  grid-area: value;
  align-self: center;
  color: #fff;
  font-size: 34px;
  line-height: 1;
  letter-spacing: -.06em;
}

.respawn-account-page .rp-account-stat-card > a,
.respawn-account-page .rp-account-inline-link {
  grid-area: link;
  width: fit-content;
  color: #b78bff !important;
  font-size: 13px;
  font-weight: 800;
  text-decoration: none !important;
}

.respawn-account-page .rp-account-inline-link:hover,
.respawn-account-page .rp-account-stat-card > a:hover {
  color: #fff !important;
}

.respawn-account-page .rp-account-main-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(280px, .8fr) minmax(290px, .95fr);
  gap: 14px;
  align-items: start;
}

.respawn-account-page .rp-account-side-stack {
  display: grid;
  gap: 14px;
}

.respawn-account-page .rp-account-panel {
  padding: 20px;
}

.respawn-account-page .rp-account-panel-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 18px;
}

.respawn-account-page .rp-account-panel-meta {
  color: rgba(245,247,251,.54);
  font-size: 12px;
  font-weight: 700;
}

.respawn-account-page .rp-account-order-list {
  display: grid;
  gap: 12px;
}

.respawn-account-page .rp-account-order-row {
  display: grid;
  grid-template-columns: 62px minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 14px;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 16px;
  background: rgba(255,255,255,.015);
}

.respawn-account-page .rp-account-order-thumb {
  width: 62px;
  height: 62px;
  border-radius: 12px;
  overflow: hidden;
  background: rgba(255,255,255,.03);
}

.respawn-account-page .rp-account-order-thumb img,
.respawn-account-page .rp-account-recommend-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.respawn-account-page .rp-account-order-copy span {
  display: block;
  color: rgba(245,247,251,.52);
  font-size: 12px;
  margin-bottom: 4px;
}

.respawn-account-page .rp-account-order-copy strong,
.respawn-account-page .rp-account-build-name {
  display: block;
  color: #fff;
  font-size: 18px;
  line-height: 1.25;
  letter-spacing: -.03em;
}

.respawn-account-page .rp-account-order-copy small {
  display: block;
  margin-top: 4px;
  color: rgba(245,247,251,.58);
  font-size: 13px;
}

.respawn-account-page .rp-account-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  font-size: 12px;
  font-weight: 800;
  color: rgba(245,247,251,.78);
}

.respawn-account-page .rp-account-status-completed {
  border-color: rgba(74, 222, 128, .24);
  background: rgba(74, 222, 128, .08);
  color: #8ce4a8;
}

.respawn-account-page .rp-account-status-processing,
.respawn-account-page .rp-account-status-on-hold,
.respawn-account-page .rp-account-status-pending {
  border-color: rgba(139,92,246,.24);
  background: rgba(139,92,246,.08);
  color: #cfb6ff;
}

.respawn-account-page .rp-account-row-button,
.respawn-account-page .rp-account-pill-button,
.respawn-account-page .rp-account-help-link {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.09);
  background: rgba(255,255,255,.02);
  color: #fff !important;
  font-size: 13px;
  font-weight: 800;
  text-decoration: none !important;
  white-space: nowrap;
}

.respawn-account-page .rp-account-row-button:hover,
.respawn-account-page .rp-account-pill-button:hover,
.respawn-account-page .rp-account-help-link:hover {
  border-color: rgba(255,255,255,.16);
  background: rgba(255,255,255,.04);
}

.respawn-account-page .rp-account-row-button-block {
  width: 100%;
  margin-top: 18px;
}

.respawn-account-page .rp-account-empty-state,
.respawn-account-page .rp-account-build-empty {
  min-height: 254px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 22px;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 18px;
  background: rgba(255,255,255,.015);
}

.respawn-account-page .rp-account-empty-state h3,
.respawn-account-page .rp-account-build-empty h3 {
  margin: 0 0 10px;
  color: #fff;
  font-size: clamp(32px, 2.2vw, 44px);
  line-height: .95;
  letter-spacing: -.07em;
}

.respawn-account-page .rp-account-empty-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.respawn-account-page .rp-account-pill-button-primary {
  border-color: rgba(139,92,246,.28);
  background: linear-gradient(90deg, #8b5cf6, #a855f7);
}

.respawn-account-page .rp-account-build-card {
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

.respawn-account-page .rp-account-timeline {
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 16px;
}

.respawn-account-page .rp-account-timeline-item {
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.respawn-account-page .rp-account-timeline-dot {
  width: 14px;
  height: 14px;
  margin-top: 4px;
  border-radius: 999px;
  border: 2px solid rgba(255,255,255,.22);
  background: transparent;
}

.respawn-account-page .rp-account-timeline-item.is-done .rp-account-timeline-dot,
.respawn-account-page .rp-account-timeline-item.is-current .rp-account-timeline-dot {
  border-color: #a970ff;
}

.respawn-account-page .rp-account-timeline-item.is-done .rp-account-timeline-dot {
  background: #a970ff;
}

.respawn-account-page .rp-account-timeline-item strong {
  display: block;
  color: #fff;
  font-size: 15px;
}

.respawn-account-page .rp-account-timeline-item small {
  display: block;
  margin-top: 3px;
  color: rgba(245,247,251,.56);
  font-size: 13px;
}

.respawn-account-page .rp-account-action-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.respawn-account-page .rp-account-action-card {
  min-height: 86px;
  padding: 16px;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 14px;
  background: rgba(255,255,255,.015);
  text-decoration: none;
}

.respawn-account-page .rp-account-action-card strong {
  display: block;
  color: #fff;
  font-size: 15px;
  line-height: 1.2;
}

.respawn-account-page .rp-account-action-card span {
  display: block;
  margin-top: 6px;
  color: rgba(245,247,251,.58);
  font-size: 13px;
  line-height: 1.45;
}

.respawn-account-page .rp-account-action-card:hover {
  border-color: rgba(255,255,255,.14);
  background: rgba(255,255,255,.03);
}

.respawn-account-page .rp-account-help-stack {
  display: grid;
  gap: 10px;
}

.respawn-account-page .rp-account-panel-recommendations {
  padding: 22px;
}

.respawn-account-page .rp-account-recommend-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.respawn-account-page .rp-account-recommend-card {
  min-height: 112px;
  display: grid;
  grid-template-columns: 74px minmax(0,1fr);
  gap: 14px;
  align-items: center;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 18px;
  background: rgba(255,255,255,.014);
  text-decoration: none;
}

.respawn-account-page .rp-account-recommend-thumb {
  width: 74px;
  height: 74px;
  overflow: hidden;
  border-radius: 14px;
  background: rgba(255,255,255,.03);
}

.respawn-account-page .rp-account-recommend-copy strong {
  display: block;
  color: #fff;
  font-size: 24px;
  line-height: .98;
  letter-spacing: -.05em;
}

.respawn-account-page .rp-account-recommend-copy small {
  display: block;
  margin-top: 6px;
  color: rgba(245,247,251,.56);
  font-size: 14px;
  line-height: 1.4;
}

.respawn-account-page .rp-account-recommend-copy em {
  display: inline-block;
  margin-top: 10px;
  color: #b78bff;
  font-size: 13px;
  font-style: normal;
  font-weight: 800;
}

@media (max-width: 1180px) {
  .respawn-account-page .respawn-account-hero-grid {
    grid-template-columns: 1fr;
  }

  .respawn-account-page .rp-account-stat-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .respawn-account-page .rp-account-main-grid {
    grid-template-columns: 1fr 1fr;
  }

  .respawn-account-page .rp-account-panel-orders {
    grid-column: 1 / -1;
  }

  .respawn-account-page .rp-account-side-stack {
    grid-column: 2;
  }

  .respawn-account-page .rp-account-recommend-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 860px) {
  .respawn-account-page .respawn-page-shell {
    width: min(100% - 28px, 1320px) !important;
  }

  .respawn-account-page .respawn-page-hero {
    padding-top: 42px !important;
  }

  .respawn-account-hero-summary {
    grid-template-columns: 1fr;
  }

  .respawn-account-hero-summary-side {
    border-left: 0;
    border-top: 1px solid rgba(255,255,255,.08);
    padding: 20px;
  }

  .respawn-account-page .rp-account-stat-grid,
  .respawn-account-page .rp-account-main-grid,
  .respawn-account-page .rp-account-action-grid {
    grid-template-columns: 1fr;
  }

  .respawn-account-page .rp-account-side-stack,
  .respawn-account-page .rp-account-panel-orders {
    grid-column: auto;
  }

  .respawn-account-page .rp-account-order-row {
    grid-template-columns: 56px minmax(0,1fr);
  }

  .respawn-account-page .rp-account-order-meta,
  .respawn-account-page .rp-account-order-row > .rp-account-row-button {
    grid-column: 2;
  }
}

@media (max-width: 640px) {
  .respawn-account-page .woocommerce-MyAccount-navigation ul {
    overflow-x: auto !important;
    flex-wrap: nowrap !important;
  }

  .respawn-account-page .woocommerce-MyAccount-navigation a {
    padding: 0 14px !important;
  }

  .respawn-account-page .rp-account-stat-card {
    grid-template-columns: 38px minmax(0, 1fr);
    grid-template-areas:
      "icon copy"
      "icon value"
      "link link";
  }

  .respawn-account-page .rp-account-stat-card > strong {
    justify-self: start;
  }

  .respawn-account-page .rp-account-empty-state h3,
  .respawn-account-page .rp-account-build-empty h3 {
    font-size: 34px;
  }

  .respawn-account-page .rp-account-row-button,
  .respawn-account-page .rp-account-help-link,
  .respawn-account-page .rp-account-pill-button {
    width: 100%;
  }
}

/* =========================================================
   Respawn Account v4 final reset
   Proper account dashboard layout. No fake order/build content.
========================================================= */

.respawn-account-page {
  background: #171922 !important;
}

.respawn-account-page .respawn-page-shell {
  width: min(1680px, calc(100% - 96px)) !important;
  max-width: none !important;
}

.respawn-account-page .respawn-page-hero {
  padding: clamp(58px, 5vw, 94px) 0 34px !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(139,92,246,.055), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.008), transparent 100%),
    #171922 !important;
  border-bottom: 1px solid rgba(255,255,255,.07) !important;
}

.respawn-account-page .respawn-page-content-section {
  padding: 34px 0 92px !important;
  background: #171922 !important;
}

.respawn-account-page .respawn-page-content-card,
.respawn-account-page .woocommerce,
.respawn-account-page .woocommerce-MyAccount-content {
  width: 100% !important;
  max-width: none !important;
  min-height: 0 !important;
  float: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.respawn-account-page .woocommerce-MyAccount-content > p {
  display: none !important;
}

.respawn-account-page .respawn-account-hero-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(520px, 780px) !important;
  gap: clamp(42px, 6vw, 110px) !important;
  align-items: end !important;
}

.respawn-account-page .respawn-page-eyebrow {
  color: #a978ff !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  letter-spacing: .24em !important;
  text-transform: uppercase !important;
  margin: 0 0 14px !important;
}

.respawn-account-page .respawn-page-hero h1 {
  margin: 0 0 18px !important;
  color: #f5f7fb !important;
  font-size: clamp(62px, 5.2vw, 98px) !important;
  line-height: .88 !important;
  letter-spacing: -.1em !important;
  font-weight: 700 !important;
}

.respawn-account-page .respawn-page-subtitle {
  max-width: 620px !important;
  margin: 0 !important;
  color: rgba(245,247,251,.68) !important;
  font-size: 16px !important;
  line-height: 1.7 !important;
}

.respawn-account-hero-summary {
  min-height: 168px !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 190px !important;
  overflow: hidden !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 22px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.014)),
    #20232d !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.035) !important;
}

.respawn-account-hero-summary-main {
  min-width: 0 !important;
  padding: 28px 30px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  gap: 8px !important;
}

.respawn-account-hero-summary-label {
  color: rgba(245,247,251,.72) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
}

.respawn-account-hero-summary-main > strong {
  color: #fff !important;
  font-size: clamp(42px, 3vw, 56px) !important;
  line-height: .9 !important;
  letter-spacing: -.07em !important;
  font-weight: 800 !important;
}

.respawn-account-hero-summary-badge {
  width: fit-content !important;
  display: inline-flex !important;
  align-items: center !important;
  min-height: 26px !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  background: rgba(139,92,246,.13) !important;
  color: #c8adff !important;
  font-size: 11px !important;
  font-weight: 900 !important;
}

.respawn-account-hero-summary-meta {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 16px !important;
  margin-top: 8px !important;
  color: rgba(245,247,251,.62) !important;
  font-size: 14px !important;
  line-height: 1.4 !important;
}

.respawn-account-hero-summary-meta a {
  color: #c8adff !important;
  text-decoration: none !important;
  font-weight: 800 !important;
}

.respawn-account-hero-summary-side {
  padding: 24px !important;
  border-left: 1px solid rgba(255,255,255,.08) !important;
  display: grid !important;
  place-items: center !important;
  text-align: center !important;
  align-content: center !important;
  gap: 9px !important;
}

.respawn-account-hero-summary-icon {
  width: 60px !important;
  height: 60px !important;
  border-radius: 999px !important;
  display: grid !important;
  place-items: center !important;
  border: 1px solid rgba(139,92,246,.32) !important;
  background: rgba(139,92,246,.09) !important;
  color: #c8adff !important;
  font-size: 24px !important;
}

.respawn-account-hero-summary-side span {
  color: rgba(245,247,251,.58) !important;
  font-size: 13px !important;
}

.respawn-account-hero-summary-side strong {
  color: #fff !important;
  font-size: 19px !important;
  line-height: 1.1 !important;
  letter-spacing: -.04em !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation {
  width: 100% !important;
  float: none !important;
  margin: 0 0 26px !important;
  border-bottom: 1px solid rgba(255,255,255,.09) !important;
  background: transparent !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation ul {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation a {
  min-height: 46px !important;
  padding: 0 17px !important;
  border: 0 !important;
  background: transparent !important;
  color: rgba(245,247,251,.64) !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation .is-active a,
.respawn-account-page .woocommerce-MyAccount-navigation a:hover {
  color: #fff !important;
}

.respawn-account-page .woocommerce-MyAccount-navigation a::after {
  background: #8b5cf6 !important;
}

/* Dashboard base */
.respawn-account-page .rp-account-dashboard-v4,
.respawn-account-page .rp-account-dashboard-v4 * {
  box-sizing: border-box;
}

.respawn-account-page .rp-account-dashboard-v4 {
  display: grid !important;
  gap: 18px !important;
  color: #f5f7fb !important;
}

.respawn-account-page .rp-account-v4-kicker {
  display: inline-block !important;
  margin: 0 0 10px !important;
  color: #a978ff !important;
  font-size: 11px !important;
  font-weight: 950 !important;
  letter-spacing: .22em !important;
  text-transform: uppercase !important;
}

.respawn-account-page .rp-account-v4-stats {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

.respawn-account-page .rp-account-v4-stats article,
.respawn-account-page .rp-account-v4-panel,
.respawn-account-page .rp-account-v4-empty-shell,
.respawn-account-page .rp-account-v4-recommendations {
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 20px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.012)),
    #20232d !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.028) !important;
}

.respawn-account-page .rp-account-v4-stats article {
  min-height: 144px !important;
  padding: 22px !important;
  display: grid !important;
  grid-template-columns: 42px minmax(0, 1fr) auto !important;
  grid-template-areas:
    "icon copy number"
    "icon copy number"
    "link link link" !important;
  gap: 8px 16px !important;
  align-items: start !important;
}

.respawn-account-page .rp-account-v4-stats article > span {
  grid-area: icon !important;
  width: 38px !important;
  height: 38px !important;
  border-radius: 999px !important;
  display: grid !important;
  place-items: center !important;
  border: 1px solid rgba(139,92,246,.28) !important;
  background: rgba(139,92,246,.08) !important;
  color: #c8adff !important;
  font-size: 12px !important;
}

.respawn-account-page .rp-account-v4-stats article > div {
  grid-area: copy !important;
  min-width: 0 !important;
}

.respawn-account-page .rp-account-v4-stats strong,
.respawn-account-page .rp-account-v4-panel h2,
.respawn-account-page .rp-account-v4-empty-shell h2,
.respawn-account-page .rp-account-v4-recommendations h2 {
  margin: 0 !important;
  color: #fff !important;
  font-weight: 800 !important;
  letter-spacing: -.055em !important;
}

.respawn-account-page .rp-account-v4-stats article > div strong {
  display: block !important;
  font-size: 22px !important;
  line-height: 1.08 !important;
}

.respawn-account-page .rp-account-v4-stats small,
.respawn-account-page .rp-account-v4-panel p,
.respawn-account-page .rp-account-v4-empty-shell p {
  color: rgba(245,247,251,.62) !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
}

.respawn-account-page .rp-account-v4-stats small {
  display: block !important;
  margin-top: 7px !important;
}

.respawn-account-page .rp-account-v4-stats b {
  grid-area: number !important;
  align-self: center !important;
  color: #fff !important;
  font-size: 34px !important;
  line-height: 1 !important;
  letter-spacing: -.06em !important;
}

.respawn-account-page .rp-account-v4-stats article > a,
.respawn-account-page .rp-account-v4-panel a,
.respawn-account-page .rp-account-v4-recommendations a {
  text-decoration: none !important;
}

.respawn-account-page .rp-account-v4-stats article > a {
  grid-area: link !important;
  width: fit-content !important;
  color: #b995ff !important;
  font-size: 13px !important;
  font-weight: 850 !important;
}

.respawn-account-page .rp-account-v4-stats article > a:hover,
.respawn-account-page .rp-account-v4-panel a:hover,
.respawn-account-page .rp-account-v4-recommendations a:hover {
  color: #fff !important;
}

/* Fresh account no-order state */
.respawn-account-page .rp-account-v4-empty-shell {
  min-height: 360px !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1.25fr) minmax(320px, .75fr) !important;
  gap: 20px !important;
  padding: 22px !important;
}

.respawn-account-page .rp-account-v4-empty-main,
.respawn-account-page .rp-account-v4-empty-side {
  border: 1px solid rgba(255,255,255,.07) !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,.015) !important;
}

.respawn-account-page .rp-account-v4-empty-main {
  min-height: 316px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: flex-start !important;
  padding: clamp(28px, 3vw, 48px) !important;
}

.respawn-account-page .rp-account-v4-empty-main h2 {
  max-width: 720px !important;
  font-size: clamp(46px, 4vw, 76px) !important;
  line-height: .9 !important;
}

.respawn-account-page .rp-account-v4-empty-main p {
  max-width: 720px !important;
  margin: 18px 0 0 !important;
  font-size: 16px !important;
}

.respawn-account-page .rp-account-v4-empty-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
  margin-top: 28px !important;
}

.respawn-account-page .rp-account-v4-button,
.respawn-account-page .rp-account-v4-help-panel > a,
.respawn-account-page .rp-account-v4-order-row > a {
  min-height: 46px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 18px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255,255,255,.11) !important;
  background: rgba(255,255,255,.025) !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  text-decoration: none !important;
}

.respawn-account-page .rp-account-v4-button-primary {
  border-color: transparent !important;
  background: linear-gradient(90deg, #8b5cf6, #a855f7) !important;
}

.respawn-account-page .rp-account-v4-empty-side {
  padding: 28px !important;
  display: grid !important;
  align-content: center !important;
  gap: 18px !important;
}

.respawn-account-page .rp-account-v4-empty-side div {
  padding: 16px 0 0 !important;
  border-top: 1px solid rgba(255,255,255,.08) !important;
}

.respawn-account-page .rp-account-v4-empty-side strong {
  display: block !important;
  color: #fff !important;
  font-size: 20px !important;
  letter-spacing: -.04em !important;
}

.respawn-account-page .rp-account-v4-empty-side p {
  margin: 6px 0 0 !important;
}

.respawn-account-page .rp-account-v4-lower-grid,
.respawn-account-page .rp-account-v4-order-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1.45fr) minmax(340px, .85fr) !important;
  gap: 18px !important;
  align-items: start !important;
}

.respawn-account-page .rp-account-v4-panel {
  padding: 24px !important;
}

.respawn-account-page .rp-account-v4-panel h2,
.respawn-account-page .rp-account-v4-recommendations h2 {
  font-size: clamp(30px, 2.15vw, 44px) !important;
  line-height: .96 !important;
}

.respawn-account-page .rp-account-v4-panel-head {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 18px !important;
  margin-bottom: 18px !important;
}

.respawn-account-page .rp-account-v4-panel-head > a {
  color: #b995ff !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}

.respawn-account-page .rp-account-v4-actions-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
  margin-top: 18px !important;
}

.respawn-account-page .rp-account-v4-actions-grid a {
  min-height: 104px !important;
  padding: 18px !important;
  border: 1px solid rgba(255,255,255,.075) !important;
  border-radius: 16px !important;
  background: rgba(255,255,255,.015) !important;
  color: #fff !important;
}

.respawn-account-page .rp-account-v4-actions-grid a:hover {
  border-color: rgba(255,255,255,.14) !important;
  background: rgba(255,255,255,.03) !important;
}

.respawn-account-page .rp-account-v4-actions-grid strong {
  display: block !important;
  color: #fff !important;
  font-size: 17px !important;
  line-height: 1.15 !important;
  letter-spacing: -.035em !important;
}

.respawn-account-page .rp-account-v4-actions-grid small {
  display: block !important;
  margin-top: 7px !important;
}

.respawn-account-page .rp-account-v4-help-panel {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}

.respawn-account-page .rp-account-v4-help-panel p {
  margin: 0 0 8px !important;
}

.respawn-account-page .rp-account-v4-help-panel > a {
  justify-content: flex-start !important;
  width: 100% !important;
  border-radius: 14px !important;
}

/* Real order state */
.respawn-account-page .rp-account-v4-orders-panel {
  min-height: 360px !important;
}

.respawn-account-page .rp-account-v4-order-list {
  display: grid !important;
  gap: 12px !important;
}

.respawn-account-page .rp-account-v4-order-row {
  display: grid !important;
  grid-template-columns: 72px minmax(0, 1fr) auto auto !important;
  align-items: center !important;
  gap: 16px !important;
  padding: 14px !important;
  border: 1px solid rgba(255,255,255,.075) !important;
  border-radius: 16px !important;
  background: rgba(255,255,255,.015) !important;
}

.respawn-account-page .rp-account-v4-order-thumb {
  width: 72px !important;
  height: 72px !important;
  border-radius: 14px !important;
  overflow: hidden !important;
  background: rgba(255,255,255,.04) !important;
}

.respawn-account-page .rp-account-v4-order-thumb img,
.respawn-account-page .rp-account-v4-recommend-grid img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

.respawn-account-page .rp-account-v4-order-copy small,
.respawn-account-page .rp-account-v4-order-copy em {
  display: block !important;
  color: rgba(245,247,251,.56) !important;
  font-size: 12px !important;
  font-style: normal !important;
}

.respawn-account-page .rp-account-v4-order-copy strong {
  display: block !important;
  margin: 4px 0 !important;
  color: #fff !important;
  font-size: 18px !important;
  line-height: 1.22 !important;
  letter-spacing: -.035em !important;
}

.respawn-account-page .rp-account-v4-status {
  min-height: 30px !important;
  display: inline-flex !important;
  align-items: center !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255,255,255,.11) !important;
  color: rgba(245,247,251,.74) !important;
  font-size: 12px !important;
  font-weight: 850 !important;
}

.respawn-account-page .rp-account-v4-status-completed {
  border-color: rgba(74,222,128,.22) !important;
  background: rgba(74,222,128,.08) !important;
  color: #86efac !important;
}

.respawn-account-page .rp-account-v4-build-panel {
  min-height: 360px !important;
}

.respawn-account-page .rp-account-v4-build-name {
  display: block !important;
  margin: 14px 0 20px !important;
  color: #fff !important;
  font-size: 16px !important;
  line-height: 1.35 !important;
  text-transform: uppercase !important;
}

.respawn-account-page .rp-account-v4-timeline {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: grid !important;
  gap: 18px !important;
}

.respawn-account-page .rp-account-v4-timeline li {
  display: grid !important;
  grid-template-columns: 20px minmax(0, 1fr) !important;
  gap: 12px !important;
  align-items: start !important;
}

.respawn-account-page .rp-account-v4-timeline i {
  width: 14px !important;
  height: 14px !important;
  margin-top: 4px !important;
  border-radius: 999px !important;
  border: 2px solid rgba(255,255,255,.2) !important;
}

.respawn-account-page .rp-account-v4-timeline li.is-done i,
.respawn-account-page .rp-account-v4-timeline li.is-current i {
  border-color: #a978ff !important;
}

.respawn-account-page .rp-account-v4-timeline li.is-done i {
  background: #a978ff !important;
}

.respawn-account-page .rp-account-v4-timeline strong {
  display: block !important;
  color: #fff !important;
  font-size: 15px !important;
}

.respawn-account-page .rp-account-v4-timeline small {
  display: block !important;
  margin-top: 3px !important;
  color: rgba(245,247,251,.56) !important;
  font-size: 13px !important;
}

/* Recommendations */
.respawn-account-page .rp-account-v4-recommendations {
  min-height: 160px !important;
  padding: 24px !important;
  display: grid !important;
  grid-template-columns: minmax(260px, .38fr) minmax(0, 1fr) !important;
  gap: 22px !important;
  align-items: center !important;
}

.respawn-account-page .rp-account-v4-recommend-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

.respawn-account-page .rp-account-v4-recommend-grid a {
  min-height: 104px !important;
  display: grid !important;
  grid-template-columns: 74px minmax(0, 1fr) !important;
  align-items: center !important;
  gap: 14px !important;
  padding: 14px !important;
  border: 1px solid rgba(255,255,255,.075) !important;
  border-radius: 16px !important;
  background: rgba(255,255,255,.015) !important;
  color: #fff !important;
}

.respawn-account-page .rp-account-v4-recommend-grid a:hover {
  border-color: rgba(255,255,255,.14) !important;
  background: rgba(255,255,255,.03) !important;
}

.respawn-account-page .rp-account-v4-recommend-grid a > span {
  width: 74px !important;
  height: 74px !important;
  overflow: hidden !important;
  border-radius: 14px !important;
  background: rgba(255,255,255,.04) !important;
  grid-row: span 4 !important;
}

.respawn-account-page .rp-account-v4-recommend-grid strong {
  display: block !important;
  color: #fff !important;
  font-size: 22px !important;
  line-height: 1 !important;
  letter-spacing: -.045em !important;
}

.respawn-account-page .rp-account-v4-recommend-grid small {
  display: block !important;
  color: rgba(245,247,251,.56) !important;
  font-size: 13px !important;
  line-height: 1.35 !important;
}

.respawn-account-page .rp-account-v4-recommend-grid em {
  display: block !important;
  color: #b995ff !important;
  font-size: 13px !important;
  font-style: normal !important;
  font-weight: 900 !important;
}

@media (max-width: 1280px) {
  .respawn-account-page .respawn-account-hero-grid,
  .respawn-account-page .rp-account-v4-empty-shell,
  .respawn-account-page .rp-account-v4-lower-grid,
  .respawn-account-page .rp-account-v4-order-layout,
  .respawn-account-page .rp-account-v4-recommendations {
    grid-template-columns: 1fr !important;
  }

  .respawn-account-page .rp-account-v4-stats,
  .respawn-account-page .rp-account-v4-recommend-grid {
    grid-template-columns: repeat(2, minmax(0,1fr)) !important;
  }
}

@media (max-width: 780px) {
  .respawn-account-page .respawn-page-shell {
    width: min(100% - 28px, 1680px) !important;
  }

  .respawn-account-page .respawn-page-hero h1 {
    font-size: clamp(48px, 14vw, 66px) !important;
  }

  .respawn-account-hero-summary {
    grid-template-columns: 1fr !important;
  }

  .respawn-account-hero-summary-side {
    border-left: 0 !important;
    border-top: 1px solid rgba(255,255,255,.08) !important;
  }

  .respawn-account-page .rp-account-v4-stats,
  .respawn-account-page .rp-account-v4-recommend-grid,
  .respawn-account-page .rp-account-v4-actions-grid {
    grid-template-columns: 1fr !important;
  }

  .respawn-account-page .rp-account-v4-stats article {
    grid-template-columns: 40px minmax(0,1fr) !important;
    grid-template-areas:
      "icon copy"
      "icon number"
      "link link" !important;
  }

  .respawn-account-page .rp-account-v4-stats b {
    justify-self: start !important;
  }

  .respawn-account-page .rp-account-v4-order-row {
    grid-template-columns: 64px minmax(0,1fr) !important;
  }

  .respawn-account-page .rp-account-v4-status,
  .respawn-account-page .rp-account-v4-order-row > a {
    grid-column: 2 !important;
    justify-self: start !important;
  }
}

/* =========================================================
   Respawn My Account - Simple approved dashboard
   Scope: dashboard page only. Does not alter header/navbar.
========================================================= */

.respawn-account-dashboard-page .respawn-page-hero {
  padding: clamp(54px, 6vw, 86px) 0 36px !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(139,92,246,.045), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.008), transparent),
    #0f1117 !important;
}

.respawn-account-dashboard-page .respawn-page-shell {
  width: min(1320px, calc(100% - 48px)) !important;
}

.respawn-account-dashboard-page .respawn-page-content-section {
  padding: 0 0 92px !important;
  background: #0f1117 !important;
}

.respawn-account-dashboard-page .respawn-page-content-card,
.respawn-account-dashboard-page .woocommerce-MyAccount-content {
  width: 100% !important;
  float: none !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.respawn-account-dashboard-page .woocommerce-MyAccount-content > p {
  display: none !important;
}

.respawn-account-dashboard-page .woocommerce-MyAccount-navigation {
  display: none !important;
}

.respawn-account-dashboard-page .respawn-account-hero-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(420px, 620px) !important;
  gap: clamp(28px, 6vw, 94px) !important;
  align-items: center !important;
}

.respawn-account-dashboard-page .respawn-page-eyebrow {
  margin: 0 0 16px !important;
  color: #a978ff !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  letter-spacing: .28em !important;
  text-transform: uppercase !important;
}

.respawn-account-dashboard-page .respawn-page-hero h1 {
  margin: 0 0 22px !important;
  color: #f5f7fb !important;
  font-size: clamp(58px, 5vw, 84px) !important;
  line-height: .92 !important;
  letter-spacing: -.08em !important;
  font-weight: 720 !important;
}

.respawn-account-dashboard-page .respawn-page-subtitle {
  max-width: 420px !important;
  margin: 0 !important;
  color: rgba(245,247,251,.68) !important;
  font-size: 17px !important;
  line-height: 1.7 !important;
}

.respawn-account-dashboard-page .respawn-account-hero-summary {
  min-height: 172px !important;
  display: grid !important;
  grid-template-columns: 76px minmax(0, 1fr) 156px !important;
  gap: 22px !important;
  align-items: center !important;
  padding: 26px 28px !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.036), rgba(255,255,255,.014)),
    #171922 !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.035) !important;
  overflow: hidden !important;
}

.respawn-account-dashboard-page .respawn-account-hero-avatar {
  width: 68px !important;
  height: 68px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, rgba(139,92,246,.82), rgba(92,55,172,.88)) !important;
  color: #efe7ff !important;
  font-size: 26px !important;
  font-weight: 900 !important;
  letter-spacing: -.04em !important;
}

.respawn-account-dashboard-page .respawn-account-hero-summary-main {
  min-width: 0 !important;
  padding: 0 !important;
}

.respawn-account-dashboard-page .respawn-account-hero-summary-label {
  display: block !important;
  margin-bottom: 4px !important;
  color: rgba(245,247,251,.66) !important;
  font-size: 14px !important;
  line-height: 1.35 !important;
}

.respawn-account-dashboard-page .respawn-account-hero-name-line {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  margin-bottom: 10px !important;
}

.respawn-account-dashboard-page .respawn-account-hero-name-line strong {
  color: #fff !important;
  font-size: 32px !important;
  line-height: 1 !important;
  letter-spacing: -.06em !important;
  font-weight: 780 !important;
}

.respawn-account-dashboard-page .respawn-account-hero-summary-badge {
  min-height: 24px !important;
  display: inline-flex !important;
  align-items: center !important;
  padding: 0 10px !important;
  border-radius: 999px !important;
  background: rgba(139,92,246,.18) !important;
  color: #d6c2ff !important;
  font-size: 11px !important;
  font-weight: 850 !important;
}

.respawn-account-dashboard-page .respawn-account-hero-email {
  display: block !important;
  color: rgba(245,247,251,.66) !important;
  font-size: 15px !important;
}

.respawn-account-dashboard-page .respawn-account-hero-edit {
  display: inline-flex !important;
  margin-top: 12px !important;
  color: #b78bff !important;
  font-size: 14px !important;
  font-weight: 850 !important;
  text-decoration: none !important;
}

.respawn-account-dashboard-page .respawn-account-hero-summary-side {
  height: calc(100% + 52px) !important;
  margin: -26px -28px -26px 0 !important;
  padding: 28px 26px !important;
  border-left: 1px solid rgba(255,255,255,.09) !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
}

.respawn-account-dashboard-page .respawn-account-hero-summary-icon {
  width: 34px !important;
  height: 34px !important;
  display: grid !important;
  place-items: center !important;
  margin-bottom: 20px !important;
  border: 0 !important;
  background: transparent !important;
  color: #a978ff !important;
  font-size: 26px !important;
  line-height: 1 !important;
}

.respawn-account-dashboard-page .respawn-account-hero-summary-side span {
  display: block !important;
  color: rgba(245,247,251,.62) !important;
  font-size: 14px !important;
  line-height: 1.3 !important;
}

.respawn-account-dashboard-page .respawn-account-hero-summary-side strong {
  display: block !important;
  margin-top: 8px !important;
  color: #fff !important;
  font-size: 22px !important;
  line-height: 1.1 !important;
  letter-spacing: -.04em !important;
}

.respawn-account-dashboard-page .rp-simple-account-dashboard {
  width: min(1320px, calc(100vw - 48px)) !important;
  margin: 0 auto !important;
  display: grid !important;
  gap: 24px !important;
}

.respawn-account-dashboard-page .rp-simple-section-label {
  display: block !important;
  margin: 0 0 14px !important;
  color: rgba(245,247,251,.88) !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  letter-spacing: .28em !important;
  text-transform: uppercase !important;
}

.respawn-account-dashboard-page .rp-simple-overview-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

.respawn-account-dashboard-page .rp-simple-overview-card,
.respawn-account-dashboard-page .rp-simple-panel {
  border: 1px solid rgba(255,255,255,.085) !important;
  border-radius: 16px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.012)),
    #171922 !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.028) !important;
}

.respawn-account-dashboard-page .rp-simple-overview-card {
  min-height: 104px !important;
  display: grid !important;
  grid-template-columns: 58px minmax(0, 1fr) auto auto !important;
  gap: 18px !important;
  align-items: center !important;
  padding: 22px 24px !important;
  text-decoration: none !important;
}

.respawn-account-dashboard-page .rp-simple-overview-icon {
  width: 52px !important;
  height: 52px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 999px !important;
  background: rgba(139,92,246,.18) !important;
  color: #b98eff !important;
}

.respawn-account-dashboard-page .rp-simple-overview-icon svg {
  width: 25px !important;
  height: 25px !important;
  fill: none !important;
  stroke: currentColor !important;
  stroke-width: 1.8 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

.respawn-account-dashboard-page .rp-simple-overview-copy strong {
  display: block !important;
  color: #f5f7fb !important;
  font-size: 20px !important;
  line-height: 1.1 !important;
  letter-spacing: -.035em !important;
  font-weight: 780 !important;
}

.respawn-account-dashboard-page .rp-simple-overview-copy small {
  display: block !important;
  margin-top: 7px !important;
  color: rgba(245,247,251,.62) !important;
  font-size: 14px !important;
  line-height: 1.35 !important;
}

.respawn-account-dashboard-page .rp-simple-overview-count {
  color: #fff !important;
  font-size: 26px !important;
  font-weight: 800 !important;
  letter-spacing: -.05em !important;
}

.respawn-account-dashboard-page .rp-simple-overview-arrow {
  color: rgba(245,247,251,.82) !important;
  font-size: 30px !important;
  line-height: 1 !important;
}

.respawn-account-dashboard-page .rp-simple-main-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 430px !important;
  gap: 20px !important;
  align-items: stretch !important;
}

.respawn-account-dashboard-page .rp-simple-panel {
  padding: 24px !important;
}

.respawn-account-dashboard-page .rp-simple-orders-panel {
  min-height: 338px !important;
}

.respawn-account-dashboard-page .rp-simple-empty-state {
  min-height: 260px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
}

.respawn-account-dashboard-page .rp-simple-empty-icon {
  width: 80px !important;
  height: 80px !important;
  display: grid !important;
  place-items: center !important;
  margin-bottom: 20px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255,255,255,.075) !important;
  background: rgba(255,255,255,.018) !important;
  color: #a978ff !important;
}

.respawn-account-dashboard-page .rp-simple-empty-icon svg {
  width: 36px !important;
  height: 36px !important;
  fill: none !important;
  stroke: currentColor !important;
  stroke-width: 1.7 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

.respawn-account-dashboard-page .rp-simple-empty-state h2 {
  margin: 0 0 12px !important;
  color: #fff !important;
  font-size: 30px !important;
  line-height: 1 !important;
  letter-spacing: -.055em !important;
  font-weight: 760 !important;
}

.respawn-account-dashboard-page .rp-simple-empty-state p {
  max-width: 440px !important;
  margin: 0 !important;
  color: rgba(245,247,251,.62) !important;
  font-size: 15px !important;
  line-height: 1.65 !important;
}

.respawn-account-dashboard-page .rp-simple-empty-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  gap: 14px !important;
  margin-top: 24px !important;
}

.respawn-account-dashboard-page .rp-simple-button {
  min-width: 178px !important;
  min-height: 46px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid rgba(139,92,246,.45) !important;
  border-radius: 10px !important;
  background: transparent !important;
  color: #c8adff !important;
  font-size: 14px !important;
  font-weight: 850 !important;
  text-decoration: none !important;
}

.respawn-account-dashboard-page .rp-simple-button-primary {
  background: linear-gradient(90deg, #8b5cf6, #a855f7) !important;
  color: #fff !important;
  border-color: transparent !important;
}

.respawn-account-dashboard-page .rp-simple-link-list {
  display: grid !important;
}

.respawn-account-dashboard-page .rp-simple-link-row {
  min-height: 68px !important;
  display: grid !important;
  grid-template-columns: 36px minmax(0, 1fr) auto !important;
  gap: 18px !important;
  align-items: center !important;
  padding: 14px 0 !important;
  border-bottom: 1px solid rgba(255,255,255,.07) !important;
  color: inherit !important;
  text-decoration: none !important;
}

.respawn-account-dashboard-page .rp-simple-link-row:last-child {
  border-bottom: 0 !important;
}

.respawn-account-dashboard-page .rp-simple-link-icon {
  color: #a978ff !important;
  font-size: 25px !important;
  line-height: 1 !important;
  text-align: center !important;
}

.respawn-account-dashboard-page .rp-simple-link-row strong {
  display: block !important;
  color: #fff !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
  font-weight: 850 !important;
}

.respawn-account-dashboard-page .rp-simple-link-row small {
  display: block !important;
  margin-top: 4px !important;
  color: rgba(245,247,251,.58) !important;
  font-size: 13px !important;
  line-height: 1.35 !important;
}

.respawn-account-dashboard-page .rp-simple-link-row em {
  color: rgba(245,247,251,.74) !important;
  font-size: 26px !important;
  font-style: normal !important;
}

.respawn-account-dashboard-page .rp-simple-range-panel {
  padding: 24px !important;
}

.respawn-account-dashboard-page .rp-simple-range-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 22px !important;
}

.respawn-account-dashboard-page .rp-simple-range-card {
  position: relative !important;
  overflow: hidden !important;
  min-height: 150px !important;
  display: flex !important;
  align-items: center !important;
  padding: 26px !important;
  border-radius: 10px !important;
  background: #080a0f !important;
  color: #fff !important;
  text-decoration: none !important;
}

.respawn-account-dashboard-page .rp-simple-range-card::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(90deg, rgba(8,10,15,.96) 0%, rgba(8,10,15,.74) 48%, rgba(8,10,15,.35) 100%) !important;
  pointer-events: none !important;
}

.respawn-account-dashboard-page .rp-simple-range-copy {
  position: relative !important;
  z-index: 2 !important;
  max-width: 58% !important;
}

.respawn-account-dashboard-page .rp-simple-range-copy strong {
  display: block !important;
  color: #fff !important;
  font-size: 22px !important;
  line-height: 1.05 !important;
  letter-spacing: -.04em !important;
  font-weight: 790 !important;
}

.respawn-account-dashboard-page .rp-simple-range-copy small {
  display: block !important;
  margin-top: 8px !important;
  color: rgba(245,247,251,.65) !important;
  font-size: 14px !important;
  line-height: 1.35 !important;
}

.respawn-account-dashboard-page .rp-simple-range-copy em {
  display: inline-block !important;
  margin-top: 18px !important;
  color: #b78bff !important;
  font-size: 14px !important;
  font-style: normal !important;
  font-weight: 850 !important;
}

.respawn-account-dashboard-page .rp-simple-range-image {
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
  width: 52% !important;
  height: 100% !important;
}

.respawn-account-dashboard-page .rp-simple-range-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  opacity: .72 !important;
}

.respawn-account-dashboard-page .rp-simple-range-card-map {
  background:
    radial-gradient(circle at 82% 55%, rgba(139,92,246,.22), transparent 12%),
    linear-gradient(90deg, #080a0f 0%, #10131b 100%) !important;
}

.respawn-account-dashboard-page .rp-simple-uk-mark {
  position: absolute !important;
  right: 52px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 1 !important;
  color: #8b5cf6 !important;
  font-size: 70px !important;
  opacity: .7 !important;
}

.respawn-account-dashboard-page .rp-simple-order-list {
  display: grid !important;
  gap: 12px !important;
}

.respawn-account-dashboard-page .rp-simple-order-row {
  min-height: 78px !important;
  display: grid !important;
  grid-template-columns: 56px minmax(0, 1fr) auto auto !important;
  gap: 14px !important;
  align-items: center !important;
  padding: 12px !important;
  border: 1px solid rgba(255,255,255,.075) !important;
  border-radius: 12px !important;
  background: rgba(255,255,255,.015) !important;
}

.respawn-account-dashboard-page .rp-simple-order-thumb {
  width: 56px !important;
  height: 56px !important;
  overflow: hidden !important;
  border-radius: 10px !important;
  background: rgba(255,255,255,.035) !important;
}

.respawn-account-dashboard-page .rp-simple-order-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

.respawn-account-dashboard-page .rp-simple-order-copy small,
.respawn-account-dashboard-page .rp-simple-order-copy em {
  display: block !important;
  color: rgba(245,247,251,.56) !important;
  font-size: 12px !important;
  font-style: normal !important;
}

.respawn-account-dashboard-page .rp-simple-order-copy strong {
  display: block !important;
  margin: 4px 0 !important;
  color: #fff !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
}

.respawn-account-dashboard-page .rp-simple-order-status,
.respawn-account-dashboard-page .rp-simple-mini-button {
  min-height: 32px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255,255,255,.1) !important;
  background: rgba(255,255,255,.02) !important;
  color: rgba(245,247,251,.78) !important;
  font-size: 12px !important;
  font-weight: 850 !important;
  text-decoration: none !important;
}

@media (max-width: 1180px) {
  .respawn-account-dashboard-page .respawn-account-hero-grid,
  .respawn-account-dashboard-page .rp-simple-main-grid {
    grid-template-columns: 1fr !important;
  }

  .respawn-account-dashboard-page .rp-simple-range-grid,
  .respawn-account-dashboard-page .rp-simple-overview-grid {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 720px) {
  .respawn-account-dashboard-page .respawn-page-shell,
  .respawn-account-dashboard-page .rp-simple-account-dashboard {
    width: min(100% - 28px, 1320px) !important;
  }

  .respawn-account-dashboard-page .respawn-account-hero-summary {
    grid-template-columns: 1fr !important;
    text-align: left !important;
  }

  .respawn-account-dashboard-page .respawn-account-hero-summary-side {
    height: auto !important;
    margin: 0 !important;
    border-left: 0 !important;
    border-top: 1px solid rgba(255,255,255,.09) !important;
    align-items: flex-start !important;
    text-align: left !important;
  }

  .respawn-account-dashboard-page .rp-simple-overview-card {
    grid-template-columns: 52px minmax(0,1fr) auto !important;
  }

  .respawn-account-dashboard-page .rp-simple-overview-arrow {
    display: none !important;
  }

  .respawn-account-dashboard-page .rp-simple-range-card {
    min-height: 132px !important;
  }

  .respawn-account-dashboard-page .rp-simple-range-copy {
    max-width: 70% !important;
  }

  .respawn-account-dashboard-page .rp-simple-empty-actions,
  .respawn-account-dashboard-page .rp-simple-empty-actions a {
    width: 100% !important;
  }
}

/* =========================================================
   Account dashboard final tile-image fix
   - Adds breathing room above the overview cards
   - Stops Explore Our Range images stretching
   - Keeps Built to Order map fully visible
========================================================= */

.respawn-account-dashboard-page .rp-simple-account-dashboard {
  padding-top: 22px !important;
}

.respawn-account-dashboard-page .rp-simple-overview-grid {
  margin-top: 0 !important;
}

.respawn-account-dashboard-page .rp-simple-range-card {
  min-height: 154px !important;
  padding: 26px !important;
  background: #07090f !important;
}

.respawn-account-dashboard-page .rp-simple-range-card::after {
  background:
    linear-gradient(90deg, rgba(7,9,15,.98) 0%, rgba(7,9,15,.92) 34%, rgba(7,9,15,.58) 62%, rgba(7,9,15,.20) 100%) !important;
}

.respawn-account-dashboard-page .rp-simple-range-copy {
  max-width: 50% !important;
}

.respawn-account-dashboard-page .rp-simple-range-image {
  position: absolute !important;
  top: auto !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 58% !important;
  height: 100% !important;
  display: flex !important;
  align-items: flex-end !important;
  justify-content: flex-end !important;
  overflow: visible !important;
  z-index: 1 !important;
  pointer-events: none !important;
}

.respawn-account-dashboard-page .rp-simple-range-image img {
  width: 100% !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: 118% !important;
  object-fit: contain !important;
  object-position: right bottom !important;
  display: block !important;
  opacity: .78 !important;
  transform: none !important;
}

.respawn-account-dashboard-page .rp-simple-range-image-map {
  right: 4px !important;
  bottom: -2px !important;
  width: 43% !important;
  height: 112% !important;
  align-items: center !important;
  justify-content: flex-end !important;
}

.respawn-account-dashboard-page .rp-simple-range-image-map img {
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center right !important;
  opacity: .76 !important;
}

.respawn-account-dashboard-page .rp-simple-range-card-map::after {
  background:
    linear-gradient(90deg, rgba(7,9,15,.98) 0%, rgba(7,9,15,.90) 40%, rgba(7,9,15,.48) 68%, rgba(7,9,15,.16) 100%) !important;
}

@media (max-width: 980px) {
  .respawn-account-dashboard-page .rp-simple-account-dashboard {
    padding-top: 16px !important;
  }

  .respawn-account-dashboard-page .rp-simple-range-copy {
    max-width: 58% !important;
  }

  .respawn-account-dashboard-page .rp-simple-range-image {
    width: 54% !important;
  }

  .respawn-account-dashboard-page .rp-simple-range-image-map {
    width: 38% !important;
  }
}

@media (max-width: 640px) {
  .respawn-account-dashboard-page .rp-simple-range-card {
    min-height: 150px !important;
  }

  .respawn-account-dashboard-page .rp-simple-range-copy {
    max-width: 62% !important;
  }

  .respawn-account-dashboard-page .rp-simple-range-image {
    width: 52% !important;
    opacity: .72 !important;
  }

  .respawn-account-dashboard-page .rp-simple-range-image-map {
    width: 40% !important;
  }
}

/* =========================================================
   Account dashboard range tiles cleanup
   Makes the Explore Our Range artwork feel built into the cards,
   not stretched/stuck on top.
========================================================= */
.respawn-account-dashboard-page .rp-simple-account-dashboard {
  padding-top: 30px !important;
}

.respawn-account-dashboard-page .rp-simple-range-panel {
  padding: 24px !important;
}

.respawn-account-dashboard-page .rp-simple-range-grid {
  gap: 20px !important;
}

.respawn-account-dashboard-page .rp-simple-range-card {
  position: relative !important;
  min-height: 152px !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 46% !important;
  align-items: stretch !important;
  gap: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 12px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.018), rgba(255,255,255,.006)),
    #080a0f !important;
}

.respawn-account-dashboard-page .rp-simple-range-card::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  pointer-events: none !important;
  background:
    linear-gradient(90deg, rgba(8,10,15,0) 0%, rgba(8,10,15,.12) 45%, rgba(8,10,15,.72) 100%) !important;
  opacity: .55 !important;
}

.respawn-account-dashboard-page .rp-simple-range-copy {
  position: relative !important;
  z-index: 3 !important;
  max-width: none !important;
  align-self: center !important;
  padding: 26px 10px 26px 26px !important;
}

.respawn-account-dashboard-page .rp-simple-range-copy strong {
  font-size: 23px !important;
  line-height: 1.02 !important;
}

.respawn-account-dashboard-page .rp-simple-range-copy small {
  max-width: 180px !important;
  font-size: 14px !important;
  line-height: 1.35 !important;
}

.respawn-account-dashboard-page .rp-simple-range-copy em {
  margin-top: 18px !important;
}

.respawn-account-dashboard-page .rp-simple-range-image {
  position: relative !important;
  inset: auto !important;
  z-index: 0 !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 152px !important;
  display: block !important;
  overflow: hidden !important;
  opacity: 1 !important;
  pointer-events: none !important;
}

.respawn-account-dashboard-page .rp-simple-range-image::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 2 !important;
  background:
    linear-gradient(90deg, rgba(8,10,15,.92) 0%, rgba(8,10,15,.36) 34%, rgba(8,10,15,.05) 100%),
    radial-gradient(circle at 72% 74%, rgba(139,92,246,.12), transparent 38%) !important;
  pointer-events: none !important;
}

.respawn-account-dashboard-page .rp-simple-range-image img {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center right !important;
  opacity: .76 !important;
  transform: scale(1.02) !important;
}

.respawn-account-dashboard-page .rp-simple-range-card-map {
  background:
    linear-gradient(180deg, rgba(255,255,255,.018), rgba(255,255,255,.006)),
    #080a0f !important;
}

.respawn-account-dashboard-page .rp-simple-range-card-map::after {
  background:
    linear-gradient(90deg, rgba(8,10,15,0) 0%, rgba(8,10,15,.16) 48%, rgba(8,10,15,.58) 100%) !important;
  opacity: .5 !important;
}

.respawn-account-dashboard-page .rp-simple-range-image-map {
  width: 100% !important;
  height: 100% !important;
  min-height: 152px !important;
  padding: 10px 14px 10px 0 !important;
  display: grid !important;
  place-items: center end !important;
}

.respawn-account-dashboard-page .rp-simple-range-image-map::before {
  background:
    radial-gradient(circle at 72% 70%, rgba(139,92,246,.18), transparent 34%),
    linear-gradient(90deg, rgba(8,10,15,.92) 0%, rgba(8,10,15,.42) 42%, rgba(8,10,15,.06) 100%) !important;
}

.respawn-account-dashboard-page .rp-simple-range-image-map img {
  width: auto !important;
  height: auto !important;
  max-width: 92% !important;
  max-height: 126px !important;
  object-fit: contain !important;
  object-position: center right !important;
  opacity: .78 !important;
  transform: none !important;
}

@media (max-width: 1180px) {
  .respawn-account-dashboard-page .rp-simple-range-card {
    grid-template-columns: minmax(0, 1fr) 44% !important;
  }
}

@media (max-width: 720px) {
  .respawn-account-dashboard-page .rp-simple-account-dashboard {
    padding-top: 20px !important;
  }

  .respawn-account-dashboard-page .rp-simple-range-card {
    min-height: 146px !important;
    grid-template-columns: minmax(0, 1fr) 42% !important;
  }

  .respawn-account-dashboard-page .rp-simple-range-copy {
    padding: 22px 8px 22px 22px !important;
  }

  .respawn-account-dashboard-page .rp-simple-range-copy small {
    max-width: 155px !important;
  }

  .respawn-account-dashboard-page .rp-simple-range-image,
  .respawn-account-dashboard-page .rp-simple-range-image-map {
    min-height: 146px !important;
  }
}

/* =========================================================
   Respawn PCs - My Account Orders endpoint
   Matches the simple premium account dashboard feel.
========================================================= */

.respawn-account-page .rp-orders-view {
  display: grid;
  gap: 18px;
}

.respawn-account-page .rp-orders-header {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 18px;
  padding-bottom: 4px;
}

.respawn-account-page .rp-orders-header-copy {
  max-width: 620px;
}

.respawn-account-page .rp-orders-kicker {
  display: inline-block;
  margin-bottom: 10px;
  color: #b78bff;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .22em;
  text-transform: uppercase;
}

.respawn-account-page .rp-orders-header h2,
.respawn-account-page .rp-orders-panel h3,
.respawn-account-page .rp-orders-empty-state h4,
.respawn-account-page .rp-orders-card h4 {
  margin: 0;
  color: #fff;
  letter-spacing: -.04em;
}

.respawn-account-page .rp-orders-header h2 {
  font-size: clamp(30px, 2.3vw, 38px);
  line-height: .98;
}

.respawn-account-page .rp-orders-header p,
.respawn-account-page .rp-orders-panel-head p,
.respawn-account-page .rp-orders-empty-state p,
.respawn-account-page .rp-orders-side-note p,
.respawn-account-page .rp-orders-side-note li,
.respawn-account-page .rp-orders-card-meta span,
.respawn-account-page .rp-orders-quick-links small {
  margin: 8px 0 0;
  color: rgba(245,247,251,.64);
  font-size: 14px;
  line-height: 1.6;
}

.respawn-account-page .rp-orders-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(120px, 1fr));
  gap: 12px;
  width: min(100%, 420px);
}

.respawn-account-page .rp-orders-summary-card,
.respawn-account-page .rp-orders-panel {
  border: 1px solid rgba(255,255,255,.09);
  background: linear-gradient(180deg, rgba(255,255,255,.022), rgba(255,255,255,.01)), rgba(23,25,34,.92);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.025);
}

.respawn-account-page .rp-orders-summary-card {
  min-height: 94px;
  padding: 16px 18px;
  border-radius: 18px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
}

.respawn-account-page .rp-orders-summary-card span {
  color: rgba(245,247,251,.62);
  font-size: 13px;
  font-weight: 700;
}

.respawn-account-page .rp-orders-summary-card strong {
  color: #fff;
  font-size: 34px;
  line-height: 1;
  letter-spacing: -.06em;
}

.respawn-account-page .rp-orders-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(300px, .8fr);
  gap: 18px;
  align-items: start;
}

.respawn-account-page .rp-orders-panel {
  border-radius: 22px;
  padding: 24px;
}

.respawn-account-page .rp-orders-panel-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 18px;
}

.respawn-account-page .rp-orders-panel h3 {
  font-size: 24px;
  line-height: 1.05;
}

.respawn-account-page .rp-orders-empty-state {
  min-height: 360px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 24px;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 18px;
  background: rgba(255,255,255,.015);
}

.respawn-account-page .rp-orders-empty-icon {
  width: 72px;
  height: 72px;
  margin-bottom: 18px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  border: 1px solid rgba(139,92,246,.22);
  background: rgba(139,92,246,.06);
  color: #b78bff;
  font-size: 20px;
}

.respawn-account-page .rp-orders-empty-state h4 {
  font-size: clamp(34px, 2.6vw, 46px);
  line-height: .95;
  letter-spacing: -.07em;
}

.respawn-account-page .rp-orders-empty-state p {
  max-width: 560px;
}

.respawn-account-page .rp-orders-empty-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  margin-top: 20px;
}

.respawn-account-page .rp-orders-action,
.respawn-account-page .rp-orders-pagination-link {
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 18px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
  color: #fff !important;
  font-size: 13px;
  font-weight: 800;
  text-decoration: none !important;
  transition: background .18s ease, border-color .18s ease, transform .18s ease;
}

.respawn-account-page .rp-orders-action:hover,
.respawn-account-page .rp-orders-pagination-link:hover {
  border-color: rgba(255,255,255,.16);
  background: rgba(255,255,255,.04);
  transform: translateY(-1px);
}

.respawn-account-page .rp-orders-action-primary {
  border-color: rgba(139,92,246,.28);
  background: linear-gradient(90deg, #8b5cf6, #a855f7);
}

.respawn-account-page .rp-orders-action-primary:hover {
  border-color: rgba(169,133,255,.42);
  background: linear-gradient(90deg, #9b6cff, #b167ff);
}

.respawn-account-page .rp-orders-list {
  display: grid;
  gap: 14px;
}

.respawn-account-page .rp-orders-card {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 16px;
  padding: 16px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  background: rgba(255,255,255,.016);
}

.respawn-account-page .rp-orders-card-media {
  width: 76px;
  height: 76px;
  border-radius: 14px;
  overflow: hidden;
  background: rgba(255,255,255,.03);
}

.respawn-account-page .rp-orders-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.respawn-account-page .rp-orders-card-number {
  display: block;
  margin-bottom: 4px;
  color: rgba(245,247,251,.52);
  font-size: 12px;
}

.respawn-account-page .rp-orders-card h4 {
  font-size: 19px;
  line-height: 1.18;
}

.respawn-account-page .rp-orders-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 8px;
}

.respawn-account-page .rp-orders-card-meta span {
  margin: 0;
  font-size: 13px;
}

.respawn-account-page .rp-orders-card-status-wrap {
  display: flex;
  justify-content: center;
}

.respawn-account-page .rp-orders-card-status {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.11);
  background: rgba(255,255,255,.02);
  color: rgba(245,247,251,.82);
  font-size: 12px;
  font-weight: 850;
  text-transform: capitalize;
}

.respawn-account-page .rp-orders-card-status-completed {
  border-color: rgba(74,222,128,.22);
  background: rgba(74,222,128,.09);
  color: #94e4ab;
}

.respawn-account-page .rp-orders-card-status-processing,
.respawn-account-page .rp-orders-card-status-pending,
.respawn-account-page .rp-orders-card-status-on-hold {
  border-color: rgba(139,92,246,.24);
  background: rgba(139,92,246,.08);
  color: #cfb6ff;
}

.respawn-account-page .rp-orders-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.respawn-account-page .rp-orders-card-actions .rp-orders-action {
  min-height: 40px;
  padding: 0 14px;
  border-radius: 12px;
}

.respawn-account-page .rp-orders-pagination {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 18px;
}

.respawn-account-page .rp-orders-panel-side {
  display: grid;
  gap: 16px;
}

.respawn-account-page .rp-orders-side-block {
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 18px;
  padding: 18px;
  background: rgba(255,255,255,.014);
}

.respawn-account-page .rp-orders-side-block h3 {
  font-size: 22px;
  margin-bottom: 14px;
}

.respawn-account-page .rp-orders-quick-links {
  display: grid;
}

.respawn-account-page .rp-orders-quick-links a {
  min-height: 76px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 0 2px;
  text-decoration: none;
  border-top: 1px solid rgba(255,255,255,.07);
}

.respawn-account-page .rp-orders-quick-links a:first-child {
  border-top: 0;
}

.respawn-account-page .rp-orders-quick-links strong {
  display: block;
  color: #fff;
  font-size: 17px;
  line-height: 1.2;
}

.respawn-account-page .rp-orders-quick-links small {
  display: block;
  margin-top: 4px;
}

.respawn-account-page .rp-orders-quick-links em {
  color: #b78bff;
  font-style: normal;
  font-size: 18px;
  font-weight: 700;
}

.respawn-account-page .rp-orders-side-note ul {
  margin: 14px 0 0;
  padding-left: 18px;
}

.respawn-account-page .rp-orders-side-note li + li {
  margin-top: 8px;
}

@media (max-width: 1180px) {
  .respawn-account-page .rp-orders-header,
  .respawn-account-page .rp-orders-layout {
    grid-template-columns: 1fr;
    display: grid;
  }

  .respawn-account-page .rp-orders-summary {
    width: 100%;
    max-width: none;
  }
}

@media (max-width: 860px) {
  .respawn-account-page .rp-orders-summary {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .respawn-account-page .rp-orders-card {
    grid-template-columns: 70px minmax(0, 1fr);
    align-items: start;
  }

  .respawn-account-page .rp-orders-card-status-wrap,
  .respawn-account-page .rp-orders-card-actions {
    grid-column: 2;
    justify-content: flex-start;
  }
}

@media (max-width: 640px) {
  .respawn-account-page .rp-orders-summary {
    grid-template-columns: 1fr;
  }

  .respawn-account-page .rp-orders-panel {
    padding: 18px;
  }

  .respawn-account-page .rp-orders-header h2 {
    font-size: 28px;
  }

  .respawn-account-page .rp-orders-empty-state {
    min-height: 300px;
  }

  .respawn-account-page .rp-orders-empty-state h4 {
    font-size: 36px;
  }

  .respawn-account-page .rp-orders-empty-actions,
  .respawn-account-page .rp-orders-empty-actions .rp-orders-action,
  .respawn-account-page .rp-orders-card-actions,
  .respawn-account-page .rp-orders-card-actions .rp-orders-action,
  .respawn-account-page .rp-orders-pagination,
  .respawn-account-page .rp-orders-pagination .rp-orders-pagination-link {
    width: 100%;
  }

  .respawn-account-page .rp-orders-card-actions {
    flex-direction: column;
  }
}

/* =========================================================
   Respawn PCs - Orders endpoint final scoped layout
   Scope: WooCommerce My Account orders template only.
========================================================= */

.respawn-account-page .respawn-page-content-card:has(.rp-orders-view),
.respawn-account-page .woocommerce-MyAccount-content:has(.rp-orders-view) {
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.respawn-account-page .rp-orders-view {
  width: min(1320px, 100%);
  margin: 0 auto;
  display: grid;
  gap: 22px;
  color: #f5f7fb;
}

.respawn-account-page .rp-orders-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 430px);
  gap: 22px;
  align-items: end;
  padding: 0;
}

.respawn-account-page .rp-orders-header-copy {
  max-width: 620px;
}

.respawn-account-page .rp-orders-kicker {
  display: block;
  margin: 0 0 10px;
  color: #a978ff;
  font-size: 12px;
  font-weight: 850;
  letter-spacing: 0;
  text-transform: uppercase;
}

.respawn-account-page .rp-orders-header h2,
.respawn-account-page .rp-orders-panel h3,
.respawn-account-page .rp-orders-empty-state h4,
.respawn-account-page .rp-orders-card h4 {
  margin: 0;
  color: #fff;
  font-weight: 760;
  letter-spacing: 0;
}

.respawn-account-page .rp-orders-header h2 {
  font-size: 38px;
  line-height: 1;
}

.respawn-account-page .rp-orders-header p,
.respawn-account-page .rp-orders-panel-head p,
.respawn-account-page .rp-orders-empty-state p,
.respawn-account-page .rp-orders-card-meta,
.respawn-account-page .rp-orders-quick-links-list small {
  color: rgba(245,247,251,.66);
  font-size: 15px;
  line-height: 1.65;
}

.respawn-account-page .rp-orders-header p,
.respawn-account-page .rp-orders-panel-head p,
.respawn-account-page .rp-orders-empty-state p {
  margin: 10px 0 0;
}

.respawn-account-page .rp-orders-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.respawn-account-page .rp-orders-summary-card,
.respawn-account-page .rp-orders-panel,
.respawn-account-page .rp-orders-card {
  border: 1px solid rgba(255,255,255,.085);
  background:
    linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.012)),
    #171922;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.028);
}

.respawn-account-page .rp-orders-summary-card {
  min-height: 104px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 8px;
  padding: 18px;
  border-radius: 16px;
}

.respawn-account-page .rp-orders-summary-card span {
  color: rgba(245,247,251,.62);
  font-size: 13px;
  font-weight: 700;
}

.respawn-account-page .rp-orders-summary-card strong {
  color: #fff;
  font-size: 32px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: 0;
}

.respawn-account-page .rp-orders-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 20px;
  align-items: start;
}

.respawn-account-page .rp-orders-panel {
  border-radius: 16px;
  padding: 24px;
}

.respawn-account-page .rp-orders-panel-main {
  min-width: 0;
}

.respawn-account-page .rp-orders-panel-head {
  margin: 0 0 20px;
}

.respawn-account-page .rp-orders-panel h3 {
  font-size: 24px;
  line-height: 1.1;
}

.respawn-account-page .rp-orders-empty-state {
  min-height: 320px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 30px;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 14px;
  background: rgba(255,255,255,.014);
}

.respawn-account-page .rp-orders-empty-icon,
.respawn-account-page .rp-orders-card-media-fallback {
  display: grid;
  place-items: center;
  color: #b78bff;
}

.respawn-account-page .rp-orders-empty-icon {
  width: 78px;
  height: 78px;
  margin: 0 0 20px;
  border: 1px solid rgba(139,92,246,.24);
  border-radius: 999px;
  background: rgba(139,92,246,.08);
}

.respawn-account-page .rp-orders-empty-icon svg,
.respawn-account-page .rp-orders-card-media-fallback svg {
  width: 34px;
  height: 34px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.7;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.respawn-account-page .rp-orders-empty-state h4 {
  font-size: 32px;
  line-height: 1.05;
}

.respawn-account-page .rp-orders-empty-state p {
  max-width: 440px;
}

.respawn-account-page .rp-orders-empty-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  margin-top: 24px;
}

.respawn-account-page .rp-orders-action,
.respawn-account-page .rp-orders-pagination-link {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 16px;
  border: 1px solid rgba(139,92,246,.42);
  border-radius: 10px;
  background: transparent;
  color: #c8adff !important;
  font-size: 14px;
  font-weight: 820;
  line-height: 1;
  text-decoration: none !important;
  transition: background .18s ease, border-color .18s ease, color .18s ease;
}

.respawn-account-page .rp-orders-action:hover,
.respawn-account-page .rp-orders-pagination-link:hover {
  border-color: rgba(169,133,255,.58);
  background: rgba(139,92,246,.10);
  color: #fff !important;
}

.respawn-account-page .rp-orders-action-primary {
  border-color: transparent;
  background: linear-gradient(90deg, #8b5cf6, #a855f7);
  color: #fff !important;
}

.respawn-account-page .rp-orders-action-cancel {
  border-color: rgba(255,255,255,.12);
  color: rgba(245,247,251,.76) !important;
}

.respawn-account-page .rp-orders-list {
  display: grid;
  gap: 14px;
}

.respawn-account-page .rp-orders-card {
  display: grid;
  grid-template-columns: 78px minmax(0, 1fr) minmax(140px, auto);
  grid-template-areas:
    "media copy status"
    "media copy actions";
  gap: 14px 18px;
  align-items: center;
  padding: 16px;
  border-radius: 14px;
}

.respawn-account-page .rp-orders-card-media {
  grid-area: media;
  width: 78px;
  height: 78px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 12px;
  background: rgba(255,255,255,.025);
}

.respawn-account-page .rp-orders-card-media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.respawn-account-page .rp-orders-card-media-fallback {
  width: 100%;
  height: 100%;
  background: rgba(139,92,246,.07);
}

.respawn-account-page .rp-orders-card-copy {
  grid-area: copy;
  min-width: 0;
}

.respawn-account-page .rp-orders-card-number {
  display: block;
  margin: 0 0 6px;
  color: rgba(245,247,251,.56);
  font-size: 13px;
  font-weight: 650;
}

.respawn-account-page .rp-orders-card h4 {
  overflow-wrap: anywhere;
  font-size: 20px;
  line-height: 1.2;
}

.respawn-account-page .rp-orders-card-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, max-content));
  gap: 16px;
  margin-top: 12px;
}

.respawn-account-page .rp-orders-card-meta span,
.respawn-account-page .rp-orders-card-meta small,
.respawn-account-page .rp-orders-card-meta strong {
  display: block;
}

.respawn-account-page .rp-orders-card-meta small {
  margin-bottom: 2px;
  color: rgba(245,247,251,.48);
  font-size: 12px;
  line-height: 1.3;
}

.respawn-account-page .rp-orders-card-meta strong {
  color: rgba(245,247,251,.88);
  font-size: 13px;
  line-height: 1.35;
  font-weight: 760;
}

.respawn-account-page .rp-orders-card-status-wrap {
  grid-area: status;
  display: flex;
  justify-content: flex-end;
}

.respawn-account-page .rp-orders-card-status {
  min-height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 12px;
  border: 1px solid rgba(255,255,255,.11);
  border-radius: 999px;
  background: rgba(255,255,255,.024);
  color: rgba(245,247,251,.82);
  font-size: 12px;
  font-weight: 820;
}

.respawn-account-page .rp-orders-card-status-completed {
  border-color: rgba(74,222,128,.24);
  background: rgba(74,222,128,.09);
  color: #a7e8b7;
}

.respawn-account-page .rp-orders-card-status-processing,
.respawn-account-page .rp-orders-card-status-pending,
.respawn-account-page .rp-orders-card-status-on-hold {
  border-color: rgba(139,92,246,.26);
  background: rgba(139,92,246,.09);
  color: #d8c4ff;
}

.respawn-account-page .rp-orders-card-status-cancelled,
.respawn-account-page .rp-orders-card-status-failed,
.respawn-account-page .rp-orders-card-status-refunded {
  border-color: rgba(255,255,255,.12);
  background: rgba(255,255,255,.028);
  color: rgba(245,247,251,.68);
}

.respawn-account-page .rp-orders-card-actions {
  grid-area: actions;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.respawn-account-page .rp-orders-card-actions .rp-orders-action {
  min-height: 38px;
  padding: 0 14px;
  font-size: 13px;
}

.respawn-account-page .rp-orders-pagination {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 18px;
}

.respawn-account-page .rp-orders-quick-links {
  align-self: start;
}

.respawn-account-page .rp-orders-quick-links h3 {
  margin-bottom: 12px;
}

.respawn-account-page .rp-orders-quick-links-list {
  display: grid;
}

.respawn-account-page .rp-orders-quick-links-list a {
  min-height: 76px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 0;
  border-top: 1px solid rgba(255,255,255,.07);
  text-decoration: none !important;
}

.respawn-account-page .rp-orders-quick-links-list a:first-child {
  border-top: 0;
}

.respawn-account-page .rp-orders-quick-links-list strong {
  display: block;
  color: #fff;
  font-size: 17px;
  line-height: 1.25;
  font-weight: 760;
}

.respawn-account-page .rp-orders-quick-links-list small {
  display: block;
  margin-top: 4px;
}

.respawn-account-page .rp-orders-quick-links-list em {
  color: #b78bff;
  font-size: 18px;
  font-style: normal;
  font-weight: 800;
}

@media (max-width: 1180px) {
  .respawn-account-page .rp-orders-header,
  .respawn-account-page .rp-orders-layout {
    grid-template-columns: 1fr;
  }

  .respawn-account-page .rp-orders-summary {
    max-width: 520px;
  }
}

@media (max-width: 860px) {
  .respawn-account-page .rp-orders-view {
    gap: 18px;
  }

  .respawn-account-page .rp-orders-header h2 {
    font-size: 32px;
  }

  .respawn-account-page .rp-orders-summary {
    max-width: none;
  }

  .respawn-account-page .rp-orders-card {
    grid-template-columns: 70px minmax(0, 1fr);
    grid-template-areas:
      "media copy"
      "media status"
      "media actions";
    align-items: start;
  }

  .respawn-account-page .rp-orders-card-media {
    width: 70px;
    height: 70px;
  }

  .respawn-account-page .rp-orders-card-status-wrap,
  .respawn-account-page .rp-orders-card-actions {
    justify-content: flex-start;
  }

  .respawn-account-page .rp-orders-card-meta {
    grid-template-columns: repeat(2, minmax(0, max-content));
  }
}

@media (max-width: 640px) {
  .respawn-account-page .rp-orders-summary,
  .respawn-account-page .rp-orders-card-meta {
    grid-template-columns: 1fr;
  }

  .respawn-account-page .rp-orders-panel {
    padding: 18px;
  }

  .respawn-account-page .rp-orders-empty-state {
    min-height: 280px;
    padding: 24px 18px;
  }

  .respawn-account-page .rp-orders-empty-state h4 {
    font-size: 28px;
  }

  .respawn-account-page .rp-orders-empty-actions,
  .respawn-account-page .rp-orders-empty-actions .rp-orders-action,
  .respawn-account-page .rp-orders-card-actions,
  .respawn-account-page .rp-orders-card-actions .rp-orders-action,
  .respawn-account-page .rp-orders-pagination,
  .respawn-account-page .rp-orders-pagination .rp-orders-pagination-link {
    width: 100%;
  }

  .respawn-account-page .rp-orders-card {
    grid-template-columns: 1fr;
    grid-template-areas:
      "media"
      "copy"
      "status"
      "actions";
  }

  .respawn-account-page .rp-orders-card-media {
    width: 100%;
    max-width: 132px;
  }

  .respawn-account-page .rp-orders-card-actions,
  .respawn-account-page .rp-orders-pagination {
    flex-direction: column;
  }
}

/* =========================================================
   Respawn PCs - site background consistency
   Main content uses graphite; header/navbar remains untouched.
========================================================= */

:root {
  --bg: #171922;
  --surface: #20232d;
  --surface-2: #20232d;
  --line: rgba(255,255,255,.10);
  --line-soft: rgba(255,255,255,.08);
  --text: #f5f7fb;
  --muted: rgba(245,247,251,.70);
}

body,
main,
.site-main,
.respawn-standard-page,
.respawn-standard-page > section,
.respawn-page-hero,
.respawn-page-content-section,
.respawn-account-page,
.respawn-account-page .respawn-page-hero,
.respawn-account-page .respawn-page-content-section,
.respawn-account-dashboard-page,
.respawn-account-dashboard-page .respawn-page-hero,
.respawn-account-dashboard-page .respawn-page-content-section,
.respawn-cart-page-shell,
.respawn-checkout-page-shell,
.rp-basket-empty-page,
body.home,
body.home main,
body.home main > section,
body.woocommerce-page,
body.woocommerce-page main,
body.post-type-archive-product main,
body.tax-product_cat main,
body.tax-product_tag main,
body.post-type-archive-product .site-main,
body.tax-product_cat .site-main,
body.tax-product_tag .site-main,
.woocommerce.archive {
  background-color: #171922 !important;
}

html body.post-type-archive-product,
html body.tax-product_cat,
html body.tax-product_tag {
  background-color: #171922 !important;
}

html body.post-type-archive-product .rpcx-shop,
html body.tax-product_cat .rpcx-shop,
html body.tax-product_tag .rpcx-shop {
  --bg: #171922;
  --panel: #20232d;
  --panel2: #20232d;
  --line: rgba(255,255,255,.10);
  --line2: rgba(255,255,255,.08);
  --text: #f5f7fb;
  --muted: rgba(245,247,251,.70);
  background-color: #171922 !important;
}

html body.post-type-archive-product .rpcx-hero,
html body.tax-product_cat .rpcx-hero,
html body.tax-product_tag .rpcx-hero {
  background: linear-gradient(90deg, #171922 0%, #171922 42%, #1f2230 72%, #171922 100%) !important;
}

html body.post-type-archive-product .rpcx-catalogue,
html body.tax-product_cat .rpcx-catalogue,
html body.tax-product_tag .rpcx-catalogue {
  background-color: #171922 !important;
}

html body.post-type-archive-product .rpcx-hero::before,
html body.tax-product_cat .rpcx-hero::before,
html body.tax-product_tag .rpcx-hero::before {
  background:
    linear-gradient(90deg, rgba(23,25,34,.98) 0%, rgba(23,25,34,.90) 42%, rgba(23,25,34,.34) 76%, rgba(23,25,34,.76) 100%),
    radial-gradient(circle at 78% 27%, rgba(139,92,246,.18), transparent 12%) !important;
}

html body.post-type-archive-product .rpcx-filter-card,
html body.tax-product_cat .rpcx-filter-card,
html body.tax-product_tag .rpcx-filter-card,
html body.post-type-archive-product .rpcx-card,
html body.tax-product_cat .rpcx-card,
html body.tax-product_tag .rpcx-card {
  background-color: #20232d !important;
}

.site-footer {
  background-color: #0f1117 !important;
}

/* =========================================================
   Respawn PCs - My Account Orders page layout fix
   Scope: /my-account/orders/ only.
========================================================= */

.respawn-account-orders-page .respawn-page-hero {
  padding: 36px 0 18px !important;
  border-bottom: 0 !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.008), transparent 100%),
    #171922 !important;
}

.respawn-account-orders-page {
  min-height: calc(100vh - 250px) !important;
}

.respawn-account-orders-page .respawn-page-shell {
  width: min(1500px, calc(100% - 56px)) !important;
  max-width: 1500px !important;
}

.respawn-account-orders-page .respawn-account-orders-hero {
  max-width: 720px !important;
}

.respawn-account-orders-page .respawn-page-eyebrow {
  margin: 0 0 10px !important;
  color: #a978ff !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  text-transform: uppercase !important;
}

.respawn-account-orders-page .respawn-page-hero h1 {
  margin: 0 0 12px !important;
  color: #f5f7fb !important;
  font-size: clamp(42px, 4vw, 64px) !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  font-weight: 760 !important;
}

.respawn-account-orders-page .respawn-page-subtitle {
  max-width: 560px !important;
  margin: 0 !important;
  color: rgba(245,247,251,.70) !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
}

.respawn-account-orders-page .respawn-account-hero-summary {
  display: none !important;
}

.respawn-account-orders-page .respawn-page-content-section {
  padding: 12px 0 80px !important;
  background: #171922 !important;
}

.respawn-account-orders-page .respawn-page-content-card,
.respawn-account-orders-page .woocommerce,
.respawn-account-orders-page .woocommerce-MyAccount-content {
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.respawn-account-orders-page .woocommerce-MyAccount-navigation {
  margin-bottom: 22px !important;
}

.respawn-account-orders-page .rp-orders-view {
  width: min(1500px, 100%) !important;
  gap: 18px !important;
}

.respawn-account-orders-page .rp-orders-header {
  grid-template-columns: minmax(0, 1fr) minmax(390px, 520px) !important;
  align-items: center !important;
}

.respawn-account-orders-page .rp-orders-header h2 {
  font-size: 32px !important;
}

.respawn-account-orders-page .rp-orders-summary-card,
.respawn-account-orders-page .rp-orders-panel {
  border-color: rgba(255,255,255,.09) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.012)),
    #20232d !important;
}

.respawn-account-orders-page .rp-orders-layout {
  grid-template-columns: minmax(0, 1fr) 340px !important;
  gap: 18px !important;
}

.respawn-account-orders-page .rp-orders-panel {
  border-radius: 14px !important;
}

.respawn-account-orders-page .rp-orders-card {
  background:
    linear-gradient(180deg, rgba(255,255,255,.024), rgba(255,255,255,.010)),
    #171922 !important;
}

.respawn-account-orders-page .rp-orders-layout.is-empty .rp-orders-panel-head {
  display: none !important;
}

.respawn-account-orders-page .rp-orders-layout.is-empty .rp-orders-panel-main {
  padding: 30px !important;
}

.respawn-account-orders-page .rp-orders-empty-state {
  min-height: 260px !important;
  padding: 28px 22px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
}

.respawn-account-orders-page .rp-orders-empty-icon {
  width: 64px !important;
  height: 64px !important;
  margin-bottom: 16px !important;
}

.respawn-account-orders-page .rp-orders-empty-state h4 {
  font-size: 30px !important;
}

.respawn-account-orders-page .rp-orders-empty-actions {
  margin-top: 20px !important;
}

@media (max-width: 1180px) {
  .respawn-account-orders-page .rp-orders-header,
  .respawn-account-orders-page .rp-orders-layout {
    grid-template-columns: 1fr !important;
  }

  .respawn-account-orders-page .rp-orders-summary {
    max-width: none !important;
  }
}

@media (max-width: 720px) {
  .respawn-account-orders-page .respawn-page-shell {
    width: min(100% - 32px, 680px) !important;
  }

  .respawn-account-orders-page .respawn-page-hero {
    padding-top: 30px !important;
  }

  .respawn-account-orders-page .respawn-page-content-section {
    padding-top: 8px !important;
  }

  .respawn-account-orders-page .rp-orders-layout.is-empty .rp-orders-panel-main {
    padding: 22px !important;
  }
}

/* =========================================================
   Respawn PCs - My Account Addresses page
   Scope: /my-account/edit-address/ only. Calm, no glow.
========================================================= */

.respawn-account-addresses-page {
  min-height: calc(100vh - 250px) !important;
  background: #171922 !important;
}

.respawn-account-addresses-page .respawn-page-hero {
  padding: 36px 0 18px !important;
  border-bottom: 0 !important;
  background: #171922 !important;
}

.respawn-account-addresses-page .respawn-page-shell {
  width: min(1320px, calc(100% - 56px)) !important;
  max-width: 1320px !important;
}

.respawn-account-addresses-page .respawn-account-addresses-hero {
  max-width: 720px !important;
}

.respawn-account-addresses-page .respawn-page-eyebrow {
  margin: 0 0 10px !important;
  color: #8b5cf6 !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  text-transform: uppercase !important;
}

.respawn-account-addresses-page .respawn-page-hero h1 {
  margin: 0 0 12px !important;
  color: #f5f7fb !important;
  font-size: clamp(42px, 4vw, 64px) !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  font-weight: 760 !important;
}

.respawn-account-addresses-page .respawn-page-subtitle {
  max-width: 620px !important;
  margin: 0 !important;
  color: rgba(245,247,251,.70) !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
}

.respawn-account-addresses-page .respawn-account-hero-summary {
  display: none !important;
}

.respawn-account-addresses-page .respawn-page-content-section {
  padding: 12px 0 80px !important;
  background: #171922 !important;
}

.respawn-account-addresses-page .respawn-page-content-card,
.respawn-account-addresses-page .woocommerce,
.respawn-account-addresses-page .woocommerce-MyAccount-content {
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.respawn-account-addresses-page .woocommerce-MyAccount-navigation {
  margin-bottom: 22px !important;
}

.respawn-account-addresses-page .rp-addresses-view {
  width: min(1320px, 100%) !important;
  margin: 0 auto !important;
  color: #f5f7fb !important;
}

.respawn-account-addresses-page .rp-addresses-header {
  max-width: 760px !important;
  margin: 0 0 22px !important;
}

.respawn-account-addresses-page .rp-addresses-kicker,
.respawn-account-addresses-page .rp-address-card-label {
  display: block !important;
  color: #8b5cf6 !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  text-transform: uppercase !important;
}

.respawn-account-addresses-page .rp-addresses-kicker {
  margin-bottom: 10px !important;
}

.respawn-account-addresses-page .rp-addresses-header h2 {
  margin: 0 !important;
  color: #fff !important;
  font-size: 32px !important;
  line-height: 1.1 !important;
  font-weight: 760 !important;
  letter-spacing: 0 !important;
}

.respawn-account-addresses-page .rp-addresses-header p {
  max-width: 720px !important;
  margin: 10px 0 0 !important;
  color: rgba(245,247,251,.70) !important;
  font-size: 15px !important;
  line-height: 1.7 !important;
}

.respawn-account-addresses-page .rp-addresses-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

.respawn-account-addresses-page .rp-address-card {
  min-height: 260px !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 24px !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 14px !important;
  background: #20232d !important;
  box-shadow: none !important;
}

.respawn-account-addresses-page .rp-address-card-top {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 18px !important;
  padding-bottom: 20px !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
}

.respawn-account-addresses-page .rp-address-card h3 {
  margin: 6px 0 0 !important;
  color: #fff !important;
  font-size: 24px !important;
  line-height: 1.1 !important;
  font-weight: 760 !important;
  letter-spacing: 0 !important;
}

.respawn-account-addresses-page .rp-address-edit {
  min-height: 40px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 16px !important;
  border: 1px solid rgba(139,92,246,.44) !important;
  border-radius: 10px !important;
  background: #8b5cf6 !important;
  color: #fff !important;
  font-size: 14px !important;
  font-weight: 820 !important;
  line-height: 1 !important;
  text-decoration: none !important;
}

.respawn-account-addresses-page .rp-address-edit:hover {
  background: #9b6cff !important;
  color: #fff !important;
}

.respawn-account-addresses-page .rp-address-card-body {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  padding-top: 22px !important;
}

.respawn-account-addresses-page .rp-address-card address {
  margin: 0 !important;
  color: rgba(245,247,251,.78) !important;
  font-size: 15px !important;
  line-height: 1.75 !important;
  font-style: normal !important;
}

.respawn-account-addresses-page .rp-address-empty strong {
  display: block !important;
  margin: 0 0 8px !important;
  color: #f5f7fb !important;
  font-size: 18px !important;
  line-height: 1.2 !important;
  font-weight: 760 !important;
}

.respawn-account-addresses-page .rp-address-empty p {
  max-width: 420px !important;
  margin: 0 !important;
  color: rgba(245,247,251,.70) !important;
  font-size: 15px !important;
  line-height: 1.65 !important;
}

@media (max-width: 900px) {
  .respawn-account-addresses-page .rp-addresses-grid {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 720px) {
  .respawn-account-addresses-page .respawn-page-shell {
    width: min(100% - 32px, 680px) !important;
  }

  .respawn-account-addresses-page .respawn-page-hero {
    padding-top: 30px !important;
  }

  .respawn-account-addresses-page .respawn-page-content-section {
    padding-top: 8px !important;
  }

  .respawn-account-addresses-page .rp-address-card {
    min-height: 0 !important;
    padding: 20px !important;
  }

  .respawn-account-addresses-page .rp-address-card-top {
    flex-direction: column !important;
  }

  .respawn-account-addresses-page .rp-address-edit {
    width: 100% !important;
  }
}

/* =========================================================
   Respawn PCs - My Account background glow removal
   Scope: account pages only. Header/navbar/footer untouched.
========================================================= */

.respawn-account-page,
.respawn-account-page .respawn-page-hero,
.respawn-account-page .respawn-page-content-section,
.respawn-account-dashboard-page .respawn-page-hero,
.respawn-account-dashboard-page .respawn-page-content-section,
.respawn-account-orders-page .respawn-page-hero,
.respawn-account-orders-page .respawn-page-content-section,
.respawn-account-addresses-page .respawn-page-hero,
.respawn-account-addresses-page .respawn-page-content-section {
  background: #171922 !important;
  background-image: none !important;
}

.respawn-account-page .respawn-page-content-card,
.respawn-account-page .woocommerce,
.respawn-account-page .woocommerce-MyAccount-content {
  background-image: none !important;
}

/* =========================================================
   Respawn PCs - 404 page
========================================================= */

.rp-404-page {
  min-height: calc(100vh - 260px);
  display: flex;
  align-items: center;
  background: #171922;
  color: #f5f7fb;
}

.rp-404-shell {
  width: min(1120px, calc(100% - 48px));
  margin: 0 auto;
  padding: 82px 0;
}

.rp-404-panel {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  gap: clamp(28px, 5vw, 64px);
  align-items: center;
  padding: clamp(28px, 4vw, 48px);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 16px;
  background: #20232d;
}

.rp-404-code {
  width: 148px;
  height: 148px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(139,92,246,.35);
  border-radius: 14px;
  color: #c8adff;
  font-size: 42px;
  line-height: 1;
  font-weight: 860;
}

.rp-404-copy {
  max-width: 660px;
}

.rp-404-kicker {
  margin: 0 0 10px;
  color: #8b5cf6;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.rp-404-copy h1 {
  margin: 0;
  color: #fff;
  font-size: clamp(38px, 4vw, 64px);
  line-height: 1;
  letter-spacing: 0;
  font-weight: 760;
}

.rp-404-copy p:not(.rp-404-kicker) {
  max-width: 560px;
  margin: 14px 0 0;
  color: rgba(245,247,251,.70);
  font-size: 16px;
  line-height: 1.65;
}

.rp-404-actions {
  grid-column: 2;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin-top: -28px;
}

.rp-404-button {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 18px;
  border: 1px solid rgba(139,92,246,.42);
  border-radius: 10px;
  background: transparent;
  color: #c8adff;
  font-size: 14px;
  font-weight: 820;
  line-height: 1;
  text-decoration: none;
}

.rp-404-button-primary {
  border-color: transparent;
  background: #8b5cf6;
  color: #fff;
}

.rp-404-button:hover,
.rp-404-link:hover {
  color: #fff;
}

.rp-404-button-primary:hover {
  background: #9b6cff;
}

.rp-404-link {
  color: rgba(245,247,251,.72);
  font-size: 14px;
  font-weight: 780;
  text-decoration: none;
}

@media (max-width: 760px) {
  .rp-404-page {
    align-items: flex-start;
  }

  .rp-404-shell {
    width: min(100% - 32px, 640px);
    padding: 56px 0 72px;
  }

  .rp-404-panel {
    grid-template-columns: 1fr;
  }

  .rp-404-code {
    width: 112px;
    height: 112px;
    font-size: 32px;
  }

  .rp-404-actions {
    grid-column: auto;
    margin-top: 0;
  }

  .rp-404-button,
  .rp-404-link {
    width: 100%;
  }
}

/* =========================================================
   Respawn PCs - My Account Account Details page
   Scope: /my-account/edit-account/ only. No glow.
========================================================= */

.respawn-account-details-page {
  min-height: calc(100vh - 250px) !important;
  background: #171922 !important;
}

.respawn-account-details-page .respawn-page-hero {
  padding: 36px 0 18px !important;
  border-bottom: 0 !important;
  background: #171922 !important;
  background-image: none !important;
}

.respawn-account-details-page .respawn-page-shell {
  width: min(1320px, calc(100% - 56px)) !important;
  max-width: 1320px !important;
}

.respawn-account-details-page .respawn-account-details-hero {
  max-width: 760px !important;
}

.respawn-account-details-page .respawn-page-eyebrow {
  margin: 0 0 10px !important;
  color: #8b5cf6 !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  text-transform: uppercase !important;
}

.respawn-account-details-page .respawn-page-hero h1 {
  margin: 0 0 12px !important;
  color: #f5f7fb !important;
  font-size: clamp(42px, 4vw, 64px) !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  font-weight: 760 !important;
}

.respawn-account-details-page .respawn-page-subtitle {
  max-width: 640px !important;
  margin: 0 !important;
  color: rgba(245,247,251,.70) !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
}

.respawn-account-details-page .respawn-account-hero-summary {
  display: none !important;
}

.respawn-account-details-page .respawn-page-content-section {
  padding: 12px 0 80px !important;
  background: #171922 !important;
  background-image: none !important;
}

.respawn-account-details-page .respawn-page-content-card,
.respawn-account-details-page .woocommerce,
.respawn-account-details-page .woocommerce-MyAccount-content {
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
}

.respawn-account-details-page .woocommerce-MyAccount-navigation {
  margin-bottom: 22px !important;
}

.respawn-account-details-page .rp-account-details-view {
  width: min(1320px, 100%) !important;
  margin: 0 auto !important;
  color: #f5f7fb !important;
}

.respawn-account-details-page .rp-account-details-header {
  max-width: 760px !important;
  margin: 0 0 22px !important;
}

.respawn-account-details-page .rp-account-details-kicker,
.respawn-account-details-page .rp-account-details-panel-label {
  display: block !important;
  color: #8b5cf6 !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  text-transform: uppercase !important;
}

.respawn-account-details-page .rp-account-details-kicker {
  margin-bottom: 10px !important;
}

.respawn-account-details-page .rp-account-details-header h2 {
  margin: 0 !important;
  color: #fff !important;
  font-size: 32px !important;
  line-height: 1.1 !important;
  font-weight: 760 !important;
  letter-spacing: 0 !important;
}

.respawn-account-details-page .rp-account-details-header p {
  max-width: 720px !important;
  margin: 10px 0 0 !important;
  color: rgba(245,247,251,.70) !important;
  font-size: 15px !important;
  line-height: 1.7 !important;
}

.respawn-account-details-page .rp-account-details-form {
  display: grid !important;
  gap: 18px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.respawn-account-details-page .rp-account-details-panel {
  padding: 24px !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 14px !important;
  background: #20232d !important;
  box-shadow: none !important;
}

.respawn-account-details-page .rp-account-details-panel-head {
  max-width: 760px !important;
  margin: 0 0 22px !important;
  padding-bottom: 20px !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
}

.respawn-account-details-page .rp-account-details-panel h3 {
  margin: 6px 0 0 !important;
  color: #fff !important;
  font-size: 24px !important;
  line-height: 1.1 !important;
  font-weight: 760 !important;
  letter-spacing: 0 !important;
}

.respawn-account-details-page .rp-account-details-panel-head p,
.respawn-account-details-page .rp-account-details-help {
  max-width: 620px !important;
  margin: 8px 0 0 !important;
  color: rgba(245,247,251,.70) !important;
  font-size: 14px !important;
  line-height: 1.65 !important;
}

.respawn-account-details-page .rp-account-details-fields {
  display: grid !important;
  gap: 16px !important;
}

.respawn-account-details-page .rp-account-details-fields-two {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.respawn-account-details-page .rp-account-details-form .form-row {
  float: none !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 0 16px !important;
  padding: 0 !important;
}

.respawn-account-details-page .rp-account-details-form .form-row:last-child {
  margin-bottom: 0 !important;
}

.respawn-account-details-page .rp-account-details-form label {
  display: block !important;
  margin: 0 0 8px !important;
  color: rgba(245,247,251,.88) !important;
  font-size: 13px !important;
  font-weight: 820 !important;
  line-height: 1.3 !important;
}

.respawn-account-details-page .rp-account-details-form .required {
  color: #8b5cf6 !important;
}

.respawn-account-details-page .rp-account-details-form input.input-text,
.respawn-account-details-page .rp-account-details-form input[type="text"],
.respawn-account-details-page .rp-account-details-form input[type="email"],
.respawn-account-details-page .rp-account-details-form input[type="password"] {
  width: 100% !important;
  min-height: 48px !important;
  padding: 0 14px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 10px !important;
  background: #171922 !important;
  color: #f5f7fb !important;
  font-size: 15px !important;
  line-height: 1.2 !important;
  box-shadow: none !important;
  outline: none !important;
}

.respawn-account-details-page .rp-account-details-form input:focus {
  border-color: rgba(139,92,246,.62) !important;
  box-shadow: 0 0 0 3px rgba(139,92,246,.14) !important;
}

.respawn-account-details-page .rp-account-details-help {
  display: block !important;
}

.respawn-account-details-page .rp-account-consent-field {
  display: grid !important;
  gap: 8px !important;
}

.respawn-account-details-page .rp-account-details-form .rp-account-checkbox {
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
  margin: 0 !important;
  color: rgba(245,247,251,.86) !important;
}

.respawn-account-details-page .rp-account-details-form .rp-account-checkbox input[type="checkbox"] {
  flex: 0 0 18px !important;
  width: 18px !important;
  height: 18px !important;
  min-height: 18px !important;
  margin: 2px 0 0 !important;
  padding: 0 !important;
  accent-color: #8b5cf6 !important;
  box-shadow: none !important;
  cursor: pointer !important;
}

.respawn-account-details-page .rp-account-details-form .rp-account-checkbox span {
  display: block !important;
  color: rgba(245,247,251,.86) !important;
  font-size: 14px !important;
  font-weight: 760 !important;
  line-height: 1.55 !important;
}

.respawn-account-details-page .rp-account-details-password-fields {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
}

.respawn-account-details-page .rp-account-details-actions {
  display: flex !important;
  justify-content: flex-end !important;
  padding: 0 !important;
  margin: 2px 0 0 !important;
}

.respawn-account-details-page .rp-account-details-save,
.respawn-account-details-page .woocommerce button.rp-account-details-save {
  min-height: 46px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 22px !important;
  border: 1px solid transparent !important;
  border-radius: 10px !important;
  background: #8b5cf6 !important;
  color: #fff !important;
  font-size: 14px !important;
  font-weight: 840 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

.respawn-account-details-page .rp-account-details-save:hover,
.respawn-account-details-page .woocommerce button.rp-account-details-save:hover {
  background: #9b6cff !important;
  color: #fff !important;
}

.respawn-account-details-page .woocommerce form.edit-account.rp-account-details-form,
.respawn-account-details-page .woocommerce form.woocommerce-EditAccountForm.rp-account-details-form {
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
}

.respawn-account-details-page .woocommerce form.edit-account .rp-account-details-password-fields,
.respawn-account-details-page .woocommerce form.woocommerce-EditAccountForm .rp-account-details-password-fields {
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
}

@media (max-width: 820px) {
  .respawn-account-details-page .rp-account-details-fields-two {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 720px) {
  .respawn-account-details-page .respawn-page-shell {
    width: min(100% - 32px, 680px) !important;
  }

  .respawn-account-details-page .respawn-page-hero {
    padding-top: 30px !important;
  }

  .respawn-account-details-page .respawn-page-content-section {
    padding-top: 8px !important;
  }

  .respawn-account-details-page .rp-account-details-panel {
    padding: 20px !important;
  }

  .respawn-account-details-page .rp-account-details-actions,
  .respawn-account-details-page .rp-account-details-save {
    width: 100% !important;
  }
}

/* ---------------------------------------------------------
   Logout confirmation modal
--------------------------------------------------------- */
.rp-logout-confirm[hidden] {
  display: none !important;
}

.rp-logout-confirm {
  position: fixed;
  inset: 0;
  z-index: 100000;
  display: grid;
  place-items: center;
  padding: 24px;
}

.rp-logout-confirm__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 17, 23, 0.78);
}

.rp-logout-confirm__dialog {
  position: relative;
  width: min(100%, 440px);
  padding: 28px;
  border: 1px solid rgba(255, 255, 255, 0.10);
  border-radius: 18px;
  background: #20232d;
  color: #f5f7fb;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.34);
}

.rp-logout-confirm__kicker {
  margin: 0 0 8px;
  color: #8b5cf6;
  font-size: 12px;
  font-weight: 850;
  letter-spacing: 0;
  text-transform: uppercase;
}

.rp-logout-confirm__dialog h2 {
  margin: 0 0 10px;
  color: #f5f7fb;
  font-size: clamp(26px, 4vw, 34px);
  line-height: 1.05;
  letter-spacing: 0;
}

.rp-logout-confirm__dialog p:not(.rp-logout-confirm__kicker) {
  margin: 0;
  color: rgba(245, 247, 251, 0.70);
  font-size: 15px;
  line-height: 1.6;
}

.rp-logout-confirm__actions {
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  margin-top: 24px;
}

.rp-logout-confirm__button {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 18px;
  border: 1px solid rgba(255, 255, 255, 0.10);
  border-radius: 10px;
  background: transparent;
  color: #f5f7fb;
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  box-shadow: none;
}

.rp-logout-confirm__button:hover,
.rp-logout-confirm__button:focus {
  border-color: rgba(139, 92, 246, 0.55);
  color: #f5f7fb;
}

.rp-logout-confirm__button-primary {
  border-color: transparent;
  background: #8b5cf6;
  color: #fff;
}

.rp-logout-confirm__button-primary:hover,
.rp-logout-confirm__button-primary:focus {
  background: #9b6cff;
  color: #fff;
}

.rp-logout-confirm-open {
  overflow: hidden;
}

@media (max-width: 520px) {
  .rp-logout-confirm {
    align-items: end;
    padding: 14px;
  }

  .rp-logout-confirm__dialog {
    padding: 22px;
    border-radius: 16px;
  }

  .rp-logout-confirm__actions {
    flex-direction: column-reverse;
  }

  .rp-logout-confirm__button {
    width: 100%;
  }
}

/* ---------------------------------------------------------
   Header account dropdown - match compact shop dropdown
--------------------------------------------------------- */
.rsp-clean-account-panel--logged-in {
  width: 292px !important;
  padding: 10px !important;
  border: 1px solid rgba(255,255,255,.095) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.018)),
    #111116 !important;
  box-shadow: 0 28px 80px rgba(0,0,0,.42) !important;
  overflow: visible !important;
}

.rsp-clean-account-panel--logged-in .rsp-clean-account-top {
  display: none !important;
}

.rsp-clean-account-panel--logged-in .rsp-clean-account-links {
  display: block !important;
}

.rsp-clean-account-panel--logged-in .rsp-clean-account-link {
  display: block !important;
  min-height: 0 !important;
  padding: 13px 14px !important;
  margin: 0 !important;
  border: 1px solid transparent !important;
  border-radius: 13px !important;
  background: transparent !important;
  color: #fff !important;
  text-decoration: none !important;
  transform: none !important;
  box-shadow: none !important;
  transition: background .16s ease, border-color .16s ease !important;
}

.rsp-clean-account-panel--logged-in .rsp-clean-account-link + .rsp-clean-account-link {
  margin-top: 3px !important;
}

.rsp-clean-account-panel--logged-in .rsp-clean-account-link:hover,
.rsp-clean-account-panel--logged-in .rsp-clean-account-link:focus {
  border-color: rgba(255,255,255,.065) !important;
  background: rgba(255,255,255,.045) !important;
  box-shadow: none !important;
  transform: none !important;
}

.rsp-clean-account-panel--logged-in .rsp-clean-account-link-icon,
.rsp-clean-account-panel--logged-in .rsp-clean-account-link-arrow {
  display: none !important;
}

.rsp-clean-account-panel--logged-in .rsp-clean-account-link-copy {
  display: block !important;
}

.rsp-clean-account-panel--logged-in .rsp-clean-account-link-copy strong {
  display: block !important;
  margin: 0 !important;
  color: #fff !important;
  font-size: 14px !important;
  line-height: 1.15 !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
}

.rsp-clean-account-panel--logged-in .rsp-clean-account-link-copy small {
  display: block !important;
  margin-top: 4px !important;
  color: rgba(247,247,248,.66) !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
  font-weight: 650 !important;
}

.rsp-clean-account-panel--logged-in .rsp-clean-account-link--logout .rsp-clean-account-link-copy strong {
  color: #ffb8b8 !important;
}

.rsp-clean-account-panel--logged-in .rsp-clean-account-link--logout:hover,
.rsp-clean-account-panel--logged-in .rsp-clean-account-link--logout:focus {
  border-color: rgba(255,120,120,.12) !important;
  background: rgba(255,120,120,.045) !important;
}

@media (max-width: 680px) {
  .rsp-clean-account-panel--logged-in {
    width: min(292px, calc(100vw - 34px)) !important;
  }
}

/* ---------------------------------------------------------
   Header action buttons - boxed, no glow
--------------------------------------------------------- */
.rsp-clean-action,
.rsp-clean-account-trigger.is-logged-in {
  border-radius: 10px !important;
  border-color: rgba(255,255,255,.10) !important;
  background: #20232d !important;
  box-shadow: none !important;
}

.rsp-clean-action:hover,
.rsp-clean-account:hover .rsp-clean-action,
.rsp-clean-account:focus-within .rsp-clean-action {
  border-color: rgba(255,255,255,.16) !important;
  background: #252936 !important;
  box-shadow: none !important;
  transform: none !important;
}

.rsp-clean-basket b {
  box-shadow: none !important;
}

/* ---------------------------------------------------------
   Homepage hero price and reassurance tidy
--------------------------------------------------------- */
.hero .price-row {
  align-items: flex-end !important;
  gap: 14px !important;
}

.hero .finance-box {
  align-self: auto !important;
  min-width: 0 !important;
  display: inline-flex !important;
  align-items: baseline !important;
  gap: 6px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  margin-bottom: 7px !important;
}

.hero .finance-box::before {
  content: none !important;
}

.hero .finance-box span,
.hero .finance-box strong {
  display: inline !important;
  margin: 0 !important;
  letter-spacing: 0 !important;
  line-height: 1.2 !important;
}

.hero .finance-box span {
  color: rgba(247,247,248,.56) !important;
  font-size: 12px !important;
  font-weight: 760 !important;
  text-transform: none !important;
}

.hero .finance-box strong {
  color: rgba(247,247,248,.86) !important;
  font-size: 14px !important;
  font-weight: 850 !important;
}

.hero .conversion-strip {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px 18px !important;
  margin-top: 16px !important;
  color: rgba(247,247,248,.76) !important;
  font-size: 14px !important;
  font-weight: 760 !important;
  line-height: 1.45 !important;
}

.hero .conversion-strip span {
  display: inline-flex !important;
  align-items: center !important;
  min-width: 0 !important;
}

@media (max-width: 760px) {
  .hero .price-row {
    align-items: flex-start !important;
    flex-direction: column !important;
    gap: 8px !important;
  }

.hero .finance-box {
    margin-bottom: 0 !important;
  }

  .hero .conversion-strip {
    margin-top: 14px !important;
    gap: 7px 14px !important;
    font-size: 13px !important;
  }
}

/* ---------------------------------------------------------
   My Account address edit form and dropdowns
--------------------------------------------------------- */
.respawn-account-addresses-page .woocommerce form .woocommerce-address-fields__field-wrapper {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 16px 28px !important;
}

.respawn-account-addresses-page .woocommerce form .form-row {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
}

.respawn-account-addresses-page .woocommerce form .form-row-wide,
.respawn-account-addresses-page .woocommerce form #billing_country_field,
.respawn-account-addresses-page .woocommerce form #shipping_country_field,
.respawn-account-addresses-page .woocommerce form #billing_state_field,
.respawn-account-addresses-page .woocommerce form #shipping_state_field,
.respawn-account-addresses-page .woocommerce form #billing_address_1_field,
.respawn-account-addresses-page .woocommerce form #shipping_address_1_field,
.respawn-account-addresses-page .woocommerce form #billing_address_2_field,
.respawn-account-addresses-page .woocommerce form #shipping_address_2_field {
  grid-column: 1 / -1 !important;
}

.respawn-account-addresses-page .woocommerce form h2 {
  margin: 0 0 22px !important;
  color: #f5f7fb !important;
  font-size: 34px !important;
  line-height: 1.1 !important;
  letter-spacing: 0 !important;
  font-weight: 760 !important;
}

.respawn-account-addresses-page .woocommerce form label {
  color: rgba(245,247,251,.74) !important;
  font-size: 13px !important;
  font-weight: 840 !important;
}

.respawn-account-addresses-page .woocommerce form .required {
  color: #8b5cf6 !important;
  text-decoration: none !important;
}

.respawn-account-addresses-page .woocommerce input.input-text,
.respawn-account-addresses-page .woocommerce input[type="text"],
.respawn-account-addresses-page .woocommerce input[type="tel"],
.respawn-account-addresses-page .woocommerce input[type="email"],
.respawn-account-addresses-page .woocommerce select,
.respawn-account-addresses-page .select2-container--default .select2-selection--single {
  min-height: 52px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 12px !important;
  background: #20232d !important;
  color: #f5f7fb !important;
  box-shadow: none !important;
}

.respawn-account-addresses-page .woocommerce select option {
  background: #20232d !important;
  color: #f5f7fb !important;
}

.respawn-account-addresses-page .select2-container--default .select2-selection--single {
  display: flex !important;
  align-items: center !important;
  padding: 0 14px !important;
}

.respawn-account-addresses-page .select2-container--default .select2-selection--single .select2-selection__rendered {
  padding: 0 !important;
  color: #f5f7fb !important;
  line-height: 1.2 !important;
}

.respawn-account-addresses-page .select2-container--default .select2-selection--single .select2-selection__arrow {
  top: 50% !important;
  right: 12px !important;
  transform: translateY(-50%) !important;
}

body.respawn-account-addresses-page .select2-dropdown {
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 12px !important;
  background: #20232d !important;
  color: #f5f7fb !important;
  overflow: hidden !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.38) !important;
}

body.respawn-account-addresses-page .select2-search--dropdown {
  padding: 8px !important;
  background: #20232d !important;
}

body.respawn-account-addresses-page .select2-search--dropdown .select2-search__field {
  min-height: 40px !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 9px !important;
  background: #171922 !important;
  color: #f5f7fb !important;
  outline: none !important;
}

body.respawn-account-addresses-page .select2-results__options {
  background: #20232d !important;
  color: #f5f7fb !important;
}

body.respawn-account-addresses-page .select2-results__option {
  color: rgba(245,247,251,.82) !important;
  background: #20232d !important;
}

body.respawn-account-addresses-page .select2-results__option[aria-selected="true"],
body.respawn-account-addresses-page .select2-results__option--highlighted[aria-selected] {
  background: #8b5cf6 !important;
  color: #fff !important;
}

@media (max-width: 760px) {
  .respawn-account-addresses-page .woocommerce form .woocommerce-address-fields__field-wrapper {
    grid-template-columns: 1fr !important;
  }
}

/* ---------------------------------------------------------
   Respawn PCs customer registration page
--------------------------------------------------------- */
.rp-register-page {
  min-height: calc(100vh - 72px);
  background: #171922;
  color: #f5f7fb;
}

.rp-register-shell {
  width: min(1180px, calc(100% - 56px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(360px, 520px);
  column-gap: clamp(34px, 6vw, 82px);
  row-gap: 26px;
  align-items: center;
  padding: 56px 0 70px;
}

.rp-register-copy {
  max-width: 650px;
}

.rp-register-kicker {
  display: block;
  margin-bottom: 12px;
  color: #8b5cf6;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.rp-register-copy h1 {
  margin: 0;
  color: #f5f7fb;
  font-size: clamp(48px, 5.2vw, 76px);
  line-height: 0.96;
  letter-spacing: 0;
  font-weight: 780;
}

.rp-register-copy p {
  max-width: 590px;
  margin: 20px 0 0;
  color: rgba(245,247,251,.70);
  font-size: 17px;
  line-height: 1.7;
}

.rp-register-benefits {
  display: grid;
  gap: 10px;
  margin-top: 30px;
}

.rp-register-benefits span {
  position: relative;
  padding-left: 18px;
  color: rgba(245,247,251,.82);
  font-size: 15px;
  font-weight: 760;
  line-height: 1.45;
}

.rp-register-benefits span::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.65em;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #8b5cf6;
}

.rp-register-panel {
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  background: #20232d;
  padding: clamp(22px, 2.4vw, 32px);
}

.rp-register-flow {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 0;
}

.rp-register-flow article {
  min-width: 0;
  padding: 18px;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 12px;
  background: #20232d;
}

.rp-register-flow span {
  display: block;
  margin-bottom: 10px;
  color: #8b5cf6;
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
}

.rp-register-flow strong {
  display: block;
  color: #f5f7fb;
  font-size: 16px;
  font-weight: 820;
  line-height: 1.25;
}

.rp-register-flow p {
  margin: 8px 0 0;
  color: rgba(245,247,251,.68);
  font-size: 13px;
  line-height: 1.55;
}

.rp-register-form {
  display: grid;
  gap: 16px;
}

.rp-register-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.rp-register-field {
  display: grid;
  gap: 8px;
}

.rp-register-field label {
  color: rgba(245,247,251,.76);
  font-size: 13px;
  font-weight: 820;
  line-height: 1.2;
}

.rp-register-field input {
  width: 100%;
  min-height: 50px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 10px;
  background: #171922;
  color: #f5f7fb;
  padding: 0 14px;
  font: inherit;
  font-size: 14px;
  font-weight: 720;
  outline: none;
  box-shadow: none;
}

.rp-register-field input:focus {
  border-color: rgba(139,92,246,.62);
}

.rp-register-consents {
  display: grid;
  gap: 12px;
  margin-top: 2px;
}

.rp-register-checkbox {
  position: relative;
  display: block;
  color: rgba(245,247,251,.82);
  font-size: 14px;
  font-weight: 720;
  line-height: 1.55;
  cursor: pointer;
}

.rp-register-checkbox input[type="checkbox"] {
  position: absolute;
  left: 0;
  top: 2px;
  width: 22px;
  height: 22px;
  margin: 0;
  opacity: 0;
  cursor: pointer;
}

.rp-register-checkbox span {
  position: relative;
  display: block;
  min-height: 22px;
  padding-left: 34px;
}

.rp-register-checkbox span::before {
  content: "";
  position: absolute;
  left: 0;
  top: 1px;
  width: 20px;
  height: 20px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 6px;
  background: #171922;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
  transition: background .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.rp-register-checkbox span::after {
  content: "";
  position: absolute;
  left: 7px;
  top: 5px;
  width: 5px;
  height: 10px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  opacity: 0;
  transform: rotate(45deg) scale(.75);
  transition: opacity .18s ease, transform .18s ease;
}

.rp-register-checkbox input[type="checkbox"]:checked + span::before {
  border-color: rgba(139,92,246,.70);
  background: #8b5cf6;
  box-shadow: 0 0 0 3px rgba(139,92,246,.14);
}

.rp-register-checkbox input[type="checkbox"]:checked + span::after {
  opacity: 1;
  transform: rotate(45deg) scale(1);
}

.rp-register-checkbox input[type="checkbox"]:focus-visible + span::before {
  outline: 2px solid rgba(139,92,246,.38);
  outline-offset: 3px;
}

.rp-register-checkbox a {
  color: #c7b0ff;
  font-weight: 820;
  text-decoration: none;
}

.rp-register-checkbox a:hover {
  color: #fff;
}

.rp-register-submit,
.rp-register-resend button {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid transparent;
  border-radius: 10px;
  background: #8b5cf6;
  color: #fff;
  padding: 0 20px;
  font: inherit;
  font-size: 14px;
  font-weight: 840;
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  box-shadow: none;
}

.rp-register-submit:hover,
.rp-register-resend button:hover {
  background: #9b6cff;
  color: #fff;
}

.rp-register-resend {
  margin-top: 14px;
}

.rp-register-resend button {
  width: 100%;
  border-color: rgba(255,255,255,.10);
  background: transparent;
  color: #f5f7fb;
}

.rp-register-resend button:hover {
  border-color: rgba(139,92,246,.55);
  background: rgba(139,92,246,.12);
}

.rp-register-login-link {
  margin: 18px 0 0;
  color: rgba(245,247,251,.70);
  font-size: 14px;
  line-height: 1.5;
}

.rp-register-login-link a {
  color: #c7b0ff;
  font-weight: 820;
  text-decoration: none;
}

.rp-register-notice {
  display: grid;
  gap: 6px;
  margin: 0 0 16px;
  padding: 14px 16px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 12px;
  background: #171922;
  color: rgba(245,247,251,.78);
  font-size: 14px;
  line-height: 1.55;
}

.rp-register-notice p {
  margin: 0;
}

.rp-register-notice-error {
  border-color: rgba(248,113,113,.36);
  color: #ffd3d3;
}

.rp-register-notice-info {
  border-color: rgba(139,92,246,.34);
}

.rp-register-notice-dev {
  border-color: rgba(250,204,21,.38);
  color: #fff4bd;
}

.rp-register-notice-dev strong {
  color: #fff;
}

@media (max-width: 900px) {
  .rp-register-shell {
    grid-template-columns: 1fr;
    align-items: start;
    padding-top: 48px;
    gap: 28px;
  }

  .rp-register-panel {
    max-width: 620px;
  }

  .rp-register-flow {
    grid-template-columns: 1fr;
    margin-top: 0;
  }
}

@media (max-width: 600px) {
  .rp-register-shell {
    width: min(100% - 32px, 1180px);
    padding: 34px 0 58px;
  }

  .rp-register-grid {
    grid-template-columns: 1fr;
  }
}

/* ---------------------------------------------------------
   Respawn PCs My Account login entry
--------------------------------------------------------- */
.respawn-account-page .rp-account-login-entry {
  width: min(1120px, 100%) !important;
  margin: 24px auto 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 420px) !important;
  gap: 18px !important;
  align-items: stretch !important;
  color: #f5f7fb !important;
}

.respawn-account-page .rp-account-login-panel,
.respawn-account-page .rp-account-login-side {
  min-width: 0 !important;
  padding: clamp(22px, 2.4vw, 30px) !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 14px !important;
  background: #20232d !important;
  box-shadow: none !important;
}

.respawn-account-page .rp-account-login-panel {
  display: grid !important;
  align-content: start !important;
}

.respawn-account-page .rp-account-login-side {
  display: flex !important;
  flex-direction: column !important;
}

.respawn-account-page .rp-account-login-kicker {
  display: block !important;
  margin: 0 0 10px !important;
  color: #8b5cf6 !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
}

.respawn-account-page .woocommerce .rp-account-login-entry h2 {
  margin: 0 !important;
  color: #f5f7fb !important;
  font-size: clamp(28px, 2.5vw, 40px) !important;
  font-weight: 760 !important;
  line-height: 1.08 !important;
  letter-spacing: 0 !important;
}

.respawn-account-page .rp-account-login-entry p {
  max-width: 560px !important;
  margin: 12px 0 0 !important;
  color: rgba(245,247,251,.70) !important;
  font-size: 15px !important;
  line-height: 1.65 !important;
}

.respawn-account-page .woocommerce form.login.rp-account-login-form {
  display: grid !important;
  gap: 16px !important;
  margin: 24px 0 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.respawn-account-page .rp-account-login-form .form-row {
  margin: 0 !important;
  padding: 0 !important;
}

.respawn-account-page .rp-account-login-form label {
  display: block !important;
  margin: 0 0 8px !important;
  color: rgba(245,247,251,.82) !important;
  font-size: 13px !important;
  font-weight: 820 !important;
  line-height: 1.3 !important;
}

.respawn-account-page .rp-account-login-form input.input-text,
.respawn-account-page .rp-account-login-form input[type="text"],
.respawn-account-page .rp-account-login-form input[type="password"] {
  width: 100% !important;
  min-height: 50px !important;
  padding: 0 14px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 10px !important;
  background: #171922 !important;
  color: #f5f7fb !important;
  font-size: 15px !important;
  font-weight: 720 !important;
  box-shadow: none !important;
  outline: none !important;
}

.respawn-account-page .rp-account-login-form input:focus {
  border-color: rgba(139,92,246,.62) !important;
  box-shadow: 0 0 0 3px rgba(139,92,246,.14) !important;
}

.respawn-account-page .rp-account-login-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
}

.respawn-account-page .rp-account-login-remember {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin: 0 !important;
  color: rgba(245,247,251,.78) !important;
  position: relative !important;
  cursor: pointer !important;
}

.respawn-account-page .rp-account-login-remember input[type="checkbox"] {
  position: absolute !important;
  left: 0 !important;
  top: 50% !important;
  width: 40px !important;
  height: 24px !important;
  margin: 0 !important;
  opacity: 0 !important;
  transform: translateY(-50%) !important;
}

.respawn-account-page .rp-account-login-remember span {
  position: relative !important;
  min-height: 24px !important;
  display: inline-flex !important;
  align-items: center !important;
  padding-left: 50px !important;
  font-size: 13px !important;
  font-weight: 760 !important;
  line-height: 1.3 !important;
}

.respawn-account-page .rp-account-login-remember span::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: 50% !important;
  width: 40px !important;
  height: 24px !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 999px !important;
  background: #171922 !important;
  transform: translateY(-50%) !important;
}

.respawn-account-page .rp-account-login-remember span::after {
  content: "" !important;
  position: absolute !important;
  left: 4px !important;
  top: 50% !important;
  width: 16px !important;
  height: 16px !important;
  border-radius: 999px !important;
  background: rgba(245,247,251,.70) !important;
  transform: translateY(-50%) !important;
  transition: transform .18s ease, background .18s ease !important;
}

.respawn-account-page .rp-account-login-remember input[type="checkbox"]:checked + span::before {
  border-color: rgba(139,92,246,.52) !important;
  background: rgba(139,92,246,.28) !important;
}

.respawn-account-page .rp-account-login-remember input[type="checkbox"]:checked + span::after {
  background: #f5f7fb !important;
  transform: translate(16px, -50%) !important;
}

.respawn-account-page .rp-account-login-remember input[type="checkbox"]:focus-visible + span::before {
  outline: 2px solid rgba(139,92,246,.34) !important;
  outline-offset: 3px !important;
}

.respawn-account-page .rp-account-login-lost,
.respawn-account-page .woocommerce .rp-account-login-lost {
  min-height: 34px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 12px !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 8px !important;
  background: #171922 !important;
  color: rgba(245,247,251,.78) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  text-decoration: none !important;
}

.respawn-account-page .rp-account-login-lost:hover,
.respawn-account-page .woocommerce .rp-account-login-lost:hover {
  border-color: rgba(139,92,246,.44) !important;
  color: #f5f7fb !important;
}

.respawn-account-page .rp-account-login-submit {
  display: flex !important;
  align-items: center !important;
}

.respawn-account-page .woocommerce .rp-account-login-submit button.button {
  min-height: 46px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 22px !important;
  border: 1px solid transparent !important;
  border-radius: 10px !important;
  background: #8b5cf6 !important;
  color: #fff !important;
  font-size: 14px !important;
  font-weight: 840 !important;
  line-height: 1 !important;
  box-shadow: none !important;
}

.respawn-account-page .woocommerce .rp-account-login-submit button.button:hover {
  background: #9b6cff !important;
}

.respawn-account-page .rp-account-login-benefits {
  display: grid !important;
  gap: 10px !important;
  margin: 22px 0 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.respawn-account-page .rp-account-login-benefits li {
  position: relative !important;
  margin: 0 !important;
  padding-left: 18px !important;
  color: rgba(245,247,251,.78) !important;
  font-size: 14px !important;
  font-weight: 760 !important;
  line-height: 1.5 !important;
}

.respawn-account-page .rp-account-login-benefits li::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: .65em !important;
  width: 7px !important;
  height: 7px !important;
  border-radius: 999px !important;
  background: #8b5cf6 !important;
}

.respawn-account-page .rp-account-login-side-actions {
  display: flex !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
  margin-top: auto !important;
  padding-top: 26px !important;
}

.respawn-account-page .rp-account-login-button {
  min-height: 44px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 18px !important;
  border-radius: 10px !important;
  font-size: 14px !important;
  font-weight: 840 !important;
  line-height: 1 !important;
  text-decoration: none !important;
}

.respawn-account-page .rp-account-login-button-primary {
  border: 1px solid transparent !important;
  background: #8b5cf6 !important;
  color: #fff !important;
}

.respawn-account-page .rp-account-login-button-primary:hover {
  background: #9b6cff !important;
  color: #fff !important;
}

.respawn-account-page .rp-account-login-button-secondary {
  border: 1px solid rgba(255,255,255,.10) !important;
  background: #171922 !important;
  color: rgba(245,247,251,.86) !important;
}

.respawn-account-page .rp-account-login-button-secondary:hover {
  border-color: rgba(139,92,246,.45) !important;
  color: #fff !important;
}

@media (max-width: 900px) {
  .respawn-account-page .rp-account-login-entry {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 600px) {
  .respawn-account-page .rp-account-login-panel,
  .respawn-account-page .rp-account-login-side {
    padding: 20px !important;
  }

  .respawn-account-page .rp-account-login-row,
  .respawn-account-page .rp-account-login-submit,
  .respawn-account-page .rp-account-login-side-actions,
  .respawn-account-page .rp-account-login-button,
  .respawn-account-page .woocommerce .rp-account-login-submit button.button {
    width: 100% !important;
  }
}

/* ---------------------------------------------------------
   Respawn PCs filled basket page
--------------------------------------------------------- */
.respawn-cart-page-shell {
  min-height: calc(100vh - 250px) !important;
  background: #171922 !important;
  color: #f5f7fb !important;
}

.respawn-cart-page-shell .respawn-page-hero {
  padding: 38px 0 20px !important;
  border-bottom: 0 !important;
  background: #171922 !important;
  background-image: none !important;
  text-align: center !important;
}

.respawn-cart-page-shell .respawn-page-shell {
  width: min(1420px, calc(100% - 96px)) !important;
  max-width: 1420px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.respawn-cart-page-shell .respawn-page-eyebrow {
  display: none !important;
}

.respawn-cart-page-shell .respawn-page-hero h1 {
  margin: 0 0 12px !important;
  color: #f5f7fb !important;
  font-size: clamp(42px, 4vw, 64px) !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  font-weight: 760 !important;
}

.respawn-cart-page-shell .respawn-page-subtitle {
  max-width: 640px !important;
  margin: 0 auto !important;
  color: rgba(245,247,251,.70) !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
}

.respawn-cart-page-shell .respawn-page-content-section {
  padding: 12px 0 82px !important;
  background: #171922 !important;
  background-image: none !important;
}

.respawn-cart-page-shell .respawn-page-content-card--cart,
.respawn-cart-page-shell .woocommerce {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
}

.respawn-cart-page-shell .woocommerce-notices-wrapper {
  width: min(1320px, 100%) !important;
  margin: 0 auto 18px !important;
}

.respawn-cart-page-shell .woocommerce-error,
.respawn-cart-page-shell .woocommerce-message,
.respawn-cart-page-shell .woocommerce-info {
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 12px !important;
  padding: 14px 16px 14px 46px !important;
  margin: 0 0 18px !important;
  background: #20232d !important;
  color: rgba(245,247,251,.78) !important;
  box-shadow: none !important;
}

.respawn-cart-form {
  width: 100% !important;
  margin: 0 auto !important;
  padding: 0 !important;
}

.respawn-cart-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 410px) !important;
  gap: 24px !important;
  align-items: start !important;
}

.respawn-cart-items-panel,
.respawn-cart-summary-panel {
  min-width: 0 !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 14px !important;
  background: #20232d !important;
  box-shadow: none !important;
}

.respawn-cart-items-panel {
  overflow: hidden !important;
}

.respawn-cart-panel-head {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 18px !important;
  padding: 24px 26px !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
}

.respawn-cart-mini-label,
.respawn-cart-product-kicker,
.respawn-summary-head span,
.respawn-cart-trust span {
  display: block !important;
  color: #8b5cf6 !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
}

.respawn-cart-panel-head h2,
.respawn-summary-head h2 {
  margin: 6px 0 0 !important;
  color: #f5f7fb !important;
  font-size: 26px !important;
  line-height: 1.12 !important;
  font-weight: 760 !important;
  letter-spacing: 0 !important;
}

.respawn-cart-continue {
  min-height: 40px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 15px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 10px !important;
  background: #171922 !important;
  color: rgba(245,247,251,.88) !important;
  font-size: 14px !important;
  font-weight: 820 !important;
  line-height: 1 !important;
  text-decoration: none !important;
}

.respawn-cart-continue:hover {
  border-color: rgba(139,92,246,.45) !important;
  color: #fff !important;
}

.respawn-cart-items-list {
  display: grid !important;
  gap: 0 !important;
}

.respawn-cart-item {
  display: grid !important;
  grid-template-columns: 190px minmax(0, 1fr) !important;
  gap: 24px !important;
  padding: 26px !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
  background: transparent !important;
}

.respawn-cart-item:last-child {
  border-bottom: 0 !important;
}

.respawn-cart-item-media {
  width: 190px !important;
  aspect-ratio: 1 !important;
  display: grid !important;
  place-items: center !important;
  overflow: hidden !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 14px !important;
  background:
    radial-gradient(circle at 50% 38%, rgba(139,92,246,.16), transparent 45%),
    #171922 !important;
}

.respawn-cart-item-media a,
.respawn-cart-item-media img {
  display: block !important;
}

.respawn-cart-item-media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  padding: 18px !important;
}

.respawn-cart-item-main {
  min-width: 0 !important;
  display: grid !important;
  gap: 16px !important;
}

.respawn-cart-item-title-row {
  display: block !important;
  max-width: 760px !important;
}

.respawn-cart-item h3 {
  margin: 6px 0 0 !important;
  color: #f5f7fb !important;
  font-size: 24px !important;
  line-height: 1.18 !important;
  font-weight: 760 !important;
  letter-spacing: 0 !important;
}

.respawn-cart-item h3 a {
  color: inherit !important;
  text-decoration: none !important;
}

.respawn-cart-item h3 a:hover {
  color: #c7b0ff !important;
}

.respawn-cart-item-main p {
  max-width: 680px !important;
  margin: 9px 0 0 !important;
  color: rgba(245,247,251,.68) !important;
  font-size: 15px !important;
  line-height: 1.6 !important;
}

.respawn-cart-qty > span,
.respawn-cart-subtotal > span {
  display: block !important;
  margin-bottom: 6px !important;
  color: rgba(245,247,251,.56) !important;
  font-size: 12px !important;
  font-weight: 820 !important;
  line-height: 1.2 !important;
}

.respawn-cart-subtotal strong {
  display: block !important;
  color: #f5f7fb !important;
  font-size: 24px !important;
  line-height: 1 !important;
  font-weight: 760 !important;
}

.respawn-cart-subtotal .amount,
.respawn-summary-line .amount,
.respawn-summary-total .amount {
  white-space: nowrap !important;
}

.respawn-cart-subtotal del {
  color: rgba(245,247,251,.44) !important;
  font-size: .72em !important;
  font-weight: 600 !important;
  text-decoration-thickness: 2px !important;
}

.respawn-cart-subtotal ins {
  color: #f5f7fb !important;
  text-decoration: none !important;
}

.respawn-cart-spec-row {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  overflow: hidden !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 12px !important;
  background: rgba(255,255,255,.055) !important;
}

.respawn-cart-spec-row div {
  min-width: 0 !important;
  padding: 13px !important;
  background: #171922 !important;
  border-right: 1px solid rgba(255,255,255,.08) !important;
}

.respawn-cart-spec-row div:last-child {
  border-right: 0 !important;
}

.respawn-cart-spec-row span {
  display: block !important;
  margin-bottom: 5px !important;
  color: #8b5cf6 !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  line-height: 1.2 !important;
}

.respawn-cart-spec-row strong {
  display: block !important;
  overflow-wrap: anywhere !important;
  color: rgba(245,247,251,.86) !important;
  font-size: 13px !important;
  font-weight: 760 !important;
  line-height: 1.35 !important;
}

.respawn-cart-item-controls {
  display: grid !important;
  grid-template-columns: minmax(120px, auto) 1fr minmax(96px, auto) !important;
  gap: 18px !important;
  align-items: center !important;
  margin-top: 2px !important;
  padding: 16px !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 12px !important;
  background: #171922 !important;
}

.respawn-cart-qty .quantity {
  display: inline-flex !important;
  align-items: center !important;
}

.respawn-cart-qty input.qty {
  width: 86px !important;
  min-height: 42px !important;
  padding: 0 10px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 10px !important;
  background: #171922 !important;
  color: #f5f7fb !important;
  font-size: 14px !important;
  font-weight: 820 !important;
  text-align: center !important;
  box-shadow: none !important;
  outline: none !important;
}

.respawn-cart-subtotal {
  justify-self: end !important;
  text-align: right !important;
}

.respawn-cart-remove {
  justify-self: end !important;
}

.respawn-cart-remove a.remove {
  width: auto !important;
  min-width: 86px !important;
  height: auto !important;
  min-height: 40px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 14px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 10px !important;
  background: transparent !important;
  color: rgba(245,247,251,.74) !important;
  font-size: 13px !important;
  font-weight: 820 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  text-indent: 0 !important;
}

.respawn-cart-remove a.remove:hover {
  border-color: rgba(248,113,113,.38) !important;
  color: #ffd3d3 !important;
}

.respawn-cart-actions-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
  padding: 22px 26px 26px !important;
  border-top: 1px solid rgba(255,255,255,.08) !important;
}

.respawn-cart-coupon {
  display: grid !important;
  grid-template-columns: auto minmax(170px, 240px) auto !important;
  gap: 10px !important;
  align-items: center !important;
}

.respawn-cart-coupon label {
  color: rgba(245,247,251,.68) !important;
  font-size: 13px !important;
  font-weight: 820 !important;
}

.respawn-cart-coupon input.input-text {
  min-height: 42px !important;
  padding: 0 12px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 10px !important;
  background: #171922 !important;
  color: #f5f7fb !important;
  box-shadow: none !important;
  outline: none !important;
}

.respawn-cart-actions-row button.button,
.respawn-cart-coupon button.button,
.respawn-cart-update {
  min-height: 42px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 16px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 10px !important;
  background: #171922 !important;
  color: #f5f7fb !important;
  font-size: 13px !important;
  font-weight: 820 !important;
  line-height: 1 !important;
  box-shadow: none !important;
}

.respawn-cart-actions-row .respawn-cart-update {
  display: none !important;
}

.respawn-cart-actions-row button.button:hover,
.respawn-cart-coupon button.button:hover,
.respawn-cart-update:hover {
  border-color: rgba(139,92,246,.45) !important;
  color: #fff !important;
}

.respawn-cart-summary-panel {
  position: sticky !important;
  top: 88px !important;
  padding: 24px !important;
}

.respawn-cart-summary-panel .cart-collaterals,
.respawn-cart-summary-panel .cart_totals {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.respawn-summary-head {
  padding-bottom: 18px !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
}

.respawn-summary-head p {
  margin: 9px 0 0 !important;
  color: rgba(245,247,251,.68) !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
}

.respawn-summary-lines {
  display: grid !important;
  gap: 0 !important;
}

.respawn-summary-line,
.respawn-summary-shipping,
.respawn-summary-total {
  display: flex !important;
  justify-content: space-between !important;
  gap: 16px !important;
  padding: 15px 0 !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
  color: rgba(245,247,251,.72) !important;
}

.respawn-summary-line span,
.respawn-summary-shipping > span,
.respawn-summary-total span {
  color: rgba(245,247,251,.70) !important;
  font-size: 14px !important;
  font-weight: 760 !important;
}

.respawn-summary-line strong,
.respawn-summary-total strong {
  color: #f5f7fb !important;
  font-size: 16px !important;
  font-weight: 820 !important;
}

.respawn-summary-total {
  align-items: center !important;
  border-bottom: 0 !important;
}

.respawn-summary-total span {
  color: #f5f7fb !important;
  font-size: 16px !important;
}

.respawn-summary-total strong {
  font-size: 28px !important;
  line-height: 1 !important;
}

.respawn-summary-note {
  margin-top: 4px !important;
  padding: 14px !important;
  border: 1px solid rgba(139,92,246,.22) !important;
  border-radius: 12px !important;
  background: #171922 !important;
  color: rgba(245,247,251,.70) !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
}

.respawn-checkout-actions {
  margin: 18px 0 0 !important;
  padding: 0 !important;
}

.respawn-checkout-actions a.checkout-button,
.respawn-cart-page-shell .wc-proceed-to-checkout a.checkout-button {
  width: 100% !important;
  min-height: 50px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 !important;
  padding: 0 18px !important;
  border: 1px solid transparent !important;
  border-radius: 10px !important;
  background: #8b5cf6 !important;
  color: #fff !important;
  font-size: 14px !important;
  font-weight: 840 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

.respawn-checkout-actions a.checkout-button:hover,
.respawn-cart-page-shell .wc-proceed-to-checkout a.checkout-button:hover {
  background: #9b6cff !important;
  color: #fff !important;
}

.respawn-checkout-actions--guest {
  display: grid !important;
  gap: 10px !important;
}

.respawn-cart-create-account {
  width: 100% !important;
  min-height: 46px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 18px !important;
  border: 1px solid rgba(139,92,246,.32) !important;
  border-radius: 10px !important;
  background: rgba(139,92,246,.08) !important;
  color: #f5f7fb !important;
  font-size: 13px !important;
  font-weight: 820 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

.respawn-cart-create-account:hover {
  border-color: rgba(155,108,255,.58) !important;
  background: rgba(155,108,255,.13) !important;
  color: #fff !important;
}

.respawn-cart-trust {
  display: grid !important;
  gap: 10px !important;
  margin-top: 18px !important;
  padding-top: 18px !important;
  border-top: 1px solid rgba(255,255,255,.08) !important;
}

.respawn-cart-trust div {
  padding: 12px !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 10px !important;
  background: #171922 !important;
}

.respawn-cart-trust strong {
  display: block !important;
  margin-top: 5px !important;
  color: rgba(245,247,251,.84) !important;
  font-size: 13px !important;
  font-weight: 760 !important;
  line-height: 1.35 !important;
}

@media (max-width: 1240px) {
  .respawn-cart-layout {
    grid-template-columns: 1fr !important;
  }

  .respawn-cart-summary-panel {
    position: static !important;
  }
}

@media (max-width: 820px) {
  .respawn-cart-page-shell .respawn-page-shell {
    width: min(100% - 32px, 680px) !important;
  }

  .respawn-cart-item,
  .respawn-cart-item-title-row,
  .respawn-cart-item-controls {
    grid-template-columns: 1fr !important;
  }

  .respawn-cart-item-media {
    width: 100% !important;
    max-width: 220px !important;
  }

  .respawn-cart-subtotal,
  .respawn-cart-remove {
    justify-self: start !important;
    text-align: left !important;
  }

  .respawn-cart-spec-row {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .respawn-cart-spec-row div:nth-child(2n) {
    border-right: 0 !important;
  }
}

@media (max-width: 620px) {
  .respawn-cart-page-shell .respawn-page-hero {
    padding-top: 30px !important;
  }

  .respawn-cart-page-shell .respawn-page-content-section {
    padding-top: 8px !important;
  }

  .respawn-cart-panel-head,
  .respawn-cart-actions-row,
  .respawn-cart-coupon {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .respawn-cart-item,
  .respawn-cart-panel-head,
  .respawn-cart-actions-row,
  .respawn-cart-summary-panel {
    padding: 20px !important;
  }

  .respawn-cart-spec-row {
    grid-template-columns: 1fr !important;
  }

  .respawn-cart-spec-row div {
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255,255,255,.08) !important;
  }

  .respawn-cart-spec-row div:last-child {
    border-bottom: 0 !important;
  }

  .respawn-cart-continue,
  .respawn-cart-actions-row button.button,
  .respawn-cart-coupon input.input-text,
  .respawn-cart-coupon button.button {
    width: 100% !important;
  }
}
/* ---------------------------------------------------------
   My Account endpoint hero summary fix
   Keeps the account summary card aligned on custom endpoints.
--------------------------------------------------------- */
.respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-grid {
  grid-template-columns: minmax(0, 1fr) minmax(420px, 620px) !important;
  align-items: center !important;
}

.respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-summary {
  min-height: 160px !important;
  display: grid !important;
  grid-template-columns: 62px minmax(0, 1fr) 142px !important;
  gap: 18px !important;
  align-items: center !important;
  padding: 22px 24px !important;
  overflow: hidden !important;
}

.respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-avatar {
  width: 58px !important;
  height: 58px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, rgba(139,92,246,.82), rgba(92,55,172,.88)) !important;
  color: #efe7ff !important;
  font-size: 22px !important;
  font-weight: 900 !important;
  letter-spacing: -.04em !important;
}

.respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-summary-main {
  min-width: 0 !important;
  padding: 0 !important;
}

.respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-summary-label {
  display: block !important;
  margin-bottom: 5px !important;
  color: rgba(245,247,251,.66) !important;
  font-size: 13px !important;
  line-height: 1.35 !important;
}

.respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-name-line {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 9px !important;
  margin: 0 0 8px !important;
}

.respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-name-line strong {
  color: #fff !important;
  font-size: 30px !important;
  line-height: .95 !important;
  letter-spacing: -.06em !important;
  font-weight: 800 !important;
}

.respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-summary-badge {
  min-height: 23px !important;
  display: inline-flex !important;
  align-items: center !important;
  width: auto !important;
  max-width: 100% !important;
  padding: 0 10px !important;
  border-radius: 999px !important;
  background: rgba(139,92,246,.18) !important;
  color: #d6c2ff !important;
  font-size: 11px !important;
  line-height: 1.1 !important;
  font-weight: 850 !important;
}

.respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-email {
  display: block !important;
  max-width: 100% !important;
  overflow: hidden !important;
  color: rgba(245,247,251,.68) !important;
  font-size: 14px !important;
  line-height: 1.35 !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-edit {
  display: inline-flex !important;
  margin-top: 10px !important;
  color: #b78bff !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  text-decoration: none !important;
}

.respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-summary-side {
  height: auto !important;
  min-height: 116px !important;
  margin: 0 !important;
  padding: 0 0 0 18px !important;
  border-left: 1px solid rgba(255,255,255,.09) !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 7px !important;
  text-align: center !important;
}

.respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-summary-icon {
  width: 42px !important;
  height: 42px !important;
  display: grid !important;
  place-items: center !important;
  margin: 0 0 4px !important;
  border: 1px solid rgba(139,92,246,.30) !important;
  border-radius: 999px !important;
  background: rgba(139,92,246,.09) !important;
  color: #c8adff !important;
  font-size: 18px !important;
  line-height: 1 !important;
}

.respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-summary-side span {
  display: block !important;
  color: rgba(245,247,251,.62) !important;
  font-size: 12px !important;
  line-height: 1.3 !important;
}

.respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-summary-side strong {
  display: block !important;
  color: #fff !important;
  font-size: 17px !important;
  line-height: 1.12 !important;
  letter-spacing: -.03em !important;
}

@media (max-width: 1180px) {
  .respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-grid {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 720px) {
  .respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-summary {
    grid-template-columns: 54px minmax(0, 1fr) !important;
    gap: 14px !important;
  }

  .respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-avatar {
    width: 52px !important;
    height: 52px !important;
  }

  .respawn-account-page:not(.respawn-account-dashboard-page) .respawn-account-hero-summary-side {
    grid-column: 1 / -1 !important;
    min-height: 0 !important;
    padding: 16px 0 0 !important;
    border-left: 0 !important;
    border-top: 1px solid rgba(255,255,255,.09) !important;
    align-items: flex-start !important;
    text-align: left !important;
  }
}
/* ---------------------------------------------------------
   Respawn PCs - Production checkout polish
   Scoped to checkout only; WooCommerce checkout logic untouched.
--------------------------------------------------------- */
.respawn-checkout-page-shell,
.respawn-checkout-page-shell .respawn-page-hero,
.respawn-checkout-page-shell .respawn-page-content-section {
  background: #171922 !important;
  background-image: none !important;
}

.respawn-checkout-page-shell .respawn-page-hero {
  padding: clamp(46px, 5vw, 76px) 0 30px !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
}

.respawn-checkout-page-shell .respawn-page-shell {
  width: min(1320px, calc(100% - 48px)) !important;
  margin: 0 auto !important;
}

.respawn-checkout-page-shell .respawn-page-eyebrow {
  color: #a978ff !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  letter-spacing: .26em !important;
  text-transform: uppercase !important;
}

.respawn-checkout-page-shell .respawn-page-hero h1 {
  margin-bottom: 16px !important;
  color: #f5f7fb !important;
  font-size: 72px !important;
  line-height: .92 !important;
  letter-spacing: 0 !important;
}

.respawn-checkout-page-shell .respawn-page-subtitle {
  max-width: 520px !important;
  color: rgba(245,247,251,.70) !important;
  font-size: 17px !important;
  line-height: 1.65 !important;
}

.respawn-checkout-page-shell .respawn-page-content-section {
  padding: 28px 0 96px !important;
}

.respawn-checkout-page-shell .respawn-page-content-card--checkout {
  width: 100% !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.respawn-checkout-page-shell .woocommerce {
  color: #f5f7fb !important;
}

.respawn-checkout-page-shell .woocommerce-notices-wrapper,
.respawn-checkout-page-shell .woocommerce-form-coupon-toggle,
.respawn-checkout-page-shell .woocommerce-form-login-toggle {
  max-width: 1320px !important;
  margin: 0 auto 16px !important;
}

.respawn-checkout-page-shell .woocommerce-info,
.respawn-checkout-page-shell .woocommerce-message,
.respawn-checkout-page-shell .woocommerce-error {
  margin: 0 0 16px !important;
  padding: 15px 18px !important;
  border: 1px solid rgba(139,92,246,.24) !important;
  border-radius: 12px !important;
  background: #20232d !important;
  color: rgba(245,247,251,.78) !important;
  font-size: 13px !important;
  font-weight: 720 !important;
  line-height: 1.45 !important;
  box-shadow: none !important;
}

.respawn-checkout-page-shell .woocommerce-error {
  border-color: rgba(248,113,113,.30) !important;
  background: rgba(127,29,29,.20) !important;
}

.respawn-checkout-page-shell .woocommerce-info::before,
.respawn-checkout-page-shell .woocommerce-message::before,
.respawn-checkout-page-shell .woocommerce-error::before {
  display: none !important;
}

.respawn-checkout-page-shell .woocommerce-info a,
.respawn-checkout-page-shell .woocommerce-message a {
  color: #c8adff !important;
  font-weight: 850 !important;
  text-decoration: none !important;
}

.respawn-checkout-page-shell .woocommerce-form-coupon-toggle .woocommerce-info {
  min-height: 52px !important;
  display: flex !important;
  align-items: center !important;
  margin-bottom: 20px !important;
}

.respawn-checkout-page-shell .woocommerce-form-coupon-toggle .woocommerce-info a {
  margin-left: 4px !important;
}

.respawn-checkout-page-shell form.checkout_coupon,
.respawn-checkout-page-shell form.login {
  max-width: 760px !important;
  margin: 0 0 18px !important;
  padding: 22px !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 14px !important;
  background: #20232d !important;
}

.respawn-checkout-page-shell form.checkout_coupon p,
.respawn-checkout-page-shell form.login p {
  color: rgba(245,247,251,.70) !important;
}

.respawn-checkout-page-shell form.checkout.woocommerce-checkout {
  width: min(1240px, 100%) !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 700px) minmax(440px, 500px) !important;
  gap: 24px !important;
  align-items: start !important;
  justify-content: center !important;
}

.respawn-checkout-page-shell #customer_details {
  grid-column: 1 !important;
  grid-row: 1 !important;
  display: grid !important;
  gap: 18px !important;
  align-self: start !important;
}

.respawn-checkout-page-shell #customer_details .col-1,
.respawn-checkout-page-shell #customer_details .col-2 {
  width: 100% !important;
  float: none !important;
  padding: clamp(22px, 2.2vw, 30px) !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 16px !important;
  background: linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.012)), #20232d !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03) !important;
}

.respawn-checkout-page-shell #customer_details h3,
.respawn-checkout-page-shell #order_review_heading {
  margin: 0 0 20px !important;
  color: #f5f7fb !important;
  font-size: 28px !important;
  line-height: 1.05 !important;
  letter-spacing: 0 !important;
}

.respawn-checkout-page-shell #order_review_heading {
  display: none !important;
}

.respawn-checkout-page-shell #order_review {
  grid-column: 2 !important;
  grid-row: 1 !important;
  position: static !important;
  top: auto !important;
  align-self: start !important;
  padding: 24px !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 16px !important;
  background: linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.012)), #20232d !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03) !important;
}

.respawn-checkout-page-shell #order_review::before {
  content: "Your order";
  display: block !important;
  margin: 0 0 18px !important;
  color: #f5f7fb !important;
  font-size: 24px !important;
  font-weight: 880 !important;
  line-height: 1.1 !important;
  letter-spacing: 0 !important;
}

.respawn-checkout-page-shell .woocommerce-billing-fields__field-wrapper,
.respawn-checkout-page-shell .woocommerce-shipping-fields__field-wrapper,
.respawn-checkout-page-shell .woocommerce-additional-fields__field-wrapper {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 16px !important;
}

.respawn-checkout-page-shell .form-row {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.respawn-checkout-page-shell .form-row-wide,
.respawn-checkout-page-shell #billing_company_field,
.respawn-checkout-page-shell #billing_country_field,
.respawn-checkout-page-shell #billing_address_1_field,
.respawn-checkout-page-shell #billing_address_2_field,
.respawn-checkout-page-shell #billing_city_field,
.respawn-checkout-page-shell #billing_postcode_field,
.respawn-checkout-page-shell #billing_phone_field,
.respawn-checkout-page-shell #billing_email_field,
.respawn-checkout-page-shell #shipping_company_field,
.respawn-checkout-page-shell #shipping_country_field,
.respawn-checkout-page-shell #shipping_address_1_field,
.respawn-checkout-page-shell #shipping_address_2_field,
.respawn-checkout-page-shell #shipping_city_field,
.respawn-checkout-page-shell #shipping_postcode_field,
.respawn-checkout-page-shell #order_comments_field {
  grid-column: 1 / -1 !important;
}

.respawn-checkout-page-shell label {
  display: block !important;
  margin: 0 0 8px !important;
  color: rgba(245,247,251,.86) !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  line-height: 1.35 !important;
}

.respawn-checkout-page-shell abbr.required {
  color: #a978ff !important;
  text-decoration: none !important;
}

.respawn-checkout-page-shell input.input-text,
.respawn-checkout-page-shell textarea,
.respawn-checkout-page-shell select,
.respawn-checkout-page-shell .select2-container--default .select2-selection--single {
  width: 100% !important;
  min-height: 46px !important;
  border: 1px solid rgba(255,255,255,.11) !important;
  border-radius: 10px !important;
  background: #171922 !important;
  color: #f5f7fb !important;
  padding: 0 14px !important;
  box-shadow: none !important;
  outline: 0 !important;
}

.respawn-checkout-page-shell textarea {
  min-height: 112px !important;
  padding: 13px 14px !important;
  resize: vertical !important;
}

.respawn-checkout-page-shell input.input-text:focus,
.respawn-checkout-page-shell textarea:focus,
.respawn-checkout-page-shell select:focus,
.respawn-checkout-page-shell .select2-container--open .select2-selection--single {
  border-color: rgba(139,92,246,.58) !important;
}

.respawn-checkout-page-shell .select2-container--default .select2-selection--single .select2-selection__rendered {
  color: #f5f7fb !important;
  line-height: 46px !important;
  padding: 0 !important;
}

.respawn-checkout-page-shell .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 46px !important;
}

body.woocommerce-checkout .select2-dropdown {
  border: 1px solid rgba(139,92,246,.36) !important;
  border-radius: 10px !important;
  background: #20232d !important;
  color: #f5f7fb !important;
  overflow: hidden !important;
}

body.woocommerce-checkout .select2-search--dropdown {
  padding: 8px !important;
  background: #20232d !important;
}

body.woocommerce-checkout .select2-search--dropdown .select2-search__field {
  min-height: 38px !important;
  border: 1px solid rgba(255,255,255,.11) !important;
  border-radius: 8px !important;
  background: #171922 !important;
  color: #f5f7fb !important;
}

body.woocommerce-checkout .select2-results__option {
  color: rgba(245,247,251,.78) !important;
  padding: 9px 12px !important;
}

body.woocommerce-checkout .select2-results__option--highlighted,
body.woocommerce-checkout .select2-results__option--selected {
  background: rgba(139,92,246,.18) !important;
  color: #fff !important;
}

.respawn-checkout-page-shell .woocommerce-invalid input.input-text,
.respawn-checkout-page-shell .woocommerce-invalid textarea,
.respawn-checkout-page-shell .woocommerce-invalid .select2-selection {
  border-color: rgba(248,113,113,.50) !important;
}

.respawn-checkout-page-shell .woocommerce-validated input.input-text,
.respawn-checkout-page-shell .woocommerce-validated textarea,
.respawn-checkout-page-shell .woocommerce-validated .select2-selection {
  border-color: rgba(74,222,128,.34) !important;
}

.respawn-checkout-page-shell .woocommerce-additional-fields {
  margin-top: 18px !important;
}

.respawn-checkout-page-shell .woocommerce-shipping-fields h3 label,
.respawn-checkout-page-shell .create-account label,
.respawn-checkout-page-shell .woocommerce-form__label-for-checkbox {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin: 0 !important;
  color: rgba(245,247,251,.82) !important;
}

.respawn-checkout-page-shell input[type="checkbox"],
.respawn-checkout-page-shell input[type="radio"] {
  width: 18px !important;
  height: 18px !important;
  accent-color: #8b5cf6 !important;
}

.respawn-checkout-page-shell table.shop_table {
  width: 100% !important;
  margin: 0 !important;
  border: 0 !important;
  border-collapse: collapse !important;
  background: transparent !important;
  color: #f5f7fb !important;
}

.respawn-checkout-page-shell table.shop_table th,
.respawn-checkout-page-shell table.shop_table td {
  padding: 15px 0 !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
  color: rgba(245,247,251,.72) !important;
  font-size: 14px !important;
  line-height: 1.45 !important;
}

.respawn-checkout-page-shell table.shop_table th:last-child,
.respawn-checkout-page-shell table.shop_table td:last-child {
  text-align: right !important;
}

.respawn-checkout-page-shell table.shop_table thead th {
  color: rgba(245,247,251,.92) !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
}

.respawn-checkout-page-shell table.shop_table .product-name {
  color: #f5f7fb !important;
  font-weight: 820 !important;
}

.respawn-checkout-page-shell table.shop_table tfoot th,
.respawn-checkout-page-shell table.shop_table tfoot td {
  color: #f5f7fb !important;
  font-weight: 850 !important;
}

.respawn-checkout-page-shell table.shop_table tfoot .order-total th,
.respawn-checkout-page-shell table.shop_table tfoot .order-total td {
  border-bottom: 0 !important;
  color: #fff !important;
  font-size: 18px !important;
}

.respawn-checkout-page-shell table.shop_table tfoot .order-total td strong,
.respawn-checkout-page-shell table.shop_table tfoot .order-total .amount {
  color: #fff !important;
  font-size: 28px !important;
  line-height: 1 !important;
}

.respawn-checkout-page-shell #payment {
  margin-top: 18px !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 14px !important;
  background: #171922 !important;
  color: #f5f7fb !important;
}

.respawn-checkout-page-shell #payment ul.payment_methods {
  padding: 0 !important;
  border: 0 !important;
}

.respawn-checkout-page-shell #payment ul.payment_methods li {
  padding: 16px !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
}

.respawn-checkout-page-shell #payment ul.payment_methods li > label {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  color: #f5f7fb !important;
  font-size: 14px !important;
  font-weight: 850 !important;
  line-height: 1.35 !important;
}

.respawn-checkout-page-shell #payment ul.payment_methods li > label img,
.respawn-checkout-page-shell #payment ul.payment_methods li > label svg {
  max-height: 22px !important;
  width: auto !important;
  margin: 0 0 0 auto !important;
}

.respawn-checkout-page-shell #payment div.payment_box {
  margin: 12px 0 0 !important;
  padding: 16px !important;
  border-radius: 10px !important;
  background: rgba(255,255,255,.035) !important;
  color: rgba(245,247,251,.70) !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
  overflow: visible !important;
}

.respawn-checkout-page-shell #payment div.payment_box::before {
  border-bottom-color: rgba(255,255,255,.035) !important;
}

.respawn-checkout-page-shell #payment .payment_box .wc-stripe-elements-field,
.respawn-checkout-page-shell #payment .payment_box .StripeElement,
.respawn-checkout-page-shell #payment .payment_box #stripe-card-element,
.respawn-checkout-page-shell #payment .payment_box #stripe-exp-element,
.respawn-checkout-page-shell #payment .payment_box #stripe-cvc-element {
  width: 100% !important;
  min-height: 46px !important;
  display: block !important;
  border: 1px solid rgba(255,255,255,.11) !important;
  border-radius: 10px !important;
  background: #171922 !important;
  padding: 13px 14px !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
}

.respawn-checkout-page-shell #payment .payment_box fieldset,
.respawn-checkout-page-shell #payment .payment_box .wc-credit-card-form {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
}

.respawn-checkout-page-shell #payment .payment_box .form-row {
  margin-top: 12px !important;
}

.respawn-checkout-page-shell #payment .payment_box .form-row-first,
.respawn-checkout-page-shell #payment .payment_box .form-row-last {
  width: calc(50% - 6px) !important;
}

.respawn-checkout-page-shell #payment .payment_box iframe,
.respawn-checkout-page-shell #payment .payment_box [id*="klarna"],
.respawn-checkout-page-shell #payment .payment_box [class*="klarna"],
.respawn-checkout-page-shell #payment .payment_box [id*="Klarna"],
.respawn-checkout-page-shell #payment .payment_box [class*="Klarna"] {
  max-width: 100% !important;
}

.respawn-checkout-page-shell #payment .place-order {
  padding: 18px !important;
  margin: 0 !important;
}

.respawn-checkout-page-shell .woocommerce-terms-and-conditions-wrapper {
  color: rgba(245,247,251,.66) !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
}

.respawn-checkout-page-shell .woocommerce-terms-and-conditions-wrapper a {
  color: #c8adff !important;
  text-decoration: none !important;
}

.respawn-checkout-page-shell button.button,
.respawn-checkout-page-shell input.button,
.respawn-checkout-page-shell a.button {
  min-height: 44px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid rgba(183,156,255,.34) !important;
  border-radius: 10px !important;
  padding: 0 18px !important;
  background: rgba(139,92,246,.12) !important;
  color: #f5f7fb !important;
  font-size: 14px !important;
  font-weight: 850 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

.respawn-checkout-page-shell button.button:hover,
.respawn-checkout-page-shell input.button:hover,
.respawn-checkout-page-shell a.button:hover {
  border-color: rgba(183,156,255,.54) !important;
  background: rgba(139,92,246,.20) !important;
  color: #fff !important;
}

.respawn-checkout-page-shell #place_order {
  width: 100% !important;
  min-height: 54px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-top: 16px !important;
  border: 1px solid transparent !important;
  border-radius: 12px !important;
  background: linear-gradient(180deg, #9b6cff, #8b5cf6) !important;
  color: #fff !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

.respawn-checkout-page-shell #place_order:hover,
.respawn-checkout-page-shell #place_order:focus {
  background: #9b6cff !important;
  color: #fff !important;
}

.respawn-checkout-page-shell .woocommerce-order {
  display: grid !important;
  gap: 18px !important;
  max-width: 980px !important;
  margin: 0 auto !important;
}

.respawn-checkout-page-shell .woocommerce-thankyou-order-received {
  margin: 0 !important;
  padding: clamp(24px, 3vw, 34px) !important;
  border: 1px solid rgba(74,222,128,.30) !important;
  border-radius: 16px !important;
  background: linear-gradient(180deg, rgba(74,222,128,.08), rgba(255,255,255,.012)), #20232d !important;
  color: #f5f7fb !important;
  font-size: 34px !important;
  line-height: 1.1 !important;
  letter-spacing: 0 !important;
  font-weight: 850 !important;
}

.respawn-checkout-page-shell ul.woocommerce-order-overview {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 12px !important;
  margin: 0 !important;
  padding: 0 !important;
}

.respawn-checkout-page-shell ul.woocommerce-order-overview li {
  margin: 0 !important;
  padding: 16px !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 12px !important;
  background: #20232d !important;
  color: rgba(245,247,251,.60) !important;
  font-size: 12px !important;
  font-weight: 850 !important;
}

.respawn-checkout-page-shell ul.woocommerce-order-overview strong {
  display: block !important;
  margin-top: 6px !important;
  color: #f5f7fb !important;
  font-size: 15px !important;
}

.respawn-checkout-page-shell .woocommerce-order-details,
.respawn-checkout-page-shell .woocommerce-customer-details {
  padding: clamp(22px, 2.2vw, 30px) !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 16px !important;
  background: #20232d !important;
}

.respawn-checkout-page-shell .woocommerce-order-details h2,
.respawn-checkout-page-shell .woocommerce-customer-details h2 {
  margin: 0 0 16px !important;
  color: #f5f7fb !important;
  font-size: 26px !important;
  line-height: 1.1 !important;
  letter-spacing: 0 !important;
}

@media (max-width: 1080px) {
  .respawn-checkout-page-shell form.checkout.woocommerce-checkout {
    grid-template-columns: 1fr !important;
  }

  .respawn-checkout-page-shell #order_review_heading,
  .respawn-checkout-page-shell #order_review {
    grid-column: 1 !important;
  }

  .respawn-checkout-page-shell #order_review {
    position: static !important;
  }
}

@media (max-width: 720px) {
  .respawn-checkout-page-shell .respawn-page-shell {
    width: min(100% - 28px, 1320px) !important;
  }

  .respawn-checkout-page-shell .respawn-page-content-section {
    padding-top: 18px !important;
  }

  .respawn-checkout-page-shell .woocommerce-billing-fields__field-wrapper,
  .respawn-checkout-page-shell .woocommerce-shipping-fields__field-wrapper,
  .respawn-checkout-page-shell .woocommerce-additional-fields__field-wrapper,
  .respawn-checkout-page-shell ul.woocommerce-order-overview {
    grid-template-columns: 1fr !important;
  }

  .respawn-checkout-page-shell #customer_details .col-1,
  .respawn-checkout-page-shell #customer_details .col-2,
  .respawn-checkout-page-shell #order_review_heading,
  .respawn-checkout-page-shell #order_review,
  .respawn-checkout-page-shell .woocommerce-order-details,
  .respawn-checkout-page-shell .woocommerce-customer-details {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
}

/* ---------------------------------------------------------
   Respawn PCs - WooCommerce Checkout Block polish
   The checkout page uses block markup; keep this visual layer scoped.
--------------------------------------------------------- */
.respawn-checkout-page-shell .respawn-page-hero {
  text-align: center !important;
}

.respawn-checkout-page-shell .respawn-page-subtitle {
  margin-left: auto !important;
  margin-right: auto !important;
}

.respawn-checkout-page-shell .wp-block-woocommerce-checkout,
.respawn-checkout-page-shell .wc-block-checkout {
  width: min(1180px, calc(100vw - 64px)) !important;
  max-width: none !important;
  margin: 0 !important;
  position: relative !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  color: #f5f7fb !important;
  font-family: inherit !important;
  box-sizing: border-box !important;
}

.respawn-checkout-page-shell .wp-block-woocommerce-checkout-express-payment-block,
.respawn-checkout-page-shell .wc-block-components-express-payment,
.respawn-checkout-page-shell .wc-block-components-express-payment-continue-rule {
  display: none !important;
}

.respawn-checkout-page-shell .wc-block-components-sidebar-layout,
.respawn-checkout-page-shell .wc-block-checkout {
  display: grid !important;
  grid-template-columns: minmax(620px, 700px) minmax(390px, 430px) !important;
  gap: 24px !important;
  align-items: start !important;
  justify-content: center !important;
  width: 100% !important;
  max-width: 1180px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.respawn-checkout-page-shell .wp-block-woocommerce-checkout.wc-block-checkout {
  display: block !important;
}

.respawn-checkout-page-shell .wc-block-components-main,
.respawn-checkout-page-shell .wc-block-checkout__main {
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
  display: grid !important;
  gap: 18px !important;
  box-sizing: border-box !important;
}

.respawn-checkout-page-shell .wc-block-components-sidebar,
.respawn-checkout-page-shell .wc-block-checkout__sidebar {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 24px !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 16px !important;
  background: linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.012)), #20232d !important;
  color: #f5f7fb !important;
  position: sticky !important;
  top: 104px !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03) !important;
  box-sizing: border-box !important;
}

.respawn-checkout-page-shell .respawn-page-content-card--checkout > *,
.respawn-checkout-page-shell .respawn-page-content-card--checkout .entry-content,
.respawn-checkout-page-shell .respawn-page-content-card--checkout .is-layout-flow,
.respawn-checkout-page-shell .respawn-page-content-card--checkout .is-layout-constrained {
  width: 100% !important;
  max-width: none !important;
}

.respawn-checkout-page-shell .wc-block-components-checkout-step {
  margin: 0 !important;
  padding: clamp(22px, 2.2vw, 30px) !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 16px !important;
  background: linear-gradient(180deg, rgba(255,255,255,.032), rgba(255,255,255,.012)), #20232d !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03) !important;
}

.respawn-checkout-page-shell .wc-block-checkout__form {
  display: grid !important;
  gap: 18px !important;
  margin: 0 !important;
}

.respawn-checkout-page-shell .wc-block-components-checkout-step__heading {
  margin: 0 0 18px !important;
  padding: 0 !important;
}

.respawn-checkout-page-shell .wc-block-components-checkout-step__title,
.respawn-checkout-page-shell .wc-block-components-title.wc-block-components-title {
  margin: 0 !important;
  color: #f5f7fb !important;
  font-size: 24px !important;
  font-weight: 880 !important;
  line-height: 1.1 !important;
  letter-spacing: 0 !important;
}

.respawn-checkout-page-shell .wc-block-components-checkout-step__description,
.respawn-checkout-page-shell .wc-block-components-checkout-step__content,
.respawn-checkout-page-shell .wc-block-components-form .wc-block-components-text-input label,
.respawn-checkout-page-shell .wc-block-components-form .wc-block-components-checkbox__label,
.respawn-checkout-page-shell .wc-block-components-validation-error,
.respawn-checkout-page-shell .wc-block-components-address-card address,
.respawn-checkout-page-shell .wc-block-components-totals-footer-item-tax {
  color: rgba(245,247,251,.70) !important;
}

.respawn-checkout-page-shell .wc-block-components-text-input,
.respawn-checkout-page-shell .wc-block-components-combobox,
.respawn-checkout-page-shell .wc-block-components-country-input,
.respawn-checkout-page-shell .wc-block-components-state-input,
.respawn-checkout-page-shell .wc-block-components-textarea {
  margin: 0 0 14px !important;
}

.respawn-checkout-page-shell .wc-block-components-text-input input,
.respawn-checkout-page-shell .wc-block-components-combobox .components-combobox-control__input,
.respawn-checkout-page-shell .wc-block-components-textarea,
.respawn-checkout-page-shell .wc-block-components-select .wc-block-components-select__select {
  width: 100% !important;
  min-height: 48px !important;
  border: 1px solid rgba(255,255,255,.11) !important;
  border-radius: 10px !important;
  background: #171922 !important;
  color: #f5f7fb !important;
  padding: 13px 14px !important;
  font-size: 14px !important;
  font-weight: 650 !important;
  line-height: 1.35 !important;
  box-shadow: none !important;
  outline: 0 !important;
}

.respawn-checkout-page-shell .wc-block-components-text-input input:focus,
.respawn-checkout-page-shell .wc-block-components-combobox .components-combobox-control__input:focus,
.respawn-checkout-page-shell .wc-block-components-textarea:focus,
.respawn-checkout-page-shell .wc-block-components-select .wc-block-components-select__select:focus {
  border-color: rgba(139,92,246,.58) !important;
}

.respawn-checkout-page-shell .wc-block-components-text-input label,
.respawn-checkout-page-shell .wc-block-components-combobox label,
.respawn-checkout-page-shell .wc-block-components-select label {
  color: rgba(245,247,251,.62) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

.respawn-checkout-page-shell .wc-block-components-address-card {
  margin: 0 !important;
  padding: 18px !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 12px !important;
  background: #171922 !important;
  color: #f5f7fb !important;
  box-shadow: none !important;
}

.respawn-checkout-page-shell .wc-block-components-address-card__address-section,
.respawn-checkout-page-shell .wc-block-components-address-card address {
  color: rgba(245,247,251,.76) !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
}

.respawn-checkout-page-shell .wc-block-components-address-card__edit,
.respawn-checkout-page-shell .wc-block-components-button.is-link,
.respawn-checkout-page-shell .wc-block-components-checkout-return-to-cart-button {
  color: #c8adff !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  text-decoration: none !important;
}

.respawn-checkout-page-shell .wc-block-components-panel,
.respawn-checkout-page-shell .wc-block-components-totals-wrapper,
.respawn-checkout-page-shell .wc-block-components-payment-methods,
.respawn-checkout-page-shell .wc-block-components-radio-control {
  border-color: rgba(255,255,255,.08) !important;
}

.respawn-checkout-page-shell .wc-block-components-radio-control,
.respawn-checkout-page-shell .wc-block-components-radio-control__option {
  border-radius: 12px !important;
  background: #171922 !important;
  color: #f5f7fb !important;
}

.respawn-checkout-page-shell .wc-block-checkout__payment-method .wc-block-components-radio-control {
  padding: 10px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  background: #171922 !important;
}

.respawn-checkout-page-shell .wc-block-components-radio-control__option {
  padding: 16px !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
}

.respawn-checkout-page-shell .wc-block-components-radio-control__option:last-child {
  border-bottom: 0 !important;
}

.respawn-checkout-page-shell .wc-block-components-panel__button,
.respawn-checkout-page-shell .wc-block-components-totals-coupon__button {
  color: #f5f7fb !important;
  font-weight: 850 !important;
}

.respawn-checkout-page-shell .wc-block-components-checkbox .wc-block-components-checkbox__input,
.respawn-checkout-page-shell .wc-block-components-radio-control__input {
  width: 18px !important;
  height: 18px !important;
  border: 1px solid rgba(255,255,255,.28) !important;
  background: #171922 !important;
  accent-color: #8b5cf6 !important;
}

.respawn-checkout-page-shell .wc-block-components-notice-banner {
  margin: 0 0 16px !important;
  padding: 14px 16px !important;
  border-radius: 12px !important;
  background: #171922 !important;
  color: rgba(245,247,251,.78) !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
  box-shadow: none !important;
}

.respawn-checkout-page-shell .wc-block-components-notice-banner.is-error {
  border: 1px solid rgba(248,113,113,.38) !important;
  background: rgba(127,29,29,.20) !important;
}

.respawn-checkout-page-shell .wc-block-checkout__payment-method .wc-block-components-radio-control,
.respawn-checkout-page-shell .wc-block-checkout__payment-method .wc-block-components-radio-control__option,
.respawn-checkout-page-shell .wc-block-checkout__payment-method .wc-block-components-radio-control-accordion-option,
.respawn-checkout-page-shell .wc-block-components-payment-methods__container {
  width: 100% !important;
  max-width: none !important;
}

.respawn-checkout-page-shell .wc-block-checkout__payment-method .wc-block-components-radio-control__option {
  border: 0 !important;
  border-radius: 10px !important;
  background: #171922 !important;
}

.respawn-checkout-page-shell .wc-block-checkout__payment-method .wc-block-components-radio-control__option-checked {
  border: 1px solid rgba(139,92,246,.36) !important;
  background: rgba(139,92,246,.055) !important;
}

.respawn-checkout-page-shell .wc-block-checkout__payment-method .wc-block-components-radio-control__label,
.respawn-checkout-page-shell .wc-block-components-radio-control__label {
  color: #f5f7fb !important;
  font-size: 14px !important;
  font-weight: 850 !important;
  line-height: 1.35 !important;
}

.respawn-checkout-page-shell .wc-block-checkout__payment-method .wc-block-components-radio-control__description,
.respawn-checkout-page-shell .wc-block-components-radio-control__description {
  color: rgba(245,247,251,.68) !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
}

.respawn-checkout-page-shell .wc-block-components-payment-method-label--with-icon {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
}

.respawn-checkout-page-shell .wc-block-components-payment-method-label--with-icon img,
.respawn-checkout-page-shell .wc-block-components-payment-method-label--with-icon svg {
  max-height: 22px !important;
  width: auto !important;
  margin: 0 !important;
}

.respawn-checkout-page-shell .wc-stripe-blocks-payment-method,
.respawn-checkout-page-shell .wc-stripe-blocks-payment-method__content,
.respawn-checkout-page-shell .wc-stripe-blocks-payment-method__fields,
.respawn-checkout-page-shell .wc-stripe-blocks-payment-method__card {
  width: 100% !important;
  max-width: none !important;
}

.respawn-checkout-page-shell .StripeElement,
.respawn-checkout-page-shell .wc-stripe-elements-field,
.respawn-checkout-page-shell .wc-stripe-card-element,
.respawn-checkout-page-shell .wc-stripe-payment-request-wrapper {
  width: 100% !important;
  min-height: 46px !important;
  border: 1px solid rgba(255,255,255,.11) !important;
  border-radius: 10px !important;
  background: #171922 !important;
  padding: 13px 14px !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
}

.respawn-checkout-page-shell .wc-stripe-blocks-payment-method__test-mode,
.respawn-checkout-page-shell .wc-stripe-blocks-payment-method__save-card-info {
  color: rgba(245,247,251,.68) !important;
  font-size: 12px !important;
  line-height: 1.55 !important;
}

.respawn-checkout-page-shell .wc-stripe-blocks-payment-method__test-mode {
  margin: 10px 0 14px !important;
}

.respawn-checkout-page-shell .wc-block-checkout__payment-method .wc-block-components-radio-control-accordion-option,
.respawn-checkout-page-shell .wc-block-checkout__payment-method .wc-block-components-radio-control-accordion-content {
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

.respawn-checkout-page-shell .wc-block-checkout__payment-method .wc-block-components-radio-control-accordion-content {
  margin-top: 14px !important;
}

.respawn-checkout-page-shell .wc-block-components-sidebar h2,
.respawn-checkout-page-shell .wc-block-components-order-summary__title {
  margin: 0 0 16px !important;
  color: #f5f7fb !important;
  font-size: 22px !important;
  font-weight: 880 !important;
  line-height: 1.1 !important;
  letter-spacing: 0 !important;
}

.respawn-checkout-page-shell .wc-block-components-order-summary {
  margin: 0 !important;
  border: 0 !important;
}

.respawn-checkout-page-shell .wp-block-woocommerce-checkout-order-summary-block,
.respawn-checkout-page-shell .checkout-order-summary-block-fill,
.respawn-checkout-page-shell .checkout-order-summary-block-fill-wrapper {
  border: 0 !important;
  background: transparent !important;
}

.respawn-checkout-page-shell .wp-block-woocommerce-checkout-order-summary-block .wc-block-components-title {
  margin-bottom: 14px !important;
}

.respawn-checkout-page-shell .wc-block-components-order-summary-item {
  display: grid !important;
  grid-template-columns: 62px minmax(0, 1fr) minmax(98px, auto) !important;
  gap: 13px !important;
  align-items: start !important;
  padding: 16px 0 !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
}

.respawn-checkout-page-shell .wc-block-components-order-summary-item__image {
  width: 62px !important;
  height: 62px !important;
  margin: 0 !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 10px !important;
  background: #171922 !important;
  overflow: hidden !important;
}

.respawn-checkout-page-shell .wc-block-components-order-summary-item__image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}

.respawn-checkout-page-shell .wc-block-components-order-summary-item__description {
  min-width: 0 !important;
  padding: 0 !important;
}

.respawn-checkout-page-shell .wc-block-components-product-name {
  color: #f5f7fb !important;
  font-size: 14px !important;
  font-weight: 850 !important;
  line-height: 1.25 !important;
}

.respawn-checkout-page-shell .wc-block-components-product-metadata,
.respawn-checkout-page-shell .wc-block-components-product-metadata__description,
.respawn-checkout-page-shell .wc-block-components-order-summary-item__quantity {
  color: rgba(245,247,251,.62) !important;
  font-size: 11px !important;
  line-height: 1.45 !important;
}

.respawn-checkout-page-shell .wc-block-components-order-summary-item__total-price {
  min-width: 98px !important;
  padding: 0 !important;
  color: #f5f7fb !important;
  text-align: right !important;
  white-space: nowrap !important;
}

.respawn-checkout-page-shell .wc-block-components-product-price,
.respawn-checkout-page-shell .wc-block-components-product-price__value,
.respawn-checkout-page-shell .wc-block-components-order-summary-item__total-price .amount,
.respawn-checkout-page-shell .wc-block-components-formatted-money-amount {
  color: #f5f7fb !important;
  font-size: 15px !important;
  font-weight: 850 !important;
  line-height: 1.15 !important;
  letter-spacing: 0 !important;
  white-space: nowrap !important;
}

.respawn-checkout-page-shell .wc-block-components-product-price del,
.respawn-checkout-page-shell .wc-block-components-product-price del .amount {
  display: block !important;
  margin-bottom: 3px !important;
  color: rgba(245,247,251,.48) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}

.respawn-checkout-page-shell .wc-block-components-product-price ins {
  display: block !important;
  color: #f5f7fb !important;
  text-decoration: none !important;
}

.respawn-checkout-page-shell .wc-block-components-totals-item {
  padding: 15px 0 !important;
  border-top: 1px solid rgba(255,255,255,.08) !important;
}

.respawn-checkout-page-shell .wc-block-components-totals-item__label,
.respawn-checkout-page-shell .wc-block-components-totals-item__value {
  color: rgba(245,247,251,.78) !important;
  font-size: 14px !important;
  font-weight: 820 !important;
}

.respawn-checkout-page-shell .wc-block-components-totals-footer-item {
  margin-top: 4px !important;
  padding-top: 18px !important;
}

.respawn-checkout-page-shell .wc-block-components-totals-footer-item .wc-block-components-totals-item__label,
.respawn-checkout-page-shell .wc-block-components-totals-footer-item .wc-block-components-totals-item__value,
.respawn-checkout-page-shell .wc-block-components-totals-footer-item .wc-block-components-formatted-money-amount {
  color: #fff !important;
  font-size: 22px !important;
  font-weight: 900 !important;
}

.respawn-checkout-page-shell .wc-block-components-button:not(.is-link),
.respawn-checkout-page-shell button.wc-block-components-button:not(.is-link) {
  min-height: 48px !important;
  border: 1px solid rgba(183,156,255,.34) !important;
  border-radius: 10px !important;
  background: rgba(139,92,246,.12) !important;
  color: #f5f7fb !important;
  font-size: 14px !important;
  font-weight: 850 !important;
  line-height: 1 !important;
  box-shadow: none !important;
}

.respawn-checkout-page-shell .wc-block-components-button:not(.is-link):hover,
.respawn-checkout-page-shell button.wc-block-components-button:not(.is-link):hover {
  border-color: rgba(183,156,255,.54) !important;
  background: rgba(139,92,246,.20) !important;
  color: #fff !important;
}

.respawn-checkout-page-shell .wc-block-components-checkout-place-order-button {
  width: 100% !important;
  min-height: 54px !important;
  margin-top: 18px !important;
  border: 1px solid transparent !important;
  border-radius: 12px !important;
  background: linear-gradient(180deg, #9b6cff, #8b5cf6) !important;
  color: #fff !important;
  font-size: 15px !important;
  font-weight: 900 !important;
}

.respawn-checkout-page-shell .wc-block-components-checkout-place-order-button:disabled,
.respawn-checkout-page-shell .wc-block-components-checkout-place-order-button[disabled] {
  border-color: rgba(255,255,255,.08) !important;
  background: rgba(255,255,255,.08) !important;
  color: rgba(245,247,251,.42) !important;
  cursor: not-allowed !important;
}

@media (max-width: 1080px) {
  .respawn-checkout-page-shell .wc-block-components-sidebar-layout,
  .respawn-checkout-page-shell .wc-block-checkout {
    grid-template-columns: 1fr !important;
  }

  .respawn-checkout-page-shell .wc-block-components-sidebar,
  .respawn-checkout-page-shell .wc-block-checkout__sidebar {
    position: static !important;
  }
}

@media (max-width: 720px) {
  .respawn-checkout-page-shell .wp-block-woocommerce-checkout,
  .respawn-checkout-page-shell .wc-block-checkout {
    width: min(100vw - 28px, 1180px) !important;
  }

  .respawn-checkout-page-shell .respawn-page-hero h1 {
    font-size: 48px !important;
  }

  .respawn-checkout-page-shell .woocommerce-thankyou-order-received {
    font-size: 26px !important;
  }

  .respawn-checkout-page-shell .wc-block-components-sidebar,
  .respawn-checkout-page-shell .wc-block-checkout__sidebar,
  .respawn-checkout-page-shell .wc-block-components-checkout-step {
    padding: 20px !important;
  }

  .respawn-checkout-page-shell .wc-block-components-order-summary-item {
    grid-template-columns: 56px minmax(0, 1fr) !important;
  }

  .respawn-checkout-page-shell .wc-block-components-order-summary-item__total-price {
    grid-column: 2 !important;
    text-align: left !important;
  }
}
