/* =====================================================
   ULTRASTORE — MAIN STYLESHEET
   Theme: Dark Glassmorphism E-Commerce
   Converted from React (Tailwind/Inline → Vanilla CSS)
   ===================================================== */

/* ── TOKENS ─────────────────────────────────────────── */
:root {
  --primary:   #00ffaa; /* Vibrant Emerald/Cyan */
  --secondary: #ff0055; /* Hot Pink/Red */
  --accent:    #0088ff; /* Royal Blue */
  --bg:        #050508;
  --surface:   rgba(255,255,255,.05);
  --text:      #ffffff;
  --text-dim:  #d0d0d0;
  --muted:     #a0a0a0;
  --font:      'Outfit', sans-serif;
  --radius:    24px;
  --glass-bg:  rgba(255,255,255,.05);
  --glass-bd:  rgba(255,255,255,.15);
}

/* ── RESET ───────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth; overflow-x:hidden; width:100%; max-width:100%;}
body{
  background-color:var(--bg);
  background-image:
    radial-gradient(circle at 10% 20%,rgba(112,0,255,.2) 0%,transparent 50%),
    radial-gradient(circle at 90% 80%,rgba(0,242,255,.2) 0%,transparent 50%);
  color:var(--text);
  font-family:var(--font);
  overflow-x:hidden; width:100%; max-width:100%;
  -webkit-font-smoothing:antialiased;
  opacity:1;transition:opacity .3s ease;
  min-height:100vh;display:flex;flex-direction:column
}
/* Ensure main content expands to push footer down */
.pp-main, .pp-hero{flex:1}
/* Safe page load — no blank screen risk */
body.pp-loaded{opacity:1}
a{color:inherit;text-decoration:none;transition:color .3s}
img{max-width:100%;height:auto;display:block}
button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit}
ul{list-style:none}
input,textarea,select{font-family:inherit;color:inherit}
h1,h2,h3{font-weight:800;letter-spacing:-.02em}

/* ── SCROLLBAR ──────────────────────────────────────── */
::-webkit-scrollbar{width:8px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--secondary);border-radius:10px}

/* ── GLASS CARD (matching React glass-card class) ──── */
.glass-card{
  background:var(--glass-bg);
  backdrop-filter:blur(16px) saturate(200%);
  -webkit-backdrop-filter:blur(16px) saturate(200%);
  border:1px solid var(--glass-bd);
  border-radius:var(--radius);
  transition:all .5s cubic-bezier(.23,1,.32,1)
}
.glass-card:hover{
  border-color:rgba(255,255,255,.3);
  box-shadow:0 0 40px rgba(0,255,170,.1)
}

/* ── TEXT GRADIENT (matching React text-gradient) ──── */
.pp-text-gradient{
  background:linear-gradient(135deg,var(--primary) 0%,#fff 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-size:200% auto;
  animation:gradientPulse 9s ease infinite
}

/* ── BUTTONS ─────────────────────────────────────────── */
.pp-btn{display:inline-flex;align-items:center;gap:10px;padding:16px 36px;
  border-radius:9999px;font-weight:800;font-size:13px;text-transform:uppercase;
  letter-spacing:.08em;transition:all .4s cubic-bezier(.23,1,.32,1)}
.pp-btn-primary{background:var(--primary);color:var(--bg);padding:20px 48px;font-size:16px;font-weight:900;
  box-shadow:0 8px 32px rgba(0,255,170,.2)}
.pp-btn-primary:hover{background:#fff;transform:translateY(-6px) scale(1.05);
  box-shadow:0 20px 48px rgba(255,255,255,.2)}
.pp-btn-ghost{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(12px)}
.pp-btn-ghost:hover{background:rgba(255,255,255,.12);border-color:var(--primary)}
.pp-btn-save{background:var(--bg);color:var(--primary);font-weight:900;font-size:11px;
  text-transform:uppercase;letter-spacing:.15em;padding:8px 20px;border-radius:8px;
  border:1px solid rgba(0,0,0,.2);display:flex;align-items:center;gap:8px}
.pp-btn-save svg{flex-shrink:0}

/* Play circle button (matching React Hero play button) */
.pp-play-circle{
  width:32px;height:32px;border-radius:50%;
  background:rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  transition:all .3s
}
.pp-btn-ghost:hover .pp-play-circle{background:var(--primary);color:var(--bg)}

/* ── ANIMATIONS ─────────────────────────────────────── */
@keyframes float{0%,100%{transform:translateY(0) rotate(-12deg)}50%{transform:translateY(-20px) rotate(-10deg)}}
@keyframes orbit{from{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1;box-shadow:0 0 0 0 rgba(0,242,255,.6)}
                 70%{transform:scale(1.15);opacity:.6;box-shadow:0 0 0 10px rgba(0,242,255,0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-60px)}to{opacity:1;transform:translateX(0)}}
@keyframes slideInRight{from{opacity:0;transform:translateX(60px)}to{opacity:1;transform:translateX(0)}}
@keyframes shimmer{0%{background-position:200% center}100%{background-position:-200% center}}
@keyframes gradientPulse{
  0%{background-position:0% 50%;filter:brightness(1)}
  10%{background-position:100% 50%;filter:brightness(1.2)}
  90%{background-position:100% 50%;filter:brightness(1.2)}
  100%{background-position:0% 50%;filter:brightness(1)}
}
@keyframes scrollText{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Croquis Logo animation (matching React Logo.jsx) */
@keyframes draw{
  0% {
    stroke-dashoffset: 500;
    opacity: 0;
  }
  15% {
    stroke-dashoffset: 0;
    opacity: 1;
  }
  90% {
    stroke-dashoffset: 0;
    opacity: 1;
  }
  100% {
    stroke-dashoffset: 0;
    opacity: 0;
  }
}

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .8s,transform .8s cubic-bezier(.23,1,.32,1)}
.reveal.visible{opacity:1;transform:none}
.reveal-left{opacity:0;transform:translateX(-60px);transition:opacity .9s,transform .9s cubic-bezier(.23,1,.32,1)}
.reveal-left.visible{opacity:1;transform:none}
.reveal-right{opacity:0;transform:translateX(60px);transition:opacity .9s,transform .9s cubic-bezier(.23,1,.32,1)}
.reveal-right.visible{opacity:1;transform:none}

/* ── HEADER (matching React Header.jsx) ────────────── */
.pp-header{
  position:fixed;top:0;left:0;width:100%;z-index:200;
  padding:8px 24px;
  background:rgba(3,3,5,.85);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid rgba(255,255,255,.05);
  box-shadow:0 4px 20px rgba(0,0,0,.3);
  transition:background .3s
}
.pp-header.scrolled{background:rgba(3,3,5,.96)}
.pp-header-inner{
  max-width:1600px;margin:0 auto;width:100%;
  display:flex;justify-content:space-between;align-items:center;
  padding:0 40px;
}

/* Logo (matching React Logo.jsx — SVG croquis text) */
.pp-logo{display:flex;align-items:center;flex-shrink:0;max-width:240px}
.pp-logo-container{cursor:pointer;overflow:visible}
.pp-logo-svg{
  width:auto;max-width:100%;height:auto;overflow:visible
}
.pp-logo-svg .pp-logo-text{
  font-family:var(--font);font-weight:900;font-size:32px;
  fill:none;stroke-width:1.5;
  stroke-dasharray:500;stroke-dashoffset:500;
  animation:draw 9s cubic-bezier(.445,.05,.55,.95) infinite;
  filter:drop-shadow(0 0 8px var(--primary));
  letter-spacing:1px
}
.pp-logo-svg .pp-logo-text-shadow{stroke-width:.3;opacity:.3}
.pp-logo img{height:36px;width:auto}

/* Nav Capsule */
.pp-nav{display:flex;align-items:center}
.pp-nav-capsule{
  display:flex;align-items:center;gap:32px;
  padding:12px 32px;
  border:1.5px solid rgba(255,255,255,.15);
  box-shadow:0 4px 20px rgba(0,0,0,.25);
  position:relative
}
.pp-menu{display:flex;align-items:center;gap:32px}
.pp-menu li a{
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:.15em;color:rgba(255,255,255,.7);transition:color .3s
}
.pp-menu li a:hover,.pp-menu li.current-menu-item a{color:#fff}
.pp-nav-divider{width:1px;height:16px;background:rgba(255,255,255,.2);flex-shrink:0}
.pp-nav-actions{display:flex;align-items:center;gap:16px}
.pp-icon-btn{color:rgba(255,255,255,.6);transition:color .3s;display:flex;align-items:center}
.pp-icon-btn:hover{color:var(--primary)}

/* Cart button (matching React ShoppingBag) */
.pp-cart-btn{position:relative;color:rgba(255,255,255,.7);display:flex;align-items:center;transition:color .3s}
.pp-cart-btn:hover{color:var(--primary)}
.pp-cart-count{
  position:absolute;top:-8px;right:-8px;min-width:20px;height:20px;
  background:var(--primary);color:var(--bg);font-size:10px;font-weight:900;
  border-radius:999px;display:flex;align-items:center;justify-content:center;
  padding:0 5px
}

/* Editor toggle (admin only — pencil icon) */
.pp-editor-toggle{
  padding:8px;border-radius:999px;color:rgba(255,255,255,.4);
  transition:all .3s;border:1px solid transparent
}
.pp-editor-toggle:hover,.pp-editor-toggle.active{
  color:var(--primary);background:rgba(0,242,255,.1);border-color:rgba(0,242,255,.2)
}

/* Mobile toggle */
.pp-mobile-toggle{display:none;color:rgba(255,255,255,.6);padding:8px}
.pp-mobile-toggle:hover{color:#fff}

/* Mobile menu */
.pp-mobile-menu{
  position:fixed;inset:0;background:rgba(3,3,5,.98);backdrop-filter:blur(24px);
  z-index:300;display:flex;flex-direction:column;padding:40px;
  transform:translateX(100%);transition:transform .4s cubic-bezier(.23,1,.32,1)
}
.pp-mobile-menu.open{transform:none}
.pp-mobile-close{align-self:flex-end;color:rgba(255,255,255,.4);margin-bottom:40px}
.pp-mobile-nav{display:flex;flex-direction:column;gap:24px}
.pp-mobile-nav li a{font-size:2rem;font-weight:900;text-transform:uppercase}

/* ── EDITOR BANNER (floating bottom-right) ─────────── */
.pp-editor-banner{
  position:fixed;bottom:24px;right:24px;z-index:950;
  background:rgba(0,242,255,.95);color:var(--bg);
  padding:14px 24px;border-radius:16px;
  display:none;align-items:center;gap:16px;
  font-weight:900;font-size:11px;letter-spacing:.1em;
  box-shadow:0 8px 32px rgba(0,242,255,.35),0 0 0 1px rgba(0,0,0,.1);
  backdrop-filter:blur(12px)
}
.pp-editor-banner.active{display:flex}
.pp-editor-label{font-size:11px;font-weight:900;letter-spacing:.15em}
.pp-btn-exit{color:var(--bg);opacity:.7;font-weight:900;font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  background:rgba(0,0,0,.15);padding:6px 14px;border-radius:8px;transition:all .2s}
.pp-btn-exit:hover{opacity:1;background:rgba(0,0,0,.3)}
.pp-editor-banner-left{display:flex;align-items:center;gap:16px}

/* Editor fields — ALWAYS hidden unless editor-active */
.pp-editor-field,.pp-editor-fields{
  display:none !important;background:rgba(0,0,0,.88);backdrop-filter:blur(16px);
  border:1px dashed rgba(0,242,255,.4);border-radius:16px;
  padding:24px;gap:16px;flex-direction:column;margin:16px 0
}
body.editor-active .pp-editor-field,
body.editor-active .pp-editor-fields{display:flex !important}
body.editor-active .pp-hero-img-editor{display:flex !important}
.pp-editor-lbl{font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.2em;color:var(--primary)}
.pp-editor-input{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:10px;padding:12px 16px;width:100%;color:#fff;font-size:14px;
  font-family:var(--font);transition:border-color .2s
}
.pp-editor-input:focus{border-color:var(--primary);outline:none}
.pp-editor-textarea{min-height:100px;resize:vertical}
.pp-editor-row{display:flex;flex-direction:column;gap:8px}
/* contenteditable outline ONLY visible in editor mode */
[data-editable="true"]{outline:none;border-radius:6px;padding:2px 6px;cursor:default}
body.editor-active [data-editable="true"]{outline:2px dashed rgba(0,242,255,.5);cursor:text}

/* ── HERO (matching React Hero.jsx) ────────────────── */
.pp-hero{
  position:relative;min-height:90vh;
  display:flex;align-items:center;
  overflow:hidden;padding:80px 32px 80px
}
.pp-hero-bg{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 80% 60% at 60% 50%,rgba(112,0,255,.18) 0%,transparent 70%)
}
.pp-hero-inner{
  max-width:1600px;margin:0 auto;width:100%;
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;
  position:relative;z-index:10;
  padding:0 40px;
}
.pp-hero-title{
  font-size:clamp(3.5rem,8vw,8rem);font-weight:900;
  line-height:.9;margin-bottom:24px;
  letter-spacing:-.03em
}
.pp-hero-sub{
  font-size:1.25rem;color:var(--text-dim);max-width:500px;
  margin-bottom:40px;line-height:1.7;font-weight:300
}
.pp-hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:32px}

/* Hero visual (matching React Hero motion.div with orbits) */
.pp-hero-visual{position:relative;display:flex;align-items:center;justify-content:center}
.pp-hero-glow{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:120%;height:120%;border-radius:50%;
  background:radial-gradient(circle,rgba(0,242,255,.2) 0%,transparent 70%);
  filter:blur(120px);pointer-events:none;opacity:.5
}
.pp-hero-img-wrap{position:relative;z-index:10;padding:48px}
.pp-hero-img{
  width:100%;max-width:600px;height:auto;object-fit:contain;
  filter:drop-shadow(0 45px 45px rgba(0,0,0,.6));
  transform:rotate(-12deg);animation:float 8s ease-in-out infinite;
  transition:transform 1s cubic-bezier(.23,1,.32,1)
}
.pp-hero-img:hover{transform:rotate(0deg) scale(1.05)}
.pp-orbit{position:absolute;top:50%;left:50%;border-radius:50%;pointer-events:none}
.pp-orbit-1{width:140%;height:140%;transform:translate(-50%,-50%);border:1px solid rgba(255,255,255,.05);animation:orbit 40s linear infinite}
.pp-orbit-2{width:110%;height:110%;transform:translate(-50%,-50%);border:1px solid rgba(255,255,255,.1);animation:orbit 25s linear infinite reverse}
.pp-edit-overlay{display:none;position:absolute;inset:0;background:rgba(0,0,0,.6);
  align-items:center;justify-content:center;color:var(--primary);font-weight:900;cursor:pointer;border-radius:16px;font-size:14px}
body.editor-active .pp-edit-overlay{display:flex}

/* ── PRODUCTS SECTION (matching React ProductGrid) ── */
.pp-products-section{padding:32px 32px 80px;position:relative}
.pp-products-header{max-width:1600px;margin:0 auto 48px;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:16px}
.pp-section-title{font-size:clamp(2.5rem,5vw,4rem);font-weight:900;font-style:italic;text-transform:uppercase;letter-spacing:-.03em}
.pp-section-sub{font-size:1rem;color:var(--muted);margin-top:8px}
.pp-section-link{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.15em;color:var(--primary);transition:gap .3s}
.pp-section-link:hover{gap:14px}

/* WooCommerce product loop override */
.pp-products-grid,ul.products{
  max-width:1600px;margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%, 350px),1fr));
  gap:40px;list-style:none;padding:60px 24px
}

