/* ============================================================
   TeamWear Premium UI Layer
   Pure visual/UX layer: no workflow, form, or business logic changes.
   ============================================================ */

:root {
  --ui-bg: #f6f8fb;
  --ui-bg-2: #edf7f6;
  --ui-surface: #ffffff;
  --ui-surface-soft: #f8fbff;
  --ui-ink: #101828;
  --ui-ink-2: #243044;
  --ui-muted: #667085;
  --ui-subtle: #98a2b3;
  --ui-line: rgba(16, 24, 40, .10);
  --ui-line-strong: rgba(16, 24, 40, .16);
  --ui-primary: #0b7285;
  --ui-primary-2: #12b886;
  --ui-accent: #f59f00;
  --ui-rose: #e64980;
  --ui-radius-sm: 8px;
  --ui-radius: 12px;
  --ui-radius-lg: 18px;
  --ui-shadow-sm: 0 8px 22px rgba(16, 24, 40, .07);
  --ui-shadow: 0 18px 50px rgba(16, 24, 40, .12);
  --ui-shadow-lg: 0 28px 80px rgba(16, 24, 40, .18);
  --maxw: 1240px;
  --brand: var(--ui-primary);
  --brand-dark: #075766;
  --ink: var(--ui-ink);
  --muted: var(--ui-muted);
  --line: rgba(16, 24, 40, .10);
  --surface-alt: var(--ui-bg);
  --radius: var(--ui-radius);
}

body:not(.home):not(.auth) main.container {
  margin-top: 0 !important;
}

/* Header */
.site-header.nav-modern {
  position: sticky !important;
  top: 0 !important;
  z-index: 100 !important;
  background: rgba(255,255,255,.78) !important;
  color: var(--ui-ink) !important;
  border-bottom: 1px solid rgba(16,24,40,.10) !important;
  box-shadow: none !important;
  backdrop-filter: saturate(160%) blur(12px) !important;
  -webkit-backdrop-filter: saturate(160%) blur(12px) !important;
}

.nav-modern .nav-shell {
  min-height: 74px !important;
  max-width: calc(var(--maxw) + 48px) !important;
  padding: 12px 24px 12px 250px !important;
  gap: 16px !important;
}

.floating-logo {
  position: absolute !important;
  left: max(18px, calc((100vw - var(--maxw)) / 2 + 16px)) !important;
  top: 6px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 228px !important;
  max-width: 30vw !important;
  min-height: 86px !important;
  padding: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  z-index: 5 !important;
}

.floating-logo img,
.brand-logo-mobile img {
  max-width: 220px !important;
  max-height: 82px !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
  filter: drop-shadow(0 14px 22px rgba(16,24,40,.16)) !important;
}

.nav-modern .brand {
  min-width: 0;
}

.nav-modern .nav-links {
  display: flex !important;
  gap: 0 !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  border: 0 !important;
}

.nav-modern .nav-links a {
  color: var(--ui-ink-2) !important;
  position: relative !important;
  padding: 10px 16px !important;
  border-radius: 0 !important;
  font-size: .91rem !important;
  font-weight: 850 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  opacity: 1 !important;
}

.nav-modern .nav-links a + a {
  border-left: 1px solid rgba(16,24,40,.14) !important;
}

.nav-modern .nav-links a::after {
  content: "" !important;
  position: absolute !important;
  left: 16px !important;
  right: 16px !important;
  bottom: 2px !important;
  height: 2px !important;
  background: var(--ui-primary) !important;
  transform: scaleX(0) !important;
  transform-origin: left !important;
  transition: transform .18s ease !important;
}

.nav-modern .nav-links a:hover {
  color: var(--ui-primary) !important;
  background: transparent !important;
  box-shadow: none !important;
}

.nav-modern .nav-links a:hover::after {
  transform: scaleX(1) !important;
}

.nav-modern .cart-link {
  min-width: 48px !important;
  min-height: 48px !important;
  justify-content: center !important;
  color: #fff !important;
  background: linear-gradient(135deg, var(--ui-primary), var(--ui-primary-2)) !important;
  border-radius: 16px 16px 16px 4px !important;
  box-shadow: 0 12px 28px rgba(11,114,133,.26) !important;
}

.cart-link:hover {
  transform: translateY(-1px);
}

.nav-modern .nav-toggle {
  width: 82px !important;
  height: 42px !important;
  border-radius: 10px 10px 10px 3px !important;
  border: 1px solid rgba(16,24,40,.16) !important;
  background: rgba(255,255,255,.86) !important;
  color: var(--ui-ink) !important;
  box-shadow: none !important;
  gap: 8px !important;
  align-items: center !important;
  justify-content: center !important;
}

.nav-modern .nav-toggle::after {
  content: "Menu" !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
  color: var(--ui-ink-2) !important;
}

.nav-modern .nav-toggle .bar {
  background: var(--ui-ink) !important;
  width: 15px !important;
}

.nav-mobile {
  background: rgba(255,255,255,.96) !important;
  border-top: 1px solid rgba(16,24,40,.08) !important;
  box-shadow: 0 24px 50px rgba(16,24,40,.12) !important;
}

.nav-mobile a {
  color: var(--ui-ink) !important;
  min-height: 46px;
}

.mini-cart {
  border: 1px solid var(--ui-line) !important;
  border-radius: var(--ui-radius-lg) !important;
  box-shadow: var(--ui-shadow-lg) !important;
  overflow: hidden !important;
}

/* Home */
body.home,
body.auth {
  overflow-x: hidden !important;
  overflow-y: auto !important;
}

body.home main.container,
body.auth main.container {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

body.home .site-header + main.container,
body.home:not(.admin):not(.auth) main.container {
  margin-top: 0 !important;
}

body.home .site-header.nav-modern {
  border-bottom: 0 !important;
  margin-bottom: 0 !important;
}

.home-hero {
  width: 100% !important;
  min-height: calc(100svh - 74px) !important;
  margin: 0 !important;
  padding: clamp(60px, 9vh, 104px) max(20px, calc((100vw - var(--maxw)) / 2 + 24px)) clamp(58px, 8vh, 98px) !important;
  color: var(--ui-ink) !important;
  background:
    linear-gradient(90deg, rgba(242,250,250,.84) 0%, rgba(242,250,250,.66) 34%, rgba(255,255,255,.18) 58%, rgba(255,255,255,.01) 100%),
    url('/assets/images/background.png') center/cover no-repeat fixed !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  justify-content: center !important;
  text-align: left !important;
}

.home-hero::before {
  background:
    linear-gradient(90deg, rgba(236,249,249,.34), rgba(255,255,255,.10) 48%, rgba(255,255,255,0) 70%),
    radial-gradient(circle at 18% 22%, rgba(11,114,133,.07), transparent 20rem),
    radial-gradient(circle at 84% 18%, rgba(245,159,0,.04), transparent 18rem) !important;
}

.home-hero .hero-logo {
  display: none !important;
}

.home-intro {
  width: min(100%, 1040px) !important;
  margin: 0 0 30px !important;
  padding: 0 4px !important;
  position: relative;
  z-index: 1;
  text-align: left !important;
}

.home-kicker {
  display: inline-block !important;
  min-height: 0 !important;
  padding: 0 0 7px !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--ui-primary) !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  margin: 0 0 14px !important;
  border-bottom: 2px solid rgba(11,114,133,.22) !important;
}

.home-lead {
  max-width: 760px !important;
  font-size: clamp(1rem, 1.45vw, 1.24rem) !important;
  line-height: 1.65 !important;
  color: var(--ui-muted) !important;
  margin: 0 0 18px !important;
}

.home-hero-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 12px !important;
  margin-top: 24px !important;
}

.home-primary-cta {
  display: inline-flex !important;
  min-height: 54px !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 22px !important;
  border-radius: 12px 12px 12px 3px !important;
  background: #0b7285 !important;
  color: #fff !important;
  text-decoration: none !important;
  font-weight: 950 !important;
  box-shadow: 0 18px 38px rgba(11,114,133,.25) !important;
}

.home-primary-cta span {
  margin-left: 2px !important;
}

.home-footnote-trigger {
  min-height: 44px !important;
  padding: 0 12px !important;
  border: 0 !important;
  border-bottom: 2px solid rgba(11,114,133,.34) !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--ui-ink) !important;
  font-weight: 850 !important;
  cursor: pointer !important;
}

.home-trust-row {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  gap: 10px !important;
  margin-bottom: 8px !important;
}

.home-trust-row span {
  display: inline-flex !important;
  min-height: 34px !important;
  align-items: center !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.82) !important;
  border: 1px solid rgba(16,24,40,.08) !important;
  color: var(--ui-ink-2) !important;
  font-size: .86rem !important;
  font-weight: 800 !important;
}

.school-chooser {
  width: min(100%, 760px) !important;
  margin: 0 !important;
  padding: 30px !important;
  border-radius: 14px 14px 14px 3px !important;
  border: 1px solid rgba(16,24,40,.10) !important;
  border-left: 6px solid var(--ui-primary) !important;
  background: rgba(255,255,255,.94) !important;
  box-shadow: 0 22px 60px rgba(16,24,40,.14) !important;
  backdrop-filter: blur(10px) saturate(145%) !important;
  -webkit-backdrop-filter: blur(10px) saturate(145%) !important;
  text-align: left !important;
}

.school-chooser .ak24-info,
.school-chooser > hr {
  display: none !important;
}

.school-chooser .ak24-form {
  margin-bottom: 0 !important;
}

.school-chooser h1,
.school-chooser h2,
.ak24-hero-title {
  color: var(--ui-ink) !important;
  letter-spacing: 0 !important;
}

.ak24-hero-title {
  display: grid !important;
  gap: 12px !important;
  margin: 0 0 18px !important;
  max-width: 940px !important;
}

.home-title-main {
  display: block !important;
  max-width: none !important;
  font-size: clamp(2.25rem, 2.85vw, 3.55rem) !important;
  line-height: .98 !important;
  letter-spacing: 0 !important;
  white-space: nowrap !important;
}

.home-title-sub {
  display: block !important;
  max-width: 760px !important;
  font-size: clamp(1.35rem, 2.1vw, 2.45rem) !important;
  line-height: 1.12 !important;
  font-weight: 850 !important;
  color: rgba(16, 24, 40, .86) !important;
}

.school-chooser p {
  color: var(--ui-muted) !important;
}

.home-cost-link {
  display: inline-flex !important;
  min-height: 20px !important;
  margin: 0 auto !important;
  padding: 0 4px 3px !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(11,114,133,.22) !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--ui-muted) !important;
  font-size: .67rem !important;
  font-weight: 850 !important;
  cursor: pointer !important;
}

.home-cost-link:hover {
  color: var(--ui-primary) !important;
  border-bottom-color: var(--ui-primary) !important;
}

.ak24-btn-primary,
.btn.primary,
.btn-primary,
button.primary,
input[type="submit"] {
  border: 0 !important;
  color: #fff !important;
  background: linear-gradient(135deg, var(--ui-primary), var(--ui-primary-2)) !important;
  border-radius: var(--ui-radius-sm) !important;
  box-shadow: 0 16px 34px rgba(11,114,133,.28) !important;
  font-weight: 800 !important;
}

.ak24-btn-primary:hover,
.btn.primary:hover,
.btn-primary:hover,
button.primary:hover,
input[type="submit"]:hover {
  transform: translateY(-2px);
  box-shadow: 0 20px 44px rgba(11,114,133,.34) !important;
}

.ak24-btn-secondary,
.btn,
.btn-light,
.card-cta {
  border: 1px solid var(--ui-line) !important;
  background: rgba(255,255,255,.88) !important;
  color: var(--ui-ink) !important;
  border-radius: var(--ui-radius-sm) !important;
  font-weight: 750 !important;
}

.ak24-btn-secondary:hover,
.btn:hover,
.btn-light:hover,
.card-cta:hover {
  transform: translateY(-1px);
  border-color: rgba(11,114,133,.22) !important;
  box-shadow: var(--ui-shadow-sm) !important;
}

.ak24-card,
.ak24-highlight {
  border-radius: var(--ui-radius) !important;
  border: 1px solid var(--ui-line) !important;
  box-shadow: 0 8px 24px rgba(16,24,40,.06) !important;
}

.home-field {
  position: relative !important;
  display: grid !important;
  gap: 7px !important;
}

.home-field label,
.school-chooser label {
  color: var(--ui-ink-2) !important;
  font-size: .82rem !important;
  font-weight: 850 !important;
}

#school-select-toggle {
  width: 100% !important;
  min-height: 54px !important;
  padding: 0 16px !important;
  border-radius: var(--ui-radius-sm) !important;
  border: 1px solid var(--ui-line-strong) !important;
  background: #fff !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  cursor: pointer !important;
  color: var(--ui-muted) !important;
  font-weight: 800 !important;
}

.home-suggest-wrap,
.home-select-field {
  position: relative !important;
}

#school-select-list,
#school-suggestions {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  top: 100% !important;
  margin-top: 8px !important;
  background: #fff !important;
  border-radius: var(--ui-radius) !important;
  border: 1px solid var(--ui-line) !important;
  box-shadow: var(--ui-shadow) !important;
  max-height: 280px !important;
  overflow: auto !important;
  z-index: 30 !important;
}

.ak24-search-row {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 14px !important;
  align-items: end !important;
  margin-top: 16px !important;
}

.home-actions {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 12px !important;
  align-items: start !important;
  margin-top: 22px !important;
}

.home-actions > * {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 52px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-sizing: border-box !important;
  text-align: center !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.home-actions .home-free-action {
  width: 100% !important;
  min-height: 0 !important;
  display: grid !important;
  gap: 6px !important;
  align-items: start !important;
  justify-content: stretch !important;
}

.home-actions .home-free-action > a {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 52px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-sizing: border-box !important;
  padding-left: 12px !important;
  padding-right: 12px !important;
  font-size: clamp(.78rem, 1.25vw, .9rem) !important;
}

.home-actions > button,
.home-actions > a {
  padding-left: 12px !important;
  padding-right: 12px !important;
  font-size: clamp(.78rem, 1.25vw, .95rem) !important;
}

.home-error {
  display: block !important;
  margin-top: 10px !important;
  color: #b42318 !important;
  font-weight: 800 !important;
}

.home-content-band {
  padding: 88px 20px !important;
  background: linear-gradient(180deg, #fff, #f6fbfb) !important;
}

.home-content-shell {
  width: min(100%, var(--maxw)) !important;
  margin: 0 auto !important;
}

.home-section-head {
  max-width: 760px !important;
  margin-bottom: 30px !important;
}

.home-section-head h2 {
  margin: 0 0 12px !important;
  font-size: clamp(1.8rem, 3vw, 3.1rem) !important;
  line-height: 1.08 !important;
}

.home-section-head p {
  color: var(--ui-muted) !important;
  font-size: 1.05rem !important;
}

.home-option-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

.home-option-card {
  min-height: 250px !important;
  padding: 24px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  background: rgba(255,255,255,.94) !important;
  border-radius: 14px 14px 14px 3px !important;
}

.home-card-index {
  display: inline-flex !important;
  min-height: 28px !important;
  align-items: center !important;
  padding: 0 0 5px !important;
  border-radius: 0 !important;
  background: transparent !important;
  border-bottom: 2px solid rgba(11,114,133,.22) !important;
  color: var(--ui-primary) !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
}

.home-option-card h3 {
  margin: 22px 0 10px !important;
  font-size: 1.35rem !important;
}

.home-option-card p {
  color: var(--ui-muted) !important;
  line-height: 1.6 !important;
}

.home-option-card button,
.home-option-card a {
  margin-top: auto !important;
  display: inline-flex !important;
  min-height: 42px !important;
  align-items: center !important;
  padding: 0 14px !important;
  border-radius: 10px 10px 10px 3px !important;
  border: 1px solid var(--ui-line) !important;
  background: #fff !important;
  color: var(--ui-primary) !important;
  font-weight: 900 !important;
  text-decoration: none !important;
  cursor: pointer !important;
}

.home-highlight-card {
  background: linear-gradient(135deg, rgba(11,114,133,.10), rgba(245,159,0,.14)) !important;
}

.home-image-break {
  display: grid !important;
  grid-template-columns: minmax(0, 1.18fr) minmax(280px, .82fr) !important;
  gap: 18px !important;
  align-items: stretch !important;
  margin: 28px 0 !important;
}

.home-image-card {
  position: relative !important;
  min-height: 340px !important;
  margin: 0 !important;
  overflow: hidden !important;
  border-radius: 18px 18px 18px 4px !important;
  border: 1px solid rgba(16,24,40,.10) !important;
  background: #dcebed !important;
  box-shadow: 0 18px 54px rgba(16,24,40,.12) !important;
}

.home-image-card-wide {
  min-height: 390px !important;
}

.home-image-card-tall {
  min-height: 390px !important;
}

.home-image-card img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center !important;
  filter: saturate(1.02) contrast(1.02) !important;
}

.home-image-card::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(180deg, rgba(16,24,40,0) 45%, rgba(16,24,40,.66) 100%) !important;
  pointer-events: none !important;
}

.home-image-card figcaption {
  position: absolute !important;
  left: 20px !important;
  right: 20px !important;
  bottom: 18px !important;
  z-index: 1 !important;
  display: grid !important;
  gap: 4px !important;
  color: #fff !important;
}

.home-image-card figcaption strong {
  font-size: clamp(1.25rem, 2vw, 1.7rem) !important;
  line-height: 1.08 !important;
  font-weight: 950 !important;
}

.home-image-card figcaption span {
  max-width: 520px !important;
  color: rgba(255,255,255,.88) !important;
  font-weight: 750 !important;
}

.home-process-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 1px !important;
  margin: 28px 0 !important;
  border: 1px solid var(--ui-line) !important;
  border-radius: 14px 14px 14px 3px !important;
  overflow: hidden !important;
  background: var(--ui-line) !important;
}

.home-process-grid > div {
  padding: 22px !important;
  background: #fff !important;
  display: grid !important;
  gap: 7px !important;
}

.home-process-grid strong {
  color: var(--ui-ink) !important;
}

.home-process-grid span {
  color: var(--ui-muted) !important;
}

.home-faq-grid {
  display: grid !important;
  gap: 12px !important;
}

.home-faq-grid details {
  border: 1px solid var(--ui-line) !important;
  border-radius: 12px 12px 12px 3px !important;
  background: #fff !important;
  padding: 0 !important;
  box-shadow: 0 8px 24px rgba(16,24,40,.04) !important;
}

.home-faq-grid summary {
  cursor: pointer !important;
  padding: 18px 20px !important;
  font-weight: 900 !important;
}

.home-faq-grid p {
  margin: 0 !important;
  padding: 0 20px 18px !important;
  color: var(--ui-muted) !important;
}

/* Shop listing */
.shop-switcher {
  margin: 0 0 24px !important;
  padding: 12px !important;
  border: 1px solid var(--ui-line) !important;
  border-radius: var(--ui-radius-lg) !important;
  background: rgba(255,255,255,.74) !important;
  box-shadow: var(--ui-shadow-sm) !important;
}

.shop-switcher__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px !important;
}

.shop-news {
  margin: 0 0 24px !important;
  padding: 18px !important;
  border-radius: var(--ui-radius-lg) !important;
  border: 1px solid var(--ui-line) !important;
  background: rgba(255,255,255,.82) !important;
  box-shadow: var(--ui-shadow-sm) !important;
}

.shop-news h2 {
  font-size: 1.15rem !important;
  font-weight: 850 !important;
}

.shop-news-item {
  border: 1px solid rgba(16,24,40,.08) !important;
  border-radius: var(--ui-radius) !important;
  box-shadow: none !important;
}

.shop-assist-bar {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(420px, .8fr) !important;
  gap: 18px !important;
  align-items: end !important;
  margin: 20px 0 14px !important;
  padding: 20px !important;
  border: 1px solid rgba(16,24,40,.08) !important;
  border-radius: var(--ui-radius-lg) !important;
  background: rgba(255,255,255,.92) !important;
  box-shadow: var(--ui-shadow-sm) !important;
}

.shop-assist-copy {
  display: grid !important;
  gap: 6px !important;
}

.shop-assist-copy strong {
  color: var(--ui-ink) !important;
  font-size: clamp(1.2rem, 2vw, 1.7rem) !important;
  line-height: 1.1 !important;
}

.shop-assist-copy span:last-child {
  color: var(--ui-muted) !important;
}

.shop-eyebrow {
  width: fit-content !important;
  display: inline-flex !important;
  min-height: 28px !important;
  align-items: center !important;
  padding: 0 10px !important;
  border-radius: 999px !important;
  background: rgba(11,114,133,.10) !important;
  color: var(--ui-primary) !important;
  font-size: .76rem !important;
  font-weight: 900 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
}

.shop-assist-controls {
  display: grid !important;
  grid-template-columns: minmax(0, 1.2fr) minmax(150px, .7fr) !important;
  gap: 12px !important;
}

.shop-assist-controls label {
  display: grid !important;
  gap: 7px !important;
  color: var(--ui-muted) !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
}

.shop-result-meta {
  margin: 0 0 14px !important;
  color: var(--ui-muted) !important;
  font-size: .92rem !important;
  font-weight: 750 !important;
}

.shop-result-meta span {
  color: var(--ui-primary) !important;
  font-weight: 950 !important;
}

.shop-empty-state {
  margin: 24px 0 !important;
  padding: 34px !important;
  border: 1px dashed rgba(11,114,133,.26) !important;
  border-radius: var(--ui-radius-lg) !important;
  background: rgba(255,255,255,.78) !important;
  text-align: center !important;
}

.shop-empty-state h2 {
  margin: 0 0 8px !important;
  font-size: clamp(1.4rem, 2.3vw, 2rem) !important;
}

