/* ═══════════════════════════════════════════════════════════
   PipeGen Pro — Styles
   ═══════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --dark:#1F3864;--mid:#2E74B5;--light:#D6E4F0;--obsidian:#0d0d1a;
  --green:#1E7145;--lgreen:#E2EFDA;--orange:#C55A11;--lorange:#FCE4D6;
  --gold:#c8a000;--lgold:#fffaeb;
  --gray:#595959;--lgray:#f4f6f9;--white:#fff;--border:#dde4ef;
  --radius:10px;--shadow:0 2px 16px rgba(31,56,100,0.10);
}
body{font-family:Arial,sans-serif;font-size:14px;color:#1a1a2e;background:#eef2f8;min-height:100vh}

/* NAV */
.nav{background:var(--obsidian);color:#fff;display:flex;align-items:center;padding:0 24px;height:54px;position:sticky;top:0;z-index:300;box-shadow:0 2px 16px rgba(0,0,0,.5);gap:12px}
.nav-logo{font-size:15px;font-weight:bold;letter-spacing:2px;color:#8CB4D5;white-space:nowrap}
.nav-badge{background:var(--gold);color:#0d0d1a;font-size:10px;font-weight:bold;padding:2px 7px;border-radius:3px;letter-spacing:.5px;margin-left:6px}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.nav-btn{background:transparent;border:1px solid #555;color:#aaa;padding:6px 14px;border-radius:6px;cursor:pointer;font-size:12px;font-family:Arial;transition:all .15s;white-space:nowrap}
.nav-btn:hover{border-color:#8CB4D5;color:#8CB4D5}

/* HERO */
.hero{background:linear-gradient(135deg,#1F3864 0%,#142744 60%,#0a1628 100%);color:#fff;padding:36px 36px 28px}
.hero-eye{font-size:11px;letter-spacing:2px;color:#8CB4D5;text-transform:uppercase;margin-bottom:8px}
.hero h1{font-size:26px;font-weight:bold;margin-bottom:6px}
.hero p{font-size:13px;color:#8CB4D5;margin-bottom:18px;max-width:700px;line-height:1.6}
.pills{display:flex;flex-wrap:wrap;gap:8px}
.pill{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);color:#d0e4f8;padding:4px 13px;border-radius:20px;font-size:11px}
.pill.gold{background:rgba(200,160,0,.2);border-color:rgba(200,160,0,.5);color:var(--gold)}

/* WRAP */
.wrap{max-width:880px;margin:0 auto;padding:28px 24px 60px}

/* STAGE TRACK */
.track{display:flex;align-items:center;margin-bottom:28px;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 24px;gap:0}
.stage{display:flex;align-items:center;gap:10px;flex:1;cursor:default}
.s-num{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:bold;font-size:13px;border:2px solid var(--border);color:var(--gray);background:#f9f9f9;flex-shrink:0;transition:all .25s}
.s-num.done{background:var(--green);border-color:var(--green);color:#fff}
.s-num.active{background:var(--mid);border-color:var(--mid);color:#fff}
.s-lbl{font-size:12px;color:var(--gray);font-weight:bold;transition:color .2s}
.s-lbl.active{color:var(--mid)}
.s-lbl.done{color:var(--green)}
.s-div{flex:0 0 32px;height:2px;background:var(--border);border-radius:2px;transition:background .3s}
.s-div.done{background:var(--green)}

/* CARD */
.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:20px;overflow:hidden;animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.card-head{padding:18px 24px 14px;border-bottom:1px solid var(--border)}
.card-head h2{font-size:16px;color:var(--dark);margin-bottom:3px}
.card-head .sub{font-size:12px;color:var(--gray);line-height:1.5}
.card-body{padding:22px 24px}

/* FORM */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-row.one{grid-template-columns:1fr}
.fg{display:flex;flex-direction:column;gap:6px}
.fg label{font-size:11px;font-weight:bold;text-transform:uppercase;letter-spacing:.5px;color:var(--gray)}
.fg input,.fg select,.fg textarea{border:1.5px solid var(--border);border-radius:7px;padding:10px 13px;font-family:Arial;font-size:13px;color:#1a1a2e;background:#fff;transition:border-color .15s;width:100%}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--mid);box-shadow:0 0 0 3px rgba(46,116,181,.10)}
.fg textarea{resize:vertical}
.fg .hint{font-size:11px;color:#999;margin-top:2px;line-height:1.4}

/* BUTTONS */
.btn{border:none;border-radius:7px;padding:11px 22px;font-size:13px;font-weight:bold;cursor:pointer;font-family:Arial;transition:all .15s;display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none}
.btn-primary{background:var(--mid);color:#fff}
.btn-primary:hover{background:var(--dark)}
.btn-gold{background:var(--gold);color:#0d0d1a}
.btn-gold:hover{background:#a88000}
.btn-ghost{background:transparent;border:1.5px solid var(--border);color:var(--gray)}
.btn-ghost:hover{border-color:var(--mid);color:var(--mid)}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:#155a33}
.btn-claude{background:linear-gradient(135deg,#cc785c,#d4956a);color:#fff}
.btn-claude:hover{background:linear-gradient(135deg,#b8674d,#c0845d);transform:translateY(-1px);box-shadow:0 4px 14px rgba(200,120,80,.35)}
.btn-full{width:100%}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none!important}
.btn-row{display:flex;gap:10px;margin-top:14px}
.btn-row .btn{flex:1}

/* PROMPT BOX */
.prompt-box{background:#0d1117;border-radius:8px;padding:0;overflow:hidden;margin:14px 0;border:1px solid #30363d}
.prompt-head{background:#161b22;padding:10px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #30363d}
.prompt-head span{font-size:11px;color:#8b949e;font-family:monospace}
.prompt-text{color:#e6edf3;font-size:12px;font-family:monospace;line-height:1.7;padding:16px;white-space:pre-wrap;max-height:260px;overflow-y:auto}
.copy-code-btn{background:#21262d;border:1px solid #30363d;color:#8b949e;border-radius:5px;padding:4px 12px;font-size:11px;cursor:pointer;font-family:Arial;transition:all .15s}
.copy-code-btn:hover{background:#30363d;color:#e6edf3}
.copy-code-btn.done{background:#1a4a2e;color:#3fb950;border-color:#3fb950}

/* PASTE AREA */
.paste-area{border:2px dashed var(--border);border-radius:8px;padding:20px;text-align:center;margin:14px 0;transition:border-color .2s;cursor:pointer}
.paste-area:hover,.paste-area.drag{border-color:var(--mid);background:#f0f6ff}
.paste-area .paste-icon{font-size:32px;margin-bottom:8px}
.paste-area p{font-size:13px;color:var(--gray)}
.paste-area textarea{width:100%;min-height:180px;border:none;resize:vertical;font-family:monospace;font-size:12px;color:#1a1a2e;background:transparent;outline:none;text-align:left;margin-top:10px}

/* MESSAGE OUTPUT */
.msg-tabs{display:flex;gap:4px;margin-bottom:-1px}
.msg-tab{background:var(--lgray);border:1.5px solid var(--border);border-bottom:none;border-radius:7px 7px 0 0;padding:8px 18px;cursor:pointer;font-size:12px;font-weight:bold;color:var(--gray);transition:all .15s}
.msg-tab.active{background:#fff;color:var(--dark);border-color:var(--border)}
.msg-panel{background:#fff;border:1.5px solid var(--border);border-radius:0 var(--radius) var(--radius) var(--radius);padding:22px;display:none}
.msg-panel.active{display:block}

.subj-label{font-size:10px;font-weight:bold;text-transform:uppercase;letter-spacing:.5px;color:var(--gray);margin-bottom:8px}
.subj-item{display:flex;align-items:center;justify-content:space-between;background:#f9f9f9;border:1px solid var(--border);border-radius:6px;padding:9px 13px;margin-bottom:6px;font-size:13px;gap:10px}
.subj-item span{flex:1;line-height:1.4}

.msg-body{white-space:pre-wrap;font-size:14px;line-height:1.9;color:#1a1a2e;background:#fafcff;border:1px solid var(--border);border-radius:7px;padding:20px 20px 48px;position:relative}
.copy-float{position:absolute;bottom:12px;right:12px;background:var(--mid);color:#fff;border:none;border-radius:5px;padding:6px 14px;font-size:11px;cursor:pointer;font-family:Arial;transition:all .15s;font-weight:bold}
.copy-float:hover{background:var(--dark)}
.copy-float.done{background:var(--green)}

/* SIGNALS */
.signal-row{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.sig-chip{background:var(--light);color:var(--dark);font-size:11px;padding:4px 10px;border-radius:12px;font-weight:bold;white-space:nowrap}
.sig-chip.ai{background:var(--lgreen);color:var(--green)}
.sig-chip.saas{background:var(--lgold);color:#7a5800}
.sig-chip.reg{background:var(--lorange);color:var(--orange)}

/* QUOTE SELECTED */
.chosen-quote{background:var(--lgold);border:1.5px solid #e8c840;border-radius:7px;padding:14px 18px;margin:10px 0}
.chosen-quote blockquote{font-style:italic;font-size:13px;line-height:1.65;color:#3a2800;margin-bottom:6px}
.chosen-quote cite{font-size:11px;font-weight:bold;color:#8a6000}

/* ALERT */
.alert{border-radius:7px;padding:12px 16px;font-size:13px;margin:10px 0;display:flex;gap:10px;align-items:flex-start;line-height:1.6}
.alert.info{background:var(--light);border:1px solid #AED6F1;color:var(--dark)}
.alert.warn{background:var(--lgold);border:1px solid #f0d060;color:#6b4f00}
.alert.success{background:var(--lgreen);border:1px solid #A9DFBF;color:var(--green)}
.ai-icon{font-size:18px;flex-shrink:0;margin-top:-2px}

/* SEC LABEL */
.sec-lbl{font-size:11px;font-weight:bold;text-transform:uppercase;letter-spacing:.8px;color:var(--mid);margin:18px 0 10px;padding-bottom:4px;border-bottom:2px solid var(--light)}

/* OUTCOMES PANEL */
.outcomes-panel{position:fixed;right:0;top:54px;bottom:0;width:360px;background:#fff;border-left:1px solid var(--border);box-shadow:-4px 0 24px rgba(0,0,0,.12);z-index:200;transform:translateX(100%);transition:transform .25s;overflow-y:auto;display:flex;flex-direction:column}
.outcomes-panel.open{transform:translateX(0)}
.out-head{background:var(--dark);color:#fff;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.out-head h3{font-size:14px}
.close-x{background:transparent;border:none;color:#8CB4D5;cursor:pointer;font-size:20px;line-height:1}
.out-body{flex:1;overflow-y:auto;padding:12px}
.out-note{font-size:12px;color:var(--gray);line-height:1.6;padding:0 2px 8px}
.outcome-card{border:1px solid var(--border);border-radius:7px;padding:13px;margin-bottom:10px;background:#fafcff}
.outcome-card h4{font-size:12px;font-weight:bold;color:var(--dark);margin-bottom:5px}
.outcome-card p{font-size:12px;color:var(--gray);line-height:1.5;margin-bottom:3px}
.outcome-card .tag-row{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}
.otag{background:var(--light);color:var(--mid);font-size:10px;padding:2px 7px;border-radius:8px}
.out-card-btns{display:flex;gap:6px;margin-top:10px}

/* HOW-TO BANNER */
.how-to{background:linear-gradient(135deg,#fff8dc,#fffaee);border:1.5px solid #e8d070;border-radius:var(--radius);padding:18px 22px;margin-bottom:20px}
.how-to h3{font-size:13px;font-weight:bold;color:#7a5800;margin-bottom:10px}
.steps-list{list-style:none;counter-reset:step}
.steps-list li{counter-increment:step;display:flex;gap:10px;align-items:flex-start;margin-bottom:8px;font-size:12px;color:#5a4000;line-height:1.5}
.steps-list li::before{content:counter(step);background:var(--gold);color:#0d0d1a;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:bold;font-size:11px;flex-shrink:0;margin-top:1px}

/* DIVIDER */
.divider{height:1px;background:var(--border);margin:18px 0}

/* OUTCOME USED */
.outcome-badge{background:var(--lgreen);border:1px solid #A9DFBF;border-radius:7px;padding:11px 14px;font-size:12px;color:var(--green);margin-top:12px}
.outcome-badge strong{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}

/* SPIN */
.spin{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* SHAKE — was orphaned in a stray <style> tag in the original */
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}

/* ACCESS GATE */
.gate-overlay{position:fixed;inset:0;background:linear-gradient(135deg,#1F3864 0%,#0a1628 100%);z-index:9999;display:flex;align-items:center;justify-content:center}
.gate-box{background:#fff;border-radius:var(--radius);box-shadow:0 8px 40px rgba(0,0,0,.4);padding:36px 32px;width:340px;text-align:center}
.gate-logo{font-size:15px;font-weight:bold;letter-spacing:2px;color:var(--dark);margin-bottom:24px}
.gate-box label{display:block;font-size:11px;font-weight:bold;text-transform:uppercase;letter-spacing:.5px;color:var(--gray);margin-bottom:8px;text-align:left}
.gate-box input{width:100%;border:1.5px solid var(--border);border-radius:7px;padding:11px 13px;font-size:14px;margin-bottom:14px;font-family:Arial;transition:border-color .15s}
.gate-box input:focus{outline:none;border-color:var(--mid);box-shadow:0 0 0 3px rgba(46,116,181,.10)}

/* HIDDEN */
.hidden{display:none!important}

@media(max-width:700px){
  .form-row{grid-template-columns:1fr}
  .wrap{padding:14px}
  .hero{padding:24px 16px}
  .nav-logo{font-size:13px}
}
