/* ════════════════════════════════════════════════════════════════════════
   VALA AGENCY — PREMIUM LAYER (Landing V2)
   World-class SaaS/agency polish. Loads AFTER style.css + vala-design-system.
   Dark, RTL-first, performance-minded (CSS/SVG visuals, no heavy WebGL).
   ════════════════════════════════════════════════════════════════════════ */
:root{
  --px-bg:        #07070c;
  --px-bg-soft:   #0c0c14;
  --px-panel:     #111120;
  --px-panel-2:   #15152a;
  --px-line:      rgba(255,255,255,.08);
  --px-line-soft: rgba(255,255,255,.05);
  --px-violet:    #7c3aed;
  --px-violet-2:  #a78bfa;
  --px-indigo:    #4f46e5;
  --px-cyan:      #22d3ee;
  --px-text:      #f4f4fb;
  --px-mut:       #a3a3c2;
  --px-dim:       #6f6f8c;
  --px-grad:      linear-gradient(120deg,#a78bfa 0%,#7c3aed 45%,#4f46e5 100%);
  --px-grad-soft: linear-gradient(120deg,rgba(167,139,250,.16),rgba(79,70,229,.08));
  --px-glow:      0 0 0 1px rgba(124,58,237,.18), 0 18px 60px -12px rgba(124,58,237,.45);
  --px-shadow:    0 20px 60px -20px rgba(0,0,0,.7);
  --px-shadow-sm: 0 8px 28px -12px rgba(0,0,0,.6);
  --px-r:         18px;
  --px-r-lg:      26px;
  --px-ease:      cubic-bezier(.22,.61,.36,1);
}

/* ── Premium section rhythm + headers ─────────────────────────────────── */
.px-section{ padding: 120px 0; position: relative; }
.px-section.tight{ padding: 80px 0; }
@media (max-width:760px){ .px-section{ padding: 72px 0; } .px-section.tight{ padding:52px 0; } }
.px-head{ max-width: 720px; margin: 0 auto 64px; text-align: center; }
.px-head.start{ text-align: start; margin-inline: 0; }
.px-eyebrow{
  display:inline-flex; align-items:center; gap:8px; padding:7px 15px; border-radius:999px;
  font-size:.78rem; font-weight:700; letter-spacing:.02em; color:var(--px-violet-2);
  background: var(--px-grad-soft); border:1px solid rgba(124,58,237,.25); margin-bottom:18px;
}
.px-eyebrow i{ font-size:.9em; }
.px-h2{ font-size: clamp(1.7rem, 1.1rem + 2.6vw, 2.9rem); font-weight:800; line-height:1.15; letter-spacing:-.02em; color:var(--px-text); margin:0 0 14px; }
.px-sub{ font-size: clamp(1rem,.95rem + .3vw,1.15rem); color:var(--px-mut); line-height:1.7; margin:0; }
.px-grad-text{ background:var(--px-grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; }

/* ── Premium buttons ──────────────────────────────────────────────────── */
.btn.btn-xl{ padding:16px 30px; font-size:1.02rem; border-radius:14px; font-weight:700; }
.btn-px{
  position:relative; display:inline-flex; align-items:center; gap:10px; cursor:pointer;
  padding:15px 28px; border-radius:14px; font-weight:700; font-size:1rem; border:none;
  color:#fff; background:var(--px-grad); overflow:hidden; text-decoration:none;
  box-shadow: 0 10px 30px -8px rgba(124,58,237,.6), inset 0 1px 0 rgba(255,255,255,.25);
  transition: transform .25s var(--px-ease), box-shadow .25s var(--px-ease);
}
.btn-px:hover{ transform: translateY(-2px); box-shadow: 0 18px 44px -10px rgba(124,58,237,.7), inset 0 1px 0 rgba(255,255,255,.3); }
.btn-px::after{ content:""; position:absolute; inset:0; background:linear-gradient(110deg,transparent 25%,rgba(255,255,255,.28) 50%,transparent 75%); transform:translateX(-120%); transition:transform .7s var(--px-ease); }
.btn-px:hover::after{ transform:translateX(120%); }
.btn-ghost-px{
  display:inline-flex; align-items:center; gap:9px; padding:15px 26px; border-radius:14px;
  font-weight:700; font-size:1rem; color:var(--px-text); text-decoration:none;
  background:rgba(255,255,255,.04); border:1px solid var(--px-line);
  transition: background .2s, border-color .2s, transform .2s;
}
.btn-ghost-px:hover{ background:rgba(255,255,255,.08); border-color:rgba(124,58,237,.4); transform:translateY(-2px); }

/* ════════════════════════════════════════════════════════════════════════
   HERO
   ════════════════════════════════════════════════════════════════════════ */
.px-hero{ position:relative; overflow:hidden; padding: clamp(96px,12vw,150px) 0 clamp(70px,8vw,110px); }
.px-hero-orbs{ position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.px-orb{ position:absolute; border-radius:50%; filter: blur(70px); opacity:.5; }
.px-orb.a{ width:520px;height:520px; background:radial-gradient(circle,#7c3aed,transparent 65%); top:-160px; inset-inline-end:-120px; animation: px-float 14s ease-in-out infinite; }
.px-orb.b{ width:440px;height:440px; background:radial-gradient(circle,#4f46e5,transparent 65%); bottom:-180px; inset-inline-start:-100px; opacity:.4; animation: px-float 18s ease-in-out infinite reverse; }
.px-orb.c{ width:300px;height:300px; background:radial-gradient(circle,#22d3ee,transparent 70%); top:30%; inset-inline-start:40%; opacity:.16; animation: px-float 20s ease-in-out infinite; }

/* ── Premium hero backdrop (CSS-only, GPU-light) — replaces the old WebGL 3D.
   Layers: dark wash → precision dot grid (masked) → drifting aurora → light beam. */
.px-hero-bg{ position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none; }
.px-hero-bg::before{ content:""; position:absolute; inset:0;
  background:
    radial-gradient(78% 58% at 80% 4%, rgba(124,58,237,.30), transparent 60%),
    radial-gradient(66% 60% at 10% 92%, rgba(34,211,238,.12), transparent 65%),
    linear-gradient(180deg,#0a0a13,#07070d 72%); }
.px-grid-fx{ position:absolute; inset:-2px;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size:46px 46px;
  -webkit-mask:radial-gradient(115% 78% at 72% 10%, #000 0%, transparent 60%);
          mask:radial-gradient(115% 78% at 72% 10%, #000 0%, transparent 60%); }
.px-aurora{ position:absolute; border-radius:50%; filter:blur(82px); opacity:.5; mix-blend-mode:screen; will-change:transform; }
.px-aurora.a{ width:560px;height:560px; background:radial-gradient(circle,#7c3aed,transparent 62%); top:-180px; inset-inline-end:-120px; animation:px-aurora 18s ease-in-out infinite; }
.px-aurora.b{ width:480px;height:480px; background:radial-gradient(circle,#4f46e5,transparent 62%); bottom:-200px; inset-inline-start:-120px; opacity:.42; animation:px-aurora 24s ease-in-out infinite reverse; }
.px-aurora.c{ width:340px;height:340px; background:radial-gradient(circle,#22d3ee,transparent 66%); top:42%; inset-inline-start:44%; opacity:.16; animation:px-aurora 28s ease-in-out infinite; }
.px-beam{ position:absolute; top:-40%; inset-inline-start:-32%; width:58%; height:180%;
  background:linear-gradient(100deg, transparent, rgba(167,139,250,.10) 46%, rgba(255,255,255,.06) 50%, transparent 60%);
  transform:rotate(8deg); animation:px-beam 11s ease-in-out infinite; }
@keyframes px-aurora{ 0%,100%{ transform:translate(0,0) scale(1);} 33%{ transform:translate(26px,-20px) scale(1.06);} 66%{ transform:translate(-20px,16px) scale(.95);} }
@keyframes px-beam{ 0%{ opacity:0; transform:translateX(-12%) rotate(8deg);} 50%{ opacity:1;} 100%{ opacity:0; transform:translateX(42%) rotate(8deg);} }
@media (prefers-reduced-motion: reduce){ .px-aurora,.px-beam{ animation:none !important; } }
@media (max-width:760px){
  .px-grid-fx{ background-size:34px 34px; -webkit-mask:radial-gradient(150% 64% at 50% 4%, #000 0%, transparent 62%); mask:radial-gradient(150% 64% at 50% 4%, #000 0%, transparent 62%); }
  .px-aurora{ filter:blur(58px); }
  .px-beam{ display:none; }
}

/* ── Page-wide ambient backdrop (homepage) — so the hero glow/grid doesn't
   "cut off"; the whole page sits on one continuous, cohesive canvas. Fixed
   layers behind all content: soft brand glows (-2) + a faint dot grid (-1). */
body.page-home{ background:#07070c; }
body.page-home::before{
  content:""; position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(58% 42% at 84% -2%, rgba(124,58,237,.26), transparent 60%),
    radial-gradient(46% 38% at 10% 16%, rgba(79,70,229,.14), transparent 62%),
    radial-gradient(55% 45% at 80% 56%, rgba(124,58,237,.12), transparent 62%),
    radial-gradient(52% 42% at 16% 92%, rgba(34,211,238,.08), transparent 60%),
    linear-gradient(180deg,#0a0a13 0%,#08080f 55%,#07070c 100%);
}
body.page-home::after{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:48px 48px;
  -webkit-mask:radial-gradient(140% 96% at 72% -6%, #000 0%, rgba(0,0,0,.45) 48%, transparent 82%);
          mask:radial-gradient(140% 96% at 72% -6%, #000 0%, rgba(0,0,0,.45) 48%, transparent 82%);
}
/* The hero keeps its own animated backdrop; on the homepage make it transparent
   at the base so it blends seamlessly into the page-wide canvas (no seam). */
body.page-home .px-hero-bg::before{ background:
  radial-gradient(78% 58% at 80% 4%, rgba(124,58,237,.20), transparent 60%),
  radial-gradient(66% 60% at 10% 92%, rgba(34,211,238,.08), transparent 65%); }
@media (max-width:760px){
  body.page-home::after{ background-size:34px 34px; }
}

.px-hero-grid{ display:grid; grid-template-columns: 1.05fr .95fr; gap:48px; align-items:center; position:relative; z-index:2; }
.px-hero-copy h1{ font-size: clamp(2.2rem, 1.4rem + 3.8vw, 4.1rem); font-weight:900; line-height:1.08; letter-spacing:-.025em; color:var(--px-text); margin:18px 0 0; }
.px-hero-copy .px-lead{ font-size: clamp(1.05rem,1rem + .5vw,1.3rem); color:var(--px-mut); line-height:1.75; margin:20px 0 0; max-width:560px; }
.px-hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:32px; }
.px-hero-trust{ display:flex; align-items:center; gap:14px; margin-top:30px; flex-wrap:wrap; }
.px-avatars{ display:flex; }
.px-avatars span{ width:40px;height:40px;border-radius:50%; display:grid;place-items:center; font-weight:800; color:#fff; font-size:.9rem; border:2px solid var(--px-bg); margin-inline-start:-12px; box-shadow:0 4px 10px rgba(0,0,0,.4); }
.px-avatars span:first-child{ margin-inline-start:0; }
.px-trust-meta .stars{ color:#fbbf24; font-size:.85rem; letter-spacing:2px; }
.px-trust-meta small{ display:block; color:var(--px-mut); font-size:.84rem; margin-top:2px; }
@media (max-width:920px){
  .px-hero-grid{ grid-template-columns:1fr; gap:42px; text-align:center; }
  .px-hero-copy .px-lead{ margin-inline:auto; }
  .px-hero-cta,.px-hero-trust{ justify-content:center; }
  .px-head.start{ text-align:center; }
}
/* Phones: guarantee hero copy legibility over the ambient 3D/orbs. A soft
   radial scrim sits behind the text block, plus a subtle shadow on the type. */
@media (max-width:760px){
  .px-hero{ padding-top: clamp(72px,18vw,104px); }
  .px-hero-copy{ position:relative; z-index:3; }
  .px-hero-copy::before{
    content:""; position:absolute; z-index:-1; inset:-26px -18px;
    background:radial-gradient(120% 90% at 50% 38%, rgba(7,7,14,.86), rgba(7,7,14,.55) 55%, transparent 78%);
    filter:blur(2px); pointer-events:none;
  }
  .px-hero-copy h1{ text-shadow:0 2px 22px rgba(5,5,12,.7); }
  .px-hero-copy .px-lead{ text-shadow:0 1px 14px rgba(5,5,12,.85); }
}

/* ── Floating dashboard mockup (CSS/SVG, GPU-light) ───────────────────── */
.px-stage{ position:relative; height:440px; perspective:1400px; }
@media (max-width:920px){ .px-stage{ height:380px; margin-top:8px; } }
.px-card3d{
  position:absolute; border-radius:18px; background:linear-gradient(160deg,var(--px-panel-2),var(--px-panel));
  border:1px solid var(--px-line); box-shadow: var(--px-shadow);
  transform-style:preserve-3d; will-change:transform;
}
.px-win{ inset-inline-end:0; top:20px; width:min(92%,440px); padding:0; overflow:hidden; animation: px-float 7s ease-in-out infinite; }
.px-win-bar{ display:flex; align-items:center; gap:7px; padding:13px 16px; border-bottom:1px solid var(--px-line-soft); background:rgba(255,255,255,.02); }
.px-win-bar i{ width:11px;height:11px;border-radius:50%; display:inline-block; }
.px-win-bar .u{ margin-inline-start:auto; height:8px; width:120px; border-radius:99px; background:rgba(255,255,255,.07); }
.px-win-body{ padding:18px; }
.px-kpis{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-bottom:16px; }
.px-kpi{ background:rgba(255,255,255,.03); border:1px solid var(--px-line-soft); border-radius:12px; padding:11px; }
.px-kpi b{ display:block; font-size:1.05rem; color:#fff; font-weight:800; }
.px-kpi span{ font-size:.62rem; color:var(--px-dim); }
.px-bars{ display:flex; align-items:flex-end; gap:8px; height:96px; padding-top:6px; }
.px-bars i{ flex:1; border-radius:6px 6px 0 0; background:var(--px-grad); opacity:.85; display:block; animation: px-grow 1.2s var(--px-ease) both; }
.px-mini{ inset-inline-start:-6px; bottom:24px; width:210px; padding:14px 16px; animation: px-float 9s ease-in-out infinite reverse; }
.px-mini .lbl{ font-size:.7rem; color:var(--px-dim); }
.px-mini .big{ font-size:1.5rem; font-weight:900; color:#fff; margin:2px 0 8px; }
.px-mini .spark{ height:34px; }
.px-pill-float{ position:absolute; inset-inline-end:-4px; bottom:46px; display:flex; align-items:center; gap:9px; padding:11px 15px; border-radius:14px; background:linear-gradient(160deg,var(--px-panel-2),var(--px-panel)); border:1px solid var(--px-line); box-shadow:var(--px-shadow-sm); animation: px-float 8s ease-in-out infinite; }
.px-pill-float .ic{ width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:rgba(16,185,129,.16);color:#10b981; }
.px-pill-float b{ color:#fff; font-size:.92rem; } .px-pill-float span{ color:var(--px-dim); font-size:.68rem; display:block; }

@keyframes px-float{ 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(-16px); } }
@keyframes px-grow{ from{ height:0; opacity:0; } }
@media (prefers-reduced-motion: reduce){
  .px-orb,.px-win,.px-mini,.px-pill-float{ animation:none !important; }
  .px-bars i{ animation:none !important; }
}

/* ════════════════════════════════════════════════════════════════════════
   SOCIAL PROOF — stats band + logo strip
   ════════════════════════════════════════════════════════════════════════ */
.px-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.px-stat{ text-align:center; padding:26px 18px; border-radius:var(--px-r); background:rgba(255,255,255,.025); border:1px solid var(--px-line-soft); transition:border-color .25s, transform .25s; }
.px-stat:hover{ border-color:rgba(124,58,237,.4); transform:translateY(-3px); }
.px-stat .n{ font-size: clamp(1.9rem,1.3rem+2vw,2.8rem); font-weight:900; line-height:1; letter-spacing:-.02em; background:var(--px-grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.px-stat .l{ margin-top:8px; color:var(--px-mut); font-size:.92rem; font-weight:600; }
@media (max-width:760px){ .px-stats{ grid-template-columns:repeat(2,1fr); gap:12px; } }

/* ════════════════════════════════════════════════════════════════════════
   SERVICES — premium product cards
   ════════════════════════════════════════════════════════════════════════ */
.px-serv-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media (max-width:980px){ .px-serv-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:620px){ .px-serv-grid{ grid-template-columns:1fr; } }
.px-serv{
  position:relative; padding:30px; border-radius:var(--px-r-lg); overflow:hidden;
  background:linear-gradient(170deg,rgba(255,255,255,.045),rgba(255,255,255,.012));
  border:1px solid var(--px-line); transition: transform .3s var(--px-ease), border-color .3s, box-shadow .3s;
  display:flex; flex-direction:column; text-decoration:none;
}
.px-serv::before{ content:""; position:absolute; inset:0; background:radial-gradient(420px circle at var(--mx,80%) -10%, rgba(124,58,237,.16), transparent 60%); opacity:0; transition:opacity .3s; pointer-events:none; }
.px-serv:hover{ transform:translateY(-6px); border-color:rgba(124,58,237,.5); box-shadow: var(--px-glow); }
.px-serv:hover::before{ opacity:1; }
.px-serv .ic{ width:54px;height:54px;border-radius:15px; display:grid;place-items:center; font-size:1.5rem; color:#fff; background:var(--px-grad); box-shadow:0 8px 22px -8px rgba(124,58,237,.7); margin-bottom:18px; }
.px-serv h3{ font-size:1.2rem; font-weight:800; color:var(--px-text); margin:0 0 8px; }
.px-serv p{ color:var(--px-mut); font-size:.94rem; line-height:1.65; margin:0 0 16px; }
.px-serv .outs{ list-style:none; padding:0; margin:0 0 18px; display:flex; flex-direction:column; gap:8px; }
.px-serv .outs li{ display:flex; align-items:center; gap:9px; font-size:.88rem; color:var(--px-text); }
.px-serv .outs li i{ color:#10b981; font-size:.95em; flex-shrink:0; }
.px-serv .go{ margin-top:auto; display:inline-flex; align-items:center; gap:7px; color:var(--px-violet-2); font-weight:700; font-size:.92rem; }
.px-serv:hover .go i{ transform: translateX(-5px); }
.px-serv .go i{ transition:transform .25s; }

/* ════════════════════════════════════════════════════════════════════════
   PROCESS — premium timeline
   ════════════════════════════════════════════════════════════════════════ */
.px-flow{ display:grid; grid-template-columns:repeat(6,1fr); gap:14px; position:relative; }
.px-flow::before{ content:""; position:absolute; top:27px; inset-inline:6%; height:2px; background:linear-gradient(90deg,transparent,var(--px-violet),var(--px-indigo),transparent); opacity:.5; }
.px-step{ position:relative; text-align:center; }
.px-step .node{ width:54px;height:54px;border-radius:50%; margin:0 auto 16px; display:grid;place-items:center; font-size:1.25rem; color:#fff; background:linear-gradient(160deg,var(--px-panel-2),var(--px-panel)); border:1px solid rgba(124,58,237,.5); box-shadow:0 0 0 6px var(--px-bg), 0 8px 20px -8px rgba(124,58,237,.6); position:relative; z-index:2; }
.px-step .k{ font-size:.66rem; font-weight:800; letter-spacing:.12em; color:var(--px-violet-2); }
.px-step h4{ font-size:1rem; font-weight:800; color:var(--px-text); margin:4px 0 6px; }
.px-step p{ font-size:.82rem; color:var(--px-mut); line-height:1.55; margin:0; }
@media (max-width:900px){
  .px-flow{ grid-template-columns:1fr; gap:0; }
  .px-flow::before{ inset-inline-start:26px; inset-inline-end:auto; top:6%; bottom:6%; width:2px; height:auto; }
  .px-step{ text-align:start; display:grid; grid-template-columns:54px 1fr; gap:16px; padding:14px 0; align-items:start; }
  .px-step .node{ margin:0; }
}

/* ════════════════════════════════════════════════════════════════════════
   PORTFOLIO — device/browser mockups
   ════════════════════════════════════════════════════════════════════════ */
.px-port-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media (max-width:980px){ .px-port-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:620px){ .px-port-grid{ grid-template-columns:1fr; } }
.px-port{ border-radius:var(--px-r-lg); overflow:hidden; background:var(--px-panel); border:1px solid var(--px-line); transition:transform .3s var(--px-ease), box-shadow .3s, border-color .3s; text-decoration:none; display:block; }
.px-port:hover{ transform:translateY(-6px); box-shadow:var(--px-shadow); border-color:rgba(124,58,237,.4); }
.px-browser{ background:rgba(255,255,255,.02); }
.px-browser .top{ display:flex; align-items:center; gap:6px; padding:11px 14px; border-bottom:1px solid var(--px-line-soft); }
.px-browser .top i{ width:10px;height:10px;border-radius:50%; }
.px-browser .top .addr{ margin-inline-start:10px; height:8px; flex:1; max-width:60%; border-radius:99px; background:rgba(255,255,255,.06); }
.px-shot{ height:178px; position:relative; overflow:hidden; display:grid; place-items:center; }
.px-shot .glyph{ font-size:2.6rem; color:#fff; opacity:.92; z-index:2; }
.px-shot::after{ content:""; position:absolute; inset:0; opacity:.9; }
.px-port .meta{ padding:16px 18px; }
.px-port .meta h4{ margin:0 0 4px; font-size:1.02rem; font-weight:800; color:var(--px-text); }
.px-port .meta .tags{ display:flex; gap:6px; flex-wrap:wrap; }
.px-port .meta .tags span{ font-size:.68rem; color:var(--px-mut); background:rgba(255,255,255,.05); padding:3px 9px; border-radius:99px; }
.px-port .meta .res{ margin-top:10px; font-size:.82rem; color:#10b981; font-weight:700; }

/* ════════════════════════════════════════════════════════════════════════
   TESTIMONIALS — premium cards
   ════════════════════════════════════════════════════════════════════════ */
.px-tst-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media (max-width:980px){ .px-tst-grid{ grid-template-columns:1fr; max-width:620px; margin-inline:auto; } }
.px-tst{ padding:28px; border-radius:var(--px-r-lg); background:linear-gradient(170deg,rgba(255,255,255,.045),rgba(255,255,255,.012)); border:1px solid var(--px-line); position:relative; }
.px-tst .q{ font-size:3rem; line-height:1; color:rgba(124,58,237,.35); font-family:Georgia,serif; height:26px; }
.px-tst .stars{ color:#fbbf24; letter-spacing:2px; font-size:.85rem; margin:6px 0 12px; }
.px-tst p{ color:var(--px-text); font-size:1rem; line-height:1.75; margin:0 0 18px; }
.px-tst .who{ display:flex; align-items:center; gap:12px; border-top:1px solid var(--px-line-soft); padding-top:16px; }
.px-tst .who .av{ width:46px;height:46px;border-radius:50%; display:grid;place-items:center; font-weight:800; color:#fff; background:var(--px-grad); }
.px-tst .who b{ color:var(--px-text); font-size:.95rem; display:block; }
.px-tst .who span{ color:var(--px-dim); font-size:.8rem; }
.px-tst .metric{ margin-inline-start:auto; text-align:center; }
.px-tst .metric b{ display:block; color:#10b981; font-weight:900; font-size:1.1rem; }
.px-tst .metric span{ font-size:.66rem; color:var(--px-dim); }

/* ════════════════════════════════════════════════════════════════════════
   FINAL CTA
   ════════════════════════════════════════════════════════════════════════ */
.px-cta-panel{ position:relative; overflow:hidden; border-radius:32px; padding: clamp(40px,6vw,72px); text-align:center;
  background: radial-gradient(900px circle at 50% -40%, rgba(124,58,237,.35), transparent 60%), linear-gradient(170deg,var(--px-panel-2),var(--px-panel));
  border:1px solid rgba(124,58,237,.3); box-shadow: var(--px-shadow); }
.px-cta-panel h2{ font-size: clamp(1.8rem,1.2rem+2.6vw,3rem); font-weight:900; color:var(--px-text); margin:0 0 14px; letter-spacing:-.02em; }
.px-cta-panel p{ color:var(--px-mut); font-size:1.1rem; max-width:560px; margin:0 auto 30px; line-height:1.7; }
.px-cta-panel .row{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.px-cta-note{ margin-top:20px; color:var(--px-dim); font-size:.85rem; }

/* ── Reveal-on-scroll (GSAP enhances; CSS fallback shows content) ──────── */
.px-reveal{ opacity:0; transform: translateY(26px); }
.px-in .px-reveal, .no-js .px-reveal{ opacity:1; transform:none; }
html:not(.js) .px-reveal{ opacity:1; transform:none; }

/* ── Sticky nav polish (applies to existing .header) ──────────────────── */
.header.px-scrolled{ background: rgba(7,7,12,.82) !important; backdrop-filter: blur(14px); border-bottom:1px solid var(--px-line) !important; }

/* ════════════════════════════════════════════════════════════════════════
   POSITIONING V3 — hero store/identity mockup, trust grid, 2-up, logo, contact
   ════════════════════════════════════════════════════════════════════════ */
.px-chips{ display:flex; gap:10px; flex-wrap:wrap; }
.px-chip{ display:inline-flex; align-items:center; gap:7px; padding:8px 15px; border-radius:999px; font-size:.86rem; font-weight:700; color:var(--px-text); background:rgba(255,255,255,.04); border:1px solid var(--px-line); }
.px-chip i{ color:var(--px-violet-2); }

.px-store-head{ display:flex; align-items:center; gap:10px; margin-bottom:14px; }
.px-store-logo{ width:34px;height:34px;border-radius:9px; display:grid;place-items:center; font-weight:900; color:#fff; background:var(--px-grad); font-family:Arial,sans-serif; }
.px-store-cart{ margin-inline-start:auto; width:32px;height:32px;border-radius:9px; display:grid;place-items:center; background:rgba(255,255,255,.06); color:var(--px-violet-2); }
.px-prod-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.px-prod{ background:rgba(255,255,255,.03); border:1px solid var(--px-line-soft); border-radius:10px; padding:8px; }
.px-prod-img{ height:54px; border-radius:7px; margin-bottom:7px; }
.px-prod span{ display:block; height:7px; border-radius:99px; background:rgba(255,255,255,.12); }
.px-prod span.s{ width:60%; margin-top:5px; background:rgba(124,58,237,.5); }

.px-swatches{ display:flex; gap:6px; margin:8px 0 10px; }
.px-swatches i{ width:26px;height:26px;border-radius:7px; border:1px solid var(--px-line); display:block; }
.px-logo-chip{ font-family:Arial,sans-serif; font-weight:900; font-size:1.4rem; letter-spacing:2px; color:#fff; background:rgba(255,255,255,.04); border:1px dashed var(--px-line); border-radius:10px; padding:8px 0; text-align:center; }

.px-trust-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; max-width:1000px; margin-inline:auto; }
.px-trust-item{ display:flex; flex-direction:column; align-items:center; gap:10px; text-align:center; padding:22px 12px; border-radius:var(--px-r); background:rgba(255,255,255,.025); border:1px solid var(--px-line-soft); transition:border-color .25s, transform .25s; }
.px-trust-item:hover{ border-color:rgba(124,58,237,.4); transform:translateY(-3px); }
.px-trust-item i{ font-size:1.5rem; color:var(--px-violet-2); }
.px-trust-item span{ font-size:.86rem; font-weight:700; color:var(--px-text); }
@media (max-width:900px){ .px-trust-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .px-trust-grid{ grid-template-columns:repeat(2,1fr); gap:10px; } .px-trust-item{ padding:16px 10px; } }

/* ── Sticky mobile call-to-action bar (mobile only, every page) ─────────── */
.m-cta{ display:none; }
@media (max-width:768px){
  .m-cta{
    display:flex; gap:10px; position:fixed; inset-inline:0; bottom:0; z-index:1200;
    padding:10px 14px calc(10px + env(safe-area-inset-bottom));
    background:rgba(10,10,18,.85); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
    border-top:1px solid var(--px-line); box-shadow:0 -10px 30px -12px rgba(0,0,0,.6);
    animation:m-cta-in .4s var(--px-ease) both;
  }
  .m-cta a{ display:inline-flex; align-items:center; justify-content:center; gap:8px;
    padding:13px 12px; border-radius:13px; font-weight:800; font-size:.95rem; text-decoration:none; white-space:nowrap; }
  .m-cta-primary{ flex:1; color:#fff; background:var(--px-grad); box-shadow:0 10px 24px -10px rgba(124,58,237,.7); }
  .m-cta-secondary{ flex:0 0 auto; color:var(--px-text); background:rgba(255,255,255,.07); border:1px solid var(--px-line); padding-inline:18px; }
  body{ padding-bottom:78px; }
  /* lift the hamburger mobile menu's lowest item clear of the bar */
  .nav.active{ padding-bottom:84px; }
}
@keyframes m-cta-in{ from{ transform:translateY(100%); } to{ transform:translateY(0); } }
@media (prefers-reduced-motion: reduce){ .m-cta{ animation:none; } }

.px-serv-grid.two{ grid-template-columns:repeat(2,1fr); max-width:900px; margin-inline:auto; }
@media (max-width:680px){ .px-serv-grid.two{ grid-template-columns:1fr; } }

/* Brand logo (header + footer) */
.header .logo{ gap:0 !important; }
.brand-logo{ height:34px; width:auto; display:block; }
@media (max-width:560px){ .brand-logo{ height:28px; } }
.footer-logo{ height:42px; width:auto; margin-bottom:14px; display:block; }

/* Contact — mobile: form first, info compact below */
@media (max-width:820px){
  .contact-grid{ gap:26px !important; }
  .contact-grid .contact-info{ order:2; }
  .contact-info h2{ font-size:1.5rem !important; margin-bottom:12px !important; }
  .contact-info > p{ margin-bottom:18px !important; }
  .info-item{ padding:12px 0 !important; }
  .page-header{ padding-block:34px 16px !important; }
}

/* ════════════════════════════════════════════════════════════════════════
   SERVICE GATEWAY — full-screen decision selector (2 paths only)
   ════════════════════════════════════════════════════════════════════════ */
body.gateway-lock{ overflow:hidden; }
.svc-gateway{ position:fixed; inset:0; z-index:4000; display:none; align-items:center; justify-content:center; padding:24px; background:rgba(5,5,12,.88); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px); }
.svc-gateway.open{ display:flex; animation:svc-fade .28s var(--px-ease); }
@keyframes svc-fade{ from{ opacity:0 } to{ opacity:1 } }
.svc-gateway-close{ position:absolute; top:20px; inset-inline-end:24px; width:46px; height:46px; border-radius:50%; border:1px solid var(--px-line); background:rgba(255,255,255,.05); color:#fff; font-size:1.5rem; line-height:1; cursor:pointer; display:grid; place-items:center; transition:background .2s,transform .2s; }
.svc-gateway-close:hover{ background:rgba(255,255,255,.12); transform:rotate(90deg); }
.svc-gateway-inner{ width:100%; max-width:1000px; animation:svc-pop .35s var(--px-ease); }
@keyframes svc-pop{ from{ opacity:0; transform:translateY(16px) scale(.98) } to{ opacity:1; transform:none } }
.svc-gateway-head{ text-align:center; margin-bottom:30px; }
.svc-gateway-head h2{ font-size:clamp(1.6rem,1.1rem+2vw,2.5rem); font-weight:900; color:var(--px-text); margin:14px 0 8px; letter-spacing:-.02em; }
.svc-gateway-head p{ color:var(--px-mut); font-size:1.02rem; margin:0; }
.svc-pick-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.svc-pick{ position:relative; overflow:hidden; border-radius:26px; padding:30px; text-decoration:none; display:flex; flex-direction:column; background:linear-gradient(170deg,var(--px-panel-2),var(--px-panel)); border:1px solid var(--px-line); transition:transform .3s var(--px-ease), border-color .3s, box-shadow .3s; }
.svc-pick::after{ content:""; position:absolute; inset:0; background:radial-gradient(480px circle at 50% 0%, rgba(124,58,237,.18), transparent 60%); opacity:0; transition:opacity .3s; pointer-events:none; }
.svc-pick:hover{ transform:translateY(-6px); border-color:rgba(124,58,237,.55); box-shadow:var(--px-glow); }
.svc-pick:hover::after{ opacity:1; }
.svc-pick.identity:hover{ border-color:rgba(16,185,129,.55); box-shadow:0 0 0 1px rgba(16,185,129,.18),0 18px 60px -12px rgba(16,185,129,.4); }
.svc-illo{ height:150px; border-radius:18px; margin-bottom:22px; position:relative; overflow:hidden; display:grid; place-items:center; }
.svc-illo .big{ font-size:3.2rem; color:#fff; z-index:2; filter:drop-shadow(0 8px 18px rgba(0,0,0,.4)); }
.svc-illo.salla{ background:linear-gradient(135deg,#7c3aed,#4f46e5); }
.svc-illo.brand{ background:linear-gradient(135deg,#10b981,#06b6d4); }
.svc-illo .deco{ position:absolute; opacity:.9; }
.svc-illo .d1{ width:56px;height:42px;border-radius:8px;background:rgba(255,255,255,.18);top:18px;inset-inline-start:24px; }
.svc-illo .d2{ width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.16);bottom:16px;inset-inline-end:30px; }
.svc-illo .d3{ width:70px;height:12px;border-radius:99px;background:rgba(255,255,255,.2);bottom:22px;inset-inline-start:28px; }
.svc-pick h3{ font-size:1.4rem; font-weight:800; color:var(--px-text); margin:0 0 8px; }
.svc-pick p{ color:var(--px-mut); font-size:.96rem; line-height:1.65; margin:0 0 20px; }
.svc-pick .pick-feats{ list-style:none; padding:0; margin:0 0 22px; display:flex; flex-wrap:wrap; gap:8px; }
.svc-pick .pick-feats li{ font-size:.78rem; color:var(--px-text); background:rgba(255,255,255,.05); border:1px solid var(--px-line-soft); padding:5px 11px; border-radius:99px; }
.svc-pick .cta{ margin-top:auto; display:inline-flex; align-items:center; justify-content:center; gap:9px; padding:14px 22px; border-radius:14px; font-weight:800; font-size:1rem; color:#fff; background:var(--px-grad); box-shadow:0 10px 26px -10px rgba(124,58,237,.6); }
.svc-pick.identity .cta{ background:linear-gradient(120deg,#34d399,#10b981,#06b6d4); box-shadow:0 10px 26px -10px rgba(16,185,129,.6); }
@media (max-width:760px){
  .svc-gateway{ padding:0; align-items:stretch; }
  .svc-gateway-inner{ max-width:none; overflow-y:auto; padding:74px 18px 28px; }
  .svc-pick-grid{ grid-template-columns:1fr; gap:16px; }
  .svc-illo{ height:120px; }
  .svc-pick{ padding:22px; }
}
/* ── /services — single-service spotlight + features + platforms ───────── */
.svc-page{ padding-top:clamp(110px,16vw,150px); }
.svc-page .px-head{ margin-bottom:40px; }

.svc-spotlight{
  display:grid; grid-template-columns:.9fr 1.1fr; gap:42px; align-items:center;
  background:linear-gradient(168deg,var(--px-panel-2),var(--px-panel));
  border:1px solid var(--px-line); border-radius:28px; padding:34px; overflow:hidden; position:relative;
}
.svc-spotlight::before{ content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(520px circle at 80% -10%, rgba(124,58,237,.16), transparent 60%); }
.svc-spot-body{ position:relative; }
.svc-spot-body h2{ font-size:clamp(1.5rem,1.1rem+1.4vw,2rem); font-weight:900; color:var(--px-text); margin:0 0 12px; letter-spacing:-.02em; }
.svc-spot-body > p{ color:var(--px-mut); font-size:1.02rem; line-height:1.8; margin:0 0 22px; }
.svc-spot-feats{ list-style:none; padding:0; margin:0 0 26px; display:grid; grid-template-columns:1fr 1fr; gap:10px 18px; }
.svc-spot-feats li{ display:flex; align-items:center; gap:9px; font-size:.92rem; font-weight:600; color:var(--px-text); }
.svc-spot-feats li i{ color:#10b981; font-size:1em; flex-shrink:0; }
.svc-spot-cta{ display:flex; flex-wrap:wrap; gap:14px; }

/* spotlight art — mini store window */
.svc-spot-art{ position:relative; min-height:280px; border-radius:22px; display:grid; place-items:center;
  background:radial-gradient(120% 100% at 30% 0%, rgba(124,58,237,.28), transparent 65%),linear-gradient(160deg,#171733,#0c0c16);
  border:1px solid var(--px-line-soft); overflow:hidden; }
.svc-spot-orb{ position:absolute; border-radius:50%; filter:blur(46px); }
.svc-spot-orb.a{ width:200px;height:200px; background:rgba(124,58,237,.5); top:-50px; inset-inline-end:-30px; }
.svc-spot-orb.b{ width:160px;height:160px; background:rgba(34,211,238,.32); bottom:-40px; inset-inline-start:-20px; }
.svc-spot-window{ position:relative; z-index:2; width:min(86%,300px); border-radius:14px; overflow:hidden;
  background:linear-gradient(160deg,#1a1a30,#10101c); border:1px solid var(--px-line); box-shadow:0 26px 60px -24px rgba(0,0,0,.8); }
.ssw-bar{ display:flex; gap:6px; padding:11px 14px; border-bottom:1px solid var(--px-line-soft); background:rgba(255,255,255,.02); }
.ssw-bar i{ width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.18); }
.ssw-bar i:first-child{ background:#ff5f57 } .ssw-bar i:nth-child(2){ background:#febc2e } .ssw-bar i:nth-child(3){ background:#28c840 }
.ssw-body{ padding:16px; }
.ssw-row{ display:flex; align-items:center; gap:10px; margin-bottom:14px; }
.ssw-logo{ width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-weight:900;color:#fff;background:var(--px-grad); }
.ssw-line{ height:9px;border-radius:99px;background:rgba(255,255,255,.12); flex:1; } .ssw-line.w60{ max-width:60%; }
.ssw-cart{ width:30px;height:30px;border-radius:9px;display:grid;place-items:center;color:#a78bfa;background:rgba(124,58,237,.16); }
.ssw-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:10px; margin-bottom:14px; }
.ssw-grid span{ height:54px; border-radius:10px; background:var(--g); }
.ssw-cta{ display:flex; align-items:center; justify-content:center; gap:7px; padding:10px; border-radius:10px; font-size:.82rem; font-weight:800; color:#fff; background:var(--px-grad); }

.svc-feat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.svc-feat{ padding:28px 24px; border-radius:20px; background:linear-gradient(165deg,rgba(21,21,42,.75),rgba(12,12,20,.65)); border:1px solid var(--px-line); transition:transform .35s var(--px-ease), border-color .35s, box-shadow .35s; }
.svc-feat:hover{ transform:translateY(-6px); border-color:rgba(124,58,237,.45); box-shadow:0 24px 56px -28px rgba(124,58,237,.6); }
.svc-feat-ic{ width:54px;height:54px;border-radius:15px;display:grid;place-items:center;font-size:1.5rem;color:#fff;background:var(--px-grad); box-shadow:0 12px 28px -12px rgba(124,58,237,.9); margin-bottom:16px; }
.svc-feat h3{ font-size:1.12rem; font-weight:800; color:var(--px-text); margin:0 0 7px; }
.svc-feat p{ color:var(--px-mut); font-size:.92rem; line-height:1.65; margin:0; }

.svc-platforms{ display:grid; grid-template-columns:1fr 1fr; gap:22px; max-width:840px; margin-inline:auto; }
.svc-plat{ text-align:center; padding:34px 26px; border-radius:22px; background:linear-gradient(165deg,rgba(21,21,42,.75),rgba(12,12,20,.65)); border:1px solid var(--px-line); transition:transform .35s var(--px-ease), border-color .35s; }
.svc-plat:hover{ transform:translateY(-6px); border-color:rgba(124,58,237,.45); }
.svc-plat-ic{ width:66px;height:66px;border-radius:18px;display:grid;place-items:center;font-size:1.9rem;color:#fff;margin:0 auto 16px; }
.svc-plat-ic.salla{ background:linear-gradient(135deg,#7c3aed,#4f46e5); box-shadow:0 14px 32px -12px rgba(124,58,237,.9); }
.svc-plat-ic.zid{ background:linear-gradient(135deg,#10b981,#06b6d4); box-shadow:0 14px 32px -12px rgba(16,185,129,.9); }
.svc-plat h3{ font-size:1.2rem; font-weight:800; color:var(--px-text); margin:0 0 8px; }
.svc-plat p{ color:var(--px-mut); font-size:.92rem; line-height:1.65; margin:0; }

@media (max-width:880px){
  .svc-spotlight{ grid-template-columns:1fr; gap:28px; padding:24px; }
  .svc-spot-art{ order:-1; min-height:230px; }
  .svc-feat-grid{ grid-template-columns:1fr 1fr; gap:14px; }
}
@media (max-width:560px){
  .svc-spot-feats{ grid-template-columns:1fr; }
  .svc-spot-cta{ flex-direction:column; }
  .svc-spot-cta .btn-px, .svc-spot-cta .btn-ghost-px{ width:100%; justify-content:center; }
  .svc-feat-grid{ grid-template-columns:1fr; }
  .svc-platforms{ grid-template-columns:1fr; }
  .svc-feat{ padding:22px 20px; }
}

/* ════════════════════════════════════════════════════════════════════════
   DEDICATED PACKAGE PAGES — cards + comparison
   ════════════════════════════════════════════════════════════════════════ */
.pp-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; align-items:stretch; }
@media (max-width:920px){ .pp-cards{ grid-template-columns:1fr; max-width:460px; margin-inline:auto; } }
.pp-card{ position:relative; display:flex; flex-direction:column; padding:32px 26px; border-radius:24px;
  background:linear-gradient(175deg,rgba(255,255,255,.04),rgba(255,255,255,.012)); border:1px solid var(--px-line);
  transition:transform .3s var(--px-ease), border-color .3s, box-shadow .3s; }
.pp-card:hover{ transform:translateY(-5px); border-color:rgba(124,58,237,.4); box-shadow:var(--px-shadow); }
.pp-card.popular{ border-color:rgba(124,58,237,.6); background:linear-gradient(175deg,rgba(124,58,237,.12),rgba(79,70,229,.04)); box-shadow:var(--px-glow); }
@media (min-width:921px){ .pp-card.popular{ transform:scale(1.04); } .pp-card.popular:hover{ transform:scale(1.04) translateY(-5px); } }
.pp-badge{ position:absolute; top:-13px; inset-inline-start:50%; transform:translateX(50%); background:var(--px-grad); color:#fff; font-size:.72rem; font-weight:800; padding:5px 16px; border-radius:999px; white-space:nowrap; box-shadow:0 8px 20px -6px rgba(124,58,237,.7); }
.pp-name{ font-size:1.35rem; font-weight:900; color:var(--px-text); }
.pp-tag{ font-size:.86rem; color:var(--px-mut); margin-top:4px; min-height:2.4em; }
.pp-price{ display:flex; align-items:baseline; gap:8px; margin-top:18px; }
.pp-price .num{ font-size:2.7rem; font-weight:900; line-height:1; letter-spacing:-1px; background:var(--px-grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.pp-card:not(.popular) .pp-price .num{ background:none; -webkit-text-fill-color:initial; color:var(--px-text); }
.pp-price .cur{ font-size:.95rem; color:var(--px-mut); font-weight:700; }
.pp-from{ font-size:.74rem; color:var(--px-dim); margin-top:4px; }
/* Contact (Elite) tier — no price number, custom positioning */
.pp-price.contact .num{ font-size:1.7rem; letter-spacing:0; background:var(--px-grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.pp-card.contact{ border-color:rgba(124,58,237,.45); background:linear-gradient(175deg,rgba(124,58,237,.10),rgba(34,211,238,.03)); }
.pp-delivery{ display:inline-flex; align-items:center; gap:7px; margin-top:16px; font-size:.8rem; font-weight:700; color:var(--px-violet-2); background:rgba(124,58,237,.1); border:1px solid rgba(124,58,237,.22); padding:6px 12px; border-radius:99px; }
.pp-feats{ list-style:none; padding:0; margin:20px 0 24px; display:flex; flex-direction:column; gap:11px; }
.pp-feats li{ display:flex; align-items:flex-start; gap:10px; font-size:.9rem; color:var(--px-text); line-height:1.5; }
.pp-feats li i{ color:#10b981; font-size:.95em; margin-top:3px; flex-shrink:0; }
.pp-cta{ margin-top:auto; display:flex; align-items:center; justify-content:center; gap:9px; padding:14px; border-radius:14px; font-weight:800; font-size:.98rem; text-decoration:none; color:var(--px-text); background:rgba(255,255,255,.05); border:1px solid var(--px-line); transition:transform .2s, box-shadow .2s, background .2s; }
.pp-cta:hover{ transform:translateY(-2px); background:rgba(255,255,255,.09); }
.pp-cta.primary{ color:#fff; background:var(--px-grad); border:none; box-shadow:0 12px 28px -10px rgba(124,58,237,.6); }

.pp-compare-wrap{ overflow-x:auto; border:1px solid var(--px-line); border-radius:22px; background:var(--px-panel); }
.pp-compare{ width:100%; border-collapse:collapse; min-width:620px; }
.pp-compare thead th{ padding:18px 18px; text-align:center; font-size:.95rem; font-weight:800; color:var(--px-text); border-bottom:1px solid var(--px-line); white-space:nowrap; }
.pp-compare thead th:first-child{ text-align:start; color:var(--px-mut); font-weight:700; }
.pp-compare thead th.pop{ color:var(--px-violet-2); background:rgba(124,58,237,.08); border-radius:14px 14px 0 0; }
.pp-compare thead th .star{ color:#fbbf24; }
.pp-compare tbody th{ padding:14px 18px; text-align:start; font-weight:600; color:var(--px-mut); font-size:.88rem; border-bottom:1px solid var(--px-line-soft); }
.pp-compare tbody td{ padding:14px 18px; text-align:center; font-size:.88rem; color:var(--px-text); border-bottom:1px solid var(--px-line-soft); white-space:nowrap; }
.pp-compare tbody td.pop{ background:rgba(124,58,237,.05); font-weight:700; }
.pp-compare tbody tr:last-child th, .pp-compare tbody tr:last-child td{ border-bottom:none; }
.pp-compare .yes{ color:#10b981; font-size:1.1rem; }
.pp-compare .no{ color:var(--px-dim); }
.pp-compare tbody tr:hover td, .pp-compare tbody tr:hover th{ background:rgba(255,255,255,.02); }
.pp-compare tbody tr:hover td.pop{ background:rgba(124,58,237,.09); }

/* ════════════════════════════════════════════════════════════════════════
   UX POLISH — premium FAQ + mobile-first package comparison
   ════════════════════════════════════════════════════════════════════════ */
/* Premium FAQ (used on /faq, package pages) */
.faq-list{ display:flex; flex-direction:column; gap:12px; max-width:760px; margin-inline:auto; }
.faq-item{ background:var(--px-panel); border:1px solid var(--px-line); border-radius:16px; overflow:hidden; transition:border-color .25s, box-shadow .25s, background .25s; }
.faq-item:hover{ border-color:rgba(124,58,237,.4); }
.faq-item.active{ border-color:rgba(124,58,237,.55); box-shadow:0 14px 34px -18px rgba(124,58,237,.55); }
.faq-question{ width:100%; padding:19px 22px; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:16px; font-weight:700; font-size:1.02rem; color:var(--px-text); background:none; border:none; text-align:start; font-family:inherit; line-height:1.5; }
.faq-question > span:first-child{ flex:1; }
.faq-icon{ width:30px; height:30px; flex-shrink:0; border-radius:9px; display:grid; place-items:center; font-size:.95rem; background:rgba(124,58,237,.12); color:var(--px-violet-2); transition:transform .3s var(--px-ease), background .25s, color .25s; }
.faq-item.active .faq-icon{ transform:rotate(45deg); background:var(--px-grad); color:#fff; }
.faq-answer{ max-height:0; overflow:hidden; padding:0 22px; color:var(--px-mut); line-height:1.85; font-size:.95rem; transition:max-height .35s var(--px-ease), padding .35s var(--px-ease); }
.faq-item.active .faq-answer{ max-height:640px; padding:0 22px 20px; }
.faq-answer-inner{ padding:0 !important; }
@media (max-width:600px){
  .faq-question{ padding:16px 18px; font-size:.95rem; }
  .faq-answer{ padding-inline:18px; }
  .faq-item.active .faq-answer{ padding:0 18px 18px; }
}

/* Mobile-first comparison: table → stacked feature cards (no horizontal scroll) */
@media (max-width:720px){
  .pp-compare-wrap{ border:none; background:transparent; overflow:visible; border-radius:0; }
  .pp-compare{ min-width:0; width:100%; }
  .pp-compare thead{ display:none; }
  .pp-compare, .pp-compare tbody, .pp-compare tr, .pp-compare > tbody > tr > th, .pp-compare td{ display:block; width:auto; }
  .pp-compare tbody tr{
    background:var(--px-panel); border:1px solid var(--px-line); border-radius:16px;
    margin-bottom:14px; padding:6px 6px 8px; box-shadow:var(--px-shadow-sm);
  }
  .pp-compare tbody tr > th{
    font-size:.98rem; font-weight:800; color:var(--px-text);
    padding:13px 16px 11px; border-bottom:1px solid var(--px-line-soft); text-align:start;
  }
  .pp-compare tbody td{
    display:flex; align-items:center; justify-content:space-between; gap:14px;
    padding:11px 16px; text-align:end; border:none; border-bottom:1px solid var(--px-line-soft);
    white-space:normal; font-weight:700;
  }
  .pp-compare tbody td:last-child{ border-bottom:none; }
  .pp-compare tbody td::before{
    content:attr(data-label); color:var(--px-mut); font-size:.84rem; font-weight:600; text-align:start;
  }
  .pp-compare tbody td.pop{ background:rgba(124,58,237,.08); border-radius:10px; }
  .pp-compare tbody td.pop::before{ color:var(--px-violet-2); }
  .pp-compare .yes{ font-size:1.05rem; }
}
