/* ============================================================
   ADVANCED FORGED SCOPE — CSS
   Same DNA as Forged Scope. Orange-red accent. Gold premium.
   ============================================================ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --bg:#08090d;--surface:#0f1117;--surface-2:#161921;--surface-3:#1d2029;
  --border:#252835;--border-active:#3d4155;
  --text:#e4e5ec;--text-dim:#8c8ea0;--text-muted:#4e5064;
  --accent:#e8553d;--accent-hover:#ec6b56;--accent-soft:rgba(232,85,61,0.1);--accent-border:rgba(232,85,61,0.25);
  --gold:#d4a853;--gold-soft:rgba(212,168,83,0.1);--gold-border:rgba(212,168,83,0.3);
  --green:#34d399;--green-soft:rgba(52,211,153,0.1);
  --amber:#f59e0b;--amber-soft:rgba(245,158,11,0.1);
  --red:#ef4444;--red-soft:rgba(239,68,68,0.1);
  --cyan:#06b6d4;--cyan-soft:rgba(6,182,212,0.08);--cyan-border:rgba(6,182,212,0.2);
  --radius:8px;--radius-lg:12px;--radius-xl:16px;
  --font:'Outfit',sans-serif;--mono:'JetBrains Mono',monospace;--display:'Playfair Display',serif;
}

html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}

/* ===== HEADER ===== */
.header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:56px;background:rgba(8,9,13,0.92);backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}
.header-left{display:flex;align-items:center}
.header-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text)}
.logo-mark{width:30px;height:30px;border-radius:7px;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff}
.logo-name{font-size:15px;font-weight:700}
.logo-sub{font-size:10px;color:var(--gold);font-weight:600;background:var(--gold-soft);border:1px solid var(--gold-border);padding:2px 8px;border-radius:10px;margin-left:6px}
.header-nav{display:flex;align-items:center;gap:14px}
.nav-link{font-size:13px;color:var(--text-dim);text-decoration:none;transition:color 0.15s}
.nav-link:hover{color:var(--text)}
.nav-btn{font-size:13px;font-weight:600;color:#fff;background:var(--accent);padding:7px 18px;border-radius:var(--radius);border:none;cursor:pointer;font-family:var(--font);transition:background 0.15s;text-decoration:none;display:inline-block}
.nav-btn:hover{background:var(--accent-hover)}
.nav-btn--outline{background:none;border:1px solid var(--border);color:var(--text-dim)}
.nav-btn--outline:hover{border-color:var(--accent-border);color:var(--text)}
.access-badge{font-size:11px;color:var(--green);font-family:var(--mono)}

/* ===== FOOTER ===== */
.footer{padding:40px 28px 24px;text-align:center;border-top:1px solid var(--border)}
.footer-inner{font-size:12px;color:var(--text-muted);display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}
.footer-link{color:var(--text-dim);text-decoration:none}
.footer-link:hover{color:var(--text)}
.footer-sep{opacity:0.3}

/* ===== PAGE LAYOUT ===== */
.page{padding:80px 28px 60px;max-width:1100px;margin:0 auto}
.page-mid{max-width:720px}
.page-title{font-family:var(--display);font-size:28px;font-weight:800}
.page-sub{font-size:14px;color:var(--text-dim);margin-top:4px}
.section-label{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);font-weight:600}

