/* ═══════════════════════════════════════════════════
   ROOT & RESET
═══════════════════════════════════════════════════ */
*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --bg:#07070e;
  --surface:#0f0f1a;
  --surface2:#161624;
  --surface3:#1e1e30;
  --surface4:#26263c;
  --border:#1f1f35;
  --border-hi:#2e2e4a;
  --accent:#8b7cf8;
  --accent2:#b09ffa;
  --accent3:#d4bbff;
  --gold:#e8c96d;
  --gold2:#f0a96b;
  --rose:#f4a5c0;
  --rose-soft:rgba(244,165,192,.1);
  --text:#f0f0fa;
  --text-muted:#6a6a95;
  --text-soft:#9898be;
  --error:#f87171;
  --error-soft:rgba(248,113,113,.08);
  --error-border:rgba(248,113,113,.22);
  --success:#34d399;
  --grad:linear-gradient(135deg,#8b7cf8 0%,#c084fc 100%);
  --grad-gold:linear-gradient(135deg,#e8c96d 0%,#f0a96b 100%);
  --grad-rose:linear-gradient(135deg,#f4a5c0 0%,#e8c96d 100%);
  --shadow-card:0 2px 0 rgba(255,255,255,.03) inset, 0 24px 64px rgba(0,0,0,.55);
  --panel-w:480px;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
}
@media(max-width:640px){:root{--panel-w:100vw;}}

::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:99px;}

body{
  font-family:var(--sans);
  background:var(--bg);color:var(--text);
  min-height:100vh;display:flex;flex-direction:column;
  -webkit-font-smoothing:antialiased;
}

/* ── INPUTS ── */
input[type=text],input[type=date],input[type=time],input[type=number],select,textarea{
  width:100%;padding:10px 14px;
  background:var(--surface3);
  border:1px solid var(--border-hi);
  border-radius:10px;color:var(--text);
  font-size:13px;font-family:var(--sans);
  outline:none;transition:border-color .15s,box-shadow .15s;
}
input[type=date],input[type=time]{cursor:pointer;color-scheme:dark;}
input::placeholder{color:var(--text-muted);}
input:focus,select:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(139,124,248,.15);
}
select option{background:var(--surface2);}
select.styled{
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7' viewBox='0 0 11 7'%3E%3Cpath fill='%236a6a95' d='M5.5 7L0 0h11z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 13px center;
  padding-right:34px;cursor:pointer;
}

/* ── BUTTONS ── */
.btn{
  width:100%;padding:12px 18px;border:none;border-radius:12px;
  font-size:13.5px;font-weight:600;cursor:pointer;
  transition:all .15s;font-family:var(--sans);letter-spacing:.01em;
}
.btn-primary{
  background:var(--grad);color:#fff;
  box-shadow:0 1px 0 rgba(255,255,255,.15) inset,0 6px 24px rgba(139,124,248,.4);
}
.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 1px 0 rgba(255,255,255,.15) inset,0 8px 28px rgba(139,124,248,.5);}
.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none;}
.btn-gold{
  background:var(--grad-gold);color:#1a1408;font-weight:700;
  box-shadow:0 1px 0 rgba(255,255,255,.2) inset,0 6px 24px rgba(232,201,109,.35);
}
.btn-gold:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 1px 0 rgba(255,255,255,.2) inset,0 8px 28px rgba(232,201,109,.5);}
.btn-gold:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none;}
.btn-ghost{
  background:var(--surface3);color:var(--text-soft);
  border:1px solid var(--border-hi);
}
.btn-ghost:hover:not(:disabled){border-color:var(--accent);color:var(--accent2);background:rgba(139,124,248,.08);}
.btn-ghost:disabled{opacity:.4;cursor:not-allowed;}

/* ── LAYOUT ── */
.app-body{flex:1;display:flex;overflow:hidden;height:100vh;}
.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative;transition:margin-right .32s cubic-bezier(.4,0,.2,1);}
@media(min-width:641px){.main-area.panel-shifted{margin-right:var(--panel-w);}}
.create-view{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding:32px 20px 48px;align-items:center;position:relative;}
.create-view>*{position:relative;z-index:1;}

/* ── SEO CONTENT ── */
.seo-content{
  width:min(940px,calc(100% - 32px));
  margin:0 auto 32px;
  padding:28px 30px;
  border:1px solid var(--border);
  border-radius:18px;
  background:linear-gradient(145deg,rgba(15,15,26,.9),rgba(22,22,36,.82));
  box-shadow:0 1px 0 rgba(255,255,255,.03) inset,0 20px 50px rgba(0,0,0,.32);
  color:var(--text-soft);
}
.seo-content h2{
  font-family:var(--serif);
  font-size:30px;
  font-weight:500;
  line-height:1.12;
  letter-spacing:.01em;
  color:var(--text);
  margin:0 0 10px;
}
.seo-content h2 + p,
.seo-content h2 + ul{margin-top:4px;}
.seo-content p{
  font-size:14px;
  line-height:1.72;
  color:var(--text-soft);
  margin:0;
}
.seo-content ul{
  margin:0;
  padding-left:20px;
  display:grid;
  gap:8px;
}
.seo-content li{
  font-size:14px;
  line-height:1.6;
  color:var(--text-soft);
}
.seo-content > * + h2{margin-top:24px;}

@media(max-width:860px){
  .seo-content{padding:24px 20px;}
  .seo-content h2{font-size:24px;}
}
@media(max-width:520px){
  .seo-content{
    width:calc(100% - 20px);
    padding:20px 16px;
    margin-bottom:20px;
    border-radius:14px;
  }
  .seo-content h2{font-size:21px;}
  .seo-content p,.seo-content li{font-size:13px;line-height:1.65;}
}


/* ── FORM CARD ── */
.form-card{width:100%;max-width:580px;display:flex;flex-direction:column;gap:0;position:relative;z-index:1;margin-bottom:32px;}

