:root{--bg:#07070d;--panel:#0d0d16;--border:#1a1a28;--text:#e0e0e8;--muted:#8888a0;--dim:#555568;--gold:#c8a245;--gold-light:#e0c878;--green:#3a9;--red:#e55;--font:system-ui,-apple-system,sans-serif}
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--bg);font-family:var(--font);color:var(--text);height:100vh;display:flex;overflow:hidden}
.sidebar{width:280px;background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}
.sidebar .side-logo{padding:16px 18px;font-weight:700;font-size:.85rem;color:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.sidebar .side-logo .dot{width:8px;height:8px;background:var(--gold);border-radius:50%}
.sidebar .side-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:4px;overflow-y:auto;overflow-x:hidden}
.sidebar .side-nav .nav-group{margin-bottom:8px}
.sidebar .side-nav .nav-group .group-title{font-size:.6rem;text-transform:uppercase;letter-spacing:.08em;color:var(--dim);padding:8px 12px 4px;font-weight:600}
.sidebar .side-nav .nav-group .group-title.clickable{cursor:pointer;display:flex;justify-content:space-between;align-items:center;user-select:none}
.sidebar .side-nav .nav-group .group-title.clickable:hover{color:var(--muted)}
.sidebar .side-nav .nav-group .group-title .arrow{font-size:.55rem;transition:transform .2s}
.sidebar .side-nav .nav-group .group-title .arrow.open{transform:rotate(180deg)}
.sidebar .side-nav .sn-item{padding:8px 12px;border-radius:6px;font-size:.78rem;cursor:pointer;color:var(--muted);transition:all .15s;display:flex;align-items:center;gap:10px}
.sidebar .side-nav .sn-item:hover{background:rgba(255,255,255,.03);color:#fff}
.sidebar .side-nav .sn-item.active{background:rgba(200,162,69,.1);color:var(--gold-light)}
.sidebar .side-nav .config-item{padding:8px 12px;border-radius:6px;font-size:.7rem;color:var(--muted);display:flex;flex-direction:column;gap:6px;margin-top:4px}
.sidebar .side-nav .config-item input{background:#0a0a10;border:1px solid var(--border);border-radius:4px;padding:4px 6px;font-size:.6rem;color:#fff;outline:none;font-family:var(--font);width:100%}
.sidebar .side-nav .config-item input:focus{border-color:rgba(200,162,69,.3)}
.sidebar .side-nav .config-item input::placeholder{color:#444}
.sidebar .side-nav .config-item button{padding:4px 10px;border-radius:6px;font-size:.65rem;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--gold-light);font-family:var(--font);margin-top:4px;transition:all .15s}
.sidebar .side-nav .config-item button:hover{background:rgba(200,162,69,.1)}
.sidebar .side-nav .config-item select{background:#0a0a10;border:1px solid var(--border);border-radius:4px;padding:4px 6px;font-size:.6rem;color:#fff;outline:none;font-family:var(--font)}
.sidebar .side-nav .ftp-item{padding:8px 12px;border-radius:6px;font-size:.7rem;color:var(--muted);display:flex;flex-direction:column;gap:6px;margin-top:4px;background:rgba(57,153,102,.05)}
.sidebar .side-nav .ftp-item .ftp-label{font-size:.58rem;color:var(--dim);text-transform:uppercase;letter-spacing:.04em;margin-bottom:1px}
.sidebar .side-nav .ftp-item .ftp-row{display:flex;gap:4px;margin-bottom:4px}
.sidebar .side-nav .ftp-item .ftp-row input{flex:1;background:#0a0a10;border:1px solid var(--border);border-radius:4px;padding:3px 5px;font-size:.58rem;color:#fff;outline:none}
.sidebar .side-nav .ftp-item .ftp-row input:focus{border-color:rgba(200,162,69,.3)}
.sidebar .side-nav .ftp-item .ftp-row select{flex:1;background:#0a0a10;border:1px solid var(--border);border-radius:4px;padding:3px 5px;font-size:.58rem;color:#fff;outline:none}
.sidebar .side-nav .ftp-item .ftp-row button{padding:4px 8px;border-radius:6px;font-size:.6rem;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--gold-light);font-family:var(--font);transition:all .15s;flex:1}
.sidebar .side-nav .ftp-item .ftp-row button:hover{background:rgba(200,162,69,.1)}
.sidebar .side-nav .ftp-item .ftp-status{font-size:.58rem;margin-top:2px;padding:3px 6px;border-radius:4px}
.sidebar .side-nav .ftp-item .ftp-status.success{background:rgba(57,153,102,.15);color:var(--green)}
.sidebar .side-nav .ftp-item .ftp-status.error{background:rgba(229,85,85,.15);color:var(--red)}
.sidebar .side-footer{padding:10px 14px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-size:.7rem}
.sidebar .side-footer .user-name{color:var(--gold-light);font-weight:500}
.sidebar .side-footer .logout-btn{color:var(--muted);cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:4px}
.sidebar .side-footer .logout-btn:hover{color:#fff}
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.main .toolbar{background:var(--panel);border-bottom:1px solid var(--border);padding:8px 16px;display:flex;align-items:center;gap:8px;flex-shrink:0}
.main .toolbar .tb-btn{padding:6px 12px;border-radius:6px;font-size:.72rem;cursor:pointer;border:1px solid transparent;background:transparent;color:var(--muted);font-family:var(--font);transition:all .15s}
.main .toolbar .tb-btn:hover{background:rgba(255,255,255,.03);color:#fff}
.main .toolbar .tb-spacer{flex:1}
.main .content{flex:1;overflow-y:auto;padding:24px}
.main .content .generator{max-width:650px;margin:0 auto}
.main .content .generator h2{font-size:1.3rem;font-weight:700;letter-spacing:-.02em;color:#fff;margin-bottom:4px;text-align:center}
.main .content .generator .sub{font-size:.75rem;color:var(--muted);text-align:center;margin-bottom:20px}
.main .content .generator .input-row{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.main .content .generator .input-row textarea{width:100%;background:#0a0a10;border:1px solid var(--border);border-radius:8px;padding:12px 14px;font-size:.82rem;color:#fff;outline:none;font-family:var(--font);resize:vertical;min-height:60px;max-height:120px;line-height:1.5}
.main .content .generator .input-row textarea:focus{border-color:rgba(200,162,69,.3)}
.main .content .generator .input-row textarea::placeholder{color:#444}
.main .content .generator .input-row button{padding:11px 20px;border-radius:8px;font-size:.82rem;font-weight:600;cursor:pointer;border:none;font-family:var(--font);white-space:nowrap;background:linear-gradient(135deg,#c8a245,#e0c878);color:#000;width:100%}
.main .content .generator .input-row button:disabled{opacity:.5;cursor:not-allowed}
.main .content .generator .case-links{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:12px}
.main .content .generator .case-links a{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border-radius:20px;font-size:.65rem;background:rgba(200,162,69,.08);border:1px solid var(--border);color:var(--gold-light);text-decoration:none;transition:all .15s}
.main .content .generator .case-links a:hover{background:rgba(200,162,69,.15);border-color:rgba(200,162,69,.3)}
.main .content .generator .info{font-size:.62rem;color:var(--dim);text-align:center}
.main .statusbar{background:var(--panel);border-top:1px solid var(--border);padding:3px 14px;display:flex;justify-content:space-between;font-size:.62rem;color:var(--dim);flex-shrink:0}
.panel-right{width:260px;background:var(--panel);border-left:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}
.panel-right .pr-header{padding:12px 14px;font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:var(--dim);font-weight:600;border-bottom:1px solid var(--border);flex-shrink:0}
.panel-right .pr-content{flex:1;overflow-y:auto;padding:12px}
.panel-right .pr-item{padding:10px 12px;border-radius:6px;cursor:pointer;transition:all .12s;display:flex;align-items:center;gap:10px;font-size:.76rem;color:var(--muted)}
.panel-right .pr-item:hover{background:rgba(255,255,255,.02);color:#fff}
.panel-right .pr-item .pr-icon{font-size:.8rem;width:20px;text-align:center}
.panel-right .pr-item .pr-badge{margin-left:auto;font-size:.56rem;background:rgba(200,162,69,.12);color:var(--gold-light);padding:2px 7px;border-radius:10px}
.panel-right .pr-item .pr-delete{width:20px;height:20px;border-radius:50%;background:transparent;border:none;color:#444;font-size:.65rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;opacity:0}
.panel-right .pr-item:hover .pr-delete{opacity:1}
.panel-right .pr-item .pr-delete:hover{background:rgba(255,80,80,.15);color:var(--red)}
.panel-right .pr-footer{padding:10px 12px;border-top:1px solid var(--border);font-size:.62rem;color:var(--dim);text-align:center}
.deploy-box{background:rgba(200,162,69,.05);border:1px solid var(--border);border-radius:8px;padding:12px;margin-bottom:12px}
.deploy-box .title{font-size:.72rem;font-weight:600;color:var(--gold-light);margin-bottom:8px}
.deploy-step{padding:6px 0;border-bottom:1px solid var(--border);font-size:.68rem;display:flex;gap:8px}
.deploy-step .step-num{color:var(--gold-light);min-width:20px}
.code-box{background:#0a0a10;border:1px solid var(--border);border-radius:6px;padding:8px;font-family:monospace;font-size:.6rem;color:var(--muted);margin-top:8px;word-break:break-all}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#fff;color:#000;padding:10px 22px;border-radius:20px;font-size:.72rem;z-index:400;display:none;white-space:pre-wrap;box-shadow:0 8px 24px rgba(0,0,0,.3);font-weight:600;max-width:90vw;text-align:center}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:200;display:none;align-items:center;justify-content:center}
.modal-overlay.show{display:flex}
.modal-box{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:24px;width:90%;max-width:450px;box-shadow:0 20px 40px rgba(0,0,0,.5)}
.modal-box h3{font-size:.95rem;font-weight:700;color:#fff;margin-bottom:4px}
.modal-box .sub{font-size:.68rem;color:var(--dim);margin-bottom:16px}
.modal-box input{width:100%;background:#0a0a10;border:1px solid var(--border);border-radius:6px;padding:10px 12px;font-size:.8rem;color:#fff;outline:none;font-family:var(--font);margin-bottom:10px}
.modal-box input:focus{border-color:rgba(200,162,69,.3)}
.modal-box .btn-row{display:flex;gap:8px;margin-top:16px}
.modal-box .btn-row button{flex:1;padding:10px;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;font-family:var(--font);border:1px solid var(--border);background:transparent;color:var(--muted);transition:all .15s}
.modal-box .btn-row button:hover{background:rgba(255,255,255,.05)}
.modal-box .btn-row button.primary{background:linear-gradient(135deg,#c8a245,#e0c878);border-color:var(--gold);color:#000}
.modal-box .btn-row button.primary:hover{opacity:.9}
.modal-box .btn-row button.danger{background:transparent;border-color:rgba(255,80,80,.3);color:var(--red)}
.purchase-option{background:#0a0a10;border:1px solid var(--border);border-radius:8px;padding:12px;margin-bottom:6px;cursor:pointer;transition:all .15s;display:flex;justify-content:space-between;align-items:center}
.purchase-option:hover{border-color:rgba(200,162,69,.3);background:rgba(200,162,69,.04)}
.purchase-option.selected{border-color:var(--gold);background:rgba(200,162,69,.08)}
.feature-option{background:#0a0a10;border:1px solid var(--border);border-radius:8px;padding:10px 12px;margin-bottom:4px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:10px}
.feature-option:hover{border-color:rgba(200,162,69,.2)}
.feature-option input[type="checkbox"]{width:auto;margin:0;accent-color:var(--gold)}
.feature-option .feature-info{flex:1}
.feature-option .feature-info strong{font-size:.75rem;color:#fff}
.feature-option .feature-info div{font-size:.62rem;color:var(--dim);margin-top:2px}
.feature-list-scroll{max-height:320px;overflow-y:auto;margin-bottom:12px}
.batch-warning{background:rgba(229,85,85,.1);border:1px solid var(--red);border-radius:6px;padding:6px 10px;margin-top:8px;font-size:.6rem;color:var(--red);text-align:center}
.preview-modal{position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:300;display:none;flex-direction:column}
.preview-modal.show{display:flex}
.preview-modal .pm-bar{padding:10px 16px;display:flex;justify-content:space-between;align-items:center;background:var(--panel);border-bottom:1px solid var(--border)}
.preview-modal .pm-bar .pm-title{font-size:.8rem;font-weight:600;color:#fff}
.preview-modal .pm-bar .pm-actions{display:flex;gap:6px}
.preview-modal .pm-bar button{background:none;border:none;color:var(--muted);font-size:.7rem;cursor:pointer;padding:5px 10px;border-radius:4px;font-family:var(--font);transition:all .15s}
.preview-modal .pm-bar button:hover{background:rgba(255,255,255,.04);color:#fff}
.preview-modal .pm-bar .pm-close{color:#fff;font-size:1.1rem}
.preview-modal iframe{flex:1;border:none;background:#fff}
@media(max-width:800px){.sidebar{width:240px}.panel-right{width:240px}}
@media(max-width:600px){.panel-right{display:none}.main .content{padding:16px}}