@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Outfit:wght@300;400;500;600;700&display=swap');

.wpvs {
  --bg:       #080810;
  --surface:  #0f0f1a;
  --card:     #15151f;
  --border:   rgba(255,255,255,0.06);
  --border-h: rgba(255,255,255,0.12);
  --text:     #ebebf5;
  --muted:    #6b6b80;
  --accent:   #e8622a;
  --gold:     #e8b84b;
  --teal:     #2dd4aa;
  --lavender: #a78bfa;
  --r:        14px;
  --r-sm:     9px;
  --font:     'Outfit', sans-serif;
  --serif:    'Instrument Serif', serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
.wpvs{font-family:var(--font);background:var(--bg);min-height:100vh;color:var(--text)}

/* ── HEADER ── */
.wpvs-hd{padding:32px 36px 0;display:flex;align-items:center;gap:16px;border-bottom:1px solid var(--border);padding-bottom:0}
.wpvs-hd-logo{width:42px;height:42px;background:linear-gradient(135deg,var(--accent),#c0440f);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 4px 16px rgba(232,98,42,0.35);flex-shrink:0}
.wpvs-hd-title{font-family:var(--serif);font-size:22px;font-style:italic;letter-spacing:-.3px;background:linear-gradient(90deg,#fff 50%,var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.wpvs-hd-sub{font-size:12px;color:var(--muted);margin-top:1px}

/* ── TABS ── */
.wpvs-tabs{display:flex;gap:0;padding:0 36px;margin-top:0;border-bottom:1px solid var(--border)}
.wpvs-tab{font-family:var(--font);font-size:13px;font-weight:500;color:var(--muted);padding:16px 20px;border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .18s ease;letter-spacing:.2px}
.wpvs-tab:hover{color:var(--text)}
.wpvs-tab.active{color:var(--text);border-bottom-color:var(--accent)}
.wpvs-tab-icon{margin-right:7px;font-size:15px}

/* ── PANELS ── */
.wpvs-panel{display:none;padding:32px 36px 60px}
.wpvs-panel.active{display:grid;grid-template-columns:1fr 340px;gap:32px}
@media(max-width:780px){.wpvs-panel.active{grid-template-columns:1fr}.wpvs-panel,.wpvs-hd,.wpvs-tabs{padding-left:20px;padding-right:20px}}

/* ── UPLOAD ZONE ── */
.wpvs-upload{border:1.5px dashed var(--border-h);border-radius:var(--r);background:var(--surface);cursor:pointer;transition:all .2s;position:relative;overflow:hidden;margin-bottom:20px;min-height:260px;display:flex;align-items:center;justify-content:center}
.wpvs-upload:hover,.wpvs-upload.drag{border-color:var(--accent);background:rgba(232,98,42,0.04)}
.wpvs-upload.has-img{min-height:0;border-style:solid;border-color:var(--border)}
.wpvs-upload-ph{text-align:center;padding:40px 24px;pointer-events:none}
.wpvs-upload-ph .ico{font-size:36px;opacity:.35;display:block;margin-bottom:10px}
.wpvs-upload-ph h3{font-size:15px;font-weight:600;margin-bottom:5px}
.wpvs-upload-ph p{font-size:12px;color:var(--muted)}
.wpvs-upload.has-img .wpvs-upload-ph{display:none}
#wpvsPPhotoPreview,#wpvsBPhotoPreview{width:100%;max-height:320px;object-fit:cover;display:block}
.wpvs-change-btn{position:absolute;bottom:10px;right:10px;background:rgba(0,0,0,0.72);border:1px solid var(--border-h);color:var(--text);font-family:var(--font);font-size:11px;padding:5px 11px;border-radius:7px;cursor:pointer;display:none;backdrop-filter:blur(6px)}
.wpvs-upload.has-img .wpvs-change-btn{display:block}

/* ── CAMERA BTN ── */
.wpvs-camera-row{display:flex;gap:8px;margin-bottom:20px}
.wpvs-cam-btn{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--muted);font-family:var(--font);font-size:12px;padding:10px;cursor:pointer;transition:all .18s;display:flex;align-items:center;justify-content:center;gap:6px}
.wpvs-cam-btn:hover{border-color:var(--border-h);color:var(--text)}

/* ── SECTION LABEL ── */
.wpvs-lbl{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.9px;color:var(--muted);display:block;margin-bottom:10px}

/* ── TEXT FIELDS (banner) ── */
.wpvs-fields{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.wpvs-field{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);display:flex;align-items:center;gap:10px;padding:0 14px;transition:border-color .18s}
.wpvs-field:focus-within{border-color:var(--accent)}
.wpvs-field-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);white-space:nowrap;min-width:56px}
.wpvs-field input{flex:1;background:none;border:none;color:var(--text);font-family:var(--font);font-size:14px;padding:13px 0;outline:none}
.wpvs-field input::placeholder{color:var(--muted);font-weight:300}

/* ── INTENT FIELD (photo) ── */
.wpvs-intent-wrap{margin-bottom:20px}
.wpvs-intent{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);font-family:var(--font);font-size:14px;padding:14px 16px;resize:none;min-height:90px;transition:border-color .18s;line-height:1.5}
.wpvs-intent:focus{outline:none;border-color:var(--accent)}
.wpvs-intent::placeholder{color:var(--muted);font-weight:300}
.wpvs-intent-hint{font-size:11px;color:var(--muted);margin-top:7px}
.wpvs-intent-hint span{color:var(--lavender);cursor:pointer}
.wpvs-intent-hint span:hover{text-decoration:underline}

/* ── QUICK INTENTS (photo) ── */
.wpvs-quick-intents{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:20px}
.wpvs-qi{background:var(--card);border:1px solid var(--border);border-radius:99px;color:var(--muted);font-family:var(--font);font-size:12px;padding:7px 14px;cursor:pointer;transition:all .18s}
.wpvs-qi:hover{border-color:var(--border-h);color:var(--text)}
.wpvs-qi.active{border-color:var(--accent);color:var(--accent);background:rgba(232,98,42,0.08)}

/* ── GENERATE BTN ── */
.wpvs-gen{width:100%;background:linear-gradient(135deg,var(--accent),#c0440f);border:none;border-radius:var(--r-sm);color:#fff;font-family:var(--font);font-size:15px;font-weight:600;padding:16px;cursor:pointer;letter-spacing:.2px;transition:all .2s;box-shadow:0 4px 18px rgba(232,98,42,0.28)}
.wpvs-gen:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 24px rgba(232,98,42,0.38)}
.wpvs-gen:disabled{opacity:.45;cursor:not-allowed;transform:none}

/* ── RIGHT SIDEBAR ── */
.wpvs-sidebar{display:flex;flex-direction:column;gap:20px}
.wpvs-sidebar-block{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:18px}

/* ── CATEGORY GRID ── */
.wpvs-cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.wpvs-cat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 10px;cursor:pointer;transition:all .18s;font-family:var(--font);font-size:12px;color:var(--muted);text-align:left;line-height:1.25}
.wpvs-cat:hover{border-color:var(--border-h);color:var(--text)}
.wpvs-cat.active{border-color:var(--teal);color:var(--teal);background:rgba(45,212,170,0.07)}

/* ── MOOD GRID ── */
.wpvs-mood-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.wpvs-mood{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:11px 10px;cursor:pointer;transition:all .18s;font-family:var(--font);font-size:12px;color:var(--muted);text-align:left}
.wpvs-mood .mood-name{display:block;font-weight:500;margin-bottom:2px;color:var(--text)}
.wpvs-mood .mood-desc{font-size:10px;color:var(--muted)}
.wpvs-mood:hover{border-color:var(--border-h)}
.wpvs-mood.active{border-color:var(--gold);background:rgba(232,184,75,0.07)}
.wpvs-mood.active .mood-name{color:var(--gold)}

/* ── FORMAT SELECT ── */
.wpvs-fmt-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.wpvs-fmt{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px;cursor:pointer;transition:all .18s;font-family:var(--font);font-size:11px;color:var(--muted);text-align:center}
.wpvs-fmt .fmt-label{display:block;font-weight:600;color:var(--text);margin-bottom:2px;font-size:12px}
.wpvs-fmt .fmt-ratio{font-size:10px;color:var(--muted)}
.wpvs-fmt:hover{border-color:var(--border-h)}
.wpvs-fmt.active{border-color:var(--lavender);background:rgba(167,139,250,0.07)}
.wpvs-fmt.active .fmt-label{color:var(--lavender)}

/* ── PROGRESS ── */
.wpvs-prog{display:none;margin-top:16px}
.wpvs-prog-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:13px;color:var(--muted)}
.wpvs-prog-row strong{color:var(--text);font-weight:500}
.wpvs-dots{display:inline-flex;gap:3px}
.wpvs-dots i{width:5px;height:5px;border-radius:50%;background:var(--accent);display:inline-block;animation:dp 1.2s ease infinite}
.wpvs-dots i:nth-child(2){animation-delay:.2s}
.wpvs-dots i:nth-child(3){animation-delay:.4s}
@keyframes dp{0%,80%,100%{transform:scale(.55);opacity:.35}40%{transform:scale(1);opacity:1}}
.wpvs-bar{height:2px;background:var(--border);border-radius:99px;overflow:hidden}
.wpvs-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--gold));border-radius:99px;width:0%;transition:width .4s ease}

