/* ══════════════════════════════════════════════════════
   MOBCITY DESIGN SYSTEM  |  ds.css
   Font: IBM Plex Sans Arabic (alias: SST Arabic)
   Direction: RTL
══════════════════════════════════════════════════════ */

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; overflow-x: hidden; scroll-behavior: smooth; }

/* ── TOKENS ── */
:root {
  /* Greyscale */
  --g-50:  #F6F6F6;
  --g-100: #E0E0E0;
  --g-300: #BDC1C8;
  --g-500: #9DA1A7;
  --g-700: #787A80;
  --g-900: #1C1C1C;

  /* Primary */
  --p-50:  #E9F4F9;
  --p-100: #E1ECF1;
  --p-500: #2790C3;
  --p-600: #1f7cad;
  --p-700: #15587d;

  /* Semantic */
  --success: #00B517;
  --warning: #FF9017;
  --error:   #FA3434;
  --info:    #2790C3;

  /* Page */
  --bg:      #FFFFFF;
  --bg-alt:  #F6F6F6;
  --ink:     #1C1C1C;
  --subtle:  #787A80;
  --border:  #E0E0E0;

  /* Radius */
  --r-xs: 4px;
  --r-sm: 8px;
  --r:    12px;
  --r-lg: 16px;
  --r-xl: 24px;
  --r-pill: 999px;

  /* Spacing */
  --sp-1: 4px; --sp-2: 8px; --sp-3: 12px; --sp-4: 16px;
  --sp-5: 24px; --sp-6: 32px; --sp-7: 40px; --sp-8: 48px;
  --sp-9: 64px; --sp-10: 80px;

  /* Sidebar */
  --sidebar-w: 260px;

  /* Transition */
  --t: 0.25s cubic-bezier(0.22, 1, 0.36, 1);
}

body {
  font-family: 'IBM Plex Sans Arabic', 'Helvetica Neue', Arial, sans-serif;
  background: var(--bg-alt);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  direction: ltr;
}

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; height: auto; }
button { font-family: inherit; cursor: pointer; }
input, select, textarea { font-family: inherit; }

/* Focus visible */
:focus-visible {
  outline: 2px solid var(--p-700);
  outline-offset: 2px;
}

/* ══════════════════════════════════════════════════════
   LAYOUT — SIDEBAR + MAIN
══════════════════════════════════════════════════════ */
.ds-sidebar {
  position: fixed;
  top: 0; left: 0; bottom: 0;
  width: var(--sidebar-w);
  background: var(--bg);
  border-right: 1px solid var(--border);
  overflow-y: auto;
  z-index: 100;
  padding: var(--sp-5) 0 var(--sp-8);
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ds-sidebar__logo {
  padding: 0 var(--sp-5) var(--sp-5);
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--sp-4);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}
.ds-sidebar__logo-img { height: 28px; }
.ds-sidebar__badge {
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--p-100);
  color: var(--p-700);
  padding: 3px 8px;
  border-radius: var(--r-pill);
}

.ds-sidebar__nav { padding: 0 var(--sp-3); display: flex; flex-direction: column; gap: 4px; }

.ds-nav-group { margin-bottom: var(--sp-4); }
.ds-nav-group__label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--g-300);
  padding: var(--sp-2) var(--sp-3);
  margin-bottom: 2px;
}
.ds-nav-link {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 8px var(--sp-3);
  border-radius: var(--r-sm);
  font-size: 0.875rem;
  color: var(--g-700);
  transition: background var(--t), color var(--t);
}
.ds-nav-link i { font-size: 1rem; flex-shrink: 0; }
.ds-nav-link:hover { background: var(--g-50); color: var(--ink); }
.ds-nav-link.active { background: var(--p-100); color: var(--p-700); font-weight: 600; }

.ds-main {
  margin-left: var(--sidebar-w);
  min-height: 100vh;
  padding-top: 56px;
}

/* Topbar */
.ds-topbar {
  position: fixed;
  top: 0;
  left: var(--sidebar-w);
  right: 0;
  height: 56px;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  padding: 0 var(--sp-8);
  z-index: 90;
}
.ds-topbar__menu { display: none; background: none; border: none; font-size: 1.4rem; color: var(--ink); }
.ds-topbar__title { font-size: 1rem; font-weight: 700; }
.ds-topbar__version { font-size: 0.75rem; background: var(--g-50); border: 1px solid var(--border); padding: 3px 10px; border-radius: var(--r-pill); color: var(--g-700); margin-left: auto; }
.ds-topbar__back {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-left: 12px;
  padding: 5px 14px;
  border-radius: var(--r-pill);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--p-700);
  background: var(--p-50, #E9F4F9);
  border: 1.5px solid var(--p-200, #A8D4EB);
  text-decoration: none;
  transition: background 0.15s, color 0.15s;
  white-space: nowrap;
}
.ds-topbar__back:hover { background: var(--p-100, #C8E6F3); color: var(--p-700); }

/* Sections */
.ds-section {
  padding: var(--sp-9) var(--sp-8);
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  margin-bottom: var(--sp-3);
}

.ds-section__header {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-5);
  margin-bottom: var(--sp-7);
  direction: ltr;
  text-align: left;
}
.ds-section__num {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--g-300);
  letter-spacing: 0.1em;
  min-width: 28px;
  padding-top: 6px;
}
.ds-section__title {
  font-size: 1.625rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-bottom: 6px;
  text-align: left;
}
.ds-section__desc {
  font-size: 0.9375rem;
  color: var(--subtle);
  line-height: 1.65;
  text-align: left;
  direction: ltr;
}

/* Comp blocks */
.ds-comp-block { margin-bottom: var(--sp-6); }
.ds-comp-block__label {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--g-500);
  margin-bottom: var(--sp-3);
  border-bottom: 1px solid var(--g-50);
  padding-bottom: var(--sp-2);
  direction: ltr;
  text-align: left;
}
.ds-comp-row { display: flex; align-items: center; flex-wrap: wrap; gap: var(--sp-3); margin-bottom: var(--sp-3); }
.ds-comp-spec { display: flex; gap: var(--sp-5); flex-wrap: wrap; font-size: 0.8125rem; color: var(--subtle); }