/* ── FORM HEADER ── */
.form-head{text-align:center;padding:0 0 28px;}
.form-head-badge{display:inline-flex;align-items:center;gap:7px;background:var(--rose-soft);border:1px solid rgba(244,165,192,.22);border-radius:99px;padding:5px 14px;font-size:11px;font-weight:600;color:var(--rose);letter-spacing:.04em;text-transform:uppercase;margin-bottom:14px;}
.form-head h1{font-family:var(--serif);font-size:32px;font-weight:300;letter-spacing:-.02em;background:var(--grad-rose);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.15;margin-bottom:8px;}
.form-head p{font-size:13px;color:var(--text-muted);font-weight:400;letter-spacing:.01em;}

/* ── PROGRESS ── */
.progress-wrap{margin-bottom:20px;}
.progress-steps{display:flex;align-items:center;justify-content:space-between;gap:0;margin-bottom:10px;}
.prog-step{display:flex;flex-direction:column;align-items:center;gap:5px;flex:1;position:relative;}
.prog-step:not(:last-child)::after{content:'';position:absolute;top:12px;left:calc(50% + 14px);right:calc(-50% + 14px);height:1px;background:var(--border-hi);transition:background .3s;}
.prog-step.done:not(:last-child)::after{background:var(--success);}
.prog-dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;border:1.5px solid var(--border-hi);background:var(--surface2);color:var(--text-muted);transition:all .25s;flex-shrink:0;z-index:1;}
.prog-step.active .prog-dot{border-color:var(--rose);background:rgba(244,165,192,.15);color:var(--rose);box-shadow:0 0 0 4px rgba(244,165,192,.1);}
.prog-step.done .prog-dot{border-color:var(--success);background:rgba(52,211,153,.15);color:var(--success);}
.prog-label{font-size:9px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;text-align:center;line-height:1;}
.prog-step.active .prog-label{color:var(--rose);}
.prog-step.done .prog-label{color:var(--success);}

/* ── STEP CARDS ── */
.step-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;overflow:hidden;margin-bottom:8px;transition:opacity .25s,border-color .25s,box-shadow .25s;box-shadow:0 1px 0 rgba(255,255,255,.02) inset;}
.step-card.step-locked{opacity:.25;pointer-events:none;}
.step-card.step-active{border-color:var(--border-hi);box-shadow:var(--shadow-card);}
.step-card.step-done{border-color:var(--border);opacity:1;}
.step-hd{display:flex;align-items:center;gap:10px;padding:13px 16px;background:var(--surface2);border-bottom:1px solid var(--border);}
.step-card.step-locked .step-hd{border-bottom-color:transparent;}
.step-card.step-done .step-hd{border-bottom:none;}
.step-num{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9.5px;font-weight:700;flex-shrink:0;border:1.5px solid var(--border-hi);background:var(--surface3);color:var(--text-muted);transition:all .25s;}
.step-card.step-active .step-num{border-color:var(--rose);background:rgba(244,165,192,.15);color:var(--rose);}
.step-card.step-done .step-num{border-color:var(--success);background:rgba(52,211,153,.15);color:var(--success);font-size:11px;}
.step-hd-info{flex:1;min-width:0;}
.step-hd-title{font-size:11.5px;font-weight:600;color:var(--text-soft);letter-spacing:.01em;}
.step-card.step-active .step-hd-title{color:var(--text);}
.step-hd-sub{font-size:10.5px;color:var(--text-muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:360px;}
.step-edit{font-size:10px;font-weight:600;color:var(--text-muted);background:var(--surface3);border:1px solid var(--border-hi);border-radius:6px;padding:3px 9px;cursor:pointer;transition:all .15s;font-family:inherit;display:none;}
.step-card.step-done .step-edit{display:block;}
.step-edit:hover{border-color:var(--rose);color:var(--rose);}
.step-body{padding:16px 16px 18px;display:flex;flex-direction:column;gap:12px;}
.step-card.step-done .step-body{display:none;}

/* ── FIELD GROUPS ── */
.field-group{display:flex;flex-direction:column;gap:6px;}
.field-label{font-size:10.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;}
.field-row{display:grid;gap:10px;}
.field-row-2{grid-template-columns:1fr 1fr;}
.field-row-3{grid-template-columns:1fr 1fr 1fr;}
.field-divider{height:1px;background:var(--border);margin:4px 0;}
.opt-pill{font-size:9px;font-weight:500;color:var(--text-muted);background:var(--surface3);border:1px solid var(--border-hi);border-radius:99px;padding:1px 7px;text-transform:none;letter-spacing:0;}
.picker-input-wrap{display:flex;align-items:center;}
.picker-input-wrap input[type=date],.picker-input-wrap input[type=time]{border:none;background:transparent;box-shadow:none;padding-right:4px;}
.picker-input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(139,124,248,.15);}
.picker-open-btn{width:28px;height:28px;border-radius:7px;border:1px solid var(--border-hi);background:var(--surface2);color:var(--text-soft);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:all .15s;}
.picker-open-btn:hover{border-color:var(--rose);color:var(--rose);}
.date-preview{font-size:11px;color:var(--text-muted);margin-top:2px;min-height:16px;}

