/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   y4des — Components v3 | RTL/LTR • Logical • Accessible
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* 🛡 حماية شاملة لجميع صور الأعمال — منع السحب والاختيار */
.pin-paper img,
.pin-img,
.h-card img,
.lb2-media-wrap img,
.tst-avatar img,
.pin-multi,
.wall img,
.featured-strip img {
  -webkit-user-drag: none;
  -khtml-user-drag: none;
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
  pointer-events: auto;
}

/* رسالة التنبيه عند محاولة حفظ صورة */
@keyframes y4fadein {
  from { opacity: 0; transform: translate(-50%, -8px); }
  to   { opacity: 1; transform: translate(-50%, 0); }
}

/* ━━ WALL FILTER BAR ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.wsw-wrap {
  display: flex;
  justify-content: center;
  margin-block-end: .85rem;
}

.wsw {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  justify-content: center;
  background: var(--ink4);
  border: 1px solid var(--brd2);
  border-radius: var(--r4);
  padding: 4px;
  width: fit-content;
}

.wsw-btn {
  padding: .38rem 1.1rem;
  border-radius: var(--r4);
  font-size: .82rem;
  font-weight: 500;
  color: var(--txt2);
  transition: var(--t-fast);
  cursor: pointer;
  white-space: nowrap;
  border: 1px solid transparent;
  font-family: inherit;
  touch-action: manipulation;
  background: none;
}
.wsw-btn:hover  { background: var(--white-alpha-07); color: var(--txt); }
.wsw-btn.on     { font-weight: 700; }
.wsw-btn[data-w=all].on      { background: var(--gold);  color: var(--ink); }
.wsw-btn[data-w=gaming].on   { background: var(--cyan);  color: var(--ink); }
.wsw-btn[data-w=stores].on   { background: var(--org);   color: var(--ink); }
.wsw-btn[data-w=companies].on{ background: var(--pur);   color: var(--ink); }

/* ━━ 3D CAROUSEL ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.c3d { margin-top: 1.25rem; display: grid; justify-items: center; }
.c3d-stage {
  position: relative;
  width: 100%;
  max-width: 980px;
  height: min(420px, 70vh);
  display: flex;
  align-items: center;
  justify-content: center;
  perspective: 1400px;
  border-radius: var(--r3);
  border: 1px solid var(--brd);
  background: radial-gradient(ellipse 120% 100% at 50% 0%, var(--goldDim), transparent 55%),
              linear-gradient(180deg, var(--white-alpha-02), var(--white-alpha-01));
  overflow: hidden;
  touch-action: pan-y;
}
.c3d-card {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  width: min(340px, 78vw);
  height: min(380px, 62vh);
  transform-style: preserve-3d;
  border-radius: var(--r2);
  border: 1px solid var(--white-alpha-12);
  background: var(--glass-bg2);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  cursor: pointer;
  transition: all .3s ease;
}
.c3d-card img { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(1.08) contrast(1.02); }
.c3d-meta {
  position: absolute;
  inset-inline: 0;
  inset-block-end: 0;
  padding: 1rem 1rem;
  background: linear-gradient(180deg, transparent, var(--glass-bg));
}
.c3d-t { font-weight: 900; font-size: 1rem; }
.c3d-c { color: var(--txt2); font-size: .82rem; margin-top: .15rem; }
.c3d-nav { display: flex; align-items: center; justify-content: center; gap: .8rem; margin-top: .75rem; }
.c3d-btn {
  width: 42px; height: 42px;
  border-radius: 50%;
  border: 1px solid var(--brd2);
  background: var(--white-alpha-03);
  color: var(--txt);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: var(--t-fast);
}
.c3d-btn:hover { border-color: var(--goldGlow); color: var(--gold); background: var(--goldDim); }
.c3d-btn:focus-visible {
  outline: none;
  border-color: var(--gold);
  color: var(--gold);
  box-shadow: 0 0 0 3px var(--goldDim);
}
[dir="rtl"] .c3d-btn iconify-icon { transform: scaleX(-1); }
.c3d-dots { display: flex; align-items: center; gap: 6px; }
.c3d-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--white-alpha-22); }
.c3d-dot.on { background: var(--gold); box-shadow: 0 0 16px var(--goldGlow); }

/* ━━ SERVICES 3D FLIP ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.svc-top{ display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; margin-top: 1.2rem; }
.svc-search{
  display:flex; align-items:center; gap:.55rem;
  padding:.55rem .75rem;
  border-radius: var(--r2);
  border:1px solid var(--brd);
  background: var(--white-alpha-03);
  min-width: min(440px, 92vw);
}
.svc-inp{ width:100%; border:none; outline:none; background:transparent; color:var(--txt); font-size:.9rem; }
.svc-inp::placeholder{ color: var(--txt3); }
.svc-hint{ color: var(--txt2); font-size:.78rem; }
.svc-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.15rem;
  margin-top: 1.2rem;
}
.svc-card{ position:relative; height: 260px; perspective: 1100px; }
@media (max-width: 480px) { .svc-card { height: 280px; } }
.svc-face{
  position:absolute; inset:0;
  border-radius: var(--r2);
  border:1px solid var(--brd);
  background: linear-gradient(135deg, var(--white-alpha-03), var(--white-alpha-02));
  backface-visibility: hidden;
  transform-style: preserve-3d;
  transition: transform .5s var(--ease), border-color .2s var(--ease2);
  overflow:hidden;
}
.svc-front{
  display:flex; flex-direction:column; gap:.55rem;
  padding: 1.15rem 1.2rem;
  text-align:start;
  cursor:pointer;
  color: var(--txt);
}
.svc-card:hover .svc-face{ border-color: var(--goldGlow); }
.svc-ic{
  width: 44px; height: 44px; border-radius: 14px;
  display:flex; align-items:center; justify-content:center;
  background: var(--goldDim);
  border:1px solid var(--goldGlow);
  color: var(--gold);
  transform: translateZ(12px);
}
.svc-t{ font-size: 1rem; font-weight: 900; transform: translateZ(10px); }
.svc-d{ color: var(--txt2); font-size: .83rem; line-height: 1.7; transform: translateZ(8px); }
.svc-tags{ display:flex; flex-wrap:wrap; gap:.35rem; margin-top:auto; }
.svc-tag{ font-size:.68rem; padding:.16rem .55rem; border-radius: 999px; border:1px solid var(--white-alpha-10); color: var(--txt2); }
.svc-flip{ margin-top: .5rem; font-weight: 900; color: var(--gold); font-size:.78rem; transform: translateZ(8px); }

.svc-back{
  padding: 1.05rem 1.1rem;
  background: var(--glass-bg);
  transform: rotateY(180deg);
  display:flex; flex-direction:column; gap:.8rem;
  overflow-y: auto;
}
.svc-back-hd{ display:flex; align-items:center; justify-content:space-between; gap:.6rem; }
.svc-back-hd b{ font-weight: 900; }
.svc-x{ border:none; background:transparent; color: var(--txt2); cursor:pointer; font-size:1.2rem; line-height:1; }
.svc-ul{ padding-inline-start: 1.15rem; color: var(--txt2); font-size:.82rem; line-height:1.8; display:grid; gap:.25rem; }
.svc-back-acts{ margin-top:auto; display:flex; gap:.6rem; flex-wrap:wrap; }
.svc-card.on .svc-front{ transform: rotateY(180deg); }
.svc-card.on .svc-back{ transform: rotateY(0deg); }
@media (prefers-reduced-motion: reduce){ .svc-face{ transition:none; } }

.skel-grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 1.15rem;
}
.skel-card{
  position: relative;
  border-radius: var(--r2);
  border: 1px solid var(--white-alpha-08);
  background: var(--white-alpha-03);
  height: 230px;
  overflow: hidden;
}
.skel-card::before{
  content:'';
  position:absolute; inset:0;
  background: linear-gradient(90deg, transparent, var(--white-alpha-08), transparent);
  transform: translateX(-100%);
  animation: skelSh 1.05s linear infinite;
}
@keyframes skelSh{ to{ transform: translateX(100%); } }
.empty-state{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:.4rem;
  padding: 2rem 1rem;
  border-radius: var(--r2);
  border: 1px solid var(--white-alpha-08);
  background: var(--white-alpha-02);
}
.empty-ic{
  width: 44px; height: 44px;
  border-radius: 14px;
  display:flex; align-items:center; justify-content:center;
  background: var(--goldDim);
  border: 1px solid var(--goldGlow);
  color: var(--gold);
  margin-bottom: .25rem;
}

/* Category pills */
.cpills {
  display: flex;
  gap: .4rem;
  flex-wrap: wrap;
  justify-content: center;
  margin-block-end: 1rem;
}