/* ── PRODUCT CARD (matching React ProductGrid card) ── */
.pp-product-card{
  position:relative;overflow:hidden;display:flex;flex-direction:column;
  border-radius:var(--radius);
  background:var(--glass-bg);border:1px solid var(--glass-bd);
  backdrop-filter:blur(12px) saturate(180%);
  -webkit-backdrop-filter:blur(12px) saturate(180%);
  transition:all .5s cubic-bezier(.23,1,.32,1)
}
.pp-product-card:hover{
  transform:translateY(-10px) scale(1.02);
  border-color:rgba(0,242,255,.3);
  box-shadow:0 40px 80px rgba(0,0,0,.5)
}

/* Every 3rd card spans 2 columns (matching React nth-child(3n)) */
.pp-product-card:nth-child(3n){grid-column:span 2}

/* Card image */
.pp-card-img-wrap{
  position:relative;aspect-ratio:1/1;overflow:hidden;display:block;
  border-radius:var(--radius) var(--radius) 0 0;
  background:var(--product-img-bg, rgba(0,0,0,.2))
}
.pp-card-img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(1.2) contrast(1.1);
  transition:transform .7s cubic-bezier(.23,1,.32,1)
}
.pp-product-card:hover .pp-card-img{transform:scale(1.1)}

/* Hover overlay (matching React product card overlay) */
.pp-card-hover-overlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,.4);
  opacity:0;
  display:flex;align-items:center;justify-content:center;gap:16px;
  transition:opacity .3s
}
.pp-product-card:hover .pp-card-hover-overlay{opacity:1}
.pp-overlay-btn{
  width:48px;height:48px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:all .3s;cursor:pointer
}
.pp-overlay-cart{background:#fff;color:var(--bg)}
.pp-overlay-cart:hover{background:var(--primary)}
.pp-overlay-view{background:rgba(255,255,255,.2);backdrop-filter:blur(8px);color:#fff;border:none}
.pp-overlay-view:hover{background:rgba(255,255,255,.4)}

/* Sale badge */
.pp-badge-sale{
  position:absolute;top:12px;left:12px;z-index:10;
  background:var(--accent);color:#fff;font-size:9px;font-weight:900;
  letter-spacing:.15em;text-transform:uppercase;padding:4px 10px;border-radius:999px
}

/* Card body */
.pp-card-body{padding:20px;display:flex;flex-direction:column;flex:1;gap:4px}
.pp-card-body-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:4px}
.pp-card-title{font-size:1.25rem;font-weight:700;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pp-card-title a:hover{color:var(--primary)}
.pp-card-price-inline,.pp-card-price-inline .amount,.pp-card-price-inline .woocommerce-Price-amount{font-weight:900;color:var(--primary);white-space:nowrap}
.pp-card-price-inline ins{text-decoration:none}
.pp-card-price-inline del{opacity:.4;font-size:.85rem;margin-right:4px}
.pp-card-cat{font-size:.875rem;color:var(--text-dim);margin-bottom:auto}

/* Add to Cart button in card (matching React "Add to Cart" button) */
.pp-card-add-btn{
  width:100%;padding:12px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-weight:700;font-size:14px;
  color:#fff;
  background:transparent;
  transition:all .3s;
  cursor:pointer;
  margin-top:12px
}
.pp-card-add-btn:hover,.pp-product-card:hover .pp-card-add-btn{
  background:#fff;color:var(--bg);border-color:#fff
}
.pp-out-stock-btn{
  cursor:default;opacity:.5;border-color:rgba(255,255,255,.05)
}
.pp-out-stock-btn:hover{background:transparent;color:#fff;opacity:.5}
.pp-no-products{text-align:center;color:var(--muted);padding:80px 0;grid-column:1/-1}
.pp-no-products a{color:var(--primary)}

/* ── ABOUT / STORE DESCRIPTION SECTION ─────────────── */
.pp-about{padding:128px 32px 80px;position:relative}
.pp-about-inner{
  max-width:1600px;margin:0 auto;
  display:flex;flex-direction:row;
  overflow:hidden;min-height:500px;
  border-color:rgba(255,255,255,.1)
}
.pp-about-content{
  flex:1.2;padding:48px 80px;position:relative;
  display:flex;flex-direction:column;justify-content:center
}
.pp-about-content::before{
  content:'';position:absolute;top:0;left:0;width:128px;height:128px;
  background:rgba(0,242,255,.2);filter:blur(80px);pointer-events:none
}
.pp-about-badge{
  font-size:11px;font-weight:900;text-transform:uppercase;
  letter-spacing:.4em;color:var(--primary);opacity:.5;
  display:block;margin-bottom:24px
}
.pp-about-title{
  font-size:clamp(2.5rem,6vw,4.5rem);font-weight:900;font-style:italic;
  text-transform:uppercase;letter-spacing:-.04em;line-height:.9;
  margin-bottom:40px
}
.pp-about-text{
  font-size:1.5rem;color:var(--text-dim);line-height:1.6;
  font-weight:300;margin-bottom:48px;max-width:640px
}
.pp-about-stats{display:flex;gap:32px;flex-wrap:wrap}
.pp-stat{display:flex;flex-direction:column;gap:4px;transition:transform .3s}
.pp-stat:hover{transform:translateY(-4px)}
.pp-stat-val{font-size:1.875rem;font-weight:900;line-height:1}
.pp-stat-lbl{font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.15em;color:var(--text-dim)}

/* About image */
.pp-about-img-wrap{
  flex:1;position:relative;min-height:400px;
  overflow:hidden
}
.pp-about-img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:grayscale(100%);
  transition:all 1s
}
.pp-about-img-wrap:hover .pp-about-img{filter:grayscale(0%);transform:scale(1.05)}
.pp-about-img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to right,var(--bg),transparent);
  display:block
}

