/* ── Veo 3 Prompt Builder — builder.css ────────────────── */
:root {
  --veo-accent:      #7F77DD;
  --veo-accent-lt:   #EEEDFE;
  --veo-accent-dk:   #534AB7;
  --veo-green:       #1D9E75;
  --veo-amber:       #BA7517;
  --veo-radius:      10px;
  --veo-radius-sm:   7px;
}

/* Wrapper */
#veo3-app-root { font-size: 16px; line-height: 1.6; color: #1a1a1a; }
.veo3-wrap { max-width: 760px; margin: 0 auto; padding: 1.5rem 0 3rem; }

/* ── Header ── */
.veo3-header {
  display: flex; align-items: center; gap: 10px;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid #e5e5e5;
  margin-bottom: 1.75rem;
}
.veo3-logo-dot {
  width: 30px; height: 30px; border-radius: 8px;
  background: var(--veo-accent);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.veo3-header-title { font-size: 16px; font-weight: 600; letter-spacing: -0.2px; }
.veo3-badge {
  margin-left: auto; font-size: 11px; font-weight: 500;
  color: #555; background: #f0f0f0;
  border-radius: 20px; padding: 3px 10px;
}
.veo3-badge.veo3-badge-pro { background: var(--veo-accent-lt); color: var(--veo-accent-dk); }

/* ── Step track ── */
.veo3-track { display: flex; gap: 4px; margin-bottom: 2rem; }
.veo3-dot { height: 3px; flex: 1; border-radius: 2px; background: #e0e0e0; transition: background .35s; }
.veo3-dot.done   { background: var(--veo-accent); }
.veo3-dot.active { background: var(--veo-accent); opacity: .45; }

/* ── Question area ── */
.veo3-q-area { }
.veo3-fade { animation: vFade .22s ease; }
@keyframes vFade { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:none; } }

.veo3-qlabel  { font-size: 11px; font-weight: 600; letter-spacing: .8px; text-transform: uppercase; color: #888; margin-bottom: .4rem; }
.veo3-qtitle  { font-size: 21px; font-weight: 700; letter-spacing: -.4px; margin-bottom: .3rem; color: #111; line-height:1.3; }
.veo3-qsub    { font-size: 13px; color: #666; margin-bottom: 1.4rem; }

/* ── Textarea ── */
.veo3-textarea {
  width: 100%; border: 1px solid #d5d5d5; border-radius: var(--veo-radius);
  padding: 11px 13px; font-size: 14px; font-family: inherit;
  background: #fff; color: #111; resize: vertical; min-height: 58px;
  transition: border-color .15s; line-height: 1.6; box-sizing: border-box;
  margin-bottom: 1rem;
}
.veo3-textarea:focus { outline: none; border-color: var(--veo-accent); }
.veo3-textarea::placeholder { color: #bbb; }

/* ── Options grid ── */
.veo3-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(155px,1fr)); gap: 7px; margin-bottom: 1.1rem; }
.veo3-opt {
  background: #fff; border: 1px solid #ddd; border-radius: var(--veo-radius-sm);
  padding: 9px 13px; cursor: pointer; text-align: left; transition: all .12s;
  color: #333; font-size: 13px; display: flex; align-items: center; gap: 8px; line-height: 1.35;
}
.veo3-opt-icon { font-size: 16px; flex-shrink: 0; }
.veo3-opt:hover { border-color: var(--veo-accent); background: var(--veo-accent-lt); color: var(--veo-accent-dk); }
.veo3-opt.sel   { border-color: var(--veo-accent); background: var(--veo-accent-lt); color: var(--veo-accent-dk); font-weight: 600; }

/* ── Tags ── */
.veo3-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 1.2rem; }
.veo3-tag {
  background: #fff; border: 1px solid #ddd; border-radius: 20px;
  padding: 5px 13px; font-size: 12px; cursor: pointer; color: #555; transition: all .12s;
}
.veo3-tag:hover { border-color: var(--veo-accent); color: var(--veo-accent-dk); }
.veo3-tag.sel   { background: var(--veo-accent-lt); border-color: var(--veo-accent); color: var(--veo-accent-dk); font-weight: 600; }

/* ── Follow-up ── */
.veo3-followup { margin-bottom: .5rem; }
.veo3-field-label { font-size: 12px; font-weight: 600; color: #666; margin-bottom: 5px; letter-spacing: .2px; }

/* ── Nav buttons ── */
.veo3-btn-row  { display: flex; gap: 8px; align-items: center; margin-top: .5rem; }
.veo3-btn-next {
  background: var(--veo-accent); color: #fff; border: none;
  border-radius: var(--veo-radius-sm); padding: 10px 22px;
  font-size: 14px; font-weight: 600; cursor: pointer;
  transition: opacity .15s, transform .1s; display: inline-flex; align-items: center; gap: 6px;
  text-decoration: none;
}
.veo3-btn-next:hover { opacity: .86; color:#fff; }
.veo3-btn-next:active { transform: scale(.98); }
.veo3-btn-next:disabled { opacity: .35; cursor: default; }
.veo3-btn-back {
  background: transparent; border: 1px solid #d5d5d5;
  border-radius: var(--veo-radius-sm); padding: 10px 16px;
  font-size: 13px; color: #666; cursor: pointer; transition: border-color .12s, color .12s;
  text-decoration: none;
}
.veo3-btn-back:hover { border-color: #aaa; color: #333; }
.veo3-skip { margin-left: auto; font-size: 12px; color: #aaa; cursor: pointer; text-decoration: underline; text-underline-offset: 2px; }
.veo3-skip:hover { color: #777; }

/* ── Paywall ── */
.veo3-paywall {
  text-align: center; padding: 3rem 1.5rem;
  border: 1px dashed #ccc; border-radius: var(--veo-radius); background: #fafafa;
  margin-top: 1rem;
}
.veo3-pw-icon { font-size: 36px; margin-bottom: .75rem; color: var(--veo-accent); }
.veo3-paywall h3 { font-size: 19px; font-weight: 700; margin-bottom: .5rem; color: #111; }
.veo3-paywall p  { font-size: 14px; color: #666; margin-bottom: 1.25rem; }
.veo3-pw-btns { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin-bottom: 1rem; }
.veo3-pw-sub { font-size: 12px; color: #aaa; }

/* ── Result summary cards ── */
.veo3-summary { display: grid; grid-template-columns: repeat(auto-fill,minmax(130px,1fr)); gap: 8px; margin-bottom: 1.4rem; }
.veo3-sc { background: #f5f5f5; border-radius: var(--veo-radius-sm); padding: 9px 12px; }
.veo3-sc-lbl { font-size: 10px; color: #999; margin-bottom: 3px; letter-spacing: .3px; text-transform: uppercase; }
.veo3-sc-val { font-size: 12px; font-weight: 600; color: #222; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ── JSON output ── */
.veo3-json-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: .7rem; }
.veo3-json-title  { font-size: 16px; font-weight: 700; color: #111; letter-spacing: -.2px; }
.veo3-copy-btn {
  font-size: 12px; font-weight: 600; color: var(--veo-accent-dk);
  background: var(--veo-accent-lt); border: none; border-radius: var(--veo-radius-sm);
  padding: 6px 14px; cursor: pointer; transition: opacity .15s;
}
.veo3-copy-btn:hover { opacity: .78; }
.veo3-json-box {
  background: #f7f7f9; border: 1px solid #e5e5e5; border-radius: var(--veo-radius);
  padding: 1.2rem; font-family: 'Courier New', Courier, monospace; font-size: 12.5px;
  line-height: 1.75; overflow-x: auto; white-space: pre-wrap; word-break: break-word;
  color: #222; max-height: 440px; overflow-y: auto;
}
.jk   { color: var(--veo-accent); }
.js   { color: var(--veo-green); }
.jnum { color: var(--veo-amber); }
.jb   { color: #D85A30; }
.jn   { color: #aaa; }

/* ────────────────────────────────────────────────────────
   Upgrade / Pricing page  [veo3_upgrade]
──────────────────────────────────────────────────────── */
#veo3-upgrade-page { max-width: 860px; margin: 0 auto; padding: 2rem 0 4rem; font-family: inherit; }
.veo3-pricing-hero { text-align: center; margin-bottom: 2.5rem; }
.veo3-pricing-hero h2 { font-size: 28px; font-weight: 800; letter-spacing: -.5px; color: #111; margin-bottom: .5rem; }
.veo3-pricing-hero p  { font-size: 15px; color: #666; }

.veo3-pricing-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; margin-bottom: 1.5rem; }

.veo3-plan-card {
  background: #fff; border: 1px solid #e0e0e0; border-radius: 14px;
  padding: 1.5rem; position: relative;
}
.veo3-plan-featured { border: 2px solid var(--veo-accent); }

.veo3-plan-badge {
  display: inline-block; font-size: 11px; font-weight: 700;
  background: var(--veo-accent-lt); color: var(--veo-accent-dk);
  border-radius: 20px; padding: 3px 10px; margin-bottom: .7rem;
}
.veo3-badge-green { background: #e1f5ee; color: #0f6e56; }

.veo3-plan-label { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; color: #888; margin-bottom: .3rem; }
.veo3-plan-price { font-size: 34px; font-weight: 800; color: #111; margin-bottom: 1rem; letter-spacing: -1px; }
.veo3-plan-price span { font-size: 14px; font-weight: 400; color: #999; }

.veo3-plan-card ul { list-style: none; padding: 0; margin: 0 0 1.25rem; }
.veo3-plan-card ul li { font-size: 13px; color: #444; padding: 4px 0; }
.veo3-plan-card ul li.muted { color: #bbb; }

.veo3-payment-buttons { display: flex; flex-direction: column; gap: 8px; }
.veo3-current-plan { display: block; font-size: 13px; color: #aaa; margin-top: .5rem; text-align: center; }
.veo3-secure-note { text-align: center; font-size: 12px; color: #aaa; }

/* ── Dark mode support ── */
@media (prefers-color-scheme: dark) {
  #veo3-app-root, .veo3-wrap { color: #e8e8e8; }
  .veo3-qtitle { color: #fff; }
  .veo3-textarea { background: #1e1e1e; color: #e8e8e8; border-color: #3a3a3a; }
  .veo3-opt { background: #1e1e1e; border-color: #3a3a3a; color: #ccc; }
  .veo3-opt.sel, .veo3-opt:hover { background: #2a2660; border-color: var(--veo-accent); color: #c8c4f8; }
  .veo3-tag { background: #1e1e1e; border-color: #3a3a3a; color: #aaa; }
  .veo3-tag.sel { background: #2a2660; border-color: var(--veo-accent); color: #c8c4f8; }
  .veo3-json-box { background: #1a1a1a; border-color: #333; color: #e8e8e8; }
  .veo3-sc { background: #222; }
  .veo3-sc-val { color: #e8e8e8; }
  .veo3-paywall { background: #1a1a1a; border-color: #333; }
  .veo3-paywall h3 { color: #eee; }
  .veo3-btn-back { color: #aaa; border-color: #444; }
  .veo3-dot { background: #333; }
  .veo3-header { border-color: #333; }
  .veo3-plan-card { background: #1e1e1e; border-color: #333; color: #e8e8e8; }
  .veo3-plan-card ul li { color: #ccc; }
  .veo3-plan-price { color: #eee; }
}
