:root{--navy: #241F4E;--teal: #54BDBF;--gold: #FFD330;--grey: #4D4D4F;--lgrey: #F3F3F3;--white: #FFFFFF;--bg: #f5f6fa;--border: #e0e4ef;--radius: 10px;--shadow: 0 2px 12px rgba(36,31,78,.08)}.app{display:flex;flex-direction:column;min-height:100vh;background:var(--bg)}.main{flex:1;max-width:1200px;margin:0 auto;padding:32px 24px;width:100%}.topbar{background:var(--navy);color:var(--white);display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:64px;box-shadow:0 2px 8px #0003;position:sticky;top:0;z-index:100}.topbar-brand{display:flex;align-items:center;gap:12px}.topbar-logo{width:38px;height:38px;background:var(--gold);color:var(--navy);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:20px}.topbar-title{font-size:17px;font-weight:700;letter-spacing:.3px}.topbar-sub{font-size:11px;opacity:.65;letter-spacing:.5px;text-transform:uppercase}.steps{display:flex;gap:4px}.step{display:flex;align-items:center;gap:8px;padding:6px 16px;border-radius:20px;font-size:13px;color:#ffffff8c;cursor:default;transition:all .2s}.step.done{color:#ffffffbf;cursor:pointer}.step.done:hover{background:#ffffff1a}.step.active{background:var(--gold);color:var(--navy);font-weight:700}.step-num{width:22px;height:22px;border-radius:50%;border:1.5px solid currentColor;display:flex;align-items:center;justify-content:center;font-size:11px}.step.active .step-num{background:var(--navy);color:var(--gold);border-color:transparent}.step.done .step-num{background:var(--teal);color:#fff;border-color:transparent}.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px;border:1px solid var(--border)}.card-title{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--teal)}.setup-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.generate-row{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;gap:12px}.generate-hint{font-size:13px;color:var(--grey);opacity:.7}.btn-primary{background:var(--navy);color:var(--white);border:none;border-radius:8px;padding:12px 28px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.btn-primary:hover:not(:disabled){background:#332d6e}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-primary.btn-lg{font-size:17px;padding:14px 40px}.btn-secondary{background:var(--teal);color:var(--white);border:none;border-radius:8px;padding:11px 24px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.btn-secondary:hover{background:#3fa5a7}.btn-ghost{background:transparent;color:var(--grey);border:1.5px solid var(--border);border-radius:8px;padding:11px 24px;font-size:14px;cursor:pointer;transition:border-color .2s}.btn-ghost:hover{border-color:var(--teal);color:var(--teal)}.template-list{display:flex;flex-direction:column;gap:12px}.template-card{display:flex;align-items:center;gap:14px;padding:14px 16px;border:2px solid var(--border);border-radius:8px;cursor:pointer;transition:border-color .2s,background .2s;position:relative}.template-card:hover{border-color:var(--teal);background:#f0fafa}.template-card.selected{border-color:var(--navy);background:#eef0f8}.template-icon{font-size:28px;flex-shrink:0}.template-name{font-weight:600;color:var(--navy);font-size:14px;margin-bottom:3px}.template-desc{font-size:12px;color:var(--grey);opacity:.75}.template-check{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:var(--navy);color:var(--gold);width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px}.drop-zone{border:2px dashed var(--border);border-radius:10px;padding:32px 20px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.drop-zone:hover,.drop-zone.dragging{border-color:var(--teal);background:#f0fafa}.drop-icon{font-size:32px;margin-bottom:10px;opacity:.4}.drop-label{font-size:14px;color:var(--grey);margin-bottom:4px}.drop-label .link{color:var(--teal);font-weight:600;text-decoration:underline}.drop-hint{font-size:12px;color:var(--grey);opacity:.6}.file-list{display:flex;flex-direction:column;gap:8px;margin-top:14px}.file-item{display:flex;align-items:center;gap:10px;background:var(--lgrey);border-radius:8px;padding:10px 12px}.file-icon{font-size:20px;flex-shrink:0}.file-info{flex:1;min-width:0}.file-name{font-size:13px;font-weight:500;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-size{font-size:11px;color:var(--grey);opacity:.6}.file-type-select{font-size:12px;padding:5px 8px;border-radius:6px;border:1px solid var(--border);background:#fff;color:var(--navy);font-weight:500;cursor:pointer}.file-remove{background:none;border:none;cursor:pointer;font-size:18px;color:var(--grey);opacity:.5;padding:0 4px;line-height:1}.file-remove:hover{opacity:1;color:#c00}.file-type-legend{display:flex;flex-direction:column;gap:4px;margin-top:16px}.legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--grey)}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.legend-dot.rfp{background:var(--navy)}.legend-dot.client{background:var(--teal)}.legend-dot.other{background:var(--gold)}.preview-layout{display:grid;grid-template-columns:1fr 240px;gap:24px;align-items:start}.preview-actions{position:sticky;top:80px;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;border:1px solid var(--border);display:flex;flex-direction:column;gap:12px}.preview-actions h3{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:4px}.preview-doc{display:flex;flex-direction:column;gap:0}.preview-page{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);padding:40px 48px;margin-bottom:16px;max-width:860px}.preview-cover{position:relative;min-height:480px}.preview-cover-bar{position:absolute;top:0;left:0;right:0;height:6px;background:var(--gold);border-radius:var(--radius) var(--radius) 0 0}.preview-cover-logo{width:60px;height:60px;background:var(--navy);color:var(--gold);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:900;margin-top:24px;margin-bottom:60px}.preview-cover-prepared{font-size:12px;font-weight:700;color:var(--teal);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:8px}.preview-cover-client{font-size:36px;font-weight:800;color:var(--navy);margin-bottom:16px}.preview-cover-rule{height:4px;background:var(--teal);border-radius:2px;margin-bottom:20px}.preview-cover-project{font-size:22px;font-weight:600;color:var(--navy);margin-bottom:20px}.preview-cover-meta{font-size:13px;color:var(--grey);opacity:.75;margin-bottom:24px}.preview-notice{border-left:4px solid var(--teal);padding:12px 16px;background:#f0fafa;border-radius:0 6px 6px 0}.preview-notice strong{display:block;font-size:11px;color:var(--navy);letter-spacing:1px;margin-bottom:4px}.preview-notice p{font-size:13px;color:var(--grey);font-style:italic}.preview-h1{font-size:22px;font-weight:800;color:var(--navy);border-bottom:3px solid var(--teal);padding-bottom:10px;margin-bottom:20px}.preview-h2{font-size:16px;font-weight:700;color:var(--teal);margin:24px 0 10px}.preview-h3{font-size:14px;font-weight:700;color:var(--navy);margin:16px 0 8px}.preview-body{font-size:14px;line-height:1.7;color:var(--grey);margin-bottom:12px}.preview-list{padding-left:24px;margin-bottom:12px}.preview-list li{font-size:14px;line-height:1.7;color:var(--grey);margin-bottom:4px}.preview-kv{display:grid;grid-template-columns:160px 1fr;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px;color:var(--grey)}.preview-kv>span:first-child{font-weight:600;color:var(--navy)}.preview-table-wrap{overflow-x:auto;margin:12px 0}.preview-table{width:100%;border-collapse:collapse;font-size:13px}.preview-table th{background:var(--navy);color:var(--white);font-weight:600;padding:10px 12px;text-align:left}.preview-table td{padding:9px 12px;border-bottom:1px solid var(--border);color:var(--grey)}.preview-table tr:nth-child(2n) td{background:var(--lgrey)}.comment-panel{display:grid;grid-template-columns:1fr 340px;gap:28px;align-items:start}.comment-left{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);padding:32px}.comment-title{font-size:22px;font-weight:800;color:var(--navy);margin-bottom:8px}.comment-sub{font-size:14px;color:var(--grey);margin-bottom:24px}.quick-edits{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.quick-label{font-size:12px;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}.quick-btn{background:#f0fafa;border:1px solid var(--teal);border-radius:6px;padding:7px 12px;font-size:12px;color:var(--navy);text-align:left;cursor:pointer;transition:background .15s}.quick-btn:hover{background:#d8f2f2}.comment-textarea{width:100%;border:1.5px solid var(--border);border-radius:8px;padding:14px;font-size:14px;font-family:inherit;color:var(--grey);resize:vertical;outline:none;transition:border-color .2s}.comment-textarea:focus{border-color:var(--teal)}.comment-actions{display:flex;justify-content:space-between;align-items:center;margin-top:16px}.comment-right{position:sticky;top:80px;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);padding:24px}.comment-preview-title{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--teal)}.comment-snapshot{display:flex;flex-direction:column;gap:10px}.snapshot-item{display:flex;flex-direction:column;gap:2px}.snapshot-label{font-size:10px;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.7px}.snapshot-value{font-size:13px;color:var(--navy);font-weight:500}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#241f4e8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:999}.loading-card{background:var(--white);border-radius:14px;padding:40px 48px;text-align:center;box-shadow:0 8px 40px #00000040}.spinner{width:44px;height:44px;border:4px solid var(--lgrey);border-top-color:var(--teal);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 20px}@keyframes spin{to{transform:rotate(360deg)}}.loading-msg{font-size:15px;color:var(--navy);font-weight:600}.error-banner{background:#fff0f0;border-bottom:3px solid #c00;padding:12px 32px;font-size:14px;color:#800;display:flex;align-items:center;justify-content:space-between}.error-close{background:none;border:none;font-size:20px;cursor:pointer;color:#800;line-height:1;padding:0}.hint{font-size:13px;color:var(--grey);opacity:.6}@media (max-width: 900px){.setup-grid,.preview-layout,.comment-panel{grid-template-columns:1fr}.steps{display:none}.preview-page{padding:24px 20px}}.manual-input{width:100%;box-sizing:border-box;border:1px solid #dce0e8;border-radius:8px;padding:12px 14px;font-size:14px;font-family:inherit;color:var(--navy);resize:vertical;line-height:1.55;transition:border-color .2s}.manual-input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px #54bdbf26}.optional-tag{font-size:12px;font-weight:400;color:var(--grey);background:#f0f4f8;border-radius:4px;padding:2px 7px;margin-left:8px;vertical-align:middle}.card-hint{font-size:13px;color:var(--grey);margin:0 0 10px;line-height:1.5}.input-toggle{display:flex;gap:0;border:1px solid #dce0e8;border-radius:8px;overflow:hidden;margin-bottom:20px}.toggle-btn{flex:1;padding:10px 0;font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;border:none;background:#f5f7fa;color:var(--grey);transition:background .15s,color .15s}.toggle-btn:first-child{border-right:1px solid #dce0e8}.toggle-btn.active{background:var(--navy);color:#fff}.toggle-btn:hover:not(.active){background:#eaecf2;color:var(--navy)}