/* ── FOOTER (matching React Footer.jsx) ─────────────── */
.pp-footer{
  background:var(--bg);border-top:1px solid rgba(255,255,255,.05);
  padding:128px 32px 96px;overflow:hidden;position:relative
}
.pp-footer-inner{max-width:1600px;margin:0 auto;position:relative;z-index:10}

/* Scrolling background text (matching React scrolling-text / text-stroke) */
.pp-footer-scroll-bg{
  position:absolute;top:0;left:0;width:100%;
  overflow:hidden;pointer-events:none;opacity:.3;user-select:none
}
.pp-scrolling-text{
  display:flex;white-space:nowrap;
  animation:scrollText 40s linear infinite;
  font-size:18rem;font-weight:900;letter-spacing:-.03em;
  -webkit-text-stroke:1.5px rgba(255,255,255,.2);
  text-shadow:0 0 1px rgba(255,255,255,.1);
  color:transparent;
  line-height:1;padding:80px 0
}
.pp-scrolling-text span{margin-right:60px}

/* Footer top grid */
.pp-footer-top{
  display:flex;justify-content:space-between;align-items:flex-start;gap:80px;
  margin-bottom:128px
}

/* Footer brand / manifesto */
.pp-footer-brand{max-width:800px;flex:1}
.pp-footer-manifesto{margin-bottom:64px}
.pp-manifesto-badge{
  display:block;font-size:11px;font-weight:900;
  text-transform:uppercase;letter-spacing:.5em;
  color:var(--primary);margin-bottom:16px
}
.pp-footer-tagline{
  font-size:clamp(2.5rem,6vw,4.5rem);font-weight:900;
  line-height:1.1;letter-spacing:-.03em;margin-bottom:0
}

