/* =================================================================
   UNIQ — Section visual styles
   Each block is themed only through tokens so the Studio theme panel
   restyles everything live.
   ================================================================= */

/* ---------------- HERO ---------------- */
.hero { min-height: 100svh; display: grid; align-items: end; position: relative; overflow: hidden; padding-bottom: var(--sp-5); isolation: isolate; }
.hero__bg { position: absolute; inset: 0; z-index: -2; }
.hero__bg::before {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(120% 90% at 80% 10%, color-mix(in srgb, var(--c-green) 55%, transparent), transparent 60%),
    radial-gradient(90% 70% at 10% 90%, color-mix(in srgb, var(--c-green-900) 90%, transparent), transparent 70%),
    linear-gradient(180deg, var(--c-ink) 0%, var(--c-green-900) 120%);
}
.hero__crystal { position: absolute; inset-block-start: 8%; inset-inline-end: 6%; width: clamp(180px, 30vw, 460px); color: var(--c-cream); opacity: 0.9; z-index: -1; filter: drop-shadow(0 30px 60px color-mix(in srgb, var(--c-green) 50%, transparent)); }
.hero__eyebrow { color: var(--c-gold); margin-bottom: var(--sp-2); }
.hero__title { font-family: var(--font-display); font-size: var(--fs-mega); line-height: 0.82; letter-spacing: var(--tracking-tight); }
.hero__title .stroke { -webkit-text-stroke: 1.5px var(--c-cream); color: transparent; }
.hero__lead { max-width: 46ch; margin-top: var(--sp-3); color: var(--text-on-dark-dim); font-size: var(--fs-lead); }
.hero__cta { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin-top: var(--sp-4); align-items: center; }
.hero__meta { position: absolute; inset-block-end: var(--sp-4); inset-inline-end: var(--gutter); display: flex; flex-direction: column; align-items: flex-end; gap: var(--sp-2); }
.hero__est { font-family: var(--font-display); font-size: 0.9rem; letter-spacing: 0.3em; color: var(--text-on-dark-dim); }
@media (max-width: 720px) { .hero__crystal { opacity: 0.35; inset-inline-end: -10%; } .hero__meta { display: none; } }

/* ---------------- MANIFESTO ---------------- */
.manifesto { position: relative; overflow: hidden; }
.manifesto .ghost-crystal { inset-block-start: 50%; inset-inline-start: 50%; transform: translate(-50%,-50%); width: min(70vw, 720px); }
.manifesto__statement { font-family: var(--font-editorial); font-weight: 300; font-size: var(--fs-h1); line-height: 1.08; max-width: 24ch; position: relative; z-index: 2; }
.manifesto__statement b { font-weight: 500; font-style: italic; color: var(--c-green); }
.section--stage .manifesto__statement b { color: var(--c-gold); }
.manifesto__word { display: inline-block; opacity: 0.16; transition: opacity var(--dur-2) var(--ease-out); }
.manifesto__word.lit { opacity: 1; }
.manifesto__foot { display: flex; flex-wrap: wrap; gap: var(--sp-5); margin-top: var(--sp-5); }
.manifesto__stat .n { font-family: var(--font-display); font-size: var(--fs-h2); display: block; }
.manifesto__stat .l { font-size: var(--fs-small); color: var(--text-on-paper-dim); letter-spacing: 0.08em; text-transform: uppercase; }
.section--stage .manifesto__stat .l { color: var(--text-on-dark-dim); }

/* ---------------- FEATURED COLLECTION ---------------- */
.collection__head { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--sp-3); margin-bottom: var(--sp-4); flex-wrap: wrap; }
.collection__head h2 { font-family: var(--font-editorial); font-size: var(--fs-h2); max-width: 14ch; }
.collection__grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: clamp(0.8rem, 1.6vw, 1.6rem); }
.pcard { position: relative; grid-column: span 4; display: flex; flex-direction: column; }
.pcard:nth-child(3n+1) { grid-column: span 4; }
.pcard__media { position: relative; aspect-ratio: 4/5; border-radius: var(--r-md); overflow: hidden; background: var(--surface-2); }
.pcard__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-4) var(--ease-spring); }
.pcard:hover .pcard__media img { transform: scale(1.06); }
.pcard__media::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, color-mix(in srgb, var(--c-ink) 60%, transparent), transparent 50%); opacity: 0.7; }
.pcard__tint { position: absolute; inset: 0; background: var(--c-green); mix-blend-mode: multiply; opacity: 0; transition: opacity var(--dur-3); }
.pcard:hover .pcard__tint { opacity: 0.22; }
.pcard__badge { position: absolute; inset-block-start: var(--sp-2); inset-inline-start: var(--sp-2); z-index: 2; background: color-mix(in srgb, var(--c-ink) 50%, transparent); backdrop-filter: blur(6px); color: var(--c-cream); }
.pcard__fav { position: absolute; inset-block-start: var(--sp-2); inset-inline-end: var(--sp-2); z-index: 2; width: 40px; height: 40px; border-radius: var(--r-pill); display: grid; place-items: center; background: color-mix(in srgb, var(--c-bone) 86%, transparent); color: var(--c-green); opacity: 0; transform: translateY(-6px); transition: opacity var(--dur-2), transform var(--dur-2) var(--ease-spring); }
.pcard:hover .pcard__fav { opacity: 1; transform: none; }
.pcard__cta { position: absolute; inset-block-end: var(--sp-2); inset-inline: var(--sp-2); z-index: 2; opacity: 0; transform: translateY(10px); transition: opacity var(--dur-2), transform var(--dur-2) var(--ease-spring); }
.pcard:hover .pcard__cta { opacity: 1; transform: none; }
.pcard__info { display: flex; justify-content: space-between; align-items: baseline; padding-block-start: var(--sp-2); gap: var(--sp-1); }
.pcard__name { font-weight: 600; font-size: 1.05rem; }
.pcard__cat { font-size: var(--fs-micro); letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-on-paper-dim); }
.section--stage .pcard__cat { color: var(--text-on-dark-dim); }
.pcard__price { font-family: var(--font-display); font-size: 1.15rem; }
.price-vat { font-size: var(--fs-micro); opacity: 0.6; }
@media (max-width: 900px) { .pcard, .pcard:nth-child(3n+1) { grid-column: span 6; } }
@media (max-width: 560px) { .pcard, .pcard:nth-child(3n+1) { grid-column: span 12; } }