/* ===== LANDING ===== */
.landing{text-align:center;padding:120px 24px 60px;max-width:1100px;margin:0 auto}
.landing-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;background:var(--accent-soft);border:1px solid var(--accent-border);font-size:12px;font-weight:500;color:var(--accent);margin-bottom:28px}
.landing h1{font-family:var(--display);font-size:52px;font-weight:900;line-height:1.08;margin-bottom:16px;letter-spacing:-0.5px;max-width:640px;margin-left:auto;margin-right:auto}
.landing h1 em{font-style:italic;color:var(--accent)}
.landing>p{font-size:16px;color:var(--text-dim);max-width:520px;line-height:1.6;margin:0 auto 36px}
.landing-ctas{display:flex;gap:12px;justify-content:center;margin-bottom:64px}
.btn-lg{padding:14px 32px;border-radius:var(--radius-lg);font-size:16px;font-weight:700;border:none;cursor:pointer;font-family:var(--font);transition:all 0.15s;text-decoration:none;display:inline-block}
.btn-lg--primary{background:var(--accent);color:#fff}
.btn-lg--primary:hover{background:var(--accent-hover)}
.btn-lg--outline{background:none;border:1px solid var(--border);color:var(--text-dim)}
.btn-lg--outline:hover{border-color:var(--accent-border);color:var(--text)}

/* How it works */
.how{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;max-width:960px;margin:0 auto 64px;text-align:left}
.how-step{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:24px}
.how-num{font-family:var(--mono);font-size:12px;color:var(--accent);font-weight:600;margin-bottom:10px}
.how-title{font-size:14px;font-weight:700;margin-bottom:6px}
.how-desc{font-size:12px;color:var(--text-dim);line-height:1.5}

/* Outputs */
.outputs{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:900px;margin:0 auto 64px}
.output-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;text-align:center}
.output-icon{font-size:28px;margin-bottom:10px}
.output-name{font-size:13px;font-weight:700;margin-bottom:4px}
.output-desc{font-size:11px;color:var(--text-dim);line-height:1.5}

/* Pricing */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:780px;margin:0 auto}
.price-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px;text-align:center;position:relative;transition:all 0.2s}
.price-card:hover{border-color:var(--accent-border)}
.price-card--feat{border-color:var(--gold-border);background:linear-gradient(180deg,rgba(212,168,83,0.04),var(--surface))}
.price-card--feat::before{content:'BEST VALUE';position:absolute;top:-10px;left:50%;transform:translateX(-50%);font-size:9px;font-weight:800;letter-spacing:1.5px;color:var(--bg);background:var(--gold);padding:3px 12px;border-radius:10px}
.price-label{font-size:13px;font-weight:600;color:var(--text-dim);margin-bottom:4px}
.price-amount{font-family:var(--display);font-size:40px;font-weight:900;margin-bottom:2px}
.price-period{font-size:12px;color:var(--text-muted);margin-bottom:20px}
.price-feat{font-size:12px;color:var(--text-dim);padding:4px 0;display:flex;align-items:center;gap:6px;justify-content:center}
.price-feat::before{content:'✓';color:var(--green);font-size:13px}
.price-btn{display:block;margin-top:20px;width:100%;padding:12px;border-radius:var(--radius);font-size:14px;font-weight:700;border:none;cursor:pointer;font-family:var(--font);text-align:center;text-decoration:none}
.price-btn--accent{background:var(--accent);color:#fff}
.price-btn--accent:hover{background:var(--accent-hover)}
.price-btn--gold{background:linear-gradient(135deg,var(--gold),#c49a45);color:#0a0b0f}

/* ===== AUTH ===== */
.auth-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px}
.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px;width:100%;max-width:400px}
.auth-title{font-family:var(--display);font-size:24px;font-weight:800;text-align:center;margin-bottom:4px}
.auth-sub{font-size:14px;color:var(--text-dim);text-align:center;margin-bottom:24px}

/* ===== FORMS ===== */
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:11px;font-weight:600;color:var(--text-dim);margin-bottom:6px;text-transform:uppercase;letter-spacing:0.5px}
.form-input{width:100%;padding:11px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font);font-size:13px;transition:border-color 0.15s}
.form-input:focus{outline:none;border-color:var(--accent)}
.form-input::placeholder{color:var(--text-muted)}
.form-select{width:100%;padding:11px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font);font-size:13px;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%238c8ea0' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;cursor:pointer;transition:border-color 0.15s}
.form-select:focus{outline:none;border-color:var(--accent)}
.form-select option{background:var(--surface-2);color:var(--text)}
.form-hint{font-size:11px;color:var(--text-muted);margin-top:4px}
.form-btn{width:100%;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-size:14px;font-weight:700;cursor:pointer;font-family:var(--font);transition:background 0.15s}
.form-btn:hover{background:var(--accent-hover)}
.form-link{font-size:13px;color:var(--accent);text-decoration:none}
.form-link--dim{color:var(--text-muted)}
.form-link--dim:hover{color:var(--text-dim)}
.form-error{background:var(--red-soft);border:1px solid rgba(239,68,68,0.3);color:var(--red);padding:10px 14px;border-radius:var(--radius);font-size:13px;margin-bottom:16px}
.form-message{background:var(--green-soft);border:1px solid rgba(52,211,153,0.3);color:var(--green);padding:10px 14px;border-radius:var(--radius);font-size:13px;margin-bottom:16px}

