:root{--bg-main:#070a13;--bg-panel:#11182bbf;--bg-panel-solid:#11182b;--bg-input:#1b243c;--bg-input-focus:#243050;--border-color:#ffffff14;--border-hover:#6366f166;--border-active:#6366f1cc;--color-text-primary:#f3f4f6;--color-text-secondary:#9ca3af;--color-text-muted:#6b7280;--accent-violet:#6366f1;--accent-violet-glow:#6366f126;--accent-fuchsia:#d946ef;--accent-emerald:#10b981;--accent-amber:#f59e0b;--accent-rose:#ef4444;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-header:"Outfit", system-ui, -apple-system, sans-serif;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000004d, 0 4px 6px -2px #0000000d;--shadow-glow:0 0 15px #6366f140;--transition-fast:.15s ease;--transition-normal:.25s ease}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-main);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.6;overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-main)}::-webkit-scrollbar-thumb{background:var(--bg-input);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent-violet)}#root{flex-direction:column;width:100vw;height:100vh;display:flex}.app-container{flex-direction:column;width:100%;height:100vh;display:flex}.app-header{border-bottom:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;background-color:#0b101cd9;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex}.brand{align-items:center;gap:.5rem;display:flex}.brand-icon{color:var(--accent-violet);filter:drop-shadow(0 0 4px #6366f180)}.brand h1{font-family:var(--font-header);letter-spacing:.05em;background:linear-gradient(90deg,#fff,#a5b4fc);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.25rem;font-weight:700}.brand span{font-family:var(--font-header);background-color:var(--accent-violet-glow);color:#a5b4fc;text-transform:uppercase;border:1px solid #6366f14d;border-radius:4px;padding:.1rem .4rem;font-size:.7rem;font-weight:600}.workspace{flex:1;display:flex;position:relative;overflow:hidden}@media (width<=1024px){.workspace{flex-direction:column}}.pane{background-color:var(--bg-panel);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-right:1px solid var(--border-color);flex-direction:column;flex:1;height:100%;display:flex;overflow:hidden}.pane:last-child{border-right:none}.btn{border:1px solid var(--border-color);background:var(--bg-input);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast);border-radius:6px;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;display:inline-flex}.btn:hover{background:var(--bg-input-focus);border-color:var(--border-hover)}.btn-primary{background:linear-gradient(135deg, var(--accent-violet) 0%, #4f46e5 100%);color:#fff;box-shadow:var(--shadow-sm);border:none}.btn-primary:hover{background:linear-gradient(135deg,#7678f3 0%,#6366f1 100%);box-shadow:0 0 10px #6366f166}.btn-primary:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.btn-danger{color:#fca5a5;background:#ef444426;border-color:#ef44444d}.btn-danger:hover{border-color:var(--accent-rose);background:#ef44444d}.btn-icon{border-radius:50%;padding:.5rem}.input-control{background-color:var(--bg-input);border:1px solid var(--border-color);width:100%;color:var(--color-text-primary);transition:all var(--transition-fast);border-radius:6px;outline:none;padding:.5rem .75rem;font-size:.875rem}.input-control:focus{border-color:var(--accent-violet);background-color:var(--bg-input-focus);box-shadow:0 0 0 2px #6366f126}.label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-bottom:.35rem;font-size:.75rem;font-weight:600;display:block}.chat-pane-container{flex:1;display:flex;position:relative;overflow:hidden}.chat-history-container{flex-direction:column;flex:1;gap:1rem;height:100%;padding:1.5rem;display:flex;overflow-y:auto}.message-bubble{max-width:85%;box-shadow:var(--shadow-sm);word-wrap:break-word;border-radius:12px;margin-bottom:.5rem;padding:.85rem 1.1rem;animation:.3s ease-out fadeIn;position:relative}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message-user{background-color:var(--accent-violet);color:#fff;border-bottom-right-radius:2px;align-self:flex-end}.message-gemini{border:1px solid var(--border-color);background-color:#1e293b99;border-bottom-left-radius:2px;align-self:flex-start}.message-meta{color:var(--color-text-muted);text-align:right;margin-top:.4rem;font-size:.7rem}.message-user .message-meta{color:#ffffffb3}.message-content{font-size:.925rem;line-height:1.6}.message-content p{margin-bottom:.75rem}.message-content p:last-child{margin-bottom:0}.message-content strong{color:#fff;font-weight:600}.message-user .message-content strong{color:#fff}.message-content ul,.message-content ol{margin-bottom:.75rem;margin-left:1.25rem}.message-content li{margin-bottom:.25rem}.message-content h3{font-family:var(--font-header);color:#fff;margin:1rem 0 .5rem;font-size:1.05rem}.message-content blockquote{border-left:3px solid var(--accent-violet);color:var(--color-text-secondary);margin:.75rem 0;padding-left:.75rem;font-style:italic}.spreadsheet-update-block{color:#a7f3d0;background:#10b9811a;border:1px dashed #10b9814d;border-radius:6px;align-items:center;gap:.5rem;margin-top:.75rem;padding:.5rem .75rem;font-size:.8rem;display:flex}.spreadsheet-update-block-icon{color:var(--accent-emerald)}.chat-input-area{border-top:1px solid var(--border-color);background-color:#0b101cf2;padding:1rem 1.5rem}.chat-input-row{gap:.75rem;display:flex;position:relative}.chat-textarea{background-color:var(--bg-input);border:1px solid var(--border-color);color:var(--color-text-primary);resize:none;min-height:48px;max-height:200px;font-size:.9rem;line-height:1.4;font-family:var(--font-sans);transition:all var(--transition-fast);border-radius:8px;outline:none;flex:1;padding:.75rem 1rem}.chat-textarea:focus{border-color:var(--accent-violet);background-color:var(--bg-input-focus)}.quick-prompts{flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;display:flex}.quick-prompt-btn{border:1px solid var(--border-color);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:#1e293b66;border-radius:4px;padding:.25rem .6rem;font-size:.75rem}.quick-prompt-btn:hover{background:var(--accent-violet-glow);color:#fff;border-color:var(--accent-violet)}.config-sidebar{border-left:1px solid var(--border-color);background-color:#0f172ad9;flex-direction:column;gap:1.25rem;width:280px;height:100%;padding:1.25rem;display:flex;overflow-y:auto}@media (width<=768px){.config-sidebar{z-index:100;height:100%;box-shadow:var(--shadow-lg);position:absolute;top:0;right:0}}.config-section-title{font-family:var(--font-header);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);border-bottom:1px solid var(--border-color);margin-bottom:.75rem;padding-bottom:.35rem;font-size:.8rem;font-weight:700}.config-item{flex-direction:column;display:flex}.preset-grid{grid-template-columns:repeat(2,1fr);gap:.35rem;display:grid}.preset-chip{background:var(--bg-input);border:1px solid var(--border-color);color:var(--color-text-secondary);text-align:center;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-overflow:ellipsis;border-radius:4px;padding:.35rem .5rem;font-size:.75rem;overflow:hidden}.preset-chip.active{background:var(--accent-violet);border-color:var(--accent-violet);color:#fff;box-shadow:0 0 6px #6366f14d}.preset-chip:hover:not(.active){background:var(--bg-input-focus);color:#fff}.connection-status{align-items:center;gap:.4rem;margin-top:.35rem;font-size:.7rem;font-weight:600;display:flex}.status-dot{border-radius:50%;width:6px;height:6px;display:inline-block}.status-connected{background-color:var(--accent-emerald);box-shadow:0 0 6px var(--accent-emerald)}.status-disconnected{background-color:var(--accent-rose);box-shadow:0 0 6px var(--accent-rose)}.spreadsheet-container{flex-direction:column;height:100%;display:flex;overflow:hidden;container:sheet/inline-size}.spreadsheet-tabs{border-bottom:1px solid var(--border-color);white-space:nowrap;background-color:#0f172ae6;padding:0 1rem;display:flex;overflow:auto hidden}.spreadsheet-tabs::-webkit-scrollbar{height:6px;display:block}.spreadsheet-tabs::-webkit-scrollbar-track{background:#0f172a80}.spreadsheet-tabs::-webkit-scrollbar-thumb{background:var(--bg-input);border-radius:3px}.spreadsheet-tabs::-webkit-scrollbar-thumb:hover{background:var(--accent-violet)}.tab-btn{color:var(--color-text-secondary);cursor:pointer;font-family:var(--font-header);transition:all var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;flex-shrink:0;align-items:center;gap:.5rem;padding:.9rem 1rem;font-size:.9rem;font-weight:500;display:inline-flex}.tab-btn:hover{color:#fff}.tab-btn.active{color:#fff;border-bottom-color:var(--accent-violet);text-shadow:0 0 8px #fff6}.sheet-toolbar{border-bottom:1px solid var(--border-color);background-color:#0f172a66;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1.25rem;display:flex}@container sheet (width<=720px){.sheet-toolbar .btn span{display:none!important}.sheet-toolbar .btn{min-width:34px;padding:.5rem .6rem!important}}@container sheet (width<=520px){.sheet-toolbar{flex-direction:column!important;align-items:stretch!important;gap:.5rem!important;padding:.5rem 1rem!important}.toolbar-left,.toolbar-right{justify-content:space-between!important;gap:.5rem!important;width:100%!important}.search-box{flex:1!important;width:auto!important}}.toolbar-left,.toolbar-right{align-items:center;gap:.5rem;display:flex}.search-box{width:200px;position:relative}.search-box input{padding-left:1.85rem;font-size:.8rem}.search-icon{color:var(--color-text-muted);position:absolute;top:50%;left:.65rem;transform:translateY(-50%)}.table-viewport{background-color:#0a0f1c66;flex:1;overflow:auto}.custom-grid{border-collapse:collapse;text-align:left;width:100%;font-size:.85rem}.custom-grid th{background-color:var(--bg-panel-solid);font-family:var(--font-header);color:var(--color-text-secondary);border-bottom:2px solid var(--border-color);border-right:1px solid var(--border-color);z-index:2;box-shadow:0 1px 0 var(--border-color);padding:.75rem 1rem;font-weight:600;position:sticky;top:0}.custom-grid th:last-child{border-right:none}.custom-grid td{border-bottom:1px solid var(--border-color);border-right:1px solid var(--border-color);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;vertical-align:middle;cursor:cell;max-width:250px;padding:.6rem 1rem;position:relative;overflow:hidden}.custom-grid td:last-child{border-right:none}.custom-grid td:hover{background-color:#ffffff05}.custom-grid tr:hover{background-color:#1e293b40}.grid-cell-editing{padding:0!important}.grid-cell-editor{border:1px solid var(--accent-violet);background-color:var(--bg-input-focus);color:#fff;width:100%;height:100%;font-family:var(--font-sans);outline:none;padding:.6rem 1rem;font-size:.85rem}.action-cell{text-align:center;width:50px;padding:.25rem!important}.row-action-btn{color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:4px;padding:.25rem}.row-action-btn:hover{color:var(--accent-rose);background-color:#ef44441a}.sync-notify-banner{color:#a7f3d0;background:linear-gradient(90deg,#10b98126 0%,#6366f126 100%);border-bottom:1px solid #10b9814d;justify-content:space-between;align-items:center;padding:.5rem 1.25rem;font-size:.8rem;animation:.3s ease-out slideDown;display:flex}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.banner-content{align-items:center;gap:.5rem;display:flex}.row-synced-add{animation:2s ease-in-out glowEmeraldPulse}.row-synced-update{animation:2s ease-in-out glowAmberPulse}@keyframes glowEmeraldPulse{0%{background-color:#10b98166;box-shadow:inset 0 0 12px #10b98199}50%{background-color:#10b98133}to{background-color:#0000}}@keyframes glowAmberPulse{0%{background-color:#f59e0b66;box-shadow:inset 0 0 12px #f59e0b99}50%{background-color:#f59e0b33}to{background-color:#0000}}.no-data-placeholder{color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.no-data-icon{color:var(--border-hover);opacity:.5}.no-data-text h3{font-family:var(--font-header);color:var(--color-text-secondary);margin-bottom:.25rem;font-size:1rem}.no-data-text p{font-size:.8rem}.welcome-screen{background-color:var(--bg-main);z-index:1000;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.welcome-card{background-color:var(--bg-panel-solid);border:1px solid var(--border-color);width:100%;max-width:520px;box-shadow:var(--shadow-lg), var(--shadow-glow);border-radius:12px;flex-direction:column;gap:1.5rem;padding:2.5rem;animation:.5s cubic-bezier(.16,1,.3,1) welcomeAppear;display:flex}@keyframes welcomeAppear{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.welcome-header{text-align:center}.welcome-header .logo-container{background:var(--accent-violet-glow);width:56px;height:56px;color:var(--accent-violet);border:1px solid #6366f140;border-radius:14px;justify-content:center;align-items:center;margin-bottom:1rem;display:inline-flex;box-shadow:0 0 15px #6366f133}.welcome-header h2{font-family:var(--font-header);letter-spacing:-.01em;margin-bottom:.35rem;font-size:1.75rem;font-weight:800}.welcome-header p{color:var(--color-text-secondary);font-size:.875rem}.welcome-form{flex-direction:column;gap:1rem;display:flex}.api-key-help{color:var(--color-text-muted);font-size:.75rem;line-height:1.4}.api-key-help a{color:var(--accent-violet);text-decoration:none}.api-key-help a:hover{text-decoration:underline}.flex-row-center{align-items:center;display:flex}.justify-between{justify-content:space-between}.gap-sm{gap:.5rem}.gap-md{gap:1rem}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.bold{font-weight:600}.italic{font-style:italic}.text-muted{color:var(--color-text-muted)}.text-center{text-align:center}.loader-spinner{border:2px solid #ffffff1a;border-top-color:currentColor;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spinner;display:inline-block}@keyframes spinner{to{transform:rotate(360deg)}}.typing-indicator{align-items:center;gap:4px;padding:.5rem;display:flex}.typing-dot{background-color:var(--color-text-secondary);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite typingGlow}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}.novel-selector-wrapper{border-left:1px solid var(--border-color);align-items:center;gap:.5rem;margin-left:1.25rem;padding-left:1.25rem;display:flex}.novel-selector-wrapper select{font-family:var(--font-header);color:var(--color-text-primary);background-color:var(--bg-input-focus);transition:all var(--transition-fast);border-radius:6px;font-weight:600}.novel-selector-wrapper select:hover{border-color:var(--accent-violet)}.novel-selector-wrapper select:focus{box-shadow:0 0 0 2px #6366f140}.novel-selector-wrapper .btn-sm{border-radius:4px;font-weight:600;font-size:.725rem!important}.split-resizer{cursor:col-resize;background-color:var(--border-color);z-index:50;width:6px;transition:background-color var(--transition-fast), box-shadow var(--transition-fast);flex:none;position:relative}.split-resizer:hover,.split-resizer.active{background-color:var(--accent-violet);box-shadow:0 0 10px #6366f166}.split-resizer:after{content:"";pointer-events:none;background-color:#ffffff40;border-radius:1px;width:2px;height:24px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.app-container.excel-mode{color:#e0e0e0;background-color:#1e1e1e}.app-container.excel-mode .workspace{background:#fff;border:1px solid silver;padding:.5rem}.app-container.excel-mode .pane{background:#fafafa}.app-container.excel-mode .grid-header,.app-container.excel-mode .grid-row{border-bottom:1px solid #e0e0e0}.app-container.excel-mode .btn-primary{background-color:#4a90e2;border-color:#357ab8}.app-container.excel-mode .btn-secondary{background-color:#6c757d;border-color:#565e64}.app-container.excel-mode ::-webkit-scrollbar{width:6px;height:6px}.app-container.excel-mode ::-webkit-scrollbar-thumb{background-color:#0003;border-radius:3px}