/* ── EVENT CARDS ── */
.event-list{display:flex;flex-direction:column;gap:10px;}
.event-item{background:var(--surface2);border:1px solid var(--border-hi);border-radius:13px;overflow:hidden;position:relative;}
.event-item-hd{display:flex;align-items:center;gap:8px;padding:9px 12px;background:var(--surface3);border-bottom:1px solid var(--border);}
.event-num{font-size:10px;font-weight:700;color:var(--rose);background:rgba(244,165,192,.12);border:1px solid rgba(244,165,192,.2);border-radius:99px;padding:2px 8px;white-space:nowrap;}
.event-title-preview{font-size:11.5px;font-weight:500;color:var(--text-soft);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.event-remove{width:22px;height:22px;border-radius:6px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-size:13px;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:inherit;flex-shrink:0;}
.event-remove:hover{background:rgba(248,113,113,.1);color:var(--error);}
.event-item-body{padding:12px 13px;display:flex;flex-direction:column;gap:10px;}
.event-quick-times{display:flex;gap:6px;flex-wrap:wrap;}
.quick-time-btn{border:1px solid var(--border-hi);background:var(--surface2);color:var(--text-soft);border-radius:999px;padding:4px 9px;font-size:10.5px;cursor:pointer;transition:all .15s;}
.quick-time-btn:hover{border-color:var(--accent);color:var(--accent2);}
.add-event-btn{display:flex;align-items:center;justify-content:center;gap:7px;padding:11px;border:1.5px dashed var(--border-hi);border-radius:12px;background:transparent;color:var(--text-muted);cursor:pointer;font-size:12px;font-weight:500;font-family:inherit;transition:all .15s;}
.add-event-btn:hover{border-color:var(--rose);color:var(--rose);border-style:solid;background:rgba(244,165,192,.04);}

/* ── STYLE CHIPS ── */
.style-chips{display:flex;flex-wrap:wrap;gap:6px;}
.style-chip{border:1px solid var(--border-hi);background:var(--surface2);color:var(--text-soft);border-radius:8px;padding:6px 12px;font-size:11.5px;cursor:pointer;transition:all .15s;font-family:var(--sans);font-weight:500;}
.style-chip:hover{border-color:var(--rose);color:var(--rose);background:rgba(244,165,192,.06);}
.style-chip.selected{border-color:var(--rose);background:rgba(244,165,192,.12);color:var(--rose);box-shadow:0 0 0 3px rgba(244,165,192,.1);}
.border-preset-group{margin-top:8px;}
.border-chips{margin-top:6px;}
.border-chip{display:inline-flex;align-items:center;gap:6px;}
.border-chip-preview{width:18px;height:18px;display:inline-block;background:transparent;}
.custom-style-wrap{margin-top:6px;}
.custom-style-toggle{display:inline-flex;align-items:center;gap:5px;background:transparent;border:1px dashed var(--border-hi);color:var(--text-muted);border-radius:8px;padding:6px 12px;font-size:11.5px;cursor:pointer;transition:all .15s;font-family:inherit;}
.custom-style-toggle:hover{border-color:var(--rose);color:var(--rose);}
.custom-style-toggle.active{border-color:var(--rose);color:var(--rose);border-style:solid;}
.custom-style-input{margin-top:6px;display:none;}
.custom-style-input.show{display:block;}

/* ── LANG CHIPS ── */
.lang-chips{display:flex;flex-wrap:wrap;gap:5px;}
.lang-chip{border:1px solid var(--border-hi);background:var(--surface2);color:var(--text-soft);border-radius:8px;padding:5px 11px;font-size:11.5px;cursor:pointer;transition:all .15s;font-family:var(--sans);font-weight:500;}
.lang-chip:hover{border-color:var(--accent);color:var(--accent2);background:rgba(139,124,248,.07);}
.lang-chip.selected{border-color:var(--accent);background:rgba(139,124,248,.15);color:var(--accent2);box-shadow:0 0 0 3px rgba(139,124,248,.1);}

/* ── BACKGROUND PICKER IN STEP 3 ── */
.bg-picker-section{
  border:1px solid rgba(244,165,192,.18);
  border-radius:14px;
  background:linear-gradient(135deg,rgba(244,165,192,.05),rgba(232,201,109,.04));
  padding:14px 14px 16px;
  display:flex;flex-direction:column;gap:10px;
}
.bg-picker-section-head{
  display:flex;align-items:center;gap:8px;
}
.bg-picker-section-icon{font-size:16px;line-height:1;}
.bg-picker-section-title{font-size:11.5px;font-weight:700;color:var(--rose);text-transform:uppercase;letter-spacing:.06em;}
.bg-picker-section-sub{font-size:11px;color:var(--text-muted);margin-top:1px;}
.bg-preview-strip{
  display:flex;gap:7px;flex-wrap:wrap;
  max-height:92px;overflow-y:auto;
}
.bg-swatch{
  width:52px;height:52px;border-radius:9px;
  border:2px solid transparent;cursor:pointer;
  background-size:cover;background-position:center;
  flex-shrink:0;transition:all .18s;position:relative;
  overflow:hidden;
}
.bg-swatch::after{
  content:'';position:absolute;inset:0;border-radius:7px;
  background:rgba(0,0,0,.22);transition:background .18s;
}
.bg-swatch:hover::after{background:rgba(0,0,0,.05);}
.bg-swatch.selected{border-color:var(--rose);box-shadow:0 0 0 3px rgba(244,165,192,.3);}
.bg-swatch.selected::after{background:rgba(0,0,0,0);}
.bg-swatch-none{
  display:flex;align-items:center;justify-content:center;
  background:var(--surface3);font-size:16px;
  color:var(--text-muted);
}
.bg-swatch-none.selected{border-color:var(--accent);box-shadow:0 0 0 3px rgba(139,124,248,.25);}
.bg-chosen-label{font-size:10.5px;color:var(--text-muted);}
.bg-chosen-label span{color:var(--rose);font-weight:600;}
.color-pref-row{
  display: none;
  align-items:center;gap:10px;flex-wrap:wrap;
  padding:10px;border:1px solid var(--border-hi);border-radius:10px;background:var(--surface2);
}
.color-pref-label{font-size:11px;color:var(--text-soft);font-weight:600;letter-spacing:.03em;}
.color-pref-picker{
  width:34px;height:34px;border:none;background:transparent;padding:0;cursor:pointer;border-radius:8px;overflow:hidden;
}
.color-pref-text{
  max-width:200px;padding:7px 9px;border-radius:8px;border:1px solid var(--border-hi);background:var(--surface3);color:var(--text-soft);font-size:11px;
}
.bg-ai-option{
  display:flex;align-items:center;gap:9px;
  background:var(--surface2);border:1px solid var(--border-hi);
  border-radius:10px;padding:9px 12px;cursor:pointer;transition:all .15s;
}
.bg-ai-option:hover{border-color:var(--accent);background:rgba(139,124,248,.08);}
.bg-ai-option.selected{border-color:var(--accent);background:rgba(139,124,248,.12);box-shadow:0 0 0 3px rgba(139,124,248,.15);}
.bg-ai-option input[type=radio]{accent-color:var(--accent);cursor:pointer;}
.bg-ai-option-text{display:flex;flex-direction:column;gap:2px;}
.bg-ai-option-label{font-size:11.5px;font-weight:600;color:var(--text);letter-spacing:.01em;}
.bg-ai-option-sub{font-size:10.5px;color:var(--text-muted);}

/* ═══════════════════════════════════════════════════
   STEP 3 — CARD PREVIEW
═══════════════════════════════════════════════════ */
/* .step3-preview-wrap {
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(244,165,192,.22);
  background: var(--surface2);
  animation: previewFadeIn .3s ease;
} */
@keyframes previewFadeIn {
  from { opacity:0; transform:translateY(6px); }
  to   { opacity:1; transform:none; }
}
.step3-preview-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 13px 8px;
  background: linear-gradient(135deg, rgba(244,165,192,.07), rgba(232,201,109,.04));
  border-bottom: 1px solid rgba(244,165,192,.12);
}
.step3-preview-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  font-weight: 700;
  color: var(--rose);
  text-transform: uppercase;
  letter-spacing: .1em;
}
.step3-preview-label-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--rose);
  box-shadow: 0 0 6px var(--rose);
  animation: previewPulse 2s ease-in-out infinite;
}
@keyframes previewPulse {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.5; transform:scale(.8); }
}
.step3-preview-badge {
  font-size: 9.5px;
  color: var(--text-muted);
  font-weight: 500;
}
.step3-preview-stage {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px 16px;
  background: #070710;
  min-height: 180px;
  position: relative;
}
/* subtle vignette */
.step3-preview-stage::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 80% at 50% 50%, transparent 55%, rgba(7,7,16,.7));
  pointer-events: none;
  z-index: 2;
}
.step3-preview-frame {
  position: relative;
  border-radius: 8px;
  overflow: hidden;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.07),
    0 16px 56px rgba(0,0,0,.75),
    0 0 0 4px rgba(244,165,192,.06);
  z-index: 1;
  transition: box-shadow .3s;
}
.step3-preview-frame:hover {
  box-shadow:
    0 0 0 1px rgba(244,165,192,.2),
    0 20px 64px rgba(0,0,0,.8),
    0 0 0 4px rgba(244,165,192,.1);
}
.step3-preview-frame iframe {
  border: none;
  display: block;
  pointer-events: none;
  transform-origin: top left;
}
/* skeleton shimmer while iframe loads */
.step3-preview-frame.loading::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, var(--surface3) 25%, var(--surface4) 50%, var(--surface3) 75%);
  background-size: 200% 100%;
  animation: step3Shimmer 1.4s ease infinite;
  z-index: 10;
  border-radius: inherit;
}
@keyframes step3Shimmer { to { background-position:-200% 0; } }