/* Full-width frame */
.ds-fullwidth-frame {
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
}

/* Token group */
.ds-token-group { margin-bottom: var(--sp-6); }
.ds-token-group__title {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--g-500);
  margin-bottom: var(--sp-4);
}

/* A11y note */
.ds-a11y-note {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-2);
  font-size: 0.8125rem;
  color: var(--g-700);
  background: var(--p-50);
  border: 1px solid var(--p-100);
  border-radius: var(--r-sm);
  padding: var(--sp-3) var(--sp-4);
  margin-top: var(--sp-4);
  line-height: 1.5;
}
.ds-a11y-note i { color: var(--p-700); flex-shrink: 0; margin-top: 1px; }

/* Form grid shared */
.ds-form-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-4);
}
.ds-radio-check-row { display: flex; gap: var(--sp-6); flex-wrap: wrap; }


/* ══════════════════════════════════════════════════════
   COLOUR SWATCHES
══════════════════════════════════════════════════════ */
.ds-swatches { display: flex; flex-wrap: wrap; gap: var(--sp-3); }

.ds-swatch {
  display: flex;
  flex-direction: column;
  width: 130px;
  border: 1px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
}
.ds-swatch__chip {
  height: 72px;
  background: var(--sw);
}
.ds-swatch__meta {
  padding: var(--sp-2) var(--sp-3);
  display: flex;
  flex-direction: column;
  gap: 2px;
  background: var(--bg);
}
.ds-swatch__name { font-size: 0.8125rem; font-weight: 600; }
.ds-swatch__hex  { font-size: 0.75rem; color: var(--subtle); }
.ds-swatch__use  { font-size: 0.75rem; color: var(--g-300); text-transform: uppercase; letter-spacing: 0.06em; }


/* ══════════════════════════════════════════════════════
   TYPOGRAPHY SPECIMEN
══════════════════════════════════════════════════════ */
.ds-type-specimen {
  background: var(--g-50);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: var(--sp-5) var(--sp-6);
  margin-bottom: var(--sp-5);
}
.ds-type-specimen__family { font-size: 2rem; font-weight: 700; letter-spacing: -0.02em; margin-bottom: var(--sp-3); }
.ds-type-specimen__weights { display: flex; gap: var(--sp-6); flex-wrap: wrap; font-size: 1.125rem; color: var(--subtle); }
.ds-type-specimen__weights span { color: var(--ink); }

.ds-type-scale { border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; }
.ds-type-scale__head {
  display: grid;
  grid-template-columns: 100px 160px 80px 160px 160px 1fr;
  gap: var(--sp-4);
  padding: var(--sp-3) var(--sp-5);
  background: var(--g-50);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--g-500);
  border-bottom: 1px solid var(--border);
}
.ds-type-scale__row {
  display: grid;
  grid-template-columns: 100px 160px 80px 160px 160px 1fr;
  gap: var(--sp-4);
  align-items: center;
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--g-50);
}
.ds-type-scale__row:last-child { border-bottom: none; }
.ds-type-tag  { font-size: 0.8125rem; font-weight: 700; }
.ds-type-spec { font-size: 0.8125rem; color: var(--subtle); }
.ds-type-use  { font-size: 0.8125rem; color: var(--g-300); }


/* ══════════════════════════════════════════════════════
   SPACING
══════════════════════════════════════════════════════ */
.ds-spacing-grid { display: flex; flex-wrap: wrap; gap: var(--sp-4); }
.ds-space-item { display: flex; flex-direction: column; align-items: center; gap: var(--sp-2); }
.ds-space-box { background: var(--p-500); border-radius: var(--r-xs); flex-shrink: 0; }
.ds-space-val { font-size: 0.875rem; font-weight: 700; }
.ds-space-token { font-size: 0.75rem; color: var(--subtle); }
.ds-space-use { font-size: 0.75rem; color: var(--g-300); text-align: center; }

.ds-radius-grid { display: flex; flex-wrap: wrap; gap: var(--sp-5); margin-top: var(--sp-4); }
.ds-radius-item { display: flex; flex-direction: column; align-items: center; gap: var(--sp-2); }
.ds-radius-box { width: 64px; height: 64px; border: 2px solid var(--g-900); background: var(--p-100); }
.ds-radius-item span { font-size: 0.8125rem; }
.ds-radius-item .ds-space-use { font-size: 0.75rem; }


/* ══════════════════════════════════════════════════════
   ICONS
══════════════════════════════════════════════════════ */
.ds-icon-sizes {
  display: flex; align-items: flex-end; gap: var(--sp-6);
  padding: var(--sp-5); background: var(--g-50);
  border: 1px solid var(--border); border-radius: var(--r);
  margin-bottom: var(--sp-5);
}
.ds-icon-size-demo { display: flex; flex-direction: column; align-items: center; gap: var(--sp-2); }
.ds-icon-size-demo span { font-size: 0.75rem; color: var(--subtle); }

