/* ============================================================
   PORNPEN.NET — Unified Design System v5.1 (fixed)
   Duplicates removed · Dead selectors cleaned · Sections merged
   ============================================================ */

/* === 0. DESIGN TOKENS === */
:root{
  --bg:#0a0b10;
  --bg-raised:#0d0f18;
  --bg-card:#11131c;
  --ink:#fff;
  --ink-2:#cfd5ff;
  --ink-3:#aeb4d9;
  --neon:#F72585;
  --neon-2:#8A2EFF;
  --neon-soft:rgba(247,37,133,.45);
  --grad:linear-gradient(90deg,#ff2dfb,#7a5fff);
  --card-bg:linear-gradient(145deg,#11131c 0%,#0b0d14 100%);
  --card-bg-flat:#0d0f18;
  --card-bd:rgba(255,0,255,.12);
  --card-glow:rgba(255,0,255,.05);
  --wrap:1180px;
  --gutter:24px;
  --hdr:64px;
  --s-xs:8px;--s-sm:12px;--s-md:16px;--s-lg:24px;--s-xl:32px;--s-2xl:48px;--s-3xl:80px;
  --r:16px;--r-lg:20px;--r-pill:999px;
  --ease:cubic-bezier(.4,0,.2,1);
  --dur:.25s;
}

/* === 1. RESET === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Oxygen,Ubuntu,sans-serif;font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
a{color:inherit}
img,video{max-width:100%;height:auto;display:block}
h1,h2,h3,h4{color:#fff;line-height:1.2}

/* === 2. LAYOUT === */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--gutter)}
.section{padding:var(--s-3xl) 0}
@media(max-width:1024px){.section{padding:56px 0}}
@media(max-width:768px){.section{padding:40px 0}}
.section h2{margin-bottom:var(--s-lg);font-size:clamp(24px,2.8vw,36px);font-weight:900;letter-spacing:-.01em}
.section p{margin-bottom:var(--s-md);color:var(--ink-2)}
.section h3{margin-bottom:var(--s-sm)}
.lead{font-size:1.1rem;line-height:1.7;color:var(--ink-2);opacity:.92}
h2[id],h3[id]{scroll-margin-top:calc(var(--hdr) + 16px)}

/* === 3. HEADER === */
.pp-header{position:sticky;top:0;z-index:9999;height:var(--hdr);display:flex;align-items:center;background:rgba(10,11,16,.88);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.06);box-shadow:0 4px 24px rgba(0,0,0,.4)}
.pp-header .wrap{display:flex;align-items:center;justify-content:space-between;width:100%}
.pp-header__logo{font-weight:900;font-size:1.2rem;text-decoration:none;letter-spacing:.3px;flex-shrink:0;transition:color var(--dur) var(--ease)}
.pp-header__logo:hover{color:var(--neon);text-shadow:0 0 12px var(--neon-soft)}
.pp-header__nav{display:flex;align-items:center;gap:20px}
.pp-header__nav a{color:var(--ink-2);font-weight:600;font-size:.93rem;text-decoration:none;white-space:nowrap;transition:color var(--dur) var(--ease)}
.pp-header__nav a:hover{color:#fff;text-shadow:0 0 8px var(--neon-soft)}
.pp-header__cta{background:var(--grad);color:#fff!important;font-weight:700;font-size:.95rem;padding:10px 22px;border-radius:var(--r-pill);border:0;box-shadow:0 0 18px rgba(255,45,251,.45),0 0 36px rgba(122,95,255,.35);transition:transform var(--dur),box-shadow var(--dur)}
.pp-header__cta:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 0 26px rgba(255,45,251,.75),0 0 48px rgba(122,95,255,.6)}

/* Burger */
.pp-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:6px;border:0;border-radius:8px;background:rgba(255,255,255,.06);cursor:pointer;transition:background var(--dur);z-index:10001}
.pp-burger span{display:block;width:100%;height:2px;border-radius:2px;background:#fff;transition:transform .3s var(--ease),opacity .2s}
.pp-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.pp-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.pp-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:768px){
  .pp-burger{display:flex}
  .pp-header__nav{position:fixed;top:var(--hdr);right:0;left:auto;height:calc(100vh - var(--hdr));height:calc(100dvh - var(--hdr));width:min(320px,85vw);flex-direction:column;align-items:stretch;gap:0;padding:20px;padding-top:24px;box-sizing:border-box;background:rgba(10,11,16,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);transform:translateX(100%);transition:transform .35s var(--ease);z-index:10000;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}
  .pp-header__nav.open{transform:translateX(0)}
  .pp-header__nav a{display:block;padding:14px 0;font-size:1.05rem;border-bottom:1px solid rgba(255,255,255,.06)}
  .pp-header__nav .pp-header__cta{margin-top:var(--s-md);text-align:center;padding:14px 24px}
}

/* === 4. HERO === */
.pp-hero{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);padding:clamp(48px,6vw,96px) clamp(32px,4vw,64px);margin:var(--s-lg) auto 0;max-width:1280px;border-radius:var(--r-lg);background:radial-gradient(ellipse at 20% 0%,rgba(247,37,133,.1),rgba(138,46,255,.06) 50%,rgba(10,11,16,.96));border:1px solid rgba(247,37,133,.15);box-shadow:0 0 50px rgba(247,37,133,.08),0 20px 48px rgba(0,0,0,.45)}
.pp-hero__col{display:flex;flex-direction:column;justify-content:center;min-width:0}
.pp-hero__col--text{order:1}
.pp-hero__col--media{order:2}
.pp-hero h1{font-size:clamp(28px,3.8vw,44px);font-weight:900;line-height:1.12;letter-spacing:-.02em;margin-bottom:var(--s-lg)}
.pp-hero .lead{margin-bottom:var(--s-md)}
.pp-hero .hero-seo{font-size:.96rem;line-height:1.6;color:var(--ink-3);margin-bottom:var(--s-xl);opacity:.85}
.pp-hero .pp-frame{margin:0;border-radius:var(--r);overflow:hidden;border:1px solid rgba(247,37,133,.15);box-shadow:0 0 36px rgba(247,37,133,.1),0 12px 32px rgba(0,0,0,.4)}
.pp-hero .pp-frame img{width:100%;height:auto;display:block;border-radius:calc(var(--r) - 1px);filter:saturate(1.15) contrast(1.1)}
.pp-hero .pp-frame img{max-height:75vh;width:100%;object-fit:contain}
@media(max-width:900px){
  .pp-hero{grid-template-columns:1fr;padding:32px 20px;margin:var(--s-sm) auto 0;gap:var(--s-lg)}
  .pp-hero__col--media{order:-1}
  .pp-hero__col--text{order:2}
  .pp-hero .pp-frame img { max-height: 80vh; width: auto; object-fit: contain; }
}