.step3-preview-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 13px 9px;
  border-top: 1px solid rgba(244,165,192,.08);
  gap: 8px;
}
.step3-preview-footnote {
  font-size: 10px;
  color: var(--text-muted);
  font-style: italic;
  flex: 1;
}
.step3-preview-dims {
  font-size: 9.5px;
  color: var(--text-muted);
  font-weight: 600;
  letter-spacing: .04em;
  white-space: nowrap;
  flex-shrink: 0;
}

/* ── GENERATE STEP ── */
.gen-summary{display:flex;flex-direction:column;gap:6px;background:var(--surface2);border:1px solid var(--border-hi);border-radius:12px;padding:12px 14px;}
.gen-summary-row{display:flex;gap:8px;align-items:baseline;}
.gen-summary-key{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;min-width:72px;flex-shrink:0;}
.gen-summary-val{font-size:12px;color:var(--text-soft);font-weight:500;}
.gen-hint{font-size:11.5px;color:var(--text-muted);text-align:center;line-height:1.55;}
.token-cost-banner{display:flex;align-items:flex-start;gap:10px;background:linear-gradient(135deg,rgba(232,201,109,.14),rgba(240,169,107,.09));border:1px solid rgba(232,201,109,.35);border-radius:12px;padding:10px 12px;}
.token-cost-icon{font-size:16px;line-height:1.2;}
.token-cost-body{display:flex;flex-direction:column;gap:2px;}
.token-cost-title{font-size:11.5px;color:var(--gold);font-weight:700;letter-spacing:.03em;text-transform:uppercase;}
.token-cost-copy{font-size:11.5px;color:var(--text-soft);line-height:1.5;}
.token-cost-copy strong{color:#ffe5a8;font-weight:700;}

/* ── ERROR BANNER ── */
.gen-error-banner{display:none;background:var(--error-soft);border:1px solid var(--error-border);border-radius:12px;padding:13px 15px;gap:11px;align-items:flex-start;}
.gen-error-banner.show{display:flex;}
.gen-error-icon{font-size:16px;flex-shrink:0;line-height:1.3;filter:drop-shadow(0 0 6px rgba(248,113,113,.35));}
.gen-error-body{flex:1;min-width:0;}
.gen-error-title{font-size:12px;font-weight:700;color:#fca5a5;letter-spacing:.01em;margin-bottom:3px;}
.gen-error-msg{font-size:11.5px;color:rgba(252,165,165,.75);line-height:1.55;word-break:break-word;}
.gen-error-actions{display:flex;gap:7px;margin-top:9px;flex-wrap:wrap;}
.gen-error-retry{display:inline-flex;align-items:center;gap:5px;padding:5px 13px;border-radius:7px;border:none;background:rgba(248,113,113,.15);border:1px solid rgba(248,113,113,.3);color:#fca5a5;font-size:11px;font-weight:600;cursor:pointer;font-family:var(--sans);transition:all .15s;}
.gen-error-retry:hover{background:rgba(248,113,113,.25);border-color:rgba(248,113,113,.5);}
.gen-error-dismiss{display:inline-flex;align-items:center;gap:5px;padding:5px 13px;border-radius:7px;border:none;background:transparent;border:1px solid var(--border-hi);color:var(--text-muted);font-size:11px;font-weight:600;cursor:pointer;font-family:var(--sans);transition:all .15s;}
.gen-error-dismiss:hover{color:var(--text-soft);}

/* ── TOAST ── */
#toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%);background:var(--surface3);border:1px solid var(--border-hi);color:var(--text);padding:9px 20px;border-radius:99px;font-size:12.5px;font-weight:600;z-index:99;box-shadow:0 8px 28px rgba(0,0,0,.6);transition:opacity .22s;pointer-events:none;opacity:0;white-space:nowrap;}

/* ── GEN OVERLAY ── */
.gen-overlay{display:none;position:fixed;right:20px;bottom:20px;width:min(340px,calc(100vw - 32px));background:rgba(15,15,26,.94);backdrop-filter:blur(12px);border:1px solid rgba(244,165,192,.22);border-radius:18px;z-index:15;align-items:flex-start;flex-direction:column;gap:14px;padding:18px 18px 16px;box-shadow:0 24px 60px rgba(0,0,0,.45);}
.gen-overlay.show{display:flex;}
.gen-spinner{width:36px;height:36px;border:2.5px solid rgba(244,165,192,.2);border-top-color:var(--rose);border-radius:50%;animation:spin .9s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.gen-overlay-text{font-size:13.5px;color:var(--text-soft);font-weight:500;}
.gen-progress{width:100%;height:3px;border-radius:99px;background:var(--surface3);overflow:hidden;}
.gen-progress-fill{width:0%;height:100%;background:var(--grad-rose);transition:width .25s linear;}
.gen-timer{font-size:11px;color:var(--rose);font-weight:700;letter-spacing:.08em;}

/* ── BG SCENE ── */
.bg-scene{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden;}
.bg-scene::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(244,165,192,.07) 1px,transparent 1px);background-size:38px 38px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 10%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 10%,transparent 100%);opacity:.3;}
.bg-scene::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 5% 15%,rgba(244,165,192,.05) 0%,transparent 60%),radial-gradient(ellipse 40% 60% at 95% 85%,rgba(232,201,109,.04) 0%,transparent 60%),radial-gradient(ellipse 30% 30% at 50% 100%,rgba(244,165,192,.03) 0%,transparent 60%);}

