.app{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--space-surface);border-right:1px solid var(--space-border);display:flex;flex-direction:column;position:fixed;height:100vh;z-index:100}.sidebar-header{padding:1.5rem 1.25rem;border-bottom:1px solid var(--space-border)}.logo-icon{color:var(--space-accent);margin-bottom:.75rem}.logo-text{font-size:1.125rem;font-weight:600;letter-spacing:.02em;color:var(--text-primary);margin-bottom:.5rem}.status-indicator{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--text-muted)}.status-icon{width:6px;height:6px;background:var(--space-success);border-radius:50%}.status-text{text-transform:uppercase;letter-spacing:.05em;font-size:.6875rem}.nav-menu{flex:1;padding:1rem 0;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.625rem 1.25rem;color:var(--text-secondary);text-decoration:none;transition:all .15s ease;font-size:.875rem;font-weight:500;margin:0 .5rem;border-radius:6px}.nav-item:hover{background:var(--space-elevated);color:var(--text-primary)}.nav-item.active{background:var(--space-elevated);color:var(--space-accent)}.nav-item svg{flex-shrink:0;width:18px;height:18px}.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid var(--space-border);display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.75rem}.footer-text{font-size:.6875rem}.main-content{flex:1;margin-left:240px;padding:2rem;min-height:100vh}.page{max-width:1400px;margin:0 auto}.page-header{margin-bottom:2rem}.page-title{font-size:2rem;margin-bottom:.5rem;color:var(--text-primary);font-weight:600;letter-spacing:-.02em}.page-subtitle{color:var(--text-secondary);font-size:.9375rem}.grid{display:grid;gap:1.25rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}@media(max-width:768px){.sidebar{width:64px}.sidebar-header .logo-text,.sidebar-header .status-text,.nav-item span,.sidebar-footer .footer-text{display:none}.main-content{margin-left:64px}.nav-item{justify-content:center;padding:.75rem}}.logout-btn{background:none;border:none;width:100%;text-align:left;cursor:pointer;margin-top:auto}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.login-box{width:100%;max-width:400px;background:var(--space-surface);border:1px solid var(--space-border);border-radius:12px;padding:3rem 2.5rem;text-align:center}.login-header{margin-bottom:2.5rem}.login-icon{color:var(--space-accent);margin-bottom:1.5rem}.login-header h1{font-size:1.75rem;margin-bottom:.5rem;color:var(--text-primary)}.login-header p{color:var(--text-secondary);font-size:.875rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.input-group{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.125rem;background:var(--space-elevated);border:1px solid var(--space-border);border-radius:8px;transition:all .2s ease}.input-group:focus-within{border-color:var(--space-accent)}.input-group svg{color:var(--text-muted);flex-shrink:0}.input-group input{flex:1;background:transparent;border:none;padding:0;color:var(--text-primary);font-size:.9375rem}.input-group input:focus{outline:none;border:none;box-shadow:none}.error-message{padding:.75rem 1rem;background:#f871711a;border:1px solid var(--space-error);border-radius:6px;color:var(--space-error);font-size:.875rem}.login-form .btn{width:100%;padding:.875rem;font-size:1rem}.login-footer{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--space-border)}.login-footer p{color:var(--text-muted);font-size:.8125rem}.dashboard{animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.section-title{font-size:1.5rem;margin:2rem 0 1rem;color:var(--text-secondary);letter-spacing:.1em}.status-cards{margin-bottom:2rem}.stat-card{display:flex;align-items:center;gap:1.5rem;padding:1.5rem}.stat-icon{padding:1rem;background:#6b5ce71a;border-radius:12px;display:flex;align-items:center;justify-content:center}.stat-content{flex:1}.stat-label{font-size:.75rem;color:var(--text-muted);letter-spacing:.1em;margin-bottom:.25rem}.stat-value{font-size:1.75rem;font-weight:700;font-family:Orbitron,sans-serif}.quick-actions{margin-bottom:2rem}.action-card{display:flex;align-items:center;gap:1.5rem;padding:2rem;text-decoration:none;color:var(--text-primary);cursor:pointer;position:relative;overflow:hidden}.action-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:currentColor;transform:scaleY(0);transition:transform .3s ease}.action-card:hover:before{transform:scaleY(1)}.action-purple{color:var(--space-purple)}.action-blue{color:var(--space-blue)}.action-cyan{color:var(--space-cyan)}.action-green{color:var(--space-green)}.action-icon{padding:1rem;background:#6b5ce71a;border-radius:12px;flex-shrink:0}.action-purple .action-icon{background:#6b5ce726;color:var(--space-purple)}.action-blue .action-icon{background:#4a9ff526;color:var(--space-blue)}.action-cyan .action-icon{background:#00d4ff26;color:var(--space-cyan)}.action-green .action-icon{background:#00ff8826;color:var(--space-green)}.action-content{flex:1}.action-title{font-size:1.25rem;margin-bottom:.25rem;font-family:Orbitron,sans-serif}.action-description{color:var(--text-secondary);font-size:.95rem}.system-info{display:flex;flex-direction:column;gap:1rem}.info-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--space-gray)}.info-row:last-child{border-bottom:none}.info-label{color:var(--text-secondary);font-weight:600}.info-value{color:var(--text-primary);font-family:Share Tech Mono,monospace}.llm-chat{max-width:1600px}.chat-container{display:grid;grid-template-columns:300px 1fr;gap:2rem}.chat-settings{height:fit-content;position:sticky;top:2rem}.settings-title{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;color:var(--space-cyan);font-size:1.1rem}.setting-group{margin-bottom:1.5rem}.setting-group label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-size:.9rem;text-transform:uppercase;letter-spacing:.05em}.provider-toggle{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.toggle-btn{padding:.75rem;background:var(--space-dark);border:1px solid var(--space-gray);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .3s ease;font-family:Orbitron,sans-serif;font-size:.9rem}.toggle-btn:hover{border-color:var(--space-purple)}.toggle-btn.active{background:linear-gradient(135deg,var(--space-purple),var(--space-blue));border-color:var(--space-purple);color:#fff;box-shadow:var(--glow-purple)}.prompt-select{width:100%}.usage-info{margin-top:2rem;padding-top:1rem;border-top:1px solid var(--space-gray);font-size:.85rem}.usage-row{display:flex;justify-content:space-between;padding:.5rem 0;color:var(--text-secondary)}.usage-row span:last-child{color:var(--space-cyan);font-weight:600}.chat-main{min-height:600px}.chat-form{display:flex;flex-direction:column;gap:1.5rem}.input-section label{display:block;margin-bottom:.75rem;color:var(--text-secondary);font-size:.9rem;text-transform:uppercase;letter-spacing:.05em}.chat-input{width:100%;min-height:200px;resize:vertical;font-family:Share Tech Mono,monospace}.submit-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;align-self:flex-start}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.response-section{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--space-gray)}.response-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:var(--space-green);font-size:1rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.response-content{background:#0000004d;border:1px solid var(--space-gray);border-radius:8px;padding:1.5rem;color:var(--text-primary);line-height:1.8;white-space:pre-wrap;max-height:600px;overflow-y:auto}@media(max-width:1024px){.chat-container{grid-template-columns:1fr}.chat-settings{position:relative;top:0}}.sbb-monitor{max-width:1400px}.monitor-controls{display:flex;flex-wrap:wrap;align-items:center;gap:1.5rem;margin-bottom:2rem}.control-group{display:flex;align-items:center;gap:.75rem;flex:1;min-width:250px;color:var(--space-cyan)}.station-input{flex:1;min-width:200px}.control-actions{display:flex;align-items:center;gap:1rem}.refresh-btn{display:flex;align-items:center;gap:.5rem}.auto-refresh-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:var(--text-secondary);font-size:.9rem}.auto-refresh-toggle input[type=checkbox]{width:auto;cursor:pointer}.last-update{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.85rem;width:100%}.connections-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.connection-card{display:flex;flex-direction:column;gap:1rem}.connection-header{padding-bottom:1rem;border-bottom:1px solid var(--space-gray)}.connection-line{display:flex;flex-direction:column;gap:.5rem}.line-badge{display:inline-block;padding:.4rem .8rem;border-radius:6px;font-size:.85rem;font-weight:700;font-family:Orbitron,sans-serif;letter-spacing:.05em;width:fit-content}.category-ic{background:var(--space-purple);color:#fff}.category-ir{background:var(--space-blue);color:#fff}.category-re{background:var(--space-cyan);color:var(--space-black)}.category-s{background:var(--space-green);color:var(--space-black)}.category-bus{background:var(--space-yellow);color:var(--space-black)}.category-tram{background:var(--space-pink);color:#fff}.connection-destination{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.connection-details{display:flex;flex-direction:column;gap:.75rem}.detail-row{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary);font-size:.95rem}.detail-row svg{color:var(--space-cyan);flex-shrink:0}.detail-label{min-width:80px}.detail-value{font-weight:600;color:var(--text-primary)}.detail-value.time{font-family:Orbitron,sans-serif;font-size:1.1rem;color:var(--space-cyan)}.detail-value.platform{padding:.25rem .75rem;background:var(--space-gray);border-radius:4px;font-family:Orbitron,sans-serif}.delay-info{color:var(--space-yellow)}.delay-info.delay-minor{color:var(--space-green)}.delay-info.delay-moderate{color:var(--space-yellow)}.delay-info.delay-severe{color:var(--space-pink)}.delay-info svg{color:currentColor}.connection-operator{margin-top:auto;padding-top:.75rem;border-top:1px solid var(--space-gray);font-size:.8rem;color:var(--text-muted);text-align:right}.empty-state{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.empty-icon{color:var(--space-gray);margin-bottom:1rem}.empty-state p{color:var(--text-secondary);font-size:1.1rem;margin:.5rem 0}.empty-hint{color:var(--text-muted);font-size:.9rem!important}@media(max-width:768px){.connections-grid{grid-template-columns:1fr}.monitor-controls{flex-direction:column;align-items:stretch}.control-group{width:100%}.control-actions{width:100%;justify-content:space-between}}.utilities{max-width:1400px}.utility-tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid var(--space-gray);overflow-x:auto}.tab-btn{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-family:Orbitron,sans-serif;font-size:.95rem;font-weight:600;transition:all .3s ease;border-bottom:2px solid transparent;margin-bottom:-2px}.tab-btn:hover{color:var(--space-cyan)}.tab-btn.active{color:var(--space-purple);border-bottom-color:var(--space-purple)}.utility-content{min-height:500px}.utility-card{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.utility-panel{display:flex;flex-direction:column;gap:1rem}.utility-panel label{color:var(--text-secondary);font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.utility-panel textarea{flex:1;font-family:Share Tech Mono,monospace;font-size:.9rem}.utility-panel textarea.error{border-color:var(--space-pink)}.button-group{display:flex;gap:1rem}.output-header{display:flex;justify-content:space-between;align-items:center}.copy-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--space-gray);border:1px solid var(--space-light-gray);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:.85rem;font-family:Share Tech Mono,monospace;transition:all .3s ease}.copy-btn:hover{border-color:var(--space-cyan);box-shadow:var(--glow-cyan)}.error-message{color:var(--space-pink);font-size:.9rem;padding:.75rem;background:#ff006e1a;border:1px solid var(--space-pink);border-radius:6px}.regex-tester{grid-template-columns:1fr;gap:2rem}.regex-inputs{display:flex;flex-direction:column;gap:1.5rem}.input-row{display:grid;grid-template-columns:1fr auto;gap:1rem}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-group.small{max-width:150px}.input-group label{color:var(--text-secondary);font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.input-group input,.input-group select{width:100%}.regex-results label{display:block;margin-bottom:1rem;color:var(--text-secondary);font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.matches-list{display:flex;flex-direction:column;gap:1rem;max-height:400px;overflow-y:auto}.match-item{padding:1rem;background:#0000004d;border:1px solid var(--space-gray);border-left:3px solid var(--space-green);border-radius:6px}.match-text{font-family:Share Tech Mono,monospace;color:var(--space-green);font-size:1rem;margin-bottom:.5rem;word-break:break-all}.match-info{font-size:.85rem;color:var(--text-muted)}.no-matches{padding:2rem;text-align:center;color:var(--text-muted);background:#0003;border:1px dashed var(--space-gray);border-radius:8px}.hash-output{padding:1.5rem;background:#0000004d;border:1px solid var(--space-gray);border-radius:8px;font-family:Share Tech Mono,monospace;color:var(--space-cyan);word-break:break-all;min-height:80px;display:flex;align-items:center}@media(max-width:1024px){.utility-card,.input-row{grid-template-columns:1fr}.input-group.small{max-width:none}}.notes .page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem}.notes-controls{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.search-box{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:#12121acc;border:1px solid var(--space-gray);border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.search-box svg{color:var(--space-cyan);flex-shrink:0}.search-box input{flex:1;background:transparent;border:none;padding:0;font-size:1rem}.search-box input:focus{outline:none;box-shadow:none}.category-filter{display:flex;gap:.75rem;flex-wrap:wrap}.filter-btn{padding:.6rem 1.2rem;background:var(--space-dark);border:1px solid var(--space-gray);border-radius:8px;color:var(--text-secondary);cursor:pointer;font-family:Orbitron,sans-serif;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;transition:all .3s ease}.filter-btn:hover{border-color:var(--space-purple)}.filter-btn.active{background:linear-gradient(135deg,var(--space-purple),var(--space-blue));border-color:var(--space-purple);color:#fff;box-shadow:var(--glow-purple)}.notes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.note-card{display:flex;flex-direction:column;gap:1rem;cursor:pointer;transition:all .3s ease}.note-card:hover{transform:translateY(-4px)}.note-card.category-code{border-left:4px solid var(--space-purple)}.note-card.category-research{border-left:4px solid var(--space-blue)}.note-card.category-snippet{border-left:4px solid var(--space-cyan)}.note-card.category-general{border-left:4px solid var(--space-green)}.note-header{display:flex;justify-content:space-between;align-items:center}.note-category{display:flex;align-items:center;gap:.5rem;padding:.4rem .8rem;background:#6b5ce726;border-radius:6px;font-size:.8rem;color:var(--space-cyan);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.note-actions{display:flex;gap:.5rem}.icon-btn{padding:.5rem;background:transparent;border:1px solid var(--space-gray);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.icon-btn:hover{border-color:var(--space-cyan);color:var(--space-cyan)}.icon-btn.delete:hover{border-color:var(--space-pink);color:var(--space-pink)}.note-title{font-size:1.25rem;font-family:Orbitron,sans-serif;color:var(--text-primary);margin:0}.note-content{flex:1;color:var(--text-secondary);line-height:1.6;font-size:.95rem}.note-tags{display:flex;flex-wrap:wrap;gap:.5rem}.tag{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .6rem;background:#00d4ff26;border:1px solid var(--space-cyan);border-radius:4px;font-size:.75rem;color:var(--space-cyan)}.tag.editable{padding-right:.3rem}.tag button{background:transparent;border:none;color:var(--space-cyan);cursor:pointer;padding:.2rem;display:flex;align-items:center;border-radius:3px;transition:all .2s ease}.tag button:hover{background:#ffffff1a;color:var(--space-pink)}.note-footer{padding-top:.75rem;border-top:1px solid var(--space-gray);font-size:.8rem;color:var(--text-muted)}.empty-notes{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--text-muted)}.empty-notes svg{margin-bottom:1rem;opacity:.5}.empty-notes p{margin:.5rem 0 1.5rem;font-size:1.1rem}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal-content{background:var(--space-dark);border:1px solid var(--space-gray);border-radius:16px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;border-bottom:1px solid var(--space-gray)}.modal-header h2{margin:0;font-size:1.75rem;background:linear-gradient(135deg,var(--space-cyan),var(--space-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.close-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;display:flex;align-items:center;transition:all .3s ease}.close-btn:hover{color:var(--space-pink)}.note-form{padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:var(--text-secondary);font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.form-group input,.form-group select,.form-group textarea{width:100%}.tag-input-container{display:flex;gap:.75rem}.tag-input-container input{flex:1}.tags-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.form-actions{display:flex;justify-content:flex-end;gap:1rem;padding-top:1rem;border-top:1px solid var(--space-gray)}.form-actions button{display:flex;align-items:center;gap:.5rem}@media(max-width:768px){.notes .page-header{flex-direction:column}.notes-grid{grid-template-columns:1fr}.modal-overlay{padding:1rem}.modal-header,.note-form{padding:1.5rem}}*{margin:0;padding:0;box-sizing:border-box}:root{--space-bg: #0d0d12;--space-surface: #16161d;--space-elevated: #1c1c26;--space-border: #2a2a35;--space-accent: #8b9aff;--space-accent-dim: #5a6899;--space-accent-bright: #a5b4ff;--space-success: #4ade80;--space-warning: #fbbf24;--space-error: #f87171;--text-primary: #e4e4e7;--text-secondary: #a1a1aa;--text-muted: #52525b;--glow-accent: 0 0 20px rgba(139, 154, 255, .15)}body{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,sans-serif;background:var(--space-bg);color:var(--text-primary);overflow-x:hidden;line-height:1.6;font-size:15px;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(1px 1px at 20% 30%,rgba(255,255,255,.4),transparent),radial-gradient(1px 1px at 60% 70%,rgba(255,255,255,.3),transparent),radial-gradient(1px 1px at 50% 50%,rgba(255,255,255,.4),transparent),radial-gradient(1px 1px at 80% 10%,rgba(255,255,255,.3),transparent),radial-gradient(1px 1px at 90% 60%,rgba(255,255,255,.4),transparent),radial-gradient(1px 1px at 33% 80%,rgba(255,255,255,.3),transparent),radial-gradient(1px 1px at 70% 40%,rgba(255,255,255,.4),transparent);background-size:200% 200%;background-position:0 0,40px 60px,130px 270px,70px 100px,150px 50px,220px 180px,180px 140px;opacity:.6;z-index:-1;pointer-events:none}h1,h2,h3,h4,h5,h6{font-weight:600;letter-spacing:-.02em}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--space-surface)}::-webkit-scrollbar-thumb{background:var(--space-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--space-accent-dim)}::selection{background:var(--space-accent);color:#fff}.card{background:var(--space-surface);border:1px solid var(--space-border);border-radius:8px;padding:1.5rem;transition:all .2s ease}.card:hover{border-color:var(--space-accent-dim);transform:translateY(-1px)}.btn{font-family:inherit;padding:.625rem 1.25rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary{background:var(--space-accent);color:#fff}.btn-primary:hover{background:var(--space-accent-bright);box-shadow:var(--glow-accent)}.btn-primary:active{transform:scale(.98)}.btn-secondary{background:var(--space-elevated);color:var(--text-primary);border:1px solid var(--space-border)}.btn-secondary:hover{border-color:var(--space-accent-dim);background:var(--space-surface)}input,textarea,select{font-family:inherit;background:var(--space-elevated);border:1px solid var(--space-border);border-radius:6px;padding:.625rem .875rem;color:var(--text-primary);font-size:.875rem;transition:all .2s ease}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--space-accent);background:var(--space-surface)}input::placeholder,textarea::placeholder{color:var(--text-muted)}.status-online{color:var(--space-success)}.status-warning{color:var(--space-warning)}.status-error{color:var(--space-error)}