/* Footer social links (matching React Footer socials with ArrowUpRight) */
.pp-footer-socials{display:flex;flex-wrap:wrap;gap:48px;align-items:center}
.pp-social-link-full{
  display:flex;align-items:center;gap:8px;
  color:var(--text-dim);transition:color .3s;
  font-weight:900;text-decoration:underline;text-transform:uppercase;
  font-size:1.25rem;line-height:1
}
.pp-social-link-full:hover{color:#fff}
.pp-social-link-full svg:last-child{transition:transform .3s}
.pp-social-link-full:hover svg:last-child{transform:translate(4px,-4px)}

/* Footer columns */
.pp-footer-col h4{
  font-size:10px;font-weight:900;text-transform:uppercase;
  letter-spacing:.3em;color:var(--primary);margin-bottom:32px
}
.pp-footer-links{display:flex;flex-direction:column;gap:24px}
.pp-footer-links li a{
  font-size:1.25rem;font-weight:700;
  color:rgba(255,255,255,.6);transition:all .3s;
  display:inline-block
}
.pp-footer-links li a:hover{color:var(--primary);transform:translateX(8px)}

/* Footer bottom */
.pp-footer-bottom{
  border-top:1px solid rgba(255,255,255,.05);padding-top:64px;
  display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px
}
.pp-footer-payment{display:flex;flex-direction:column;gap:24px;align-items:flex-start}
.pp-payment-label{font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.3em;opacity:.4}
.pp-payment-capsule{
  display:inline-flex;align-items:center;gap:0;
  padding:16px 32px;border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 0 30px rgba(0,0,0,.5);
  transition:border-color .5s
}
.pp-payment-capsule:hover{border-color:rgba(0,242,255,.3)}
.pp-payment-icons{
  display:flex;gap:24px;align-items:center;
  filter:grayscale(100%);opacity:.4;
  transition:all .7s
}
.pp-payment-capsule:hover .pp-payment-icons{
  filter:grayscale(0%);opacity:1
}
.pp-payment-icons img{height:16px;filter:invert(1);transition:transform .3s}
.pp-payment-icons img:hover{transform:scale(1.25)}
.pp-payment-sep{width:1px;height:16px;background:rgba(255,255,255,.1)}
.pp-node-inline{
  display:none;border-left:1px solid rgba(255,255,255,.1);padding-left:24px;margin-left:24px;
  align-items:center;gap:10px
}
.pp-node-dot{width:8px;height:8px;background:var(--primary);border-radius:50%;box-shadow:0 0 10px var(--primary);animation:pulse 2s ease infinite;flex-shrink:0}
.pp-node-text{font-size:10px;font-weight:900;letter-spacing:.25em;text-transform:uppercase;color:var(--primary)}
.pp-footer-copy-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.pp-footer-copy{font-size:10px;color:rgba(255,255,255,.25);font-weight:900;letter-spacing:.15em;text-transform:uppercase}
.pp-wp-admin-link{color:var(--primary);font-size:11px;transition:opacity .3s}
.pp-wp-admin-link:hover{opacity:.7}
.pp-footer-glow{position:absolute;bottom:-50%;right:-25%;width:500px;height:500px;background:rgba(112,0,255,.2);filter:blur(150px);border-radius:50%;pointer-events:none}

/* ── WC SINGLE PRODUCT (matching React ProductDetailPage.jsx) */
.pp-main{
  padding-top:100px;min-height:100vh;
  position:relative;z-index:1;
}
.pp-single-product{max-width:1280px;margin:0 auto;padding:40px 32px 80px}
.pp-back-link{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:900;
  text-transform:uppercase;letter-spacing:.15em;color:rgba(255,255,255,.4);
  margin-bottom:48px;transition:all .3s}
.pp-back-link:hover{color:#fff;gap:14px}
.pp-product-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.pp-product-gallery{position:sticky;top:120px}
.pp-gallery-main{border-radius:var(--radius);overflow:hidden;aspect-ratio:1;background:radial-gradient(circle at center,rgba(0,242,255,.05) 0%,rgba(0,0,0,.5) 100%);position:relative;padding:8px;box-shadow:0 30px 60px rgba(0,0,0,.6),inset 0 0 0 1px rgba(255,255,255,.1)}
.pp-gallery-main::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:conic-gradient(from 0deg,transparent 60%,var(--primary) 100%);animation:orbitRotate 4s linear infinite;z-index:-2}
.pp-gallery-main::after{content:'';position:absolute;inset:2px;background:var(--bg);border-radius:calc(var(--radius) - 2px);z-index:-1;box-shadow:inset 0 0 40px rgba(0,242,255,.03)}
@keyframes orbitRotate{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
.pp-gallery-main img{width:100%;height:100%;object-fit:contain;padding:24px;transition:transform 1s;position:relative;z-index:10;filter:drop-shadow(0 20px 30px rgba(0,0,0,.5))}
.pp-gallery-main:hover img{transform:scale(1.12)}
.pp-gallery-cat-badge{position:absolute;top:20px;right:20px;background:rgba(3,3,5,.8);
  backdrop-filter:blur(8px);font-size:9px;font-weight:900;letter-spacing:.15em;
  text-transform:uppercase;padding:6px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.1)}
.pp-gallery-thumbs{display:flex;gap:12px;margin-top:16px;flex-wrap:wrap}
.pp-gallery-thumb{width:72px;height:72px;border-radius:12px;overflow:hidden;cursor:pointer;border:1px solid rgba(255,255,255,.1);transition:border-color .3s;flex-shrink:0}
.pp-gallery-thumb:hover,.pp-gallery-thumb.active{border-color:var(--primary)}
.pp-gallery-thumb img{width:100%;height:100%;object-fit:cover}

/* Product info */
.pp-product-info{display:flex;flex-direction:column;gap:24px}
.pp-product-cat{font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.4em;color:var(--primary);opacity:.7}
.pp-product-title{font-size:clamp(2rem,5vw,5rem);font-weight:900;font-style:italic;text-transform:uppercase;letter-spacing:-.03em;line-height:.9}
.pp-product-rating{display:flex;align-items:center;gap:12px}
.pp-stars{display:flex;gap:2px;color:var(--primary)}
.pp-rating-count{font-size:12px;color:var(--muted)}
.pp-product-price-wrap .price,.pp-product-price-wrap{font-size:3rem;font-weight:900;line-height:1}
.pp-product-price-wrap ins{text-decoration:none;color:#fff}
.pp-product-price-wrap del{opacity:.4;font-size:1.25rem;margin-right:12px}
.pp-product-desc{font-size:1.5rem;color:var(--text-dim);line-height:1.6;font-weight:300;border-left:2px solid var(--primary);padding-left:32px;font-style:italic}
.pp-product-desc p{margin-bottom:12px}

/* Product actions */
.pp-product-actions{display:flex;flex-direction:column;gap:16px;border-top:1px solid rgba(255,255,255,.06);padding-top:24px}
.pp-add-to-cart-btn,.single_add_to_cart_button{
  width:100%;padding:24px;border-radius:0;
  background:var(--primary);color:var(--bg);font-size:1.5rem;font-weight:900;
  text-transform:uppercase;letter-spacing:-.02em;transition:all .4s cubic-bezier(.23,1,.32,1);
  border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:16px
}
.pp-add-to-cart-btn:hover,.single_add_to_cart_button:hover{background:#fff;transform:none;box-shadow:0 20px 40px rgba(0,0,0,.4)}

/* Guarantees */
.pp-product-guarantees{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pp-product-guarantees .glass-card,.pp-guarantee-card{
  padding:24px;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center
}
.pp-guarantee{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--muted)}
.pp-guarantee svg{color:var(--primary);flex-shrink:0}

/* Product meta */
.pp-product-meta-info{display:flex;flex-direction:column;gap:8px;padding-top:48px;border-top:1px solid rgba(255,255,255,.05)}
.pp-meta-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.pp-meta-key{color:var(--text-dim);font-size:.875rem;text-transform:uppercase}
.pp-meta-val{color:rgba(255,255,255,.8);font-weight:700}

/* WC override for cart form */
.woocommerce div.product form.cart{display:flex;flex-direction:column;gap:16px}
.woocommerce div.product form.cart .quantity,
.woocommerce div.product .quantity{
  display:flex;align-items:center;gap:0;
  border:1px solid rgba(255,255,255,.15);border-radius:16px;
  overflow:hidden;background:rgba(255,255,255,.05);
  backdrop-filter:blur(8px);width:fit-content
}
.woocommerce div.product .quantity input.qty,
.woocommerce .quantity input.qty{
  width:64px;height:52px;background:transparent;border:none;
  text-align:center;font-family:var(--font);font-size:18px;
  font-weight:900;color:#fff;letter-spacing:.05em;
  -moz-appearance:textfield;outline:none
}
.woocommerce .quantity input.qty::-webkit-outer-spin-button,
.woocommerce .quantity input.qty::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
/* Custom +/- buttons wrapping the qty */
.pp-qty-btn{
  width:48px;height:52px;display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.5);font-size:20px;font-weight:700;
  transition:all .2s;cursor:pointer;background:transparent;
  border:none
}
.pp-qty-btn:hover{color:var(--primary);background:rgba(0,242,255,.1)}
.woocommerce div.product form.cart .button{
  width:100%;padding:24px;border-radius:0;
  background:var(--primary);color:var(--bg);font-family:var(--font);
  font-size:1.5rem;font-weight:900;text-transform:uppercase;
  letter-spacing:-.02em;transition:all .4s;border:none;cursor:pointer
}
.woocommerce div.product form.cart .button:hover{background:#fff}

/* WC Breadcrumb */
.pp-breadcrumb,.woocommerce .woocommerce-breadcrumb{color:var(--muted);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:32px;display:flex;align-items:center;gap:8px}
.pp-breadcrumb a,.woocommerce .woocommerce-breadcrumb a{color:var(--primary);transition:opacity .3s}
.pp-breadcrumb a:hover,.woocommerce .woocommerce-breadcrumb a:hover{opacity:.7}
.pp-bc-sep{opacity:.4}

/* WC Notices */
.woocommerce-message,.woocommerce-error,.woocommerce-info{border-radius:16px;padding:16px 20px;margin-bottom:24px;font-weight:700;font-size:13px;border:1px solid}
.woocommerce-message{background:rgba(0,242,255,.1);border-color:rgba(0,242,255,.3);color:var(--primary)}
.woocommerce-error{background:rgba(255,80,80,.1);border-color:rgba(255,80,80,.3);color:#ff5050}

/* WC Checkout & Cart forms */
.woocommerce{max-width:1200px;margin:0 auto;padding:40px 32px}
.woocommerce table.shop_table{width:100%;border-collapse:collapse}
.woocommerce table.shop_table th,.woocommerce table.shop_table td{padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.06);font-size:13px}
.woocommerce table.shop_table th{font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.15em;color:var(--muted)}
.woocommerce table.shop_table .product-name a{color:#fff;font-weight:700}
.woocommerce table.shop_table .product-name a:hover{color:var(--primary)}
.woocommerce-page .woocommerce input[type="text"],
.woocommerce-page .woocommerce input[type="email"],
.woocommerce-page .woocommerce input[type="tel"],
.woocommerce-page .woocommerce input[type="number"],
.woocommerce-page .woocommerce input[type="password"],
.woocommerce-page .woocommerce select,
.woocommerce-page .woocommerce textarea{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:12px;padding:20px 16px;width:100%;color:#fff;
  font-family:var(--font);transition:border-color .2s;font-size:14px
}
.woocommerce-page .woocommerce input:focus,.woocommerce-page .woocommerce textarea:focus{border-color:var(--primary);outline:none}
.woocommerce-page h1,.woocommerce-page h2,.woocommerce-page h3{font-style:italic;text-transform:uppercase;letter-spacing:-.02em}
#place_order,.woocommerce #respond input#submit,.woocommerce a.button,.woocommerce button.button{
  background:var(--primary);color:var(--bg);font-family:var(--font);
  font-weight:900;font-size:14px;text-transform:uppercase;letter-spacing:.1em;
  padding:20px 40px;border-radius:16px;border:none;cursor:pointer;transition:all .3s;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%
}
#place_order:hover,.woocommerce a.button:hover,.woocommerce button.button:hover{background:#fff;transform:translateY(-3px)}

/* Checkout page heading */
.pp-checkout-page .woocommerce h3,
.pp-checkout-page #order_review_heading{
  font-size:1.25rem;font-weight:900;
  display:flex;align-items:center;gap:12px;
  letter-spacing:.15em;color:rgba(255,255,255,.4);text-transform:uppercase;
  margin-bottom:24px
}

/* ── CUSTOM CART PAGE (matching React CartPage.jsx) ── */
.pp-cart-container{max-width:1400px;margin:0 auto;padding:128px 32px 80px}
.pp-cart-header{margin-bottom:48px}
.pp-cart-title{font-size:clamp(3rem,6vw,4rem);font-weight:900;font-style:italic;letter-spacing:-.03em;text-transform:uppercase}
.pp-cart-subtitle{color:var(--text-dim);font-size:1.125rem}

/* Empty cart */
.pp-cart-empty{padding:80px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:24px}
.pp-cart-empty-icon{width:80px;height:80px;border-radius:50%;background:rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;opacity:.2}
.pp-cart-empty h2{font-size:1.875rem;font-weight:700}
.pp-cart-empty p{color:var(--text-dim);max-width:400px}

/* Cart layout */
.pp-cart-layout{display:grid;grid-template-columns:2fr 1fr;gap:48px}

/* Cart items */
.pp-cart-items{display:flex;flex-direction:column;gap:24px}
.pp-cart-item{padding:24px;display:flex;align-items:center;gap:32px}
.pp-cart-item-img-wrap{width:128px;height:128px;border-radius:12px;overflow:hidden;background:rgba(255,255,255,.05);flex-shrink:0}
.pp-cart-item-img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.pp-cart-item:hover .pp-cart-item-img{transform:scale(1.1)}
.pp-cart-item-info{flex:1}
.pp-cart-item-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}
.pp-cart-item-name{font-size:1.5rem;font-weight:900;letter-spacing:-.02em}
.pp-cart-item-name a{color:#fff}
.pp-cart-item-name a:hover{color:var(--primary)}
.pp-cart-item-remove{color:var(--text-dim);transition:color .3s;padding:4px;cursor:pointer}
.pp-cart-item-remove:hover{color:#ef4444}
.pp-cart-item-cat{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--text-dim);margin-bottom:16px}
.pp-cart-item-bottom{display:flex;justify-content:space-between;align-items:center}
.pp-cart-qty-controls{display:flex;align-items:center;gap:0;background:rgba(255,255,255,.05);border-radius:8px;padding:4px}
.pp-cart-qty-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--text-dim);transition:color .3s;cursor:pointer}
.pp-cart-qty-btn:hover{color:#fff}
.pp-cart-qty-val{font-weight:700;width:16px;text-align:center}
.pp-cart-item-total,.pp-cart-item-total .amount{font-size:1.5rem;font-weight:900;color:var(--primary)}

/* Cart summary sidebar */
.pp-cart-sidebar .pp-cart-summary{padding:32px;position:sticky;top:128px}
.pp-cart-summary-title{font-size:1.5rem;font-weight:900;margin-bottom:32px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.1)}
.pp-cart-summary-rows{display:flex;flex-direction:column;gap:16px;margin-bottom:32px}
.pp-cart-summary-row{display:flex;justify-content:space-between;color:var(--text-dim)}
.pp-cart-summary-val,.pp-cart-summary-val .amount{color:#fff;font-weight:700}
.pp-cart-summary-total{font-size:1.5rem;font-weight:900;padding-top:16px;border-top:1px solid rgba(255,255,255,.1);color:#fff}
.pp-cart-summary-val-total,.pp-cart-summary-val-total .amount{color:var(--primary);font-weight:900}
.pp-cart-checkout-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;padding:16px;
  background:#fff;color:var(--bg);
  font-weight:900;border-radius:12px;
  transition:all .3s
}
.pp-cart-checkout-btn:hover{background:var(--primary)}
.pp-cart-security-note{font-size:.75rem;color:var(--text-dim);margin-top:24px;text-align:center;line-height:1.6}

/* ── SHOP / ARCHIVE PAGE ───────────────────────────── */
.post-type-archive-product .pp-main,
.tax-product_cat .pp-main,
.woocommerce-shop .pp-main{
  position:relative;
}
.pp-archive-header{max-width:1400px;margin:0 auto 48px;padding:0 40px}
.pp-archive-title{font-size:clamp(2.5rem,5vw,5rem);font-weight:900;font-style:italic;text-transform:uppercase;letter-spacing:-.03em;margin-bottom:8px}
.woocommerce-result-count{color:var(--muted);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em}
.woocommerce-ordering select{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:10px 14px;color:#fff;font-family:var(--font);font-weight:700}

/* Pagination */
.woocommerce nav.woocommerce-pagination{display:flex;justify-content:center;margin-top:60px}
.woocommerce nav.woocommerce-pagination ul{border:none;display:flex;gap:8px}
.woocommerce nav.woocommerce-pagination ul li{border:none}
.woocommerce nav.woocommerce-pagination ul li a,.woocommerce nav.woocommerce-pagination ul li span{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:#fff;
  border-radius:10px;padding:10px 18px;font-weight:700;transition:all .3s
}
.woocommerce nav.woocommerce-pagination ul li a:hover,.woocommerce nav.woocommerce-pagination ul li span.current{
  background:var(--primary);border-color:var(--primary);color:var(--bg)
}

/* ── VIDEO MODAL ────────────────────────────────────── */
.pp-modal{position:fixed;inset:0;z-index:400;background:rgba(3,3,5,.95);backdrop-filter:blur(20px);
  display:none;align-items:center;justify-content:center;padding:32px}
.pp-modal.open{display:flex}
.pp-modal-inner{position:relative;width:100%;max-width:1000px;aspect-ratio:16/9;
  background:#000;border-radius:24px;overflow:hidden;border:1px solid rgba(255,255,255,.1);
  box-shadow:0 32px 64px rgba(0,0,0,.6)}
.pp-modal-close{position:absolute;top:24px;right:24px;z-index:10;width:48px;height:48px;
  border-radius:999px;background:#fff;color:var(--bg);display:flex;align-items:center;justify-content:center;transition:background .3s}
.pp-modal-close:hover{background:var(--primary)}

/* ── EDITOR PANEL ───────────────────────────────────── */
.pp-editor-panel{
  position:fixed;bottom:0;left:0;width:100%;z-index:900;
  background:rgba(3,3,5,.98);backdrop-filter:blur(24px);
  border-top:1px solid rgba(0,242,255,.3);box-shadow:0 -10px 40px rgba(0,0,0,.5);
  transform:translateY(100%);transition:transform .4s cubic-bezier(.23,1,.32,1);
  max-height:80vh;display:flex;flex-direction:column;
}
.pp-editor-panel.active{transform:translateY(0)}
.pp-editor-panel-inner{
  max-width:1000px;margin:0 auto;width:100%;padding:32px;
  overflow-y:auto;overflow-x:hidden;
}
.pp-editor-panel-header{text-align:center;margin-bottom:32px;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:16px}
.pp-editor-panel-header h3{font-size:1.5rem;color:var(--primary);margin-bottom:8px;font-weight:900;text-transform:uppercase;}
.pp-editor-panel-header p{color:var(--muted);font-size:14px}
.pp-editor-sections{display:flex;flex-direction:column;gap:32px}
.pp-editor-section{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:24px}
.pp-editor-section-title{font-size:1.125rem;color:#fff;margin-bottom:24px;display:flex;align-items:center;gap:8px;font-weight:900;text-transform:uppercase}
.pp-editor-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:768px){ .pp-editor-grid{grid-template-columns:1fr 1fr} }
.pp-editor-links-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}
.pp-editor-link-row{display:flex;gap:12px;align-items:center}
.pp-editor-remove-btn{background:rgba(255,80,80,.1);color:#ff5050;border:1px solid rgba(255,80,80,.2);width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.pp-editor-remove-btn:hover{background:#ff5050;color:#fff}
.pp-editor-add-btn{background:rgba(0,242,255,.1);color:var(--primary);border:1px dashed rgba(0,242,255,.3);padding:12px;border-radius:10px;width:100%;font-weight:900;transition:all .2s;text-transform:uppercase;font-size:11px;letter-spacing:.1em}
.pp-editor-add-btn:hover{background:rgba(0,242,255,.2);border-style:solid}

/* ── LANDING PAGE — SHARED ─────────────────────────── */
.pp-landing{overflow-x:hidden}
.pp-lp-container{max-width:1280px;margin:0 auto;padding:0 32px}
.pp-lp-section-title{
  font-size:clamp(2rem,4vw,3.5rem);font-weight:900;
  text-align:center;margin-bottom:16px;
  text-transform:uppercase;letter-spacing:-.02em
}
.pp-lp-section-sub{
  text-align:center;color:var(--text-dim);font-size:1.125rem;
  max-width:600px;margin:0 auto 56px;line-height:1.7;font-weight:300
}

/* ── LP HERO ──────────────────────────────────────── */
.pp-lp-hero{
  position:relative;padding:40px 32px 80px;
  max-width:1280px;margin:0 auto
}
.pp-lp-hero-bg{
  display:none; /* Disabled to inherit body background */
}
.pp-lp-hero-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;
  position:relative;z-index:1
}

/* Trust row under Add to Cart */
.pp-trust-row{
  display:flex;gap:24px;flex-wrap:wrap;
  padding-top:16px;border-top:1px solid rgba(255,255,255,.06)
}
.pp-trust-item{
  display:flex;align-items:center;gap:6px;
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--text-dim)
}
.pp-trust-item svg{color:var(--primary);flex-shrink:0}

/* Quantity wrap */
.pp-qty-wrap{
  display:flex;align-items:center;gap:0;
  border:1px solid rgba(255,255,255,.15);border-radius:16px;
  overflow:hidden;background:rgba(255,255,255,.05);
  backdrop-filter:blur(8px);width:fit-content
}

/* Out of stock message */
.pp-out-of-stock-msg{
  color:#ff5050;font-weight:900;text-transform:uppercase;
  letter-spacing:.1em;font-size:14px
}

/* ── LP BENEFITS ──────────────────────────────────── */
.pp-lp-benefits{padding:100px 0;position:relative}
.pp-benefits-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px
}
.pp-benefit-card{
  padding:40px 32px;display:flex;flex-direction:column;
  align-items:center;text-align:center;gap:20px;
  transition:all .5s cubic-bezier(.23,1,.32,1)
}
.pp-benefit-card:hover{
  transform:translateY(-8px);
  border-color:rgba(0,242,255,.3);
  box-shadow:0 20px 60px rgba(0,0,0,.4)
}
.pp-benefit-icon{
  width:56px;height:56px;border-radius:16px;
  background:rgba(0,242,255,.1);
  display:flex;align-items:center;justify-content:center;
  color:var(--primary);flex-shrink:0
}
.pp-benefit-title{
  font-size:1rem;font-weight:800;text-transform:uppercase;
  letter-spacing:.08em
}
.pp-benefit-desc{
  font-size:.875rem;color:var(--text-dim);line-height:1.7;font-weight:300
}