.shop-empty-state p {
  max-width: 560px !important;
  margin: 0 auto !important;
  color: var(--ui-muted) !important;
}

.shop-recent-products {
  margin: 0 0 18px !important;
  padding: 14px !important;
  border: 1px solid var(--ui-line) !important;
  border-radius: var(--ui-radius-lg) !important;
  background: linear-gradient(135deg, rgba(11,114,133,.08), rgba(255,255,255,.88)) !important;
}

.shop-recent-head {
  margin: 0 0 10px !important;
  color: var(--ui-muted) !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
}

.shop-recent-list {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
  gap: 10px !important;
}

.shop-recent-list a {
  display: grid !important;
  gap: 3px !important;
  padding: 12px !important;
  border: 1px solid rgba(16,24,40,.08) !important;
  border-radius: var(--ui-radius-sm) !important;
  background: rgba(255,255,255,.86) !important;
  color: var(--ui-ink) !important;
  text-decoration: none !important;
}

.shop-recent-list span {
  color: var(--ui-primary) !important;
  font-weight: 850 !important;
}

#product-filter-form {
  position: sticky !important;
  top: 92px !important;
  z-index: 30 !important;
  margin: 0 0 28px !important;
  padding: 16px !important;
  gap: 12px !important;
  border: 1px solid rgba(16,24,40,.08) !important;
  border-radius: var(--ui-radius-lg) !important;
  background: rgba(255,255,255,.88) !important;
  box-shadow: var(--ui-shadow-sm) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
}

#product-filter-form label {
  min-width: 156px !important;
  flex: 1 1 156px !important;
  color: var(--ui-muted) !important;
  font-size: .78rem !important;
  font-weight: 800 !important;
  text-transform: uppercase;
  letter-spacing: .05em;
}

#product-filter-form select {
  width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 11px 38px 11px 12px !important;
  font-size: .95rem !important;
  text-transform: none;
  letter-spacing: 0;
}

#product-filter-form > a {
  align-self: stretch !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 44px !important;
  padding: 0 14px !important;
  margin-left: 0 !important;
  border: 1px solid var(--ui-line) !important;
  border-radius: var(--ui-radius-sm) !important;
  background: #fff !important;
  color: var(--ui-primary) !important;
  text-decoration: none !important;
  font-weight: 800 !important;
}

.product-grid {
  grid-template-columns: repeat(auto-fill, minmax(245px, 1fr)) !important;
  gap: 22px !important;
}

.product-card {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  border: 1px solid rgba(16,24,40,.08) !important;
  border-radius: var(--ui-radius-lg) !important;
  background: rgba(255,255,255,.92) !important;
  box-shadow: 0 12px 34px rgba(16,24,40,.08) !important;
}

.product-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 18% 12%, rgba(18,184,134,.12), transparent 12rem),
    radial-gradient(circle at 86% 18%, rgba(245,159,0,.10), transparent 12rem);
  opacity: 0;
  transition: opacity .25s ease;
}

.product-card:hover {
  transform: translateY(-5px);
  border-color: rgba(11,114,133,.20) !important;
  box-shadow: 0 24px 62px rgba(16,24,40,.14) !important;
}

.product-card:hover::before {
  opacity: 1;
}

.product-link {
  display: flex !important;
  flex-direction: column !important;
  min-height: 100% !important;
  color: inherit !important;
}

.product-card .product-render,
.pd-card-media .product-render {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(145deg, #fff, #eef5f7) !important;
  border-radius: var(--ui-radius) !important;
  /* Muss exakt der Backend-Overlay-Vorschau entsprechen: padding-top 120%. */
  aspect-ratio: 5 / 6 !important;
}

.product-card .product-render {
  margin: 14px 14px 0 !important;
}

.product-render .base {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  filter: drop-shadow(0 18px 22px rgba(16,24,40,.10));
  transform: none !important;
}

.product-render .logo {
  position: absolute !important;
  object-fit: contain !important;
  max-width: none !important;
  max-height: none !important;
}

.product-remainder-badge {
  position: absolute !important;
  left: 12px !important;
  top: 12px !important;
  z-index: 5 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  max-width: calc(100% - 24px) !important;
  padding: 7px 10px !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, .94) !important;
  border: 1px solid rgba(15, 23, 42, .12) !important;
  color: #0f172a !important;
  box-shadow: 0 10px 24px rgba(15, 23, 42, .14) !important;
  font-size: .76rem !important;
  font-weight: 900 !important;
  line-height: 1 !important;
}

.product-remainder-badge img {
  width: 18px !important;
  height: 18px !important;
  object-fit: contain !important;
  filter: none !important;
}

.product-info-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 14px !important;
  padding: 18px 18px 10px !important;
}

.product-info-main h2 {
  margin: 0 0 6px !important;
  font-size: clamp(1.02rem, 1.5vw, 1.2rem) !important;
  line-height: 1.18 !important;
  font-weight: 850 !important;
  color: var(--ui-ink) !important;
}

.product-manufacturer-line {
  margin: 0 0 12px !important;
  color: var(--ui-muted) !important;
  font-size: .88rem !important;
}

.product-badges {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  margin: 10px 0 !important;
}

.badge,
.product-badges .badge {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 24px !important;
  padding: 4px 8px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(11,114,133,.14) !important;
  background: rgba(11,114,133,.08) !important;
  color: #075766 !important;
  box-shadow: none !important;
  font-size: .72rem !important;
  font-weight: 850 !important;
}

.price,
.pd-price-main {
  color: var(--ui-primary) !important;
  font-weight: 900 !important;
}

.pd-remainder-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  width: fit-content !important;
  margin-top: 10px !important;
  padding: 7px 10px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(251, 146, 60, .42) !important;
  background: #fff7ed !important;
  color: #9a3412 !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
}

.pd-remainder-badge img {
  width: 18px !important;
  height: 18px !important;
  object-fit: contain !important;
}

.product-card .price {
  margin: 12px 0 0 !important;
  font-size: 1.05rem !important;
}

.product-stock-line {
  display: grid !important;
  gap: 2px !important;
  margin: 8px 0 0 !important;
  padding: 9px 10px !important;
  border-radius: 8px !important;
  background: #f8fafc !important;
  border: 1px solid rgba(148, 163, 184, 0.26) !important;
  color: #334155 !important;
  font-size: .78rem !important;
  line-height: 1.25 !important;
}

.product-stock-line strong {
  color: #0f172a !important;
  font-size: .86rem !important;
}

.product-stock-line.is-stocked {
  background: #ecfdf5 !important;
  border-color: rgba(16, 185, 129, 0.24) !important;
}

.product-stock-line.is-backorder {
  background: #fffbeb !important;
  border-color: rgba(245, 158, 11, 0.32) !important;
}

.product-stock-line.is-backorder strong {
  color: #92400e !important;
}

.product-size-line {
  display: none !important;
  align-items: center !important;
  gap: 7px !important;
  margin: 8px 0 0 !important;
  color: var(--ui-muted) !important;
  font-size: .72rem !important;
  line-height: 1.2 !important;
}

.product-size-line__label {
  flex: 0 0 auto !important;
  color: #64748b !important;
  font-weight: 900 !important;
  letter-spacing: .03em !important;
  text-transform: uppercase !important;
}

.product-size-line__chips {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 4px !important;
  min-width: 0 !important;
}

.product-size-line__chips span {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 19px !important;
  padding: 2px 6px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(11, 114, 133, .14) !important;
  background: rgba(11, 114, 133, .06) !important;
  color: #075766 !important;
  font-size: .7rem !important;
  font-weight: 850 !important;
}

.product-brand-logo {
  width: 54px !important;
  height: 54px !important;
  object-fit: contain !important;
  border: 1px solid var(--ui-line) !important;
  border-radius: var(--ui-radius-sm) !important;
  background: #fff !important;
  padding: 7px !important;
}

.card-cta {
  margin: auto 18px 18px !important;
  padding: 11px 14px !important;
  text-align: center !important;
  color: var(--ui-primary) !important;
}

/* Product detail */
.product-detail .wrap {
  max-width: var(--maxw) !important;
  margin: 0 auto !important;
}

.pd-page-heading {
  max-width: 820px !important;
  margin: 0 0 24px !important;
}

.pd-top-grid {
  grid-template-columns: minmax(0, 1.45fr) minmax(340px, .72fr) !important;
  gap: 28px !important;
  align-items: start !important;
}

.pd-card {
  border: 1px solid rgba(16,24,40,.08) !important;
  border-radius: var(--ui-radius-lg) !important;
  background: rgba(255,255,255,.92) !important;
  box-shadow: var(--ui-shadow-sm) !important;
}

.pd-card-media {
  overflow: hidden !important;
  padding: 26px !important;
}

.pd-media-inner {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 22px !important;
}

.pd-card-buy {
  position: sticky !important;
  top: 104px !important;
  padding: 22px !important;
  box-shadow: var(--ui-shadow) !important;
}

.pd-header {
  margin: 0 0 6px !important;
}

.pd-title {
  margin: 0 !important;
  font-size: clamp(2rem, 4vw, 4.1rem) !important;
  line-height: .98 !important;
  letter-spacing: 0 !important;
  font-weight: 900 !important;
  color: var(--ui-ink) !important;
}

.breadcrumbs {
  margin: 0 0 18px !important;
}

.breadcrumbs a {
  display: inline-flex !important;
  min-height: 38px !important;
  align-items: center !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  background: rgba(11,114,133,.08) !important;
  color: var(--ui-primary) !important;
  font-weight: 800 !important;
}

.pd-card-media .product-render {
  width: min(100%, 760px) !important;
  min-height: 0 !important;
  padding: 0 !important;
  border-radius: var(--ui-radius-lg) !important;
  background: linear-gradient(180deg, #fff, #f7fbfb) !important;
  box-shadow: inset 0 0 0 1px rgba(16,24,40,.06), 0 26px 56px rgba(11,114,133,.08) !important;
  display: block !important;
  margin: 0 auto !important;
}

.pd-card-media .product-render .base {
  max-height: none !important;
  width: 100% !important;
  max-width: none !important;
}

.pd-image-thumbs {
  margin-top: 0 !important;
  padding: 18px !important;
  border: 1px solid var(--ui-line) !important;
  border-radius: var(--ui-radius) !important;
  background: rgba(248,250,252,.78) !important;
}

.pd-section-header {
  margin-bottom: 10px !important;
}

.pd-section-label,
.pd-label {
  color: var(--ui-muted) !important;
  font-size: .76rem !important;
  font-weight: 900 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
}

.pd-image-thumbs-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(68px, 1fr)) !important;
  gap: 10px !important;
}

.pd-swatch {
  width: 100% !important;
  height: 72px !important;
  padding: 5px !important;
  border-radius: var(--ui-radius-sm) !important;
  border: 1px solid var(--ui-line-strong) !important;
  background: #fff !important;
  box-shadow: 0 6px 16px rgba(16,24,40,.06) !important;
}

.pd-swatch img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}

.pd-swatch:hover,
.pd-swatch.is-active {
  border-color: var(--ui-primary) !important;
  box-shadow: 0 0 0 4px rgba(11,114,133,.12), 0 10px 22px rgba(16,24,40,.10) !important;
  transform: translateY(-2px);
}

.pd-form {
  display: grid !important;
  gap: 18px !important;
}

.pd-buy-price-row {
  padding: 18px !important;
  border-radius: var(--ui-radius) !important;
  background:
    linear-gradient(135deg, rgba(11,114,133,.10), rgba(245,159,0,.10)) !important;
}

.pd-price-main {
  display: block !important;
  font-size: clamp(2rem, 4vw, 3.2rem) !important;
  line-height: 1 !important;
}

.pd-price-tax-hint {
  display: block !important;
  margin-top: 8px !important;
  color: var(--ui-muted) !important;
  font-size: .9rem !important;
}

.pd-trust-grid {
  display: grid !important;
  gap: 10px !important;
}

.pd-trust-grid > div {
  padding: 12px !important;
  border: 1px solid var(--ui-line) !important;
  border-radius: var(--ui-radius-sm) !important;
  background: rgba(248,250,252,.82) !important;
}

.pd-trust-grid strong {
  display: block !important;
  color: var(--ui-ink) !important;
  font-size: .92rem !important;
}

.pd-trust-grid span {
  display: block !important;
  margin-top: 2px !important;
  color: var(--ui-muted) !important;
  font-size: .84rem !important;
  line-height: 1.35 !important;
}

.pd-volume {
  padding: 16px !important;
  border: 1px solid var(--ui-line) !important;
  border-radius: var(--ui-radius) !important;
  background: #fff !important;
}

.pd-volume-table,
table.cart-table,
.checkout-card table {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  overflow: hidden !important;
  border-radius: var(--ui-radius) !important;
}

.pd-volume-table th,
.pd-volume-table td,
table.cart-table th,
table.cart-table td,
.checkout-card th,
.checkout-card td {
  padding: 12px !important;
  border-bottom: 1px solid rgba(16,24,40,.08) !important;
}

.pd-volume-table th,
table.cart-table th,
.checkout-card th {
  color: var(--ui-muted) !important;
  background: var(--ui-surface-soft) !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
}

.pd-volume-note {
  color: var(--ui-muted) !important;
  font-size: .88rem !important;
}

.pd-field {
  display: grid !important;
  gap: 7px !important;
}

.pd-select,
.pd-qty-input {
  min-height: 48px !important;
  padding: 0 12px !important;
  font-size: 1rem !important;
}

.pd-qty-row {
  display: grid !important;
  grid-template-columns: 120px 1fr !important;
  gap: 14px !important;
  align-items: end !important;
}

.pd-checkbox-label {
  min-height: 48px !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 10px 12px !important;
  border: 1px solid var(--ui-line) !important;
  border-radius: var(--ui-radius-sm) !important;
  background: #fff !important;
  color: var(--ui-ink-2) !important;
  font-weight: 750 !important;
}

.pd-subtotal-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: 16px 0 !important;
  border-top: 1px solid var(--ui-line) !important;
  color: var(--ui-muted) !important;
}

.pd-subtotal-row strong {
  color: var(--ui-ink) !important;
  font-size: 1.3rem !important;
}

.pd-btn-add {
  width: 100% !important;
  min-height: 54px !important;
  font-size: 1rem !important;
}

.pd-card-desc {
  padding: 0 !important;
  overflow: hidden !important;
}

.pd-desc-title {
  margin: 0 !important;
  padding: 22px 26px !important;
  font-size: clamp(1.4rem, 2.2vw, 2rem) !important;
  font-weight: 900 !important;
  cursor: pointer !important;
  list-style: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}

.pd-desc-title::-webkit-details-marker {
  display: none !important;
}

.pd-desc-title::after {
  content: "+" !important;
  width: 34px !important;
  height: 34px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 999px !important;
  background: rgba(11,114,133,.10) !important;
  color: var(--ui-primary) !important;
}

.pd-card-desc[open] .pd-desc-title::after {
  content: "-" !important;
}

.product-description {
  color: var(--ui-ink-2) !important;
  line-height: 1.75 !important;
  padding: 0 26px 26px !important;
}

.pd-card-desc .pd-manufacturer {
  margin: 0 26px 20px !important;
}

.product-description p {
  margin: 0 0 13px !important;
}

.product-description strong {
  color: var(--ui-ink) !important;
}

/* Cart and checkout */
.cart-form,
.checkout-grid,
.checkout-card,
.checkout-summary,
.legal-page,
.auth-card,
.admin-page,
.admin-card,
.dashboard-card,
[class*="admin"] .card {
  border-radius: var(--ui-radius-lg) !important;
}

table.cart-table,
.checkout-card,
.checkout-summary,
.cart-form {
  border: 1px solid var(--ui-line) !important;
  background: rgba(255,255,255,.92) !important;
  box-shadow: var(--ui-shadow-sm) !important;
}

.checkout-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, .85fr) !important;
  gap: 24px !important;
  align-items: start !important;
}

.checkout-card,
.checkout-summary {
  padding: 22px !important;
}

.checkout-card h2,
.checkout-summary h2,
.cart-form h1 {
  color: var(--ui-ink) !important;
  font-weight: 900 !important;
}

/* Admin surfaces */
.admin-dashboard,
.admin-school-dashboard,
.admin-page {
  max-width: var(--maxw) !important;
  margin: 0 auto !important;
}

.admin-dashboard section,
.admin-school-dashboard section,
.admin-dashboard [style*="background:#fff"],
.admin-school-dashboard [style*="background:#fff"] {
  border-radius: var(--ui-radius-lg) !important;
  border: 1px solid var(--ui-line) !important;
  background: rgba(255,255,255,.92) !important;
  box-shadow: var(--ui-shadow-sm) !important;
}

.admin-dashboard a,
.admin-school-dashboard a {
  border-radius: var(--ui-radius-sm) !important;
}

.admin-setup-panel {
  display: grid !important;
  grid-template-columns: minmax(0, .95fr) minmax(360px, 1.05fr) !important;
  gap: 20px !important;
  align-items: start !important;
  margin: 0 0 22px !important;
  padding: 22px !important;
  border: 1px solid rgba(16,24,40,.08) !important;
  border-radius: var(--ui-radius-lg) !important;
  background:
    linear-gradient(135deg, rgba(11,114,133,.10), rgba(255,255,255,.92)),
    #fff !important;
  box-shadow: var(--ui-shadow-sm) !important;
}

.admin-kicker {
  margin: 0 0 8px !important;
  color: var(--ui-primary) !important;
  font-size: .76rem !important;
  font-weight: 950 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
}

.admin-setup-panel h2 {
  margin: 0 0 8px !important;
  font-size: clamp(1.35rem, 2.2vw, 2rem) !important;
}

.admin-setup-panel p:not(.admin-kicker) {
  margin: 0 !important;
  color: var(--ui-muted) !important;
  line-height: 1.6 !important;
}

.admin-setup-steps {
  display: grid !important;
  gap: 9px !important;
}

.admin-setup-steps a {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  min-height: 48px !important;
  padding: 9px 12px !important;
  border: 1px solid rgba(16,24,40,.08) !important;
  border-radius: var(--ui-radius-sm) !important;
  background: rgba(255,255,255,.84) !important;
  color: var(--ui-ink) !important;
  font-weight: 850 !important;
}

.admin-setup-steps span {
  width: 28px !important;
  height: 28px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 999px !important;
  background: var(--ui-primary) !important;
  color: #fff !important;
  font-size: .82rem !important;
}

/* Modal and popup */
.ak24-modal-content,
.school-popup-box {
  border-radius: var(--ui-radius-lg) !important;
  border: 1px solid rgba(255,255,255,.70) !important;
  box-shadow: var(--ui-shadow-lg) !important;
}

.school-popup-overlay {
  background: rgba(16,24,40,.58) !important;
}

.floating-shirt-cta {
  position: fixed !important;
  right: clamp(14px, 2vw, 28px) !important;
  bottom: clamp(14px, 2vw, 28px) !important;
  z-index: 95 !important;
  width: 176px !important;
  display: grid !important;
  justify-items: center !important;
  gap: 4px !important;
  padding: 14px 12px 12px !important;
  border-radius: 18px 18px 18px 5px !important;
  background: rgba(255,255,255,.86) !important;
  border: 1px solid rgba(255,255,255,.78) !important;
  box-shadow: 0 22px 60px rgba(16,24,40,.18), 0 0 0 1px rgba(16,24,40,.05) !important;
  color: var(--ui-ink) !important;
  text-align: center !important;
  text-decoration: none !important;
  backdrop-filter: blur(18px) saturate(160%) !important;
  -webkit-backdrop-filter: blur(18px) saturate(160%) !important;
}

.floating-shirt-cta:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 28px 72px rgba(16,24,40,.22), 0 0 0 1px rgba(11,114,133,.16) !important;
}

.floating-shirt-cta__eyebrow {
  color: #e64980 !important;
  font-size: .78rem !important;
  font-weight: 950 !important;
  letter-spacing: .08em !important;
}

.floating-shirt-cta__text {
  max-width: 136px !important;
  color: var(--ui-ink) !important;
  font-size: .84rem !important;
  font-weight: 900 !important;
  line-height: 1.12 !important;
}

.floating-shirt-cta img {
  width: 82px !important;
  height: 82px !important;
  object-fit: contain !important;
  margin: 2px 0 !important;
}

.floating-shirt-cta__link {
  display: inline-flex !important;
  min-height: 30px !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 10px !important;
  border-radius: 999px !important;
  color: #fff !important;
  background: linear-gradient(135deg, var(--ui-primary), var(--ui-primary-2)) !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
}

/* States */
.muted,
small {
  color: var(--ui-muted) !important;
}

[disabled],
.disabled {
  opacity: .56 !important;
  cursor: not-allowed !important;
  transform: none !important;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    transition-duration: .01ms !important;
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
  }
}

