/* ============================================================
   Mustafa Haj — Public Site (Arabic RTL) · app styles
   (design tokens come from the bound _ds colors_and_type.css,
    linked in the HTML head)
   ============================================================ */

html, body { background: var(--surface); min-height: 100%; }
body { overflow-x: hidden; }
html { direction: rtl; scroll-behavior: smooth; }

* { -webkit-tap-highlight-color: transparent; }
::selection { background: var(--vibrant-highlight); color: var(--deep-purple-void); }

a { color: inherit; text-decoration: none; }
button { font-family: inherit; }
img { display: block; max-width: 100%; }

/* Arabic content gets Plex; English display gets Anton; meta gets Alexandria */
body { font-family: var(--font-arabic); }
.en { font-family: var(--font-display); direction: ltr; text-transform: uppercase; }
.meta-en { font-family: var(--font-meta); direction: ltr; letter-spacing: 0.10em; text-transform: uppercase; }
.mono { font-family: var(--font-mono); direction: ltr; }

h1, h2 { font-family: var(--font-display); }
:lang(ar) h1, :lang(ar) h2, .ar-head { font-family: var(--font-arabic); }

/* ---------- Interactive blueprint background ---------- */
#bp-canvas {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  width: 100vw; height: 100vh;
}
#app { position: relative; z-index: 1; }

/* content is always visible — no opacity-gated entrance (keeps the
   page robust even where the animation clock is paused) */
.reveal { opacity: 1; }

/* ============================================================
   Layout primitives
   ============================================================ */
.wrap { max-width: 1280px; margin: 0 auto; padding-inline: 48px; }
.section { padding-block: 96px; position: relative; }
.section-sm { padding-block: 56px; }

.eyebrow-row { display: inline-flex; align-items: center; gap: 10px; }
.eyebrow-row::before { content: ''; width: 22px; height: 1.5px; background: var(--electric-purple); }
.eyebrow-row .tx { font-family: var(--font-meta); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--electric-purple); }

.kicker { font-family: var(--font-meta); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--on-surface-variant); }
.coord { font-family: var(--font-meta); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--on-surface-variant); opacity: 0.65; direction: ltr; }

.section-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 36px; flex-wrap: wrap; }
.section-head h2 { font-size: clamp(30px, 4vw, 46px); line-height: 1.05; color: var(--deep-purple-void); font-weight: 700; letter-spacing: -0.01em; }
.section-head .view-all { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-meta); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--electric-purple); padding: 10px 16px; border-radius: var(--radius-full); box-shadow: inset 0 0 0 1px rgba(78,61,199,0.22); transition: all var(--duration-base) var(--ease-out); white-space: nowrap; }
.section-head .view-all:hover { background: var(--electric-purple); color: #fff; box-shadow: var(--shadow-glow-primary-soft); }

/* ============================================================
   Buttons
   ============================================================ */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 9px; padding: 13px 22px; border-radius: var(--radius-md); border: 0; cursor: pointer; font-size: 14px; font-weight: 600; font-family: var(--font-arabic); transition: all var(--duration-base) var(--ease-out); white-space: nowrap; }