/* ── LP REVIEWS ───────────────────────────────────── */
.pp-lp-reviews{padding:100px 0;position:relative}
.pp-reviews-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px
}
.pp-review-card{padding:32px;display:flex;flex-direction:column;gap:20px}
.pp-review-card:hover{
  border-color:rgba(0,242,255,.2);
  box-shadow:0 16px 48px rgba(0,0,0,.3)
}
.pp-review-stars{display:flex;gap:2px}
.pp-review-text{
  font-size:1rem;color:rgba(255,255,255,.85);line-height:1.7;
  font-style:italic;flex:1
}
.pp-review-author{display:flex;align-items:center;gap:12px}
.pp-review-avatar{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--secondary));
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:14px;color:var(--bg);flex-shrink:0
}
.pp-review-name{font-weight:700;font-size:.875rem;display:block}
.pp-review-badge{
  font-size:10px;color:var(--primary);font-weight:900;
  text-transform:uppercase;letter-spacing:.1em
}

/* ── LP OFFER / COUNTDOWN ─────────────────────────── */
.pp-lp-offer{padding:80px 0}
.pp-offer-card{padding:48px;position:relative;overflow:hidden}
.pp-offer-card::before{
  content:'';position:absolute;top:-50%;right:-30%;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,242,255,.15),transparent 70%);
  pointer-events:none
}
.pp-offer-badge{
  position:absolute;top:24px;right:24px;
  background:var(--accent);color:#fff;
  font-size:10px;font-weight:900;letter-spacing:.15em;
  padding:6px 16px;border-radius:999px;text-transform:uppercase
}
.pp-offer-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.pp-offer-title{
  font-size:clamp(2rem,4vw,3rem);font-weight:900;
  margin-bottom:16px;line-height:1
}
.pp-offer-text{color:var(--text-dim);font-size:1.1rem;line-height:1.7;margin-bottom:24px}
.pp-offer-text del{opacity:.5}
.pp-offer-text strong{color:var(--primary);font-weight:900}
.pp-offer-price-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.pp-offer-price-old,.pp-offer-price-old .amount{font-size:1.5rem;color:var(--text-dim);text-decoration:line-through;opacity:.5}
.pp-offer-price-new,.pp-offer-price-new .amount{font-size:2.5rem;font-weight:900;color:#fff}
.pp-offer-save-badge{
  background:rgba(34,197,94,.15);color:#22c55e;
  font-size:11px;font-weight:900;letter-spacing:.1em;
  padding:6px 14px;border-radius:999px
}

/* Countdown */
.pp-countdown-label{
  font-size:10px;font-weight:900;text-transform:uppercase;
  letter-spacing:.3em;color:var(--text-dim);margin-bottom:16px
}
.pp-countdown{display:flex;align-items:center;gap:8px}
.pp-cd-block{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:12px;padding:12px 20px;text-align:center;min-width:72px
}
.pp-cd-num{
  display:block;font-size:2rem;font-weight:900;line-height:1;
  font-variant-numeric:tabular-nums;color:var(--primary)
}
.pp-cd-lbl{font-size:9px;font-weight:900;letter-spacing:.2em;color:var(--text-dim);margin-top:4px;display:block}
.pp-cd-sep{font-size:1.5rem;font-weight:900;color:rgba(255,255,255,.2)}

/* Stock bar */
.pp-stock-bar{
  height:6px;background:rgba(255,255,255,.1);border-radius:3px;
  margin-top:24px;overflow:hidden
}
.pp-stock-bar-fill{
  height:100%;border-radius:3px;
  background:linear-gradient(90deg,var(--accent),#ff5050);
  transition:width 1s ease
}
.pp-stock-warn{
  font-size:13px;color:rgba(255,255,255,.7);margin-top:10px;
  font-weight:700
}
.pp-stock-warn strong{color:var(--accent)}

/* ── LP SPECS ─────────────────────────────────────── */
.pp-lp-specs{padding:80px 0}
.pp-specs-card{
  max-width:800px;margin:0 auto;padding:32px;
  display:flex;flex-direction:column;gap:0
}

/* ── LP FAQ ───────────────────────────────────────── */
.pp-lp-faq{padding:100px 0}
.pp-faq-list{
  max-width:800px;margin:0 auto;
  display:flex;flex-direction:column;gap:12px
}
.pp-faq-item{overflow:hidden;transition:border-color .3s}
.pp-faq-item.active{border-color:rgba(0,242,255,.3)}
.pp-faq-question{
  width:100%;padding:24px 28px;
  display:flex;justify-content:space-between;align-items:center;
  gap:16px;cursor:pointer;
  font-size:1rem;font-weight:700;color:#fff;
  text-align:left;background:none;border:none;font-family:var(--font);
  transition:color .3s
}
.pp-faq-question:hover{color:var(--primary)}
.pp-faq-icon{
  flex-shrink:0;width:32px;height:32px;border-radius:50%;
  background:rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:center;
  transition:all .3s;color:var(--text-dim)
}
.pp-faq-item.active .pp-faq-icon{
  background:rgba(0,242,255,.15);color:var(--primary);
  transform:rotate(45deg)
}
.pp-faq-answer{
  max-height:0;overflow:hidden;
  transition:max-height .4s cubic-bezier(.23,1,.32,1),padding .3s
}
.pp-faq-answer p{
  padding:0 28px 24px;color:var(--text-dim);
  line-height:1.8;font-size:.95rem
}
.pp-faq-item.active .pp-faq-answer{max-height:300px}

/* ── LP FINAL CTA ─────────────────────────────────── */
.pp-lp-cta{
  padding:120px 0;position:relative;overflow:hidden;
  text-align:center
}
.pp-lp-cta-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 50% at 50% 50%,rgba(112,0,255,.18) 0%,transparent 70%),
    radial-gradient(circle at 50% 80%,rgba(0,242,255,.1) 0%,transparent 50%)
}
.pp-cta-content{max-width:700px;margin:0 auto}
.pp-cta-title{
  font-size:clamp(2.5rem,5vw,4rem);font-weight:900;
  margin-bottom:20px;line-height:1;
  text-transform:uppercase;letter-spacing:-.02em
}
.pp-cta-sub{
  color:var(--text-dim);font-size:1.25rem;line-height:1.7;
  margin-bottom:40px;font-weight:300
}
.pp-cta-price{
  font-size:3rem;font-weight:900;margin-bottom:32px
}
.pp-cta-price ins{text-decoration:none;color:#fff}
.pp-cta-price del{opacity:.4;font-size:1.25rem;margin-right:12px}
.pp-cta-price .amount{color:var(--primary)}
.pp-cta-buy-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:12px;
  padding:22px 56px;border-radius:999px;
  background:var(--primary);color:var(--bg);
  font-size:1.125rem;font-weight:900;text-transform:uppercase;
  letter-spacing:.05em;cursor:pointer;
  transition:all .4s cubic-bezier(.23,1,.32,1);
  border:none;font-family:var(--font);
  box-shadow:0 8px 32px rgba(0,242,255,.3)
}
.pp-cta-buy-btn:hover{
  background:#fff;transform:translateY(-4px) scale(1.03);
  box-shadow:0 16px 48px rgba(255,255,255,.15)
}
.pp-cta-trust{
  display:flex;align-items:center;justify-content:center;gap:24px;
  margin-top:32px;flex-wrap:wrap
}
.pp-cta-trust span{
  display:flex;align-items:center;gap:6px;
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--text-dim)
}
.pp-cta-trust svg{color:var(--primary)}