/* Mobile */
@media (max-width: 979px) {
  .container {
    padding: 18px 14px 34px !important;
  }

  .nav-modern .nav-shell {
    min-height: 66px !important;
    grid-template-columns: auto 1fr auto !important;
    padding: 10px 14px !important;
  }

  .floating-logo {
    display: none !important;
  }

  .brand-logo-mobile {
    display: inline-flex !important;
  }

  .nav-modern .nav-links {
    display: none !important;
  }

  .nav-mobile.open {
    display: grid !important;
    gap: 8px !important;
    padding: 12px 14px 16px !important;
    background: rgba(255,255,255,.98) !important;
    border-bottom: 1px solid rgba(16,24,40,.08) !important;
  }

  .nav-mobile.open a {
    min-height: 44px !important;
    display: flex !important;
    align-items: center !important;
    padding: 0 12px !important;
    border-radius: 10px !important;
    background: rgba(248,250,252,.92) !important;
  }

  #product-filter-form {
    position: static !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    padding: 14px !important;
  }

  #product-filter-form label,
  #product-filter-form > a {
    min-width: 0 !important;
    width: 100% !important;
  }

  .pd-top-grid,
  .checkout-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .pd-card-buy {
    position: static !important;
  }

  .pd-page-heading {
    margin-bottom: 18px !important;
  }

  .pd-card-media {
    padding: 14px !important;
  }

  .pd-card-media .product-render {
    width: min(100%, 560px) !important;
    min-height: 0 !important;
    padding: 0 !important;
  }

  .pd-card-media .product-render .base {
    max-height: none !important;
  }

  .pd-image-thumbs-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }

  .pd-title {
    font-size: clamp(1.8rem, 10vw, 3rem) !important;
  }

  .home-hero {
    min-height: calc(100svh - 66px) !important;
    padding: 34px 14px 52px !important;
    background-attachment: scroll !important;
    align-items: center !important;
  }

  .home-intro,
  .school-chooser {
    width: min(100%, 680px) !important;
  }

  .home-intro {
    text-align: left !important;
  }

  .ak24-search-row,
  .home-actions,
  .home-option-grid,
  .home-image-break,
  .home-process-grid {
    grid-template-columns: 1fr !important;
  }

  .home-image-card,
  .home-image-card-wide,
  .home-image-card-tall {
    min-height: 330px !important;
  }

  .home-content-band {
    padding: 54px 14px !important;
  }

  .home-hero-actions {
    gap: 8px !important;
  }

  .home-option-card {
    min-height: auto !important;
  }

  .shop-assist-bar,
  .shop-assist-controls,
  .admin-setup-panel {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 640px) {
  body {
    background: linear-gradient(180deg, #fbfcff, #f3f7fb 52%, #fff 100%) !important;
  }

  .home-hero {
    min-height: calc(100svh - 64px) !important;
    padding: 26px 12px 34px !important;
    align-items: stretch !important;
    justify-content: center !important;
  }

  .ak24-hero-title {
    gap: 8px !important;
  }

  .home-title-main {
    font-size: clamp(2.15rem, 12vw, 3.45rem) !important;
    line-height: 1.01 !important;
    white-space: normal !important;
  }

  .home-title-sub {
    font-size: clamp(1.18rem, 6vw, 1.65rem) !important;
    line-height: 1.14 !important;
  }

  .home-primary-cta,
  .home-footnote-trigger {
    width: 100% !important;
  }

  .home-footnote-trigger {
    justify-content: center !important;
    border: 1px solid rgba(16,24,40,.12) !important;
    border-radius: 10px 10px 10px 3px !important;
    background: rgba(255,255,255,.76) !important;
  }

  .school-chooser {
    width: 100% !important;
    padding: 18px !important;
  }

  .ak24-search-row,
  .home-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  #product-filter-form {
    grid-template-columns: 1fr !important;
  }

  .product-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  .home-image-break {
    margin: 22px 0 !important;
    gap: 12px !important;
  }

  .home-image-card,
  .home-image-card-wide,
  .home-image-card-tall {
    min-height: 260px !important;
    border-radius: 14px 14px 14px 3px !important;
  }

  .home-image-card figcaption {
    left: 14px !important;
    right: 14px !important;
    bottom: 14px !important;
  }

  .product-card .product-render {
    aspect-ratio: 5 / 6 !important;
  }

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

  .product-brand-logo {
    width: 46px !important;
    height: 46px !important;
  }

  .pd-card-media,
  .pd-card-buy {
    padding: 16px !important;
  }

  .pd-card-desc {
    padding: 0 !important;
  }

  .pd-card-media .product-render {
    width: min(100%, 420px) !important;
    min-height: 0 !important;
    padding: 0 !important;
  }

  .pd-swatch {
    width: 48px !important;
    height: 48px !important;
  }

  .pd-qty-row {
    grid-template-columns: 1fr !important;
  }

  .pd-price-main {
    font-size: 2.25rem !important;
  }

  table.cart-table,
  table.cart-table thead,
  table.cart-table tbody,
  table.cart-table th,
  table.cart-table td,
  table.cart-table tr {
    display: block !important;
    width: 100% !important;
  }

  table.cart-table thead {
    display: none !important;
  }

  table.cart-table tr {
    padding: 12px !important;
    border-bottom: 1px solid var(--ui-line) !important;
  }

  table.cart-table td {
    display: flex !important;
    justify-content: space-between !important;
    gap: 12px !important;
    border-bottom: 0 !important;
  }

  .shop-news {
    padding: 14px !important;
  }

  .floating-shirt-cta {
    width: 132px !important;
    padding: 10px 9px 9px !important;
    right: 10px !important;
    bottom: 10px !important;
  }

  .floating-shirt-cta img {
    width: 58px !important;
    height: 58px !important;
  }

  .floating-shirt-cta__text {
    max-width: 110px !important;
    font-size: .72rem !important;
  }

  .floating-shirt-cta__link {
    min-height: 26px !important;
    font-size: .7rem !important;
  }
}



* {
  scrollbar-color: rgba(11, 114, 133, .38) transparent;
}

html {
  scroll-behavior: smooth;
  background: var(--ui-bg);
}

body {
  min-height: 100vh;
  color: var(--ui-ink);
  background:
    radial-gradient(circle at 12% 0%, rgba(18,184,134,.13), transparent 28rem),
    radial-gradient(circle at 88% 4%, rgba(245,159,0,.13), transparent 24rem),
    linear-gradient(180deg, #fbfcff 0%, var(--ui-bg) 46%, #fff 100%) !important;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  letter-spacing: 0;
  text-rendering: geometricPrecision;
}

img {
  max-width: 100%;
}

a,
button,
input,
select,
textarea {
  transition:
    color .18s ease,
    background-color .18s ease,
    border-color .18s ease,
    box-shadow .18s ease,
    transform .18s ease,
    opacity .18s ease;
}

a:focus-visible,
button:focus-visible,
input:focus,
select:focus,
textarea:focus {
  outline: 3px solid rgba(11, 114, 133, .20) !important;
  outline-offset: 3px;
}

button,
.btn,
[class*="btn"],
input[type="submit"] {
  min-height: 42px;
}

input,
select,
textarea {
  border-radius: var(--ui-radius-sm) !important;
  border: 1px solid var(--ui-line-strong) !important;
  background: #fff !important;
  color: var(--ui-ink) !important;
  box-shadow: 0 1px 0 rgba(16,24,40,.03);
}

input:hover,
select:hover,
textarea:hover {
  border-color: rgba(11,114,133,.34) !important;
}

input:focus,
select:focus,
textarea:focus {
  border-color: rgba(11,114,133,.70) !important;
  box-shadow: 0 0 0 4px rgba(11,114,133,.14), 0 1px 0 rgba(16,24,40,.03) !important;
}

.container {
  width: min(100%, calc(var(--maxw) + 48px));
  margin: 0 auto !important;
  padding: 32px 24px 48px !important;
}

/* Above-the-fold redesign: clean Vereinsshop start area */
header.site-header.nav-modern,
.site-header.nav-modern {
  position: sticky !important;
  top: 0 !important;
  z-index: 1000 !important;
  background: rgba(255,255,255,.97) !important;
  color: #16243c !important;
  border-bottom: 1px solid rgba(16,24,40,.10) !important;
  box-shadow: 0 8px 24px rgba(16,24,40,.07) !important;
  backdrop-filter: saturate(145%) blur(10px) !important;
  -webkit-backdrop-filter: saturate(145%) blur(10px) !important;
}

.nav-modern .nav-shell {
  width: min(100%, calc(var(--maxw) + 40px)) !important;
  min-height: 64px !important;
  margin: 0 auto !important;
  padding: 8px 20px !important;
  display: grid !important;
  grid-template-columns: minmax(150px, 220px) minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 16px !important;
}

.floating-logo,
.brand-logo-mobile {
  display: none !important;
}

.nav-modern .topbar-brand,
.nav-modern .topbar-brand picture {
  display: inline-flex !important;
  align-items: center !important;
  min-width: 0 !important;
  width: auto !important;
  line-height: 0 !important;
}

.nav-modern .topbar-logo {
  display: block !important;
  width: auto !important;
  max-width: 190px !important;
  max-height: 42px !important;
  object-fit: contain !important;
  object-position: left center !important;
  margin: 0 !important;
}

.nav-modern .topbar-logo-club {
  max-width: 150px !important;
  max-height: 42px !important;
}

.nav-modern .nav-links {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 4px !important;
  min-width: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
}

.nav-modern .nav-links a {
  min-height: 34px !important;
  display: inline-flex !important;
  align-items: center !important;
  padding: 8px 10px !important;
  border: 0 !important;
  border-radius: 8px !important;
  color: #25324a !important;
  font-size: .88rem !important;
  font-weight: 750 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  opacity: 1 !important;
}

.nav-modern .nav-links a + a {
  border-left: 0 !important;
}

.nav-modern .nav-links a::after {
  content: none !important;
}

.nav-modern .nav-links a:hover {
  color: #f25c05 !important;
  background: #fff3eb !important;
  box-shadow: none !important;
}

.nav-modern .nav-links .nav-cta {
  background: #16243c !important;
  color: #fff !important;
  padding-inline: 13px !important;
}

.nav-modern .nav-links .nav-cta:hover {
  background: #f25c05 !important;
  color: #fff !important;
}

.nav-modern .nav-actions {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  min-width: max-content !important;
}

.nav-admin-link {
  min-height: 34px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 10px !important;
  border: 1px solid rgba(16,24,40,.12) !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.68) !important;
  color: #526071 !important;
  font-size: .78rem !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.nav-admin-link:hover {
  border-color: rgba(242,92,5,.26) !important;
  color: #f25c05 !important;
  background: #fff8f3 !important;
}

.nav-admin-link-muted {
  opacity: .78 !important;
}

.nav-modern .cart-link {
  flex: 0 0 40px !important;
  width: 40px !important;
  min-width: 40px !important;
  height: 40px !important;
  min-height: 40px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid rgba(16,24,40,.14) !important;
  border-radius: 999px !important;
  background: #16243c !important;
  color: #fff !important;
  box-shadow: 0 10px 22px rgba(16,24,40,.14) !important;
  overflow: visible !important;
  transform: translateZ(0);
  transition: background .16s ease, box-shadow .16s ease, transform .12s ease !important;
}

.nav-modern .cart-link:hover {
  background: #f25c05 !important;
  box-shadow: 0 14px 28px rgba(242,92,5,.24) !important;
  transform: translateY(-1px) !important;
}

.nav-modern .cart-link:active {
  transform: translateY(0) scale(.98) !important;
}

.cart-icon {
  width: 20px !important;
  height: 20px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.cart-icon::before,
.cart-icon::after {
  content: none !important;
  display: none !important;
}

.cart-icon svg {
  width: 20px !important;
  height: 20px !important;
  display: block !important;
  fill: none !important;
  stroke: currentColor !important;
  stroke-width: 2 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

.nav-modern .cart-link .badge,
#cart-count {
  position: absolute !important;
  top: -5px !important;
  right: -6px !important;
  min-width: 18px !important;
  height: 18px !important;
  padding: 0 5px !important;
  border-radius: 999px !important;
  background: #f25c05 !important;
  color: #fff !important;
  font-size: 10px !important;
  font-weight: 900 !important;
  line-height: 18px !important;
  text-align: center !important;
  box-shadow: 0 0 0 2px #fff !important;
  transform: none !important;
}

.nav-modern .nav-toggle {
  width: 40px !important;
  height: 40px !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  flex-direction: column !important;
  gap: 4px !important;
  padding: 0 !important;
  border: 1px solid rgba(16,24,40,.14) !important;
  border-radius: 999px !important;
  background: #fff !important;
  color: #16243c !important;
  box-shadow: none !important;
}

.nav-modern .nav-toggle::after {
  content: none !important;
}

.nav-modern .nav-toggle .bar {
  display: block !important;
  width: 18px !important;
  height: 2px !important;
  margin: 0 !important;
  border-radius: 999px !important;
  background: #16243c !important;
}

.nav-mobile {
  display: none;
  background: #fff !important;
  border-top: 1px solid rgba(16,24,40,.10) !important;
  box-shadow: 0 18px 36px rgba(16,24,40,.12) !important;
}

.nav-mobile.open {
  display: grid !important;
}

.nav-mobile a {
  min-height: 44px !important;
  color: #16243c !important;
  font-weight: 760 !important;
}

.nav-mobile-divider {
  display: block !important;
  height: 1px !important;
  margin: 4px 16px !important;
  background: rgba(16,24,40,.10) !important;
}

body.home {
  background: #f5f7fb !important;
}

body.home main.container,
body.home .site-header + main.container,
body.home:not(.admin):not(.auth) main.container {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.teamwear-home-hero {
  position: relative !important;
  width: 100% !important;
  min-height: clamp(520px, 72svh, 680px) !important;
  box-sizing: border-box !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  padding: clamp(42px, 7vh, 78px) max(20px, calc((100vw - var(--maxw)) / 2 + 24px)) !important;
  color: #fff !important;
  text-align: left !important;
  background:
    linear-gradient(90deg, rgba(9,17,30,.90) 0%, rgba(9,17,30,.80) 43%, rgba(9,17,30,.32) 76%, rgba(9,17,30,.14) 100%),
    url('/assets/images/background.png') center center / cover no-repeat !important;
  isolation: isolate !important;
}

.teamwear-home-hero::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: -1 !important;
  background: linear-gradient(180deg, rgba(9,17,30,.08), rgba(9,17,30,.22)) !important;
}

.teamwear-home-hero .home-hero-panel {
  position: relative !important;
  z-index: 1 !important;
  width: min(100%, 760px) !important;
  margin: 0 !important;
  padding: clamp(24px, 3vw, 38px) !important;
  border-left: 4px solid #ff6a00 !important;
  border-radius: 8px !important;
  background: rgba(9,17,30,.80) !important;
  box-shadow: 0 22px 60px rgba(0,0,0,.24) !important;
}

.teamwear-home-hero .home-kicker,
.home-shop-finder-section .home-kicker {
  display: inline-flex !important;
  min-height: 0 !important;
  margin: 0 0 14px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  color: #ffb15f !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
}

.teamwear-home-hero .ak24-hero-title {
  display: block !important;
  max-width: 760px !important;
  margin: 0 !important;
  color: #fff !important;
  letter-spacing: 0 !important;
  line-height: 1.05 !important;
}

.teamwear-home-hero .home-title-main,
.teamwear-home-hero .home-title-sub {
  display: block !important;
  max-width: none !important;
  white-space: normal !important;
  letter-spacing: 0 !important;
}

.teamwear-home-hero .home-title-main {
  font-size: clamp(2.45rem, 5vw, 4.9rem) !important;
  line-height: 1.03 !important;
  font-weight: 900 !important;
}

.teamwear-home-hero .home-title-sub {
  margin-top: 12px !important;
  color: rgba(255,255,255,.88) !important;
  font-size: clamp(1.2rem, 2vw, 1.8rem) !important;
  line-height: 1.2 !important;
  font-weight: 760 !important;
}

.teamwear-home-hero .home-lead {
  max-width: 650px !important;
  margin: 18px 0 0 !important;
  color: rgba(255,255,255,.84) !important;
  font-size: clamp(1rem, 1.25vw, 1.16rem) !important;
  line-height: 1.6 !important;
}

.teamwear-hero-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 10px !important;
  margin-top: 24px !important;
}

.teamwear-hero-primary,
.teamwear-hero-secondary {
  min-height: 48px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 18px !important;
  border-radius: 8px !important;
  font-size: .98rem !important;
  font-weight: 850 !important;
  line-height: 1.15 !important;
  text-decoration: none !important;
  transition: background .16s ease, border-color .16s ease, box-shadow .16s ease, transform .12s ease !important;
}

.teamwear-hero-primary {
  background: #ff6a00 !important;
  color: #fff !important;
  border: 1px solid #ff6a00 !important;
  box-shadow: 0 16px 34px rgba(255,106,0,.28) !important;
}

.teamwear-hero-primary:hover {
  background: #f25c05 !important;
  border-color: #f25c05 !important;
  box-shadow: 0 20px 40px rgba(242,92,5,.32) !important;
  transform: translateY(-1px) !important;
}

.teamwear-hero-secondary {
  background: rgba(255,255,255,.08) !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,.34) !important;
  box-shadow: none !important;
}

.teamwear-hero-secondary:hover {
  background: rgba(255,255,255,.16) !important;
  border-color: rgba(255,255,255,.62) !important;
  transform: translateY(-1px) !important;
}

.teamwear-hero-process {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 10px !important;
  margin-top: 20px !important;
  color: rgba(255,255,255,.72) !important;
  font-size: .88rem !important;
  font-weight: 760 !important;
}

.teamwear-hero-steps {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.teamwear-hero-steps li {
  min-height: 28px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: rgba(255,255,255,.84) !important;
  font-size: .88rem !important;
  font-weight: 760 !important;
}

.teamwear-hero-steps li + li::before {
  content: "" !important;
  display: inline-block !important;
  width: 18px !important;
  height: 1px !important;
  margin-right: 1px !important;
  background: rgba(255,255,255,.26) !important;
}

.teamwear-hero-steps span {
  width: 22px !important;
  height: 22px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.14) !important;
  color: #fff !important;
  font-size: .75rem !important;
  font-weight: 900 !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.20) !important;
}

.home-shop-finder-section {
  background: #f5f7fb !important;
  padding: clamp(34px, 6vw, 72px) max(20px, calc((100vw - var(--maxw)) / 2 + 24px)) !important;
  color: #16243c !important;
}

.home-shop-finder-shell {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: minmax(240px, 420px) minmax(320px, 560px) !important;
  align-items: start !important;
  justify-content: space-between !important;
  gap: clamp(24px, 5vw, 72px) !important;
}

.home-shop-finder-copy {
  max-width: 420px !important;
  padding-top: 8px !important;
}

.home-shop-finder-copy .home-kicker {
  color: #f25c05 !important;
}

.home-shop-finder-copy h2 {
  margin: 0 !important;
  color: #16243c !important;
  font-size: clamp(1.6rem, 2.6vw, 2.45rem) !important;
  line-height: 1.12 !important;
  letter-spacing: 0 !important;
}

.home-shop-finder-copy p {
  margin: 14px 0 0 !important;
  color: #526071 !important;
  font-size: 1rem !important;
  line-height: 1.65 !important;
}

.home-shop-finder-section .school-chooser,
.home-shop-finder-section .teamwear-shop-finder {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: clamp(20px, 3vw, 28px) !important;
  border: 1px solid rgba(16,24,40,.10) !important;
  border-left: 4px solid #ff6a00 !important;
  border-radius: 8px !important;
  background: #fff !important;
  box-shadow: 0 18px 48px rgba(16,24,40,.10) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.home-shop-finder-section .school-chooser .ak24-info,
.home-shop-finder-section .school-chooser > hr {
  display: none !important;
}

.home-shop-finder-section .ak24-form {
  margin-bottom: 0 !important;
}

.home-shop-finder-section .ak24-form h2 {
  font-size: 1.18rem !important;
  line-height: 1.25 !important;
}

.home-shop-finder-section label,
.home-shop-finder-section .school-chooser label {
  color: #344054 !important;
  font-size: .8rem !important;
  font-weight: 850 !important;
}

.home-shop-finder-section input,
.home-shop-finder-section #school-select-toggle {
  min-height: 48px !important;
  border-radius: 8px !important;
  border: 1px solid rgba(16,24,40,.16) !important;
  background: #fff !important;
  font-size: .95rem !important;
}

.home-shop-finder-section input:focus,
.home-shop-finder-section #school-select-toggle:focus-visible {
  border-color: rgba(242,92,5,.52) !important;
  box-shadow: 0 0 0 3px rgba(242,92,5,.12) !important;
}

.home-shop-finder-section .ak24-search-row {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 12px !important;
  align-items: end !important;
  margin-top: 16px !important;
}

.home-shop-finder-section .home-finder-actions {
  display: flex !important;
  grid-template-columns: none !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 14px !important;
  margin-top: 20px !important;
}

.home-shop-finder-section .home-finder-actions .ak24-btn-primary {
  flex: 1 1 auto !important;
  min-height: 48px !important;
  border-radius: 8px !important;
  background: #16243c !important;
  box-shadow: 0 14px 28px rgba(16,24,40,.16) !important;
}

.home-shop-finder-section .home-finder-actions .ak24-btn-primary:hover {
  background: #f25c05 !important;
  box-shadow: 0 18px 34px rgba(242,92,5,.24) !important;
}

.home-shop-finder-section .home-cost-link {
  flex: 0 0 auto !important;
  min-height: 32px !important;
  margin: 0 !important;
  padding: 0 2px 2px !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(82,96,113,.34) !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: #526071 !important;
  font-size: .78rem !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
}

.home-shop-finder-section .home-cost-link:hover {
  color: #f25c05 !important;
  border-bottom-color: #f25c05 !important;
  box-shadow: none !important;
  transform: none !important;
}

@media (max-width: 960px) {
  .nav-modern .nav-shell {
    grid-template-columns: minmax(130px, 180px) minmax(0, 1fr) auto !important;
    gap: 10px !important;
    padding-inline: 16px !important;
  }

  .nav-modern .topbar-logo {
    max-width: 150px !important;
    max-height: 38px !important;
  }

  .nav-modern .topbar-logo-club {
    max-width: 128px !important;
    max-height: 38px !important;
  }

  .nav-modern .nav-links a {
    font-size: .82rem !important;
    padding-inline: 8px !important;
  }

  .home-shop-finder-shell {
    grid-template-columns: 1fr !important;
    gap: 22px !important;
  }

  .home-shop-finder-copy {
    max-width: 680px !important;
    padding-top: 0 !important;
  }
}