/* ---------------- LOOKBOOK / EDITORIAL ---------------- */
.lookbook { position: relative; }
.lookbook__grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: clamp(1rem, 2vw, 2rem); align-items: center; }
.lookbook__media { position: relative; border-radius: var(--r-md); overflow: hidden; }
.lookbook__media img { width: 100%; height: 100%; object-fit: cover; }
.lookbook__a { grid-column: 1 / span 7; aspect-ratio: 16/11; }
.lookbook__b { grid-column: 8 / span 5; aspect-ratio: 3/4; align-self: end; transform: translateY(-8%); }
.lookbook__copy { grid-column: 1 / span 5; }
.lookbook__copy h2 { font-family: var(--font-editorial); font-size: var(--fs-h2); margin-bottom: var(--sp-2); }
.lookbook__overlap { position: absolute; inset-inline-start: 4%; inset-block-end: -4%; font-family: var(--font-display); font-size: clamp(3rem, 10vw, 9rem); color: var(--c-bone); mix-blend-mode: difference; pointer-events: none; z-index: 3; }
[dir='rtl'] .lookbook__a { grid-column: 6 / span 7; }
[dir='rtl'] .lookbook__b { grid-column: 1 / span 5; }
@media (max-width: 820px) {
  .lookbook__a, .lookbook__b, .lookbook__copy { grid-column: 1 / -1; transform: none; }
}

/* ---------------- MARQUEE ---------------- */
.marquee { padding-block: var(--sp-3); border-block: 1px solid var(--line); overflow: hidden; }
.marquee__item { font-family: var(--font-display); font-size: clamp(2rem, 6vw, 5rem); display: inline-flex; align-items: center; gap: 3rem; }
.marquee__star { color: var(--c-gold); font-size: 0.5em; }
.marquee__item .outline { -webkit-text-stroke: 1.5px currentColor; color: transparent; }

