/* ============================================================
   EXT — Dual Identity Landing
   Dark = SIGNAL (streetwear/urban)   Light = QUIET LUXURY (refined)
   ============================================================ */

/* ---------- Theme tokens ---------- */
:root,
[data-theme="dark"]{
  --bg:        #0A0A0A;
  --layer-1:   #111827;
  --layer-2:   #1F2937;
  --accent-dk: #1B3A6B;
  --accent:    #2B5BA8;   /* navy */
  --text:      #FFFFFF;
  --muted:     rgba(255,255,255,.52);
  --line:      rgba(255,255,255,.12);
  --card:      #0E1117;

  --font-display: 'Archivo', 'Space Grotesk', sans-serif;
  --font-body:    'Space Grotesk', system-ui, sans-serif;
  --font-mono:    'Space Mono', monospace;
  --display-weight: 900;
  --display-spacing: -0.02em;
  --hero-style: normal;
  --tee: #131313;
  --tee-ink: #FFFFFF;
  --shadow: 0 30px 80px -30px rgba(0,0,0,.8);
  color-scheme: dark;
}

[data-theme="light"]{
  --bg:        #F9F6F1;
  --layer-1:   #EDE8E1;
  --layer-2:   #D9CFC5;
  --accent-dk: #3D3228;
  --accent:    #7A6A5A;   /* mid brown */
  --text:      #1C1713;
  --muted:     rgba(28,23,19,.55);
  --line:      rgba(28,23,19,.14);
  --card:      #FFFFFF;

  --font-display: 'Cormorant Garamond', serif;
  --font-body:    'Cormorant Garamond', serif;
  --font-mono:    'Space Mono', monospace;
  --display-weight: 500;
  --display-spacing: 0.01em;
  --hero-style: normal;
  --tee: #E7E0D5;
  --tee-ink: #2A2118;
  --shadow: 0 30px 80px -40px rgba(60,50,40,.35);
  color-scheme: light;
}

/* Arabic typography overrides */
html[lang="ar"]{ --font-body: 'Tajawal', sans-serif; }
html[lang="ar"][data-theme="dark"]  { --font-display: 'El Messiri', sans-serif; --display-weight:700; }
html[lang="ar"][data-theme="light"] { --font-display: 'El Messiri', sans-serif; --display-weight:600; }

