.login-container{align-items:center;background:var(--background);display:flex;flex-direction:column;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;justify-content:center;min-height:100vh;overflow-x:hidden;padding:2rem 1rem;width:100vw}.login-content{gap:2rem;max-width:420px}.login-content,.logo-section{align-items:center;display:flex;flex-direction:column;width:100%}.logo-section{gap:1rem}.logo{height:80px;transition:transform .8s cubic-bezier(.4,0,.2,1);width:80px}.logo.spinning{animation:logoSpin 1.5s cubic-bezier(.4,0,.2,1)}@keyframes logoSpin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.welcome-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--primary-terracotta),var(--dark-terracotta));-webkit-background-clip:text;background-clip:text;color:var(--text-dark);font-size:2rem;font-weight:700;margin:0;text-align:center}.secured-text{align-items:center;color:var(--text-gray);display:flex;font-size:.875rem;font-weight:500;gap:.5rem}.shield-icon{color:var(--primary-terracotta)}.llama-container{height:40px;margin-top:.5rem;overflow:hidden;position:relative;width:100%}.llama{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));height:40px;position:absolute;transition:right .05s linear;width:40px;z-index:10}@keyframes llamaHop{0%{transform:scaleX(-1) translateY(0)}50%{transform:scaleX(-1) translateY(-15px)}to{transform:scaleX(-1) translateY(0)}}.form-section{animation:formFadeIn .8s ease-out;display:flex;flex-direction:column;gap:1.5rem;width:100%}@keyframes formFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.message{padding:.875rem 1rem;text-align:left}.message.info{background:var(--ultra-light-teal);border:1px solid var(--primary-teal);color:var(--dark-teal)}.form-toggle{background:var(--white);border:1px solid var(--border);border-radius:.5rem;box-shadow:0 2px 4px #0000000d;display:flex;overflow:hidden}.form-toggle button{background:#0000;border:none;color:var(--text-gray);cursor:pointer;flex:1 1;font-size:.875rem;font-weight:500;padding:.75rem 1rem;transition:all .3s ease}.form-toggle button.active{background:#c4a48426;border-bottom:2px solid var(--primary-terracotta);color:var(--dark-terracotta)}.form-toggle button:hover:not(.active){background:var(--light-gray);color:var(--text-dark)}.auth-form{display:flex;flex-direction:column;gap:1rem;width:100%}.input-group{align-items:center;display:flex;position:relative}.input-icon{color:#9ca3af;left:1rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);z-index:2}.input-group input{background:var(--white);border:1px solid var(--border);border-radius:.5rem;box-shadow:0 2px 4px #0000000d;color:var(--text-dark);font-size:.875rem;padding:.875rem 1rem .875rem 3rem;transition:all .3s ease;width:100%}.input-group input:focus{border-color:var(--primary-terracotta);box-shadow:0 0 0 3px #c4a48426;outline:none}.input-group input::placeholder{color:#9ca3af}.password-toggle{align-items:center;background:none;border:none;border-radius:4px;color:#6669;cursor:pointer;display:flex;justify-content:center;padding:5px;position:absolute;right:12px;transition:all .2s ease;z-index:2}.password-toggle:hover{background:#c4a48426;color:var(--primary-terracotta)}.remember-me{align-items:center;color:var(--text-gray);display:flex;font-size:.875rem;gap:.5rem}.remember-me input[type=checkbox]{accent-color:var(--primary-terracotta);cursor:pointer;height:16px;width:16px}.remember-me label{cursor:pointer;-webkit-user-select:none;user-select:none}.auth-button{align-items:center;background:var(--dark);border:none;border-radius:.5rem;box-shadow:0 4px 6px #0000001a;color:var(--cream);cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;padding:.875rem 1rem;transition:all .3s ease;width:100%}.auth-button:hover:not(:disabled){background:#1f2937;box-shadow:0 6px 12px #00000026;transform:translateY(-1px)}.auth-button:active:not(:disabled){box-shadow:0 2px 4px #0000001a;transform:translateY(0)}.auth-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.auth-button.create-account{background:linear-gradient(135deg,var(--primary-terracotta),var(--dark-terracotta))}.auth-button.create-account:hover:not(:disabled){background:linear-gradient(135deg,var(--dark-terracotta),#8b7355)}.back-button{background:#0000;border:1px solid var(--border);border-radius:.5rem;color:var(--text-gray);cursor:pointer;font-size:.875rem;font-weight:500;padding:.75rem 1rem;transition:all .3s ease;width:100%}.back-button:hover{background:var(--light-gray);color:var(--text-dark)}.mfa-header{align-items:center;display:flex;flex-direction:column;gap:.75rem;padding:1rem 0;text-align:center}.mfa-header h2{color:var(--text-dark);font-size:1.25rem;font-weight:600;margin:0}.mfa-header p{color:var(--text-gray);font-size:.875rem;margin:0}.mfa-setup{display:flex;flex-direction:column;gap:1.5rem}.qr-code{background:var(--white);border:1px solid var(--border);border-radius:.75rem;display:flex;justify-content:center;padding:1rem}.qr-code img{height:200px;width:200px}.manual-code{background:var(--light-gray);border-radius:.5rem;padding:1rem;text-align:center}.manual-code p{color:var(--text-gray);font-size:.75rem;margin:0 0 .5rem}.manual-code code{color:var(--text-dark);font-family:Courier New,monospace;font-size:.875rem;font-weight:600;letter-spacing:.05em;word-break:break-all}.backup-codes{background:var(--warning-bg);border:1px solid var(--warning-border);border-radius:.5rem;padding:1rem}.backup-codes p{color:var(--warning-text);font-size:.875rem;margin:0 0 .75rem}.codes-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(2,1fr)}.codes-grid code{background:var(--white);border-radius:.25rem;font-family:Courier New,monospace;font-size:.75rem;padding:.25rem .5rem;text-align:center}.verify-text{color:var(--text-gray);font-size:.875rem;margin:0;text-align:center}.login-footer{color:var(--text-gray);font-size:.75rem;margin-top:2rem}@media (max-width:768px){.login-container{padding:1.5rem 1rem}.login-content{gap:1.5rem;max-width:360px;padding:1rem}.welcome-text{font-size:1.75rem}.logo{height:70px;width:70px}.design-line{width:150px}.form-section{gap:1.25rem}}@media (max-width:640px){.login-container{padding:1rem .75rem}.login-content{max-width:340px;padding:.75rem}.welcome-text{font-size:1.625rem}.logo{height:65px;width:65px}.secured-text{font-size:.8125rem}.input-group input{font-size:1rem;padding:.75rem .875rem .75rem 2.75rem}.auth-button{padding:.75rem 1rem}.mfa-header h2{font-size:1.125rem}.backup-codes{padding:.875rem}}@media (max-width:480px){.login-container{padding:1rem .5rem}.login-content{max-width:320px;padding:.5rem}.welcome-text{font-size:1.5rem}.logo{height:60px;width:60px}.design-line{width:120px}.form-toggle button{font-size:.8rem;padding:.625rem .75rem}.input-icon{left:.75rem}.input-group input{padding:.75rem .75rem .75rem 2.5rem}.qr-code img{height:160px;width:160px}.codes-grid{grid-template-columns:1fr}.manual-code code{font-size:.75rem}.login-footer{margin-top:1.5rem}}@media (max-width:320px){.login-container{padding:.75rem .375rem}.login-content{gap:1rem;max-width:100%}.welcome-text{font-size:1.25rem}.logo{height:50px;width:50px}.design-line{width:100px}.form-toggle button{font-size:.75rem;padding:.5rem}.input-group input{font-size:.9375rem;padding:.625rem .625rem .625rem 2.25rem}.auth-button{font-size:.8125rem;padding:.625rem .875rem}.qr-code img{height:140px;width:140px}.mfa-header h2{font-size:1rem}.mfa-header p{font-size:.8125rem}}.xterm{cursor:text;position:relative;user-select:none;-ms-user-select:none;-webkit-user-select:none}.xterm.focus,.xterm:focus{outline:none}.xterm .xterm-helpers{position:absolute;top:0;z-index:5}.xterm .xterm-helper-textarea{border:0;height:0;left:-9999em;margin:0;opacity:0;overflow:hidden;padding:0;position:absolute;resize:none;top:0;white-space:nowrap;width:0;z-index:-5}.xterm .composition-view{background:#000;color:#fff;display:none;position:absolute;white-space:nowrap;z-index:1}.xterm .composition-view.active{display:block}.xterm .xterm-viewport{background-color:#000;bottom:0;cursor:default;left:0;overflow-y:scroll;position:absolute;right:0;top:0}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{left:0;position:absolute;top:0}.xterm .xterm-scroll-area{visibility:hidden}.xterm-char-measure-element{display:inline-block;left:-9999em;line-height:normal;position:absolute;top:0;visibility:hidden}.xterm.enable-mouse-events{cursor:default}.xterm .xterm-cursor-pointer,.xterm.xterm-cursor-pointer{cursor:pointer}.xterm.column-select.focus{cursor:crosshair}.xterm .xterm-accessibility,.xterm .xterm-message{bottom:0;color:#0000;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:10}.xterm .live-region{height:1px;left:-9999px;overflow:hidden;position:absolute;width:1px}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{-webkit-text-decoration:double underline;text-decoration:double underline}.xterm-underline-3{-webkit-text-decoration:wavy underline;text-decoration:wavy underline}.xterm-underline-4{-webkit-text-decoration:dotted underline;text-decoration:dotted underline}.xterm-underline-5{-webkit-text-decoration:dashed underline;text-decoration:dashed underline}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:overline underline}.xterm-overline.xterm-underline-2{-webkit-text-decoration:overline double underline;text-decoration:overline double underline}.xterm-overline.xterm-underline-3{-webkit-text-decoration:overline wavy underline;text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{-webkit-text-decoration:overline dotted underline;text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{-webkit-text-decoration:overline dashed underline;text-decoration:overline dashed underline}.xterm-strikethrough{text-decoration:line-through}.xterm-screen .xterm-decoration-container .xterm-decoration{position:absolute;z-index:6}.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer{z-index:7}.xterm-decoration-overview-ruler{pointer-events:none;position:absolute;right:0;top:0;z-index:8}.xterm-decoration-top{position:relative;z-index:2}.terminal-panel{background:#faf9f6;background:var(--cream-light,#faf9f6);border-left:1px solid #e5e7eb;border-left:1px solid var(--border,#e5e7eb);box-shadow:-4px 0 24px #0000001a;display:flex;flex-direction:column;height:100vh;max-width:800px;min-width:500px;position:fixed;right:0;top:0;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);width:50%;z-index:1001}.terminal-panel.open{transform:translateX(0)}.terminal-panel.fullscreen{max-width:none;min-width:auto;width:100%}.terminal-header{align-items:center;background:#fff;background:var(--white,#fff);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border,#e5e7eb);display:flex;justify-content:space-between;padding:12px 16px}.terminal-header-left{align-items:center;display:flex;gap:10px}.terminal-header-right{align-items:center;display:flex;gap:12px}.terminal-collapse-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#6b7280;color:var(--gray,#6b7280);cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .15s ease}.terminal-collapse-btn:hover{background:#c4a48426;color:#111827;color:var(--dark,#111827)}.terminal-icon{color:#14b8a6;color:var(--accent-teal,#14b8a6)}.terminal-title{color:#111827;color:var(--dark,#111827);font-size:14px;font-weight:600}.terminal-location{background:#c4a48426;color:#6b7280;color:var(--gray,#6b7280);gap:4px;padding:3px 8px}.terminal-location,.terminal-status{align-items:center;border-radius:12px;display:flex;font-size:12px}.terminal-status{gap:6px;padding:4px 10px}.terminal-status.connected{background:#f0fdfa;background:var(--success-bg,#f0fdfa);color:#0d9488;color:var(--success-text,#0d9488)}.terminal-status.connecting{background:#fffbeb;background:var(--warning-bg,#fffbeb);color:#d97706;color:var(--warning-text,#d97706)}.terminal-status.disconnected{background:#fff5f5;background:var(--error-bg,#fff5f5);color:#dc2626;color:var(--error-text,#dc2626)}.terminal-actions{align-items:center;display:flex;gap:4px}.terminal-actions button{align-items:center;background:#0000;border:none;border-radius:6px;color:#6b7280;color:var(--gray,#6b7280);cursor:pointer;display:flex;justify-content:center;padding:6px 8px;transition:all .15s ease}.terminal-actions button:hover{background:#14b8a61a;color:#14b8a6;color:var(--accent-teal,#14b8a6)}.terminal-close-btn:hover{background:#fff5f5!important;background:var(--error-bg,#fff5f5)!important;color:#dc2626!important;color:var(--error-text,#dc2626)!important}.terminal-content{background:#1a1a1a;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.terminal-container{flex:1 1;padding:8px}.terminal-container .xterm{height:100%}.terminal-container .xterm-viewport{overflow-y:auto}.terminal-error{background:#ef44441a;border-bottom:1px solid #ef44444d;color:#ef4444;font-size:13px;padding:8px 16px}@media (max-width:1200px){.terminal-panel{width:60%}}@media (max-width:900px){.terminal-panel{max-width:none;min-width:auto;width:100%}}.terminal-container ::-webkit-scrollbar{width:8px}.terminal-container ::-webkit-scrollbar-track{background:#2a2a2a}.terminal-container ::-webkit-scrollbar-thumb{background:#4a4a4a;border-radius:4px}.terminal-container ::-webkit-scrollbar-thumb:hover{background:#5a5a5a}.service-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.service-modal{background:var(--white);border-radius:1rem;box-shadow:0 20px 40px #00000026;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.service-modal-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.service-modal-title{align-items:center;display:flex;gap:.75rem}.service-modal-title h2{color:var(--text-dark);font-size:1.25rem;font-weight:600;margin:0}.service-modal-header .close-button{background:none;border:none;border-radius:.375rem;color:var(--text-gray);cursor:pointer;padding:.5rem;transition:all .2s ease}.service-modal-header .close-button:hover{background:var(--light-gray);color:var(--text-dark)}.service-form{display:flex;flex-direction:column;gap:1.25rem;padding:1.5rem}.service-error{align-items:center;background:#ef44441a;border-radius:.5rem;color:var(--error-text);display:flex;font-size:.875rem;gap:.5rem;padding:.75rem 1rem}.form-group input[type=text],.form-group select,.form-group textarea{background:var(--white);border:1px solid var(--border);border-radius:.5rem;color:var(--text-dark);font-size:.875rem;padding:.75rem 1rem;transition:border-color .2s ease}.form-group input[type=text]:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary-teal);outline:none}.form-group select:disabled{background:var(--light-gray);cursor:not-allowed}.issue-type-buttons{display:flex;gap:.75rem}.issue-type-btn{background:var(--white);border:1px solid var(--border);border-radius:.5rem;color:var(--text-gray);cursor:pointer;flex:1 1;font-size:.875rem;font-weight:500;padding:.75rem 1rem;transition:all .2s ease}.issue-type-btn:hover{border-color:var(--primary-terracotta);color:var(--text-dark)}.issue-type-btn.active{background:#14b8a61a;border-color:var(--primary-teal);color:var(--primary-teal)}.checkbox-group{gap:.75rem}.checkbox-label{align-items:center;color:var(--text-dark);cursor:pointer;display:flex;font-size:.875rem;gap:.5rem}.checkbox-label input[type=checkbox]{accent-color:var(--primary-teal);cursor:pointer;height:1rem;width:1rem}.approved-by-input{margin-top:.5rem}.tech-checkboxes{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr)}.tech-checkbox{background:var(--light-gray);border-radius:.375rem;padding:.625rem .75rem;transition:background .2s ease}.tech-checkbox:hover{background:var(--cream)}.service-modal-footer{border-top:1px solid var(--border);display:flex;gap:.75rem;justify-content:flex-end;margin-top:.5rem;padding-top:1.25rem}.service-modal-footer .btn-secondary{background:var(--white);border:1px solid var(--border);border-radius:.5rem;color:var(--text-gray);cursor:pointer;font-size:.875rem;font-weight:500;padding:.75rem 1.25rem;transition:all .2s ease}.service-modal-footer .btn-secondary:hover{border-color:var(--text-gray);color:var(--text-dark)}.service-modal-footer .btn-primary{align-items:center;background:var(--primary-teal);border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1.25rem;transition:all .2s ease}.service-modal-footer .btn-primary:hover:not(:disabled){background:var(--dark-teal)}.service-modal-footer .btn-primary:disabled{cursor:not-allowed;opacity:.6}.service-sent{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:3rem 2rem;text-align:center}.service-sent h3{color:var(--text-dark);font-size:1.25rem;font-weight:600;margin:0}.service-sent p{color:var(--text-gray);font-size:.875rem;margin:0}.dashboard{display:flex;flex-direction:column;gap:1.5rem}.dashboard-loading{color:var(--text-gray);flex-direction:column;justify-content:center;min-height:400px}.dashboard-header,.dashboard-loading{align-items:center;display:flex;gap:1rem}.dashboard-header{flex-wrap:wrap;justify-content:space-between}.dashboard-header h1{color:var(--text-dark);font-size:1.75rem;font-weight:700;margin:0}.dashboard-header p{color:var(--text-gray);font-size:.875rem;margin:.25rem 0 0}.refresh-button{background:var(--white);border:1px solid var(--border);border-radius:.5rem;color:var(--text-dark);font-size:.875rem;gap:.5rem;padding:.625rem 1rem;transition:all .2s ease}.refresh-button:hover:not(:disabled){border-color:var(--primary-terracotta);color:var(--dark-terracotta)}.refresh-button .spinning{animation:spin 1s linear infinite}.header-actions{align-items:center;display:flex;gap:.75rem}.service-button{align-items:center;background:var(--primary-teal);border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.625rem 1rem;transition:all .2s ease}.service-button:hover{background:var(--dark-teal)}.dashboard-toolbar{background:var(--white);border:1px solid var(--border);border-radius:.75rem;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem}.dashboard-toolbar,.search-box{align-items:center;display:flex}.search-box{background:var(--light-gray);border-radius:.5rem;flex:1 1;gap:.5rem;max-width:400px;padding:.5rem 1rem}.search-box svg{color:var(--text-gray)}.search-box input{background:none;border:none;color:var(--text-dark);font-size:.875rem;width:100%}.search-box input:focus{outline:none}.search-box input::placeholder{color:var(--text-gray)}.toolbar-right{gap:1rem}.sort-select,.toolbar-right{align-items:center;display:flex}.sort-select{color:var(--text-gray);gap:.5rem}.sort-select select{background:var(--white);border:1px solid var(--border);border-radius:.375rem;color:var(--text-dark);cursor:pointer;font-size:.875rem;padding:.5rem .75rem}.view-toggle{background:var(--light-gray);border-radius:.5rem;display:flex;padding:.25rem}.view-toggle button{background:none;border:none;border-radius:.375rem;color:var(--text-gray);cursor:pointer;padding:.5rem;transition:all .2s ease}.view-toggle button:hover{color:var(--text-dark)}.view-toggle button.active{background:var(--white);box-shadow:0 1px 3px #0000001a;color:var(--dark-terracotta)}.error-message{align-items:center;background:var(--error-bg);border:1px solid var(--error-border);border-radius:.5rem;color:var(--error-text);display:flex;gap:.75rem;padding:1rem}.empty-state{background:var(--white);border:2px dashed var(--border);border-radius:1rem}.locations-container{display:flex;flex-direction:column;gap:2rem}.location-group{background:var(--white);border:1px solid var(--border);border-radius:1rem;overflow:hidden}.location-header{align-items:center;background:var(--cream-light);border-bottom:1px solid var(--border);display:flex;gap:.75rem;padding:1rem 1.25rem}.location-header.clickable{cursor:pointer;transition:background .2s ease;-webkit-user-select:none;user-select:none}.location-header.clickable:hover{background:#c4a48433}.location-header svg{color:var(--primary-terracotta)}.location-header h2{color:var(--text-dark);flex:1 1;font-size:1rem;font-weight:600;margin:0}.tunnel-count{background:var(--primary-terracotta);border-radius:1rem;color:#fff;font-size:.75rem;font-weight:600;padding:.25rem .75rem}.tunnels-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));padding:1rem}.tunnels-list{display:flex;flex-direction:column;padding:.5rem}.tunnels-list .tunnel-card{border-radius:.5rem;margin:.25rem 0}.tunnel-card{background:var(--white);border:1px solid var(--border);border-radius:.75rem;display:flex;flex-direction:column;gap:.75rem;padding:1rem;transition:all .2s ease}.tunnel-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.tunnel-card.status-online{border-left:3px solid var(--success-text)}.tunnel-card.status-offline{border-left:3px solid var(--error-text)}.tunnel-card.status-unknown{border-left:3px solid var(--warning-text)}.tunnel-header{justify-content:space-between}.tunnel-header,.tunnel-status{align-items:center;display:flex}.tunnel-status{font-size:.75rem;font-weight:500;gap:.375rem;text-transform:capitalize}.software-badge{border-radius:.25rem;font-size:.625rem;font-weight:600;margin-left:.25rem;padding:.125rem .375rem}.software-ne{background:#14b8a61a;color:#14b8a6b3}.software-nr{background:#ef444414;color:#ef444480}.tunnel-header-actions{align-items:center;display:flex;gap:.25rem}.expand-button,.terminal-button{background:none;border:none;border-radius:.375rem;color:var(--text-gray);cursor:pointer;padding:.375rem;transition:all .2s ease}.expand-button:hover{background:var(--light-gray);color:var(--dark-terracotta)}.terminal-button:hover{background:#14b8a61a;color:var(--accent-teal)}.tunnel-name{color:var(--text-dark);font-size:1rem;font-weight:600;margin:0}.tunnel-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--text-gray);display:-webkit-box;font-size:.8125rem;margin:0;overflow:hidden}.tunnel-footer{border-top:1px solid var(--border);justify-content:space-between;padding-top:.5rem}.tunnel-footer,.tunnel-link{align-items:center;display:flex}.tunnel-link{color:var(--primary-terracotta);font-size:.75rem;font-weight:500;gap:.375rem}.tunnel-link:hover{color:var(--dark-terracotta)}.tunnel-id{color:var(--text-gray);font-size:.7rem}.tunnel-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.tunnel-modal{animation:modalFadeIn .3s ease;background:var(--white);border-radius:1rem;display:flex;flex-direction:column;height:90vh;max-width:1200px;overflow:hidden;width:100%}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.modal-header,.modal-title{align-items:center;display:flex}.modal-title{gap:.75rem}.modal-title h3{color:var(--text-dark);font-size:1.125rem;font-weight:600;margin:0}.location-badge{display:flex;font-size:.75rem;gap:.25rem}.modal-actions{align-items:center;display:flex;gap:1rem}.modal-actions .btn-primary{align-items:center;background:var(--dark);border:none;border-radius:.5rem;color:var(--cream);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;text-decoration:none;transition:all .2s ease}.modal-actions .btn-primary:hover{background:#1f2937;box-shadow:0 4px 12px #1118274d;transform:translateY(-1px)}.close-button{background:none;border:none;color:var(--text-gray);cursor:pointer;padding:.25rem;transition:color .2s ease}.close-button:hover{color:var(--error-text)}.modal-content{flex:1 1;overflow:hidden;padding:0}.tunnel-iframe{border:none;height:149.25%;transform:scale(.67);transform-origin:top left;width:149.25%}@media (max-width:768px){.dashboard{gap:1rem}.dashboard-header h1{font-size:1.5rem}.dashboard-toolbar{align-items:stretch;flex-direction:column;padding:.875rem}.search-box{max-width:none}.toolbar-right{justify-content:space-between}.tunnels-grid{gap:.875rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));padding:.875rem}.modal-header{align-items:flex-start;flex-direction:column;padding:1rem}.modal-actions{justify-content:space-between;width:100%}.tunnel-modal{border-radius:.75rem;height:85vh}.location-header{padding:.875rem 1rem}}@media (max-width:640px){.dashboard-header{align-items:flex-start;flex-direction:column}.dashboard-header h1{font-size:1.375rem}.refresh-button{justify-content:center;width:100%}.dashboard-toolbar{border-radius:.5rem;padding:.75rem}.toolbar-right{flex-direction:column;gap:.75rem}.sort-select{width:100%}.sort-select select{flex:1 1}.view-toggle{justify-content:center;width:100%}.tunnels-grid{gap:.75rem;grid-template-columns:1fr;padding:.75rem}.tunnel-card{padding:.875rem}.tunnel-name{font-size:.9375rem}.tunnel-modal{border-radius:.5rem;height:90vh;max-height:calc(100vh - 2rem)}.tunnel-modal-overlay{padding:.5rem}.modal-title h3{font-size:1rem}.location-group{border-radius:.75rem}.locations-container{gap:1.25rem}.empty-state{padding:2rem 1rem}.empty-state h3{font-size:1.1rem}}@media (max-width:480px){.dashboard-header h1{font-size:1.25rem}.dashboard-toolbar{padding:.625rem}.search-box{padding:.375rem .75rem}.tunnels-grid{gap:.5rem;padding:.5rem}.tunnel-card{gap:.5rem;padding:.75rem}.tunnel-footer{align-items:flex-start;flex-direction:column;gap:.5rem}.tunnel-modal{height:95vh;max-height:calc(100vh - 1rem)}.modal-header{padding:.75rem}.modal-actions{flex-direction:column;gap:.5rem}.modal-actions .btn-primary{justify-content:center;width:100%}.location-header{flex-wrap:wrap;padding:.75rem}.location-header h2{font-size:.9375rem}}@media (max-width:320px){.dashboard-header h1{font-size:1.1rem}.tunnel-name{font-size:.875rem}.tunnel-description{font-size:.75rem}.tunnel-card{padding:.625rem}}.downloads-page{margin:0 auto;max-width:1200px;padding:24px}.downloads-loading{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;gap:16px;height:400px;justify-content:center}.toast-container{display:flex;flex-direction:column;gap:8px;position:fixed;right:24px;top:80px;z-index:1000}.toast{align-items:center;animation:slideIn .3s ease;background:var(--card-bg);border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;gap:10px;min-width:280px;padding:12px 16px}.toast.success{border-left:4px solid var(--primary-teal)}.toast.success svg{color:var(--primary-teal)}.toast.error{border-left:4px solid #dc2626}.toast.error svg{color:#dc2626}.toast span{color:var(--text-primary);flex:1 1;font-size:14px}.toast button{align-items:center;background:none;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:4px}.toast button:hover{background:var(--hover-bg)}.downloads-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:32px}.header-title{align-items:center;display:flex;gap:16px}.header-title svg{color:var(--primary-teal)}.header-title h1{color:var(--text-primary);font-size:24px;font-weight:600;margin:0}.header-title p{color:var(--text-secondary);font-size:14px;margin:4px 0 0}.refresh-button{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 16px;transition:all .2s}.refresh-button:hover{background:var(--hover-bg);border-color:var(--primary-teal)}.refresh-button:disabled{cursor:not-allowed;opacity:.6}.refresh-button svg.spinning{animation:spin 1s linear infinite}.downloads-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(500px,1fr))}.download-category{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.category-header{align-items:center;background:linear-gradient(135deg,#c4a4840d,#0000);border-bottom:1px solid var(--border-color);display:flex;gap:16px;padding:20px}.category-icon{align-items:center;background:linear-gradient(135deg,var(--primary-terracotta),var(--primary-teal));border-radius:12px;color:#fff;display:flex;height:48px;justify-content:center;width:48px}.category-info{flex:1 1}.category-info h2{color:var(--text-primary);font-size:18px;font-weight:600;margin:0}.category-info p{color:var(--text-secondary);font-size:13px;margin:4px 0 0}.upload-button{align-items:center;background:var(--primary-teal);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 14px;transition:all .2s}.upload-button:hover{background:#0d9488;transform:translateY(-1px)}.upload-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.files-list{max-height:400px;overflow-y:auto;padding:12px}.no-files{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;gap:12px;justify-content:center;padding:48px 24px}.no-files svg{opacity:.4}.no-files p{font-size:14px;margin:0}.file-item{align-items:center;border-radius:8px;display:flex;gap:12px;padding:12px;transition:background .2s}.file-item:hover{background:var(--hover-bg)}.file-icon{align-items:center;background:#c4a48426;border-radius:8px;color:var(--primary-terracotta);display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.file-info{flex:1 1;min-width:0}.file-name{color:var(--text-primary);display:block;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-meta{display:flex;gap:16px;margin-top:4px}.file-date,.file-size{align-items:center;color:var(--text-secondary);display:flex;font-size:12px;gap:4px}.file-actions{display:flex;flex-shrink:0;gap:4px}.delete-button,.download-button{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.download-button{background:var(--primary-teal);color:#fff}.download-button:hover{background:#0d9488;transform:translateY(-1px)}.delete-button{background:#0000;color:var(--text-secondary)}.delete-button:hover{background:#fee2e2;color:#dc2626}.files-list::-webkit-scrollbar{width:6px}.files-list::-webkit-scrollbar-track{background:#0000}.files-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.files-list::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@media (max-width:768px){.downloads-page{padding:16px}.downloads-header{align-items:flex-start;flex-direction:column;gap:16px}.downloads-grid{grid-template-columns:1fr}.category-header{flex-wrap:wrap}.upload-button{justify-content:center;margin-top:8px;width:100%}.file-meta{flex-direction:column;gap:4px}.toast-container{left:16px;right:16px}.toast{min-width:auto}}.preview-button{align-items:center;background:#c4a48426;border:none;border-radius:6px;color:var(--primary-terracotta);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.preview-button:hover{background:var(--primary-terracotta);color:#fff;transform:translateY(-1px)}.preview-modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;padding:24px;position:fixed;right:0;top:0;z-index:10000}.preview-modal{animation:scaleIn .2s ease;background:#0a0a0a;border-radius:16px;box-shadow:0 25px 50px -12px #00000080;display:flex;flex-direction:column;height:90vh;max-height:900px;max-width:1400px;overflow:hidden;width:100%}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.preview-modal-header{align-items:center;background:#111;border-bottom:1px solid #262626;display:flex;justify-content:space-between;padding:16px 20px}.preview-modal-title{align-items:center;color:#e5e5e5;display:flex;font-size:16px;font-weight:600;gap:12px}.preview-modal-title svg{color:var(--primary-teal)}.preview-modal-actions{display:flex;gap:8px}.preview-close-btn,.preview-fullscreen-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#a3a3a3;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.preview-fullscreen-btn:hover{background:#262626;color:#e5e5e5}.preview-close-btn:hover{background:#dc2626;color:#fff}.preview-modal-content{flex:1 1;overflow:hidden;position:relative}.preview-loading{align-items:center;background:#0a0a0a;bottom:0;color:#a3a3a3;display:flex;flex-direction:column;gap:16px;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.preview-loading p{font-size:14px}.preview-iframe{background:#0a0a0a;border:none;height:100%;width:100%}@media (max-width:768px){.preview-modal-overlay{padding:0}.preview-modal{border-radius:0;height:100vh;max-height:100vh;max-width:100%}}.file-icon.pdf-icon{background:#dc262626;color:#dc2626}.file-icon.manual-icon{background:#1a1a1a;color:var(--primary-terracotta)}.pdf-view-button{background:#c4a48426;color:var(--primary-terracotta)}.pdf-view-button:hover{background:var(--primary-terracotta);color:#fff;transform:translateY(-1px)}.pdf-viewer-modal .preview-modal-title svg{color:var(--primary-terracotta)}.download-pdf-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#a3a3a3;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.download-pdf-btn:hover{background:var(--primary-teal);color:#fff}.pdf-iframe{background:#fff}.pdf-viewer-content{background:#f5f5f5}.code-view-button{background:#6366f126;color:#6366f1}.code-view-button:hover{background:#6366f1;color:#fff;transform:translateY(-1px)}.code-viewer-modal{max-width:1000px}.code-viewer-modal .preview-modal-title svg{color:#6366f1}.copy-code-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#a3a3a3;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.copy-code-btn:hover{background:#262626;color:#e5e5e5}.copy-code-btn.copied{background:#22c55e;color:#fff}.code-viewer-content{background:#0d1117;overflow:auto}.code-block{word-wrap:break-word;color:#e6edf3;font-family:JetBrains Mono,Fira Code,SF Mono,Consolas,monospace;font-size:13px;line-height:1.6;margin:0;padding:20px;tab-size:2;white-space:pre-wrap}.code-block code{color:inherit;font-family:inherit}.code-block code::selection,.code-block::selection{background:#264f78}.developer-tools-section{margin-bottom:24px}.cli-category{background:var(--card-bg);border:1px solid var(--border-color)}.cli-category .category-header{border-bottom-color:var(--border-color)}.cli-category h2{color:var(--text-primary)}.cli-category p{color:var(--text-secondary)}.cli-icon{background:linear-gradient(135deg,var(--primary-teal),var(--primary-terracotta))!important;color:#fff!important}.cli-item{background:var(--card-bg)!important;border-color:var(--border-color)!important}.cli-item:hover{background:var(--hover-bg)!important;border-color:var(--primary-teal)!important}.cli-file-icon{background:var(--primary-teal)!important;color:#fff!important}.cli-name-row{align-items:center;display:flex;gap:10px;margin-bottom:6px}.cli-name-row .file-name{color:var(--text-primary);font-size:16px}.cli-version{background:var(--primary-teal);border-radius:12px;color:#fff;font-size:11px;font-weight:600;padding:2px 8px}.cli-description{color:var(--text-secondary);font-size:13px;line-height:1.5;margin-bottom:10px}.cli-install-command{background:var(--hover-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--primary-teal);display:inline-block;font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;padding:6px 12px}.npm-button{background:#cb3837!important;color:#fff!important}.npm-button:hover{background:#a02c2c!important}.settings{display:flex;flex-direction:column;gap:1.5rem}.settings-loading{color:var(--text-gray);flex-direction:column;justify-content:center;min-height:400px}.settings-header,.settings-loading{align-items:center;display:flex;gap:1rem}.settings-header{flex-wrap:wrap;justify-content:space-between}.settings-header h1{color:var(--text-dark);font-size:1.75rem;font-weight:700;margin:0}.settings-header p{color:var(--text-gray);font-size:.875rem;margin:.25rem 0 0}.add-button{align-items:center;background:var(--dark);border:none;border-radius:.5rem;color:var(--cream);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.625rem 1.25rem;transition:all .2s ease}.add-button:hover{background:#1f2937;box-shadow:0 4px 12px #1118274d;transform:translateY(-1px)}.message{align-items:center;border-radius:.5rem;display:flex;font-size:.875rem;gap:.75rem;padding:1rem}.message.success{background:var(--success-bg);border:1px solid var(--success-border);color:var(--success-text)}.message.error{background:var(--error-bg);border:1px solid var(--error-border);color:var(--error-text)}.tunnel-form-card{background:var(--white);border:1px solid var(--border);border-radius:1rem;overflow:hidden}.form-header{align-items:center;background:var(--cream-light);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:1rem 1.5rem}.form-header h2{color:var(--text-dark);font-size:1.125rem;font-weight:600;margin:0}.cancel-button{background:none;border:none;border-radius:.375rem;color:var(--text-gray);cursor:pointer;padding:.25rem;transition:all .2s ease}.cancel-button:hover{background:var(--light-gray);color:var(--error-text)}.tunnel-form{display:flex;flex-direction:column;gap:1.25rem;padding:1.5rem}.form-row{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{align-items:center;color:var(--text-dark);display:flex;font-size:.875rem;font-weight:500;gap:.5rem}.form-group label svg{color:var(--primary-terracotta)}.form-group input,.form-group textarea{border:1px solid var(--border);border-radius:.5rem;color:var(--text-dark);font-size:.875rem;padding:.75rem 1rem;transition:all .2s ease}.form-group input:focus,.form-group textarea:focus{border-color:var(--primary-terracotta);box-shadow:0 0 0 3px #c4a48426;outline:none}.form-group input::placeholder,.form-group textarea::placeholder{color:#9ca3af}.form-group textarea{min-height:80px;resize:vertical}.form-hint{color:var(--text-gray);font-size:.75rem;margin-top:.25rem}.form-actions{border-top:1px solid var(--border);display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem}.btn-cancel{background:var(--white);border:1px solid var(--border);border-radius:.5rem;color:var(--text-gray);cursor:pointer;font-size:.875rem;font-weight:500;padding:.625rem 1.25rem;transition:all .2s ease}.btn-cancel:hover{background:var(--light-gray);color:var(--text-dark)}.btn-save{align-items:center;background:var(--accent-teal);border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.625rem 1.25rem;transition:all .2s ease}.btn-save:hover:not(:disabled){background:var(--dark-teal);box-shadow:0 4px 12px #14b8a64d;transform:translateY(-1px)}.btn-save:disabled{cursor:not-allowed;opacity:.6}.tunnels-list-container{background:var(--white);border:1px solid var(--border);border-radius:1rem;overflow:hidden}.tunnels-list-container h2{background:var(--light-gray);border-bottom:1px solid var(--border);color:var(--text-dark);font-size:1rem;font-weight:600;margin:0;padding:1rem 1.5rem}.empty-state{gap:1rem;padding:4rem 2rem;text-align:center}.empty-state svg{color:var(--text-gray);opacity:.5}.empty-state h3{color:var(--text-dark);font-size:1.25rem;margin:0}.empty-state p{color:var(--text-gray)}.tunnels-table-wrapper{overflow-x:auto}.tunnels-table{border-collapse:collapse;width:100%}.tunnels-table td,.tunnels-table th{border-bottom:1px solid var(--border);padding:1rem 1.25rem;text-align:left}.tunnels-table th{background:var(--light-gray);color:var(--text-gray);font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.tunnels-table tr:last-child td{border-bottom:none}.tunnels-table tr:hover td{background:var(--cream-light)}.tunnel-name-cell{display:flex;flex-direction:column;gap:.25rem}.tunnel-name-cell .name{color:var(--text-dark);font-weight:500}.tunnel-name-cell .description{color:var(--text-gray);font-size:.75rem}.location-badge{align-items:center;background:#c4a48426;border-radius:1rem;color:var(--dark-terracotta);display:inline-flex;font-size:.8125rem;font-weight:500;gap:.375rem;padding:.25rem .75rem}.tunnel-id{background:var(--light-gray);border-radius:.25rem;font-family:monospace;font-size:.8125rem;padding:.25rem .5rem}.tunnel-url{color:var(--primary-terracotta);display:block;font-size:.8125rem;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tunnel-url:hover{color:var(--dark-terracotta)}.action-buttons{align-items:center;display:flex;gap:.5rem}.action-btn{background:none;border:none;border-radius:.375rem;cursor:pointer;padding:.5rem;transition:all .2s ease}.action-btn.edit{color:var(--primary-terracotta)}.action-btn.edit:hover{background:#c4a48426}.action-btn.delete{color:var(--error-text)}.action-btn.delete:hover{background:var(--error-bg)}.delete-confirm{display:flex;gap:.25rem}.action-btn.confirm{color:var(--success-text)}.action-btn.confirm:hover{background:var(--success-bg)}.action-btn.cancel{color:var(--text-gray)}.action-btn.cancel:hover{background:var(--light-gray)}@media (max-width:768px){.settings{gap:1rem}.settings-header{align-items:flex-start;flex-direction:column}.settings-header h1{font-size:1.5rem}.add-button{justify-content:center;width:100%}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn-cancel,.btn-save{justify-content:center;width:100%}.tunnel-form{padding:1.25rem}.form-header{padding:.875rem 1.25rem}.tunnels-table td,.tunnels-table th{padding:.75rem}.tunnels-table td:nth-child(3),.tunnels-table th:nth-child(3){display:none}.tunnels-list-container h2{padding:.875rem 1.25rem}}@media (max-width:640px){.settings-header h1{font-size:1.375rem}.tunnel-form-card{border-radius:.75rem}.tunnel-form{gap:1rem;padding:1rem}.form-header{padding:.75rem 1rem}.form-header h2{font-size:1rem}.form-group input,.form-group textarea{padding:.625rem .875rem}.tunnels-list-container{border-radius:.75rem}.tunnels-list-container h2{font-size:.9375rem;padding:.75rem 1rem}.tunnels-table td,.tunnels-table th{font-size:.8125rem;padding:.625rem .75rem}.tunnels-table td:nth-child(4),.tunnels-table th:nth-child(4){display:none}.empty-state{padding:2rem 1rem}.empty-state h3{font-size:1.1rem}.action-buttons{gap:.25rem}.action-btn{padding:.375rem}}@media (max-width:480px){.settings-header h1{font-size:1.25rem}.add-button{font-size:.8125rem;padding:.5rem 1rem}.tunnel-form{padding:.875rem}.form-group label{font-size:.8125rem}.tunnels-table td,.tunnels-table th{font-size:.75rem;padding:.5rem}.tunnels-table thead{display:none}.tunnels-table,.tunnels-table tbody,.tunnels-table td,.tunnels-table tr{display:block;width:100%}.tunnels-table tr{border:1px solid var(--border);border-radius:.5rem;margin-bottom:.5rem;padding:.75rem}.tunnels-table td{border:none;padding:.25rem 0;text-align:left}.tunnels-table td:before{color:var(--text-gray);content:attr(data-label);display:block;font-size:.6875rem;font-weight:600;margin-bottom:.125rem;text-transform:uppercase}.tunnels-table td:last-child{border-top:1px solid var(--border);margin-top:.5rem;padding-top:.5rem}.action-buttons{justify-content:flex-start}.tunnel-url{max-width:100%}.location-badge{font-size:.75rem;padding:.125rem .5rem}}@media (max-width:320px){.settings-header h1{font-size:1.1rem}.tunnel-form{padding:.75rem}.form-group input,.form-group textarea{font-size:.8125rem;padding:.5rem .75rem}.tunnels-table tr{padding:.625rem}}.devops-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.devops-panel{background:var(--white);border-radius:1rem;box-shadow:0 20px 40px #00000026;display:flex;flex-direction:column;max-height:85vh;max-width:800px;overflow:hidden;width:100%}.devops-header{background:var(--cream-light);border-bottom:1px solid var(--border);justify-content:space-between;padding:1.25rem 1.5rem}.devops-header,.devops-title{align-items:center;display:flex}.devops-title{gap:.75rem}.devops-title svg{color:var(--primary-teal)}.devops-title h2{color:var(--text-dark);font-size:1.25rem;font-weight:600;margin:0}.devops-header .close-button{background:none;border:none;border-radius:.375rem;color:var(--text-gray);cursor:pointer;padding:.5rem;transition:all .2s ease}.devops-header .close-button:hover{background:var(--light-gray);color:var(--text-dark)}.devops-tabs{background:var(--white);border-bottom:1px solid var(--border);display:flex}.devops-tabs .tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:var(--text-gray);cursor:pointer;display:flex;flex:1 1;font-size:.875rem;font-weight:500;gap:.5rem;justify-content:center;padding:1rem;transition:all .2s ease}.devops-tabs .tab:hover{background:var(--cream-light);color:var(--text-dark)}.devops-tabs .tab.active{border-bottom-color:var(--primary-teal);color:var(--primary-teal)}.devops-tabs .badge{background:var(--primary-teal);border-radius:1rem;color:#fff;font-size:.75rem;font-weight:600;padding:.125rem .5rem}.devops-content{flex:1 1;overflow-y:auto;padding:1.5rem}.content-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.content-header h3{color:var(--text-dark);font-size:.875rem;font-weight:600;margin:0}.refresh-btn{align-items:center;background:var(--light-gray);border:none;border-radius:.375rem;color:var(--text-gray);cursor:pointer;display:flex;font-size:.75rem;font-weight:500;gap:.375rem;padding:.5rem .75rem;transition:all .2s ease}.refresh-btn:hover:not(:disabled){background:var(--border);color:var(--text-dark)}.refresh-btn .spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.filter-group{align-items:center;display:flex;gap:.5rem;position:relative}.filter-group svg{color:var(--text-gray)}.filter-group select{-webkit-appearance:none;appearance:none;background:var(--white);border:1px solid var(--border);border-radius:.375rem;color:var(--text-dark);cursor:pointer;font-size:.75rem;padding:.5rem 2rem .5rem .75rem}.filter-group .select-arrow{pointer-events:none;position:absolute;right:.5rem}.empty-state{align-items:center;color:var(--text-gray);display:flex;flex-direction:column;gap:.75rem;justify-content:center;padding:3rem}.empty-state p{font-size:.875rem;margin:0}.sessions-list{display:flex;flex-direction:column;gap:.75rem}.session-card{background:var(--cream-light);border:1px solid var(--border);border-radius:.5rem;padding:1rem}.session-main{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.75rem}.session-user{display:flex;flex-direction:column;gap:.125rem}.session-user .username{color:var(--text-dark);font-weight:600}.session-user .email{color:var(--text-gray);font-size:.75rem}.terminate-btn{background:none;border:none;border-radius:.25rem;color:var(--text-gray);cursor:pointer;padding:.375rem;transition:all .2s ease}.terminate-btn:hover{background:var(--error-bg);color:var(--error-text)}.session-details{display:flex;flex-wrap:wrap;gap:1rem}.session-details .detail{align-items:center;color:var(--text-gray);display:flex;font-size:.75rem;gap:.375rem}.audit-list{border:1px solid var(--border);border-radius:.5rem;display:flex;flex-direction:column;overflow:hidden}.audit-row{grid-gap:.75rem;align-items:center;border-bottom:1px solid var(--border);display:grid;font-size:.75rem;gap:.75rem;grid-template-columns:120px 100px 120px 1fr 100px;padding:.75rem 1rem}.audit-row:last-child{border-bottom:none}.audit-row:nth-child(odd){background:var(--cream-light)}.audit-time{color:var(--text-gray)}.audit-user{color:var(--text-dark);font-weight:500}.audit-action{border-radius:.25rem;font-size:.625rem;font-weight:500;letter-spacing:.025em;padding:.25rem .5rem;text-align:center;text-transform:uppercase}.action-login{background:#14b8a626;color:var(--primary-teal)}.action-logout{background:#6b728026;color:var(--gray)}.action-create{background:#22c55e26;color:#16a34a}.action-delete{background:#ef444426;color:var(--error-text)}.action-update{background:#c4a48426;color:var(--dark-terracotta)}.action-default{background:var(--light-gray);color:var(--text-gray)}.audit-details{color:var(--text-gray);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.audit-ip{color:var(--text-gray);font-family:monospace;font-size:.6875rem}@media (max-width:768px){.devops-panel{border-radius:.75rem;max-height:90vh}.audit-row{gap:.375rem;grid-template-columns:1fr}.audit-ip,.audit-time{font-size:.6875rem}}.layout{background:var(--background);display:flex;flex-direction:column;min-height:100vh}.header{background:var(--white);border-bottom:1px solid var(--border);height:64px;justify-content:space-between;padding:0 1.5rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header,.header-left{align-items:center;display:flex}.header-left{gap:1rem}.mobile-menu-button{background:none;border:none;border-radius:.375rem;color:var(--text-gray);cursor:pointer;display:none;padding:.5rem}.mobile-menu-button:hover{background:var(--light-gray);color:var(--text-dark)}.logo{align-items:center;cursor:pointer;display:flex;gap:.5rem}.logo-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--primary-terracotta),var(--dark-terracotta));-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:700}.nav-desktop,.nav-item{align-items:center;display:flex;gap:.5rem}.nav-item{background:none;border:none;border-radius:.5rem;color:var(--text-gray);cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.nav-item:hover{background:var(--light-gray);color:var(--text-dark)}.nav-item.active{background:#c4a48426;color:var(--dark-terracotta)}.header-right{align-items:center;display:flex;gap:1rem}.user-menu-container{position:relative}.user-menu-button{align-items:center;background:none;border:1px solid var(--border);border-radius:.5rem;cursor:pointer;display:flex;gap:.5rem;padding:.375rem .75rem;transition:all .2s ease}.user-menu-button:hover{background:var(--light-gray);border-color:var(--gray)}.user-avatar{align-items:center;background:linear-gradient(135deg,var(--primary-terracotta),var(--dark-terracotta));border-radius:50%;color:#fff;display:flex;height:32px;justify-content:center;width:32px}.user-avatar.large{height:48px;width:48px}.user-name{color:var(--text-dark);font-size:.875rem;font-weight:500}.user-menu-button svg.rotated{transform:rotate(180deg)}.user-menu-button svg{transition:transform .2s ease}.user-menu-dropdown{animation:dropdownFadeIn .2s ease;background:var(--white);border:1px solid var(--border);border-radius:.75rem;box-shadow:0 10px 40px #0000001a;position:absolute;right:0;top:calc(100% + .5rem);width:280px;z-index:110}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.user-info{align-items:center;display:flex;gap:1rem;padding:1rem}.user-info .username{color:var(--text-dark);font-size:.9rem;font-weight:600;margin:0}.user-info .email{color:var(--text-gray);font-size:.75rem;margin:.25rem 0}.role-badge{border-radius:1rem;display:inline-block;font-size:.65rem;font-weight:600;padding:.125rem .5rem;text-transform:uppercase}.role-badge.admin{background:var(--primary-orange);color:#fff}.role-badge.user{background:var(--light-gray);color:var(--text-gray)}.menu-divider{background:var(--border);height:1px;margin:0}.menu-item{align-items:center;background:none;border:none;color:var(--text-dark);cursor:pointer;display:flex;font-size:.875rem;gap:.75rem;padding:.75rem 1rem;transition:all .2s ease;width:100%}.menu-item:hover{background:var(--light-gray)}.menu-item.logout{color:var(--error-text)}.menu-item.logout:hover{background:var(--error-bg)}.nav-mobile{background:var(--white);border-bottom:1px solid var(--border);display:none;flex-direction:column;padding:.5rem}.nav-mobile .nav-item{justify-content:flex-start;padding:.75rem 1rem}.nav-mobile .nav-item.logout{border-top:1px solid var(--border);color:var(--error-text);margin-top:.5rem;padding-top:1rem}.main-content{flex:1 1;margin:0 auto;max-width:1400px;padding:1.5rem;width:100%}@media (max-width:768px){.nav-desktop{display:none}.mobile-menu-button,.nav-mobile{display:flex}.user-name{display:none}.header{height:56px;padding:0 1rem}.main-content{padding:1rem}.user-menu-dropdown{right:-.5rem;width:260px}.logo-text{font-size:1.1rem}}@media (max-width:640px){.header{height:52px;padding:0 .75rem}.main-content{padding:.75rem}.logo-text{font-size:1rem}.user-menu-dropdown{right:-.75rem;width:240px}.user-info{padding:.875rem}.menu-item{padding:.625rem .875rem}.nav-mobile .nav-item{font-size:.9375rem;padding:.875rem 1rem}}@media (max-width:480px){.header{height:48px;padding:0 .5rem}.main-content{padding:.5rem}.logo-text{font-size:.9375rem}.user-avatar{height:28px;width:28px}.user-menu-button{padding:.25rem .5rem}.user-menu-dropdown{left:.5rem;position:fixed;right:.5rem;top:48px;width:auto}}@media (max-width:320px){.header{height:44px}.logo-text{font-size:.875rem}.mobile-menu-button{padding:.375rem}}:root{--primary-terracotta:#c4a484;--dark-terracotta:#a08060;--accent-teal:#14b8a6;--dark-teal:#0d9488;--dark:#111827;--gray:#6b7280;--light-gray:#f3f4f6;--cream:#fffdf7;--cream-light:#faf9f6;--ultra-light-cream:#faf9f6;--border:#e5e7eb;--background:#faf9f6;--white:#fff;--primary-teal:#14b8a6;--primary-orange:#c4a484;--dark-orange:#a08060;--ultra-light-teal:#faf9f6;--text-dark:#111827;--text-gray:#6b7280;--success-bg:#f0fdfa;--success-border:#5eead4;--success-text:#0d9488;--error-bg:#fff5f5;--error-border:#fca5a5;--error-text:#dc2626;--warning-bg:#fffbeb;--warning-border:#fcd34d;--warning-text:#d97706}[data-theme=dark]{--primary-terracotta:#d4b494;--dark-terracotta:#c4a484;--accent-teal:#2dd4bf;--dark-teal:#14b8a6;--dark:#f9fafb;--gray:#9ca3af;--light-gray:#1f2937;--cream:#111827;--cream-light:#1a1f2e;--ultra-light-cream:#1a1f2e;--border:#374151;--background:#0f172a;--white:#1e293b;--text-dark:#f9fafb;--text-gray:#9ca3af;--success-bg:#0d948826;--success-border:#0d9488;--success-text:#2dd4bf;--error-bg:#dc262626;--error-border:#dc2626;--error-text:#f87171;--warning-bg:#d9770626;--warning-border:#d97706;--warning-text:#fbbf24}*,:after,:before{box-sizing:border-box}body,html{height:auto;min-height:100%;overflow-x:hidden;overflow-y:auto}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#faf9f6;background:var(--background);color:#111827;color:var(--text-dark);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0;padding:0}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f3f4f6;background:var(--light-gray)}::-webkit-scrollbar-thumb{background:#6b7280;background:var(--gray);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#0d9488;background:var(--dark-teal)}::selection{background:#14b8a6;background:var(--primary-teal);color:#fff;color:var(--white)}:focus-visible{outline:2px solid #14b8a6;outline:2px solid var(--primary-teal);outline-offset:2px}a{color:#14b8a6;color:var(--primary-teal);text-decoration:none;transition:color .2s ease}a:hover{color:#0d9488;color:var(--dark-teal)}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:all .2s ease}.btn-primary{background:#111827;background:var(--dark);color:#fffdf7;color:var(--cream)}.btn-primary:hover{background:#1f2937;box-shadow:0 4px 12px #1118274d;transform:translateY(-2px)}.btn-secondary{background:#14b8a6;background:var(--accent-teal);color:#fff;color:var(--white)}.btn-secondary:hover{background:#0d9488;background:var(--dark-teal);box-shadow:0 4px 12px #14b8a666;transform:translateY(-2px)}.btn-outline{background:#0000;border:2px solid #14b8a6;border:2px solid var(--primary-teal);color:#14b8a6;color:var(--primary-teal)}.btn-outline:hover{background:#14b8a6;background:var(--primary-teal);color:#fff;color:var(--white)}.card{background:#fff;background:var(--white);border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:1.5rem;transition:all .3s ease}.card:hover{box-shadow:0 10px 40px #0000001a;transform:translateY(-4px)}.design-line{background:linear-gradient(90deg,#faf9f6,#c4a484 25%,#fffdf7 50%,#a08060 75%,#faf9f6);border-radius:1px;height:2px;opacity:.8;width:200px}.gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#c4a484,#a08060);background:linear-gradient(135deg,var(--primary-terracotta),var(--dark-terracotta));-webkit-background-clip:text;background-clip:text}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn .6s ease-out forwards}.animate-slide-in{animation:slideIn .6s ease-out forwards}@media (max-width:768px){body{font-size:15px}.card{border-radius:10px;padding:1.25rem}.btn,a,button,input,select,textarea{min-height:44px}}@media (max-width:640px){body{font-size:14px}.card{border-radius:8px;padding:1rem}.btn{font-size:.8125rem;padding:.625rem 1.25rem;width:100%}.design-line{width:120px}h1{font-size:1.5rem!important}h2{font-size:1.25rem!important}h3{font-size:1.1rem!important}}@media (max-width:480px){body{font-size:13px}.card{padding:.875rem}.btn{font-size:.75rem;padding:.5rem 1rem}.design-line{width:100px}}@media (max-width:320px){body{font-size:12px}.card{padding:.75rem}h1{font-size:1.25rem!important}h2{font-size:1.1rem!important}}
/*# sourceMappingURL=main.6988bf33.css.map*/