/* ---------------- TRUST / COMPLIANCE ---------------- */
.trust { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: var(--sp-3); }
.trust__item { display: flex; gap: var(--sp-2); align-items: flex-start; }
.trust__item .ico { width: 44px; height: 44px; flex: none; border-radius: var(--r-sm); display: grid; place-items: center; background: color-mix(in srgb, var(--c-green) 12%, transparent); color: var(--c-green); }
.section--stage .trust__item .ico { background: color-mix(in srgb, var(--c-cream) 12%, transparent); color: var(--c-cream); }
.trust__item h4 { font-size: 1rem; margin-bottom: 0.2rem; }
.trust__item p { font-size: var(--fs-small); color: var(--text-on-paper-dim); }
.section--stage .trust__item p { color: var(--text-on-dark-dim); }
.pay-strip { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; margin-top: var(--sp-3); }
.pay-badge { height: 34px; padding: 0 0.7rem; border-radius: var(--r-xs); display: inline-flex; align-items: center; gap: 0.4rem; font-size: var(--fs-micro); font-weight: 700; letter-spacing: 0.04em; background: var(--surface-1); color: var(--c-ink); border: 1px solid var(--line); }
.pay-badge.mada { background: #231f20; color: #fff; }
.pay-badge.applepay { background: #000; color: #fff; }
.pay-badge.stc { background: #4f008c; color: #fff; }
.pay-badge.tabby { background: #3fe0c5; color: #06302a; }
.pay-badge.tamara { background: #ffd5c2; color: #3a1d12; }
.pay-badge.visa { color: #1a1f71; }
.pay-badge.mc { color: #b3402d; }
.pay-badge.cod { background: var(--c-green); color: var(--c-cream); }

/* ---------------- FOOTER ---------------- */
.footer__grid { display: grid; grid-template-columns: 1.4fr repeat(3, 1fr); gap: var(--sp-4); margin-bottom: var(--sp-5); }
.footer__news h3 { font-family: var(--font-editorial); font-size: var(--fs-h3); margin-bottom: var(--sp-2); max-width: 16ch; }
.news-form { display: flex; gap: 0.5rem; max-width: 380px; margin-top: var(--sp-2); }
.news-form input { flex: 1; padding: 0.9rem 1.1rem; border-radius: var(--r-pill); border: 1px solid var(--line-strong); background: transparent; color: inherit; }
.news-form input::placeholder { color: var(--text-on-dark-dim); }
.footer__col h5 { font-size: var(--fs-micro); letter-spacing: 0.16em; text-transform: uppercase; color: var(--c-gold); margin-bottom: var(--sp-2); }
.footer__col a { display: block; padding-block: 0.3rem; font-size: var(--fs-small); color: var(--text-on-dark-dim); transition: color var(--dur-1); }
.footer__col a:hover { color: var(--c-cream); }
.footer__legal { display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--sp-2); padding-top: var(--sp-3); border-top: 1px solid var(--line); align-items: center; }
.footer__legal small { color: var(--text-on-dark-dim); font-size: var(--fs-micro); line-height: 1.8; }
.compliance-badges { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; }
.maroof, .zatca { display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.4rem 0.7rem; border: 1px solid var(--line-strong); border-radius: var(--r-sm); font-size: var(--fs-micro); }
.maroof { color: #1a7d8a; } .zatca { color: var(--c-gold); }
@media (max-width: 820px) { .footer__grid { grid-template-columns: 1fr 1fr; } .footer__news { grid-column: 1 / -1; } }

/* ---------------- PRODUCT STORY (Apple-style) ---------------- */
.pstory { background: var(--c-ink); color: var(--c-cream); position: relative; }
.pstory__pin { height: 100svh; position: relative; display: grid; place-items: center; overflow: hidden; }
.pstory__stage { position: absolute; inset: 0; display: grid; place-items: center; }
.pstory__hero-img { width: clamp(280px, 42vw, 620px); aspect-ratio: 3/4; object-fit: contain; will-change: transform; filter: drop-shadow(0 40px 80px rgba(0,0,0,0.5)); }
.pstory__caption { position: absolute; max-width: 30ch; }
.pstory__caption .eyebrow { color: var(--c-gold); }
.pstory__caption h3 { font-family: var(--font-editorial); font-size: var(--fs-h2); margin-block: 0.5rem; }
.pstory__caption p { color: var(--text-on-dark-dim); font-size: var(--fs-lead); }
.pstory__beat { position: absolute; opacity: 0; }
.pstory__intro-title { font-family: var(--font-display); font-size: var(--fs-mega); text-align: center; line-height: 0.85; }
.pstory__spot { position: absolute; inset: 0; cursor: grab; }
.pstory__spot:active { cursor: grabbing; }
.pstory__hint { position: absolute; inset-block-end: 8%; inset-inline-start: 50%; transform: translateX(-50%); font-size: var(--fs-micro); letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-on-dark-dim); }

/* Buy block */
.pbuy { background: var(--bg-paper); color: var(--text-on-paper); }
.pbuy__grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-5); align-items: start; }
.pbuy__media { position: sticky; top: 100px; border-radius: var(--r-md); overflow: hidden; aspect-ratio: 4/5; background: var(--surface-2); }
.pbuy__media img { width: 100%; height: 100%; object-fit: cover; }
.pbuy h2 { font-family: var(--font-editorial); font-size: var(--fs-h1); line-height: 1; }
.pbuy__price { display: flex; align-items: baseline; gap: 0.6rem; margin-block: var(--sp-2); }
.pbuy__price .now { font-family: var(--font-display); font-size: var(--fs-h2); }
.pbuy__price .vat { font-size: var(--fs-small); color: var(--text-on-paper-dim); }
.opt-group { margin-block: var(--sp-3); }
.opt-group .label { font-size: var(--fs-micro); letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-on-paper-dim); margin-bottom: var(--sp-1); display: flex; justify-content: space-between; }
.swatches { display: flex; gap: 0.6rem; }
.swatch { width: 38px; height: 38px; border-radius: var(--r-pill); border: 2px solid transparent; box-shadow: inset 0 0 0 2px var(--surface-1); cursor: pointer; transition: transform var(--dur-1) var(--ease-spring); }
.swatch[aria-pressed='true'] { border-color: var(--c-green); transform: scale(1.08); }
.sizes { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.size { min-width: 54px; padding: 0.7rem 0.9rem; border: 1px solid var(--line-strong); border-radius: var(--r-sm); font-weight: 600; text-align: center; transition: background var(--dur-1), color var(--dur-1), border-color var(--dur-1); }
.size[aria-pressed='true'] { background: var(--c-green); color: var(--c-cream); border-color: var(--c-green); }
.size:hover { border-color: var(--c-green); }
.bnpl { display: flex; align-items: center; gap: 0.6rem; padding: 0.8rem 1rem; border: 1px dashed var(--line-strong); border-radius: var(--r-sm); font-size: var(--fs-small); margin-block: var(--sp-2); }
.pbuy__accordion details { border-top: 1px solid var(--line); }
.pbuy__accordion summary { padding-block: var(--sp-2); cursor: pointer; font-weight: 600; display: flex; justify-content: space-between; list-style: none; }
.pbuy__accordion summary::-webkit-details-marker { display: none; }
.pbuy__accordion p { padding-bottom: var(--sp-2); font-size: var(--fs-small); color: var(--text-on-paper-dim); }
@media (max-width: 820px) { .pbuy__grid { grid-template-columns: 1fr; } .pbuy__media { position: relative; top: 0; } }

/* Sticky add-to-cart bar */
.buybar {
  position: fixed; inset-block-end: 0; inset-inline: 0; z-index: var(--z-header);
  display: flex; align-items: center; justify-content: space-between; gap: var(--sp-2);
  padding: 0.8rem var(--gutter); background: color-mix(in srgb, var(--c-ink) 88%, transparent);
  backdrop-filter: blur(16px); border-top: 1px solid var(--line);
  transform: translateY(120%); transition: transform var(--dur-3) var(--ease-spring);
}
.buybar.is-shown { transform: translateY(0); }
.buybar__info { display: flex; flex-direction: column; line-height: 1.2; }
.buybar__info strong { font-weight: 600; }
.buybar__info span { font-size: var(--fs-small); color: var(--text-on-dark-dim); }
@media (min-width: 821px) { .buybar { display: none; } }

/* Static fallback for product story (reduced-motion / no gsap) */
.pstory.is-static .pstory__pin { height: auto; display: block; padding-block: var(--sp-5); }
.pstory.is-static .pstory__stage { position: relative; display: block; }
.pstory.is-static .pstory__layer { position: relative !important; margin-block: var(--sp-4); }
.pstory.is-static .pstory__beat { position: relative !important; inset: auto !important; text-align: center; max-width: 60ch; margin: var(--sp-2) auto; }
.pstory.is-static .pstory__hint { display: none; }

/* Size guide dialog */
dialog.sizeguide { border: none; border-radius: var(--r-lg); padding: var(--sp-4); max-width: 460px; width: 92vw; background: var(--bg-paper); color: var(--text-on-paper); box-shadow: var(--shadow-float); }
dialog.sizeguide::backdrop { background: color-mix(in srgb, var(--c-ink) 60%, transparent); backdrop-filter: blur(4px); }
dialog.sizeguide header { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--sp-3); }
dialog.sizeguide header h3 { font-family: var(--font-editorial); font-size: var(--fs-h3); }
dialog.sizeguide table { width: 100%; border-collapse: collapse; }
dialog.sizeguide th, dialog.sizeguide td { padding: 0.6rem; text-align: start; border-bottom: 1px solid var(--line); font-size: var(--fs-small); }
dialog.sizeguide th { color: var(--c-green); font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; font-size: var(--fs-micro); }

/* ---------------- SHOP — CATALOG + FILTERS ---------------- */
.shop__toolbar { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-2); flex-wrap: wrap; padding-block: var(--sp-2); border-block: 1px solid var(--line); margin-bottom: var(--sp-3); }
.shop__toolbar-left { display: flex; align-items: center; gap: var(--sp-2); }
.shop__count { font-size: var(--fs-small); letter-spacing: 0.04em; color: var(--text-on-paper-dim); font-variant-numeric: tabular-nums; }
.shop__filter-toggle { display: none; }
.shop__sort-wrap { display: inline-flex; align-items: center; gap: 0.6rem; font-size: var(--fs-micro); letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-on-paper-dim); }
.shop-sort { appearance: none; -webkit-appearance: none; padding: 0.5rem 2.2rem 0.5rem 0.9rem; border: 1px solid var(--line-strong); border-radius: var(--r-pill); background: transparent; color: var(--text-on-paper); font: inherit; font-size: var(--fs-small); cursor: pointer; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2322494c' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 0.9rem center; }
[dir='rtl'] .shop-sort { padding: 0.5rem 0.9rem 0.5rem 2.2rem; background-position: left 0.9rem center; }
.shop-sort:focus-visible { outline: 2px solid var(--c-green); outline-offset: 2px; }

.shop__layout { display: grid; grid-template-columns: 268px 1fr; gap: clamp(1.5rem, 3vw, 3rem); align-items: start; }

/* Filter rail */
.shop__rail { position: sticky; top: 96px; display: flex; flex-direction: column; gap: var(--sp-3); }
.shop__rail-head { display: flex; align-items: center; justify-content: space-between; padding-bottom: var(--sp-2); border-bottom: 1px solid var(--line-strong); }
.shop__rail-head h3 { font-family: var(--font-editorial); font-size: var(--fs-h3); }
.shop__clear { display: inline-flex; align-items: center; gap: 0.35rem; font-size: var(--fs-micro); letter-spacing: 0.08em; text-transform: uppercase; color: var(--c-green); padding: 0.3rem 0.5rem; border-radius: var(--r-pill); transition: background var(--dur-1), color var(--dur-1); }
.shop__clear:hover { background: color-mix(in srgb, var(--c-green) 12%, transparent); }
.shop-facet__title { font-size: var(--fs-micro); letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-on-paper-dim); margin-bottom: 0.7rem; }
.shop-chips { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.shop-chip { padding: 0.45rem 0.9rem; border: 1px solid var(--line-strong); border-radius: var(--r-pill); font-size: var(--fs-small); font-weight: 500; color: var(--text-on-paper); background: transparent; cursor: pointer; transition: background var(--dur-1), color var(--dur-1), border-color var(--dur-1), transform var(--dur-1) var(--ease-spring); }
.shop-chip:hover { border-color: var(--c-green); }
.shop-chip:active { transform: scale(0.95); }
.shop-chip:focus-visible { outline: 2px solid var(--c-green); outline-offset: 2px; }
.shop-chip[aria-pressed='true'] { background: var(--c-green); color: var(--c-cream); border-color: var(--c-green); }

.shop-swatches { display: flex; flex-wrap: wrap; gap: 0.7rem; }
.shop-swatch { width: 34px; height: 34px; display: grid; place-items: center; border-radius: var(--r-pill); border: 2px solid transparent; background: transparent; cursor: pointer; transition: transform var(--dur-1) var(--ease-spring), border-color var(--dur-1); }
.shop-swatch__dot { width: 26px; height: 26px; border-radius: var(--r-pill); background: var(--sw); box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--c-ink) 22%, transparent); }
.shop-swatch:hover { transform: scale(1.08); }
.shop-swatch:focus-visible { outline: 2px solid var(--c-green); outline-offset: 2px; }
.shop-swatch[aria-pressed='true'] { border-color: var(--c-green); transform: scale(1.08); }