/* Toggles */
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0}
.toggle-label{font-size:13px;color:var(--text-dim)}
.toggle{width:36px;height:20px;border-radius:10px;background:var(--surface-3);border:1px solid var(--border);position:relative;cursor:pointer;transition:all 0.2s;flex-shrink:0}
.toggle.on{background:var(--accent);border-color:var(--accent)}
.toggle-knob{width:14px;height:14px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform 0.2s}
.toggle.on .toggle-knob{transform:translateX(16px)}

/* Multi-select pills */
.multi-select{display:flex;flex-wrap:wrap;gap:6px}
.pill{padding:5px 12px;border-radius:20px;font-size:11px;font-weight:500;border:1px solid var(--border);color:var(--text-dim);cursor:pointer;transition:all 0.15s;background:none;font-family:var(--font)}
.pill:hover{border-color:var(--accent-border);color:var(--text)}
.pill.sel{background:var(--accent-soft);border-color:var(--accent-border);color:var(--accent)}

/* ===== DASHBOARD ===== */
.dash-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;flex-wrap:wrap;gap:12px}
.dash-access{font-size:12px;color:var(--text-dim);background:var(--surface-2);padding:8px 14px;border-radius:var(--radius);border:1px solid var(--border)}
.dash-access .access-date{color:var(--green);font-family:var(--mono);font-weight:600}
.dash-actions{display:flex;gap:10px;margin-bottom:28px}

/* Spec cards */
.spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.spec-card{display:block;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:22px;cursor:pointer;transition:all 0.2s;position:relative;overflow:hidden;text-decoration:none;color:var(--text)}
.spec-card:hover{border-color:var(--accent-border);transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,0.3)}
.spec-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:transparent;transition:background 0.25s}
.spec-card:hover::before{background:var(--accent)}
.spec-card--new{border-style:dashed;opacity:0.6;text-align:center;padding:40px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.spec-name{font-size:16px;font-weight:700;margin-bottom:4px}
.spec-desc{font-size:12px;color:var(--text-dim);margin-bottom:14px}
.spec-meta{display:flex;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.spec-tag{font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:4px}
.spec-tag--draft{color:var(--amber)}
.spec-tag--building{color:var(--accent)}
.spec-tag--complete{color:var(--green)}
.spec-tag--exported{color:var(--gold)}
.spec-bar{height:4px;background:var(--surface-3);border-radius:2px;overflow:hidden}
.spec-bar-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--accent),var(--gold))}
.spec-pct{font-size:11px;font-family:var(--mono);font-weight:600;margin-top:6px}
.pct-gold{color:var(--gold)}
.pct-green{color:var(--green)}
.pct-amber{color:var(--amber)}
.pct-red{color:var(--red)}

/* Empty state */
.empty{text-align:center;padding:60px 20px;background:var(--surface);border:2px dashed var(--border);border-radius:var(--radius-xl)}
.empty-icon{font-size:40px;margin-bottom:12px;opacity:0.5}
.empty h3{font-size:16px;font-weight:600;margin-bottom:6px}
.empty p{font-size:13px;color:var(--text-dim);margin-bottom:20px}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:28px;width:100%;max-width:440px}
.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.modal-header h2{font-size:18px;font-weight:700}
.modal-close{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer}

