:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-dark: #0a0a0f;--bg-card: #12121a;--bg-hover: #1a1a25;--border-color: #2a2a3a;--text-primary: #ffffff;--text-secondary: #8b8b9a;--accent-blue: #3b82f6;--accent-green: #10b981;--accent-red: #ef4444;--accent-amber: #f59e0b;--accent-purple: #8b5cf6}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg-dark);color:var(--text-primary);min-height:100vh}.app{display:flex;min-height:100vh}.sidebar{width:260px;background:var(--bg-card);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:20px 0;position:fixed;height:100vh;overflow-y:auto}.sidebar-header{display:flex;align-items:center;gap:12px;padding:0 20px 24px;border-bottom:1px solid var(--border-color);margin-bottom:20px}.sidebar-header svg{color:var(--accent-blue)}.sidebar-header h1{font-size:18px;font-weight:600}.sidebar-nav{display:flex;flex-direction:column;gap:4px;padding:0 12px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:transparent;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s;font-size:14px;text-align:left;width:100%}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-blue);color:#fff}.nav-item .badge{margin-left:auto;background:#fff3;padding:2px 8px;border-radius:10px;font-size:12px}.sidebar-stats{margin-top:auto;padding:20px;border-top:1px solid var(--border-color)}.sidebar-stats h3{font-size:12px;text-transform:uppercase;color:var(--text-secondary);margin-bottom:16px;letter-spacing:.5px}.sidebar-user{display:flex;align-items:center;gap:10px;padding:16px 20px;border-top:1px solid var(--border-color);font-size:12px;color:var(--text-secondary)}.sidebar-user svg:first-child{color:var(--accent-blue)}.sidebar-user span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s}.logout-btn:hover{background:var(--bg-hover);color:var(--accent-red)}.stat{display:flex;align-items:center;gap:8px;padding:8px 0;color:var(--text-secondary);font-size:13px}.stat strong{margin-left:auto;color:var(--text-primary)}.main-content{flex:1;margin-left:260px;padding:24px 32px;position:relative}.content-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.header-left h2{font-size:24px;font-weight:600;margin-bottom:4px}.header-left p{color:var(--text-secondary);font-size:14px}.header-actions{display:flex;gap:12px}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;border:none;transition:all .2s;text-decoration:none}.btn-primary{background:var(--accent-blue);color:#fff}.btn-primary:hover{background:#2563eb}.btn-secondary{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--border-color)}.btn-danger{background:var(--accent-red);color:#fff}.btn-danger:hover{background:#dc2626}.filters{display:flex;gap:16px;margin-bottom:20px;flex-wrap:wrap}.search-box{display:flex;align-items:center;gap:12px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:0 16px;flex:1;max-width:400px}.search-box svg{color:var(--text-secondary)}.search-box input{flex:1;background:transparent;border:none;padding:12px 0;color:var(--text-primary);font-size:14px;outline:none}.search-box input::placeholder{color:var(--text-secondary)}.filter-buttons{display:flex;gap:8px;flex-wrap:wrap}.filter-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s}.filter-btn:hover{border-color:var(--accent-blue);color:var(--text-primary)}.filter-btn.active{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.warning-banner{display:flex;align-items:flex-start;gap:12px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:10px;padding:16px 20px;margin-bottom:24px}.warning-banner svg{color:var(--accent-amber);flex-shrink:0;margin-top:2px}.warning-banner strong{display:block;margin-bottom:4px;color:var(--accent-amber)}.warning-banner p{color:var(--text-secondary);font-size:13px;margin:0}.sites-container{display:flex;flex-direction:column;gap:24px}.category-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.category-header{display:flex;align-items:center;gap:10px;width:100%;padding:16px 20px;background:transparent;border:none;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:15px;font-weight:600;cursor:pointer;text-align:left}.category-header:hover{background:var(--bg-hover)}.category-count{margin-left:auto;background:var(--bg-hover);padding:2px 10px;border-radius:10px;font-size:12px;color:var(--text-secondary)}.sites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;padding:16px}.site-card{background:var(--bg-dark);border:1px solid var(--border-color);border-radius:10px;padding:16px;cursor:pointer;transition:all .2s}.site-card:hover{border-color:var(--accent-blue);transform:translateY(-2px)}.site-card.selected{border-color:var(--accent-blue);box-shadow:0 0 0 2px #3b82f633}.site-card.locked{border-left:3px solid var(--accent-green)}.site-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.site-name{display:flex;align-items:center;gap:8px;font-weight:500;font-size:14px}.site-name svg{color:var(--accent-blue)}.lock-btn{background:var(--bg-hover);border:1px solid var(--border-color);border-radius:6px;padding:6px;cursor:pointer;color:var(--text-secondary);transition:all .2s}.lock-btn:hover{background:var(--border-color);color:var(--text-primary)}.lock-btn.locked{background:#10b98133;border-color:var(--accent-green);color:var(--accent-green)}.site-domain{margin-bottom:12px}.site-domain a{display:inline-flex;align-items:center;gap:6px;color:var(--accent-blue);font-size:13px;text-decoration:none}.site-domain a:hover{text-decoration:underline}.site-domain .no-domain{display:inline-flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:13px}.site-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.meta-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:500}.meta-tag.db{background:#8b5cf633;color:var(--accent-purple)}.meta-tag.github{background:#3b82f633;color:var(--accent-blue)}.site-id{font-size:11px}.site-id code{background:var(--bg-hover);padding:2px 6px;border-radius:4px;color:var(--text-secondary)}.detail-panel{position:fixed;right:0;top:0;width:400px;height:100vh;background:var(--bg-card);border-left:1px solid var(--border-color);overflow-y:auto;z-index:100;animation:slideIn .2s ease}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.detail-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color);position:sticky;top:0;background:var(--bg-card)}.detail-header h3{font-size:16px;font-weight:600}.close-btn{background:transparent;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;padding:0;line-height:1}.close-btn:hover{color:var(--text-primary)}.detail-content{padding:24px}.detail-section{margin-bottom:24px}.detail-section h4{font-size:12px;text-transform:uppercase;color:var(--text-secondary);margin-bottom:12px;letter-spacing:.5px}.detail-row{display:flex;justify-content:space-between;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--border-color);font-size:13px}.detail-row span:first-child{color:var(--text-secondary)}.detail-row code{background:var(--bg-hover);padding:2px 6px;border-radius:4px;font-size:11px;word-break:break-all;max-width:200px}.detail-row a{color:var(--accent-blue);text-decoration:none;display:inline-flex;align-items:center;gap:4px}.detail-row a:hover{text-decoration:underline}.status-locked{color:var(--accent-green);display:inline-flex;align-items:center;gap:4px}.status-unlocked{color:var(--text-secondary);display:inline-flex;align-items:center;gap:4px}.detail-section p{color:var(--text-secondary);font-size:13px;line-height:1.6}.detail-actions{display:flex;flex-direction:column;gap:12px;margin-top:32px}.detail-actions .btn{justify-content:center}.repos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.repo-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:20px;cursor:pointer;transition:all .2s}.repo-card:hover{border-color:var(--accent-blue);transform:translateY(-2px)}.repo-card.selected{border-color:var(--accent-blue);box-shadow:0 0 0 2px #3b82f633}.repo-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.repo-icon{color:var(--accent-blue)}.repo-name{font-weight:600;font-size:15px}.repo-description{color:var(--text-secondary);font-size:13px;margin-bottom:16px;line-height:1.5}.repo-meta{display:flex;gap:16px;flex-wrap:wrap;font-size:13px;color:var(--text-secondary)}.repo-language{display:flex;align-items:center;gap:6px}.lang-dot{width:10px;height:10px;border-radius:50%;background:var(--text-secondary)}.lang-dot.javascript{background:#f7df1e}.lang-dot.typescript{background:#3178c6}.lang-dot.html{background:#e34c26}.lang-dot.css{background:#563d7c}.lang-dot.python{background:#3572a5}.repo-stars,.repo-updated{display:flex;align-items:center;gap:4px}.repo-linked{display:flex;align-items:center;gap:6px;margin-top:16px;padding-top:12px;border-top:1px solid var(--border-color);font-size:12px;color:var(--accent-green)}.databases-container{display:flex;flex-direction:column;gap:24px}.database-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px}.db-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.db-title{display:flex;align-items:center;gap:16px}.db-icon{color:var(--accent-purple)}.db-title h3{font-size:18px;font-weight:600;margin-bottom:4px}.db-provider{font-size:13px;color:var(--text-secondary)}.db-status{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500}.db-status.connected{background:#10b98126;color:var(--accent-green)}.db-status.disconnected{background:#ef444426;color:var(--accent-red)}.db-info{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px;padding:16px;background:var(--bg-dark);border-radius:8px}.db-info-row{display:flex;flex-direction:column;gap:4px}.db-info-row span{font-size:12px;color:var(--text-secondary);text-transform:uppercase}.db-info-row code{font-size:12px;color:var(--text-primary);background:var(--bg-hover);padding:4px 8px;border-radius:4px;word-break:break-all}.db-info-row strong{font-size:14px;color:var(--text-primary)}.db-connections h4{font-size:14px;font-weight:600;margin-bottom:12px}.connected-sites-list{display:flex;flex-direction:column;gap:8px}.connected-site{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-dark);border-radius:6px;font-size:13px}.connected-site svg{color:var(--accent-blue)}.connected-site .site-name{flex:1}.connected-site .schema-name{background:var(--bg-hover);padding:2px 8px;border-radius:4px;font-size:11px;color:var(--accent-purple)}.db-warning{display:flex;align-items:flex-start;gap:12px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:10px;padding:16px 20px;margin-top:24px}.db-warning svg{color:var(--accent-amber);flex-shrink:0}.db-warning strong{display:block;margin-bottom:4px;color:var(--accent-amber)}.db-warning p{font-family:monospace;font-size:12px;color:var(--text-secondary);word-break:break-all;margin:8px 0}.db-warning small{color:var(--text-secondary);font-size:12px}.domains-table-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.domains-table{width:100%;border-collapse:collapse}.domains-table th{text-align:left;padding:14px 20px;font-size:12px;text-transform:uppercase;color:var(--text-secondary);background:var(--bg-hover);border-bottom:1px solid var(--border-color);font-weight:500;letter-spacing:.5px}.domains-table td{padding:16px 20px;font-size:14px;border-bottom:1px solid var(--border-color)}.domains-table tr:last-child td{border-bottom:none}.domains-table tr:hover td{background:var(--bg-hover)}.domain-name{display:flex;align-items:center;gap:10px}.domain-name svg{color:var(--accent-blue)}.domain-name a{color:var(--text-primary);text-decoration:none;font-weight:500}.domain-name a:hover{color:var(--accent-blue);text-decoration:underline}.dns-badge{padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500}.dns-badge.cloudflare{background:#f59e0b26;color:var(--accent-amber)}.dns-badge.netlify{background:#3b82f626;color:var(--accent-blue)}.expires-date{color:var(--text-secondary)}.icon-success{color:var(--accent-green)}.icon-warning{color:var(--accent-amber)}.ssl-active{display:flex;align-items:center;gap:4px;color:var(--accent-green);font-size:13px}.ssl-inactive{color:var(--text-secondary);font-size:13px}.linked-site-badge{background:var(--bg-hover);padding:4px 10px;border-radius:4px;font-size:12px;color:var(--text-secondary)}.settings-container{display:flex;flex-direction:column;gap:32px}.settings-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px}.settings-section h3{font-size:16px;font-weight:600;margin-bottom:16px}.settings-section .section-desc{color:var(--text-secondary);font-size:13px;margin-bottom:16px}.setting-row{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid var(--border-color)}.setting-row:last-child{border-bottom:none}.setting-info strong{display:block;margin-bottom:4px;font-size:14px}.setting-info p{color:var(--text-secondary);font-size:13px;margin:0}.token-status{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500}.token-status.configured{background:#10b98126;color:var(--accent-green)}.token-status.missing{background:#ef444426;color:var(--accent-red)}.protected-sites-list{display:flex;flex-direction:column;gap:8px}.protected-site{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--bg-dark);border-radius:8px;font-size:14px}.protected-site svg{color:var(--accent-green)}.protected-site .domain{margin-left:auto;color:var(--text-secondary);font-size:13px}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-dark)}.login-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:40px;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:32px}.login-header svg{color:var(--accent-blue);margin-bottom:16px}.login-header h1{font-size:24px;font-weight:600;margin-bottom:8px}.login-header p{color:var(--text-secondary);font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:var(--text-secondary)}.form-group input{background:var(--bg-dark);border:1px solid var(--border-color);border-radius:8px;padding:12px 16px;font-size:14px;color:var(--text-primary);outline:none;transition:border-color .2s}.form-group input:focus{border-color:var(--accent-blue)}.form-group input::placeholder{color:var(--text-secondary)}.login-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:12px 16px;color:var(--accent-red);font-size:13px;text-align:center}.login-btn{background:var(--accent-blue);color:#fff;border:none;border-radius:8px;padding:14px;font-size:15px;font-weight:500;cursor:pointer;transition:background .2s}.login-btn:hover{background:#2563eb}.login-btn:disabled{background:var(--bg-hover);color:var(--text-secondary);cursor:not-allowed}.site-actions{display:flex;gap:8px;margin:12px 0}.action-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 10px;background:var(--bg-hover);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:12px;cursor:pointer;text-decoration:none;transition:all .2s}.action-btn:hover{background:var(--border-color);color:var(--text-primary)}.action-btn.launch{background:#10b98126;border-color:var(--accent-green);color:var(--accent-green)}.action-btn.launch:hover{background:#10b98140}.action-btn.admin{background:#3b82f626;border-color:var(--accent-blue);color:var(--accent-blue)}.action-btn.admin:hover{background:#3b82f640}.action-btn.deploy:disabled{opacity:.5;cursor:not-allowed}.repo-actions{display:flex;gap:8px;margin-top:16px;padding-top:12px;border-top:1px solid var(--border-color)}.loading{display:flex;align-items:center;justify-content:center;padding:60px;color:var(--text-secondary);font-size:16px}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:32px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal h2{font-size:20px;font-weight:600;margin-bottom:24px}.modal .form-group{margin-bottom:16px}.modal .form-group select{width:100%;background:var(--bg-dark);border:1px solid var(--border-color);border-radius:8px;padding:12px 16px;font-size:14px;color:var(--text-primary);outline:none}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.nas-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:32px}.nas-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;text-align:center}.nas-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:#3b82f626;border-radius:16px;margin:0 auto 16px;color:var(--accent-blue)}.nas-card h3{font-size:18px;font-weight:600;margin-bottom:8px}.nas-card p{color:var(--text-secondary);font-size:14px;margin-bottom:20px}.nas-info{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px}.nas-info h3{font-size:16px;font-weight:600;margin-bottom:16px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-color)}.info-row:last-child{border-bottom:none}.info-row span{color:var(--text-secondary)}.info-row code{background:var(--bg-hover);padding:4px 10px;border-radius:4px;font-size:13px}.db-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;margin-bottom:32px}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;text-align:center}.stat-card svg{color:var(--accent-purple);margin-bottom:12px}.stat-value{font-size:28px;font-weight:600;margin-bottom:4px}.stat-label{font-size:13px;color:var(--text-secondary)}.db-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.schema-tabs{display:flex;gap:4px;padding:16px;border-bottom:1px solid var(--border-color);flex-wrap:wrap}.schema-tab{padding:8px 16px;background:var(--bg-hover);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s}.schema-tab:hover{background:var(--border-color);color:var(--text-primary)}.schema-tab.active{background:var(--accent-purple);border-color:var(--accent-purple);color:#fff}.tables-list{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:14px 20px;font-size:12px;text-transform:uppercase;color:var(--text-secondary);background:var(--bg-dark);font-weight:500}.data-table td{padding:14px 20px;font-size:14px;border-bottom:1px solid var(--border-color)}.data-table tr:hover td{background:var(--bg-hover)}.data-table code{background:var(--bg-hover);padding:2px 8px;border-radius:4px;font-size:13px}@media(max-width:1200px){.detail-panel{width:350px}}@media(max-width:900px){.sidebar{display:none}.main-content{margin-left:0}.detail-panel{width:100%}.domains-table-container{overflow-x:auto}.domains-table{min-width:800px}.modal{margin:20px}}