.shop-toggle { display: inline-flex; align-items: center; gap: 0.6rem; background: transparent; border: none; cursor: pointer; font-size: var(--fs-small); color: var(--text-on-paper); padding: 0; }
.shop-toggle__track { width: 42px; height: 24px; border-radius: var(--r-pill); background: color-mix(in srgb, var(--c-green) 18%, transparent); position: relative; transition: background var(--dur-1); flex: none; }
.shop-toggle__knob { position: absolute; top: 3px; inset-inline-start: 3px; width: 18px; height: 18px; border-radius: var(--r-pill); background: var(--surface-1); box-shadow: var(--shadow-1); transition: transform var(--dur-2) var(--ease-spring); }
.shop-toggle[aria-pressed='true'] .shop-toggle__track { background: var(--c-green); }
.shop-toggle[aria-pressed='true'] .shop-toggle__knob { transform: translateX(18px); }
[dir='rtl'] .shop-toggle[aria-pressed='true'] .shop-toggle__knob { transform: translateX(-18px); }
.shop-toggle:focus-visible { outline: 2px solid var(--c-green); outline-offset: 3px; border-radius: var(--r-sm); }

/* Results grid: shares .pcard but its own responsive column rules */
.shop__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(0.8rem, 1.6vw, 1.6rem); min-height: 40vh; }
.shop__card { grid-column: auto; }
.shop__empty { grid-column: 1 / -1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--sp-2); padding: var(--sp-6) var(--sp-2); text-align: center; color: var(--text-on-paper-dim); }
.shop__empty p { font-size: var(--fs-lead); font-family: var(--font-editorial); }