/* ════════════════════════════════════════════════
   PREVIEW PANEL
════════════════════════════════════════════════ */
.panel-tab{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:12;display:flex;flex-direction:column;align-items:center;gap:6px;background:var(--surface2);border:1px solid var(--border-hi);border-right:none;border-radius:12px 0 0 12px;padding:14px 10px;cursor:pointer;transition:background .15s,border-color .15s,right .32s cubic-bezier(.4,0,.2,1);box-shadow:-3px 0 20px rgba(0,0,0,.4);user-select:none;appearance:none;font-family:inherit;}
.panel-tab:hover{background:var(--surface3);border-color:var(--rose);}
.panel-tab.panel-open{right:var(--panel-w);background:var(--surface3);border-color:var(--rose);}
.panel-count-badge{min-width:18px;height:18px;border-radius:99px;background:var(--grad-rose);color:#1a0a10;font-size:9.5px;font-weight:700;display:none;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 2px 8px rgba(244,165,192,.4);}
.panel-count-badge.show{display:flex;}
.panel-tab-label{font-size:9px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);transition:color .15s;}
.panel-tab.panel-open .panel-tab-label{color:var(--rose);}

.panel-backdrop{position:fixed;inset:0;background:rgba(7,7,14,.48);backdrop-filter:blur(2px);z-index:11;opacity:0;pointer-events:none;transition:opacity .22s ease;}
.panel-backdrop.show{opacity:1;pointer-events:auto;}

.preview-panel{position:fixed;right:0;top:0;bottom:0;width:var(--panel-w);background:var(--surface);border-left:1px solid var(--border-hi);z-index:12;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);box-shadow:-6px 0 40px rgba(0,0,0,.55);}
.preview-panel.panel-visible{transform:translateX(0);}
.panel-resizer{position:absolute;left:-4px;top:0;bottom:0;width:8px;cursor:col-resize;background:transparent;border:none;padding:0;z-index:2;touch-action:none;}
.panel-resizer::before{content:'';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:2px;height:68px;border-radius:999px;background:rgba(244,165,192,.32);opacity:.58;transition:background .15s,opacity .15s;}
.panel-resizer:hover::before{background:rgba(244,165,192,.72);opacity:1;}
body.panel-resizing{cursor:col-resize;user-select:none;}

@media(max-width:640px){
  .panel-resizer{display:none;}
  .preview-panel{top:auto;bottom:0;left:0;right:0;width:100vw;height:80vh;border-left:none;border-top:1px solid var(--border-hi);border-radius:20px 20px 0 0;transform:translateY(100%);}
  .preview-panel.panel-visible{transform:translateY(0);}
  .panel-tab{writing-mode:horizontal-tb;transform:none;flex-direction:row;right:0;}
  .panel-tab.panel-open{right:0;bottom:80vh;top:auto;transform:none;border-radius:12px 12px 0 0;border-right:1px solid var(--border-hi);border-bottom:none;padding:10px 14px;}
  .panel-tab-label{writing-mode:horizontal-tb;transform:none;}
}

.pp-head{padding:14px 16px 12px;border-bottom:1px solid var(--border);background:var(--surface2);display:flex;align-items:center;gap:10px;flex-shrink:0;}
.pp-head-title{font-family:var(--serif);font-size:17px;font-weight:400;flex:1;letter-spacing:-.01em;}
.pp-history-select{min-width:150px;max-width:200px;padding:5px 9px;border-radius:8px;border:1px solid var(--border-hi);background:var(--surface3);color:var(--text-soft);font-size:11px;font-family:inherit;}
.pp-close-btn{width:26px;height:26px;border-radius:50%;background:var(--surface3);border:1px solid var(--border-hi);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;transition:all .15s;font-family:inherit;flex-shrink:0;}
.pp-close-btn:hover{border-color:var(--rose);color:var(--rose);}

.pp-booklet-wrap{flex:1;overflow-y:auto;overflow-x:hidden;padding:0;background:var(--surface);}
.pp-booklet-wrap::-webkit-scrollbar{width:4px;}
.pp-booklet-wrap::-webkit-scrollbar-thumb{background:var(--border-hi);}

.pp-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:56px 32px;text-align:center;color:var(--text-muted);font-size:12.5px;line-height:1.6;height:100%;}
.pp-empty-icon{font-size:44px;opacity:.25;}