/* ===== SETUP ===== */
.setup-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:36px;max-width:620px;margin:0 auto}
.setup-title{font-family:var(--display);font-size:24px;font-weight:800;margin-bottom:4px}
.setup-sub{font-size:14px;color:var(--text-dim);margin-bottom:28px}
.setup-section{margin-bottom:24px}
.setup-section-label{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--border)}

/* ===== BUILDER ===== */
.builder-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.builder-name{background:none;border:none;font-family:var(--display);font-size:24px;font-weight:800;color:var(--text);outline:none;border-bottom:2px solid transparent;padding:2px 0}
.builder-name:focus{border-bottom-color:var(--accent)}
.builder-header-right{display:flex;align-items:center;gap:16px}
.builder-save-status{font-size:11px;font-family:var(--mono);margin-left:12px}
.builder-save-status.saved{color:var(--green)}
.builder-save-status.saving{color:var(--amber)}
.builder-save-status.error{color:var(--red)}
.builder-save-group{display:flex;align-items:center;gap:8px}
.builder-save-btn{padding:8px 16px;background:#22c55e;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font);transition:background .2s,transform .1s}
.builder-save-btn:hover{background:#16a34a}
.builder-save-btn:active{background:#15803d;transform:scale(.98)}
.builder-save-btn.saving{background:#a3a3a3;cursor:wait}
.builder-save-indicator{display:flex;align-items:center;gap:5px;font-size:11px;font-family:var(--mono);color:var(--text-muted)}
.builder-save-indicator .save-dot{width:6px;height:6px;border-radius:50%;background:var(--text-muted)}
.builder-save--saving .save-dot{background:var(--amber);animation:pulse 1s infinite}
.builder-save--saved .save-dot{background:var(--green)}
.builder-save--saved .save-text{color:var(--green)}
.builder-save--error .save-dot{background:var(--red)}
.builder-save--error .save-text{color:var(--red)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.builder-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:24px;position:sticky;top:56px;background:var(--bg);z-index:50;padding-top:4px}
.builder-tab{flex:1;padding:14px 16px;text-align:center;font-size:13px;font-weight:600;color:var(--text-muted);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;font-family:var(--font);transition:all 0.15s;display:flex;align-items:center;justify-content:center;gap:8px}
.builder-tab:hover{color:var(--text-dim)}
.builder-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:var(--accent-soft)}
.tab-count{font-size:10px;font-family:var(--mono);background:var(--surface-3);padding:2px 6px;border-radius:8px}
.builder-tab.active .tab-count{background:var(--accent);color:#fff}
.builder-panel{display:none}
.builder-panel.active{display:block}

/* Blocks */
.block{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:12px;overflow:hidden}
.block-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;cursor:pointer;transition:background 0.15s}
.block-header:hover{background:var(--surface-2)}
.block-left{display:flex;align-items:center;gap:12px}
.block-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.block-dot--done{background:var(--green)}
.block-dot--partial{background:var(--amber)}
.block-dot--empty{background:var(--red)}
.block-title{font-size:14px;font-weight:600}
.block-subtitle{font-size:11px;color:var(--text-muted);margin-left:8px}
.block-chevron{color:var(--text-muted);font-size:12px;transition:transform 0.2s}
.block-body{padding:0 20px 20px;display:none}
.block.open .block-body{display:block}
.block.open .block-chevron{transform:rotate(90deg)}

/* Entity builder */
.entity{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;margin-bottom:12px}
.entity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.entity-name{font-size:14px;font-weight:700}
.entity-remove{font-size:11px;color:var(--text-muted);cursor:pointer;padding:4px 8px;border-radius:var(--radius);border:1px solid transparent}
.entity-remove:hover{color:var(--red);border-color:rgba(239,68,68,0.2)}
.field-row{display:grid;grid-template-columns:2fr 1.5fr 50px 30px;gap:8px;margin-bottom:6px;align-items:center}
.field-label{font-size:10px;color:var(--text-muted);font-weight:600;text-transform:uppercase}
.field-toggle{width:28px;height:16px;border-radius:8px;background:var(--surface-3);border:1px solid var(--border);cursor:pointer;position:relative;transition:all 0.2s}
.field-toggle.on{background:var(--accent);border-color:var(--accent)}
.add-field{font-size:12px;color:var(--accent);cursor:pointer;padding:6px 0;display:flex;align-items:center;gap:4px}
.add-field:hover{text-decoration:underline}
.add-entity{width:100%;padding:12px;background:none;border:2px dashed var(--border);border-radius:var(--radius-lg);color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all 0.15s}
.add-entity:hover{border-color:var(--accent-border);color:var(--accent)}

/* Completeness */
.completeness{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-top:24px;position:sticky;bottom:20px}
.comp-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.comp-label{font-size:12px;font-weight:600;color:var(--text-dim)}
.comp-pct{font-family:var(--mono);font-size:22px;font-weight:700;color:var(--gold)}
.comp-bar{height:6px;background:var(--surface-3);border-radius:3px;overflow:hidden;margin-bottom:10px}
.comp-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--accent),var(--gold));transition:width 0.6s}
.comp-stats{display:flex;gap:16px;margin-bottom:14px;flex-wrap:wrap}
.comp-stat{font-size:10px;color:var(--text-muted);display:flex;align-items:center;gap:4px}
.comp-warnings{margin-bottom:14px}
.comp-warn{font-size:11px;color:var(--amber);padding:4px 0;display:flex;align-items:center;gap:6px}
.comp-btn{width:100%;padding:12px;border-radius:var(--radius);font-size:14px;font-weight:700;border:none;cursor:pointer;font-family:var(--font);background:linear-gradient(135deg,var(--accent),#c44232);color:#fff}
.comp-btn:disabled{opacity:0.4;cursor:not-allowed}
.comp-btn:not(:disabled):hover{opacity:0.9}

/* ===== EXPORT ===== */
.export-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:1px solid var(--border)}
.export-tab{padding:12px 20px;font-size:13px;font-weight:600;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-family:var(--font);transition:all 0.15s}
.export-tab:hover{color:var(--text-dim)}
.export-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.export-panel{display:none}
.export-panel.active{display:block}
.export-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:28px;margin-bottom:20px}
.export-md{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;font-family:var(--mono);font-size:11px;color:var(--text-dim);line-height:1.9;max-height:500px;overflow-y:auto;white-space:pre-wrap;word-wrap:break-word}
.export-actions{display:flex;gap:10px;flex-wrap:wrap}
.exp-btn{padding:11px 22px;border-radius:var(--radius);font-size:13px;font-weight:600;border:none;cursor:pointer;font-family:var(--font);transition:all 0.15s}
.exp-btn--primary{background:var(--accent);color:#fff}
.exp-btn--primary:hover{background:var(--accent-hover)}
.exp-btn--outline{background:none;border:1px solid var(--border);color:var(--text-dim)}
.exp-btn--outline:hover{border-color:var(--accent-border);color:var(--text)}
.exp-btn--gold{background:linear-gradient(135deg,var(--gold),#c49a45);color:#0a0b0f}
.exp-btn--gold:hover{opacity:0.9}

/* Wireframe preview */
.wf-preview{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.wf-browser{display:flex;align-items:center;gap:6px;padding:10px 14px;background:var(--surface-3);border-bottom:1px solid var(--border)}
.wf-dot{width:8px;height:8px;border-radius:50%;background:var(--border-active)}
.wf-url{font-size:11px;color:var(--text-muted);font-family:var(--mono);margin-left:8px;background:var(--surface);padding:4px 10px;border-radius:4px;flex:1}
.wf-body{padding:20px}

/* Prompt */
.prompt-box{background:var(--bg);border:1px solid var(--accent-border);border-radius:var(--radius-lg);padding:20px;font-family:var(--mono);font-size:12px;color:var(--text-dim);line-height:1.8;max-height:500px;overflow-y:auto;white-space:pre-wrap;word-wrap:break-word}
.prompt-comment{color:var(--text-muted)}
.prompt-var{color:var(--cyan)}

/* ===== UPLOAD ===== */
.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-xl);padding:36px 28px;text-align:center;transition:all 0.2s;cursor:pointer}
.upload-zone:hover{border-color:var(--accent-border);background:var(--accent-soft)}
.upload-zone.has-files{border-style:solid;border-color:rgba(52,211,153,0.25);background:var(--green-soft)}
.upload-zone-icon{font-size:28px;margin-bottom:8px}
.upload-zone-title{font-size:14px;font-weight:700;margin-bottom:4px}
.upload-zone-desc{font-size:12px;color:var(--text-dim)}
.upload-zone-formats{font-size:11px;color:var(--text-muted);font-family:var(--mono);margin-top:8px}
.upload-files{margin-top:14px;text-align:left}
.upload-file{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:4px}
.upload-file-icon{font-size:16px}
.upload-file-name{font-size:12px;font-weight:600;flex:1}
.upload-file-size{font-size:10px;color:var(--text-muted);font-family:var(--mono)}
.upload-file-remove{font-size:11px;color:var(--text-muted);cursor:pointer;background:none;border:none;font-family:var(--font)}
.upload-file-remove:hover{color:var(--red)}

.form-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--text-muted);font-size:12px}
.form-divider::before,.form-divider::after{content:'';flex:1;height:1px;background:var(--border)}