.cpill {
  padding: .28rem .72rem;
  border-radius: var(--r4);
  font-size: .76rem;
  border: 1px solid var(--white-alpha-12);
  color: var(--txt2);
  background: var(--white-alpha-04);
  transition: var(--t-fast);
  cursor: pointer;
  font-family: inherit;
  touch-action: manipulation;
}
.cpill:hover { background: var(--white-alpha-08); color: var(--txt); border-color: var(--brd3); }
.cpill:focus-visible,
.sort-pill:focus-visible,
.lbtn:focus-visible,
.clink:focus-visible,
.svc-front:focus-visible,
.svc-x:focus-visible,
.lb2-btn:focus-visible,
.lb2-arr:focus-visible,
.lb2-thumbbtn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--goldDim);
  border-color: var(--goldGlow);
}
.cpill.on {
  background: var(--goldGlow);
  border-color: var(--gold3);
  color: var(--gold);
  font-weight: 700;
  box-shadow: 0 0 14px var(--goldDim);
}

/* Sort bar */
.wall-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .75rem;
  margin-block-end: 1.5rem;
}
.wall-count { font-size: .75rem; color: var(--txt3); }
.sort-row   { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }
.sort-lbl   { font-size: .72rem; color: var(--txt3); }
.sort-pills { display: flex; gap: .35rem; flex-wrap: wrap; }

.sort-pill {
  padding: .25rem .7rem;
  border-radius: var(--r4);
  font-size: .72rem;
  border: 1px solid var(--brd);
  color: var(--txt3);
  transition: var(--t-fast);
  cursor: pointer;
  font-family: inherit;
  touch-action: manipulation;
  background: none;
}
.sort-pill.on  { color: var(--cyan); border-color: rgba(0,229,255,.4); }
.sort-pill:hover { color: var(--txt2); border-color: var(--brd2); }