/* ── RESULT ── */
.wpvs-result{display:none;margin-top:20px}
.wpvs-cmp{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.wpvs-cmp-side{position:relative}
.wpvs-cmp-side img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--r-sm);border:1px solid var(--border);display:block}
.wpvs-cmp-badge{position:absolute;bottom:7px;left:7px;background:rgba(0,0,0,0.7);backdrop-filter:blur(5px);border:1px solid var(--border-h);border-radius:6px;padding:2px 8px;font-size:10px;color:var(--muted);font-weight:600}
.wpvs-cmp-badge.new{color:var(--accent);border-color:rgba(232,98,42,.3)}
.wpvs-result-full{width:100%;border-radius:var(--r-sm);border:1px solid var(--border);display:block;margin-bottom:14px}
.wpvs-result-actions{display:flex;gap:8px}
.wpvs-dl{flex:1;background:rgba(255,255,255,0.05);border:1px solid var(--border-h);border-radius:var(--r-sm);color:var(--text);font-family:var(--font);font-size:13px;font-weight:500;padding:11px;text-decoration:none;text-align:center;transition:all .18s;display:block}
.wpvs-dl:hover{background:rgba(255,255,255,0.09);color:var(--text)}
.wpvs-new-btn{background:transparent;border:1px solid var(--border);border-radius:var(--r-sm);color:var(--muted);font-family:var(--font);font-size:13px;padding:11px 14px;cursor:pointer;transition:all .18s}
.wpvs-new-btn:hover{color:var(--text);border-color:var(--border-h)}
.wpvs-ai-note{font-size:11px;color:var(--muted);margin-top:10px;padding:8px 12px;background:rgba(167,139,250,0.07);border:1px solid rgba(167,139,250,0.15);border-radius:var(--r-sm)}