@media (max-width: 780px) {
  .nav-modern .nav-shell {
    min-height: 58px !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
  }

  .nav-modern .nav-links {
    display: none !important;
  }

  .nav-modern .nav-actions {
    grid-column: 2 !important;
  }

  .nav-modern .nav-toggle {
    display: inline-flex !important;
  }

  .nav-modern .topbar-logo {
    max-width: 138px !important;
    max-height: 36px !important;
  }

  .teamwear-home-hero {
    min-height: auto !important;
    padding: 28px 16px 34px !important;
    background:
      linear-gradient(180deg, rgba(9,17,30,.92) 0%, rgba(9,17,30,.78) 62%, rgba(9,17,30,.34) 100%),
      url('/assets/images/background.png') center center / cover no-repeat !important;
  }

  .teamwear-home-hero .home-hero-panel {
    width: 100% !important;
    padding: 22px !important;
  }

  .teamwear-home-hero .home-title-main {
    font-size: clamp(2.05rem, 9.4vw, 3.2rem) !important;
    line-height: 1.06 !important;
  }

  .teamwear-home-hero .home-title-sub {
    font-size: clamp(1.08rem, 4.4vw, 1.45rem) !important;
  }

  .teamwear-hero-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .teamwear-hero-primary,
  .teamwear-hero-secondary {
    width: 100% !important;
  }

  .teamwear-hero-process {
    align-items: flex-start !important;
  }

  .teamwear-hero-steps {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 5px !important;
  }

  .teamwear-hero-steps li + li::before {
    content: none !important;
  }

  .home-shop-finder-section {
    padding: 32px 16px 44px !important;
  }

  .home-shop-finder-section .ak24-search-row {
    grid-template-columns: 1fr !important;
  }

  .home-shop-finder-section .home-finder-actions {
    align-items: stretch !important;
    flex-direction: column !important;
  }

  .home-shop-finder-section .home-cost-link {
    align-self: flex-start !important;
  }
}

@media (max-width: 560px) {
  .nav-modern .nav-shell {
    padding: 8px 12px !important;
  }

  .nav-modern .topbar-logo {
    max-width: 112px !important;
    max-height: 34px !important;
  }

  .nav-modern .topbar-logo-club {
    max-width: 104px !important;
    max-height: 34px !important;
  }

  .nav-admin-link {
    display: none !important;
  }

  .nav-modern .cart-link,
  .nav-modern .nav-toggle {
    width: 38px !important;
    min-width: 38px !important;
    height: 38px !important;
    min-height: 38px !important;
  }

  .mini-cart {
    right: -46px !important;
    width: min(340px, calc(100vw - 20px)) !important;
  }

  .teamwear-home-hero {
    padding-inline: 12px !important;
  }

  .teamwear-home-hero .home-hero-panel {
    padding: 20px !important;
  }
}

/* Admin polish: readable header CTA, normalized checkboxes, Superadmin group, custom editor */
:root {
  --nav-cta-bg: #16243c;
  --nav-cta-fg: #ffffff;
  --nav-cta-hover-bg: #f25c05;
  --nav-cta-hover-fg: #ffffff;
}