/* ===== EVALUATION ===== */
.eval-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;flex-wrap:wrap;gap:16px}
.eval-type{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:20px;background:var(--cyan-soft);border:1px solid var(--cyan-border);font-size:12px;font-weight:500;color:var(--cyan);margin-bottom:8px}
.eval-summary{font-size:14px;color:var(--text-dim);line-height:1.6;max-width:580px}
.eval-score-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:24px;text-align:center;min-width:180px}
.eval-score-num{font-family:var(--display);font-size:48px;font-weight:900;background:linear-gradient(135deg,var(--accent),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.eval-score-label{font-size:12px;color:var(--text-dim);margin-top:2px}
.eval-score-bar{height:6px;background:var(--surface-3);border-radius:3px;margin-top:10px;overflow:hidden}
.eval-score-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--accent),var(--gold))}
.eval-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:24px}
.eval-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden}
.eval-card-head{padding:18px 20px 0}
.eval-card-title{font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px;margin-bottom:14px}
.eval-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.eval-item{display:flex;align-items:flex-start;gap:10px;padding:10px 20px;border-bottom:1px solid var(--border)}
.eval-item:last-child{border:none}
.eval-item-icon{flex-shrink:0;font-size:14px;margin-top:1px}
.eval-item-label{font-size:12px;font-weight:600;margin-bottom:2px}
.eval-item-detail{font-size:11px;color:var(--text-dim);line-height:1.4}
.eval-item-source{font-size:9px;font-family:var(--mono);color:var(--text-muted);margin-top:2px}