/* ── LP RELATED ───────────────────────────────────── */
.pp-lp-related{padding:80px 0 120px}

/* ═══════════════════════════════════════════════════════
   CUSTOM CHECKOUT PAGE
   ═══════════════════════════════════════════════════════ */

/* Progress Steps */
.pp-checkout-progress{
  display:flex;align-items:center;justify-content:center;
  gap:0;margin-bottom:56px;padding:0 20px
}
.pp-progress-step{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  text-decoration:none;color:rgba(255,255,255,.3);transition:color .3s
}
.pp-progress-step.active,.pp-progress-step.completed{color:#fff}
.pp-progress-dot{
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.06);border:2px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:13px;transition:all .3s
}
.pp-progress-step.active .pp-progress-dot{
  background:var(--primary);border-color:var(--primary);color:var(--bg)
}
.pp-progress-step.completed .pp-progress-dot{
  background:rgba(34,197,94,.2);border-color:#22c55e;color:#22c55e
}
.pp-progress-label{
  font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.15em
}
.pp-progress-line{
  width:80px;height:2px;background:rgba(255,255,255,.1);
  margin:0 8px;margin-bottom:24px
}
.pp-progress-line.active{background:var(--primary)}

/* Checkout Layout */
.pp-checkout-form{max-width:1200px;margin:0 auto}
.pp-checkout-layout{
  display:grid;grid-template-columns:1.2fr 1fr;gap:32px;align-items:start
}
.pp-checkout-section{padding:32px;margin-bottom:24px}
.pp-checkout-section-title{
  font-size:1rem;font-weight:900;text-transform:uppercase;
  letter-spacing:.12em;margin-bottom:24px;
  display:flex;align-items:center;gap:12px;
  color:rgba(255,255,255,.6);font-style:normal
}
.pp-checkout-section-title svg{color:var(--primary);flex-shrink:0}

/* Checkout Fields override */
.pp-checkout-fields .form-row{margin-bottom:16px}
.pp-checkout-fields label{
  font-size:11px;font-weight:900;text-transform:uppercase;
  letter-spacing:.15em;color:var(--text-dim);margin-bottom:6px;display:block
}
.pp-checkout-fields label .required{color:var(--accent)}
.pp-checkout-fields .woocommerce-input-wrapper{display:block}
.pp-checkout-fields input[type="text"],
.pp-checkout-fields input[type="email"],
.pp-checkout-fields input[type="tel"],
.pp-checkout-fields input[type="number"],
.pp-checkout-fields input[type="password"],
.pp-checkout-fields select,
.pp-checkout-fields textarea{
  background:rgba(255,255,255,.04) !important;
  border:1px solid rgba(255,255,255,.1) !important;
  border-radius:12px !important;padding:16px !important;
  width:100% !important;color:#fff !important;
  font-family:var(--font) !important;font-size:14px !important;
  transition:border-color .2s !important
}
.pp-checkout-fields input:focus,
.pp-checkout-fields select:focus,
.pp-checkout-fields textarea:focus{
  border-color:var(--primary) !important;outline:none !important
}
.pp-checkout-fields select{
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23a0a0a0' viewBox='0 0 16 16'%3E%3Cpath d='M1.5 5.5L8 12l6.5-6.5'/%3E%3C/svg%3E") !important;
  background-repeat:no-repeat !important;
  background-position:right 16px center !important;
  padding-right:40px !important
}

/* Order Summary */
.pp-order-summary{position:sticky;top:120px}
.pp-order-items{display:flex;flex-direction:column;gap:16px;margin-bottom:24px;
  padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.08)}
.pp-order-item{display:flex;align-items:center;gap:16px}
.pp-order-item-img{
  position:relative;width:64px;height:64px;border-radius:12px;
  overflow:hidden;background:rgba(255,255,255,.05);flex-shrink:0
}
.pp-order-item-img img{width:100%;height:100%;object-fit:cover}
.pp-order-item-qty{
  position:absolute;top:-6px;right:-6px;
  width:22px;height:22px;border-radius:50%;
  background:var(--primary);color:var(--bg);
  font-size:10px;font-weight:900;
  display:flex;align-items:center;justify-content:center
}
.pp-order-item-info{flex:1;display:flex;justify-content:space-between;align-items:center}
.pp-order-item-name{font-weight:700;font-size:.9rem}
.pp-order-item-price,.pp-order-item-price .amount{font-weight:900;color:var(--primary)}

/* Order totals */
.pp-order-totals{display:flex;flex-direction:column;gap:12px;
  margin-bottom:24px;padding-bottom:24px;
  border-bottom:1px solid rgba(255,255,255,.08)}
.pp-order-total-row{display:flex;justify-content:space-between;color:var(--text-dim);font-size:.9rem}
.pp-order-total-row span:last-child,.pp-order-total-row .amount{color:#fff;font-weight:700}
.pp-order-total-final{
  font-size:1.25rem;font-weight:900;color:#fff;
  padding-top:12px;border-top:1px solid rgba(255,255,255,.08)
}
.pp-order-total-final span:last-child,.pp-order-total-final .amount{color:var(--primary)}
.pp-order-discount span:last-child{color:#22c55e}

/* Payment section & Shipping Options (WooCommerce defaults) */
#shipping_method { list-style: none; padding: 0; margin: 0; width: 100%; }
#shipping_method li {
  margin-bottom: 8px;
  background: rgba(255,255,255, 0.03);
  border: 1px solid rgba(255,255,255, 0.08);
  border-radius: 12px;
  padding: 12px 16px;
  display: flex;
  align-items: center;
  transition: all 0.3s ease;
}
#shipping_method li:has(input:checked) {
  border-color: var(--primary);
  background: rgba(0, 242, 255, 0.04);
}
#shipping_method input[type="radio"] { margin-right: 12px; cursor: pointer; accent-color: var(--primary); transform: scale(1.2); }
#shipping_method label {
  cursor: pointer !important; font-size: 0.9rem !important; font-weight: 700 !important; color: #fff !important; width: 100% !important;
  display: flex !important; justify-content: space-between !important; margin-bottom: 0 !important; text-transform: none !important; letter-spacing: normal !important;
}

