/* =========================================================
   PIXLZA — Product page builder
   Per-product colors injected as --p / --s / --a on .pp wrapper.
   Templates: classic | bold | minimal | showcase
   ========================================================= */
.pp{
  --p:#07194C; --s:#061B5B; --a:#05B3B6;
  --ink:#0e1630; --muted:#5b6480; --card:#fff; --surface:#f6f9fc; --line:rgba(7,25,76,.12);
  --on-hero:#fff;
  color:var(--ink);
}
.pp[data-mode="light"]{ --hero-bg:linear-gradient(135deg,#fff, #f2f6fb); --on-hero:var(--p); }
.pp[data-mode="dark"]{ --hero-bg:linear-gradient(135deg,var(--p),var(--s)); --on-hero:#fff; }
.pp *{box-sizing:border-box}
.pp .wrap{width:min(1180px,92%);margin-inline:auto}
.pp section{padding:84px 0;position:relative}
.pp .tag{display:inline-block;color:var(--a);font-weight:800;letter-spacing:2px;text-transform:uppercase;font-size:13px;margin-bottom:8px}
.pp h2.ttl{font-size:clamp(1.7rem,3.6vw,2.4rem);font-weight:800;color:var(--p);margin-bottom:10px}
.pp[data-mode="dark"] .sec-dark h2.ttl{color:#fff}
.pp .lead{color:var(--muted);max-width:620px}

/* ---- buttons ---- */
.pp .pbtn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:50px;font-weight:700;
  border:none;cursor:pointer;transition:.3s;font-family:inherit;font-size:15px}
.pp .pbtn.solid{background:var(--a);color:#fff;box-shadow:0 12px 30px color-mix(in srgb,var(--a) 45%,transparent)}
.pp .pbtn.solid:hover{transform:translateY(-3px)}
.pp .pbtn.ghost{background:transparent;color:var(--on-hero);border:1.6px solid color-mix(in srgb,var(--on-hero) 55%,transparent)}
.pp .pbtn.ghost:hover{background:color-mix(in srgb,var(--on-hero) 14%,transparent)}

/* ====================== HERO ====================== */
.pp-hero{background:var(--hero-bg);color:var(--on-hero);overflow:hidden;position:relative;padding:150px 0 90px}
.pp-hero .pcanvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:.55}
.pp-hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.pp-hero .badge{display:inline-flex;gap:8px;align-items:center;background:color-mix(in srgb,var(--a) 20%,transparent);
  border:1px solid color-mix(in srgb,var(--a) 45%,transparent);color:var(--a);padding:7px 16px;border-radius:50px;font-weight:700;font-size:13px}
.pp-hero h1{font-size:clamp(2.1rem,5.2vw,3.6rem);line-height:1.15;font-weight:800;margin:16px 0}
.pp-hero h1 .hl{color:var(--a)}
.pp-hero p.sub{font-size:1.12rem;opacity:.9;max-width:540px}
.pp-hero .hcta{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap}
.pp-hero .hmedia{position:relative;display:grid;place-items:center;perspective:1000px}
.pp-hero .tilt{width:100%;border-radius:24px;overflow:hidden;box-shadow:0 40px 90px rgba(0,0,0,.35);
  transform-style:preserve-3d;transition:transform .15s ease-out;background:color-mix(in srgb,var(--p) 70%,#000)}
.pp-hero .tilt img{display:block;width:100%}
.pp-hero .tilt .ph{aspect-ratio:4/3;display:grid;place-items:center;font-size:5rem;font-weight:800;
  color:color-mix(in srgb,var(--a) 60%,transparent);background:linear-gradient(135deg,var(--p),var(--s))}
.pp-hero .glow{position:absolute;width:360px;height:360px;border-radius:50%;background:var(--a);filter:blur(120px);opacity:.4;
  inset-inline-end:-60px;top:-40px;z-index:0;animation:ppfloat 9s ease-in-out infinite}

/* ====================== SLIDER ====================== */
.pp-slider{position:relative;border-radius:24px;overflow:hidden;box-shadow:0 24px 60px rgba(7,25,76,.18);background:var(--p)}
.pp-slider .track{display:flex;transition:transform .55s cubic-bezier(.6,.05,.2,1)}
.pp-slider .slide{min-width:100%;position:relative;aspect-ratio:16/9}
.pp-slider .slide img{width:100%;height:100%;object-fit:cover}
.pp-slider .slide .ph{width:100%;height:100%;display:grid;place-items:center;color:rgba(255,255,255,.25);font-size:3rem;font-weight:800;
  background:linear-gradient(135deg,var(--p),var(--a))}
.pp-slider .cap{position:absolute;inset-inline:0;bottom:0;padding:22px;color:#fff;
  background:linear-gradient(to top,rgba(0,0,0,.7),transparent);font-weight:600}
.pp-slider .nav{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;border:none;cursor:pointer;
  background:rgba(255,255,255,.85);color:var(--p);display:grid;place-items:center;font-size:20px;z-index:3;transition:.2s}
.pp-slider .nav:hover{background:#fff;transform:translateY(-50%) scale(1.08)}
.pp-slider .prev{inset-inline-start:14px}.pp-slider .next{inset-inline-end:14px}
.pp-slider .dots{position:absolute;inset-inline:0;bottom:14px;display:flex;gap:8px;justify-content:center;z-index:3}
.pp-slider .dots b{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.5);cursor:pointer;transition:.2s}
.pp-slider .dots b.on{background:var(--a);width:26px;border-radius:6px}

/* ====================== GALLERY ====================== */
.pp-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.pp-gallery .g{aspect-ratio:1;border-radius:14px;overflow:hidden;cursor:pointer;position:relative;background:var(--surface)}
.pp-gallery .g img{width:100%;height:100%;object-fit:cover;transition:.4s}
.pp-gallery .g:hover img{transform:scale(1.08)}
.pp-gallery .g .ph{width:100%;height:100%;display:grid;place-items:center;color:var(--a);font-weight:800;font-size:1.6rem;
  background:color-mix(in srgb,var(--a) 12%,#fff)}
/* lightbox */
.pp-lb{position:fixed;inset:0;background:rgba(8,12,30,.92);display:none;place-items:center;z-index:9999;padding:30px}
.pp-lb.on{display:grid}
.pp-lb img{max-width:90vw;max-height:86vh;border-radius:12px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.pp-lb .x{position:absolute;top:20px;inset-inline-end:24px;color:#fff;font-size:34px;cursor:pointer;background:none;border:none}

/* ====================== FEATURES ====================== */
.pp-feats{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pp-feat{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:30px 26px;transition:.3s;
  transform-style:preserve-3d;will-change:transform}
.pp-feat:hover{box-shadow:0 26px 60px rgba(7,25,76,.14);border-color:transparent}
.pp-feat .ic{width:58px;height:58px;border-radius:15px;display:grid;place-items:center;margin-bottom:16px;
  background:color-mix(in srgb,var(--a) 14%,#fff);color:var(--a);transition:.3s}
.pp-feat:hover .ic{background:var(--a);color:#fff;transform:translateZ(20px) rotate(-6deg)}
.pp-feat h3{color:var(--p);font-size:1.2rem;margin-bottom:6px}
.pp-feat p{color:var(--muted);font-size:.97rem}

/* ====================== SPECS ====================== */
.pp-specs{background:var(--card);border:1px solid var(--line);border-radius:18px;overflow:hidden}
.pp-specs .row{display:grid;grid-template-columns:1fr 1.4fr;border-bottom:1px solid var(--line)}
.pp-specs .row:last-child{border-bottom:none}
.pp-specs .k{padding:16px 22px;font-weight:700;color:var(--p);background:color-mix(in srgb,var(--a) 7%,#fff)}
.pp-specs .v{padding:16px 22px;color:var(--muted)}

/* ====================== STATS ====================== */
.pp-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:center;
  background:linear-gradient(135deg,var(--p),var(--s));border-radius:22px;padding:46px 28px;color:#fff}
.pp-stats .n{font-size:2.8rem;font-weight:800;color:var(--a)}
.pp-stats .l{opacity:.85;font-weight:600;margin-top:4px}

/* ====================== VIDEO ====================== */
.pp-video{border-radius:22px;overflow:hidden;box-shadow:0 24px 60px rgba(7,25,76,.2);aspect-ratio:16/9;background:#000}
.pp-video iframe{width:100%;height:100%;border:0;display:block}

/* ====================== PRICING ====================== */
.pp-plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px;max-width:900px;margin-inline:auto}
.pp-plan{background:var(--card);border:1.5px solid var(--line);border-radius:20px;padding:32px 26px;transition:.3s;position:relative}
.pp-plan.feat{border-color:var(--a);box-shadow:0 24px 60px color-mix(in srgb,var(--a) 28%,transparent);transform:translateY(-6px)}
.pp-plan.feat::before{content:"★";position:absolute;top:18px;inset-inline-end:20px;color:var(--a)}
.pp-plan h3{color:var(--p);font-size:1.3rem}
.pp-plan .price{font-size:2.6rem;font-weight:800;color:var(--p);margin:10px 0}
.pp-plan .price span{font-size:1rem;color:var(--muted);font-weight:600}
.pp-plan ul{list-style:none;padding:0;margin:16px 0;display:grid;gap:10px}
.pp-plan ul li{color:var(--muted);display:flex;gap:8px;align-items:flex-start}
.pp-plan ul li::before{content:"✓";color:var(--a);font-weight:800}

/* ====================== REVIEWS ====================== */
.pp-reviews{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.pp-review{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:28px}
.pp-review .stars{color:var(--a);margin-bottom:10px;letter-spacing:2px}
.pp-review p{color:var(--ink);font-size:1.02rem;margin-bottom:14px}
.pp-review .who{display:flex;align-items:center;gap:12px}
.pp-review .av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--p),var(--a));color:#fff;display:grid;place-items:center;font-weight:800}
.pp-review .who b{color:var(--p);display:block}
.pp-review .who span{color:var(--muted);font-size:.9rem}

/* ====================== FAQ ====================== */
.pp-faqs{max-width:820px;margin-inline:auto;display:grid;gap:12px}
.pp-faq{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.pp-faq .q{padding:18px 22px;font-weight:700;color:var(--p);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px}
.pp-faq .q::after{content:"+";font-size:1.5rem;color:var(--a);transition:.3s}
.pp-faq.open .q::after{transform:rotate(45deg)}
.pp-faq .a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--muted)}
.pp-faq .a p{padding:0 22px 18px}
.pp-faq.open .a{max-height:300px}

/* ====================== CTA band ====================== */
.pp-cta{background:linear-gradient(135deg,var(--p),var(--a));border-radius:24px;padding:54px 30px;text-align:center;color:#fff}
.pp-cta h2{font-size:clamp(1.6rem,3.4vw,2.3rem);font-weight:800;margin-bottom:20px}

/* ====================== TEMPLATE VARIANTS ====================== */
/* BOLD: color-blocked sections */
.pp[data-tpl="bold"] section.alt{background:linear-gradient(135deg,var(--p),var(--s));color:#fff}
.pp[data-tpl="bold"] section.alt h2.ttl{color:#fff}
.pp[data-tpl="bold"] section.alt .lead{color:rgba(255,255,255,.8)}
.pp[data-tpl="bold"] section.alt .pp-feat,
.pp[data-tpl="bold"] section.alt .pp-specs{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.15);color:#fff}
.pp[data-tpl="bold"] section.alt .pp-feat h3,.pp[data-tpl="bold"] section.alt .pp-specs .k{color:#fff;background:transparent}
.pp[data-tpl="bold"] section.alt .pp-feat p,.pp[data-tpl="bold"] section.alt .pp-specs .v{color:rgba(255,255,255,.8)}
.pp[data-tpl="bold"] h1,.pp[data-tpl="bold"] h2.ttl{letter-spacing:-.5px}

/* MINIMAL: airy, thin, accent touches only */
.pp[data-tpl="minimal"]{--card:#fff}
.pp[data-tpl="minimal"] .pp-hero{--hero-bg:#fff;color:var(--p);border-bottom:1px solid var(--line)}
.pp[data-tpl="minimal"] .pp-hero .pcanvas{opacity:.18}
.pp[data-tpl="minimal"] section{padding:70px 0}
.pp[data-tpl="minimal"] .pp-feat,.pp[data-tpl="minimal"] .pp-plan{box-shadow:none;border-radius:10px}
.pp[data-tpl="minimal"] .pp-feat:hover{box-shadow:0 12px 30px rgba(7,25,76,.08)}
.pp[data-tpl="minimal"] .pp-stats{background:#fff;color:var(--p);border:1px solid var(--line)}
.pp[data-tpl="minimal"] .pp-stats .l{color:var(--muted)}

/* SHOWCASE: slider-first, large media */
.pp[data-tpl="showcase"] .pp-hero{padding-bottom:40px}
.pp[data-tpl="showcase"] .pp-gallery{grid-template-columns:repeat(3,1fr)}
.pp[data-tpl="showcase"] .pp-gallery .g{aspect-ratio:4/3}

/* scroll progress */
.pp-progress{position:fixed;inset-block-start:0;inset-inline:0;height:3px;z-index:101;background:transparent;pointer-events:none}
.pp-progress span{display:block;height:100%;width:0;background:var(--a);transition:width .1s linear}

/* sticky in-page nav */
.pp-nav{position:sticky;top:58px;z-index:80;background:color-mix(in srgb,var(--p) 92%,#000);
  backdrop-filter:blur(8px);border-block-end:1px solid color-mix(in srgb,var(--a) 30%,transparent)}
.pp-nav .wrap{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;padding:6px 0}
.pp-nav .wrap::-webkit-scrollbar{display:none}
.pp-nav a{flex:0 0 auto;color:rgba(255,255,255,.8);font-weight:700;font-size:14px;padding:9px 16px;border-radius:30px;
  white-space:nowrap;transition:.2s}
.pp-nav a:hover{color:#fff;background:color-mix(in srgb,#fff 12%,transparent)}
.pp-nav a.active{background:var(--a);color:#fff}
.pp [id^="sec-"]{scroll-margin-top:120px}

/* perf: skip rendering offscreen sections */
.pp section{content-visibility:auto;contain-intrinsic-size:1px 600px}
.pp-hero{content-visibility:visible}

/* reveal */
.pp .rv{opacity:0;transform:translateY(30px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.pp .rv.in{opacity:1;transform:none}

/* respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .pp .rv{opacity:1!important;transform:none!important;transition:none}
  .pp-hero .tilt,.pp-feat{transition:none!important}
  .pp-hero .glow,.orbit,.about-art .ring{animation:none!important}
  .pp-progress span{transition:none}
}

@keyframes ppfloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-24px)}}

/* responsive */
@media(max-width:920px){
  .pp-hero{padding:120px 0 64px}
  .pp-hero .wrap{grid-template-columns:1fr;text-align:center}
  .pp-hero p.sub{margin-inline:auto}.pp-hero .hcta{justify-content:center}
  .pp-hero .hmedia{max-width:460px;margin-inline:auto}
  .pp-feats{grid-template-columns:repeat(2,1fr)}
  .pp-gallery,.pp[data-tpl="showcase"] .pp-gallery{grid-template-columns:repeat(3,1fr)}
  .pp-stats{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:600px){
  .pp section{padding:56px 0}
  .pp-hero{padding:104px 0 52px}
  .pp-hero .hcta{flex-direction:column}
  .pp-hero .hcta .pbtn{width:100%;justify-content:center}
  .pp-feats,.pp-stats,.pp-specs .row{grid-template-columns:1fr}
  .pp-gallery,.pp[data-tpl="showcase"] .pp-gallery{grid-template-columns:repeat(2,1fr)}
  .pp-nav a{font-size:13px;padding:8px 13px}
  .pp-plans{grid-template-columns:1fr}
}