/* ── ERROR ── */
.wpvs-err{display:none;background:rgba(220,50,30,0.1);border:1px solid rgba(220,50,30,0.25);border-radius:var(--r-sm);padding:11px 14px;font-size:13px;color:#f08070;margin-top:12px}

/* ── PIN ── */
.wpvs-pin{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);font-family:var(--font)}
.wpvs-pin-box{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:40px;width:290px;text-align:center}
.wpvs-pin-box h2{font-family:var(--serif);font-size:22px;font-style:italic;margin-bottom:22px}
.wpvs-pin-box input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);font-size:18px;text-align:center;padding:13px;margin-bottom:12px;letter-spacing:5px;font-family:var(--font)}
.wpvs-pin-box button{width:100%;background:linear-gradient(135deg,var(--accent),#c0440f);border:none;border-radius:var(--r-sm);color:#fff;font-family:var(--font);font-size:14px;font-weight:600;padding:13px;cursor:pointer}

/* ── CINEMATIC EFFECTS GRID ── */
.wpvs-cine-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px}
.wpvs-cine-btn{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:12px 14px;cursor:pointer;transition:all .2s;font-family:var(--font);text-align:left;color:var(--muted)}
.wpvs-cine-btn:hover{border-color:var(--border-h);color:var(--text)}
.wpvs-cine-btn.active{border-color:var(--accent);background:rgba(232,98,42,0.08);color:var(--text)}
.cine-label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:3px}
.cine-desc{display:block;font-size:11px;color:var(--muted)}
.wpvs-cine-btn.active .cine-label{color:var(--accent)}

/* ── ARTICLE CTA ── */
.wpvs-article-cta{margin-top:16px}
.wpvs-article-box{display:flex;align-items:center;gap:12px;background:rgba(167,139,250,0.07);border:1px solid rgba(167,139,250,0.2);border-radius:var(--r-sm);padding:14px 16px}
.wpvs-article-icon{font-size:22px;flex-shrink:0}
.wpvs-article-box div{flex:1}
.wpvs-article-box strong{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px}
.wpvs-article-box span{font-size:11px;color:var(--muted)}
.wpvs-article-btn{flex-shrink:0;background:linear-gradient(135deg,#a78bfa,#7c3aed);border:none;border-radius:var(--r-sm);color:#fff;font-family:var(--font);font-size:12px;font-weight:600;padding:9px 14px;cursor:pointer;white-space:nowrap;transition:all .18s}
.wpvs-article-btn:hover{opacity:.88}
.wpvs-article-btn:disabled{opacity:.45;cursor:not-allowed}
.wpvs-article-result{margin-top:12px}
.wpvs-article-ready{padding:12px 14px;background:rgba(45,212,170,0.08);border:1px solid rgba(45,212,170,0.25);border-radius:var(--r-sm);font-size:13px;color:var(--teal)}
.wpvs-article-edit-link{color:var(--teal);text-decoration:underline;margin-left:8px}
.wpvs-article-prompt{padding:14px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-sm)}
.wpvs-article-prompt strong{display:block;font-size:12px;margin-bottom:8px;color:var(--lavender)}
.wpvs-article-prompt-text{font-size:12px;color:var(--muted);line-height:1.6;padding:10px;background:var(--surface);border-radius:6px;margin-bottom:8px;max-height:120px;overflow-y:auto}
.wpvs-copy-btn{background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:var(--font);font-size:11px;padding:6px 12px;cursor:pointer}
.wpvs-copy-btn:hover{border-color:var(--border-h)}

/* ── CINEMATIC UPLOAD LABEL ── */
.wpvs-upload-label{display:flex;cursor:pointer}
.wpvs-upload-label:hover,.wpvs-upload-label.drag{border-color:var(--accent);background:rgba(232,98,42,0.04)}