#payment { background: transparent !important; }
#payment ul.payment_methods { list-style: none; padding: 0; margin: 0 0 24px; border-bottom: 1px solid rgba(255,255,255,0.08); padding-bottom: 24px; }
#payment ul.payment_methods li {
  background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px; padding: 16px; margin-bottom: 8px; transition: all 0.3s ease;
}
#payment ul.payment_methods li:-webkit-any(has(input:checked)) { border-color: var(--primary); }
#payment ul.payment_methods li:has(input:checked) { border-color: var(--primary); background: rgba(0, 242, 255, 0.04); }
#payment ul.payment_methods input[type="radio"] { margin-right: 12px; accent-color: var(--primary); transform: scale(1.2); }
#payment ul.payment_methods label { font-weight: 700; display: inline-flex; align-items: center; cursor: pointer; font-size: 0.95rem; margin-bottom: 0; color: #fff; text-transform: none; letter-spacing: normal; }
#payment ul.payment_methods label img { max-height: 24px; margin-left: 10px; }
#payment .payment_box { padding-top: 12px; color: var(--text-dim); font-size: 0.85rem; line-height: 1.6; }

/* Place Order button */
.woocommerce-terms-and-conditions-wrapper { margin-bottom: 24px !important; }
.woocommerce-privacy-policy-text { margin-bottom: 16px !important; color: var(--text-dim); font-size: 0.85rem; }

#payment .place-order { padding: 0; margin: 0; background: transparent !important; border: none !important; }
button#place_order {
  display: flex; width: 100%; align-items: center; justify-content: center; gap: 12px;
  padding: 22px 32px; border-radius: 999px; background: var(--primary); color: var(--bg);
  font-size: 1.125rem; font-weight: 900; text-transform: uppercase; letter-spacing: 0.05em;
  cursor: pointer; transition: all 0.4s cubic-bezier(0.23, 1, 0.32, 1); border: none;
  font-family: var(--font); box-shadow: 0 8px 32px rgba(0,242,255,0.3);
  margin-top: 16px !important;
}
button#place_order:hover {
  background: #fff; transform: translateY(-4px); box-shadow: 0 16px 48px rgba(255,255,255,0.15);
}
button#place_order::after { content: '\2192'; font-family: sans-serif; font-size: 20px; line-height: 1; }

/* Trust badges */
.pp-checkout-trust{
  display:flex;flex-direction:column;gap:16px;margin-top:24px
}
.pp-checkout-trust-item{
  display:flex;align-items:center;gap:14px;
  padding:16px 20px;border-radius:12px;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05)
}
.pp-checkout-trust-item svg{color:var(--primary);flex-shrink:0}
.pp-checkout-trust-item strong{display:block;font-size:.85rem;font-weight:700}
.pp-checkout-trust-item span{font-size:.75rem;color:var(--text-dim)}

/* ═══════════════════════════════════════════════════════
   THANK YOU PAGE
   ═══════════════════════════════════════════════════════ */
.pp-thankyou{max-width:800px;margin:0 auto;padding:40px 32px 120px;text-align:center}

/* Animated Checkmark */
.pp-ty-icon-wrap{margin:0 auto 32px;width:80px;height:80px}
.pp-ty-checkmark{width:80px;height:80px}
.pp-ty-circle{
  stroke:var(--primary);stroke-width:2;
  stroke-dasharray:157;stroke-dashoffset:157;
  animation:pp-ty-stroke .6s cubic-bezier(.65,0,.45,1) .2s forwards
}
.pp-ty-check{
  stroke:#fff;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:48;stroke-dashoffset:48;
  animation:pp-ty-stroke .4s cubic-bezier(.65,0,.45,1) .6s forwards
}
@keyframes pp-ty-stroke{to{stroke-dashoffset:0}}
.pp-ty-icon-success{
  background:rgba(0,242,255,.1);border-radius:50%;
  display:flex;align-items:center;justify-content:center
}
.pp-ty-icon-fail{
  background:rgba(255,80,80,.1);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:2rem;font-weight:900;color:#ff5050;
  width:80px;height:80px
}

/* Hero text */
.pp-ty-title{
  font-size:clamp(2rem,5vw,3rem);font-weight:900;
  margin-bottom:16px;text-transform:uppercase
}
.pp-ty-sub{color:var(--text-dim);font-size:1.1rem;line-height:1.7;margin-bottom:8px}
.pp-ty-sub strong{color:#fff}
.pp-ty-email{color:var(--text-dim);font-size:.9rem;margin-bottom:48px}
.pp-ty-email strong{color:var(--primary)}

/* Summary */
.pp-ty-summary{padding:32px;text-align:left;margin-bottom:48px}
.pp-ty-summary-title{
  font-size:1rem;font-weight:900;text-transform:uppercase;
  letter-spacing:.15em;margin-bottom:24px;
  padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.08)
}
.pp-ty-items{display:flex;flex-direction:column;gap:16px;
  margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.08)}