.pp-actions{padding:10px 12px;border-top:1px solid var(--border);display:flex;gap:7px;flex-shrink:0;}
.pp-btn{flex:1;padding:8px 10px;border:none;border-radius:9px;font-size:11.5px;font-weight:600;cursor:pointer;transition:all .15s;font-family:var(--sans);display:flex;align-items:center;justify-content:center;gap:5px;white-space:nowrap;}
.pp-btn-primary{background:var(--grad-rose);color:#1a0a10;box-shadow:0 3px 12px rgba(244,165,192,.3);}
.pp-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 5px 16px rgba(244,165,192,.45);}
.pp-btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none;}
.pp-btn-ghost{background:var(--surface2);color:var(--text-soft);border:1px solid var(--border-hi);}
.pp-btn-ghost:hover{border-color:var(--rose);color:var(--rose);background:rgba(244,165,192,.06);}
.pp-btn-pdf{background:var(--grad-gold);color:#1a1408;}
.pp-btn-pdf:hover:not(:disabled){transform:translateY(-1px);}
.pp-btn-pdf:disabled{opacity:.4;cursor:not-allowed;transform:none;}
.pp-btn-edit{background:var(--surface3);color:var(--text);border:1px solid var(--border-hi);}
.pp-btn-edit:hover:not(:disabled){border-color:var(--accent);color:var(--accent3);}
.pp-btn-edit:disabled{opacity:.4;cursor:not-allowed;}
.pp-btn-attach{background:rgba(244,165,192,.1);color:var(--rose);border:1px solid rgba(244,165,192,.34);}
.pp-btn-attach:hover:not(:disabled){background:rgba(244,165,192,.18);border-color:rgba(244,165,192,.55);}
.pp-btn-attach:disabled{opacity:.4;cursor:not-allowed;}

.dl-progress-bar{width:100%;height:4px;border-radius:99px;background:var(--surface3);overflow:hidden;display:none;}
.dl-progress-bar.show{display:block;}
.dl-progress-fill{height:100%;background:var(--grad-gold);transition:width .2s ease;width:0%;}

/* ── PREVIEW BG ATTACH MODAL ── */
.preview-bg-modal{
  position:fixed;inset:0;z-index:84;
  background:rgba(7,7,14,.78);backdrop-filter:blur(4px);
  display:none;align-items:flex-end;justify-content:center;
}
.preview-bg-modal.show{display:flex;}
.preview-bg-sheet{
  width:min(520px,100%);max-height:86vh;overflow:auto;
  background:var(--surface);border:1px solid var(--border-hi);border-bottom:none;
  border-radius:18px 18px 0 0;padding:14px 14px 12px;
  display:flex;flex-direction:column;gap:10px;
}
.preview-bg-head{display:flex;align-items:center;gap:9px;}
.preview-bg-title{font-size:12.5px;font-weight:700;color:var(--rose);letter-spacing:.03em;flex:1;}
.preview-bg-close{width:26px;height:26px;border-radius:7px;border:1px solid var(--border-hi);background:var(--surface3);color:var(--text-muted);cursor:pointer;}
.preview-bg-close:hover{border-color:var(--rose);color:var(--rose);}
.preview-bg-sub{font-size:11px;color:var(--text-muted);}
.preview-bg-actions{display:flex;gap:8px;}
.preview-bg-actions .pp-btn{padding:9px 12px;}

/* ── PHOTO UPLOAD SECTION ── */
.photo-upload-section{
  border:1px solid rgba(244,165,192,.18);
  border-radius:14px;
  background:linear-gradient(135deg,rgba(244,165,192,.05),rgba(232,201,109,.04));
  padding:14px 14px 16px;
  display:flex;flex-direction:column;gap:10px;
}
.photo-upload-head{display:flex;align-items:center;gap:8px;}
.photo-upload-icon{font-size:16px;line-height:1;}
.photo-upload-title{font-size:11.5px;font-weight:700;color:var(--rose);text-transform:uppercase;letter-spacing:.06em;}
.photo-upload-sub{font-size:11px;color:var(--text-muted);margin-top:1px;}

.photo-drop-zone{
  border:1.5px dashed rgba(244,165,192,.35);
  border-radius:11px;
  background:rgba(244,165,192,.03);
  padding:20px 16px;
  text-align:center;
  cursor:pointer;
  transition:all .18s;
  position:relative;
}
.photo-drop-zone:hover,.photo-drop-zone.drag-over{
  border-color:var(--rose);
  background:rgba(244,165,192,.07);
}
.photo-drop-zone input[type=file]{
  position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;
}
.photo-drop-label{font-size:12px;color:var(--text-muted);pointer-events:none;}
.photo-drop-label strong{color:var(--rose);font-weight:600;}
.photo-drop-hint{font-size:10.5px;color:var(--text-muted);margin-top:3px;pointer-events:none;}

.photo-grid{display:flex;flex-direction:column;gap:8px;}
.photo-item{
  display:flex;align-items:center;gap:10px;
  background:var(--surface2);border:1px solid var(--border-hi);
  border-radius:11px;padding:8px 10px;
  transition:border-color .15s;
}
.photo-item:hover{border-color:rgba(244,165,192,.3);}
.photo-thumb{
  width:48px;height:48px;border-radius:8px;
  object-fit:cover;flex-shrink:0;
  border:1px solid var(--border-hi);
  background:var(--surface3);
}
.photo-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px;}
.photo-size-badge{
  font-size:9.5px;color:var(--text-muted);
  font-weight:600;letter-spacing:.04em;
}
.photo-tag-input{
  width:100%;padding:5px 9px;
  background:var(--surface3);
  border:1px solid var(--border-hi);
  border-radius:7px;color:var(--text);
  font-size:11.5px;font-family:var(--sans);
  outline:none;transition:border-color .15s,box-shadow .15s;
}
.photo-tag-input:focus{
  border-color:var(--rose);
  box-shadow:0 0 0 2px rgba(244,165,192,.12);
}
.photo-tag-input::placeholder{color:var(--text-muted);}
.photo-remove-btn{
  width:24px;height:24px;border-radius:6px;border:none;
  background:transparent;color:var(--text-muted);
  cursor:pointer;font-size:13px;
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;flex-shrink:0;
}
.photo-remove-btn:hover{background:rgba(248,113,113,.1);color:var(--error);}
.photo-count-hint{font-size:10.5px;color:var(--text-muted);text-align:right;}