/* ━━ WALL GRID ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.wall {
  display: grid;
  /* ⚡ مرونة كاملة باستخدام auto-fit — يستغل المساحة المتاحة دائماً */
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: calc(var(--u) * 3);
  align-items: start;
}
/* breakpoints صريحة لضمان الاتساق على المنصات الشائعة */
@media (min-width: 1400px) { .wall { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 1023px) { .wall { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 767px)  { .wall { grid-template-columns: repeat(2, 1fr); gap: calc(var(--u) * 2); } }
@media (max-width: 420px)  { .wall { grid-template-columns: 1fr; } }
@media (max-width: 767px) {
  .wall-topbar { align-items: stretch; }
  .sort-row { width: 100%; justify-content: space-between; }
  .sort-pills {
    max-width: 100%;
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 2px;
    -webkit-mask-image: linear-gradient(to left, transparent 0, #000 12px, #000 calc(100% - 12px), transparent 100%);
    mask-image: linear-gradient(to left, transparent 0, #000 12px, #000 calc(100% - 12px), transparent 100%);
  }
}

/* ━━ PIN CARD ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.pin {
  position: relative;
  transform: perspective(900px) var(--pin-rot, rotate(0deg)) rotateX(var(--pin-rx, 0deg)) rotateY(var(--pin-ry, 0deg));
  transform-style: preserve-3d;
  /* ⚡ أداء: will-change على hover فقط (بدل الكل دائماً) */
  transition: transform .3s ease;
  animation: pinIn .55s var(--ease) both;
  cursor: pointer;
  /* ⚡ أداء: يتخطى المتصفح رسم البطاقات خارج الشاشة — مكاسب 40-60% */
  content-visibility: auto;
  contain-intrinsic-size: 380px 320px;
  contain: layout paint;
}
.pin:hover, .pin:focus-visible { will-change: transform; }
.pin.dimmed { opacity: .3; transform: scale(.97); }
.pin:not(.dimmed):hover {
  --pin-rx: -6deg;
  --pin-ry: 6deg;
  transform: perspective(900px) rotateX(var(--pin-rx)) rotateY(var(--pin-ry)) translateY(-10px) scale(1.04) !important;
  z-index: 10;
}
.pin:not(.dimmed):hover .pin-paper {
  border-color: var(--goldGlow);
  box-shadow: var(--shadow-lg), 0 0 0 1px var(--goldDim);
}
/* (تمت إزالة قاعدة .pin-img hover المكررة — تم تعريفها أسفل مع حاوي .pin-media) */
.pin:not(.dimmed):hover .pin-brief { max-height: 55px; padding-block-start: .35rem; }
.pin:not(.dimmed):hover .pin-acts  { opacity: 1; transform: none; }
.pin:focus-visible {
  outline: none;
  transform: perspective(900px) translateY(-4px) scale(1.015);
}
.pin:focus-visible .pin-paper {
  border-color: var(--goldGlow);
  box-shadow: var(--shadow-lg), 0 0 0 1px var(--goldDim);
}

/* Paper — إطار أنيق يضمّ العمل مهما كانت نسبته */
.pin-paper {
  background: var(--card-bg, var(--ink3));
  border: 1px solid var(--brd);
  border-radius: var(--r);
  overflow: hidden;
  transition: all .3s ease;
  transform: translateZ(14px);
  /* ⚡ إنشاء سياق طبقي (isolation stacking context) — يضمن الأيقونات فوق الصورة */
  isolation: isolate;
  position: relative;
}

/* 🎨 حاوي فنّي للصورة — خلفية مَطْموسة من نفس العمل تملأ الفراغ */
.pin-media {
  position: relative;
  width: 100%;
  aspect-ratio: var(--pin-ar, 4 / 3);
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 30%, rgba(245,197,53,.06), transparent 60%),
    linear-gradient(135deg, var(--ink3) 0%, var(--ink4) 50%, var(--ink3) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
  isolation: isolate;
}

/* ⚡ خلفية الصورة مَطْموسة (blur backdrop) — تملأ الفراغ بنفس ألوان العمل */
.pin-media::before {
  content: '';
  position: absolute;
  inset: -8%;
  background-image: var(--pin-bg, none);
  background-size: cover;
  background-position: center;
  filter: blur(20px) brightness(0.65) saturate(1.15);
  transform: scale(1.15);
  z-index: 0;
  opacity: .85;
  pointer-events: none;
  transition: filter .4s ease, opacity .4s ease;
}
.pin:hover .pin-media::before {
  filter: blur(24px) brightness(0.55) saturate(1.25);
  opacity: 1;
}

.pin-img {
  position: relative;
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  /* ⚡ contain = الصورة تظهر بالكامل دائماً داخل الإطار بدون قصّ ولا خروج */
  object-fit: contain;
  object-position: center;
  display: block;
  transition: transform .35s var(--ease);
  z-index: 2;
  filter: drop-shadow(0 4px 12px rgba(0, 0, 0, .35));
}

/* تأثير تكبير خفيف عند hover — داخل الإطار فقط */
.pin:not(.dimmed):hover .pin-img {
  transform: scale(1.04);
}

/* ⚡ مؤشر "العمل يحتوي عدة ملفات" — فوق الصورة دائماً */
.pin-multi {
  position: absolute;
  inset-block-start: 10px;
  inset-inline-end: 10px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 8px;
  background: rgba(0, 0, 0, .78);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255, 255, 255, .18);
  border-radius: 999px;
  color: #fff;
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .02em;
  /* ⚡ فوق الصورة دائماً */
  z-index: 5;
  pointer-events: none;
  box-shadow: 0 4px 12px rgba(0, 0, 0, .4);
}
.pin-multi iconify-icon { color: var(--gold); font-size: .8rem; }
.pin:hover .pin-multi { background: var(--gold); color: #000; border-color: var(--gold2); }
.pin:hover .pin-multi iconify-icon { color: #000; }

.pin-foot {
  padding: .7rem .85rem .8rem;
  background: var(--ink4);
  position: relative;
  z-index: 2;
}

.pin-client {
  font-size: .66rem;
  color: var(--gold);
  opacity: .9;
  margin-block-end: 2px;
  display: flex; align-items: center; gap: 4px;
}
.pin-client::before { content: '—'; opacity: .5; }

.pin-name {
  font-size: .85rem;
  font-weight: 800;
  line-height: 1.3;
  color: var(--txt);
}

.pin-brief {
  font-size: .7rem;
  color: var(--txt2);
  line-height: 1.5;
  max-height: 0;
  overflow: hidden;
  transition: max-height .35s var(--ease), padding-block-start .35s;
}

.pin-acts {
  display: flex; align-items: center; gap: .45rem;
  padding-block-start: .5rem;
  opacity: 0;
  transform: translateY(5px);
  transition: opacity .3s, transform .3s;
}

/* Like button */
.lbtn {
  background: var(--white-alpha-08);
  border: 1px solid var(--white-alpha-18);
  border-radius: var(--r);
  padding: .3rem .65rem;
  font-size: .72rem;
  color: var(--txt2);
  display: flex; align-items: center; gap: .22rem;
  transition: var(--t-fast);
  cursor: pointer;
  touch-action: manipulation;
  font-family: inherit;
}
.lbtn:hover { background: rgba(255,77,109,.12); border-color: rgba(255,77,109,.32); color: var(--rose); }
.lbtn.liked { background: rgba(255,77,109,.18); border-color: rgba(255,77,109,.48); color: var(--rose); font-weight: 700; }

.lc   { font-size: .67rem; }
.vlbl {
  font-size: .7rem;
  color: var(--txt3);
  display: flex; align-items: center; gap: 3px;
  margin-inline-start: auto;
}

@media (hover: none), (pointer: coarse) {
  .pin,
  .pin:not(.dimmed):hover {
    transform: none !important;
  }
  .pin-brief {
    max-height: 46px;
    padding-block-start: .35rem;
  }
  .pin-acts {
    opacity: 1;
    transform: none;
  }
}

/* Keyframes */
@keyframes pinIn    { from { opacity: 0; transform: translateY(12px) scale(.97); } to { opacity: 1; transform: none; } }
@keyframes heartPop { 0% { transform: scale(0); } 70% { transform: scale(1.3); } 100% { transform: scale(1); } }

/* ━━ LIGHTBOX ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.lbox2 {
  position: fixed; inset: 0; z-index: 800;
  background: var(--lb-overlay);
  backdrop-filter: blur(18px);
  display: flex; flex-direction: column;
  opacity: 0; visibility: hidden;
  transition: opacity .3s, visibility .3s;
}
.lbox2.open { opacity: 1; visibility: visible; }

.lb2-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: .75rem 1.25rem; flex-shrink: 0;
  background: var(--lb-toolbar);
  border-block-end: 1px solid var(--white-alpha-06);
}
.lb2-info    { display: flex; align-items: center; gap: .75rem; }
.lb2-badge   {
  font-size: .68rem; font-weight: 700;
  padding: .18rem .6rem; border-radius: var(--r4);
  background: var(--goldDim); color: var(--gold);
  border: 1px solid var(--goldGlow);
  display: flex; align-items: center; gap: 4px;
}
.lb2-client  { font-size: .78rem; color: var(--txt2); }
.lb2-actions { display: flex; align-items: center; gap: .45rem; }

.lb2-btn {
  background: var(--white-alpha-07);
  border: 1px solid var(--white-alpha-14);
  border-radius: var(--r);
  padding: .38rem .65rem; font-size: .78rem;
  color: var(--txt2);
  display: flex; align-items: center; gap: .3rem;
  transition: var(--t-fast); cursor: pointer;
  touch-action: manipulation; font-family: inherit;
}
.lb2-btn:hover  { background: var(--white-alpha-12); color: var(--gold); }
.lb2-btn.liked  { color: var(--rose); }
.lb2-share-btn:hover { color: var(--cyan) !important; }
.lb2-cta {
  background: var(--gold) !important; color: var(--ink) !important;
  border-color: var(--gold) !important; font-weight: 700 !important;
}
.lb2-cta:hover   { background: var(--gold2) !important; }
.lb2-close:hover { background: rgba(255,77,109,.14) !important; color: var(--rose) !important; border-color: rgba(255,77,109,.28) !important; }

.lb2-stage {
  position: relative;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  flex: 1; min-height: 0; padding: .8rem 1rem; overflow: hidden;
  gap: .85rem;
}

.lb2-media-wrap {
  position: relative;
  display: inline-flex; align-items: center; justify-content: center;
  width: min(1240px, calc(100vw - 2rem));
  min-height: clamp(240px, 56vh, 760px);
  max-width: min(1240px, calc(100vw - 2rem));
  max-height: calc(100dvh - 220px);
  isolation: isolate;
}
.lb2-media-stage {
  position: relative;
  z-index: 2;
  width: 100%;
  min-height: inherit;
  display: flex;
  align-items: center;
  justify-content: center;
}
.lb2-media-stage--swipe {
  touch-action: none;
  overscroll-behavior: contain;
}
.lb2-media-wrap img,
.lb2-media-wrap video,
.lb2-media-wrap iframe {
  width: 100%;
  max-width: 100%;
  max-height: calc(100dvh - 230px);
  border-radius: var(--r2); object-fit: contain; display: block;
  image-rendering: auto;
  -webkit-user-drag: none;
  user-select: none;
  position: relative;
  z-index: 2;
}
.lb2-media-wrap img { filter: contrast(1.02) saturate(1.02); }
/* ⚡ watermark مخففة جداً — زاوية واحدة بدل نمط كامل مزعج */
.lb2-watermark-grid {
  display: none; /* أُلغيت شبكة الـwatermark الكاملة — تُزعج العميل المحتمل */
}
.lb2-empty {
  width: 100%;
  min-height: clamp(220px, 45vh, 560px);
  display: grid;
  place-items: center;
  border-radius: var(--r2);
  border: 1px dashed var(--white-alpha-14);
  background: var(--white-alpha-04);
  color: var(--txt2);
  font-size: .9rem;
  text-align: center;
  padding: 1rem;
  z-index: 2;
}

/* Navigation overlay — fixed layer for arrows so they don't move with swipe */
.lb2-nav-overlay {
  position: absolute;
  inset: 0;
  z-index: 10;
  pointer-events: none;
}
.lb2-nav-overlay button {
  pointer-events: all;
}

/* ⚡ أسهم الصور داخل نفس العمل — تصميم أنظف وأوضح */
.lb2-arr {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 48px; height: 48px; border-radius: 50%;
  background: rgba(0,0,0,.75);
  border: 2px solid var(--gold);
  color: var(--gold); font-size: 1.6rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .18s var(--ease2);
  z-index: 10;
  touch-action: manipulation;
  box-shadow: 0 4px 16px rgba(0,0,0,.4), 0 0 0 4px rgba(245,197,53,.0);
  line-height: 1;
  opacity: .85;
}
.lb2-arr:hover {
  opacity: 1;
  background: var(--gold);
  color: #000;
  box-shadow: 0 4px 16px rgba(0,0,0,.4), 0 0 0 4px rgba(245,197,53,.3), 0 0 24px rgba(245,197,53,.5);
  transform: translateY(-50%) scale(1.08);
}
.lb2-arr:active { transform: translateY(-50%) scale(1); }
.lb2-arr:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--gold), 0 0 0 6px rgba(245,197,53,.3); }

[dir="rtl"] .lb2-prv iconify-icon,
[dir="rtl"] .lb2-nxt iconify-icon { transform: scaleX(-1); }
.lb2-prv { inset-inline-start: 14px; }
.lb2-nxt { inset-inline-end: 14px; }

/* (scroll-snap معرَّف ضمن القواعد الرئيسية أدناه — تمت إزالة التكرار) */

/* ⚡ تابلت — مرحلة وسيطة (768-1024px) لاستغلال المساحة بشكل أفضل */
@media (max-width: 1024px) and (min-width: 601px) {
  .lb2-stage { padding: .7rem .85rem; gap: .75rem; }
  .lb2-media-wrap {
    width: calc(100vw - 2rem);
    min-height: clamp(280px, 60vh, 700px);
    max-height: calc(100dvh - 200px);
  }
  .lb2-arr { width: 46px; height: 46px; }
}

@media (max-width: 600px) {
  .lb2-arr { width: 40px; height: 40px; font-size: 1.2rem; opacity: .95; }
  .lb2-prv { inset-inline-start: 8px; }
  .lb2-nxt { inset-inline-end: 8px; }
  .lb2-stage { padding: .55rem .6rem; gap: .6rem; }
  .lb2-media-wrap {
    width: calc(100vw - 1.2rem);
    min-height: clamp(220px, 58vh, 620px);
    max-height: calc(100dvh - 195px);
  }
  .lb2-media-wrap img,
  .lb2-media-wrap video,
  .lb2-media-wrap iframe {
    max-height: calc(100dvh - 205px);
  }
}

/* ⚡ شاشات صغيرة جداً — ضمان عدم اختفاء الأدوات أسفل الشاشة */
@media (max-height: 600px) {
  .lb2-media-wrap {
    min-height: clamp(180px, 46vh, 400px);
    max-height: calc(100dvh - 160px);
  }
  .lb2-info-panel { padding: .5rem .75rem; gap: .35rem; }
}

.lb2-watermark {
  position: absolute;
  inset-block-end: .5rem;
  inset-inline-start: .75rem;
  font-size: .58rem; color: rgba(255,255,255,.22);
  font-weight: 700; pointer-events: none; user-select: none;
}

/* Sub media bar — ثابت في الأسفل، الصور الفرعية كلها بنفس المقاس بالضبط */
.lb2-subbar {
  width: min(720px, calc(100vw - 2rem));
  display: flex;
  gap: 6px;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 6px 8px;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  background: var(--lb-subbar);
  border: 1px solid var(--white-alpha-08);
  border-radius: var(--r2);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  /* ⚡ ارتفاع ثابت — لا يتغيّر مع حجم الصور */
  height: 60px;
  min-height: 60px;
  max-height: 60px;
  flex-shrink: 0;
}
/* 🔒 صور فرعية ثابتة دائماً — 64×48 على الديسك​توب، 52×40 على الجوال */
.lb2-thumbbtn {
  width: 64px !important;
  height: 48px !important;
  min-width: 64px;
  min-height: 48px;
  max-width: 64px;
  max-height: 48px;
  aspect-ratio: 4 / 3;
  border-radius: 8px;
  border: 2px solid var(--white-alpha-10);
  background: var(--white-alpha-04);
  color: var(--txt);
  opacity: .8;
  flex: 0 0 64px;
  cursor: pointer;
  overflow: hidden;
  transition: var(--t-fast);
  scroll-snap-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  box-sizing: border-box;
}
.lb2-thumbbtn:hover { border-color: var(--goldGlow); opacity: 1; transform: translateY(-1px); }
.lb2-thumbbtn.on { border-color: var(--gold); box-shadow: 0 0 0 3px var(--goldDim); opacity: 1; }
/* الصورة الفرعية — دائماً تملأ الزر بدون تغيير حجمه */
.lb2-thumbimg {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block;
  aspect-ratio: auto;  /* يرث من الزر */
}
.lb2-thumbvid {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,.35);
  color: var(--gold);
}

@media (max-width: 767px) {
  .lb2-subbar { width: calc(100vw - 1.6rem); height: 54px; min-height: 54px; max-height: 54px; }
  .lb2-thumbbtn {
    width: 52px !important;
    height: 40px !important;
    min-width: 52px;
    max-width: 52px;
    min-height: 40px;
    max-height: 40px;
    flex: 0 0 52px;
    border-radius: 7px;
  }
  .lb2-info-panel { padding: .7rem 1rem; gap: .6rem; }
  .lb2-meta { flex-wrap: wrap; gap: .45rem; }
}

/* Info panel — محدَّث بتصميم أوضح + CTA + أزرار تنقل مدموجة */
.lb2-info-panel {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 1rem;
  padding: .9rem 1.5rem; flex-shrink: 0;
  background: var(--lb-info);
  border-block-start: 1px solid var(--white-alpha-08);
}
.lb2-info-main { flex: 1 1 280px; min-width: 0; }
.lb2-title   { font-size: 1.05rem; font-weight: 800; color: var(--txt); }
.lb2-brief   { font-size: .8rem; color: var(--txt2); line-height: 1.65; margin-block-start: .3rem; }
.lb2-meta    { display: flex; align-items: center; gap: .75rem; white-space: nowrap; margin-block-start: .45rem; }
.lb2-views   { font-size: .75rem; color: var(--txt2); display: flex; align-items: center; gap: 4px; }
.lb2-counter { font-size: .72rem; color: var(--txt2); display: inline-flex; align-items: center; gap: 4px; padding: 2px 8px; background: var(--white-alpha-06); border-radius: 20px; }

/* ⚡ منطقة الإجراءات: CTA أساسي + أزرار تنقل بين الأعمال */
.lb2-info-actions {
  display: flex; align-items: center; gap: .75rem; flex-wrap: wrap;
  flex: 0 0 auto;
}
.lb2-cta-similar {
  padding: .6rem 1.2rem !important;
  font-size: .85rem !important;
  white-space: nowrap;
}
.lb2-work-nav {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .35rem .6rem;
  background: var(--white-alpha-04);
  border: 1px solid var(--brd);
  border-radius: 999px;
}
.lb2-worknav-btn {
  display: inline-flex; align-items: center; gap: 4px;
  padding: .35rem .7rem;
  font-size: .78rem; font-weight: 700;
  color: var(--txt2);
  background: transparent;
  border: none;
  border-radius: 999px;
  cursor: pointer;
  transition: all .15s var(--ease2);
  font-family: inherit;
}
.lb2-worknav-btn:hover {
  background: var(--goldDim);
  color: var(--gold);
}
.lb2-worknav-btn:active { background: var(--goldGlow); }
.lb2-worknav-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--gold);
}
.lb2-work-count {
  font-size: .72rem; color: var(--txt3); font-weight: 600;
  padding: 0 .35rem;
  min-width: 38px; text-align: center;
}