.pp-ty-item{display:flex;align-items:center;gap:16px}
.pp-ty-item-img{
  position:relative;width:56px;height:56px;border-radius:10px;
  overflow:hidden;background:rgba(255,255,255,.05);flex-shrink:0
}
.pp-ty-item-img img{width:100%;height:100%;object-fit:cover}
.pp-ty-item-qty{
  position:absolute;top:-5px;right:-5px;
  width:20px;height:20px;border-radius:50%;
  background:var(--primary);color:var(--bg);
  font-size:9px;font-weight:900;
  display:flex;align-items:center;justify-content:center
}
.pp-ty-item-info{flex:1;display:flex;justify-content:space-between;align-items:center}
.pp-ty-item-name{font-weight:700;font-size:.9rem}
.pp-ty-item-total,.pp-ty-item-total .amount{font-weight:900;color:var(--primary)}
.pp-ty-totals{display:flex;flex-direction:column;gap:10px}
.pp-ty-total-row{display:flex;justify-content:space-between;color:var(--text-dim);font-size:.9rem}
.pp-ty-total-row span:last-child,.pp-ty-total-row .amount{color:#fff;font-weight:700}
.pp-ty-total-final{
  font-size:1.125rem;font-weight:900;color:#fff;
  padding-top:12px;border-top:1px solid rgba(255,255,255,.08)
}
.pp-ty-total-final span:last-child,.pp-ty-total-final .amount{color:var(--primary)}

/* Timeline */
.pp-ty-timeline{margin-bottom:56px;text-align:left}
.pp-ty-timeline-title{
  font-size:1rem;font-weight:900;text-transform:uppercase;
  letter-spacing:.15em;margin-bottom:32px;text-align:center
}
.pp-ty-steps{display:flex;flex-direction:column;gap:0;position:relative;padding-left:24px}
.pp-ty-step{
  display:flex;gap:20px;padding-bottom:32px;position:relative;
  opacity:.35;transition:opacity .3s
}
.pp-ty-step.active{opacity:1}
.pp-ty-step::before{
  content:'';position:absolute;left:-13px;top:40px;
  width:2px;height:calc(100% - 40px);background:rgba(255,255,255,.1)
}
.pp-ty-step:last-child::before{display:none}
.pp-ty-step.active::before{background:var(--primary)}
.pp-ty-step-dot{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  background:rgba(255,255,255,.06);border:2px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  position:relative;z-index:2;color:var(--text-dim)
}
.pp-ty-step.active .pp-ty-step-dot{
  background:rgba(0,242,255,.15);border-color:var(--primary);color:var(--primary)
}
.pp-ty-step-content h4{font-size:.9rem;font-weight:800;margin-bottom:4px}
.pp-ty-step-content p{font-size:.85rem;color:var(--text-dim);line-height:1.6}

/* CTA */
.pp-ty-cta{text-align:center}

/* Failed state */
.pp-ty-failed{max-width:500px;margin:0 auto;padding:64px 40px;text-align:center}
.pp-ty-failed h2{font-size:1.5rem;margin-bottom:16px}
.pp-ty-failed p{color:var(--text-dim);margin-bottom:32px;line-height:1.7}


@media(min-width:1025px){
  .pp-node-inline{display:flex}
}

@media(max-width:1024px){
  .pp-hero-inner{grid-template-columns:1fr;gap:40px}
  .pp-hero-visual{order:-1}
  .pp-hero-img{max-width:460px;margin:0 auto}
  .pp-about-inner{flex-direction:column}
  .pp-about-content{padding:32px}
  .pp-about-img-wrap{min-height:300px}
  .pp-about-img-overlay{background:linear-gradient(to bottom,var(--bg),transparent)}
  .pp-product-layout{grid-template-columns:1fr;gap:48px}
  .pp-gallery-main img{padding:20px}
  .pp-product-gallery{position:static}
  .pp-footer-top{flex-direction:column;gap:40px}
  .pp-cart-layout{grid-template-columns:1fr}
  .pp-product-card:nth-child(3n){grid-column:span 1}
  /* Landing page responsive */
  .pp-lp-hero-grid{grid-template-columns:1fr;gap:40px}
  .pp-reviews-grid{grid-template-columns:repeat(2,1fr)}
}

/* ========================================================
   13. MARQUEE & SHOP PILLS DIVIDERS
   ======================================================== */
.pp-marquee-divider {
  width: 100vw; max-width: 100%; overflow: hidden; background: linear-gradient(90deg, var(--bg) 0%, rgba(0,242,255,0.05) 50%, var(--bg) 100%);
  color: var(--primary); padding: 24px 0; display: flex; white-space: nowrap; user-select: none;
  border-top: 1px solid rgba(0,242,255,0.2); border-bottom: 1px solid rgba(0,242,255,0.2); position: relative; z-index: 10;
}
.pp-marquee-inner { display: flex; flex-wrap: nowrap; align-items: center; animation: scroll-left 25s linear infinite; }
.pp-marquee-inner:hover { animation-play-state: paused; }
.pp-mq-text { font-weight: 900; font-size: 1.25rem; letter-spacing: 0.15em; padding: 0 32px; text-transform: uppercase; color: #fff; text-shadow: 0 0 15px rgba(0,242,255,0.4); }
.pp-mq-separator { padding: 0 32px; font-size: 1.5rem; opacity: 0.7; color: var(--primary); }
@keyframes scroll-left { 0% { transform: translateX(0); } 100% { transform: translateX(-33.33333%); } }

.pp-shop-categories-wrap { 
  display: flex; gap: 12px; overflow-x: auto; padding: 16px 8px; margin: 32px auto 0;
  max-width: 1200px; -webkit-overflow-scrolling: touch; scrollbar-width: none;
}
.pp-shop-categories-wrap::-webkit-scrollbar { display: none; }
.pp-cat-pill {
  flex-shrink: 0; padding: 12px 24px; border-radius: 999px; background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.1); color: #fff; font-size: 0.9rem; font-weight: 700;
  letter-spacing: 0.05em; text-transform: uppercase; text-decoration: none; transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  backdrop-filter: blur(10px);
}
.pp-cat-pill:hover { background: rgba(255,255,255,0.1); transform: translateY(-3px); box-shadow: 0 8px 20px rgba(0,0,0,0.3); }
.pp-cat-pill.active { background: var(--primary); color: var(--bg); border-color: var(--primary); box-shadow: 0 0 20px rgba(0,242,255,0.4); }

/* ========================================================
   14. SALES CONVERSION BOOSTER (STICKY CART, WOO AJAX)
   ======================================================== */
@keyframes ppPulseRed { 0% { opacity:1; } 50% { opacity:.5; box-shadow:0 0 15px rgba(255,107,107,.4); } 100% { opacity:1; } }

/* Premium Reveal (Lightweight CSS transition) */
.pp-premium-reveal {
  opacity: 0;
  filter: blur(8px);
  transform: translateY(20px);
  transition: opacity 0.6s ease-out, filter 0.6s ease-out, transform 0.6s cubic-bezier(0.23, 1, 0.32, 1);
}
.pp-premium-reveal.visible {
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
}

/* Replace WooCommerce "Wait" Screen thoroughly */
.woocommerce .blockUI.blockOverlay {
  background: rgba(10, 10, 15, 0.75) !important;
  backdrop-filter: blur(10px) !important;
  opacity: 1 !important; z-index: 1000 !important; cursor: wait !important;
}
.woocommerce .blockUI.blockOverlay::before {
  content: ''; position: absolute; top: 50%; left: 50%;
  width: 48px; height: 48px; margin: -24px 0 0 -24px;
  border: 4px solid rgba(0, 242, 255, 0.1);
  border-top-color: var(--primary); border-radius: 50%;
  animation: ppWooSpin 0.8s linear infinite; box-shadow: 0 0 20px rgba(0,242,255,0.3);
}
@keyframes ppWooSpin { to { transform: rotate(360deg); } }

/* Sticky Cart */
.pp-sticky-cart-bar {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 999;
  background: rgba(10, 10, 15, 0.9); backdrop-filter: blur(20px);
  border-top: 1px solid rgba(0,242,255,0.2); box-shadow: 0 -10px 40px rgba(0,0,0,0.7);
  padding: 16px 24px; transform: translateY(150%);
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  display: flex; justify-content: center;
}
/* Trigger via JS logic later, but for fallback: force visible on mobile when scrolling could be tricky without JS, let's just make it active via JS */
.pp-sticky-cart-bar.active { transform: translateY(0); }
.pp-sticky-cart-inner { width: 100%; max-width: 1200px; display: flex; justify-content: space-between; align-items: center; }
.pp-sticky-info { display: flex; align-items: center; gap: 16px; }
.pp-sticky-info img { width: 48px; height: 48px; border-radius: 8px; object-fit: cover; border: 1px solid rgba(255,255,255,0.1); }
.pp-sticky-text { display: flex; flex-direction: column; }
.pp-sticky-title { font-weight: 700; font-size: 1rem; color: #fff; }
.pp-sticky-price { color: var(--primary); font-weight: 900; }
.pp-sticky-btn { height: 48px; padding: 0 40px; font-size: 1rem; border-radius: 999px; }

@media (max-width: 768px) {
  /* Hide info on mobile sticking cart, keep just the huge button */
  .pp-sticky-info { display: none; }
  .pp-sticky-btn { width: 100%; height: 56px; font-size: 1.1rem; }
  .pp-sticky-cart-bar { padding: 12px 16px; }
  
  /* Mobile Checkout UX Boosts */
  .woocommerce-checkout input[type="text"],
  .woocommerce-checkout input[type="email"],
  .woocommerce-checkout input[type="tel"],
  .woocommerce-checkout select {
    min-height: 52px !important;
    font-size: 16px !important; /* Prevents auto-zoom on iOS */
  }
  .pp-offer-grid{grid-template-columns:1fr;gap:32px}
}
/* ========================================================
   ULTRA-RESPONSIVE CONFIGURATION (ALL DEVICES)
   ======================================================== */
@media (max-width: 1200px) {
  .pp-header-inner, .pp-hero-inner, .pp-about-inner, .pp-footer-inner, .pp-cart-layout, .pp-checkout-layout {
    padding-left: 24px; padding-right: 24px;
  }
}
@media (max-width: 768px) {
  /* Layout Normalize */
  .pp-header { padding: 6px 12px; width: 100%; }
  .pp-menu, .pp-nav-divider { display: none; }
  .pp-mobile-toggle { display: block; }
  
  /* Sections & Containers */
  .pp-hero { padding: 70px 16px 50px; }
  .pp-products-section, .pp-about, .pp-footer { padding-left: 16px; padding-right: 16px; }
  .pp-footer-top { grid-template-columns: 1fr; }
  .pp-about-inner { padding: 0; }
  .pp-about-content { padding: 24px 16px; }
  .pp-single-product { padding: 24px 16px 60px; }
  .pp-cart-container { padding: 90px 16px 60px; }
  .pp-lp-container { padding: 0 16px; }
  .pp-lp-hero { padding: 24px 16px 60px; }
  
  /* Grids to Stack */
  .pp-lp-hero-grid, .pp-product-layout { grid-template-columns: 1fr; gap: 40px; }
  .pp-products-grid, ul.products { grid-template-columns: 1fr; grid-auto-rows: auto; gap: 24px; padding: 40px 16px; }
  .pp-gallery-main { aspect-ratio: 1; width: 100%; height: auto; min-height: unset; display: flex; align-items: center; justify-content: center; overflow: hidden; }
  .pp-gallery-main img { object-fit: contain; width: 100%; height: 100%; padding: 20px; box-sizing: border-box; }
  .pp-benefits-grid, .pp-reviews-grid, .pp-product-guarantees { grid-template-columns: 1fr; }
  .pp-offer-grid { grid-template-columns: 1fr; gap: 32px; }
  .pp-checkout-layout, .pp-cart-layout { grid-template-columns: 1fr; gap: 24px; }
  
  /* Cart & Checkout Elements */
  .pp-cart-item { flex-direction: column; gap: 16px; align-items: stretch; text-align: center; }
  .pp-cart-item-img-wrap { width: 100%; height: 200px; }
  .pp-cart-item-name { font-size: 1.25rem; }
  .pp-checkout-section, .pp-order-summary { padding: 20px 16px; margin-top: 24px; position: static; }
  .pp-checkout-progress { display: none; }
  .pp-ty-summary { padding: 24px 16px; }
  .pp-ty-item { flex-direction: column; align-items: flex-start; gap: 8px; }
  
  /* Dynamic Typography for very small screens */
  .pp-scrolling-text { font-size: 6rem; letter-spacing: 0.1em; }
  .pp-hero-title { font-size: clamp(2.5rem, 8vw, 3.5rem); line-height: 1.1; word-break: break-word; }
  .pp-product-title { font-size: clamp(1.5rem, 6vw, 2.5rem); word-break: break-word; }
  
  /* Cards & Components */
  .pp-offer-card { padding: 24px 16px; }
  .pp-countdown { flex-wrap: wrap; justify-content: center; gap: 6px; }
  .pp-cd-block { min-width: 50px; padding: 8px 10px; }
  .pp-cd-num { font-size: 1.25rem; }
  .pp-trust-row { flex-direction: column; text-align: center; gap: 12px; }
  .pp-cta-buy-btn { padding: 16px 24px; font-size: 0.95rem; width: 100%; }
  .pp-ty-icon-wrap { width: 56px; height: 56px; margin-bottom: 20px; }
  .pp-ty-checkmark { width: 56px; height: 56px; }
}

@media (max-width: 480px) {
  /* Extreme Micro-device tuning (e.g., iPhone SE) */
  .pp-btn, .pp-card-add-btn { padding: 12px 20px; font-size: 11px; }
  .pp-hero-actions { flex-direction: column; width: 100%; }
  .pp-hero-actions .pp-btn { width: 100%; justify-content: center; }
  .pp-card-title { font-size: 1.1rem; }
  .pp-products-grid, ul.products { grid-template-columns: 1fr; }
}

/* ── MOBILE TOUCH & ACCESSIBILITY IMPROVEMENTS ─────── */
@media (max-width: 768px) {
  /* Ensure tap targets are large enough (min 44px) */
  .pp-btn, .pp-card-add-btn, .pp-overlay-btn,
  .woocommerce a.button, .woocommerce button.button {
    min-height: 44px;
    touch-action: manipulation;
  }
  /* Stop double-tap zoom on interactive elements */
  button, a, input, select, textarea {
    touch-action: manipulation;
  }
  /* Prevent text from being too small on mobile */
  .pp-card-cat, .pp-footer-copy, .pp-mq-text { font-size: 0.85rem; }
  /* Eliminate horizontal scroll caused by any overflowing elements */
  section, .pp-hero, .pp-about, .pp-footer { max-width: 100%; overflow-x: hidden; }
}

/* ── ELEMENTOR COMPATIBILITY ─────────────────────────── */
.elementor-section, .elementor-widget-wrap { background: transparent !important; }
body.elementor-editor-active .pp-header { z-index: 1000; }
body.elementor-editor-active .pp-sticky-cart-bar { display: none !important; }

/* ── PRINT STYLES ───────────────────────────────────── */
@media print {
  .pp-header, .pp-footer, .pp-sticky-cart-bar, .pp-mobile-menu { display: none !important; }
  body { background: #fff !important; color: #000 !important; }
}