/* ===== UPLOAD-AWARE BLOCKS ===== */
.pill.upload-sel{background:var(--cyan-soft);border-color:var(--cyan-border);color:var(--cyan)}
.block.from-upload{border-left:3px solid var(--cyan)}
.block-dot--upload{background:var(--cyan)}
.block-badge{font-size:9px;padding:2px 8px;border-radius:8px;font-weight:600;font-family:var(--mono);margin-left:8px}
.block-badge--upload{background:var(--cyan-soft);border:1px solid var(--cyan-border);color:var(--cyan)}
.block-badge--needed{background:var(--amber-soft);border:1px solid rgba(245,158,11,0.25);color:var(--amber)}
.upload-prefill{font-size:10px;font-family:var(--mono);color:var(--cyan);margin-top:4px;display:flex;align-items:center;gap:4px}

/* ===== TYPE LABELS ===== */
.type-label{font-size:11px;padding:3px 10px;border-radius:12px;border:1px solid var(--border);display:inline-flex;align-items:center;gap:4px}
.type-label--web3{border-color:var(--cyan-border);color:var(--cyan);background:var(--cyan-soft)}

/* ===== BUILDER V2 — New Components ===== */

/* Type labels */
.type-label--standard{border-color:var(--border);color:var(--text-dim)}
.type-label--web3{border-color:var(--cyan-border);color:var(--cyan);background:var(--cyan-soft)}
.type-label--ai{border-color:rgba(168,85,247,0.3);color:#a855f7;background:rgba(168,85,247,0.08)}

/* Helper buttons (WHY / EX) */
.block-helpers{display:flex;gap:4px;margin-left:8px}
.helper-btn,.block-modal-link{font-size:9px;font-weight:800;letter-spacing:0.5px;padding:2px 8px;border-radius:8px;border:1px solid var(--border);background:none;cursor:pointer;font-family:var(--mono);transition:all 0.15s;margin-left:4px}
.helper-btn--why,.block-modal-link:nth-child(1){color:var(--amber);border-color:rgba(245,158,11,0.25)}
.helper-btn--why:hover,.block-modal-link:nth-child(1):hover{background:var(--amber-soft);border-color:rgba(245,158,11,0.5)}
.helper-btn--ex,.block-modal-link:nth-child(2){color:var(--cyan);border-color:var(--cyan-border)}
.helper-btn--ex:hover,.block-modal-link:nth-child(2):hover{background:var(--cyan-soft);border-color:rgba(6,182,212,0.5)}

/* Helper modal */
.modal--helper{max-width:560px;max-height:80vh;overflow-y:auto}
.helper-content{font-size:13px;color:var(--text-dim);line-height:1.7}
.helper-content p{margin-bottom:12px}
.helper-content strong{color:var(--text);font-weight:600}

/* Textarea */
.form-textarea{width:100%;padding:11px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font);font-size:13px;transition:border-color 0.15s;min-height:80px;resize:vertical;line-height:1.6}
.form-textarea:focus{outline:none;border-color:var(--accent)}
.form-textarea::placeholder{color:var(--text-muted)}
.form-textarea--sm{min-height:56px}