.nav-modern .nav-links .nav-cta,
header.site-header .nav-links a.nav-cta {
  background: var(--nav-cta-bg, #16243c) !important;
  color: var(--nav-cta-fg, #ffffff) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  box-shadow: 0 12px 24px rgba(16,24,40,.16) !important;
}

.nav-modern .nav-links .nav-cta:hover,
.nav-modern .nav-links .nav-cta:focus-visible,
header.site-header .nav-links a.nav-cta:hover,
header.site-header .nav-links a.nav-cta:focus-visible {
  background: var(--nav-cta-hover-bg, #f25c05) !important;
  color: var(--nav-cta-hover-fg, #ffffff) !important;
  box-shadow: 0 16px 30px rgba(242,92,5,.24) !important;
}

.nav-modern .nav-links .nav-cta:active,
header.site-header .nav-links a.nav-cta:active {
  transform: translateY(0) scale(.98) !important;
}

input[type="checkbox"] {
  appearance: auto !important;
  -webkit-appearance: checkbox !important;
  box-sizing: border-box !important;
  flex: 0 0 auto !important;
  width: 16px !important;
  min-width: 16px !important;
  max-width: 16px !important;
  height: 16px !important;
  min-height: 16px !important;
  max-height: 16px !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 3px !important;
  accent-color: var(--brand, #0b7285) !important;
  box-shadow: none !important;
}

.auth-password-toggle,
.checkbox-line,
.bulk-check {
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 8px !important;
  min-height: 24px !important;
  color: var(--ui-ink-2) !important;
  font-size: .92rem !important;
  font-weight: 760 !important;
  line-height: 1.25 !important;
}

.auth-password-toggle span,
.auth-password-toggle label {
  margin: 0 !important;
}

.admin-superarea {
  margin-top: 28px !important;
  padding: 22px !important;
  border: 1px solid rgba(16,24,40,.10) !important;
  border-radius: 14px !important;
  background: linear-gradient(180deg, rgba(248,250,252,.96), rgba(255,255,255,.94)) !important;
  box-shadow: 0 14px 38px rgba(16,24,40,.08) !important;
}

.admin-superarea-head {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 16px !important;
  margin-bottom: 16px !important;
}

.admin-superarea-head h2 {
  margin: 0 0 6px !important;
  color: var(--ui-ink) !important;
  font-size: clamp(1.35rem, 2vw, 1.8rem) !important;
  letter-spacing: 0 !important;
}

.admin-superarea-head p:not(.admin-kicker) {
  max-width: 720px !important;
  margin: 0 !important;
  color: var(--ui-muted) !important;
  line-height: 1.55 !important;
}

.admin-superarea-status {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 28px !important;
  padding: 0 10px !important;
  border-radius: 999px !important;
  background: #ecfdf5 !important;
  color: #047857 !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
  white-space: nowrap !important;
}

.admin-supergrid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)) !important;
  gap: 12px !important;
}

.admin-supercard {
  display: grid !important;
  grid-template-columns: 38px minmax(0, 1fr) !important;
  gap: 10px 12px !important;
  align-items: start !important;
  min-height: 116px !important;
  padding: 14px !important;
  border: 1px solid rgba(16,24,40,.10) !important;
  border-radius: 10px !important;
  background: #fff !important;
  color: var(--ui-ink) !important;
  text-decoration: none !important;
  box-shadow: 0 8px 22px rgba(16,24,40,.05) !important;
}

.admin-supercard:hover {
  transform: translateY(-1px) !important;
  border-color: rgba(16,24,40,.16) !important;
  box-shadow: 0 14px 32px rgba(16,24,40,.10) !important;
}

.admin-supericon {
  grid-row: span 2 !important;
  width: 38px !important;
  height: 38px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 9px !important;
  background: #f1f5f9 !important;
  color: #16243c !important;
  font-size: .78rem !important;
  font-weight: 950 !important;
}

.admin-supercard strong {
  display: block !important;
  color: var(--ui-ink) !important;
  font-size: 1rem !important;
  line-height: 1.2 !important;
}

.admin-supercard small {
  display: block !important;
  color: var(--ui-muted) !important;
  font-size: .84rem !important;
  line-height: 1.45 !important;
}

.admin-supercard.is-orange .admin-supericon { background: #fff7ed !important; color: #c2410c !important; }
.admin-supercard.is-blue .admin-supericon { background: #eff6ff !important; color: #1d4ed8 !important; }
.admin-supercard.is-green .admin-supericon { background: #ecfdf5 !important; color: #047857 !important; }
.admin-supercard.is-teal .admin-supericon { background: #ecfeff !important; color: #0f766e !important; }
.admin-supercard.is-lime .admin-supericon { background: #f7fee7 !important; color: #4d7c0f !important; }
.admin-supercard.is-violet .admin-supericon { background: #f5f3ff !important; color: #6d28d9 !important; }

.tw-rich-editor {
  display: grid !important;
  gap: 10px !important;
  width: 100% !important;
}

.tw-rich-editor-source {
  display: none !important;
}

.tw-rich-toolbar {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 8px !important;
  border: 1px solid rgba(16,24,40,.10) !important;
  border-radius: 8px !important;
  background: #f8fafc !important;
}

.tw-rich-toolbar button,
.tw-rich-toolbar select,
.tw-rich-toolbar input[type="color"] {
  min-height: 34px !important;
  border: 1px solid rgba(16,24,40,.14) !important;
  border-radius: 7px !important;
  background: #fff !important;
  color: var(--ui-ink) !important;
  font: inherit !important;
  font-size: .82rem !important;
  font-weight: 800 !important;
}

.tw-rich-toolbar button {
  min-width: 34px !important;
  padding: 0 10px !important;
  cursor: pointer !important;
}

.tw-rich-toolbar button:hover,
.tw-rich-toolbar select:hover {
  border-color: rgba(11,114,133,.32) !important;
  background: #f0fdfa !important;
}

.tw-rich-toolbar input[type="color"] {
  width: 40px !important;
  padding: 2px !important;
  cursor: pointer !important;
}

.tw-rich-surface,
.tw-rich-preview {
  min-height: 260px !important;
  max-height: 620px !important;
  overflow: auto !important;
  padding: 16px !important;
  border: 1px solid rgba(16,24,40,.14) !important;
  border-radius: 8px !important;
  background: #fff !important;
  color: var(--ui-ink) !important;
  font-size: .96rem !important;
  line-height: 1.65 !important;
}

.tw-rich-surface:empty::before {
  content: attr(data-placeholder);
  color: #98a2b3;
}

.admin-products-head,
.admin-products-row {
  grid-template-columns: 44px 74px minmax(420px, 2fr) minmax(170px, 1fr) minmax(130px, .8fr) minmax(160px, .9fr) minmax(150px, .8fr) minmax(160px, .9fr) 110px minmax(180px, .9fr) !important;
  min-width: 1480px !important;
}

.tw-rich-surface:focus {
  outline: 3px solid rgba(11,114,133,.16) !important;
  border-color: rgba(11,114,133,.55) !important;
}

.tw-rich-editor.is-expanded .tw-rich-surface {
  min-height: 460px !important;
}

.tw-rich-preview[hidden] {
  display: none !important;
}

.tw-rich-editor.is-fullscreen {
  position: fixed !important;
  inset: 18px !important;
  z-index: 9999 !important;
  padding: 18px !important;
  border-radius: 12px !important;
  background: #fff !important;
  box-shadow: 0 28px 80px rgba(16,24,40,.24) !important;
}

.tw-rich-editor.is-fullscreen .tw-rich-surface {
  min-height: calc(100vh - 180px) !important;
  max-height: none !important;
}

.tw-rich-surface h2,
.tw-rich-preview h2 {
  margin: .2rem 0 .7rem !important;
  font-size: 1.35rem !important;
}

.tw-rich-surface h3,
.tw-rich-preview h3 {
  margin: .2rem 0 .6rem !important;
  font-size: 1.15rem !important;
}

.tw-rich-surface p,
.tw-rich-preview p {
  margin: 0 0 .75rem !important;
}

@media (max-width: 760px) {
  .admin-superarea {
    padding: 16px !important;
  }

  .admin-superarea-head {
    display: grid !important;
  }

  .admin-supergrid {
    grid-template-columns: 1fr !important;
  }

  .tw-rich-toolbar {
    align-items: stretch !important;
  }

  .tw-rich-toolbar select {
    flex: 1 1 150px !important;
  }

  .tw-rich-surface,
  .tw-rich-preview {
    min-height: 300px !important;
  }
}

/* Product admin card layout */
.admin-products-table.admin-products-list,
.admin-products-table {
  display: grid !important;
  gap: 16px !important;
  overflow: visible !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.admin-products-head {
  display: none !important;
}

.admin-products-row {
  position: relative !important;
  display: grid !important;
  grid-template-columns: 34px 84px minmax(0, 1fr) minmax(170px, .34fr) !important;
  gap: 16px !important;
  align-items: start !important;
  min-width: 0 !important;
  padding: 18px !important;
  border: 1px solid rgba(16,24,40,.10) !important;
  border-radius: 14px !important;
  background: #fff !important;
  box-shadow: 0 14px 36px rgba(16,24,40,.08) !important;
}

.admin-products-row:hover {
  background: #fff !important;
  border-color: rgba(11,114,133,.22) !important;
  box-shadow: 0 18px 44px rgba(16,24,40,.11) !important;
}

.admin-products-cell {
  min-width: 0 !important;
}

.cell-select {
  padding-top: 18px !important;
}

.cell-select input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
}

.cell-thumb img {
  width: 78px !important;
  height: 78px !important;
  border-radius: 12px !important;
  object-fit: contain !important;
  background: #f8fafc !important;
  box-shadow: inset 0 0 0 1px rgba(16,24,40,.08) !important;
}

.admin-product-row-form {
  display: grid !important;
  grid-template-columns: minmax(300px, 1.2fr) minmax(190px, .75fr) minmax(160px, .55fr) minmax(190px, .75fr) minmax(180px, .7fr) minmax(180px, .7fr) 90px !important;
  gap: 14px !important;
  align-items: start !important;
  min-width: 0 !important;
}

.admin-product-row-form label,
.variant-manager,
.admin-info-field {
  gap: 6px !important;
  font-size: .8rem !important;
  color: #475569 !important;
}

.admin-product-row-form input,
.admin-product-row-form select,
.admin-product-row-form textarea,
.variant-manager input,
.variant-manager textarea {
  min-height: 42px !important;
  border-color: rgba(16,24,40,.14) !important;
  border-radius: 9px !important;
  padding: .62rem .72rem !important;
}

.admin-product-row-form input:focus,
.admin-product-row-form select:focus,
.admin-product-row-form textarea:focus,
.variant-manager input:focus,
.variant-manager textarea:focus {
  outline: 3px solid rgba(11,114,133,.16) !important;
  border-color: rgba(11,114,133,.52) !important;
}

.cell-main {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(150px, .55fr) !important;
  gap: 12px !important;
  grid-column: span 2 !important;
}

.cell-main .admin-inline-details {
  grid-column: 1 / -1 !important;
}

.admin-inline-details {
  border: 1px solid rgba(16,24,40,.10) !important;
  border-radius: 12px !important;
  background: #f8fafc !important;
  padding: 0 !important;
  overflow: hidden !important;
}

.admin-inline-details summary {
  display: flex !important;
  align-items: center !important;
  min-height: 46px !important;
  padding: 12px 14px !important;
  background: #f1f5f9 !important;
  border-bottom: 1px solid rgba(16,24,40,.08) !important;
}

.admin-inline-details[open] {
  display: grid !important;
  gap: 14px !important;
  padding-bottom: 14px !important;
}

.admin-inline-details[open] > label,
.admin-inline-details[open] > .variant-manager,
.admin-inline-details[open] > .admin-product-upload-grid,
.admin-inline-details[open] > .admin-gallery-existing {
  margin-inline: 14px !important;
}

.admin-field-label {
  display: block !important;
  font-size: .8rem !important;
  font-weight: 900 !important;
  color: #475569 !important;
}

.tw-rich-surface,
.tw-rich-preview {
  min-height: 360px !important;
}

.tw-rich-editor.is-expanded .tw-rich-surface {
  min-height: 560px !important;
}

.admin-club-badge,
.admin-type-badge {
  display: inline-flex !important;
  align-items: center !important;
  width: fit-content !important;
  max-width: 100% !important;
  min-height: 30px !important;
  padding: 0 10px !important;
  border-radius: 999px !important;
  font-size: .8rem !important;
  font-weight: 900 !important;
  line-height: 1.2 !important;
}

.admin-club-badge {
  background: #eef2ff !important;
  color: #3730a3 !important;
}

.admin-type-badge.is-personalizable {
  background: #ecfdf5 !important;
  color: #047857 !important;
}

.admin-type-badge.is-static {
  background: #fff7ed !important;
  color: #c2410c !important;
}

.switch-line {
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 9px !important;
  min-height: 32px !important;
  margin-top: 8px !important;
  color: #344054 !important;
  font-weight: 850 !important;
}

.switch-line input[type="checkbox"] {
  position: absolute !important;
  inline-size: 1px !important;
  block-size: 1px !important;
  opacity: 0 !important;
}

.switch-control {
  position: relative !important;
  width: 38px !important;
  height: 22px !important;
  border-radius: 999px !important;
  background: #cbd5e1 !important;
  box-shadow: inset 0 0 0 1px rgba(16,24,40,.12) !important;
  transition: background .16s ease, box-shadow .16s ease !important;
}

.switch-control::after {
  content: "" !important;
  position: absolute !important;
  width: 18px !important;
  height: 18px !important;
  top: 2px !important;
  left: 2px !important;
  border-radius: 999px !important;
  background: #fff !important;
  box-shadow: 0 2px 5px rgba(16,24,40,.20) !important;
  transition: transform .16s ease !important;
}

.switch-line input[type="checkbox"]:checked + .switch-control {
  background: var(--brand, #0b7285) !important;
}

.switch-line input[type="checkbox"]:checked + .switch-control::after {
  transform: translateX(16px) !important;
}

.variant-manager {
  display: grid !important;
  gap: 10px !important;
}

.variant-presets,
.variant-list,
.variant-add-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}

.variant-presets button,
.variant-pill {
  border: 1px solid rgba(16,24,40,.12) !important;
  border-radius: 999px !important;
  background: #fff !important;
  color: #16243c !important;
  min-height: 32px !important;
  padding: 0 11px !important;
  font-weight: 900 !important;
}

.variant-presets button {
  cursor: pointer !important;
}

.variant-presets button:hover {
  border-color: rgba(11,114,133,.36) !important;
  background: #f0fdfa !important;
}

.variant-pill {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  background: #eef2ff !important;
}

.variant-pill button {
  border: 0 !important;
  background: transparent !important;
  color: #475569 !important;
  cursor: pointer !important;
  font-weight: 900 !important;
}

.variant-add-row input {
  flex: 1 1 130px !important;
}

.variant-advanced {
  border: 1px dashed rgba(16,24,40,.18) !important;
  border-radius: 10px !important;
  padding: 10px !important;
  background: #fff !important;
}

.variant-advanced summary {
  padding: 0 !important;
  min-height: auto !important;
  border: 0 !important;
  background: transparent !important;
  font-size: .82rem !important;
}

.admin-product-upload-grid {
  grid-template-columns: repeat(2, minmax(220px, 1fr)) !important;
  gap: 12px !important;
}

.admin-current-main-image {
  display: inline-grid !important;
  gap: 8px !important;
  width: fit-content !important;
  max-width: 100% !important;
  margin-inline: 14px !important;
  padding: 10px !important;
  border: 1px solid rgba(16,24,40,.10) !important;
  border-radius: 12px !important;
  background: #fff !important;
}

.admin-current-main-image span {
  color: #475569 !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
}

.admin-current-main-image img {
  width: 118px !important;
  height: 118px !important;
  object-fit: contain !important;
  border-radius: 10px !important;
  background: #f8fafc !important;
}

.admin-upload-field {
  min-height: 128px !important;
  border-radius: 12px !important;
  background: #fff !important;
  border-color: rgba(11,114,133,.34) !important;
  padding: 14px !important;
  justify-content: flex-start !important;
}

.admin-upload-field small {
  display: block !important;
  margin-top: 4px !important;
  color: #64748b !important;
  font-size: .78rem !important;
  font-weight: 650 !important;
}

.admin-upload-field input[type="file"] {
  min-height: auto !important;
  padding: 0 !important;
  border: 0 !important;
  margin-top: 10px !important;
}

.admin-upload-preview {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin-top: 10px !important;
}

.admin-upload-file,
.admin-gallery-item {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  max-width: 100% !important;
  border: 1px solid rgba(16,24,40,.10) !important;
  border-radius: 10px !important;
  background: #fff !important;
  padding: 6px 8px !important;
  color: #475569 !important;
  font-size: .78rem !important;
  font-weight: 750 !important;
}

.admin-upload-file img,
.admin-gallery-item img {
  width: 42px !important;
  height: 42px !important;
  border-radius: 8px !important;
  object-fit: cover !important;
  background: #f8fafc !important;
}

.admin-gallery-existing {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}

.admin-gallery-item input[type="checkbox"] {
  width: 16px !important;
  height: 16px !important;
  min-width: 16px !important;
  min-height: 16px !important;
}

.admin-gallery-item em {
  color: #991b1b !important;
  font-style: normal !important;
}

.cell-actions {
  display: grid !important;
  gap: 8px !important;
}

.cell-actions .btn {
  min-height: 38px !important;
  border-radius: 9px !important;
}

@media (max-width: 1240px) {
  .admin-products-row {
    grid-template-columns: 34px 76px minmax(0, 1fr) !important;
  }

  .cell-actions {
    grid-column: 1 / -1 !important;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)) !important;
  }

  .admin-product-row-form {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .cell-main {
    grid-column: 1 / -1 !important;
  }
}

@media (max-width: 760px) {
  .admin-products-row {
    grid-template-columns: 28px minmax(64px, 72px) minmax(0, 1fr) !important;
    padding: 14px !important;
    gap: 12px !important;
  }

  .admin-product-row-form {
    grid-column: 1 / -1 !important;
    grid-template-columns: 1fr !important;
  }

  .cell-main {
    grid-template-columns: 1fr !important;
  }

  .admin-product-upload-grid {
    grid-template-columns: 1fr !important;
  }

  .cell-actions {
    grid-column: 1 / -1 !important;
    grid-template-columns: 1fr !important;
  }
}

/* Modernized product administration overview */
.admin-products-page {
  --admin-surface: #fff;
  --admin-muted: #64748b;
  --admin-ink: #111827;
  --admin-soft: #f6f8fb;
  --admin-line: rgba(15, 23, 42, .10);
  --admin-line-strong: rgba(15, 23, 42, .16);
  --admin-shadow: 0 16px 38px rgba(15, 23, 42, .075);
  padding: 2.25rem 1rem 3rem !important;
}

.admin-products-wrap {
  max-width: 1360px !important;
}

.admin-products-hero {
  align-items: center !important;
  gap: 1rem !important;
  margin-bottom: 1.2rem !important;
}

.admin-products-hero .lead {
  max-width: 760px !important;
  color: var(--admin-muted) !important;
}

.admin-products-actions .btn,
.admin-products-tabs .tab,
.admin-products-create .btn,
.admin-products-toolbar .btn,
.admin-products-bulk .btn,
.cell-actions .btn {
  min-height: 40px !important;
  border-radius: 10px !important;
  font-weight: 850 !important;
}

.admin-products-create {
  display: grid !important;
  grid-template-columns: minmax(220px, .95fr) minmax(180px, 1fr) minmax(130px, .65fr) minmax(170px, .75fr) minmax(240px, 1.15fr) auto !important;
  align-items: stretch !important;
  gap: 14px !important;
  padding: 16px !important;
  border-radius: 14px !important;
  border: 1px solid var(--admin-line) !important;
  background: var(--admin-surface) !important;
  box-shadow: var(--admin-shadow) !important;
}

.admin-products-create-copy {
  display: grid !important;
  align-content: center !important;
  gap: 3px !important;
  padding-right: 4px !important;
}

.admin-products-create-copy span,
.admin-products-toolbar label > span,
.admin-products-create label > span,
.admin-product-row-form label > span,
.admin-field-label {
  color: #475569 !important;
  font-size: .74rem !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

.admin-products-create-copy strong {
  color: var(--admin-ink) !important;
  font-size: 1.05rem !important;
  line-height: 1.15 !important;
}

.admin-products-create-copy small,
.admin-dropzone small {
  color: var(--admin-muted) !important;
  font-size: .76rem !important;
  font-weight: 650 !important;
  line-height: 1.35 !important;
}

.admin-dropzone-create {
  min-height: 86px !important;
  border-color: rgba(37, 99, 235, .28) !important;
  background: linear-gradient(180deg, #fff, #f8fbff) !important;
}

.admin-products-toolbar {
  position: sticky !important;
  top: 74px !important;
  z-index: 20 !important;
  display: grid !important;
  grid-template-columns: minmax(240px, 1.8fr) repeat(4, minmax(136px, .8fr)) auto !important;
  align-items: end !important;
  gap: 12px !important;
  padding: 14px !important;
  border-radius: 14px !important;
  border: 1px solid var(--admin-line) !important;
  background: rgba(255, 255, 255, .96) !important;
  box-shadow: 0 12px 30px rgba(15, 23, 42, .07) !important;
  backdrop-filter: blur(10px) !important;
}

.admin-products-reset {
  align-self: end !important;
  white-space: nowrap !important;
  background: #f8fafc !important;
}

.admin-products-bulk {
  display: grid !important;
  grid-template-columns: minmax(190px, auto) minmax(220px, 1fr) auto minmax(170px, auto) !important;
  gap: 12px !important;
  align-items: center !important;
  padding: 12px 14px !important;
  border-radius: 14px !important;
  border: 1px solid var(--admin-line) !important;
  background: #fff !important;
  box-shadow: 0 10px 26px rgba(15, 23, 42, .055) !important;
}

.admin-products-bulk button:disabled,
.cell-actions button:disabled {
  cursor: not-allowed !important;
  opacity: .48 !important;
  transform: none !important;
}

.admin-products-count {
  margin-left: 0 !important;
  justify-self: end !important;
  color: var(--admin-muted) !important;
  font-size: .85rem !important;
  font-weight: 800 !important;
}

.admin-products-table {
  display: grid !important;
  gap: 14px !important;
  overflow: visible !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.admin-products-head {
  display: none !important;
}

.admin-products-row {
  position: relative !important;
  display: grid !important;
  grid-template-columns: 32px 88px minmax(0, 1fr) 176px !important;
  gap: 16px !important;
  align-items: start !important;
  min-width: 0 !important;
  padding: 16px !important;
  border: 1px solid var(--admin-line) !important;
  border-radius: 14px !important;
  background: #fff !important;
  box-shadow: 0 10px 30px rgba(15, 23, 42, .06) !important;
  transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease !important;
}

.admin-products-row:hover {
  border-color: rgba(37, 99, 235, .22) !important;
  box-shadow: 0 16px 40px rgba(15, 23, 42, .09) !important;
}

.admin-products-row.is-dirty {
  border-color: rgba(245, 158, 11, .45) !important;
}

.cell-select {
  padding-top: 26px !important;
}

.cell-select input[type="checkbox"],
.bulk-check input[type="checkbox"] {
  inline-size: 18px !important;
  block-size: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  accent-color: var(--brand, #2563eb) !important;
}

.admin-product-thumb-link {
  display: block !important;
  width: 84px !important;
  height: 84px !important;
  border-radius: 12px !important;
  border: 1px solid var(--admin-line) !important;
  background: #f8fafc !important;
  overflow: hidden !important;
  transition: transform .16s ease, box-shadow .16s ease !important;
}

.admin-product-thumb-link:hover {
  transform: scale(1.04) !important;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .15) !important;
}

.cell-thumb img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.admin-product-row-form {
  display: grid !important;
  grid-template-columns: minmax(300px, 1.35fr) minmax(180px, .72fr) minmax(190px, .78fr) minmax(168px, .66fr) !important;
  grid-template-areas:
    "main category type price"
    "main status status price"
    "main club created price" !important;
  gap: 12px !important;
  align-items: start !important;
  min-width: 0 !important;
}

.cell-main { grid-area: main !important; }
.cell-category { grid-area: category !important; }
.cell-type { grid-area: type !important; }
.cell-price { grid-area: price !important; }
.cell-status { grid-area: status !important; }
.cell-club { grid-area: club !important; }
.cell-created { grid-area: created !important; }

.cell-main {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(130px, .45fr) !important;
  gap: 10px !important;
  align-content: start !important;
}

.cell-main .admin-inline-details {
  grid-column: 1 / -1 !important;
}

.admin-product-row-form label {
  display: grid !important;
  gap: 5px !important;
  min-width: 0 !important;
}

.admin-product-row-form input,
.admin-product-row-form select,
.admin-product-row-form textarea,
.admin-products-toolbar input,
.admin-products-toolbar select,
.admin-products-create input,
.admin-products-create select,
.admin-products-bulk select {
  min-height: 40px !important;
  border: 1px solid var(--admin-line-strong) !important;
  border-radius: 9px !important;
  background: #fff !important;
  color: var(--admin-ink) !important;
  padding: .58rem .68rem !important;
  font-size: .86rem !important;
  line-height: 1.2 !important;
}

.admin-product-row-form input:focus,
.admin-product-row-form select:focus,
.admin-product-row-form textarea:focus,
.admin-products-toolbar input:focus,
.admin-products-toolbar select:focus,
.admin-products-create input:focus,
.admin-products-create select:focus,
.admin-products-bulk select:focus {
  outline: 3px solid rgba(37, 99, 235, .14) !important;
  border-color: rgba(37, 99, 235, .55) !important;
}

.admin-category-note {
  display: inline-flex !important;
  width: fit-content !important;
  max-width: 100% !important;
  min-height: 24px !important;
  align-items: center !important;
  border-radius: 999px !important;
  padding: 0 8px !important;
  font-size: .72rem !important;
  font-style: normal !important;
  font-weight: 900 !important;
}

.admin-category-note.is-missing {
  background: #fff7ed !important;
  color: #c2410c !important;
}

.admin-category-note.is-set {
  background: #eef2ff !important;
  color: #3730a3 !important;
}

.cell-price {
  display: grid !important;
  gap: 9px !important;
  padding: 12px !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  border-radius: 12px !important;
  background: #f8fafc !important;
}

.admin-price-total {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  min-height: 44px !important;
  border-radius: 10px !important;
  background: #111827 !important;
  color: #fff !important;
  padding: 0 12px !important;
  font-size: 1rem !important;
  font-weight: 950 !important;
}

.admin-price-total::before {
  content: "Endpreis" !important;
  color: rgba(255, 255, 255, .70) !important;
  font-size: .72rem !important;
  font-weight: 850 !important;
}

.product-status,
.admin-type-badge,
.admin-club-badge {
  min-height: 28px !important;
  border-radius: 999px !important;
  padding: 0 10px !important;
  font-size: .76rem !important;
  font-weight: 950 !important;
  line-height: 1.1 !important;
}

.cell-status,
.cell-type,
.cell-club,
.cell-created {
  display: grid !important;
  gap: 8px !important;
  align-content: start !important;
}

.cell-created span {
  color: var(--admin-muted) !important;
  font-size: .8rem !important;
  font-weight: 850 !important;
}

.switch-line {
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 8px !important;
  width: fit-content !important;
  max-width: 100% !important;
  margin-top: 0 !important;
  color: #334155 !important;
  font-size: .8rem !important;
  font-weight: 850 !important;
}

.admin-inline-details {
  border: 1px solid var(--admin-line) !important;
  border-radius: 12px !important;
  background: #f8fafc !important;
  padding: 0 !important;
  overflow: hidden !important;
}

.admin-inline-details summary {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  min-height: 44px !important;
  padding: 0 13px !important;
  background: #eef2f7 !important;
  border-bottom: 0 !important;
  color: var(--admin-ink) !important;
  font-weight: 950 !important;
  cursor: pointer !important;
  list-style: none !important;
}

.admin-inline-details summary::-webkit-details-marker {
  display: none !important;
}

.admin-accordion-icon {
  position: relative !important;
  width: 18px !important;
  height: 18px !important;
  border-radius: 999px !important;
  background: #fff !important;
  border: 1px solid var(--admin-line-strong) !important;
}

.admin-accordion-icon::before,
.admin-accordion-icon::after {
  content: "" !important;
  position: absolute !important;
  left: 4px !important;
  right: 4px !important;
  top: 8px !important;
  height: 2px !important;
  border-radius: 999px !important;
  background: #334155 !important;
}

.admin-accordion-icon::after {
  transform: rotate(90deg) !important;
}

.admin-inline-details[open] .admin-accordion-icon::after {
  transform: rotate(0deg) !important;
}

.admin-detail-body {
  display: grid !important;
  gap: 14px !important;
  padding: 14px !important;
}

.admin-inline-details[open] {
  display: block !important;
  padding-bottom: 0 !important;
}

.admin-detail-body > label,
.variant-manager,
.admin-current-main-image,
.admin-product-upload-grid,
.admin-individual-note,
.admin-gallery-existing {
  margin-inline: 0 !important;
}

.tw-rich-surface,
.tw-rich-preview {
  min-height: 320px !important;
}

.admin-product-upload-grid {
  grid-template-columns: repeat(2, minmax(190px, 1fr)) !important;
}

.admin-upload-field,
.admin-dropzone-create {
  border-radius: 12px !important;
  border-style: dashed !important;
}

.cell-actions {
  display: grid !important;
  gap: 8px !important;
  align-content: start !important;
}

.cell-actions form {
  margin: 0 !important;
}

.cell-actions .btn {
  width: 100% !important;
  justify-content: center !important;
  min-height: 38px !important;
  padding: .5rem .7rem !important;
}

.admin-action-secondary {
  background: #fff !important;
  border-color: var(--admin-line-strong) !important;
  color: #172033 !important;
}

.admin-action-ghost {
  background: #f8fafc !important;
  border-color: transparent !important;
  color: #334155 !important;
}

.admin-action-danger,
.btn.danger.admin-action-danger {
  background: #fff7f7 !important;
  border-color: #fecaca !important;
  color: #991b1b !important;
}

.admin-save-state {
  display: inline-flex !important;
  justify-content: center !important;
  align-items: center !important;
  min-height: 24px !important;
  color: #64748b !important;
  font-size: .72rem !important;
  font-weight: 900 !important;
}

.admin-save-state.is-dirty {
  color: #b45309 !important;
}

.admin-save-state.is-saving {
  color: #2563eb !important;
}

@media (max-width: 1280px) {
  .admin-products-row {
    grid-template-columns: 32px 84px minmax(0, 1fr) !important;
  }

  .cell-actions {
    grid-column: 1 / -1 !important;
    grid-template-columns: repeat(auto-fit, minmax(145px, 1fr)) !important;
  }

  .admin-product-row-form {
    grid-template-columns: minmax(280px, 1.2fr) minmax(180px, .8fr) minmax(180px, .8fr) !important;
    grid-template-areas:
      "main category price"
      "main type price"
      "main status status"
      "main club created" !important;
  }
}

@media (max-width: 980px) {
  .admin-products-hero {
    align-items: stretch !important;
  }

  .admin-products-toolbar,
  .admin-products-create,
  .admin-products-bulk {
    position: static !important;
    grid-template-columns: 1fr 1fr !important;
  }

  .admin-products-create-copy,
  .admin-dropzone-create,
  .admin-products-count {
    grid-column: 1 / -1 !important;
  }

  .admin-product-row-form {
    grid-template-columns: 1fr 1fr !important;
    grid-template-areas:
      "main main"
      "category type"
      "price status"
      "club created" !important;
  }
}

@media (max-width: 680px) {
  .admin-products-page {
    padding-inline: .75rem !important;
  }

  .admin-products-row {
    grid-template-columns: 28px 74px minmax(0, 1fr) !important;
    padding: 13px !important;
    gap: 10px !important;
  }

  .admin-product-thumb-link {
    width: 70px !important;
    height: 70px !important;
  }

  .admin-product-row-form {
    grid-column: 1 / -1 !important;
    grid-template-columns: 1fr !important;
    grid-template-areas:
      "main"
      "category"
      "type"
      "price"
      "status"
      "club"
      "created" !important;
  }

  .cell-main,
  .admin-products-toolbar,
  .admin-products-create,
  .admin-products-bulk,
  .admin-product-upload-grid {
    grid-template-columns: 1fr !important;
  }

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

  .admin-products-count {
    justify-self: start !important;
  }
}

/* Article administration split: compact overview + dedicated detail page */
.admin-products-page--compact {
  --admin-surface: #fff;
  --admin-ink: #101827;
  --admin-muted: #667085;
  --admin-line: rgba(15, 23, 42, .10);
  --admin-soft: #f4f7fb;
  --admin-blue: #143a8f;
}

.admin-products-page--compact .admin-products-hero--compact {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 1rem !important;
  margin-bottom: 1rem !important;
}

.admin-products-page--compact .admin-products-hero h1 {
  margin: 0 !important;
  font-size: clamp(2rem, 3vw, 3rem) !important;
  line-height: 1.05 !important;
}

.admin-products-page--compact .admin-products-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
  gap: .65rem !important;
}

.admin-products-tabs--compact {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: .5rem !important;
  margin: 0 0 1rem !important;
}

.admin-products-tabs--compact .tab {
  min-height: 38px !important;
  padding: .55rem .8rem !important;
  border-radius: 9px !important;
  font-size: .9rem !important;
}

.admin-products-toolbar--compact {
  position: static !important;
  display: grid !important;
  grid-template-columns: minmax(220px, 1.5fr) repeat(5, minmax(140px, .8fr)) auto !important;
  gap: .75rem !important;
  align-items: end !important;
  padding: 1rem !important;
  border: 1px solid var(--admin-line) !important;
  border-radius: 14px !important;
  background: #fff !important;
  box-shadow: 0 14px 34px rgba(15, 23, 42, .06) !important;
}

.admin-products-filter-summary {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  margin: .85rem 0;
  color: var(--admin-muted);
  font-weight: 850;
}

.admin-filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
}

.admin-filter-chip {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 0 .65rem;
  border-radius: 999px;
  background: #eef2ff;
  color: #283593;
  font-size: .78rem;
  font-weight: 900;
}

.admin-products-bulk--compact {
  display: grid !important;
  grid-template-columns: auto minmax(220px, 1fr) auto auto !important;
  gap: .75rem !important;
  align-items: center !important;
  margin-bottom: 1rem !important;
  padding: .85rem 1rem !important;
  border: 1px solid var(--admin-line) !important;
  border-radius: 14px !important;
  background: #fff !important;
}

.admin-products-table--overview {
  display: grid !important;
  gap: 0 !important;
  overflow: hidden !important;
  border: 1px solid var(--admin-line) !important;
  border-radius: 16px !important;
  background: #fff !important;
  box-shadow: 0 18px 46px rgba(15, 23, 42, .07) !important;
}

.admin-products-table--overview .admin-products-head,
.admin-products-table--overview .admin-products-row--overview {
  display: grid !important;
  grid-template-columns: 42px 70px minmax(180px, 1.35fr) minmax(110px, .65fr) minmax(140px, .8fr) minmax(150px, .85fr) minmax(100px, .58fr) minmax(74px, .44fr) minmax(140px, .75fr) minmax(180px, .8fr) !important;
  align-items: center !important;
  gap: .75rem !important;
}

.admin-products-table--overview .admin-products-head {
  padding: .75rem 1rem !important;
  background: #f7f9fc !important;
  color: #475467 !important;
  font-size: .74rem !important;
  font-weight: 950 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

.admin-products-table--overview .admin-products-row--overview {
  min-width: 0 !important;
  margin: 0 !important;
  padding: .9rem 1rem !important;
  border: 0 !important;
  border-top: 1px solid var(--admin-line) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: #fff !important;
}

.admin-products-table--overview .admin-products-row--overview:hover {
  transform: none !important;
  background: #fbfdff !important;
  box-shadow: inset 3px 0 0 rgba(37, 99, 235, .35) !important;
}

.admin-products-table--overview .admin-products-cell {
  min-width: 0 !important;
  padding: 0 !important;
}

.admin-products-table--overview .cell-select {
  padding-top: 0 !important;
}

.admin-products-table--overview .admin-product-thumb-link {
  width: 56px !important;
  height: 56px !important;
  border-radius: 10px !important;
}

.admin-products-table--overview .cell-main {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: .45rem !important;
}

.admin-product-name-link {
  color: #101827;
  font-size: .98rem;
  font-weight: 950;
  line-height: 1.2;
  text-decoration: none;
}

.admin-product-name-link:hover {
  color: var(--admin-blue);
}

.admin-product-badges {
  display: flex;
  flex-wrap: wrap;
  gap: .32rem;
}

.admin-chip {
  display: inline-flex;
  align-items: center;
  min-height: 23px;
  padding: 0 .5rem;
  border-radius: 999px;
  font-size: .68rem;
  font-weight: 950;
  white-space: nowrap;
}

.admin-chip--blue { background: #eaf2ff; color: #174ea6; }
.admin-chip--indigo { background: #eef2ff; color: #3730a3; }
.admin-chip--warning { background: #fff7ed; color: #c2410c; }
.admin-chip--green { background: #ecfdf3; color: #027a48; }
.admin-chip--neutral { background: #f2f4f7; color: #344054; }
.admin-chip--muted { background: #f1f5f9; color: #64748b; }
.admin-chip--sale { background: #fff7ed; color: #b42318; border-color: #fed7aa; }

.admin-table-label {
  display: none;
  color: #667085;
  font-size: .72rem;
  font-weight: 900;
}

.admin-products-table--overview .cell-price,
.admin-products-table--overview .cell-stock,
.admin-products-table--overview .cell-status,
.admin-products-table--overview .cell-type,
.admin-products-table--overview .cell-category,
.admin-products-table--overview .cell-sku {
  display: grid !important;
  gap: .25rem !important;
  background: transparent !important;
  border: 0 !important;
}

.admin-products-table--overview .cell-actions {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: .4rem !important;
}

.admin-products-table--overview .cell-actions .btn {
  min-height: 34px !important;
  padding: .42rem .55rem !important;
  border-radius: 8px !important;
  font-size: .78rem !important;
}

.admin-products-table--overview .cell-actions form {
  margin: 0 !important;
}

.article-detail-page {
  --detail-surface: #fff;
  --detail-soft: #f4f7fb;
  --detail-line: rgba(15, 23, 42, .10);
  --detail-ink: #101827;
  --detail-muted: #667085;
  padding: 2rem 1rem 3.5rem !important;
}

.article-detail-wrap {
  max-width: 1320px !important;
}

.article-detail-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.article-back-link {
  display: inline-flex;
  margin-bottom: .55rem;
  color: #3152a0;
  font-weight: 900;
  text-decoration: none;
}

.article-detail-header h1 {
  margin: 0;
  color: var(--detail-ink);
  font-size: clamp(2rem, 3.2vw, 3.3rem);
  line-height: 1.04;
}

.article-detail-meta,
.article-detail-header-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  align-items: center;
  margin-top: .65rem;
}

.article-detail-meta > span:not(.product-status) {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 .65rem;
  border-radius: 999px;
  background: #f2f4f7;
  color: #344054;
  font-size: .78rem;
  font-weight: 900;
}

.article-detail-shell {
  display: grid;
  grid-template-columns: 230px minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

.article-detail-tabs {
  position: sticky;
  top: 88px;
  display: grid;
  gap: .45rem;
  padding: .7rem;
  border: 1px solid var(--detail-line);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 16px 40px rgba(15, 23, 42, .06);
}

.article-detail-tabs button {
  width: 100%;
  min-height: 40px;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: #344054;
  padding: .55rem .7rem;
  text-align: left;
  font: inherit;
  font-size: .9rem;
  font-weight: 900;
  cursor: pointer;
}

.article-detail-tabs button:hover,
.article-detail-tabs button.is-active {
  background: #eef4ff;
  color: #143a8f;
}

.article-detail-form {
  min-width: 0;
}

.article-detail-panel {
  display: none;
}

.article-detail-panel.is-active {
  display: block;
}

.article-detail-card {
  display: grid;
  gap: 1.15rem;
  padding: 1.15rem;
  border: 1px solid var(--detail-line);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 16px 42px rgba(15, 23, 42, .065);
}

.article-detail-card > header h2 {
  margin: 0 0 .2rem;
  color: var(--detail-ink);
  font-size: 1.25rem;
  line-height: 1.2;
}

.article-detail-card > header p {
  margin: 0;
  color: var(--detail-muted);
  font-weight: 750;
}

.article-form-grid,
.article-pricing-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(220px, 1fr));
  gap: .9rem;
}

.article-form-grid label,
.article-pricing-grid label,
.article-editor-field {
  display: grid;
  gap: .4rem;
  color: #344054;
  font-weight: 900;
}

.article-form-grid label > span,
.article-pricing-grid label > span,
.article-editor-field > span,
.article-readonly-field > span,
.article-visibility-state span {
  color: #667085;
  font-size: .78rem;
  font-weight: 950;
}

.article-form-grid input,
.article-form-grid select,
.article-form-grid textarea,
.article-pricing-grid input {
  width: 100%;
  min-height: 44px;
  border: 1px solid rgba(15, 23, 42, .16);
  border-radius: 10px;
  background: #fff;
  color: var(--detail-ink);
  padding: .68rem .8rem;
  font: inherit;
  font-size: .94rem;
  font-weight: 800;
}

.article-form-grid textarea {
  min-height: 120px;
  resize: vertical;
}

.article-readonly-field {
  display: grid;
  align-content: center;
  gap: .35rem;
  min-height: 76px;
  padding: .75rem .85rem;
  border: 1px solid var(--detail-line);
  border-radius: 12px;
  background: #f8fafc;
}

.article-warning,
.article-muted-note,
.article-empty-state {
  padding: .85rem 1rem;
  border-radius: 12px;
  font-weight: 850;
}

.article-warning {
  background: #fff7ed;
  color: #c2410c;
}

.article-muted-note,
.article-empty-state {
  background: #f2f4f7;
  color: #475467;
}

.article-image-layout {
  display: grid;
  grid-template-columns: minmax(220px, 320px) minmax(0, 1fr);
  gap: 1rem;
  align-items: stretch;
}

.article-main-preview {
  display: grid;
  gap: .65rem;
  margin: 0;
  padding: 1rem;
  border: 1px solid var(--detail-line);
  border-radius: 14px;
  background: #f8fafc;
}

.article-main-preview img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
}

.article-main-preview figcaption,
.article-base-colors figcaption {
  color: var(--detail-muted);
  font-size: .82rem;
  font-weight: 850;
}

.article-upload-stack {
  display: grid;
  grid-template-columns: repeat(2, minmax(220px, 1fr));
  gap: .9rem;
}

.article-upload-stack.is-muted {
  opacity: .55;
}

.article-variant-grid,
.article-base-colors {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: .85rem;
}

.article-variant-card,
.article-base-colors figure {
  display: grid;
  gap: .65rem;
  margin: 0;
  padding: .75rem;
  border: 1px solid var(--detail-line);
  border-radius: 14px;
  background: #fff;
}

.article-variant-card img,
.article-base-colors img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  border-radius: 10px;
  background: #f8fafc;
}

.article-variant-card strong,
.article-variant-card span {
  display: block;
}

.article-variant-card span {
  color: var(--detail-muted);
  font-size: .8rem;
  font-weight: 800;
  word-break: break-word;
}

.article-remove-line,
.article-checkbox {
  display: inline-flex !important;
  align-items: center;
  gap: .55rem;
  min-height: 32px;
  color: #344054;
  font-weight: 900;
}

.article-remove-line input,
.article-checkbox input,
.admin-products-page--compact .bulk-check input,
.admin-products-page--compact .cell-select input {
  inline-size: 18px !important;
  block-size: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
}

.article-remainder-toggle {
  margin-top: 14px;
  padding: 10px 12px;
  border: 1px solid rgba(251, 146, 60, .35);
  border-radius: 12px;
  background: #fff7ed;
  color: #9a3412;
}

.article-inline-action {
  width: fit-content;
}

.article-price-total {
  display: grid;
  align-content: center;
  gap: .3rem;
  min-height: 92px;
  padding: 1rem;
  border-radius: 14px;
  background: #111827;
  color: #fff;
}

.article-price-total span {
  color: rgba(255, 255, 255, .68);
  font-size: .8rem;
  font-weight: 900;
}

.article-price-total strong {
  font-size: 1.45rem;
  line-height: 1;
}

.article-price-formula {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.article-price-formula span {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  min-height: 32px;
  padding: 0 .75rem;
  border-radius: 999px;
  background: #f2f4f7;
  color: #475467;
  font-weight: 850;
}

.article-editor-field .tw-rich-editor {
  width: 100%;
}

.article-detail-page .tw-rich-surface,
.article-detail-page .tw-rich-preview {
  min-height: 420px !important;
}

.article-form-grid--description {
  grid-template-columns: minmax(280px, 1.4fr) repeat(3, minmax(160px, .7fr));
}

.article-visibility-state {
  display: grid;
  grid-template-columns: repeat(4, minmax(150px, 1fr));
  gap: .75rem;
}

.article-visibility-state > div {
  display: grid;
  gap: .35rem;
  padding: .85rem;
  border: 1px solid var(--detail-line);
  border-radius: 12px;
  background: #f8fafc;
}

.article-visibility-reason {
  grid-column: 1 / -1;
}

.article-detail-savebar {
  position: sticky;
  bottom: 1rem;
  z-index: 15;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 1rem;
  padding: .85rem;
  border: 1px solid rgba(20, 58, 143, .18);
  border-radius: 14px;
  background: rgba(255, 255, 255, .96);
  box-shadow: 0 16px 42px rgba(15, 23, 42, .12);
  backdrop-filter: blur(12px);
}

.article-detail-savebar span {
  color: #475467;
  font-weight: 900;
}

.article-detail-page.is-danger-tab .article-detail-savebar {
  display: none;
}

.pd-order-variants {
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 12px;
  padding: 12px;
  background: #f8fafc;
  margin: 12px 0;
}

.pd-static-gallery {
  display: grid;
  gap: 16px;
}

.pd-static-main {
  position: relative;
  min-height: 420px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(148, 163, 184, 0.35);
  border-radius: 10px;
  background: #f8fafc;
  overflow: hidden;
}

.pd-static-main img {
  width: 100%;
  height: 100%;
  max-height: 640px;
  object-fit: contain;
}

.pd-gallery-nav {
  position: absolute;
  top: 50%;
  z-index: 2;
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.82);
  color: #fff;
  font-size: 32px;
  line-height: 1;
  display: grid;
  place-items: center;
  cursor: pointer;
  transform: translateY(-50%);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.22);
}

.pd-gallery-nav:hover {
  background: #0f172a;
  transform: translateY(-50%) scale(1.04);
}

.pd-gallery-nav--prev {
  left: 16px;
}

.pd-gallery-nav--next {
  right: 16px;
}

.pd-static-thumbs {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: stretch;
}

.pd-variant-image-strip {
  padding: 4px 0 2px;
}

.pd-static-thumb {
  width: 112px;
  min-height: 132px;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: 10px;
  background: #fff;
  color: #0f172a;
  display: grid;
  grid-template-rows: 82px auto;
  gap: 8px;
  align-items: center;
  justify-items: center;
  padding: 8px;
  cursor: pointer;
}

.pd-static-thumb:hover,
.pd-static-thumb.is-active {
  border-color: #1d4ed8;
  box-shadow: 0 10px 24px rgba(37, 99, 235, 0.16);
}

.pd-static-thumb img {
  width: 82px;
  height: 82px;
  object-fit: contain;
}

.pd-static-thumb span {
  width: 100%;
  color: #0f172a;
  font-size: 0.86rem;
  font-weight: 800;
  line-height: 1.18;
  text-align: center;
  overflow-wrap: anywhere;
}

.pd-stock-panel {
  display: grid;
  gap: 10px;
  margin-top: 18px;
  padding: 18px 20px;
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-left: 6px solid #047857;
  border-radius: 12px;
  background: #ecfdf5;
  color: #0f172a;
}

.pd-stock-panel.is-backorder {
  border-left-color: #f97316;
  background: #fff7ed;
}

.pd-stock-kicker {
  display: block;
  color: #64748b;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 2px;
}

.pd-stock-panel strong {
  display: block;
  font-size: 1.2rem;
  line-height: 1.2;
}

.pd-stock-panel p {
  margin: 0;
  color: #475569;
  font-size: 0.96rem;
  line-height: 1.45;
  font-weight: 700;
}

@media (max-width: 780px) {
  .pd-static-main {
    min-height: 300px;
  }

  .pd-gallery-nav {
    width: 38px;
    height: 38px;
    font-size: 26px;
  }

  .pd-gallery-nav--prev {
    left: 10px;
  }

  .pd-gallery-nav--next {
    right: 10px;
  }

  .pd-static-thumb {
    width: 96px;
    min-height: 120px;
    grid-template-rows: 72px auto;
  }

  .pd-static-thumb img {
    width: 72px;
    height: 72px;
  }
}

.pd-order-variant-grid {
  display: grid;
  gap: 10px;
}

.pd-order-variant-option {
  width: 100%;
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  padding: 8px;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: 10px;
  background: #fff;
  color: #0f172a;
  text-align: left;
  cursor: pointer;
}

.pd-order-variant-option:hover,
.pd-order-variant-option.is-active {
  border-color: #0f172a;
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.08);
}

.pd-order-variant-option img {
  width: 54px;
  height: 54px;
  object-fit: contain;
  border-radius: 8px;
  background: #f1f5f9;
}

.pd-order-variant-option span {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.pd-order-variant-option strong,
.pd-order-variant-option small,
.pd-order-variant-option em {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.pd-order-variant-option em {
  color: #047857;
  font-style: normal;
  font-weight: 800;
}

.pd-stock-hint {
  display: block;
  margin-top: 6px;
  min-height: 1.2em;
  color: #475569;
  font-weight: 700;
}

.article-inventory-block {
  border: 1px solid rgba(148, 163, 184, 0.28);
  border-radius: 12px;
  padding: 14px;
  background: #f8fafc;
}

.article-inventory-block--central {
  margin-top: 18px;
}

.article-inventory-block h3,
.article-order-variant-card h3 {
  margin: 0 0 6px;
  font-size: 1rem;
}

.article-inventory-block p {
  margin: 0 0 12px;
  color: #64748b;
}

.article-stock-grid,
.article-order-variant-head,
.article-upload-inline,
.article-variant-image-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
  align-items: end;
}

.article-stock-grid input[readonly] {
  background: #eef2f7;
  color: #64748b;
  cursor: not-allowed;
}

.article-stock-total {
  display: block;
  margin-top: 5px;
  color: #0f766e;
  font-size: .78rem;
  font-weight: 900;
}

.article-order-variant-card--stock {
  gap: 10px;
  background: #fbfdff;
}

.article-order-variant-list {
  display: grid;
  gap: 16px;
  margin-top: 16px;
}

.article-order-variant-card {
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: 14px;
  padding: 16px;
  background: #fff;
  display: grid;
  gap: 16px;
}

.article-order-variant-card--new {
  border-style: dashed;
  background: #fbfdff;
}

.article-variant-image-editor {
  display: grid;
  gap: 12px;
}

.article-variant-image-row {
  grid-template-columns: 80px minmax(120px, .75fr) minmax(150px, 1fr) 86px minmax(130px, .8fr) minmax(150px, auto);
  align-items: center;
  border: 1px solid rgba(148, 163, 184, 0.22);
  border-radius: 12px;
  padding: 10px;
  background: #f8fafc;
}

.article-variant-image-row img {
  width: 72px;
  height: 72px;
  object-fit: contain;
  border-radius: 10px;
  background: #fff;
}

.article-upload-inline {
  align-items: center;
  border-top: 1px solid rgba(148, 163, 184, 0.22);
  padding-top: 12px;
}

.article-variant-image-row .article-upload-inline {
  display: block;
  border-top: 0;
  padding-top: 0;
}

.article-danger-toggle {
  color: #991b1b;
}

@media (max-width: 780px) {
  .article-variant-image-row {
    grid-template-columns: 72px minmax(0, 1fr);
  }

  .article-variant-image-row label {
    grid-column: 1 / -1;
  }
}

.article-danger-panel {
  grid-column: 2;
}

/* Product detail refinement */
body.product-detail-view main.container {
  margin-top: 0 !important;
}

body.product-detail-view header.site-header.has-club-logo .topbar-logo-club {
  height: 130px !important;
  max-width: 231px !important;
  transform: translateY(-18%) !important;
}

.product-detail {
  padding: clamp(10px, 1.6vw, 24px) 0 46px !important;
}

.product-detail .wrap {
  max-width: 1340px !important;
}

.pd-page-heading {
  max-width: none !important;
  margin: 0 0 12px !important;
}

.pd-title {
  font-size: clamp(2rem, 3.45vw, 3.2rem) !important;
  line-height: 1.02 !important;
}

.pd-top-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 420px) !important;
  gap: 24px !important;
  align-items: start !important;
  margin-bottom: 18px !important;
}

.pd-card-media,
.pd-card-buy {
  height: auto !important;
  min-height: 0 !important;
  align-self: start !important;
  box-sizing: border-box !important;
}

.pd-card-media {
  padding: 14px !important;
  overflow: visible !important;
}

.pd-media-inner {
  gap: 14px !important;
  min-height: 0 !important;
}

.pd-static-gallery {
  gap: 12px !important;
  align-content: start !important;
  min-height: 0 !important;
}

.pd-static-main {
  height: clamp(330px, calc(100svh - 330px), 520px) !important;
  min-height: 0 !important;
  aspect-ratio: 4 / 3 !important;
  background: linear-gradient(180deg, #fff 0%, #f8fafc 100%) !important;
  border-radius: 12px !important;
}

.pd-static-main img {
  width: 100% !important;
  height: 100% !important;
  max-height: none !important;
  object-fit: contain !important;
}

.pd-card-media .product-render {
  /* Overlay coordinates are authored in the backend 5:6 preview. */
  width: min(100%, clamp(360px, 42vw, 560px)) !important;
  max-width: 560px !important;
  height: auto !important;
  max-height: none !important;
  aspect-ratio: 5 / 6 !important;
  min-height: 0 !important;
  display: block !important;
  margin: 0 auto !important;
}

.pd-gallery-nav {
  width: 34px !important;
  height: 34px !important;
  font-size: 24px !important;
  background: rgba(15, 23, 42, .74) !important;
  box-shadow: 0 10px 24px rgba(15, 23, 42, .18) !important;
}

.pd-gallery-nav--prev {
  left: 12px !important;
}

.pd-gallery-nav--next {
  right: 12px !important;
}

.pd-static-thumbs {
  gap: 10px !important;
  align-items: flex-start !important;
  overflow: visible !important;
}

.pd-static-thumb {
  width: 96px !important;
  min-height: 108px !important;
  grid-template-rows: 62px auto !important;
  gap: 6px !important;
  padding: 7px !important;
  border-radius: 9px !important;
}

.pd-static-thumb img {
  width: 62px !important;
  height: 62px !important;
}

.pd-static-thumb span {
  font-size: .75rem !important;
  line-height: 1.12 !important;
  white-space: normal !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none !important;
}

.pd-main-lightbox-trigger {
  cursor: zoom-in !important;
}

.pd-main-lightbox-trigger:focus-visible {
  outline: 3px solid var(--ui-primary) !important;
  outline-offset: 4px !important;
}

body.pd-lightbox-open {
  overflow: hidden !important;
}

.pd-lightbox {
  position: fixed !important;
  inset: 0 !important;
  z-index: 99999 !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 42px !important;
  background: rgba(8, 13, 27, .9) !important;
  backdrop-filter: blur(10px) !important;
}

.pd-lightbox.is-open {
  display: flex !important;
}

.pd-lightbox-figure {
  width: min(100%, 1500px) !important;
  height: calc(100svh - 84px) !important;
  margin: 0 !important;
  display: grid !important;
  grid-template-rows: minmax(0, 1fr) auto !important;
  place-items: center !important;
  gap: 12px !important;
}

.pd-lightbox-render {
  position: relative !important;
  display: block !important;
  width: calc(100vw - 128px) !important;
  height: calc(100svh - 128px) !important;
  max-width: calc(100vw - 128px) !important;
  max-height: calc(100svh - 128px) !important;
  background: #fff !important;
  border-radius: 14px !important;
  overflow: hidden !important;
  box-shadow: 0 30px 90px rgba(0, 0, 0, .34) !important;
}

.pd-lightbox-img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
}

.pd-lightbox-logo {
  position: absolute !important;
  object-fit: contain !important;
  pointer-events: none !important;
}

.pd-lightbox-caption {
  min-height: 20px !important;
  color: rgba(255, 255, 255, .86) !important;
  font-weight: 900 !important;
  text-align: center !important;
}

.pd-lightbox-close,
.pd-lightbox-nav {
  position: fixed !important;
  z-index: 100000 !important;
  width: 44px !important;
  height: 44px !important;
  border: 1px solid rgba(255, 255, 255, .22) !important;
  border-radius: 999px !important;
  background: rgba(15, 23, 42, .82) !important;
  color: #fff !important;
  display: grid !important;
  place-items: center !important;
  cursor: pointer !important;
  box-shadow: 0 16px 34px rgba(0, 0, 0, .26) !important;
}

.pd-lightbox-close:hover,
.pd-lightbox-nav:hover {
  background: rgba(15, 23, 42, .98) !important;
  transform: scale(1.04) !important;
}

.pd-lightbox-close {
  top: 22px !important;
  right: 22px !important;
  font-size: 28px !important;
  line-height: 1 !important;
}

.pd-lightbox-nav {
  top: 50% !important;
  transform: translateY(-50%) !important;
  font-size: 34px !important;
  line-height: 1 !important;
}

.pd-lightbox-nav:hover {
  transform: translateY(-50%) scale(1.04) !important;
}

.pd-lightbox-nav--prev {
  left: 22px !important;
}

.pd-lightbox-nav--next {
  right: 22px !important;
}

.pd-lightbox-nav[hidden] {
  display: none !important;
}

.pd-card-buy {
  top: 78px !important;
  padding: 16px !important;
  width: 100% !important;
  min-width: 0 !important;
}

.pd-form {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}

.pd-buy-price-row {
  order: 1 !important;
  padding: 14px !important;
}

.pd-price-main {
  font-size: clamp(2rem, 3vw, 2.8rem) !important;
}

.pd-trust-grid {
  order: 1 !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 7px !important;
}

.pd-trust-grid > div {
  min-height: 42px !important;
  padding: 8px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
}

.pd-trust-grid span {
  display: none !important;
}

.pd-trust-grid strong {
  font-size: .76rem !important;
  line-height: 1.15 !important;
}

.pd-order-variants {
  order: 2 !important;
  margin: 2px 0 !important;
  padding: 10px !important;
}

.pd-order-variant-option {
  min-height: 58px !important;
  grid-template-columns: 46px minmax(0, 1fr) !important;
  border-radius: 11px !important;
}

.pd-order-variant-option img {
  width: 46px !important;
  height: 46px !important;
}

.pd-order-variant-option.is-active::after {
  content: "Ausgewaehlt" !important;
  grid-column: 2 !important;
  align-self: start !important;
  color: #047857 !important;
  font-size: .72rem !important;
  font-weight: 900 !important;
}

.pd-field {
  order: 3 !important;
}

.pd-qty-row {
  order: 5 !important;
  gap: 10px !important;
}

.pd-stock-panel {
  order: 4 !important;
  gap: 6px !important;
  margin-top: 0 !important;
  padding: 10px 12px !important;
  border-left-width: 4px !important;
}

.pd-stock-panel strong {
  font-size: 1rem !important;
}

.pd-stock-panel p {
  font-size: .84rem !important;
  line-height: 1.35 !important;
  font-weight: 750 !important;
}

.pd-subtotal-row {
  order: 7 !important;
  padding: 8px 0 0 !important;
  border-top: 0 !important;
}

.pd-actions {
  order: 6 !important;
}

.pd-volume {
  order: initial !important;
  padding: 0 !important;
  overflow: hidden !important;
}

.pd-volume summary {
  min-height: 44px !important;
  padding: 0 14px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  color: var(--ui-ink) !important;
  font-weight: 900 !important;
  cursor: pointer !important;
  list-style: none !important;
}

.pd-volume summary::-webkit-details-marker {
  display: none !important;
}

.pd-volume summary::after {
  content: "+" !important;
  color: var(--ui-primary) !important;
  font-size: 1.1rem !important;
}

.pd-volume[open] summary::after {
  content: "-" !important;
}

.pd-volume-table {
  border-radius: 0 !important;
  table-layout: fixed !important;
}

.pd-volume-table th,
.pd-volume-table td {
  padding: 10px 8px !important;
  font-size: .78rem !important;
}

.pd-volume-note {
  margin: 10px 14px 14px !important;
}

.pd-desc-row {
  margin-top: 0 !important;
}

.pd-card-desc {
  margin-top: 0 !important;
}

.pd-detail-info-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 420px) !important;
  gap: 18px !important;
  align-items: start !important;
  margin: 0 0 18px !important;
}

.pd-support-card {
  padding: 16px !important;
}

.pd-detail-info-grid .pd-support-card:only-child {
  grid-column: 1 / -1 !important;
}

.pd-detail-info-grid .pd-trust-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

.pd-detail-info-grid .pd-trust-grid > div {
  min-height: 72px !important;
  padding: 12px !important;
  display: block !important;
  text-align: left !important;
}

.pd-detail-info-grid .pd-trust-grid strong {
  font-size: .92rem !important;
  line-height: 1.2 !important;
}

.pd-detail-info-grid .pd-trust-grid span {
  display: block !important;
  margin-top: 3px !important;
  color: var(--ui-muted) !important;
  font-size: .84rem !important;
  line-height: 1.35 !important;
}

.pd-volume-details {
  align-self: start !important;
}

@media (max-width: 920px) {
  .pd-top-grid {
    grid-template-columns: 1fr !important;
  }

  .pd-detail-info-grid {
    grid-template-columns: 1fr !important;
  }

  .pd-card-buy {
    position: static !important;
  }

  .pd-page-heading {
    margin-top: 8px !important;
  }
}

@media (max-width: 620px) {
  body.product-detail-view header.site-header.has-club-logo .topbar-logo-club {
    height: 102px !important;
    max-width: 161px !important;
    transform: translateY(-16%) !important;
  }

  .product-detail {
    padding-top: 16px !important;
  }

  .pd-title {
    font-size: clamp(1.9rem, 9vw, 2.55rem) !important;
  }

  .pd-card-media,
  .pd-card-buy {
    padding: 12px !important;
  }

  .pd-static-main {
    height: 280px !important;
    min-height: 0 !important;
  }

  .pd-lightbox {
    padding: 16px !important;
  }

  .pd-lightbox-figure {
    height: calc(100svh - 32px) !important;
  }

  .pd-lightbox-render,
  .pd-lightbox-img {
    max-width: calc(100vw - 32px) !important;
    max-height: calc(100svh - 88px) !important;
  }

  .pd-lightbox-close {
    top: 12px !important;
    right: 12px !important;
  }

  .pd-lightbox-nav {
    width: 38px !important;
    height: 38px !important;
  }

  .pd-lightbox-nav--prev {
    left: 10px !important;
  }

  .pd-lightbox-nav--next {
    right: 10px !important;
  }

  .pd-qty-row {
    grid-template-columns: 1fr !important;
  }

  .pd-trust-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .pd-btn-add {
    min-height: 56px !important;
  }
}

.article-detail-card--danger {
  border-color: rgba(220, 38, 38, .24);
  background: #fffafa;
}

.article-danger-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(180px, 1fr));
  gap: .85rem;
}

.article-danger-grid form,
.article-danger-grid button {
  width: 100%;
}

@media (max-width: 1200px) {
  .admin-products-toolbar--compact {
    grid-template-columns: repeat(3, minmax(170px, 1fr)) !important;
  }

  .admin-products-table--overview .admin-products-head,
  .admin-products-table--overview .admin-products-row--overview {
    grid-template-columns: 38px 64px minmax(180px, 1.3fr) minmax(100px, .7fr) minmax(130px, .8fr) minmax(100px, .6fr) minmax(70px, .45fr) minmax(130px, .75fr) minmax(170px, .8fr) !important;
  }

  .admin-products-table--overview .cell-category {
    display: none !important;
  }
}

@media (max-width: 960px) {
  .admin-products-page--compact .admin-products-hero--compact,
  .article-detail-header {
    flex-direction: column;
  }

  .admin-products-page--compact .admin-products-actions,
  .article-detail-header-actions {
    justify-content: flex-start !important;
  }

  .admin-products-table--overview .admin-products-head {
    display: none !important;
  }

  .admin-products-table--overview .admin-products-row--overview {
    grid-template-columns: 34px 70px minmax(0, 1fr) !important;
    align-items: start !important;
  }

  .admin-products-table--overview .cell-sku,
  .admin-products-table--overview .cell-type,
  .admin-products-table--overview .cell-price,
  .admin-products-table--overview .cell-stock,
  .admin-products-table--overview .cell-status,
  .admin-products-table--overview .cell-actions {
    grid-column: 3 !important;
  }

  .admin-products-table--overview .cell-category {
    display: grid !important;
    grid-column: 3 !important;
  }

  .admin-table-label {
    display: block;
  }

  .admin-products-table--overview .cell-actions {
    grid-template-columns: repeat(2, minmax(120px, 1fr)) !important;
  }

  .article-detail-shell {
    grid-template-columns: 1fr;
  }

  .article-detail-tabs {
    position: static;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .article-danger-panel {
    grid-column: 1;
  }

  .article-image-layout,
  .article-upload-stack,
  .article-form-grid,
  .article-pricing-grid,
  .article-form-grid--description,
  .article-visibility-state {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .admin-products-toolbar--compact,
  .admin-products-bulk--compact {
    grid-template-columns: 1fr !important;
  }

  .admin-products-table--overview .admin-products-row--overview {
    grid-template-columns: 28px 62px minmax(0, 1fr) !important;
    padding: .8rem !important;
  }

  .admin-products-table--overview .admin-product-thumb-link {
    width: 58px !important;
    height: 58px !important;
  }

  .admin-products-table--overview .cell-actions {
    grid-template-columns: 1fr !important;
  }

  .article-detail-tabs {
    grid-template-columns: 1fr;
  }

  .article-detail-card {
    padding: .9rem;
  }

  .article-detail-savebar,
  .article-danger-grid {
    grid-template-columns: 1fr;
    flex-direction: column;
    align-items: stretch;
  }
}

/* Final shop layout cleanup: cart, product cards and detail columns */
body.cart-view main.container,
body.checkout-view main.container {
  margin-top: clamp(4.5rem, 7vw, 6.5rem) !important;
}

.cart-title {
  margin: 0 0 24px !important;
  color: var(--ui-ink) !important;
  font-size: clamp(2rem, 3.2vw, 3.2rem) !important;
  line-height: 1.04 !important;
  font-weight: 950 !important;
}

.cart-form {
  padding: 0 0 18px !important;
  overflow: hidden !important;
}

table.cart-table {
  width: 100% !important;
  margin: 0 !important;
  table-layout: fixed !important;
  border: 0 !important;
  border-radius: var(--ui-radius-lg) var(--ui-radius-lg) 0 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

.cart-table.has-color-column .cart-col-article { width: 32% !important; }
.cart-table.has-color-column .cart-col-color { width: 11% !important; }
.cart-table.has-color-column .cart-col-size { width: 10% !important; }
.cart-table.has-color-column .cart-col-qty { width: 18% !important; }
.cart-table.has-color-column .cart-col-price { width: 13% !important; }
.cart-table.has-color-column .cart-col-sum { width: 11% !important; }
.cart-table.has-color-column .cart-col-remove { width: 5% !important; }

.cart-table.has-no-color-column .cart-col-article { width: 36% !important; }
.cart-table.has-no-color-column .cart-col-size { width: 12% !important; }
.cart-table.has-no-color-column .cart-col-qty { width: 22% !important; }
.cart-table.has-no-color-column .cart-col-price { width: 14% !important; }
.cart-table.has-no-color-column .cart-col-sum { width: 12% !important; }
.cart-table.has-no-color-column .cart-col-remove { width: 4% !important; }

table.cart-table th,
table.cart-table td {
  box-sizing: border-box !important;
  padding: 16px 14px !important;
  vertical-align: middle !important;
}

table.cart-table th {
  text-align: center !important;
}

.cart-cell-article {
  text-align: left !important;
}

.cart-cell-color,
.cart-cell-size,
.cart-cell-qty,
.cart-cell-remove {
  text-align: center !important;
}

.cart-cell-price,
.cart-cell-sum {
  text-align: right !important;
}

.cart-product {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  min-width: 0 !important;
}

.cart-product .thumb,
table.cart-table .thumb {
  flex: 0 0 auto !important;
  width: 82px !important;
  height: 66px !important;
  object-fit: contain !important;
  border-radius: 10px !important;
  border: 1px solid var(--ui-line) !important;
  background: #fff !important;
}

.cart-product-copy {
  display: grid !important;
  gap: 4px !important;
  min-width: 0 !important;
}

.cart-product-copy strong {
  color: var(--ui-ink) !important;
  font-weight: 850 !important;
}

.cart-product-copy small {
  color: var(--ui-muted) !important;
  line-height: 1.35 !important;
}

.cart-cell-qty input {
  width: min(100%, 160px) !important;
  min-height: 38px !important;
  padding: 0 10px !important;
  border: 1px solid var(--ui-line) !important;
  border-radius: 10px !important;
  background: #fff !important;
  font-weight: 700 !important;
}

.cart-remove {
  width: 42px !important;
  height: 42px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid rgba(153, 27, 27, .18) !important;
  border-radius: 10px !important;
  background: #fff !important;
  color: #991b1b !important;
  font-size: 1.25rem !important;
  cursor: pointer !important;
}

.cart-remove:hover,
.cart-remove:focus-visible {
  background: #fef2f2 !important;
  border-color: rgba(153, 27, 27, .32) !important;
}

.cart-total-label {
  text-align: left !important;
}

.cart-total-value {
  text-align: right !important;
  color: var(--ui-ink) !important;
  font-size: 1.1rem !important;
}

.cart-actions {
  margin: 22px 0 0 !important;
}

.product-grid {
  align-items: stretch !important;
}

.product-card {
  display: flex !important;
  flex-direction: column !important;
  min-height: 100% !important;
  padding: 0 !important;
}

.product-link {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  min-height: 100% !important;
}

.product-card .product-render {
  width: auto !important;
  margin: 16px 16px 0 !important;
  background: #fff !important;
  border: 1px solid rgba(16,24,40,.06) !important;
  border-radius: 12px !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.75) !important;
  aspect-ratio: 5 / 6 !important;
}

.product-card .product-render .base,
.product-card .product-render img.base {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
  border-radius: 0 !important;
  aspect-ratio: auto !important;
  object-fit: contain !important;
  object-position: center !important;
  background: #fff !important;
}

.product-info-row {
  flex: 1 1 auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: start !important;
  padding: 16px 18px 10px !important;
}

.product-info-main {
  min-height: 100% !important;
  display: flex !important;
  flex-direction: column !important;
}

.product-info-main h2 {
  min-height: 2.42em !important;
  margin-bottom: 8px !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

.product-badges {
  min-height: 58px !important;
  align-content: flex-start !important;
}

.product-card .price {
  margin-top: auto !important;
}

.product-size-line {
  min-height: 24px !important;
}

.card-cta {
  margin: 12px 18px 18px !important;
}

.pd-top-grid {
  align-items: start !important;
}

.pd-card-media {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  background: rgba(255,255,255,.96) !important;
}

.pd-media-inner,
.pd-static-gallery {
  gap: 10px !important;
}

.pd-static-main {
  height: clamp(320px, 38vw, 500px) !important;
  background: #fff !important;
  border: 1px solid var(--ui-line) !important;
  overflow: hidden !important;
}

.pd-static-main img {
  object-fit: contain !important;
  object-position: center !important;
  background: #fff !important;
}

.pd-static-thumbs {
  margin: 0 !important;
}

.pd-support-card--inline {
  padding: 12px 0 0 !important;
  border-top: 1px solid var(--ui-line) !important;
}

.pd-support-card--inline .pd-trust-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

.pd-support-card--inline .pd-trust-grid > div {
  min-height: 74px !important;
  padding: 12px !important;
  border: 1px solid var(--ui-line) !important;
  border-radius: 10px !important;
  background: #fff !important;
  display: block !important;
  text-align: left !important;
}

.pd-support-card--inline .pd-trust-grid strong {
  display: block !important;
  color: var(--ui-ink) !important;
  font-size: .92rem !important;
  line-height: 1.2 !important;
}

.pd-support-card--inline .pd-trust-grid span {
  display: block !important;
  margin-top: 4px !important;
  color: var(--ui-muted) !important;
  font-size: .84rem !important;
  line-height: 1.35 !important;
}

.pd-detail-info-grid--side-only {
  grid-template-columns: minmax(0, 1fr) minmax(360px, 420px) !important;
  margin-top: -6px !important;
}

.pd-detail-info-spacer {
  display: block !important;
}

@media (max-width: 920px) {
  .pd-detail-info-grid--side-only {
    grid-template-columns: 1fr !important;
    margin-top: 0 !important;
  }

  .pd-detail-info-spacer {
    display: none !important;
  }

  .pd-support-card--inline .pd-trust-grid {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 720px) {
  body.cart-view main.container,
  body.checkout-view main.container {
    margin-top: 2.5rem !important;
  }

  table.cart-table,
  table.cart-table thead,
  table.cart-table tbody,
  table.cart-table tfoot,
  table.cart-table tr,
  table.cart-table th,
  table.cart-table td {
    display: block !important;
    width: 100% !important;
  }

  table.cart-table colgroup,
  table.cart-table thead {
    display: none !important;
  }

  table.cart-table tbody tr {
    padding: 14px !important;
    border-bottom: 1px solid var(--ui-line) !important;
    background: #fff !important;
  }

  table.cart-table td {
    padding: 9px 0 !important;
    border-bottom: 0 !important;
  }

  table.cart-table tbody td:not(.cart-cell-article) {
    display: grid !important;
    grid-template-columns: 112px minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: center !important;
    text-align: right !important;
  }

  table.cart-table tbody td:not(.cart-cell-article)::before {
    content: attr(data-label);
    color: var(--ui-muted);
    text-align: left;
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .04em;
    text-transform: uppercase;
  }

  .cart-cell-qty input {
    justify-self: end !important;
    width: min(100%, 160px) !important;
  }

  .cart-cell-remove {
    text-align: right !important;
  }

  table.cart-table tfoot tr {
    padding: 14px !important;
  }

  table.cart-table tfoot td {
    padding: 6px 0 !important;
    text-align: right !important;
  }

  .cart-total-label {
    text-align: left !important;
  }

  .cart-actions {
    padding: 0 14px !important;
  }

  .cart-actions .btn {
    width: 100% !important;
  }

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

  .product-info-main h2 {
    min-height: 0 !important;
  }

  .product-badges {
    min-height: 0 !important;
  }

  .pd-static-main {
    height: 300px !important;
  }
}
.admin-products-page--compact .admin-products-row--overview {
  min-height: 0 !important;
  padding: 0.65rem 0.75rem !important;
  gap: 0.75rem !important;
  align-items: center !important;
}

.admin-products-page--compact .admin-products-cell {
  padding-top: 0.2rem !important;
  padding-bottom: 0.2rem !important;
}

.admin-products-page--compact .cell-thumb img,
.superadmin-article-table .cell-thumb img {
  width: 88px !important;
  height: 88px !important;
  object-fit: contain !important;
}

.superadmin-article-table .admin-products-head,
.superadmin-article-table .admin-products-row--overview {
  grid-template-columns:
    92px
    minmax(230px, 1.7fr)
    minmax(140px, 0.9fr)
    minmax(100px, 0.55fr)
    minmax(130px, 0.7fr)
    minmax(130px, 0.7fr)
    minmax(110px, 0.55fr)
    minmax(130px, 0.6fr) !important;
}

.admin-products-page--compact .admin-product-badges {
  gap: 0.25rem !important;
  margin-top: 0.25rem !important;
}

.admin-products-page--compact .admin-chip {
  padding: 0.18rem 0.45rem !important;
  font-size: 0.78rem !important;
}

.admin-products-page--compact .cell-actions {
  gap: 0.35rem !important;
}

.superadmin-color-card img {
  background: #fff;
}

.article-detail-card--nested {
  margin-top: 1rem;
  border: 1px solid var(--line, #e5e7eb);
}

/* Superadmin: globale Artikelbilder kompakt halten */
.superadmin-article-detail,
.superadmin-article-detail * {
  box-sizing: border-box;
}

.superadmin-article-detail .article-detail-wrap,
.superadmin-article-detail .article-detail-form,
.superadmin-article-detail .article-detail-card {
  min-width: 0;
  max-width: 100%;
}

.superadmin-article-detail .article-image-layout {
  grid-template-columns: minmax(180px, 240px) minmax(0, 1fr);
  align-items: start;
}

.superadmin-article-detail .article-main-preview {
  align-self: start;
}

.superadmin-article-detail .article-main-preview img {
  width: 100%;
  max-width: 210px;
  height: auto;
  max-height: 260px;
  justify-self: center;
  aspect-ratio: 1 / 1;
  object-fit: contain;
}

.superadmin-article-detail .article-upload-stack,
.superadmin-article-detail .article-form-grid {
  min-width: 0;
}

.superadmin-article-detail .article-variant-grid {
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  align-items: start;
}

.superadmin-article-detail .article-variant-card {
  min-width: 0;
  overflow: hidden;
}

.superadmin-article-detail .article-variant-card > img {
  width: 100%;
  height: 170px;
  max-width: 100%;
  aspect-ratio: auto;
  object-fit: contain;
}

.superadmin-article-detail .article-variant-card > div {
  min-width: 0;
}

.superadmin-article-detail .article-variant-card .article-form-grid {
  grid-template-columns: minmax(0, 1fr);
  gap: .45rem;
}

.superadmin-article-detail .article-variant-card input,
.superadmin-article-detail .article-variant-card select,
.superadmin-article-detail .article-variant-card textarea,
.superadmin-article-detail .article-upload-inline,
.superadmin-article-detail .article-upload-inline label {
  min-width: 0;
  max-width: 100%;
}

.superadmin-article-detail .article-variant-card input[type="file"],
.superadmin-article-detail .admin-dropzone input[type="file"] {
  width: 100%;
  font-size: .78rem;
}

.superadmin-article-detail .article-remove-line {
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  width: 100%;
}

.superadmin-article-detail .article-remove-line span,
.superadmin-article-detail .article-variant-card span {
  overflow-wrap: anywhere;
}

@media (max-width: 760px) {
  .superadmin-article-detail .article-image-layout,
  .superadmin-article-detail .article-upload-stack {
    grid-template-columns: minmax(0, 1fr);
  }

  .superadmin-article-detail .article-main-preview img,
  .superadmin-article-detail .article-variant-card > img {
    max-height: 220px;
  }
}

/* Backend article overview: keep table header, cells and actions in one aligned grid. */
.admin-products-page--compact .admin-products-table--overview {
  display: block !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  border: 1px solid var(--admin-line, #dbe3ea) !important;
  border-radius: 16px !important;
  background: #fff !important;
  box-shadow: 0 16px 42px rgba(15, 23, 42, .07) !important;
}

.admin-products-page--compact .admin-products-table--overview > .admin-products-head,
.admin-products-page--compact .admin-products-table--overview > .admin-products-row--overview {
  display: grid !important;
  grid-template-columns:
    58px
    82px
    minmax(220px, 1.35fr)
    minmax(130px, .7fr)
    minmax(150px, .8fr)
    minmax(158px, .85fr)
    minmax(120px, .62fr)
    minmax(170px, .82fr)
    minmax(168px, .82fr)
    minmax(220px, .95fr) !important;
  align-items: center !important;
  gap: 14px !important;
  min-width: 1380px !important;
}

.admin-products-page--compact .admin-products-table--overview > .admin-products-head {
  padding: 14px 18px !important;
  background: #f8fafc !important;
  border-bottom: 1px solid var(--admin-line, #dbe3ea) !important;
  color: #475569 !important;
  font-size: .74rem !important;
  font-weight: 950 !important;
  letter-spacing: .03em !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
}

.admin-products-page--compact .admin-products-table--overview > .admin-products-row--overview {
  min-height: 0 !important;
  height: auto !important;
  margin: 0 !important;
  padding: 16px 18px !important;
  border: 0 !important;
  border-bottom: 1px solid #edf2f7 !important;
  border-radius: 0 !important;
  background: #fff !important;
  box-shadow: none !important;
}

.admin-products-page--compact .admin-products-table--overview > .admin-products-row--overview:hover {
  transform: none !important;
  background: #fbfdff !important;
  box-shadow: inset 3px 0 0 rgba(20, 116, 132, .28) !important;
}

.admin-products-page--compact .admin-products-table--overview > .admin-products-row--overview:last-child {
  border-bottom: 0 !important;
}

.admin-products-page--compact .admin-products-table--overview .admin-products-cell {
  grid-area: auto !important;
  min-width: 0 !important;
  padding: 0 !important;
  align-self: center !important;
  background: transparent !important;
  border: 0 !important;
}

.admin-products-page--compact .admin-products-table--overview .cell-select {
  display: flex !important;
  justify-content: center !important;
}

.admin-products-page--compact .admin-products-table--overview .cell-thumb {
  display: flex !important;
  justify-content: flex-start !important;
}

.admin-products-page--compact .admin-products-table--overview .admin-product-thumb-link {
  display: flex !important;
  width: 64px !important;
  height: 64px !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  border: 1px solid var(--admin-line, #dbe3ea) !important;
  border-radius: 10px !important;
  background: #f8fafc !important;
}

.admin-products-page--compact .admin-products-table--overview .admin-product-thumb-link img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}

.admin-products-page--compact .admin-products-table--overview .cell-main,
.admin-products-page--compact .admin-products-table--overview .cell-sku,
.admin-products-page--compact .admin-products-table--overview .cell-category,
.admin-products-page--compact .admin-products-table--overview .cell-type,
.admin-products-page--compact .admin-products-table--overview .cell-price,
.admin-products-page--compact .admin-products-table--overview .cell-stock,
.admin-products-page--compact .admin-products-table--overview .cell-status {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: .3rem !important;
}

.admin-products-page--compact .admin-products-table--overview .cell-main {
  align-content: center !important;
}

.admin-products-page--compact .admin-products-table--overview .admin-table-label {
  display: none !important;
}

.admin-products-page--compact .admin-products-table--overview .admin-product-name-link {
  color: #101827 !important;
  font-size: 1rem !important;
  font-weight: 950 !important;
  line-height: 1.22 !important;
}

.admin-products-page--compact .admin-products-table--overview .admin-product-badges {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: .25rem !important;
  margin-top: .1rem !important;
}

.admin-products-page--compact .admin-products-table--overview .admin-chip {
  min-height: 21px !important;
  padding: .12rem .45rem !important;
  font-size: .68rem !important;
  line-height: 1.2 !important;
}

.admin-products-page--compact .admin-products-table--overview .cell-sku strong,
.admin-products-page--compact .admin-products-table--overview .cell-price strong,
.admin-products-page--compact .admin-products-table--overview .cell-stock strong {
  color: #101827 !important;
  font-size: .9rem !important;
  font-weight: 900 !important;
  line-height: 1.25 !important;
  overflow-wrap: anywhere !important;
}

.admin-products-page--compact .admin-products-table--overview .cell-status small {
  color: #64748b !important;
  font-size: .74rem !important;
  font-weight: 800 !important;
  line-height: 1.25 !important;
}

.admin-products-page--compact .admin-products-table--overview .cell-actions {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: .45rem !important;
}

.admin-products-page--compact .admin-products-table--overview .cell-actions form {
  margin: 0 !important;
}

.admin-products-page--compact .admin-products-table--overview .cell-actions .btn {
  width: 100% !important;
  min-height: 36px !important;
  padding: .45rem .6rem !important;
  border-radius: 9px !important;
  font-size: .8rem !important;
  line-height: 1.1 !important;
  justify-content: center !important;
}

@media (max-width: 980px) {
  .admin-products-page--compact .admin-products-table--overview {
    overflow: visible !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .admin-products-page--compact .admin-products-table--overview > .admin-products-head {
    display: none !important;
  }

  .admin-products-page--compact .admin-products-table--overview > .admin-products-row--overview {
    grid-template-columns: 34px 72px minmax(0, 1fr) !important;
    gap: 12px !important;
    min-width: 0 !important;
    padding: 14px !important;
    margin-bottom: 12px !important;
    border: 1px solid var(--admin-line, #dbe3ea) !important;
    border-radius: 12px !important;
    box-shadow: 0 10px 26px rgba(15, 23, 42, .05) !important;
  }

  .admin-products-page--compact .admin-products-table--overview .cell-sku,
  .admin-products-page--compact .admin-products-table--overview .cell-category,
  .admin-products-page--compact .admin-products-table--overview .cell-type,
  .admin-products-page--compact .admin-products-table--overview .cell-price,
  .admin-products-page--compact .admin-products-table--overview .cell-stock,
  .admin-products-page--compact .admin-products-table--overview .cell-status,
  .admin-products-page--compact .admin-products-table--overview .cell-actions {
    grid-column: 3 !important;
  }

  .admin-products-page--compact .admin-products-table--overview .admin-table-label {
    display: block !important;
    color: #64748b !important;
    font-size: .68rem !important;
    font-weight: 900 !important;
    letter-spacing: .04em !important;
    line-height: 1.1 !important;
    text-transform: uppercase !important;
  }
}

/* Backend article overview: use a wider work area and a tighter desktop table before switching to cards. */
.admin-products-page--compact {
  padding-inline: clamp(.75rem, 1.25vw, 1.25rem) !important;
}

.admin-products-page--compact .admin-products-wrap {
  width: min(1720px, calc(100vw - 40px)) !important;
  max-width: min(1720px, calc(100vw - 40px)) !important;
  margin-inline: auto !important;
  padding-inline: 0 !important;
}

.admin-products-page--compact .admin-products-toolbar--compact {
  grid-template-columns:
    minmax(200px, 1.45fr)
    repeat(5, minmax(120px, .82fr))
    minmax(150px, .72fr) !important;
  gap: .6rem !important;
}

.admin-products-page--compact .admin-products-toolbar--compact .admin-products-reset {
  width: 100% !important;
  min-width: 0 !important;
  padding-inline: .65rem !important;
  white-space: nowrap !important;
}

@media (min-width: 981px) and (max-width: 1500px) {
  .admin-products-page--compact .admin-products-table--overview > .admin-products-head,
  .admin-products-page--compact .admin-products-table--overview > .admin-products-row--overview {
    grid-template-columns:
      36px
      62px
      minmax(160px, 1.25fr)
      minmax(112px, .78fr)
      minmax(112px, .76fr)
      minmax(128px, .8fr)
      minmax(92px, .58fr)
      minmax(138px, .75fr)
      minmax(170px, .92fr) !important;
    gap: 8px !important;
    min-width: 1090px !important;
  }

  .admin-products-page--compact .admin-products-table--overview > .admin-products-head {
    padding-inline: 12px !important;
    font-size: .68rem !important;
    letter-spacing: .02em !important;
  }

  .admin-products-page--compact .admin-products-table--overview > .admin-products-head span:nth-child(9),
  .admin-products-page--compact .admin-products-table--overview .cell-status {
    display: none !important;
  }

  .admin-products-page--compact .admin-products-table--overview > .admin-products-row--overview {
    padding: 14px 12px !important;
  }

  .admin-products-page--compact .admin-products-table--overview .admin-product-thumb-link {
    width: 54px !important;
    height: 54px !important;
  }

  .admin-products-page--compact .admin-products-table--overview .admin-product-name-link {
    font-size: .93rem !important;
  }

  .admin-products-page--compact .admin-products-table--overview .admin-chip {
    font-size: .62rem !important;
    padding-inline: .36rem !important;
  }

  .admin-products-page--compact .admin-products-table--overview .cell-sku strong,
  .admin-products-page--compact .admin-products-table--overview .cell-price strong,
  .admin-products-page--compact .admin-products-table--overview .cell-stock strong,
  .admin-products-page--compact .admin-products-table--overview .admin-type-badge,
  .admin-products-page--compact .admin-products-table--overview .admin-category-note {
    font-size: .78rem !important;
    line-height: 1.22 !important;
  }

  .admin-products-page--compact .admin-products-table--overview .cell-actions {
    grid-template-columns: 1fr 1fr !important;
    gap: .32rem !important;
  }

  .admin-products-page--compact .admin-products-table--overview .cell-actions .btn {
    min-height: 32px !important;
    padding: .38rem .45rem !important;
    font-size: .72rem !important;
  }
}

@media (min-width: 981px) and (max-width: 1280px) {
  .admin-products-page--compact .admin-products-toolbar--compact {
    grid-template-columns: repeat(4, minmax(150px, 1fr)) !important;
  }

  .admin-products-page--compact .admin-products-toolbar--compact .admin-products-reset {
    grid-column: span 2 !important;
  }
}

/* Backend article overview: fit the full table into the viewport. */
.admin-products-page--compact .admin-products-wrap {
  width: min(1480px, calc(100vw - 48px)) !important;
  max-width: min(1480px, calc(100vw - 48px)) !important;
  margin-inline: auto !important;
}

.admin-products-page--compact .admin-products-hero--compact {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: start !important;
}

.admin-products-page--compact .admin-products-hero h1 {
  max-width: 100% !important;
  font-size: clamp(2rem, 2.65vw, 2.75rem) !important;
}

.admin-products-page--compact .admin-products-actions {
  max-width: 100% !important;
}

.admin-products-page--compact .admin-products-toolbar--compact {
  grid-template-columns: repeat(auto-fit, minmax(145px, 1fr)) !important;
}

@media (min-width: 981px) {
  .admin-products-page--compact .admin-products-table--overview {
    overflow-x: hidden !important;
  }

  .admin-products-page--compact .admin-products-table--overview > .admin-products-head,
  .admin-products-page--compact .admin-products-table--overview > .admin-products-row--overview {
    width: 100% !important;
    min-width: 0 !important;
    grid-template-columns:
      34px
      58px
      minmax(170px, 1.2fr)
      minmax(104px, .66fr)
      minmax(112px, .66fr)
      minmax(122px, .74fr)
      minmax(92px, .54fr)
      minmax(134px, .72fr)
      minmax(160px, .84fr) !important;
    gap: 9px !important;
  }

  .admin-products-page--compact .admin-products-table--overview > .admin-products-head span:nth-child(9),
  .admin-products-page--compact .admin-products-table--overview .cell-status {
    display: none !important;
  }

  .admin-products-page--compact .admin-products-table--overview > .admin-products-head {
    padding-inline: 12px !important;
    font-size: .66rem !important;
  }

  .admin-products-page--compact .admin-products-table--overview > .admin-products-row--overview {
    padding: 14px 12px !important;
  }

  .admin-products-page--compact .admin-products-table--overview .admin-product-thumb-link {
    width: 52px !important;
    height: 52px !important;
  }

  .admin-products-page--compact .admin-products-table--overview .admin-product-name-link {
    font-size: .9rem !important;
  }

  .admin-products-page--compact .admin-products-table--overview .admin-chip {
    min-height: 18px !important;
    padding: .08rem .32rem !important;
    font-size: .6rem !important;
  }

  .admin-products-page--compact .admin-products-table--overview .cell-sku strong,
  .admin-products-page--compact .admin-products-table--overview .cell-price strong,
  .admin-products-page--compact .admin-products-table--overview .cell-stock strong,
  .admin-products-page--compact .admin-products-table--overview .admin-type-badge,
  .admin-products-page--compact .admin-products-table--overview .admin-category-note {
    font-size: .76rem !important;
    line-height: 1.2 !important;
    overflow-wrap: anywhere !important;
  }

  .admin-products-page--compact .admin-products-table--overview .cell-actions {
    grid-template-columns: 1fr 1fr !important;
    gap: .3rem !important;
  }

  .admin-products-page--compact .admin-products-table--overview .cell-actions .btn {
    min-height: 31px !important;
    padding: .34rem .38rem !important;
    font-size: .68rem !important;
  }
}

@media (min-width: 981px) and (max-width: 1280px) {
  .admin-products-page--compact .admin-products-hero--compact {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .admin-products-page--compact .admin-products-actions {
    justify-content: flex-start !important;
  }

  .admin-products-page--compact .admin-products-table--overview > .admin-products-head,
  .admin-products-page--compact .admin-products-table--overview > .admin-products-row--overview {
    grid-template-columns:
      32px
      54px
      minmax(150px, 1.25fr)
      minmax(96px, .72fr)
      minmax(116px, .78fr)
      minmax(86px, .56fr)
      minmax(126px, .72fr)
      minmax(148px, .86fr) !important;
  }

  .admin-products-page--compact .admin-products-table--overview > .admin-products-head span:nth-child(5),
  .admin-products-page--compact .admin-products-table--overview .cell-category {
    display: none !important;
  }
}

/* Final backend article overview viewport lock: no horizontal page overflow. */
body:has(.admin-products-page--compact) {
  overflow-x: hidden !important;
}

.admin-products-page--compact {
  max-width: 100vw !important;
  overflow-x: clip !important;
  box-sizing: border-box !important;
  padding-inline: clamp(12px, 1.35vw, 22px) !important;
}

.admin-products-page--compact *,
.admin-products-page--compact *::before,
.admin-products-page--compact *::after {
  box-sizing: border-box !important;
}

.admin-products-page--compact .admin-products-wrap {
  width: min(100%, calc(100vw - clamp(24px, 2.7vw, 44px))) !important;
  max-width: 1360px !important;
  min-width: 0 !important;
  margin-inline: auto !important;
  padding-inline: 0 !important;
  overflow: visible !important;
}

.admin-products-page--compact .admin-products-hero--compact {
  grid-template-columns: minmax(0, 1fr) !important;
  gap: 18px !important;
}

.admin-products-page--compact .admin-products-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  min-width: 0 !important;
}

.admin-products-page--compact .admin-products-actions .btn {
  min-width: 0 !important;
  white-space: nowrap !important;
}

.admin-products-page--compact .admin-products-tabs,
.admin-products-page--compact .admin-products-toolbar--compact,
.admin-products-page--compact .admin-products-bulk--compact,
.admin-products-page--compact .admin-products-table--overview {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
}

.admin-products-page--compact .admin-products-toolbar--compact {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)) !important;
  gap: 10px !important;
  overflow: hidden !important;
}

.admin-products-page--compact .admin-products-toolbar--compact label,
.admin-products-page--compact .admin-products-toolbar--compact input,
.admin-products-page--compact .admin-products-toolbar--compact select,
.admin-products-page--compact .admin-products-toolbar--compact button {
  min-width: 0 !important;
  max-width: 100% !important;
}

.admin-products-page--compact .admin-products-reset {
  width: 100% !important;
}

.admin-products-page--compact .admin-products-bulk--compact {
  display: grid !important;
  grid-template-columns: max-content minmax(0, 1fr) auto max-content !important;
  gap: 10px !important;
  align-items: center !important;
  overflow: hidden !important;
}

.admin-products-page--compact .admin-products-bulk--compact select {
  min-width: 0 !important;
  width: 100% !important;
}

@media (min-width: 981px) {
  .admin-products-page--compact .admin-products-table--overview {
    overflow-x: hidden !important;
  }

  .admin-products-page--compact .admin-products-table--overview > .admin-products-head,
  .admin-products-page--compact .admin-products-table--overview > .admin-products-row--overview {
    width: 100% !important;
    min-width: 0 !important;
    grid-template-columns:
      34px
      56px
      minmax(190px, 1.55fr)
      minmax(110px, .82fr)
      minmax(86px, .58fr)
      minmax(132px, .86fr)
      minmax(132px, .78fr) !important;
    gap: 8px !important;
    padding-inline: 12px !important;
  }

  .admin-products-page--compact .admin-products-table--overview > .admin-products-head span:nth-child(5),
  .admin-products-page--compact .admin-products-table--overview > .admin-products-head span:nth-child(6),
  .admin-products-page--compact .admin-products-table--overview > .admin-products-head span:nth-child(9),
  .admin-products-page--compact .admin-products-table--overview .cell-category,
  .admin-products-page--compact .admin-products-table--overview .cell-type,
  .admin-products-page--compact .admin-products-table--overview .cell-status {
    display: none !important;
  }

  .admin-products-page--compact .admin-products-table--overview .cell-actions {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 6px !important;
    align-items: center !important;
    position: relative !important;
  }

  .admin-products-page--compact .admin-products-table--overview .cell-actions > .btn,
  .admin-products-page--compact .admin-products-table--overview .cell-actions summary.btn {
    min-height: 32px !important;
    padding: .38rem .5rem !important;
    font-size: .72rem !important;
    white-space: nowrap !important;
  }
}

.admin-row-actions-menu {
  position: relative !important;
  min-width: 0 !important;
}

.admin-row-actions-menu > summary {
  list-style: none !important;
  cursor: pointer !important;
}

.admin-row-actions-menu > summary::-webkit-details-marker {
  display: none !important;
}

.admin-row-actions-popover {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: 6px !important;
  min-width: 148px !important;
  margin-top: 6px !important;
  padding: 8px !important;
  border: 1px solid rgba(15, 23, 42, .12) !important;
  border-radius: 12px !important;
  background: #fff !important;
  box-shadow: 0 18px 36px rgba(15, 23, 42, .14) !important;
}

.admin-row-actions-popover form {
  margin: 0 !important;
}

.admin-row-actions-popover .btn {
  width: 100% !important;
  justify-content: center !important;
}

@media (max-width: 980px) {
  .admin-products-page--compact .admin-products-wrap {
    width: min(100%, calc(100vw - 24px)) !important;
  }

  .admin-products-page--compact .admin-products-bulk--compact {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .admin-products-page--compact .admin-products-table--overview .cell-actions {
    grid-template-columns: minmax(0, 1fr) auto !important;
  }
}

/* Superadmin global article list: dedicated, non-overlapping grid. */
.superadmin-articles-page .admin-products-wrap {
  width: min(100%, calc(100vw - 40px)) !important;
  max-width: 1500px !important;
}

.superadmin-articles-page .superadmin-article-table {
  overflow-x: hidden !important;
}

.superadmin-articles-page .superadmin-article-table > .admin-products-head,
.superadmin-articles-page .superadmin-article-table > .superadmin-article-row {
  display: grid !important;
  width: 100% !important;
  min-width: 0 !important;
  grid-template-columns:
    72px
    minmax(210px, 1.35fr)
    minmax(140px, .78fr)
    minmax(145px, .82fr)
    minmax(96px, .54fr)
    minmax(150px, .78fr)
    minmax(120px, .62fr)
    minmax(116px, .56fr) !important;
  gap: 12px !important;
  align-items: center !important;
}

.superadmin-articles-page .superadmin-article-table > .admin-products-head span,
.superadmin-articles-page .superadmin-article-table .cell-thumb,
.superadmin-articles-page .superadmin-article-table .cell-main,
.superadmin-articles-page .superadmin-article-table .cell-manufacturer,
.superadmin-articles-page .superadmin-article-table .cell-type,
.superadmin-articles-page .superadmin-article-table .cell-price,
.superadmin-articles-page .superadmin-article-table .cell-stock,
.superadmin-articles-page .superadmin-article-table .cell-status,
.superadmin-articles-page .superadmin-article-table .cell-actions {
  display: flex !important;
  min-width: 0 !important;
}

.superadmin-articles-page .superadmin-article-table .cell-main,
.superadmin-articles-page .superadmin-article-table .cell-manufacturer,
.superadmin-articles-page .superadmin-article-table .cell-type,
.superadmin-articles-page .superadmin-article-table .cell-price,
.superadmin-articles-page .superadmin-article-table .cell-stock,
.superadmin-articles-page .superadmin-article-table .cell-status {
  flex-direction: column !important;
  align-items: flex-start !important;
  justify-content: center !important;
  gap: 4px !important;
  overflow-wrap: anywhere !important;
}

.superadmin-articles-page .superadmin-article-table .cell-thumb img {
  width: 58px !important;
  height: 58px !important;
  object-fit: contain !important;
}

.superadmin-articles-page .superadmin-article-table .cell-actions {
  align-items: center !important;
  justify-content: flex-end !important;
}

.superadmin-articles-page .superadmin-article-table .cell-actions .btn {
  width: auto !important;
  min-width: 96px !important;
  padding-inline: .7rem !important;
}

.manufacturer-mini {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  max-width: 100%;
}

.manufacturer-mini img {
  width: 36px;
  height: 28px;
  object-fit: contain;
  flex: 0 0 auto;
  border: 1px solid rgba(15, 23, 42, .10);
  border-radius: 8px;
  background: #fff;
}

.manufacturer-mini strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-muted {
  color: #64748b;
  font-weight: 800;
}

.article-manufacturer-card .manufacturer-admin-grid {
  display: grid;
  grid-template-columns: minmax(160px, 220px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.article-manufacturer-card .manufacturer-current {
  display: grid;
  gap: 10px;
  place-items: center;
  min-height: 160px;
  padding: 18px;
  border: 1px solid rgba(15, 23, 42, .10);
  border-radius: 16px;
  background: #f8fafc;
  text-align: center;
}

.article-manufacturer-card .manufacturer-current img {
  width: 140px;
  max-width: 100%;
  max-height: 96px;
  object-fit: contain;
  background: #fff;
  border-radius: 12px;
  padding: 10px;
}

.article-manufacturer-card .manufacturer-current span {
  color: #64748b;
  font-weight: 900;
}

.article-manufacturer-card .manufacturer-admin-fields {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.article-attribute-field {
  display: grid;
  gap: .5rem;
  min-width: 0;
}

.article-form-grid .article-attribute-field--wide,
.article-form-grid .article-attribute-new {
  grid-column: 1 / -1;
}

.article-attribute-field > span {
  color: #475569;
  font-size: .78rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .03em;
}

.article-attribute-options {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  min-width: 0;
}

.article-attribute-options--grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

.article-attribute-options .article-checkbox {
  min-height: 36px;
  margin: 0;
  padding: .45rem .6rem;
  border: 1px solid rgba(15, 23, 42, .10);
  border-radius: 10px;
  background: #f8fafc;
}

@media (max-width: 1180px) and (min-width: 981px) {
  .superadmin-articles-page .superadmin-article-table > .admin-products-head,
  .superadmin-articles-page .superadmin-article-table > .superadmin-article-row {
    grid-template-columns:
      64px
      minmax(190px, 1.5fr)
      minmax(126px, .8fr)
      minmax(94px, .58fr)
      minmax(140px, .85fr)
      minmax(112px, .65fr)
      minmax(104px, .58fr) !important;
  }

  .superadmin-articles-page .superadmin-article-table > .admin-products-head span:nth-child(4),
  .superadmin-articles-page .superadmin-article-table .cell-type {
    display: none !important;
  }
}

@media (max-width: 980px) {
  .superadmin-articles-page .admin-products-wrap {
    width: min(100%, calc(100vw - 24px)) !important;
  }

  .superadmin-articles-page .superadmin-article-table > .admin-products-head {
    display: none !important;
  }

  .superadmin-articles-page .superadmin-article-table > .superadmin-article-row {
    display: grid !important;
    grid-template-columns: 64px minmax(0, 1fr);
    grid-template-areas:
      "thumb main"
      "manufacturer manufacturer"
      "type type"
      "price stock"
      "status actions";
    gap: 10px !important;
    padding: 14px !important;
  }

  .superadmin-articles-page .superadmin-article-table .cell-thumb {
    grid-area: thumb;
  }

  .superadmin-articles-page .superadmin-article-table .cell-main {
    grid-area: main;
  }

  .superadmin-articles-page .superadmin-article-table .cell-manufacturer {
    grid-area: manufacturer;
  }

  .superadmin-articles-page .superadmin-article-table .cell-type {
    grid-area: type;
    display: flex !important;
  }

  .superadmin-articles-page .superadmin-article-table .cell-price {
    grid-area: price;
  }

  .superadmin-articles-page .superadmin-article-table .cell-stock {
    grid-area: stock;
  }

  .superadmin-articles-page .superadmin-article-table .cell-status {
    grid-area: status;
    display: flex !important;
  }

  .superadmin-articles-page .superadmin-article-table .cell-actions {
    grid-area: actions;
    justify-content: flex-end !important;
  }

  .article-manufacturer-card .manufacturer-admin-grid,
  .article-manufacturer-card .manufacturer-admin-fields {
    grid-template-columns: minmax(0, 1fr);
  }
}