/* ── HTML VIEWER MODAL ── */
.html-modal-backdrop{
  position:fixed;inset:0;background:rgba(7,7,14,.78);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  display:none;align-items:center;justify-content:center;
  z-index:85;padding:18px;
}
.html-modal-backdrop.show{display:flex;}
.html-modal{
  width:min(980px,100%);max-height:min(84vh,860px);
  background:rgba(15,15,26,.96);
  border:1px solid rgba(244,165,192,.22);
  border-radius:16px;
  box-shadow:0 28px 80px rgba(0,0,0,.7);
  overflow:hidden;display:flex;flex-direction:column;
}
.html-modal-head{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;background:var(--surface2);
  border-bottom:1px solid var(--border);
}
.html-modal-title{
  font-size:12px;font-weight:700;color:var(--text);
  letter-spacing:.01em;flex:1;min-width:0;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.html-modal-actions{display:flex;gap:8px;align-items:center;}
.html-modal-btn{
  padding:7px 12px;border-radius:9px;border:1px solid var(--border-hi);
  background:var(--surface3);color:var(--text-soft);
  font-size:11.5px;font-weight:600;cursor:pointer;
  font-family:var(--sans);transition:all .15s;white-space:nowrap;
}
.html-modal-btn:hover{border-color:var(--rose);color:var(--rose);background:rgba(244,165,192,.06);}
.html-modal-btn.primary{
  background:var(--grad-rose);border-color:transparent;color:#1a0a10;
}
.html-modal-btn.primary:hover{transform:translateY(-1px);box-shadow:0 5px 16px rgba(244,165,192,.45);}
.html-modal-body{padding:12px 14px 14px;overflow:auto;}
.html-modal-text{
  width:100%;min-height:46vh;max-height:70vh;
  resize:vertical;
  overflow:auto;
  background:#0b1220;color:#e6edf3;
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  padding:12px 12px;
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,'Liberation Mono','Courier New',monospace;
  font-size:12px;line-height:1.45;
  tab-size:2;
  outline:none;
}
.html-modal-text:focus{border-color:rgba(244,165,192,.5);box-shadow:0 0 0 3px rgba(244,165,192,.12);}


/* ════════════════════════════════════════════════════════════
   SEO EDITORIAL SECTION
════════════════════════════════════════════════════════════ */
 
.seo-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .7s cubic-bezier(.4,0,.2,1), transform .7s cubic-bezier(.4,0,.2,1);
}
.seo-reveal.visible {
  opacity: 1;
  transform: none;
}
 
.seo-editorial {
  width: min(960px, calc(100% - 32px));
  margin: 0 auto 56px;
  position: relative;
}
 
.seo-ornament {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin-bottom: 48px;
}
.seo-ornament-line {
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(232,201,109,.35), transparent);
}
.seo-ornament-icon {
  font-size: 18px;
  opacity: .7;
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--gold);
  font-family: var(--serif);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(232,201,109,.6);
}
 
.seo-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.seo-grid-full {
  grid-column: 1 / -1;
}
 
.seo-card {
  border-radius: 18px;
  padding: 28px 28px 26px;
  position: relative;
  overflow: hidden;
  border: 1px solid var(--border-hi);
  background: linear-gradient(145deg, var(--surface), var(--surface2));
  transition: border-color .25s, box-shadow .25s, transform .25s;
}
.seo-card::before {
  content: '';
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .3s;
  pointer-events: none;
  background: radial-gradient(ellipse 80% 60% at 20% 30%, rgba(244,165,192,.05), transparent 70%);
}
.seo-card:hover {
  border-color: rgba(244,165,192,.2);
  box-shadow: 0 12px 40px rgba(0,0,0,.45), 0 0 0 1px rgba(244,165,192,.08);
  transform: translateY(-2px);
}
.seo-card:hover::before { opacity: 1; }
 
.seo-card-gold {
  background: linear-gradient(145deg, #0e0e1c, #141424);
  border-color: rgba(232,201,109,.2);
}
.seo-card-gold::before {
  background: radial-gradient(ellipse 80% 60% at 20% 30%, rgba(232,201,109,.06), transparent 70%);
}
.seo-card-gold:hover {
  border-color: rgba(232,201,109,.4);
  box-shadow: 0 12px 40px rgba(0,0,0,.45), 0 0 0 1px rgba(232,201,109,.12);
}
 
.seo-card-hero {
  background: linear-gradient(135deg, #0d0d1c 0%, #12101e 50%, #0b0b14 100%);
  border-color: rgba(244,165,192,.18);
  padding: 36px 32px 32px;
}
.seo-card-hero::after {
  content: '';
  position: absolute;
  top: -60px; right: -60px;
  width: 240px; height: 240px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(244,165,192,.07) 0%, transparent 70%);
  pointer-events: none;
}
 
.seo-card-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: 8px;
  background: rgba(244,165,192,.1);
  border: 1px solid rgba(244,165,192,.22);
  font-family: var(--serif);
  font-size: 13px;
  color: var(--rose);
  margin-bottom: 14px;
  font-style: italic;
}
.seo-card-gold .seo-card-num {
  background: rgba(232,201,109,.1);
  border-color: rgba(232,201,109,.25);
  color: var(--gold);
}
 
.seo-card-icon {
  font-size: 26px;
  margin-bottom: 12px;
  line-height: 1;
  display: block;
}
 
.seo-card h2 {
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: -.01em;
  color: var(--text);
  margin: 0 0 10px;
}
.seo-card-hero h2 {
  font-size: 27px;
  background: var(--grad-rose);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.seo-card-gold h2 {
  background: var(--grad-gold);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.seo-card p {
  font-size: 13.5px;
  line-height: 1.72;
  color: var(--text-muted);
  margin: 0;
  font-weight: 400;
}
.seo-card p strong {
  color: var(--text-soft);
  font-weight: 600;
}
 
.seo-features {
  list-style: none;
  margin: 14px 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 9px;
}
.seo-features li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
  line-height: 1.55;
  color: var(--text-muted);
}
.seo-features li::before {
  content: '✦';
  font-size: 8px;
  color: var(--rose);
  flex-shrink: 0;
  margin-top: 4px;
  opacity: .7;
}
.seo-card-gold .seo-features li::before {
  color: var(--gold);
}
 
.seo-stat-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 16px;
}
.seo-stat {
  background: rgba(244,165,192,.07);
  border: 1px solid rgba(244,165,192,.15);
  border-radius: 99px;
  padding: 5px 13px;
  font-size: 11px;
  font-weight: 600;
  color: var(--rose);
  letter-spacing: .04em;
  white-space: nowrap;
}
.seo-card-gold .seo-stat {
  background: rgba(232,201,109,.07);
  border-color: rgba(232,201,109,.18);
  color: var(--gold);
}
 