/* Checklist */
.checklist{display:flex;flex-direction:column;gap:4px}
.check-item{display:flex;align-items:flex-start;gap:10px;padding:8px 12px;border-radius:var(--radius);cursor:pointer;transition:background 0.1s}
.check-item:hover{background:var(--surface-2)}
.check-item input[type="checkbox"]{display:none}
.check-mark{width:18px;height:18px;border-radius:4px;border:1.5px solid var(--border-active);flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;transition:all 0.15s;font-size:11px;color:transparent}
.check-item input:checked+.check-mark{background:var(--accent);border-color:var(--accent);color:#fff}
.check-item input:checked+.check-mark::after{content:'✓'}
.check-text{display:flex;flex-direction:column;gap:2px}
.check-label{font-size:13px;color:var(--text)}
.check-desc{font-size:11px;color:var(--text-muted);line-height:1.4}

/* Not Sure */
.not-sure-row{margin-top:8px}
.not-sure-btn{background:none;border:none;font-size:11px;color:var(--text-muted);cursor:pointer;font-family:var(--font);display:flex;align-items:center;gap:4px;padding:4px 0;transition:color 0.15s}
.not-sure-btn:hover{color:var(--text-dim)}
.not-sure-arrow{font-size:9px}
.not-sure-body{margin-top:6px}

/* Go Deeper */
.deeper-section{margin-top:16px;border-top:1px solid var(--border);padding-top:12px}
.deeper-toggle{width:100%;display:flex;align-items:center;gap:8px;padding:10px 0;background:none;border:none;color:var(--text-dim);font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font);transition:color 0.15s}
.deeper-toggle:hover{color:var(--text)}
.deeper-icon{font-size:14px}
.deeper-count{color:var(--text-muted);font-weight:400}
.deeper-arrow{margin-left:auto;font-size:10px;transition:transform 0.2s}
.deeper-open .deeper-arrow{transform:rotate(90deg)}
.deeper-body{padding:8px 0 4px;border-top:1px dashed var(--border);margin-top:8px}

