/* Omixus Single Product Page — ported from preview/product-v1.html */
:root{
  /* ── Matched to homepage [data-theme="dark"] prototype tokens ── */
  /* Surfaces — warmer violet-tinted dark to feel like shopping, not a void */
  --bg:#120A24;
  --bg-2:#1B1233;
  --surface:#241947;
  --surface-2:#2D2154;
  --text:#F4F4F8;
  --text-2:#D1CCE4;
  --text-3:#9C94B8;
  --text-4:#635C82;

  /* Single accent — purple only */
  --brand:#6311B9;
  --brand-h:#4E0E93;
  --brand-soft:rgba(99,17,185,.08);
  --brand-glow:rgba(99,17,185,.20);
  --brand-lav:#C4B5FD;          /* lavender for secondary highlights (matches hero gradient) */

  /* Semantic colors from theme */
  --success:#34C759;
  --warning:#FF9F0A;
  --danger:#FF453A;
  --amber:#FBBF24;   /* star rating + amber accents */

  /* Solid borders — warmer violet-tinted to harmonize with background */
  --border:#2E2250;
  --border-2:#3C2D66;

  /* 8pt grid spacing */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:20px;
  --s-6:24px; --s-7:32px; --s-8:40px; --s-9:48px; --s-10:64px;
  --s-11:80px; --s-12:96px;

  /* Radii — theme scale only */
  --r-1:4px; --r-2:8px; --r-3:12px; --r-4:16px; --r-5:20px; --r-6:24px;
  --r-full:999px;
  --radius:12px;        /* legacy alias */
  --radius-lg:20px;     /* legacy alias */

  /* Theme shadow system */
  --shadow-xs:0 1px 2px rgba(0,0,0,.2);
  --shadow-sm:0 1px 3px rgba(0,0,0,.3);
  --shadow-md:0 4px 16px rgba(0,0,0,.3);
  --shadow-lg:0 8px 32px rgba(0,0,0,.4);
  --shadow-xl:0 16px 48px rgba(0,0,0,.5);
  --shadow-glow:0 0 34px var(--brand-glow);

  /* Typography — theme fonts */
  --f-ar:'IBM Plex Sans Arabic',system-ui,sans-serif;
  --f-display:'Readex Pro','IBM Plex Sans Arabic',sans-serif;
  --f-mono:'JetBrains Mono',monospace;

  /* Hero gradient (matches homepage .hero-main-card) */
  --hero-gradient:linear-gradient(140deg,#16102E 0%,#1F1544 35%,#2A1A5A 65%,#181033 100%);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  /* Uniform bg with a single subtle top-center glow — scrolls with content for consistency */
  background:
    radial-gradient(1800px 900px at 50% 0, rgba(99,17,185,.09), transparent 70%),
    var(--bg);
  color:var(--text);
  font-family:var(--f-ar);
  font-size:15px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
button{border:0;font:inherit;background:transparent;color:inherit;cursor:pointer}
img{max-width:100%;display:block}

/* Noise overlay */
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.04;
  mix-blend-mode:overlay;
  background:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");
}

.container{
  max-width:1280px;
  margin:0 auto;
  padding:0 32px;
  position:relative;
  z-index:2;
}

/* ── Top bar / breadcrumb ── */
.top-bar{
  padding:18px 0;
  border-bottom:1px solid var(--border);
  font-family:var(--f-ar);
  font-size:13px;
  color:var(--text-3);
}
.top-bar .crumb{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.top-bar .crumb li{display:inline-flex;align-items:center;gap:8px}
.top-bar a{color:var(--text-3);transition:color .2s;text-decoration:none}
.top-bar a:hover{color:var(--brand-lav)}
.top-bar .crumb li[aria-current="page"] span{color:var(--text);font-weight:700}
.top-bar .crumb-brand{color:var(--text-3);font-weight:400}
.top-bar .sep{opacity:.35;font-size:11px}
@media (max-width:600px){
  .top-bar{padding:12px 0;font-size:12px}
  .top-bar .crumb{gap:6px}
  .top-bar .crumb li{gap:6px}
}

/* ── HERO ── */
#productHero > .hero{
  margin:0;
  padding:20px 0 16px;
  display:grid;
  grid-template-columns:1.15fr 1fr;
  gap:56px;
  align-items:stretch;
  position:relative;
}

/* Gallery */
.gallery{
  position:relative;
  display:flex;
  flex-direction:column;
}
.gallery-main-wrap{
  display:grid;
  grid-template-columns:78px 1fr;
  gap:14px;
  flex:1;
}

/* Vertical thumbnail rail — Apple/Jarir style */
.gallery-rail{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:0;
  align-items:stretch;
}
.gal-thumb{
  position:relative;
  width:78px;
  height:96px;
  border-radius:14px;
  border:1px solid var(--border);
  background:linear-gradient(160deg,#1A1030 0%,#150a28 60%,#120A24 100%);
  cursor:pointer;
  overflow:hidden;
  transition:border-color .3s, transform .3s, box-shadow .3s;
  display:flex;
  align-items:center;
  justify-content:center;
}
.gal-thumb::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 50% 30%,rgba(99,17,185,.18),transparent 70%);
  pointer-events:none;
}
.gal-thumb:hover{
  border-color:rgba(99,17,185,.35);
  transform:translateY(-2px);
}
.gal-thumb.is-active{
  border-color:var(--brand);
  box-shadow:
    0 0 0 1px var(--brand),
    0 8px 24px -8px rgba(99,17,185,.55);
}
.gal-thumb.is-active::after{
  content:"";
  position:absolute;
  right:6px;top:6px;
  width:6px;height:6px;
  border-radius:50%;
  background:var(--brand-lav);
  box-shadow:0 0 8px var(--brand-lav);
}
.gal-thumb-phone{
  position:relative;
  width:38px;
  height:72px;
  border-radius:10px;
  background:linear-gradient(145deg,#0a0a0f 0%,#1a1a24 55%,#0a0a0f 100%);
  border:1px solid rgba(90,85,120,.4);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.04),
    0 4px 16px -4px rgba(99,17,185,.5);
}
.gal-thumb-phone::before{
  content:"";
  position:absolute;
  top:5px;left:50%;
  transform:translateX(-50%);
  width:18px;height:5px;
  background:#000;
  border-radius:999px;
}
.gal-thumb-phone::after{
  content:"";
  position:absolute;
  top:13px;left:3px;right:3px;bottom:3px;
  border-radius:7px;
  background:linear-gradient(160deg,#1a1540 0%,#0f0a25 60%,#060418 100%);
}
/* Color variants */
.gal-thumb[data-color="titanium"] .gal-thumb-phone{
  background:linear-gradient(145deg,#d4d2ca 0%,#9e9a8c 50%,#6f6a5a 100%);
  border-color:rgba(255,240,200,.35);
}
.gal-thumb[data-color="desert"] .gal-thumb-phone{
  background:linear-gradient(145deg,#c4a575 0%,#8a6c3f 55%,#4d3820 100%);
  border-color:rgba(255,180,100,.35);
}
.gal-thumb[data-color="white"] .gal-thumb-phone{
  background:linear-gradient(145deg,#f5f5f0 0%,#c8c5bc 55%,#8a8578 100%);
  border-color:rgba(255,255,255,.5);
}
/* Dynamic per-thumb tint — uses inline --phone-color from PHP swatch hex.
   Applies to any color slug not matched by the hard-coded rules above. */
.gal-thumb-phone[style*="--phone-color"]{
  background:linear-gradient(145deg,
    color-mix(in srgb,var(--phone-color) 85%,#0a0810) 0%,
    color-mix(in srgb,var(--phone-color) 55%,#1a1520) 55%,
    color-mix(in srgb,var(--phone-color) 30%,#06040e) 100%);
  border-color:color-mix(in srgb,var(--phone-color) 60%,rgba(255,255,255,.35));
}
.gal-thumb-phone[style*="--phone-color"]::after{
  background:linear-gradient(160deg,
    color-mix(in srgb,var(--phone-color) 35%,#0f0a25) 0%,
    color-mix(in srgb,var(--phone-color) 18%,#060418) 100%);
}
.gal-thumb[data-view="back"] .gal-thumb-phone::after{
  background:
    radial-gradient(circle at 30% 28%, #1a1530 4px, transparent 5px),
    radial-gradient(circle at 50% 28%, #1a1530 4px, transparent 5px),
    radial-gradient(circle at 40% 42%, #1a1530 4px, transparent 5px),
    linear-gradient(160deg,#0f0a25 0%,#060418 100%);
}
.gal-thumb[data-view="video"]::after,
.gal-thumb[data-view="video"].is-active::after{
  content:"";
  position:absolute;
  left:50%;top:50%;
  right:auto;bottom:auto;
  transform:translate(-50%,-50%);
  z-index:2;
  background:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><polygon points='3.2,2 10,6 3.2,10' fill='white'/></svg>") no-repeat center/10px 10px,
    rgba(0,0,0,.6);
  width:28px;height:28px;
  border-radius:50%;
  backdrop-filter:blur(4px);
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 4px 12px -4px rgba(0,0,0,.6);
}

.gallery-main{
  flex:1;
  min-height:560px;
  background:var(--hero-gradient);
  border-radius:var(--radius-lg);
  border:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
}
.gallery-main::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 30% 40%,rgba(99,17,185,.28),transparent 60%);
  pointer-events:none;
  z-index:0;
}
.gallery-main img{
  max-width:80%;
  max-height:80%;
  width:auto;
  height:auto;
  object-fit:contain;
  filter:drop-shadow(0 80px 80px rgba(0,0,0,.7));
  position:relative;
  z-index:1;
}
.gallery-placeholder{
  position:relative;z-index:1;
  width:240px;height:340px;
  border-radius:36px;
  background:linear-gradient(155deg,#2a2440 0%,#1a1530 45%,#0f0a25 100%);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:
    0 60px 100px -30px rgba(0,0,0,.8),
    0 30px 60px -20px rgba(99,17,185,.35),
    inset 0 1px 0 rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;
}
.gallery-placeholder::before{
  content:"";
  position:absolute;inset:8px;
  border-radius:28px;
  background:
    radial-gradient(ellipse at 30% 20%, rgba(99,17,185,.18), transparent 60%),
    radial-gradient(ellipse at 70% 80%, rgba(196,181,253,.10), transparent 55%);
}
.gallery-placeholder::after{
  content:"";
  position:absolute;top:16px;left:50%;transform:translateX(-50%);
  width:90px;height:22px;
  border-radius:20px;
  background:rgba(0,0,0,.6);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}
.gallery-placeholder svg{position:relative;z-index:1;color:rgba(255,255,255,.14)}
.gallery-view{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  visibility:hidden;
  transition:opacity .5s cubic-bezier(.2,.8,.2,1);
  z-index:1;
}
.gallery-view.is-active{opacity:1;visibility:visible}
.gallery-view model-viewer{
  width:100%;
  height:100%;
  background:transparent;
  --poster-color:transparent;
}

/* ── CSS 3D iPhone Mockup ── */
.css3d-stage{
  width:100%;height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  perspective:1800px;
  perspective-origin:50% 50%;
  position:relative;
  transform:scale(1.3);
  transform-origin:center center;
}
.css3d-shadow{
  position:absolute;
  bottom:8%;
  left:50%;
  width:24%;
  height:12px;
  background:radial-gradient(ellipse at center,rgba(0,0,0,.35) 0%,rgba(0,0,0,.12) 50%,transparent 80%);
  transform:translateX(-50%);
  filter:blur(14px);
  animation:p3dShadow 8s ease-in-out infinite;
  pointer-events:none;
}
@keyframes p3dShadow{
  0%,100%{width:24%;opacity:.55}
  50%{width:18%;opacity:.35}
}
.css3d-phone{
  position:relative;
  width:180px;
  height:360px;
  transform-style:preserve-3d;
  animation:p3dSpin 14s linear infinite;
  cursor:grab;
  touch-action:none;
}
.css3d-phone:active{cursor:grabbing}
.css3d-phone.is-frozen{animation:none}
@keyframes p3dSpin{
  0%{transform:rotateY(-25deg) rotateX(-5deg)}
  25%{transform:rotateY(65deg) rotateX(-3deg)}
  50%{transform:rotateY(155deg) rotateX(-5deg)}
  75%{transform:rotateY(245deg) rotateX(-3deg)}
  100%{transform:rotateY(335deg) rotateX(-5deg)}
}
.p3d-face{
  position:absolute;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
}
.p3d-front,.p3d-back{
  width:180px;
  height:360px;
  border-radius:28px;
}
.p3d-front{
  background:linear-gradient(145deg,#0a0a0f 0%,#1a1a24 50%,#0a0a0f 100%);
  border:1.5px solid rgba(90,85,120,.4);
  transform:translateZ(13px);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.04),
    0 0 40px -10px rgba(99,17,185,.3);
  overflow:hidden;
}
.p3d-notch{
  position:absolute;
  top:10px;
  left:50%;
  transform:translateX(-50%);
  width:56px;
  height:14px;
  background:#000;
  border-radius:999px;
  z-index:2;
  box-shadow:inset 0 0 0 .5px rgba(255,255,255,.05);
}
.p3d-notch::after{
  content:"";
  position:absolute;
  top:50%;left:14px;
  width:4px;height:4px;
  border-radius:50%;
  background:radial-gradient(circle,#1a1a2a 30%,#0a0a15 70%);
  transform:translateY(-50%);
  box-shadow:0 0 0 .5px rgba(255,255,255,.08);
}
.p3d-screen{
  position:absolute;
  inset:5px;
  border-radius:24px;
  background:
    radial-gradient(circle at 30% 15%,rgba(99,17,185,.45) 0%,transparent 55%),
    radial-gradient(circle at 75% 80%,rgba(196,181,253,.35) 0%,transparent 55%),
    linear-gradient(155deg,#0d0817 0%,#140a24 50%,#07050f 100%);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  align-items:center;
  padding-top:34px;
}
.p3d-time{
  font-family:var(--f-display);
  font-size:54px;
  font-weight:200;
  color:#fff;
  letter-spacing:-.02em;
  text-shadow:0 2px 20px rgba(99,17,185,.6);
  margin-top:18px;
}
.p3d-grid{
  margin-top:auto;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px 14px;
  padding:0 18px 60px;
}
.p3d-grid span{
  width:22px;height:22px;
  border-radius:6px;
  background:linear-gradient(155deg,rgba(255,255,255,.12),rgba(255,255,255,.03));
  border:.5px solid rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.1);
}
.p3d-grid span:nth-child(1){background:linear-gradient(155deg,#34d399,#10b981)}
.p3d-grid span:nth-child(2){background:linear-gradient(155deg,#60a5fa,#2563eb)}
.p3d-grid span:nth-child(3){background:linear-gradient(155deg,#f472b6,#db2777)}
.p3d-grid span:nth-child(4){background:linear-gradient(155deg,#fbbf24,var(--warning))}
.p3d-grid span:nth-child(5){background:linear-gradient(155deg,#a78bfa,#7c3aed)}
.p3d-grid span:nth-child(6){background:linear-gradient(155deg,#22d3ee,#0891b2)}
.p3d-grid span:nth-child(7){background:linear-gradient(155deg,#fb923c,#ea580c)}
.p3d-grid span:nth-child(8){background:linear-gradient(155deg,#f87171,#dc2626)}

.p3d-back{
  background:
    radial-gradient(ellipse at 30% 20%,rgba(99,17,185,.2) 0%,transparent 50%),
    linear-gradient(155deg,#1c1a26 0%,#0d0b15 100%);
  border:1.5px solid rgba(90,85,120,.4);
  transform:translateZ(-13px) rotateY(180deg);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.04),
    inset 0 2px 8px rgba(255,255,255,.06);
}
.p3d-logo{
  position:absolute;
  top:50%;left:50%;
  width:34px;height:34px;
  color:rgba(255,255,255,.12);
  transform:translate(-50%,-50%);
}
.p3d-logo svg{width:100%;height:100%}
.p3d-label{
  position:absolute;
  bottom:22px;left:50%;
  transform:translateX(-50%);
  font-family:var(--f-display);
  font-size:9px;
  font-weight:700;
  letter-spacing:.12em;
  color:rgba(255,255,255,.18);
  text-transform:uppercase;
  white-space:nowrap;
}
.p3d-camera-plate{
  position:absolute;
  top:18px;left:18px;
  width:74px;height:74px;
  border-radius:20px;
  background:linear-gradient(155deg,#1a1824 0%,#0a0812 100%);
  border:.5px solid rgba(255,255,255,.08);
  box-shadow:
    inset 0 0 0 .5px rgba(255,255,255,.03),
    0 2px 8px rgba(0,0,0,.6);
  padding:10px;
}
.p3d-lens{
  position:absolute;
  width:22px;height:22px;
  border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#3a3548 0%,#0a0612 60%,#000 100%);
  border:1px solid rgba(255,255,255,.1);
  box-shadow:
    inset 0 0 4px rgba(0,0,0,.8),
    0 0 0 1px rgba(0,0,0,.5);
}
.p3d-lens span{
  position:absolute;
  top:50%;left:50%;
  width:11px;height:11px;
  border-radius:50%;
  background:radial-gradient(circle at 40% 35%,rgba(99,17,185,.3) 0%,#000 70%);
  transform:translate(-50%,-50%);
  border:.5px solid rgba(99,17,185,.25);
}
.p3d-lens span::after{
  content:"";
  position:absolute;
  top:20%;left:25%;
  width:3px;height:3px;
  border-radius:50%;
  background:rgba(255,255,255,.5);
  filter:blur(.5px);
}
.p3d-lens-1{top:6px;left:6px}
.p3d-lens-2{top:6px;right:6px}
.p3d-lens-3{bottom:6px;left:6px}
.p3d-flash{
  position:absolute;
  bottom:10px;right:10px;
  width:14px;height:14px;
  border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#fef3c7,#fbbf24 60%,#d97706);
  box-shadow:0 0 8px rgba(251,191,36,.35);
}
.p3d-lidar{
  position:absolute;
  bottom:12px;right:30px;
  width:10px;height:10px;
  border-radius:50%;
  background:radial-gradient(circle,#0a0612 0%,#000 100%);
  border:.5px solid rgba(255,255,255,.08);
}

/* Phone side edges — thick enough to read as a phone at all rotation angles */
.p3d-left,.p3d-right{
  width:26px;height:360px;
  top:0;
  background:
    linear-gradient(to right,
      rgba(255,255,255,.18) 0%,
      #3a3548 8%,
      #1c1826 35%,
      #0e0c16 55%,
      #1c1826 80%,
      #3a3548 95%,
      rgba(255,255,255,.12) 100%);
  border-top:.5px solid rgba(255,255,255,.2);
  border-bottom:.5px solid rgba(0,0,0,.7);
  box-shadow:inset 0 0 8px rgba(0,0,0,.4);
}
.p3d-left{
  left:0;
  transform:rotateY(-90deg) translateZ(13px);
  transform-origin:left center;
}
.p3d-right{
  right:0;
  transform:rotateY(90deg) translateZ(13px);
  transform-origin:right center;
}
.p3d-top,.p3d-bottom{
  width:180px;height:26px;
  left:0;
  background:
    linear-gradient(to bottom,
      rgba(255,255,255,.18) 0%,
      #3a3548 8%,
      #1c1826 35%,
      #0e0c16 55%,
      #1c1826 80%,
      #3a3548 95%,
      rgba(255,255,255,.12) 100%);
  box-shadow:inset 0 0 8px rgba(0,0,0,.4);
}
.p3d-top{
  top:0;
  transform:rotateX(90deg) translateZ(13px);
  transform-origin:center top;
}
.p3d-bottom{
  bottom:0;
  transform:rotateX(-90deg) translateZ(13px);
  transform-origin:center bottom;
}
/* USB-C port + speaker grille on bottom edge */
.p3d-bottom::before{
  content:"";
  position:absolute;
  top:50%;left:50%;
  width:14px;height:5px;
  border-radius:3px;
  background:radial-gradient(ellipse,#000 0%,#0a0612 80%);
  transform:translate(-50%,-50%);
  box-shadow:inset 0 0 0 .5px rgba(0,0,0,.8);
}
.p3d-bottom::after{
  content:"";
  position:absolute;
  top:50%;right:18px;
  width:30px;height:3px;
  border-radius:2px;
  background:repeating-linear-gradient(to right,rgba(0,0,0,.7) 0 2px,transparent 2px 4px);
  transform:translateY(-50%);
}

/* Physical side buttons */
.p3d-sidebar{
  position:absolute;
  width:2px;height:80%;
  top:10%;
  background:linear-gradient(to right,rgba(255,255,255,.08),rgba(0,0,0,.3));
  z-index:1;
}
.p3d-sb-left{left:-1px}
.p3d-sb-right{right:-1px}
.p3d-btn{
  position:absolute;
  background:linear-gradient(to right,#2a2638,#1a1624);
  border-radius:2px;
  z-index:3;
}
.p3d-btn-vol-up{left:-4px;top:25%;width:5px;height:32px;box-shadow:inset 0 0 0 .5px rgba(0,0,0,.6),0 1px 0 rgba(255,255,255,.1)}
.p3d-btn-vol-down{left:-4px;top:38%;width:5px;height:32px;box-shadow:inset 0 0 0 .5px rgba(0,0,0,.6),0 1px 0 rgba(255,255,255,.1)}
.p3d-btn-mute{left:-4px;top:15%;width:5px;height:16px;background:#1a1420;box-shadow:inset 0 0 0 .5px rgba(0,0,0,.8)}
.p3d-btn-power{right:-4px;top:25%;width:5px;height:50px;box-shadow:inset 0 0 0 .5px rgba(0,0,0,.6),0 1px 0 rgba(255,255,255,.1)}

/* Segmented mode toggle */
.gallery-mode{
  position:absolute;
  top:16px;
  right:16px;
  left:auto;
  z-index:5;
  display:inline-flex;
  padding:4px;
  background:rgba(10,10,15,.55);
  border:1px solid rgba(255,255,255,.08);
  border-radius:999px;
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
}
.gm-btn{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:8px 14px;
  font-family:var(--f-ar);
  font-size:11px;
  font-weight:700;
  color:var(--text-2);
  border-radius:999px;
  transition:all .3s ease;
}
.gm-btn svg{opacity:.7;transition:opacity .3s}
.gm-btn:hover{color:#fff}
.gm-btn.is-active{
  background:linear-gradient(135deg,var(--brand),#9333EA);
  color:#fff;
  box-shadow:var(--shadow-md);
}
.gm-btn.is-active svg{opacity:1}
.gm-btn .dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--brand-lav);
  box-shadow:0 0 8px var(--brand-lav);
  margin-inline-end:4px;
}
.gallery-3d-hint{
  position:absolute;
  bottom:16px;
  left:50%;
  transform:translateX(-50%);
  z-index:5;
  padding:7px 14px;
  background:rgba(10,10,15,.6);
  border:1px solid rgba(255,255,255,.08);
  border-radius:999px;
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  font-size:10.5px;
  color:var(--text-2);
  display:flex;
  align-items:center;
  gap:6px;
  opacity:0;
  transition:opacity .4s;
  pointer-events:none;
  white-space:nowrap;
}
.gallery-main[data-mode="3d"] .gallery-3d-hint{opacity:1}
.gallery-3d-hint svg{color:var(--brand-lav)}
/* Info panel */
.info{padding-top:10px}
.title{
  font-family:var(--f-display);
  font-size:42px;
  font-weight:800;
  line-height:1.05;
  letter-spacing:-.02em;
  margin:0 0 10px;
}
.rating{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:0;
  flex-wrap:nowrap;
  padding:12px 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  margin-bottom:26px;
}
.rating-num{font-weight:900;font-size:14px;color:var(--amber);line-height:1;margin-inline-start:5px}
.stars{display:flex;gap:2px;color:var(--amber);opacity:.9;font-size:13px}
.rating-count{color:var(--text-3);font-size:10.5px;font-weight:500;margin-inline-start:5px}
.rating-dot{display:none}
.rating-sold{
  display:inline-flex;
  align-items:center;
  gap:5px;
  color:var(--text-3);
  font-size:13px;
  font-weight:500;
  margin-inline-start:0;
}
.rating-sold::before{
  content:"";display:inline-block;
  width:1px;height:14px;
  background:rgba(255,255,255,.1);
  margin:0 10px;flex:none;
  vertical-align:middle;
}
.rating-sold b{color:var(--text);font-weight:700}
.rating-sold-ic{flex-shrink:0;color:var(--amber);opacity:.8}

.price-block{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:4px;
  flex-wrap:nowrap;
  margin-bottom:8px;
}
.price-main-row{
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:10px;
}
.price-main{
  display:inline-flex;
  align-items:center;
  gap:.18em;
  font-family:var(--f-display);
  font-size:56px;
  font-weight:800;
  color:#fff;
  line-height:1;
  letter-spacing:-.02em;
}
.price-ccy{display:none}
/* New Saudi Riyal glyph — viewBox aspect 1124:1256 ≈ 0.895
   Sized like Noon: readable at body scale, proportionally trimmed for hero */
.sar{
  display:inline-block;
  width:.82em;
  height:.92em;
  vertical-align:-.06em;
  fill:currentColor;
  flex:none;
}
.price-main .sar{
  width:.46em;
  height:.52em;
  align-self:center;
  translate:0 4%;
}
.price-old{
  display:inline-flex;
  align-items:center;
  gap:.2em;
  font-size:20px;
  color:var(--text-3);
  text-decoration:line-through;
  text-decoration-thickness:1.5px;
}
.price-old .sar{width:.68em;height:.76em;translate:0 2%}
/* Stacked savings column: small "وفر" label on top, strikethrough below
   align-self:flex-end keeps the old price baseline aligned with the main price */
.price-sub{
  display:flex;flex-direction:column;align-items:flex-start;
  gap:4px;line-height:1;align-self:flex-end;padding-bottom:4px;
}
.price-save-tag{
  display:inline-flex;align-items:center;gap:3px;
  font-family:var(--f-display);font-size:13px;font-weight:900;
  color:#34C759;letter-spacing:.01em;line-height:1;
  white-space:nowrap;
}
.price-save-tag .sar{width:.88em;height:1em;translate:0 -2%}
/* Borderless installment — balanced between price and color label */
.price-inst{
  display:inline-flex;
  align-items:center;
  gap:14px;
  padding:0;
  margin:20px 0;
  background:transparent;
  border:0;
  border-radius:0;
  box-shadow:none;
}
.price-inst::before,
.price-inst::after{content:none;display:none}
.inst-text{
  font-size:12.5px;
  color:var(--text-2);
  line-height:1;
  margin:0;
  white-space:nowrap;
}
.inst-text b{
  color:var(--text);
  font-weight:800;
  font-family:var(--f-display);
}
.inst-text .amt{
  color:var(--brand-lav);
}
.inst-divider{
  width:1px;
  height:20px;
  background:var(--border-2);
  flex:none;
}
.inst-brands{
  display:flex;
  gap:6px;
  align-items:center;
  font-family:var(--f-display);
  font-size:11px;
  font-weight:800;
  text-transform:lowercase;
  letter-spacing:-.01em;
  line-height:1;
}
.inst-brands .t{color:#3BEEA3}
.inst-brands .sep{color:var(--text-4)}
.inst-brands .m{color:#F57CA8}

.section-label{
  display:block;
  font-family:var(--f-sans);
  font-size:14px;
  font-weight:700;
  letter-spacing:.01em;
  color:var(--text-1);
  margin-bottom:12px;
}
.variants{
  display:flex;
  gap:8px;
  margin-bottom:12px;
  flex-wrap:wrap;
  align-items:center;
}
.variant{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:4px;
  padding:6px 12px;
  border:1.5px solid rgba(255,255,255,.12);
  border-radius:999px;
  font-weight:500;
  font-size:12px;
  color:rgba(255,255,255,.85);
  background:rgba(255,255,255,.04);
  transition:all .25s;
  white-space:nowrap;
  cursor:pointer;
}
.variant:hover{border-color:var(--brand)}
.variant.active{border-color:var(--brand);background:rgba(99,17,185,.12);color:#fff}
.variant .swatch{
  width:13px;
  height:13px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.2);
  flex-shrink:0;
}
/* color row — circles only */
.variants .variant{
  width:34px;
  height:34px;
  padding:0;
  border-radius:50%;
  border:2px solid rgba(255,255,255,.15);
  background:transparent;
  font-size:0;
  gap:0;
  flex-shrink:0;
  transition:border-color .2s,box-shadow .2s;
}
.variants .variant:hover{border-color:rgba(255,255,255,.4)}
.variants .variant.active{
  border-color:var(--brand);
  background:transparent;
  box-shadow:0 0 0 3px rgba(99,17,185,.35);
}
.variants .variant .swatch{
  width:26px;
  height:26px;
  border-radius:50%;
  border:none;
  display:block;
  flex-shrink:0;
}
.variant[data-color="black"] .swatch{background:#1A1A1E}
.variant[data-color="titanium"] .swatch{background:linear-gradient(135deg,#B8B8BE,#8A8A92)}
.variant[data-color="desert"] .swatch{background:linear-gradient(135deg,#C8AA8A,#A4866A)}
.variant[data-color="white"] .swatch{background:#F0F0F2}

.storage{
  display:flex;
  gap:10px;
  margin-bottom:26px;
  flex-wrap:wrap;
}
.storage button{
  padding:10px 20px;
  border:1.5px solid var(--border-2);
  border-radius:12px;
  font-family:var(--f-mono);
  font-weight:800;
  font-size:12px;
  letter-spacing:.04em;
  transition:all .25s;
}
.storage button:hover{border-color:var(--brand)}
.storage button.active{border-color:var(--brand);background:rgba(99,17,185,.12);color:#fff}

.meta-strip{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 0;
  margin-bottom:22px;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.meta-line{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  color:var(--text-2);
}
.meta-line svg{flex:none;color:var(--success)}
.meta-line b{color:#fff;font-weight:700}
.meta-line.meta-urgent svg{color:var(--amber)}
.meta-line.meta-urgent b{color:var(--amber)}
.meta-sep{
  width:1px;
  height:16px;
  background:var(--border);
}

.cta-row{
  display:flex;
  gap:10px;
  align-items:center;
  margin-bottom:14px;
}

.qty{
  display:inline-flex;
  align-items:center;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:12px;
  overflow:hidden;
  height:46px;
}
.qty button{
  width:32px;
  height:100%;
  font-size:15px;
  font-weight:700;
  color:var(--text-2);
}
.qty button:hover{color:var(--brand-lav);background:rgba(255,255,255,.03)}
.qty input{
  width:28px;
  text-align:center;
  background:transparent;
  border:0;
  color:#fff;
  font-weight:800;
  font-size:13.5px;
  font-family:var(--f-mono);
}
.qty input::-webkit-outer-spin-button,
.qty input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}

.btn-buy{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  height:46px;
  padding:0 24px;
  background:linear-gradient(105deg,#8B3FD4 0%,#6311B9 45%,#4A0E8F 100%);
  color:#fff;
  border-radius:12px;
  font-family:var(--f-display);
  font-weight:800;
  font-size:14px;
  box-shadow:0 6px 28px rgba(99,17,185,.45),inset 0 1px 0 rgba(255,255,255,.15);
  transition:transform .25s,box-shadow .25s;
  position:relative;
  overflow:hidden;
}
.btn-buy::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,transparent 40%,rgba(255,255,255,.2) 50%,transparent 60%);
  transform:translateX(-100%);
  transition:transform .8s;
}
.btn-buy:hover{transform:translateY(-2px);box-shadow:0 18px 42px -12px rgba(99,17,185,.6),inset 0 0 0 1px rgba(255,255,255,.12)}
.btn-buy:hover::before{transform:translateX(100%)}
.btn-buy:disabled{background:rgba(255,255,255,.06);color:rgba(255,255,255,.3);box-shadow:none;cursor:not-allowed;pointer-events:none;}
.btn-buy:disabled::before{display:none;}
.btn-buy.is-loading{opacity:.7;cursor:wait;pointer-events:none;}
.btn-buy.is-loading .btn-buy-slot[data-slot="add-to-cart"]::after{content:" ...";opacity:.6;}
.btn-buy.is-added{background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 8px 24px -8px rgba(22,163,74,.5);}
.btn-buy.is-added::before{display:none;}
.btn-icon{
  width:46px;
  height:46px;
  background:var(--bg-2);
  border:1px solid var(--border-2);
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--text-2);
  transition:all .25s;
}
.btn-icon:hover{color:var(--danger);border-color:var(--danger)}

/* ── Assurance card — amber ribbon (design 1) ── */
.urg-bar{
  --urg-c:255,159,10;
  --urg-c-solid:var(--warning);
  display:flex;
  flex-direction:column;
  gap:8px;
  margin:12px 0 16px;
  padding:10px 14px;
  background:rgba(var(--urg-c),.07);
  border:1px solid rgba(var(--urg-c),.2);
  border-radius:10px;
  overflow:hidden;
  transition:none;
}
/* ── State modifiers ── */
.urg-bar[data-state="available"]{--urg-c:52,199,89;--urg-c-solid:var(--success)}
.urg-bar[data-state="low"]      {--urg-c:255,159,10;--urg-c-solid:var(--warning)}
.urg-bar[data-state="hot"]      {--urg-c:251,191,36;--urg-c-solid:var(--amber)}
.urg-bar[data-state="out"]      {--urg-c:156,148,184;--urg-c-solid:var(--text-3)}

/* Only the top row matching the current state is visible */
.urg-top{display:none}
.urg-bar[data-state="available"] .urg-top[data-for="available"],
.urg-bar[data-state="low"]       .urg-top[data-for="low"],
.urg-bar[data-state="hot"]       .urg-top[data-for="hot"],
.urg-bar[data-state="out"]       .urg-top[data-for="out"]{display:flex}

/* top row — urgency */
.urg-top{
  align-items:center;
  gap:8px;
  padding:0;
  border-bottom:none;
  min-width:0;
  overflow:hidden;
}
.urg-ic{
  flex:none;width:16px;height:16px;
  display:flex;align-items:center;justify-content:center;
  color:var(--urg-c-solid);
}
/* Only the "low" state has the pulsing flame animation */
.urg-bar[data-state="low"] .urg-ic{animation:urgFlame 1.6s ease-in-out infinite}
@keyframes urgFlame{
  0%,100%{transform:scale(1) rotate(-2deg)}
  50%{transform:scale(1.08) rotate(3deg)}
}
.urg-txt{
  flex:1;
  font-size:11.5px;
  line-height:1.3;
  color:var(--text-2);
}
.urg-txt b{
  color:#fff;
  font-weight:800;
  font-family:var(--f-display);
}
.urg-chip{
  flex:none;
  font-family:var(--f-ar);
  font-size:10px;
  font-weight:800;
  letter-spacing:0;
  color:#000;
  padding:2px 8px;
  background:var(--urg-c-solid);
  border:none;
  border-radius:4px;
  white-space:nowrap;
  letter-spacing:.06em;
}
/* Progress bar only shows on "low" state (stock % remaining) */
.urg-bar:not([data-state="low"]) .urg-progress{display:none}

/* ── CTA button slot system — swaps content based on [data-action] ── */
.btn-buy{position:relative;overflow:hidden}
.btn-buy-slot{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}
.btn-buy .btn-buy-slot[data-slot="notify"]{display:none}
.btn-buy[data-action="notify"] .btn-buy-slot[data-slot="add-to-cart"]{display:none}
.btn-buy[data-action="notify"] .btn-buy-slot[data-slot="notify"]{display:flex}

/* Hide qty selector in "out" state — can't pick quantity of something that doesn't exist */
.cta-row.cta-out .qty{display:none}

/* ── Notify-me modal ── */
.notify-modal{
  position:fixed;
  inset:0;
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .28s ease, visibility 0s linear .28s;
}
.notify-modal.is-open{opacity:1;visibility:visible;pointer-events:auto;transition:opacity .28s ease, visibility 0s linear 0s}
.notify-modal.is-open .notify-card{animation:notifySlide .35s cubic-bezier(.2,.9,.3,1)}
.notify-modal:not(.is-open) .notify-card{transform:translateY(8px) scale(.98);opacity:.6;transition:transform .28s ease, opacity .28s ease}

/* Product video modal — YouTube iframe in a 16:9 card */
.video-modal{
  position:fixed;inset:0;z-index:9999;display:none;
  align-items:center;justify-content:center;padding:24px;
}
.video-modal.is-open{display:flex;animation:notifyFade .2s ease}
.video-backdrop{
  position:absolute;inset:0;
  background:rgba(6,4,18,.85);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}
.video-card{
  position:relative;width:100%;max-width:960px;
  border-radius:16px;overflow:hidden;
  box-shadow:0 40px 120px -30px rgba(0,0,0,.9),0 0 0 1px rgba(196,181,253,.14);
  animation:notifySlide .35s cubic-bezier(.2,.9,.3,1);
}
.video-close{
  position:absolute;top:-44px;right:0;
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);
  color:#fff;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  transition:background .15s ease;
}
.video-close:hover{background:rgba(255,255,255,.22)}
.video-frame{
  position:relative;width:100%;aspect-ratio:16/9;
  background:#000;
}
.video-frame iframe{
  position:absolute;inset:0;width:100%;height:100%;border:0;
}
@keyframes notifyFade{from{opacity:0}to{opacity:1}}
.notify-backdrop{
  position:absolute;
  inset:0;
  background:rgba(10,6,22,.78);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.notify-card{
  position:relative;
  width:100%;
  max-width:420px;
  padding:28px 26px 24px;
  background:
    radial-gradient(500px 300px at 50% -10%,rgba(99,17,185,.18),transparent 70%),
    linear-gradient(180deg,#1A1333,#120A24);
  border:1px solid rgba(196,181,253,.2);
  border-radius:20px;
  box-shadow:0 40px 80px -30px rgba(0,0,0,.8),0 0 0 1px rgba(196,181,253,.06),inset 0 1px 0 rgba(255,255,255,.06);
  animation:notifySlide .35s cubic-bezier(.2,.9,.3,1);
}
@keyframes notifySlide{from{transform:translateY(20px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
.notify-close{
  position:absolute;
  top:14px;
  inset-inline-start:14px;
  width:32px;height:32px;
  background:transparent;
  border:1px solid var(--border);
  border-radius:50%;
  color:var(--text-3);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .2s;
}
.notify-close:hover{color:var(--text);border-color:var(--border-2);background:rgba(255,255,255,.04)}
.notify-ic{
  width:56px;height:56px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:6px auto 16px;
  color:var(--brand-lav);
  background:rgba(99,17,185,.14);
  border:1px solid rgba(196,181,253,.28);
  border-radius:50%;
}
.notify-title{
  text-align:center;
  font-family:var(--f-display);
  font-size:20px;
  font-weight:800;
  color:var(--text);
  margin:0 0 8px;
}
.notify-sub{
  text-align:center;
  font-size:13px;
  line-height:1.6;
  color:var(--text-3);
  margin:0 0 22px;
}
.notify-form{display:flex;flex-direction:column;gap:14px}
.notify-form[hidden]{display:none}
.notify-field{display:flex;flex-direction:column;gap:6px}
.notify-field span{
  font-size:12px;
  font-weight:700;
  color:var(--text-2);
}
.notify-field span b{color:var(--danger);font-weight:900}
.notify-field span small{color:var(--text-4);font-weight:500;font-size:11px}
.notify-field input{
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius:10px;
  padding:12px 14px;
  color:var(--text);
  font-family:var(--f-ar);
  font-size:14px;
  transition:all .2s;
}
.notify-field input:focus{
  outline:none;
  border-color:var(--brand);
  background:rgba(99,17,185,.06);
  box-shadow:0 0 0 3px rgba(99,17,185,.18);
}
.notify-submit{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  margin-top:6px;
  padding:14px;
  background:linear-gradient(180deg,var(--brand) 0%,var(--brand-h) 100%);
  border:none;
  border-radius:12px;
  color:#fff;
  font-family:var(--f-ar);
  font-size:14px;
  font-weight:800;
  cursor:pointer;
  transition:all .25s;
  box-shadow:0 14px 28px -10px rgba(99,17,185,.5);
}
.notify-submit:hover{transform:translateY(-1px);box-shadow:0 18px 36px -10px rgba(99,17,185,.6)}
.notify-note{
  text-align:center;
  font-size:11px;
  color:var(--text-4);
  margin:8px 0 0;
  line-height:1.5;
}
.notify-success{
  text-align:center;
  padding:14px 0 6px;
}
.notify-success svg{color:var(--success);margin-bottom:10px}
.notify-success h4{
  font-family:var(--f-display);
  font-size:18px;
  font-weight:800;
  color:var(--text);
  margin:0 0 6px;
}
.notify-success p{
  font-size:13px;
  color:var(--text-3);
  margin:0;
}
.notify-success p b{color:var(--brand-lav);font-weight:800}

/* ── Preview-only state picker (remove in production) ── */
.urg-picker{
  display:flex;
  align-items:center;
  gap:6px;
  margin:14px 0 6px;
  padding:6px;
  background:rgba(255,255,255,.015);
  border:1px dashed var(--border);
  border-radius:12px;
}
.urg-picker-lbl{
  font-family:var(--f-mono);
  font-size:9px;
  color:var(--text-4);
  padding:0 8px 0 6px;
  letter-spacing:.08em;
  text-transform:uppercase;
  white-space:nowrap;
}
.urg-picker button{
  flex:1;
  background:transparent;
  border:1px solid var(--border);
  color:var(--text-3);
  padding:7px 8px;
  border-radius:8px;
  font-family:var(--f-ar);
  font-size:11px;
  font-weight:700;
  cursor:pointer;
  transition:all .2s ease;
}
.urg-picker button:hover{
  color:var(--text-2);
  border-color:var(--border-2);
  background:rgba(255,255,255,.02);
}
.urg-picker button[aria-pressed="true"]{
  background:rgba(99,17,185,.14);
  border-color:rgba(99,17,185,.42);
  color:var(--brand-lav);
}
/* bottom row — trust signals (HR separator via border-top) */
.urg-trust{
  display:flex;
  flex-direction:row;
  gap:0;
  align-items:center;
  flex-wrap:wrap;
  justify-content:flex-start;
  border-top:1px solid rgba(var(--urg-c),.15);
  padding-top:8px;
}
.urg-trust-item{
  display:flex;
  align-items:center;
  gap:6px;
  padding:4px 0;
  min-width:0;
  position:relative;
  flex:none;
}
.urg-trust-item + .urg-trust-item::before{
  content:"";
  display:inline-block;
  width:1px;
  height:14px;
  background:rgba(var(--urg-c),.4);
  margin:0 10px;
  vertical-align:middle;
  flex:none;
}
.urg-trust-ic{
  flex:none;width:14px;height:14px;
  color:var(--brand-lav);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  opacity:.85;
}
.urg-trust-ic svg{width:14px;height:14px}
.urg-trust-txt{
  display:flex;flex-direction:column;
  line-height:1.2;
  min-width:0;
  gap:2px;
}
.urg-trust-txt b{
  color:var(--text);
  font-size:11.5px;
  font-weight:700;
  font-family:var(--f-display);
  letter-spacing:-.005em;
  white-space:nowrap;
}
.urg-trust-txt small{
  display:none;
}
.us-dot{
  flex:none;
  width:8px;height:8px;
  border-radius:50%;
  background:var(--success);
  box-shadow:0 0 0 0 rgba(52,199,89,.6);
  animation:urgDot 1.6s ease-out infinite;
}
@keyframes urgDot{
  0%{box-shadow:0 0 0 0 rgba(52,199,89,.6)}
  70%{box-shadow:0 0 0 8px rgba(52,199,89,0)}
  100%{box-shadow:0 0 0 0 rgba(52,199,89,0)}
}



/* ── Tabbed Detail Bar — editorial hairline w/ index numbers ── */
.pdp-tabs-wrap{
  margin-top:0;
  display:flex;
  justify-content:center;
  align-items:center;
}
.pdp-tabs-bar{
  margin-top:16px;
  margin-bottom:0;
  display:flex;
  justify-content:flex-start;
  padding:0;
  position:relative;
}
.pdp-tabs-bar::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:0;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--border) 6%,var(--border) 94%,transparent);
}
.pdp-tabs-bar .pdp-tabs{
  counter-reset:tabidx;
  border-radius:0;
  border:0;
  background:transparent;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
  padding:0;
  gap:0;
  box-shadow:none;
  margin:0;
  overflow:visible;
}
.panel-lede{
  max-width:640px;
  margin:0 auto 32px;
  text-align:center;
  font-size:14px;
  color:var(--text-2);
  font-weight:400;
  line-height:1.7;
}
.pdp-tabs{
  display:inline-flex;
  gap:6px;
  padding:8px;
  border-radius:999px;
  border:1px solid var(--border);
  background:linear-gradient(155deg,rgba(28,24,44,.7) 0%,rgba(14,12,24,.7) 100%);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  overflow-x:auto;
  scrollbar-width:none;
  width:max-content;
  max-width:100%;
  box-shadow:
    0 20px 40px -20px rgba(0,0,0,.6),
    inset 0 1px 0 rgba(255,255,255,.04);
}
.pdp-tabs::-webkit-scrollbar{display:none}
.pdp-tab{
  padding:8px 14px;
  color:var(--text-3);
  font-family:var(--f-ar);
  font-weight:700;
  font-size:13.5px;
  white-space:nowrap;
  transition:color .3s ease,background .3s ease;
  position:relative;
  border-radius:999px;
}
.pdp-tab:hover{color:var(--text)}
.pdp-tab.is-active{
  color:#fff;
  background:linear-gradient(135deg,rgba(99,17,185,.28),rgba(196,181,253,.18));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.1);
}
.pdp-tab-count{
  font-style:normal;
  font-family:var(--f-mono);
  font-size:10px;
  font-weight:700;
  padding:2px 7px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  color:var(--text-3);
  margin-inline-start:8px;
  transition:all .3s;
}
.pdp-tab.is-active .pdp-tab-count{
  background:rgba(99,17,185,.2);
  color:var(--brand-lav);
}

/* Line Underscore (V2) — only inside .pdp-tabs-bar */
.pdp-tabs-bar .pdp-tabs{gap:40px}
.pdp-tabs-bar .pdp-tab{
  position:relative;
  padding:4px 2px 18px;
  background:transparent;
  border:0;
  border-radius:0;
  color:var(--text-3);
  font-family:var(--f-ar);
  font-weight:700;
  font-size:14px;
  display:inline-flex;
  align-items:center;
  box-shadow:none;
  transition:color .35s;
}
.pdp-tabs-bar .pdp-tab:hover{
  color:var(--text-2);
  background:transparent;
  box-shadow:none;
}
.pdp-tabs-bar .pdp-tab.is-active{
  color:var(--text);
  background:transparent;
  box-shadow:none;
}
.pdp-tabs-bar .pdp-tab.is-active::after{display:none}
.pdp-tab-count{display:none}

/* Tab panels — hide inactive with animation */
.pdp-panel{
  display:block;
  max-height:0;
  opacity:0;
  overflow:hidden;
  padding:0;
  position:relative;
  transition:max-height .35s cubic-bezier(.2,.8,.2,1),opacity .25s ease,padding .25s ease;
  pointer-events:none;
}
.pdp-panel.is-active{
  max-height:8000px;
  opacity:1;
  padding:0 0 16px;
  pointer-events:auto;
}
@keyframes panelFade{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}

/* ── Bento Highlights ── */
.highlights{padding:20px 0 24px}
.highlights-legacy{display:none !important}

/* ══════════════════════════════════════════════════
   UNIFIED GLASS SHELL — Applied to ALL tab panels
   (Overview, Specs, Shipping & Warranty, Reviews)
   Note: per-panel glow removed — body ambient + shell radial do the work
   ══════════════════════════════════════════════════ */

.glass-shell{
  max-width:1040px;
  margin:0 auto;
  padding:40px 44px 48px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.008));
  border:1px solid var(--border);
  border-radius:22px;
  backdrop-filter:blur(18px) saturate(120%);
  -webkit-backdrop-filter:blur(18px) saturate(120%);
  box-shadow:
    0 40px 100px -50px rgba(99,17,185,.35),
    inset 0 1px 0 rgba(255,255,255,.06);
  position:relative;
}
.gs-head{
  text-align:center;
  margin:0 0 32px;
  padding-bottom:28px;
  border-bottom:1px solid var(--border);
  position:relative;
}
.gs-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--f-mono);
  font-size:10.5px;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--brand-lav);
  padding:6px 14px;
  border-radius:999px;
  border:1px solid rgba(99,17,185,.32);
  background:rgba(99,17,185,.08);
  margin-bottom:14px;
}
.gs-eyebrow::before{
  content:"";
  width:6px;height:6px;
  border-radius:50%;
  background:var(--brand-lav);
  box-shadow:0 0 10px var(--brand-lav);
}
.gs-title{
  font-family:var(--f-display);
  font-size:24px;
  font-weight:800;
  color:var(--text);
  margin:0 0 10px;
  letter-spacing:-.01em;
}
.gs-lede{
  max-width:540px;
  margin:0 auto;
  font-size:13.5px;
  color:var(--text-2);
  line-height:1.7;
}
.gs-body{position:relative}

@media (max-width:900px){
  .glass-shell{padding:28px 20px 32px;border-radius:18px}
  .gs-title{font-size:20px}
}

/* ── Overview — legacy .ov-grid now purely a content wrapper; visuals come from .glass-shell ── */
.ov-grid{display:contents}

/* ── Compact Overview — collapsible "about product" (not a book) ── */
.ov-compact{
  max-width:1040px;
  margin:0 auto;
  padding:32px 0 28px;
  position:relative;
}
.ov-compact-head{
  display:flex;
  align-items:center;
  gap:18px;
  margin-bottom:22px;
}
.ov-compact-title{
  font-family:var(--f-display);
  font-size:16px;
  font-weight:800;
  color:var(--text);
  letter-spacing:-.01em;
  margin:0;
  white-space:nowrap;
}
.ov-compact-line{
  flex:1;
  height:1px;
  background:linear-gradient(90deg,var(--border),transparent);
}
.ov-compact-body{
  position:relative;
  overflow:hidden;
  max-height:92px;
  transition:max-height .45s cubic-bezier(.2,.8,.2,1);
}
.ov-compact-body::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:0;
  height:60px;
  background:linear-gradient(180deg,transparent,var(--bg) 90%);
  pointer-events:none;
  transition:opacity .35s;
}
.ov-compact.is-expanded .ov-compact-body{max-height:1200px}
.ov-compact.is-expanded .ov-compact-body::after{opacity:0}
.ov-compact-desc{
  font-size:14px;
  line-height:1.85;
  color:var(--text-2);
  margin:0 0 22px;
  max-width:780px;
}
.ov-chips{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-wrap:wrap;
  gap:8px 10px;
}
.ov-chips li{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  color:var(--text-2);
  font-family:var(--f-display);
  letter-spacing:-.005em;
  transition:border-color .3s, color .3s, background .3s;
}
.ov-chips li:hover{
  border-color:rgba(99,17,185,.4);
  color:var(--text);
  background:rgba(99,17,185,.06);
}
.ov-chips svg{
  width:14px;height:14px;
  color:var(--brand-lav);
  flex:none;
}
.ov-toggle{
  margin-top:18px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:9px 18px 9px 16px;
  background:transparent;
  border:1px solid var(--border);
  border-radius:999px;
  font-family:var(--f-display);
  font-size:11.5px;
  font-weight:700;
  color:var(--text-2);
  cursor:pointer;
  transition:border-color .3s, color .3s, background .3s;
}
.ov-toggle:hover{
  border-color:var(--brand);
  color:var(--text);
  background:rgba(99,17,185,.08);
}
.ov-toggle svg{
  width:14px;height:14px;
  transition:transform .35s cubic-bezier(.2,.8,.2,1);
}
.ov-compact.is-expanded .ov-toggle svg{transform:rotate(180deg)}
.ov-toggle-less{display:none}
.ov-compact.is-expanded .ov-toggle-more{display:none}
.ov-compact.is-expanded .ov-toggle-less{display:inline}

/* Main column */
.ov-main{min-width:0}
.ov-headline{
  font-family:var(--f-display);
  font-size:14px;
  font-weight:700;
  color:var(--text-3);
  letter-spacing:.04em;
  text-transform:uppercase;
  margin:0 0 20px;
  padding-bottom:14px;
  border-bottom:1px solid var(--border);
}
.ov-description p{
  font-size:15px;
  line-height:1.85;
  color:var(--text-2);
  margin:0 0 16px;
}
.ov-description p:last-child{margin-bottom:0}

.ov-highlights{
  list-style:none;
  margin:36px 0 0;
  padding:0;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px 28px;
}
.ov-highlights li{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:14px 16px;
  border-radius:12px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.015);
  font-size:13px;
  color:var(--text);
  line-height:1.5;
  transition:border-color .3s,background .3s;
}
.ov-highlights li:hover{
  border-color:rgba(99,17,185,.35);
  background:rgba(99,17,185,.04);
}
.ov-highlights svg{
  flex:none;
  width:22px;height:22px;
  padding:4px;
  border-radius:50%;
  background:linear-gradient(135deg,rgba(16,185,129,.2),rgba(16,185,129,.05));
  color:var(--success);
  border:1px solid rgba(16,185,129,.3);
  margin-top:1px;
}

/* ══════════════════════════════════════════════════
   FREQUENTLY BOUGHT TOGETHER · Compact Row Layout
   Position: Right after hero — Amazon golden spot
   Palette: Brand purple + success green (savings only)
   ══════════════════════════════════════════════════ */
.fbt{padding:24px 0 24px;position:relative}
.fbt-d4-header{display:none}
.fbt > *{position:relative;z-index:1}

/* Left column wrapper: title block + summary card */
.fbt-aside-col{display:flex;flex-direction:column;gap:20px;position:sticky;top:24px;align-self:center}

/* Title block — narrow column variant (no eyebrow) */
.fbt-head{
  display:flex;flex-direction:column;align-items:flex-start;text-align:start;
  gap:10px;padding:4px 6px 2px;
}
.fbt-eyebrow{display:none}
.fbt-title{
  font-family:var(--f-display);font-size:26px;font-weight:800;color:#fff;
  margin:0;letter-spacing:-.022em;line-height:1.22;
}
.fbt-title em{
  font-style:normal;
  background:linear-gradient(135deg,var(--brand-lav),var(--brand));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.fbt-sub{font-size:12.5px;color:var(--text-3);margin:0;line-height:1.7;max-width:340px}
.fbt-save-badge{display:none}

/* Body: item list + summary aside */
.fbt-body{
  display:grid;grid-template-columns:1fr 360px;gap:32px;align-items:stretch;
}

/* Stack of item rows */
.fbt-stack{display:flex;flex-direction:column;gap:10px}

.fbt-item{
  position:relative;display:flex;align-items:center;gap:14px;
  padding:12px 16px;min-height:72px;
  background:linear-gradient(135deg,rgba(99,17,185,.08),rgba(99,17,185,.02));
  border:1px solid rgba(196,181,253,.18);border-radius:14px;
  cursor:pointer;transition:border-color .3s,background .3s,transform .3s,box-shadow .3s;
}
.fbt-item:hover{
  background:linear-gradient(135deg,rgba(99,17,185,.16),rgba(99,17,185,.05));
  border-color:rgba(196,181,253,.4);
  transform:translateX(2px);
}
[dir="rtl"] .fbt-item:hover{transform:translateX(-2px)}
.fbt-item.is-main{
  background:linear-gradient(135deg,rgba(99,17,185,.26),rgba(99,17,185,.07));
  border-color:rgba(196,181,253,.65);
  box-shadow:
    0 0 0 1px rgba(196,181,253,.22) inset,
    0 0 0 4px rgba(99,17,185,.08),
    0 14px 34px -14px rgba(99,17,185,.55);
  cursor:default;
}
.fbt-item.is-main:hover{transform:none}
.fbt-item.is-unchecked{opacity:.45;filter:grayscale(.7)}

/* Checkbox — inline at start of row */
.fbt-check{
  position:relative;width:22px;height:22px;
  appearance:none;-webkit-appearance:none;
  border-radius:7px;border:1.5px solid var(--border-2);
  background:rgba(0,0,0,.4);cursor:pointer;flex-shrink:0;
  transition:background .25s,border-color .25s,box-shadow .25s;
}
.fbt-check:checked{
  background:linear-gradient(135deg,var(--brand),#9333EA);
  border-color:var(--brand);
  box-shadow:0 0 0 4px rgba(99,17,185,.14);
}
.fbt-check:checked::after{
  content:"";position:absolute;
  inset:0;margin:auto;
  width:5px;height:10px;
  border:solid #fff;border-width:0 2px 2px 0;
  transform:rotate(45deg) translate(-1px,-1px);
}
.fbt-check:disabled{cursor:default;opacity:1}

.fbt-media{
  position:static;width:56px;height:56px;border-radius:12px;flex-shrink:0;
  background:
    radial-gradient(ellipse at 30% 25%,rgba(99,17,185,.22),transparent 70%),
    rgba(0,0,0,.4);
  border:1px solid var(--border);
  display:grid;place-items:center;color:var(--brand-lav);margin:0;
}
.fbt-media svg{width:26px;height:26px;opacity:.95}
.fbt-info{
  flex:1;min-width:0;text-align:start;
  display:flex;flex-direction:column;gap:4px;
}
.fbt-name .fbt-swatch{
  display:inline-block;width:10px;height:10px;border-radius:50%;
  vertical-align:middle;margin-inline:0 3px;translate:0 -1px;
  border:1px solid rgba(255,255,255,.22);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.25);
}
.fbt-name{
  font-family:var(--f-ar);font-size:13.5px;font-weight:700;color:var(--text);
  letter-spacing:-.005em;line-height:1.4;
  align-self:flex-start;max-width:fit-content;
}
.fbt-variant{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--f-ar);font-size:11.5px;font-weight:600;
  color:var(--text-3);line-height:1;
}
.fbt-var-swatch{
  width:10px;height:10px;border-radius:50%;
  border:1px solid rgba(255,255,255,.22);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.25);
}
.fbt-var-sep{color:var(--text-4);opacity:.6}
.fbt-pricetag{
  font-family:var(--f-display);font-size:14px;font-weight:800;
  color:var(--brand-lav);letter-spacing:-.01em;
  display:inline-flex;align-items:center;gap:4px;
}
.fbt-pricetag em{
  font-style:normal;color:var(--text-3);
  display:inline-flex;align-items:center;line-height:1;
}
.fbt-pricetag .sar{width:.72em;height:.82em;translate:0 -2%}
.fbt-pin{
  position:static;transform:none;
  font-family:var(--f-ar);font-size:11.5px;font-weight:800;
  letter-spacing:0;color:#E6DCFF;
  background:rgba(99,17,185,.32);padding:5px 12px;
  border-radius:999px;border:1px solid rgba(196,181,253,.55);
  flex-shrink:0;white-space:nowrap;
  box-shadow:0 0 0 1px rgba(99,17,185,.18) inset;
}
.fbt-op{display:none}

/* Summary aside — Savings Hero variant (modular scale 1.2x: 10·11·13·14·19·23·32·58) */
.fbt-summary{
  position:relative;display:flex;flex-direction:column;
  padding:26px 26px 22px;border-radius:20px;
  border:1px solid rgba(196,181,253,.15);
  background:
    radial-gradient(460px 260px at 50% -10%,rgba(99,17,185,.11),transparent 72%),
    linear-gradient(180deg,#16161E,#0F0F15);
  box-shadow:0 30px 60px -28px rgba(0,0,0,.6),0 0 0 1px rgba(196,181,253,.04),inset 0 1px 0 rgba(255,255,255,.05);
  overflow:hidden;
}
/* Top kicker — pulsing urgency cue */
.fs-kicker{
  position:relative;display:inline-flex;align-items:center;gap:8px;
  padding:6px 13px;border-radius:999px;
  background:rgba(255,59,48,.14);border:1px solid rgba(255,59,48,.4);
  font-family:var(--f-ar);font-size:11px;font-weight:800;color:#FF6B63;
  margin-bottom:20px;letter-spacing:.01em;align-self:flex-start;
}
.fs-kicker-pulse{
  width:6px;height:6px;border-radius:50%;background:#FF3B30;
  box-shadow:0 0 0 0 rgba(255,59,48,.6);animation:fsPulse 1.8s infinite;
}
@keyframes fsPulse{
  0%{box-shadow:0 0 0 0 rgba(255,59,48,.6)}
  70%{box-shadow:0 0 0 6px rgba(255,59,48,0)}
  100%{box-shadow:0 0 0 0 rgba(255,59,48,0)}
}
/* Hero savings number — force LTR math flow so minus stays LEFT of digits in RTL pages */
.fs-hero{
  position:relative;display:flex;align-items:baseline;gap:2px;
  margin-bottom:8px;
  direction:ltr;unicode-bidi:isolate;
}
.fs-hero-sign{
  font-family:var(--f-display);font-size:32px;font-weight:800;
  color:var(--success);line-height:1;letter-spacing:-.04em;opacity:.75;
  margin-inline-end:4px;
}
.fs-hero-num{
  font-family:var(--f-display);font-size:58px;font-weight:800;
  background:linear-gradient(180deg,#5BE077,#34C759 70%,#1F9E40);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  line-height:.9;letter-spacing:-.045em;
  unicode-bidi:isolate;
}
.fs-hero-unit{
  font-family:var(--f-ar);font-size:19px;font-weight:800;color:var(--success);
  padding-inline-start:8px;line-height:1;
  direction:rtl;unicode-bidi:isolate;
}
.fs-hero-label{
  position:relative;font-family:var(--f-ar);font-size:14px;font-weight:700;color:#fff;
  margin:0 0 20px;line-height:1.5;opacity:.95;
}
.fs-hero-label em{
  font-style:normal;color:var(--brand-lav);font-weight:800;
}
/* Two-column split — before / total */
.fs-split{
  position:relative;display:flex;justify-content:space-between;align-items:center;
  padding:16px 0;margin-bottom:22px;
  border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08);
}
.fs-split-col{display:flex;flex-direction:column;gap:4px}
.fs-split-col-end{text-align:end;align-items:flex-end}
.fs-split-k{
  font-family:var(--f-ar);font-size:11.5px;color:var(--text-2);
  letter-spacing:.02em;font-weight:700;
}
.fs-split-v{
  font-family:var(--f-display);font-size:15px;font-weight:700;color:var(--text-2);
  letter-spacing:-.01em;font-variant-numeric:tabular-nums;
  display:inline-flex;align-items:center;gap:5px;
}
.fs-split-v .sar{width:.95em;height:1.08em;translate:0 -2%}
.fs-strike{text-decoration:line-through;color:var(--text-4);font-weight:600}
.fs-strike .sar{color:var(--text-4)}
.fs-split-v-total{
  display:inline-flex;align-items:baseline;gap:4px;
  font-family:var(--f-display);font-variant-numeric:tabular-nums;
}
.fs-split-v-total b{
  font-size:25px;font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1;
}
.fs-split-v-total em{
  font-style:normal;font-size:15px;color:var(--text-2);
  display:inline-flex;align-items:center;line-height:1;
}
.fs-split-v-total em .sar{width:.95em;height:1.08em;translate:0 -2%}
.fs-split-sep{width:1px;height:42px;background:rgba(255,255,255,.08)}
/* Hidden compat holders for JS */
.fs-hidden-compat{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);pointer-events:none}
/* CTA row — savings + price button in one line */
.fs-cta-row{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:rgba(34,197,94,.06);border:1px solid rgba(34,197,94,.14);
  border-radius:14px;padding:12px 16px;
}
.fs-cta-save{display:flex;flex-direction:column;gap:2px}
.fs-cta-save-lbl{font-size:10.5px;color:rgba(74,222,128,.6);font-weight:600;font-family:var(--f-ar)}
.fs-cta-save-amt{font-size:16px;font-weight:900;color:#4ADE80;font-family:var(--f-ar)}
.fs-cta-save-amt b{font-weight:900}
.fs-cta-sar{font-size:11px;font-weight:600;opacity:.8}
.btn-fbt-add{
  position:relative;width:auto;flex:none;padding:13px 22px;
  background:linear-gradient(105deg,#8B3FD4,#6311B9);
  color:#fff;border-radius:12px;border:0;cursor:pointer;
  font-family:var(--f-ar);font-weight:900;font-size:17px;letter-spacing:-.01em;
  display:flex;align-items:center;justify-content:center;gap:6px;
  box-shadow:0 6px 24px rgba(99,17,185,.5),inset 0 1px 0 rgba(255,255,255,.14);
  transition:transform .2s,box-shadow .2s;overflow:hidden;
}
.btn-fbt-add::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 40%,rgba(255,255,255,.2) 50%,transparent 60%);
  transform:translateX(-100%);transition:transform .7s;
}
.btn-fbt-add:hover{transform:translateY(-1px);box-shadow:0 8px 28px rgba(99,17,185,.6)}
.btn-fbt-add:hover::before{transform:translateX(100%)}
.btn-fbt-add span{position:relative;z-index:1}
.btn-fbt-add.is-added{background:linear-gradient(135deg,#16a34a,#15803d)!important;box-shadow:0 8px 24px -8px rgba(22,163,74,.5)!important;animation:none!important}
.btn-fbt-add.is-added::before{display:none!important}
/* Micro footnote */
.fs-footnote{
  position:relative;display:flex;align-items:center;gap:8px;margin-top:14px;
  font-family:var(--f-ar);font-size:12px;font-weight:600;color:var(--text-3);
  justify-content:center;letter-spacing:.01em;
}
.fs-footnote svg{
  width:13px;height:13px;color:var(--brand-lav);flex-shrink:0;
}

.bento{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  grid-auto-rows:180px;
  gap:14px;
}
.bento-card{
  position:relative;
  overflow:hidden;
  border-radius:20px;
  border:1px solid var(--border);
  background:var(--surface);
  padding:28px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  transition:border-color .4s cubic-bezier(.2,.8,.2,1),transform .4s cubic-bezier(.2,.8,.2,1);
}
.bento-card::before{
  content:"";
  position:absolute;
  inset:0;
  opacity:.65;
  transition:opacity .5s;
  pointer-events:none;
}
.bento-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.4));
  pointer-events:none;
}
.bento-card:hover{transform:translateY(-3px)}
.bento-card:hover::before{opacity:1}
.bento-card > *{position:relative;z-index:2}

/* Card A — A18 Pro chip (hero, 4 col × 2 row) */
.bento-a{grid-column:span 4;grid-row:span 2}
.bento-a::before{
  background:
    radial-gradient(ellipse 80% 60% at 20% 30%,rgba(99,17,185,.35),transparent 55%),
    radial-gradient(ellipse 70% 50% at 80% 80%,rgba(196,181,253,.18),transparent 60%);
}
.bento-a:hover{border-color:rgba(99,17,185,.45)}
.bento-a .bc-label{color:#b08bff}
.bento-a .bc-stat{
  font-family:var(--f-display);
  font-size:88px;
  font-weight:800;
  line-height:.9;
  letter-spacing:-.04em;
  background:linear-gradient(180deg,#ffffff,#9b8bff);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  margin-top:auto;
}
.bento-a .bc-unit{
  font-family:var(--f-display);
  font-size:22px;
  font-weight:700;
  color:rgba(255,255,255,.6);
  margin-inline-start:8px;
  letter-spacing:-.01em;
}
.bento-a .bc-chip-gfx{
  position:absolute;
  top:28px;
  inset-inline-end:28px;
  width:120px;
  height:120px;
  opacity:.55;
}
.bento-a .bc-title{
  font-family:var(--f-display);
  font-size:22px;
  font-weight:800;
  margin-bottom:6px;
}
.bento-a .bc-specs-row{
  display:flex;
  gap:22px;
  margin:18px 0 14px;
  padding:14px 0;
  border-top:1px dashed rgba(176,139,255,.2);
  border-bottom:1px dashed rgba(176,139,255,.2);
}
.bento-a .bc-specs-row span{
  display:flex;
  flex-direction:column;
  gap:4px;
  font-family:var(--f-display);
  font-size:16px;
  font-weight:800;
  color:#fff;
  line-height:1;
}
.bento-a .bc-specs-row em{
  font-style:normal;
  font-family:var(--f-mono);
  font-size:9.5px;
  font-weight:700;
  letter-spacing:.08em;
  color:#b08bff;
  opacity:.8;
}
.bento-a .bc-desc{
  font-size:13px;
  color:var(--text-2);
  max-width:420px;
  line-height:1.55;
}

/* Card B — Camera (2 col × 2 row) */
.bento-b{grid-column:span 2;grid-row:span 2}
.bento-b::before{
  background:
    radial-gradient(ellipse 90% 70% at 50% 20%,rgba(196,181,253,.22),transparent 60%),
    radial-gradient(ellipse 80% 80% at 50% 100%,rgba(15,23,42,.6),transparent 50%);
}
.bento-b:hover{border-color:rgba(196,181,253,.4)}
.bento-b .bc-stat{
  font-family:var(--f-display);
  font-size:64px;
  font-weight:800;
  line-height:.9;
  letter-spacing:-.03em;
  color:#fff;
}
.bento-b .bc-stat sup{
  font-size:22px;
  font-weight:700;
  color:var(--brand-lav);
  margin-inline-start:2px;
  vertical-align:super;
}
.bento-b .bc-label{color:var(--brand-lav)}
.bento-b .bc-title{
  font-family:var(--f-display);
  font-size:18px;
  font-weight:800;
  margin-bottom:6px;
}
.bento-b .bc-desc{font-size:12px;color:var(--text-2);line-height:1.55}
.bento-b .bc-lens{
  position:absolute;
  top:26px;inset-inline-end:26px;
  display:flex;gap:4px;
}
.bento-b .bc-lens span{
  width:14px;height:14px;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#0a0a14,#000);
  border:1px solid rgba(255,255,255,.15);
  box-shadow:inset 0 0 4px rgba(196,181,253,.3);
}

/* Card C — Battery (3 col × 1 row) */
.bento-c{grid-column:span 3;grid-row:span 1}
.bento-c::before{
  background:radial-gradient(ellipse 80% 100% at 20% 50%,rgba(255,159,10,.18),transparent 60%);
}
.bento-c:hover{border-color:rgba(255,159,10,.4)}
.bento-c{flex-direction:row;align-items:center;gap:24px;padding:24px 28px}
.bento-c .bc-stat{
  font-family:var(--f-display);
  font-size:56px;
  font-weight:800;
  line-height:1;
  letter-spacing:-.03em;
  color:#fff;
  flex:none;
}
.bento-c .bc-stat .bc-unit{
  font-size:16px;
  font-weight:700;
  color:var(--warning);
  margin-inline-start:4px;
}
.bento-c .bc-content{flex:1;min-width:0}
.bento-c .bc-label{color:var(--warning)}
.bento-c .bc-title{
  font-family:var(--f-display);
  font-size:16px;
  font-weight:800;
  margin:6px 0 4px;
}
.bento-c .bc-desc{font-size:12px;color:var(--text-2);line-height:1.5}

/* Card D — Titanium (3 col × 1 row) */
.bento-d{grid-column:span 3;grid-row:span 1}
.bento-d::before{
  background:
    linear-gradient(115deg,rgba(255,255,255,.05) 0%,transparent 30%,rgba(255,255,255,.03) 60%,transparent 100%),
    radial-gradient(ellipse 80% 100% at 80% 50%,rgba(200,200,220,.1),transparent 60%);
}
.bento-d:hover{border-color:rgba(200,200,220,.25)}
.bento-d{flex-direction:row;align-items:center;gap:24px;padding:24px 28px}
.bento-d .bc-stat{
  font-family:var(--f-display);
  font-size:56px;
  font-weight:800;
  line-height:1;
  letter-spacing:-.03em;
  background:linear-gradient(180deg,#f5f5fa,#9ca3af);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  flex:none;
}
.bento-d .bc-stat .bc-unit{
  font-size:16px;
  font-weight:700;
  color:rgba(255,255,255,.5);
  margin-inline-start:4px;
  -webkit-text-fill-color:rgba(255,255,255,.5);
}
.bento-d .bc-content{flex:1;min-width:0}
.bento-d .bc-label{color:rgba(255,255,255,.55)}
.bento-d .bc-title{
  font-family:var(--f-display);
  font-size:16px;
  font-weight:800;
  margin:6px 0 4px;
}
.bento-d .bc-desc{font-size:12px;color:var(--text-2);line-height:1.5}

/* Shared label */
.bc-label{
  font-family:var(--f-mono);
  font-size:10px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.bc-label::before{
  content:"";
  width:18px;
  height:1px;
  background:currentColor;
  opacity:.6;
}

/* ── Specs ── */
.specs-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:4px 80px;
}
.spec-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 0;
  border-bottom:1px solid var(--border);
}
.spec-row .label{color:var(--text-2);font-size:13px;font-weight:500}
.spec-row .value{color:#fff;font-weight:700;font-size:14px;font-family:var(--f-display)}

/* ── Trust (Shipping & Warranty) ── */
.trust-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}
.trust-card{
  position:relative;
  overflow:hidden;
  border-radius:20px;
  border:1px solid var(--border);
  background:var(--surface);
  padding:32px 32px 28px;
  display:flex;
  flex-direction:column;
  gap:14px;
  transition:border-color .4s cubic-bezier(.2,.8,.2,1),transform .4s cubic-bezier(.2,.8,.2,1);
}
.trust-card::before{
  content:"";
  position:absolute;inset:0;
  background:radial-gradient(circle at 85% 15%,rgba(99,17,185,.12),transparent 55%);
  opacity:0;
  transition:opacity .5s;
  pointer-events:none;
}
.trust-card:hover{border-color:rgba(99,17,185,.4);transform:translateY(-3px)}
.trust-card:hover::before{opacity:1}
.trust-ship::before{background:radial-gradient(circle at 85% 15%,rgba(196,181,253,.14),transparent 55%)}
.trust-ship:hover{border-color:rgba(196,181,253,.45)}
.trust-warranty::before{background:radial-gradient(circle at 85% 15%,rgba(16,185,129,.14),transparent 55%)}
.trust-warranty:hover{border-color:rgba(16,185,129,.45)}
.trust-return::before{background:radial-gradient(circle at 85% 15%,rgba(251,146,60,.14),transparent 55%)}
.trust-return:hover{border-color:rgba(251,146,60,.45)}
.trust-pay::before{background:radial-gradient(circle at 85% 15%,rgba(176,139,255,.14),transparent 55%)}
.trust-pay:hover{border-color:rgba(176,139,255,.45)}

.tc-head{
  position:relative;z-index:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
.tc-icon{
  width:38px;height:38px;
  padding:9px;
  border-radius:12px;
  color:var(--text);
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
}
.trust-ship .tc-icon{color:var(--brand-lav);background:rgba(196,181,253,.08);border-color:rgba(196,181,253,.22)}
.trust-warranty .tc-icon{color:#6ee7b7;background:rgba(16,185,129,.08);border-color:rgba(16,185,129,.22)}
.trust-return .tc-icon{color:#fdba74;background:rgba(251,146,60,.08);border-color:rgba(251,146,60,.22)}
.trust-pay .tc-icon{color:#c4b5fd;background:rgba(176,139,255,.08);border-color:rgba(176,139,255,.22)}

.tc-tag{
  font-family:var(--f-mono);
  font-size:10px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:5px 11px;
  border-radius:999px;
  background:rgba(255,255,255,.04);
  color:var(--text-2);
  border:1px solid var(--border);
}
.tc-title{
  position:relative;z-index:1;
  font-family:var(--f-display);
  font-size:20px;
  font-weight:700;
  color:#fff;
  margin:4px 0 0;
  letter-spacing:-.01em;
}
.tc-desc{
  position:relative;z-index:1;
  font-size:13px;
  line-height:1.75;
  color:var(--text-2);
  margin:0;
  flex:1;
}
.tc-meta{
  position:relative;z-index:1;
  display:flex;
  gap:10px;
  margin-top:4px;
  padding-top:18px;
  border-top:1px dashed rgba(255,255,255,.08);
}
.tc-meta span{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:3px;
  font-size:13px;
  font-weight:700;
  color:#fff;
  font-family:var(--f-display);
}
.tc-meta em{
  font-style:normal;
  font-family:var(--f-mono);
  font-size:9.5px;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--text-3);
}

/* ═══════════════════════════════════════════════════════════
   REVIEWS — verified, filterable, photo-first
   ═══════════════════════════════════════════════════════════ */
.reviews-summary{
  display:grid;
  grid-template-columns:minmax(260px,1fr) 1.6fr;
  gap:44px;
  align-items:stretch;
  margin-bottom:36px;
  padding-bottom:36px;
  border-bottom:1px solid var(--border);
}
.rev-score{
  text-align:center;
  padding:32px 28px;
  background:
    radial-gradient(ellipse at 50% 0%,rgba(245,158,11,.10),transparent 70%),
    linear-gradient(180deg,rgba(99,17,185,.05),rgba(255,255,255,.01));
  border:1px solid var(--border);
  border-radius:16px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px;
}
.rev-score-num{
  font-family:var(--f-display);
  font-size:72px;
  font-weight:800;
  line-height:.95;
  background:linear-gradient(135deg,#fff 0%,#C8B8E8 55%,#9B9BAD 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  letter-spacing:-.02em;
}
.rev-score-stars{
  display:flex;
  justify-content:center;
  gap:3px;
  color:var(--amber);
  filter:drop-shadow(0 2px 8px rgba(245,158,11,.35));
}
.rev-score-stars svg{width:18px;height:18px}
.rev-score-count{
  font-size:12.5px;
  color:var(--text-2);
  margin-top:4px;
}
.rev-score-count strong{color:var(--text);font-weight:800}
.rev-score-hint{
  display:inline-flex;
  align-items:center;
  gap:5px;
  font-size:10.5px;
  font-family:var(--f-mono);
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--success);
  padding:5px 10px;
  border-radius:999px;
  background:rgba(34,197,94,.08);
  border:1px solid rgba(34,197,94,.22);
  margin-top:6px;
}

.rev-bars{
  display:flex;
  flex-direction:column;
  gap:8px;
  justify-content:center;
}
.rev-bar{
  display:grid;
  grid-template-columns:62px 1fr 58px;
  gap:14px;
  align-items:center;
  font-size:12.5px;
  padding:9px 14px;
  border:1px solid transparent;
  border-radius:10px;
  background:transparent;
  color:var(--text-2);
  cursor:pointer;
  font-family:inherit;
  text-align:inherit;
  transition:background .22s,border-color .22s,transform .22s;
}
.rev-bar:hover{
  background:rgba(99,17,185,.05);
  border-color:rgba(99,17,185,.18);
}
.rev-bar.is-active{
  background:linear-gradient(180deg,rgba(99,17,185,.12),rgba(99,17,185,.04));
  border-color:rgba(99,17,185,.35);
  box-shadow:0 0 0 1px rgba(99,17,185,.1) inset;
}
.rev-bar .rb-stars{
  display:inline-flex;
  align-items:center;
  gap:4px;
  font-family:var(--f-mono);
  font-weight:800;
  color:var(--text);
  font-size:12px;
}
.rev-bar .rb-stars svg{color:var(--amber)}
.rev-bar .rb-track{
  height:6px;
  background:rgba(255,255,255,.05);
  border-radius:100px;
  overflow:hidden;
  position:relative;
}
.rev-bar .rb-fill{
  height:100%;
  background:linear-gradient(90deg,#FBBF24 0%,var(--amber) 55%,#F97316 100%);
  border-radius:100px;
  box-shadow:0 0 12px rgba(245,158,11,.35);
  transition:width .45s cubic-bezier(.2,.8,.2,1);
}
.rev-bar[data-rating="all"] .rb-fill{
  background:linear-gradient(90deg,var(--brand-lav),var(--brand));
  box-shadow:0 0 12px rgba(99,17,185,.4);
}
.rev-bar .rb-count{
  color:var(--text-3);
  font-family:var(--f-mono);
  font-size:11px;
  font-weight:700;
  text-align:start;
}
.rev-bar.is-active .rb-count{color:var(--text-2)}

/* ── Sort bar (slim) ── */
.rev-toolbar{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  margin-bottom:20px;
  padding-bottom:16px;
  border-bottom:1px dashed var(--border);
}
.rev-sort{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:12px;
  color:var(--text-3);
}
.rev-sort label{
  font-family:var(--f-mono);
  font-size:10.5px;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.rev-sort select{
  padding:8px 14px;
  background:var(--bg-2);
  border:1px solid var(--border);
  border-radius:10px;
  color:var(--text);
  font-family:inherit;
  font-size:12px;
  font-weight:700;
  cursor:pointer;
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%239B9BAD' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:left 14px center;
  padding-inline-start:36px;
}
.rev-sort select:hover{border-color:rgba(99,17,185,.4)}

/* ── Review Cards ── */
.review-cards{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}
.rev-card{
  padding:24px 26px 20px;
  background:rgba(255,255,255,.02);
  border:1px solid var(--border);
  border-radius:14px;
  transition:border-color .25s,transform .25s;
}
.rev-card:hover{
  border-color:rgba(99,17,185,.28);
  transform:translateY(-2px);
}
.rev-card-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  margin-bottom:12px;
}
.rev-author{display:flex;align-items:center;gap:12px}
.rev-avatar{
  width:42px;
  height:42px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--brand),var(--brand-lav));
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  font-size:15px;
  color:#fff;
  box-shadow:0 4px 14px -6px rgba(99,17,185,.6);
}
.rev-name{font-weight:800;font-size:13.5px;color:var(--text);margin-bottom:3px}
.rev-verified{
  display:inline-flex;
  align-items:center;
  gap:4px;
  font-size:10.5px;
  font-family:var(--f-mono);
  font-weight:700;
  letter-spacing:.03em;
  color:var(--success);
}
.rev-stars{color:var(--amber);display:flex;gap:2px;flex-shrink:0}
.rev-title{font-weight:800;margin:8px 0 6px;font-size:14.5px;color:var(--text)}
.rev-body{color:var(--text-2);font-size:13px;line-height:1.75}
.rev-meta{
  display:flex;
  align-items:center;
  gap:8px;
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid var(--border);
  font-size:10.5px;
  color:var(--text-3);
  font-family:var(--f-mono);
  letter-spacing:.03em;
}
.rev-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-top:12px;
}
.rev-helpful{
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:7px 14px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius:999px;
  color:var(--text-2);
  font-size:11.5px;
  font-weight:700;
  cursor:pointer;
  font-family:inherit;
  transition:all .2s;
}
.rev-helpful em{
  font-style:normal;
  font-family:var(--f-mono);
  color:var(--text-3);
  font-size:10.5px;
}
.rev-helpful:hover{
  color:#fff;
  background:rgba(99,17,185,.12);
  border-color:rgba(99,17,185,.4);
}
.rev-helpful.is-voted{
  color:var(--brand-lav);
  background:rgba(99,17,185,.14);
  border-color:rgba(99,17,185,.45);
}
.rev-report{
  background:none;
  border:none;
  padding:4px 8px;
  font-family:var(--f-mono);
  font-size:10px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--text-3);
  cursor:pointer;
  transition:color .2s;
}
.rev-report:hover{color:var(--danger,#EF4444)}

/* ── Load More ── */
.rev-loadmore-wrap{
  display:flex;
  justify-content:center;
  margin:28px 0 34px;
}
.rev-loadmore{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 28px;
  background:rgba(99,17,185,.08);
  border:1px solid rgba(99,17,185,.3);
  border-radius:999px;
  color:var(--text);
  font-size:13px;
  font-weight:800;
  cursor:pointer;
  font-family:inherit;
  transition:all .25s;
}
.rev-loadmore em{
  font-family:var(--f-mono);
  font-size:11px;
  font-weight:700;
  color:var(--text-3);
  font-style:normal;
}
.rev-loadmore:hover{
  background:rgba(99,17,185,.16);
  border-color:var(--brand-lav);
  transform:translateY(-2px);
  box-shadow:0 14px 32px -14px rgba(99,17,185,.6);
}
.rev-loadmore svg{transition:transform .4s}
.rev-loadmore:hover svg{transform:rotate(-120deg)}

/* ── Write Review Gate ── */
.rev-write{
  display:grid;
  grid-template-columns:64px 1fr;
  gap:22px;
  align-items:center;
  padding:28px 30px;
  background:
    radial-gradient(ellipse at 0% 50%,rgba(99,17,185,.1),transparent 60%),
    linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.005));
  border:1px solid var(--border);
  border-radius:16px;
  margin-top:4px;
}
.rev-write-icon{
  width:64px;
  height:64px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,rgba(99,17,185,.2),rgba(167,139,250,.1));
  border:1px solid rgba(99,17,185,.35);
  border-radius:16px;
  color:var(--brand-lav);
  flex-shrink:0;
}
.rev-write-icon svg{width:28px;height:28px}
.rev-write-title{
  font-size:16px;
  font-weight:800;
  margin:0 0 6px;
  color:var(--text);
}
.rev-write-desc{
  font-size:12.5px;
  color:var(--text-2);
  line-height:1.65;
  margin:0 0 14px;
  max-width:640px;
}
.rev-write-actions{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
}
.rev-write-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:11px 22px;
  background:linear-gradient(180deg,var(--brand-lav),var(--brand));
  border:1px solid rgba(167,139,250,.4);
  border-radius:999px;
  color:#fff;
  font-size:12.5px;
  font-weight:800;
  cursor:pointer;
  font-family:inherit;
  box-shadow:0 12px 28px -12px rgba(99,17,185,.7);
  transition:transform .2s,box-shadow .2s;
}
.rev-write-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 38px -14px rgba(99,17,185,.85);
}
.rev-write-note{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-family:var(--f-mono);
  font-size:10.5px;
  font-weight:700;
  color:var(--text-3);
  letter-spacing:.03em;
}

/* ── Related ── */
.rel-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.rel-card{
  padding:20px;
  background:var(--bg-2);
  border:1px solid var(--border);
  border-radius:var(--radius);
  transition:border-color .25s,transform .25s;
  cursor:pointer;
}
.rel-card:hover{border-color:rgba(99,17,185,.4);transform:translateY(-3px)}
.rel-media{
  aspect-ratio:1;
  background:linear-gradient(155deg,#1f1a35 0%,#120e22 55%,#0a0818 100%);
  border-radius:10px;
  margin-bottom:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
}
.rel-media::before{
  content:"";
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 30% 25%, rgba(99,17,185,.16), transparent 60%);
}
.rel-media svg{position:relative;z-index:1;color:rgba(255,255,255,.18);width:46px;height:46px}
.rel-brand{
  font-family:var(--f-mono);
  font-size:10px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--text-3);
  margin-bottom:4px;
}
.rel-name{font-weight:800;font-size:14px;margin-bottom:10px;line-height:1.3}
.rel-price{
  font-family:var(--f-display);
  font-size:18px;
  font-weight:800;
  color:#fff;
}

/* ═══════════════════════════════════════════════════════════
   MORE FROM APPLE — persistent same-brand carousel
   Header now handled by unified .gs-head (.glass-shell)
   ═══════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════════════════════════════
   RELATED ROWS — matches home-page .pc-card design
   Uses same class names as template-parts/product-card.php
   so future refactors stay in sync across preview + theme
   ═══════════════════════════════════════════════════════════ */
.rel-rows{padding:16px 0 40px}
.rel-row{margin-bottom:40px}
.rel-row:last-child{margin-bottom:0}

/* Row header — title left, see-all right */
.rel-row-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
  padding-inline:2px;
}
.rel-row-ttl h2{
  font-family:var(--f-display);
  font-size:20px;
  font-weight:800;
  color:var(--text);
  letter-spacing:-.015em;
  line-height:1.2;
  margin:0 0 4px;
}
.rel-row-ttl p{
  font-size:12.5px;
  color:var(--text-3);
  margin:0;
  line-height:1.4;
}
.rel-row-all{
  display:inline-flex;
  align-items:center;
  gap:5px;
  font-family:var(--f-display);
  font-size:12px;
  font-weight:700;
  color:var(--text-3);
  text-decoration:none;
  padding:7px 10px;
  border-radius:8px;
  transition:color .2s, background .2s;
  flex-shrink:0;
}
.rel-row-all:hover{color:var(--brand-lav);background:rgba(99,17,185,.08)}
.rel-row-all svg{transition:transform .2s}
.rel-row-all:hover svg{transform:translateX(-3px)}

/* Strip — 5 uniform columns */
.rel-strip{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:16px;
}

/* Preview ribbon */
.preview-ribbon{
  position:fixed;
  top:14px;
  left:14px;
  z-index:100;
  padding:8px 14px;
  background:linear-gradient(135deg,var(--brand),var(--brand-lav));
  color:#fff;
  font-family:var(--f-mono);
  font-size:10px;
  font-weight:800;
  letter-spacing:.1em;
  text-transform:uppercase;
  border-radius:999px;
  box-shadow:var(--shadow-sm);
}

/* ═══════════════════════════════════════════════════════════
   SITE MAIN HEADER (nav)
   ═══════════════════════════════════════════════════════════ */
.site-head{
  background:var(--bg-0);
  border-bottom:1px solid var(--border);
  position:sticky;
  top:0;
  z-index:60;
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  background:rgba(10,10,14,.92);
}
.sh-inner{
  display:flex;
  align-items:center;
  gap:32px;
  padding:18px 32px;
  max-width:1400px;
  margin:0 auto;
}
.sh-logo{
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:var(--text);
  flex:none;
}
.sh-logo-mark{
  width:34px;height:34px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--brand),var(--brand-lav));
  border-radius:10px;
  font-family:var(--f-display);
  font-weight:800;
  font-size:19px;
  color:#fff;
  box-shadow:0 6px 18px -6px rgba(99,17,185,.55),inset 0 0 0 1px rgba(255,255,255,.12);
}
.sh-logo-text{
  font-family:var(--f-display);
  font-weight:800;
  font-size:18px;
  letter-spacing:.04em;
  background:linear-gradient(135deg,#fff,var(--brand-lav));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.sh-nav{
  flex:1;
  display:flex;
  justify-content:center;
  gap:32px;
}
.sh-nav a{
  color:var(--text-2);
  text-decoration:none;
  font-family:var(--f-ar);
  font-size:13.5px;
  font-weight:700;
  padding:8px 0;
  position:relative;
  transition:color .2s;
}
.sh-nav a::after{
  content:"";
  position:absolute;
  bottom:0;
  right:50%;
  translate:50% 0;
  width:0;
  height:2px;
  background:var(--brand-lav);
  border-radius:2px;
  transition:width .25s;
}
.sh-nav a:hover{color:#fff}
.sh-nav a:hover::after,
.sh-nav a.is-active::after{width:20px}
.sh-nav a.is-active{color:#fff}
.sh-tools{display:flex;gap:8px;align-items:center;flex:none}
.sh-tool{
  width:40px;height:40px;
  background:var(--bg-2);
  border:1px solid var(--border-2);
  border-radius:10px;
  color:var(--text-2);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:all .2s;
  position:relative;
}
.sh-tool:hover{color:var(--brand-lav);border-color:rgba(99,17,185,.35);background:rgba(99,17,185,.06)}
.sh-cart-count{
  position:absolute;
  top:-4px;
  left:-4px;
  width:18px;height:18px;
  background:var(--brand);
  color:#fff;
  border-radius:50%;
  font-family:var(--f-mono);
  font-size:10px;
  font-weight:800;
  display:flex;align-items:center;justify-content:center;
  border:2px solid var(--bg-0);
}

/* ═══════════════════════════════════════════════════════════
   SITE FOOTER
   ═══════════════════════════════════════════════════════════ */
.site-foot{
  margin-top:80px;
  background:linear-gradient(180deg,transparent,rgba(99,17,185,.04));
  border-top:1px solid var(--border);
  padding:56px 0 0;
}
.sf-top{
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1.2fr;
  gap:56px;
  padding-bottom:48px;
}
.sf-brand-col .sf-logo{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-bottom:14px;
}
.sf-logo-mark{
  width:38px;height:38px;
  background:linear-gradient(135deg,var(--brand),var(--brand-lav));
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-display);
  font-weight:800;
  font-size:22px;
  color:#fff;
  box-shadow:0 8px 22px -8px rgba(99,17,185,.6);
}
.sf-logo-text{
  font-family:var(--f-display);
  font-weight:800;
  font-size:22px;
  letter-spacing:.04em;
  color:#fff;
}
.sf-tagline{
  font-size:13px;
  color:var(--text-3);
  line-height:1.65;
  margin-bottom:18px;
  max-width:320px;
}
.sf-social{display:flex;gap:8px}
.sf-social a{
  width:34px;height:34px;
  border:1px solid var(--border-2);
  border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  color:var(--text-3);
  text-decoration:none;
  transition:all .2s;
}
.sf-social a:hover{color:var(--brand-lav);border-color:rgba(99,17,185,.35);background:rgba(99,17,185,.06)}
.sf-col h4{
  font-family:var(--f-display);
  font-size:13px;
  font-weight:800;
  color:#fff;
  margin-bottom:18px;
  letter-spacing:-.005em;
}
.sf-col ul{list-style:none}
.sf-col ul li{margin-bottom:10px}
.sf-col ul li a{
  color:var(--text-3);
  text-decoration:none;
  font-size:12.5px;
  font-family:var(--f-ar);
  transition:color .2s;
}
.sf-col ul li a:hover{color:var(--brand-lav)}
.sf-pay{display:flex;flex-wrap:wrap;gap:6px}
.sf-pay-chip{
  font-family:var(--f-display);
  font-size:10.5px;
  font-weight:800;
  padding:5px 10px;
  background:var(--bg-2);
  border:1px solid var(--border-2);
  border-radius:6px;
  color:var(--text-2);
  letter-spacing:.02em;
}
.sf-pay-tabby{background:var(--success);color:#00322A;border-color:transparent}
.sf-pay-tamara{background:#FFCDDC;color:#8E1C3E;border-color:transparent}
.sf-bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:20px 32px;
  border-top:1px solid var(--border);
  font-size:11.5px;
  color:var(--text-4);
  font-family:var(--f-ar);
}
.sf-bottom p{margin:0}
.sf-legal{display:flex;gap:10px;align-items:center}
.sf-legal a{color:var(--text-3);text-decoration:none}
.sf-legal a:hover{color:var(--brand-lav)}
.sf-legal span{color:var(--text-4)}

/* Responsive */
@media (max-width:1100px){
  .hero{grid-template-columns:1fr;gap:40px}
  .title{font-size:40px}
  .price-main{font-size:44px}
  .gallery-main-wrap{grid-template-columns:1fr;gap:14px}
  .gallery-rail{
    flex-direction:row;
    overflow-x:auto;
    padding-bottom:4px;
    scrollbar-width:none;
  }
  .gallery-rail::-webkit-scrollbar{display:none}
  .gal-thumb{flex:none}
  .bento{grid-template-columns:repeat(2,1fr)}
  .bento-a,.bento-b,.bento-c,.bento-d{grid-column:span 2;grid-row:auto}
  .bento-a{min-height:340px}
  .bento-b{min-height:280px}
  .rel-grid{grid-template-columns:repeat(2,1fr)}
  .mb-grid{grid-template-columns:repeat(3,1fr)}
  .mb-grid .mb-card:nth-child(n+4){display:none}
  .sh-nav{display:none}
  .sf-top{grid-template-columns:1fr 1fr;gap:32px}
  .urg-trust{grid-template-columns:1fr}
  .urg-trust-item + .urg-trust-item::before{
    left:12px;right:12px;top:0;bottom:auto;width:auto;height:1px;
    background:linear-gradient(90deg,transparent,var(--border),transparent);
  }
  .specs-grid{grid-template-columns:1fr}
  .trust-grid{grid-template-columns:1fr}
  .ov-highlights{grid-template-columns:1fr}
  .reviews-summary{grid-template-columns:1fr;gap:24px}
  .review-cards{grid-template-columns:1fr}
  .rev-write{grid-template-columns:1fr;text-align:center;gap:14px}
  .rev-write-icon{margin:0 auto}
  .rev-write-actions{justify-content:center}
  .section-head h2{font-size:32px}
  .fbt-body{grid-template-columns:1fr;gap:24px}
  .fbt-aside-col{position:static;top:auto;order:-1;gap:14px}
  .fbt-title{font-size:26px}
  .fbt-item{padding:12px 14px;min-height:72px}
  .fbt-media{width:48px;height:48px}
  .fbt-media svg{width:22px;height:22px}
}
@media (max-width:640px){
  .container{padding:0 20px}
  .title{font-size:32px}
  .price-main{font-size:36px}
  .cta-row{flex-wrap:wrap}
  .pdp-tab{padding:12px 14px;font-size:12px}
  .pdp-tab-count{display:none}
}

/* Entry animations */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(30px)}
  to{opacity:1;transform:translateY(0)}
}
.hero > *{animation:fadeUp .8s ease both}
.hero .gallery{animation-delay:.1s}
.hero .info{animation-delay:.25s}

/* ── #1 Urgency progress — hairline fill across top row of assurance card ── */
.urg-bar{position:relative}
.urg-progress{
  position:absolute;
  top:0;
  inset-inline-start:0;
  inset-inline-end:0;
  height:2px;
  background:rgba(0,0,0,.45);
  pointer-events:none;
  z-index:2;
}
.urg-progress span{
  display:block;
  height:100%;
  width:0;
  background:linear-gradient(to left,#ff9500,#ff3b30);
  box-shadow:0 0 10px rgba(255,59,48,.55);
  transition:width 1.6s cubic-bezier(.2,.8,.2,1);
}
.urg-bar.is-filled .urg-progress span{width:var(--fill,90%)}

/* ── #2 3D phone — moving light reflection tied to rotation ── */
.p3d-front{position:relative}
.p3d-front::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  background:linear-gradient(
    calc(115deg + var(--lightAngle,0deg)),
    transparent 35%,
    rgba(255,255,255,.09) 48%,
    rgba(255,255,255,.18) 50%,
    rgba(255,255,255,.09) 52%,
    transparent 65%
  );
  mix-blend-mode:screen;
  opacity:.85;
}
.p3d-back{position:relative}
.p3d-back::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  background:linear-gradient(
    calc(-115deg + var(--lightAngle,0deg)),
    transparent 40%,
    rgba(255,255,255,.06) 50%,
    transparent 60%
  );
  mix-blend-mode:screen;
}

/* ── #3 First-time drag tooltip ── */
.p3d-tooltip{
  position:absolute;
  top:18px;inset-inline-start:50%;
  transform:translateX(-50%) translateY(-4px);
  display:flex;align-items:center;gap:6px;
  padding:7px 12px;
  background:rgba(10,8,22,.92);
  border:1px solid var(--border-2);
  border-radius:999px;
  font-family:var(--f-display);
  font-size:11px;
  font-weight:700;
  color:#fff;
  white-space:nowrap;
  backdrop-filter:blur(10px);
  box-shadow:0 8px 24px -8px rgba(99,17,185,.5);
  opacity:0;
  pointer-events:none;
  transition:opacity .4s ease,transform .4s ease;
  z-index:5;
}
.p3d-tooltip.is-visible{opacity:1;transform:translateX(-50%) translateY(0)}
.p3d-tooltip svg{color:var(--brand-lav);animation:tipHand 1.6s ease-in-out infinite}
@keyframes tipHand{
  0%,100%{transform:translateX(0)}
  50%{transform:translateX(4px)}
}

/* ── #4 Variant color tints (swap phone skin on click) ── */
[data-phone-color="titanium"] .p3d-front{
  background:linear-gradient(145deg,#2a2730 0%,#4a4550 50%,#2a2730 100%);
  border-color:rgba(180,175,195,.45);
}
[data-phone-color="titanium"] .p3d-back{
  background:
    radial-gradient(ellipse at 30% 20%,rgba(200,195,215,.18) 0%,transparent 50%),
    linear-gradient(155deg,#3a3740 0%,#1c1a22 100%);
}
[data-phone-color="desert"] .p3d-front{
  background:linear-gradient(145deg,#1a1410 0%,#3a2a1e 50%,#1a1410 100%);
  border-color:rgba(200,170,138,.45);
}
[data-phone-color="desert"] .p3d-back{
  background:
    radial-gradient(ellipse at 30% 20%,rgba(200,170,138,.22) 0%,transparent 50%),
    linear-gradient(155deg,#2e2418 0%,#14100a 100%);
}
[data-phone-color="white"] .p3d-front{
  background:linear-gradient(145deg,#1a1a20 0%,#5a5660 50%,#1a1a20 100%);
  border-color:rgba(220,215,230,.5);
}
[data-phone-color="white"] .p3d-back{
  background:
    radial-gradient(ellipse at 30% 20%,rgba(240,240,248,.22) 0%,transparent 50%),
    linear-gradient(155deg,#48454e 0%,#1e1c22 100%);
}
/* Dynamic tint — uses --p3d-color (hex from variant swatch) when set via JS.
   Works for any color slug (Arabic or English) without hard-coded CSS mapping. */
.css3d-stage[style*="--p3d-color"] .p3d-front{
  background:linear-gradient(145deg,color-mix(in srgb,var(--p3d-color) 30%,#0a0812) 0%,color-mix(in srgb,var(--p3d-color) 55%,#1a1520) 50%,color-mix(in srgb,var(--p3d-color) 30%,#0a0812) 100%);
  border-color:color-mix(in srgb,var(--p3d-color) 50%,#1a1520);
}
.css3d-stage[style*="--p3d-color"] .p3d-back{
  background:
    radial-gradient(ellipse at 30% 20%,color-mix(in srgb,var(--p3d-color) 35%,transparent) 0%,transparent 50%),
    linear-gradient(155deg,color-mix(in srgb,var(--p3d-color) 45%,#14101c) 0%,color-mix(in srgb,var(--p3d-color) 20%,#0a0812) 100%);
}
.css3d-stage[style*="--p3d-color"] .p3d-left,
.css3d-stage[style*="--p3d-color"] .p3d-right{
  background:linear-gradient(to right,
    color-mix(in srgb,var(--p3d-color) 40%,rgba(255,255,255,.25)) 0%,
    color-mix(in srgb,var(--p3d-color) 45%,#1a1520) 35%,
    color-mix(in srgb,var(--p3d-color) 20%,#08060e) 55%,
    color-mix(in srgb,var(--p3d-color) 45%,#1a1520) 80%,
    color-mix(in srgb,var(--p3d-color) 40%,rgba(255,255,255,.2)) 100%);
}
.css3d-stage[style*="--p3d-color"] .p3d-top,
.css3d-stage[style*="--p3d-color"] .p3d-bottom{
  background:linear-gradient(to bottom,
    color-mix(in srgb,var(--p3d-color) 40%,rgba(255,255,255,.25)) 0%,
    color-mix(in srgb,var(--p3d-color) 45%,#1a1520) 35%,
    color-mix(in srgb,var(--p3d-color) 20%,#08060e) 55%,
    color-mix(in srgb,var(--p3d-color) 45%,#1a1520) 80%,
    color-mix(in srgb,var(--p3d-color) 40%,rgba(255,255,255,.2)) 100%);
}
.css3d-phone{transition:filter .5s ease}

/* ── #5 Buy button discreet pulse every 8s ── */
@keyframes btnPulse{
  0%,92%,100%{
    transform:scale(1);
    box-shadow:0 12px 32px -12px rgba(99,17,185,.45),inset 0 0 0 1px rgba(255,255,255,.08);
  }
  94%{
    transform:scale(1.022);
    box-shadow:0 16px 42px -10px rgba(99,17,185,.7),inset 0 0 0 1px rgba(255,255,255,.14),0 0 0 6px rgba(99,17,185,.14);
  }
  96%{
    transform:scale(1);
    box-shadow:0 12px 32px -12px rgba(99,17,185,.45),inset 0 0 0 1px rgba(255,255,255,.08);
  }
}
.btn-buy{animation:btnPulse 8s ease-in-out infinite}
.btn-buy:hover{animation:none}


/* ═══════════════════════════════════════════════════════════
   CLEAN TAB PANELS — Overview · Specs · Reviews
   Borderless, typography-led. All use `.pv-` prefix.
   ═══════════════════════════════════════════════════════════ */
.pv-wrap{max-width:100%;margin:0;padding:40px 0 32px;position:relative}
.pv-wrap.pv-ov,.pv-wrap.pv-sp,.pv-wrap.pv-rv{padding-top:0}
.pv-head{display:flex;align-items:center;gap:18px;margin-bottom:26px}
.pv-title{
  font-family:var(--f-display);font-size:16px;font-weight:800;color:var(--text);
  letter-spacing:-.01em;margin:0;white-space:nowrap;
}
.pv-line{flex:1;height:1px;background:linear-gradient(90deg,var(--border),transparent)}
.pv-meta{font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-4);white-space:nowrap}

/* Shared show-more wrapper */
.pv-sm-wrap{position:relative;overflow:hidden;transition:max-height .5s cubic-bezier(.2,.8,.2,1)}
.pv-sm-wrap::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:80px;
  background:linear-gradient(180deg,transparent,var(--bg) 92%);pointer-events:none;transition:opacity .35s;
}
.pv-sm-wrap.is-expanded::after{opacity:0}
.pv-sm-toggle{
  margin-top:22px;display:inline-flex;align-items:center;gap:8px;
  padding:10px 20px;background:transparent;border:1px solid var(--border);border-radius:999px;
  font-family:var(--f-display);font-size:11.5px;font-weight:700;color:var(--text-2);cursor:pointer;
  transition:border-color .3s,color .3s,background .3s;
}
.pv-sm-toggle:hover{border-color:var(--brand);color:var(--text);background:rgba(99,17,185,.08)}
.pv-sm-toggle svg{width:13px;height:13px;transition:transform .35s cubic-bezier(.2,.8,.2,1)}
.pv-sm-wrap.is-expanded + .pv-sm-toggle svg{transform:rotate(180deg)}
.pv-sm-toggle .t-more{display:inline}
.pv-sm-toggle .t-less{display:none}
.pv-sm-wrap.is-expanded + .pv-sm-toggle .t-more{display:none}
.pv-sm-wrap.is-expanded + .pv-sm-toggle .t-less{display:inline}

/* ─── OVERVIEW V4 · Two-Column Editorial with Drop Cap ─── */
.pv-ov-body{
  column-count:2;column-gap:64px;column-rule:1px solid var(--border);
  font-size:14px;line-height:1.9;color:var(--text-2);max-width:100%;
}
.pv-ov-body p{margin-bottom:15px;break-inside:avoid}
/* Drop cap removed — Arabic compound letters (آ/أ/إ) render awkwardly with ::first-letter */
.pv-ov-body strong{color:var(--text);font-weight:700}
.pv-ov .pv-sm-wrap{max-height:240px}
.pv-ov .pv-sm-wrap.is-expanded{max-height:1600px}
@media (max-width:780px){.pv-ov-body{column-count:1;column-rule:none}}

/* ─── OVERVIEW · Feature Highlights Strip (4 hero stats above editorial) ─── */
.pv-ov-features{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
  margin:0 0 40px;
}
.pv-feat{
  position:relative;padding:22px 20px 20px;border-radius:18px;
  background:
    radial-gradient(380px 220px at 50% -10%,rgba(99,17,185,.13),transparent 72%),
    linear-gradient(180deg,#191921,#121219);
  border:1px solid rgba(196,181,253,.14);
  box-shadow:0 18px 40px -24px rgba(99,17,185,.32),inset 0 1px 0 rgba(255,255,255,.05);
  overflow:hidden;
  transition:transform .35s,border-color .35s,box-shadow .35s;
}
.pv-feat::before{
  content:'';position:absolute;top:-70px;inset-inline:0;height:200px;
  background:radial-gradient(340px 190px at 50% 0,rgba(99,17,185,.32),transparent 72%);
  opacity:0;transition:opacity .45s;pointer-events:none;
}
.pv-feat:hover{
  transform:translateY(-4px);
  border-color:rgba(196,181,253,.4);
  box-shadow:0 28px 56px -22px rgba(99,17,185,.6),inset 0 1px 0 rgba(255,255,255,.1);
}
.pv-feat:hover::before{opacity:1}
.pv-feat:hover .pv-feat-ic{color:#D4BFFF;transform:scale(1.08)}
.pv-feat-ic{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;color:var(--brand-lav);
  vertical-align:middle;flex-shrink:0;
}
.pv-feat-ic svg{display:block;width:100%;height:100%;stroke-width:1.6;}
.pv-feat-stat{
  position:relative;font-family:var(--f-display);font-size:28px;font-weight:800;
  color:#fff;line-height:.95;letter-spacing:-.022em;margin-bottom:10px;
  display:flex;align-items:center;gap:8px;justify-content:flex-start;
  text-align:right;
}
.pv-feat-stat em{
  font-style:normal;font-size:16px;font-weight:700;
  color:var(--brand-lav);letter-spacing:.04em;text-transform:uppercase;
}
.pv-feat-stat sup{font-size:16px;font-weight:700;color:var(--text-2);margin-inline-start:2px}
.pv-feat-title{
  position:relative;font-family:var(--f-ar);font-size:13px;font-weight:800;
  color:#fff;margin:0 0 4px;line-height:1.4;text-align:right;
}
.pv-feat-desc{
  position:relative;font-family:var(--f-ar);font-size:11px;font-weight:500;
  color:var(--text-3);margin:0;line-height:1.6;text-align:right;
}
@media (max-width:900px){.pv-ov-features{grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:32px}}
@media (max-width:520px){
  .pv-ov-features{grid-template-columns:repeat(2,1fr);gap:10px}
  .pv-feat{padding:14px;border-radius:14px}
  .pv-feat-ic{width:32px;height:32px;}
  .pv-feat-stat{font-size:22px}
  .pv-feat-title{font-size:11.5px}
}

/* ─── SPECS V2 · Grouped 2-Column ─── */
.pv-sp-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px 80px;max-width:100%}
.pv-sp-group-title{
  font-family:var(--f-display);font-size:10.5px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;
  color:var(--brand-lav);margin-bottom:18px;padding-bottom:12px;
  border-bottom:1px solid var(--border);
}
.pv-sp-row{
  display:flex;align-items:baseline;justify-content:space-between;gap:16px;
  padding:11px 0;
  border-bottom:1px solid transparent;
  border-image:linear-gradient(90deg,rgba(46,34,80,.6),transparent 85%) 1;
}
.pv-sp-row:last-child{border-image:none;padding-bottom:0}
.pv-sp-row-label{font-size:13px;color:var(--text-2);font-weight:600;font-family:var(--f-ar);letter-spacing:.005em}
.pv-sp-row-value{font-size:14px;color:var(--text);font-weight:600;text-align:left;font-family:var(--f-display);letter-spacing:-.005em}
.pv-sp .pv-sm-wrap{max-height:360px}
.pv-sp .pv-sm-wrap.is-expanded{max-height:2400px}
@media (max-width:780px){.pv-sp-grid{grid-template-columns:1fr;gap:44px}}

/* ─── REVIEWS V3 · Score Aside + Compact List + Photos + Filter ─── */
/* Dedicated "rating" token — warm amber, only used inside .pv-rv */
.pv-rv{--rv-gold:#F5B547;--rv-gold-dim:rgba(245,181,71,.22);--rv-gold-empty:#514430}
.pv-rv-grid{display:grid;grid-template-columns:260px 1fr;gap:64px;max-width:100%;align-items:start}

/* Aside: big score + stars + clickable distribution */
.pv-rv-aside{position:sticky;top:60px}
.pv-rv-score{font-family:var(--f-display);font-size:78px;font-weight:800;color:var(--text);letter-spacing:-.035em;line-height:.78;margin-bottom:14px}
.pv-rv-score sup{font-size:26px;font-weight:600;color:var(--text-3);letter-spacing:0;margin-right:4px;vertical-align:14px}
.pv-rv-stars{display:flex;gap:4px;margin-bottom:26px}
.pv-rv-stars svg{width:19px;height:19px;color:var(--rv-gold);filter:drop-shadow(0 0 14px rgba(245,181,71,.35))}
.pv-rv-dist{display:flex;flex-direction:column;gap:4px}
.pv-rv-dist-row{
  display:flex;align-items:center;gap:12px;
  padding:8px 10px 8px 8px;margin:0 -10px 0 -8px;border-radius:8px;
  font-size:12.5px;color:var(--text-2);font-family:var(--f-mono);font-weight:600;
  background:transparent;border:0;cursor:pointer;text-align:inherit;width:auto;
  transition:background .25s, color .25s;
}
.pv-rv-dist-row:hover{background:rgba(99,17,185,.08);color:var(--text)}
.pv-rv-dist-row.is-active{background:rgba(99,17,185,.14);color:var(--text)}
.pv-rv-dist-row.is-active .pv-rv-dist-bar i{background:linear-gradient(90deg,var(--brand-lav),#fff)}
.pv-rv-dist-row .pv-rv-dist-label{flex:0 0 32px;display:inline-flex;align-items:center;gap:3px;font-weight:800;color:var(--text)}
.pv-rv-dist-row .pv-rv-dist-label svg{width:11px;height:11px;fill:var(--rv-gold)}
.pv-rv-dist-bar{flex:1;height:5px;background:var(--border);border-radius:999px;overflow:hidden}
.pv-rv-dist-bar i{display:block;height:100%;background:var(--brand-lav);border-radius:999px;transition:background .25s}
.pv-rv-dist-pct{flex:0 0 38px;text-align:left;color:var(--text);font-weight:700}
.pv-rv-filter-clear{
  margin-top:14px;display:none;align-items:center;gap:6px;
  padding:6px 12px;background:transparent;border:1px solid var(--border);border-radius:999px;
  font-family:var(--f-mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);cursor:pointer;
  transition:border-color .3s,color .3s;
}
.pv-rv-filter-clear.is-visible{display:inline-flex}
.pv-rv-filter-clear:hover{border-color:var(--brand);color:var(--text)}
.pv-rv-filter-clear svg{width:10px;height:10px}

/* Main column: photo strip + status + review list */
.pv-rv-main{min-width:0}

.pv-rv-photos-head{
  display:flex;align-items:baseline;gap:14px;margin-bottom:14px;
}
.pv-rv-photos-head h4{
  font-family:var(--f-ar);font-size:19px;font-weight:800;color:var(--text);
  letter-spacing:-.005em;margin:0;line-height:1;
}
.pv-rv-photos-head span{
  font-family:var(--f-ar);font-size:12.5px;font-weight:600;color:var(--text-2);
}
.pv-rv-photos-strip{
  display:flex;gap:10px;overflow-x:auto;
  padding:2px 2px 14px;margin-bottom:10px;
  scrollbar-width:thin;scrollbar-color:var(--border-2) transparent;
}
.pv-rv-photos-strip::-webkit-scrollbar{height:4px}
.pv-rv-photos-strip::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:999px}
.pv-rv-photo-thumb{
  flex:0 0 72px;width:72px;height:72px;border-radius:10px;overflow:hidden;
  cursor:pointer;border:2px solid transparent;position:relative;
  transition:border-color .3s, transform .3s;
}
.pv-rv-photo-thumb:hover{border-color:var(--brand-lav);transform:translateY(-2px)}
.pv-rv-photo-thumb.is-more{
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.025);border:1px dashed var(--border-2);
  color:var(--text-3);font-family:var(--f-mono);font-size:10px;font-weight:700;
}
.pv-rv-photo-thumb.is-more:hover{color:var(--text);border-color:var(--brand-lav)}

/* Placeholder photo gradients (shop-safe deterministic patterns) */
.pv-ph-1{background:linear-gradient(135deg,#4A3180 0%,#1D0F3D 100%)}
.pv-ph-2{background:linear-gradient(135deg,#6311B9 0%,#2D2154 50%,#120A24 100%)}
.pv-ph-3{background:linear-gradient(150deg,#C4B5FD 0%,#4E0E93 100%)}
.pv-ph-4{background:radial-gradient(circle at 30% 30%,#9C94B8 0%,#241947 70%)}
.pv-ph-5{background:linear-gradient(45deg,#1B1233 0%,#6311B9 50%,#1B1233 100%)}
.pv-ph-6{background:linear-gradient(135deg,#635C82 0%,#120A24 100%)}
.pv-ph-7{background:radial-gradient(circle at 70% 60%,#C4B5FD 0%,#2D2154 80%)}
.pv-ph-8{background:linear-gradient(135deg,#D1CCE4 0%,#6311B9 100%)}

/* Active filter status line — hidden by default, only visible when filter active */
.pv-rv-status{display:none}
.pv-rv-status.is-filtered{
  display:flex;align-items:center;gap:10px;
  font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-2);
  margin-bottom:14px;
}
.pv-rv-status b{color:var(--text);font-family:var(--f-display);font-weight:700;letter-spacing:.02em}

/* ─── Write Review CTA + Form ─── */
.pv-rv-write{
  position:relative;margin-bottom:24px;padding:20px 22px;
  background:linear-gradient(135deg,rgba(99,17,185,.06),rgba(99,17,185,.02) 60%);
  border:1px solid rgba(99,17,185,.2);border-radius:14px;
  transition:padding .4s cubic-bezier(.2,.8,.2,1);
}
.pv-rv-write::before{
  content:"";position:absolute;inset:0;border-radius:14px;pointer-events:none;
  background:radial-gradient(400px 120px at 90% -20%,rgba(196,181,253,.16),transparent 60%);
}
.pv-rv-write-head{display:flex;align-items:center;gap:14px;position:relative}
.pv-rv-write-icon{
  flex:0 0 44px;width:44px;height:44px;border-radius:12px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--brand-lav),var(--brand));
  color:#fff;box-shadow:0 6px 20px rgba(99,17,185,.35);
}
.pv-rv-write-icon svg{width:22px;height:22px}
.pv-rv-write-text{flex:1;min-width:0}
.pv-rv-write-title{
  font-family:var(--f-display);font-size:15px;font-weight:800;color:var(--text);margin:0 0 2px;letter-spacing:-.005em;
}
.pv-rv-write-sub{font-family:var(--f-ar);font-size:12px;color:var(--text-3);margin:0}
.pv-rv-write-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 18px;border-radius:999px;border:0;cursor:pointer;
  background:var(--text);color:var(--bg);
  font-family:var(--f-display);font-size:12.5px;font-weight:700;letter-spacing:.01em;
  transition:transform .25s,box-shadow .25s;
}
.pv-rv-write-btn:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(0,0,0,.35)}
.pv-rv-write-btn svg{width:14px;height:14px}

/* Expanded form body */
.pv-rv-write-body{
  max-height:0;overflow:hidden;opacity:0;
  transition:max-height .5s cubic-bezier(.2,.8,.2,1),opacity .4s,margin-top .4s;
}
.pv-rv-write.is-open{padding-bottom:18px}
.pv-rv-write.is-open .pv-rv-write-body{max-height:600px;opacity:1;margin-top:16px}
.pv-rv-write.is-open .pv-rv-write-btn{display:none}

.pv-rv-form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.pv-rv-form-inline{display:flex;gap:14px;align-items:flex-start;margin-bottom:12px;flex-wrap:wrap}
.pv-rv-form-inline .pv-rv-form-row{flex:1;min-width:180px;margin-bottom:0}
.pv-rv-form-label{
  font-family:var(--f-ar);font-size:11.5px;font-weight:700;color:var(--text-2);letter-spacing:.01em;
}
.pv-rv-form-label b{color:var(--brand-lav);margin-inline-start:3px}

/* Login-required note (shown when guest opens the review form) */
.pv-rv-form-login-note{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;margin-bottom:12px;
  border-radius:10px;
  border:1px dashed var(--border-2);
  background:rgba(99,17,185,.06);
  color:var(--text-2);font-family:var(--f-ar);font-size:13px;
}
.pv-rv-form-login-note svg{width:18px;height:18px;color:var(--brand-lav);flex:0 0 auto}
.pv-rv-form-login-note a{
  margin-inline-start:auto;color:var(--brand-lav);font-weight:700;
  text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s;
}
.pv-rv-form-login-note a:hover{border-bottom-color:var(--brand-lav)}
.pv-rv-form-submit[disabled]{opacity:.5;cursor:not-allowed}

/* Star rating picker */
.pv-rv-rate-pick{display:flex;gap:4px;direction:ltr;justify-content:flex-end}
.pv-rv-rate-pick button{
  background:transparent;border:0;padding:2px;cursor:pointer;
  color:var(--rv-gold-empty);transition:color .2s,transform .2s;
}
.pv-rv-rate-pick button svg{width:22px;height:22px;fill:currentColor}
.pv-rv-rate-pick button:hover{transform:scale(1.1)}
.pv-rv-rate-pick button.is-on{color:var(--rv-gold);filter:drop-shadow(0 0 8px rgba(245,181,71,.4))}

/* Textarea */
.pv-rv-form-textarea{
  width:100%;min-height:80px;padding:12px 14px;border-radius:10px;resize:vertical;
  background:rgba(0,0,0,.25);border:1px solid var(--border);
  color:var(--text);font-family:var(--f-ar);font-size:13.5px;line-height:1.7;
  transition:border-color .3s,background .3s;
}
.pv-rv-form-textarea::placeholder{color:var(--text-4)}
.pv-rv-form-textarea:focus{outline:0;border-color:var(--brand-lav);background:rgba(0,0,0,.35)}

/* Photo upload dropzone — compact inline */
.pv-rv-form-drop{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;border:1.5px dashed var(--border-2);border-radius:10px;
  background:rgba(255,255,255,.02);cursor:pointer;
  transition:border-color .3s,background .3s;
}
.pv-rv-form-drop:hover{border-color:var(--brand-lav);background:rgba(99,17,185,.04)}
.pv-rv-form-drop svg{width:20px;height:20px;color:var(--brand-lav);flex-shrink:0}
.pv-rv-form-drop-text{flex:1;min-width:0}
.pv-rv-form-drop-title{font-family:var(--f-ar);font-size:12px;font-weight:700;color:var(--text);margin:0}
.pv-rv-form-drop-hint{font-family:var(--f-ar);font-size:10.5px;color:var(--text-3);margin:1px 0 0}
.pv-rv-form-drop input{display:none}

/* Photo previews */
.pv-rv-form-previews{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.pv-rv-form-previews:empty{display:none}
.pv-rv-form-preview{
  position:relative;width:68px;height:68px;border-radius:10px;overflow:hidden;
  border:1px solid var(--border-2);
}
.pv-rv-form-preview img{width:100%;height:100%;object-fit:cover}
.pv-rv-form-preview button{
  position:absolute;top:4px;left:4px;width:18px;height:18px;border-radius:50%;
  background:rgba(0,0,0,.7);border:0;color:#fff;cursor:pointer;
  display:grid;place-items:center;padding:0;
}
.pv-rv-form-preview button svg{width:10px;height:10px}

/* Form footer */
.pv-rv-form-foot{display:flex;align-items:center;gap:10px;margin-top:4px}
.pv-rv-form-submit{
  flex:1;padding:10px 20px;border-radius:9px;border:0;cursor:pointer;
  background:linear-gradient(135deg,var(--brand-lav),var(--brand));
  color:#fff;font-family:var(--f-display);font-size:13px;font-weight:800;letter-spacing:.01em;
  box-shadow:0 6px 20px rgba(99,17,185,.35);
  transition:transform .25s,box-shadow .25s;
}
.pv-rv-form-submit:hover{transform:translateY(-1px);box-shadow:0 10px 26px rgba(99,17,185,.5)}
.pv-rv-form-cancel{
  padding:10px 16px;border-radius:9px;cursor:pointer;
  background:transparent;border:1px solid var(--border-2);color:var(--text-2);
  font-family:var(--f-ar);font-size:12px;font-weight:600;
  transition:border-color .3s,color .3s;
}
.pv-rv-form-cancel:hover{border-color:var(--brand-lav);color:var(--text)}

/* Review list */
.pv-rv-list{display:flex;flex-direction:column;gap:4px}
.pv-rv-item{
  padding:24px 0 28px;
  border-bottom:1px solid rgba(99,17,185,.14);
  position:relative;
}
.pv-rv-item::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(196,181,253,.28) 20%,rgba(196,181,253,.28) 80%,transparent);
}
.pv-rv-item:first-child{padding-top:8px}
.pv-rv-item:last-child{border-bottom:0}
.pv-rv-item:last-child::after{display:none}
.pv-rv-item:last-child{border-image:none}
.pv-rv-item.is-hidden{display:none}
.pv-rv-item-head{display:flex;align-items:center;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.pv-rv-item-stars{display:flex;gap:2px}
.pv-rv-item-stars svg{width:12px;height:12px;color:var(--rv-gold);fill:currentColor}
.pv-rv-item-stars svg.is-empty{fill:none;stroke:var(--rv-gold-empty);stroke-width:2;stroke-linejoin:round;color:var(--rv-gold-empty)}
.pv-rv-item-author{font-family:var(--f-display);font-size:14px;font-weight:700;color:var(--text)}
.pv-rv-item-verified{
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--f-ar);font-size:11.5px;font-weight:600;letter-spacing:.01em;color:var(--success);
}
.pv-rv-item-verified svg{width:12px;height:12px}
.pv-rv-item-date{
  font-family:var(--f-ar);font-size:11.5px;font-weight:500;color:var(--text-3);
  padding-inline-start:8px;border-inline-start:1px solid var(--border-2);
}
.pv-rv-item-text{font-size:14px;line-height:1.9;color:var(--text-2);max-width:none;margin-bottom:12px}
.pv-rv-item-text:last-child{margin-bottom:0}
.pv-rv-item-meta{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--f-ar);font-size:11.5px;font-weight:600;color:var(--brand-lav);
  padding:4px 10px;margin-bottom:12px;border-radius:999px;
  background:rgba(99,17,185,.08);border:1px solid rgba(99,17,185,.22);
}
.pv-rv-item-meta::before{
  content:"";width:5px;height:5px;border-radius:999px;background:var(--brand-lav);
  box-shadow:0 0 8px rgba(196,181,253,.6);
}

/* Photos under a review */
.pv-rv-item-photos{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px;justify-content:flex-start}
.pv-rv-item-photo{
  width:92px;height:92px;border-radius:10px;overflow:hidden;
  border:1px solid var(--border);cursor:pointer;
  transition:border-color .3s, transform .3s;
}
.pv-rv-item-photo:hover{border-color:var(--brand-lav);transform:scale(1.02)}

.pv-rv .pv-sm-wrap{max-height:560px}
.pv-rv .pv-sm-wrap.is-expanded{max-height:5000px}
.pv-rv .pv-sm-wrap::after{display:none}

@media (max-width:880px){
  .pv-rv-grid{grid-template-columns:1fr;gap:36px}
  .pv-rv-aside{position:static}
}

/* FBT preview-only navigation toast */
#fbtNavToast{
  position:fixed;top:24px;left:50%;
  z-index:99999;padding:14px 22px;border-radius:999px;
  background:linear-gradient(135deg,#6311B9,#9333EA);color:#fff;
  font-family:"IBM Plex Sans Arabic",sans-serif;font-size:14px;font-weight:800;
  box-shadow:0 20px 50px -10px rgba(99,17,185,.55),inset 0 0 0 1px rgba(196,181,253,.35);
  display:flex;align-items:center;gap:10px;white-space:nowrap;pointer-events:none;
  opacity:0;visibility:hidden;
  transform:translate(-50%,-24px);
  transition:opacity .25s ease,transform .3s cubic-bezier(.2,.9,.3,1.2),visibility 0s linear .25s;
}
#fbtNavToast.is-visible{
  opacity:1;visibility:visible;
  transform:translate(-50%,0);
  transition:opacity .25s ease,transform .3s cubic-bezier(.2,.9,.3,1.2),visibility 0s linear 0s;
}

/* ══════════════════════════════════════════════════════════
   Bundle continuation banner — shown when ?bundle= present
   Links shopper back to the parent product + shows savings.
   ══════════════════════════════════════════════════════════ */
.bundle-banner{
  margin:18px 0 20px;
  background:
    radial-gradient(600px 220px at 90% -20%, rgba(196,181,253,.18), transparent 60%),
    linear-gradient(100deg, rgba(99,17,185,.22) 0%, rgba(74,43,156,.16) 100%);
  border:1px solid rgba(196,181,253,.32);
  border-radius:14px;
  box-shadow:0 14px 36px -18px rgba(99,17,185,.55), inset 0 1px 0 rgba(255,255,255,.05);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  overflow:hidden;
  animation:bundleBannerIn .4s cubic-bezier(.2,.9,.3,1);
}
@keyframes bundleBannerIn{
  from{opacity:0;transform:translateY(-6px)}
  to{opacity:1;transform:translateY(0)}
}
.bundle-banner-inner{
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;
}
.bundle-banner-ic{
  flex:none;
  width:36px;height:36px;border-radius:10px;
  display:grid;place-items:center;
  background:rgba(99,17,185,.28);
  color:#E6DCFF;
  border:1px solid rgba(196,181,253,.45);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);
}
.bundle-banner-text{
  flex:1;min-width:0;
  display:flex;flex-direction:column;gap:2px;
}
.bundle-banner-text strong{
  font-family:var(--f-ar);font-size:14px;font-weight:800;
  color:#fff;letter-spacing:-.005em;
}
.bundle-banner-text span{
  font-family:var(--f-ar);font-size:12.5px;font-weight:500;
  color:var(--text-2);line-height:1.4;
}
.bundle-banner-back{
  flex:none;
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(196,181,253,.35);
  color:#fff;
  font-family:var(--f-ar);font-size:12.5px;font-weight:700;
  text-decoration:none;
  transition:background .2s ease,transform .2s ease,border-color .2s ease;
}
.bundle-banner-back:hover{
  background:rgba(99,17,185,.35);
  border-color:rgba(196,181,253,.6);
  transform:translateX(-2px);
}
.bundle-banner-back svg{opacity:.85}
@media (max-width:640px){
  .bundle-banner-inner{flex-wrap:wrap;gap:10px;padding:12px 14px}
  .bundle-banner-back{margin-inline-start:auto}
}

/* ═══════════════════════════════════════════════
   FBT INLINE SWAP — alternatives panel
   ═══════════════════════════════════════════════ */
.fbt-slot{position:relative}

.fbt-item{position:relative}

/* Active preview — full glow, matches the main item highlight. */
.fbt-slot.is-swapping > .fbt-item{
  background:linear-gradient(135deg,rgba(99,17,185,.26),rgba(99,17,185,.07));
  border-color:rgba(196,181,253,.65);
  box-shadow:
    0 0 0 1px rgba(196,181,253,.22) inset,
    0 0 0 4px rgba(99,17,185,.08),
    0 14px 34px -14px rgba(99,17,185,.55);
}

.fbt-alts{
  position:relative;
  margin-top:10px;
  border:1px solid rgba(196,181,253,.22);
  border-radius:14px;
  background:linear-gradient(180deg, rgba(23,18,38,.92) 0%, rgba(17,13,28,.96) 100%);
  box-shadow:0 18px 42px -22px rgba(0,0,0,.7),inset 0 1px 0 rgba(255,255,255,.04);
  backdrop-filter:blur(10px);
  overflow:hidden;
  opacity:0;
  transform:translateY(-6px);
  max-height:0;
  transition:opacity .22s ease, transform .22s ease, max-height .28s ease;
}
.fbt-alts.is-open{
  opacity:1;
  transform:translateY(0);
  max-height:600px;
}

.fbt-alts-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;
  border-bottom:1px solid rgba(255,255,255,.06);
  font-family:var(--f-ar);font-size:12px;font-weight:700;
  color:var(--text-2);
  letter-spacing:-.005em;
}
.fbt-alts-head-end{justify-content:flex-end;}
.fbt-alts-close{
  width:22px;height:22px;border-radius:50%;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  color:var(--text-3);
  cursor:pointer;
  font-size:16px;line-height:1;
  display:grid;place-items:center;
  transition:background .16s ease,color .16s ease,border-color .16s ease;
}
.fbt-alts-close:hover{
  background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.18);
}

.fbt-alts-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(130px,1fr));
  gap:8px;
  padding:12px;
}
.fbt-alt{
  display:flex;flex-direction:column;gap:6px;
  padding:10px;
  border-radius:10px;
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.06);
  color:var(--text);
  cursor:pointer;
  text-align:start;
  transition:background .16s ease,border-color .16s ease,transform .16s ease;
}
.fbt-alt:hover{
  background:rgba(99,17,185,.1);
  border-color:rgba(196,181,253,.35);
  transform:translateY(-1px);
}
/* Already-in-bundle card: dim the interior but keep the label loud enough to read. */
.fbt-alt.is-dupe{
  position:relative;
  cursor:not-allowed;
  opacity:.55;
}
.fbt-alt.is-dupe:hover{
  background:rgba(255,255,255,.025);
  border-color:rgba(255,255,255,.06);
  transform:none;
}
.fbt-alt-dupe{
  position:absolute;top:6px;inset-inline-end:6px;
  padding:3px 7px;border-radius:999px;
  background:rgba(34,197,94,.2);
  border:1px solid rgba(34,197,94,.35);
  color:#86EFAC;
  font-family:var(--f-ar);font-size:9.5px;font-weight:800;
  letter-spacing:-.005em;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}

/* Transient toast for blocked actions (dupe attempts, etc.) */
.fbt-flash{
  position:absolute;bottom:14px;left:50%;transform:translateX(-50%) translateY(8px);
  padding:8px 14px;border-radius:10px;
  background:rgba(10,10,15,.88);
  color:#fff;
  font-family:var(--f-ar);font-size:12px;font-weight:700;
  letter-spacing:-.005em;
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 10px 24px -12px rgba(0,0,0,.55);
  opacity:0;pointer-events:none;
  transition:opacity .18s ease,transform .18s ease;
  z-index:5;
}
.fbt-flash.is-visible{opacity:1;transform:translateX(-50%) translateY(0)}
.fbt-alt-img{
  display:block;width:100%;aspect-ratio:1;
  border-radius:8px;
  background:rgba(255,255,255,.03);
  overflow:hidden;
  display:grid;place-items:center;
}
.fbt-alt-img img{width:100%;height:100%;object-fit:cover;display:block}
.fbt-alt-img svg{width:32px;height:32px;color:var(--text-4);opacity:.5}
.fbt-alt-name{
  font-family:var(--f-ar);font-size:12px;font-weight:600;
  color:var(--text);
  line-height:1.35;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;
  min-height:32px;
}
.fbt-alt-price{
  display:inline-flex;align-items:center;gap:4px;
  font-family:var(--f-sans);font-size:12px;font-weight:700;
  color:var(--accent, #C4B5FD);
}
.fbt-alt-price .sar{width:9px;height:9px;fill:currentColor}

.fbt-alts-loading{
  padding:22px;
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--f-ar);font-size:12px;
  color:var(--text-3);
}
.fbt-alts-spin{
  width:14px;height:14px;border-radius:50%;
  border:2px solid rgba(196,181,253,.25);
  border-top-color:#C4B5FD;
  animation:fbtAltsSpin .7s linear infinite;
}
@keyframes fbtAltsSpin{to{transform:rotate(360deg)}}

.fbt-alts-empty{
  padding:22px;text-align:center;
  font-family:var(--f-ar);font-size:12px;
  color:var(--text-3);
}

/* Swap confirmation — green success halo + subtle lift, plus image
   crossfade so the eye catches up with the data change. */
.fbt-slot.was-swapped .fbt-item{
  animation:fbtSwapSuccess .95s cubic-bezier(.22,1,.36,1);
}
@keyframes fbtSwapSuccess{
  0%   {box-shadow:0 0 0 0 rgba(34,197,94,.55); transform:scale(1)}
  15%  {transform:scale(1.025)}
  55%  {box-shadow:0 0 0 10px rgba(34,197,94,0)}
  100% {box-shadow:0 0 0 0 rgba(34,197,94,0); transform:scale(1)}
}
.fbt-slot.was-swapped .fbt-media img{
  animation:fbtImgCrossfade .55s cubic-bezier(.22,1,.36,1);
}
@keyframes fbtImgCrossfade{
  0%   {opacity:0; transform:scale(.9)}
  100% {opacity:1; transform:scale(1)}
}
/* A quick green ✓ tick anchored to the bottom-left corner so it never
   covers the product name/price during the success beat. */
.fbt-slot.was-swapped::after{
  content:'✓ تم الاستبدال';
  position:absolute;top:50%;left:56px;
  padding:6px 12px;border-radius:999px;
  background:rgba(34,197,94,.95);color:#04231A;
  font-family:var(--f-ar);font-size:11.5px;font-weight:800;
  box-shadow:0 8px 22px -6px rgba(34,197,94,.55), 0 2px 8px rgba(0,0,0,.35);
  animation:fbtSwapToast 1.1s cubic-bezier(.22,1,.36,1);
  pointer-events:none;z-index:4;
  opacity:0;
}
@keyframes fbtSwapToast{
  0%   {opacity:0; transform:translateY(-50%) translateY(8px) scale(.92)}
  20%  {opacity:1; transform:translateY(-50%) translateY(0) scale(1)}
  75%  {opacity:1; transform:translateY(-50%) translateY(-1px) scale(1)}
  100% {opacity:0; transform:translateY(-50%) translateY(-6px) scale(.96)}
}

/* Panel closing — smooth fade out instead of the abrupt [hidden] snap. */
.fbt-alts.is-closing{
  opacity:0;
  transform:translateY(-6px) scale(.985);
  max-height:0;
  transition:opacity .25s ease, transform .25s ease, max-height .28s ease;
}

@media (max-width:540px){
  /* Mobile alts: horizontal swipeable rail — uses .pc-card styles, rail just controls layout */
  .fbt-alts-grid{display:flex!important;grid-template-columns:none;flex-direction:row;gap:10px;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:8px 12px 12px;margin:0;scrollbar-width:none}
  .fbt-alts-grid::-webkit-scrollbar{display:none}
  /* Each pc-card sized as a snap card in the rail — narrower so 2.5 visible (encourages swipe) */
  .fbt-alts-grid .pc-card.fbt-alt{flex:0 0 138px!important;width:138px;max-width:138px;scroll-snap-align:start;text-decoration:none}
  /* Edge fade hint: subtle gradient on right edge to suggest more content (LTR view; in RTL flips naturally) */
  .fbt-alts{position:relative}
  .fbt-alts-grid .pc-card.fbt-alt.is-dupe{opacity:.5}
  /* Compact internal spacing — trim ALL gaps inside FBT alt cards */
  .fbt-alts-grid .pc-card.fbt-alt{padding:0!important;overflow:hidden}
  .fbt-alts-grid .pc-card.fbt-alt .pc-media{margin:0!important;padding:0!important;width:100%;border-radius:0;display:block}
  .fbt-alts-grid .pc-card.fbt-alt .pc-media img{width:100%!important;height:100%!important;display:block;border-radius:0}
  .fbt-alts-grid .pc-card.fbt-alt .pc-body{padding:6px 10px 4px!important;gap:3px!important;margin:0}
  .fbt-alts-grid .pc-card.fbt-alt{padding-bottom:0!important;margin-bottom:0!important}
  .fbt-alts-grid .pc-card.fbt-alt > *:last-child{margin-bottom:0!important;padding-bottom:0!important}
  .fbt-alts-grid .pc-card.fbt-alt .pc-cat{margin:0!important;padding:0!important;line-height:1.1}
  .fbt-alts-grid .pc-card.fbt-alt .pc-name{margin:0!important;padding:0!important;line-height:1.3}
  .fbt-alts-grid .pc-card.fbt-alt .pc-signals{margin:1px 0 0!important;padding:0!important;flex-wrap:wrap;gap:4px}
  .fbt-alts-grid .pc-card.fbt-alt .pc-foot{margin:0!important;padding:0!important}
  .fbt-alts-grid .pc-card.fbt-alt .pc-price-col{gap:0!important;padding:0!important;margin:0!important}
  .fbt-alts-grid .pc-card.fbt-alt .pc-price-old{margin:0!important;padding:0!important;line-height:1.2}
  .fbt-alts-grid .pc-card.fbt-alt .pc-price{margin:0!important;padding:0!important;line-height:1.1}
  .fbt-alts-grid .pc-card.fbt-alt .pc-inst{margin:0!important;padding:0!important;line-height:1.2}
  .fbt-alts-grid .pc-card.fbt-alt::before,
  .fbt-alts-grid .pc-card.fbt-alt::after{display:none!important}
  .fbt-alt-dupe{position:absolute;top:6px;inset-inline-end:6px;font-size:9px;padding:2px 6px;background:rgba(0,0,0,.78);color:#fff;border-radius:4px;z-index:3;font-family:var(--f-ar);font-weight:700}
  .fbt-alts-head{padding:8px 12px}
}

/* Richer alt cards — rating + meta row */
.fbt-alt{position:relative}
.fbt-alt-meta{
  display:flex;align-items:center;justify-content:space-between;gap:6px;
}
.fbt-alt-rating{
  display:inline-flex;align-items:center;gap:2px;
  font-family:var(--f-sans);font-size:10.5px;font-weight:700;
  color:#FBBF24;
  letter-spacing:-.005em;
}

/* ───────────── Detail preview (in-panel) ───────────── */
.fbt-alts.is-loading{min-height:88px}

.fbt-det-back{
  display:inline-flex;align-items:center;gap:4px;
  padding:5px 10px 5px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  color:var(--text-2);
  font-family:var(--f-ar);font-size:11.5px;font-weight:700;
  cursor:pointer;
  transition:background .16s ease,color .16s ease,border-color .16s ease;
}
.fbt-det-back:hover{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.18);}

.fbt-det-body{
  display:grid;
  grid-template-columns:120px 1fr;
  gap:14px;
  padding:12px;
  align-items:stretch;
}

/* Media column stretches to match info column height; thumbs flex to fill. */
.fbt-det-media{display:flex;flex-direction:column;gap:6px;align-self:stretch;}

/* Small green ribbon on the main image — shown only in 'current' mode. */
.fbt-det-bundle-ribbon{
  position:absolute;top:6px;inset-inline-start:6px;
  padding:3px 7px;border-radius:6px;
  background:rgba(34,197,94,.92);color:#0B2A16;
  font-family:var(--f-ar);font-size:9.5px;font-weight:800;letter-spacing:-.005em;
  box-shadow:0 2px 6px rgba(0,0,0,.35);
  pointer-events:none;
  z-index:2;
}
.fbt-det-main{
  position:relative;
  width:100%;aspect-ratio:1;
  border-radius:12px;
  background:rgba(255,255,255,.03);
  overflow:hidden;
  display:grid;place-items:center;
  border:1px solid rgba(255,255,255,.05);
}
.fbt-det-main img{width:100%;height:100%;object-fit:cover;display:block}
.fbt-det-main svg{width:42px;height:42px;color:var(--text-4);opacity:.5}

/* Prev/next arrows on the main preview image */
.fbt-det-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:30px;height:30px;border-radius:50%;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(10,10,15,.55);
  color:#fff;cursor:pointer;
  display:grid;place-items:center;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:0;
  transition:opacity .18s ease,background .18s ease,border-color .18s ease,transform .18s ease;
}
.fbt-det-main:hover .fbt-det-nav,
.fbt-det-nav:focus-visible{opacity:1}
.fbt-det-nav:hover{background:rgba(99,17,185,.55);border-color:rgba(196,181,253,.6);}
.fbt-det-nav svg{width:14px;height:14px}
/* RTL-aware positioning: prev sits on the reading-start edge. */
html[dir="rtl"] .fbt-det-nav-prev,
[dir="rtl"] .fbt-det-nav-prev{right:8px;left:auto}
html[dir="rtl"] .fbt-det-nav-next,
[dir="rtl"] .fbt-det-nav-next{left:8px;right:auto}
html:not([dir="rtl"]) .fbt-det-nav-prev,
:not([dir="rtl"]) > .fbt-det-nav-prev{left:8px}
html:not([dir="rtl"]) .fbt-det-nav-next,
:not([dir="rtl"]) > .fbt-det-nav-next{right:8px}

.fbt-det-count{
  position:absolute;bottom:8px;inset-inline-end:10px;
  padding:3px 8px;border-radius:999px;
  background:rgba(10,10,15,.6);
  color:var(--text-2);
  font-family:var(--f-sans);font-size:10.5px;font-weight:700;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  letter-spacing:.02em;
}
.fbt-det-count b{color:#fff;font-weight:800}

.fbt-det-gal{
  display:grid;grid-template-columns:repeat(4,1fr);gap:4px;flex:1;
}
.fbt-det-thumb{
  aspect-ratio:1;padding:0;border:1px solid rgba(255,255,255,.06);
  border-radius:8px;overflow:hidden;cursor:pointer;
  background:rgba(255,255,255,.03);
  transition:border-color .16s ease,transform .16s ease;
}
.fbt-det-thumb:hover{border-color:rgba(196,181,253,.45);transform:translateY(-1px)}
.fbt-det-thumb.is-active{border-color:rgba(196,181,253,.7);box-shadow:0 0 0 2px rgba(99,17,185,.22)}
.fbt-det-thumb img{width:100%;height:100%;object-fit:cover;display:block}

.fbt-det-info{
  display:flex;flex-direction:column;justify-content:space-between;gap:8px;
  min-width:0;
}

.fbt-det-chips{
  display:flex;flex-wrap:wrap;gap:6px;
}
.fbt-det-chip{
  display:inline-flex;align-items:center;
  padding:3px 8px;border-radius:999px;
  background:rgba(99,17,185,.14);
  border:1px solid rgba(196,181,253,.22);
  font-family:var(--f-ar),"Segoe UI","Tahoma","Arial",system-ui,sans-serif;
  font-size:10.5px;font-weight:700;
  color:#E6DCFF;letter-spacing:-.005em;
  unicode-bidi:plaintext;
}
.fbt-det-stock{
  padding:3px 8px;border-radius:999px;
  font-family:var(--f-ar);font-size:10.5px;font-weight:700;
  letter-spacing:-.005em;
}
.fbt-det-stock.is-in{background:rgba(34,197,94,.14);color:#86EFAC;border:1px solid rgba(34,197,94,.28);}
.fbt-det-stock.is-out{background:rgba(239,68,68,.14);color:#FCA5A5;border:1px solid rgba(239,68,68,.3);}

.fbt-det-name{
  margin:0;display:block;text-decoration:none;
  font-family:var(--f-ar);font-size:15px;font-weight:800;
  color:var(--text);line-height:1.35;letter-spacing:-.01em;
  transition:color .15s ease;
}
.fbt-det-name:hover{color:var(--brand-lav,#C4B5FD);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;}

.fbt-det-rate{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--f-sans);font-size:12px;font-weight:700;color:var(--text-2);
}
.fbt-det-rate em{color:#FBBF24;font-style:normal;font-weight:800}
.fbt-det-rate i{color:var(--text-4);font-style:normal;font-weight:600;font-size:11px}
.fbt-det-rate-empty{color:var(--text-4);font-weight:600}
.fbt-star{color:rgba(255,255,255,.2);font-size:12px;line-height:1}
.fbt-star.is-full{color:#FBBF24}
.fbt-star.is-half{
  background:linear-gradient(90deg,#FBBF24 50%,rgba(255,255,255,.2) 50%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

.fbt-det-pricerow{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;}
.fbt-det-price{
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--f-sans);font-size:18px;font-weight:800;
  color:var(--accent,#C4B5FD);letter-spacing:-.02em;
}
.fbt-det-price .sar{width:13px;height:13px;fill:currentColor}
.fbt-det-strike{
  font-family:var(--f-sans);font-size:12.5px;font-weight:700;
  color:var(--text-4);text-decoration:line-through;
}
.fbt-det-save{
  display:inline-flex;align-items:center;
  padding:3px 8px;border-radius:999px;
  background:linear-gradient(135deg,rgba(34,197,94,.24),rgba(16,185,129,.22));
  border:1px solid rgba(52,211,153,.4);
  color:#86EFAC;
  font-family:var(--f-sans);font-size:11px;font-weight:800;
  letter-spacing:.01em;
}

.fbt-det-excerpt{
  margin:0;
  font-family:var(--f-ar);font-size:12px;line-height:1.7;
  color:var(--text-2);letter-spacing:-.005em;
}

.fbt-det-feat{
  list-style:none;margin:0;padding:0;
  display:grid;gap:4px;
  border-top:1px solid rgba(255,255,255,.05);
  padding-top:10px;
}
.fbt-det-feat li{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  font-family:var(--f-ar);font-size:11.5px;
}
.fbt-det-feat span{color:var(--text-3);font-weight:600}
.fbt-det-feat b{color:var(--text);font-weight:700;letter-spacing:-.005em;text-align:end}

.fbt-det-actions{
  display:flex;align-items:stretch;
  margin-top:4px;
}
.fbt-det-confirm,
.fbt-det-show-alts{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  flex:1;
  padding:11px 16px;border-radius:10px;
  border:1px solid rgba(196,181,253,.5);
  color:#fff;
  font-family:var(--f-ar);font-size:12.5px;font-weight:800;
  letter-spacing:-.005em;
  cursor:pointer;
  transition:transform .16s ease,box-shadow .16s ease,filter .16s ease,background .2s ease;
}
.fbt-det-confirm{
  background:linear-gradient(100deg,#6311B9 0%,#A855F7 100%);
  box-shadow:0 10px 24px -12px rgba(99,17,185,.7);
}
.fbt-det-confirm:hover{transform:translateY(-1px);filter:brightness(1.08);box-shadow:0 14px 28px -12px rgba(99,17,185,.8)}
.fbt-det-show-alts{
  background:rgba(99,17,185,.16);
  border-color:rgba(196,181,253,.35);
  color:#E6DCFF;
}
.fbt-det-show-alts:hover{
  background:rgba(99,17,185,.3);
  border-color:rgba(196,181,253,.65);
  color:#fff;
  transform:translateY(-1px);
}

/* Kicker above "current" item detail — signals "you have this" */
.fbt-det-kicker{
  align-self:flex-start;
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 10px;border-radius:999px;
  background:rgba(34,197,94,.14);
  border:1px solid rgba(34,197,94,.28);
  color:#86EFAC;
  font-family:var(--f-ar);font-size:11px;font-weight:700;
  letter-spacing:-.005em;
  margin-bottom:-4px;
}
.fbt-det-kicker::before{
  content:"";
  width:6px;height:6px;border-radius:50%;
  background:#22C55E;
  box-shadow:0 0 0 3px rgba(34,197,94,.25);
}

/* Hover hint for clickable FBT image+name (non-main) */
.fbt-slot .fbt-item:not(.is-main) .fbt-media,
.fbt-slot .fbt-item:not(.is-main) .fbt-name{
  transition:opacity .16s ease,transform .16s ease;
}
.fbt-slot .fbt-item:not(.is-main) .fbt-media:hover{opacity:.85}
.fbt-slot .fbt-item:not(.is-main) .fbt-name:hover{color:#C4B5FD}
.fbt-det-full{
  align-self:flex-start;
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--f-ar);font-size:11.5px;font-weight:700;
  color:var(--text-3);text-decoration:none;
  padding:4px 0;
  margin-top:-2px;
  transition:color .16s ease,transform .16s ease;
}
.fbt-det-full svg{opacity:.7;transition:transform .18s ease,opacity .18s ease}
.fbt-det-full:hover{color:#C4B5FD;}
.fbt-det-full:hover svg{opacity:1;transform:translate(2px,-2px)}

@media (max-width:640px){
  /* Glued inline preview — visual extension of the product row, no separate box */
  .fbt-alts{padding:0!important;background:transparent!important;border:0!important;position:relative;margin:0;border-radius:0}
  /* Slot itself wraps both row + panel as one continuous unit (subtle tint when open) */
  .fbt-slot:has(.fbt-alts:not([hidden])){background:rgba(99,17,185,.04)}
  /* Header: close × pinned to top-end corner (start in RTL flow), no full row */
  .fbt-alts-head,.fbt-alts-head-end{position:absolute;top:6px;inset-inline-end:6px;padding:0;background:none;border:0;z-index:5;justify-content:flex-end;min-height:0}
  .fbt-alts-close{width:26px;height:26px;border-radius:50%;background:rgba(0,0,0,.4)!important;backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.1)!important;font-size:14px}
  .fbt-det-back{padding:5px 10px;font-size:11.5px;border-radius:6px}
  /* 2x2 grid — row 1: image | info, row 2 (fixed 36px): thumbs | button locked at exact same Y */
  .fbt-det-body{display:grid!important;grid-template-columns:96px 1fr;grid-template-rows:auto 36px;gap:6px 10px;padding:10px 12px 10px}
  .fbt-det-main{grid-column:1;grid-row:1;aspect-ratio:1;border-radius:9px}
  .fbt-det-info{grid-column:2;grid-row:1;display:flex;flex-direction:column;gap:5px;min-width:0;justify-content:center}
  /* Row 2: thumbs as flex of fixed-size squares + button matching same height */
  .fbt-det-gal{grid-column:1;grid-row:2;display:flex!important;justify-content:space-between;gap:4px;height:36px;align-self:start;width:96px}
  .fbt-det-gal .fbt-det-thumb{width:28px;height:28px;aspect-ratio:auto;margin:0;align-self:center}
  .fbt-det-actions{grid-column:2;grid-row:2;height:36px;align-self:start;display:flex;align-items:center;padding:0;margin:0}
  .fbt-det-actions .fbt-det-confirm,.fbt-det-actions .fbt-det-show-alts{height:36px;padding:0 14px;line-height:1;display:flex;align-items:center;justify-content:center;width:100%}
  .fbt-det-thumb{aspect-ratio:1;border-radius:6px;border-width:1.5px}
  .fbt-det-thumb:nth-child(n+4){display:none}
  .fbt-det-thumb.is-active{border-color:var(--brand-lav);box-shadow:0 0 0 1.5px rgba(99,17,185,.35)}
  .fbt-det-nav{display:none!important}
  /* Info column */
  .fbt-det-info{gap:4px}
  .fbt-det-name{font-size:12.5px;font-weight:800;line-height:1.3;text-align:right}
  /* Show rating placeholder ("جديد") instead of hiding — keeps row balanced */
  .fbt-det-rate-empty{display:inline-flex!important;color:var(--text-3)}
  .fbt-det-rate-empty .fbt-star{color:rgba(251,191,36,.35)}
  /* Meta row: rating + sales side by side */
  .fbt-det-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;direction:rtl}
  .fbt-det-rate{font-size:10.5px;gap:3px}
  .fbt-det-rate .fbt-star{font-size:10px}
  .fbt-det-sales{display:inline-flex;align-items:center;gap:4px;font-family:var(--f-ar);font-size:11px;font-weight:800;color:var(--amber);unicode-bidi:isolate}
  .fbt-det-sales svg{width:11px;height:11px;flex:none;color:var(--amber);opacity:.95}
  /* Compact variant picker — label+name on top row, dots only below */
  .fbt-det-variants{display:flex;flex-direction:column;gap:4px;margin:0;direction:rtl}
  .fbt-det-var-head{display:flex;align-items:baseline;gap:4px;font-family:var(--f-ar);font-size:10.5px}
  .fbt-det-var-label{color:var(--text-3);font-weight:700}
  .fbt-det-var-active-name{color:var(--text);font-weight:800;font-size:11px}
  .fbt-det-var-list{display:flex;gap:6px;flex-wrap:wrap}
  /* Dot-only swatch — colored circle, ring on active */
  .fbt-det-var-swatch{width:18px;height:18px;border-radius:50%;background:var(--sw,#444);border:1.5px solid rgba(255,255,255,.18);cursor:pointer;padding:0;flex:none;box-shadow:inset 0 0 0 1px rgba(0,0,0,.15);transition:transform .15s,box-shadow .15s}
  .fbt-det-var-swatch:hover{transform:scale(1.1)}
  .fbt-det-var-swatch.is-active{box-shadow:0 0 0 2px var(--brand-lav),inset 0 0 0 1px rgba(0,0,0,.2);transform:scale(1.05)}
  /* Price row — gap from .fbt-det-info handles spacing; no extra margin */
  .fbt-det-pricerow{gap:6px;align-items:center;flex-wrap:wrap;direction:rtl;margin:0}
  .fbt-det-price{font-size:15.5px;font-weight:900;color:var(--amber)}
  .fbt-det-price .sar{width:11px;height:12px}
  .fbt-det-strike{font-size:11px;opacity:.55}
  /* direction:ltr forces "-14%" to render correctly (bidi was flipping minus to end) */
  .fbt-det-save{font-size:9.5px;padding:1.5px 5px;font-weight:800;border-radius:5px;direction:ltr;unicode-bidi:isolate}
  /* Bundle ribbon */
  .fbt-det-bundle-ribbon{font-size:8px;padding:1.5px 5px;top:3px;inset-inline-start:3px;border-radius:4px}
  /* Action area — pinned to bottom of info column (aligns with thumbs row visually) */
  .fbt-det-actions{padding:0;margin-top:auto;display:flex;justify-content:flex-end}
  .fbt-det-confirm,.fbt-det-show-alts{font-size:11.5px;padding:7px 12px;width:auto;justify-content:center;gap:5px;border-radius:7px}
  .fbt-det-confirm svg,.fbt-det-show-alts svg{width:12px;height:12px}
}

/* Screen-reader-only utility — visually hidden but read by assistive tech.
   Paired with role="status"/aria-live="polite" for the FBT swap announcer. */
.sr-only{
  position:absolute!important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* ── Review Photo Lightbox ── */
.pv-lb{position:fixed;inset:0;z-index:9000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .22s;}
.pv-lb.is-open{opacity:1;pointer-events:all;}
.pv-lb-backdrop{position:absolute;inset:0;background:rgba(5,2,14,.93);backdrop-filter:blur(6px);}
.pv-lb-img-wrap{position:relative;z-index:1;max-width:min(88vw,860px);max-height:74vh;display:flex;align-items:center;justify-content:center;}
.pv-lb-img-wrap img{max-width:100%;max-height:74vh;object-fit:contain;border-radius:14px;box-shadow:0 24px 80px rgba(0,0,0,.7);transition:opacity .18s;}
.pv-lb-close{position:absolute;top:20px;inset-inline-end:20px;z-index:2;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;}
.pv-lb-close:hover{background:rgba(255,255,255,.22);}
.pv-lb-close svg{width:18px;height:18px;}
.pv-lb-prev,.pv-lb-next{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.08);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;}
.pv-lb-prev:hover,.pv-lb-next:hover{background:rgba(255,255,255,.2);}
.pv-lb-prev{inset-inline-end:20px;}
.pv-lb-next{inset-inline-start:20px;}
.pv-lb-prev svg,.pv-lb-next svg{width:20px;height:20px;}
.pv-lb-bottom{position:absolute;bottom:0;inset-inline:0;z-index:2;padding:20px 24px;background:linear-gradient(to top,rgba(5,2,14,.85) 0%,transparent 100%);display:flex;flex-direction:column;align-items:center;gap:6px;}
.pv-lb-counter{font-size:12px;color:rgba(255,255,255,.5);letter-spacing:.04em;}
.pv-lb-meta{text-align:center;}
.pv-lb-author{display:block;font-size:13px;font-weight:600;color:#fff;margin-bottom:4px;}
.pv-lb-text{font-size:13px;color:rgba(255,255,255,.65);margin:0;max-width:520px;line-height:1.5;}
.pv-rv-item-photo{cursor:pointer;transition:opacity .15s;}
.pv-rv-item-photo:hover{opacity:.85;}
.pv-rv-photo-thumb{cursor:pointer;}

.pv-lb-stars{display:flex;gap:2px;justify-content:center;margin-bottom:6px;}
.pv-lb-variant{font-size:11px;color:rgba(255,255,255,.45);margin-bottom:4px;}

/* lightbox overrides — bigger image */
.pv-lb{flex-direction:column;gap:0;}
.pv-lb-img-wrap{max-width:min(92vw,1000px);max-height:78vh;flex:1;display:flex;align-items:center;justify-content:center;}
.pv-lb-img-wrap img{max-width:100%;max-height:78vh;border-radius:10px;}
.pv-lb-bottom{position:relative;padding:12px 20px 16px;background:transparent;gap:4px;}
.pv-lb-counter{font-size:11px;}
.pv-lb-author{font-size:13px;}
.pv-lb-variant{font-size:11px;color:rgba(255,255,255,.4);}
.pv-lb-text{font-size:12px;margin:0;}

/* lightbox — max image size */
.pv-lb-img-wrap{max-width:min(96vw,1200px);max-height:85vh;}
.pv-lb-img-wrap img{max-height:85vh;}

/* ── Digital / Package product overrides ── */
.gallery-pkg-brand{
  width:100%;flex:1;min-height:400px;
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse at 60% 40%, color-mix(in srgb, var(--brand,#6311B9) 35%, transparent), transparent 70%),
             linear-gradient(135deg, color-mix(in srgb, var(--brand,#6311B9) 20%, #120A24) 0%, #120A24 100%);
  border-radius:20px;
}
.gallery-pkg-logo{max-width:180px;max-height:120px;object-fit:contain;filter:drop-shadow(0 4px 24px rgba(0,0,0,.5));}
.gallery-pkg-name{font-size:48px;font-weight:800;letter-spacing:-.02em;color:#fff;opacity:.9;}

.price-period{display:block;font-size:13px;color:var(--p-accent,#a78bfa);font-weight:500;margin-bottom:4px;letter-spacing:.02em;}

.cta-row-pkg .btn-buy{flex:1;}

.pv-pkg-feats{list-style:none;padding:0;margin:0 0 24px;display:flex;flex-direction:column;gap:10px;}
.pv-pkg-feats li{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--p-txt-2,rgba(255,255,255,.75));}
.pv-pkg-feats li svg{width:18px;height:18px;flex-shrink:0;color:var(--p-accent,#a78bfa);}

/* plan features inside info panel */
.info-pkg-feats{list-style:none;padding:0;margin:16px 0 0;display:flex;flex-direction:column;gap:8px;}
.info-pkg-feats li{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.75);}
.info-pkg-feats li svg{width:16px;height:16px;flex-shrink:0;color:#a78bfa;}

/* period inline after ريال */
.price-period{font-size:13px;font-weight:500;color:#a78bfa;margin-inline-start:6px;vertical-align:middle;}

/* package info — centered text + period fix */
#productHero .info:has(~ *) .price-period,
.cta-row-pkg ~ * .price-period { display:inline; }
.price-main .price-period{font-size:14px;font-weight:600;color:#a78bfa;margin-inline-start:8px;}

.price-main .price-period{display:inline !important;font-size:14px;font-weight:600;color:#a78bfa;margin-inline-start:8px;letter-spacing:.02em;}

.price-main-wrap{display:flex;align-items:baseline;gap:8px;}
.price-main-wrap .price-period{font-size:15px;font-weight:600;color:#a78bfa;white-space:nowrap;}

/* package variant buttons */
.pkg-variants{display:flex;flex-wrap:wrap;gap:8px;}
.pkg-var-btn{padding:8px 20px;border-radius:10px;border:1.5px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05);color:rgba(255,255,255,.75);font-size:14px;font-weight:500;cursor:pointer;transition:border-color .15s,background .15s,color .15s;}
.pkg-var-btn:hover{border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.09);}
.pkg-var-btn.active{border-color:var(--p-accent,#a78bfa);background:rgba(167,139,250,.12);color:#fff;}

/* pkg-attrs wrapper — scoped spacing for attribute groups */
.pkg-attrs{display:flex;flex-direction:column;gap:20px;margin:20px 0 24px;}
.pkg-attr-group{display:flex;flex-direction:column;gap:10px;}
.pkg-attr-group .section-label{margin-bottom:0;}

/* pkg info panel — flex column + anchor CTA to bottom ONLY when variants exist */
.info:has(.pkg-attrs){
  display:flex;
  flex-direction:column;
}
.info:has(.pkg-attrs) .cta-row-pkg{margin-top:auto;padding-top:8px;}

/* tighten urg-bar inside pkg panel */
.info:has(.pkg-attrs) .urg-bar{margin-bottom:16px;}

/* share button feedback */
.btn-icon.is-shared{color:var(--p-accent,#a78bfa);border-color:var(--p-accent,#a78bfa);background:rgba(167,139,250,.12);}

/* Color rail thumbs: when they carry a real image, make it fill + overlay a color dot */
.gal-thumb{position:relative;overflow:hidden;}
.gal-thumb img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit;}
.gal-thumb-dot{position:absolute;top:6px;inset-inline-end:6px;width:14px;height:14px;border-radius:999px;background:var(--phone-color,#1A1A1E);border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.35);}

/* Main-image prev/next arrows */
.gallery-view[data-view="photo"]{position:relative;}
.gallery-nav{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:999px;background:rgba(14,14,18,.72);border:1px solid rgba(255,255,255,.08);color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .18s ease, transform .18s ease, opacity .18s ease;opacity:.85;z-index:3;}
.gallery-nav:hover{background:rgba(167,139,250,.9);opacity:1;transform:translateY(-50%) scale(1.06);}
.gallery-nav-prev{inset-inline-start:14px;}
.gallery-nav-next{inset-inline-end:14px;}
.gallery-nav svg{display:block;}

/* Pagination dots */
.gallery-dots{position:absolute;inset-inline:0;bottom:14px;display:flex;justify-content:center;gap:7px;z-index:2;pointer-events:none;}
.gallery-dot{width:7px;height:7px;border-radius:999px;background:rgba(255,255,255,.35);transition:background .18s ease, width .18s ease;}
.gallery-dot.is-active{background:var(--p-accent,#a78bfa);width:22px;}

/* Smooth crossfade when swapping main image */
#galleryActiveImg{transition:opacity .18s ease;}
#galleryActiveImg.is-swapping{opacity:.35;}


/* ════════════════════════════════════════════════════════════
   MOBILE OVERHAUL — clean, tight product detail page (≤640px)
   Last in cascade so it wins over older mobile rules above.
   ════════════════════════════════════════════════════════════ */
@media (max-width:900px){
  /* FORCE single-column stack on mobile/tablet — gallery on top, info below.
     Higher specificity (#productHero) so it beats the desktop grid above. */
  #productHero > .hero{
    display:flex !important;
    flex-direction:column !important;
    gap:18px !important;
    padding:14px 0 0 !important;
  }
  /* Gallery thumbnail rail goes BELOW the main image on mobile — flip to row */
  .gallery-main-wrap{
    grid-template-columns:1fr !important;
    grid-template-rows:1fr auto;
    gap:10px !important;
  }
  .gallery-thumbs,
  .gallery-thumbs-rail{
    display:flex !important;
    flex-direction:row !important;
    overflow-x:auto;
    gap:8px;
    scrollbar-width:none;
    grid-row:2;
  }
  .gallery-thumbs::-webkit-scrollbar,
  .gallery-thumbs-rail::-webkit-scrollbar{display:none}
  .gallery-thumb{flex:0 0 64px;width:64px;height:64px}
}
@media (max-width:640px){
  /* Section spacing — zero hero bottom padding so .fbt margin-top:8px is the only gap */
  .hero{padding:0 12px 0}
  #productHero > .hero{gap:0 !important}
  .info{display:flex;flex-direction:column;padding:0;gap:4px;margin-top:-12px}
  .info-brand{font-size:10px;letter-spacing:.18em;margin-bottom:4px;color:var(--p-c-brand-2)}
  .title{font-size:22px;line-height:1.18;letter-spacing:-.02em;margin:0}
  .crumb-trail{font-size:11px}

  /* Rating — Trust Strip (design 6) */
  .rating{gap:0;margin-bottom:0;flex-wrap:nowrap}
  .stars{font-size:11px}
  .rating-num{font-size:12px;margin-inline-start:4px}
  .rating-count{font-size:10px}
  .rating-sold{font-size:10.5px}
  .rating-sold::before{margin:0 8px;height:12px}

  /* Price block — keep current sizing but tighten gaps */
  .price-block{margin-top:0;margin-bottom:0;gap:4px}
  .price-main{font-size:30px;letter-spacing:-.02em}
  .price-sub{gap:8px;flex-wrap:wrap}
  .price-old{font-size:14px}
  .price-save-tag{font-size:11px;padding:3px 8px}

  /* Installment line tighter */
  .price-inst{font-size:12px;line-height:1.4;margin-top:0;margin-bottom:0;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:10px}
  .inst-brands{gap:6px}

  /* Guaranteed visual order — reset all info children high, then pull key ones down */
  .info>*{order:99}
  .info .info-brand{order:1}
  .info .title{order:2}
  .info .crumb-trail{order:3}
  .info .rating{order:4}
  .info .dx-stock-live{order:4}
  .info .price-block{order:5}
  .info .price-inst{order:6}
  .info .section-label:has(#colorLabel){order:7}
  .info .variants{order:8}
  .info .section-label:has(#storageLabel){order:9}
  .info .storage{order:10}
  .info .urg-bar{order:20}
  .info .cta-row{order:30}

  /* Variant pickers */
  .section-label{font-size:12px;margin-bottom:4px;margin-top:2px}
  .variants{margin-bottom:0}
  .storage{display:flex;flex-wrap:nowrap;gap:6px;margin:0}
  .urg-bar{margin:6px 0}
  .cta-row{margin-top:0}
  .storage button{
    flex:1 1 0;
    padding:11px 8px;font-size:12px;font-weight:600;
    border-radius:14px;margin:0;min-width:0;
  }

  /* Trust strip — inline row, packed start */
  .urg-trust{gap:0;flex-wrap:nowrap;justify-content:flex-start;overflow:hidden}
  .urg-trust-item{padding:2px 0;gap:4px;flex:none}
  .urg-trust-item+.urg-trust-item::before{width:1px;height:12px;margin:0 8px;font-size:unset;font-weight:unset}
  .urg-trust-ic{width:12px;height:12px}
  .urg-trust-ic svg{width:12px;height:12px}
  .urg-trust-txt b{font-size:10.5px;white-space:nowrap}
  .urg-trust-txt small{display:none}
  .urg-txt{font-size:10.5px;min-width:0}
  .urg-chip{font-size:11.5px;padding:3px 9px;font-family:var(--f-ar);font-weight:800;letter-spacing:0;white-space:nowrap;line-height:1.5;border-radius:6px}

  /* In-page CTA on mobile */
  .cta-row{
    position:static !important;
    display:flex !important;
    align-items:center;
    padding:10px 14px !important;
    border-radius:14px;
    border:1px solid rgba(255,255,255,.07);
    box-shadow:none;
    background:rgba(255,255,255,.03);
    margin:4px 0 0 !important;
    gap:8px !important;
  }
  /* Compact quantity stepper */
  .cta-row .qty{
    flex-shrink:0;
    display:inline-flex;align-items:center;gap:4px;
    background:rgba(255,255,255,.06);
    border-radius:10px;
    padding:4px;
    border:1px solid var(--p-c-line-2);
  }
  .cta-row .qty button,
  .cta-row .qty .qty-btn{
    width:28px;height:28px;
    background:transparent;border:0;color:#fff;
    font-size:16px;cursor:pointer;
  }
  .cta-row .qty input,
  .cta-row .qty .qty-val{
    width:24px;text-align:center;
    background:transparent;border:0;color:#fff;
    font-size:14px;font-weight:700;
    -moz-appearance:textfield;
  }
  /* Hide share button on mobile — keep nav primary */
  .cta-row .btn-share,
  .cta-row .share-btn,
  .cta-row [aria-label*="مشاركة"]{display:none !important}
  /* Buy button — flex grow, single line */
  .cta-row .btn-buy,
  .cta-row [type="submit"],
  .cta-row .single_add_to_cart_button{
    flex:1 !important;
    font-size:14px !important;
    padding:13px 14px !important;
    white-space:nowrap;
    text-overflow:ellipsis;
    overflow:hidden;
  }

  /* Tabs — Pill Segment (iOS-style) — chosen design #2 */
  .pdp-tabs-bar{padding:8px 14px;margin-top:8px!important;margin-bottom:0!important}
  .pdp-tabs-bar::after{display:none!important}
  .pdp-tabs-bar .pdp-tabs{display:flex!important;width:100%!important;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07);padding:3px!important;border-radius:10px;gap:2px!important;overflow:visible!important;flex-wrap:nowrap;justify-content:stretch;box-sizing:border-box}
  .pdp-tabs::-webkit-scrollbar{display:none}
  .pdp-tabs-bar .pdp-tab{flex:1!important;display:flex!important;align-items:center!important;justify-content:center!important;text-align:center;padding:9px 4px!important;font-size:12.5px!important;font-weight:700!important;line-height:1.2!important;color:rgba(255,255,255,.6);border:0;background:transparent;border-radius:8px;white-space:nowrap;transition:all .25s;font-family:var(--f-ar);box-shadow:none!important}
  .pdp-tabs-bar .pdp-tab.is-active{background:linear-gradient(135deg,#7C3AED,#6311B9)!important;color:#fff!important;box-shadow:0 4px 12px rgba(99,17,185,.4),inset 0 1px 0 rgba(255,255,255,.1)!important}
  .pdp-tabs-bar .pdp-tab::after{display:none!important}
  .pdp-tabs-bar .pdp-tab.is-active::before{display:none!important}
  /* Reviews — clean strip: ★★★★★ visual + 4.7 + total count, then filter chips */
  .pv-rv-grid{display:flex!important;flex-direction:column!important;gap:10px}
  .pv-rv-aside{background:transparent!important;border:0!important;padding:0!important;display:flex!important;flex-direction:column!important;gap:10px!important}
  .pv-rv-summary-strip{display:flex;align-items:center;gap:8px;direction:rtl;line-height:1;min-height:18px}
  .pv-rv-summary-strip .pv-rv-stars{display:inline-flex!important;align-items:center;gap:2px;direction:ltr;line-height:1;height:18px;margin:0!important;padding:0!important}
  .pv-rv-summary-strip .pv-rv-stars svg{width:15px;height:15px;color:#FBBF24;fill:currentColor;display:block;filter:none!important}
  .pv-rv-summary-strip .pv-rv-stars svg.is-empty{color:rgba(255,255,255,.18)}
  .pv-rv-summary-strip .pv-rv-stars svg.is-half{color:#FBBF24;opacity:.5}
  .pv-rv-summary-strip .pv-rv-score{display:inline-flex!important;align-items:center;font-size:14px!important;font-weight:800!important;color:#fff!important;margin:0!important;line-height:1;height:18px;letter-spacing:0!important;font-family:inherit!important}
  .pv-rv-summary-strip .pv-rv-total{display:inline-flex!important;align-items:center;font-size:14px!important;color:#fff!important;font-weight:800!important;direction:rtl;line-height:1;height:18px}
  .pv-rv-summary-strip .pv-rv-total::before{content:"·";margin-inline-end:5px;color:rgba(255,255,255,.4);font-weight:600}
  /* Force the reviews main column to respect parent width (no horizontal overflow) */
  .pv-rv-main{width:100%!important;max-width:100%!important;min-width:0!important;overflow-x:hidden}
  /* Customer photos head + strip — fit mobile width */
  .pv-rv-photos-head{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:8px!important;margin-bottom:8px!important;flex-wrap:wrap;width:100%!important;max-width:100%!important;min-width:0!important;direction:rtl}
  .pv-rv-photos-head h4{font-size:13px!important;font-weight:800!important;line-height:1.2!important;margin:0!important;flex:0 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis}
  .pv-rv-photos-head span{font-size:10.5px!important;color:rgba(255,255,255,.5)!important;font-weight:700;flex:0 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .pv-rv-photos-strip{display:flex!important;gap:6px!important;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:2px 0 6px!important;margin-bottom:10px!important;max-width:100%!important;width:100%!important}
  .pv-rv-photos-strip::-webkit-scrollbar{display:none}
  .pv-rv-photo-thumb{flex:0 0 64px!important;width:64px!important;height:64px!important;scroll-snap-align:start;border-radius:8px!important;margin:0!important}
  /* Rating link — clickable, jumps to reviews tab */
  .rating-link{display:inline-flex;align-items:center;gap:0;text-decoration:none;color:inherit;cursor:pointer;padding:2px 0;border-radius:4px;transition:opacity .15s}
  .rating-link .rating-num{margin-inline-start:0!important;margin-inline-end:5px}
  .rating-link:hover{opacity:.75}
  .rating-link:active{opacity:.55}
  /* Related rails (rel-strip) — convert grid to horizontal swipeable rail */
  .rel-rows{padding:0 0 16px!important;margin-top:12px!important}
  /* Active panel handles its own bottom gap (12px); zero out so it doesn't add to rel-rows margin-top */
  .container.pdp-panel{margin-bottom:0!important}
  .rel-row{margin-bottom:12px!important}
  .rel-row:last-child{margin-bottom:0!important}
  .rel-row-head{margin-bottom:8px!important}
  .rel-row-head h2{font-size:15px!important;line-height:1.3!important}
  .rel-row-head p{font-size:11px!important;color:rgba(255,255,255,.5)!important}
  .rel-row-all{font-size:11px!important}
  .rel-strip{display:flex!important;grid-template-columns:none!important;flex-direction:row;gap:10px!important;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:4px 0 8px}
  .rel-strip::-webkit-scrollbar{display:none}
  .rel-strip > .pc-card{flex:0 0 158px!important;width:158px!important;max-width:158px!important;scroll-snap-align:start;padding:0!important;overflow:hidden}
  .rel-strip > .pc-card .pc-media{margin:0!important;padding:0!important;width:100%}
  .rel-strip > .pc-card .pc-media img{width:100%!important;height:100%!important;display:block}
  .rel-strip > .pc-card .pc-body{padding:8px 10px 10px!important;gap:3px!important}
  .rel-strip > .pc-card .pc-cat{font-size:9px!important;line-height:1.1!important;margin:0!important;padding:0!important}
  .rel-strip > .pc-card .pc-name{font-size:11.5px!important;line-height:1.3!important;margin:0!important;padding:0!important;-webkit-line-clamp:2;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}
  .rel-strip > .pc-card .pc-signals{margin:2px 0 0!important;padding:0!important;flex-wrap:wrap;gap:4px}
  .rel-strip > .pc-card .pc-foot{margin:0!important;padding:0!important}
  .rel-strip > .pc-card .pc-price-col{gap:0!important;padding:0!important;margin:0!important}
  .rel-strip > .pc-card .pc-price-old,
  .rel-strip > .pc-card .pc-price,
  .rel-strip > .pc-card .pc-inst{margin:0!important;padding:0!important;line-height:1.2!important}
  .rel-strip > .pc-card .pc-price{font-size:14px!important}
  .rel-strip > .pc-card .pc-inst{font-size:10px!important}
  /* Digital subscription cards inside PDP related rails — match homepage design, just constrain width for horizontal scroll */
  .rel-strip > .dl-card{flex:0 0 158px!important;width:158px!important;max-width:158px!important;scroll-snap-align:start}
  .rel-strip:has(> .dl-card:only-child){justify-content:flex-start}
  /* Reviews list — show ~1.5 reviews, fade-out + floating "Show more" button */
  .pv-rv-list{position:relative}
  .pv-rv-list:not(.is-expanded){max-height:560px;overflow:hidden;mask-image:linear-gradient(180deg,#000 78%,transparent 100%);-webkit-mask-image:linear-gradient(180deg,#000 78%,transparent 100%)}
  .pv-rv-list.is-expanded{max-height:none;overflow:visible}
  .pv-rv-show{position:absolute;bottom:8px;inset-inline:0;margin:0 auto;width:fit-content;display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;background:#1A1428;border:1px solid rgba(167,139,250,.4);color:#A78BFA;border-radius:999px;font-family:var(--f-ar);font-size:12px;font-weight:800;cursor:pointer;transition:all .2s;box-shadow:0 6px 20px rgba(0,0,0,.5);z-index:5;white-space:nowrap}
  .pv-rv-list.is-expanded ~ .pv-rv-show,
  .pv-rv-list.is-expanded + .pv-rv-show{position:static;margin-top:14px;background:rgba(167,139,250,.08)}
  .pv-rv-show:hover{background:rgba(167,139,250,.15);border-color:#A78BFA;color:#fff}
  .pv-rv-show svg{width:13px;height:13px;transition:transform .25s ease}
  .pv-rv-list.is-expanded ~ .pv-rv-show svg{transform:rotate(180deg)}
  .pv-rv-show .t-more{display:inline}
  .pv-rv-show .t-less{display:none}
  .pv-rv-list.is-expanded ~ .pv-rv-show .t-more{display:none}
  .pv-rv-list.is-expanded ~ .pv-rv-show .t-less{display:inline}
  /* Tighter review item — reduce top/bottom padding */
  .pv-rv-item{padding:10px 0 12px!important}
  .pv-rv-item-actions{margin-top:6px!important}
  /* Variant chip — purple-tinted pill, more distinct */
  .pv-rv-item-meta{display:inline-flex!important;align-items:center;gap:5px;padding:4px 10px!important;background:rgba(99,17,185,.14)!important;border:1px solid rgba(167,139,250,.22)!important;border-radius:999px!important;font-size:10.5px!important;font-weight:700!important;color:#C4B5FD!important;margin:6px 0 8px!important;width:fit-content;font-family:var(--f-ar)!important}
  /* Bigger action buttons (32px touch targets) */
  .pv-rv-item-actions .rv-like{height:32px!important;padding:0 8px!important;font-size:12px!important}
  .pv-rv-item-actions .rv-like svg{width:15px!important;height:15px!important}
  .pv-rv-item-actions .rv-report{padding:8px 4px!important;font-size:11px!important;min-height:32px!important;display:inline-flex;align-items:center}
  /* Per-review photos: smaller + horizontal scroll (no 2-line wrap) */
  .pv-rv-item-photos{display:flex!important;gap:5px!important;flex-wrap:nowrap!important;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-top:6px!important;padding-bottom:2px}
  .pv-rv-item-photos::-webkit-scrollbar{display:none}
  .pv-rv-item-photo{flex:0 0 50px!important;width:50px!important;height:50px!important;border-radius:6px!important;scroll-snap-align:start}
  /* Container query — chips auto-scale based on actual panel width */
  .container.pdp-panel.is-active[data-panel="reviews"]{container-type:inline-size;container-name:rvpanel}
  .pv-rv-dist{display:flex!important;flex-direction:row!important;gap:clamp(3px,1cqi,5px)!important;overflow:hidden!important;flex-wrap:nowrap!important;justify-content:space-between!important;padding:0 0 2px!important;margin:0!important;background:transparent!important;border:0!important;min-width:0!important;max-width:100%!important;width:100%!important;box-sizing:border-box!important}
  .pv-rv-dist::-webkit-scrollbar{display:none}
  .pv-rv-dist-row{display:inline-flex!important;align-items:center;justify-content:center;gap:3px!important;padding:clamp(4px,1.2cqi,6px) clamp(6px,2.4cqi,11px)!important;margin:0!important;background:rgba(255,255,255,.05)!important;border:1px solid rgba(255,255,255,.1)!important;border-radius:7px!important;font-size:clamp(9px,2.9cqi,11px)!important;font-weight:700!important;color:rgba(255,255,255,.7)!important;cursor:pointer;flex:1 1 auto!important;white-space:nowrap;min-height:28px;min-width:0;width:auto;height:auto;aspect-ratio:auto;direction:ltr;unicode-bidi:isolate}
  .pv-rv-dist-row[data-pv-rating="all"]{direction:rtl}
  .pv-rv-dist-row[data-pv-rating="all"] .pv-rv-dist-pct{display:none!important}
  .pv-rv-dist-row.is-active{background:rgba(99,17,185,.2)!important;border-color:#A78BFA!important;color:#fff!important}
  .pv-rv-dist-label{display:inline-flex!important;align-items:center;gap:1px;flex:0 0 auto!important;width:auto!important;padding:0!important;margin:0!important}
  .pv-rv-dist-label svg{width:10px;height:10px;color:#FBBF24;margin:0!important}
  .pv-rv-dist-bar{display:none!important}
  .pv-rv-dist-pct{display:inline!important;font-size:10px!important;font-weight:700;color:inherit;opacity:.6;direction:ltr;unicode-bidi:isolate;flex:0 0 auto!important;width:auto!important;margin:0!important;padding:0!important;text-align:left}
  /* Review item actions: Like (with count, used for sort) + report link */
  .pv-rv-item-actions{display:flex;align-items:center;justify-content:flex-start;gap:14px;margin-top:8px}
  .pv-rv-item-actions .rv-like{display:inline-flex;align-items:center;gap:5px;height:30px;padding:0 6px;background:transparent;border:0;color:rgba(255,255,255,.55);cursor:pointer;font-family:inherit;font-size:11.5px;font-weight:700;border-radius:6px;transition:color .15s,background .15s}
  .pv-rv-item-actions .rv-like:hover{color:#A78BFA;background:rgba(167,139,250,.08)}
  .pv-rv-item-actions .rv-like.is-marked{color:#86EFAC}
  .pv-rv-item-actions .rv-like svg{width:14px;height:14px;flex:none}
  .pv-rv-item-actions .rv-like b{font-weight:800;direction:ltr;unicode-bidi:isolate}
  .pv-rv-item-actions .rv-report{background:transparent;border:0;padding:4px 0;color:rgba(255,255,255,.45);cursor:pointer;font-family:inherit;font-size:10.5px;font-weight:600;text-decoration:underline;text-underline-offset:2px;transition:color .15s}
  .pv-rv-item-actions .rv-report:hover{color:#FCA5A5}
  /* Compact "Write your review" CTA on mobile */
  .pv-rv-write{padding:11px 14px!important;margin-bottom:14px!important;background:rgba(255,255,255,.025)!important;border:1px dashed rgba(167,139,250,.25)!important;border-radius:10px!important}
  .pv-rv-write::before{display:none!important}
  .pv-rv-write-head{gap:10px!important}
  .pv-rv-write-icon{flex:0 0 30px!important;width:30px!important;height:30px!important;border-radius:50%!important;background:rgba(167,139,250,.2)!important;color:#A78BFA!important;box-shadow:none!important}
  .pv-rv-write-icon svg{width:14px!important;height:14px!important}
  .pv-rv-write-title{font-size:12px!important;font-weight:800!important;margin:0 0 1px!important;color:#fff!important}
  .pv-rv-write-sub{font-size:10.5px!important;color:rgba(255,255,255,.55)!important;line-height:1.35}
  .pv-rv-write-btn{padding:6px 12px!important;font-size:11px!important;background:rgba(167,139,250,.18)!important;color:#A78BFA!important;border-radius:8px!important;flex:none}
  .pv-rv-write-btn svg{width:11px!important;height:11px!important}
  .pv-rv-write-btn:hover{transform:none!important;box-shadow:none!important;background:rgba(167,139,250,.3)!important;color:#fff!important}
  /* Overview body — single column on mobile (was 2-col, made text cramped) */
  .pv-ov-body{column-count:1!important;column-gap:0!important;column-rule:0!important;font-size:13.5px;line-height:1.75;color:var(--text-2)}
  .pv-ov-body p{margin:0 0 10px}
  /* "From the manufacturer" marketing layout — Amazon-style image + text blocks */
  .pv-mfr{display:flex;flex-direction:column;gap:24px}
  .pv-mfr-kicker{font-family:var(--f-ar);font-size:10.5px;font-weight:800;color:#FBBF24;text-transform:uppercase;letter-spacing:.08em;margin:0 0 4px;padding-bottom:8px;border-bottom:1px solid rgba(251,191,36,.18);direction:ltr;text-align:right}
  .pv-mfr-block{margin:0;padding:0;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.06);border-radius:14px;overflow:hidden}
  .pv-mfr-img{margin:0;padding:0;width:100%;aspect-ratio:16/10;background:rgba(0,0,0,.3);overflow:hidden;display:block}
  .pv-mfr-img img{width:100%;height:100%;object-fit:cover;display:block}
  .pv-mfr-content{padding:14px 14px 16px}
  .pv-mfr-block h3{font-family:var(--f-ar);font-size:15.5px;font-weight:800;color:#fff;margin:0 0 8px;line-height:1.35;letter-spacing:-.005em}
  .pv-mfr-block h4{font-family:var(--f-ar);font-size:12.5px;font-weight:800;color:#A78BFA;margin:10px 0 4px}
  .pv-mfr-block p{font-size:12.5px;line-height:1.75;color:rgba(255,255,255,.72);margin:0 0 8px}
  .pv-mfr-block p:last-child{margin-bottom:0}
  .pv-mfr-stat{font-family:var(--f-display,Cairo);font-size:20px!important;font-weight:900!important;color:#A78BFA!important;letter-spacing:-.02em;margin:8px 0 0!important;line-height:1.1!important}
  .pv-mfr-bullets{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:5px}
  .pv-mfr-bullets li{position:relative;padding-inline-start:14px;font-size:11.5px;line-height:1.55;color:rgba(255,255,255,.7)}
  .pv-mfr-bullets li::before{content:"";position:absolute;inset-inline-start:0;top:8px;width:5px;height:5px;border-radius:50%;background:#A78BFA}
  .pv-mfr-bullets li b{color:#fff;font-weight:800;margin-inline-end:3px}
  /* Overview "show more" — clip to ~1.5 blocks with fade-out gradient + floating button */
  .pv-mfr{position:relative}
  .pv-mfr-block{flex-shrink:0}
  .pv-mfr:not(.is-expanded){max-height:560px;overflow:hidden;mask-image:linear-gradient(180deg,#000 78%,transparent 100%);-webkit-mask-image:linear-gradient(180deg,#000 78%,transparent 100%)}
  .pv-mfr.is-expanded{max-height:none;overflow:visible;mask-image:none;-webkit-mask-image:none}
  .pv-mfr-show{position:absolute;bottom:8px;inset-inline:0;margin:0 auto;width:fit-content;display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;background:#1A1428;border:1px solid rgba(167,139,250,.4);color:#A78BFA;border-radius:999px;font-family:var(--f-ar);font-size:12px;font-weight:800;cursor:pointer;transition:all .2s;box-shadow:0 6px 20px rgba(0,0,0,.5);z-index:5}
  .pv-mfr.is-expanded .pv-mfr-show{position:static;margin-top:14px;background:rgba(167,139,250,.08)}
  .pv-mfr-show:hover{background:rgba(167,139,250,.15);border-color:#A78BFA;color:#fff}
  .pv-mfr-show svg{width:13px;height:13px;transition:transform .25s ease}
  .pv-mfr.is-expanded .pv-mfr-show svg{transform:rotate(180deg)}
  .pv-mfr-show .t-more{display:inline}
  .pv-mfr-show .t-less{display:none}
  .pv-mfr.is-expanded .pv-mfr-show .t-more{display:none}
  .pv-mfr.is-expanded .pv-mfr-show .t-less{display:inline}
  /* Specs hero stats — 4 highlight cards above grouped table */
  .pv-sp-hero{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px}
  .pv-sp-stat{background:linear-gradient(135deg,rgba(99,17,185,.16),rgba(99,17,185,.06));border:1px solid rgba(167,139,250,.18);border-radius:12px;padding:10px 12px;text-align:right}
  .pv-sp-stat-num{font-size:20px;font-weight:900;color:#fff;line-height:1.1;letter-spacing:-.02em;direction:ltr;unicode-bidi:isolate}
  .pv-sp-stat-num em{font-size:11px;font-weight:700;color:#A78BFA;font-style:normal;margin-inline-start:3px}
  .pv-sp-stat-lbl{font-size:10.5px;font-weight:700;color:rgba(255,255,255,.55);margin-top:3px}
  /* Grouped specs table — clean cards */
  .pv-sp-grid{display:flex;flex-direction:column;gap:12px}
  .pv-sp-grid > div{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:10px;overflow:hidden;padding:0!important}
  /* Accordion: title is button, full-width, with chevron */
  .pv-sp-group-title{display:flex!important;justify-content:space-between!important;align-items:center;width:100%;padding:14px 14px!important;font-size:13px!important;font-weight:700!important;color:#A78BFA!important;background:rgba(99,17,185,.12);border:0;margin:0!important;cursor:pointer;font-family:var(--f-ar),"Segoe UI",Tahoma,Arial,sans-serif!important;text-align:right;letter-spacing:0!important;line-height:1.7!important;-webkit-font-smoothing:antialiased;min-height:46px}
  .pv-sp-group-title span{display:inline-block;letter-spacing:0;font-feature-settings:"liga","calt"}
  .pv-sp-group:not(.is-open) .pv-sp-group-title{border-bottom:0}
  .pv-sp-group.is-open .pv-sp-group-title{border-bottom:1px solid rgba(167,139,250,.18)}
  .pv-sp-chev{width:13px;height:13px;color:#A78BFA;transition:transform .25s ease;flex:none}
  .pv-sp-group.is-open .pv-sp-chev{transform:rotate(180deg)}
  /* Body: collapsed by default, expand on .is-open */
  .pv-sp-group-body{max-height:0;overflow:hidden;transition:max-height .3s ease,opacity .2s ease;opacity:0}
  .pv-sp-group.is-open .pv-sp-group-body{max-height:600px;opacity:1}
  .pv-sp-row{display:flex!important;justify-content:space-between!important;align-items:center;padding:8px 12px!important;font-size:11.5px!important;border-bottom:1px solid rgba(255,255,255,.04)}
  .pv-sp-grid > div .pv-sp-row:last-child{border-bottom:0}
  .pv-sp-row-label{color:rgba(255,255,255,.55)!important;font-weight:600!important;flex:none}
  .pv-sp-row-value{color:#fff!important;font-weight:700!important;text-align:left;direction:ltr;unicode-bidi:isolate}
  /* Disable fade gradient that obscures the description */
  .pv-sm-wrap::after{display:none!important}
  .pv-ov .pv-sm-wrap,
  .pv-sp .pv-sm-wrap,
  .pv-rv .pv-sm-wrap{max-height:none!important;overflow:visible!important}

  /* Section headings on PDP */
  .pdp-tab-section h2,
  .pdp-tab-section h3{font-size:16px;letter-spacing:-.01em}

  /* Gallery — compact, no fixed huge height */
  .gallery{margin-bottom:14px}
}

/* ════════════════════════════════════════════════════════════
   AMAZON LEGENDARY — 8 mobile upgrades
   Only active <=640px, scoped to .dx-* classes so desktop unaffected
   ════════════════════════════════════════════════════════════ */
.dx-mobile-only{display:none}
@media (max-width:640px){
  .dx-mobile-only{display:block}
  .dx-mobile-only.dx-flex{display:flex}
  .dx-mobile-only.dx-inline{display:inline-flex}
  .dx-desktop-only{display:none !important}

  /* 1. Sticky mini-bar — appears on scroll */
  .dx-mini{
    position:fixed;top:0;inset-inline:0;z-index:120;
    display:flex;align-items:center;gap:8px;
    background:rgba(10,6,18,.92);backdrop-filter:blur(18px) saturate(160%);
    -webkit-backdrop-filter:blur(18px) saturate(160%);
    border-bottom:1px solid rgba(255,255,255,.08);
    padding:8px 12px;
    transform:translateY(-100%);transition:transform .25s ease;
  }
  .dx-mini.is-on{transform:translateY(0)}
  .dx-mini-img{width:36px;height:36px;border-radius:8px;background:rgba(255,255,255,.06);background-size:cover;background-position:center;flex-shrink:0;border:1px solid rgba(255,255,255,.1)}
  .dx-mini-info{flex:1;min-width:0}
  .dx-mini-nm{font-family:var(--f-ar);font-size:11px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}
  .dx-mini-pr{font-family:var(--f-display);font-size:13px;font-weight:800;color:var(--brand-lav,#C4B5FD);direction:ltr;unicode-bidi:isolate}
  .dx-mini-btn{padding:8px 14px;border-radius:10px;background:linear-gradient(135deg,var(--brand,#6311B9),#8B5CF6);color:#fff;font-family:var(--f-ar);font-size:11px;font-weight:800;border:0;flex-shrink:0;cursor:pointer}

  /* 2. ETA delivery + timer */
  .dx-eta{
    display:flex;align-items:center;gap:10px;
    background:linear-gradient(135deg,rgba(52,199,89,.14),rgba(52,199,89,.04));
    border:1px solid rgba(52,199,89,.25);border-radius:14px;
    padding:12px;margin:12px 0;
  }
  .dx-eta-ic{width:36px;height:36px;border-radius:10px;background:rgba(52,199,89,.2);color:#34C759;display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .dx-eta-ic svg{width:18px;height:18px}
  .dx-eta-txt{flex:1;font-family:var(--f-ar);font-size:11.5px;color:rgba(255,255,255,.78);line-height:1.5}
  .dx-eta-txt b{color:#fff;font-weight:800}
  .dx-eta-timer{font-family:var(--f-display);font-weight:800;color:#34C759;background:rgba(52,199,89,.15);padding:1px 6px;border-radius:5px;letter-spacing:.02em;direction:ltr;unicode-bidi:isolate;display:inline-block;margin:0 2px}

  /* 3. Loyalty chip */
  .dx-loyalty{
    display:inline-flex;align-items:center;gap:6px;
    font-family:var(--f-ar);font-size:11px;color:#F5A524;
    background:rgba(245,165,36,.1);border:1px solid rgba(245,165,36,.25);
    padding:5px 10px;border-radius:999px;margin:8px 0 0;
  }
  .dx-loyalty b{color:#fff;font-family:var(--f-display);font-weight:800}

  /* 4. Verified buyers row */
  .dx-verified{
    display:flex;align-items:center;gap:8px;margin-top:10px;
    padding:8px 10px;background:rgba(255,255,255,.03);
    border-radius:10px;border:1px solid rgba(255,255,255,.08);
  }
  .dx-verified-avs{display:flex;flex-shrink:0}
  .dx-verified-avs span{
    width:22px;height:22px;border-radius:999px;
    border:2px solid var(--p-bg,#0A0612);
    background:linear-gradient(135deg,#7C3AED,#A78BFA);
    margin-inline-start:-8px;font-size:9px;color:#fff;
    display:flex;align-items:center;justify-content:center;font-weight:700
  }
  .dx-verified-avs span:first-child{margin-inline-start:0}
  .dx-verified-txt{flex:1;font-family:var(--f-ar);font-size:11px;color:rgba(255,255,255,.78)}
  .dx-verified-txt b{color:#fff;font-family:var(--f-display)}

  /* 5. Comparison ribbon */
  .dx-compare{
    display:flex;align-items:center;gap:8px;
    background:linear-gradient(135deg,rgba(99,17,185,.1),transparent);
    border:1px solid rgba(196,181,253,.2);border-radius:10px;
    padding:8px 12px;margin-top:10px;
    font-family:var(--f-ar);font-size:11px;color:rgba(255,255,255,.78);
    text-decoration:none;
  }
  .dx-compare b{color:#C4B5FD;font-weight:800}
  .dx-compare-arrow{margin-inline-start:auto;color:#C4B5FD;font-size:14px}

  /* 6. AI ask chip */
  .dx-ai{
    display:flex;align-items:center;gap:8px;
    background:linear-gradient(135deg,rgba(99,17,185,.15),rgba(139,92,246,.08));
    border:1px solid rgba(196,181,253,.25);border-radius:12px;
    padding:10px 12px;margin:14px 0;text-decoration:none;
  }
  .dx-ai-ic{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--brand,#6311B9),#8B5CF6);display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .dx-ai-ic svg{width:14px;height:14px;color:#fff}
  .dx-ai-txt{flex:1;font-family:var(--f-ar);font-size:12px;color:rgba(255,255,255,.78);line-height:1.4}
  .dx-ai-txt b{color:#fff;font-weight:800}
  .dx-ai-arrow{color:#C4B5FD;font-size:14px}

  /* 7. Trust meter live */
  .dx-trust-meter{
    background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);
    border-radius:12px;padding:12px;margin-top:10px;
  }
  .dx-trust-meter-row{display:flex;justify-content:space-between;align-items:center;font-family:var(--f-ar);font-size:11px;color:rgba(255,255,255,.78);margin-bottom:6px}
  .dx-trust-meter-row b{color:#fff;font-family:var(--f-display)}
  .dx-trust-bar{height:5px;background:rgba(255,255,255,.06);border-radius:999px;overflow:hidden}
  .dx-trust-bar span{display:block;height:100%;background:linear-gradient(90deg,#34C759,#5BE077);width:98%;animation:dxTrustPulse 2s ease-in-out infinite}
  @keyframes dxTrustPulse{0%,100%{opacity:.85}50%{opacity:1}}

  /* Gallery container — relative for overlays + strip frame chrome */
  #productHero .gallery,
  #productHero .gallery-main-wrap,
  #productHero .gallery-main{
    position:relative;
    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;
    padding:0 !important;
    border-radius:0 !important;
  }
  /* Force linear column so order works (gallery photo on top, view toggle below) */
  #productHero .gallery-main-wrap{
    display:flex !important;flex-direction:column !important;
    grid-template-columns:none !important;grid-template-rows:none !important;
    gap:0 !important;
  }

  /* Hide thumbs rail on mobile — color overlay pills on the photo replace it */
  #productHero .gallery-thumbs,
  #productHero .gallery-thumbs-rail,
  #productHero .gallery-rail,
  #productHero .gal-thumb{display:none !important}

  /* Remove the framed box around the photo — let it float on store bg with soft glow */
  #productHero .gallery-view{
    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;
    padding:0 !important;
  }
  #productHero .gallery-view[data-view="photo"]{
    position:relative;
    aspect-ratio:1;
    overflow:visible;
  }
  /* Soft radial glow under the product, blends with page background */
  #productHero .gallery-view[data-view="photo"]::before{
    content:"";position:absolute;inset:6% 0 0 0;
    background:radial-gradient(60% 55% at 50% 55%, rgba(196,181,253,.14) 0%, rgba(99,17,185,.06) 40%, transparent 75%);
    filter:blur(8px);
    pointer-events:none;z-index:0;
  }
  #productHero #galleryActiveImg,
  #productHero .gallery-view[data-view="photo"] img{
    position:relative;z-index:1;
    width:auto !important;max-width:68% !important;height:auto !important;max-height:220px !important;
    margin:0 auto;display:block;
    object-fit:contain;
    background:transparent;
    border-radius:14px;
    filter:drop-shadow(0 14px 28px rgba(0,0,0,.55));
  }
  #productHero .gallery-view[data-view="photo"]{
    aspect-ratio:auto !important;
    height:280px !important;min-height:0 !important;max-height:280px !important;
    display:flex;align-items:center;justify-content:center;
    margin:16px 0 4px;
  }
  #productHero .gallery-view[data-view="photo"]::before{inset:0}
  #productHero .gallery-main-wrap{min-height:0 !important;height:auto !important}
  #productHero .gallery-main{min-height:0 !important;height:auto !important}

  /* Functional toggle — pinned to top of gallery, buttons at corners via flex */
  #productHero .gallery-mode{
    position:absolute !important;
    top:14px !important;bottom:auto !important;
    inset-inline-start:14px !important;inset-inline-end:14px !important;
    left:14px !important;right:14px !important;
    z-index:7 !important;
    background:transparent !important;border:0 !important;padding:0 !important;
    margin:0 !important;width:auto !important;height:auto !important;
    display:flex !important;justify-content:space-between !important;align-items:center;gap:6px !important;
    pointer-events:none;
  }
  /* Toggle button - fixed right, no border */
  #productHero .gallery-mode .gm-btn{
    position:absolute !important;
    top:0 !important;
    inset-inline-start:0 !important;
    margin:0 !important;
    border:none !important;
    outline:none !important;
    box-shadow:none !important;
    pointer-events:auto;
    font-family:var(--f-ar) !important;font-size:10.5px !important;font-weight:700 !important;
    padding:6px 11px !important;height:auto !important;width:auto !important;
    border-radius:999px !important;
    background:rgba(0,0,0,.55) !important;color:rgba(255,255,255,.85) !important;
    backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    display:inline-flex !important;align-items:center;gap:5px;white-space:nowrap;cursor:pointer;
  }
  #productHero .gallery-mode .gm-btn svg{width:11px !important;height:11px !important}
  #productHero .gallery-mode .gm-btn.is-active{display:none !important}

  /* Color overlay on gallery — visible, replaces dots */
  .dx-color-overlay{display:flex !important}
  #productHero .gallery-dots{display:none !important}

  /* Shipping badge — removed per user (clutter on photo) */
  .dx-badge-shipping{display:none !important}

  /* Gallery hero — 1:1 square, image contained centered, soft glow */
  #productHero .gallery-view[data-view="photo"]{
    aspect-ratio:1/1 !important;
    height:auto !important;min-height:0 !important;max-height:none !important;
    margin:0 0 14px !important;
    display:flex;align-items:center;justify-content:center;
    position:relative;overflow:visible;
    background:transparent !important;border:0 !important;outline:0 !important;
    box-shadow:none !important;
  }
  #productHero .gallery-view[data-view="photo"] *{outline:0 !important}
  #productHero .gallery-view[data-view="photo"]::before{
    content:"";position:absolute;inset:0;
    background:radial-gradient(45% 35% at 50% 55%, rgba(196,181,253,.10) 0%, transparent 70%);
    filter:blur(20px);
    pointer-events:none;z-index:0;
  }
  #productHero #galleryActiveImg,
  #productHero .gallery-view[data-view="photo"] img{
    width:100% !important;max-width:100% !important;height:100% !important;max-height:100% !important;
    margin:0;display:block;position:relative;z-index:1;
    object-fit:cover;
    border-radius:20px;border:0 !important;outline:0 !important;
    box-shadow:none !important;filter:none !important;
  }

  /* Discount badge — hidden per user */
  .dx-badge-discount{display:none !important}
  .dx-badge-shipping{
    position:absolute;top:14px;inset-inline-start:14px;z-index:5;
    background:rgba(0,0,0,.55);color:#fff;
    font-family:var(--f-ar);font-weight:700;font-size:10.5px;
    padding:5px 10px;border-radius:999px;
    backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    border:1px solid rgba(255,255,255,.1);
    display:inline-flex;align-items:center;gap:4px;
  }
  .dx-badge-shipping::before{content:"🚚";font-size:11px}

  /* 3D view container — also transparent */
  #productHero .gallery-view[data-view="3d"]{background:transparent}
  #productHero .css3d-stage{background:transparent !important;transform:scale(.55) !important;transform-origin:center !important}
  /* Hide drag-mouse hint on mobile (touch is self-evident) */
  #productHero .gallery-3d-hint,
  #productHero .p3d-tooltip{display:none !important}

  /* Custom zoom hint + AR button — hidden, real functional gallery-mode used */
  .dx-zoom-hint,
  .dx-ar-btn{display:none !important}


  /* 8. Color overlay — pinned to the bottom of the photo */
  .dx-color-overlay{
    position:absolute;
    inset-inline:0;bottom:14px;
    display:flex;gap:14px;justify-content:center;align-items:center;
    background:transparent !important;backdrop-filter:none !important;
    border:0 !important;padding:0 !important;border-radius:0 !important;
    margin:0;
    z-index:6;pointer-events:auto;
  }
  .dx-color-pill{
    width:30px;height:30px;border-radius:999px;
    display:flex;align-items:center;justify-content:center;
    border:2px solid transparent;cursor:pointer;
    transition:transform .15s, border-color .15s;
    background:transparent;padding:0;
  }
  .dx-color-pill > span{
    width:22px;height:22px;border-radius:999px;
    border:1.5px solid rgba(255,255,255,.18);
    display:block;
    box-shadow:0 1px 4px rgba(0,0,0,.4);
  }
  .dx-color-pill.is-on{
    border-color:#fff;
    animation:dxPillPulse .4s ease;
  }
  .dx-color-pill.is-on > span{
    box-shadow:0 0 0 2px rgba(255,255,255,.15), 0 2px 8px rgba(0,0,0,.4);
  }
  @keyframes dxPillPulse{0%{transform:scale(1)}50%{transform:scale(1.18)}100%{transform:scale(1)}}

  /* 9. Hide arrows on mobile — swipe is native */
  #productHero .gallery-nav{display:none !important}

  /* 10. Swipe only — no zoom */
  #productHero .gallery-view[data-view="photo"]{touch-action:pan-y}
  #productHero #galleryActiveImg{
    transform-origin:center center;
    transition:transform .25s ease;
    will-change:transform;
  }
  #productHero #galleryActiveImg.is-zoomed{
    transition:transform .15s ease;
    cursor:zoom-out;
  }

  /* FBT — Design 4 Receipt Style on mobile */
  .fbt{padding:10px 20px 8px;position:relative}
  /* Collapse/expand toggle — chevron in top-start corner */
  .fbt-toggle{position:absolute;top:50%;inset-inline-end:24px;transform:translateY(-50%);width:26px;height:26px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:rgba(0,0,0,.55);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;z-index:5;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .15s,border-color .15s}
  .fbt-toggle:hover{background:rgba(0,0,0,.7);border-color:rgba(255,255,255,.3)}
  .fbt-toggle svg{width:13px;height:13px;transition:transform .15s ease-out}
  /* Unified mobile horizontal padding — every full-width section aligns to same edge */
  .container,
  .container.fbt,
  .container.pdp-tabs-bar,
  .container.pdp-panel{padding-left:16px!important;padding-right:16px!important;padding-inline:16px!important;width:100%!important;max-width:100%!important;box-sizing:border-box!important}
  /* Smooth collapse: native interpolate-size + height auto↔0 (Chrome 129+/Edge) */
  .fbt{interpolate-size:allow-keywords}
  .fbt .fbt-body{height:auto;overflow:hidden!important;opacity:1;box-sizing:border-box!important;transition:height .42s cubic-bezier(.33,1,.68,1),opacity .42s cubic-bezier(.33,1,.68,1)}
  .fbt.is-collapsed .fbt-body{height:0!important;opacity:0!important;pointer-events:none}
  .fbt.is-collapsed .fbt-toggle svg{transform:rotate(-90deg);transition:transform .8s ease}
  .fbt.is-collapsed .fbt-d4-header{border-radius:12px;border-bottom:1px solid rgba(248,113,113,.26)}
  /* Uniform 12px section rhythm — kill all padding+margin extras */
  .info{gap:12px!important}
  .urg-bar{margin:0!important}
  .cta-row{margin-bottom:12px!important;margin-top:0!important}
  .fbt{margin-top:0!important;margin-bottom:12px!important;padding-top:0!important;padding-bottom:0!important}
  .fbt.is-collapsed{margin-bottom:12px!important}
  /* Smooth tab panel transitions — JS toggles .is-leaving for fade-out */
  .container.pdp-panel{transition:opacity .22s ease,transform .22s ease}
  .container.pdp-panel.is-active{opacity:1;transform:none}
  .container.pdp-panel.is-active.is-leaving{opacity:0;transform:translateY(6px)}
  /* Hidden panels: zero their layout impact */
  .container.pdp-panel:not(.is-active){margin:0!important;padding:0!important;display:none!important}
  .container.pdp-panel.is-entering{opacity:0;transform:translateY(6px)}
  /* Tabs → content gap: ZERO ALL contributors except panel padding-top (which sets the actual gap) */
  .container.pdp-tabs-bar{margin:0!important;padding:0 16px!important}
  .pdp-tabs-bar > *,
  .pdp-tabs-bar > *::after,
  .pdp-tabs-bar > *::before{margin:0!important}
  .container.pdp-panel{margin-top:0!important;margin-bottom:0!important}
  .container.pdp-panel.is-active{padding:12px 16px 0!important;margin-top:0!important}
  .pdp-panel .pv-wrap{padding:0!important;margin:0!important}
  .pdp-panel > *,
  .pdp-panel .pv-wrap > *,
  .pdp-panel .pv-rv-grid,
  .pdp-panel .pv-rv-grid > *,
  .pdp-panel .pv-sp-grid,
  .pdp-panel .pv-sm-wrap{margin-top:0!important}
  .pdp-panel > *:first-child,
  .pdp-panel .pv-wrap > *:first-child,
  .pdp-panel .pv-rv-grid > *:first-child,
  .pdp-panel .pv-sp-grid > *:first-child,
  .pdp-panel .pv-sm-wrap > *:first-child,
  .pdp-panel .pv-rv-aside > *:first-child{margin-top:0!important;padding-top:0!important}
  /* Hook header — mobile only */
  /* Header — amber/red hook (loss aversion) + subtle social proof */
  .fbt-d4-header{display:block;margin-bottom:0;padding:11px 14px;border-radius:12px 12px 0 0;background:linear-gradient(135deg,rgba(248,113,113,.14),rgba(245,158,11,.08));border:1px solid rgba(248,113,113,.26);border-bottom:0;text-align:right;direction:rtl;position:relative;z-index:2}
  /* "Instead of X... Bundle Y" — direct comparison hook */
  .fbt-d4-hook{display:flex!important;align-items:baseline;justify-content:flex-start;flex-wrap:wrap;gap:5px;font-size:13px;font-weight:700;color:#fff;line-height:1.5;font-family:var(--f-ar)}
  .fbt-d4-instead{color:rgba(255,255,255,.55);font-weight:700}
  /* Strikethrough orig: number RIGHT, icon LEFT (natural RTL), icon flipped to correct orientation */
  .fbt-d4-orig{color:#F87171;text-decoration:none;font-weight:700;display:inline-flex;align-items:baseline;gap:3px}
  .fbt-d4-orig b{font-weight:800;text-decoration:line-through;text-decoration-thickness:1.5px;line-height:1}
  .fbt-d4-orig svg.sar,.fbt-d4-orig > svg{width:11px!important;height:12px!important;opacity:.85;display:inline-block;align-self:center;flex:none}
  .fbt-d4-dot{color:rgba(255,255,255,.4);font-size:14px;margin:0 2px;font-weight:600}
  .fbt-d4-hook-flat{justify-content:flex-start}
  .fbt-d4-hook[hidden],.fbt-d4-hook-flat[hidden]{display:none!important}
  .fbt-d4-bundle{color:var(--amber);font-weight:800;display:inline-flex;align-items:baseline;gap:4px}
  .fbt-d4-bundle b{color:var(--amber);font-weight:900;font-size:15.5px;line-height:1}
  .fbt-d4-bundle svg.sar,.fbt-d4-bundle > svg{width:12px!important;height:13px!important;color:var(--amber);opacity:.95;align-self:center;flex:none}
  .fbt-d4-sub{font-size:11px;color:rgba(255,255,255,.55);text-align:right;margin-top:5px;font-family:var(--f-ar);display:flex;align-items:center;gap:5px;line-height:1.4;justify-content:flex-start}
  .fbt-d4-trend{width:12px;height:12px;color:#4ADE80;flex:none}
  /* Body: stack vertically — override desktop grid */
  .fbt-body{display:flex!important;flex-direction:column!important;gap:0!important}
  .fbt-stack{order:1;gap:0;border-inline:1px solid rgba(255,255,255,.07);border-top:0;border-bottom:0;border-radius:0;overflow:hidden}
  .fbt-stack .fbt-slot:last-child .fbt-item{border-bottom:0!important}
  .fbt-aside-col{order:2;position:static!important;top:auto;align-self:auto;width:100%}
  /* Product rows — simplified */
  .fbt-slot{position:relative}
  .fbt-item{
    display:flex!important;align-items:center;
    padding:11px 12px;gap:8px;border-radius:0!important;
    border-bottom:1px solid rgba(255,255,255,.06)!important;
    border-inline:none!important;border-top:none!important;
    background:rgba(255,255,255,.03)!important;
    box-shadow:none!important;cursor:pointer;min-height:0!important;
  }
  .fbt-item.is-main{background:rgba(99,17,185,.08)!important}
  .fbt-item:last-child{border-bottom:none!important}
  /* Hide: checkboxes, pin, variant — keep media (images) */
  .fbt-pin,.fbt-variant,.fbt-alts{display:none!important}
  /* Small custom checkbox indicator for accessories — main is disabled, hide its check */
  .fbt-item.is-main .fbt-check{display:none!important}
  .fbt-item:not(.is-main) .fbt-check{display:inline-block!important;appearance:none;-webkit-appearance:none;width:18px;height:18px;border-radius:50%;border:1.5px solid rgba(255,255,255,.28);background:transparent;flex:none;cursor:pointer;position:relative;margin-inline-end:2px;transition:all .15s}
  .fbt-item:not(.is-main) .fbt-check:checked{background:var(--brand);border-color:var(--brand)}
  .fbt-item:not(.is-main) .fbt-check:checked::after{content:"✓";position:absolute;inset:0;margin:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:900;line-height:1;width:auto;height:auto;border:0;transform:none;background:transparent}
  /* Images — 36px rounded */
  .fbt-media{
    display:flex!important;flex:none!important;
    width:36px!important;height:36px!important;
    border-radius:8px!important;overflow:hidden;
    background:rgba(255,255,255,.06)!important;
    border:1px solid rgba(255,255,255,.08)!important;
  }
  .fbt-media img{width:100%!important;height:100%!important;object-fit:cover}
  /* Info row: name spans 2 rows (right), price+saving stack on left */
  .fbt-info{display:grid!important;grid-template-columns:1fr auto;grid-template-rows:auto auto;align-items:center;width:100%;gap:1px 8px}
  .fbt-name{font-size:12.5px;font-weight:600;color:var(--text);text-align:right;max-width:none;grid-column:1;grid-row:1/3;align-self:center;justify-self:start;width:fit-content}
  .fbt-pricetag{font-size:13px;font-weight:700;color:var(--amber);white-space:nowrap;direction:ltr;unicode-bidi:isolate;grid-column:2;grid-row:1;justify-self:end;align-self:end}
  /* No saving present? Price spans both rows and centers vertically (matches ‹ arrow baseline) */
  .fbt-info:not(:has(.fbt-saving)) .fbt-pricetag{grid-row:1/3;align-self:center}
  .fbt-pricetag em{display:inline!important}
  .fbt-pricetag .sar{width:13px;height:13px;vertical-align:middle;opacity:.9}
  .fbt-saving{grid-column:2;grid-row:2;justify-self:end;align-self:start;font-size:10px;font-weight:700;color:#4ADE80;font-family:var(--f-ar);display:inline-flex;align-items:center;gap:3px;white-space:nowrap;line-height:1.2}
  .fbt-saving b{font-weight:800}
  .fbt-saving .sar{width:9px;height:10px;opacity:.85}
  /* Arrow › on far LEFT (RTL end, use ::after) */
  .fbt-item::before{display:none!important}
  .fbt-item::after{content:"›";color:rgba(255,255,255,.22);font-size:17px;font-weight:300;flex:none;line-height:1;pointer-events:none}
  /* Click zones: name+media open panel (JS preventDefault); rest of label toggles checkbox */
  .fbt-item{cursor:pointer}
  .fbt-item .fbt-name,
  .fbt-item .fbt-media{cursor:zoom-in}
  /* Disable hover-shift animation on mobile — feels jittery on touch */
  .fbt-item:hover,
  [dir="rtl"] .fbt-item:hover{transform:none!important}
  /* Summary — strip card, show only CTA row */
  .fbt-summary{background:none!important;border:none!important;padding:0!important;box-shadow:none!important;border-radius:0}
  .fs-hero,.fs-hero-label,.fs-split,.fbt-save-badge,.fs-footnote,#fbtPct,#fbtDiscount,#fbtPctChip{display:none!important}
  /* CTA footer */
  .fs-cta-row{
    border-radius:0 0 12px 12px;
    border-top:1px solid rgba(34,197,94,.14)!important;
    margin-top:0;align-items:center;
    direction:rtl;justify-content:space-between!important;gap:10px;
    padding:10px 8px!important;
  }
  /* Savings column: strikethrough orig stacked above "وفر X" — aligned right edge */
  .fs-cta-save-amt{display:flex!important;flex-direction:column;align-items:flex-start;gap:3px;flex:none;white-space:nowrap;font-size:unset;font-weight:unset;text-align:right}
  .fs-cta-orig{font-size:11.5px;font-weight:600;color:var(--text-3);text-decoration:line-through;display:inline-flex;align-items:center;gap:3px;unicode-bidi:isolate}
  .fs-cta-orig .sar{width:11px;height:12px;opacity:.55}
  .fs-cta-waffar{font-size:12.5px;font-weight:800;color:#4ADE80;display:inline-flex;align-items:center;gap:3px}
  .fs-cta-waffar .sar{width:11px;height:12px;opacity:.9}
  /* Enhanced CTA button: cart icon + label + price */
  .btn-fbt-add{flex:1!important;flex-direction:row!important;gap:6px!important;padding:11px 14px!important;font-size:14.5px!important;font-weight:800!important;justify-content:center!important;align-items:center!important;position:relative;overflow:hidden;box-shadow:0 4px 18px rgba(99,17,185,.45),0 0 0 0 rgba(99,17,185,.4);animation:fbtCtaPulse 2.4s ease-in-out infinite}
  .btn-fbt-add .sar{width:14px;height:16px;opacity:.95}
  .btn-fbt-add .btn-fbt-price{display:inline-flex;align-items:center;gap:4px;unicode-bidi:isolate}
  .btn-fbt-add .btn-fbt-cart{width:17px;height:17px;color:#fff;flex:none}
  .btn-fbt-add .btn-fbt-label{font-family:var(--f-ar);font-size:14px;font-weight:800;color:#fff;letter-spacing:.01em}
  .btn-fbt-add .btn-fbt-sep{opacity:.45;font-size:13px;margin:0 1px}
  @keyframes fbtCtaPulse{
    0%,100%{box-shadow:0 4px 18px rgba(99,17,185,.45),0 0 0 0 rgba(99,17,185,.45)}
    50%{box-shadow:0 4px 22px rgba(99,17,185,.55),0 0 0 6px rgba(99,17,185,0)}
  }

  /* ── FBT: checked / unchecked visual states ── */
  .fbt-slot .fbt-item:has(.fbt-check:not(:checked)){opacity:.32;transition:opacity .2s}
  .fbt-slot .fbt-item:has(.fbt-check:not(:checked)) .fbt-pricetag{text-decoration:line-through;color:var(--text-3)}
  .fbt-slot .fbt-item:has(.fbt-check:checked){opacity:1;transition:opacity .2s}

  /* ── FBT: main product distinction (subtle bg, no neon side accent) ── */
  .fbt-item.is-main{border-inline-end:0!important;background:rgba(99,17,185,.06)}

  .fbt-item.is-main::after{color:rgba(255,255,255,.1)!important}

  /* ── FBT: main product info grid (name+price row 1, variant row 2, badge row 3) ── */
  /* Main: name+variant on right, price+saving stacked on left */
  .fbt-item.is-main .fbt-info{display:grid!important;grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:3px 8px;align-items:center;width:100%}
  .fbt-item.is-main .fbt-name{grid-column:1;grid-row:1;text-align:right;justify-self:start;width:fit-content}
  .fbt-item.is-main .fbt-pricetag{grid-column:2;grid-row:1;align-self:end;justify-self:end}
  .fbt-item.is-main .fbt-info:not(:has(.fbt-saving)) .fbt-pricetag{grid-row:1/3;align-self:center}
  .fbt-item.is-main .fbt-saving{grid-column:2;grid-row:2;align-self:start;justify-self:end}
  .fbt-item.is-main .fbt-variant{grid-column:1;grid-row:2;display:flex!important;justify-content:flex-start;flex-wrap:wrap;gap:3px;font-size:10px;color:var(--text-3);font-family:var(--f-ar)}
  .fbt-item.is-main .fbt-variant span{background:rgba(255,255,255,.07);padding:1px 5px;border-radius:4px}

  /* ── FBT: tap-to-expand panel (accessories) ── */
  .fbt-slot.is-swapping .fbt-item:not(.is-main)::after{content:"−"!important;color:var(--brand)!important;font-size:16px}
  .fbt-alts{padding:10px 14px;background:rgba(255,255,255,.04);border-top:1px solid rgba(255,255,255,.06);animation:fbtPanelIn .2s ease}
  .fbt-alts[hidden]{display:none!important}
  .fbt-alts:not([hidden]){display:block!important}
  @keyframes fbtPanelIn{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}
  .fbt-panel-desc{font-size:11.5px;line-height:1.55;text-align:right;color:var(--text-3);font-family:var(--f-ar);margin-bottom:8px}
  .fbt-panel-desc:empty{display:none}
  .fbt-panel-actions{display:flex;justify-content:flex-end;gap:8px}
  .fbt-panel-link{font-size:11px;font-weight:700;color:var(--brand);font-family:var(--f-ar);text-decoration:none;padding:5px 10px;border:1px solid rgba(99,17,185,.4);border-radius:8px}

  .dx-sheet{
    position:fixed;inset-inline:0;bottom:0;
    background:linear-gradient(180deg,#120A24 0%,#0A0612 100%);
    border-radius:24px 24px 0 0;
    border-top:1px solid rgba(255,255,255,.14);
    padding:8px 16px 32px;
    transform:translateY(100%);transition:transform .35s cubic-bezier(.2,.8,.2,1);
    z-index:130;max-height:88vh;overflow-y:auto;-webkit-overflow-scrolling:touch;
    box-shadow:0 -20px 60px rgba(0,0,0,.6);
  }
  .dx-sheet.is-open{transform:translateY(0)}
  .dx-sheet-handle{width:40px;height:4px;background:rgba(255,255,255,.2);border-radius:999px;margin:0 auto 14px}
  .dx-sheet-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
  .dx-sheet-head h3{font-family:var(--f-ar);font-size:16px;font-weight:800;color:#fff;margin:0}
  .dx-sheet-close{width:30px;height:30px;border-radius:8px;background:rgba(255,255,255,.06);color:#fff;display:flex;align-items:center;justify-content:center;border:0;cursor:pointer}
  .dx-sheet-close svg{width:14px;height:14px}

  .dx-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .25s;z-index:125}
  .dx-backdrop.is-on{opacity:1;pointer-events:all}

  /* Hide original FBT on mobile when bundle trigger is shown — collapse into sheet */
  body.dx-fbt-mobile-sheet .fbt-section{display:none}
  .dx-sheet .fbt-section{display:block;margin:0 0 16px;padding:0}
  .dx-sheet .fbt-section .container{padding:0}

  /* Split CTA — add WhatsApp icon button on mobile (icon-only, square) */
  .dx-wa-btn{
    flex:0 0 44px !important;width:44px;height:44px;padding:0 !important;
    background:rgba(37,211,102,.12) !important;color:#25D366 !important;
    border-radius:12px;border:1px solid rgba(37,211,102,.3) !important;display:inline-flex;align-items:center;justify-content:center;
    box-shadow:none;text-decoration:none;font-size:0;
  }
  .dx-wa-btn svg{width:18px;height:18px}
  .dx-wa-btn{font-size:0 !important}

  /* Tighten CTA row — nowrap so qty + cart + WA stay on one line */
  .cta-row{flex-wrap:nowrap !important;gap:6px !important;padding:8px 10px !important}
  .cta-row .qty{flex:0 0 auto !important}
  .cta-row .qty button,
  .cta-row .qty .qty-btn{width:24px !important;height:24px !important;font-size:14px}
  .cta-row .qty input,
  .cta-row .qty .qty-val{width:18px !important;font-size:13px !important}
  .cta-row .btn-buy,
  .cta-row [type="submit"],
  .cta-row .single_add_to_cart_button{
    flex:1 1 0 !important;
    min-width:0;
    padding:11px 8px !important;
    font-size:12.5px !important;
  }
  .cta-row .btn-buy svg{width:14px !important;height:14px !important}

  /* Live stock chip */
  .dx-stock-live{
    display:inline-flex;align-items:center;gap:5px;
    font-family:var(--f-ar);font-size:10.5px;font-weight:700;color:#FFB3B0;
    background:rgba(255,59,48,.1);border:1px solid rgba(255,59,48,.25);
    padding:4px 9px;border-radius:999px;margin-top:6px;
  }
  .dx-stock-live::before{content:"";width:6px;height:6px;background:#FF3B30;border-radius:999px;animation:dxLivePulse 1.4s infinite}
  @keyframes dxLivePulse{0%,100%{opacity:1}50%{opacity:.3}}

  /* Price count-up animation hook */
  .price-main.is-counting{will-change:contents}

  /* Color variant click — image crossfade signal */
  .gallery-view.is-swapping #galleryActiveImg,
  .gallery-view.is-swapping img{opacity:.35;transform:scale(.95);transition:opacity .2s, transform .25s}

  /* Reviews preview card */
  .dx-rv-card{
    background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.08);
    border-radius:14px;padding:14px;margin:14px 0;
  }
  .dx-rv-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
  .dx-rv-head h3{font-family:var(--f-ar);font-size:14px;font-weight:800;color:#fff;margin:0}
  .dx-rv-recommend{font-family:var(--f-ar);font-size:11px;font-weight:700;color:#34C759;background:rgba(52,199,89,.12);padding:4px 8px;border-radius:6px}
  .dx-rv-summary{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:12px;margin-bottom:10px}
  .dx-rv-score{font-family:var(--f-display);font-size:32px;font-weight:900;color:#fff;line-height:1}
  .dx-rv-meta{flex:1}
  .dx-rv-stars{color:#F5A524;font-size:13px;letter-spacing:1px}
  .dx-rv-meta small{display:block;font-family:var(--f-ar);font-size:10px;color:rgba(255,255,255,.55);margin-top:2px}
  .dx-rv-filter{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;margin-bottom:10px;padding-bottom:2px}
  .dx-rv-filter::-webkit-scrollbar{display:none}
  .dx-rv-fchip{flex-shrink:0;font-family:var(--f-ar);font-size:10.5px;font-weight:600;padding:5px 10px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.78);white-space:nowrap;cursor:pointer}
  .dx-rv-fchip.is-on{background:rgba(196,181,253,.12);border-color:#8B5CF6;color:#fff}
  .dx-rv-item{display:flex;gap:10px;padding:10px 0;border-top:1px solid rgba(255,255,255,.06)}
  .dx-rv-av{width:32px;height:32px;border-radius:999px;background:linear-gradient(135deg,#7C3AED,#A78BFA);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--f-ar);font-size:13px;font-weight:700;flex-shrink:0}
  .dx-rv-body{flex:1;min-width:0}
  .dx-rv-name{font-family:var(--f-ar);font-size:12px;font-weight:700;color:#fff;display:flex;align-items:center;gap:6px}
  .dx-rv-verify{font-family:var(--f-ar);font-size:9px;color:#34C759;background:rgba(52,199,89,.12);padding:1px 5px;border-radius:4px;font-weight:700}
  .dx-rv-text{font-family:var(--f-ar);font-size:11.5px;color:rgba(255,255,255,.78);line-height:1.5;margin-top:2px}
  .dx-rv-all{width:100%;margin-top:10px;font-family:var(--f-ar);font-size:12px;font-weight:700;padding:10px;border-radius:10px;background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.14);cursor:pointer}

  /* Smart accessories rail */
  .dx-acc-rail{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding-bottom:6px;margin-bottom:10px}
  .dx-acc-rail::-webkit-scrollbar{display:none}
  .dx-acc-card{
    flex:0 0 120px;background:rgba(255,255,255,.03);
    border:1px solid rgba(255,255,255,.08);border-radius:12px;
    padding:8px;text-decoration:none;color:#fff;
  }
  .dx-acc-img{width:100%;aspect-ratio:1;background:rgba(255,255,255,.04) center/cover no-repeat;border-radius:8px;margin-bottom:6px}
  .dx-acc-name{font-family:var(--f-ar);font-size:11px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
  .dx-acc-price{font-family:var(--f-display);font-size:11.5px;font-weight:700;color:#C4B5FD;direction:ltr;unicode-bidi:isolate}
}
