/*
Theme Name: PixverseAI DE
Theme URI: https://pixverseai.de/
Author: PixverseAI
Author URI: https://pixverseai.de/
Description: Cinematic dark WordPress theme for Pixverse AI — built for German YouTubers and content creators. Features a glowing violet/cyan AI-video aesthetic, one-click homepage demo importer, and an InVideo "Try first, pay later" partner CTA. Optimised for all devices and SEO-ready.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: pixverseai-de
Tags: dark, blog, one-column, custom-colors, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, full-width-template
*/

/* ==========================================================================
   Design Tokens — Cinematic Dark (Violet × Cyan)
   ========================================================================== */
:root{
  --pv-bg:           #07060d;
  --pv-bg-2:         #0d0a1a;
  --pv-surface:      #131027;
  --pv-surface-2:    #1a1633;
  --pv-border:       rgba(124,58,237,.22);
  --pv-text:         #ECEAF5;
  --pv-muted:        #9892B0;
  --pv-violet:       #7C3AED;
  --pv-violet-2:     #A855F7;
  --pv-cyan:         #06B6D4;
  --pv-cyan-2:       #22D3EE;
  --pv-pink:         #EC4899;
  --pv-grad:         linear-gradient(135deg,#7C3AED 0%,#06B6D4 100%);
  --pv-grad-soft:    linear-gradient(135deg,rgba(124,58,237,.18),rgba(6,182,212,.14));
  --pv-glow-v:       0 0 60px rgba(124,58,237,.45);
  --pv-glow-c:       0 0 60px rgba(6,182,212,.35);
  --pv-radius:       16px;
  --pv-radius-sm:    10px;
  --pv-shadow:       0 20px 60px -20px rgba(0,0,0,.7), 0 0 0 1px var(--pv-border);
  --pv-font-display: 'Space Grotesk', 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --pv-font-body:    'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --pv-container:    1200px;
}

/* Reset / Base */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--pv-font-body);
  background:var(--pv-bg);
  color:var(--pv-text);
  line-height:1.65;
  font-size:16px;
  overflow-x:hidden;
  background-image:
    radial-gradient(1200px 600px at 80% -10%, rgba(124,58,237,.18), transparent 60%),
    radial-gradient(900px 500px at -10% 30%, rgba(6,182,212,.12), transparent 60%);
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--pv-cyan-2); text-decoration:none; transition:color .2s; }
a:hover{ color:var(--pv-violet-2); }
h1,h2,h3,h4,h5,h6{ font-family:var(--pv-font-display); font-weight:700; line-height:1.15; margin:0 0 .6em; letter-spacing:-.02em; color:#fff; }
h1{ font-size:clamp(2.2rem,5vw,4rem); }
h2{ font-size:clamp(1.7rem,3.4vw,2.6rem); }
h3{ font-size:clamp(1.2rem,2vw,1.5rem); }
p{ margin:0 0 1em; color:var(--pv-text); }
.pv-container{ max-width:var(--pv-container); margin:0 auto; padding:0 24px; }
.pv-muted{ color:var(--pv-muted); }
.pv-grad-text{
  background:var(--pv-grad);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
}

/* ==========================================================================
   Header / Nav
   ========================================================================== */
.pv-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  background:rgba(7,6,13,.7);
  border-bottom:1px solid var(--pv-border);
}
.pv-nav{ display:flex; align-items:center; justify-content:space-between; padding:14px 0; gap:24px; }
.pv-brand{ display:flex; align-items:center; gap:10px; font-family:var(--pv-font-display); font-weight:700; font-size:1.25rem; color:#fff; }
.pv-brand img{ width:34px; height:34px; }
.pv-brand span small{ display:block; font-size:.65rem; letter-spacing:.18em; color:var(--pv-muted); text-transform:uppercase; font-weight:500; }
.pv-menu{ display:flex; gap:6px; list-style:none; padding:0; margin:0; }
.pv-menu a{ color:var(--pv-text); padding:8px 14px; border-radius:999px; font-size:.95rem; font-weight:500; transition:background .2s, color .2s; }
.pv-menu a:hover, .pv-menu .current-menu-item a{ background:rgba(124,58,237,.18); color:#fff; }
.pv-nav-cta{ display:flex; gap:10px; align-items:center; }
.pv-burger{ display:none; background:none; border:1px solid var(--pv-border); color:#fff; padding:8px 10px; border-radius:10px; cursor:pointer; }
@media(max-width:900px){
  .pv-menu, .pv-nav-cta .pv-btn-ghost{ display:none; }
  .pv-burger{ display:inline-flex; }
  .pv-menu.is-open{ display:flex; flex-direction:column; position:absolute; top:100%; left:0; right:0; background:var(--pv-bg-2); padding:16px; border-bottom:1px solid var(--pv-border); }
}

/* ==========================================================================
   Buttons
   ========================================================================== */
.pv-btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:14px 26px; border-radius:999px; font-weight:600; font-size:.98rem; cursor:pointer; transition:transform .15s, box-shadow .25s, background .25s; border:0; line-height:1; text-align:center; }
.pv-btn-primary{ background:var(--pv-grad); color:#fff; box-shadow:0 12px 30px -10px rgba(124,58,237,.6); }
.pv-btn-primary:hover{ transform:translateY(-2px); box-shadow:0 18px 40px -10px rgba(124,58,237,.8); color:#fff; }
.pv-btn-ghost{ background:rgba(255,255,255,.04); color:#fff; border:1px solid var(--pv-border); }
.pv-btn-ghost:hover{ background:rgba(124,58,237,.18); color:#fff; }
.pv-btn-lg{ padding:18px 34px; font-size:1.05rem; }

/* ==========================================================================
   Hero
   ========================================================================== */
.pv-hero{ position:relative; padding:80px 0 90px; overflow:hidden; }
.pv-hero::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(800px 400px at 70% 30%, rgba(168,85,247,.22), transparent 60%),
    radial-gradient(600px 400px at 20% 70%, rgba(34,211,238,.18), transparent 60%);
  pointer-events:none;
}
.pv-hero-grid{ position:relative; display:grid; grid-template-columns:1.1fr 1fr; gap:56px; align-items:center; }
@media(max-width:900px){ .pv-hero-grid{ grid-template-columns:1fr; gap:40px; } }
.pv-eyebrow{ display:inline-flex; align-items:center; gap:8px; padding:6px 14px; border-radius:999px; background:var(--pv-grad-soft); border:1px solid var(--pv-border); color:#fff; font-size:.8rem; font-weight:500; letter-spacing:.06em; text-transform:uppercase; margin-bottom:20px; }
.pv-eyebrow .dot{ width:8px; height:8px; border-radius:50%; background:var(--pv-cyan); box-shadow:0 0 12px var(--pv-cyan); }
.pv-hero h1 span{ display:inline-block; }
.pv-hero p.lead{ font-size:1.15rem; color:var(--pv-muted); max-width:560px; margin:0 0 28px; }
.pv-hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:24px; }
.pv-hero-trust{ display:flex; gap:18px; flex-wrap:wrap; align-items:center; color:var(--pv-muted); font-size:.88rem; }
.pv-hero-trust b{ color:#fff; font-weight:600; }
.pv-hero-visual{ position:relative; aspect-ratio:16/12; border-radius:24px; overflow:hidden; box-shadow:var(--pv-shadow); border:1px solid var(--pv-border); }
.pv-hero-visual::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 60%,rgba(7,6,13,.6)); }
.pv-hero-visual img{ width:100%; height:100%; object-fit:cover; }
.pv-hero-badge{ position:absolute; bottom:18px; left:18px; right:18px; z-index:2; display:flex; gap:10px; flex-wrap:wrap; }
.pv-chip{ padding:8px 14px; background:rgba(13,10,26,.85); border:1px solid var(--pv-border); border-radius:999px; font-size:.78rem; color:#fff; backdrop-filter:blur(8px); }

/* ==========================================================================
   Logo strip / Marquee
   ========================================================================== */
.pv-strip{ padding:30px 0; border-top:1px solid var(--pv-border); border-bottom:1px solid var(--pv-border); background:rgba(13,10,26,.5); }
.pv-strip-inner{ display:flex; flex-wrap:wrap; gap:32px 56px; align-items:center; justify-content:center; color:var(--pv-muted); font-size:.85rem; letter-spacing:.16em; text-transform:uppercase; }
.pv-strip-inner b{ color:#fff; font-weight:600; }

/* ==========================================================================
   Sections (generic)
   ========================================================================== */
.pv-section{ padding:90px 0; position:relative; }
.pv-section-head{ max-width:760px; margin:0 auto 56px; text-align:center; }
.pv-section-head .pv-eyebrow{ margin-bottom:14px; }
.pv-section-head p{ color:var(--pv-muted); font-size:1.05rem; }

/* Features */
.pv-features{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media(max-width:900px){ .pv-features{ grid-template-columns:1fr; } }
.pv-card{
  background:linear-gradient(180deg,var(--pv-surface),var(--pv-surface-2));
  border:1px solid var(--pv-border); border-radius:var(--pv-radius); padding:28px;
  position:relative; overflow:hidden; transition:transform .25s, box-shadow .25s, border-color .25s;
}
.pv-card:hover{ transform:translateY(-6px); border-color:rgba(124,58,237,.5); box-shadow:0 24px 60px -20px rgba(124,58,237,.4); }
.pv-card .pv-icon{ width:48px; height:48px; border-radius:12px; display:grid; place-items:center; background:var(--pv-grad); margin-bottom:16px; box-shadow:var(--pv-glow-v); }
.pv-card .pv-icon svg{ width:24px; height:24px; color:#fff; }
.pv-card h3{ margin:0 0 8px; }
.pv-card p{ color:var(--pv-muted); margin:0; font-size:.95rem; }

/* Showcase row */
.pv-showcase{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
.pv-showcase.reverse{ direction:rtl; }
.pv-showcase.reverse > *{ direction:ltr; }
@media(max-width:900px){ .pv-showcase{ grid-template-columns:1fr; } .pv-showcase.reverse{ direction:ltr; } }
.pv-showcase-img{ border-radius:20px; overflow:hidden; border:1px solid var(--pv-border); box-shadow:var(--pv-shadow); aspect-ratio:5/4; }
.pv-showcase-img img{ width:100%; height:100%; object-fit:cover; }
.pv-showcase ul{ list-style:none; padding:0; margin:18px 0 24px; }
.pv-showcase li{ display:flex; gap:10px; align-items:flex-start; padding:6px 0; color:var(--pv-text); }
.pv-showcase li::before{ content:""; width:18px; height:18px; flex-shrink:0; margin-top:4px; border-radius:50%; background:var(--pv-grad); box-shadow:0 0 12px rgba(124,58,237,.6); }

/* Steps */
.pv-steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; counter-reset:step; }
@media(max-width:900px){ .pv-steps{ grid-template-columns:1fr; } }
.pv-step{ background:var(--pv-surface); border:1px solid var(--pv-border); border-radius:var(--pv-radius); padding:28px; position:relative; }
.pv-step::before{ counter-increment:step; content:"0" counter(step); position:absolute; top:18px; right:22px; font-family:var(--pv-font-display); font-size:2.2rem; font-weight:700; background:var(--pv-grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; opacity:.9; }
.pv-step h3{ margin-top:0; padding-right:60px; }

/* Partner CTA */
.pv-partner{
  position:relative; padding:64px; border-radius:24px; overflow:hidden;
  background:linear-gradient(135deg, rgba(124,58,237,.25), rgba(6,182,212,.18));
  border:1px solid var(--pv-border); box-shadow:var(--pv-shadow);
  display:grid; grid-template-columns:1.4fr 1fr; gap:40px; align-items:center;
}
.pv-partner::before{ content:""; position:absolute; inset:0; background:radial-gradient(600px 300px at 80% 20%, rgba(168,85,247,.35), transparent 60%); pointer-events:none; }
@media(max-width:900px){ .pv-partner{ grid-template-columns:1fr; padding:36px; } }
.pv-partner h2{ margin-top:0; }
.pv-partner-badge{ display:inline-flex; align-items:center; gap:8px; padding:6px 12px; background:rgba(7,6,13,.6); border:1px solid var(--pv-border); border-radius:999px; font-size:.78rem; color:var(--pv-cyan-2); letter-spacing:.14em; text-transform:uppercase; margin-bottom:14px; }
.pv-partner-stats{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.pv-stat{ background:rgba(7,6,13,.55); border:1px solid var(--pv-border); border-radius:var(--pv-radius-sm); padding:18px; text-align:center; }
.pv-stat b{ display:block; font-family:var(--pv-font-display); font-size:1.8rem; background:var(--pv-grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.pv-stat span{ color:var(--pv-muted); font-size:.85rem; }

/* Pricing / Try-Pay */
.pv-pay{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media(max-width:900px){ .pv-pay{ grid-template-columns:1fr; } }
.pv-pay-card{ background:var(--pv-surface); border:1px solid var(--pv-border); border-radius:var(--pv-radius); padding:32px; position:relative; }
.pv-pay-card.is-featured{ border-color:rgba(124,58,237,.7); box-shadow:0 20px 60px -20px rgba(124,58,237,.5); transform:translateY(-8px); }
.pv-pay-card.is-featured::before{ content:"Empfohlen"; position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--pv-grad); color:#fff; padding:4px 14px; border-radius:999px; font-size:.75rem; font-weight:600; letter-spacing:.08em; }
.pv-pay-price{ font-family:var(--pv-font-display); font-size:2.4rem; font-weight:700; margin:8px 0; }
.pv-pay-price small{ font-size:.9rem; color:var(--pv-muted); font-weight:500; }
.pv-pay-card ul{ list-style:none; padding:0; margin:18px 0 24px; }
.pv-pay-card li{ padding:6px 0; color:var(--pv-text); display:flex; gap:10px; align-items:flex-start; }
.pv-pay-card li::before{ content:"✓"; color:var(--pv-cyan-2); font-weight:700; }

/* FAQ */
.pv-faq{ max-width:820px; margin:0 auto; display:grid; gap:14px; }
.pv-faq details{ background:var(--pv-surface); border:1px solid var(--pv-border); border-radius:var(--pv-radius-sm); padding:20px 24px; transition:border-color .2s; }
.pv-faq details[open]{ border-color:rgba(124,58,237,.5); }
.pv-faq summary{ cursor:pointer; font-weight:600; color:#fff; font-family:var(--pv-font-display); list-style:none; display:flex; justify-content:space-between; gap:14px; }
.pv-faq summary::after{ content:"+"; color:var(--pv-cyan-2); font-size:1.4rem; transition:transform .2s; }
.pv-faq details[open] summary::after{ transform:rotate(45deg); }
.pv-faq p{ margin:14px 0 0; color:var(--pv-muted); }

/* Final CTA */
.pv-cta-final{ text-align:center; padding:80px 24px; border-radius:24px; background:var(--pv-grad-soft); border:1px solid var(--pv-border); position:relative; overflow:hidden; }
.pv-cta-final::before{ content:""; position:absolute; inset:0; background:radial-gradient(800px 400px at 50% 0%, rgba(124,58,237,.3), transparent 60%); pointer-events:none; }
.pv-cta-final h2{ margin-top:0; }
.pv-cta-final .pv-hero-cta{ justify-content:center; }

/* Footer */
.pv-footer{ background:#050409; padding:64px 0 28px; border-top:1px solid var(--pv-border); margin-top:80px; }
.pv-footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; }
@media(max-width:900px){ .pv-footer-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:600px){ .pv-footer-grid{ grid-template-columns:1fr; } }
.pv-footer h4{ font-size:.85rem; letter-spacing:.16em; text-transform:uppercase; color:var(--pv-muted); font-weight:600; margin:0 0 16px; font-family:var(--pv-font-body); }
.pv-footer ul{ list-style:none; padding:0; margin:0; }
.pv-footer li{ margin-bottom:10px; }
.pv-footer a{ color:var(--pv-text); font-size:.92rem; }
.pv-footer a:hover{ color:var(--pv-cyan-2); }
.pv-footer-bottom{ margin-top:48px; padding-top:24px; border-top:1px solid var(--pv-border); display:flex; justify-content:space-between; flex-wrap:wrap; gap:16px; color:var(--pv-muted); font-size:.85rem; }

/* Admin notice for demo importer */
.pv-import-notice{ padding:14px 18px; }
.pv-import-notice .pv-btn{ padding:8px 18px; font-size:.9rem; }

/* Utilities */
.sr-only{ position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }

/* Print */
@media print{ .pv-header,.pv-footer,.pv-hero-visual{ display:none; } body{ background:#fff; color:#000; } }