.btn svg { width: 17px; height: 17px; }
.btn-primary { background: var(--electric-purple); color: #fff; box-shadow: var(--shadow-glow-primary-soft); }
.btn-primary:hover { background: var(--electric-purple-deep); box-shadow: var(--shadow-glow-primary); transform: translateY(-1px); }
.btn-primary:active { transform: scale(0.98); }
.btn-outline { background: transparent; color: var(--deep-purple-void); box-shadow: inset 0 0 0 1px var(--outline-variant); }
.btn-outline:hover { box-shadow: inset 0 0 0 1.5px var(--electric-purple); color: var(--electric-purple); }
.btn-ghost { background: var(--vibrant-highlight-soft); color: var(--electric-purple); }
.btn-ghost:hover { background: var(--vibrant-highlight); }
.btn-block { width: 100%; }
.btn-lg { padding: 16px 28px; font-size: 15px; }
.btn-sm { padding: 9px 16px; font-size: 13px; }

.chip { display: inline-flex; align-items: center; gap: 7px; padding: 7px 14px; border-radius: var(--radius-full); font-family: var(--font-meta); font-size: 11px; letter-spacing: 0.06em; background: var(--surface-container); color: var(--on-surface-variant); cursor: pointer; transition: all var(--duration-fast) var(--ease-out); border: 0; }
.chip:hover { background: var(--vibrant-highlight-soft); color: var(--electric-purple); }
.chip.active { background: var(--electric-purple); color: #fff; box-shadow: var(--shadow-glow-primary-soft); }

.badge { display: inline-flex; align-items: center; gap: 6px; padding: 5px 11px; border-radius: var(--radius-full); font-family: var(--font-meta); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; }
.badge-purple { background: var(--vibrant-highlight); color: var(--electric-purple-deep); }
.badge-void { background: var(--deep-purple-void); color: #fff; }
.badge-success { background: rgba(31,138,91,0.12); color: var(--success); }
.badge-warn { background: rgba(176,116,6,0.12); color: var(--warning); }
.badge-error { background: var(--error-container); color: var(--on-error-container); }

/* ============================================================
   Header / Navigation
   ============================================================ */
.nav { position: sticky; top: 0; z-index: 40; background: rgba(250,249,252,0.82); backdrop-filter: blur(16px) saturate(150%); border-bottom: 1px solid rgba(8,0,65,0.07); }
.nav-inner { max-width: 1280px; margin: 0 auto; padding: 12px 48px; display: flex; align-items: center; gap: 28px; }
.nav .brand { display: flex; align-items: center; gap: 11px; cursor: pointer; flex: none; }
.nav .brand img { height: 30px; width: auto; }
.nav .brand .wm { display: flex; flex-direction: column; line-height: 1.05; }
.nav .brand .wm .ar { font-family: var(--font-arabic); font-weight: 700; font-size: 15px; color: var(--deep-purple-void); }
.nav .brand .wm .en { font-family: var(--font-meta); font-size: 9px; letter-spacing: 0.18em; color: var(--on-surface-variant); }
.nav .links { display: flex; align-items: center; gap: 4px; }
.nav .links a { font-size: 14px; font-weight: 500; color: var(--on-surface-variant); padding: 9px 14px; border-radius: var(--radius-full); transition: all var(--duration-fast) var(--ease-out); cursor: pointer; }
.nav .links a:hover { color: var(--electric-purple); background: var(--vibrant-highlight-soft); }
.nav .links a.active { color: var(--electric-purple); background: var(--vibrant-highlight); }
.nav .spacer { flex: 1; }
.nav .tools { display: flex; align-items: center; gap: 4px; }
.icon-btn { position: relative; width: 40px; height: 40px; border-radius: var(--radius-full); display: inline-flex; align-items: center; justify-content: center; background: transparent; border: 0; cursor: pointer; color: var(--deep-purple-void); transition: all var(--duration-fast) var(--ease-out); }
.icon-btn:hover { background: var(--surface-container); color: var(--electric-purple); }
.icon-btn svg { width: 19px; height: 19px; }
.icon-btn .count { position: absolute; top: 2px; inset-inline-start: 2px; min-width: 17px; height: 17px; padding: 0 4px; border-radius: 9px; background: var(--electric-purple); color: #fff; font-family: var(--font-mono); font-size: 10px; display: flex; align-items: center; justify-content: center; box-shadow: 0 0 0 2px var(--surface); }
.hamburger { display: none; }

/* search overlay */
.search-overlay { position: fixed; inset: 0; z-index: 60; background: rgba(8,0,65,0.32); backdrop-filter: blur(6px); display: flex; align-items: flex-start; justify-content: center; padding-top: 14vh; opacity: 0; pointer-events: none; transition: opacity var(--duration-base) var(--ease-out); }
.search-overlay.open { opacity: 1; pointer-events: auto; }
.search-box { width: min(640px, 92vw); background: var(--pure-white); border-radius: var(--radius-lg); box-shadow: var(--shadow-card-lifted); padding: 8px; transform: translateY(-12px); transition: transform var(--duration-base) var(--ease-out); }
.search-overlay.open .search-box { transform: translateY(0); }
.search-box .row { display: flex; align-items: center; gap: 12px; padding: 14px 18px; }
.search-box input { flex: 1; border: 0; outline: 0; background: transparent; font-family: var(--font-arabic); font-size: 18px; color: var(--deep-purple-void); }
.search-box .hint { padding: 6px 18px 14px; font-family: var(--font-meta); font-size: 10px; letter-spacing: 0.12em; color: var(--on-surface-variant); border-top: 1px solid var(--surface-container); margin-top: 4px; padding-top: 12px; }

/* ============================================================
   Drawer (cart / favorites)
   ============================================================ */
.scrim { position: fixed; inset: 0; z-index: 70; background: rgba(8,0,65,0.34); backdrop-filter: blur(4px); opacity: 0; pointer-events: none; transition: opacity var(--duration-base) var(--ease-out); }
.scrim.open { opacity: 1; pointer-events: auto; }
.drawer { position: fixed; top: 0; inset-inline-start: 0; height: 100%; width: min(420px, 92vw); background: var(--surface); z-index: 80; box-shadow: 0 0 60px -10px rgba(8,0,65,0.4); transform: translateX(105%); transition: transform var(--duration-slow) var(--ease-out); display: flex; flex-direction: column; }
.drawer.open { transform: translateX(0); }
.drawer-head { display: flex; align-items: center; justify-content: space-between; padding: 22px 24px; border-bottom: 1px solid rgba(8,0,65,0.08); }
.drawer-head h3 { font-size: 20px; font-weight: 700; color: var(--deep-purple-void); }
.drawer-body { flex: 1; overflow-y: auto; padding: 16px 20px; }
.drawer-foot { padding: 20px 24px; border-top: 1px solid rgba(8,0,65,0.08); background: var(--surface-container-lowest); }
.drawer-empty { text-align: center; padding: 64px 20px; color: var(--on-surface-variant); }
.drawer-empty svg { width: 44px; height: 44px; margin: 0 auto 16px; color: var(--outline-variant); }

.line-item { display: flex; gap: 14px; padding: 14px 0; border-bottom: 1px solid rgba(8,0,65,0.07); }
.line-item .thumb { width: 64px; height: 64px; border-radius: var(--radius-default); flex: none; overflow: hidden; }
.line-item .li-body { flex: 1; min-width: 0; }
.line-item .li-title { font-weight: 600; font-size: 14px; color: var(--deep-purple-void); margin-bottom: 4px; }
.line-item .li-meta { font-family: var(--font-meta); font-size: 10px; letter-spacing: 0.08em; color: var(--on-surface-variant); text-transform: uppercase; }
.line-item .li-price { font-family: var(--font-mono); font-size: 14px; color: var(--electric-purple); margin-top: 6px; }
.line-item .li-remove { align-self: flex-start; width: 30px; height: 30px; border-radius: 50%; border: 0; background: transparent; color: var(--outline); cursor: pointer; display: flex; align-items: center; justify-content: center; }
.line-item .li-remove:hover { background: var(--error-container); color: var(--on-error-container); }
.total-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.total-row .lbl { font-family: var(--font-meta); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--on-surface-variant); }
.total-row .val { font-family: var(--font-mono); font-size: 24px; color: var(--deep-purple-void); }

/* ============================================================
   Cards (product / generic)
   ============================================================ */
.card { background: var(--pure-white); border-radius: var(--radius-lg); box-shadow: var(--shadow-card); overflow: hidden; position: relative; transition: transform var(--duration-base) var(--ease-out), box-shadow var(--duration-base) var(--ease-out); display: flex; flex-direction: column; }
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card-lifted); }
.card .thumb { aspect-ratio: 16/10; position: relative; overflow: hidden; }
.card .thumb .ph-label { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.card .card-body { padding: 20px 22px 22px; display: flex; flex-direction: column; flex: 1; }
.card .card-body h3 { font-size: 18px; font-weight: 700; color: var(--deep-purple-void); line-height: 1.3; margin-bottom: 8px; }
.card .card-body p { font-size: 13.5px; color: var(--on-surface-variant); line-height: 1.6; margin-bottom: 16px; }
.card .card-foot { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.price { font-family: var(--font-mono); font-size: 18px; color: var(--electric-purple); direction: ltr; }
.price .cur { font-size: 13px; color: var(--on-surface-variant); }
.price-free { font-family: var(--font-meta); font-size: 12px; letter-spacing: 0.08em; color: var(--success); text-transform: uppercase; }

.card-meta-row { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.card-fav { position: absolute; top: 12px; inset-inline-end: 12px; width: 36px; height: 36px; border-radius: 50%; background: rgba(255,255,255,0.9); backdrop-filter: blur(6px); border: 0; cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--deep-purple-void); z-index: 2; transition: all var(--duration-fast) var(--ease-out); box-shadow: 0 2px 10px -2px rgba(8,0,65,0.2); }
.card-fav:hover { color: var(--electric-purple); transform: scale(1.08); }
.card-fav.on { color: #fff; background: var(--electric-purple); }
.card-fav.on svg { fill: currentColor; }

/* image placeholder visual */
.ph { background:
  repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 11px),
  radial-gradient(circle at 30% 20%, rgba(255,255,255,0.10), transparent 60%),
  var(--deep-purple-void);
  position: relative; }
.ph.alt { background:
  repeating-linear-gradient(135deg, rgba(8,0,65,0.05) 0 2px, transparent 2px 11px),
  radial-gradient(circle at 70% 30%, rgba(78,61,199,0.18), transparent 60%),
  var(--vibrant-highlight); }
.ph .glyph { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; opacity: 0.5; }
.ph .glyph img { height: 40%; width: auto; opacity: 0.85; }
.ph .ph-tag { position: absolute; bottom: 10px; inset-inline-start: 12px; font-family: var(--font-meta); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.6); direction: ltr; }
.ph.alt .ph-tag { color: var(--on-surface-variant); }

/* ============================================================
   Carousel
   ============================================================ */
.carousel { position: relative; }
.carousel-track { display: flex; gap: 22px; overflow-x: auto; scroll-snap-type: x mandatory; padding-bottom: 8px; scrollbar-width: none; }
.carousel-track::-webkit-scrollbar { display: none; }
.carousel-track > * { scroll-snap-align: start; flex: 0 0 300px; }
.carousel-nav { display: inline-flex; gap: 8px; }
.car-btn { width: 42px; height: 42px; border-radius: 50%; border: 0; background: var(--pure-white); box-shadow: inset 0 0 0 1px var(--outline-variant); color: var(--deep-purple-void); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all var(--duration-fast) var(--ease-out); }
.car-btn:hover { background: var(--electric-purple); color: #fff; box-shadow: var(--shadow-glow-primary-soft); }
.car-btn:disabled { opacity: 0.35; cursor: default; }
.car-btn:disabled:hover { background: var(--pure-white); color: var(--deep-purple-void); box-shadow: inset 0 0 0 1px var(--outline-variant); }

/* ============================================================
   Hero
   ============================================================ */
.hero { padding-block: 72px 64px; position: relative; }
.hero-grid { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 56px; align-items: center; }
.hero h1 { font-family: var(--font-arabic); font-weight: 700; font-size: clamp(40px, 6.2vw, 86px); line-height: 1.02; letter-spacing: -0.02em; color: var(--deep-purple-void); margin: 20px 0 22px; }
.hero h1 .pop { color: var(--electric-purple); }
.hero .sub { font-size: 18px; line-height: 1.7; color: var(--on-surface-variant); max-width: 520px; margin-bottom: 28px; }
.hero .actions { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.hero-stats { display: flex; gap: 36px; margin-top: 40px; padding-top: 28px; border-top: 1px solid rgba(8,0,65,0.1); }
.hero-stats .st .n { font-family: var(--font-display); font-size: 34px; color: var(--deep-purple-void); direction: ltr; }
.hero-stats .st .l { font-family: var(--font-meta); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--on-surface-variant); margin-top: 4px; }

.hero-portrait { position: relative; aspect-ratio: 4/5; border-radius: var(--radius-lg); overflow: hidden; background: var(--deep-purple-void); box-shadow: 0 30px 70px -28px rgba(8,0,65,0.45), inset 0 0 0 1px rgba(255,255,255,0.06); }
.hero-portrait img { width: 100%; height: 100%; object-fit: cover; }
.hero-portrait .corner { position: absolute; width: 18px; height: 18px; z-index: 2; }
.hero-portrait .corner::before, .hero-portrait .corner::after { content: ''; position: absolute; background: rgba(255,255,255,0.7); }
.hero-portrait .corner::before { width: 100%; height: 1.5px; top: 0; }
.hero-portrait .corner::after { height: 100%; width: 1.5px; top: 0; }
.hero-portrait .corner.tr { top: 12px; right: 12px; } .hero-portrait .corner.tr::after { right: 0; }
.hero-portrait .corner.bl { bottom: 12px; left: 12px; transform: rotate(180deg); }
.hero-portrait .glass { position: absolute; inset-inline: 14px; bottom: 14px; backdrop-filter: blur(16px) saturate(160%); background: rgba(255,255,255,0.12); box-shadow: inset 0 0 0 1px rgba(255,255,255,0.2); border-radius: var(--radius-md); padding: 13px 15px; color: #fff; display: flex; align-items: center; gap: 12px; }
.hero-portrait .glass .dot { width: 8px; height: 8px; border-radius: 50%; background: #C6BFFF; box-shadow: 0 0 12px #C6BFFF; flex: none; }
.hero-portrait .glass .m { font-family: var(--font-meta); font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.78); direction: ltr; }
.hero-portrait .glass .nm { font-weight: 600; font-size: 13px; margin-top: 2px; }

/* live notification ticker */
.live-ticker { display: flex; align-items: center; gap: 14px; background: var(--pure-white); border-radius: var(--radius-full); padding: 9px 9px 9px 18px; box-shadow: var(--shadow-card); width: fit-content; max-width: 100%; overflow: hidden; }
.live-ticker .pulse { width: 9px; height: 9px; border-radius: 50%; background: var(--success); flex: none; position: relative; }
.live-ticker .pulse::after { content: ''; position: absolute; inset: -4px; border-radius: 50%; border: 1.5px solid var(--success); animation: pulse-ring 1.8s ease-out infinite; }
@keyframes pulse-ring { 0% { transform: scale(0.7); opacity: 0.8; } 100% { transform: scale(1.8); opacity: 0; } }
.live-ticker .tk-label { font-family: var(--font-meta); font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--on-surface-variant); flex: none; }
.live-ticker .tk-content { font-size: 13px; color: var(--deep-purple-void); white-space: nowrap; overflow: hidden; }
.live-ticker .tk-content b { color: var(--electric-purple); font-weight: 600; }
.tk-fade { transition: opacity var(--duration-base) var(--ease-out); }

/* ============================================================
   Service cards (4-up)
   ============================================================ */
.services-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.svc { background: var(--pure-white); border-radius: var(--radius-lg); padding: 26px 24px 22px; box-shadow: var(--shadow-card); position: relative; overflow: hidden; display: flex; flex-direction: column; min-height: 240px; cursor: pointer; transition: transform var(--duration-base) var(--ease-out), box-shadow var(--duration-base) var(--ease-out); }
.svc::before { content: ''; position: absolute; inset-inline-start: 0; top: 16%; bottom: 16%; width: 3px; background: var(--electric-purple); border-radius: 0 3px 3px 0; transition: width var(--duration-base) var(--ease-out); }
.svc:hover { transform: translateY(-4px); box-shadow: var(--shadow-card-lifted); }
.svc:hover::before { width: 5px; }
.svc.t-tertiary::before { background: var(--tertiary); }
.svc.t-void::before { background: var(--deep-purple-void); }
.svc.t-deep::before { background: var(--electric-purple-deep); }
.svc .ic { width: 48px; height: 48px; border-radius: var(--radius-default); background: var(--vibrant-highlight-soft); display: flex; align-items: center; justify-content: center; color: var(--electric-purple); margin-bottom: 18px; }
.svc .ic svg { width: 24px; height: 24px; }
.svc h3 { font-size: 19px; font-weight: 700; color: var(--deep-purple-void); margin-bottom: 8px; }
.svc p { font-size: 13.5px; color: var(--on-surface-variant); line-height: 1.6; margin-bottom: 16px; }
.svc .lnk { margin-top: auto; display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-meta); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--electric-purple); }
.svc .num { position: absolute; top: 22px; inset-inline-end: 22px; font-family: var(--font-mono); font-size: 11px; color: var(--outline-variant); }

/* ============================================================
   CTA band
   ============================================================ */
.cta-band { background: var(--deep-purple-void); border-radius: var(--radius-xl); padding: 64px 56px; position: relative; overflow: hidden; color: #fff; text-align: center; }
.cta-band::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 1px 1px, rgba(255,255,255,0.05) 1px, transparent 1.5px) 0 0 / 18px 18px; pointer-events: none; }
.cta-band .glow { position: absolute; width: 480px; height: 480px; border-radius: 50%; background: radial-gradient(circle, rgba(78,61,199,0.55), transparent 65%); top: -200px; left: 50%; transform: translateX(-50%); filter: blur(20px); pointer-events: none; }
.cta-band h2 { position: relative; font-family: var(--font-arabic); font-weight: 700; font-size: clamp(30px, 4.5vw, 52px); line-height: 1.1; margin-bottom: 16px; }
.cta-band h2 .pop { color: #C6BFFF; }
.cta-band p { position: relative; color: rgba(255,255,255,0.78); font-size: 17px; line-height: 1.6; max-width: 520px; margin: 0 auto 28px; }
.cta-band .actions { position: relative; display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.btn-on-dark { background: #fff; color: var(--deep-purple-void); }
.btn-on-dark:hover { background: var(--vibrant-highlight); }
.btn-on-dark-outline { background: transparent; color: #fff; box-shadow: inset 0 0 0 1px rgba(255,255,255,0.3); }
.btn-on-dark-outline:hover { box-shadow: inset 0 0 0 1.5px #fff; }

/* ============================================================
   Page title section
   ============================================================ */
.page-head { padding-block: 56px 32px; }
.page-head .crumbs { display: flex; align-items: center; gap: 8px; font-family: var(--font-meta); font-size: 11px; letter-spacing: 0.08em; color: var(--on-surface-variant); margin-bottom: 18px; text-transform: uppercase; }
.page-head .crumbs a { cursor: pointer; } .page-head .crumbs a:hover { color: var(--electric-purple); }
.page-head h1 { font-family: var(--font-arabic); font-weight: 700; font-size: clamp(34px, 5vw, 60px); line-height: 1.05; letter-spacing: -0.015em; color: var(--deep-purple-void); margin-bottom: 16px; }
.page-head .lead { font-size: 17px; line-height: 1.7; color: var(--on-surface-variant); max-width: 620px; }

.grid-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }

/* ============================================================
   Featured package (prompts)
   ============================================================ */
.featured-pkg { background: var(--deep-purple-void); border-radius: var(--radius-xl); padding: 44px; color: #fff; position: relative; overflow: hidden; display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; }
.featured-pkg::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 1px 1px, rgba(255,255,255,0.05) 1px, transparent 1.5px) 0 0 / 18px 18px; }
.featured-pkg .glow { position: absolute; width: 360px; height: 360px; border-radius: 50%; background: radial-gradient(circle, rgba(78,61,199,0.6), transparent 65%); top: -140px; inset-inline-end: -80px; filter: blur(10px); }
.featured-pkg .fp-l { position: relative; }
.featured-pkg .fp-price { font-family: var(--font-display); font-size: 72px; line-height: 1; color: #fff; direction: ltr; }
.featured-pkg .fp-price .cur { color: #C6BFFF; }
.featured-pkg h2 { font-family: var(--font-arabic); font-weight: 700; font-size: 30px; margin: 14px 0 12px; }
.featured-pkg p { color: rgba(255,255,255,0.78); line-height: 1.7; font-size: 15px; }
.featured-pkg .fp-r { position: relative; }
.feat-list { list-style: none; padding: 0; margin: 0 0 24px; display: flex; flex-direction: column; gap: 14px; }
.feat-list li { display: flex; align-items: flex-start; gap: 12px; font-size: 15px; color: rgba(255,255,255,0.9); }
.feat-list li .ck { width: 24px; height: 24px; border-radius: 50%; background: rgba(198,191,255,0.18); color: #C6BFFF; flex: none; display: flex; align-items: center; justify-content: center; }
.feat-list li .ck svg { width: 14px; height: 14px; }

/* prompt card */
.prompt-card { background: var(--pure-white); border-radius: var(--radius-lg); padding: 24px; box-shadow: var(--shadow-card); position: relative; overflow: hidden; display: flex; flex-direction: column; transition: transform var(--duration-base) var(--ease-out), box-shadow var(--duration-base) var(--ease-out); }
.prompt-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-card-lifted); }
.prompt-card .pc-cat { font-family: var(--font-meta); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--electric-purple); margin-bottom: 12px; }
.prompt-card h3 { font-size: 18px; font-weight: 700; color: var(--deep-purple-void); margin-bottom: 10px; line-height: 1.3; }
.prompt-card p { font-size: 13.5px; color: var(--on-surface-variant); line-height: 1.6; margin-bottom: 18px; flex: 1; }
.prompt-card .pc-foot { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.prompt-card .tools { display: flex; gap: 6px; }
.prompt-card .tool-tag { font-family: var(--font-mono); font-size: 10px; padding: 3px 8px; border-radius: var(--radius-full); background: var(--surface-container); color: var(--on-surface-variant); }

/* ============================================================
   Detail pages
   ============================================================ */
.detail-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 40px; align-items: start; }
.detail-main { min-width: 0; }
.sticky-side { position: sticky; top: 88px; }

/* course learning layout — player + lessons together in the main
   column; buy CTA + quick-access in a sticky rail. On mobile it
   reflows: player → lessons → buy/access → desc → curriculum → reviews */
.course-layout { display: grid; grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr); column-gap: 40px; row-gap: 24px; align-items: start; }
.course-layout > .panel, .course-layout > .cl-included, .course-layout > .cl-ratings { margin-bottom: 0; }
.cl-player { grid-column: 1; grid-row: 1; }
.cl-lessons { grid-column: 1; grid-row: 2; }
.cl-desc { grid-column: 1; grid-row: 3; }
.cl-included { grid-column: 1; grid-row: 4; min-width: 0; }
.cl-curr { grid-column: 1; grid-row: 5; }
.cl-ratings { grid-column: 1; grid-row: 6; min-width: 0; }
.cl-side { grid-column: 2; grid-row: 1 / span 6; position: sticky; top: 88px; min-width: 0; display: flex; flex-direction: column; gap: 24px; }
.cl-side .panel, .cl-included .panel, .cl-ratings .panel { margin-bottom: 0; }
.cl-now { padding: 16px 20px; display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.cl-now-t { color: var(--deep-purple-void); font-size: 15.5px; }
.lesson-list { display: flex; flex-direction: column; gap: 2px; max-height: 360px; overflow-y: auto; }

@media (max-width: 1024px) {
  .course-layout { grid-template-columns: 1fr; }
  .course-layout > * { grid-column: 1 !important; grid-row: auto !important; }
  .cl-side { position: static; }
  .cl-player { order: 1; }
  .cl-lessons { order: 2; }
  .cl-side { order: 3; display: flex; flex-direction: column; gap: 24px; }
  .cl-desc { order: 4; }
  .cl-included { order: 5; }
  .cl-curr { order: 6; }
  .cl-ratings { order: 7; }
  .lesson-list { max-height: 320px; }
}
.panel { background: var(--pure-white); border-radius: var(--radius-lg); box-shadow: var(--shadow-card); padding: 28px; margin-bottom: 24px; }
.panel h3 { font-size: 20px; font-weight: 700; color: var(--deep-purple-void); margin-bottom: 14px; }
.panel-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; gap: 12px; }
.prose { font-size: 15.5px; line-height: 1.85; color: var(--on-surface-variant); }
.prose p { margin-bottom: 14px; }

.copy-block { background: var(--surface-container-low); border-radius: var(--radius-default); padding: 18px 20px; font-family: var(--font-mono); font-size: 13.5px; line-height: 1.8; color: var(--deep-purple-void); direction: rtl; white-space: pre-wrap; box-shadow: inset 0 0 0 1px rgba(8,0,65,0.07); position: relative; }
.btn-copy { display: inline-flex; align-items: center; gap: 7px; padding: 8px 14px; border-radius: var(--radius-full); border: 0; background: var(--vibrant-highlight-soft); color: var(--electric-purple); font-family: var(--font-meta); font-size: 11px; letter-spacing: 0.06em; cursor: pointer; transition: all var(--duration-fast) var(--ease-out); }
.btn-copy:hover { background: var(--electric-purple); color: #fff; }

/* curriculum / accordion */
.curr { display: flex; flex-direction: column; gap: 10px; }
.curr-item { border-radius: var(--radius-default); box-shadow: inset 0 0 0 1px rgba(8,0,65,0.08); overflow: hidden; background: var(--pure-white); }
.curr-head { display: flex; align-items: center; gap: 14px; padding: 16px 18px; cursor: pointer; user-select: none; }
.curr-head .ix { font-family: var(--font-mono); font-size: 12px; color: var(--electric-purple); width: 28px; }
.curr-head .ti { flex: 1; font-weight: 600; font-size: 15px; color: var(--deep-purple-void); }
.curr-head .ch { color: var(--outline); transition: transform var(--duration-base) var(--ease-out); }
.curr-item.open .curr-head .ch { transform: rotate(180deg); }
.curr-body { max-height: 0; overflow: hidden; transition: max-height var(--duration-slow) var(--ease-out); }
.curr-item.open .curr-body { max-height: 600px; }
.curr-body ul { margin: 0; padding: 4px 18px 18px 18px; list-style: none; display: flex; flex-direction: column; gap: 8px; }
.curr-body li { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--on-surface-variant); padding-inline-start: 42px; }
.curr-body li::before { content: '↳'; color: var(--electric-purple); font-family: var(--font-mono); }

/* lesson list (course player) */
.lesson { display: flex; align-items: center; gap: 12px; padding: 13px 16px; border-radius: var(--radius-default); cursor: pointer; transition: background var(--duration-fast) var(--ease-out); }
.lesson:hover { background: var(--surface-container-low); }
.lesson.active { background: var(--vibrant-highlight); }
.lesson .lx { font-family: var(--font-mono); font-size: 12px; color: var(--electric-purple); width: 26px; flex: none; }
.lesson .lt { flex: 1; font-size: 14px; color: var(--deep-purple-void); font-weight: 500; }
.lesson .done-btn { width: 26px; height: 26px; border-radius: 50%; border: 1.5px solid var(--outline-variant); background: transparent; cursor: pointer; display: flex; align-items: center; justify-content: center; color: transparent; flex: none; }
.lesson.complete .done-btn { background: var(--success); border-color: var(--success); color: #fff; }

.progress-track { height: 6px; border-radius: 3px; background: var(--surface-container); overflow: hidden; }
.progress-fill { height: 100%; background: var(--electric-purple); border-radius: 3px; transition: width var(--duration-slow) var(--ease-out); }

/* media player */
.player { background: var(--deep-purple-void); border-radius: var(--radius-lg); overflow: hidden; position: relative; }
.player .screen { aspect-ratio: 16/9; position: relative; background: var(--ph); }
.player .controls { display: flex; align-items: center; gap: 14px; padding: 14px 18px; background: var(--pure-white); }
.player .controls .pbtn { width: 40px; height: 40px; border-radius: 50%; border: 0; background: var(--electric-purple); color: #fff; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.player .controls .sbtn { width: 36px; height: 36px; border-radius: 50%; border: 0; background: var(--surface-container); color: var(--deep-purple-void); cursor: pointer; display: flex; align-items: center; justify-content: center; }
.player .controls .time { font-family: var(--font-mono); font-size: 12px; color: var(--on-surface-variant); }
.player .controls input[type=range] { flex: 1; accent-color: var(--electric-purple); }

/* pdf viewer */
.pdf-viewer { background: var(--surface-container-low); border-radius: var(--radius-lg); overflow: hidden; box-shadow: inset 0 0 0 1px rgba(8,0,65,0.08); }
.pdf-bar { display: flex; align-items: center; gap: 12px; padding: 12px 16px; background: var(--pure-white); border-bottom: 1px solid rgba(8,0,65,0.08); }
.pdf-bar .pg { font-family: var(--font-mono); font-size: 12px; color: var(--on-surface-variant); margin-inline-start: auto; }
.pdf-page { aspect-ratio: 1/1.3; max-width: 480px; margin: 28px auto; background: #fff; box-shadow: 0 12px 40px -16px rgba(8,0,65,0.3); border-radius: 6px; display: flex; align-items: center; justify-content: center; color: var(--outline-variant); }

/* star rating */
.ratings .stars { display: flex; gap: 8px; margin-bottom: 18px; }
.star-btn { width: 44px; height: 44px; border-radius: var(--radius-default); border: 1.5px solid var(--outline-variant); background: transparent; cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--outline); transition: all var(--duration-fast) var(--ease-out); }
.star-btn:hover, .star-btn.on { border-color: var(--electric-purple); color: var(--warning); background: var(--vibrant-highlight-soft); }
.star-btn.on svg { fill: var(--warning); }
.review-area { width: 100%; min-height: 110px; border-radius: var(--radius-default); border: 1.5px solid var(--outline-variant); padding: 14px 16px; font-family: var(--font-arabic); font-size: 15px; resize: vertical; color: var(--deep-purple-void); background: var(--surface-container-lowest); }
.review-area:focus { outline: 0; border-color: var(--electric-purple); }
.char-count { font-family: var(--font-mono); font-size: 11px; color: var(--on-surface-variant); }
.empty-state { text-align: center; padding: 40px 20px; color: var(--on-surface-variant); }
.empty-state svg { width: 40px; height: 40px; color: var(--outline-variant); margin: 0 auto 12px; }

/* ============================================================
   Forms (advertise / contact)
   ============================================================ */
.form-field { display: flex; flex-direction: column; gap: 8px; margin-bottom: 20px; }
.form-field .fl { display: flex; align-items: baseline; justify-content: space-between; }
.form-field label { font-family: var(--font-meta); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--deep-purple-void); font-weight: 500; }
.form-field .tag { font-family: var(--font-meta); font-size: 10px; letter-spacing: 0.06em; color: var(--electric-purple); direction: ltr; }
.form-field input, .form-field select, .form-field textarea { width: 100%; padding: 14px 16px; border-radius: var(--radius-md); background: var(--surface-container-lowest); color: var(--deep-purple-void); border: 1.5px solid var(--outline-variant); font-family: var(--font-arabic); font-size: 15px; transition: border-color var(--duration-fast) var(--ease-out); }
.form-field input:focus, .form-field textarea:focus, .form-field select:focus { outline: 0; border-color: var(--electric-purple); }
.form-field textarea { min-height: 130px; resize: vertical; }
.upload-zone { border: 2px dashed var(--outline-variant); border-radius: var(--radius-md); padding: 28px; text-align: center; cursor: pointer; transition: all var(--duration-fast) var(--ease-out); color: var(--on-surface-variant); }
.upload-zone:hover { border-color: var(--electric-purple); background: var(--vibrant-highlight-soft); color: var(--electric-purple); }
.price-summary { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; background: var(--vibrant-highlight-soft); border-radius: var(--radius-md); margin-bottom: 20px; }
.price-summary .lbl { font-family: var(--font-meta); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--on-surface-variant); }
.price-summary .val { font-family: var(--font-mono); font-size: 28px; color: var(--electric-purple); direction: ltr; }
.notice { display: flex; gap: 10px; align-items: flex-start; padding: 14px 16px; border-radius: var(--radius-default); background: rgba(176,116,6,0.08); color: var(--warning); font-size: 13px; line-height: 1.6; }
.notice svg { width: 18px; height: 18px; flex: none; margin-top: 2px; }

.contact-card { background: var(--pure-white); border-radius: var(--radius-lg); box-shadow: var(--shadow-card); overflow: hidden; }
.contact-row { display: flex; align-items: center; gap: 18px; padding: 22px 26px; border-bottom: 1px solid rgba(8,0,65,0.07); transition: background var(--duration-fast) var(--ease-out); }
.contact-row:last-child { border-bottom: 0; }
.contact-row:hover { background: var(--surface-container-low); }
.contact-row .ci { width: 48px; height: 48px; border-radius: var(--radius-default); background: var(--vibrant-highlight-soft); color: var(--electric-purple); display: flex; align-items: center; justify-content: center; flex: none; }
.contact-row .cl { font-family: var(--font-meta); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--on-surface-variant); margin-bottom: 3px; }
.contact-row .cv { font-size: 16px; font-weight: 600; color: var(--deep-purple-void); direction: ltr; text-align: start; }

/* ============================================================
   About
   ============================================================ */
.about-hero { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: 48px; align-items: center; }
.about-portrait { aspect-ratio: 1/1; border-radius: var(--radius-xl); overflow: hidden; background: var(--deep-purple-void); box-shadow: 0 30px 70px -28px rgba(8,0,65,0.45); }
.about-portrait img { width: 100%; height: 100%; object-fit: cover; }
.about-tags { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.stat-strip { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.stat-box { background: var(--pure-white); border-radius: var(--radius-lg); padding: 28px 24px; box-shadow: var(--shadow-card); position: relative; overflow: hidden; }
.stat-box::before { content:''; position: absolute; inset-inline-start: 0; top: 20%; bottom: 20%; width: 3px; background: var(--electric-purple); }
.stat-box .n { font-family: var(--font-display); font-size: 44px; color: var(--deep-purple-void); direction: ltr; line-height: 1; }
.stat-box .l { font-size: 13px; color: var(--on-surface-variant); margin-top: 8px; }

/* ============================================================
   Footer
   ============================================================ */
.footer { background: var(--deep-purple-void); color: #fff; position: relative; overflow: hidden; margin-top: 40px; }
.footer::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 1px 1px, rgba(255,255,255,0.04) 1px, transparent 1.5px) 0 0 / 20px 20px; pointer-events: none; }
.footer-inner { position: relative; max-width: 1280px; margin: 0 auto; padding: 64px 48px 32px; }
.footer-top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 40px; border-bottom: 1px solid rgba(255,255,255,0.12); }
.footer .f-brand img { height: 34px; margin-bottom: 18px; }
.footer .f-brand .ar { font-family: var(--font-arabic); font-weight: 700; font-size: 22px; margin-bottom: 10px; }
.footer .f-brand p { color: rgba(255,255,255,0.62); font-size: 14px; line-height: 1.7; max-width: 280px; }
.footer .f-social { display: flex; gap: 10px; margin-top: 20px; }
.footer .f-social a { width: 40px; height: 40px; border-radius: 50%; background: rgba(255,255,255,0.08); display: flex; align-items: center; justify-content: center; color: #fff; transition: all var(--duration-fast) var(--ease-out); cursor: pointer; }
.footer .f-social a:hover { background: var(--electric-purple); transform: translateY(-2px); }
.footer .f-col h4 { font-family: var(--font-meta); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.5); margin-bottom: 16px; }
.footer .f-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 11px; }
.footer .f-col a { color: rgba(255,255,255,0.82); font-size: 14px; cursor: pointer; transition: color var(--duration-fast) var(--ease-out); }
.footer .f-col a:hover { color: #C6BFFF; }
.footer .f-contact li { display: flex; align-items: center; gap: 10px; color: rgba(255,255,255,0.82); font-size: 13.5px; }
.footer .f-contact li svg { width: 15px; height: 15px; color: #C6BFFF; flex: none; }
.footer .f-contact span { direction: ltr; }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; padding-top: 24px; flex-wrap: wrap; gap: 12px; }
.footer-bottom .cr { font-family: var(--font-meta); font-size: 11px; letter-spacing: 0.06em; color: rgba(255,255,255,0.5); }
.footer-bottom .mono { font-family: var(--font-mono); font-size: 11px; color: rgba(255,255,255,0.4); }

/* ============================================================
   Toast
   ============================================================ */
.toast { position: fixed; bottom: 28px; inset-inline-start: 50%; transform: translateX(50%) translateY(120px); background: var(--deep-purple-void); color: #fff; padding: 13px 22px; border-radius: var(--radius-full); font-size: 13px; box-shadow: 0 16px 40px -12px rgba(8,0,65,0.5); z-index: 120; display: inline-flex; align-items: center; gap: 10px; transition: transform var(--duration-slow) var(--ease-spring); }
.toast.show { transform: translateX(50%) translateY(0); }
.toast .dot { width: 7px; height: 7px; border-radius: 50%; background: #6BE6A8; box-shadow: 0 0 8px #6BE6A8; }

/* ============================================================
   Mobile menu
   ============================================================ */
.mobile-menu { position: fixed; inset: 0; z-index: 90; background: var(--surface); transform: translateX(-100%); transition: transform var(--duration-slow) var(--ease-out); display: flex; flex-direction: column; }
.mobile-menu.open { transform: translateX(0); }
.mobile-menu .mm-head { display: flex; align-items: center; justify-content: space-between; padding: 16px 24px; border-bottom: 1px solid rgba(8,0,65,0.08); }
.mobile-menu nav { padding: 24px; display: flex; flex-direction: column; gap: 4px; }
.mobile-menu nav a { font-size: 22px; font-weight: 700; color: var(--deep-purple-void); padding: 14px 0; border-bottom: 1px solid rgba(8,0,65,0.06); cursor: pointer; display: flex; align-items: center; justify-content: space-between; }
.mobile-menu nav a:hover { color: var(--electric-purple); }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1024px) {
  .wrap, .nav-inner, .footer-inner { padding-inline: 32px; }
  .hero-grid { grid-template-columns: 1fr 0.9fr; gap: 36px; }
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .grid-cards { grid-template-columns: repeat(2, 1fr); }
  .detail-grid { grid-template-columns: 1fr; }
  .sticky-side { position: static; }
  .featured-pkg { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 32px; }
  .stat-strip { grid-template-columns: repeat(2,1fr); }
  .nav .links { display: none; }
  .hamburger { display: inline-flex; }
}

@media (max-width: 760px) {
  .wrap, .nav-inner, .footer-inner { padding-inline: 20px; }
  .section { padding-block: 60px; }
  .hero { padding-block: 40px 48px; }
  .hero-grid { grid-template-columns: 1fr; gap: 32px; }
  .hero-portrait { max-width: 420px; }
  .hero-stats { gap: 24px; }
  .services-grid { grid-template-columns: 1fr; }
  .grid-cards, .grid-2 { grid-template-columns: 1fr; }
  .about-hero { grid-template-columns: 1fr; gap: 28px; }
  .about-portrait { max-width: 360px; }
  .featured-pkg { padding: 28px; }
  .featured-pkg .fp-price { font-size: 56px; }
  .cta-band { padding: 44px 24px; border-radius: var(--radius-lg); }
  .footer-top { grid-template-columns: 1fr; gap: 28px; }
  .stat-strip { grid-template-columns: 1fr 1fr; }
  .nav .tools .hide-sm { display: none; }
  .section-head h2 { font-size: 28px; }
  .carousel-track > .card { width: 280px; }
}

/* ============================================================
   Single Training page
   ============================================================ */
.train-banner { background: var(--deep-purple-void); border-radius: var(--radius-xl); padding: 48px 48px 56px; position: relative; overflow: hidden; color: #fff; }
.train-banner::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 1px 1px, rgba(255,255,255,0.05) 1px, transparent 1.5px) 0 0 / 18px 18px; pointer-events: none; }
.train-banner .corner { position: absolute; width: 18px; height: 18px; z-index: 2; }
.train-banner .corner::before, .train-banner .corner::after { content: ''; position: absolute; background: rgba(255,255,255,0.6); }
.train-banner .corner::before { width: 100%; height: 1.5px; top: 0; }
.train-banner .corner::after { height: 100%; width: 1.5px; top: 0; }
.train-banner .corner.tr { top: 16px; right: 16px; } .train-banner .corner.tr::after { right: 0; }
.train-banner .corner.bl { bottom: 16px; left: 16px; transform: rotate(180deg); }
.tb-grid { display: grid; grid-template-columns: 1fr auto; gap: 40px; align-items: center; position: relative; }
.tb-text h1 { font-family: var(--font-arabic); font-weight: 700; font-size: clamp(32px, 4.5vw, 54px); line-height: 1.06; letter-spacing: -0.015em; margin: 0 0 16px; }
.tb-text p { color: rgba(255,255,255,0.78); font-size: 16px; line-height: 1.75; max-width: 560px; margin: 0 0 26px; }
.tb-cta { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.tb-seats { display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-meta); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(255,255,255,0.82); }
.tb-seats .pulse { width: 9px; height: 9px; border-radius: 50%; background: #6BE6A8; box-shadow: 0 0 10px #6BE6A8; position: relative; }
.tb-seats .pulse::after { content: ''; position: absolute; inset: -4px; border-radius: 50%; border: 1.5px solid #6BE6A8; animation: pulse-ring 1.8s ease-out infinite; }
.tb-mark { display: flex; flex-direction: column; align-items: center; opacity: 0.9; }
.tb-mark img { height: 96px; width: auto; }

.train-info { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: rgba(8,0,65,0.08); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-card-lifted); }
.ti-cell { background: var(--pure-white); padding: 22px 24px; display: flex; align-items: center; gap: 14px; }
.ti-cell .ti-ic { width: 42px; height: 42px; border-radius: var(--radius-default); background: var(--vibrant-highlight-soft); color: var(--electric-purple); display: flex; align-items: center; justify-content: center; flex: none; }
.ti-cell .ti-l { font-family: var(--font-meta); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--on-surface-variant); margin-bottom: 3px; }
.ti-cell .ti-v { font-weight: 700; font-size: 15px; color: var(--deep-purple-void); }

.train-features { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.tf-item { display: flex; align-items: flex-start; gap: 11px; font-size: 14.5px; color: var(--on-surface-variant); line-height: 1.5; }
.tf-item .tf-ck { width: 24px; height: 24px; border-radius: 50%; background: var(--vibrant-highlight); color: var(--electric-purple); flex: none; display: flex; align-items: center; justify-content: center; }

.agree-row { display: flex; align-items: flex-start; gap: 11px; font-size: 13px; color: var(--on-surface-variant); line-height: 1.5; margin: 4px 0 14px; cursor: pointer; }
.agree-box { width: 22px; height: 22px; border-radius: 6px; border: 1.5px solid var(--outline-variant); background: var(--surface-container-lowest); flex: none; display: flex; align-items: center; justify-content: center; color: #fff; cursor: pointer; transition: all var(--duration-fast) var(--ease-out); }
.agree-box.on { background: var(--electric-purple); border-color: var(--electric-purple); }

@media (max-width: 760px) {
  .train-banner { padding: 32px 24px 40px; }
  .tb-grid { grid-template-columns: 1fr; gap: 24px; }
  .tb-mark { display: none; }
  .train-info { grid-template-columns: 1fr 1fr; }
  .train-features { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* ============================================================
   a11y: skip link + visible focus
   ============================================================ */
.skip-link { position: fixed; top: 10px; inset-inline-start: 50%; transform: translate(50%, -150%); z-index: 200; background: var(--electric-purple); color: #fff; padding: 10px 18px; border-radius: var(--radius-full); font-size: 13px; font-weight: 600; transition: transform var(--duration-base) var(--ease-out); }
.skip-link:focus { transform: translate(50%, 0); outline: none; }
:focus-visible { outline: 2.5px solid var(--electric-purple); outline-offset: 2px; border-radius: 4px; }
.icon-btn:focus-visible, .btn:focus-visible, .chip:focus-visible { outline-offset: 3px; }
main:focus { outline: none; }

/* ============================================================
   Live search results
   ============================================================ */
.search-results { max-height: 56vh; overflow-y: auto; padding: 6px; border-top: 1px solid var(--surface-container); margin-top: 4px; }
.search-item { display: flex; align-items: center; gap: 14px; width: 100%; text-align: start; padding: 12px 14px; border: 0; background: transparent; border-radius: var(--radius-md); cursor: pointer; transition: background var(--duration-fast) var(--ease-out); }
.search-item.active { background: var(--vibrant-highlight-soft); }
.search-item .si-ic { width: 38px; height: 38px; border-radius: var(--radius-default); background: var(--surface-container); color: var(--electric-purple); display: flex; align-items: center; justify-content: center; flex: none; }
.search-item.active .si-ic { background: var(--electric-purple); color: #fff; }
.search-item .si-body { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.search-item .si-title { font-weight: 600; font-size: 15px; color: var(--deep-purple-void); }
.search-item .si-sub { font-size: 12.5px; color: var(--on-surface-variant); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.search-item .si-kind { font-family: var(--font-meta); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--on-surface-variant); background: var(--surface-container); padding: 4px 9px; border-radius: var(--radius-full); flex: none; }
.search-empty { text-align: center; padding: 36px 20px; color: var(--on-surface-variant); }
.search-empty svg { color: var(--outline-variant); margin-bottom: 10px; }
.search-suggest { padding: 16px 18px 8px; border-top: 1px solid var(--surface-container); margin-top: 4px; }
.search-suggest .ss-label { font-family: var(--font-meta); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--on-surface-variant); margin-bottom: 12px; }
.search-suggest .ss-chips { display: flex; flex-wrap: wrap; gap: 8px; }

/* ============================================================
   Checkout
   ============================================================ */
.pay-methods { display: flex; flex-direction: column; gap: 10px; }
.pay-method { display: flex; align-items: center; gap: 12px; padding: 15px 18px; border-radius: var(--radius-md); border: 0; box-shadow: inset 0 0 0 1.5px var(--outline-variant); background: var(--surface-container-lowest); color: var(--deep-purple-void); font-family: var(--font-arabic); font-size: 15px; font-weight: 500; cursor: pointer; transition: all var(--duration-fast) var(--ease-out); }
.pay-method:hover { box-shadow: inset 0 0 0 1.5px var(--electric-purple); }
.pay-method .pm-radio { margin-inline-start: auto; width: 20px; height: 20px; border-radius: 50%; box-shadow: inset 0 0 0 2px var(--outline-variant); transition: all var(--duration-fast) var(--ease-out); }
.pay-method.on { box-shadow: inset 0 0 0 2px var(--electric-purple); background: var(--vibrant-highlight-soft); color: var(--electric-purple-deep); }
.pay-method.on .pm-radio { box-shadow: inset 0 0 0 6px var(--electric-purple); }
.sum-row { display: flex; align-items: center; gap: 11px; }
.sum-row .sum-ic { width: 32px; height: 32px; border-radius: var(--radius-default); background: var(--vibrant-highlight-soft); color: var(--electric-purple); display: flex; align-items: center; justify-content: center; flex: none; }
.sum-row .sum-title { flex: 1; min-width: 0; font-size: 14px; color: var(--deep-purple-void); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sum-row .sum-price { font-family: var(--font-mono); font-size: 14px; color: var(--electric-purple); }
.coupon-row { display: flex; gap: 8px; margin-top: 4px; }
.coupon-row input { flex: 1; padding: 11px 14px; border-radius: var(--radius-md); border: 1.5px solid var(--outline-variant); background: var(--surface-container-lowest); font-family: var(--font-arabic); font-size: 14px; color: var(--deep-purple-void); }
.coupon-row input:focus { outline: 0; border-color: var(--electric-purple); }
.sum-line { display: flex; align-items: center; justify-content: space-between; padding: 7px 0; font-size: 14px; color: var(--on-surface-variant); }
.sum-total { display: flex; align-items: center; justify-content: space-between; padding-top: 14px; margin-top: 8px; border-top: 1px solid var(--surface-container); font-weight: 700; font-size: 17px; color: var(--deep-purple-void); }
.sum-total .mono, .sum-line .mono { font-family: var(--font-mono); }
.sum-total span:last-child { font-size: 24px; color: var(--electric-purple); }
.secure-note { display: flex; align-items: center; justify-content: center; gap: 7px; margin-top: 14px; font-size: 12px; color: var(--on-surface-variant); }
.secure-note svg { color: var(--success); }
.checkout-tick { width: 80px; height: 80px; border-radius: 50%; background: var(--success); color: #fff; display: flex; align-items: center; justify-content: center; margin: 0 auto; box-shadow: 0 0 0 8px rgba(31,138,91,0.14); }

/* ============================================================
   Skeleton loaders
   ============================================================ */
.sk { display: block; background: linear-gradient(100deg, var(--surface-container) 30%, var(--surface-container-high, #e7e4f0) 50%, var(--surface-container) 70%); background-size: 220% 100%; animation: sk-shimmer 1.3s ease-in-out infinite; }
@keyframes sk-shimmer { 0% { background-position: 100% 0; } 100% { background-position: -120% 0; } }
@media (prefers-reduced-motion: reduce) { .sk { animation: none; } }

/* ============================================================
   DARK THEME
   ============================================================ */
[data-theme="dark"] {
  --surface: #0B0726;
  --light-gray-matrix: #0B0726;
  --surface-container-lowest: #120E38;
  --surface-container-low: #161241;
  --surface-container: #1C1750;
  --surface-container-high: #241E60;
  --surface-container-highest: #2B2470;
  --pure-white: #151140;
  --deep-purple-void: #ECEAFF;
  --on-surface: #ECEAFF;
  --on-surface-variant: #A39EDA;
  --outline-variant: rgba(255,255,255,0.13);
  --outline: rgba(255,255,255,0.30);
  --vibrant-highlight: rgba(108,92,235,0.34);
  --vibrant-highlight-soft: rgba(108,92,235,0.18);
  --shadow-card: 0 1px 0 rgba(0,0,0,0.3), 0 10px 28px -14px rgba(0,0,0,0.6);
  --shadow-card-lifted: 0 18px 44px -16px rgba(0,0,0,0.7);
}
[data-theme="dark"] body, [data-theme="dark"] html { background: var(--surface); }
[data-theme="dark"] .nav { background: rgba(11,7,38,0.82); border-bottom-color: rgba(255,255,255,0.08); }
/* keep intentionally-dark sections dark (they use void as bg + white text) */
[data-theme="dark"] .footer,
[data-theme="dark"] .cta-band,
[data-theme="dark"] .featured-pkg,
[data-theme="dark"] .train-banner { background: #0A0524; }
[data-theme="dark"] .hero-portrait, [data-theme="dark"] .about-portrait { background: #0A0524; }
[data-theme="dark"] .badge-void { background: var(--electric-purple); }
[data-theme="dark"] .toast { background: #2B2470; }
[data-theme="dark"] .ph { background: repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 11px), radial-gradient(circle at 30% 20%, rgba(108,92,235,0.25), transparent 60%), #0A0524; }
[data-theme="dark"] .ph.alt { background: repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 11px), radial-gradient(circle at 70% 30%, rgba(108,92,235,0.3), transparent 60%), #181252; }
[data-theme="dark"] .player .screen { background: #0A0524; }
[data-theme="dark"] .btn-on-dark { background: var(--electric-purple); color: #fff; }
[data-theme="dark"] .btn-copy, [data-theme="dark"] .chip { background: var(--surface-container); }
[data-theme="dark"] .live-ticker { box-shadow: var(--shadow-card); }
[data-theme="dark"] .train-info { background: rgba(255,255,255,0.1); }
[data-theme="dark"] .pdf-page { background: #1b1656; color: var(--on-surface-variant); }
[data-theme="dark"] .copy-block { box-shadow: inset 0 0 0 1px rgba(255,255,255,0.1); }

/* ============================================================
   Nav external link
   ============================================================ */
.nav .links a.has-ext { display: inline-flex; align-items: center; gap: 5px; }
.nav .links a.has-ext svg { opacity: 0.6; }

/* ============================================================
   AJAX search states
   ============================================================ */
.search-spin { width: 20px; height: 20px; border-radius: 50%; border: 2.5px solid var(--vibrant-highlight); border-top-color: var(--electric-purple); animation: sp 0.7s linear infinite; flex: none; }
@keyframes sp { to { transform: rotate(360deg); } }
.search-loading { padding: 8px; }
.sl-row { display: flex; align-items: center; gap: 14px; padding: 12px 14px; }

/* ============================================================
   Custom protected video player
   ============================================================ */
.vplayer { background: var(--deep-purple-void); position: relative; user-select: none; }
.vp-stage { position: relative; aspect-ratio: 16/9; background: #05021c; overflow: hidden; }
.vp-video { width: 100%; height: 100%; object-fit: contain; background: #05021c; display: block; pointer-events: none; }
.vp-hit { position: absolute; inset: 0; width: 100%; height: 100%; background: transparent; border: 0; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.vp-bigplay { width: 76px; height: 76px; border-radius: 50%; background: var(--electric-purple); color: #fff; display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow-glow-primary); padding-inline-start: 4px; }
.vp-wm { position: absolute; top: 12px; inset-inline-end: 14px; font-family: var(--font-meta); font-size: 10px; letter-spacing: 0.08em; color: rgba(255,255,255,0.32); pointer-events: none; direction: ltr; }
.vp-loading { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(5,2,28,0.6); }
.vp-bar { display: flex; align-items: center; gap: 10px; padding: 12px 16px; background: var(--pure-white); flex-wrap: wrap; }
.vp-left { display: flex; align-items: center; gap: 8px; }
.vp-right { display: flex; align-items: center; gap: 8px; margin-inline-start: auto; }
.vp-progress { display: flex; align-items: center; gap: 10px; flex: 1 1 220px; min-width: 0; }
.vp-btn { position: relative; min-width: 40px; height: 40px; padding: 0 10px; border-radius: var(--radius-default); border: 0; background: var(--surface-container); color: var(--deep-purple-void); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-size: 13px; transition: all var(--duration-fast) var(--ease-out); }
.vp-btn:hover { background: var(--vibrant-highlight); color: var(--electric-purple); }
.vp-btn.primary { background: var(--electric-purple); color: #fff; width: 44px; height: 44px; }
.vp-btn.primary:hover { background: var(--electric-purple-deep); }
.vp-skip { position: absolute; bottom: 3px; inset-inline-end: 4px; font-size: 8px; font-family: var(--font-meta); opacity: 0.7; }
.vp-time { font-family: var(--font-mono); font-size: 12px; color: var(--on-surface-variant); flex: none; }
.vp-seek { flex: 1; min-width: 60px; accent-color: var(--electric-purple); cursor: pointer; height: 6px; }
.vp-rate { position: relative; }
.vp-rate-menu { position: absolute; bottom: 50px; inset-inline-end: 0; background: var(--pure-white); border-radius: var(--radius-md); box-shadow: var(--shadow-card-lifted); padding: 6px; display: flex; flex-direction: column; gap: 2px; z-index: 6; min-width: 84px; }
.vp-rate-menu button { border: 0; background: transparent; padding: 9px 12px; border-radius: var(--radius-default); cursor: pointer; font-family: var(--font-mono); font-size: 13px; color: var(--deep-purple-void); text-align: start; }
.vp-rate-menu button:hover { background: var(--surface-container); }
.vp-rate-menu button.on { background: var(--electric-purple); color: #fff; }

@media (max-width: 600px) {
  .vp-progress { order: -1; flex-basis: 100%; }
  .vp-bar { gap: 8px; padding: 10px 12px; }
  .vp-btn { min-width: 44px; height: 44px; }
  .vp-btn.primary { width: 48px; height: 48px; }
  .vp-wm { font-size: 9px; max-width: 45%; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
  .vp-bigplay { width: 64px; height: 64px; }
}

/* ============================================================
   Included products
   ============================================================ */
.incl-list { display: flex; flex-direction: column; gap: 8px; }
.incl-item { display: flex; align-items: center; gap: 13px; width: 100%; text-align: start; padding: 13px 15px; border: 0; border-radius: var(--radius-md); background: var(--surface-container-low); cursor: pointer; transition: all var(--duration-fast) var(--ease-out); }
.incl-item:hover { background: var(--vibrant-highlight-soft); transform: translateX(-3px); }
.incl-ic { width: 40px; height: 40px; border-radius: var(--radius-default); background: var(--vibrant-highlight); color: var(--electric-purple); display: flex; align-items: center; justify-content: center; flex: none; }
.incl-body { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.incl-t { font-weight: 600; font-size: 14.5px; color: var(--deep-purple-void); }
.incl-k { font-family: var(--font-meta); font-size: 10.5px; letter-spacing: 0.06em; color: var(--on-surface-variant); margin-top: 3px; }
.incl-tick { width: 26px; height: 26px; border-radius: 50%; background: var(--success); color: #fff; display: flex; align-items: center; justify-content: center; flex: none; }

/* quick-access (course included products) */
.qa-panel { background: linear-gradient(180deg, var(--vibrant-highlight-soft), var(--pure-white) 60%); }
.qa-sub { font-size: 12.5px; color: var(--on-surface-variant); margin: 0 0 14px; line-height: 1.55; }
.qa-list { display: flex; flex-direction: column; gap: 8px; }
.qa-item { display: flex; align-items: center; gap: 11px; width: 100%; text-align: start; padding: 11px 13px; border: 0; border-radius: var(--radius-md); background: var(--pure-white); box-shadow: inset 0 0 0 1px var(--outline-variant); cursor: pointer; transition: all var(--duration-fast) var(--ease-out); }
.qa-item:hover { box-shadow: inset 0 0 0 1.5px var(--electric-purple); transform: translateX(-3px); }
.qa-ic { width: 34px; height: 34px; border-radius: var(--radius-default); background: var(--vibrant-highlight); color: var(--electric-purple); display: flex; align-items: center; justify-content: center; flex: none; }
.qa-t { flex: 1; min-width: 0; font-size: 13.5px; font-weight: 600; color: var(--deep-purple-void); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.qa-go { color: var(--electric-purple); flex: none; }
[data-theme="dark"] .qa-panel { background: var(--pure-white); }

/* ============================================================
   Offers
   ============================================================ */
.offer-card { position: relative; overflow: hidden; background: var(--deep-purple-void); color: #fff; border-radius: var(--radius-lg); padding: 28px; cursor: pointer; display: flex; flex-direction: column; min-height: 230px; transition: transform var(--duration-base) var(--ease-out), box-shadow var(--duration-base) var(--ease-out); }
.offer-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card-lifted); }
.offer-card::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 1px 1px, rgba(255,255,255,0.05) 1px, transparent 1.5px) 0 0 / 16px 16px; }
.offer-card .oc-glow { position: absolute; width: 280px; height: 280px; border-radius: 50%; background: radial-gradient(circle, rgba(78,61,199,0.6), transparent 65%); top: -120px; inset-inline-end: -60px; filter: blur(10px); }
.oc-head { position: relative; display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.oc-count { font-size: 11px; color: rgba(255,255,255,0.6); }
.offer-card h3 { position: relative; font-size: 22px; font-weight: 700; line-height: 1.3; margin-bottom: 10px; }
.offer-card p { position: relative; color: rgba(255,255,255,0.72); font-size: 14px; line-height: 1.6; margin-bottom: 20px; }
.oc-foot { position: relative; margin-top: auto; display: flex; align-items: flex-end; justify-content: space-between; gap: 12px; }
.oc-price { display: flex; align-items: baseline; gap: 10px; }
.oc-old { font-size: 15px; color: rgba(255,255,255,0.5); text-decoration: line-through; }
.oc-new { font-family: var(--font-display); font-size: 38px; line-height: 1; color: #fff; direction: ltr; }
.oc-new .cur { color: #C6BFFF; font-size: 22px; }
.oc-save { background: var(--success); color: #fff; font-family: var(--font-meta); font-size: 11px; letter-spacing: 0.06em; padding: 7px 13px; border-radius: var(--radius-full); }

.offer-hero { position: relative; overflow: hidden; background: var(--deep-purple-void); color: #fff; border-radius: var(--radius-xl); padding: 48px; }
.offer-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 1px 1px, rgba(255,255,255,0.05) 1px, transparent 1.5px) 0 0 / 18px 18px; }
.offer-hero .oh-glow { position: absolute; width: 420px; height: 420px; border-radius: 50%; background: radial-gradient(circle, rgba(78,61,199,0.55), transparent 65%); top: -180px; inset-inline-end: -80px; filter: blur(14px); }
.offer-hero .corner { position: absolute; width: 18px; height: 18px; z-index: 2; }
.offer-hero .corner::before, .offer-hero .corner::after { content: ''; position: absolute; background: rgba(255,255,255,0.6); }
.offer-hero .corner::before { width: 100%; height: 1.5px; top: 0; }
.offer-hero .corner::after { height: 100%; width: 1.5px; top: 0; }
.offer-hero .corner.tr { top: 16px; right: 16px; } .offer-hero .corner.tr::after { right: 0; }
.offer-hero .corner.bl { bottom: 16px; left: 16px; transform: rotate(180deg); }
.oh-inner { position: relative; }
.offer-hero h1 { font-family: var(--font-arabic); font-weight: 700; font-size: clamp(30px, 4.5vw, 52px); line-height: 1.06; letter-spacing: -0.015em; margin: 0 0 14px; }
.offer-hero p { color: rgba(255,255,255,0.78); font-size: 17px; line-height: 1.7; max-width: 560px; margin: 0 0 28px; }
.oh-pricebar { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; }
.oh-pb-l { display: flex; flex-direction: column; }
.oh-old { font-size: 12px; color: rgba(255,255,255,0.55); }
.oh-now { font-family: var(--font-display); font-size: 56px; line-height: 1; direction: ltr; }
.oh-now .cur { color: #C6BFFF; font-size: 30px; }
.oh-save-badge { background: var(--success); color: #fff; padding: 10px 16px; border-radius: var(--radius-md); font-weight: 700; font-size: 16px; }
.oh-save-badge span { font-size: 12px; opacity: 0.85; font-weight: 500; }

.offer-breakdown { display: flex; flex-direction: column; gap: 8px; }
.ob-row { display: flex; align-items: center; gap: 13px; width: 100%; text-align: start; padding: 13px 15px; border: 0; border-radius: var(--radius-md); background: var(--surface-container-low); cursor: pointer; transition: all var(--duration-fast) var(--ease-out); }
.ob-row:hover { background: var(--vibrant-highlight-soft); }
.ob-ic { width: 40px; height: 40px; border-radius: var(--radius-default); background: var(--vibrant-highlight); color: var(--electric-purple); display: flex; align-items: center; justify-content: center; flex: none; }
.ob-body { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.ob-t { font-weight: 600; font-size: 14.5px; color: var(--deep-purple-void); }
.ob-k { font-family: var(--font-meta); font-size: 10.5px; letter-spacing: 0.06em; color: var(--on-surface-variant); margin-top: 3px; }
.ob-price { font-family: var(--font-mono); font-size: 14px; color: var(--electric-purple); flex: none; }
.ob-total { display: flex; align-items: center; justify-content: space-between; padding: 14px 4px 0; font-size: 14px; color: var(--on-surface-variant); }
.ob-grand { font-weight: 700; font-size: 18px; color: var(--deep-purple-void); border-top: 1px solid var(--surface-container); margin-top: 8px; padding-top: 14px; }
.ob-grand .mono { color: var(--electric-purple); font-size: 22px; }

/* event */
.ev-when { display: flex; gap: 22px; flex-wrap: wrap; margin-top: 8px; }
.ev-when span { display: inline-flex; align-items: center; gap: 8px; color: rgba(255,255,255,0.82); font-size: 14px; }
.ev-when svg { color: #C6BFFF; }
.ev-info { margin-top: 18px; padding-top: 16px; border-top: 1px solid rgba(8,0,65,0.08); display: flex; flex-direction: column; gap: 12px; }
.ev-info-row { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--on-surface-variant); }
.ev-info-row svg { color: var(--electric-purple); flex: none; }

[data-theme="dark"] .offer-card, [data-theme="dark"] .offer-hero { background: #0A0524; }

/* ============================================================
   Player overlays: long-press 2× badge + double-tap skip hints
   ============================================================ */
.vp-rate-badge { position: absolute; top: 14px; inset-inline-start: 50%; transform: translateX(-50%); background: rgba(5,2,28,0.82); color: #fff; font-family: var(--font-mono); font-size: 15px; padding: 7px 16px; border-radius: var(--radius-full); opacity: 0; transition: opacity .15s var(--ease-out); pointer-events: none; display: inline-flex; align-items: center; gap: 7px; z-index: 5; }
.vp-rate-badge::before { content: '⏩'; }
.vp-rate-badge.show { opacity: 1; }
.vp-skip-hint { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(5,2,28,0.55); color: #fff; font-family: var(--font-mono); font-size: 15px; width: 62px; height: 62px; border-radius: 50%; display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity .2s var(--ease-out); pointer-events: none; z-index: 5; }
.vp-skip-back { left: 7%; }
.vp-skip-fwd { right: 7%; }
.vp-skip-hint.show { opacity: 1; }

/* ============================================================
   Custom PDF reader (RTL, 2-page on desktop / 1 on mobile)
   ============================================================ */
.pdf-reader { background: var(--surface-container-low); border-radius: var(--radius-lg); box-shadow: inset 0 0 0 1px rgba(8,0,65,0.08); padding: 16px; outline: none; }
.pdf-stage { display: flex; gap: 10px; align-items: center; justify-content: center; min-height: 240px; direction: rtl; }
.pdf-canvas { aspect-ratio: 9/16; height: min(68vh, 560px); width: auto; max-width: 48%; background: #fff; border-radius: 6px; box-shadow: 0 12px 40px -16px rgba(8,0,65,0.30); display: block; }
.pdf-loading, .pdf-error { padding: 60px 20px; text-align: center; color: var(--on-surface-variant); }
.pdf-error { color: var(--error); }
.pdf-bar { display: flex; align-items: center; gap: 10px; justify-content: center; margin-top: 14px; flex-wrap: wrap; }
.pdf-count { font-family: var(--font-mono); font-size: 13px; color: var(--on-surface-variant); min-width: 96px; text-align: center; direction: ltr; }
.pdf-reader:fullscreen { background: var(--deep-purple-void); display: flex; flex-direction: column; justify-content: center; padding: 20px; }
.pdf-reader:fullscreen .pdf-canvas { height: 84vh; max-width: 47vw; }
.pdf-reader:-webkit-full-screen { background: var(--deep-purple-void); }
@media (max-width: 819px) {
  .pdf-canvas { max-width: 94%; height: min(72vh, 620px); }
  .pdf-reader:fullscreen .pdf-canvas { max-width: 94vw; height: 86vh; }
}

/* ============================================================
   CSS pseudo-fullscreen (fallback for mobile/iOS where the
   Fullscreen API is unavailable for non-video elements)
   ============================================================ */
html.fs-lock, body.fs-lock { overflow: hidden !important; }
.vplayer.is-fs { position: fixed; inset: 0; z-index: 9999; background: #000; display: flex; flex-direction: column; justify-content: center; border-radius: 0; }
.vplayer.is-fs .vp-stage { flex: 1 1 auto; aspect-ratio: auto; height: auto; min-height: 0; }
.vplayer.is-fs .vp-video { width: 100%; height: 100%; }
.vplayer.is-fs .vp-bar { flex: 0 0 auto; }
.pdf-reader.is-fs { position: fixed; inset: 0; z-index: 9999; background: var(--deep-purple-void); display: flex; flex-direction: column; justify-content: center; padding: 16px; border-radius: 0; }
.pdf-reader.is-fs .pdf-stage { flex: 1; min-height: 0; }
.pdf-reader.is-fs .pdf-canvas { height: 82vh; max-width: 47vw; }
@media (max-width: 819px) { .pdf-reader.is-fs .pdf-canvas { max-width: 92vw; height: 84vh; } }