.ds-icon-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
  gap: var(--sp-2);
}
.ds-icon-item {
  display: flex; flex-direction: column; align-items: center; gap: var(--sp-2);
  padding: var(--sp-4) var(--sp-2);
  border: 1px solid var(--border); border-radius: var(--r-sm);
  font-size: 1.5rem; color: var(--ink);
  transition: background var(--t), border-color var(--t);
  cursor: default;
}
.ds-icon-item:hover { background: var(--p-50); border-color: var(--p-500); }
.ds-icon-item span { font-size: 0.6rem; color: var(--subtle); text-align: center; letter-spacing: 0.02em; }


/* ══════════════════════════════════════════════════════
   ACCESSIBILITY
══════════════════════════════════════════════════════ */
.ds-a11y-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: var(--sp-4); margin-bottom: var(--sp-5); }
.ds-a11y-card { border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; }
.ds-a11y-ratio { font-size: 1.5rem; font-weight: 700; padding: var(--sp-3) var(--sp-4); background: var(--g-50); }
.ds-a11y-sample { padding: var(--sp-3) var(--sp-4); font-size: 0.875rem; font-weight: 500; }
.ds-a11y-badge { display: block; padding: var(--sp-2) var(--sp-4); font-size: 0.75rem; font-weight: 700; }
.ds-a11y-badge--pass { background: #E6F4EA; color: #1A7232; }
.ds-a11y-badge--warn { background: #FFF3E6; color: #7A4500; }

.ds-a11y-rules { display: flex; flex-direction: column; gap: var(--sp-2); }
.ds-a11y-rule {
  display: flex; align-items: center; gap: var(--sp-2);
  font-size: 0.9rem; color: var(--subtle); padding: var(--sp-2) 0;
}
.ds-a11y-rule code { background: var(--g-50); border: 1px solid var(--border); border-radius: var(--r-xs); padding: 1px 6px; font-size: 0.8125rem; }


/* ══════════════════════════════════════════════════════
   MC DESIGN SYSTEM COMPONENTS (RTL)
══════════════════════════════════════════════════════ */

/* ── BUTTONS ── */
.mc-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
  border: 1.5px solid transparent; border-radius: var(--r);
  font-family: inherit; font-weight: 600; white-space: nowrap;
  cursor: pointer; transition: background var(--t), color var(--t), border-color var(--t), box-shadow var(--t), transform 0.15s;
  line-height: 1;
}
.mc-btn:hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(0,0,0,0.08); }
.mc-btn:active { transform: translateY(0); box-shadow: none; }
.mc-btn:disabled { opacity: 0.4; cursor: not-allowed; pointer-events: none; }

.mc-btn--lg { min-height: 52px; padding: 14px 28px; font-size: 1rem; border-radius: var(--r); }
.mc-btn--md { min-height: 44px; padding: 11px 22px; font-size: 0.9375rem; }
.mc-btn--sm { min-height: 36px; padding: 8px 16px; font-size: 0.875rem; border-radius: var(--r-sm); }