.seo-cta-strip {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 14px;
  padding: 20px 24px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(244,165,192,.06), rgba(232,201,109,.04));
  border: 1px solid rgba(244,165,192,.14);
}
.seo-cta-text {
  font-family: var(--serif);
  font-size: 16px;
  font-weight: 300;
  color: var(--text-soft);
  letter-spacing: .01em;
  font-style: italic;
}
.seo-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 20px;
  border-radius: 99px;
  border: 1px solid rgba(244,165,192,.3);
  background: rgba(244,165,192,.08);
  color: var(--rose);
  font-size: 11.5px;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--sans);
  letter-spacing: .04em;
  text-transform: uppercase;
  text-decoration: none;
  transition: all .15s;
}
.seo-cta-btn:hover {
  background: rgba(244,165,192,.16);
  border-color: var(--rose);
  transform: translateY(-1px);
}
 
@media (max-width: 680px) {
  .seo-grid { grid-template-columns: 1fr; }
  .seo-card { padding: 22px 18px 20px; }
  .seo-card-hero { padding: 26px 20px 22px; }
  .seo-card h2 { font-size: 19px; }
  .seo-card-hero h2 { font-size: 22px; }
  .seo-editorial { width: calc(100% - 20px); margin-bottom: 36px; }
  .seo-ornament { margin-bottom: 28px; }
}

/* ── VALIDATION MODAL ── */
.val-modal-backdrop {
  position: fixed; inset: 0; z-index: 86;
  background: rgba(7,7,14,.72); backdrop-filter: blur(6px);
  display: none; align-items: center; justify-content: center; padding: 20px;
  animation: val-fade-in .18s ease;
}
.val-modal-backdrop.show { display: flex; }
@keyframes val-fade-in { from { opacity: 0; } to { opacity: 1; } }

.val-modal {
  background: var(--surface2);
  border: 1px solid rgba(248,113,113,.3);
  border-radius: 18px;
  padding: 28px 24px 22px;
  max-width: 360px; width: 100%;
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  text-align: center;
  animation: val-slide-up .2s cubic-bezier(.4,0,.2,1);
  box-shadow: 0 24px 64px rgba(0,0,0,.6), 0 0 0 1px rgba(248,113,113,.1);
}
@keyframes val-slide-up {
  from { transform: translateY(16px); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}

.val-modal-icon {
  font-size: 32px; line-height: 1;
  width: 56px; height: 56px;
  border-radius: 50%;
  background: rgba(248,113,113,.1);
  border: 1px solid rgba(248,113,113,.25);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 2px;
}

.val-modal-title {
  font-size: 15px; font-weight: 700;
  color: #fca5a5; letter-spacing: .01em;
}

.val-modal-body {
  font-size: 13px; color: var(--text-soft);
  line-height: 1.6; margin-bottom: 4px;
}

.val-modal-body ul {
  list-style: none; padding: 0; margin: 8px 0 0;
  display: flex; flex-direction: column; gap: 6px; text-align: left;
}

.val-modal-body ul li {
  display: flex; align-items: flex-start; gap: 8px;
  font-size: 12.5px; color: rgba(252,165,165,.8);
}

.val-modal-body ul li::before {
  content: '•';
  color: var(--error); font-size: 14px; flex-shrink: 0; line-height: 1.4;
}

.val-modal-btn {
  margin-top: 4px;
  padding: 9px 32px;
  border-radius: 99px;
  border: none;
  background: rgba(248,113,113,.15);
  border: 1px solid rgba(248,113,113,.35);
  color: #fca5a5;
  font-size: 13px; font-weight: 600;
  cursor: pointer; font-family: var(--sans);
  transition: all .15s;
}
.val-modal-btn:hover {
  background: rgba(248,113,113,.26);
  border-color: rgba(248,113,113,.6);
}
/* 5-step progress — connector after step 4 (not step 5) */
.prog-step:nth-child(5):not(:last-child)::after { display: none; }


/* ── MOCKUP SIDE PANEL (right) ── */
.mockup-panel {
  position: fixed;
  right: 0;
  top:0;
  width: var(--panel-w);
  height: 100%;
  background: var(--surface);
  border-left: 1px solid var(--border-hi);
  z-index: 15;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform .32s cubic-bezier(.4,0,.2,1);
  box-shadow: -6px 0 40px rgba(0,0,0,.55);
}
.mockup-panel.panel-visible {
  transform: translateX(0);
}
.mockup-panel-body {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
}
@media (min-width: 641px) {
  .main-area.mockup-shifted { margin-right: var(--panel-w); }
}
/* mobile: slide up from bottom */
@media (max-width: 640px) {
  .mockup-panel {
    top: auto; left: 0; right: 0;
    width: 100vw; height: 75vh;
    border-left: none;
    border-top: 1px solid var(--border-hi);
    border-radius: 20px 20px 0 0;
    transform: translateY(100%);
  }
  .mockup-panel.panel-visible {
    transform: translateY(0);
  }
}

/* Single-flow mode (Aamantran): keep all sections visible in one scroll */
body.single-step-flow .progress-wrap{display:none;}
body.single-step-flow .step-card.step-locked,
body.single-step-flow .step-card.step-done,
body.single-step-flow .step-card.step-active{opacity:1;pointer-events:auto;}
body.single-step-flow .step-card.step-done .step-body{display:flex;}
body.single-step-flow .step-edit,
body.single-step-flow #btn-step1-next,
body.single-step-flow #btn-step2-next,
body.single-step-flow #btn-step3-next,
body.single-step-flow #btn-step4-next{display:none !important;}