@media (max-width: 640px) {
  .lb2-info-panel { flex-direction: column; align-items: stretch; gap: .75rem; padding: .8rem 1rem; }
  .lb2-info-actions { width: 100%; flex-direction: column; gap: .5rem; }
  .lb2-cta-similar { width: 100%; justify-content: center; }
  .lb2-work-nav { width: 100%; justify-content: space-between; }
  .lb2-worknav-btn { flex: 1; justify-content: center; }
}

/* (تمت إزالة القواعد المكررة — القواعد الأساسية أعلاه تفرض الأبعاد الثابتة) */

/* CTA band */
.cta-band {
  display: grid; grid-template-columns: 1fr auto;
  align-items: center; gap: 2rem;
  padding: 2rem 2.5rem; margin-block-start: 2rem;
  background: linear-gradient(135deg, var(--ink3), var(--ink4));
  border: 1px solid var(--goldGlow); border-radius: var(--r2);
}
.cta-band .btn-ghost {
  justify-self: end;
  min-height: 44px;
}
.cta-band h3 { font-size: 1.1rem; font-weight: 800; margin-block-end: .35rem; }
.cta-band p  { font-size: .85rem; color: var(--txt2); }
.cta-band em { color: var(--gold); font-style: normal; }
@media (max-width: 580px) { .cta-band { grid-template-columns: 1fr; text-align: center; } }