.mc-btn--primary  { background: var(--p-500); color: #ffffff; border-color: var(--p-500); }
.mc-btn--primary:hover { background: var(--p-600); border-color: var(--p-600); }
.mc-btn--secondary { background: transparent; border-color: var(--g-900); color: var(--g-900); }
.mc-btn--secondary:hover { background: var(--g-900); color: #fff; }
.mc-btn--ghost { background: transparent; border-color: transparent; color: var(--g-900); }
.mc-btn--ghost:hover { background: var(--g-50); }
.mc-btn--danger { background: var(--error); border-color: var(--error); color: #fff; }
.mc-btn--danger:hover { background: #d42b2b; border-color: #d42b2b; }

.mc-btn--icon-only { padding: 10px; border: 1.5px solid var(--border); background: transparent; color: var(--g-700); border-radius: var(--r-sm); }
.mc-btn--icon-only.mc-btn--sm { padding: 7px; min-width: 44px; min-height: 44px; }
.mc-btn--icon-only.mc-btn--lg { padding: 14px; border-radius: var(--r); }
.mc-btn--icon-only:hover { background: var(--g-50); border-color: var(--g-300); color: var(--ink); }
.mc-btn--icon-only.mc-card__wish--active { color: var(--error); border-color: var(--error); background: #FFF0F0; }

.mc-btn--full { width: 100%; }

/* ── BADGES ── */
.mc-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px; border-radius: var(--r-pill);
  font-size: 0.6875rem; font-weight: 700; letter-spacing: 0.04em;
}
.mc-badge--new        { background: #E6F4EA; color: #1A7232; }
.mc-badge--sale       { background: #FFF0F0; color: var(--error); }
.mc-badge--hot        { background: #FFF3E6; color: var(--warning); }
.mc-badge--instock    { background: #E6F4EA; color: #1A7232; }
.mc-badge--low        { background: #FFF3E6; color: var(--warning); }
.mc-badge--out        { background: var(--g-50); color: var(--g-700); }
.mc-badge--unsupported{ background: var(--g-50); color: var(--g-500); text-decoration: line-through; }

.mc-tag {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 5px 14px; border: 1.5px solid var(--border); border-radius: var(--r-pill);
  font-size: 0.8125rem; font-weight: 500; color: var(--subtle);
  background: var(--bg); cursor: pointer;
  transition: border-color var(--t), color var(--t), background var(--t);
}
.mc-tag:hover { border-color: var(--g-700); color: var(--ink); }
.mc-tag--active { border-color: var(--g-900); background: var(--g-900); color: #fff; }
.mc-tag--add    { border-style: dashed; color: var(--g-500); }
.mc-tag--add:hover { border-color: var(--p-700); color: var(--p-700); background: var(--p-50); }

/* ── ALERTS ── */
.mc-alert {
  display: flex; align-items: flex-start; gap: var(--sp-3);
  padding: var(--sp-4); border-radius: var(--r-sm);
  font-size: 0.9rem; margin-bottom: var(--sp-3); line-height: 1.55;
  position: relative;
}
.mc-alert i:first-child { font-size: 1.25rem; flex-shrink: 0; margin-top: 1px; }
.mc-alert > div { flex: 1; }
.mc-alert__close { background: none; border: none; font-size: 1rem; cursor: pointer; margin-right: auto; color: inherit; opacity: 0.6; flex-shrink: 0; }
.mc-alert__close:hover { opacity: 1; }
.mc-alert--success { background: #E6F4EA; color: #1A4726; border: 1px solid #A8D5B5; }
.mc-alert--success > i:first-child { color: var(--success); }
.mc-alert--warning { background: #FFF3E6; color: #6B3A00; border: 1px solid #FFCF8B; }
.mc-alert--warning > i:first-child { color: var(--warning); }
.mc-alert--error   { background: #FFF0F0; color: #7A1818; border: 1px solid #FFA8A8; }
.mc-alert--error > i:first-child   { color: var(--error); }
.mc-alert--info    { background: var(--p-50); color: #0d3d59; border: 1px solid var(--p-100); }
.mc-alert--info > i:first-child    { color: var(--p-700); }

/* ── FORMS ── */
.mc-field { display: flex; flex-direction: column; gap: var(--sp-2); }
.mc-field--full { grid-column: span 2; }
.mc-label { font-size: 0.8125rem; font-weight: 600; color: var(--ink); text-align: right; }

.mc-input-wrap { position: relative; display: flex; align-items: center; width: 100%; }
.mc-input-wrap--select .mc-input { padding-left: 36px; }
.mc-input-wrap--phone { }

.mc-input {
  width: 100%; padding: 10px 14px;
  border: 1.5px solid var(--border); border-radius: var(--r-sm);
  font-size: 0.9375rem; font-family: inherit; color: var(--ink);
  background: var(--bg); outline: none; direction: rtl;
  transition: border-color var(--t), box-shadow var(--t);
}
.mc-input:focus { border-color: var(--g-500); box-shadow: 0 0 0 3px rgba(252,204,192,.3); }
.mc-input::placeholder { color: var(--g-300); }
.mc-input--sm { padding: 7px 12px; font-size: 0.875rem; }
.mc-input--success { border-color: var(--success); }
.mc-input--success:focus { box-shadow: 0 0 0 3px rgba(0,181,23,.15); }
.mc-input--error   { border-color: var(--error); }
.mc-input--error:focus   { box-shadow: 0 0 0 3px rgba(250,52,52,.15); }
.mc-textarea { resize: vertical; min-height: 100px; }
.mc-select { cursor: pointer; appearance: none; }

.mc-input-icon {
  position: absolute;
  font-size: 1.125rem; color: var(--g-300); pointer-events: none; flex-shrink: 0;
}
/* RTL: icon on right (start) */
.mc-input-icon:not(.mc-input-icon--end) { right: 12px; }
.mc-input-wrap > .mc-input { padding-right: 38px; }
.mc-input-icon--end { left: 12px; right: auto; pointer-events: none; }
/* for toggle eye btn */
.mc-input-toggle { pointer-events: auto; background: none; border: none; cursor: pointer; padding: 0; }
.mc-input-wrap > .mc-input { padding-left: 38px; }
/* wraps without left icon */
.mc-input-wrap:not(:has(.mc-input-icon--end)) > .mc-input { padding-left: 14px; }

.mc-input-wrap--phone .mc-phone-prefix {
  position: absolute; right: 12px;
  font-size: 0.875rem; font-weight: 600; color: var(--g-700);
}
.mc-input-wrap--phone .mc-input--phone { padding-right: 48px; }

.mc-input-wrap--select .mc-select-arrow { pointer-events: none; }

.mc-select-arrow { left: 12px; right: auto; color: var(--g-500); }
.mc-input-wrap--select > .mc-input { padding-left: 36px; }

.mc-input-group { display: flex; gap: var(--sp-2); }
.mc-input-group .mc-input { flex: 1; }
.mc-input-group .mc-btn { flex-shrink: 0; }

.mc-price-range { display: flex; align-items: center; gap: var(--sp-2); }
.mc-price-sep { font-size: 0.875rem; color: var(--subtle); flex-shrink: 0; }
.mc-price-range .mc-input { text-align: center; }

/* Stepper */
.mc-stepper {
  display: inline-flex; align-items: center;
  border: 1.5px solid var(--border); border-radius: var(--r-sm); overflow: hidden;
}
.mc-stepper__btn {
  background: var(--g-50); border: none; padding: 10px 14px;
  font-size: 1rem; color: var(--ink); cursor: pointer; flex-shrink: 0;
  transition: background var(--t);
}
.mc-stepper__btn:hover { background: var(--g-100); }
.mc-stepper__input {
  width: 56px; border: none; border-right: 1.5px solid var(--border);
  border-left: 1.5px solid var(--border);
  text-align: center; font-size: 0.9375rem; font-family: inherit;
  color: var(--ink); padding: 8px 0; outline: none;
  -moz-appearance: textfield;
}
.mc-stepper__input::-webkit-outer-spin-button,
.mc-stepper__input::-webkit-inner-spin-button { -webkit-appearance: none; }

/* File Upload */
.mc-upload {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: var(--sp-2); padding: var(--sp-7) var(--sp-5);
  border: 2px dashed var(--border); border-radius: var(--r-sm);
  cursor: pointer; transition: border-color var(--t), background var(--t);
  text-align: center; font-size: 0.9rem; color: var(--g-700);
}
.mc-upload i { font-size: 2rem; color: var(--g-300); }
.mc-upload:hover { border-color: var(--p-500); background: var(--p-50); }
.mc-upload__hint { font-size: 0.75rem; color: var(--g-300); }
.mc-upload__input { display: none; }

/* Hint */
.mc-hint { display: flex; align-items: center; gap: 4px; font-size: 0.75rem; }
.mc-hint--success { color: var(--success); }
.mc-hint--error   { color: var(--error); }
.mc-icon--success { color: var(--success) !important; pointer-events: none; }
.mc-icon--error   { color: var(--error)   !important; pointer-events: none; }

/* Radio / Checkbox */
.mc-fieldset { border: none; padding: 0; }
.mc-radio-label, .mc-check-label {
  display: flex; align-items: center; gap: var(--sp-2);
  font-size: 0.9rem; color: var(--ink); cursor: pointer;
  padding: var(--sp-2) 0;
}
.mc-radio, .mc-checkbox {
  width: 18px; height: 18px; flex-shrink: 0; cursor: pointer;
  accent-color: var(--g-900);
}
.mc-radio-label input:disabled + *, .mc-check-label input:disabled + * { color: var(--g-300); }

/* Switch */
.mc-switch-label {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--sp-2) 0; font-size: 0.9rem; color: var(--ink); cursor: pointer; gap: var(--sp-5);
}
.mc-switch { flex-shrink: 0; }
.mc-switch input { display: none; }
.mc-switch__track {
  display: block; width: 42px; height: 24px; border-radius: var(--r-pill);
  background: var(--g-100); position: relative; transition: background var(--t);
}
.mc-switch__track::after {
  content: ''; position: absolute;
  top: 3px; right: 3px; /* RTL: start on right */
  width: 18px; height: 18px; border-radius: 50%;
  background: #fff; box-shadow: 0 1px 4px rgba(0,0,0,0.15);
  transition: transform var(--t);
}
.mc-switch input:checked + .mc-switch__track { background: var(--g-900); }
.mc-switch input:checked + .mc-switch__track::after { transform: translateX(-18px); }

/* ── BREADCRUMB ── */
.mc-breadcrumb { display: flex; align-items: center; flex-wrap: wrap; gap: 4px; }
.mc-breadcrumb__item { font-size: 0.8125rem; color: var(--subtle); transition: color var(--t); }
.mc-breadcrumb__item:hover { color: var(--ink); }
.mc-breadcrumb__item--current { color: var(--ink); font-weight: 600; }
.mc-breadcrumb__sep { font-size: 0.75rem; color: var(--g-300); display: flex; align-items: center; }

/* ── PRODUCT CARD (Grid) ── */
.mc-card-row { display: flex; flex-wrap: wrap; gap: var(--sp-4); }

.mc-card {
  width: 220px; flex-shrink: 0;
  border: 1px solid var(--border); border-radius: var(--r); overflow: hidden;
  background: var(--bg);
  transition: box-shadow var(--t), transform var(--t);
}
.mc-card:hover { box-shadow: 0 8px 32px rgba(0,0,0,0.1); transform: translateY(-3px); }
.mc-card--out { opacity: 0.75; }
.mc-card--plp { width: 100%; border-radius: 0; border: none; }
.mc-card--plp:hover { transform: none; }

.mc-card__media {
  position: relative; background: var(--g-50); aspect-ratio: 1/1; overflow: hidden;
}
.mc-card__media img {
  width: 100%; height: 100%; object-fit: contain;
  transition: transform 0.5s ease;
  padding: 12px;
}
.mc-card:hover .mc-card__media img { transform: scale(1.04); }
.mc-card__badges { position: absolute; top: 10px; right: 10px; display: flex; flex-direction: column; gap: 4px; }
.mc-card__wish {
  position: absolute; top: 8px; left: 8px;
  background: rgba(255,255,255,0.9) !important;
  border-color: transparent !important;
}
.mc-card__body { padding: var(--sp-4); display: flex; flex-direction: column; gap: var(--sp-2); }
.mc-card__brand { font-size: 0.6875rem; font-weight: 700; color: var(--subtle); text-transform: uppercase; letter-spacing: 0.08em; }
.mc-card__name  { font-size: 0.875rem; font-weight: 700; color: var(--ink); line-height: 1.35; }
.mc-card__rating { display: flex; align-items: center; gap: 2px; font-size: 0.75rem; color: var(--warning); }
.mc-card__rating-count { color: var(--subtle); margin-right: 4px; }
.mc-card__price-row { display: flex; align-items: center; gap: var(--sp-2); flex-wrap: wrap; }
.mc-card__price { font-size: 1rem; font-weight: 700; color: var(--ink); }
.mc-card__price-old { font-size: 0.8125rem; color: var(--g-300); text-decoration: line-through; }

/* List card */
.mc-list-card {
  display: flex; gap: var(--sp-4);
  border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; background: var(--bg);
  padding: var(--sp-4);
}
.mc-list-card__media {
  position: relative; width: 160px; flex-shrink: 0;
  border-radius: var(--r-sm); overflow: hidden; background: var(--g-50);
}
.mc-list-card__media img { width: 100%; aspect-ratio: 1; object-fit: contain; padding: 8px; }
.mc-list-card__media .mc-card__badges { top: 6px; right: 6px; }
.mc-list-card__body { flex: 1; display: flex; flex-direction: column; gap: var(--sp-3); }
.mc-list-card__top { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--sp-5); }
.mc-list-card__price-col { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; white-space: nowrap; }
.mc-list-card__bottom { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: var(--sp-3); }
.mc-list-card__tags { display: flex; gap: var(--sp-2); flex-wrap: wrap; }
.mc-list-card__actions { display: flex; gap: var(--sp-2); }

/* ── SUBSCRIPTION ── */
.mc-subscription {
  display: flex; align-items: center; justify-content: space-between; gap: var(--sp-6);
  padding: var(--sp-7); background: var(--p-50);
  border: 1px solid var(--p-100); border-radius: var(--r-lg);
  flex-wrap: wrap;
}
.mc-subscription__text h3 { font-size: 1.25rem; font-weight: 700; margin-bottom: var(--sp-2); }
.mc-subscription__text p  { font-size: 0.9rem; color: var(--subtle); }
.mc-subscription__form { min-width: 320px; flex: 1; }

/* ── HEADER ORGANISM ── */
.mc-topbar {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 20px; background: var(--g-900); color: rgba(255,255,255,0.65); font-size: 0.8125rem;
}
.mc-topbar__links { display: flex; gap: var(--sp-5); }
.mc-topbar__links a { color: rgba(255,255,255,0.65); transition: color var(--t); }
.mc-topbar__links a:hover { color: #fff; }

.mc-header-org { background: var(--bg); border-bottom: 1px solid var(--border); }
.mc-header-org__inner {
  display: flex; align-items: center; gap: var(--sp-5); padding: var(--sp-4) 20px;
}
.mc-header-org__logo { flex-shrink: 0; }
.mc-header-org__search { flex: 1; }
.mc-header-org__actions { display: flex; align-items: center; gap: var(--sp-3); flex-shrink: 0; }
.mc-header-org__action-btn {
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  height: auto; padding: 6px 10px; border: none !important;
}
.mc-action-label { font-size: 0.625rem; color: var(--subtle); }
.mc-header-org__cart { position: relative; }
.mc-cart-badge {
  position: absolute; top: 2px; left: 2px;
  background: var(--p-500); color: #ffffff; font-size: 0.6rem; font-weight: 700;
  min-width: 16px; height: 16px; border-radius: var(--r-pill);
  display: flex; align-items: center; justify-content: center; padding: 0 3px;
}

.mc-nav-bar {
  display: flex; border-top: 1px solid var(--border);
  background: var(--bg);
}
.mc-nav-bar__link {
  display: flex; align-items: center; gap: 4px;
  padding: 12px 16px; font-size: 0.875rem; font-weight: 500; color: var(--subtle);
  transition: color var(--t); border-bottom: 2px solid transparent;
  white-space: nowrap;
}
.mc-nav-bar__link:hover { color: var(--ink); }
.mc-nav-bar__link--active { color: var(--ink); border-bottom-color: var(--g-900); font-weight: 700; }

/* ── FOOTER ORGANISM ── */
.mc-footer-org { }
.mc-footer-org__inner {
  display: grid; grid-template-columns: 1.5fr repeat(3,1fr); gap: var(--sp-6); padding: var(--sp-7) var(--sp-6);
}
.mc-footer-org__brand p { font-size: 0.875rem; color: rgba(255,255,255,0.5); line-height: 1.65; margin: var(--sp-3) 0 var(--sp-4); }
.mc-footer-org__socials { display: flex; gap: var(--sp-3); }
.mc-footer-org__socials a {
  width: 36px; height: 36px; border-radius: var(--r-sm);
  background: rgba(255,255,255,0.08); display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.6); font-size: 1.1rem;
  transition: background var(--t), color var(--t);
}
.mc-footer-org__socials a:hover { background: rgba(255,255,255,0.15); color: #fff; }
.mc-footer-org__col { display: flex; flex-direction: column; gap: var(--sp-3); }
.mc-footer-org__col-title { font-size: 0.8125rem; font-weight: 700; color: #fff; margin-bottom: 4px; }
.mc-footer-org__col a { font-size: 0.875rem; color: rgba(255,255,255,0.5); transition: color var(--t); }
.mc-footer-org__col a:hover { color: #fff; }
.mc-footer-org__payments { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.mc-payment-chip {
  padding: 4px 10px; border: 1px solid rgba(255,255,255,0.15);
  border-radius: var(--r-xs); font-size: 0.75rem; font-weight: 700;
  color: rgba(255,255,255,0.6);
}
.mc-footer-org__bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--sp-4) var(--sp-6); border-top: 1px solid rgba(255,255,255,0.1);
  font-size: 0.8125rem; color: rgba(255,255,255,0.35); flex-wrap: wrap; gap: var(--sp-3);
}
.mc-footer-org__bottom a { color: rgba(255,255,255,0.35); transition: color var(--t); }
.mc-footer-org__bottom a:hover { color: rgba(255,255,255,0.7); }

/* ── PLP ── */
.mc-plp-bar {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: var(--sp-3); padding: var(--sp-3) 20px;
  border-bottom: 1px solid var(--border); background: var(--bg);
}
.mc-plp-bar__right { display: flex; align-items: center; gap: var(--sp-2); flex-wrap: wrap; }
.mc-plp-bar__left  { display: flex; align-items: center; gap: var(--sp-2); flex-wrap: wrap; }
.mc-plp-bar__count { font-size: 0.8125rem; color: var(--subtle); }
.mc-plp-view-btn { border: 1px solid var(--border) !important; }
.mc-plp-view-btn--active { background: var(--g-50) !important; }
.mc-plp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(175px, 1fr));
  gap: 1px; background: var(--border);
}

/* ── PDP ── */
.mc-pdp { display: grid; grid-template-columns: 1fr 1fr; }

.mc-pdp__gallery { padding: var(--sp-5); background: var(--g-50); display: flex; flex-direction: column; gap: var(--sp-3); }
.mc-pdp__gallery-main { border-radius: var(--r); overflow: hidden; border: 1px solid var(--border); background: #fff; }
.mc-pdp__gallery-main img { width: 100%; aspect-ratio: 1; object-fit: contain; padding: 20px; }
.mc-pdp__gallery-thumbs { display: flex; gap: var(--sp-2); }
.mc-pdp__thumb { width: 68px; height: 68px; border-radius: var(--r-sm); overflow: hidden; border: 2px solid transparent; cursor: pointer; background: var(--bg); transition: border-color var(--t); }
.mc-pdp__thumb img { width: 100%; height: 100%; object-fit: contain; padding: 4px; }
.mc-pdp__thumb--active { border-color: var(--g-900); }
.mc-pdp__thumb:hover:not(.mc-pdp__thumb--active) { border-color: var(--g-300); }

.mc-pdp__info { padding: var(--sp-6); background: var(--bg); display: flex; flex-direction: column; gap: var(--sp-4); }
.mc-pdp__brand { font-size: 0.75rem; font-weight: 700; color: var(--subtle); text-transform: uppercase; letter-spacing: 0.1em; }
.mc-pdp__title { font-size: 1.25rem; font-weight: 700; letter-spacing: -0.02em; line-height: 1.35; }
.mc-pdp__rating { display: flex; align-items: center; gap: 3px; font-size: 0.875rem; color: var(--warning); }
.mc-pdp__rating > span:first-of-type { font-weight: 700; color: var(--ink); }
.mc-pdp__review-count { color: var(--subtle); font-size: 0.8125rem; margin-right: var(--sp-2); }
.mc-pdp__pricing { display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap; }
.mc-pdp__price { font-size: 1.75rem; font-weight: 700; }
.mc-pdp__price-old { font-size: 1rem; color: var(--g-300); text-decoration: line-through; }

.mc-pdp__option-group { display: flex; flex-direction: column; gap: var(--sp-2); }
.mc-pdp__option-label { font-size: 0.8125rem; font-weight: 600; color: var(--subtle); }
.mc-pdp__options { display: flex; gap: var(--sp-2); flex-wrap: wrap; }
.mc-pdp__colors { display: flex; gap: var(--sp-2); }

.mc-option-btn {
  padding: 8px 16px; border: 1.5px solid var(--border); border-radius: var(--r-sm);
  font-size: 0.875rem; font-weight: 600; background: var(--bg); color: var(--ink);
  cursor: pointer; font-family: inherit; transition: border-color var(--t), background var(--t);
}
.mc-option-btn:hover { border-color: var(--g-500); }
.mc-option-btn--active { border-color: var(--g-900); background: var(--g-50); }

.mc-color-btn {
  width: 30px; height: 30px; border-radius: 50%; border: 2px solid transparent;
  background: var(--c); cursor: pointer; transition: transform 0.2s, outline var(--t);
}
.mc-color-btn:hover { transform: scale(1.1); }
.mc-color-btn--active { outline: 2.5px solid var(--g-900); outline-offset: 2px; }

.mc-pdp__actions { display: flex; gap: var(--sp-2); flex-wrap: wrap; }
.mc-pdp__actions .mc-btn--full { flex: 1; min-width: 140px; }

.mc-pdp__badges-row {
  display: grid; grid-template-columns: repeat(2,1fr); gap: var(--sp-2);
  padding: var(--sp-4); background: var(--g-50); border-radius: var(--r-sm);
}
.mc-pdp__badge-item {
  display: flex; align-items: center; gap: var(--sp-2);
  font-size: 0.8125rem; color: var(--g-700);
}
.mc-pdp__badge-item i { font-size: 1.1rem; color: var(--p-700); }

/* ── CHECKOUT ── */
.mc-checkout-steps {
  display: flex; align-items: center; padding: var(--sp-5) var(--sp-6);
  border-bottom: 1px solid var(--border); background: var(--bg);
  flex-wrap: wrap; gap: 0;
}
.mc-checkout-step { display: flex; align-items: center; gap: var(--sp-2); font-size: 0.875rem; font-weight: 600; color: var(--g-300); flex-shrink: 0; }
.mc-checkout-step--active { color: var(--ink); }
.mc-checkout-step--done   { color: var(--success); }
.mc-checkout-step__num {
  width: 28px; height: 28px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.8125rem; font-weight: 700;
  background: var(--g-50); color: var(--g-500); border: 1.5px solid var(--border);
}
.mc-checkout-step--active .mc-checkout-step__num { background: var(--g-900); color: #fff; border-color: var(--g-900); }
.mc-checkout-step--done   .mc-checkout-step__num { background: var(--success); color: #fff; border-color: var(--success); }
.mc-checkout-step__line { flex: 1; height: 1px; background: var(--border); margin: 0 var(--sp-2); min-width: var(--sp-5); }

.mc-checkout-body { display: grid; grid-template-columns: 1fr 380px; }
.mc-checkout-form { padding: var(--sp-5); border-left: 1px solid var(--border); }
.mc-checkout-form__title { font-size: 1rem; font-weight: 700; margin-bottom: var(--sp-5); }
.mc-checkout-summary { padding: var(--sp-5); background: var(--g-50); }

.mc-checkout-item {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-3) 0; border-bottom: 1px solid var(--border); margin-bottom: var(--sp-3);
}
.mc-checkout-item__img { width: 60px; height: 60px; object-fit: contain; padding: 4px; border-radius: var(--r-sm); background: var(--bg); border: 1px solid var(--border); flex-shrink: 0; }
.mc-checkout-item__body { flex: 1; }
.mc-checkout-item__name { font-size: 0.875rem; font-weight: 600; }
.mc-checkout-item__variant { font-size: 0.8125rem; color: var(--subtle); margin-top: 2px; }
.mc-checkout-item__price { font-size: 0.9375rem; font-weight: 700; white-space: nowrap; }

.mc-checkout-totals { display: flex; flex-direction: column; gap: var(--sp-3); }
.mc-checkout-total-row { display: flex; justify-content: space-between; font-size: 0.875rem; color: var(--subtle); }
.mc-checkout-total-row--grand { font-size: 1rem; font-weight: 700; color: var(--ink); padding-top: var(--sp-3); border-top: 1px solid var(--border); }
.mc-checkout-total-row--discount { }
.mc-free { color: var(--success); font-weight: 600; }
.mc-discount { color: var(--error); font-weight: 600; }

/* ── USER PROFILE ── */
.mc-profile { display: grid; grid-template-columns: 240px 1fr; }
.mc-profile__sidebar { padding: var(--sp-5); border-left: 1px solid var(--border); background: var(--g-50); }
.mc-profile__avatar { display: flex; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-5); padding-bottom: var(--sp-5); border-bottom: 1px solid var(--border); }
.mc-profile__avatar-img {
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--g-100); display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.mc-profile__name  { font-size: 0.9375rem; font-weight: 700; }
.mc-profile__email { font-size: 0.8125rem; color: var(--subtle); }
.mc-profile__nav { display: flex; flex-direction: column; gap: 2px; }
.mc-profile__nav-link {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-3); border-radius: var(--r-sm);
  font-size: 0.875rem; color: var(--subtle);
  transition: background var(--t), color var(--t);
}
.mc-profile__nav-link:hover { background: var(--g-100); color: var(--ink); }
.mc-profile__nav-link--active { background: var(--bg); color: var(--ink); font-weight: 600; }
.mc-profile__nav-link--danger { color: var(--error); margin-top: var(--sp-3); }
.mc-profile__nav-link--danger:hover { background: #FFF0F0; }
.mc-profile__content { padding: var(--sp-5); }

.mc-order-list { display: flex; flex-direction: column; }
.mc-order-item { display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-3) 0; border-bottom: 1px solid var(--border); }
.mc-order-item__body { flex: 1; }
.mc-order-item__meta { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; }


/* ══════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .mc-footer-org__inner { grid-template-columns: 1fr 1fr; }
  .mc-profile { grid-template-columns: 1fr; }
  .mc-profile__sidebar { border-left: none; border-bottom: 1px solid var(--border); }
  .mc-pdp { grid-template-columns: 1fr; }
  .mc-checkout-body { grid-template-columns: 1fr; }
  .mc-checkout-form { border-left: none; border-bottom: 1px solid var(--border); }
  .ds-type-scale__head,
  .ds-type-scale__row { grid-template-columns: 80px 130px 60px 120px 120px 1fr; font-size: 0.8125rem; }
}

@media (max-width: 900px) {
  .ds-sidebar { display: none; }
  .ds-sidebar.open { display: flex; }
  .ds-main { margin-left: 0; }
  .ds-topbar { left: 0; right: 0; }
  .ds-topbar__menu { display: flex; align-items: center; }
  .ds-section { padding: var(--sp-7) var(--sp-5); }
  .ds-form-grid { grid-template-columns: 1fr; }
  .mc-field--full { grid-column: span 1; }
  .ds-type-scale__head { display: none; }
  .ds-type-scale__row { grid-template-columns: 1fr; gap: 4px; padding: var(--sp-4); border-bottom: 1px solid var(--border); }
  .ds-radio-check-row { flex-direction: column; gap: var(--sp-4); }
  .mc-header-org__inner { flex-wrap: wrap; }
  .mc-header-org__search { order: 3; width: 100%; }
  .mc-subscription { flex-direction: column; }
  .mc-subscription__form { width: 100%; }
}

@media (max-width: 640px) {
  .mc-footer-org__inner { grid-template-columns: 1fr; }
  .mc-pdp__badges-row { grid-template-columns: 1fr; }
  .mc-list-card { flex-direction: column; }
  .mc-list-card__media { width: 100%; }
  .mc-card-row { gap: var(--sp-3); }
  .mc-card { width: calc(50% - var(--sp-3)/2); }
  .ds-icon-grid { grid-template-columns: repeat(auto-fill, minmax(64px,1fr)); }
  .ds-swatches { gap: var(--sp-2); }
  .ds-swatch { width: 110px; }
}