/* === 4b. SOCIAL PROOF === */
.pp-social-proof{display:flex;gap:16px;flex-wrap:wrap;margin-top:var(--s-lg)}
.pp-sp-item{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--r-pill);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);font-size:.88rem;font-weight:700;color:var(--ink-2);white-space:nowrap}
.pp-micro-trigger{margin-top:var(--s-sm);font-size:.85rem;color:var(--ink-3);opacity:.8;letter-spacing:.2px}

/* === 5. BULLETS === */
.pp-bullets,.bullets{list-style:none;margin:0 0 var(--s-xl);padding:0}
.pp-bullets li,.bullets li{position:relative;margin:.55rem 0;padding-left:22px;color:#e5e8ff;line-height:1.55}
.pp-bullets li::before,.bullets li::before{content:"";position:absolute;left:0;top:.6em;width:8px;height:8px;border-radius:50%;background:var(--neon);box-shadow:0 0 10px var(--neon)}

/* === 6. BUTTONS === */
.btn,.pp-cta-primary{display:inline-flex;align-items:center;justify-content:center;min-height:50px;padding:13px 28px;border-radius:var(--r-pill);border:0;font-weight:800;font-size:1rem;color:#fff;text-decoration:none;cursor:pointer;transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);white-space:nowrap}
.btn-primary,.pp-cta-primary{background:var(--grad);box-shadow:0 0 20px rgba(255,45,251,.45),0 0 40px rgba(122,95,255,.3)}
.btn-primary:hover,.pp-cta-primary:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 0 30px rgba(255,45,251,.75),0 0 52px rgba(122,95,255,.6)}
.btn--sm{min-height:42px;padding:10px 22px;font-size:.92rem}
.btn-secondary,.pp-cta-secondary{display:inline-flex;align-items:center;min-height:44px;padding:0 10px;border-radius:10px;font-weight:700;font-size:.97rem;color:var(--ink-2);background:transparent;text-decoration:underline;text-underline-offset:3px;transition:color var(--dur)}
.btn-secondary:hover,.pp-cta-secondary:hover{color:#fff}

@keyframes ctaPulse{
  0%,100%{box-shadow:0 0 20px rgba(255,45,251,.45),0 0 40px rgba(122,95,255,.3)}
  50%{box-shadow:0 0 30px rgba(255,45,251,.65),0 0 54px rgba(122,95,255,.5)}
}
.pp-cta-pulse{animation:ctaPulse 3s ease-in-out infinite}

.hero-cta,
.pp-video-cta__actions,
.ready__cta,
.why__cta,
.pp-compare__cta{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.hero-cta{justify-content:flex-start}
@media(max-width:640px){
  .hero-cta{flex-direction:column;align-items:stretch;gap:10px}
  .hero-cta .pp-cta-primary,.hero-cta .btn-primary{width:100%;text-align:center}
}

/* === 7. ICON HUB === */
.icon-hub{padding:var(--s-2xl) 0 0}
.icon-hub h2{text-align:center;margin-bottom:var(--s-sm)}
.icon-hub__lead{text-align:center;color:var(--ink-3);margin-bottom:var(--s-xl);font-size:1.02rem}
.icon-hub__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:820px){.icon-hub__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.icon-hub__grid{grid-template-columns:1fr}}
.icon-hub__card{display:flex;flex-direction:column;text-decoration:none;padding:0;border-radius:18px;overflow:hidden;background:var(--card-bg);border:1px solid var(--card-bd);box-shadow:0 0 28px var(--card-glow);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.icon-hub__card:hover{transform:translateY(-6px);box-shadow:0 0 40px rgba(255,0,255,.16);border-color:rgba(247,37,133,.32)}
.icon-hub__card img{width:100%;aspect-ratio:3/4;object-fit:cover;background:#0b0b12;display:block}
.icon-hub__card-body{padding:18px 20px}
.icon-hub__card-title{display:flex;align-items:center;justify-content:space-between;color:#fff;font-weight:800;font-size:1.05rem;margin-bottom:6px}
.icon-hub__card-title::after{content:"\2192";color:var(--neon);font-size:1.2rem;flex-shrink:0}
.icon-hub__card-desc{color:var(--ink-3);font-size:.92rem;line-height:1.45;margin:0}

/* === 8. TOC === */
.pp-toc{margin:var(--s-xl) auto var(--s-2xl);max-width:var(--wrap);padding:22px var(--gutter);border-radius:var(--r);border:1px solid rgba(247,37,133,.12);background:linear-gradient(135deg,rgba(247,37,133,.04),rgba(138,46,255,.02) 60%,transparent);box-shadow:0 10px 24px rgba(0,0,0,.3)}
.pp-toc__title{margin:0 0 14px;font-weight:900;font-size:clamp(18px,1.8vw,24px)}
.pp-toc__list{list-style:none;margin:0;padding:0;display:grid;gap:10px;grid-template-columns:1fr;counter-reset:toc}
@media(min-width:768px){.pp-toc__list{grid-template-columns:1fr 1fr}}
.pp-toc__list li{counter-increment:toc}
.pp-toc__list a{display:grid;grid-template-columns:34px 1fr;align-items:center;gap:10px;text-decoration:none;padding:11px 14px;border-radius:12px;color:var(--ink-2);background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);transition:transform .14s var(--ease),box-shadow .14s,border-color .14s}
.pp-toc__list a:hover{transform:translateY(-1px);color:#fff;border-color:rgba(247,37,133,.22);box-shadow:0 6px 16px rgba(0,0,0,.35),0 0 10px rgba(247,37,133,.12)}
.pp-toc__list a::before{content:counter(toc);display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;font-weight:900;font-size:.82rem;color:#fff;background:linear-gradient(135deg,var(--neon),var(--neon-2));box-shadow:0 0 10px rgba(247,37,133,.35)}

/* === 9. INTRO === */
.intro .intro__row{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(28px,4vw,40px);align-items:start}
.intro .intro__text p{color:var(--ink-2)}
@media(max-width:820px){.intro .intro__row{grid-template-columns:1fr}}

/* === 10. CARD (mini-gallery) === */
.card{margin:0;border-radius:18px;overflow:hidden;background:#0b0b12;border:1px solid var(--card-bd);box-shadow:0 0 28px var(--card-glow);transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;position:relative}
.card:hover{transform:translateY(-5px);border-color:rgba(247,37,133,.28);box-shadow:0 0 40px rgba(255,0,255,.15)}
.gallery-row .card img,
.gallery-row .card video{display:block;width:100%;aspect-ratio:4/5;object-fit:cover;background:#0b0b12}
.gallery-row.images .card{cursor:zoom-in}
.gallery-row.videos .card video{background:#000}
.card figcaption{padding:12px 14px;font-size:.9rem;line-height:1.4;color:#e7eaff;background:rgba(255,255,255,.04);border-top:1px solid rgba(255,255,255,.06);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card figcaption strong{color:#fff;font-weight:800;margin-right:.3em}

/* === 11. GALLERY-ROW === */
.gallery-row{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:1100px){.gallery-row{grid-template-columns:repeat(3,1fr)}}
@media(max-width:820px){.gallery-row{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.gallery-row.images,.gallery-row.videos{grid-template-columns:1fr}}

/* === 12. HOW-STEPS === */
.how-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin:var(--s-xl) 0}
@media(max-width:980px){.how-steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.how-steps{grid-template-columns:1fr}}
.how-card{position:relative;display:flex;flex-direction:column;gap:10px;background:var(--card-bg);border:1px solid var(--card-bd);border-radius:var(--r);padding:30px 22px 24px;box-shadow:0 0 28px var(--card-glow);transition:transform .3s var(--ease),box-shadow .3s}
.how-card:hover{transform:translateY(-5px);box-shadow:0 0 40px rgba(255,0,255,.15)}
.how-card .n{position:absolute;top:-14px;left:-14px;width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#FF5ACD,var(--neon) 55%,var(--neon-2));box-shadow:0 0 12px rgba(247,37,133,.5);color:#fff;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;z-index:2}
.how-card h3{margin:6px 0;font-size:16px;font-weight:700}
.how-card p{margin:0;font-size:14.5px;line-height:1.55;color:var(--ink-2)}

/* === 13. FEATURES === */
.features__grid{display:grid;gap:20px;grid-template-columns:repeat(3,1fr)}
@media(max-width:980px){.features__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.features__grid{grid-template-columns:1fr}}
.feature{padding:24px;border-radius:var(--r);background:var(--card-bg);border:1px solid var(--card-bd);box-shadow:0 0 28px var(--card-glow);transition:transform .3s var(--ease),box-shadow .3s,border-color .3s}
.feature:hover{transform:translateY(-5px);border-color:rgba(247,37,133,.28);box-shadow:0 0 40px rgba(255,0,255,.15)}
.feature h3{margin:0 0 10px;font-size:clamp(15px,1.4vw,17px);display:flex;align-items:center;gap:10px}
.feature h3 .icon{width:24px;height:24px;flex:0 0 auto;border-radius:6px;display:flex;align-items:center;justify-content:center;background:var(--grad);box-shadow:0 0 8px rgba(255,45,251,.4);font-size:13px;color:#fff}
.feature p{margin:0;color:var(--ink-2);font-size:14px;line-height:1.55}

/* === 14. RELATED === */
.related-grid{display:grid;gap:20px;grid-template-columns:repeat(2,1fr)}
@media(max-width:680px){.related-grid{grid-template-columns:1fr}}
.related-card{display:block;padding:26px 24px;border-radius:var(--r);background:var(--card-bg-flat);border:1px solid var(--card-bd);box-shadow:0 0 28px var(--card-glow);text-decoration:none;transition:transform .3s var(--ease),box-shadow .3s}
.related-card:hover{transform:translateY(-5px);box-shadow:0 0 40px rgba(255,0,255,.15)}
.related-card .h3{display:block;margin:0 0 8px;color:#fff;font-weight:800;font-size:1.12rem}
.related-card .p{display:block;margin:0;color:#d1d5ff;line-height:1.55}

/* === 15. WHY CHOOSE === */
.why .why__row{display:flex;align-items:center;gap:clamp(32px,5vw,64px)}
.why .why__text{flex:1.2}
.why .why__media{flex:.8;display:flex;justify-content:center}
.why .why__thumb{margin:0;border-radius:var(--r);overflow:hidden;box-shadow:0 0 0 1px rgba(247,37,133,.18),0 16px 36px rgba(0,0,0,.45),0 0 32px rgba(247,37,133,.18)}
.why .why__thumb img{display:block;width:100%;border-radius:var(--r)}
.why .lead{color:var(--ink-2);margin-bottom:var(--s-lg);line-height:1.55;font-size:1.04rem}
.why__cta{margin-top:var(--s-xl)}
.why__cta a{background:var(--grad);color:#fff;padding:13px 28px;border-radius:var(--r-pill);font-weight:700;text-decoration:none;display:inline-flex;box-shadow:0 0 20px rgba(255,45,251,.45),0 0 36px rgba(122,95,255,.35);transition:all var(--dur) var(--ease)}
.why__cta a:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 0 30px rgba(255,45,251,.8),0 0 48px rgba(122,95,255,.65)}
@media(max-width:900px){
  .why .why__row{flex-direction:column}
  .why .why__media{order:-1}
}

/* === 15b. BEFORE / AFTER COMPARE (enhanced — replaces old dead selectors) === */
.pp-compare__row{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;margin-top:var(--s-xl);align-items:stretch}
@media(max-width:640px){.pp-compare__row{grid-template-columns:1fr;gap:20px}}
.pp-compare__card{display:flex;flex-direction:column;border-radius:18px;overflow:hidden;background:#0b0b12;border:1px solid var(--card-bd);box-shadow:0 0 28px var(--card-glow);transition:transform .3s,box-shadow .3s}
.pp-compare__card:hover{transform:translateY(-4px)}
.pp-compare__card--before{border-color:rgba(255,255,255,.08)}
.pp-compare__card--before .pp-compare__img-wrap{position:relative}
.pp-compare__card--before .pp-compare__img-wrap::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.12);pointer-events:none}
.pp-compare__card--before img{filter:blur(0.8px) saturate(.6) contrast(.85)}
.pp-compare__card--after{border:2px solid rgba(247,37,133,.35);box-shadow:0 0 40px rgba(247,37,133,.18),0 0 80px rgba(122,95,255,.1)}
.pp-compare__img-wrap{overflow:hidden}
.pp-compare__card img{width:100%;aspect-ratio:4/5;object-fit:cover;display:block}
.pp-compare__label{padding:20px;flex:1;display:flex;flex-direction:column;gap:10px}
.pp-compare__badge{display:inline-block;padding:6px 16px;border-radius:999px;font-weight:800;font-size:.82rem;letter-spacing:.4px;text-transform:uppercase;width:fit-content}
.pp-compare__badge--free{background:rgba(255,255,255,.08);color:rgba(255,255,255,.5)}
.pp-compare__badge--pornpen{background:linear-gradient(90deg,#ff2dfb,#7a5fff);color:#fff;box-shadow:0 0 14px rgba(255,45,251,.4)}
.pp-compare__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px;font-size:.9rem;color:var(--ink-2)}
.pp-compare__card--before .pp-compare__list li::before{content:"✗ ";color:rgba(255,80,80,.7);font-weight:700}
.pp-compare__card--after .pp-compare__list li::before{content:"✓ ";color:#2dfff2;font-weight:700}
.pp-compare__cta{text-align:center;margin-top:32px}
.pp-compare__micro{color:var(--ink-3);font-size:.88rem;margin-top:10px}

/* === 16. PP-GALLERY (main gallery) === */
.pp-gallery{display:grid;gap:20px;grid-template-columns:repeat(4,1fr)}
@media(max-width:1100px){.pp-gallery{grid-template-columns:repeat(3,1fr)}}
@media(max-width:820px){.pp-gallery{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.pp-gallery{grid-template-columns:1fr}}

.pp-gallery-hint{text-align:center;color:var(--ink-3);font-size:.92rem;margin-bottom:var(--s-lg);opacity:.8}

.pp-card{
  position:relative;
  margin:0;
  border-radius:18px;
  overflow:hidden;
  background:#0b0c12;
  border:1px solid rgba(255,255,255,.06);
  box-shadow:0 0 28px var(--card-glow);
  cursor:zoom-in;
  display:flex;
  flex-direction:column;
  transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease;
}
.pp-card::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:linear-gradient(120deg,rgba(247,37,133,.15),rgba(122,95,255,.12),rgba(45,255,242,.10));
  opacity:0;
  transition:opacity .35s ease;
  pointer-events:none;
}
.pp-card:hover{
  transform:translateY(-6px) scale(1.02);
  box-shadow:0 18px 40px rgba(0,0,0,.6),0 0 25px rgba(247,37,133,.35);
  border-color:rgba(247,37,133,.45);
}
.pp-card:hover::before{opacity:1}

.pp-card img{
  display:block;
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
  background:#0b0b12;
  transition:transform .6s cubic-bezier(.2,.6,.2,1),filter .6s ease;
}
.pp-card:hover img{
  transform:scale(1.05);
  filter:contrast(1.05) saturate(1.05);
}

.pp-card figcaption{
  position:absolute;
  left:0;right:0;bottom:0;
  z-index:2;
  padding:14px 16px;
  font-size:.9rem;
  line-height:1.3;
  color:#e7eaff;
  background:linear-gradient(to top,rgba(0,0,0,.85),rgba(0,0,0,.45),transparent);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  transform:translateY(100%);
  transition:transform .35s ease;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.pp-card:hover figcaption{transform:translateY(0)}
.pp-card figcaption strong{color:#fff;font-weight:800;margin-right:.3em}

/* Inline CTA card */
.pp-card--cta{
  cursor:default;
  background:linear-gradient(145deg,rgba(247,37,133,.12),rgba(138,46,255,.1),rgba(10,11,16,.95));
  border:2px solid rgba(247,37,133,.3);
  box-shadow:0 0 32px rgba(247,37,133,.15);
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:300px;
}
.pp-card--cta::before{display:none}
.pp-card--cta:hover{transform:none;box-shadow:0 0 40px rgba(247,37,133,.25)}
.pp-card--cta__inner{text-align:center;padding:28px 20px}
.pp-card--cta__icon{display:block;font-size:2.4rem;margin-bottom:var(--s-sm)}
.pp-card--cta__inner strong{display:block;font-size:1.15rem;color:#fff;margin-bottom:var(--s-xs)}
.pp-card--cta__inner p{color:var(--ink-2);font-size:.92rem;margin-bottom:var(--s-md)}

/* === 17. LIGHTBOX === */
.pp-lightbox{position:fixed;inset:0;display:none;background:rgba(0,0,0,.92);z-index:99999}
.pp-lightbox.active{display:flex;align-items:center;justify-content:center;animation:fadeBg .25s ease}
body.lb-open{overflow:hidden}

@keyframes fadeBg{from{background:rgba(0,0,0,0)}to{background:rgba(0,0,0,.92)}}

.pp-lightbox-content{
  position:relative;
  width:94vw;max-width:1060px;max-height:92vh;
  background:#0b0c14;
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;
  box-shadow:0 16px 48px rgba(0,0,0,.7),0 0 40px rgba(247,37,133,.12);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  align-items:center;
  animation:popIn .25s ease;
}
@keyframes popIn{
  from{transform:scale(.96);opacity:0}
  to{transform:scale(1);opacity:1}
}

.pp-big{display:block;width:100%;max-height:75vh;flex:1 1 auto;min-height:0;object-fit:contain;background:#000}
.pp-close,.pp-prev,.pp-next{position:absolute;appearance:none;border:0;border-radius:10px;background:rgba(0,0,0,.6);color:#fff;padding:8px 12px;font-weight:900;box-shadow:0 2px 10px rgba(0,0,0,.4);cursor:pointer;z-index:2;transition:background .16s}
.pp-close{top:10px;right:10px;font-size:18px}
.pp-prev{left:10px;top:50%;transform:translateY(-50%);font-size:26px}
.pp-next{right:10px;top:50%;transform:translateY(-50%);font-size:26px}
.pp-close:hover,.pp-prev:hover,.pp-next:hover{background:rgba(255,255,255,.16)}

.pp-lightbox-caption{width:100%;padding:14px 16px;border-top:1px solid rgba(255,255,255,.07);background:rgba(255,255,255,.04);color:#e7eaff;flex-shrink:0;text-align:center}
.pp-lightbox-caption .pp-alt{display:none}
.pp-lightbox-caption .pp-pr{margin-bottom:8px;font-size:.95rem;line-height:1.45}
.pp-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.pp-copy{display:inline-flex;align-items:center;justify-content:center;border-radius:10px;padding:10px 18px;font-weight:800;font-size:.93rem;text-decoration:none;transition:transform var(--dur) var(--ease),box-shadow var(--dur);border:0;color:#fff;background:linear-gradient(90deg,#7a5fff,#ff2dfb);box-shadow:0 0 18px rgba(247,37,133,.45);cursor:pointer}
.pp-copy:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 0 26px rgba(247,37,133,.7)}

/* FIX: merged complete .pp-generate styles (was incomplete in original section 17) */
.pp-generate{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;border-radius:999px;background:linear-gradient(90deg,#ff2dfb,#7a5fff);color:#fff;font-weight:800;font-size:.92rem;text-decoration:none;box-shadow:0 0 18px rgba(255,45,251,.5);transition:transform .2s,box-shadow .2s}
.pp-generate:hover{transform:scale(1.05);box-shadow:0 0 28px rgba(255,45,251,.7)}

@media(max-width:640px){
  .pp-lightbox-content{width:100vw;max-width:100vw;max-height:100vh;border-radius:0}
  .pp-big{max-height:60vh}
  .pp-actions{flex-direction:column}
  .pp-copy,.pp-generate{width:100%;text-align:center}
}

/* === 18. NEON-BOX === */
.neon-box{border:2px solid var(--neon);border-radius:var(--r-lg);padding:48px 28px;background:rgba(10,11,16,.85);box-shadow:0 0 24px rgba(247,37,133,.35),0 0 48px rgba(138,46,255,.24);position:relative;overflow:hidden;isolation:isolate;max-width:900px;margin-left:auto;margin-right:auto}
.neon-box::before{content:"";position:absolute;inset:-2px;border-radius:inherit;padding:2px;background:linear-gradient(90deg,#ff2dfb,#7a5fff,#2dfff2,#ff2dfb);background-size:400% 400%;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;animation:neonBorder 6s linear infinite;pointer-events:none}
@keyframes neonBorder{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.neon-box .wrap,.neon-box a{position:relative;z-index:1}
.ready__cta .neon-cta{background:linear-gradient(90deg,#ff2dfb,#7a5fff,#2dfff2);background-size:300% 300%;color:#fff;font-weight:800;font-size:19px;padding:16px 40px;border-radius:var(--r-pill);text-transform:uppercase;letter-spacing:.5px;text-shadow:0 0 10px rgba(255,255,255,.8);text-decoration:none;display:inline-flex;box-shadow:0 0 22px rgba(255,45,251,.7),0 0 44px rgba(122,95,255,.5),0 0 66px rgba(45,255,242,.4);animation:neonShift 5s ease infinite;transition:transform var(--dur),box-shadow var(--dur)}
.ready__cta .neon-cta:hover{transform:scale(1.06) translateY(-2px);box-shadow:0 0 32px rgba(255,45,251,1),0 0 64px rgba(122,95,255,.85),0 0 88px rgba(45,255,242,.8)}
@keyframes neonShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

/* === 19. FAQ === */
.faq-section{margin-top:80px}
.faq-pp{background:linear-gradient(145deg,#0e1018,#0a0b10);border-radius:var(--r);padding:36px 32px;border:2px solid rgba(247,37,133,.22);box-shadow:0 0 28px rgba(247,37,133,.14),0 12px 28px rgba(0,0,0,.35);max-width:900px;margin-left:auto;margin-right:auto;margin-top:80px}
@media(max-width:640px){.faq-section{margin-top:80px}.faq-pp{padding:24px 18px}}
.faq-pp__title{font-weight:900;font-size:clamp(22px,2.6vw,34px);margin:0 0 12px}
.faq-pp__intro{color:var(--ink-2);line-height:1.6;margin:0 0 24px}
.faq-pp__sub{margin:28px 6px 12px;padding:0 6px 12px;color:#ffe3ff;font-weight:800;font-size:clamp(18px,1.9vw,22px);position:relative}
.faq-pp__sub::before{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;border-radius:999px;background:var(--grad);box-shadow:0 0 12px rgba(247,37,133,.35)}
.faq-pp__sub + .faq-pp__item{border-top:0}
.faq-pp__item{border-top:1px solid rgba(255,255,255,.06)}
.faq-pp__item:first-of-type{border-top:0}
.faq-pp__item summary{list-style:none;display:flex;align-items:center;gap:10px;padding:18px 6px;cursor:pointer;font-size:clamp(15px,1.5vw,19px);font-weight:700;color:#ffe3ff;transition:color var(--dur)}
.faq-pp__item summary::-webkit-details-marker{display:none}
.faq-pp__item summary::before{content:"";width:9px;height:9px;flex-shrink:0;border:2px solid var(--neon);border-left:0;border-top:0;transform:rotate(-45deg);transition:transform .2s var(--ease);filter:drop-shadow(0 0 5px var(--neon))}
.faq-pp__item[open] summary{color:#fff}
.faq-pp__item[open] summary::before{transform:rotate(45deg)}
.faq-pp__a{padding:6px 6px 20px}
.faq-pp__a p{margin:.6rem 0;color:#e5e8ff;line-height:1.7;font-size:1rem}
.faq-pp__a strong{color:#fff}
.faq-pp__a a{color:#8ec5ff;text-decoration:underline}

/* FIX: FAQ micro CTA (was only in duplicate block) */
.faq-pp__try{margin:8px 0 4px 6px}
.faq-pp__try a{color:var(--neon);font-weight:700;font-size:.88rem;text-decoration:none;transition:color .2s}
.faq-pp__try a:hover{color:#fff;text-shadow:0 0 8px var(--neon)}

/* === 20. VIDEO CTA === */
.pp-video-cta{padding:var(--s-2xl) 0}
.pp-video-cta__wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--gutter)}
.pp-video-cta__box{position:relative;border-radius:var(--r);padding:32px 28px;background:var(--card-bg-flat);border:2px solid rgba(247,37,133,.25);box-shadow:0 0 32px rgba(247,37,133,.18),0 14px 32px rgba(0,0,0,.4);overflow:hidden}
.pp-video-cta__box::before{content:"";position:absolute;inset:-2px;background:radial-gradient(120% 120% at 0% 0%,rgba(255,90,205,.08),rgba(247,37,133,.05) 45%,rgba(138,46,255,.04));filter:blur(18px);pointer-events:none;z-index:0}
.pp-video-cta__head{position:relative;z-index:1}
.pp-video-cta__head h2{margin:0 0 12px;font-size:clamp(22px,2.6vw,32px);text-shadow:0 0 12px rgba(247,37,133,.3)}
.pp-video-cta__head .lead{margin:0 0 18px}
.pp-video-cta__bullets{position:relative;z-index:1;list-style:none;margin:0 0 22px;padding:0;display:grid;gap:12px;grid-template-columns:repeat(3,1fr)}
.pp-video-cta__bullets li{position:relative;padding-left:20px;color:#e7eaff;line-height:1.55}
.pp-video-cta__bullets li::before{content:"";position:absolute;left:0;top:.65em;width:8px;height:8px;border-radius:50%;background:var(--neon);box-shadow:0 0 10px var(--neon)}
@media(max-width:900px){.pp-video-cta__bullets{grid-template-columns:1fr}}
.pp-video-cta__actions{position:relative;z-index:1}

/* === 21. FINAL CTA === */
.final-cta__box{border-radius:var(--r-lg);background:var(--card-bg-flat);border:2px solid rgba(247,37,133,.25);box-shadow:0 0 32px rgba(247,37,133,.18),0 14px 32px rgba(0,0,0,.45);text-align:center;padding:44px 28px 32px}
.final-cta__box h2{margin:0 0 12px;font-size:clamp(22px,2.6vw,32px);text-shadow:0 0 12px rgba(247,37,133,.3)}
.final-cta__box p{margin:0 0 20px;color:var(--ink-2);line-height:1.6}
.final-cta__btns{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin:10px 0 14px}
.final-cta__links{margin-top:12px;font-size:.95rem;color:var(--ink-2);display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.final-cta__links a{color:#8ec5ff;text-decoration:underline}
/* FIX: was only in duplicate block */
.final-cta__micro{color:var(--ink-3);font-size:.88rem;margin-top:10px;text-align:center}

/* Urgency trigger */
.pp-urgency{display:inline-block;margin-top:var(--s-sm);padding:6px 18px;border-radius:var(--r-pill);background:rgba(255,180,0,.12);border:1px solid rgba(255,180,0,.25);color:#ffc940;font-weight:700;font-size:.88rem;letter-spacing:.2px;animation:urgencyPulse 2.5s ease-in-out infinite}
@keyframes urgencyPulse{
  0%,100%{opacity:.85}
  50%{opacity:1;box-shadow:0 0 12px rgba(255,180,0,.3)}
}

/* === 22. TABLE === */
.table-resp{overflow:auto;-webkit-overflow-scrolling:touch}
.table-resp table{width:100%;min-width:720px;border-collapse:separate;border-spacing:0;border-radius:var(--r);overflow:hidden}
.table-resp th,.table-resp td{padding:14px 16px;text-align:left;vertical-align:top}
.table-resp thead th{color:#fff;font-weight:800;border-bottom:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03)}
.table-resp tbody td{color:#e7eaff}
.table-resp tbody tr:nth-child(odd){background:rgba(255,255,255,.02)}
.table-resp tbody tr:nth-child(even){background:rgba(255,255,255,.04)}

/* === 23. PPV PAGES (shared) === */
.ppv-step{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:center;margin:var(--s-xl) 0}
@media(max-width:820px){.ppv-step{grid-template-columns:1fr}}
.ppv-step-illustration{margin:0;border-radius:var(--r);overflow:hidden;box-shadow:0 0 28px var(--card-glow)}
.ppv-step-illustration img{width:100%;display:block;border-radius:var(--r)}
.ppv-scope .ppv-section{padding:56px 0}
.ppv-scope .ppv-wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--gutter)}
.ppv-scope .ppv-muted{color:var(--ink-2);margin:0 0 28px;line-height:1.6}
.ppv-scope .ppv-gallery-grid{display:grid;gap:20px;grid-template-columns:repeat(3,1fr)}
@media(max-width:1100px){.ppv-scope .ppv-gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.ppv-scope .ppv-gallery-grid{grid-template-columns:1fr}}
.ppv-card{margin:0;border-radius:var(--r);overflow:hidden;background:var(--card-bg-flat);border:1px solid var(--card-bd);box-shadow:0 0 28px var(--card-glow);transition:transform .3s var(--ease),box-shadow .3s}
.ppv-card:hover{transform:translateY(-5px);box-shadow:0 0 40px rgba(255,0,255,.15)}
.ppv-card img{display:block;width:100%;object-fit:cover}
.ppv-card figcaption{padding:14px 16px;font-size:.95rem;color:#e7eaff;background:rgba(255,255,255,.04);border-top:1px solid rgba(255,255,255,.06)}
.ppv-neonbox{max-width:980px;margin:40px auto;text-align:center;border-radius:var(--r-lg);padding:36px 28px;background:var(--card-bg-flat);border:2px solid rgba(247,37,133,.25);box-shadow:0 0 36px rgba(247,37,133,.18),0 14px 36px rgba(0,0,0,.45)}
.ppv-cta-title{margin:0 0 12px;color:#fff;font-weight:900;font-size:clamp(22px,2.6vw,34px);text-shadow:0 0 12px rgba(247,37,133,.3)}
.ppv-cta-sub{margin:0 0 18px;color:var(--ink-2);line-height:1.6}
.ppv-btnrow{display:flex;justify-content:center;flex-wrap:wrap;gap:14px;margin-top:18px}
.ppv-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin:10px 0 20px}
.ppv-chip{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--r-pill);background:rgba(255,255,255,.05);color:#e7eaff;font-weight:700;font-size:.93rem}
.ppv-chip::before{content:"";width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--neon);box-shadow:0 0 10px var(--neon)}

/* === 24. FOOTER === */
.pp-footer{padding:36px 0;border-top:1px solid rgba(255,255,255,.05);text-align:center;color:var(--ink-3);font-size:.88rem}
.pp-footer a{color:#caa8ff;text-decoration:none;transition:color var(--dur)}
.pp-footer a:hover{color:#fff;text-shadow:0 0 8px rgba(200,150,255,.4)}

/* === 25. RU BADGE === */
.pp-lang-note{margin-top:10px;font-size:15px;color:rgba(255,255,255,.7);animation:fadeIn 1.2s ease both}
.pp-lang-note a{color:#ff6bfa;font-weight:600;text-decoration:none;transition:color var(--dur)}
.pp-lang-note a:hover{color:#fff;text-shadow:0 0 8px rgba(255,107,250,.6)}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

/* === 26. STICKY MOBILE CTA === */
.pp-sticky-cta{
  position:fixed;
  bottom:0;left:0;right:0;
  z-index:9998;
  padding:10px 16px;
  padding-bottom:calc(10px + env(safe-area-inset-bottom,0px));
  background:rgba(10,11,16,.94);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-top:1px solid rgba(247,37,133,.2);
  box-shadow:0 -4px 20px rgba(0,0,0,.5);
  transform:translateY(100%);
  transition:transform .35s var(--ease);
  display:none;
}
.pp-sticky-cta.visible{transform:translateY(0)}
.pp-sticky-cta__btn{
  display:block;
  width:100%;
  text-align:center;
  padding:14px 24px;
  border-radius:var(--r-pill);
  background:var(--grad);
  color:#fff;
  font-weight:800;
  font-size:1rem;
  text-decoration:none;
  box-shadow:0 0 20px rgba(255,45,251,.5),0 0 40px rgba(122,95,255,.35);
  animation:ctaPulse 3s ease-in-out infinite;
}
/* FIX: was only in duplicate block */
.pp-sticky-cta__sub{display:block;text-align:center;color:var(--ink-3);font-size:.72rem;font-weight:600;margin-top:4px;letter-spacing:.3px}

@media(max-width:768px){
  .pp-sticky-cta{display:block}
  .pp-footer{padding-bottom:80px}
}
@media(min-width:769px){
  .pp-sticky-cta{display:none!important}
}

/* === 27. A11Y === */
:focus-visible{outline:2px solid var(--neon);outline-offset:2px}

/* === 28. NAV OVERLAY === */
.pp-nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);z-index:9998;opacity:0;pointer-events:none;transition:opacity .25s ease}
.pp-nav-overlay.active{opacity:1;pointer-events:auto}
body.pp-nav-open{overflow:hidden}
body.pp-nav-open .pp-header__nav{transform:translateX(0)}

/* === 29. PIPELINE === */
.pp-pipeline__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:var(--s-xl)}
@media(max-width:1024px){.pp-pipeline__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.pp-pipeline__grid{grid-template-columns:1fr}}
.pp-pipeline__card{position:relative;border-radius:18px;background:#0b0b12;border:1px solid var(--card-bd);box-shadow:0 0 28px var(--card-glow);transition:transform .3s var(--ease),box-shadow .3s,border-color .3s}
.pp-pipeline__card:hover{transform:translateY(-6px);box-shadow:0 0 40px rgba(255,0,255,.16);border-color:rgba(247,37,133,.32)}
.pp-pipeline__badge{position:absolute;top:12px;left:12px;z-index:3;padding:5px 14px;border-radius:var(--r-pill);font-weight:800;font-size:.78rem;letter-spacing:.4px;text-transform:uppercase;color:#fff;background:var(--grad);box-shadow:0 0 12px rgba(255,45,251,.5)}
.pp-pipeline__badge--refined{background:linear-gradient(90deg,#7a5fff,#2dfff2)}
.pp-pipeline__badge--video{background:linear-gradient(90deg,#ff2dfb,#ff6b6b)}
.pp-pipeline__badge--chat{background:linear-gradient(90deg,#7a5fff,#ff2dfb)}
.pp-pipeline__media{position:relative;aspect-ratio:4/5;overflow:hidden;background:#0b0b12;border-radius:18px 18px 0 0}
/* FIX: split object-fit — cover for images, contain for video */
.pp-pipeline__media img{width:100%;height:100%;object-fit:cover;display:block}
.pp-pipeline__media video{width:100%;height:100%;object-fit:contain;display:block}
.pp-pipeline__overlay{position:absolute;bottom:0;left:0;right:0;padding:10px 14px;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);color:var(--ink-2);font-size:.85rem;font-style:italic;z-index:2}
.pp-pipeline__play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:50%;border:0;background:rgba(255,45,251,.7);color:#fff;font-size:24px;cursor:pointer;z-index:3;box-shadow:0 0 24px rgba(255,45,251,.6);transition:transform .2s,background .2s}
.pp-pipeline__play:hover{transform:translate(-50%,-50%) scale(1.1);background:rgba(255,45,251,.9)}
.pp-pipeline__chat-bubbles{position:absolute;bottom:16px;left:12px;right:12px;z-index:2;display:flex;flex-direction:column;gap:8px}
.pp-pipeline__bubble{padding:10px 14px;border-radius:16px;font-size:.85rem;line-height:1.4;max-width:85%}
.pp-pipeline__bubble--user{background:rgba(122,95,255,.25);color:#e0d4ff;align-self:flex-end;border-bottom-right-radius:4px}
.pp-pipeline__bubble--ai{background:rgba(255,45,251,.2);color:#ffd4f8;align-self:flex-start;border-bottom-left-radius:4px}
.pp-pipeline__card figcaption{border-radius:0 0 18px 18px;padding:14px 16px;font-size:.88rem;color:var(--ink-2);line-height:1.4;border-top:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.03)}

/* FIX: pipeline arrows — was only in duplicate block */
@media(min-width:1025px){
  .pp-pipeline__grid{column-gap:48px}
  .pp-pipeline__card:not(:last-child)::after{content:"\2192";position:absolute;top:40%;right:-36px;font-size:1.8rem;color:rgba(255,45,251,.6);font-weight:900;z-index:10;text-shadow:0 0 16px rgba(255,45,251,.4);pointer-events:none}
}

/* === 30. MINI HOW (enhanced version) === */
.pp-mini-how__steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:var(--s-lg)}
.pp-mini-how__step{display:flex;align-items:center;gap:14px;padding:18px 28px;border-radius:18px;background:linear-gradient(145deg,rgba(20,18,40,.8),rgba(14,16,24,.9));border:1px solid rgba(247,37,133,.18);box-shadow:0 0 20px rgba(247,37,133,.08),0 8px 24px rgba(0,0,0,.3);font-weight:700;font-size:1.05rem;color:#fff;transition:transform .25s,box-shadow .25s}
.pp-mini-how__step:hover{transform:translateY(-3px);box-shadow:0 0 30px rgba(247,37,133,.15),0 12px 32px rgba(0,0,0,.4)}
.pp-mini-how__n{width:32px;height:32px;border-radius:50%;background:linear-gradient(90deg,#ff2dfb,#7a5fff);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:.85rem;flex-shrink:0;box-shadow:0 0 10px rgba(247,37,133,.4)}
@media(max-width:820px){.pp-mini-how__steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.pp-mini-how__steps{grid-template-columns:1fr}}


/* === 31. AI PORN GENERATOR CATEGORIES === */
.pp-categories__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:var(--s-xl)}
@media(max-width:1100px){.pp-categories__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.pp-categories__grid{grid-template-columns:1fr}}
.pp-category-card{position:relative;border-radius:12px;overflow:hidden;background:#0b0b12;border:1px solid var(--card-bd);box-shadow:0 0 28px var(--card-glow);transition:box-shadow .35s ease}
.pp-category-card:hover{box-shadow:0 0 20px rgba(255,0,120,.25)}
.pp-category-card img{display:block;width:100%;aspect-ratio:4/5;object-fit:cover;transition:transform .5s ease}
.pp-category-card:hover img{transform:scale(1.05)}
.pp-category-overlay{position:absolute;left:0;right:0;bottom:0;padding:20px;background:linear-gradient(to top,rgba(0,0,0,.85),rgba(0,0,0,.55),rgba(0,0,0,0))}
.pp-category-title{color:#fff;font-weight:800;font-size:1.05rem;transform:translateY(4px);transition:transform .3s ease}
.pp-category-card:hover .pp-category-title{transform:translateY(0)}

/* Prompt text style */
.pp-prompt-text{font-family:'Courier New',Courier,monospace;background:rgba(45,255,242,.08);border:1px solid rgba(45,255,242,.15);padding:2px 8px;border-radius:6px;color:#2dfff2;font-size:.9em;white-space:nowrap}

/* Comparison table neon */
.pp-table-neon table{border:1px solid rgba(247,37,133,.2);border-radius:16px;overflow:hidden}
.pp-table-neon thead th{background:rgba(255,255,255,.04);border-bottom:2px solid rgba(247,37,133,.15)}
.pp-table-neon thead th:nth-child(2){background:linear-gradient(135deg,rgba(247,37,133,.15),rgba(138,46,255,.1));color:#fff;font-size:1.05em;text-shadow:0 0 8px rgba(247,37,133,.3)}
.pp-table-neon tbody tr{transition:background .2s}
.pp-table-neon tbody tr:hover{background:rgba(255,255,255,.04)}
.pp-table-neon td:nth-child(2){border-left:2px solid rgba(247,37,133,.2);border-right:2px solid rgba(247,37,133,.2);background:rgba(247,37,133,.03)}
.pp-table-neon .t-good::before{content:"✓ ";color:#2dfff2;font-weight:800}
.pp-table-neon .t-bad::before{content:"✗ ";color:#ff4d4d;font-weight:800}
.pp-table-neon .t-mid::before{content:"⚠ ";color:#ffc940;font-weight:800}