/* ━━ JOURNEY / PROCESS ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#process { z-index: 20; }

.journey2 {
  display: flex; flex-direction: column;
  gap: 0; position: relative; overflow: visible;
}
@media (min-width: 768px) {
  .journey2 { flex-direction: row; align-items: flex-start; gap: .5rem; }
}

.j2step {
  flex: 1; text-align: center; overflow: visible;
  cursor: pointer; position: relative; z-index: 1;
  padding: .75rem .5rem 1rem;
  border-radius: var(--r2);
  transition: background .2s;
}
@media (min-width: 768px) {
  /* رفع الـ step الـhovered فوق إخوته حتى يظهر tooltip خارج حدوده */
  .j2step:hover { background: var(--admin-alpha-03, rgba(255,255,255,.03)); z-index: 10; }
}
.j2circle {
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--ink3); border: 2px solid var(--white-alpha-14);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem; transition: var(--t-normal);
  margin-inline: auto; margin-block-end: .75rem;
  /* لا z-index هنا: إزالة stacking context الداخلي حتى يعمل z-index:9999 على tooltip */
  position: relative;
}
.j2circle:focus { outline: none; box-shadow: 0 0 0 3px var(--goldGlow); }

/* ── tooltip: نظهره فوق الزر مباشرة ── */
.j2tip {
  position: absolute;
  left: 50%;
  top: calc(100% + 10px);
  bottom: auto;
  transform: translateX(-50%) translateY(-4px);
  width: min(260px, 72vw);
  text-align: start;
  background: var(--glass-bg3, rgba(10,10,30,.95));
  border: 1px solid var(--goldGlow);
  border-radius: 14px;
  padding: .7rem .85rem;
  box-shadow: var(--shadow-lg), 0 0 32px var(--goldDim);
  backdrop-filter: blur(14px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;
  z-index: 9999;
  white-space: normal;
}
.j2tip::after {
  content: '';
  position: absolute;
  top: -7px;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
  width: 13px; height: 13px;
  background: var(--glass-bg3, rgba(10,10,30,.95));
  border-inline-start: 1px solid var(--goldGlow);
  border-block-start: 1px solid var(--goldGlow);
}
.j2tip b   { display:block; font-size:.82rem; font-weight:900; color: var(--txt); margin-bottom:.22rem; }
.j2tip span{ display:block; font-size:.76rem; color: var(--txt2); line-height:1.6; }
.j2circle:hover .j2tip,
.j2circle:focus .j2tip { opacity: 1; transform: translateX(-50%) translateY(0); }

/* حالة النشاط */
.j2step.on .j2circle {
  border-color: var(--jcolor, var(--gold));
  background: var(--goldDim);
  box-shadow: 0 0 20px var(--goldGlow);
}
.j2step.on .j2detail { display: block !important; }

.j2header {
  display: flex; align-items: center; gap: .65rem;
  margin-block-end: .4rem; flex-wrap: wrap; justify-content: center;
}
.j2num   { font-size: .6rem; font-weight: 800; color: var(--jcolor, var(--gold)); letter-spacing: 2px; text-transform: uppercase; }
.j2title { font-size: 1rem; font-weight: 800; color: var(--txt); }
.j2step.on .j2title { color: var(--jcolor, var(--gold)); }
.j2detail { display: none; padding-top: .45rem; }
.j2desc   { font-size: .85rem; color: var(--txt2); line-height: 1.8; margin-block-end: .6rem; }
.j2tags   { display: flex; flex-wrap: wrap; gap: .38rem; margin-block-end: .55rem; }
.j2tag    { padding: .24rem .7rem; border-radius: var(--r4); background: var(--goldDim); color: var(--gold); font-size: .7rem; border: 1px solid var(--goldGlow); }
.j2time   { display: inline-flex; align-items: center; gap: 5px; font-size: .74rem; color: var(--txt2); }

/* Popover */
.j2-popover {
  position: fixed; z-index: 99999;
  background: var(--popover-bg);
  border: 1px solid var(--goldGlow); border-radius: var(--r2);
  padding: 1.3rem 1.5rem; width: 275px;
  box-shadow: var(--shadow-lg), 0 0 60px var(--goldDim);
  pointer-events: all;
  opacity: 0; visibility: hidden; transform: translateY(8px);
  transition: opacity .2s, transform .2s, visibility .2s;
}
.j2-popover.show { opacity: 1; visibility: visible; transform: translateY(0); }
.j2-popover::before {
  content: ''; position: absolute;
  inset-block-start: -7px;
  inset-inline-start: var(--arrow-pct, 50%);
  transform: translateX(-50%) rotate(45deg);
  width: 13px; height: 13px; background: var(--popover-bg-flat);
  border-inline-start: 1px solid var(--goldGlow);
  border-block-start: 1px solid var(--goldGlow);
  z-index: -1;
}
.j2pop-step  { font-size: .6rem; color: var(--gold); font-weight: 800; letter-spacing: 2px; text-transform: uppercase; margin-block-end: .25rem; }
.j2pop-title { font-size: .95rem; font-weight: 800; margin-block-end: .55rem; color: var(--txt); }
.j2pop-desc  { font-size: .77rem; color: var(--txt2); line-height: 1.7; margin-block-end: .5rem; }
.j2pop-tags  { display: flex; flex-wrap: wrap; gap: .25rem; margin-block-end: .45rem; }
.j2pop-tag   { padding: .16rem .55rem; border-radius: var(--r4); background: var(--goldDim); color: var(--gold); font-size: .67rem; border: 1px solid var(--goldGlow); }
.j2pop-time  { font-size: .69rem; color: var(--txt2); display: flex; align-items: center; gap: 4px; }

@media (max-width: 767px) {
  .j2-popover {
    position: fixed !important;
    inset-block-end: 1rem !important;
    inset-inline: 1rem !important;
    top: auto !important; width: auto !important;
  }
  .j2step   { text-align: start; padding-inline-start: .5rem; }
  .j2circle { margin-inline-start: 0; margin-inline-end: auto; }
  .j2header { justify-content: flex-start; }
  /* على الموبايل: اعرض التفاصيل دائماً */
  .j2detail { display: block; padding-top: .35rem; }
  /* اخفِ tooltip على اللمس */
  .j2circle:hover .j2tip { opacity: 0; pointer-events: none; }
}

/* ━━ TESTIMONIALS ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.tgrid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
}
.tgrid-featured {
  grid-template-columns: minmax(0, min(100%, 760px));
  justify-content: center;
}

.tcard {
  background: var(--card-bg, var(--ink3));
  border: 1px solid var(--brd);
  border-radius: var(--r2);
  padding: 1.5rem 1.75rem;
  display: flex; flex-direction: column; gap: 1rem;
  transition: var(--t-normal);
  min-height: 100%;
}
.tcard:hover { border-color: var(--goldGlow); transform: translateY(-3px); }

.tcard-stars { font-size: 1rem; color: var(--gold); letter-spacing: 3px; }

.tcard-txt {
  font-size: .88rem; color: var(--txt2); line-height: 1.75;
  font-style: italic; flex: 1; position: relative;
}
.tcard-txt::before {
  content: '"'; font-size: 3rem; color: var(--goldDim);
  position: absolute; inset-block-start: -.75rem; inset-inline-end: 0;
  font-family: serif; line-height: 1; pointer-events: none;
}

.tcard-auth {
  display: flex; align-items: center; gap: .85rem;
  border-block-start: 1px solid var(--brd);
  padding-block-start: .85rem;
}
.tcard-av {
  width: 42px; height: 42px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, var(--gold), var(--cyan));
  display: flex; align-items: center; justify-content: center;
  font-size: .85rem; font-weight: 900; color: var(--ink);
}
.tcard-av img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.tcard-name { font-weight: 800; font-size: .88rem; }
.tcard-role { font-size: .72rem; color: var(--txt2); margin-block-start: .1rem; }

/* Link arrow — عكس حسب الاتجاه */
.clink-arr {
  color: var(--txt3); flex-shrink: 0;
  transition: var(--t-fast); margin-inline-start: auto;
}
html[dir="ltr"] .clink-arr { transform: scaleX(-1); }
.clink:hover .clink-arr { color: var(--gold); }

/* ━━ PROOF BAR ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.proofbar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(1rem, 4vw, 2.5rem);
  flex-wrap: wrap;
  padding: 1.5rem clamp(1rem, 3vw, 2rem);
  border-block: 1px solid var(--brd);
  background: var(--ink2);
}
.proof-item {
  display: flex; flex-direction: column; align-items: center; gap: .2rem;
  text-align: center;
}
.proof-num  { font-size: clamp(1.35rem, 4.5vw, 1.85rem); font-weight: 900; color: var(--gold); line-height: 1; }
.proof-lbl  { font-size: .72rem; color: var(--txt2); }

/* ⚡ النسخة المحسَّنة: أيقونات + بطاقات تفاعلية + count-up */
.proofbar.proofbar--enhanced {
  background: linear-gradient(135deg, var(--ink2) 0%, var(--ink3) 50%, var(--ink2) 100%);
  padding: 1.8rem clamp(1rem, 3vw, 2rem);
  position: relative;
  overflow: hidden;
}
.proofbar--enhanced::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 80% at 50% 0%, var(--goldDim), transparent 70%);
  pointer-events: none;
}
.proofbar--enhanced .proof-item {
  flex-direction: row;
  align-items: center;
  gap: .85rem;
  padding: .7rem 1.1rem;
  border-radius: 14px;
  border: 1px solid transparent;
  background: var(--white-alpha-02, rgba(255,255,255,.02));
  cursor: default;
  transition: transform .25s var(--ease), border-color .25s, background .25s, box-shadow .25s;
  text-align: start;
  min-width: 150px;
  position: relative;
  z-index: 1;
}
.proofbar--enhanced .proof-item:hover {
  transform: translateY(-3px);
  border-color: var(--goldGlow);
  background: var(--goldDim);
  box-shadow: 0 8px 24px rgba(245,197,53,.12), 0 0 0 1px var(--goldGlow);
}
.proofbar--enhanced .proof-ic {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: var(--goldDim);
  border: 1px solid var(--goldGlow);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--gold);
  flex-shrink: 0;
  transition: transform .3s var(--ease);
}
.proofbar--enhanced .proof-item:hover .proof-ic {
  transform: scale(1.08) rotate(-3deg);
  background: var(--goldGlow);
}
.proofbar--enhanced .proof-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  align-items: flex-start;
}
.proofbar--enhanced .proof-num {
  font-size: clamp(1.5rem, 4vw, 2rem);
  font-weight: 900;
  color: var(--gold);
  line-height: 1;
  letter-spacing: -.02em;
  font-variant-numeric: tabular-nums;
  text-shadow: 0 0 24px rgba(245,197,53,.3);
}
.proofbar--enhanced .proof-lbl {
  font-size: .76rem;
  color: var(--txt2);
  font-weight: 600;
  white-space: nowrap;
}
@media (max-width: 600px) {
  .proofbar--enhanced .proof-item {
    min-width: 0;
    padding: .55rem .8rem;
    gap: .55rem;
  }
  .proofbar--enhanced .proof-ic {
    width: 36px; height: 36px;
  }
  .proofbar--enhanced .proof-num {
    font-size: 1.4rem;
  }
}

