:root{--bg-main: #f7f8fc;--bg-blend: #e7e6f7;--panel: #ffffff;--panel-strong: rgba(255, 255, 255, .86);--text: #111111;--muted: #666666;--accent: #b46cff;--accent-strong: #a156ff;--border: #eaeaea;--border-strong: #dcd7f3;--system: #eef6ff;--error: #ffecec;--shadow-soft: 0 12px 40px rgba(25, 23, 40, .08);--shadow-strong: 0 20px 60px rgba(25, 23, 40, .12)}*{box-sizing:border-box}html,body,#root{margin:0;width:100%;min-height:100%}body{font-family:Inter,Arial,sans-serif;color:var(--text);background:var(--bg-main)}.mainBg{min-height:100vh;width:100%;display:flex;align-items:stretch;justify-content:stretch;background:radial-gradient(circle at top right,rgba(180,108,255,.16),transparent 28%),radial-gradient(circle at left bottom,rgba(92,152,255,.12),transparent 26%),linear-gradient(135deg,var(--bg-main) 72%,var(--bg-blend) 100%);padding:18px}.authPageBg{padding:18px}.authLoading{background:#fff;border:1px solid var(--border);padding:16px 20px;border-radius:14px;font-weight:600}.authShell{width:min(1320px,100%);min-height:calc(100vh - 36px);display:grid;grid-template-columns:1.02fr .98fr;background:var(--panel-strong);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-radius:28px;overflow:hidden;border:1px solid rgba(255,255,255,.72);box-shadow:var(--shadow-strong)}.authFormPane{padding:clamp(28px,4vw,56px);background:linear-gradient(180deg,#ffffffe0,#f7f8fcf0),radial-gradient(circle at top left,rgba(180,108,255,.08),transparent 30%);display:flex;flex-direction:column;justify-content:center}.authTitle{margin:0;font-family:Montserrat,Arial,sans-serif;font-size:clamp(2rem,3vw,3.25rem);line-height:1.02;letter-spacing:-.03em}.authSubtitle{margin:14px 0 22px;color:var(--muted);font-size:1rem;max-width:46ch}.authTabs{background:#ececf4e0;border:1px solid rgba(220,215,243,.7);border-radius:14px;padding:5px;display:grid;grid-template-columns:1fr 1fr;gap:5px;margin-bottom:20px}.authTab{border:none;padding:12px 10px;border-radius:10px;background:transparent;color:#70707b;font-weight:700;cursor:pointer}.authTab.active{background:#fff;color:#111;box-shadow:0 4px 16px #19172814}.authForm{display:grid;gap:14px;max-width:520px}.authLabel{display:grid;gap:6px;font-size:.94rem;color:#2a2a33}.authInput{border:1px solid rgba(216,216,228,.95);border-radius:14px;background:#ffffffeb;padding:14px 15px;font-size:.98rem;transition:border-color .12s ease,box-shadow .12s ease,transform .12s ease}.authInput:focus{outline:none;border-color:#b46cffb8;box-shadow:0 0 0 4px #b46cff24}.authError{background:#ffecec;color:#9d2f2f;border:1px solid #ffd6d6;border-radius:10px;padding:10px 12px;font-size:.9rem}.authSubmit{margin-top:8px;border:none;border-radius:14px;padding:14px 16px;color:#fff;font-weight:800;font-size:1rem;background:linear-gradient(90deg,var(--accent-strong),var(--accent));box-shadow:0 10px 24px #b46cff38;cursor:pointer}.authSubmit:disabled{opacity:.75;cursor:not-allowed}.authVisualPane{position:relative;min-height:100%;background:linear-gradient(180deg,#10121c26,#10121c80),#111}.authVisualImg{width:100%;height:100%;object-fit:cover;opacity:.93}.authVisualOverlay{position:absolute;left:28px;right:28px;bottom:28px;border:1px solid rgba(255,255,255,.12);background:#090b1194;color:#edf2ff;padding:16px 18px;border-radius:18px;font-size:.98rem;line-height:1.5;box-shadow:var(--shadow-soft)}.assistantWrapper{background:linear-gradient(180deg,#ffffffe0,#fffffff5);border-radius:30px;box-shadow:var(--shadow-strong);width:min(1440px,calc(100vw - 36px));min-height:calc(100vh - 36px);max-width:100%;margin:0 auto;display:flex;flex-direction:row;position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.7);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.assistantWrapper:before{content:"";position:absolute;left:0;top:0;right:0;bottom:0;background-image:repeating-linear-gradient(to right,var(--border) 0 1px,transparent 1px 55px),repeating-linear-gradient(to bottom,var(--border) 0 1px,transparent 1px 55px);opacity:.45;pointer-events:none;z-index:1}.bgDecor{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden}.bgBubble,.bgRing{position:absolute;display:block}.bgBubble{border-radius:999px;filter:blur(.2px);opacity:.6}.bubbleOne{width:180px;height:180px;top:-40px;right:-40px;background:radial-gradient(circle at 30% 30%,#b46cff59,#b46cff0a 70%);animation:floatDriftA 9s ease-in-out infinite}.bubbleTwo{width:220px;height:220px;bottom:-70px;left:-70px;background:radial-gradient(circle at 35% 35%,#5c98ff38,#5c98ff08 72%);animation:floatDriftB 11s ease-in-out infinite}.bubbleThree{width:130px;height:130px;top:38%;right:14%;background:radial-gradient(circle at 40% 40%,#ffc57033,#ffc57008 70%);animation:floatDriftC 8s ease-in-out infinite}.bgRing{width:320px;height:320px;border-radius:999px;border:1px solid rgba(180,108,255,.16);top:44%;right:-120px;transform-origin:center;animation:orbitTilt 18s linear infinite}@keyframes floatDriftA{0%,to{transform:translateZ(0)}50%{transform:translate3d(-8px,10px,0)}}@keyframes floatDriftB{0%,to{transform:translateZ(0)}50%{transform:translate3d(10px,-8px,0)}}@keyframes floatDriftC{0%,to{transform:translateZ(0)}50%{transform:translate3d(-6px,7px,0)}}@keyframes orbitTilt{0%{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(1.03)}to{transform:rotate(360deg) scale(1)}}.assistantLeft{flex:1 1 0;padding:clamp(22px,2.5vw,34px);display:flex;flex-direction:column;z-index:2}.assistantHeaderRow{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:12px}.assistantHeaderRight{margin-left:auto;display:flex;align-items:center;justify-content:flex-end;gap:10px}.chatTopActions{display:flex;gap:8px}.iconActionBtn{border:none;border-radius:10px;width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;cursor:pointer;font-size:1.3rem;font-weight:700;line-height:1}.iconActionBtn.ghost{background:#eef1f8;color:#2b3350}.iconActionBtn svg{display:block}.topActionBtn{border:none;border-radius:8px;padding:8px 10px;font-size:.8rem;font-weight:600;background:var(--accent);color:#fff;cursor:pointer}.topActionBtn.ghost{background:#eef1f8;color:#2b3350}.historyOverlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0c1473;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:40;display:flex;align-items:center;justify-content:center;padding:16px}.historyPanel{width:min(740px,100%);max-height:84vh;overflow:hidden;border-radius:18px;background:#fff;border:1px solid #ececf4}.historyHeader{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #ececf4}.historyHeader h3{margin:0;font-size:1rem;font-family:Montserrat,Arial,sans-serif}.historyBody{padding:12px;overflow:auto;max-height:calc(84vh - 60px);display:grid;gap:10px}.historyEmpty{border:1px dashed #d9daea;border-radius:10px;padding:16px;color:#5f647e;text-align:center}.historyItem{text-align:left;border:1px solid #e7e8f3;border-radius:12px;padding:10px;background:#fbfbfe;cursor:pointer}.historyItem.active{border-color:#b46cff;box-shadow:inset 0 0 0 1px #b46cff4d}.historyItemTop{display:flex;justify-content:space-between;gap:8px}.historyId{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.76rem;color:#44485c}.historyStatus{font-size:.74rem;text-transform:capitalize;border-radius:999px;padding:2px 8px;background:#eceffc;color:#334385}.historyMeta{margin-top:6px;font-size:.79rem;color:#555b75;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.assistantDate{font-size:.95rem;margin-bottom:10px}.assistantDateCompact{font-size:.8rem;margin-bottom:0;color:#5e6379}.assistantTitle{font-size:clamp(2rem,2.6vw,3.3rem);font-weight:800;color:var(--text);margin:0;line-height:1.02;letter-spacing:-.03em;font-family:Montserrat,Arial,sans-serif}.assistantName{color:var(--accent);font-weight:800}.assistantQuestion{font-size:clamp(1.1rem,1.5vw,1.45rem);color:var(--accent);font-style:normal;font-weight:700;margin:8px 0 10px;font-family:Montserrat,Arial,sans-serif}.buildHint{margin-top:2px;margin-bottom:6px;font-size:.92rem;color:var(--muted)}.generatedSummaryRow{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin:4px 0 10px}.generatedSummaryPill{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;background:#b46cff1f;color:#5d2fa8;font-size:.82rem;font-weight:700}.generatedSummaryHint{color:var(--muted);font-size:.82rem}.logsHeader{display:flex;justify-content:flex-end;align-items:center;margin:0 0 8px}.copyLogsBtn{border:1px solid rgba(180,108,255,.22);border-radius:999px;background:linear-gradient(180deg,#b46cff1f,#b46cff0f);color:#5d2fa8;font-weight:700;font-size:.82rem;padding:9px 12px;cursor:pointer;box-shadow:0 8px 18px #1917280d}.copyLogsBtn:hover{border-color:#b46cff6b;background:linear-gradient(180deg,#b46cff2e,#b46cff17)}.copyLogsBtn:active{transform:translateY(1px)}.generatedFilesPanel{display:grid;gap:10px;margin-bottom:10px;max-height:26vh;overflow:auto;padding-right:4px}.generatedFilesEmpty{border:1px dashed #d9daea;border-radius:14px;padding:16px;color:#5f647e;background:#ffffffbd}.generatedFileRow{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid #e7e8f3;border-radius:14px;padding:12px;background:#fbfbfe;box-shadow:0 8px 18px #1917280a}.generatedFileMeta{min-width:0;display:grid;gap:4px}.generatedFilePath{font-size:.86rem;font-weight:700;color:#22253b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.generatedFileLines{font-size:.78rem;color:#5f647e}.eyeBtn{border:1px solid rgba(180,108,255,.18);border-radius:12px;min-width:42px;min-height:42px;width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#b46cff24,#b46cff14);color:#5d2fa8;cursor:pointer;flex:0 0 auto;transition:transform .12s ease,border-color .12s ease,background .12s ease}.eyeBtn:hover{border-color:#b46cff6b;background:linear-gradient(180deg,#b46cff33,#b46cff1f);transform:translateY(-1px)}.eyeBtn svg{display:block}.socketStatus{margin-bottom:10px;width:min(640px,100%);border:1px solid rgba(220,223,236,.95);border-radius:999px;background:#ffffffd6;font-size:.82rem;padding:8px 12px;color:#444;display:flex;align-items:center;gap:8px;box-shadow:0 8px 22px #1917280a}.socketStatusCentered{margin-left:auto;margin-right:auto}.socketChip{border-radius:999px;padding:3px 8px;font-size:.74rem;font-weight:600;text-transform:capitalize;line-height:1;background:#f3f4f8}.socket-connected{background:#e9f8ee;color:#1f7a3d}.socket-disconnected{background:#ffecec;color:#9d2f2f}.socket-connecting{background:#eef6ff;color:#1f5f9d}.socketText{min-width:0;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.socketPct{font-weight:600}.assistantInputRow{margin-top:12px;display:flex;align-items:center;width:100%;max-width:100%;background:#ffffffe6;border-radius:22px;box-shadow:0 10px 26px #0000000f;border:1.5px solid rgba(220,223,236,.95);padding:6px 8px 6px 16px;margin-bottom:max(8px,env(safe-area-inset-bottom))}.assistantInput{flex:1;border:none;outline:none;font-size:1.02rem;background:transparent;color:#222;padding:16px 0}.assistantSend{border:none;border-radius:12px;padding:11px 14px;background:var(--accent);color:#fff;font-weight:600;cursor:pointer}.assistantSend:disabled{opacity:.6;cursor:not-allowed}.activityBox{margin-top:8px;width:100%;max-width:100%;border-radius:18px;background:#ffffffe0;border:1px solid rgba(220,223,236,.9);min-height:112px;max-height:none;flex:1;overflow:auto;padding:14px;box-shadow:inset 0 1px #fffc}.projectMeta{margin-top:8px;font-size:.77rem;color:#6a6a76;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.msg{font-size:.86rem;line-height:1.4;margin-bottom:8px;padding:6px 8px;border-radius:8px;overflow-wrap:anywhere;word-break:break-word}.msg a{color:inherit;text-decoration:underline;overflow-wrap:anywhere}.msg.user{background:#f0e8ff}.msg.assistant{background:#f8f8fb}.msg.system{background:var(--system)}.msg.error{background:#fff2f2;color:#8d2a2a;border:1px solid #ffd7d7}.msg.details{background:#f6f7fb;border:1px solid #dfe3f1}.msgDetails{display:grid;gap:8px}.msgDetails summary{cursor:pointer;font-weight:600;color:#39415f;list-style:none}.msgDetails summary::-webkit-details-marker{display:none}.msgDetails summary:before{content:"▸";display:inline-block;margin-right:6px;transition:transform .15s ease}.msgDetails[open] summary:before{transform:rotate(90deg)}.msgDetails pre{margin:0;white-space:pre-wrap;word-break:break-word;font:inherit;color:#2d334d;background:#fff;border:1px solid #e4e7f3;border-radius:10px;padding:10px;overflow:auto}.connectionRow{display:flex;align-items:center;gap:8px;margin-bottom:10px}.elapsedTimer{font-size:.78rem;color:var(--muted);font-weight:600}.phaseTracker{display:flex;align-items:center;padding:14px 4px;margin-bottom:10px;overflow-x:auto;scrollbar-width:none}.phaseTracker::-webkit-scrollbar{display:none}.phaseStep{display:flex;flex-direction:column;align-items:center;gap:5px;flex-shrink:0}.phaseStepDot{width:26px;height:26px;border-radius:50%;border:2px solid #dcd7f3;background:#f7f8fc;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#bbb;transition:background .2s ease,border-color .2s ease,color .2s ease}.phaseStep.done .phaseStepDot{background:#e5f7ec;border-color:#2a9d54;color:#2a9d54}.phaseStep.active .phaseStepDot{background:#b46cff1f;border-color:var(--accent);color:var(--accent);animation:phasePulse 1.5s ease-in-out infinite}@keyframes phasePulse{0%,to{box-shadow:0 0 #b46cff59}50%{box-shadow:0 0 0 5px #b46cff00}}.phaseStepLabel{font-size:.68rem;font-weight:600;color:#bbb;white-space:nowrap;transition:color .2s ease}.phaseStep.done .phaseStepLabel{color:#2a9d54}.phaseStep.active .phaseStepLabel{color:var(--accent-strong)}.phaseConnector{flex:1 1 0;height:2px;min-width:10px;max-width:36px;background:#dcd7f3;margin-bottom:20px;transition:background .2s ease}.phaseConnector.done{background:#2a9d54}.buildLogSection{margin-bottom:8px}.buildLogToggle{border:1px solid rgba(180,108,255,.2);border-radius:999px;background:transparent;color:#7a4ecf;font-size:.76rem;font-weight:600;padding:5px 12px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background .12s ease}.buildLogToggle:hover{background:#b46cff12}.buildLogCount{background:#b46cff26;color:#6136b0;border-radius:999px;padding:1px 7px;font-size:.7rem;font-weight:700}.buildLogPanel{margin-top:7px;background:#0e0f14;border-radius:12px;padding:12px 14px;max-height:180px;overflow-y:auto;font-family:JetBrains Mono,Fira Code,Menlo,Courier New,monospace;font-size:.71rem;line-height:1.6;color:#9ab3cb;scrollbar-width:thin;scrollbar-color:#2a2d3a transparent}.buildLogLine{white-space:pre-wrap;word-break:break-all}.generatedFilesSection{margin-bottom:10px;display:flex;flex-direction:column;gap:6px}.chatEmptyHint{color:var(--muted);font-size:.88rem;padding:10px 4px}.deployCard{margin:8px 0;border:1px solid #b8f0ca;border-radius:14px;background:linear-gradient(135deg,#f0fdf4,#e6f9ed);padding:16px 18px;display:flex;flex-direction:column;gap:8px}.deployCardLabel{font-size:.78rem;font-weight:700;color:#1f7a3d;text-transform:uppercase;letter-spacing:.04em}.deployCardUrl{font-size:.84rem;color:#1a6632;word-break:break-all;text-decoration:none}.deployCardUrl:hover{text-decoration:underline}.deployCardBtn{align-self:flex-start;background:#1f7a3d;color:#fff;border-radius:999px;padding:8px 18px;font-size:.82rem;font-weight:700;text-decoration:none;transition:background .12s ease}.deployCardBtn:hover{background:#196633}.confirmationCard{margin:8px 0;border:1px solid #bfdbfe;border-radius:14px;background:linear-gradient(135deg,#eff6ff,#dbeafe);padding:16px 18px;display:flex;flex-direction:column;gap:12px}.confirmationSummary{font-size:.88rem;color:#1e3a5f;line-height:1.6;white-space:pre-wrap}.confirmationActions{display:flex;flex-direction:column;gap:6px}.startBuildBtn{align-self:flex-start;background:#1d4ed8;color:#fff;border:none;border-radius:999px;padding:9px 22px;font-size:.84rem;font-weight:700;cursor:pointer;transition:background .12s ease}.startBuildBtn:hover{background:#1e40af}.confirmHint{font-size:.75rem;color:#4b6a94}.historyUrl{font-size:.78rem;color:#1d4ed8;text-decoration:none;word-break:break-all}.historyUrl:hover{text-decoration:underline}@media (max-width: 900px){.mainBg{padding:10px}.authShell{grid-template-columns:1fr;min-height:calc(100vh - 20px)}.authFormPane{padding:28px 18px}.authVisualPane{min-height:240px}.assistantWrapper{flex-direction:column;width:100%;min-height:calc(100vh - 20px);border-radius:24px}.assistantLeft{padding:22px 14px 12px}.assistantHeaderRow{align-items:flex-start;flex-direction:row;gap:10px}.assistantHeaderRight{width:auto;gap:8px}.assistantTitle{font-size:1.75rem}.assistantQuestion{font-size:1.06rem}.activityBox{max-height:300px}}@media (max-width: 600px){.authPageBg{padding:8px}.authTitle{font-size:1.6rem}.authVisualPane{min-height:210px}.assistantDate{font-size:.88rem;margin-bottom:10px}.assistantTitle{font-size:1.35rem;line-height:1.08}.assistantQuestion{font-size:.98rem;margin-bottom:8px}.socketStatus{font-size:.74rem;gap:6px;padding:5px 8px}.socketChip{padding:2px 7px;font-size:.68rem}.buildHint{margin-bottom:5px;font-size:.84rem}.logsHeader{margin-bottom:6px}.copyLogsBtn{width:100%}.assistantInput{font-size:.98rem;padding:13px 0}.assistantSend{padding:10px 12px;font-size:.92rem}.activityBox{max-height:42vh}.assistantWrapper{max-width:100vw;border-radius:20px}.historyOverlay{align-items:flex-end;padding:8px}.historyPanel{width:100%;max-height:82vh;border-radius:16px 16px 0 0}.historyHeader{padding:12px;gap:10px;align-items:flex-start}.historyBody{padding:10px;max-height:calc(82vh - 72px)}.historyItem{padding:10px}.historyId{font-size:.71rem;max-width:64vw;overflow:hidden;text-overflow:ellipsis}.historyMeta{white-space:normal;overflow-wrap:anywhere}.assistantInput{font-size:.96rem;padding:14px 0}.chatTopActions{width:auto;flex-wrap:wrap}.iconActionBtn{width:36px;height:36px}}.fileDialogOverlay{z-index:50}.fileDialogPanel{width:min(900px,96vw);max-height:88vh;display:flex;flex-direction:column;border-radius:18px;background:#13141c;border:1px solid rgba(255,255,255,.08);box-shadow:0 32px 80px #0000008c}.fileDialogPanel .historyHeader{background:#1a1b26;border-bottom:1px solid rgba(255,255,255,.07);border-radius:18px 18px 0 0;padding:14px 18px;align-items:flex-start;gap:12px}.fileDialogTitleBlock{min-width:0;flex:1}.fileDialogTitle{margin:0 0 4px;font-size:.95rem;font-weight:600;color:#e2e4f0;font-family:Montserrat,Arial,sans-serif}.fileDialogMeta{font-size:.78rem;color:#7b8097;font-family:JetBrains Mono,Fira Code,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fileDialogHeaderActions{display:flex;align-items:center;gap:8px;flex-shrink:0}.fileDialogPanel .topActionBtn.ghost{color:#9097b8;border-color:#ffffff1a;background:#ffffff0a}.fileDialogPanel .topActionBtn.ghost:hover{color:#e2e4f0;border-color:#ffffff2e;background:#ffffff14}.fileDialogBody{flex:1;overflow:auto;padding:0}.fileDialogCode{margin:0;padding:20px 22px;font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace;font-size:.825rem;line-height:1.65;color:#cdd6f4;white-space:pre;-moz-tab-size:2;tab-size:2}.fileDialogLoading{padding:40px 24px;color:#7b8097;font-size:.9rem;text-align:center}.fileDialogError{padding:24px;color:#f38ba8;font-size:.88rem;font-family:JetBrains Mono,monospace}