@media (max-width: 1024px) { .shop__layout { grid-template-columns: 220px 1fr; } .shop__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 760px) {
  .shop__filter-toggle { display: inline-flex; }
  .shop__layout { grid-template-columns: 1fr; }
  .shop__rail { position: static; top: auto; max-height: 0; overflow: hidden; gap: 0; transition: max-height var(--dur-3) var(--ease-out); }
  .shop__rail.is-open { max-height: 1200px; gap: var(--sp-3); padding-block: var(--sp-2) var(--sp-3); }
  .shop__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 460px) { .shop__grid { grid-template-columns: 1fr; } }
.shop__clear[hidden] { display: none; }
/* Override .pcard span rules so cards flow in the shop track grid */
.shop__grid .pcard, .shop__grid .pcard:nth-child(3n+1) { grid-column: auto; }

/* ---------------------------------------------------------------
   Checkout
--------------------------------------------------------------- */
.checkout__title { font-family: var(--font-editorial); font-size: var(--fs-h2); max-width: 18ch; margin-bottom: var(--sp-4); }
.checkout__layout { display: grid; grid-template-columns: 1.6fr 1fr; gap: clamp(1.5rem, 3vw, 3rem); align-items: start; }
.checkout__section-title { font-size: var(--fs-micro); letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-on-paper-dim); margin: var(--sp-4) 0 var(--sp-2); }
.checkout__section-title:first-child { margin-top: 0; }