/* ━━ CONTACT FORM ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.contact-form {
  display: flex; flex-direction: column; gap: 1rem;
  max-width: 520px; margin-inline: auto;
}
.contact-grid .contact-form { max-width: none; margin-inline: 0; }
.cform-title { font-weight: 900; color: var(--gold); font-size: 1.05rem; }
.cform-alert { padding: 1rem; border-radius: var(--r2); text-align: center; border: 1px solid transparent; }
.cform-alert.ok { background: rgba(0,255,157,.10); color: var(--green); border-color: rgba(0,255,157,.18); }
.cform-alert.err { background: rgba(255,77,109,.10); color: var(--red); border-color: rgba(255,77,109,.18); }
.cform-fields { display: grid; gap: 1rem; }
.cform-submit { width: 100%; padding: 1rem; font-size: 1.05rem; }
.cform-hint { font-size: .73rem; color: var(--txt3); margin-top: -.25rem; margin-bottom: -.25rem; }
.contact-form textarea.finput { min-height: 160px; resize: vertical; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 520px) { .form-row { grid-template-columns: 1fr; } }

.finput {
  width: 100%; padding: .72rem 1rem;
  background: var(--input-bg);
  border: 1px solid var(--brd); border-radius: var(--r);
  color: var(--txt); font-size: .88rem;
  font-family: inherit; outline: none;
  transition: var(--t-fast);
}
.finput:focus { border-color: var(--gold); background: var(--goldDim); }
.finput::placeholder { color: var(--txt3); }
/* خيارات الـ select — نفرض اللون لمنع إرث المتصفح الأبيض */
select.finput option { background: var(--ink2, #1a1a2e); color: var(--txt); }
[data-theme="light"] select.finput option { background: #ffffff; color: #0f0f2e; }
/* حقل فيه خطأ — حدود حمراء مع تلميح بصري واضح */
.finput--err { border-color: var(--red) !important; background: rgba(255,77,109,.05) !important; }
.finput--err:focus { border-color: var(--red) !important; background: rgba(255,77,109,.08) !important; }

textarea.finput { resize: vertical; min-height: 120px; line-height: 1.6; }

/* ⚡ منع iOS auto-zoom على حقول الإدخال — يجب ≥ 16px */
@media (max-width: 767px) {
  .finput, textarea.finput, .svc-inp, input.fi, select.fi, textarea.fi {
    font-size: 16px !important;
  }
}

/* ━━ SECTION HEAD ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.sh { margin-block-end: 1.75rem; text-align: center; }
.sh mark { color: var(--gold); background: var(--goldDim); padding: 0 .35rem; border-radius: .45rem; }

/* ━━ CONTACT LINKS ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.clinks { display: grid; gap: .75rem; align-content: start; }
.clink {
  display: flex; align-items: center; gap: .8rem;
  padding: 1rem 1.1rem;
  border-radius: var(--r2);
  background: var(--white-alpha-03);
  border: 1px solid var(--brd);
  color: var(--txt);
  transition: var(--t-fast);
}
.clink:hover { border-color: var(--goldGlow); background: var(--goldDim); }
.clink span { color: var(--txt2); font-size: .78rem; }
.clink b { font-weight: 900; font-size: .9rem; color: var(--txt); }
.clink.is-disabled { opacity: .55; pointer-events: none; }

.stars-input { display: inline-flex; gap: .25rem; }
.stars-input button {
  font-size: 1.35rem;
  color: var(--gold);
  opacity: .55;
  padding: .1rem .15rem;
  border-radius: 6px;
}
.stars-input button[aria-checked="true"] { opacity: 1; }
.stars-input button:hover { opacity: 1; }

/* ━━ URGENT CTA ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ucta-box {
  border-radius: var(--r3);
  border: 1px solid var(--brd);
  background: linear-gradient(135deg, rgba(168,85,247,.14), rgba(0,229,255,.08));
  padding: 2rem 2rem;
  text-align: center;
}
.utag {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .25rem .75rem;
  border-radius: var(--r4);
  background: var(--goldDim);
  border: 1px solid var(--goldGlow);
  color: var(--gold);
  font-weight: 800;
  font-size: .75rem;
  margin-block-end: 1rem;
}
.utitle { font-size: clamp(1.35rem, 2.6vw, 2rem); font-weight: 900; margin-block-end: .6rem; }
.usub { color: var(--txt2); font-size: .95rem; line-height: 1.8; margin-block-end: 1.25rem; }
.usub em { color: var(--gold); font-style: normal; font-weight: 800; }
.ubtns { display: flex; justify-content: center; gap: .6rem; flex-wrap: wrap; }
@media (max-width: 520px) { .ucta-box { padding: 1.35rem 1.1rem; } }

@media (prefers-reduced-motion: reduce) {
  .c3d-card,
  .pin,
  .pin-paper,
  .pin-img,
  .tcard,
  .ft-link,
  .cta-band,
  .svc-face {
    transition: none !important;
    animation: none !important;
    transform: none !important;
  }
}

/* ━━ SHARE MODAL ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.share-card{
  width: min(520px, 92vw);
  background: var(--glass-bg);
  border: 1px solid var(--brd);
  border-radius: var(--r2);
  padding: 1.1rem 1.1rem;
  position: relative;
}
.share-hd{ margin-bottom: .8rem; }
.share-title{ font-weight: 900; font-size: 1.05rem; }
.share-sub{ color: var(--txt2); font-size: .78rem; margin-top: .2rem; }
.share-prev{
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: .75rem;
  padding: .75rem;
  border-radius: 14px;
  border: 1px solid var(--white-alpha-08);
  background: var(--white-alpha-02);
}
.share-img{ width: 92px; height: 92px; object-fit: cover; border-radius: 12px; border: 1px solid var(--white-alpha-08); }
.share-meta b{ display:block; font-weight: 900; margin-bottom: .2rem; }
.share-actions{ display:flex; gap:.6rem; flex-wrap:wrap; margin-top: .85rem; }
.share-grid{ display:grid; grid-template-columns:1fr 1fr; gap:.55rem; margin-top:.75rem; }
.share-pill{
  display:flex; align-items:center; justify-content:center; gap:.45rem;
  padding:.6rem .7rem;
  border-radius: 12px;
  border: 1px solid var(--white-alpha-10);
  background: var(--white-alpha-03);
  color: var(--txt);
  transition: var(--t-fast);
}
.share-pill:hover{ border-color: var(--goldGlow); background: var(--goldDim); color: var(--gold); }
@media (max-width: 520px){ .share-grid{ grid-template-columns:1fr; } .share-prev{ grid-template-columns:1fr; } .share-img{ width: 100%; height: 160px; } }

/* ━━ PRIVATE BANNER ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#privateBanner {
  position: sticky;
  inset-block-start: var(--nav-h, 60px);
  inset-inline: 0;
  z-index: 300;
  /* display يتحكم فيه Alpine x-show — لا تضع display:none هنا */
  padding: .65rem 1.5rem;
  text-align: center;
  font-size: .85rem; font-weight: 700; color: #fff;
  backdrop-filter: blur(8px);
  background: linear-gradient(90deg, rgba(168,85,247,.9), rgba(0,229,255,.9));
}

/* ━━ PITCH REVIEW BOX ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#pitchReviewBox {
  position: fixed;
  bottom: 1.5rem;
  inset-inline-end: 1.5rem;
  z-index: 8500;
  max-width: 260px;
  /* display يتحكم فيه Alpine x-show */
}
@media (max-width: 480px) {
  #pitchReviewBox { inset-inline: 1rem; max-width: none; bottom: 1rem; }
}

/* Mobile-first UX tuning (EN/AR) */
.wsw-btn,
.cpill,
.sort-pill,
.share-pill { min-height: 40px; }

@media (max-width: 767px) {
  .wsw-wrap,
  .cpills {
    justify-content: flex-start;
    overflow-x: auto;
    overflow-y: hidden;
    padding-block-end: 2px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .wsw-wrap::-webkit-scrollbar,
  .cpills::-webkit-scrollbar { display: none; }
  .wsw {
    flex-wrap: nowrap;
    justify-content: flex-start;
    min-width: max-content;
  }
  .c3d-stage { height: min(320px, 58vh); border-radius: 14px; }
  .c3d-card { width: min(260px, 78vw); height: min(280px, 50vh); }
  .c3d-meta { padding: .75rem; }
  .wall-topbar { align-items: stretch; gap: .6rem; }
  .sort-row,
  .sort-pills { width: 100%; }
  .sort-pill {
    flex: 1 1 calc(50% - .2rem);
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .3rem;
  }
  .proofbar {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    padding: 1rem .75rem;
  }
  .proof-item { align-items: flex-start; text-align: start; }
  [dir="rtl"] .proof-item { align-items: flex-end; text-align: end; }
  .proof-num { font-size: 1.45rem; }
  .proof-lbl { font-size: .68rem; }
  .pin {
    transform: none !important;
  }
  .pin:not(.dimmed):hover {
    transform: none !important;
  }
  .pin-brief {
    max-height: 44px;
    padding-block-start: .32rem;
  }
  .pin-acts {
    opacity: 1;
    transform: none;
    padding-block-start: .55rem;
  }
  .pin-foot { padding: .75rem .8rem .82rem; }
  .finput { min-height: 44px; font-size: .92rem; }
  .contact-form textarea.finput { min-height: 145px; }
  .share-actions .btn-gold,
  .share-actions .btn-ghost { flex: 1 1 100%; justify-content: center; min-height: 44px; }
  .share-pill { min-height: 42px; }
}

/* Desktop polish (EN/AR) */
@media (min-width: 1024px) {
  .sort-pill { min-height: 36px; }
  html[lang="en"] .proofbar { gap: 3rem; }
  html[lang="ar"] .proofbar { gap: 2.6rem; }
}

/* ━━ LIVE BADGE ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.live-dot   { width:6px; height:6px; border-radius:50%; background:var(--green); animation:pulse 1.5s ease-in-out infinite; }
.live-badge { display:flex; align-items:center; gap:6px; padding:.3rem .85rem; border-radius:var(--r4); background:rgba(0,255,157,.07); border:1px solid rgba(0,255,157,.18); color:var(--green); font-size:.72rem; }
