@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--bg: #f4f2f7;--surface: #ffffff;--surface2: #f8f7fb;--surface3: #efedf5;--border: #e8e5f0;--border2: #d4d0e3;--accent: #7c3aed;--accent-light: #8b5cf6;--accent-soft: #f3f0ff;--accent-mid: #c4b5fd;--gradient: linear-gradient(135deg, #7c3aed 0%, #a855f7 40%, #ec4899 100%);--gradient-soft: linear-gradient(135deg, #f3f0ff 0%, #fdf2f8 100%);--green: #10b981;--green-soft: #ecfdf5;--yellow: #f59e0b;--yellow-soft: #fffbeb;--red: #ef4444;--red-soft: #fef2f2;--text: #1e1b4b;--text2: #4c4673;--muted: #6b6394;--r: 16px;--shadow: 0 1px 3px rgba(0,0,0,.04), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px rgba(0,0,0,.04), 0 2px 4px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px rgba(0,0,0,.04), 0 4px 6px rgba(0,0,0,.06)}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;-webkit-font-smoothing:antialiased}.app{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.main{overflow-y:auto;background:var(--bg)}.content{padding:24px 32px;max-width:1400px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0;transform:translate(20px)}}@keyframes blink{50%{opacity:0}}.spin{width:15px;height:15px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.spin-dark{width:15px;height:15px;border:2px solid rgba(124,58,237,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.pulse{animation:pulse 2s infinite}code{background:var(--surface3);border:1px solid var(--border);padding:1px 7px;border-radius:6px;font-size:12px;font-family:JetBrains Mono,Fira Code,monospace;color:var(--text2)}a{color:var(--accent)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.skel{background:linear-gradient(90deg,var(--surface3) 25%,var(--surface2) 50%,var(--surface3) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--r)}.skel-title{height:24px;width:200px;margin-bottom:20px}.skel-card{height:180px;margin-bottom:16px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:768px){.app{grid-template-columns:1fr}.content{padding:16px}.sidebar{position:fixed;left:-280px;width:280px;height:100vh;z-index:100;transition:left .3s cubic-bezier(.4,0,.2,1);box-shadow:none}.sidebar.open{left:0;box-shadow:4px 0 24px #00000026}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.hamburger{display:flex!important}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:24px;margin-bottom:16px;box-shadow:var(--shadow);transition:box-shadow .2s}.card-gradient{background:var(--gradient-soft)}.ch{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px}.ct{font-size:15px;font-weight:700;color:var(--text)}.cs{font-size:12.5px;color:var(--muted);margin-top:2px}.btn{padding:9px 18px;border-radius:10px;border:none;cursor:pointer;font-size:13px;font-weight:600;transition:all .2s;display:inline-flex;align-items:center;gap:6px;font-family:inherit;min-height:38px}.bp{background:var(--accent);color:#fff;box-shadow:0 2px 8px #7c3aed40}.bp:hover{background:#6d28d9;transform:translateY(-1px);box-shadow:0 4px 16px #7c3aed59}.bs{background:var(--surface);color:var(--text2);border:1px solid var(--border)}.bs:hover{border-color:var(--accent-mid);color:var(--accent);background:var(--accent-soft)}.bg{background:var(--green-soft);color:var(--green);border:1px solid #a7f3d0}.bg:hover{background:#d1fae5}.sm{padding:7px 14px;font-size:12px;min-height:34px}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;box-shadow:none!important}.g2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}@media(max-width:768px){.g2,.g3,.g4,.fr,.qa{grid-template-columns:1fr}.btn{min-height:44px}}@media(max-width:1024px){.g4,.g3{grid-template-columns:1fr 1fr}}label{display:block;font-size:11px;font-weight:600;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.8px}input,select,textarea{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:10px 14px;color:var(--text);font-size:13.5px;outline:none;transition:all .2s;font-family:inherit}input[type=checkbox],input[type=radio]{width:auto;padding:0;border-radius:4px}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #7c3aed1a;background:#fff}textarea{resize:vertical}.fg{margin-bottom:14px}.fr{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}.tag{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:600}.tb{background:var(--accent-soft);color:var(--accent);border:1px solid var(--accent-mid)}.tg{background:var(--green-soft);color:var(--green);border:1px solid #a7f3d0}.ty{background:var(--yellow-soft);color:var(--yellow);border:1px solid #fde68a}.tr{background:var(--red-soft);color:var(--red);border:1px solid #fca5a5}.al{padding:12px 16px;border-radius:12px;font-size:13px;margin-bottom:14px;display:flex;align-items:flex-start;gap:10px}.ai{background:var(--accent-soft);border:1px solid var(--accent-mid);color:#5b21b6}.as{background:var(--green-soft);border:1px solid #a7f3d0;color:#065f46}.aw{background:var(--yellow-soft);border:1px solid #fde68a;color:#92400e}.ae{background:var(--red-soft);border:1px solid #fca5a5;color:#b91c1c}.sc{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px 20px;box-shadow:var(--shadow)}.sl{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.8px}.sv{font-size:28px;font-weight:800;margin:4px 0 0;color:var(--text)}.cl{display:flex;flex-wrap:wrap;gap:6px;margin-top:7px}.chip{background:var(--accent-soft);border:1px solid var(--accent-mid);border-radius:20px;padding:4px 12px;font-size:12px;display:flex;align-items:center;gap:6px;color:var(--accent);font-weight:500}.chip .x{cursor:pointer;color:var(--accent-mid);font-size:14px;line-height:1;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center}.chip .x:hover{color:#fff;background:var(--red)}.aio{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:16px;font-size:13px;line-height:1.75;white-space:pre-wrap;max-height:420px;overflow-y:auto;color:var(--text);font-family:JetBrains Mono,monospace;min-height:60px}.aio:empty:before{content:"AI output will appear here…";color:var(--muted);font-style:italic;font-family:Inter,sans-serif}.aio-md{background:var(--surface2);border:1px solid var(--border);border-radius:14px;padding:22px 26px;font-size:13.5px;line-height:1.7;max-height:600px;overflow-y:auto;color:var(--text);font-family:Inter,sans-serif;min-height:60px;scroll-behavior:smooth}.aio-placeholder{color:var(--muted);font-style:italic}.aio-md h1,.aio-md h2{font-size:16px;font-weight:700;color:var(--accent);margin:22px 0 10px;padding-bottom:6px;border-bottom:2px solid var(--accent-soft)}.aio-md h3{font-size:14px;font-weight:700;color:var(--text);margin:16px 0 8px}.aio-md h4{font-size:13px;font-weight:700;color:var(--text2);margin:12px 0 6px}.aio-md p{margin:6px 0}.aio-md ul,.aio-md ol{margin:6px 0;padding-left:22px}.aio-md li{margin:3px 0}.aio-md strong{color:var(--text);font-weight:700}.aio-md em{color:var(--text2)}.aio-md blockquote{margin:10px 0;padding:12px 18px;border-left:3px solid var(--accent);background:var(--accent-soft);border-radius:0 10px 10px 0;font-size:13px;color:#5b21b6}.aio-md code{background:var(--surface3);padding:2px 6px;border-radius:5px;font-size:12px;font-family:JetBrains Mono,monospace;color:var(--accent)}.aio-md pre{background:#1e1b4b;border:none;border-radius:10px;padding:14px 16px;overflow-x:auto;margin:8px 0}.aio-md pre code{background:none;padding:0;font-size:12px;color:#e2e8f0}.aio-md table{width:100%;border-collapse:collapse;margin:10px 0;font-size:12.5px}.aio-md th{background:var(--accent-soft);color:var(--accent);font-weight:600;text-align:left;padding:10px 12px;border:1px solid var(--accent-mid);font-size:11px;text-transform:uppercase;letter-spacing:.4px}.aio-md td{padding:8px 12px;border:1px solid var(--border);vertical-align:top}.aio-md tr:nth-child(2n) td{background:var(--surface2)}.aio-md tr:hover td{background:var(--accent-soft)}.aio-md hr{border:none;border-top:1px solid var(--border);margin:16px 0}.aio-md input[type=checkbox]{margin-right:6px;accent-color:var(--accent)}.streaming-cursor{display:inline-block;width:2px;height:1em;background:var(--accent);animation:blink 1s step-end infinite;margin-left:2px;vertical-align:text-bottom}.streaming-placeholder{display:flex;align-items:center;gap:10px;color:var(--muted);font-style:italic;padding:16px 0}.ws{display:flex;margin-bottom:22px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:4px;gap:3px}.wst{flex:1;text-align:center;padding:10px 6px;font-size:12px;color:var(--muted);cursor:pointer;transition:all .2s;border-radius:12px;font-weight:600}.wst span{font-size:10px;display:block;margin-bottom:1px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.wst:hover{background:var(--surface2);color:var(--text2)}.wst.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px #7c3aed4d}.wst.done{background:var(--green-soft);color:var(--green)}.tabs{display:flex;gap:2px;border-bottom:2px solid var(--border);margin-bottom:18px}.tab{padding:10px 16px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .18s}.tab:hover{color:var(--text2)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tp{display:none}.tp.active{display:block}.toast-container{position:fixed;bottom:20px;right:20px;z-index:1000;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{pointer-events:auto;animation:slideInRight .3s ease-out;box-shadow:var(--shadow-lg);min-width:280px;max-width:420px;font-size:13px;border-radius:12px}.toast-close{background:none;border:none;font-size:18px;cursor:pointer;color:inherit;opacity:.6;padding:0 0 0 8px;line-height:1;font-family:inherit}.toast-close:hover{opacity:1}.hamburger{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:6px;border-radius:8px}.hamburger:hover{background:var(--surface2)}.hamburger span{width:20px;height:2px;background:var(--text);border-radius:2px;transition:all .2s}.sb{display:flex;gap:8px}.sb input{flex:1}.cw{position:relative}.cw input{padding-right:66px}.ct2{position:absolute;right:9px;top:50%;transform:translateY(-50%);background:var(--surface3);border:1px solid var(--border);border-radius:6px;padding:3px 10px;font-size:11px;cursor:pointer;color:var(--muted);font-family:inherit;transition:all .15s}.ct2:hover{color:var(--accent);border-color:var(--accent-mid)}.pfx{display:flex}.pfx span{background:var(--surface3);border:1px solid var(--border);border-right:none;border-radius:10px 0 0 10px;padding:10px 12px;font-size:13px;color:var(--muted)}.pfx input{border-radius:0 10px 10px 0}.divider{height:1px;background:var(--border);margin:20px 0}.input-row{display:flex;gap:8px;align-items:center}.sidebar{background:var(--surface);border-right:1px solid var(--border);padding:0;display:flex;flex-direction:column;overflow-y:auto}.logo{padding:24px 22px 20px;border-bottom:1px solid var(--border)}.logo h1{font-size:17px;font-weight:800;color:var(--accent);letter-spacing:-.3px}.logo p{font-size:11.5px;color:var(--muted);margin-top:3px;font-weight:500}.ns{padding:20px 22px 8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--muted)}.ni{display:flex;align-items:center;gap:10px;padding:10px 22px;cursor:pointer;font-size:13.5px;font-weight:500;color:var(--text2);transition:all .2s;margin:1px 8px;border-radius:10px;text-decoration:none}.ni:hover{color:var(--accent);background:var(--accent-soft)}.ni.active{color:#fff;background:var(--gradient);font-weight:600;box-shadow:0 2px 8px #7c3aed4d}.ni .ico{font-size:16px;width:22px;text-align:center}.sf{margin-top:auto;padding:16px 22px;border-top:1px solid var(--border)}.status-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text2);margin-bottom:7px}.dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dot.on{background:var(--green);box-shadow:0 0 6px var(--green)}.dot.off{background:#d4d0e3}.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:16px 32px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}.topbar h2{font-size:16px;font-weight:700;color:var(--text)}@media(max-width:768px){.topbar{padding:12px 16px}.topbar h2{font-size:14px}}.qa{display:grid;grid-template-columns:1fr 1fr;gap:12px}.qa-item{background:var(--surface2);border:1px solid var(--border);border-radius:14px;padding:16px 18px;cursor:pointer;transition:all .2s;display:flex;align-items:flex-start;gap:14px}.qa-item:hover{border-color:var(--accent-mid);background:var(--accent-soft);transform:translateY(-2px);box-shadow:var(--shadow-md)}.qa-num{width:32px;height:32px;border-radius:10px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}.qa-text h4{font-size:13.5px;font-weight:700;color:var(--text)}.qa-text p{font-size:12px;color:var(--muted);margin-top:3px;line-height:1.4}@media(max-width:768px){.qa{grid-template-columns:1fr}}.camp-row{padding:14px 16px;background:var(--surface2);border:1px solid var(--border);border-radius:12px;margin-bottom:8px;display:flex;align-items:center;gap:12px;transition:all .15s}.camp-row:hover{border-color:var(--accent-mid);box-shadow:var(--shadow)}.scr-setup{background:var(--gradient-soft);border:1px solid var(--accent-mid);border-radius:14px;padding:18px 20px;margin-bottom:16px}.scr-setup h4{font-size:13px;font-weight:700;color:var(--accent);margin-bottom:8px}.scr-setup .steps{display:flex;flex-direction:column;gap:5px}.scr-setup .step{font-size:12px;color:var(--text2);display:flex;align-items:center;gap:8px}.hero{background:var(--gradient);border-radius:var(--r);padding:28px 32px;color:#fff;margin-bottom:20px;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;border-radius:50%;background:#ffffff14}.hero:after{content:"";position:absolute;right:60px;bottom:-60px;width:140px;height:140px;border-radius:50%;background:#ffffff0d}.hero h2{font-size:22px;font-weight:800;margin-bottom:6px;letter-spacing:-.3px}.hero p{font-size:14px;opacity:.9;font-weight:400}.prog-bar{height:4px;background:var(--surface3);border-radius:4px;overflow:hidden;margin:10px 0 0}.prog-fill{height:100%;background:var(--gradient);border-radius:4px;transition:width .5s ease}