/* Form */
.uform .field { display: flex; flex-direction: column; gap: 0.35rem; margin-bottom: var(--sp-2); }
.uform label { font-size: var(--fs-small); color: var(--text-on-paper-dim); }
.uform input, .uform select, .uform textarea {
  padding: 0.85rem 1.1rem; border-radius: var(--r-sm); border: 1px solid var(--line-strong);
  background: var(--surface-1); color: inherit; font: inherit; width: 100%;
  transition: border-color var(--dur-1), box-shadow var(--dur-1);
}
.uform textarea { resize: vertical; min-height: 5.5rem; }
.uform input:hover, .uform select:hover, .uform textarea:hover { border-color: var(--c-green); }
.uform input:focus-visible, .uform select:focus-visible, .uform textarea:focus-visible {
  outline: none; border-color: var(--c-green); box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-green) 18%, transparent);
}
.uform input[aria-invalid='true'], .uform select[aria-invalid='true'], .uform textarea[aria-invalid='true'] { border-color: var(--c-gold); }
.field-error { display: block; min-height: 1em; font-size: var(--fs-micro); color: var(--c-gold); }
.checkout__form-error { min-height: 1.2em; margin: 0.4rem 0 0; font-size: var(--fs-small); color: var(--c-gold); text-align: center; }