/* ---------- Reset ---------- */
*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  line-height:1.55;
  overflow-x:hidden;
  transition:background .7s cubic-bezier(.65,0,.35,1), color .7s cubic-bezier(.65,0,.35,1);
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
::selection{ background:var(--accent); color:#fff; }
[data-theme="light"] ::selection{ background:var(--accent); color:#F9F6F1; }

/* hide native cursor where custom cursor active (desktop) */
@media (hover:hover) and (pointer:fine){
  body.cursor-on, body.cursor-on a, body.cursor-on button{ cursor:none; }
}

/* ---------- Layout helpers ---------- */
.wrap{ width:min(1240px, 92vw); margin-inline:auto; }
.eyebrow{
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.32em;
  text-transform:uppercase; color:var(--accent); display:inline-block;
}
html[lang="ar"] .eyebrow{ font-family:var(--font-mono); letter-spacing:.12em; }
.muted{ color:var(--muted); }

/* reveal animation */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity 1s cubic-bezier(.16,1,.3,1), transform 1s cubic-bezier(.16,1,.3,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s } .reveal.d2{ transition-delay:.16s }
.reveal.d3{ transition-delay:.24s } .reveal.d4{ transition-delay:.32s }

/* ============================================================
   PRELOADER
   ============================================================ */
#loader{
  position:fixed; inset:0; z-index:1000; background:var(--bg);
  display:grid; place-items:center; transition:opacity .8s ease, visibility .8s;
}
#loader.done{ opacity:0; visibility:hidden; }
.loader-logo{ position:relative; text-align:center; }
.loader-logo .lg{
  font-family:var(--font-display); font-weight:var(--display-weight);
  font-size:clamp(3rem,12vw,7rem); letter-spacing:var(--display-spacing);
  line-height:1; display:flex; gap:.04em; overflow:hidden;
}
.loader-logo .lg span{
  display:inline-block; transform:translateY(110%); animation:lgUp .9s cubic-bezier(.16,1,.3,1) forwards;
}
.loader-logo .lg span:nth-child(2){ animation-delay:.12s; color:var(--accent); }
.loader-logo .lg span:nth-child(3){ animation-delay:.24s; }
@keyframes lgUp{ to{ transform:translateY(0); } }
.loader-bar{ height:2px; width:0; background:var(--accent); margin:18px auto 0; animation:lgBar 1.4s .3s cubic-bezier(.7,0,.3,1) forwards; }
@keyframes lgBar{ to{ width:180px; } }

/* ============================================================
   CUSTOM CURSOR
   ============================================================ */
.cursor-dot, .cursor-ring{ position:fixed; top:0; left:0; z-index:900; pointer-events:none; border-radius:50%; mix-blend-mode:difference; }
.cursor-dot{ width:7px; height:7px; background:#fff; transform:translate(-50%,-50%); }
.cursor-ring{ width:38px; height:38px; border:1px solid rgba(255,255,255,.6); transform:translate(-50%,-50%); transition:width .25s, height .25s, background .25s, border-color .25s; }
.cursor-ring.grow{ width:64px; height:64px; background:rgba(255,255,255,.1); border-color:transparent; }
@media (hover:none),(pointer:coarse){ .cursor-dot,.cursor-ring{ display:none; } }

/* ============================================================
   NAV
   ============================================================ */
header{
  position:fixed; top:0; left:0; right:0; z-index:500;
  padding:20px 0; transition:padding .4s ease, background .4s ease, border-color .4s ease;
  border-bottom:1px solid transparent;
}
header.shrink{
  padding:12px 0; background:color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter:blur(14px); border-bottom:1px solid var(--line);
}
.nav{ display:flex; align-items:center; justify-content:space-between; gap:18px; }
.nav-links{ display:flex; gap:30px; align-items:center; }
.nav-links a{ position:relative; font-family:var(--font-mono); font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); transition:color .3s; }
html[lang="ar"] .nav-links a{ font-family:var(--font-body); font-size:.95rem; letter-spacing:0; font-weight:500; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:-6px; height:1px; width:0; background:var(--accent); transition:width .35s cubic-bezier(.16,1,.3,1); }
.nav-links a:hover{ color:var(--text); } .nav-links a:hover::after{ width:100%; }

/* brand mark (SVG logo) */
.brandmark{ display:flex; align-items:center; gap:12px; }
.brandmark svg{ height:30px; width:auto; }
.brandmark .lockup-sub{ font-family:var(--font-mono); font-size:.56rem; letter-spacing:.3em; color:var(--muted); text-transform:uppercase; }

/* real logo images — blend mode hides their solid background */
/* unified vector logo — letters + swords both adapt colour to the active mode; forced LTR so it never reverses in Arabic */
.brand-svg{ height:30px; width:auto; display:block; color:var(--text); direction:ltr; }
.brand-svg .brand-x{ fill:var(--accent); }
.foot-brand .brand-svg{ height:42px; }

/* controls */
.controls{ display:flex; align-items:center; gap:10px; }
.pill{
  font-family:var(--font-mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase;
  border:1px solid var(--line); color:var(--text); background:transparent;
  padding:9px 14px; border-radius:40px; cursor:pointer; transition:.3s; white-space:nowrap;
}
.pill:hover{ border-color:var(--accent); color:var(--accent); }
html[lang="ar"] .pill{ font-family:var(--font-body); letter-spacing:0; font-weight:500; }

/* mode toggle */
.mode-toggle{
  display:flex; align-items:center; gap:9px; border:1px solid var(--line); border-radius:40px;
  padding:6px 8px 6px 14px; cursor:pointer; background:transparent; transition:.3s;
}
.mode-toggle:hover{ border-color:var(--accent); }
.mode-toggle .mt-label{ font-family:var(--font-mono); font-size:.64rem; letter-spacing:.16em; text-transform:uppercase; color:var(--text); min-width:64px; text-align:center; }
.mode-toggle .mt-track{ width:42px; height:22px; border-radius:20px; background:var(--layer-2); position:relative; transition:background .5s; }
.mode-toggle .mt-knob{ position:absolute; top:2px; left:2px; width:18px; height:18px; border-radius:50%; background:var(--accent); transition:transform .5s cubic-bezier(.65,0,.35,1); }
[data-theme="light"] .mode-toggle .mt-knob{ transform:translateX(20px); }

/* burger */
.burger{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px; }
.burger span{ width:24px; height:2px; background:var(--text); transition:.3s; }

/* account button + auth modal */
.acct-btn{ position:relative; width:32px; height:32px; background:none; border:none; color:var(--text); cursor:pointer; display:grid; place-items:center; }
.acct-btn .acct-ini{ display:none; position:absolute; inset:0; place-items:center; background:var(--accent); color:#fff; border-radius:50%; font-family:var(--font-mono); font-size:.72rem; font-weight:700; }
.acct-btn.signed > svg{ visibility:hidden; }
.auth-overlay{ position:fixed; inset:0; background:rgba(0,0,0,.62); backdrop-filter:blur(4px); display:none; place-items:center; z-index:200; padding:20px; }
.auth-overlay.open{ display:grid; }
.auth-card{ position:relative; width:min(400px,94vw); background:var(--card); border:1px solid var(--line); border-radius:18px; padding:34px 30px; box-shadow:var(--shadow); }
.auth-close{ position:absolute; top:14px; right:16px; background:none; border:none; color:var(--muted); font-size:1.5rem; line-height:1; cursor:pointer; }
.auth-logo{ font-family:'Archivo',sans-serif; font-weight:900; font-size:1.7rem; letter-spacing:-1px; text-align:center; margin-bottom:16px; }
.auth-logo span{ color:var(--accent); }
.auth-card h3{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:1.45rem; text-align:center; margin-bottom:16px; }
.auth-sub{ color:var(--muted); font-size:.9rem; text-align:center; margin-bottom:16px; }
.gbtn-wrap{ display:flex; justify-content:center; min-height:44px; }
.auth-or{ display:flex; align-items:center; gap:12px; color:var(--muted); font-size:.72rem; text-transform:uppercase; letter-spacing:.12em; margin:16px 0; }
.auth-or::before, .auth-or::after{ content:""; flex:1; height:1px; background:var(--line); }
.auth-input{ width:100%; background:var(--bg); border:1px solid var(--line); color:var(--text); padding:12px 14px; border-radius:10px; font-size:.95rem; margin-bottom:12px; transition:border-color .2s; }
.auth-input:focus{ outline:none; border-color:var(--accent); }
.auth-code{ text-align:center; letter-spacing:.5em; font-size:1.3rem; font-family:var(--font-mono); }
.auth-submit{ width:100%; justify-content:center; margin-top:6px; }
.auth-err{ color:#e98a8a; font-size:.82rem; margin-top:10px; min-height:1em; text-align:center; }
.auth-switch{ text-align:center; font-size:.85rem; color:var(--muted); margin-top:16px; }
.auth-switch a{ color:var(--accent); cursor:pointer; text-decoration:underline; }
.auth-back{ display:block; text-align:center; color:var(--muted); font-size:.85rem; margin-top:14px; cursor:pointer; }
.auth-avatar{ width:64px; height:64px; border-radius:50%; background:var(--accent); color:#fff; display:grid; place-items:center; font-family:'Archivo',sans-serif; font-weight:900; font-size:1.6rem; margin:0 auto 14px; }
html[lang="ar"] .auth-card h3, html[lang="ar"] .auth-switch, html[lang="ar"] .auth-sub{ font-family:var(--font-body); }

/* ============================================================
   HERO
   ============================================================ */
.hero{ min-height:100vh; display:flex; align-items:center; position:relative; overflow:hidden; padding-top:90px; }
.hero-grid{ position:absolute; inset:0; opacity:.5; pointer-events:none;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px; mask-image:radial-gradient(circle at 50% 40%, #000 10%, transparent 72%); }
.hero-glow{ position:absolute; width:60vw; height:60vw; border-radius:50%; filter:blur(120px); opacity:.25;
  background:radial-gradient(circle, var(--accent), transparent 65%); top:-10%; right:-10%; pointer-events:none; transition:background .7s; }

.hero-inner{ position:relative; z-index:2; width:100%; max-width:min(1240px, 92vw); margin-inline:auto; }
.hero-top{ display:flex; justify-content:space-between; align-items:flex-end; gap:30px; flex-wrap:wrap; margin-bottom:8px; }
.hero-tag{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.24em; text-transform:uppercase; color:var(--muted); }
html[lang="ar"] .hero-tag{ font-family:var(--font-body); letter-spacing:0; }

.hero-title{
  font-family:'Archivo','Space Grotesk',sans-serif; font-weight:900; letter-spacing:-0.02em; /* fixed — never changes with mode/language */
  font-size:clamp(5rem, 23vw, 21rem); line-height:.82; display:flex; gap:.02em; position:relative;
  direction:ltr; /* brand name always reads EXT, even in RTL */
}
.loader-logo .lg{ direction:ltr; }
.hero-title .ch{ display:inline-block; transform:translateY(120%); }
.loaded .hero-title .ch{ animation:chUp 1.1s cubic-bezier(.16,1,.3,1) forwards; }
.hero-title .ch:nth-child(2){ animation-delay:.12s; color:var(--accent); position:relative; }
.hero-title .ch:nth-child(3){ animation-delay:.24s; }
@keyframes chUp{ to{ transform:translateY(0); } }

/* crossed swords mark sitting on the X */
.swords{ position:absolute; left:50%; top:48%; transform:translate(-50%,-50%); width:.5em; height:.5em; opacity:0; transition:opacity .6s .9s; pointer-events:none; }
.loaded .swords{ opacity:1; }
.swords svg{ width:100%; height:100%; stroke:var(--text); }

.hero-sub{ display:flex; justify-content:space-between; align-items:flex-start; gap:30px; flex-wrap:wrap; margin-top:26px; }
.hero-statement{ max-width:30ch; font-size:clamp(1.05rem,1.4vw,1.4rem); color:var(--muted); }
[data-theme="light"] .hero-statement{ font-size:clamp(1.2rem,1.7vw,1.7rem); }
.hero-cta{ display:flex; gap:14px; align-items:center; flex-wrap:wrap; }

.btn{
  font-family:var(--font-mono); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase;
  padding:15px 28px; border-radius:46px; cursor:pointer; border:1px solid var(--accent);
  transition:.35s cubic-bezier(.16,1,.3,1); position:relative; overflow:hidden; display:inline-flex; align-items:center; gap:10px;
}
html[lang="ar"] .btn{ font-family:var(--font-body); letter-spacing:0; font-weight:700; font-size:.95rem; }
.btn-primary{ background:var(--accent); color:#fff; }
[data-theme="light"] .btn-primary{ color:#F9F6F1; }
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 16px 30px -12px var(--accent); }
.btn-ghost{ background:transparent; color:var(--text); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--accent); color:var(--accent); }

.scroll-hint{ position:absolute; bottom:26px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; color:var(--muted); font-family:var(--font-mono); font-size:.6rem; letter-spacing:.3em; text-transform:uppercase; }
.scroll-hint .line{ width:1px; height:42px; background:linear-gradient(var(--accent),transparent); animation:scrollLine 1.8s infinite; }
@keyframes scrollLine{ 0%{transform:scaleY(0); transform-origin:top;} 50%{transform:scaleY(1); transform-origin:top;} 51%{transform-origin:bottom;} 100%{transform:scaleY(0); transform-origin:bottom;} }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:20px 0; overflow:hidden; white-space:nowrap; background:var(--layer-1); }
.marquee-track{ display:inline-flex; gap:42px; animation:scrollX 26s linear infinite; will-change:transform; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee span{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:clamp(1.4rem,3vw,2.4rem); letter-spacing:var(--display-spacing); text-transform:uppercase; display:inline-flex; align-items:center; gap:42px; }
.marquee .dot{ width:9px; height:9px; border-radius:50%; background:var(--accent); }
@keyframes scrollX{ to{ transform:translateX(-50%); } }

/* ============================================================
   MANIFESTO / DUAL IDENTITY
   ============================================================ */
.section{ padding:clamp(80px,12vh,150px) 0; }
.sec-head{ display:flex; align-items:baseline; gap:16px; margin-bottom:54px; flex-wrap:wrap; }
.sec-head h2{ font-family:var(--font-display); font-weight:var(--display-weight); letter-spacing:var(--display-spacing); font-size:clamp(2.2rem,6vw,4.6rem); line-height:1; }
.sec-num{ font-family:var(--font-mono); font-size:.8rem; color:var(--accent); letter-spacing:.2em; }

.manifesto p{ font-size:clamp(1.5rem,3.6vw,3rem); line-height:1.3; max-width:18ch; font-family:var(--font-display); font-weight:calc(var(--display-weight) - 200); letter-spacing:var(--display-spacing); }
[data-theme="light"] .manifesto p{ font-weight:400; max-width:20ch; }
.manifesto .accent{ color:var(--accent); }
.manifesto .meta{ display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:24px; margin-top:64px; }
.manifesto .meta .item{ border-top:1px solid var(--line); padding-top:16px; }
.manifesto .meta .k{ font-family:var(--font-mono); font-size:.64rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.manifesto .meta .v{ font-size:1.15rem; margin-top:8px; }

/* dual mode split panels */
.dual{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:64px; }
.dual .panel{ border:1px solid var(--line); border-radius:18px; padding:34px; position:relative; overflow:hidden; min-height:280px; display:flex; flex-direction:column; justify-content:space-between; transition:transform .5s, border-color .5s; }
.dual .panel:hover{ transform:translateY(-6px); border-color:var(--accent); }
.dual .panel.signal{ background:#0A0A0A; color:#fff; }
.dual .panel.quiet{ background:#F9F6F1; color:#1C1713; }
.dual .panel .pn-name{ font-family:'Archivo',sans-serif; font-weight:900; font-size:2rem; letter-spacing:-.02em; }
.dual .panel.quiet .pn-name{ font-family:'Cormorant Garamond',serif; font-weight:500; }
.dual .panel .pn-tag{ font-family:'Space Mono',monospace; font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; opacity:.6; }
.dual .panel .pn-desc{ font-size:1.05rem; margin-top:auto; opacity:.85; max-width:34ch; }
.dual .panel .swatches{ display:flex; gap:8px; margin-top:18px; }
.dual .panel .swatches i{ width:26px; height:26px; border-radius:6px; display:block; }
.dual .panel .pn-x{ color:#2B5BA8; } .dual .panel.quiet .pn-x{ color:#1C1713; }

/* ============================================================
   COLLECTION
   ============================================================ */
.collection-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.product{ background:var(--card); border:1px solid var(--line); border-radius:16px; overflow:hidden; transition:transform .5s cubic-bezier(.16,1,.3,1), border-color .5s; }
.product:hover{ transform:translateY(-8px); border-color:var(--accent); }
.product .ph{ position:relative; aspect-ratio:4/5; display:grid; place-items:center; background:
   radial-gradient(circle at 50% 30%, var(--layer-1), var(--bg)); overflow:hidden; }
.product .badge{ position:absolute; top:14px; left:14px; font-family:var(--font-mono); font-size:.6rem; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); border:1px solid var(--line); padding:5px 9px; border-radius:30px; }
.product .tee-wrap{ width:78%; transition:transform .6s cubic-bezier(.16,1,.3,1); }
.product:hover .tee-wrap{ transform:scale(1.05) rotate(-1deg); }
.product .meta-row{ display:flex; justify-content:space-between; align-items:center; padding:18px 20px; gap:12px; }
.product .pname{ font-family:var(--font-display); font-weight:calc(var(--display-weight) - 100); font-size:1.15rem; letter-spacing:var(--display-spacing); }
.product .price{ font-family:var(--font-mono); font-size:.92rem; color:var(--accent); }
.product .pcat{ font-family:var(--font-mono); font-size:.6rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); padding:0 20px 18px; }

/* tee SVG print text */
.tee-print{ font-family:'Archivo',sans-serif; font-weight:900; fill:var(--tee-ink); }
.tee-slogan{ font-family:'Space Mono',monospace; fill:color-mix(in srgb, var(--tee-ink) 55%, transparent); }

/* ============================================================
   PHILOSOPHY STRIP (numbers)
   ============================================================ */
.philo{ display:grid; grid-template-columns:repeat(2,minmax(0,360px)); justify-content:center; gap:18px; }
.philo .stat{ border:1px solid var(--line); border-radius:16px; padding:36px 30px; }
.philo .stat .big{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:clamp(2.6rem,6vw,4.4rem); letter-spacing:var(--display-spacing); line-height:1; }
.philo .stat .big .u{ color:var(--accent); }
.philo .stat .lab{ margin-top:14px; color:var(--muted); font-size:.98rem; }

/* ============================================================
   CTA / NEWSLETTER
   ============================================================ */
.cta{ text-align:center; position:relative; overflow:hidden; }
.cta .big-x{ position:absolute; inset:0; display:grid; place-items:center; font-family:var(--font-display); font-weight:var(--display-weight); font-size:60vw; color:var(--text); opacity:.03; pointer-events:none; line-height:1; }
.cta h2{ font-family:var(--font-display); font-weight:var(--display-weight); letter-spacing:var(--display-spacing); font-size:clamp(2.4rem,7vw,6rem); line-height:1; position:relative; }
.cta p{ color:var(--muted); max-width:46ch; margin:22px auto 0; font-size:1.1rem; position:relative; }
.signup{ display:flex; gap:10px; justify-content:center; margin-top:40px; flex-wrap:wrap; position:relative; }
.signup input{ background:transparent; border:1px solid var(--line); color:var(--text); padding:15px 22px; border-radius:46px; font-family:var(--font-mono); font-size:.85rem; min-width:280px; transition:.3s; }
.signup input:focus{ outline:none; border-color:var(--accent); }
.signup input::placeholder{ color:var(--muted); }

/* ============================================================
   FOOTER
   ============================================================ */
footer{ border-top:1px solid var(--line); padding:60px 0 36px; }
.foot-grid{ display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; }
.foot-grid h4{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-bottom:18px; }
html[lang="ar"] .foot-grid h4{ font-family:var(--font-body); font-weight:700; letter-spacing:0; }
.foot-grid ul{ list-style:none; display:flex; flex-direction:column; gap:11px; }
.foot-grid a{ color:var(--muted); transition:.3s; } .foot-grid a:hover{ color:var(--accent); }
.foot-grid .soc-link{ display:inline-flex; align-items:center; gap:9px; }
.foot-grid .soc-ico{ width:16px; height:16px; flex:0 0 auto; fill:currentColor; }
.foot-brand p{ color:var(--muted); max-width:34ch; margin-top:16px; }
.foot-bottom{ display:flex; justify-content:space-between; align-items:center; gap:20px; margin-top:50px; padding-top:24px; border-top:1px solid var(--line); flex-wrap:wrap; }
.foot-bottom span{ font-family:var(--font-mono); font-size:.68rem; letter-spacing:.12em; color:var(--muted); }

/* ============================================================
   CART BUTTON + DRAWER + PRODUCT MODAL
   ============================================================ */
.cart-btn{ position:relative; display:grid; place-items:center; width:42px; height:42px; border-radius:50%; border:1px solid var(--line); background:transparent; color:var(--text); cursor:pointer; transition:.3s; }
.cart-btn:hover{ border-color:var(--accent); color:var(--accent); }
.cart-count{ position:absolute; top:-4px; right:-4px; min-width:18px; height:18px; padding:0 4px; border-radius:20px; background:var(--accent); color:#fff; font-family:var(--font-mono); font-size:.62rem; display:grid; place-items:center; transform:scale(0); transition:transform .35s cubic-bezier(.34,1.56,.64,1); }
[data-theme="light"] .cart-count{ color:#F9F6F1; }
.cart-count.show{ transform:scale(1); }
.cart-count.bump{ animation:bump .4s; }
@keyframes bump{ 0%,100%{transform:scale(1);} 40%{transform:scale(1.4);} }

/* shared backdrop */
.backdrop{ position:fixed; inset:0; z-index:600; background:rgba(0,0,0,.6); backdrop-filter:blur(4px); opacity:0; visibility:hidden; transition:opacity .4s, visibility .4s; }
.backdrop.open{ opacity:1; visibility:visible; }

/* drawer */
.drawer{ position:fixed; top:0; right:0; bottom:0; width:min(440px,92vw); z-index:650; background:var(--bg); border-left:1px solid var(--line); display:flex; flex-direction:column; transform:translateX(100%); transition:transform .55s cubic-bezier(.65,0,.35,1); }
html[dir="rtl"] .drawer{ right:auto; left:0; border-left:none; border-right:1px solid var(--line); transform:translateX(-100%); }
.drawer.open, html[dir="rtl"] .drawer.open{ transform:none; }
.drawer-head{ display:flex; align-items:center; justify-content:space-between; padding:24px 26px; border-bottom:1px solid var(--line); }
.drawer-head h3{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:1.5rem; letter-spacing:var(--display-spacing); }
.drawer-close{ background:none; border:none; color:var(--text); cursor:pointer; font-size:1.6rem; line-height:1; transition:transform .3s; }
.drawer-close:hover{ transform:rotate(90deg); color:var(--accent); }
.drawer-body{ flex:1; overflow-y:auto; padding:14px 26px; }
.cart-empty{ color:var(--muted); text-align:center; padding:60px 0; font-family:var(--font-mono); font-size:.85rem; letter-spacing:.1em; }
html[lang="ar"] .cart-empty{ font-family:var(--font-body); letter-spacing:0; }

.cart-line{ display:flex; gap:14px; padding:16px 0; border-bottom:1px solid var(--line); align-items:center; }
.cart-line .thumb{ width:62px; height:78px; border-radius:8px; background:radial-gradient(circle at 50% 30%, var(--layer-1), var(--bg)); display:grid; place-items:center; flex-shrink:0; border:1px solid var(--line); }
.cart-line .thumb svg{ width:80%; }
.cart-line .ci-info{ flex:1; min-width:0; }
.cart-line .ci-name{ font-family:var(--font-display); font-weight:calc(var(--display-weight) - 100); font-size:1.02rem; }
.cart-line .ci-meta{ font-family:var(--font-mono); font-size:.64rem; letter-spacing:.12em; color:var(--muted); text-transform:uppercase; margin-top:3px; }
.cart-line .ci-price{ color:var(--accent); font-family:var(--font-mono); font-size:.82rem; margin-top:6px; }
.qty{ display:flex; align-items:center; gap:10px; margin-top:8px; }
.qty button{ width:24px; height:24px; border-radius:6px; border:1px solid var(--line); background:transparent; color:var(--text); cursor:pointer; font-size:1rem; line-height:1; transition:.25s; }
.qty button:hover{ border-color:var(--accent); color:var(--accent); }
.qty span{ font-family:var(--font-mono); font-size:.85rem; min-width:18px; text-align:center; }
.ci-remove{ background:none; border:none; color:var(--muted); cursor:pointer; font-family:var(--font-mono); font-size:.6rem; letter-spacing:.12em; text-transform:uppercase; align-self:flex-start; transition:.25s; }
.ci-remove:hover{ color:#e05252; }

.drawer-foot{ padding:22px 26px; border-top:1px solid var(--line); }
.drawer-foot .sub{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:16px; }
.drawer-foot .sub .lbl{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.drawer-foot .sub .amt{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:1.6rem; }
.drawer-foot .btn{ width:100%; justify-content:center; }

/* product modal (PDP) */
.pdp{ position:fixed; inset:0; z-index:700; display:grid; place-items:center; padding:24px; opacity:0; visibility:hidden; transition:opacity .4s, visibility .4s; }
.pdp.open{ opacity:1; visibility:visible; }
.pdp-card{ width:min(940px,96vw); max-height:90vh; overflow:auto; background:var(--bg); border:1px solid var(--line); border-radius:20px; display:grid; grid-template-columns:1fr 1fr; transform:scale(.94) translateY(12px); transition:transform .5s cubic-bezier(.16,1,.3,1); }
.pdp.open .pdp-card{ transform:none; }
.pdp-visual{ background:radial-gradient(circle at 50% 30%, var(--layer-1), var(--bg)); display:grid; place-items:center; padding:30px; position:relative; }
.pdp-visual svg{ width:88%; }
.pdp-close{ position:absolute; top:16px; right:16px; width:38px; height:38px; border-radius:50%; border:1px solid var(--line); background:var(--bg); color:var(--text); cursor:pointer; font-size:1.3rem; transition:transform .3s, border-color .3s; z-index:2; }
.pdp-close:hover{ transform:rotate(90deg); border-color:var(--accent); }
.pdp-info{ padding:40px 38px; display:flex; flex-direction:column; }
.pdp-info .badge{ position:static; display:inline-block; width:fit-content; }
.pdp-info h2{ font-family:var(--font-display); font-weight:var(--display-weight); letter-spacing:var(--display-spacing); font-size:2.4rem; line-height:1.05; margin:14px 0 6px; }
.pdp-info .pdp-price{ font-family:var(--font-mono); color:var(--accent); font-size:1.1rem; }
.pdp-info .pdp-desc{ color:var(--muted); margin:18px 0; font-size:1.02rem; line-height:1.6; }
.opt-label{ font-family:var(--font-mono); font-size:.64rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin:14px 0 9px; }
html[lang="ar"] .opt-label{ font-family:var(--font-body); letter-spacing:0; font-weight:700; }
.sizes{ display:flex; gap:8px; flex-wrap:wrap; }
.size-opt{ min-width:46px; padding:10px 12px; border:1px solid var(--line); border-radius:8px; background:transparent; color:var(--text); cursor:pointer; font-family:var(--font-mono); font-size:.8rem; transition:.25s; }
.size-opt:hover{ border-color:var(--accent); }
.size-opt.sel{ background:var(--accent); color:#fff; border-color:var(--accent); }
[data-theme="light"] .size-opt.sel{ color:#F9F6F1; }
.pdp-actions{ display:flex; gap:10px; margin-top:26px; align-items:center; }
.pdp-actions .btn{ flex:1; justify-content:center; }

@media (max-width:680px){
  .pdp-card{ grid-template-columns:1fr; }
  .pdp-visual{ padding:30px 30px 0; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .collection-grid{ grid-template-columns:repeat(2,1fr); }
  .philo{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:760px){
  .nav-links{ position:fixed; inset:0; flex-direction:column; justify-content:center; gap:34px; background:var(--bg); transform:translateX(100%); transition:transform .5s cubic-bezier(.65,0,.35,1); z-index:480; }
  .nav-links.open{ transform:none; }
  .nav-links a{ font-size:1.4rem; }
  .burger{ display:flex; z-index:490; }
  .mode-toggle .mt-label{ display:none; }
  .dual{ grid-template-columns:1fr; }
  .collection-grid{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr; gap:30px; }
  .hero-statement{ max-width:100%; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; transition-duration:.001ms !important; }
  .reveal{ opacity:1; transform:none; }
}
/* Reduced motion: Collection becomes a normal vertical stack (no pin / scroll-jacking) */
html.reduce-motion .hscroll-pin{ height:auto; overflow:visible; display:block; padding:10px 0 0; }
html.reduce-motion .hscroll-track{ flex-direction:column; transform:none !important; padding-inline:0; gap:22px; align-items:stretch; }
html.reduce-motion .hcards{ flex-direction:column; }
html.reduce-motion .hpanel, html.reduce-motion .hcards .product{ width:100%; }
html.reduce-motion .hscroll-rail{ display:none; }

/* Keyboard focus visibility (a11y) — only shows for keyboard users, not mouse */
a:focus-visible, button:focus-visible, [role="button"]:focus-visible,
input:focus-visible, textarea:focus-visible, select:focus-visible,
.pill:focus-visible, .mode-toggle:focus-visible, .acct-btn:focus-visible,
.cart-btn:focus-visible, .burger:focus-visible, .drawer-close:focus-visible,
.auth-input:focus-visible, .signup input:focus-visible,
.co-field input:focus-visible, .pay-opt:focus-visible, .product:focus-visible{
  outline:2px solid var(--accent); outline-offset:3px; border-radius:6px;
}

/* ============================================================
   STORE STATES + PRODUCT PAGE (added for ext-shop)
   ============================================================ */
.store-status{ grid-column:1/-1; text-align:center; padding:70px 20px; color:var(--muted); }
.store-status .big{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:clamp(1.6rem,4vw,2.4rem); color:var(--text); margin-bottom:10px; letter-spacing:var(--display-spacing); }
.skel{ aspect-ratio:4/5; border-radius:16px; background:linear-gradient(100deg,var(--card) 30%,var(--layer-1) 50%,var(--card) 70%); background-size:200% 100%; animation:skel 1.3s infinite; border:1px solid var(--line); }
@keyframes skel{ to{ background-position:-200% 0; } }

.product .ph img{ width:78%; aspect-ratio:4/5; object-fit:cover; border-radius:10px; transition:transform .6s cubic-bezier(.16,1,.3,1); }
.product:hover .ph img{ transform:scale(1.05); }

/* product page */
.pp{ padding-top:120px; min-height:100vh; }
.pp-back{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); display:inline-flex; gap:8px; align-items:center; transition:color .3s; }
html[lang="ar"] .pp-back{ font-family:var(--font-body); letter-spacing:0; }
.pp-back:hover{ color:var(--accent); }
.pp-grid{ display:grid; grid-template-columns:1.1fr 1fr; gap:50px; margin-top:30px; align-items:start; }
.pp-visual{ position:sticky; top:110px; background:radial-gradient(circle at 50% 30%, var(--layer-1), var(--bg)); border:1px solid var(--line); border-radius:20px; aspect-ratio:4/5; display:grid; place-items:center; overflow:hidden; }
.pp-visual img{ width:100%; height:100%; object-fit:cover; }
.pp-visual svg{ width:86%; }
.pp-info h1{ font-family:var(--font-display); font-weight:var(--display-weight); letter-spacing:var(--display-spacing); font-size:clamp(2.2rem,5vw,3.6rem); line-height:1.02; margin:14px 0 8px; }
.pp-info .pp-price{ font-family:var(--font-mono); color:var(--accent); font-size:1.3rem; }
.pp-info .pp-desc{ color:var(--muted); margin:22px 0; font-size:1.08rem; line-height:1.65; max-width:48ch; }
.pp-actions{ display:flex; gap:12px; margin-top:30px; flex-wrap:wrap; }
.pp-actions .btn{ min-width:200px; justify-content:center; }
.pp-note{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-top:18px; }
html[lang="ar"] .pp-note{ font-family:var(--font-body); letter-spacing:0; }
@media (max-width:820px){ .pp-grid{ grid-template-columns:1fr; gap:26px; } .pp-visual{ position:static; } }

/* ============================================================
   CHECKOUT PAGE
   ============================================================ */
.co{ padding-top:120px; min-height:100vh; }

/* ---- policy / legal pages ---- */
.policy{ padding:120px 0 90px; min-height:100vh; }
.policy .wrap{ max-width:780px; }
.policy h1{ font-family:var(--font-display); font-weight:var(--display-weight); letter-spacing:var(--display-spacing); font-size:clamp(2.1rem,5vw,3.2rem); line-height:1; margin:22px 0 8px; }
.policy .updated{ display:block; font-family:var(--font-mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-bottom:38px; }
html[lang="ar"] .policy .updated{ font-family:var(--font-body); letter-spacing:0; }
.policy .lead{ font-size:1.08rem; line-height:1.75; margin-bottom:30px; }
.policy h2{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:clamp(1.2rem,2.6vw,1.6rem); letter-spacing:var(--display-spacing); margin:40px 0 14px; }
.policy p, .policy li{ color:var(--fg); opacity:.85; line-height:1.75; font-size:1rem; }
.policy p{ margin-bottom:14px; }
.policy ul{ margin:0 0 16px; padding-inline-start:22px; display:flex; flex-direction:column; gap:9px; list-style:disc; }
.policy a{ color:var(--accent); text-decoration:underline; text-underline-offset:3px; }
.policy .policy-contact{ margin-top:40px; padding-top:22px; border-top:1px solid var(--line); color:var(--muted); }
.policy table.kv{ width:100%; border-collapse:collapse; margin:8px 0 18px; }
.policy table.kv td{ border:1px solid var(--line); padding:11px 14px; vertical-align:top; font-size:.96rem; opacity:.9; }
.policy table.kv td:first-child{ color:var(--muted); width:38%; }

/* ---- cookie consent banner ---- */
.cookie-bar{ position:fixed; left:16px; right:16px; bottom:16px; z-index:680; max-width:820px; margin-inline:auto; background:var(--bg); border:1px solid var(--line); border-radius:16px; padding:18px 20px; box-shadow:0 24px 70px rgba(0,0,0,.55); }
.cookie-bar[hidden]{ display:none; }
.cookie-main{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.cookie-main p{ flex:1 1 280px; color:var(--muted); font-size:.92rem; line-height:1.6; margin:0; }
.cookie-main p a{ color:var(--accent); text-decoration:underline; }
.cookie-acts{ display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
.cookie-acts .btn{ padding:10px 16px; font-size:.78rem; }
.cookie-panel{ margin-top:16px; padding-top:16px; border-top:1px solid var(--line); display:flex; flex-direction:column; gap:14px; }
.cookie-panel[hidden]{ display:none; }
.cookie-cat{ display:flex; align-items:center; justify-content:space-between; gap:16px; }
.cookie-cat span{ display:flex; flex-direction:column; gap:3px; }
.cookie-cat strong{ font-size:.9rem; }
.cookie-cat small{ color:var(--muted); font-size:.78rem; }
.cookie-cat input{ width:18px; height:18px; accent-color:var(--accent); flex:0 0 auto; }
@media (max-width:560px){ .cookie-acts{ width:100%; } .cookie-acts .btn{ flex:1 1 auto; justify-content:center; } }
.co h1{ font-family:var(--font-display); font-weight:var(--display-weight); letter-spacing:var(--display-spacing); font-size:clamp(2rem,5vw,3.2rem); line-height:1; margin-bottom:6px; }
.co .co-sub{ color:var(--muted); margin-bottom:36px; }
.co-grid{ display:grid; grid-template-columns:1.3fr 1fr; gap:40px; align-items:start; }
.co-card{ border:1px solid var(--line); border-radius:18px; padding:28px; background:var(--card); }
.co-card h3{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-bottom:20px; }
html[lang="ar"] .co-card h3{ font-family:var(--font-body); letter-spacing:0; font-weight:700; }
.co-field{ margin-bottom:16px; }
.co-field label{ display:block; font-family:var(--font-mono); font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:7px; }
html[lang="ar"] .co-field label{ font-family:var(--font-body); letter-spacing:0; }
.co-field input{ width:100%; background:var(--bg); border:1px solid var(--line); color:var(--text); padding:13px 15px; border-radius:10px; font-family:var(--font-body); font-size:1rem; transition:border-color .2s; }
.co-field input:focus{ outline:none; border-color:var(--accent); }
.co-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.pay-opt{ display:flex; align-items:center; gap:12px; border:1px solid var(--line); border-radius:10px; padding:14px 16px; cursor:pointer; transition:border-color .2s; }
.pay-opt + .pay-opt{ margin-top:10px; }
/* checkout coupon */
.co-coupon{ margin:16px 0 4px; }
.cp-row{ display:flex; gap:8px; }
.cp-row input{ flex:1; min-width:0; background:transparent; border:1px solid var(--line); border-radius:10px; padding:11px 14px; color:var(--fg); font-family:var(--font-mono); text-transform:uppercase; letter-spacing:.08em; }
.cp-row input:focus{ outline:none; border-color:var(--accent); }
.cp-row .btn{ flex:0 0 auto; padding:11px 18px; }
.cp-applied{ display:flex; align-items:center; justify-content:space-between; gap:10px; border:1px dashed var(--accent); border-radius:10px; padding:10px 14px; }
.cp-tag{ font-family:var(--font-mono); letter-spacing:.05em; color:var(--accent); }
.cp-x{ background:none; border:none; color:var(--muted); cursor:pointer; font-size:.78rem; text-decoration:underline; }
.cp-x:hover{ color:var(--fg); }
.cp-msg{ font-size:.8rem; margin-top:8px; min-height:1em; }
.sum-tot .cp-disc span{ color:var(--accent); }
.pay-opt:hover{ border-color:var(--accent); }
.pay-opt .dot{ width:16px; height:16px; border-radius:50%; border:2px solid var(--muted); position:relative; flex-shrink:0; transition:border-color .2s; }
.pay-opt .dot::after{ content:""; position:absolute; inset:3px; border-radius:50%; background:var(--accent); opacity:0; transition:opacity .2s; }
.pay-opt.sel{ border-color:var(--accent); }
.pay-opt.sel .dot{ border-color:var(--accent); }
.pay-opt.sel .dot::after{ opacity:1; }
.pay-opt .pt{ font-size:1rem; } .pay-opt .ps{ font-family:var(--font-mono); font-size:.62rem; color:var(--muted); margin-inline-start:auto; letter-spacing:.1em; text-transform:uppercase; }
.co-payerr{ background:rgba(200,60,60,.12); border:1px solid rgba(200,60,60,.45); color:#e98a8a; border-radius:10px; padding:11px 14px; font-size:.85rem; margin-top:18px; }
.co-gate{ max-width:440px; margin:70px auto; text-align:center; padding:0 20px; }
.co-gate-lock{ color:var(--accent); margin-bottom:18px; display:flex; justify-content:center; }
.co-gate h1{ font-family:var(--font-display); font-weight:var(--display-weight); letter-spacing:var(--display-spacing); font-size:clamp(1.7rem,4vw,2.5rem); line-height:1.1; margin-bottom:12px; }
.co-gate p{ color:var(--muted); margin-bottom:26px; font-size:1rem; line-height:1.6; }
.co-gate .btn{ display:inline-flex; }
html[lang="ar"] .co-gate p{ font-family:var(--font-body); }

/* my orders page */
.acc-title{ font-family:var(--font-display); font-weight:var(--display-weight); letter-spacing:var(--display-spacing); font-size:clamp(2rem,5vw,3rem); margin-bottom:26px; }
.ao-card{ background:var(--card); border:1px solid var(--line); border-radius:14px; margin-bottom:16px; overflow:hidden; transition:border-color .2s; }
.ao-card.open{ border-color:var(--accent); }
.ao-summary{ display:flex; align-items:center; gap:16px; padding:16px 20px; cursor:pointer; }
.ao-summary:hover{ background:rgba(255,255,255,.025); }
.ao-thumbs{ display:flex; align-items:center; flex-shrink:0; }
.ao-th{ width:44px; height:54px; border-radius:8px; background:#16181d center/cover no-repeat; border:1px solid var(--line); margin-inline-start:-14px; box-shadow:-5px 0 12px rgba(0,0,0,.45); }
.ao-th:first-child{ margin-inline-start:0; }
.ao-th.ph{ background:linear-gradient(135deg,var(--layer-1),var(--bg)); }
.ao-th.more{ display:grid; place-items:center; font-family:var(--font-mono); font-size:.7rem; color:var(--muted); background:var(--layer-1); }
.ao-meta{ flex:1; min-width:0; }
.ao-id{ font-family:var(--font-mono); font-size:.88rem; font-weight:700; }
.ao-date{ color:var(--muted); font-size:.74rem; margin-top:4px; }
.ao-right{ display:flex; align-items:center; gap:14px; flex-shrink:0; }
.ao-chev{ color:var(--muted); transition:transform .25s; font-size:1.1rem; line-height:1; }
.ao-card.open .ao-chev{ transform:rotate(180deg); }
.ao-status{ font-family:var(--font-mono); font-size:.6rem; letter-spacing:.08em; text-transform:uppercase; padding:4px 11px; border-radius:20px; border:1px solid var(--line); white-space:nowrap; }
.ao-new{ color:#5b9bd5; border-color:rgba(91,155,213,.5); }
.ao-processing{ color:#e0a458; border-color:rgba(224,164,88,.5); }
.ao-shipped{ color:#8aa77a; border-color:rgba(138,167,122,.5); }
.ao-delivered{ color:#5cb85c; border-color:rgba(92,184,92,.5); background:rgba(92,184,92,.08); }
.ao-cancelled{ color:#d9534f; border-color:rgba(217,83,79,.5); }
.ao-pending{ color:#9aa6b2; border-color:var(--line); }
.ao-total{ font-family:var(--font-mono); color:var(--accent); font-weight:700; font-size:.95rem; }
.ao-details{ padding:0 20px 18px; }
.ao-items{ border-top:1px solid var(--line); padding:12px 0; margin-bottom:8px; }
.ao-item{ display:flex; justify-content:space-between; gap:12px; font-size:.9rem; padding:3px 0; }
.ao-item span:last-child{ color:var(--muted); font-family:var(--font-mono); white-space:nowrap; }
.ao-ship{ font-size:.85rem; color:var(--muted); line-height:1.9; border-top:1px solid var(--line); padding-top:10px; }
.ao-lbl{ color:var(--text); font-family:var(--font-mono); font-size:.66rem; text-transform:uppercase; letter-spacing:.05em; }
.ao-track{ color:var(--accent); margin-bottom:6px; }
.ao-track .ao-lbl{ color:var(--accent); }
.ao-tlink{ display:inline-block; background:var(--accent); color:#fff; text-decoration:none; padding:4px 13px; border-radius:20px; font-family:var(--font-mono); font-size:.66rem; margin-inline-start:8px; white-space:nowrap; }
.ao-tlink:hover{ filter:brightness(1.12); }
html[lang="ar"] .ao-status, html[lang="ar"] .ao-lbl{ font-family:var(--font-body); letter-spacing:0; }
@media (max-width:560px){ .ao-th{ width:38px; height:46px; } .ao-right{ gap:8px; } .ao-status{ font-size:.55rem; padding:3px 8px; } }

/* summary */
.co-sum{ position:sticky; top:110px; }
.sum-line{ display:flex; gap:12px; align-items:center; padding:12px 0; border-bottom:1px solid var(--line); }
.sum-line .thumb{ width:46px; height:56px; border-radius:7px; background:radial-gradient(circle at 50% 30%, var(--layer-1), var(--bg)); border:1px solid var(--line); display:grid; place-items:center; overflow:hidden; flex-shrink:0; }
.sum-line .thumb img{ width:100%; height:100%; object-fit:cover; } .sum-line .thumb svg{ width:84%; }
.sum-line .sl-info{ flex:1; min-width:0; }
.sum-line .sl-name{ font-weight:500; font-size:.98rem; } [data-theme="dark"] .sum-line .sl-name{ font-family:var(--font-body); }
.sum-line .sl-meta{ font-family:var(--font-mono); font-size:.6rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-top:2px; }
.sum-line .sl-price{ font-family:var(--font-mono); font-size:.82rem; color:var(--accent); }
.sum-tot{ margin-top:18px; display:flex; flex-direction:column; gap:10px; }
.sum-tot .r{ display:flex; justify-content:space-between; align-items:center; font-size:.95rem; color:var(--muted); }
.sum-tot .r.grand{ color:var(--text); border-top:1px solid var(--line); padding-top:14px; margin-top:6px; }
.sum-tot .r.grand .amt{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:1.6rem; }
.co-place{ width:100%; justify-content:center; margin-top:22px; }

/* confirmation */
.co-done{ text-align:center; padding:80px 20px; max-width:560px; margin:0 auto; }
.co-done .check{ width:74px; height:74px; border-radius:50%; border:2px solid var(--accent); color:var(--accent); display:grid; place-items:center; font-size:2.2rem; margin:0 auto 26px; }
.co-done h1{ margin-bottom:14px; }
.co-done p{ color:var(--muted); margin-bottom:8px; }
.co-done .ordno{ font-family:var(--font-mono); color:var(--accent); font-size:1.1rem; letter-spacing:.1em; }
.co-empty{ text-align:center; padding:90px 20px; color:var(--muted); }
.co-empty .big{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:1.8rem; color:var(--text); margin-bottom:14px; }

@media (max-width:840px){ .co-grid{ grid-template-columns:1fr; } .co-sum{ position:static; } }
@media (max-width:520px){ .co-row{ grid-template-columns:1fr; } }

/* ============================================================
   SPLIT TEXT (SplitType + GSAP) + Barba transitions
   ============================================================ */
.split-text .word{ overflow:hidden; display:inline-block; }
.split-text .char{ display:inline-block; will-change:transform; }
.split-text{ opacity:1; }
[data-barba="container"]{ min-height:60vh; }

/* ============================================================
   CINEMATIC PRELOADER (v2)
   ============================================================ */
#loader{ overflow:hidden; }
.loader-inner{ text-align:center; width:min(460px,84vw); }
.loader-mark{ font-family:'Archivo','Space Grotesk',sans-serif; font-weight:900; font-size:clamp(3.4rem,11vw,6.5rem); letter-spacing:-.03em; line-height:1; display:flex; justify-content:center; gap:.01em; }
.loader-mark .x{ color:var(--accent); }
.loader-count{ font-family:var(--font-mono); font-size:1rem; color:var(--muted); margin-top:22px; letter-spacing:.25em; display:flex; justify-content:center; align-items:baseline; gap:2px; }
.loader-count i{ font-style:normal; font-size:.7rem; }
.loader-bar{ height:2px; width:100%; background:var(--line); margin-top:14px; overflow:hidden; border-radius:2px; }
.loader-bar #loadFill{ display:block; height:100%; width:100%; background:var(--accent); transform:scaleX(0); transform-origin:left; }
.loader-word{ font-family:var(--font-mono); font-size:.6rem; letter-spacing:.34em; text-transform:uppercase; color:var(--muted); margin-top:26px; }
html[lang="ar"] .loader-word{ font-family:var(--font-body); letter-spacing:.05em; }

/* ============================================================
   HORIZONTAL SCROLL COLLECTION (pinned)
   ============================================================ */
.hscroll{ position:relative; background:var(--bg); }
.hscroll-pin{ height:100vh; display:flex; align-items:center; overflow:hidden; direction:ltr; /* keep the over-wide track left-aligned in RTL too, so scroll motion matches LTR */ }
.hscroll-track{ display:flex; align-items:center; gap:34px; padding-inline:7vw; will-change:transform; direction:ltr; }
.hcards{ display:flex; align-items:center; gap:24px; }
.hpanel{ flex:0 0 auto; width:min(520px,84vw); }
.hpanel .sec-num{ display:block; margin-bottom:14px; }
.hpanel h2{ font-family:var(--font-display); font-weight:var(--display-weight); letter-spacing:var(--display-spacing); font-size:clamp(2.6rem,6vw,4.6rem); line-height:.92; overflow-wrap:break-word; }
.hpanel p{ color:var(--muted); margin-top:18px; font-family:var(--font-mono); font-size:.8rem; letter-spacing:.18em; text-transform:uppercase; }
html[lang="ar"] .hpanel p{ font-family:var(--font-body); letter-spacing:0; }
.hpanel.outro{ display:flex; flex-direction:column; justify-content:space-between; min-height:64vh; padding-bottom:28px; }
.hpanel.outro .big-x{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:clamp(4rem,12vw,9rem); color:var(--accent); line-height:1; }
.hpanel.outro .outro-text{ display:flex; flex-direction:column; }
.hpanel.outro .outro-line{ font-family:var(--font-body); font-size:clamp(.98rem,1.15vw,1.18rem); letter-spacing:0; text-transform:none; color:var(--muted); margin-top:14px; max-width:36ch; line-height:1.55; }
html[lang="ar"] .hpanel.outro .outro-line{ font-size:clamp(1.05rem,1.3vw,1.3rem); }
.hcards .product{ flex:0 0 auto; width:clamp(300px,26vw,360px); }

/* progress rail under the pinned section */
.hscroll-rail{ position:absolute; left:7vw; right:7vw; bottom:46px; height:2px; background:var(--line); border-radius:2px; overflow:hidden; }
.hscroll-rail i{ position:absolute; left:0; top:0; height:100%; width:100%; background:var(--accent); transform:scaleX(0); transform-origin:left; }

@media (max-width:899px){
  .hscroll-pin{ height:auto; overflow:visible; display:block; padding:10px 0 0; }
  .hscroll-track{ flex-direction:column; transform:none !important; padding-inline:0; gap:22px; align-items:stretch; }
  .hcards{ flex-direction:column; }
  .hpanel, .hcards .product{ width:100%; }
  .hpanel h2{ font-size:clamp(2.2rem,9vw,3.4rem); }
  .hscroll-rail{ display:none; }
}

/* ============================================================
   PRODUCT GALLERY + STOCK (admin v2 additions)
   ============================================================ */
.pp-visual{ background:none !important; border:none !important; aspect-ratio:auto !important; display:block !important; }
.pp-main{ background:radial-gradient(circle at 50% 30%, var(--layer-1), var(--bg)); border:1px solid var(--line); border-radius:20px; aspect-ratio:4/5; display:grid; place-items:center; overflow:hidden; }
.pp-main img{ width:100%; height:100%; object-fit:cover; }
.pp-main svg{ width:86%; }
.pp-thumbs{ display:flex; gap:10px; margin-top:14px; flex-wrap:wrap; }
.pp-thumb{ width:58px; height:72px; border-radius:8px; overflow:hidden; border:1px solid var(--line); background:#16181d; padding:0; cursor:pointer; opacity:.55; transition:.2s; }
.pp-thumb img{ width:100%; height:100%; object-fit:cover; }
.pp-thumb.sel, .pp-thumb:hover{ opacity:1; border-color:var(--accent); }
.btn[disabled]{ opacity:.45; cursor:not-allowed; transform:none !important; filter:none !important; box-shadow:none !important; }

/* sold-out on cards */
.product{ position:relative; }
.product .sold{ position:absolute; top:14px; inset-inline-end:14px; font-family:var(--font-mono); font-size:.56rem; letter-spacing:.14em; background:#0a0a0a; color:#fff; border:1px solid var(--line); padding:4px 9px; border-radius:30px; z-index:3; text-transform:uppercase; }
.product.oos .ph{ opacity:.5; }
.pp-stock-out{ display:inline-block; margin-top:14px; font-family:var(--font-mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:#e0726b; }
html[lang="ar"] .pp-stock-out{ font-family:var(--font-body); letter-spacing:0; }

/* ============================================================
   MOBILE REFINEMENTS (v3 — storefront polish for phones/tablets)
   ============================================================ */
@media (max-width:900px){
  .section{ padding:64px 0; }
  .hscroll{ padding:8px 0; }
  .hscroll-track{ padding-inline:6vw; gap:16px; }
  .hcards{ gap:16px; width:100%; }
  .hpanel{ padding-block:6px; }
  .hpanel.intro p{ display:none; }              /* "scroll to explore" irrelevant when stacked */
  .hpanel.outro .big-x{ font-size:4rem; }
}

@media (max-width:600px){
  /* --- nav --- */
  header{ padding:13px 0; }
  .brandmark .lockup-sub{ display:none; }
  .controls{ gap:7px; }
  .pill{ padding:8px 11px; font-size:.6rem; letter-spacing:.1em; }
  .cart-btn{ width:37px; height:37px; }
  .logo-img{ height:28px; }

  /* --- hero --- */
  .hero{ padding-top:80px; min-height:90vh; }
  .hero-top{ gap:6px; }
  .hero-tag{ font-size:.6rem; letter-spacing:.12em; }
  .hero-top .hero-tag:last-child{ display:none; }   /* hide EST. RIYADH on phone */
  .hero-title{ font-size:clamp(3.8rem,27vw,8rem); }
  .hero-sub{ margin-top:22px; gap:18px; }
  .hero-statement{ font-size:1.08rem; max-width:100%; }
  .hero-cta{ width:100%; gap:10px; }
  .hero-cta .btn{ flex:1; justify-content:center; padding:14px 10px; }

  /* --- sections / typography --- */
  .sec-head{ margin-bottom:30px; gap:12px; }
  .manifesto p{ font-size:1.65rem; max-width:100%; }
  .manifesto .meta{ margin-top:40px; gap:18px; }
  .dual{ margin-top:36px; }
  .dual .panel{ min-height:210px; padding:24px; }

  /* --- horizontal collection (stacked) --- */
  .hpanel h2{ font-size:2.3rem; }
  .hcards .product{ width:100%; }

  /* --- product page --- */
  .pp{ padding-top:96px; }
  .pp-actions .btn{ width:100%; min-width:0; }
  .pp-info h1{ font-size:2.2rem; }

  /* --- cta / newsletter --- */
  .cta h2{ font-size:2.6rem; }
  .signup{ flex-direction:column; }
  .signup input{ min-width:0; width:100%; }
  .signup .btn{ width:100%; }

  /* --- footer --- */
  .foot-bottom{ flex-direction:column; align-items:flex-start; gap:10px; }
}
