@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap";
:root{--loom-primary:#6c5ce7;--loom-primary-light:#a29bfe;--loom-primary-dark:#4834d4;--loom-accent:#00d2d3;--loom-accent-light:#55e6c1;--bg-app:#0f0e17;--bg-surface:#1a1929;--bg-surface-hover:#232236;--bg-surface-elevated:#252440;--bg-card:#1e1d2f;--bg-input:#16152a;--text-primary:#fffffe;--text-secondary:#a7a5c6;--text-muted:#6b6990;--text-accent:#a29bfe;--status-success:#00b894;--status-error:#ff6b6b;--status-warning:#fdcb6e;--status-info:#74b9ff;--border-subtle:#a7a5c61a;--border-active:#6c5ce780;--shadow-sm:0 2px 8px #0003;--shadow-md:0 4px 16px #0000004d;--shadow-lg:0 8px 32px #0006;--shadow-glow:0 0 20px #6c5ce74d;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg-app);height:100%;color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,sans-serif}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.app-container{flex-direction:column;min-height:100vh;display:flex}.navbar{padding:var(--space-md) var(--space-xl);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-subtle);z-index:100;background:#1a1929cc;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.navbar-brand{align-items:center;gap:var(--space-sm);color:var(--text-primary);text-decoration:none;display:flex}.navbar-brand svg{width:28px;height:28px}.navbar-brand span{background:linear-gradient(135deg, var(--loom-primary-light), var(--loom-accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:700}.navbar-actions{align-items:center;gap:var(--space-md);display:flex}.btn{align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);cursor:pointer;border:none;padding:10px 20px;font-family:Inter,sans-serif;font-size:.875rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--loom-primary), var(--loom-primary-dark));color:#fff;box-shadow:var(--shadow-sm), 0 0 0 0 #6c5ce700}.btn-primary:hover{box-shadow:var(--shadow-md), var(--shadow-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-subtle)}.btn-secondary:hover{background:var(--bg-surface-hover);border-color:var(--border-active)}.btn-danger{color:var(--status-error);background:#ff6b6b26;border:1px solid #ff6b6b4d}.btn-danger:hover{background:#ff6b6b40}.btn-ghost{color:var(--text-secondary);background:0 0;padding:8px 12px}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-surface-hover)}.btn-sm{padding:6px 14px;font-size:.8125rem}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all .2s}.card:hover{border-color:var(--border-active);box-shadow:var(--shadow-sm)}.input{background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-md);width:100%;color:var(--text-primary);outline:none;padding:12px 16px;font-family:Inter,sans-serif;font-size:.9375rem;transition:border-color .2s}.input:focus{border-color:var(--loom-primary);box-shadow:0 0 0 3px #6c5ce726}.input::placeholder{color:var(--text-muted)}.textarea{resize:vertical;min-height:100px;font-family:Inter,sans-serif}.label{color:var(--text-secondary);margin-bottom:var(--space-sm);text-transform:uppercase;letter-spacing:.05em;font-size:.8125rem;font-weight:600;display:block}.text-muted{color:var(--text-muted)}.text-accent{color:var(--text-accent)}.mono{font-family:JetBrains Mono,monospace}.badge{border-radius:100px;align-items:center;gap:6px;padding:4px 12px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-success{color:var(--status-success);background:#00b89426}.badge-error{color:var(--status-error);background:#ff6b6b26}.badge-warning{color:var(--status-warning);background:#fdcb6e26}.toast-container{top:80px;right:var(--space-xl);z-index:1000;gap:var(--space-sm);flex-direction:column;display:flex;position:fixed}.toast{border-radius:var(--radius-md);min-width:300px;box-shadow:var(--shadow-lg);padding:14px 20px;font-size:.875rem;font-weight:500;animation:.3s slideIn}.toast-success{color:#fff;background:#00b894f2}.toast-error{color:#fff;background:#ff6b6bf2}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.spinner{border:2px solid var(--border-subtle);border-top-color:var(--loom-primary);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}.spinner-lg{border-width:3px;width:40px;height:40px}@keyframes spin{to{transform:rotate(360deg)}}.dashboard{max-width:1200px;padding:var(--space-2xl) var(--space-xl);margin:0 auto}.dashboard-header{margin-bottom:var(--space-2xl)}.dashboard-header h1{margin-bottom:var(--space-sm);background:linear-gradient(135deg, var(--text-primary) 0%, var(--text-secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:800}.dashboard-header p{color:var(--text-secondary);font-size:1.0625rem}.sites-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(340px,1fr));display:grid}.site-card{cursor:pointer}.site-card-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:flex-start;display:flex}.site-card-icon{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--loom-primary), var(--loom-accent));justify-content:center;align-items:center;width:44px;height:44px;font-size:1.25rem;display:flex}.site-card h3{margin-bottom:4px;font-size:1.125rem;font-weight:700}.site-card-url{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:.8125rem}.site-card-meta{gap:var(--space-md);margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-subtle);display:flex}.site-card-meta-item{color:var(--text-muted);font-size:.75rem}.site-card-meta-item span{color:var(--text-secondary);font-weight:600}.connect-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.connect-modal{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-2xl);width:480px;max-width:90vw;box-shadow:var(--shadow-lg);animation:.25s scaleIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.connect-modal h2{margin-bottom:var(--space-sm);font-size:1.5rem;font-weight:700}.connect-modal p{color:var(--text-secondary);margin-bottom:var(--space-lg);line-height:1.6}.form-group{margin-bottom:var(--space-md)}.form-actions{gap:var(--space-md);margin-top:var(--space-lg);display:flex}.form-error{color:var(--status-error);margin-top:var(--space-sm);font-size:.8125rem}.editor-layout{grid-template-columns:1fr 400px;height:calc(100vh - 57px);display:grid;overflow:hidden}.editor-sidebar{background:var(--bg-surface);border-right:1px solid var(--border-subtle);flex-direction:column;display:flex;overflow-y:auto}.editor-sidebar-header{padding:var(--space-md);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;display:flex}.editor-sidebar-header h3{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-size:.8125rem;font-weight:700}.file-tree{padding:var(--space-sm);flex:1;overflow-y:auto}.file-tree-item{align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);padding:8px 12px;font-size:.8125rem;transition:all .15s;display:flex}.file-tree-item:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.file-tree-item.active{color:var(--loom-primary-light);background:#6c5ce726}.file-tree-item-icon{text-align:center;flex-shrink:0;width:20px;font-size:.875rem}.file-tree-item-name{text-overflow:ellipsis;white-space:nowrap;font-family:JetBrains Mono,monospace;font-size:.8125rem;overflow:hidden}.file-tree-dir{padding-left:8px}.editor-main{flex-direction:column;display:flex;overflow:hidden}.editor-toolbar{padding:var(--space-sm) var(--space-md);background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;min-height:44px;display:flex}.editor-toolbar-file{align-items:center;gap:var(--space-sm);color:var(--text-secondary);font-family:JetBrains Mono,monospace;font-size:.875rem;display:flex}.editor-toolbar-actions{gap:var(--space-sm);display:flex}.editor-container{flex:1;overflow:hidden}.editor-empty{height:100%;color:var(--text-muted);justify-content:center;align-items:center;gap:var(--space-md);flex-direction:column;display:flex}.editor-empty-icon{opacity:.3;font-size:3rem}.chat-panel{background:var(--bg-surface);border-left:1px solid var(--border-subtle);flex-direction:column;display:flex;overflow:hidden}.chat-panel-header{padding:var(--space-md);border-bottom:1px solid var(--border-subtle)}.chat-panel-header h3{font-size:.9375rem;font-weight:700}.chat-panel-header p{color:var(--text-muted);margin-top:2px;font-size:.75rem}.chat-messages{padding:var(--space-md);gap:var(--space-md);flex-direction:column;flex:1;display:flex;overflow-y:auto}.chat-message{padding:var(--space-md);border-radius:var(--radius-md);font-size:.875rem;line-height:1.6;animation:.2s fadeIn}.chat-message-user{background:#6c5ce726;border:1px solid #6c5ce733;align-self:flex-end;max-width:90%}.chat-message-ai{background:var(--bg-card);border:1px solid var(--border-subtle);max-width:90%}.chat-message-system{color:var(--loom-accent);text-align:center;background:#00d2d31a;border:1px solid #00d2d333;font-size:.8125rem}.chat-message-plan{background:#fdcb6e14;border:1px solid #fdcb6e33;max-width:90%}.chat-message-assistant{background:var(--bg-card);border:1px solid var(--border-subtle);max-width:90%}.chat-message-error{color:var(--status-error);background:#ff6b6b1a;border:1px solid #ff6b6b33;font-size:.8125rem}.chat-input-area{padding:var(--space-md);border-top:1px solid var(--border-subtle)}.chat-input-wrapper{gap:var(--space-sm);align-items:flex-end;display:flex}.chat-input{background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);resize:none;outline:none;flex:1;min-height:44px;max-height:150px;padding:12px 16px;font-family:Inter,sans-serif;font-size:.875rem;line-height:1.5;transition:border-color .2s}.chat-input:focus{border-color:var(--loom-primary)}.chat-send-btn{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--loom-primary), var(--loom-primary-dark));color:#fff;cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;transition:all .2s;display:flex}.chat-send-btn:hover:not(:disabled){box-shadow:var(--shadow-glow);transform:translateY(-1px)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.backup-panel{padding:var(--space-md);border-top:1px solid var(--border-subtle)}.backup-panel h4{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--space-sm);font-size:.75rem;font-weight:700}.backup-item{border-radius:var(--radius-sm);color:var(--text-secondary);justify-content:space-between;align-items:center;padding:8px 12px;font-size:.75rem;transition:background .15s;display:flex}.backup-item:hover{background:var(--bg-surface-hover)}.backup-item-time{font-family:JetBrains Mono,monospace}.diff-toolbar{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:#00b8941a;border-bottom:1px solid #00b89433;display:flex}.diff-toolbar-text{color:var(--status-success);font-size:.8125rem;font-weight:600}@media (max-width:1024px){.editor-layout{grid-template-columns:1fr 360px}}@media (max-width:768px){.editor-layout{grid-template-rows:1fr auto;grid-template-columns:1fr}.chat-panel{border-left:none;border-top:1px solid var(--border-subtle);max-height:300px}}