/* Payment method picker */
.checkout__pay-group { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.checkout__pay-group .pay-badge { height: 40px; padding-inline: 1rem; cursor: pointer; transition: transform var(--dur-1) var(--ease-spring), box-shadow var(--dur-1); }
.checkout__pay-group .pay-badge:hover { transform: translateY(-2px); }
.checkout__pay-group .pay-badge:active { transform: scale(0.96); }
.checkout__pay-group .pay-badge:focus-visible { outline: 2px solid var(--c-green); outline-offset: 2px; }
.checkout__pay-group .pay-badge.is-selected { box-shadow: 0 0 0 2px var(--c-green), 0 8px 18px -10px color-mix(in srgb, var(--c-green) 55%, transparent); }

/* Embedded card-details form — shown in-page for mada/visa/mc */
.checkout__card-form {
  display: none;
  flex-direction: column;
  margin-top: var(--sp-2);
  padding: var(--sp-3);
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
}
.checkout__card-form.is-visible { display: flex; animation: checkout-card-in var(--dur-2) var(--ease-spring); }
.checkout__card-form-title { font-size: var(--fs-micro); letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-on-paper-dim); margin-bottom: var(--sp-2); }
.checkout__card-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-2); }
.checkout__card-note { display: flex; align-items: center; gap: 0.4rem; font-size: var(--fs-micro); color: var(--text-on-paper-dim); margin-top: 0.2rem; }
.checkout__card-note svg { flex-shrink: 0; color: var(--c-green); }
@keyframes checkout-card-in {
  from { opacity: 0; transform: translateY(-8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Shipping method picker */
.checkout__ship-group { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.checkout__ship-group .ship-option {
  flex: 1 1 200px; display: flex; flex-direction: column; align-items: flex-start; gap: 0.3rem;
  padding: 0.85rem 1.1rem; border-radius: var(--r-sm); border: 1px solid var(--line-strong);
  background: var(--surface-1); color: inherit; font: inherit; text-align: start; cursor: pointer;
  transition: transform var(--dur-1) var(--ease-spring), box-shadow var(--dur-1), border-color var(--dur-1);
}
.checkout__ship-group .ship-option:hover { border-color: var(--c-green); transform: translateY(-2px); }
.checkout__ship-group .ship-option:active { transform: scale(0.98); }
.checkout__ship-group .ship-option:focus-visible { outline: 2px solid var(--c-green); outline-offset: 2px; }
.checkout__ship-group .ship-option.is-selected { border-color: var(--c-green); box-shadow: 0 0 0 2px var(--c-green), 0 8px 18px -10px color-mix(in srgb, var(--c-green) 55%, transparent); }
.ship-option__name { font-weight: 700; font-size: var(--fs-small); }
.ship-option__eta { font-size: var(--fs-micro); color: var(--text-on-paper-dim); }
.ship-option__price { font-family: var(--font-mono); font-size: var(--fs-small); font-weight: 600; color: var(--c-green-700); margin-top: 0.1rem; }

/* Order summary */
.checkout__summary { position: sticky; top: 96px; background: var(--surface-1); border: 1px solid var(--line); border-radius: var(--r-sm); padding: var(--sp-3); display: flex; flex-direction: column; gap: var(--sp-1); }
.checkout__lines { display: flex; flex-direction: column; gap: var(--sp-2); margin-bottom: var(--sp-2); padding-bottom: var(--sp-2); border-bottom: 1px solid var(--line); }

/* Promo code entry */
.checkout__promo { display: flex; flex-direction: column; gap: 0.4rem; margin-bottom: var(--sp-2); padding-bottom: var(--sp-2); border-bottom: 1px solid var(--line); }
.checkout__promo-row { display: flex; gap: 0.5rem; }
.checkout__promo-input {
  flex: 1; min-width: 0; padding: 0.6rem 0.85rem; border-radius: var(--r-sm); border: 1px solid var(--line-strong);
  background: var(--surface-1); color: inherit; font: inherit; font-size: var(--fs-small);
  text-transform: uppercase; letter-spacing: 0.04em;
  transition: border-color var(--dur-1), box-shadow var(--dur-1);
}
.checkout__promo-input:hover { border-color: var(--c-green); }
.checkout__promo-input:focus-visible {
  outline: none; border-color: var(--c-green); box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-green) 18%, transparent);
}
.checkout__promo-input:disabled { opacity: 0.6; }
.checkout__promo-btn {
  padding: 0.6rem 1.1rem; border-radius: var(--r-sm); border: 1px solid var(--c-green);
  background: var(--c-green); color: var(--c-cream); font: inherit; font-size: var(--fs-small); font-weight: 600;
  cursor: pointer; white-space: nowrap;
  transition: transform var(--dur-1) var(--ease-spring), box-shadow var(--dur-1), background-color var(--dur-1), color var(--dur-1), border-color var(--dur-1);
}
.checkout__promo-btn:hover { background: var(--c-green-700); box-shadow: 0 6px 16px -8px color-mix(in srgb, var(--c-green) 55%, transparent); }
.checkout__promo-btn:active { transform: scale(0.96); }
.checkout__promo-btn:focus-visible { outline: 2px solid var(--c-green); outline-offset: 2px; }
.checkout__promo-btn.is-remove { background: transparent; color: var(--c-green-700); border-color: var(--line-strong); }
.checkout__promo-btn.is-remove:hover { background: var(--surface-2); border-color: var(--c-green); box-shadow: none; }
.checkout__promo-msg { margin: 0; font-size: var(--fs-micro); }
.checkout__promo-msg.is-success { color: var(--c-green-700); }
.checkout__promo-msg.is-error { color: var(--c-gold); }
.checkout__line { display: grid; grid-template-columns: 56px 1fr auto; gap: var(--sp-2); align-items: center; font-size: var(--fs-small); }
.checkout__line img { width: 56px; height: 70px; object-fit: cover; border-radius: var(--r-xs); background: var(--surface-2); }
.checkout__line .meta strong { display: block; font-weight: 600; }
.checkout__line .meta span { display: block; color: var(--text-on-paper-dim); font-size: var(--fs-micro); margin-top: 0.15rem; }
.checkout__line-price { font-weight: 600; white-space: nowrap; }

/* Empty / success */
.checkout__empty, .checkout__success { max-width: 420px; margin-inline: auto; }
.checkout__order-number { margin-top: var(--sp-2); font-size: var(--fs-lead); }
.checkout__order-number strong { font-family: var(--font-editorial); color: var(--text-on-paper); margin-inline-start: 0.5rem; letter-spacing: 0.05em; }
.checkout__paid-with { margin-top: 0.3rem; font-size: var(--fs-small); color: var(--text-on-paper-dim); }

/* "What you ordered" — order contents on the success view */
.checkout__order-items { margin-top: var(--sp-4); padding-top: var(--sp-3); border-top: 1px solid var(--line); text-align: start; }
.checkout__order-items .checkout__section-title { margin-top: 0; }

.checkout__success-actions { display: flex; flex-wrap: wrap; gap: var(--sp-2); justify-content: center; margin-top: var(--sp-3); }
.checkout__success-actions .btn { flex: 1 1 200px; max-width: 320px; }

@media (max-width: 1024px) {
  .checkout__layout { grid-template-columns: 1fr; }
  .checkout__summary { position: static; top: auto; }
}

/* ---------------------------------------------------------------
   Tax invoice — ZATCA Phase-1 QR stub
--------------------------------------------------------------- */
.tax-invoice { margin-top: var(--sp-4); padding-top: var(--sp-3); border-top: 1px dashed var(--line-strong); text-align: start; }
.tax-invoice__head { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--sp-3); }
.tax-invoice__seller { display: flex; flex-direction: column; gap: 0.25rem; }
.tax-invoice__seller strong { font-family: var(--font-editorial); font-size: var(--fs-lead); letter-spacing: 0.01em; color: var(--text-on-paper); }
.tax-invoice__seller span { font-family: var(--font-mono); font-size: var(--fs-micro); letter-spacing: 0.03em; color: var(--text-on-paper-dim); }
.tax-invoice__qr { flex: none; line-height: 0; padding: 6px; background: var(--surface-1); border: 1px solid var(--line); border-radius: var(--r-xs); box-shadow: var(--shadow-1); }
.tax-invoice__qr svg { display: block; width: 84px; height: 84px; }
.tax-invoice__meta {
  display: flex; flex-wrap: wrap; align-items: baseline; gap: var(--sp-1) var(--sp-3);
  margin-top: var(--sp-2); padding-top: var(--sp-2); border-top: 1px solid var(--line);
  font-family: var(--font-mono); font-size: var(--fs-micro); letter-spacing: 0.05em;
  text-transform: uppercase; color: var(--text-on-paper-dim);
}
.tax-invoice__meta .tax-invoice__number,
.tax-invoice__meta .tax-invoice__total { color: var(--text-on-paper); font-weight: 700; }
.tax-invoice__meta .tax-invoice__total { margin-inline-start: auto; }

@media (max-width: 480px) {
  .tax-invoice__head { flex-direction: column-reverse; align-items: center; text-align: center; gap: var(--sp-2); }
  .tax-invoice__seller { align-items: center; }
  .tax-invoice__meta { justify-content: center; }
  .tax-invoice__meta .tax-invoice__total { margin-inline-start: 0; }
}

/* ---------------------------------------------------------------
   Account
--------------------------------------------------------------- */
.account__auth { max-width: 420px; margin-inline: auto; }
.account__welcome { color: var(--text-on-paper-dim); line-height: 1.7; margin-bottom: var(--sp-3); }

.account__tabs { display: flex; gap: 4px; background: var(--surface-2); border-radius: var(--r-pill); padding: 4px; margin-bottom: var(--sp-3); }
.account__tab {
  flex: 1; padding: 0.6rem 1rem; border: none; border-radius: var(--r-pill); background: transparent;
  font: inherit; font-size: var(--fs-small); font-weight: 600; color: var(--text-on-paper-dim); cursor: pointer;
  transition: background var(--dur-2) var(--ease-spring), color var(--dur-1), transform var(--dur-1) var(--ease-spring);
}
.account__tab:hover { color: var(--text-on-paper); }
.account__tab:focus-visible { outline: 2px solid var(--c-green); outline-offset: 2px; }
.account__tab:active { transform: scale(0.97); }
.account__tab.is-active { background: var(--c-green); color: var(--c-cream); box-shadow: var(--shadow-1); }

.account__form-error { min-height: 1.2em; margin: 0.4rem 0 0; font-size: var(--fs-small); color: var(--c-gold); text-align: center; }

/* Profile */
.account__view { display: flex; flex-direction: column; gap: var(--sp-4); }
.account__profile {
  display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3);
  background: var(--surface-1); border: 1px solid var(--line); border-radius: var(--r-sm);
  padding: var(--sp-3); box-shadow: var(--shadow-1);
}
.account__profile-info h3 { font-family: var(--font-editorial); font-size: var(--fs-h3); margin-bottom: 0.2rem; }
.account__profile-info p { color: var(--text-on-paper-dim); font-size: var(--fs-small); }

