/* RAJ PERFUMES Optimized CSS Bundle
   Generated from css.zip. Use this single file instead of loading many page CSS files. */

@import url("https://fonts.googleapis.com/css2?family=Cairo:wght@400;500;600;700;800;900;1000&display=swap");


/* ===== cairo_font.css ===== */

body,
button,
input,
select,
textarea,
.primary-btn,
.secondary-btn,
.btn-dark,
.btn-outline,
.add-bag-btn,
.header-icons,
.header-tools,
.harrods-account,
.harrods-country,
.harrods-nav,
.main-nav,
.luxury-nav,
.search-box,
.header-search,
.filter-block,
.filter-group,
.listing-toolbar,
.results-toolbar,
.product-info p,
.tile-body p,
.cart-line-info small,
.summary-note,
.empty-state,
.footer-grid,
.footer-columns,
.reef-footer,
.luxury-footer {
  font-family: "Cairo", Arial, Tahoma, sans-serif !important;
}

.hero-content h1,
.hero-inner h1,
.section-title h2,
.section-heading h2,
.category-banner h1,
.plp-intro h1,
.detail-content h1,
.pdp-info h1,
.editorial-card h2,
.product-info h3,
.tile-body h3,
.cart-line-info h3 {
  font-family: "Cairo", Georgia, "Times New Roman", serif !important;
  font-weight: 600;
}

.logo-fallback,
.luxury-logo strong,
.harrods-logo span {
  font-family: "Cairo", Georgia, "Times New Roman", serif !important;
  font-weight: 700;
}

body {
  letter-spacing: 0;
}

input,
textarea,
select {
  font-weight: 500;
}

.harrods-nav,
.main-nav,
.luxury-nav {
  font-weight: 700;
}

.product-brand,
.tile-brand,
.price-line strong,
.tile-footer strong {
  font-family: "Cairo", Arial, Tahoma, sans-serif !important;
}


/* ===== store.css ===== */

:root {
  /* RAJ PERFUMES final identity */
  --lux-bg: #f7f3ea;
  --lux-paper: #ffffff;
  --lux-ink: #161a12;
  --lux-soft-ink: #2b2f26;
  --lux-muted: #6f7668;

  --lux-line: #d8dec9;
  --lux-cream: #eafada;
  --lux-light: #fbf8f1;
  --lux-mist: #eafada;

  --lux-dark: #2b3b1b;
  --lux-green: #2b3b1b;
  --lux-forest: #1f2d16;
  --lux-deep-olive: #6d8c4e;
  --lux-olive: #92b66e;
  --lux-soft-olive: #c9ddb6;

  --lux-gold: #c8a24a;
  --lux-gold-soft: #e8d18a;
  --lux-gold-pale: #f3e4b3;

  --lux-blush: #fbe3ee;
  --lux-crimson: #a43163;
  --lux-wine: #870c46;
  --lux-bordeaux: #3f0d24;

  --lux-danger: #b83b34;
  --lux-success: #1c7a4a;

  --lux-shadow: rgba(22, 34, 16, 0.12);
  --lux-shadow-strong: rgba(22, 34, 16, 0.22);

  /* Old RAJ palette mapped to new identity */
  --raj-gold: var(--lux-gold);
  --raj-navy: #101827;
  --raj-ivory: var(--lux-bg);
  --raj-oud: #4A2F24;
  --raj-palm: var(--lux-dark);

  /* Reef compatibility */
  --reef-bg: var(--lux-bg);
  --reef-paper: var(--lux-paper);
  --reef-ink: var(--lux-ink);
  --reef-muted: var(--lux-muted);
  --reef-line: var(--lux-line);
  --reef-brown: var(--lux-dark);
  --reef-tan: var(--lux-gold);
  --reef-soft: var(--lux-cream);
  --reef-cream: var(--lux-light);
  --reef-dark: var(--lux-dark);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: var(--lux-bg);
  color: var(--lux-ink);
  font-family: Georgia, "Times New Roman", serif;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

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

button,
input,
select,
textarea {
  font-family: Arial, Tahoma, sans-serif;
}

@media (max-width: 768px) {

  html,
  body {
    padding-top: 0 !important;
    scroll-padding-top: 0 !important;
  }

header,
.site-header,
.public-header,
.main-header,
.lux-header,
.kp-header,
.harrods-header,
.store-header,
.harrods-top,
.harrods-main,
.harrods-main-row,
.harrods-tools-row,
.reef-header,
.luxury-header,
.announcement-bar,
.luxury-topbar,
.kp-announcement,
.harrods-promo,
.top-promo {
  position: relative !important;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
}

.harrods-header,
.site-header,
.public-header,
.main-header,
.kp-header,
.store-header,
.reef-header,
.luxury-header {
  z-index: 20 !important;
}

/* Remove any old fixed-header offset */
html,
body {
  padding-top: 0 !important;
  scroll-padding-top: 0 !important;
}

@media (max-width: 768px) {

  header,
  .site-header,
  .public-header,
  .main-header,
  .lux-header,
  .kp-header,
  .harrods-header,
  .store-header,
  .harrods-top,
  .harrods-main {
    position: relative !important;
    top: auto !important;
    z-index: 20 !important;
  }

  .harrods-main {
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 12px 20px 10px !important;
    min-height: auto !important;
  }

  .harrods-left,
  .harrods-location,
  .header-left {
    justify-self: start !important;
    grid-column: 1 !important;
  }

  .harrods-logo,
  .site-logo,
  .kp-logo {
    justify-self: center !important;
    grid-column: 2 !important;
    min-height: auto !important;
  }

  .harrods-logo img,
  .site-logo img,
  .kp-logo img,
  header img {
    max-height: 74px !important;
    width: auto !important;
    object-fit: contain !important;
  }

  .harrods-icons,
  .header-icons,
  .kp-header-icons {
    justify-self: end !important;
    grid-column: 3 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 12px !important;
    width: auto !important;
  }

  .kp-mobile-menu-btn,
  #kpMobileMenuOpen {
    grid-column: 3 !important;
    justify-self: end !important;
    margin-left: auto !important;
    margin-right: 0 !important;
    order: 99 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 64px !important;
    min-width: 64px !important;
    height: 54px !important;
    border: 1px solid #a88961 !important;
    background: #ffffff !important;
    color: #173f35 !important;
  }

  .harrods-main > .kp-mobile-menu-btn,
  .harrods-main > #kpMobileMenuOpen {
    grid-column: 3 !important;
    justify-self: end !important;
  }

  .harrods-search,
  .header-search,
  .kp-search {
    padding: 8px 20px 14px !important;
  }

  .harrods-search form,
  .header-search form,
  .kp-search form {
    display: grid !important;
    grid-template-columns: 1fr auto !important;
    align-items: center !important;
    border-bottom: 1px solid #173f35 !important;
  }

  .harrods-search input,
  .header-search input,
  .kp-search input {
    min-height: 40px !important;
    border: 0 !important;
    background: transparent !important;
  }

  .harrods-search button,
  .header-search button,
  .kp-search button {
    border: 0 !important;
    background: transparent !important;
    color: #173f35 !important;
    font-weight: 900 !important;
  }
}

@media (max-width: 430px) {
  .harrods-main {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .kp-mobile-menu-btn,
  #kpMobileMenuOpen {
    width: 58px !important;
    min-width: 58px !important;
    height: 50px !important;
  }

  .harrods-logo img,
  .site-logo img,
  .kp-logo img {
    max-height: 68px !important;
  }
}


  .harrods-search,
  .header-search,
  .kp-search {
    padding-top: 6px !important;
    padding-bottom: 10px !important;
  }

  .harrods-search input,
  .header-search input,
  .kp-search input {
    min-height: 38px !important;
  }

  .top-promo,
  .announcement-bar,
  .kp-announcement,
  .harrods-promo {
    position: relative !important;
    top: auto !important;
  }
}

.announcement-bar,
.luxury-topbar {
  height: 34px;
  background: #111;
  color: #fff;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 12px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

.luxury-topbar {
  gap: 34px;
}

.marquee {
  display: flex;
  gap: 34px;
  white-space: nowrap;
  animation: marquee 26s linear infinite;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.5px;
}

.marquee span::before {
  content: "• ";
  opacity: 0.7;
}

@keyframes marquee {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-45%);
  }
}

.harrods-header {
  background: #fff;
  border-bottom: 1px solid #ddd8cf;
  position: sticky;
  top: 0;
  z-index: 200;
  color: #111;
}

.harrods-offer-bar {
  min-height: 72px;
  background: #274c35;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 16px;
  font-weight: 700;
}

.harrods-offer-bar a {
  color: #fff;
  text-decoration: underline;
  text-underline-offset: 3px;
  font-weight: 800;
}

.harrods-gold-line {
  height: 4px;
  background: #b59a63;
}

.harrods-main-row {
  min-height: 124px;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: start;
  padding: 18px 8.5vw 0;
  background: #fff;
}

.harrods-country {
  display: flex;
  align-items: center;
  gap: 9px;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 16px;
  color: #111;
  padding-top: 2px;
}

.flag-dot {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  overflow: hidden;
  font-size: 24px;
}

.chevron {
  font-size: 24px;
  line-height: 1;
  transform: translateY(-2px);
}

.harrods-main-row {
  min-height: 160px !important;
  align-items: center !important;
  padding-top: 10px !important;
  padding-bottom: 0 !important;
}

.harrods-logo {
  min-height: 135px !important;
  width: 420px !important;
  max-width: 420px !important;
}

.harrods-logo img {
  width: 100% !important;
  max-width: 420px !important;
  max-height: 145px !important;
  height: auto !important;
  object-fit: contain !important;
}

.harrods-tools-row {
  margin-top: -10px !important;
}

.harrods-account {
  justify-self: end;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 16px;
  padding-top: 4px;
}

.harrods-account a {
  color: #000;
}

.harrods-tools-row {
  display: grid;
  grid-template-columns: minmax(120px, 1fr) auto minmax(120px, 1fr);
  align-items: center;
  padding: 0 8.5vw 28px;
  background: #fff;
}

.harrods-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 34px;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 21px;
  white-space: nowrap;
}

.harrods-nav a {
  color: #19202a;
}

.harrods-icons {
  justify-self: end;
  display: flex;
  align-items: center;
  gap: 28px;
}

.harrods-icons a {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  color: #aa855c;
}

.harrods-icons svg {
  width: 28px;
  height: 28px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.7;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.bag-icon b {
  position: absolute;
  right: -11px;
  top: 7px;
  min-width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #a88961;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 12px;
  font-weight: 800;
}

.harrods-mobile-search {
  display: none;
}

.luxury-topbar,
.luxury-header:not(.keep-old-header),
.announcement-bar,
.reef-header:not(.keep-old-header) {
  display: none;
}

main {
  background: #f7f5f1;
}

@media (max-width: 1380px) {
  .harrods-main-row,
  .harrods-tools-row {
    padding-left: 5vw;
    padding-right: 5vw;
  }

  .harrods-nav {
    gap: 22px;
    font-size: 18px;
  }
}

@media (max-width: 1100px) {
  .harrods-tools-row {
    grid-template-columns: 1fr;
    gap: 18px;
    padding-bottom: 18px;
  }

  .harrods-nav {
    justify-content: flex-start;
    overflow: auto;
    padding-bottom: 6px;
  }

  .harrods-icons {
    justify-self: end;
    position: absolute;
    right: 5vw;
    top: 156px;
  }
}

@media (max-width: 760px) {
  .harrods-offer-bar {
    min-height: 46px;
    font-size: 13px;
    padding: 0 12px;
    text-align: center;
  }

  .harrods-main-row {
    min-height: auto;
    grid-template-columns: 1fr auto 1fr;
    padding: 14px 4vw;
    align-items: center;
  }

  .harrods-country span:not(.flag-dot) {
    display: none;
  }

  .flag-dot {
    width: 24px;
    height: 24px;
    font-size: 21px;
  }

  .harrods-logo {
    min-height: auto;
  }

  .harrods-logo img {
    max-height: 58px;
    max-width: 170px;
  }

  .harrods-logo span {
    font-size: 31px;
  }

  .harrods-account {
    display: none;
  }

  .harrods-tools-row {
    padding: 0 4vw 12px;
  }

  .harrods-nav {
    gap: 20px;
    font-size: 14px;
    justify-content: flex-start;
    overflow: auto;
    padding: 6px 0 10px;
  }

  .harrods-icons {
    position: static;
    justify-self: end;
    gap: 16px;
    grid-row: 1;
    margin-bottom: 8px;
  }

  .harrods-icons a,
  .harrods-icons svg {
    width: 24px;
    height: 24px;
  }

  .harrods-mobile-search {
    display: grid;
    grid-template-columns: 1fr auto;
    margin: 0 4vw 14px;
    border-bottom: 1px solid #111;
  }

  .harrods-mobile-search input {
    border: 0;
    outline: 0;
    background: transparent;
    min-height: 38px;
  }

  .harrods-mobile-search button {
    border: 0;
    background: transparent;
    font-weight: 800;
    text-transform: uppercase;
  }
}

.reef-header,
.luxury-header {
  background: #fff;
  position: sticky;
  top: 0;
  z-index: 100;
  border-bottom: 1px solid var(--lux-line);
}

.header-top,
.header-primary {
  display: grid;
  grid-template-columns: 190px minmax(260px, 1fr) 260px 190px;
  gap: 22px;
  align-items: center;
  padding: 18px 5vw;
  background: #fff;
}

.menu-btn,
.menu-toggle {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 7px;
  width: auto;
  height: auto;
  min-height: 44px;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--lux-ink);
  cursor: pointer;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

.menu-toggle span {
  display: block;
  width: 18px;
  height: 1px;
  background: #111;
}

.menu-btn::after {
  content: "Menu";
  margin-left: 8px;
  font-size: 12px;
  letter-spacing: 0.8px;
}

.site-logo,
.luxury-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  justify-self: center;
}

.site-logo img,
.luxury-logo img {
  max-height: 66px;
  max-width: 230px;
  object-fit: contain;
}