/* Free-form */
.freeform-section{margin-top:16px}
.freeform-toggle,.go-deeper-toggle{display:flex;align-items:center;gap:8px;padding:10px 0;background:none;border:none;color:var(--text-dim);font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font);transition:color 0.15s}
.freeform-toggle:hover,.go-deeper-toggle:hover{color:var(--text)}
.freeform-body,.go-deeper-body{display:none;padding:8px 0 4px}
.freeform-section.open .freeform-body,.go-deeper.open .go-deeper-body{display:block}
.freeform-divider{display:flex;align-items:center;gap:12px;margin-bottom:14px;color:var(--text-muted);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px}
.freeform-divider::before,.freeform-divider::after{content:'';flex:1;height:1px;background:var(--border)}

/* Item Builder */
.item-builder{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}
.ib-items{display:flex;flex-direction:column;gap:10px;margin-bottom:10px}
.ib-item{display:flex;gap:10px;align-items:flex-start;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}
.ib-fields{flex:1;display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px}
.ib-field .form-label{font-size:9px;margin-bottom:3px}
.ib-field .form-input,.ib-field .form-select{padding:8px 10px;font-size:12px}
.ib-remove{background:none;border:1px solid transparent;color:var(--text-muted);font-size:14px;cursor:pointer;padding:6px 8px;border-radius:var(--radius);flex-shrink:0;margin-top:16px;transition:all 0.15s}
.ib-remove:hover{color:var(--red);border-color:rgba(239,68,68,0.2)}
.ib-add{width:100%;padding:10px;background:none;border:1px dashed var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all 0.15s}
.ib-add:hover{border-color:var(--accent-border);color:var(--accent);background:var(--accent-soft)}

/* ===== RESPONSIVE ===== */
/* Unsaved Changes Modal */
.unsaved-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:9999;backdrop-filter:blur(4px)}
.unsaved-modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;max-width:400px;width:90%;text-align:center}
.unsaved-modal-icon{font-size:36px;margin-bottom:12px}
.unsaved-modal-title{font-family:var(--display);font-size:18px;font-weight:700;color:var(--text);margin:0 0 8px}
.unsaved-modal-desc{font-size:13px;color:var(--text-dim);margin:0 0 24px}
.unsaved-modal-actions{display:flex;flex-direction:column;gap:8px}
.unsaved-btn{padding:12px 16px;border:none;border-radius:var(--radius);font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font);transition:background .15s}
.unsaved-btn--save{background:#22c55e;color:#fff}
.unsaved-btn--save:hover{background:#16a34a}
.unsaved-btn--leave{background:var(--surface-3);color:var(--text-dim)}
.unsaved-btn--leave:hover{background:var(--border);color:var(--text)}
.unsaved-btn--cancel{background:none;color:var(--text-muted);text-decoration:underline}
.unsaved-btn--cancel:hover{color:var(--text-dim)}

@media(max-width:768px){
  .how,.outputs{grid-template-columns:1fr 1fr}
  .pricing,.spec-grid,.eval-grid{grid-template-columns:1fr}
  .landing h1{font-size:36px}
  .field-row{grid-template-columns:1fr 1fr 50px 30px}
  .header{padding:0 16px}
  .page{padding:72px 16px 40px}
  .builder-tabs{overflow-x:auto}
  .dash-header{flex-direction:column;align-items:flex-start}
  .eval-header{flex-direction:column}
}
@media(max-width:480px){
  .how,.outputs{grid-template-columns:1fr}
  .landing h1{font-size:28px}
  .export-tabs{overflow-x:auto}
  .header-nav{gap:8px}
  .landing-ctas{flex-direction:column;align-items:center}
}