/* Order history */
.account__orders { display: flex; flex-direction: column; gap: var(--sp-3); }
.account__order { background: var(--surface-1); border: 1px solid var(--line); border-radius: var(--r-sm); padding: var(--sp-3); }
.account__order-head { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-2); margin-bottom: var(--sp-2); padding-bottom: var(--sp-2); border-bottom: 1px solid var(--line); }
.account__order-head strong { display: block; font-family: var(--font-editorial); letter-spacing: 0.04em; }
.account__order-head span:not(.order-status) { color: var(--text-on-paper-dim); font-size: var(--fs-micro); }

.order-status { font-size: var(--fs-micro); font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; padding: 0.3rem 0.7rem; border-radius: var(--r-pill); white-space: nowrap; }
.order-status.pending { background: color-mix(in srgb, var(--c-gold) 22%, transparent); color: color-mix(in srgb, var(--c-gold) 60%, var(--c-ink)); }
.order-status.paid { background: color-mix(in srgb, var(--c-green) 16%, transparent); color: color-mix(in srgb, var(--c-green) 70%, var(--c-ink)); }
.order-status.processing { background: color-mix(in srgb, var(--c-gold) 34%, transparent); color: color-mix(in srgb, var(--c-gold) 72%, var(--c-ink)); }
.order-status.shipped { background: color-mix(in srgb, var(--c-green) 30%, transparent); color: color-mix(in srgb, var(--c-green) 55%, var(--c-ink)); }
.order-status.delivered { background: var(--c-green); color: var(--c-cream); }
.order-status.cancelled { background: color-mix(in srgb, var(--c-rust) 20%, transparent); color: color-mix(in srgb, var(--c-rust) 65%, var(--c-ink)); }
.order-status.refunded { background: color-mix(in srgb, var(--c-rust) 12%, transparent); color: color-mix(in srgb, var(--c-rust) 50%, var(--c-ink)); }

/* Tracking */
.account__tracking { margin-top: var(--sp-2); padding-top: var(--sp-2); border-top: 1px solid var(--line); display: flex; flex-direction: column; gap: 0.3rem; }
.account__tracking-row { display: flex; align-items: baseline; gap: var(--sp-2); flex-wrap: wrap; font-size: var(--fs-small); }
.account__tracking-label { color: var(--text-on-paper-dim); font-size: var(--fs-micro); letter-spacing: 0.08em; text-transform: uppercase; }
.account__tracking-number { font-family: var(--font-mono); font-weight: 600; letter-spacing: 0.03em; }
.account__track-link {
  color: var(--c-green-700); font-weight: 600; font-size: var(--fs-small); text-decoration: none;
  border-bottom: 1px solid color-mix(in srgb, var(--c-green-700) 40%, transparent);
  transition: color var(--dur-1), border-color var(--dur-1), transform var(--dur-1) var(--ease-spring);
}
.account__track-link:hover { color: var(--c-green); border-color: var(--c-green); transform: translateY(-1px); }
.account__track-link:focus-visible { outline: 2px solid var(--c-green); outline-offset: 2px; }
.account__track-link:active { transform: scale(0.97); }

@media (max-width: 600px) {
  .account__profile { flex-direction: column; align-items: flex-start; }
  .account__profile .btn { width: 100%; justify-content: center; }
  .account__order-head { flex-wrap: wrap; }
}