.logo-fallback,
.luxury-logo strong {
  color: var(--lux-ink);
  background: transparent;
  width: auto;
  height: auto;
  border-radius: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 28px;
  font-weight: 400;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.search-box,
.header-search {
  display: grid;
  grid-template-columns: 1fr auto;
  max-width: 380px;
  border: 0;
  border-bottom: 1px solid #111;
  background: transparent;
  border-radius: 0;
  overflow: visible;
  justify-self: stretch;
}

.search-box input,
.header-search input {
  border: 0;
  outline: 0;
  min-height: 34px;
  padding: 0 8px 0 0;
  background: transparent;
  font-size: 13px;
  color: var(--lux-ink);
}

.search-box input::placeholder,
.header-search input::placeholder {
  color: #777;
}

.search-box button,
.header-search button {
  border: 0;
  background: transparent;
  color: var(--lux-ink);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  cursor: pointer;
  padding: 0 0 0 12px;
}

.header-icons,
.header-tools {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 18px;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.cart-button,
.bag-link {
  background: transparent;
  padding: 0;
  border-radius: 0;
}

.cart-button b,
.bag-link b {
  background: #111;
  color: #fff;
  border-radius: 50%;
  min-width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 5px;
  padding: 0;
  font-size: 11px;
}

.main-nav,
.luxury-nav {
  display: flex;
  justify-content: center;
  gap: 36px;
  padding: 12px 5vw;
  border-top: 1px solid var(--lux-line);
  background: #fff;
  overflow: auto;
  color: var(--lux-ink);
  font-family: Arial, Tahoma, sans-serif;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.6px;
}

.main-nav a,
.luxury-nav a {
  white-space: nowrap;
  color: var(--lux-ink);
}

.reef-hero,
.editorial-hero {
  min-height: 520px;
  margin: 0;
  border-radius: 0;
  background:
    linear-gradient(90deg, rgba(17, 17, 17, 0.68), rgba(17, 17, 17, 0.15)),
    linear-gradient(135deg, #d9d0c4, #f7f5f1);
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.hero-content,
.hero-inner {
  max-width: 760px;
  padding: 70px 5vw;
  color: #fff;
}

.hero-content span,
.hero-inner span,
.crumb,
.section-title span,
.section-heading span {
  font-family: Arial, Tahoma, sans-serif;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1.6px;
  font-weight: 800;
  color: var(--lux-gold);
}

.hero-content h1,
.hero-inner h1 {
  font-size: 64px;
  line-height: 1.03;
  margin: 14px 0;
  font-weight: 400;
}

.hero-content p,
.hero-inner p {
  max-width: 640px;
  font-size: 19px;
  line-height: 1.7;
  color: #fff;
}

.hero-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 26px;
}

.primary-btn,
.secondary-btn,
.btn-dark,
.btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 12px 22px;
  border-radius: 0;
  border: 1px solid #111;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  cursor: pointer;
  transition: 0.18s ease;
}

.primary-btn,
.btn-dark {
  background: #111;
  color: #fff;
}

.primary-btn:hover,
.btn-dark:hover {
  background: #333;
}

.secondary-btn,
.btn-outline {
  background: #fff;
  color: #111;
}

.secondary-btn:hover,
.btn-outline:hover {
  background: #111;
  color: #fff;
}

.primary-btn.full,
.secondary-btn.full,
.btn-dark.full,
.btn-outline.full {
  width: 100%;
  margin-top: 10px;
}

.section-wrap,
.content-wrap {
  padding: 42px 5vw;
}

.section-title,
.section-heading {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 22px;
}

.section-title h2,
.section-heading h2 {
  margin: 6px 0 0;
  font-size: 34px;
  font-weight: 400;
}

.section-heading a {
  color: #111;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  border-bottom: 1px solid #111;
}

.category-grid,
.category-row {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 0;
  border: 1px solid var(--lux-line);
  background: #fff;
}

.category-grid a,
.category-row a {
  min-height: 94px;
  display: flex;
  align-items: flex-end;
  padding: 22px 16px;
  border-right: 1px solid var(--lux-line);
  border-radius: 0;
  background: #fff;
  box-shadow: none;
  color: #111;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.category-grid a:last-child,
.category-row a:last-child {
  border-right: 0;
}

.split-editorial {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}

.editorial-card,
.brand-panel {
  background: #fff;
  border: 1px solid var(--lux-line);
  padding: 34px;
}

.editorial-card h2 {
  font-size: 40px;
  font-weight: 400;
  line-height: 1.15;
  margin: 10px 0;
}

.editorial-card p {
  color: var(--lux-muted);
  font-family: Arial, Tahoma, sans-serif;
  line-height: 1.6;
}

.reef-brand-strip,
.brand-grid,
.brand-list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.reef-brand-strip a,
.brand-card,
.brand-list a {
  background: #fff;
  border: 1px solid var(--lux-line);
  border-radius: 0;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  color: #111;
}

.brand-list a {
  border-width: 0 0 1px;
  padding: 12px 0;
}

.reef-brand-strip small,
.brand-card small,
.brand-list small {
  color: var(--lux-muted);
  font-family: Arial, Tahoma, sans-serif;
}

.category-banner,
.plp-intro {
  background: #fff;
  border-bottom: 1px solid var(--lux-line);
  padding: 36px 5vw;
}

.category-banner span,
.breadcrumb {
  color: var(--lux-muted);
  font-family: Arial, Tahoma, sans-serif;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.category-banner h1,
.plp-intro h1 {
  font-size: 44px;
  font-weight: 400;
  margin: 10px 0;
}

.category-banner p,
.plp-intro p {
  max-width: 760px;
  margin: 0;
  color: #333;
  font-size: 16px;
  line-height: 1.7;
}

.shop-shell,
.plp-layout {
  display: grid;
  grid-template-columns: 290px minmax(0, 1fr);
  gap: 28px;
  padding: 26px 5vw;
}

.reef-sidebar,
.filters-panel {
  background: #fff;
  border: 0;
  border-right: 1px solid var(--lux-line);
  border-radius: 0;
  padding: 0 22px 0 0;
  align-self: start;
  position: sticky;
  top: 132px;
  max-height: calc(100vh - 150px);
  overflow: auto;
}

.filter-block,
.filter-group {
  border-bottom: 1px solid var(--lux-line);
  padding: 0 0 18px;
  margin-bottom: 18px;
  display: grid;
  gap: 10px;
}

.filter-block h3,
.filter-group h3 {
  margin: 0 0 4px;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.filter-block a,
.filter-group a,
.brand-option,
.check-line {
  color: #222;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 13px;
}

.input,
select {
  width: 100%;
  min-height: 42px;
  border: 1px solid var(--lux-line);
  border-radius: 0;
  background: #fff;
  padding: 9px 10px;
  color: #111;
}

.brand-option,
.check-line {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 8px;
  align-items: center;
}

.brand-option small,
.check-line small {
  color: var(--lux-muted);
}

.listing-toolbar,
.results-toolbar {
  background: #fff;
  border: 0;
  border-bottom: 1px solid var(--lux-line);
  border-radius: 0;
  padding: 0 0 16px;
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: #111;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.sort-form,
.sort-box {
  display: flex;
  align-items: center;
  gap: 10px;
}

.sort-form label,
.sort-box label {
  color: var(--lux-muted);
  font-weight: 800;
}

.sort-form select,
.sort-box select {
  min-width: 210px;
}

.filter-trigger {
  display: none;
  border: 1px solid #111;
  background: #fff;
  padding: 10px 14px;
  text-transform: uppercase;
  font-weight: 800;
  cursor: pointer;
}

.reef-products-grid,
.product-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 28px 18px;
}

.reef-product-card,
.product-tile {
  background: #fff;
  border: 1px solid transparent;
  border-radius: 0;
  overflow: hidden;
  box-shadow: none;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  transition: 0.18s ease;
}

.reef-product-card:hover,
.product-tile:hover {
  transform: none;
  border-color: var(--lux-line);
  box-shadow: none;
}

.product-image-box,
.tile-image {
  height: 330px;
  background: #f5f3ef;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.product-image-box img,
.tile-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 26px;
}

.product-badge,
.tile-label {
  position: absolute;
  top: 14px;
  left: 14px;
  background: #111;
  color: #fff;
  border-radius: 0;
  padding: 6px 9px;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

.product-info,
.tile-body {
  padding: 15px 4px 0;
}

.product-brand,
.tile-brand {
  display: block;
  color: #111;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin-bottom: 6px;
}

.product-info h3,
.tile-body h3 {
  min-height: 44px;
  margin: 0 0 8px;
  font-size: 16px;
  line-height: 1.35;
  font-weight: 400;
}

.product-info p,
.tile-body p {
  margin: 0 0 10px;
  color: var(--lux-muted);
  font-family: Arial, Tahoma, sans-serif;
  font-size: 13px;
  line-height: 1.45;
}

.price-line,
.tile-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.price-line strong,
.tile-footer strong {
  color: #111;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 14px;
  font-weight: 800;
}

.price-line small,
.tile-footer small {
  color: var(--lux-muted);
  background: transparent;
  border-radius: 0;
  padding: 0;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 11px;
  font-weight: 400;
}

.pdp-layout,
.reef-product-detail {
  max-width: 1540px;
  margin: 0 auto;
  padding: 56px 7vw 70px !important;
  gap: 52px !important;
}

.pdp-gallery {
  min-width: 0;
}

.pdp-image-main,
.detail-image {
  width: 100%;
  min-height: 620px !important;
  background: #fff !important;
  border: 1px solid var(--lux-line, #ddd8cf);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.pdp-image-main img,
.detail-image img {
  width: 100% !important;
  height: 100% !important;
  max-height: 600px !important;
  object-fit: contain !important;
  object-position: center center !important;
  padding: 46px !important;
}

.pdp-info,
.detail-content {
  padding: 28px 0 0 !important;
  min-width: 0;
}

.pdp-info h1,
.detail-content h1 {
  max-width: 100%;
  overflow-wrap: anywhere;
}

.pdp-title-ar {
  padding-inline: 0;
  text-align: right;
}

.option-block,
.variant-panel,
.pdp-accordion {
  margin-top: 24px !important;
}

.purchase-box,
.buy-row {
  margin: 24px 0 !important;
}

.harrods-main-row {
  min-height: 155px !important;
  align-items: center !important;
}

.harrods-logo {
  width: 420px !important;
  max-width: 420px !important;
  min-height: 120px !important;
}

.harrods-logo img {
  width: 100% !important;
  max-width: 420px !important;
  max-height: 140px !important;
  height: auto !important;
  object-fit: contain !important;
}

@media (max-width: 980px) {
  .pdp-layout,
  .reef-product-detail {
    grid-template-columns: 1fr !important;
    padding: 42px 6vw 58px !important;
    gap: 32px !important;
  }

  .pdp-image-main,
  .detail-image {
    min-height: 520px !important;
  }

  .pdp-image-main img,
  .detail-image img {
    max-height: 500px !important;
    padding: 34px !important;
  }
}

@media (max-width: 620px) {
  body {
    overflow-x: hidden;
  }

  .pdp-layout,
  .reef-product-detail {
    width: 100%;
    max-width: 100%;
    padding: 28px 18px 44px !important;
    gap: 24px !important;
  }

  .pdp-gallery {
    width: 100%;
    max-width: 100%;
    display: block !important;
  }

  .pdp-image-main,
  .detail-image {
    width: 100% !important;
    min-height: auto !important;
    height: 430px !important;
    max-height: 430px !important;
    background: #fff !important;
    overflow: hidden !important;
  }

  .pdp-image-main img,
  .detail-image img {
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
    max-height: 400px !important;
    object-fit: contain !important;
    object-position: center center !important;
    padding: 24px !important;
  }

  .pdp-thumbs {
    display: none !important;
  }

  .pdp-info,
  .detail-content {
    width: 100%;
    padding: 22px 0 0 !important;
  }

  .pdp-breadcrumb,
  .crumb {
    font-size: 11px !important;
    line-height: 1.5;
  }

  .pdp-info h1,
  .detail-content h1 {
    font-size: 28px !important;
    line-height: 1.25 !important;
    margin: 10px 0 12px !important;
  }

  .pdp-title-ar {
    font-size: 22px !important;
    text-align: right;
    line-height: 1.45;
  }

  .pdp-price {
    font-size: 18px !important;
    margin: 10px 0 18px !important;
  }

  .arabic-seo-note {
    margin: 14px 0 !important;
    padding: 12px !important;
    font-size: 14px !important;
  }

  .size-options {
    grid-template-columns: 1fr !important;
  }

  .purchase-box,
  .buy-row {
    grid-template-columns: 82px 1fr !important;
    gap: 10px !important;
  }

  .purchase-box .input,
  .buy-row .input {
    min-height: 48px;
  }

  .add-bag-btn {
    min-height: 48px;
  }

  .pdp-accordion details {
    padding: 14px 0 !important;
  }

  
  .harrods-main-row {
    min-height: 92px !important;
    padding: 12px 18px !important;
  }

  .harrods-logo {
    width: 230px !important;
    max-width: 230px !important;
    min-height: 72px !important;
  }

  .harrods-logo img {
    max-width: 230px !important;
    max-height: 82px !important;
  }
}

@media (max-width: 390px) {
  .pdp-layout,
  .reef-product-detail {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .pdp-image-main,
  .detail-image {
    height: 380px !important;
    max-height: 380px !important;
  }

  .pdp-image-main img,
  .detail-image img {
    max-height: 360px !important;
    padding: 18px !important;
  }
}

.lead,
.pdp-lead {
  color: #333;
  font-size: 16px;
  line-height: 1.7;
}

.variant-panel,
.option-block {
  border-top: 1px solid var(--lux-line);
  padding-top: 18px;
  margin: 22px 0 0;
  display: grid;
  gap: 10px;
}

.option-block > span,
.variant-panel h3 {
  display: block;
  margin: 0 0 6px;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 12px;
  text-transform: uppercase;
  font-weight: 800;
}

.variant-row,
.size-options label {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items: center;
  background: #fff;
  border: 1px solid var(--lux-line);
  border-radius: 0;
  padding: 14px;
  cursor: pointer;
  font-family: Arial, Tahoma, sans-serif;
}

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

.size-options label {
  display: block;
}

.size-options input {
  margin-right: 6px;
}

.size-options strong {
  display: block;
  margin-top: 6px;
}

.variant-row small,
.size-options small {
  display: block;
  color: var(--lux-muted);
  font-size: 11px;
  margin-top: 4px;
}

.buy-row,
.purchase-box {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 12px;
  margin: 22px 0;
}

.add-bag-btn {
  min-height: 48px;
  border: 0;
  background: #111;
  color: #fff;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  cursor: pointer;
}

.description-panel,
.pdp-accordion {
  border-top: 1px solid var(--lux-line);
  margin-top: 24px;
  padding-top: 18px;
}

.pdp-accordion details {
  border-bottom: 1px solid var(--lux-line);
  padding: 16px 0;
}

.pdp-accordion summary {
  font-family: Arial, Tahoma, sans-serif;
  text-transform: uppercase;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
}

.pdp-accordion p,
.description-panel p {
  line-height: 1.7;
  color: #333;
}

.cart-page {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 24px;
  padding: 26px 5vw;
  align-items: start;
}

.cart-main,
.cart-summary-card {
  background: #fff;
  border: 1px solid var(--lux-line);
  border-radius: 0;
  padding: 18px;
  box-shadow: none;
}

.cart-summary-card {
  position: sticky;
  top: 132px;
}

.cart-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}

.cart-items-list {
  display: grid;
  gap: 12px;
}

.cart-line {
  display: grid;
  grid-template-columns: 110px minmax(0, 1fr) 120px 140px;
  gap: 14px;
  align-items: center;
  border: 1px solid var(--lux-line);
  border-radius: 0;
  padding: 12px;
  background: #fff;
}

.cart-line-img {
  height: 110px;
  background: #f5f3ef;
  border: 0;
  border-radius: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.cart-line-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 8px;
}

.cart-line-info span {
  display: block;
  color: #111;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.cart-line-info h3 {
  margin: 5px 0;
  font-size: 17px;
  line-height: 1.35;
  font-weight: 400;
}

.cart-line-info small {
  display: block;
  color: var(--lux-muted);
  font-family: Arial, Tahoma, sans-serif;
  margin-top: 3px;
}

.cart-qty {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.cart-qty button {
  width: 34px;
  height: 34px;
  border: 1px solid var(--lux-line);
  background: #fff;
  border-radius: 0;
  font-size: 20px;
  cursor: pointer;
  color: #111;
}

.cart-qty strong {
  min-width: 30px;
  text-align: center;
  font-family: Arial, Tahoma, sans-serif;
}

.cart-line-price {
  text-align: right;
}

.cart-line-price strong {
  display: block;
  color: #111;
  font-family: Arial, Tahoma, sans-serif;
  font-size: 18px;
}

.cart-line-price small {
  display: block;
  color: var(--lux-muted);
  font-family: Arial, Tahoma, sans-serif;
  margin: 4px 0 8px;
}

.cart-line-price button {
  border: 0;
  background: transparent;
  color: var(--lux-danger);
  font-weight: 800;
  cursor: pointer;
}

.summary-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid var(--lux-line);
}

.summary-row strong {
  font-size: 18px;
}

.summary-row.total {
  font-size: 22px;
  font-weight: 800;
}

.summary-note {
  background: var(--lux-light);
  color: var(--lux-muted);
  border: 1px solid var(--lux-line);
  border-radius: 0;
  padding: 12px;
  margin: 14px 0;
  line-height: 1.5;
  font-family: Arial, Tahoma, sans-serif;
}

.cart-warning-box {
  background: #fff8e6;
  border: 1px solid #efd18a;
  border-radius: 0;
  padding: 12px;
  margin-bottom: 14px;
  color: #755115;
  font-family: Arial, Tahoma, sans-serif;
  font-weight: 800;
  display: grid;
  gap: 6px;
}

.empty-state {
  background: #fff;
  border: 1px dashed var(--lux-line);
  border-radius: 0;
  padding: 36px;
  text-align: center;
  color: var(--lux-muted);
  font-family: Arial, Tahoma, sans-serif;
}

.reef-footer,
.luxury-footer {
  background: #111;
  color: #fff;
  margin-top: 44px;
  font-family: Arial, Tahoma, sans-serif;
}

.footer-grid,
.footer-columns {
  display: grid;
  grid-template-columns: 1.2fr repeat(3, 1fr);
  gap: 30px;
  padding: 38px 5vw;
}

.footer-grid h3,
.footer-columns h3,
.footer-grid h4,
.footer-columns h4 {
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

.reef-footer a,
.luxury-footer a,
.footer-columns p,
.footer-grid p {
  display: block;
  color: #d6d6d6;
  font-size: 13px;
  line-height: 1.7;
  margin-top: 8px;
}

.footer-bottom {
  border-top: 1px solid #333;
  padding: 14px 5vw;
  color: #aaa;
  font-size: 12px;
}

@media (max-width: 1180px) {
  .header-top,
  .header-primary {
    grid-template-columns: 80px 1fr 230px 160px;
  }

  .reef-products-grid,
  .product-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .category-grid,
  .category-row {
    grid-template-columns: repeat(3, 1fr);
  }

  .category-grid a,
  .category-row a {
    border-bottom: 1px solid var(--lux-line);
  }

  .reef-product-detail,
  .pdp-layout {
    grid-template-columns: 1fr;
  }

  .detail-image,
  .pdp-image-main {
    min-height: 520px;
  }
}

@media (max-width: 900px) {
  .announcement-bar,
  .luxury-topbar {
    display: none;
  }

  .header-top,
  .header-primary {
    grid-template-columns: 44px 1fr auto;
    gap: 12px;
    padding: 14px 4vw;
  }

  .search-box,
  .header-search {
    grid-column: 1 / -1;
    max-width: none;
    order: 2;
  }

  .site-logo,
  .luxury-logo {
    grid-column: 2;
  }

  .header-icons,
  .header-tools {
    grid-column: 3;
  }

  .header-icons a:first-child,
  .header-tools a:first-child {
    display: none;
  }

  .main-nav,
  .luxury-nav {
    justify-content: flex-start;
  }

  .shop-shell,
  .plp-layout {
    grid-template-columns: 1fr;
  }

  .reef-sidebar,
  .filters-panel {
    position: static;
    max-height: none;
    border-right: 0;
    padding-right: 0;
  }

  .filter-trigger {
    display: inline-block;
  }

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

  .split-editorial {
    grid-template-columns: 1fr;
  }

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

  .cart-page {
    grid-template-columns: 1fr;
  }

  .cart-summary-card {
    position: static;
  }

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

  .size-options {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 560px) {
  .site-logo img,
  .luxury-logo img {
    max-height: 54px;
    max-width: 180px;
  }

  .reef-hero,
  .editorial-hero {
    min-height: 420px;
  }

  .hero-content,
  .hero-inner {
    padding: 46px 4vw;
  }

  .hero-content h1,
  .hero-inner h1 {
    font-size: 38px;
  }

  .section-wrap,
  .content-wrap,
  .shop-shell,
  .plp-layout,
  .category-banner,
  .plp-intro,
  .reef-product-detail,
  .pdp-layout,
  .cart-page {
    padding-left: 4vw;
    padding-right: 4vw;
  }

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

  .reef-products-grid,
  .product-grid {
    gap: 22px 10px;
  }

  .product-image-box,
  .tile-image {
    height: 230px;
  }

  .product-info h3,
  .tile-body h3 {
    min-height: auto;
  }

  .listing-toolbar,
  .results-toolbar {
    flex-direction: column;
    align-items: flex-start;
  }

  .sort-form,
  .sort-box {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
  }

  .buy-row,
  .purchase-box {
    grid-template-columns: 1fr;
  }

  .detail-image,
  .pdp-image-main {
    min-height: 380px;
  }

  .detail-content h1,
  .pdp-info h1 {
    font-size: 30px;
  }

  .cart-line {
    grid-template-columns: 84px 1fr;
  }

  .cart-line-img {
    height: 84px;
  }

  .cart-qty {
    justify-content: flex-start;
  }

  .cart-line-price {
    text-align: left;
  }

  .cart-toolbar {
    flex-direction: column;
    align-items: flex-start;
  }

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

.product-name-ar {
  margin: -3px 0 8px;
  color: var(--lux-muted, #6f6f6f);
  font-family: "Cairo", Arial, Tahoma, sans-serif;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.5;
}

.pdp-title-ar {
  display: block;
  margin-top: 8px;
  color: var(--lux-muted, #6f6f6f);
  font-family: "Cairo", Arial, Tahoma, sans-serif;
  font-size: clamp(22px, 2.2vw, 30px);
  font-weight: 600;
  line-height: 1.35;
}

.arabic-seo-note {
  margin: 14px 0;
  padding: 12px 14px;
  background: var(--lux-light, #faf9f6);
  border: 1px solid var(--lux-line, #ddd8cf);
  color: var(--lux-ink, #111);
  font-family: "Cairo", Arial, Tahoma, sans-serif;
  font-size: 15px;
  font-weight: 600;
}

.pdp-accordion [lang="ar"],
.description-panel [lang="ar"] {
  font-family: "Cairo", Arial, Tahoma, sans-serif;
  font-size: 16px;
  line-height: 1.8;
}

.harrods-category-page {
  background: #fff;
  min-height: 70vh;
  border-top: 1px solid #e5e1da;
}

.harrods-breadcrumb {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 28px 3.2vw 10px;
  color: #222;
  font-family: "Cairo", Arial, Tahoma, sans-serif;
  font-size: 16px;
}

.harrods-breadcrumb a {
  color: #8a6a45;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.harrods-breadcrumb span {
  color: #333;
}

.harrods-plp-shell {
  display: grid;
  grid-template-columns: 380px minmax(0, 1fr);
  gap: 44px;
  padding: 0 3.2vw 40px;
  align-items: start;
}

.harrods-filter-sidebar {
  position: sticky;
  top: 188px;
  max-height: calc(100vh - 210px);
  overflow: auto;
  padding: 16px 28px 20px 0;
  background: #fff;
}

.harrods-filter-sidebar::-webkit-scrollbar {
  width: 0;
}

.filter-scroll-indicator {
  text-align: right;
  color: #d6d2cc;
  font-size: 18px;
  height: 20px;
}

.filter-section {
  border-bottom: 1px solid #ddd8cf;
}

.filter-heading {
  width: 100%;
  min-height: 77px;
  border: 0;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0;
  cursor: pointer;
  color: #3c3c3c;
  font-family: "Cairo", Arial, Tahoma, sans-serif;
  font-size: 17px;
  font-weight: 800;
  letter-spacing: 1.7px;
  text-transform: uppercase;
}

.filter-heading b {
  position: relative;
  width: 24px;
  height: 24px;
  flex: 0 0 24px;
}

.filter-heading b::before,
.filter-heading b::after {
  content: "";
  position: absolute;
  background: #a88961;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.filter-heading b::before {
  width: 23px;
  height: 1px;
}

.filter-heading b::after {
  width: 1px;
  height: 23px;
}

.filter-section.open .filter-heading b::after {
  display: none;
}

.filter-content {
  display: none;
  padding: 0 0 22px 14px;
  gap: 18px;
}

.filter-section.open .filter-content {
  display: grid;
}

.filter-content a {
  display: block;
  color: #262626;
  font-family: "Cairo", Arial, Tahoma, sans-serif;
  font-size: 18px;
  line-height: 1.25;
}

.filter-content a small {
  color: #222;
  font-size: 17px;
}

.filter-muted {
  color: #777;
  font-family: "Cairo", Arial, Tahoma, sans-serif;
}

.brand-filter-content {
  max-height: 360px;
  overflow: auto;
  padding-right: 6px;
}

.filter-radio {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  font-family: "Cairo", Arial, Tahoma, sans-serif;
  font-size: 15px;
  color: #222;
}

.filter-radio small {
  color: #777;
}

.harrods-results-area {
  min-width: 0;
}

.harrods-results-top {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 84px 0 58px;
}

.harrods-results-top h1 {
  margin: 0;
  color: #30323a;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 24px;
  font-weight: 400;
  text-align: center;
  white-space: nowrap;
}

.harrods-sort {
  justify-self: end;
}

.harrods-sort select {
  width: 200px;
  min-height: 42px;
  border: 1px solid #a88961;
  background: #fff;
  color: #8a6a45;
  padding: 0 42px 0 16px;
  border-radius: 0;
  font-family: "Cairo", Arial, Tahoma, sans-serif;
  font-size: 14px;
  font-weight: 800;
  text-transform: uppercase;
  appearance: auto;
}

.harrods-product-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  column-gap: 74px;
  row-gap: 62px;
}

.harrods-product-card {
  position: relative;
  text-align: center;
  background: #fff;
}

.wishlist-btn {
  position: absolute;
  right: 5%;
  top: 0;
  z-index: 3;
  width: 36px;
  height: 36px;
  border: 0;
  background: transparent;
  color: #a88961;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
}

.harrods-product-image {
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  height: 390px;
  background: #fff;
  margin-bottom: 28px;
}

.harrods-product-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center bottom;
  padding: 32px 22px 0;
}

.featured-label {
  position: absolute;
  top: 47px;
  left: 50%;
  transform: translateX(-50%);
  min-width: 88px;
  height: 26px;
  padding: 3px 14px;
  border: 1px solid #333;
  border-radius: 5px;
  background: #fff;
  color: #111;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: "Cairo", Arial, Tahoma, sans-serif;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  z-index: 2;
}

.harrods-product-info {
  display: block;
  color: #333;
}

.product-brand-name {
  display: block;
  color: #111;
  font-family: "Cairo", Arial, Tahoma, sans-serif;
  font-size: 16px;
  font-weight: 900;
  text-transform: uppercase;
  line-height: 1.2;
  margin-bottom: 8px;
}

.harrods-product-info h2 {
  max-width: 330px;
  min-height: 50px;
  margin: 0 auto 10px;
  color: #444;
  font-family: "Cairo", Arial, Tahoma, sans-serif;
  font-size: 18px;
  font-weight: 400;
  line-height: 1.35;
}

.harrods-product-info .product-name-ar {
  margin: 0 auto 8px;
  color: #777;
  font-family: "Cairo", Arial, Tahoma, sans-serif;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.4;
}

.harrods-product-info strong {
  display: block;
  color: #444;
  font-family: "Cairo", Arial, Tahoma, sans-serif;
  font-size: 16px;
  font-weight: 500;
}

.harrods-category-page .plp-layout,
.harrods-category-page .shop-shell,
.harrods-category-page .product-grid,
.harrods-category-page .reef-products-grid {
  display: none;
}

@media (max-width: 1300px) {
  .harrods-plp-shell {
    grid-template-columns: 300px minmax(0, 1fr);
    gap: 28px;
  }

  .harrods-product-grid {
    column-gap: 36px;
  }

  .harrods-product-image {
    height: 340px;
  }
}

@media (max-width: 980px) {
  .harrods-plp-shell {
    grid-template-columns: 1fr;
  }

  .harrods-filter-sidebar {
    position: static;
    max-height: none;
    padding-right: 0;
  }

  .filter-section:not(.open) .filter-content {
    display: none;
  }

  .harrods-results-top {
    padding: 28px 0;
    grid-template-columns: 1fr;
    gap: 16px;
    text-align: center;
  }

  .harrods-sort {
    justify-self: center;
  }

  .harrods-product-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 24px;
  }
}

@media (max-width: 620px) {
  .harrods-breadcrumb {
    padding: 20px 4vw 8px;
    font-size: 14px;
  }

  .harrods-plp-shell {
    padding: 0 4vw 30px;
  }

  .filter-heading {
    min-height: 58px;
    font-size: 14px;
  }

  .filter-content a {
    font-size: 15px;
  }

  .harrods-product-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 14px;
    row-gap: 38px;
  }

  .harrods-product-image {
    height: 240px;
    margin-bottom: 16px;
  }

  .harrods-product-image img {
    padding: 24px 8px 0;
  }

  .featured-label {
    top: 22px;
    min-width: 72px;
    height: 23px;
    font-size: 11px;
  }

  .wishlist-btn {
    right: 0;
    top: -6px;
    font-size: 24px;
  }

  .product-brand-name {
    font-size: 13px;
  }

  .harrods-product-info h2 {
    font-size: 14px;
    min-height: auto;
  }

  .harrods-product-info strong {
    font-size: 14px;
  }
}

.active-filter {
  color: #8a6a45 !important;
  font-weight: 900;
  text-decoration: underline;
  text-underline-offset: 4px;
}

.active-category-note {
  margin: -30px 0 34px;
  padding: 12px 16px;
  border: 1px solid #ddd8cf;
  background: #faf9f6;
  color: #333;
  font-family: "Cairo", Arial, Tahoma, sans-serif;
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
}

.active-category-note a {
  color: #8a6a45;
  text-decoration: underline;
  font-weight: 800;
}

@media (max-width: 620px) {
  .active-category-note {
    margin: 0 0 22px;
    flex-direction: column;
    align-items: flex-start;
  }
}

.logo {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  text-decoration: none;
}

.logo-icon {
  width: 46px;
  height: auto;
}

.logo-text {
  line-height: 1;
  text-align: left;
}

.logo-text .brand {
  font-family: Georgia, serif;
  font-size: 30px;
  font-weight: 700;
  color: #b18a5a;
}

.logo-text .sub {
  font-size: 12px;
  letter-spacing: 4px;
  color: #b18a5a;
  margin-top: 6px;
}

.page-title {
  max-width: 1480px;
  margin: 0 auto;
  padding: 34px 5vw 22px;
  background: transparent;
  border-bottom: 0;
}

.page-title > div {
  max-width: 100%;
}

.page-title span {
  display: block;
  margin-bottom: 28px;
  font-family: "Cairo", Arial, sans-serif;
  font-size: 14px;
  color: #333;
}

.page-title h1 {
  margin: 0 0 22px;
  font-family: "Cairo", Arial, sans-serif;
  font-size: 34px;
  font-weight: 800;
  color: #111;
}

.page-title p {
  margin: 0;
  font-family: "Cairo", Arial, sans-serif;
  font-size: 15px;
  color: #333;
}

.cart-page {
  max-width: 1480px;
  margin: 0 auto;
  padding: 24px 5vw 50px;
}

.harrods-account {
  display: flex;
  align-items: center;
  gap: 8px;
  justify-self: end;
  font-family: "Cairo", Arial, Tahoma, sans-serif;
  font-size: 16px;
  padding-top: 4px;
}

.harrods-account a {
  color: #000;
  font-weight: 700;
}

.account-separator {
  color: #a88961;
  font-weight: 700;
}

.order-success-page {
  min-height: 70vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f7f5f1;
  padding: 52px 5vw;
  font-family: "Cairo", Arial, sans-serif;
}

.order-success-card {
  width: 100%;
  max-width: 820px;
  background: #fff;
  border: 1px solid #ddd8cf;
  padding: 42px;
  text-align: center;
  box-shadow: 0 22px 60px rgba(0, 0, 0, 0.06);
}

.success-icon {
  width: 74px;
  height: 74px;
  border-radius: 50%;
  background: #173f35;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 18px;
  font-size: 38px;
  font-weight: 900;
}

.success-icon.warning {
  background: #b83b34;
}

.success-kicker {
  color: #8a6a45;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-weight: 900;
}

.order-success-card h1 {
  margin: 8px 0 10px;
  font-size: 38px;
  line-height: 1.18;
}

.order-success-card p {
  max-width: 620px;
  margin: 0 auto 22px;
  color: #555;
  line-height: 1.8;
}

.success-order-number {
  background: #faf9f6;
  border: 1px solid #ddd8cf;
  padding: 18px;
  margin: 24px auto;
  max-width: 430px;
}

.success-order-number span,
.success-summary-grid span {
  display: block;
  color: #777;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  font-weight: 900;
}

.success-order-number strong {
  display: block;
  color: #111;
  font-size: 24px;
  margin-top: 5px;
}

.success-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin: 24px 0;
}

.success-summary-grid div {
  border: 1px solid #ddd8cf;
  padding: 14px;
  background: #fff;
}

.success-summary-grid strong {
  display: block;
  color: #111;
  margin-top: 6px;
  font-size: 14px;
}

.success-note-box {
  text-align: left;
  background: #eef8f1;
  border: 1px solid #9fd0ad;
  padding: 16px;
  color: #1c6b3a;
  margin: 22px 0;
}

.success-note-box p {
  margin: 6px 0 0;
  color: #1c6b3a;
}

.success-actions {
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 20px;
}

.track-page {
  background: #f7f5f1;
  padding: 44px 5vw 76px;
  font-family: "Cairo", Arial, sans-serif;
}

.track-hero {
  max-width: 1260px;
  margin: 0 auto 26px;
  background: #173f35;
  color: #fff;
  padding: 38px;
}

.track-hero span {
  display: block;
  color: #d8c090;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 1.5px;
}

.track-hero h1 {
  margin: 8px 0 10px;
  font-size: 42px;
}

.track-hero p {
  color: rgba(255, 255, 255, 0.82);
  margin: 0;
  line-height: 1.8;
}

.track-layout {
  max-width: 1260px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 390px minmax(0, 1fr);
  gap: 24px;
  align-items: start;
}

.track-card,
.track-result {
  background: #fff;
  border: 1px solid #ddd8cf;
  padding: 26px;
}

.track-card h2,
.track-result h2,
.track-items h3 {
  margin: 0 0 16px;
}

.track-form {
  display: grid;
  gap: 10px;
}

.track-form label {
  font-size: 13px;
  font-weight: 900;
}

.track-form input {
  min-height: 48px;
  border: 1px solid #ddd8cf;
  padding: 10px 12px;
  font-family: "Cairo", Arial, sans-serif;
}

.track-form button {
  min-height: 52px;
  border: 0;
  background: #111;
  color: #fff;
  font-weight: 900;
  text-transform: uppercase;
  cursor: pointer;
  margin-top: 8px;
}

.track-error {
  background: #fff1f0;
  border: 1px solid #e3aaa5;
  color: #9f251c;
  padding: 12px;
  margin-bottom: 14px;
  font-weight: 800;
}

.track-order-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  border-bottom: 1px solid #eee;
  padding-bottom: 18px;
  margin-bottom: 20px;
}

.track-order-head span {
  display: block;
  color: #777;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.track-order-head h2 {
  margin: 4px 0 0;
}

.track-order-head > strong {
  background: #faf9f6;
  border: 1px solid #ddd8cf;
  padding: 8px 12px;
  text-transform: uppercase;
  font-size: 12px;
}

.track-steps {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  margin: 20px 0 24px;
}

.track-steps div {
  text-align: center;
}

.track-steps b {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid #ddd8cf;
  background: #fff;
  color: #777;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 8px;
}

.track-steps div.active b {
  background: #173f35;
  border-color: #173f35;
  color: #fff;
}

.track-steps span {
  display: block;
  font-size: 12px;
  font-weight: 800;
  color: #777;
}

.track-steps div.active span {
  color: #173f35;
}

.track-cancelled {
  background: #fff1f0;
  border: 1px solid #e3aaa5;
  color: #9f251c;
  padding: 14px;
  font-weight: 800;
  margin: 18px 0;
}

.track-info-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin: 18px 0 24px;
}

.track-info-grid div {
  border: 1px solid #ddd8cf;
  padding: 13px;
}

.track-info-grid span {
  display: block;
  color: #777;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.track-info-grid strong {
  display: block;
  margin-top: 5px;
}

.track-items {
  border-top: 1px solid #eee;
  padding-top: 20px;
}

.track-item {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 13px 0;
  border-bottom: 1px solid #eee;
}

.track-item strong,
.track-item b {
  color: #111;
}

.track-item span {
  display: block;
  color: #777;
  font-size: 12px;
  margin-top: 4px;
}

@media (max-width: 950px) {
  .track-layout {
    grid-template-columns: 1fr;
  }
  .success-summary-grid,
  .track-info-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 620px) {
  .order-success-page,
  .track-page {
    padding: 28px 16px 52px;
  }
  .order-success-card,
  .track-hero,
  .track-card,
  .track-result {
    padding: 24px 18px;
  }
  .order-success-card h1,
  .track-hero h1 {
    font-size: 30px;
  }
  .success-summary-grid,
  .track-info-grid,
  .track-steps {
    grid-template-columns: 1fr;
  }
  .track-order-head,
  .track-item {
    flex-direction: column;
  }
}

.secure-track-page{
  min-height:72vh;
  background:#f7f5f1;
  padding:52px 5vw 76px;
  font-family:"Cairo", Arial, sans-serif;
}

.secure-track-card{
  max-width:980px;
  margin:0 auto;
  background:#fff;
  border:1px solid #ddd8cf;
  padding:42px;
  text-align:center;
  box-shadow:0 22px 60px rgba(0,0,0,.06);
}

.secure-track-icon{
  width:72px;
  height:72px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#173f35;
  color:#fff;
  font-size:36px;
  font-weight:900;
  margin:0 auto 18px;
}

.secure-track-icon.danger{
  background:#b83b34;
}

.secure-track-card > span{
  display:block;
  color:#8a6a45;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:1.4px;
  font-weight:900;
}

.secure-track-card h1{
  margin:8px 0 10px;
  color:#111;
  font-size:38px;
  line-height:1.15;
}

.secure-track-card p{
  max-width:660px;
  margin:0 auto 20px;
  color:#555;
  line-height:1.8;
}

.secure-status-pill{
  display:inline-flex;
  min-height:38px;
  align-items:center;
  justify-content:center;
  padding:0 18px;
  background:#faf9f6;
  border:1px solid #ddd8cf;
  color:#111;
  font-weight:900;
  text-transform:uppercase;
  font-size:12px;
  margin:10px 0 24px;
}

.secure-track-steps{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:10px;
  margin:24px 0 30px;
}

.secure-track-steps div{
  text-align:center;
}

.secure-track-steps b{
  width:42px;
  height:42px;
  border-radius:50%;
  border:1px solid #ddd8cf;
  background:#fff;
  color:#777;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 8px;
}

.secure-track-steps div.active b{
  background:#173f35;
  color:#fff;
  border-color:#173f35;
}

.secure-track-steps span{
  display:block;
  color:#777;
  font-size:12px;
  font-weight:800;
}

.secure-track-steps div.active span{
  color:#173f35;
}

.secure-info-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin:22px 0;
}

.secure-info-grid div{
  border:1px solid #ddd8cf;
  padding:14px;
  text-align:left;
}

.secure-info-grid span{
  display:block;
  color:#777;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  margin-bottom:5px;
}

.secure-info-grid strong{
  color:#111;
}

.secure-track-items{
  margin-top:26px;
  text-align:left;
  border-top:1px solid #eee;
  padding-top:22px;
}

.secure-track-items h2{
  margin:0 0 12px;
  font-size:22px;
}

.secure-track-item{
  display:flex;
  justify-content:space-between;
  gap:14px;
  padding:13px 0;
  border-bottom:1px solid #eee;
}

.secure-track-item strong{
  color:#111;
}

.secure-track-item span{
  display:block;
  color:#777;
  margin-top:4px;
  font-size:12px;
}

.secure-track-item b{
  color:#111;
}

@media(max-width:760px){
  .secure-track-page{
    padding:30px 16px 54px;
  }

  .secure-track-card{
    padding:26px 18px;
  }

  .secure-track-card h1{
    font-size:28px;
  }

  .secure-track-steps,
  .secure-info-grid{
    grid-template-columns:1fr;
  }

  .secure-track-item{
    flex-direction:column;
  }
}

body {
  background:
    radial-gradient(circle at 8% 0%, rgba(234, 250, 218, 0.55), transparent 30%),
    linear-gradient(180deg, var(--lux-light), var(--lux-bg));
  color: var(--lux-ink);
}

main {
  background:
    radial-gradient(circle at 92% 6%, rgba(146, 182, 110, 0.12), transparent 26%),
    linear-gradient(180deg, var(--lux-light), var(--lux-bg));
}

::selection {
  background: var(--lux-dark);
  color: #fff;
}

.harrods-header {
  background: rgba(255, 255, 255, 0.96);
  border-bottom-color: var(--lux-line);
  color: var(--lux-ink);
  box-shadow: 0 10px 30px rgba(22, 34, 16, 0.045);
  backdrop-filter: blur(10px);
}

.harrods-offer-bar,
.announcement-bar,
.luxury-topbar {
  background:
    radial-gradient(circle at 20% 30%, rgba(146, 182, 110, 0.28), transparent 28%),
    linear-gradient(135deg, var(--lux-forest), var(--lux-dark));
  color: #fff;
}

.harrods-gold-line {
  background: linear-gradient(90deg, var(--lux-gold), var(--lux-gold-soft), var(--lux-gold));
}

.harrods-nav a,
.main-nav a,
.luxury-nav a,
.harrods-account a {
  color: var(--lux-ink);
  transition: color .18s ease, opacity .18s ease;
}

.harrods-nav a:hover,
.main-nav a:hover,
.luxury-nav a:hover,
.harrods-account a:hover {
  color: var(--lux-deep-olive);
}

.harrods-icons a,
.account-separator {
  color: var(--lux-gold);
}

.bag-icon b,
.cart-button b,
.bag-link b {
  background: var(--lux-dark);
  color: #fff;
}

.search-box,
.header-search,
.harrods-mobile-search {
  border-bottom-color: var(--lux-dark);
}

.search-box input,
.header-search input,
.harrods-mobile-search input {
  color: var(--lux-ink);
}

.search-box button,
.header-search button,
.harrods-mobile-search button {
  color: var(--lux-dark);
}

.primary-btn,
.btn-dark,
.add-bag-btn,
.track-form button {
  background: var(--lux-dark);
  border-color: var(--lux-dark);
  color: #fff;
}

.primary-btn:hover,
.btn-dark:hover,
.add-bag-btn:hover,
.track-form button:hover {
  background: var(--lux-deep-olive);
  border-color: var(--lux-deep-olive);
  color: #fff;
}

.secondary-btn,
.btn-outline {
  background: #fff;
  border-color: var(--lux-dark);
  color: var(--lux-dark);
}

.secondary-btn:hover,
.btn-outline:hover {
  background: var(--lux-dark);
  color: #fff;
}

.reef-hero,
.editorial-hero {
  background:
    linear-gradient(90deg, rgba(31, 45, 22, 0.82), rgba(43, 59, 27, 0.34)),
    radial-gradient(circle at 80% 20%, rgba(146, 182, 110, 0.42), transparent 30%),
    linear-gradient(135deg, var(--lux-dark), var(--lux-deep-olive));
}

.hero-content span,
.hero-inner span,
.crumb,
.section-title span,
.section-heading span,
.success-kicker,
.track-hero span {
  color: var(--lux-gold);
}

.category-grid,
.category-row,
.editorial-card,
.brand-panel,
.reef-brand-strip a,
.brand-card,
.brand-list a,
.category-banner,
.plp-intro,
.cart-main,
.cart-summary-card,
.track-card,
.track-result,
.order-success-card,
.success-order-number,
.success-summary-grid div,
.track-info-grid div {
  background: var(--lux-paper);
  border-color: var(--lux-line);
}

.category-grid a,
.category-row a {
  color: var(--lux-ink);
  background: linear-gradient(180deg, #fff, var(--lux-light));
}

.category-grid a:hover,
.category-row a:hover {
  color: var(--lux-dark);
  background: var(--lux-mist);
}

.harrods-category-page {
  background: linear-gradient(180deg, var(--lux-light), var(--lux-bg));
  border-top-color: var(--lux-line);
}

.harrods-breadcrumb a,
.section-heading a,
.active-category-note a,
.harrods-sort select {
  color: var(--lux-deep-olive);
}

.harrods-filter-sidebar,
.filters-panel,
.reef-sidebar {
  background: transparent;
}

.filter-heading {
  color: var(--lux-soft-ink);
}

.filter-heading b::before,
.filter-heading b::after {
  background: var(--lux-gold);
}

.filter-content a:hover,
.active-filter {
  color: var(--lux-deep-olive) !important;
}

.active-category-note {
  background: var(--lux-mist);
  border-color: var(--lux-line);
  color: var(--lux-dark);
}

.input,
select,
.track-form input {
  border-color: var(--lux-line);
  color: var(--lux-ink);
  background: #fff;
}

.input:focus,
select:focus,
.track-form input:focus {
  outline: none;
  border-color: var(--lux-deep-olive);
  box-shadow: 0 0 0 3px rgba(109, 140, 78, .16);
}

.reef-product-card,
.product-tile,
.harrods-product-card {
  background: var(--lux-paper);
}

.reef-product-card:hover,
.product-tile:hover,
.harrods-product-card:hover {
  border-color: var(--lux-line);
}

.product-image-box,
.tile-image,
.harrods-product-image,
.cart-line-img {
  background:
    radial-gradient(circle at 50% 20%, rgba(234, 250, 218, 0.65), transparent 40%),
    var(--lux-light);
}

.product-badge,
.tile-label,
.featured-label {
  background: var(--lux-dark);
  color: #fff;
  border-color: var(--lux-dark);
}

.product-brand,
.tile-brand,
.product-brand-name {
  color: var(--lux-dark);
}

.harrods-product-info h2,
.product-info h3,
.tile-body h3 {
  color: var(--lux-soft-ink);
}

.price-line strong,
.tile-footer strong,
.harrods-product-info strong,
.cart-line-price strong {
  color: var(--lux-dark);
}

.pdp-image-main,
.detail-image,
.variant-row,
.size-options label {
  background: var(--lux-paper) !important;
  border-color: var(--lux-line);
}

.lead,
.pdp-lead,
.pdp-accordion p,
.description-panel p,
.category-banner p,
.plp-intro p {
  color: var(--lux-soft-ink);
}

.arabic-seo-note,
.summary-note {
  background: var(--lux-mist);
  border-color: var(--lux-line);
  color: var(--lux-dark);
}

.cart-line,
.cart-summary-card,
.cart-main {
  border-color: var(--lux-line);
}

.cart-qty button {
  border-color: var(--lux-line);
  color: var(--lux-dark);
}

.cart-qty button:hover {
  background: var(--lux-mist);
}

.cart-warning-box {
  background: var(--lux-mist);
  border-color: var(--lux-soft-olive);
  color: var(--lux-dark);
}

.empty-state {
  background: #fff;
  border-color: var(--lux-line);
}

.success-icon,
.track-hero,
.track-steps div.active b {
  background:
    radial-gradient(circle at 15% 12%, rgba(146, 182, 110, 0.25), transparent 28%),
    linear-gradient(135deg, var(--lux-forest), var(--lux-dark));
}

.success-icon.warning {
  background: var(--lux-danger);
  color: #fff;
}

.track-cancelled {
  background: #fff1f0;
  border-color: rgba(184, 59, 52, .28);
  color: var(--lux-danger);
}

.success-note-box {
  background: var(--lux-mist);
  border-color: var(--lux-soft-olive);
  color: var(--lux-dark);
}

.success-note-box p,
.track-steps div.active span {
  color: var(--lux-dark);
}

.track-order-head > strong {
  background: var(--lux-mist);
  border-color: var(--lux-line);
  color: var(--lux-dark);
}

.reef-footer,
.luxury-footer {
  background:
    radial-gradient(circle at 14% 0%, rgba(146, 182, 110, 0.14), transparent 24%),
    linear-gradient(180deg, var(--lux-forest), #11170d);
  color: #fff;
}

.footer-bottom {
  border-top-color: rgba(232, 209, 138, .20);
}

.women-section,
.gift-highlight,
.lux-blush-panel {
  background: var(--lux-blush) !important;
}

.offer-badge,
.sale-badge,
.lux-wine-badge {
  background: var(--lux-wine) !important;
  color: #fff !important;
}

@media (max-width: 760px) {
  .harrods-offer-bar {
    background: linear-gradient(135deg, var(--lux-forest), var(--lux-dark));
  }

  .harrods-main-row,
  .harrods-tools-row {
    background: rgba(255, 255, 255, .98);
  }
}

@media (max-width: 620px) {
  .harrods-category-page,
  main {
    background: var(--lux-bg);
  }

  .harrods-product-image,
  .product-image-box,
  .tile-image {
    background: var(--lux-light);
  }
}

.footer-information a,
.luxury-footer a,
.reef-footer a {
  transition: color .18s ease, transform .18s ease;
}

.footer-information a:hover,
.luxury-footer a:hover,
.reef-footer a:hover {
  color: var(--lux-gold, #c8a24a);
  transform: translateX(3px);
}

.footer-columns h3,
.footer-grid h3,
.footer-columns h4,
.footer-grid h4 {
  color: #fff;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 1px;
}

.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.kp-footer-contact {
  margin-top: 24px;
  color: rgba(255,255,255,.72);
  font-family: "Cairo", Arial, sans-serif;
}

.kp-footer-contact span {
  display: block;
  margin-bottom: 8px;
}

.kp-footer-contact a {
  margin-bottom: 0;
  color: var(--lux-gold, #c8a24a);
}


/* ===== app.css ===== */

:root {
  
  --bg: #f7f3ea;
  --bg2: #fbf8f1;
  --card: #fffdf7;
  --card2: #f3f7ea;

  
  --ink: #161a12;
  --muted: #6f7668;

  
  --dark: #172210;
  --dark2: #2b3b1b;
  --dark3: #3f5428;
  --brown: #4f6038;
  --copper: #6d8c4e;

  
  --gold: #c8a24a;
  --gold2: #e8d18a;
  --gold3: #f3e4b3;

  
  --danger: #870c46;
  --danger2: #a43163;
  --ok: #168f5a;
  --ok2: #31b477;

  
  --line: #d8dec9;
  --line2: #b9c6a3;
  --soft: #eafada;
  --cream: #fffaf1;

  
  --blush: #fbe3ee;
  --wine: #870c46;
  --bordeaux: #3f0d24;

  
  --shadow: rgba(22, 34, 16, 0.14);
}

html {
  min-height: 100%;
}

body {
  margin: 0;
  font-family: "Cairo", Arial, Helvetica, sans-serif;
  color: var(--ink);
  background:
    radial-gradient(
      circle at 8% 6%,
      rgba(232, 200, 121, 0.38),
      transparent 25%
    ),
    radial-gradient(
      circle at 92% 15%,
      rgba(107, 61, 32, 0.18),
      transparent 28%
    ),
    radial-gradient(
      circle at 60% 100%,
      rgba(200, 148, 56, 0.16),
      transparent 30%
    ),
    linear-gradient(180deg, var(--bg2), var(--bg));
}

.btn {
  border: 0;
  border-radius: 17px;
  padding: 12px 17px;
  cursor: pointer;
  font-weight: 900;
  background: linear-gradient(135deg, var(--dark2), var(--dark3));
  color: #fff;
  display: inline-block;
  text-align: center;
  box-shadow: 0 10px 22px rgba(27, 13, 6, 0.16);
  transition: 0.16s ease;
}

.btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 26px rgba(27, 13, 6, 0.22);
}

.btn.gold {
  background: linear-gradient(135deg, #b77622 0%, #d9a846 48%, #f4d88a 100%);
  color: #241208;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.45),
    0 12px 24px rgba(168, 101, 49, 0.26);
}

.btn.danger {
  background: linear-gradient(135deg, var(--danger), var(--danger2));
}

.btn.ok {
  background: linear-gradient(135deg, var(--ok), var(--ok2));
}

.btn.light {
  background: linear-gradient(180deg, #fffdf8, #fff2df);
  color: var(--ink);
  border: 1px solid rgba(207, 174, 120, 0.7);
  box-shadow: 0 8px 18px rgba(49, 24, 11, 0.08);
}

.btn.sm {
  padding: 7px 10px;
  border-radius: 11px;
  font-size: 13px;
}

.input,
select,
textarea {
  width: 100%;
  padding: 13px 15px;
  border: 1px solid rgba(207, 174, 120, 0.72);
  border-radius: 16px;
  background: linear-gradient(180deg, #fffdf9, #fff6ea);
  color: var(--ink);
  font-size: 16px;
  outline: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.input:focus,
select:focus,
textarea:focus {
  border-color: var(--gold);
  box-shadow:
    0 0 0 4px rgba(200, 148, 56, 0.17),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.card {
  background: linear-gradient(
    180deg,
    rgba(255, 250, 241, 0.98),
    rgba(255, 244, 228, 0.95)
  );
  border: 1px solid rgba(207, 174, 120, 0.48);
  border-radius: 28px;
  padding: 18px;
  box-shadow:
    0 18px 45px var(--shadow),
    inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

.login-wrap {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 20px;
  background:
    radial-gradient(
      circle at 15% 15%,
      rgba(232, 200, 121, 0.35),
      transparent 32%
    ),
    radial-gradient(
      circle at 88% 12%,
      rgba(107, 61, 32, 0.18),
      transparent 32%
    ),
    linear-gradient(180deg, #f8efe2, #eadcc8);
}

.login-card {
  width: 100%;
  max-width: 430px;
}

.login-card h1 {
  margin-top: 0;
}

.alert {
  padding: 12px 14px;
  border-radius: 15px;
  background: #ffe1dc;
  color: #8f1e18;
  margin-bottom: 12px;
  border: 1px solid #f1b4ac;
}

.success {
  padding: 12px 14px;
  border-radius: 15px;
  background: #e5f8ed;
  color: #126b43;
  margin-bottom: 12px;
  border: 1px solid #a9e0c2;
}

.pos-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 430px;
  gap: 18px;
  padding: 18px;
  min-height: 100vh;
  background:
    radial-gradient(
      circle at top left,
      rgba(232, 200, 121, 0.26),
      transparent 27%
    ),
    radial-gradient(circle at 75% 8%, rgba(107, 61, 32, 0.14), transparent 24%),
    radial-gradient(
      circle at bottom right,
      rgba(74, 41, 25, 0.14),
      transparent 38%
    ),
    linear-gradient(180deg, #f8efe2, #eadcc8);
}

.pos-left,
.pos-right {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.pos-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  background:
    radial-gradient(
      circle at 92% 15%,
      rgba(247, 225, 163, 0.2),
      transparent 28%
    ),
    linear-gradient(135deg, #1b0d06 0%, #2d160b 42%, #573018 100%);
  color: #fff;
  overflow: hidden;
  position: relative;
  border: 1px solid rgba(232, 200, 121, 0.24);
  box-shadow:
    0 18px 42px rgba(27, 13, 6, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.pos-header:before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.06), transparent 26%),
    repeating-linear-gradient(
      45deg,
      rgba(255, 255, 255, 0.025) 0 1px,
      transparent 1px 10px
    );
  pointer-events: none;
}

.pos-header:after {
  content: "";
  position: absolute;
  right: -52px;
  top: -82px;
  width: 245px;
  height: 245px;
  border-radius: 50%;
  background: radial-gradient(
    circle,
    rgba(232, 200, 121, 0.28),
    rgba(200, 148, 56, 0.1) 58%,
    transparent 62%
  );
}

.pos-title h1 {
  margin: 0;
  font-size: 31px;
  letter-spacing: -0.7px;
  position: relative;
  z-index: 2;
}

.pos-title p {
  margin: 5px 0 0;
  color: #f2dec0;
  position: relative;
  z-index: 2;
}

.pos-actions {
  display: flex;
  gap: 8px;
  position: relative;
  z-index: 3;
}

.scan-card {
  padding: 16px;
  background: linear-gradient(
    135deg,
    rgba(255, 250, 241, 0.98),
    rgba(250, 236, 216, 0.96)
  );
}

.scan-box {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
}

.scan-hint {
  margin: 10px 0 0;
  color: var(--muted);
  font-size: 13px;
}

.toolbar {
  display: grid;
  grid-template-columns: 1fr 190px 190px;
  gap: 10px;
}

.product-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(220px, 1fr));
  gap: 16px;
}

.product-card {
  background: linear-gradient(180deg, #fffaf1 0%, #fff5e7 100%);
  border: 1px solid rgba(207, 174, 120, 0.55);
  border-radius: 26px;
  padding: 0;
  cursor: pointer;
  transition: 0.18s ease;
  overflow: hidden;
  position: relative;
  min-height: 450px;
  box-shadow:
    0 12px 26px rgba(49, 24, 11, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.product-card:hover {
  transform: translateY(-5px);
  box-shadow:
    0 22px 42px rgba(49, 24, 11, 0.17),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
  border-color: rgba(200, 148, 56, 0.78);
}

.product-img {
  height: 275px;
  background: radial-gradient(
    circle at 50% 42%,
    #fffdf7 0%,
    #fff7e9 34%,
    #efddc5 78%,
    #e5ccb0 100%
  );
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gold);
  font-size: 34px;
  font-weight: 900;
  overflow: hidden;
  padding: 18px;
  position: relative;
}

.product-img:after {
  content: "";
  position: absolute;
  left: 10%;
  right: 10%;
  bottom: 14px;
  height: 18px;
  border-radius: 50%;
  background: rgba(49, 24, 11, 0.1);
  filter: blur(8px);
}

.product-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center center;
  filter: drop-shadow(0 18px 22px rgba(42, 21, 11, 0.24));
  position: relative;
  z-index: 2;
}

.product-body {
  padding: 15px;
  background: linear-gradient(180deg, #fffaf1, #fff3e2);
  border-top: 1px solid rgba(207, 174, 120, 0.32);
}

.product-card h3 {
  margin: 0 0 5px;
  font-size: 16px;
  line-height: 1.2;
  color: #211209;
  letter-spacing: -0.2px;
}

.product-card .name-ar {
  font-size: 13px;
  font-weight: 900;
  color: #6b3d20;
  margin-bottom: 7px;
  direction: rtl;
  text-align: left;
}

.product-card p {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.product-card .price {
  margin-top: 11px;
  font-weight: 1000;
  color: #b77421;
  font-size: 19px;
}

.stock-pill {
  position: absolute;
  top: 12px;
  right: 12px;
  background: rgba(255, 250, 241, 0.96);
  border: 1px solid rgba(207, 174, 120, 0.72);
  font-size: 11px;
  padding: 6px 8px;
  border-radius: 999px;
  font-weight: 900;
  color: #3a2114;
  z-index: 5;
  box-shadow: 0 6px 14px rgba(49, 24, 11, 0.08);
}

.stock-pill.low {
  background: #ffe1dc;
  color: #9b211d;
  border-color: #efb1a9;
}

.cart-card {
  position: sticky;
  top: 18px;
}

.cart-card h2 {
  letter-spacing: -0.4px;
}

.cart-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 47vh;
  overflow: auto;
  padding-right: 2px;
}

.cart-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
  border: 1px solid rgba(207, 174, 120, 0.46);
  border-radius: 20px;
  padding: 12px;
  background: linear-gradient(180deg, #fffaf1, #fff2df);
  box-shadow: 0 8px 18px rgba(49, 24, 11, 0.06);
}

.cart-item h4 {
  margin: 0;
  font-size: 15px;
}

.cart-item small {
  color: var(--muted);
}

.qty-controls {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-top: 9px;
}

.qty-controls button {
  width: 32px;
  height: 32px;
  border-radius: 12px;
  border: 1px solid rgba(207, 174, 120, 0.7);
  background: #fffaf3;
  font-weight: 1000;
  cursor: pointer;
  color: #2d160b;
}

.qty-controls button:hover {
  background: #fff0d8;
}

.totals {
  border-top: 1px solid rgba(207, 174, 120, 0.58);
  padding-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 9px;
}

.totals div {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.totals .grand {
  font-size: 26px;
  font-weight: 1000;
  color: #1b0d06;
}

.empty-cart {
  text-align: center;
  padding: 28px;
  color: var(--muted);
  border: 1px dashed #cfae78;
  border-radius: 20px;
  background: #fff7e9;
}

.admin-shell {
  display: grid;
  grid-template-columns: 250px 1fr;
  min-height: 100vh;
}

.sidebar {
  background:
    radial-gradient(circle at top, rgba(232, 200, 121, 0.12), transparent 28%),
    linear-gradient(180deg, #1b0d06, #2d160b 54%, #4a2919);
  color: #fff;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  box-shadow: 12px 0 30px rgba(27, 13, 6, 0.16);
}

.sidebar .brand {
  font-size: 22px;
  font-weight: 1000;
  margin-bottom: 15px;
  color: #e8c879;
  letter-spacing: -0.3px;
}

.sidebar a {
  padding: 12px;
  border-radius: 14px;
  color: #fff;
  transition: 0.15s ease;
}

.sidebar a:hover {
  background: rgba(232, 200, 121, 0.13);
  transform: translateX(2px);
}

.admin-main {
  padding: 22px;
}

.topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 18px;
}

.topbar h1 {
  margin: 0;
}

.topbar p {
  margin: 4px 0;
  color: var(--muted);
}

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

.table-wrap {
  overflow: auto;
}

table {
  width: 100%;
  border-collapse: collapse;
  background: #fffaf1;
  border-radius: 20px;
  overflow: hidden;
}

th,
td {
  padding: 12px;
  border-bottom: 1px solid rgba(207, 174, 120, 0.4);
  text-align: left;
  vertical-align: top;
}

th {
  background: #f4e4cf;
  font-size: 13px;
  color: #75583f;
}

.badge {
  padding: 5px 8px;
  border-radius: 999px;
  background: #eee;
  font-size: 12px;
  font-weight: 900;
  display: inline-block;
}

.badge.low {
  background: #ffe1dc;
  color: #9b211d;
}

.badge.ok {
  background: #e5f8ed;
  color: #126b43;
}

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

.form-grid .full {
  grid-column: 1/-1;
}

.variant-box {
  border: 1px solid rgba(207, 174, 120, 0.48);
  border-radius: 22px;
  padding: 14px;
  background: #fff7e9;
  margin-bottom: 12px;
}

.variant-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
  margin-bottom: 10px;
}

.product-thumb {
  width: 76px;
  height: 76px;
  border-radius: 18px;
  object-fit: contain;
  background: #fff5e6;
  border: 1px solid #dfcdb7;
  padding: 5px;
}

.receipt-page {
  background: #eee;
}

.receipt-actions {
  text-align: center;
  margin: 18px;
}

.receipt {
  width: 80mm;
  max-width: 80mm;
  margin: 12px auto;
  background: #fff;
  color: #000;
  padding: 8px 9px;
  font-family: "Courier New", monospace;
  font-size: 12px;
  line-height: 1.35;
  box-shadow: 0 10px 35px rgba(0, 0, 0, 0.12);
}

.receipt .center {
  text-align: center;
}

.receipt h1 {
  font-size: 18px;
  margin: 0 0 4px;
  font-family: Arial, Helvetica, sans-serif;
}

.receipt .muted {
  color: #333;
}

.receipt .rule {
  border-top: 1px dashed #000;
  margin: 7px 0;
}

.receipt table {
  border-radius: 0;
  font-size: 12px;
  font-family: "Courier New", monospace;
  background: #fff;
}

.receipt th,
.receipt td {
  border: 0;
  padding: 3px 0;
  background: #fff;
  color: #000;
}

.receipt th {
  border-bottom: 1px dashed #000;
}

.receipt .right {
  text-align: right;
}

.receipt .total-row {
  font-size: 15px;
  font-weight: 900;
}

.receipt .barcode {
  font-family: Arial, Helvetica, sans-serif;
  letter-spacing: 1px;
  margin-top: 8px;
}

.receipt .small {
  font-size: 11px;
}

.invoice {
  max-width: 820px;
  margin: 25px auto;
  background: #fff;
  padding: 28px;
  border-radius: 18px;
}

.invoice-head {
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid var(--line);
  padding-bottom: 18px;
  margin-bottom: 18px;
}

.print-actions {
  text-align: center;
  margin: 18px;
}

@media print {
  .print-actions,
  .receipt-actions,
  .sidebar,
  .topbar {
    display: none !important;
  }
  body {
    background: #fff;
  }
  @page {
    size: 80mm auto;
    margin: 3mm;
  }
  .receipt {
    box-shadow: none;
    margin: 0;
    width: 74mm;
    max-width: 74mm;
    padding: 0;
    font-size: 11px;
  }
  .invoice {
    box-shadow: none;
    margin: 0;
    max-width: none;
    border-radius: 0;
  }
}

@media (max-width: 1200px) {
  .product-grid {
    grid-template-columns: repeat(3, minmax(220px, 1fr));
  }
}

@media (max-width: 1100px) {
  .pos-shell {
    grid-template-columns: 1fr;
  }
  .cart-card {
    position: static;
  }
  .admin-shell {
    grid-template-columns: 1fr;
  }
  .sidebar {
    position: static;
    flex-direction: row;
    overflow: auto;
  }
  .grid-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .pos-shell {
    padding: 10px;
  }
  .pos-header {
    align-items: flex-start;
    flex-direction: column;
  }
  .pos-actions {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .scan-box,
  .toolbar {
    grid-template-columns: 1fr;
  }
  .product-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
  .product-img {
    height: 210px;
    padding: 12px;
  }
  .product-card {
    min-height: 390px;
  }
  .form-grid {
    grid-template-columns: 1fr;
  }
  .grid-4 {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 460px) {
  .product-grid {
    grid-template-columns: 1fr;
  }
}

button,
input,
select,
textarea {
  font-family: "Cairo", Arial, Helvetica, sans-serif;
}

.pos-alert-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(27, 13, 6, 0.62);
  backdrop-filter: blur(7px);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  z-index: 9999;
}

.pos-alert-backdrop.show {
  display: flex;
  animation: fadeIn 0.16s ease-out;
}

.pos-alert-box {
  width: min(520px, 100%);
  background:
    radial-gradient(
      circle at top left,
      rgba(232, 200, 121, 0.26),
      transparent 36%
    ),
    linear-gradient(180deg, #fffaf1, #fff0dc);
  border: 2px solid rgba(232, 200, 121, 0.78);
  border-radius: 34px;
  padding: 22px;
  box-shadow:
    0 30px 80px rgba(0, 0, 0, 0.35),
    inset 0 1px 0 rgba(255, 255, 255, 0.75);
  position: relative;
  text-align: center;
  transform: scale(0.96);
  animation: popIn 0.18s ease-out forwards;
}

.pos-alert-close {
  position: absolute;
  top: 12px;
  right: 14px;
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 50%;
  background: #2d160b;
  color: #fff;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 10px 20px rgba(45, 22, 11, 0.18);
}

.pos-alert-image {
  width: 100%;
  max-width: 330px;
  margin: 4px auto 14px;
}

.pos-alert-image img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 26px;
}

.pos-alert-content h2 {
  margin: 0 0 8px;
  font-size: 30px;
  color: #2d160b;
  letter-spacing: -0.6px;
}

.pos-alert-content p {
  margin: 0 auto 18px;
  color: #6b3d20;
  font-size: 17px;
  font-weight: 800;
  max-width: 420px;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes popIn {
  from {
    opacity: 0.4;
    transform: scale(0.92) translateY(10px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

@media (max-width: 600px) {
  .pos-alert-box {
    padding: 18px;
    border-radius: 28px;
  }

  .pos-alert-content h2 {
    font-size: 24px;
  }

  .pos-alert-content p {
    font-size: 15px;
  }
}

.pos-shell {
  padding-top: 14px;
}

.scan-card {
  border-top: 3px solid rgba(232, 200, 121, 0.55);
}

@media (max-width: 760px) {
  .pos-shell {
    padding-top: 10px;
  }
}

.cashier-mini-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 22px;
  background: linear-gradient(
    135deg,
    rgba(45, 22, 11, 0.96),
    rgba(87, 48, 24, 0.94)
  );
  color: #fff;
  border: 1px solid rgba(232, 200, 121, 0.28);
  box-shadow: 0 12px 28px rgba(27, 13, 6, 0.16);
}

.cashier-mini-bar span {
  display: block;
  font-size: 12px;
  color: #f1dcb8;
  margin-top: 2px;
}

.cashier-mini-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.cashier-page {
  min-height: 100vh;
  padding: 18px;
  background:
    radial-gradient(
      circle at top left,
      rgba(232, 200, 121, 0.26),
      transparent 27%
    ),
    radial-gradient(
      circle at bottom right,
      rgba(74, 41, 25, 0.14),
      transparent 38%
    ),
    linear-gradient(180deg, #f8efe2, #eadcc8);
}

.cashier-page-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  margin-bottom: 16px;
}

.cashier-page-header h1 {
  margin: 0;
  letter-spacing: -0.5px;
}

.cashier-page-header p {
  margin: 5px 0 0;
  color: var(--muted);
}

.cashier-summary {
  margin-bottom: 16px;
}

.x-report-receipt {
  width: 88mm;
  max-width: 88mm;
}

@media print {
  .no-print {
    display: none !important;
  }
}

@media (max-width: 760px) {
  .cashier-mini-bar,
  .cashier-page-header {
    align-items: flex-start;
    flex-direction: column;
  }

  .cashier-mini-actions {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr;
  }

  .cashier-page {
    padding: 10px;
  }
}

.receipt-actions form {
  display: inline-block;
  margin: 0 4px;
}

.receipt .total-row td {
  padding-top: 6px;
  border-top: 1px dashed #000;
}

.pos-right {
  min-height: 0;
}

.cart-card {
  position: sticky;
  top: 14px;
  height: calc(100vh - 28px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.cart-card > h2 {
  flex: 0 0 auto;
}

.cart-list {
  flex: 1 1 auto;
  min-height: 160px;
  max-height: none !important;
  overflow: auto;
  padding-right: 4px;
  margin-bottom: 10px;
}

.totals {
  flex: 0 0 auto;
  background: linear-gradient(180deg, #fffaf1, #fff1dc);
  border: 1px solid rgba(207, 174, 120, 0.35);
  border-radius: 18px;
  padding: 12px;
  margin-top: auto;
}

.cart-card label,
.cart-card select,
.cart-card textarea,
.cart-card .complete-sale-btn,
.cart-card button {
  flex: 0 0 auto;
}

.complete-sale-btn {
  position: relative;
  z-index: 3;
  min-height: 54px;
  box-shadow: 0 14px 28px rgba(22, 143, 90, 0.22);
}

.complete-sale-btn:disabled {
  opacity: 0.65;
  cursor: not-allowed;
  transform: none !important;
}

@media (max-width: 1100px) {
  .cart-card {
    position: static;
    height: auto;
    max-height: none;
  }

  .cart-list {
    max-height: 45vh !important;
  }
}

.totals div strong,
.totals div span:last-child {
  font-variant-numeric: tabular-nums;
}

.totals div:nth-child(3) {
  color: #6b3d20;
}

.totals .grand {
  border-top: 1px dashed rgba(107, 61, 32, 0.35);
  padding-top: 10px;
  margin-top: 2px;
}

.payment-buttons {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 8px;
}

.pay-btn {
  border: 1px solid rgba(207, 174, 120, 0.72);
  border-radius: 18px;
  padding: 14px 12px;
  background: linear-gradient(180deg, #fffdf8, #fff2df);
  color: #24140c;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-family: "Cairo", Arial, Helvetica, sans-serif;
  font-weight: 900;
  box-shadow: 0 8px 18px rgba(49, 24, 11, 0.08);
  transition: 0.16s ease;
  min-height: 58px;
}

.pay-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(49, 24, 11, 0.13);
}

.pay-btn.active {
  background: linear-gradient(135deg, #b77622 0%, #d9a846 48%, #f4d88a 100%);
  border-color: #b77622;
  color: #241208;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.5),
    0 14px 26px rgba(168, 101, 49, 0.24);
}

.pay-icon {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(45, 22, 11, 0.1);
  font-weight: 1000;
}

.pay-btn.active .pay-icon {
  background: rgba(45, 22, 11, 0.16);
}

@media (max-width: 420px) {
  .payment-buttons {
    grid-template-columns: 1fr;
  }
}

.barcode-svg {
  max-width: 100%;
  height: auto;
  background: #fff;
}

.return-qty {
  text-align: center;
  font-weight: 900;
}

tr[data-barcode] {
  transition: 0.18s ease;
}

@media print {
  .barcode-svg {
    max-width: 100%;
  }
}

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

@media (max-width: 520px) {
  .payment-buttons-3 {
    grid-template-columns: 1fr;
  }
}

.x-report-receipt strong {
  display: block;
  margin: 6px 0 4px;
}

.settings-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 16px;
  align-items: start;
}

.settings-logo-preview {
  max-width: 220px;
  max-height: 160px;
  object-fit: contain;
  background: #111;
  border-radius: 18px;
  padding: 10px;
  border: 1px solid rgba(207, 174, 120, 0.55);
}

.brand-preview-card {
  position: sticky;
  top: 18px;
}

.mini-receipt-preview {
  background: #fff;
  color: #111;
  border-radius: 18px;
  padding: 18px;
  text-align: center;
  border: 1px solid var(--line);
}

.mini-receipt-preview img {
  max-width: 160px;
  max-height: 140px;
  object-fit: contain;
  background: #000;
  border-radius: 16px;
  padding: 8px;
}

.mini-receipt-preview h3 {
  margin: 10px 0 2px;
  font-size: 24px;
}

.mini-receipt-preview h4 {
  margin: 0;
  letter-spacing: 2px;
}

.mini-receipt-preview p {
  margin: 6px 0;
  letter-spacing: 3px;
  font-size: 12px;
}

.receipt-brand img {
  max-width: 44mm;
  max-height: 32mm;
  object-fit: contain;
  display: block;
  margin: 0 auto 4px;
}

.receipt-brand h1 {
  font-size: 17px;
  margin: 2px 0;
}

.receipt-brand h2 {
  font-size: 13px;
  margin: 0 0 3px;
  letter-spacing: 1px;
}

@media (max-width: 1000px) {
  .settings-layout {
    grid-template-columns: 1fr;
  }
  .brand-preview-card {
    position: static;
  }
}

@media print {
  .receipt-brand img {
    max-width: 38mm;
    max-height: 26mm;
  }
}

.role-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

.role-grid > div {
  background: #fff7e9;
  border: 1px solid rgba(207, 174, 120, 0.45);
  border-radius: 18px;
  padding: 14px;
}

.role-grid p {
  color: var(--muted);
  margin: 6px 0 0;
  font-size: 13px;
}

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

@media (max-width: 600px) {
  .role-grid {
    grid-template-columns: 1fr;
  }
}

.stock-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(360px, 0.8fr);
  gap: 16px;
  align-items: start;
}

.stock-big-number {
  border-radius: 24px;
  background: linear-gradient(135deg, #fffaf1, #fff0d8);
  border: 1px solid rgba(207, 174, 120, 0.55);
  padding: 22px;
  font-size: 48px;
  font-weight: 1000;
  color: #168f5a;
  text-align: center;
  box-shadow: 0 12px 28px rgba(49, 24, 11, 0.08);
}

.stock-big-number span {
  display: block;
  font-size: 14px;
  color: var(--muted);
  font-weight: 800;
  margin-top: 4px;
}

.stock-big-number.low {
  color: #c83d38;
  background: linear-gradient(135deg, #fff5ed, #ffe1dc);
}

.stock-low-text {
  color: #c83d38;
}

@media (max-width: 1100px) {
  .stock-layout {
    grid-template-columns: 1fr;
  }
}

.products-search-box {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 160px auto auto;
  gap: 10px;
  align-items: center;
}

#productSearchInput {
  font-size: 17px;
  font-weight: 800;
}

#productSearchInput:focus {
  border-color: #d9a846;
  box-shadow: 0 0 0 4px rgba(217, 168, 70, 0.18);
}

@media (max-width: 760px) {
  .products-search-box {
    grid-template-columns: 1fr;
  }
}

.import-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 390px;
  gap: 16px;
  align-items: start;
}

.code-box {
  background: #21120a;
  color: #fff3d6;
  padding: 14px;
  border-radius: 16px;
  overflow: auto;
  font-size: 13px;
  line-height: 1.55;
}

.import-log {
  max-height: 420px;
  overflow: auto;
  background: #fff8ea;
  border: 1px solid rgba(207, 174, 120, 0.45);
  border-radius: 16px;
  padding: 12px;
  font-size: 13px;
}

.import-log div {
  padding: 5px 0;
  border-bottom: 1px dashed rgba(107, 61, 32, 0.18);
}

@media (max-width: 1000px) {
  .import-layout {
    grid-template-columns: 1fr;
  }
}

.reports-filter {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  align-items: end;
}

.report-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.report-card {
  background: linear-gradient(135deg, #fffaf1, #fff1dc);
  border: 1px solid rgba(207, 174, 120, 0.55);
  border-radius: 24px;
  padding: 18px;
  box-shadow: 0 12px 26px rgba(49, 24, 11, 0.08);
}

.report-card span {
  display: block;
  color: var(--muted);
  font-weight: 800;
  font-size: 13px;
}

.report-card strong {
  display: block;
  font-size: 28px;
  margin: 6px 0;
}

.report-card small {
  color: var(--muted);
}

.report-card.success strong {
  color: #168f5a;
}

.report-card.danger strong {
  color: #c83d38;
}

.reports-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

@media (max-width: 1100px) {
  .reports-filter {
    grid-template-columns: 1fr 1fr;
  }
  .report-kpis {
    grid-template-columns: 1fr 1fr;
  }
  .reports-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 620px) {
  .reports-filter,
  .report-kpis {
    grid-template-columns: 1fr;
  }
}

@media print {
  .admin-sidebar,
  .admin-topbar,
  .no-print,
  .btn,
  form {
    display: none !important;
  }
  .card {
    box-shadow: none !important;
    border: 1px solid #ddd !important;
  }
  .report-kpis,
  .reports-grid {
    break-inside: avoid;
  }
}

.dashboard-hero {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  background: linear-gradient(135deg, #1e120a, #5a3219 54%, #b77622);
  color: #fff;
  overflow: hidden;
  position: relative;
}

.dashboard-hero h1 {
  margin: 0;
  font-size: 32px;
}

.dashboard-hero h2 {
  margin: 2px 0;
  font-size: 20px;
  letter-spacing: 1px;
}

.dashboard-hero p {
  margin: 4px 0 0;
  color: #ffe8be;
}

.dashboard-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.dashboard-kpis {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
}

.dash-kpi {
  display: block;
  text-decoration: none;
  color: inherit;
  background: linear-gradient(135deg, #fffaf1, #fff0d8);
  border: 1px solid rgba(207, 174, 120, 0.55);
  border-radius: 24px;
  padding: 16px;
  box-shadow: 0 12px 26px rgba(49, 24, 11, 0.08);
  transition: 0.15s ease;
}

.dash-kpi:hover {
  transform: translateY(-2px);
}

.dash-kpi span {
  display: block;
  color: var(--muted);
  font-weight: 900;
  font-size: 13px;
}

.dash-kpi strong {
  display: block;
  font-size: 25px;
  margin: 5px 0;
}

.dash-kpi small {
  color: var(--muted);
}

.dash-kpi.success strong {
  color: #168f5a;
}

.dash-kpi.danger strong {
  color: #c83d38;
}

.dash-kpi.warning strong {
  color: #b77622;
}

.dashboard-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  align-items: start;
}

.section-title-row {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
  margin-bottom: 10px;
}

.section-title-row h2 {
  margin: 0;
}

@media (max-width: 1300px) {
  .dashboard-kpis {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .dashboard-hero {
    display: block;
  }
  .dashboard-actions {
    margin-top: 12px;
  }
  .dashboard-grid {
    grid-template-columns: 1fr;
  }
  .dashboard-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .dashboard-kpis {
    grid-template-columns: 1fr;
  }
}

@media print {
  .dashboard-actions,
  .no-print {
    display: none !important;
  }
  .dashboard-hero {
    background: #fff !important;
    color: #000 !important;
    border: 1px solid #ddd !important;
  }
  .dashboard-hero p {
    color: #555 !important;
  }
  .dash-kpi,
  .card {
    box-shadow: none !important;
  }
}

.customer-box{
  background:rgba(255,248,234,.70);
  border:1px solid rgba(207,174,120,.45);
  border-radius:18px;
  padding:12px;
  margin-bottom:12px;
}

#customerPhone{
  font-weight:900;
  font-size:16px;
}

.customer-search-row{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
}

.selected-customer{
  margin-top:8px;
  background:#eaf8f0;
  border:1px solid rgba(22,143,90,.25);
  border-radius:14px;
  padding:9px;
}

.mini-remove{
  float:right;
  border:0;
  background:#c83d38;
  color:#fff;
  border-radius:50%;
  width:22px;
  height:22px;
  cursor:pointer;
}

@media(max-width:620px){
  .customer-search-row{grid-template-columns:1fr;}
}

@media (min-width: 768px){

  .current-sale,
  .cart-panel,
  .sale-panel,
  .pos-cart,
  .right-panel,
  .cart-summary{
    position: sticky !important;
    top: 10px !important;
    height: calc(100vh - 20px) !important;
    max-height: calc(100vh - 20px) !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
  }

  .cart-items,
  .sale-items,
  .current-items,
  #cartItems,
  #saleItems{
    overflow-y: auto !important;
    max-height: 210px !important;
  }

  .sale-actions,
  .checkout-actions,
  .cart-actions,
  .complete-sale-actions{
    margin-top: auto !important;
    position: sticky !important;
    bottom: 0 !important;
    z-index: 999 !important;
    background: linear-gradient(180deg, rgba(255,247,232,.70), #fff7e8 32%, #fff7e8 100%) !important;
    border-top: 1px solid rgba(207,174,120,.45) !important;
    padding: 12px 0 6px !important;
    box-shadow: 0 -12px 28px rgba(49,24,11,.08) !important;
  }

  #completeSaleBtn,
  .complete-sale-btn,
  .btn-complete-sale,
  button[onclick*="completeSale"]{
    flex-shrink: 0 !important;
    width: 100% !important;
    min-height: 50px !important;
    margin-top: 10px !important;
    position: sticky !important;
    bottom: 8px !important;
    z-index: 1000 !important;
  }

  .customer-box{
    padding: 8px 10px !important;
    margin-bottom: 8px !important;
  }

  .customer-box label{
    margin-bottom: 4px !important;
    font-size: 13px !important;
  }

  #customerPhone{
    height: 42px !important;
    min-height: 42px !important;
    font-size: 14px !important;
  }

  .customer-search-row{
    gap: 6px !important;
  }

  .customer-search-row .btn{
    min-height: 42px !important;
    padding: 8px 12px !important;
    font-size: 12px !important;
  }

  .customer-box small{
    font-size: 11px !important;
    line-height: 1.25 !important;
  }

  .payment-buttons,
  .payment-buttons-3{
    gap: 8px !important;
  }

  .pay-btn{
    min-height: 58px !important;
    padding: 8px !important;
  }

  .pay-btn strong{
    font-size: 12px !important;
  }

  textarea#note,
  textarea[name="note"],
  #saleNote{
    min-height: 46px !important;
    height: 54px !important;
    max-height: 58px !important;
  }
}

@media (max-width: 767px){
  .sale-actions,
  .checkout-actions,
  .cart-actions,
  .complete-sale-actions{
    position: fixed !important;
    left: 10px !important;
    right: 10px !important;
    bottom: 10px !important;
    z-index: 9999 !important;
    background: #fff7e8 !important;
    border: 1px solid rgba(207,174,120,.55) !important;
    border-radius: 18px !important;
    padding: 10px !important;
    box-shadow: 0 12px 30px rgba(49,24,11,.22) !important;
  }

  body{
    padding-bottom: 110px !important;
  }
}

.current-sale,
.cart-panel,
.sale-panel,
.pos-cart,
.right-panel,
.cart-summary{
  background:#fffaf1 !important;
  border:1px solid rgba(207,174,120,.48) !important;
  border-radius:24px !important;
}

@media (min-width: 768px){
  .current-sale,
  .cart-panel,
  .sale-panel,
  .pos-cart,
  .right-panel,
  .cart-summary{
    position: sticky !important;
    top: 10px !important;
    height: calc(100vh - 20px) !important;
    max-height: calc(100vh - 20px) !important;
    display:flex !important;
    flex-direction:column !important;
    overflow:hidden !important;
  }
}

.sale-type-box{
  padding:10px 10px 8px;
  border-bottom:1px solid rgba(207,174,120,.32);
}

.sale-type-title{
  display:block;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.6px;
  color:#6b5038;
  margin-bottom:7px;
}

.sale-type-buttons{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:6px;
}

.sale-type-btn{
  border:1px solid rgba(207,174,120,.45);
  background:#fff;
  color:#4c321f;
  border-radius:12px;
  min-height:54px;
  padding:8px 5px;
  font-weight:900;
  font-size:12px;
  cursor:pointer;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:3px;
}

.sale-type-btn span{
  font-size:18px;
  line-height:1;
}

.sale-type-btn.active{
  background:#fff1cf;
  border-color:#d9a846;
  box-shadow:0 6px 14px rgba(217,168,70,.18);
}

.customer-box{
  padding:8px 10px !important;
  margin:0 10px 8px !important;
  border-radius:14px !important;
  background:#fff7e8 !important;
  border:1px solid rgba(207,174,120,.36) !important;
}

.customer-box label{
  font-size:12px !important;
  margin-bottom:5px !important;
}

.customer-search-row{
  display:grid !important;
  grid-template-columns:1fr auto !important;
  gap:6px !important;
}

#customerPhone{
  height:40px !important;
  min-height:40px !important;
  font-size:13px !important;
  font-weight:800 !important;
}

.customer-search-row .btn{
  min-height:40px !important;
  padding:7px 10px !important;
  font-size:12px !important;
  border-radius:12px !important;
}

.customer-box small{
  font-size:10.5px !important;
}

.cart-items,
.sale-items,
.current-items,
#cartItems,
#saleItems,
.current-sale-items{
  flex:1 1 auto !important;
  overflow-y:auto !important;
  min-height:120px !important;
  max-height:none !important;
  padding-right:3px;
}

.cart-empty-state{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:#9a8c7a;
  min-height:180px;
}

.cart-empty-state .empty-icon{
  font-size:44px;
  opacity:.35;
  display:block;
  margin-bottom:8px;
}

.cart-empty-state strong{
  display:block;
  font-size:14px;
  color:#8d7b68;
}

.cart-empty-state small{
  display:block;
  margin-top:4px;
  font-size:12px;
}

textarea#note,
textarea[name="note"],
#saleNote{
  height:44px !important;
  min-height:44px !important;
  max-height:52px !important;
  border-radius:14px !important;
}

.payment-buttons,
.payment-buttons-3{
  display:grid !important;
  grid-template-columns:repeat(3,1fr) !important;
  gap:7px !important;
}

.pay-btn{
  border:1px solid rgba(207,174,120,.48) !important;
  border-radius:12px !important;
  min-height:50px !important;
  padding:7px !important;
  background:#fff !important;
  color:#4c321f !important;
  box-shadow:none !important;
}

.pay-btn.active{
  background:#dca43a !important;
  border-color:#bf8428 !important;
  color:#241406 !important;
  box-shadow:0 10px 18px rgba(191,132,40,.18) !important;
}

.pay-btn strong{
  font-size:12px !important;
}

.pay-icon{
  width:24px !important;
  height:24px !important;
  font-size:13px !important;
}

.totals,
.sale-totals,
.cart-totals,
#saleTotals{
  border-radius:16px !important;
  padding:10px !important;
  margin-bottom:8px !important;
}

.total-row,
.grand{
  font-size:18px !important;
}

.pos-bottom-zone,
.sale-actions,
.checkout-actions,
.cart-actions,
.complete-sale-actions{
  flex:0 0 auto !important;
  margin-top:auto !important;
  background:#fffaf1 !important;
  border-top:1px solid rgba(207,174,120,.34) !important;
  padding:10px 10px 8px !important;
  z-index:999 !important;
  box-shadow:0 -10px 22px rgba(49,24,11,.06) !important;
}

#completeSaleBtn,
.complete-sale-btn,
.btn-complete-sale,
button[onclick*="completeSale"]{
  width:100% !important;
  min-height:50px !important;
  border-radius:14px !important;
  font-size:16px !important;
  font-weight:1000 !important;
  margin-top:8px !important;
}

.pos-bottom-secondary{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-top:8px;
}

.pos-bottom-secondary .btn{
  min-height:40px;
  border-radius:12px;
}

@media (max-width:767px){
  .current-sale,
  .cart-panel,
  .sale-panel,
  .pos-cart,
  .right-panel,
  .cart-summary{
    border-radius:22px !important;
  }

  .pos-bottom-zone,
  .sale-actions,
  .checkout-actions,
  .cart-actions,
  .complete-sale-actions{
    position:fixed !important;
    left:8px !important;
    right:8px !important;
    bottom:8px !important;
    border:1px solid rgba(207,174,120,.5) !important;
    border-radius:18px !important;
    box-shadow:0 14px 34px rgba(49,24,11,.24) !important;
  }

  body{
    padding-bottom:140px !important;
  }
}

.reorder-filter{
  grid-template-columns:150px 180px 220px minmax(220px,1fr) auto;
}

@media(max-width:1100px){
  .reorder-filter{grid-template-columns:1fr 1fr;}
}

@media(max-width:620px){
  .reorder-filter{grid-template-columns:1fr;}
}

@media print{
  .no-print,.admin-sidebar,.admin-topbar,.btn,form{display:none!important;}
  .card{box-shadow:none!important;border:1px solid #ddd!important;}
}

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

.backup-card{
  background:linear-gradient(135deg,#fffaf1,#fff1dc);
  border:1px solid rgba(207,174,120,.5);
  border-radius:24px;
  padding:18px;
  box-shadow:0 12px 26px rgba(49,24,11,.08);
}

.backup-card.disabled{
  opacity:.55;
}

.backup-card h3{
  margin:0 0 8px;
}

.backup-card p{
  color:var(--muted);
  min-height:40px;
}

.backup-card small{
  display:block;
  color:var(--muted);
  margin-bottom:14px;
}

.backup-warning{
  border-color:rgba(200,61,56,.35)!important;
  background:#fff4f1!important;
}

.backup-warning p{
  margin-bottom:0;
  color:var(--muted);
}

.backup-routine{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}

.backup-routine div{
  border:1px solid rgba(207,174,120,.45);
  border-radius:18px;
  padding:14px;
  background:#fff8ea;
}

.backup-routine strong{
  display:block;
  margin-bottom:5px;
}

.backup-routine span{
  color:var(--muted);
  font-size:13px;
}

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

@media(max-width:640px){
  .backup-grid,.backup-routine{grid-template-columns:1fr;}
}

.loyalty-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  align-items:start;
}

@media(max-width:900px){
  .loyalty-layout{grid-template-columns:1fr;}
}

.loyalty-redeem-box{
  margin-top:8px;
  padding:10px;
  border-radius:14px;
  border:1px solid rgba(207,174,120,.45);
  background:#fff8ea;
}

.loyalty-balance{
  display:grid;
  grid-template-columns:1fr auto;
  gap:4px 10px;
  align-items:center;
  margin-bottom:8px;
}

.loyalty-balance span{
  color:var(--muted);
  font-size:12px;
  font-weight:800;
}

.loyalty-balance strong{
  font-size:16px;
}

.loyalty-balance small{
  grid-column:1 / -1;
  color:var(--muted);
}

.loyalty-redeem-row{
  display:grid;
  grid-template-columns:1fr auto auto;
  gap:6px;
}

.loyalty-redeem-row .btn{
  min-height:40px!important;
  padding:7px 10px!important;
  font-size:12px!important;
}

@media(max-width:620px){
  .loyalty-redeem-row{grid-template-columns:1fr;}
}

.loyalty-status-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  border-width:2px!important;
}

.loyalty-status-card strong{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:72px;
  height:42px;
  border-radius:999px;
  font-size:18px;
  font-weight:1000;
}

.loyalty-status-card.enabled{
  background:#eefaf4!important;
  border-color:rgba(22,143,90,.35)!important;
}

.loyalty-status-card.enabled strong{
  background:#168f5a;
  color:#fff;
}

.loyalty-status-card.disabled{
  background:#fff3f1!important;
  border-color:rgba(200,61,56,.35)!important;
}

.loyalty-status-card.disabled strong{
  background:#c83d38;
  color:#fff;
}

.loyalty-toggle-form{
  margin:0;
}

.loyalty-toggle-btn{
  border:0;
  min-width:118px;
  height:44px;
  padding:0 18px;
  border-radius:999px;
  color:#fff;
  font-size:14px;
  font-weight:1000;
  cursor:pointer;
  box-shadow:0 10px 20px rgba(49,24,11,.14);
}

.loyalty-toggle-btn.on{
  background:#168f5a;
}

.loyalty-toggle-btn.off{
  background:#c83d38;
}

.loyalty-toggle-btn:hover{
  transform:translateY(-1px);
}

@media(max-width:620px){
  .loyalty-status-card{
    display:block!important;
  }
  .loyalty-toggle-form{
    margin-top:12px;
  }
  .loyalty-toggle-btn{
    width:100%;
  }
}

.activity-filter{
  display:grid;
  grid-template-columns:150px 150px 220px 220px minmax(220px,1fr) auto;
  gap:10px;
  align-items:end;
}

.activity-action{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:5px 9px;
  border-radius:999px;
  background:#fff1cf;
  border:1px solid rgba(217,168,70,.45);
  font-weight:900;
  font-size:12px;
}

details pre{
  max-width:360px;
  max-height:220px;
  overflow:auto;
  background:#21120a;
  color:#fff3d6;
  border-radius:12px;
  padding:10px;
  font-size:11px;
  white-space:pre-wrap;
}

@media(max-width:1200px){
  .activity-filter{grid-template-columns:1fr 1fr 1fr;}
}

@media(max-width:720px){
  .activity-filter{grid-template-columns:1fr;}
}

@media print{
  .no-print,.admin-sidebar,.admin-topbar,.btn,form{display:none!important;}
  .card{box-shadow:none!important;border:1px solid #ddd!important;}
  details pre{max-height:none;background:#fff;color:#000;border:1px solid #ddd;}
}

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

.security-grid .full{grid-column:1 / -1}

.security-checks{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;background:#fff8ea;border:1px solid rgba(207,174,120,.45);border-radius:18px;padding:14px}

.security-checks label{display:flex;align-items:center;gap:8px;font-weight:800}

@media(max-width:900px){.security-grid{grid-template-columns:1fr}.security-checks{grid-template-columns:1fr}}

.portal-login{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0;
  padding:24px;
  font-family:Arial,Tahoma,sans-serif;
}

.staff-portal{
  background:linear-gradient(135deg,#21120a,#70451f 58%,#d6a64a);
}

.admin-portal{
  background:linear-gradient(135deg,#101827,#263b5e 58%,#b8944c);
}

.chooser-portal{
  background:linear-gradient(135deg,#21120a,#2f251d 58%,#8f6934);
}

.portal-card{
  width:min(430px,94vw);
  background:#fffaf1;
  border:1px solid rgba(207,174,120,.65);
  border-radius:30px;
  padding:30px;
  box-shadow:0 24px 70px rgba(0,0,0,.28);
}

.portal-icon{
  width:58px;
  height:58px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:20px;
  background:#fff1cf;
  font-size:30px;
  margin-bottom:14px;
}

.portal-card h1{
  margin:0 0 6px;
  color:#21120a;
  font-size:29px;
}

.portal-card p{
  margin:0 0 20px;
  color:#7e6a54;
  font-weight:700;
}

.portal-card label{
  display:block;
  margin:12px 0 6px;
  font-weight:900;
  color:#4c321f;
}

.portal-card .input{
  width:100%;
  min-height:50px;
  border-radius:15px;
  border:1px solid rgba(207,174,120,.65);
  padding:11px 13px;
  font-size:15px;
  box-sizing:border-box;
}

.portal-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:52px;
  margin-top:18px;
  border:0;
  border-radius:17px;
  background:#c7973b;
  color:#21120a;
  font-weight:1000;
  font-size:16px;
  cursor:pointer;
  text-decoration:none;
  box-sizing:border-box;
}

.portal-btn.secondary{
  background:#1f2f4c;
  color:#fff;
}

.portal-alert{
  background:#fff3f1;
  color:#9f2d27;
  border:1px solid rgba(200,61,56,.35);
  padding:12px;
  border-radius:14px;
  margin-bottom:14px;
  font-weight:800;
}

.portal-note{
  background:#fff8ea;
  border:1px solid rgba(207,174,120,.45);
  color:#6b5038;
  padding:12px;
  border-radius:14px;
  margin-bottom:14px;
  font-weight:800;
}

.portal-switch{
  margin-top:18px;
  text-align:center;
  color:#7e6a54;
  font-weight:700;
}

.portal-switch a{
  color:#5a3219;
  font-weight:1000;
  text-decoration:none;
}

.chooser-buttons{
  display:grid;
  gap:12px;
}

.chooser-buttons .portal-btn{
  margin-top:0;
}

.online-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  align-items:start;
}

.bulk-online-bar{
  display:grid;
  grid-template-columns:auto 240px auto;
  gap:10px;
  align-items:center;
  margin-bottom:16px;
}

.online-products-list{
  display:grid;
  gap:16px;
}

.online-product-card{
  border:1px solid rgba(207,174,120,.45);
  border-radius:24px;
  padding:16px;
  background:#fffaf1;
}

.online-card-top{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  gap:12px;
  align-items:start;
  margin-bottom:14px;
}

.online-card-top h3{margin:0 0 4px;}

.online-card-top p{margin:0 0 4px;color:var(--muted);}

.online-check input{width:20px;height:20px;}

.online-badges{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.online-product-form{
  border-top:1px dashed rgba(107,80,56,.25);
  padding-top:14px;
}

.variant-online-box{
  margin:14px 0;
  border:1px solid rgba(207,174,120,.35);
  border-radius:18px;
  padding:12px;
  background:#fff8ea;
}

.variant-online-box h4{margin:0 0 10px;}

.variant-online-row{
  display:grid;
  grid-template-columns:90px 100px minmax(0,1fr) 160px;
  gap:10px;
  align-items:center;
  padding:8px 0;
  border-top:1px dashed rgba(107,80,56,.18);
}

.variant-online-row:first-of-type{border-top:0;}

@media(max-width:1000px){
  .online-layout{grid-template-columns:1fr;}
  .bulk-online-bar{grid-template-columns:1fr;}
  .variant-online-row{grid-template-columns:1fr 1fr;}
}

@media(max-width:620px){
  .online-card-top{grid-template-columns:1fr;}
  .online-badges{justify-content:flex-start;}
  .variant-online-row{grid-template-columns:1fr;}
}

.checkout-page,
.checkout-wrap,
.checkout-shell{
  max-width: 1480px;
  margin: 0 auto;
  padding: 42px 5vw 70px;
  background: #f7f5f1;
}

.checkout-title,
.checkout-heading,
.checkout-page h1{
  font-family: "Cairo", Arial, sans-serif;
  font-size: 36px;
  line-height: 1.2;
  font-weight: 800;
  color: #111;
  margin: 0 0 12px;
}

.checkout-subtitle,
.checkout-page > p,
.checkout-intro{
  font-family: "Cairo", Arial, sans-serif;
  color: #555;
  font-size: 15px;
  line-height: 1.7;
  margin: 0 0 28px;
}

.checkout-grid{
  display: grid;
  grid-template-columns: minmax(0, 1fr) 420px;
  gap: 26px;
  align-items: start;
}

.checkout-form-card,
.checkout-summary,
.checkout-summary-card,
.checkout-card{
  background: #fff;
  border: 1px solid #ddd8cf;
  padding: 28px;
  box-shadow: none;
}

.checkout-summary,
.checkout-summary-card{
  position: sticky;
  top: 190px;
}

.checkout-section{
  border-bottom: 1px solid #eee8df;
  padding-bottom: 24px;
  margin-bottom: 24px;
}

.checkout-section:last-child{
  border-bottom: 0;
  padding-bottom: 0;
  margin-bottom: 0;
}

.checkout-section h2,
.checkout-section h3,
.checkout-card h2,
.checkout-card h3,
.checkout-summary h2,
.checkout-summary-card h2{
  font-family: "Cairo", Arial, sans-serif;
  font-size: 20px;
  font-weight: 800;
  color: #111;
  margin: 0 0 16px;
}

.checkout-form label,
.checkout-section label,
.form-label{
  display: block;
  font-family: "Cairo", Arial, sans-serif;
  font-size: 13px;
  font-weight: 800;
  color: #222;
  margin-bottom: 7px;
}

.checkout-form input,
.checkout-form textarea,
.checkout-form select,
.checkout-section input,
.checkout-section textarea,
.checkout-section select,
.checkout-input,
.checkout-select,
.checkout-textarea{
  width: 100%;
  min-height: 48px;
  border: 1px solid #ddd8cf;
  background: #fff;
  color: #111;
  padding: 11px 13px;
  font-family: "Cairo", Arial, sans-serif;
  font-size: 14px;
  outline: none;
  border-radius: 0;
}

.checkout-form textarea,
.checkout-section textarea,
.checkout-textarea{
  min-height: 110px;
  resize: vertical;
}

.checkout-form input:focus,
.checkout-form textarea:focus,
.checkout-form select:focus,
.checkout-section input:focus,
.checkout-section textarea:focus,
.checkout-section select:focus{
  border-color: #a88961;
  box-shadow: 0 0 0 2px rgba(168,137,97,.12);
}

.form-grid,
.checkout-fields{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.form-grid .full,
.checkout-fields .full,
.full-field{
  grid-column: 1 / -1;
}

.checkout-options,
.delivery-options,
.payment-options,
.order-type-options{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.checkout-option,
.delivery-option,
.payment-option,
.order-type-option{
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 64px;
  border: 1px solid #ddd8cf;
  background: #fff;
  padding: 14px;
  cursor: pointer;
  font-family: "Cairo", Arial, sans-serif;
  font-weight: 800;
  color: #111;
}

.checkout-option input,
.delivery-option input,
.payment-option input,
.order-type-option input{
  width: auto;
  min-height: auto;
  accent-color: #111;
}

.checkout-option:has(input:checked),
.delivery-option:has(input:checked),
.payment-option:has(input:checked),
.order-type-option:has(input:checked){
  border-color: #111;
  background: #faf9f6;
}

.checkout-option.active,
.delivery-option.active,
.payment-option.active,
.order-type-option.active{
  border-color: #111;
  background: #faf9f6;
}

.checkout-items,
.summary-items{
  display: grid;
  gap: 12px;
  margin-bottom: 18px;
}

.checkout-item,
.summary-item{
  display: grid;
  grid-template-columns: 70px 1fr auto;
  gap: 12px;
  align-items: center;
  padding-bottom: 12px;
  border-bottom: 1px solid #eee8df;
}

.checkout-item img,
.summary-item img{
  width: 70px;
  height: 70px;
  object-fit: contain;
  background: #f5f3ef;
  border: 1px solid #eee8df;
  padding: 6px;
}

.checkout-item-info,
.summary-item-info{
  min-width: 0;
}

.checkout-item-info strong,
.summary-item-info strong{
  display: block;
  font-family: "Cairo", Arial, sans-serif;
  font-size: 14px;
  font-weight: 800;
  color: #111;
  line-height: 1.35;
}

.checkout-item-info span,
.summary-item-info span,
.checkout-item-info small,
.summary-item-info small{
  display: block;
  color: #777;
  font-family: "Cairo", Arial, sans-serif;
  font-size: 12px;
  margin-top: 3px;
}

.checkout-item-price,
.summary-item-price{
  font-family: "Cairo", Arial, sans-serif;
  font-weight: 900;
  font-size: 14px;
  color: #111;
  text-align: right;
}

.checkout-total-row,
.summary-row,
.checkout-row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 12px 0;
  border-bottom: 1px solid #eee8df;
  font-family: "Cairo", Arial, sans-serif;
  color: #222;
}

.checkout-total-row strong,
.summary-row strong,
.checkout-row strong{
  font-weight: 900;
}

.checkout-total-row.total,
.summary-row.total,
.checkout-row.total,
.grand-total{
  border-bottom: 0;
  padding-top: 18px;
  font-size: 22px;
  font-weight: 900;
  color: #111;
}

.place-order-btn,
.checkout-submit,
.checkout-btn,
button.place-order-btn{
  width: 100%;
  min-height: 54px;
  border: 0;
  background: #111;
  color: #fff;
  font-family: "Cairo", Arial, sans-serif;
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .8px;
  cursor: pointer;
  margin-top: 18px;
  transition: .18s ease;
}

.place-order-btn:hover,
.checkout-submit:hover,
.checkout-btn:hover{
  background: #274c35;
}

.checkout-secondary-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  border: 1px solid #111;
  background: #fff;
  color: #111;
  padding: 10px 18px;
  font-family: "Cairo", Arial, sans-serif;
  font-weight: 800;
  text-transform: uppercase;
}

.checkout-note,
.checkout-help,
.checkout-warning{
  background: #faf9f6;
  border: 1px solid #ddd8cf;
  color: #555;
  padding: 12px 14px;
  margin-top: 12px;
  font-family: "Cairo", Arial, sans-serif;
  font-size: 13px;
  line-height: 1.6;
}

.checkout-warning{
  background: #fff8e6;
  border-color: #e0c27d;
  color: #684b12;
  font-weight: 700;
}

.checkout-error{
  background: #fff1f0;
  border: 1px solid #e3aaa5;
  color: #9f251c;
  padding: 12px 14px;
  margin: 0 0 18px;
  font-family: "Cairo", Arial, sans-serif;
  font-weight: 700;
}

.checkout-success{
  background: #eef8f1;
  border: 1px solid #9fd0ad;
  color: #1c6b3a;
  padding: 12px 14px;
  margin: 0 0 18px;
  font-family: "Cairo", Arial, sans-serif;
  font-weight: 700;
}

.checkout-empty,
.empty-checkout{
  max-width: 760px;
  margin: 50px auto;
  background: #fff;
  border: 1px dashed #ddd8cf;
  padding: 38px;
  text-align: center;
  font-family: "Cairo", Arial, sans-serif;
}

.checkout-empty h2,
.empty-checkout h2{
  margin: 0 0 10px;
  font-size: 26px;
}

.success-page{
  max-width: 880px;
  margin: 48px auto;
  background: #fff;
  border: 1px solid #ddd8cf;
  padding: 38px;
  text-align: center;
  font-family: "Cairo", Arial, sans-serif;
}

.success-icon{
  width: 64px;
  height: 64px;
  margin: 0 auto 16px;
  background: #274c35;
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 34px;
  font-weight: 900;
}

.order-no{
  display: inline-block;
  font-size: 22px;
  margin: 8px 0 24px;
}

.success-summary,
.success-items{
  max-width: 620px;
  margin: 22px auto;
  text-align: left;
  border-top: 1px solid #eee8df;
}

.success-summary div,
.success-items div{
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid #eee8df;
}

@media(max-width: 980px){
  .checkout-grid{
    grid-template-columns: 1fr;
  }

  .checkout-summary,
  .checkout-summary-card{
    position: static;
  }
}

@media(max-width: 620px){
  .checkout-page,
  .checkout-wrap,
  .checkout-shell{
    padding: 28px 16px 48px;
  }

  .checkout-title,
  .checkout-heading,
  .checkout-page h1{
    font-size: 28px;
  }

  .checkout-form-card,
  .checkout-summary,
  .checkout-summary-card,
  .checkout-card{
    padding: 20px 16px;
  }

  .form-grid,
  .checkout-fields{
    grid-template-columns: 1fr;
  }

  .checkout-options,
  .delivery-options,
  .payment-options,
  .order-type-options{
    grid-template-columns: 1fr;
  }

  .checkout-item,
  .summary-item{
    grid-template-columns: 58px 1fr;
  }

  .checkout-item-price,
  .summary-item-price{
    grid-column: 2;
    text-align: left;
  }

  .checkout-item img,
  .summary-item img{
    width: 58px;
    height: 58px;
  }

  .success-page{
    margin: 28px 16px;
    padding: 24px 18px;
  }

  .success-summary div,
  .success-items div{
    flex-direction: column;
    gap: 4px;
  }
}

@media (max-width: 768px){

  .harrods-header,
  .site-header,
  header{
    overflow-x: hidden;
  }

  .harrods-promo{
    font-size: 13px;
    line-height: 1.4;
    padding: 12px 10px;
    text-align: center;
    white-space: normal;
  }

  .harrods-main{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    padding: 18px 16px 12px !important;
    text-align: center;
  }

  .harrods-left,
  .harrods-location,
  .header-left{
    order: 1;
    justify-self: start;
    font-size: 14px;
    line-height: 1.5;
  }

  .harrods-logo{
    order: 2;
    justify-self: center !important;
    width: 100%;
    min-height: auto !important;
    padding: 0 !important;
    margin: 0 auto !important;
  }

  .harrods-logo img{
    max-width: 190px !important;
    max-height: 95px !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain;
  }

  .harrods-account{
    order: 3;
    justify-self: center !important;
    display: flex !important;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 7px !important;
    width: 100%;
    font-size: 13px !important;
    line-height: 1.3;
    padding: 0 !important;
    margin-top: 2px;
  }

  .harrods-account a{
    font-size: 13px !important;
    font-weight: 800;
    white-space: nowrap;
  }

  .account-separator{
    font-size: 12px;
    color: #a88961;
  }

  .harrods-icons,
  .header-icons{
    order: 4;
    justify-self: center !important;
    display: flex !important;
    justify-content: center;
    align-items: center;
    gap: 18px !important;
    width: 100%;
    margin-top: 6px;
  }

  .harrods-icons a,
  .header-icons a{
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .harrods-icons svg,
  .header-icons svg{
    width: 23px;
    height: 23px;
  }

  .harrods-nav{
    display: flex !important;
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
    gap: 24px !important;
    padding: 14px 16px !important;
    justify-content: flex-start !important;
    border-top: 1px solid #eee8df;
    scrollbar-width: none;
  }

  .harrods-nav::-webkit-scrollbar{
    display: none;
  }

  .harrods-nav a{
    flex: 0 0 auto;
    font-size: 14px !important;
    font-weight: 900;
  }

  .harrods-search,
  .header-search{
    padding: 0 16px 14px !important;
    margin: 0 !important;
  }

  .harrods-search form,
  .header-search form{
    display: grid !important;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 8px;
    border-bottom: 1px solid #111;
  }

  .harrods-search input,
  .header-search input{
    min-height: 44px;
    border: 0 !important;
    padding: 0 2px !important;
    font-size: 13px;
    background: transparent;
  }

  .harrods-search button,
  .header-search button{
    border: 0;
    background: transparent;
    font-size: 12px;
    font-weight: 900;
    padding: 0 0 0 8px;
  }
}

@media (max-width: 430px){

  .harrods-main{
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .harrods-logo img{
    max-width: 165px !important;
    max-height: 82px !important;
  }

  .harrods-account{
    gap: 5px !important;
  }

  .harrods-account a{
    font-size: 12px !important;
  }

  .harrods-icons,
  .header-icons{
    gap: 16px !important;
  }

  .harrods-nav{
    gap: 20px !important;
  }

  .harrods-nav a{
    font-size: 13px !important;
  }
}


/* ===== mobile_navigation.css ===== */

.kp-mobile-menu-btn{
  display:none;
}

.kp-mobile-drawer,
.kp-mobile-backdrop{
  display:none;
}

@media(max-width:768px){

  body.kp-menu-open{
    overflow:hidden;
  }

  .kp-mobile-menu-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:72px;
    min-height:38px;
    border:1px solid #a88961;
    background:#fff;
    color:#111;
    font-family:"Cairo", Arial, sans-serif;
    font-size:13px;
    font-weight:900;
    text-transform:uppercase;
    cursor:pointer;
    gap:8px;
  }

  .kp-mobile-menu-btn svg{
    width:18px;
    height:18px;
  }

  .kp-mobile-backdrop{
    display:block;
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.45);
    z-index:9990;
    opacity:0;
    pointer-events:none;
    transition:.22s ease;
  }

  body.kp-menu-open .kp-mobile-backdrop{
    opacity:1;
    pointer-events:auto;
  }

  .kp-mobile-drawer{
    display:flex;
    flex-direction:column;
    position:fixed;
    top:0;
    right:0;
    width:min(88vw, 380px);
    height:100vh;
    background:#173f35;
    color:#fff;
    z-index:9991;
    transform:translateX(100%);
    transition:.26s ease;
    box-shadow:-22px 0 55px rgba(0,0,0,.28);
    font-family:"Cairo", Arial, sans-serif;
  }

  body.kp-menu-open .kp-mobile-drawer{
    transform:translateX(0);
  }

  .kp-mobile-drawer-head{
    padding:20px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    border-bottom:1px solid rgba(216,192,144,.32);
  }

  .kp-mobile-drawer-logo{
    display:flex;
    align-items:center;
    gap:10px;
    color:#fff;
    font-weight:900;
    text-decoration:none;
  }

  .kp-mobile-drawer-logo img{
    width:62px;
    height:auto;
    object-fit:contain;
  }

  .kp-mobile-drawer-logo span{
    color:#d8c090;
    font-size:15px;
    letter-spacing:.4px;
  }

  .kp-mobile-close{
    width:40px;
    height:40px;
    border:1px solid rgba(255,255,255,.35);
    background:transparent;
    color:#fff;
    font-size:28px;
    line-height:1;
    cursor:pointer;
  }

  .kp-mobile-drawer-body{
    padding:18px 20px 28px;
    overflow:auto;
  }

  .kp-mobile-account{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
    margin-bottom:18px;
  }

  .kp-mobile-account a{
    min-height:42px;
    display:flex;
    align-items:center;
    justify-content:center;
    border:1px solid rgba(216,192,144,.5);
    color:#fff;
    text-decoration:none;
    font-size:13px;
    font-weight:900;
  }

  .kp-mobile-account a.primary{
    background:#d8c090;
    color:#173f35;
  }

  .kp-mobile-nav{
    display:grid;
    gap:0;
    border-top:1px solid rgba(255,255,255,.16);
  }

  .kp-mobile-nav a{
    display:flex;
    align-items:center;
    justify-content:space-between;
    min-height:52px;
    border-bottom:1px solid rgba(255,255,255,.16);
    color:#fff;
    text-decoration:none;
    font-size:16px;
    font-weight:800;
  }

  .kp-mobile-nav a::after{
    content:"›";
    color:#d8c090;
    font-size:24px;
    line-height:1;
  }

  .kp-mobile-search{
    margin:18px 0;
    border:1px solid rgba(216,192,144,.45);
    display:grid;
    grid-template-columns:1fr auto;
    background:rgba(255,255,255,.06);
  }

  .kp-mobile-search input{
    min-height:46px;
    border:0;
    background:transparent;
    color:#fff;
    padding:0 12px;
    font-family:"Cairo", Arial, sans-serif;
    outline:none;
  }

  .kp-mobile-search input::placeholder{
    color:rgba(255,255,255,.65);
  }

  .kp-mobile-search button{
    border:0;
    border-left:1px solid rgba(216,192,144,.35);
    background:transparent;
    color:#d8c090;
    padding:0 14px;
    font-weight:900;
    cursor:pointer;
  }

  .kp-mobile-mini-links{
    margin-top:18px;
    display:flex;
    flex-wrap:wrap;
    gap:8px;
  }

  .kp-mobile-mini-links a{
    color:#d8c090;
    font-size:12px;
    text-decoration:underline;
  }

  
  .harrods-account{
    display:none !important;
  }

  .harrods-nav{
    display:none !important;
  }

  .harrods-main{
    display:grid !important;
    grid-template-columns:1fr auto 1fr !important;
    align-items:center !important;
    gap:10px !important;
    padding:16px 14px 12px !important;
  }

  .harrods-left,
  .harrods-location,
  .header-left{
    justify-self:start !important;
    font-size:13px !important;
    line-height:1.4;
  }

  .harrods-logo{
    justify-self:center !important;
    min-height:auto !important;
    width:auto !important;
  }

  .harrods-logo img{
    max-width:170px !important;
    max-height:86px !important;
    object-fit:contain !important;
  }

  .harrods-icons,
  .header-icons{
    justify-self:end !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-end !important;
    gap:12px !important;
    width:auto !important;
  }

  .harrods-icons a,
  .header-icons a{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
  }

  .harrods-icons svg,
  .header-icons svg{
    width:22px !important;
    height:22px !important;
  }

  .harrods-search,
  .header-search{
    padding:0 14px 14px !important;
  }

  .harrods-search form,
  .header-search form{
    display:grid !important;
    grid-template-columns:1fr auto;
    border-bottom:1px solid #111;
  }

  .harrods-search input,
  .header-search input{
    border:0 !important;
    background:transparent;
    min-height:42px;
    padding:0 2px !important;
  }

  .harrods-search button,
  .header-search button{
    border:0;
    background:transparent;
    font-weight:900;
    font-size:12px;
  }
}

@media(max-width:430px){
  .kp-mobile-menu-btn{
    min-width:64px;
    font-size:12px;
  }

  .harrods-logo img{
    max-width:150px !important;
    max-height:78px !important;
  }

  .harrods-icons,
  .header-icons{
    gap:10px !important;
  }
}

@media(max-width:768px){
  .kp-mobile-menu-target{
    display:initial;
  }

  .kp-mobile-drawer.kp-mobile-menu-target{
    display:flex;
  }

  body.kp-menu-open .kp-mobile-drawer.kp-mobile-menu-target{
    display:flex !important;
  }
}


/* ===== mini_cart.css ===== */

body.mini-cart-open{overflow:hidden}

.mini-cart-backdrop{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.45);
  z-index:11500;
  opacity:0;
  pointer-events:none;
  transition:.22s ease;
}

body.mini-cart-open .mini-cart-backdrop{
  opacity:1;
  pointer-events:auto;
}

.mini-cart-drawer{
  position:fixed;
  top:0;
  right:0;
  width:min(92vw,430px);
  height:100vh;
  background:#fff;
  z-index:11501;
  transform:translateX(100%);
  transition:.28s ease;
  box-shadow:-24px 0 70px rgba(0,0,0,.24);
  display:flex;
  flex-direction:column;
  font-family:"Cairo",Arial,sans-serif;
}

body.mini-cart-open .mini-cart-drawer{transform:translateX(0)}

.mini-cart-head{
  padding:20px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  border-bottom:1px solid #eee8df;
}

.mini-cart-head span{
  display:block;
  color:#8a6a45;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:1px;
  margin-bottom:3px;
}

.mini-cart-head h2{
  margin:0;
  color:#111;
  font-size:26px;
}

.mini-cart-close{
  width:40px;
  height:40px;
  border:1px solid #ddd8cf;
  background:#fff;
  color:#111;
  font-size:28px;
  line-height:1;
  cursor:pointer;
}

.mini-cart-body{
  flex:1;
  overflow:auto;
  padding:14px 18px;
}

.mini-cart-item{
  display:grid;
  grid-template-columns:94px 1fr;
  gap:14px;
  padding:14px 0;
  border-bottom:1px solid #eee8df;
}

.mini-cart-img{
  width:94px;
  height:112px;
  background:#faf9f6;
  border:1px solid #eee8df;
  display:flex;
  align-items:center;
  justify-content:center;
}

.mini-cart-img img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:9px;
}

.mini-cart-info span{
  display:block;
  color:#8a6a45;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.6px;
  margin-bottom:4px;
}

.mini-cart-name{
  display:block;
  color:#111;
  font-size:15px;
  line-height:1.35;
  font-weight:800;
  text-decoration:none;
}

.mini-cart-info small{
  display:block;
  color:#777;
  margin-top:5px;
  font-size:12px;
}

.mini-cart-line{
  margin-top:10px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.mini-cart-line strong{
  color:#111;
  font-size:14px;
}

.mini-cart-line button{
  border:0;
  background:transparent;
  color:#9f251c;
  font-size:12px;
  font-weight:900;
  cursor:pointer;
  text-decoration:underline;
}

.mini-cart-qty{
  margin-top:10px;
  display:inline-grid;
  grid-template-columns:34px 52px 34px;
  border:1px solid #ddd8cf;
}

.mini-cart-qty button{
  border:0;
  background:#faf9f6;
  color:#111;
  font-size:18px;
  cursor:pointer;
}

.mini-cart-qty input{
  border:0;
  border-left:1px solid #ddd8cf;
  border-right:1px solid #ddd8cf;
  min-height:34px;
  text-align:center;
  font-size:13px;
}

.mini-cart-footer{
  border-top:1px solid #eee8df;
  padding:18px 20px 20px;
  background:#fff;
}

.mini-cart-subtotal{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:8px;
}

.mini-cart-subtotal span{
  color:#555;
  font-weight:900;
  text-transform:uppercase;
  font-size:12px;
  letter-spacing:.7px;
}

.mini-cart-subtotal strong{
  color:#111;
  font-size:22px;
}

.mini-cart-footer p{
  margin:0 0 14px;
  color:#777;
  font-size:12px;
  line-height:1.5;
}

.mini-cart-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}

.mini-cart-btn{
  min-height:46px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  border:1px solid #111;
}

.mini-cart-btn.light{background:#fff;color:#111}

.mini-cart-btn.dark{background:#111;color:#fff}

.mini-cart-btn.dark:hover{background:#173f35;border-color:#173f35}

.mini-cart-empty{
  padding:50px 20px;
  text-align:center;
}

.mini-cart-empty h3{
  margin:0 0 8px;
  color:#111;
  font-size:22px;
}

.mini-cart-empty p{
  color:#666;
  line-height:1.6;
}

.mini-cart-empty a{
  min-height:42px;
  display:inline-flex;
  align-items:center;
  padding:0 16px;
  background:#111;
  color:#fff;
  text-decoration:none;
  font-weight:900;
  text-transform:uppercase;
  margin-top:10px;
}

@media(max-width:520px){
  .mini-cart-head{padding:16px}
  .mini-cart-body{padding:10px 14px}
  .mini-cart-item{grid-template-columns:82px 1fr}
  .mini-cart-img{width:82px;height:100px}
  .mini-cart-actions{grid-template-columns:1fr}
}


/* ===== quick_shop.css ===== */

.quick-card-actions{display:flex;gap:8px;justify-content:center;margin-top:12px;flex-wrap:wrap}

.quick-card-actions button,.quick-card-actions a{min-height:36px;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;border:1px solid #111;background:#fff;color:#111;font-family:"Cairo",Arial,sans-serif;font-size:12px;font-weight:900;text-transform:uppercase;cursor:pointer}

.quick-card-actions button:hover,.quick-card-actions a:hover{background:#111;color:#fff}

.quick-shop-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.48);z-index:11000;opacity:0;pointer-events:none;transition:.22s ease}

.quick-shop-modal{position:fixed;top:50%;left:50%;width:min(94vw,920px);max-height:90vh;overflow:auto;transform:translate(-50%,-45%) scale(.98);background:#fff;border:1px solid #ddd8cf;z-index:11001;opacity:0;pointer-events:none;transition:.22s ease;box-shadow:0 28px 80px rgba(0,0,0,.28);font-family:"Cairo",Arial,sans-serif}

body.quick-shop-open{overflow:hidden}

body.quick-shop-open .quick-shop-backdrop,body.quick-shop-open .quick-shop-modal{opacity:1;pointer-events:auto}

body.quick-shop-open .quick-shop-modal{transform:translate(-50%,-50%) scale(1)}

.quick-shop-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid #eee8df}

.quick-shop-head strong{color:#111;font-size:20px}

.quick-shop-head button{width:40px;height:40px;border:1px solid #ddd8cf;background:#fff;color:#111;font-size:28px;line-height:1;cursor:pointer}

.quick-shop-body{padding:24px}

.quick-shop-product{display:grid;grid-template-columns:380px minmax(0,1fr);gap:28px;align-items:start}

.quick-shop-image{background:#faf9f6;border:1px solid #eee8df;min-height:430px;display:flex;align-items:center;justify-content:center}

.quick-shop-image img{width:100%;height:100%;max-height:430px;object-fit:contain;padding:34px}

.quick-brand{display:block;color:#8a6a45;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}

.quick-shop-details h2{margin:0 0 8px;color:#111;font-size:30px;line-height:1.18}

.quick-shop-details h3{margin:0 0 12px;color:#555;font-size:20px;font-weight:700}

.quick-shop-details p{color:#555;line-height:1.8;margin:0 0 18px}

.quick-shop-form label{display:block;font-weight:900;color:#111;margin-bottom:8px}

.quick-variants{display:grid;gap:9px;margin-bottom:18px}

.quick-variant{display:flex!important;align-items:center;justify-content:space-between;gap:12px;border:1px solid #ddd8cf;padding:12px;cursor:pointer;transition:.15s ease}

.quick-variant.selected,.quick-variant:hover{border-color:#111;background:#faf9f6}

.quick-variant input{display:none}

.quick-variant strong{display:block;color:#111}

.quick-variant small{display:block;color:#777;margin-top:2px}

.quick-variant em{font-style:normal;color:#777;font-size:12px;font-weight:800;white-space:nowrap}

.quick-qty-row{margin:18px 0}

.quick-qty{display:inline-grid;grid-template-columns:42px 72px 42px;border:1px solid #ddd8cf}

.quick-qty button{border:0;background:#faf9f6;font-size:20px;cursor:pointer}

.quick-qty input{border:0;border-left:1px solid #ddd8cf;border-right:1px solid #ddd8cf;text-align:center;min-height:42px}

.quick-add-main{width:100%;min-height:52px;border:0;background:#111;color:#fff;font-weight:900;text-transform:uppercase;cursor:pointer;font-family:"Cairo",Arial,sans-serif}

.quick-add-main:hover{background:#173f35}

.quick-view-full{display:flex;justify-content:center;margin-top:12px;color:#111;font-weight:900;text-transform:uppercase;font-size:12px;text-decoration:underline}

.quick-shop-loading,.quick-shop-error{padding:38px;text-align:center;font-weight:900;color:#111}

.quick-shop-error{color:#9f251c}

.quick-shop-toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(20px);background:#111;color:#fff;z-index:12000;padding:12px 18px;font-family:"Cairo",Arial,sans-serif;font-weight:900;opacity:0;pointer-events:none;transition:.22s ease}

.quick-shop-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media(max-width:780px){
  .quick-shop-product{grid-template-columns:1fr}
  .quick-shop-image{min-height:300px}
  .quick-shop-image img{max-height:300px}
  .quick-shop-details h2{font-size:24px}
  .quick-shop-body{padding:18px}
}


/* ===== products_search.css ===== */

.products-page{
  background:#f7f5f1;
  padding:44px 5vw 76px;
  font-family:"Cairo", Arial, sans-serif;
}

.products-hero{
  max-width:1480px;
  margin:0 auto 28px;
  background:#173f35;
  color:#fff;
  padding:46px;
  position:relative;
  overflow:hidden;
}

.products-hero::after{
  content:"";
  position:absolute;
  width:360px;
  height:360px;
  border:1px solid rgba(216,192,144,.34);
  border-radius:50%;
  right:-120px;
  bottom:-150px;
}

.products-hero span{
  display:block;
  color:#d8c090;
  font-size:12px;
  font-weight:900;
  letter-spacing:1.5px;
  text-transform:uppercase;
}

.products-hero h1{
  margin:8px 0 12px;
  font-size:46px;
  line-height:1.1;
}

.products-hero p{
  max-width:760px;
  margin:0;
  color:rgba(255,255,255,.84);
  line-height:1.8;
  font-size:16px;
}

.products-layout{
  max-width:1480px;
  margin:0 auto;
  display:grid;
  grid-template-columns:280px minmax(0, 1fr);
  gap:24px;
  align-items:start;
}

.products-filter{
  background:#fff;
  border:1px solid #ddd8cf;
  padding:20px;
  position:sticky;
  top:170px;
}

.products-filter h2{
  margin:0 0 16px;
  font-size:20px;
}

.products-filter form{
  display:grid;
  gap:10px;
}

.products-filter label{
  font-size:13px;
  font-weight:900;
  color:#111;
}

.products-filter input,
.products-filter select{
  min-height:44px;
  border:1px solid #ddd8cf;
  padding:8px 10px;
  font-family:"Cairo", Arial, sans-serif;
  background:#fff;
}

.products-filter button{
  min-height:46px;
  border:0;
  background:#111;
  color:#fff;
  font-weight:900;
  text-transform:uppercase;
  cursor:pointer;
  margin-top:8px;
}

.products-filter a{
  display:flex;
  min-height:38px;
  align-items:center;
  justify-content:center;
  color:#111;
  font-weight:900;
  border:1px solid #111;
}

.products-toolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  background:#fff;
  border:1px solid #ddd8cf;
  padding:16px 20px;
  margin-bottom:22px;
}

.products-toolbar strong{
  color:#111;
  font-size:22px;
}

.products-toolbar span{
  color:#666;
  margin-left:5px;
}

.products-toolbar a{
  display:inline-flex;
  min-height:38px;
  align-items:center;
  padding:0 14px;
  border:1px solid #111;
  color:#111;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
}

.products-toolbar a:hover{
  background:#111;
  color:#fff;
}

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

.product-card{
  background:#fff;
  border:1px solid #ddd8cf;
  transition:.2s ease;
}

.product-card:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 36px rgba(0,0,0,.08);
}

.product-image{
  height:360px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  overflow:hidden;
}

.product-image img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:34px;
  transition:.25s ease;
}

.product-card:hover .product-image img{
  transform:scale(1.035);
}

.product-info{
  padding:18px;
  text-align:center;
  border-top:1px solid #eee8df;
}

.product-info strong{
  display:block;
  color:#111;
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.6px;
  margin-bottom:6px;
}

.product-info a{
  display:block;
  color:#333;
  font-size:16px;
  line-height:1.4;
}

.product-info small{
  display:block;
  color:#777;
  margin-top:6px;
  font-size:14px;
}

.product-info b{
  display:block;
  color:#111;
  margin-top:10px;
  font-size:15px;
}

.products-empty{
  background:#fff;
  border:1px dashed #ddd8cf;
  text-align:center;
  padding:46px 24px;
}

.products-empty h2{
  margin:0 0 8px;
}

.products-empty p{
  color:#666;
  max-width:620px;
  margin:0 auto 16px;
  line-height:1.7;
}

.products-empty a{
  display:inline-flex;
  min-height:42px;
  align-items:center;
  padding:0 16px;
  background:#111;
  color:#fff;
  font-weight:900;
  text-transform:uppercase;
}

.products-pagination{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:center;
  margin-top:28px;
}

.products-pagination a{
  min-width:40px;
  min-height:40px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  border:1px solid #ddd8cf;
  color:#111;
  font-weight:900;
}

.products-pagination a.active{
  background:#111;
  color:#fff;
}

@media(max-width:1100px){
  .products-layout{
    grid-template-columns:1fr;
  }

  .products-filter{
    position:static;
  }

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

@media(max-width:760px){
  .products-page{
    padding:28px 16px 52px;
  }

  .products-hero{
    padding:28px 20px;
  }

  .products-hero h1{
    font-size:32px;
  }

  .products-grid{
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:14px;
  }

  .products-toolbar{
    flex-direction:column;
    align-items:flex-start;
  }

  .product-image{
    height:260px;
  }
}

@media(max-width:430px){
  .product-image{
    height:230px;
  }

  .product-image img{
    padding:22px;
  }

  .product-info{
    padding:14px 10px;
  }

  .product-info a{
    font-size:14px;
  }
}


/* ===== products_filters.css ===== */

.enhanced-products-page .products-filter{
  position:sticky;
  top:170px;
}

.price-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}

.filter-check{
  display:flex!important;
  align-items:center;
  gap:10px;
  padding:12px;
  border:1px solid #ddd8cf;
  background:#faf9f6;
}

.filter-check input{
  width:auto!important;
  min-height:auto!important;
}

.filter-head-mobile{
  display:flex;
  align-items:center;
  justify-content:space-between;
}

.filter-head-mobile button{
  display:none;
}

.mobile-filter-bar{
  display:none;
}

.products-error{
  background:#fff1f0;
  border:1px solid #e3aaa5;
  color:#9f251c;
  padding:14px;
  margin-bottom:16px;
  font-family:"Cairo",Arial,sans-serif;
  font-weight:800;
}

.product-badges{
  position:absolute;
  top:12px;
  left:12px;
  display:flex;
  flex-direction:column;
  gap:6px;
  z-index:2;
}

.product-image{
  position:relative;
}

.product-badges span{
  background:#111;
  color:#fff;
  padding:5px 8px;
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.6px;
}

.product-meta-line{
  display:flex;
  gap:8px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:9px;
}

.product-meta-line span{
  color:#777;
  font-size:11px;
  font-weight:800;
  text-transform:uppercase;
}

.products-auto-load-sentinel{
  margin:24px auto 0;
  min-height:34px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.products-auto-load-hint,
.products-end-message{
  color:#8a6a45;
  font-family:"Cairo",Arial,sans-serif;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.8px;
}

.products-load-more-wrap{
  display:flex;
  justify-content:center;
  margin-top:18px;
}

.products-load-more-btn{
  min-width:190px;
  min-height:48px;
  border:1px solid #111;
  background:#111;
  color:#fff;
  font-family:"Cairo",Arial,sans-serif;
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.6px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}

.products-load-more-btn:hover{
  background:#173f35;
  border-color:#173f35;
}

.products-load-more-btn:disabled{
  opacity:.75;
  cursor:not-allowed;
}

.products-loader-icon{
  width:18px;
  height:18px;
  border:2px solid rgba(255,255,255,.35);
  border-top-color:#fff;
  border-radius:50%;
  display:none;
}

.products-load-more-btn.loading .products-loader-icon{
  display:inline-block;
  animation:productsSpin .75s linear infinite;
}

@keyframes productsSpin{
  to{ transform:rotate(360deg); }
}

.product-enter{
  opacity:0;
  transform:translateY(14px);
  transition:.28s ease;
}

.product-enter.show{
  opacity:1;
  transform:translateY(0);
}

@media(max-width:1100px){
  .mobile-filter-bar{
    max-width:1480px;
    margin:0 auto 16px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    background:#fff;
    border:1px solid #ddd8cf;
    padding:12px 14px;
    font-family:"Cairo",Arial,sans-serif;
  }

  .mobile-filter-bar button{
    min-height:40px;
    border:1px solid #111;
    background:#111;
    color:#fff;
    padding:0 14px;
    font-weight:900;
    text-transform:uppercase;
  }

  .mobile-filter-bar span{
    color:#555;
    font-weight:800;
  }

  .products-filter-backdrop{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.45);
    z-index:9000;
    opacity:0;
    pointer-events:none;
    transition:.22s ease;
  }

  .products-filter{
    position:fixed!important;
    top:0!important;
    left:0;
    bottom:0;
    width:min(88vw,380px);
    z-index:9001;
    overflow:auto;
    transform:translateX(-100%);
    transition:.25s ease;
    box-shadow:22px 0 55px rgba(0,0,0,.22);
  }

  body.products-filter-open{
    overflow:hidden;
  }

  body.products-filter-open .products-filter{
    transform:translateX(0);
  }

  body.products-filter-open .products-filter-backdrop{
    opacity:1;
    pointer-events:auto;
  }

  .filter-head-mobile button{
    display:inline-flex;
    width:38px;
    height:38px;
    border:1px solid #ddd8cf;
    background:#fff;
    align-items:center;
    justify-content:center;
    font-size:26px;
    line-height:1;
    cursor:pointer;
  }
}

@media(max-width:520px){
  .price-row{
    grid-template-columns:1fr;
  }

  .mobile-filter-bar{
    margin-bottom:14px;
  }
}

.products-page{
  overflow-x:hidden;
}

.products-layout{
  max-width:1480px !important;
  margin:0 auto !important;
  display:grid !important;
  grid-template-columns:280px minmax(0, 1fr) !important;
  gap:24px !important;
  align-items:start !important;
}

.products-filter{
  width:100% !important;
  max-width:280px !important;
  grid-column:1 !important;
}

.products-main{
  grid-column:2 !important;
  min-width:0 !important;
}

.products-grid{
  width:100% !important;
  display:grid !important;
  grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
  gap:24px !important;
}

.product-card{
  width:100% !important;
  min-width:0 !important;
}

.product-image{
  width:100% !important;
  height:360px !important;
}

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

.products-filter form{
  width:100% !important;
}

.products-filter input,
.products-filter select{
  width:100% !important;
  box-sizing:border-box !important;
}

.price-row{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:10px !important;
}

.products-toolbar{
  width:100% !important;
}

.mobile-filter-bar{
  display:none !important;
}

@media(max-width:1100px){
  .products-layout{
    display:block !important;
  }

  .products-main{
    width:100% !important;
  }

  .products-grid{
    grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
  }

  .mobile-filter-bar{
    max-width:1480px;
    margin:0 auto 16px;
    display:flex !important;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    background:#fff;
    border:1px solid #ddd8cf;
    padding:12px 14px;
  }

  .products-filter{
    max-width:none !important;
  }
}

@media(max-width:760px){
  .products-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
    gap:14px !important;
  }

  .product-image{
    height:250px !important;
  }
}

@media(max-width:430px){
  .products-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
    gap:12px !important;
  }

  .product-image{
    height:220px !important;
  }

  .product-info{
    padding:12px 8px !important;
  }

  .product-info a{
    font-size:14px !important;
  }
}


/* ===== arrivals.css ===== */

.arrivals-page{
  background:#f7f5f1;
  padding:44px 5vw 76px;
  font-family:"Cairo", Arial, sans-serif;
}

.arrivals-hero{
  max-width:1480px;
  margin:0 auto 28px;
  background:#173f35;
  color:#fff;
  padding:46px;
  position:relative;
  overflow:hidden;
}

.arrivals-hero::after{
  content:"";
  position:absolute;
  width:360px;
  height:360px;
  border:1px solid rgba(216,192,144,.34);
  border-radius:50%;
  right:-120px;
  bottom:-150px;
}

.arrivals-hero span{
  display:block;
  color:#d8c090;
  font-size:12px;
  font-weight:900;
  letter-spacing:1.5px;
  text-transform:uppercase;
}

.arrivals-hero h1{
  margin:8px 0 12px;
  font-size:48px;
  line-height:1.1;
}

.arrivals-hero p{
  max-width:740px;
  margin:0;
  color:rgba(255,255,255,.84);
  line-height:1.8;
  font-size:16px;
}

.arrivals-toolbar{
  max-width:1480px;
  margin:0 auto 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  background:#fff;
  border:1px solid #ddd8cf;
  padding:16px 20px;
}

.arrivals-toolbar strong{
  color:#111;
  font-size:22px;
}

.arrivals-toolbar span{
  color:#666;
  margin-left:5px;
}

.arrivals-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.arrivals-actions a{
  display:inline-flex;
  min-height:38px;
  align-items:center;
  padding:0 14px;
  border:1px solid #111;
  color:#111;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
}

.arrivals-actions a:hover{
  background:#111;
  color:#fff;
}

.arrivals-grid{
  max-width:1480px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:24px;
}

.arrival-card{
  background:#fff;
  border:1px solid #ddd8cf;
  transition:.2s ease;
}

.arrival-card:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 36px rgba(0,0,0,.08);
}

.arrival-image{
  height:360px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  position:relative;
  overflow:hidden;
}

.arrival-image img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:34px;
  transition:.25s ease;
}

.arrival-card:hover .arrival-image img{
  transform:scale(1.035);
}

.arrival-image span{
  position:absolute;
  top:14px;
  left:14px;
  background:#111;
  color:#fff;
  padding:6px 10px;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.7px;
}

.arrival-info{
  padding:18px;
  text-align:center;
  border-top:1px solid #eee8df;
}

.arrival-info strong{
  display:block;
  color:#111;
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.6px;
  margin-bottom:6px;
}

.arrival-info a{
  display:block;
  color:#333;
  font-size:16px;
  line-height:1.4;
}

.arrival-info small{
  display:block;
  color:#777;
  margin-top:6px;
  font-size:14px;
}

.arrival-info b{
  display:block;
  color:#111;
  margin-top:10px;
  font-size:15px;
}

.arrivals-empty{
  max-width:720px;
  margin:40px auto;
  background:#fff;
  border:1px dashed #ddd8cf;
  padding:42px 24px;
  text-align:center;
}

.arrivals-empty h2{
  margin:0 0 8px;
}

.arrivals-empty p{
  color:#666;
}

.arrivals-empty a{
  display:inline-flex;
  min-height:44px;
  align-items:center;
  justify-content:center;
  padding:0 18px;
  background:#111;
  color:#fff;
  font-weight:900;
  text-transform:uppercase;
  margin-top:10px;
}

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

@media(max-width:760px){
  .arrivals-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:14px;
  }

  .arrivals-toolbar{
    flex-direction:column;
    align-items:flex-start;
  }

  .arrival-image{
    height:280px;
  }
}

@media(max-width:520px){
  .arrivals-page{
    padding:28px 16px 52px;
  }

  .arrivals-hero{
    padding:28px 20px;
  }

  .arrivals-hero h1{
    font-size:34px;
  }

  .arrival-image{
    height:240px;
  }

  .arrival-image img{
    padding:22px;
  }

  .arrival-info{
    padding:14px 10px;
  }

  .arrival-info a{
    font-size:14px;
  }
}


/* ===== brands.css ===== */

.brands-page,.brand-page{background:#f7f5f1;padding:44px 5vw 76px;font-family:"Cairo",Arial,sans-serif}

.brands-hero,.brand-hero{max-width:1480px;margin:0 auto 28px;background:#173f35;color:#fff;padding:46px;position:relative;overflow:hidden}

.brands-hero::after,.brand-hero::after{content:"";position:absolute;width:360px;height:360px;border:1px solid rgba(216,192,144,.34);border-radius:50%;right:-120px;bottom:-150px}

.brands-hero span,.brand-hero span{display:block;color:#d8c090;font-size:12px;font-weight:900;letter-spacing:1.5px;text-transform:uppercase}

.brands-hero h1,.brand-hero h1{margin:8px 0 12px;font-size:48px;line-height:1.1}

.brands-hero p,.brand-hero p{max-width:760px;margin:0;color:rgba(255,255,255,.84);line-height:1.8;font-size:16px}

.brands-toolbar,.brand-toolbar{max-width:1480px;margin:0 auto 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;background:#fff;border:1px solid #ddd8cf;padding:16px 20px}

.brands-toolbar strong{color:#111;font-size:22px}

.brands-toolbar a,.brand-toolbar a,.brands-empty a{display:inline-flex;min-height:38px;align-items:center;padding:0 14px;border:1px solid #111;color:#111;font-size:12px;font-weight:900;text-transform:uppercase}

.brands-toolbar a:hover,.brand-toolbar a:hover,.brands-empty a:hover{background:#111;color:#fff}

.brands-grid,.brand-products-grid{max-width:1480px;margin:0 auto;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:22px}

.brand-card,.brand-product-card{background:#fff;border:1px solid #ddd8cf;transition:.2s ease}

.brand-card:hover,.brand-product-card:hover{transform:translateY(-3px);box-shadow:0 18px 36px rgba(0,0,0,.08)}

.brand-card-inner{display:block;color:#111;text-decoration:none;height:100%}

.brand-logo-box{height:220px;display:flex;align-items:center;justify-content:center;background:#fff;border-bottom:1px solid #eee8df;overflow:hidden}

.brand-logo-box img{width:100%;height:100%;object-fit:contain;padding:38px}

.brand-logo-box span,.brand-hero-logo span{width:92px;height:92px;border-radius:50%;background:#173f35;color:#d8c090;display:flex;align-items:center;justify-content:center;font-size:42px;font-weight:900;border:1px solid rgba(216,192,144,.5)}

.brand-info{padding:20px;text-align:center}

.brand-info h2{margin:0 0 8px;font-size:22px}

.brand-info p{min-height:54px;margin:0 0 14px;color:#666;line-height:1.6;font-size:14px}

.brand-info strong{color:#8a6a45;font-size:13px;font-weight:900;text-transform:uppercase}

.brands-empty{max-width:760px;margin:42px auto;background:#fff;border:1px dashed #ddd8cf;text-align:center;padding:42px 24px}

.brands-empty h2{margin:0 0 8px}

.brands-empty p{color:#666}

.brand-hero{display:grid;grid-template-columns:160px 1fr;gap:26px;align-items:center}

.brand-hero-logo{position:relative;z-index:1;width:150px;height:150px;background:#fff;border:1px solid rgba(216,192,144,.35);display:flex;align-items:center;justify-content:center}

.brand-hero-logo img{width:100%;height:100%;object-fit:contain;padding:18px}

.brand-hero-logo span{background:#fff;color:#173f35}

.brand-toolbar div{display:flex;align-items:center;gap:8px;color:#777;font-size:13px;font-weight:800;text-transform:uppercase}

.brand-toolbar b{color:#111}

.brand-product-image{height:360px;display:flex;align-items:center;justify-content:center;background:#fff;overflow:hidden}

.brand-product-image img{width:100%;height:100%;object-fit:contain;padding:34px;transition:.25s ease}

.brand-product-card:hover .brand-product-image img{transform:scale(1.035)}

.brand-product-info{padding:18px;text-align:center;border-top:1px solid #eee8df}

.brand-product-info strong{display:block;color:#111;font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px}

.brand-product-info a{display:block;color:#333;font-size:16px;line-height:1.4}

.brand-product-info small{display:block;color:#777;margin-top:6px;font-size:14px}

.brand-product-info b{display:block;color:#111;margin-top:10px;font-size:15px}

@media(max-width:1100px){.brands-grid,.brand-products-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}

@media(max-width:760px){.brands-grid,.brand-products-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.brands-toolbar,.brand-toolbar{flex-direction:column;align-items:flex-start}.brand-hero{grid-template-columns:1fr}.brand-product-image{height:280px}}

@media(max-width:520px){.brands-page,.brand-page{padding:28px 16px 52px}.brands-hero,.brand-hero{padding:28px 20px}.brands-hero h1,.brand-hero h1{font-size:34px}.brand-logo-box{height:170px}.brand-product-image{height:240px}.brand-product-image img{padding:22px}.brand-product-info{padding:14px 10px}.brand-product-info a{font-size:14px}}


/* ===== brand_load_more.css ===== */

.brand-load-more-wrap{
  max-width:1480px;
  margin:30px auto 0;
  display:flex;
  justify-content:center;
}

.brand-load-more-btn{
  min-width:190px;
  min-height:48px;
  border:1px solid #111;
  background:#111;
  color:#fff;
  font-family:"Cairo", Arial, sans-serif;
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.6px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  transition:.18s ease;
}

.brand-load-more-btn:hover{
  background:#173f35;
  border-color:#173f35;
}

.brand-load-more-btn:disabled{
  opacity:.75;
  cursor:not-allowed;
}

.brand-loader-icon{
  width:18px;
  height:18px;
  border:2px solid rgba(255,255,255,.35);
  border-top-color:#fff;
  border-radius:50%;
  display:none;
}

.brand-load-more-btn.loading .brand-loader-icon{
  display:inline-block;
  animation:brandSpin .75s linear infinite;
}

@keyframes brandSpin{
  to{ transform:rotate(360deg); }
}

.brand-product-enter{
  opacity:0;
  transform:translateY(14px);
  transition:.28s ease;
}

.brand-product-enter.show{
  opacity:1;
  transform:translateY(0);
}


/* ===== brand_auto_load.css ===== */

.brand-auto-load-sentinel{
  max-width:1480px;
  margin:18px auto 0;
  min-height:34px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.brand-auto-load-hint{
  color:#777;
  font-family:"Cairo", Arial, sans-serif;
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.7px;
}

.brand-end-message{
  color:#8a6a45;
  font-family:"Cairo", Arial, sans-serif;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.8px;
}

.brand-load-more-wrap{
  margin-top:18px;
}

.brand-load-more-btn{
  opacity:.95;
}

.brand-load-more-btn span::after{
  content:"";
}


/* ===== luxury_product_page.css ===== */

.lux-pdp{background:#f7f5f1;padding:34px 5vw 70px}

.lux-pdp-breadcrumb{max-width:1480px;margin:0 auto 24px;display:flex;gap:9px;align-items:center;font-family:"Cairo",Arial,sans-serif;font-size:13px;text-transform:uppercase;letter-spacing:1px;font-weight:800;color:#8a6a45}

.lux-pdp-breadcrumb a{color:#8a6a45}

.lux-pdp-main{max-width:1480px;margin:0 auto;display:grid;grid-template-columns:minmax(0,1.08fr) minmax(430px,.92fr);gap:42px;align-items:start}

.lux-gallery-card{background:#fff;border:1px solid #ddd8cf;min-height:680px;position:relative;display:flex;align-items:center;justify-content:center;padding:38px}

.lux-product-badges{position:absolute;top:22px;left:22px;right:22px;display:flex;gap:8px;flex-wrap:wrap;z-index:2}

.lux-product-badges span{background:#111;color:#fff;padding:7px 10px;font-family:"Cairo",Arial,sans-serif;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.6px}

.lux-image-frame{width:100%;height:600px;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#fff,#fbfaf7)}

.lux-image-frame img{width:100%;height:100%;object-fit:contain;padding:36px;filter:drop-shadow(0 26px 24px rgba(0,0,0,.13))}

.lux-product-panel{background:#fff;border:1px solid #ddd8cf;padding:38px;position:sticky;top:190px}

.lux-brand{display:block;font-family:"Cairo",Arial,sans-serif;font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:1.4px;color:#8a6a45;margin-bottom:10px}

.lux-product-panel h1{margin:0;font-family:"Cairo",Arial,sans-serif;font-size:38px;line-height:1.18;font-weight:700;color:#111}

.lux-product-panel h1 small{display:block;margin-top:8px;color:#777;font-size:24px;font-weight:600;line-height:1.4}

.lux-rating{margin:18px 0 10px;display:flex;gap:10px;align-items:center;font-family:"Cairo",Arial,sans-serif}

.lux-rating span{color:#a88961;letter-spacing:2px;font-size:15px}

.lux-rating small{color:#666;font-size:13px}

.lux-price{font-family:"Cairo",Arial,sans-serif;font-size:26px;font-weight:900;color:#111;margin:18px 0}

.lux-short{color:#444;line-height:1.75;font-size:16px;margin:0 0 18px}

.lux-benefits{display:grid;gap:10px;background:#faf9f6;border:1px solid #ddd8cf;padding:15px;margin:22px 0}

.lux-benefits div{display:flex;gap:10px;align-items:center;font-family:"Cairo",Arial,sans-serif;font-size:14px;color:#222}

.lux-benefits strong{color:#173f35}

.lux-option-box{border-top:1px solid #ddd8cf;padding-top:22px;margin-top:22px}

.lux-option-title{font-family:"Cairo",Arial,sans-serif;font-size:12px;text-transform:uppercase;letter-spacing:1px;font-weight:900;margin-bottom:12px}

.lux-size-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}

.lux-size-grid label{border:1px solid #ddd8cf;padding:13px;display:grid;grid-template-columns:auto 1fr;gap:9px;cursor:pointer;font-family:"Cairo",Arial,sans-serif;background:#fff}

.lux-size-grid b{display:block;font-size:15px}

.lux-size-grid small{display:block;color:#777;font-size:12px}

.lux-buy-row{display:grid;grid-template-columns:105px 1fr;gap:12px;margin:22px 0}

.lux-buy-row .input{min-height:52px}

.lux-add-btn{min-height:52px;border:0;background:#111;color:#fff;font-family:"Cairo",Arial,sans-serif;font-weight:900;text-transform:uppercase;letter-spacing:.8px;cursor:pointer}

.lux-add-btn:hover{background:#274c35}

.lux-service-row{border-top:1px solid #ddd8cf;padding-top:20px;display:grid;grid-template-columns:1fr 1fr;gap:12px}

.lux-service-row div{background:#faf9f6;padding:12px;font-family:"Cairo",Arial,sans-serif}

.lux-service-row strong{display:block;font-size:13px;color:#111}

.lux-service-row span{display:block;color:#666;font-size:12px;margin-top:3px}

.lux-info-grid{max-width:1480px;margin:38px auto 0;display:grid;grid-template-columns:1.1fr .9fr;gap:22px}

.lux-info-card{background:#fff;border:1px solid #ddd8cf;padding:28px}

.lux-info-card h2{margin:0 0 14px;font-family:"Cairo",Arial,sans-serif;font-size:22px;font-weight:800}

.lux-info-card p{margin:0;color:#333;line-height:1.8}

.lux-info-card dl{margin:0;display:grid}

.lux-info-card dl div{display:flex;justify-content:space-between;gap:12px;padding:13px 0;border-bottom:1px solid #eee;font-family:"Cairo",Arial,sans-serif}

.lux-info-card dt{color:#777;font-weight:700}

.lux-info-card dd{margin:0;color:#111;font-weight:800;text-align:right}

.lux-product-section{max-width:1480px;margin:46px auto 0}

.lux-section-heading{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:20px}

.lux-section-heading span{display:block;color:#8a6a45;font-family:"Cairo",Arial,sans-serif;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:1.2px}

.lux-section-heading h2{margin:5px 0 0;font-family:"Cairo",Arial,sans-serif;font-size:30px;font-weight:800}

.lux-section-heading a{color:#111;border-bottom:1px solid #111;font-family:"Cairo",Arial,sans-serif;font-size:13px;font-weight:800;text-transform:uppercase}

.lux-related-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:22px}

@media(max-width:1100px){.lux-pdp-main{grid-template-columns:1fr}.lux-product-panel{position:static}.lux-info-grid{grid-template-columns:1fr}.lux-related-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}

@media(max-width:620px){.lux-pdp{padding:24px 16px 46px}.lux-pdp-breadcrumb{font-size:11px;flex-wrap:wrap;margin-bottom:16px}.lux-pdp-main{gap:18px}.lux-gallery-card{min-height:auto;padding:18px}.lux-product-badges{top:12px;left:12px;right:12px}.lux-product-badges span{font-size:10px;padding:5px 8px}.lux-image-frame{height:390px}.lux-image-frame img{padding:28px}.lux-product-panel{padding:22px 18px}.lux-product-panel h1{font-size:28px}.lux-product-panel h1 small{font-size:21px}.lux-price{font-size:22px}.lux-size-grid{grid-template-columns:1fr}.lux-buy-row{grid-template-columns:82px 1fr}.lux-service-row{grid-template-columns:1fr}.lux-info-card{padding:20px}.lux-section-heading{align-items:flex-start;flex-direction:column}.lux-section-heading h2{font-size:24px}.lux-related-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}}


/* ===== store_checkout_addon.css ===== */

.checkout-heading-block{max-width:1480px;margin:0 auto 26px}

.checkout-breadcrumb{display:flex;gap:8px;align-items:center;margin-bottom:18px;font-family:"Cairo",Arial,sans-serif;font-size:13px;color:#8a6a45;text-transform:uppercase;letter-spacing:.8px;font-weight:800}

.checkout-breadcrumb a{color:#8a6a45}

.shipping-methods{display:grid;gap:12px}

.shipping-card{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;border:1px solid #ddd8cf;padding:16px;background:#fff;cursor:pointer;font-family:"Cairo",Arial,sans-serif}

.shipping-card:has(input:checked){border-color:#111;background:#faf9f6}

.shipping-card input{width:auto;min-height:auto;accent-color:#111}

.shipping-card strong{display:block;font-size:15px;color:#111}

.shipping-card small{display:block;color:#666;margin-top:3px;line-height:1.4}

.shipping-card em{display:block;margin-top:5px;color:#274c35;font-style:normal;font-weight:800;font-size:12px}

.shipping-card-price{color:#111;font-weight:900;white-space:nowrap}

.create-account-line{display:flex!important;align-items:flex-start;gap:10px;margin-top:16px!important;padding:13px;border:1px solid #ddd8cf;background:#faf9f6}

.create-account-line input{width:auto!important;min-height:auto!important;margin-top:5px}

@media(max-width:620px){.shipping-card{grid-template-columns:auto 1fr}.shipping-card-price{grid-column:2}}


/* ===== cart_sync.css ===== */

.cart-page{
  background:#f7f5f1;
  padding:44px 5vw 76px;
  font-family:"Cairo", Arial, sans-serif;
}

.cart-hero{
  max-width:1480px;
  margin:0 auto 28px;
  background:#173f35;
  color:#fff;
  padding:46px;
  position:relative;
  overflow:hidden;
}

.cart-hero::after{
  content:"";
  position:absolute;
  width:360px;
  height:360px;
  border:1px solid rgba(216,192,144,.34);
  border-radius:50%;
  right:-120px;
  bottom:-150px;
}

.cart-hero span{
  display:block;
  color:#d8c090;
  font-size:12px;
  font-weight:900;
  letter-spacing:1.5px;
  text-transform:uppercase;
}

.cart-hero h1{
  margin:8px 0 12px;
  font-size:46px;
  line-height:1.1;
}

.cart-hero p{
  max-width:760px;
  margin:0;
  color:rgba(255,255,255,.84);
  line-height:1.8;
}

.cart-alert{
  max-width:1480px;
  margin:0 auto 18px;
  padding:14px 16px;
  font-weight:800;
  line-height:1.6;
}

.cart-alert.warning{
  background:#fff8e6;
  border:1px solid #e5c76c;
  color:#735112;
}

.cart-layout{
  max-width:1480px;
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(0,1fr) 360px;
  gap:24px;
  align-items:start;
}

.cart-items{
  display:grid;
  gap:14px;
}

.cart-item{
  background:#fff;
  border:1px solid #ddd8cf;
  display:grid;
  grid-template-columns:130px minmax(0,1fr) 160px 130px;
  gap:18px;
  padding:16px;
  align-items:center;
}

.cart-item-image{
  width:130px;
  height:150px;
  background:#faf9f6;
  border:1px solid #eee8df;
  display:flex;
  align-items:center;
  justify-content:center;
}

.cart-item-image img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:12px;
}

.cart-item-info span{
  display:block;
  color:#8a6a45;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.8px;
  margin-bottom:5px;
}

.cart-item-name{
  display:block;
  color:#111;
  font-size:17px;
  font-weight:900;
  line-height:1.35;
  text-decoration:none;
}

.cart-item-info small{
  display:block;
  color:#777;
  margin-top:5px;
}

.cart-item-info strong{
  display:block;
  color:#111;
  margin-top:10px;
}

.cart-qty{
  display:inline-grid;
  grid-template-columns:38px 60px 38px;
  border:1px solid #ddd8cf;
}

.cart-qty button{
  border:0;
  background:#faf9f6;
  font-size:20px;
  cursor:pointer;
}

.cart-qty input{
  min-height:38px;
  border:0;
  border-left:1px solid #ddd8cf;
  border-right:1px solid #ddd8cf;
  text-align:center;
}

.cart-remove{
  margin-top:12px;
  border:0;
  background:transparent;
  color:#9f251c;
  font-weight:900;
  cursor:pointer;
  text-decoration:underline;
}

.cart-line-total{
  text-align:right;
}

.cart-line-total strong{
  display:block;
  color:#111;
  font-size:18px;
}

.cart-line-total small{
  display:block;
  color:#777;
  margin-top:5px;
}

.cart-summary{
  position:sticky;
  top:160px;
  background:#fff;
  border:1px solid #ddd8cf;
  padding:22px;
}

.cart-summary h2{
  margin:0 0 18px;
}

.cart-summary-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 0;
  border-bottom:1px solid #eee8df;
}

.cart-summary-row span{
  color:#555;
  font-weight:900;
  text-transform:uppercase;
  font-size:12px;
  letter-spacing:.8px;
}

.cart-summary-row strong{
  color:#111;
  font-size:20px;
}

.cart-summary p{
  color:#777;
  line-height:1.6;
  font-size:13px;
}

.cart-checkout-btn,
.cart-continue-btn,
.cart-empty a{
  min-height:48px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  font-weight:900;
  text-transform:uppercase;
  font-size:12px;
  margin-top:10px;
}

.cart-checkout-btn{
  background:#111;
  color:#fff;
}

.cart-checkout-btn:hover{
  background:#173f35;
}

.cart-checkout-btn.disabled{
  opacity:.45;
  pointer-events:none;
}

.cart-continue-btn{
  background:#fff;
  color:#111;
  border:1px solid #111;
}

.cart-loading,
.cart-error,
.cart-empty{
  background:#fff;
  border:1px solid #ddd8cf;
  padding:46px 24px;
  text-align:center;
}

.cart-error{
  color:#9f251c;
  border-color:#e3aaa5;
  background:#fff1f0;
}

.cart-empty h2{
  margin:0 0 8px;
}

.cart-empty p{
  color:#666;
}

.cart-empty a{
  display:inline-flex;
  background:#111;
  color:#fff;
  padding:0 18px;
}

@media(max-width:980px){
  .cart-layout{
    grid-template-columns:1fr;
  }

  .cart-summary{
    position:static;
  }

  .cart-item{
    grid-template-columns:110px minmax(0,1fr);
  }

  .cart-item-controls,
  .cart-line-total{
    grid-column:2;
    text-align:left;
  }
}

@media(max-width:620px){
  .cart-page{
    padding:28px 16px 52px;
  }

  .cart-hero{
    padding:28px 20px;
  }

  .cart-hero h1{
    font-size:34px;
  }

  .cart-item{
    grid-template-columns:88px minmax(0,1fr);
    gap:12px;
    padding:12px;
  }

  .cart-item-image{
    width:88px;
    height:108px;
  }

  .cart-item-name{
    font-size:14px;
  }

  .cart-line-total{
    grid-column:1 / -1;
  }
}


/* ===== customer_account.css ===== */

.auth-page{
  min-height:70vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:50px 18px;
  background:#f7f5f1;
}

.auth-card{
  width:100%;
  max-width:520px;
  background:#fff;
  border:1px solid #ddd8cf;
  padding:34px;
}

.auth-kicker{
  display:block;
  color:#8a6a45;
  font-family:"Cairo",Arial,sans-serif;
  font-size:12px;
  font-weight:900;
  letter-spacing:1.4px;
  text-transform:uppercase;
  margin-bottom:8px;
}

.auth-card h1{
  margin:0 0 8px;
  font-family:"Cairo",Arial,sans-serif;
  font-size:34px;
}

.auth-card p{
  margin:0 0 22px;
  color:#555;
  line-height:1.7;
}

.auth-form{
  display:grid;
  gap:10px;
}

.auth-form label{
  font-family:"Cairo",Arial,sans-serif;
  font-size:13px;
  font-weight:800;
}

.auth-form input,
.auth-form textarea{
  width:100%;
  min-height:48px;
  border:1px solid #ddd8cf;
  padding:10px 12px;
  font-family:"Cairo",Arial,sans-serif;
}

.auth-form button{
  margin-top:10px;
  min-height:52px;
  border:0;
  background:#111;
  color:#fff;
  font-family:"Cairo",Arial,sans-serif;
  font-weight:900;
  text-transform:uppercase;
  cursor:pointer;
}

.auth-switch{
  margin-top:18px;
  padding-top:18px;
  border-top:1px solid #eee;
  font-family:"Cairo",Arial,sans-serif;
}

.auth-switch a{
  color:#8a6a45;
  font-weight:900;
}

.auth-error,
.auth-success{
  padding:12px 14px;
  margin:0 0 16px;
  font-family:"Cairo",Arial,sans-serif;
  font-weight:800;
}

.auth-error{
  background:#fff1f0;
  border:1px solid #e3aaa5;
  color:#9f251c;
}

.auth-success{
  background:#eef8f1;
  border:1px solid #9fd0ad;
  color:#1c6b3a;
}

.account-page{
  max-width:1480px;
  margin:0 auto;
  padding:42px 5vw 70px;
  display:grid;
  grid-template-columns:280px minmax(0,1fr);
  gap:28px;
  background:#f7f5f1;
}

.account-sidebar{
  background:#fff;
  border:1px solid #ddd8cf;
  padding:22px;
  align-self:start;
  position:sticky;
  top:180px;
}

.account-sidebar h2{
  margin:0 0 18px;
  font-family:"Cairo",Arial,sans-serif;
}

.account-sidebar a{
  display:block;
  padding:12px 0;
  border-bottom:1px solid #eee;
  font-family:"Cairo",Arial,sans-serif;
  color:#111;
  font-weight:800;
}

.account-sidebar a.active{
  color:#8a6a45;
}

.account-content{
  display:grid;
  gap:20px;
}

.account-card{
  background:#fff;
  border:1px solid #ddd8cf;
  padding:26px;
}

.account-card > span{
  display:block;
  color:#8a6a45;
  font-family:"Cairo",Arial,sans-serif;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:1px;
}

.account-card h1,
.account-card h2{
  font-family:"Cairo",Arial,sans-serif;
  margin:0 0 8px;
}

.account-card p{
  color:#555;
  line-height:1.7;
}

.account-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}

.account-stats a{
  background:#fff;
  border:1px solid #ddd8cf;
  padding:24px;
  font-family:"Cairo",Arial,sans-serif;
}

.account-stats strong{
  display:block;
  font-size:28px;
  color:#111;
}

.account-stats span{
  display:block;
  color:#666;
  margin-top:4px;
}

.orders-list{
  display:grid;
  gap:12px;
}

.order-row{
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:center;
  background:#fff;
  border:1px solid #ddd8cf;
  padding:18px;
  font-family:"Cairo",Arial,sans-serif;
}

.order-row strong,
.order-row b{
  display:block;
  color:#111;
}

.order-row span,
.order-row em{
  display:block;
  color:#666;
  font-style:normal;
  margin-top:4px;
}

.order-item-line{
  display:flex;
  justify-content:space-between;
  gap:14px;
  padding:13px 0;
  border-bottom:1px solid #eee;
  font-family:"Cairo",Arial,sans-serif;
}

.order-item-line span{
  display:block;
  color:#777;
}

.account-empty{
  background:#fff;
  border:1px dashed #ddd8cf;
  padding:34px;
  text-align:center;
  font-family:"Cairo",Arial,sans-serif;
}

.account-empty a{
  display:inline-flex;
  margin-top:12px;
  background:#111;
  color:#fff;
  min-height:44px;
  align-items:center;
  padding:0 18px;
  font-weight:900;
}

.account-grid-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}

.address-box{
  border:1px solid #ddd8cf;
  padding:14px;
  margin-bottom:12px;
  font-family:"Cairo",Arial,sans-serif;
}

.address-box p{
  margin:8px 0;
}

.address-box a{
  color:#b83b34;
  font-weight:900;
}

@media(max-width:900px){
  .account-page{
    grid-template-columns:1fr;
  }

  .account-sidebar{
    position:static;
  }

  .account-stats,
  .account-grid-2{
    grid-template-columns:1fr;
  }
}

@media(max-width:560px){
  .auth-card{
    padding:24px 18px;
  }

  .account-page{
    padding:28px 16px 50px;
  }

  .order-row{
    flex-direction:column;
    align-items:flex-start;
  }
}


/* ===== register_secure.css ===== */

.kp-register-page{
  background:
    radial-gradient(circle at 20% 10%, rgba(168,137,97,.16), transparent 28%),
    linear-gradient(135deg, #f7f5f1 0%, #fff 45%, #f3eee6 100%);
  padding:56px 5vw 76px;
  min-height:78vh;
}

.kp-register-shell{
  max-width:1220px;
  margin:0 auto;
  display:grid;
  grid-template-columns:.92fr 1.08fr;
  gap:26px;
  align-items:stretch;
}

.kp-register-visual{
  background:#173f35;
  color:#fff;
  padding:42px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  min-height:620px;
  position:relative;
  overflow:hidden;
}

.kp-register-visual::after{
  content:"";
  position:absolute;
  width:380px;
  height:380px;
  border:1px solid rgba(181,154,99,.35);
  border-radius:50%;
  right:-140px;
  bottom:-100px;
}

.kp-register-visual > span{
  color:#d8c090;
  font-family:"Cairo",Arial,sans-serif;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:1.8px;
}

.kp-register-visual h1{
  position:relative;
  z-index:1;
  max-width:520px;
  margin:50px 0 18px;
  font-family:"Cairo",Arial,sans-serif;
  font-size:48px;
  line-height:1.08;
  font-weight:800;
}

.kp-register-visual p{
  position:relative;
  z-index:1;
  max-width:520px;
  color:rgba(255,255,255,.82);
  font-family:"Cairo",Arial,sans-serif;
  font-size:16px;
  line-height:1.8;
}

.kp-register-benefits{
  position:relative;
  z-index:1;
  display:grid;
  gap:12px;
  margin-top:34px;
}

.kp-register-benefits div{
  display:grid;
  grid-template-columns:52px 1fr;
  align-items:center;
  gap:12px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.06);
  padding:14px;
  font-family:"Cairo",Arial,sans-serif;
}

.kp-register-benefits strong{
  color:#d8c090;
  font-size:18px;
}

.kp-register-benefits span{
  color:#fff;
  font-weight:700;
}

.kp-register-card{
  background:#fff;
  border:1px solid #ddd8cf;
  padding:38px;
  box-shadow:0 20px 55px rgba(0,0,0,.06);
}

.kp-register-card-head span{
  display:block;
  color:#8a6a45;
  font-family:"Cairo",Arial,sans-serif;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:1.3px;
}

.kp-register-card-head h2{
  margin:6px 0 8px;
  font-family:"Cairo",Arial,sans-serif;
  font-size:36px;
  line-height:1.15;
}

.kp-register-card-head p{
  margin:0 0 22px;
  color:#666;
  font-family:"Cairo",Arial,sans-serif;
  line-height:1.7;
}

.kp-register-form{
  display:grid;
  gap:15px;
}

.kp-hp-field{
  position:absolute;
  left:-9999px;
  opacity:0;
  height:0;
  overflow:hidden;
}

.kp-field{
  display:grid;
  gap:7px;
}

.kp-field label{
  font-family:"Cairo",Arial,sans-serif;
  font-size:13px;
  font-weight:900;
  color:#111;
}

.kp-field label em{
  color:#777;
  font-style:normal;
  font-weight:600;
}

.kp-field input{
  width:100%;
  min-height:50px;
  border:1px solid #ddd8cf;
  background:#fff;
  padding:11px 13px;
  font-family:"Cairo",Arial,sans-serif;
  font-size:15px;
  outline:none;
  transition:.18s ease;
}

.kp-field input:focus{
  border-color:#a88961;
  box-shadow:0 0 0 3px rgba(168,137,97,.13);
}

.kp-field small{
  color:#777;
  font-family:"Cairo",Arial,sans-serif;
  font-size:12px;
  line-height:1.5;
}

.kp-password-wrap{
  display:grid;
  grid-template-columns:1fr auto;
  border:1px solid #ddd8cf;
}

.kp-password-wrap:focus-within{
  border-color:#a88961;
  box-shadow:0 0 0 3px rgba(168,137,97,.13);
}

.kp-password-wrap input{
  border:0;
  box-shadow:none !important;
}

.kp-show-pass{
  border:0;
  border-left:1px solid #ddd8cf;
  background:#faf9f6;
  color:#111;
  padding:0 14px;
  font-family:"Cairo",Arial,sans-serif;
  font-weight:900;
  cursor:pointer;
}

.kp-password-meter{
  height:7px;
  background:#eee8df;
  overflow:hidden;
}

.kp-password-meter span{
  display:block;
  width:0%;
  height:100%;
  background:#b83b34;
  transition:.25s ease;
}

.kp-password-meter span.medium{
  width:55%;
  background:#c6922e;
}

.kp-password-meter span.strong{
  width:100%;
  background:#173f35;
}

.kp-password-rules{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6px 12px;
  margin:0;
  padding:0;
  list-style:none;
}

.kp-password-rules li{
  color:#777;
  font-family:"Cairo",Arial,sans-serif;
  font-size:12px;
  position:relative;
  padding-left:18px;
}

.kp-password-rules li::before{
  content:"×";
  position:absolute;
  left:0;
  color:#b83b34;
  font-weight:900;
}

.kp-password-rules li.valid{
  color:#173f35;
  font-weight:800;
}

.kp-password-rules li.valid::before{
  content:"✓";
  color:#173f35;
}

#matchMessage.valid{
  color:#173f35;
  font-weight:800;
}

#matchMessage.invalid{
  color:#b83b34;
  font-weight:800;
}

.kp-check-line{
  display:flex;
  align-items:flex-start;
  gap:11px;
  padding:13px;
  border:1px solid #ddd8cf;
  background:#faf9f6;
  font-family:"Cairo",Arial,sans-serif;
  font-size:13px;
  line-height:1.6;
  color:#333;
}

.kp-check-line input{
  margin-top:5px;
  accent-color:#173f35;
}

.kp-register-btn{
  min-height:54px;
  border:0;
  background:#111;
  color:#fff;
  font-family:"Cairo",Arial,sans-serif;
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.8px;
  cursor:pointer;
  transition:.18s ease;
}

.kp-register-btn:hover{
  background:#173f35;
}

.kp-register-btn:disabled{
  opacity:.6;
  cursor:not-allowed;
}

.kp-register-switch{
  margin-top:22px;
  padding-top:20px;
  border-top:1px solid #eee8df;
  font-family:"Cairo",Arial,sans-serif;
  color:#555;
}

.kp-register-switch a{
  color:#8a6a45;
  font-weight:900;
}

@media(max-width:980px){
  .kp-register-shell{
    grid-template-columns:1fr;
  }

  .kp-register-visual{
    min-height:auto;
  }
}

@media(max-width:620px){
  .kp-register-page{
    padding:28px 16px 48px;
  }

  .kp-register-visual,
  .kp-register-card{
    padding:24px 18px;
  }

  .kp-register-visual h1{
    font-size:34px;
    margin-top:28px;
  }

  .kp-register-card-head h2{
    font-size:30px;
  }

  .kp-password-rules{
    grid-template-columns:1fr;
  }
}


/* ===== legal_pages.css ===== */

.legal-page{
  background:#f7f5f1;
  padding:44px 5vw 76px;
  font-family:"Cairo",Arial,sans-serif;
}

.legal-hero{
  max-width:1260px;
  margin:0 auto 28px;
  background:#173f35;
  color:#fff;
  padding:42px;
  position:relative;
  overflow:hidden;
}

.legal-hero::after{
  content:"";
  position:absolute;
  width:320px;
  height:320px;
  border:1px solid rgba(216,192,144,.35);
  border-radius:50%;
  right:-100px;
  bottom:-140px;
}

.legal-hero span{
  color:#d8c090;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:1.5px;
}

.legal-hero h1{
  position:relative;
  z-index:1;
  margin:8px 0 10px;
  font-size:44px;
  line-height:1.1;
}

.legal-hero p{
  position:relative;
  z-index:1;
  max-width:760px;
  margin:0 0 14px;
  color:rgba(255,255,255,.84);
  line-height:1.8;
}

.legal-hero small{
  color:rgba(255,255,255,.7);
}

.legal-layout{
  max-width:1260px;
  margin:0 auto;
  display:grid;
  grid-template-columns:270px minmax(0,1fr);
  gap:24px;
  align-items:start;
}

.legal-toc{
  position:sticky;
  top:180px;
  background:#fff;
  border:1px solid #ddd8cf;
  padding:18px;
}

.legal-toc a{
  display:block;
  padding:11px 0;
  border-bottom:1px solid #eee8df;
  color:#111;
  font-weight:800;
}

.legal-toc a:last-child{
  border-bottom:0;
}

.legal-content{
  background:#fff;
  border:1px solid #ddd8cf;
  padding:34px;
}

.legal-content section{
  border-bottom:1px solid #eee8df;
  padding-bottom:24px;
  margin-bottom:24px;
}

.legal-content section:last-child{
  border-bottom:0;
  padding-bottom:0;
  margin-bottom:0;
}

.legal-content h2{
  margin:0 0 12px;
  font-size:24px;
  color:#111;
}

.legal-content p,
.legal-content li{
  color:#333;
  line-height:1.85;
  font-size:15px;
}

.legal-content ul{
  padding-left:22px;
}

.legal-box{
  margin-top:14px;
  padding:14px 16px;
  background:#fff8e6;
  border:1px solid #e0c27d;
  color:#654a15;
  line-height:1.7;
}

.legal-consent-text{
  font-size:13px;
  color:#555;
  line-height:1.7;
}

.legal-consent-text a{
  color:#8a6a45;
  font-weight:900;
  text-decoration:underline;
}

@media(max-width:900px){
  .legal-layout{
    grid-template-columns:1fr;
  }

  .legal-toc{
    position:static;
  }
}

@media(max-width:620px){
  .legal-page{
    padding:28px 16px 52px;
  }

  .legal-hero,
  .legal-content{
    padding:24px 18px;
  }

  .legal-hero h1{
    font-size:32px;
  }
}



/* ==========================================================================\n   Final mobile header/menu performance override\n   - Header is not fixed on mobile\n   - Old drawer menu styling remains active\n   - Prevents previous simple mobile-menu patch conflicts\n   ========================================================================== */
@media (max-width:768px){
  html,body{padding-top:0!important;scroll-padding-top:0!important;}
  header,.site-header,.public-header,.main-header,.lux-header,.kp-header,.harrods-header,.harrods-top,.harrods-main,.store-header{
    position:relative!important;top:auto!important;left:auto!important;right:auto!important;bottom:auto!important;z-index:20!important;
  }
  .harrods-header,.public-header,.kp-header,.store-header{min-height:auto!important;}
  .harrods-main{min-height:auto!important;padding:10px 14px!important;}
  .harrods-logo,.site-logo,.kp-logo{min-height:auto!important;}
  .harrods-logo img,.site-logo img,.kp-logo img,header img{max-height:74px!important;width:auto!important;object-fit:contain!important;}
  .harrods-search,.header-search,.kp-search{padding-top:6px!important;padding-bottom:10px!important;}
  .harrods-search input,.header-search input,.kp-search input{min-height:38px!important;}
  .top-promo,.announcement-bar,.kp-announcement,.harrods-promo{position:relative!important;top:auto!important;}
  .kp-mobile-menu-target{display:initial;}
  .kp-mobile-drawer.kp-mobile-menu-target{display:flex;}
  body.kp-menu-open .kp-mobile-drawer.kp-mobile-menu-target{display:flex!important;}
}

/* =========================================================
   RAJ PERFUMES — Final Luxury Brand Theme Override
   Palette derived from the gold palm logo:
   Deep Navy + Royal Gold + Warm Ivory + Oud Brown
   ========================================================= */

:root {
  /* Store / luxury theme */
  --raj-navy: #101827;
  --raj-navy-2: #0A1020;
  --raj-gold: #C9A24A;
  --raj-gold-soft: #E8D18A;
  --raj-gold-pale: #F3E4B3;
  --raj-ivory: #F8F3E8;
  --raj-light: #FBF7EF;
  --raj-paper: #FFFDF7;
  --raj-oud: #4A2F24;
  --raj-oud-2: #2F1E17;
  --raj-muted: #6D6256;
  --raj-line: #E4D8C0;
  --raj-success: #173B2F;
  --raj-danger: #8E1F2F;

  --lux-bg: var(--raj-ivory);
  --lux-paper: var(--raj-paper);
  --lux-ink: var(--raj-navy);
  --lux-soft-ink: #1B2433;
  --lux-muted: var(--raj-muted);
  --lux-line: var(--raj-line);
  --lux-cream: #F6EEDC;
  --lux-light: var(--raj-light);
  --lux-mist: #F2E7D2;
  --lux-dark: var(--raj-navy);
  --lux-green: var(--raj-navy);
  --lux-forest: var(--raj-navy-2);
  --lux-deep-olive: var(--raj-oud);
  --lux-olive: #9B7A3A;
  --lux-soft-olive: #D9C48A;
  --lux-gold: var(--raj-gold);
  --lux-gold-soft: var(--raj-gold-soft);
  --lux-gold-pale: var(--raj-gold-pale);
  --lux-danger: var(--raj-danger);
  --lux-success: var(--raj-success);
  --lux-shadow: rgba(16, 24, 39, 0.10);
  --lux-shadow-strong: rgba(16, 24, 39, 0.22);

  /* POS / admin theme */
  --bg: var(--raj-ivory);
  --bg2: var(--raj-light);
  --card: var(--raj-paper);
  --card2: #F4EAD6;
  --ink: var(--raj-navy);
  --muted: var(--raj-muted);
  --dark: var(--raj-navy-2);
  --dark2: var(--raj-navy);
  --dark3: #1B2433;
  --brown: var(--raj-oud);
  --copper: #9B7A3A;
  --gold: var(--raj-gold);
  --gold2: var(--raj-gold-soft);
  --gold3: var(--raj-gold-pale);
  --danger: var(--raj-danger);
  --danger2: #A93646;
  --ok: var(--raj-success);
  --ok2: #246B55;
  --line: var(--raj-line);
  --line2: #CDBB97;
  --soft: #F2E7D2;
  --cream: #FFF8E8;
  --shadow: rgba(16, 24, 39, 0.12);
}

body {
  background:
    radial-gradient(circle at 8% 0%, rgba(201,162,74,.20), transparent 28%),
    radial-gradient(circle at 92% 10%, rgba(74,47,36,.10), transparent 30%),
    linear-gradient(180deg, var(--raj-light), var(--raj-ivory)) !important;
  color: var(--raj-navy) !important;
}

main,
.harrods-category-page,
.products-page,
.arrivals-page,
.checkout-page,
.checkout-wrap,
.checkout-shell,
.track-page,
.order-success-page,
.secure-track-page {
  background:
    radial-gradient(circle at 92% 6%, rgba(201,162,74,.10), transparent 26%),
    linear-gradient(180deg, var(--raj-light), var(--raj-ivory)) !important;
}

::selection { background: var(--raj-gold); color: var(--raj-navy); }

/* Header */
.harrods-header,
.reef-header,
.luxury-header,
.site-header,
.public-header,
.main-header,
.store-header {
  background: rgba(255, 253, 247, .97) !important;
  color: var(--raj-navy) !important;
  border-bottom-color: var(--raj-line) !important;
  box-shadow: 0 12px 32px rgba(16,24,39,.06) !important;
}

.harrods-offer-bar,
.announcement-bar,
.luxury-topbar,
.harrods-promo {
  background:
    radial-gradient(circle at 20% 30%, rgba(201,162,74,.22), transparent 26%),
    linear-gradient(135deg, var(--raj-navy-2), var(--raj-navy)) !important;
  color: #fff !important;
}

.harrods-gold-line,
.logo-divider,
.gold-line {
  background: linear-gradient(90deg, var(--raj-gold), var(--raj-gold-soft), var(--raj-gold)) !important;
}

.harrods-nav a,
.main-nav a,
.luxury-nav a,
.harrods-account a,
.header-icons a,
.harrods-country,
.header-left,
.harrods-location {
  color: var(--raj-navy) !important;
}

.harrods-nav a:hover,
.main-nav a:hover,
.luxury-nav a:hover,
.harrods-account a:hover,
.header-icons a:hover {
  color: var(--raj-gold) !important;
}

.harrods-icons a,
.account-separator,
.kp-footer-contact a,
.footer-information a:hover,
.luxury-footer a:hover,
.reef-footer a:hover {
  color: var(--raj-gold) !important;
}

.search-box,
.header-search,
.harrods-mobile-search,
.harrods-search form {
  border-bottom-color: var(--raj-navy) !important;
}

.search-box button,
.header-search button,
.harrods-mobile-search button,
.harrods-search button {
  color: var(--raj-navy) !important;
}

.bag-icon b,
.cart-button b,
.bag-link b {
  background: var(--raj-gold) !important;
  color: var(--raj-navy) !important;
}

/* Buttons */
.primary-btn,
.btn-dark,
.add-bag-btn,
.place-order-btn,
.checkout-submit,
.checkout-btn,
.track-form button,
.products-filter button,
.products-load-more-btn,
.quick-add-main,
.mini-cart-btn.dark,
.products-empty a,
.portal-btn.secondary {
  background: var(--raj-navy) !important;
  border-color: var(--raj-navy) !important;
  color: #fff !important;
}

.primary-btn:hover,
.btn-dark:hover,
.add-bag-btn:hover,
.place-order-btn:hover,
.checkout-submit:hover,
.checkout-btn:hover,
.track-form button:hover,
.products-filter button:hover,
.products-load-more-btn:hover,
.quick-add-main:hover,
.mini-cart-btn.dark:hover {
  background: var(--raj-oud) !important;
  border-color: var(--raj-oud) !important;
  color: #fff !important;
}

.secondary-btn,
.btn-outline,
.checkout-secondary-btn,
.products-toolbar a,
.mini-cart-btn.light {
  background: #fff !important;
  border-color: var(--raj-navy) !important;
  color: var(--raj-navy) !important;
}

.secondary-btn:hover,
.btn-outline:hover,
.checkout-secondary-btn:hover,
.products-toolbar a:hover,
.mini-cart-btn.light:hover {
  background: var(--raj-navy) !important;
  color: #fff !important;
}

.btn.gold,
.pay-btn.active,
.portal-btn,
.sale-type-btn.active {
  background: linear-gradient(135deg, #B98A2D 0%, var(--raj-gold) 50%, var(--raj-gold-soft) 100%) !important;
  border-color: #B98A2D !important;
  color: var(--raj-navy) !important;
}

/* Hero / brand panels */
.reef-hero,
.editorial-hero,
.products-hero,
.arrivals-hero,
.track-hero,
.dashboard-hero,
.pos-header {
  background:
    radial-gradient(circle at 82% 18%, rgba(201,162,74,.30), transparent 30%),
    linear-gradient(135deg, var(--raj-navy-2), var(--raj-navy) 58%, var(--raj-oud)) !important;
  color: #fff !important;
}

.hero-content span,
.hero-inner span,
.crumb,
.section-title span,
.section-heading span,
.success-kicker,
.track-hero span,
.products-hero span,
.arrivals-hero span,
.quick-brand,
.mini-cart-head span {
  color: var(--raj-gold) !important;
}

/* Cards and product surfaces */
.category-grid,
.category-row,
.editorial-card,
.brand-panel,
.reef-brand-strip a,
.brand-card,
.brand-list a,
.category-banner,
.plp-intro,
.cart-main,
.cart-summary-card,
.track-card,
.track-result,
.order-success-card,
.success-order-number,
.success-summary-grid div,
.track-info-grid div,
.checkout-form-card,
.checkout-summary,
.checkout-summary-card,
.checkout-card,
.products-filter,
.products-toolbar,
.product-card,
.harrods-product-card,
.card,
.online-product-card,
.report-card,
.dash-kpi,
.backup-card,
.portal-card,
.mini-cart-drawer,
.quick-shop-modal {
  background: var(--raj-paper) !important;
  border-color: var(--raj-line) !important;
}

.product-image-box,
.tile-image,
.harrods-product-image,
.cart-line-img,
.product-image,
.quick-shop-image,
.mini-cart-img,
.product-img {
  background:
    radial-gradient(circle at 50% 18%, rgba(201,162,74,.16), transparent 42%),
    linear-gradient(180deg, #FFFDF7, #F5ECDA) !important;
}

.product-badge,
.tile-label,
.featured-label,
.product-badges span,
.offer-badge,
.sale-badge,
.lux-wine-badge {
  background: var(--raj-navy) !important;
  color: #fff !important;
  border-color: var(--raj-navy) !important;
}

.product-brand,
.tile-brand,
.product-brand-name,
.price-line strong,
.tile-footer strong,
.harrods-product-info strong,
.cart-line-price strong,
.product-card .price,
.product-info b,
.report-card strong,
.dash-kpi strong {
  color: var(--raj-oud) !important;
}

.harrods-product-info h2,
.product-info h3,
.tile-body h3,
.product-info a,
.checkout-section h2,
.checkout-section h3,
.page-title h1,
.products-toolbar strong {
  color: var(--raj-navy) !important;
}

.product-info p,
.tile-body p,
.lead,
.pdp-lead,
.pdp-accordion p,
.description-panel p,
.category-banner p,
.plp-intro p,
.checkout-subtitle,
.checkout-intro,
.products-hero p,
.arrivals-hero p {
  color: var(--raj-muted) !important;
}

/* Forms */
.input,
select,
textarea,
.checkout-form input,
.checkout-form textarea,
.checkout-form select,
.checkout-section input,
.checkout-section textarea,
.checkout-section select,
.checkout-input,
.checkout-select,
.checkout-textarea,
.products-filter input,
.products-filter select,
.track-form input,
.portal-card .input {
  background: #fff !important;
  border-color: var(--raj-line) !important;
  color: var(--raj-navy) !important;
}

.input:focus,
select:focus,
textarea:focus,
.checkout-form input:focus,
.checkout-form textarea:focus,
.checkout-form select:focus,
.checkout-section input:focus,
.checkout-section textarea:focus,
.checkout-section select:focus,
.products-filter input:focus,
.products-filter select:focus,
.track-form input:focus,
.portal-card .input:focus {
  border-color: var(--raj-gold) !important;
  box-shadow: 0 0 0 3px rgba(201,162,74,.18) !important;
}

/* Filters and active states */
.harrods-breadcrumb a,
.section-heading a,
.active-category-note a,
.harrods-sort select,
.filter-content a:hover,
.active-filter,
.filter-heading b::before,
.filter-heading b::after {
  color: var(--raj-gold) !important;
}

.filter-heading b::before,
.filter-heading b::after {
  background: var(--raj-gold) !important;
}

.active-category-note,
.arabic-seo-note,
.summary-note,
.checkout-note,
.checkout-help,
.loyalty-redeem-box,
.customer-box,
.variant-online-box,
.filter-check {
  background: #F7EEDB !important;
  border-color: var(--raj-line) !important;
  color: var(--raj-navy) !important;
}

/* POS / Admin */
.admin-shell,
.pos-shell,
.cashier-page,
.login-wrap {
  background:
    radial-gradient(circle at top left, rgba(201,162,74,.20), transparent 28%),
    radial-gradient(circle at bottom right, rgba(74,47,36,.12), transparent 34%),
    linear-gradient(180deg, var(--raj-light), var(--raj-ivory)) !important;
}

.sidebar,
.admin-sidebar,
.kp-mobile-drawer,
.cashier-mini-bar {
  background:
    radial-gradient(circle at top, rgba(201,162,74,.16), transparent 30%),
    linear-gradient(180deg, var(--raj-navy-2), var(--raj-navy)) !important;
  color: #fff !important;
}

.sidebar .brand,
.kp-mobile-drawer-logo span,
.kp-mobile-nav a::after,
.kp-mobile-search button,
.kp-mobile-mini-links a {
  color: var(--raj-gold) !important;
}

.table-wrap table,
table,
.cart-item,
.variant-box,
.empty-cart,
.totals,
.sale-totals,
.cart-totals,
.current-sale,
.cart-panel,
.sale-panel,
.pos-cart,
.right-panel,
.cart-summary {
  background: var(--raj-paper) !important;
  border-color: var(--raj-line) !important;
}

th {
  background: #F1E4CB !important;
  color: var(--raj-oud) !important;
}

/* Footer */
.reef-footer,
.luxury-footer {
  background:
    radial-gradient(circle at 14% 0%, rgba(201,162,74,.16), transparent 24%),
    linear-gradient(180deg, var(--raj-navy-2), #050812) !important;
  color: #fff !important;
}

.footer-bottom {
  border-top-color: rgba(201,162,74,.22) !important;
}

/* Mobile drawer/menu */
.kp-mobile-menu-btn,
#kpMobileMenuOpen {
  border-color: var(--raj-gold) !important;
  background: #fff !important;
  color: var(--raj-navy) !important;
}

.kp-mobile-account a.primary {
  background: var(--raj-gold) !important;
  color: var(--raj-navy) !important;
}

/* Success / status */
.success-icon,
.secure-track-icon,
.track-steps div.active b,
.secure-track-steps div.active b {
  background: linear-gradient(135deg, var(--raj-navy), var(--raj-oud)) !important;
  color: #fff !important;
}

.success-note-box,
.loyalty-status-card.enabled,
.selected-customer {
  background: #EEF6F2 !important;
  border-color: rgba(23,59,47,.24) !important;
  color: var(--raj-success) !important;
}

.alert,
.checkout-error,
.track-error,
.portal-alert,
.track-cancelled {
  background: #FFF0F1 !important;
  border-color: rgba(142,31,47,.28) !important;
  color: var(--raj-danger) !important;
}

/* Logo text fallback */
.logo-text .brand,
.logo-text .sub,
.logo-fallback,
.luxury-logo strong,
.harrods-logo span {
  color: var(--raj-gold) !important;
}

@media (max-width: 760px) {
  .harrods-main-row,
  .harrods-tools-row,
  .harrods-main {
    background: rgba(255, 253, 247, .98) !important;
  }

  .harrods-offer-bar,
  .harrods-promo {
    background: linear-gradient(135deg, var(--raj-navy-2), var(--raj-navy)) !important;
  }
}

/* =========================================================
   RAJ PERFUMES - FINAL BRAND IDENTITY OVERRIDES
   Keep this block at the very end of the bundle.
   ========================================================= */
:root {
  --lux-bg: #f7f3ea;
  --lux-paper: #ffffff;
  --lux-ink: #161a12;
  --lux-soft-ink: #2b2f26;
  --lux-muted: #6f7668;

  --lux-line: #d8dec9;
  --lux-cream: #eafada;
  --lux-light: #fbf8f1;
  --lux-mist: #eafada;

  --lux-dark: #2b3b1b;
  --lux-green: #2b3b1b;
  --lux-forest: #1f2d16;
  --lux-deep-olive: #6d8c4e;
  --lux-olive: #92b66e;
  --lux-soft-olive: #c9ddb6;

  --lux-gold: #c8a24a;
  --lux-gold-soft: #e8d18a;
  --lux-gold-pale: #f3e4b3;

  --lux-blush: #fbe3ee;
  --lux-crimson: #a43163;
  --lux-wine: #870c46;
  --lux-bordeaux: #3f0d24;

  --lux-danger: #b83b34;
  --lux-success: #1c7a4a;

  --lux-shadow: rgba(22, 34, 16, 0.12);
  --lux-shadow-strong: rgba(22, 34, 16, 0.22);

  --reef-bg: var(--lux-bg);
  --reef-paper: var(--lux-paper);
  --reef-ink: var(--lux-ink);
  --reef-muted: var(--lux-muted);
  --reef-line: var(--lux-line);
  --reef-brown: var(--lux-dark);
  --reef-tan: var(--lux-gold);
  --reef-soft: var(--lux-cream);
  --reef-cream: var(--lux-light);
  --reef-dark: var(--lux-dark);

  /* Old/admin/POS variable compatibility */
  --bg: var(--lux-bg);
  --bg2: var(--lux-light);
  --card: var(--lux-paper);
  --card2: var(--lux-mist);
  --ink: var(--lux-ink);
  --muted: var(--lux-muted);
  --dark: var(--lux-forest);
  --dark2: var(--lux-dark);
  --dark3: var(--lux-deep-olive);
  --brown: var(--lux-dark);
  --copper: var(--lux-olive);
  --gold: var(--lux-gold);
  --gold2: var(--lux-gold-soft);
  --gold3: var(--lux-gold-pale);
  --danger: var(--lux-wine);
  --danger2: var(--lux-crimson);
  --ok: var(--lux-success);
  --ok2: var(--lux-olive);
  --line: var(--lux-line);
  --line2: var(--lux-soft-olive);
  --soft: var(--lux-cream);
  --cream: var(--lux-light);
  --blush: var(--lux-blush);
  --wine: var(--lux-wine);
  --bordeaux: var(--lux-bordeaux);
  --shadow: var(--lux-shadow);
}

html,
body {
  color: var(--lux-ink) !important;
  background: linear-gradient(180deg, var(--lux-light), var(--lux-bg)) !important;
}

main,
.harrods-category-page,
.products-page,
.arrivals-page,
.checkout-page,
.checkout-wrap,
.checkout-shell,
.cart-page,
.track-page,
.secure-track-page,
.order-success-page {
  background:
    radial-gradient(circle at 92% 6%, rgba(146, 182, 110, 0.12), transparent 26%),
    linear-gradient(180deg, var(--lux-light), var(--lux-bg)) !important;
}

/* Header should scroll away normally, never sticky/fixed */
header,
.site-header,
.public-header,
.main-header,
.lux-header,
.kp-header,
.store-header,
.harrods-header,
.reef-header,
.luxury-header,
.harrods-main,
.harrods-main-row,
.harrods-tools-row {
  position: relative !important;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
}

.harrods-header,
.site-header,
.store-header {
  background: rgba(255,255,255,.98) !important;
  border-bottom: 1px solid var(--lux-line) !important;
  box-shadow: 0 10px 30px rgba(22, 34, 16, 0.045) !important;
  color: var(--lux-ink) !important;
}

.harrods-offer-bar,
.announcement-bar,
.luxury-topbar,
.harrods-promo,
.kp-announcement,
.top-promo {
  background:
    radial-gradient(circle at 18% 30%, rgba(146, 182, 110, .22), transparent 28%),
    linear-gradient(135deg, var(--lux-forest), var(--lux-dark)) !important;
  color: #fff !important;
}

.harrods-gold-line,
.kp-gold-line {
  background: linear-gradient(90deg, var(--lux-gold), var(--lux-gold-soft), var(--lux-gold)) !important;
}

/* Final RAJ logo sizing */
.harrods-logo,
.site-logo,
.kp-logo,
.luxury-logo {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: auto !important;
}

.harrods-logo img,
.site-logo img,
.kp-logo img,
.luxury-logo img {
  width: auto !important;
  height: auto !important;
  max-width: 280px !important;
  max-height: 118px !important;
  object-fit: contain !important;
}

@media (max-width: 1100px) {
  .harrods-logo img,
  .site-logo img,
  .kp-logo img,
  .luxury-logo img {
    max-width: 240px !important;
    max-height: 105px !important;
  }
}

@media (max-width: 768px) {
  .harrods-logo img,
  .site-logo img,
  .kp-logo img,
  .luxury-logo img {
    max-width: 170px !important;
    max-height: 86px !important;
  }
}

@media (max-width: 430px) {
  .harrods-logo img,
  .site-logo img,
  .kp-logo img,
  .luxury-logo img {
    max-width: 155px !important;
    max-height: 78px !important;
  }
}

.harrods-nav a,
.main-nav a,
.luxury-nav a,
.harrods-account a,
.product-info a,
.harrods-product-info h2 {
  color: var(--lux-ink) !important;
}

.harrods-nav a:hover,
.main-nav a:hover,
.luxury-nav a:hover,
.harrods-account a:hover,
.product-info a:hover {
  color: var(--lux-deep-olive) !important;
}

.harrods-icons a,
.header-icons a,
.account-separator,
.wishlist-btn,
.product-brand-name,
.product-brand,
.tile-brand,
.quick-brand,
.success-kicker,
.track-hero span,
.products-hero span,
.arrivals-hero span {
  color: var(--lux-gold) !important;
}

.bag-icon b,
.cart-button b,
.bag-link b,
.mini-cart-count,
.cart-count {
  background: var(--lux-dark) !important;
  color: #fff !important;
}

.primary-btn,
.btn-dark,
.add-bag-btn,
.quick-add-main,
.place-order-btn,
.checkout-submit,
.checkout-btn,
.products-filter button,
.products-load-more-btn,
.mini-cart-btn.dark,
.track-form button {
  background: var(--lux-dark) !important;
  border-color: var(--lux-dark) !important;
  color: #fff !important;
}

.primary-btn:hover,
.btn-dark:hover,
.add-bag-btn:hover,
.quick-add-main:hover,
.place-order-btn:hover,
.checkout-submit:hover,
.checkout-btn:hover,
.products-filter button:hover,
.products-load-more-btn:hover,
.mini-cart-btn.dark:hover,
.track-form button:hover {
  background: var(--lux-deep-olive) !important;
  border-color: var(--lux-deep-olive) !important;
  color: #fff !important;
}

.secondary-btn,
.btn-outline,
.checkout-secondary-btn,
.mini-cart-btn.light,
.quick-card-actions button,
.quick-card-actions a,
.products-toolbar a,
.products-filter a {
  background: var(--lux-paper) !important;
  border-color: var(--lux-dark) !important;
  color: var(--lux-dark) !important;
}

.secondary-btn:hover,
.btn-outline:hover,
.checkout-secondary-btn:hover,
.mini-cart-btn.light:hover,
.quick-card-actions button:hover,
.quick-card-actions a:hover,
.products-toolbar a:hover,
.products-filter a:hover {
  background: var(--lux-dark) !important;
  color: #fff !important;
}

.input,
select,
textarea,
.checkout-form input,
.checkout-form textarea,
.checkout-form select,
.checkout-section input,
.checkout-section textarea,
.checkout-section select,
.checkout-input,
.checkout-select,
.checkout-textarea,
.products-filter input,
.products-filter select {
  border-color: var(--lux-line) !important;
  color: var(--lux-ink) !important;
  background: var(--lux-paper) !important;
}

.input:focus,
select:focus,
textarea:focus,
.checkout-form input:focus,
.checkout-form textarea:focus,
.checkout-form select:focus,
.checkout-section input:focus,
.checkout-section textarea:focus,
.checkout-section select:focus,
.products-filter input:focus,
.products-filter select:focus {
  border-color: var(--lux-gold) !important;
  box-shadow: 0 0 0 3px rgba(200, 162, 74, .18) !important;
}

.cart-main,
.cart-summary-card,
.checkout-form-card,
.checkout-summary,
.checkout-summary-card,
.checkout-card,
.mini-cart-drawer,
.quick-shop-modal,
.product-card,
.harrods-product-card,
.reef-product-card,
.product-tile,
.track-card,
.track-result,
.order-success-card,
.secure-track-card,
.products-filter,
.products-toolbar {
  background: var(--lux-paper) !important;
  border-color: var(--lux-line) !important;
  color: var(--lux-ink) !important;
}

.product-image,
.product-image-box,
.tile-image,
.harrods-product-image,
.quick-shop-image,
.checkout-item img,
.summary-item img,
.mini-cart-img,
.cart-line-img {
  background:
    radial-gradient(circle at 50% 20%, rgba(234, 250, 218, .65), transparent 42%),
    var(--lux-light) !important;
}

.product-badge,
.tile-label,
.featured-label,
.product-badges span {
  background: var(--lux-dark) !important;
  border-color: var(--lux-dark) !important;
  color: #fff !important;
}

.products-hero,
.arrivals-hero,
.track-hero,
.success-icon,
.secure-track-icon,
.track-steps div.active b,
.secure-track-steps div.active b {
  background:
    radial-gradient(circle at 15% 12%, rgba(146, 182, 110, .25), transparent 28%),
    linear-gradient(135deg, var(--lux-forest), var(--lux-dark)) !important;
  color: #fff !important;
}

.checkout-option:has(input:checked),
.delivery-option:has(input:checked),
.payment-option:has(input:checked),
.order-type-option:has(input:checked),
.checkout-option.active,
.delivery-option.active,
.payment-option.active,
.order-type-option.active,
.quick-variant.selected,
.quick-variant:hover,
.active-category-note,
.arabic-seo-note,
.summary-note,
.checkout-note,
.checkout-help {
  background: var(--lux-mist) !important;
  border-color: var(--lux-soft-olive) !important;
  color: var(--lux-dark) !important;
}

.checkout-error,
.track-error,
.secure-track-icon.danger,
.success-icon.warning {
  background: #fff1f0 !important;
  border-color: rgba(184, 59, 52, .28) !important;
  color: var(--lux-danger) !important;
}

.checkout-success,
.success-note-box {
  background: var(--lux-mist) !important;
  border-color: var(--lux-soft-olive) !important;
  color: var(--lux-success) !important;
}

.reef-footer,
.luxury-footer,
.footer {
  background:
    radial-gradient(circle at 14% 0%, rgba(146, 182, 110, .14), transparent 24%),
    linear-gradient(180deg, var(--lux-forest), #11170d) !important;
  color: #fff !important;
}

.footer a,
.reef-footer a,
.luxury-footer a,
.kp-footer-contact a {
  color: var(--lux-gold) !important;
}

body.mini-cart-open,
body.quick-shop-open,
body.kp-menu-open,
body.products-filter-open {
  overflow: hidden !important;
}



/* ===== RAJ PERFUMES Footer Fix ===== */
.kp-footer {
  background:
    radial-gradient(circle at 14% 0%, rgba(146, 182, 110, 0.14), transparent 24%),
    linear-gradient(180deg, var(--lux-forest, #1f2d16), #11170d) !important;
  color: #fff !important;
  padding: 72px 0 34px !important;
  margin-top: 0;
  font-family: "Cairo", Arial, sans-serif;
}

.kp-footer * {
  box-sizing: border-box;
}

.kp-footer-inner {
  width: min(100% - 64px, 1500px);
  margin: 0 auto;
}

.kp-footer-grid {
  display: grid;
  grid-template-columns: 1.35fr 1fr 1fr 1fr;
  gap: clamp(36px, 6vw, 92px);
  align-items: start;
}

.kp-footer h3 {
  margin: 0 0 24px !important;
  color: #fff !important;
  font-size: 14px !important;
  line-height: 1.2;
  font-weight: 1000 !important;
  letter-spacing: 1.1px;
  text-transform: uppercase;
}

.kp-footer p {
  max-width: 430px;
  margin: 0 !important;
  color: rgba(255,255,255,.86) !important;
  font-size: 16px !important;
  line-height: 1.9 !important;
  font-weight: 400;
}

.kp-footer a {
  display: block;
  width: fit-content;
  color: rgba(255,255,255,.88) !important;
  text-decoration: none !important;
  font-size: 16px !important;
  line-height: 1.7;
  margin: 0 0 14px !important;
  font-weight: 400;
  transition: color .18s ease, transform .18s ease;
}

.kp-footer a:hover {
  color: var(--lux-gold, #c8a24a) !important;
  transform: translateX(3px);
}

.kp-footer-contact {
  margin-top: 24px;
  color: rgba(255,255,255,.72);
}

.kp-footer-contact span {
  display: block;
  margin-bottom: 8px;
  color: rgba(255,255,255,.72);
}

.kp-footer-contact a {
  margin-bottom: 0 !important;
  color: var(--lux-gold, #c8a24a) !important;
}

.kp-footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
  margin-top: 56px;
  padding-top: 26px;
  border-top: 1px solid rgba(232, 209, 138, .22);
  color: rgba(255,255,255,.72);
  font-size: 14px;
}

.kp-footer-mini-links {
  display: flex;
  align-items: center;
  gap: 10px;
}

.kp-footer-mini-links a {
  display: inline-flex;
  margin: 0 !important;
  font-size: 14px !important;
}

.kp-footer-mini-links span {
  color: rgba(255,255,255,.45);
}

@media (max-width: 980px) {
  .kp-footer-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 620px) {
  .kp-footer {
    padding: 46px 0 28px !important;
  }

  .kp-footer-inner {
    width: min(100% - 36px, 1500px);
  }

  .kp-footer-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .kp-footer h3 {
    margin-bottom: 14px !important;
  }

  .kp-footer a {
    margin-bottom: 10px !important;
  }

  .kp-footer-bottom {
    align-items: flex-start;
    flex-direction: column;
    margin-top: 34px;
  }
}
.activation-success-box {
  background: #fbf8f1;
  border: 1px solid #d8dec9;
  border-left: 5px solid #2b3b1b;
  border-radius: 18px;
  padding: 20px;
  margin-bottom: 22px;
  color: #161a12;
  box-shadow: 0 12px 28px rgba(22,34,16,.08);
}

.activation-success-box h3 {
  margin: 0 0 8px;
  color: #2b3b1b;
  font-size: 18px;
}

.activation-success-box p {
  margin: 8px 0;
  line-height: 1.7;
  color: #2b2f26;
}

.activation-success-box hr {
  border: 0;
  border-top: 1px solid #d8dec9;
  margin: 16px 0;
}

#rajPwaBanner {
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: 18px;
  z-index: 99999;
  font-family: inherit;
}

.raj-pwa-banner-inner {
  max-width: 980px;
  margin: 0 auto;
  background: linear-gradient(135deg, #2b3b1b 0%, #1f2d16 100%);
  color: #ffffff;
  border: 1px solid rgba(200, 162, 74, 0.45);
  box-shadow: 0 18px 48px rgba(22, 34, 16, 0.28);
  border-radius: 22px;
  padding: 16px 18px;
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
}

.raj-pwa-banner-inner strong {
  display: block;
  color: #e8d18a;
  font-size: 16px;
  letter-spacing: .02em;
}

.raj-pwa-banner-inner span {
  display: block;
  color: rgba(255,255,255,.82);
  font-size: 14px;
  margin-top: 4px;
}

.raj-pwa-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.raj-pwa-actions button,
.raj-pwa-actions a {
  border: 1px solid #e8d18a;
  padding: 10px 15px;
  border-radius: 999px;
  font-weight: 800;
  text-decoration: none;
  background: #e8d18a;
  color: #1f2d16;
  cursor: pointer;
}

.raj-pwa-actions a {
  background: transparent;
  color: #e8d18a;
}

#rajPwaCloseBtn {
  width: 36px;
  height: 36px;
  padding: 0;
  background: rgba(255,255,255,.08);
  color: #ffffff;
  border-color: rgba(255,255,255,.25);
}

.raj-pwa-actions button:disabled {
  opacity: .55;
  cursor: not-allowed;
}

@media (max-width: 700px) {
  #rajPwaBanner {
    left: 10px;
    right: 10px;
    bottom: 12px;
  }

  .raj-pwa-banner-inner {
    align-items: flex-start;
    flex-direction: column;
    border-radius: 18px;
  }

  .raj-pwa-actions {
    width: 100%;
  }

  .raj-pwa-actions button,
  .raj-pwa-actions a {
    flex: 1;
    text-align: center;
  }
}