.audit-page{padding:2rem;max-width:1200px;margin:0 auto}.audit-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem;flex-wrap:wrap}.audit-eyebrow{display:block;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.audit-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem;letter-spacing:-.02em}.audit-subtitle{font-size:.95rem;color:var(--text-secondary);margin:0;max-width:400px}.audit-actions{display:flex;gap:.75rem;flex-wrap:wrap}.audit-search{position:relative;display:flex;align-items:center}.audit-search-icon{position:absolute;left:.875rem;color:var(--text-muted);font-size:.875rem}.audit-search-input{padding:.625rem .875rem .625rem 2.5rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;width:200px;transition:all .2s}.audit-search-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f61a}.audit-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;font-size:.875rem;font-weight:500;border-radius:8px;border:none;cursor:pointer;transition:all .2s}.audit-btn-secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.audit-btn-secondary:hover{background:var(--border-color)}.audit-filters{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.audit-filter-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;font-size:.8rem;font-weight:500;background:transparent;border:1px solid var(--border-color);border-radius:20px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.audit-filter-btn:hover{background:var(--bg-tertiary);border-color:var(--text-muted)}.audit-filter-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.audit-filter-btn.active:hover{background:var(--accent-primary-hover, #2563eb);border-color:var(--accent-primary-hover, #2563eb)}.audit-table-container{background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);overflow:hidden}.audit-table{width:100%;border-collapse:collapse}.audit-table th{text-align:left;padding:.875rem 1rem;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.audit-table td{padding:.875rem 1rem;font-size:.875rem;color:var(--text-primary);border-bottom:1px solid var(--border-color);vertical-align:middle}.audit-table tbody tr:last-child td{border-bottom:none}.audit-table tbody tr:hover{background:var(--bg-tertiary)}.audit-event{display:flex;align-items:center;gap:.625rem}.audit-event-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.audit-event-action{font-weight:500}.audit-user{display:flex;flex-direction:column;gap:.125rem}.audit-user-name{font-weight:500}.audit-user-email{font-size:.75rem;color:var(--text-muted)}.audit-resource{display:flex;flex-direction:column;gap:.125rem}.audit-resource-type{font-size:.75rem;color:var(--text-muted);text-transform:uppercase}.audit-resource-name{font-weight:500}.audit-details{color:var(--text-secondary);font-size:.8rem;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.audit-time{font-size:.8rem;color:var(--text-muted)}.audit-empty{text-align:center;padding:3rem!important;color:var(--text-muted)}.audit-loading,.audit-error{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.audit-error{color:var(--error)}.audit-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.audit-page-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;transition:all .2s}.audit-page-btn:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--text-muted)}.audit-page-btn:disabled{opacity:.5;cursor:not-allowed}.audit-page-info{font-size:.875rem;color:var(--text-secondary)}@media(max-width:768px){.audit-page{padding:1.5rem}.audit-header{flex-direction:column;gap:1rem;margin-bottom:1.5rem}.audit-title{font-size:1.5rem}.audit-actions{width:100%;gap:.5rem}.audit-search-input{width:100%;flex:1;min-height:44px;padding:10px 12px 10px 36px;font-size:1rem}.audit-btn{min-height:44px;font-size:.9rem;padding:10px 12px}.audit-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.audit-table{min-width:600px}.audit-filters{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:.75rem;gap:.5rem}.audit-filter-btn{flex-shrink:0;min-height:40px;padding:8px 12px}.audit-table td,.audit-table th{padding:.75rem;font-size:.85rem}}@media(max-width:600px){.audit-page{padding:1rem}.audit-title{font-size:1.3rem}.audit-subtitle{font-size:.9rem}.audit-eyebrow{font-size:.7rem}.audit-actions{gap:.375rem;flex-direction:column}.audit-search-input{width:100%;min-height:44px;font-size:1rem;padding:10px 12px 10px 32px}.audit-btn{width:100%;justify-content:center;min-height:44px}.audit-filters{gap:.375rem;padding-bottom:.5rem}.audit-filter-btn{min-height:40px;padding:8px 10px;font-size:.85rem}.audit-table{min-width:500px;font-size:.8rem}.audit-table td,.audit-table th{padding:.6rem}}@media(max-width:480px){.audit-page{padding:.75rem}.audit-title{font-size:1.2rem}.audit-subtitle{font-size:.85rem}.audit-search-input{width:100%;padding:8px 10px 8px 28px;font-size:1rem;min-height:40px}.audit-btn{padding:8px;font-size:.8rem;min-height:40px}.audit-btn-text{display:none}.audit-table{min-width:450px;font-size:.75rem}.audit-table td,.audit-table th{padding:.5rem}}@media(max-width:375px){.audit-page{padding:.5rem}.audit-title{font-size:1.1rem}.audit-search-input{padding:6px 8px 6px 26px;font-size:.95rem}.audit-btn{padding:6px 8px}.audit-table{min-width:400px;font-size:.7rem}.audit-table td,.audit-table th{padding:.4rem}}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:radial-gradient(circle at top,rgba(16,163,127,.1),transparent 45%)}.error-boundary-card{max-width:420px;text-align:center;padding:2.5rem;border-radius:16px;background:var(--bg-elevated);border:1px solid var(--border);box-shadow:0 20px 40px #0006}.error-boundary-card h2{margin:0 0 .75rem;color:var(--text-primary)}.error-boundary-card p{margin:0 0 1.5rem;color:var(--text-muted)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:2rem;box-sizing:border-box}.login-container{width:100%;max-width:440px;animation:fadeInUp .5s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-card{background:var(--bg-secondary);border-radius:16px;padding:3rem 2.5rem;box-shadow:0 4px 24px #0000001f;border:1px solid var(--border-color)}.login-header{text-align:center;margin-bottom:2rem}.login-logo{width:64px;height:64px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;box-shadow:0 4px 12px #3b82f64d}.login-logo svg{color:#fff;font-size:28px}.login-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem;letter-spacing:-.02em}.login-subtitle{font-size:.95rem;color:var(--text-secondary);margin:0;line-height:1.5}.login-divider{display:flex;align-items:center;margin:2rem 0;gap:1rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.login-divider span{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.login-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;border-radius:10px;border:none;cursor:pointer;transition:all .2s ease}.login-btn-google{background:#fff;color:#333;border:1px solid var(--border-color);box-shadow:0 1px 3px #00000014}.login-btn-google:hover{background:#f8f9fa;border-color:#dadce0;box-shadow:0 2px 8px #0000001f;transform:translateY(-1px)}.login-btn-google:active{transform:translateY(0)}.login-btn-google svg{font-size:1.125rem}.login-features{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.login-features-title{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem;text-align:center}.login-features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.login-feature{display:flex;align-items:center;gap:.5rem;padding:.625rem .75rem;background:var(--bg-tertiary);border-radius:8px;font-size:.8rem;color:var(--text-secondary)}.login-feature svg{color:var(--accent-primary);flex-shrink:0}.login-footer{text-align:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.login-footer-text{font-size:.8rem;color:var(--text-muted);margin:0;display:flex;align-items:center;justify-content:center;gap:.5rem}.login-footer-text svg{color:#10b981}.login-brand{text-align:center;margin-top:1.5rem}.login-brand-name{font-size:1.25rem;font-weight:700;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@media(max-width:480px){.login-page{padding:1rem}.login-card{padding:2rem 1.5rem}.login-title{font-size:1.5rem}.login-features-grid{grid-template-columns:1fr}}.confirm-modal{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:2rem;z-index:70}.confirm-modal-content{width:min(520px,100%);border-radius:16px;border:1px solid var(--border);background:var(--bg-elevated);box-shadow:0 24px 48px #0006;padding:2rem}.confirm-header h3{margin:0 0 .75rem;color:var(--text-primary);font-size:1.3rem}.confirm-message{margin:0 0 1.25rem;color:var(--text-muted);line-height:1.5}.confirm-error{margin-bottom:1rem;padding:.75rem 1rem;border-radius:10px;border:1px solid rgba(239,68,68,.4);color:#fca5a5;background:#ef444414;font-size:.9rem}.confirm-actions{display:flex;justify-content:flex-end;gap:.75rem}.btn-secondary{height:48px;padding:0 22px;border-radius:12px;border:1px solid var(--border);background:transparent;color:var(--text-primary);font-weight:600;cursor:pointer}.btn-primary.danger{background:linear-gradient(135deg,#ef4444,#b91c1c);box-shadow:0 10px 20px -5px #ef444466}.btn-primary.danger:hover{filter:brightness(1.05)}.machine-form{padding:2.5rem;width:100%;border-radius:18px;background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--glass-shadow);display:flex;flex-direction:column}.form-header{margin-bottom:2rem}.form-title{margin:0 0 .4rem;font-size:1.6rem;font-weight:700;color:var(--text-primary)}.form-subtitle{margin:0;color:var(--text-muted);font-size:.9rem}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem}.full-width{grid-column:1 / -1}.input-group-modern{display:flex;flex-direction:column;gap:8px}.input-label{font-size:.85rem;font-weight:600;color:var(--text-muted)}.machine-form input,.machine-form select,.machine-form textarea{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:12px;padding:0 14px;color:var(--text-main);font-size:.95rem;transition:border .2s ease,box-shadow .2s ease}.machine-form input,.machine-form select{height:48px}.machine-form textarea{padding:12px 14px;resize:vertical}.machine-form input:focus,.machine-form select:focus,.machine-form textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow);outline:none}.machine-form input::placeholder,.machine-form textarea::placeholder{color:#ffffff40}.input-helper{font-size:.75rem;color:var(--text-muted)}.auth-section{background:#ffffff08;padding:1.5rem;border-radius:16px;border:1px solid var(--border);margin-top:.5rem}.toggle-container{display:flex;background:var(--bg-input);padding:4px;border-radius:12px;border:1px solid var(--border)}.toggle-btn{flex:1;padding:10px;border-radius:8px;border:none;background:transparent;color:var(--text-muted);font-weight:600;cursor:pointer;transition:all .2s ease}.toggle-btn.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px var(--primary-glow)}.code-input-wrapper{border-radius:12px;overflow:hidden;border:1px solid var(--border);background:var(--bg-code)}.code-input-wrapper:focus-within{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow)}.code-input{width:100%;min-height:220px;background:transparent;border:none;color:var(--primary);font-family:var(--font-mono);font-size:.9rem;line-height:1.6;padding:1.2rem;resize:vertical;outline:none}.form-actions{margin-top:2rem;display:flex;justify-content:flex-end;gap:.75rem;position:sticky;bottom:0;padding-top:1rem;background:linear-gradient(180deg,#17171700,#171717f2 30%,#171717f2)}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--accent));padding:0 28px;height:48px;border-radius:12px;font-weight:600;font-size:.95rem;color:#fff;border:none;cursor:pointer;transition:all .2s ease;box-shadow:0 10px 20px -5px var(--primary-glow)}.btn-primary:hover{transform:translateY(-1px)}.btn-primary:disabled{opacity:.7;cursor:wait}.btn-secondary{height:48px;padding:0 22px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:transparent;color:var(--text-primary);font-weight:600;cursor:pointer}.btn-secondary:hover{border-color:#10a37f99;color:var(--primary)}@media(max-width:720px){.machine-form{padding:1.25rem}.form-grid{grid-template-columns:1fr;gap:1rem}.form-title{font-size:1.4rem}.machine-form input,.machine-form select{min-height:44px;height:44px;font-size:1rem}.machine-form textarea{min-height:100px;font-size:1rem}.form-actions{gap:.5rem}.btn-primary,.btn-secondary{height:44px;min-height:44px;flex:1;font-size:.95rem}}@media(max-width:600px){.machine-form{padding:1rem;border-radius:14px}.form-header{margin-bottom:1.5rem}.form-title{font-size:1.3rem;margin-bottom:.3rem}.form-subtitle{font-size:.85rem}.input-group-modern{gap:6px}.input-label{font-size:.85rem}.machine-form input,.machine-form select,.machine-form textarea{border-radius:10px;padding:0 12px}.machine-form input,.machine-form select{min-height:44px}.auth-section{padding:1rem;margin-top:.4rem}.toggle-container{border-radius:10px}.toggle-btn{padding:8px;font-size:.9rem}.code-input{font-size:.85rem;padding:1rem;min-height:180px}.form-actions{margin-top:1.5rem;gap:.375rem}.btn-primary,.btn-secondary{height:44px;padding:0 12px;font-size:.9rem}}@media(max-width:480px){.machine-form{padding:.875rem}.form-header{margin-bottom:1.25rem}.form-title{font-size:1.2rem}.form-subtitle{font-size:.8rem}.machine-form input,.machine-form select,.machine-form textarea{font-size:1rem}.input-helper{font-size:.7rem}.code-input{min-height:150px;font-size:.8rem}.form-actions{flex-wrap:wrap}.btn-primary,.btn-secondary{flex:1 1 48%;min-width:100px}}@media(max-width:375px){.machine-form{padding:.75rem;border-radius:12px}.form-title{font-size:1.1rem}.form-grid{gap:.75rem}.input-label{font-size:.8rem}.machine-form input,.machine-form select{padding:0 10px;height:40px}.auth-section{padding:.75rem;border-radius:8px}.code-input{padding:.75rem;min-height:130px;font-size:.75rem}.btn-primary,.btn-secondary{height:40px;font-size:.85rem;padding:0 8px}}.toast-stack{position:fixed;right:24px;bottom:24px;display:flex;flex-direction:column;gap:12px;z-index:90;max-width:min(360px,90vw)}.toast{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);box-shadow:0 16px 30px #00000059;font-size:.9rem}.toast span{flex:1;line-height:1.4}.toast-close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:8px;transition:color .2s ease,background .2s ease}.toast-close:hover{color:var(--text-primary);background:#ffffff14}.toast-info{border-left:4px solid var(--primary)}.toast-success{border-left:4px solid var(--status-success)}.toast-warning{border-left:4px solid var(--status-warning)}.toast-error{border-left:4px solid var(--status-danger)}@media(max-width:720px){.toast-stack{left:16px;right:16px;bottom:16px}}.machines-page{max-width:1400px;margin:0 auto;padding:2rem 1.5rem 3rem}.machines-toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;min-height:44px}.toolbar-left{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.title-group{display:flex;flex-direction:column;gap:.2rem}.title-group h2{margin:0;font-size:1.8rem;font-weight:700}.count-pill{font-size:.8rem;color:var(--text-muted)}.toolbar-search{display:flex;align-items:center;gap:.5rem;min-height:44px;height:44px;padding:0 12px;border-radius:10px;border:1px solid var(--border);background:var(--bg-input);color:var(--text-muted);flex:1;min-width:0}.toolbar-search input{background:transparent;border:none;color:var(--text-primary);font-size:.95rem;width:100%;min-width:0}.toolbar-filter{display:flex;align-items:center;gap:.5rem;padding:0 12px;min-height:44px;height:44px;border-radius:10px;border:1px solid var(--border);background:var(--bg-input);color:var(--text-muted)}.toolbar-filter select{background:transparent;border:none;color:var(--text-primary);font-size:.95rem;outline:none;cursor:pointer}.toolbar-right{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.filter-toggle,.quick-btn{display:inline-flex;align-items:center;gap:.4rem;padding:8px 12px;border-radius:10px;border:1px solid var(--border);background:transparent;color:var(--text-primary);cursor:pointer;min-height:44px;font-size:.95rem}.quick-btn span{font-size:.75rem;color:var(--text-muted)}.view-toggle{display:inline-flex;border-radius:10px;border:1px solid var(--border);overflow:hidden;height:44px}.view-toggle button{background:transparent;border:none;padding:8px 16px;color:var(--text-muted);cursor:pointer;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;font-size:1rem}.view-toggle button.active{background:#10a37f33;color:var(--primary)}.btn-primary{display:inline-flex;align-items:center;gap:.5rem;padding:10px 16px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--accent));border:none;color:#fff;font-weight:600;cursor:pointer;box-shadow:0 10px 24px -8px var(--primary-glow);min-height:44px;font-size:.95rem}.machines-layout{display:grid;grid-template-columns:260px 1fr;gap:1.5rem}.machines-filters{padding:1.25rem;border-radius:14px;border:1px solid var(--border);background:var(--bg-card);height:fit-content}.filters-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.filters-header h4{margin:0;font-size:1rem}.filters-header button{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:.85rem}.filter-section{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.filter-section h5{margin:0 0 .4rem;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.filter-option{display:flex;align-items:center;gap:.5rem;color:var(--text-primary);font-size:.9rem}.filter-empty{font-size:.85rem;color:var(--text-muted)}.tag-folder-header{display:flex;justify-content:space-between;align-items:center}.tag-hint{font-size:.7rem;color:var(--text-muted)}.tag-folder-list{display:flex;flex-direction:column;gap:.75rem}.tag-folder{border:1px dashed var(--border);border-radius:12px;padding:.6rem;background:var(--bg-card)}.tag-folder.system{border-style:solid}.tag-folder-title{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-primary);margin-bottom:.5rem}.tag-folder-title svg{color:var(--text-muted)}.folder-actions{margin-left:auto;display:flex;gap:.4rem}.folder-actions button{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:.75rem}.folder-edit{display:flex;gap:.4rem;flex:1}.folder-edit input{flex:1;border-radius:6px;border:1px solid var(--border);background:var(--bg-input);color:var(--text-primary);padding:4px 6px}.folder-edit button{background:#10a37f26;border:none;border-radius:6px;color:var(--primary);padding:4px 8px;cursor:pointer;font-size:.75rem}.tag-folder-tags{display:flex;flex-wrap:wrap;gap:.4rem}.tag-folder-create{display:flex;gap:.5rem;margin-top:.75rem}.tag-folder-create input{flex:1;height:34px;border-radius:8px;padding:0 10px;border:1px solid var(--border);background:var(--bg-input);color:var(--text-primary)}.tag-folder-create button{width:36px;height:34px;border-radius:8px;border:none;background:#10a37f33;color:var(--primary);cursor:pointer}.machines-list{display:flex;flex-direction:column;gap:1.5rem}.bulk-bar{padding:1rem;border-radius:12px;border:1px solid var(--border);background:var(--bg-card);display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.bulk-info{display:flex;align-items:center;gap:.75rem}.bulk-info button{background:transparent;border:none;color:var(--text-muted);cursor:pointer}.bulk-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.bulk-actions input{height:38px;border-radius:8px;padding:0 12px;background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary)}.bulk-actions input:disabled{opacity:.6;cursor:not-allowed}.bulk-btn{padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text-primary);cursor:pointer}.bulk-btn:disabled{opacity:.6;cursor:not-allowed}.bulk-btn.danger{border-color:#ef444466;color:var(--status-danger)}.bulk-error{margin-top:.5rem;color:#fca5a5;font-size:.85rem}.select-all-row{display:flex;align-items:center;gap:.5rem;color:var(--text-muted)}.machine-group{display:flex;flex-direction:column;gap:.75rem}.group-header{display:flex;align-items:center;justify-content:space-between;text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;color:var(--text-muted)}.machine-table{display:flex;flex-direction:column;gap:.5rem}.machine-table.virtualized{gap:0;position:relative}.machine-row-wrap{padding-bottom:.5rem}.machine-group-wrap{padding:.75rem 0 .5rem}.machine-row{display:grid;grid-template-columns:40px 1.6fr .8fr 1fr;gap:1rem;align-items:center;padding:.9rem 1rem;border-radius:12px;border:1px solid var(--border);background:var(--bg-card);position:relative;transition:border .2s ease,background .2s ease}.machine-row:hover:not(.menu-open){border-color:#10a37f66;background:var(--bg-card-hover)}.machine-row.menu-open{border-color:var(--border)}.machine-row.selected{border-color:#10a37f99;box-shadow:0 0 0 1px #10a37f4d}.row-select{display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px}.row-select input{width:20px;height:20px;cursor:pointer}.row-main{display:flex;flex-direction:column;gap:.4rem}.row-title{display:flex;align-items:center;gap:.8rem;background:transparent;border:none;color:inherit;padding:0;cursor:pointer;text-align:left}.machine-name{font-weight:600;font-size:1rem}.machine-host{color:var(--text-muted);font-size:.85rem}.row-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;font-size:.8rem;color:var(--text-muted)}.tag-list{display:flex;gap:.4rem;flex-wrap:wrap}.tag-chip{padding:2px 8px;border-radius:999px;border:1px solid rgba(16,163,127,.35);color:var(--primary);font-size:.7rem;background:#10a37f1a;cursor:pointer}.tag-chip.selected{background:#10a37f4d;color:#fff}.row-info{display:flex;flex-direction:column;gap:.4rem;font-size:.8rem;color:var(--text-muted);align-items:center;text-align:center}.status-pill{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em}.status-pill.online{background:#22c55e26;color:var(--status-success)}.status-pill.offline{background:#94a3b826;color:var(--text-muted)}.status-pill.unknown{background:#f59e0b26;color:var(--status-warning)}.row-actions{display:flex;align-items:center;gap:.5rem;justify-content:flex-end;flex-wrap:wrap;position:relative}.connect-btn{display:inline-flex;align-items:center;gap:.4rem;padding:8px 14px;border-radius:8px;border:1px solid rgba(16,163,127,.3);background:#10a37f1f;color:var(--primary);font-weight:600;cursor:pointer;transition:all .15s ease;min-height:44px;font-size:.95rem}.connect-btn:hover:not(:disabled){background:#10a37f33;border-color:#10a37f80}.connect-btn:disabled{opacity:.6;cursor:not-allowed}.icon-btn{min-width:44px;min-height:44px;width:44px;height:44px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text-muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s ease;font-size:1rem}.icon-btn:hover{background:#ffffff0a;color:var(--text-primary);border-color:#ffffff26}.icon-btn.danger{border-color:#ef444459;color:var(--status-danger)}.icon-btn.danger:hover{background:#ef44441a}.action-btn{padding:6px 10px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text-primary);cursor:pointer}.action-btn.ghost{color:var(--text-muted)}.machine-menu{position:fixed;background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;padding:6px;display:flex;flex-direction:column;gap:2px;min-width:180px;z-index:1000;box-shadow:0 8px 24px #0006}.machine-menu button{background:transparent;border:none;color:var(--text-primary);text-align:left;padding:10px 12px;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:0;font-size:.9rem;transition:background .15s ease}.machine-menu button:hover{background:#ffffff0f}.machine-menu button.danger{color:var(--status-danger)}.machine-menu button.danger:hover{background:#ef44441a}.copy-toast{position:absolute;top:-12px;right:16px;background:#22c55e33;color:var(--status-success);padding:4px 8px;border-radius:999px;font-size:.7rem}.inline-edit{display:grid;gap:.5rem}.inline-edit input{height:38px;border-radius:8px;padding:0 10px;border:1px solid var(--border);background:var(--bg-input);color:var(--text-primary)}.machine-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.machine-card{border-radius:14px;border:1px solid var(--border);background:var(--bg-card);padding:1rem;display:flex;flex-direction:column;gap:1rem;position:relative}.machine-card.selected{border-color:#10a37f99}.card-header{display:flex;justify-content:space-between;align-items:center}.card-title{display:flex;align-items:center;gap:.5rem}.card-title h4{margin:0;font-size:1rem}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.online{background:var(--status-success)}.status-dot.offline{background:var(--text-muted)}.status-dot.unknown{background:var(--status-warning)}.card-body{display:flex;flex-direction:column;gap:.6rem;font-size:.85rem;color:var(--text-muted)}.card-row{display:flex;justify-content:space-between;gap:.5rem}.card-row .muted{color:var(--text-muted)}.card-footer{display:flex;flex-direction:column;gap:.6rem}.empty-state{border:1px dashed var(--border);border-radius:16px;padding:3rem 2rem;text-align:center;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:.8rem}.empty-state h3{margin:0;color:var(--text-primary)}.empty-example{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-muted)}.machine-modal{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:flex-start;justify-content:center;padding:2rem;z-index:50;overflow-y:auto}.machine-modal-content{width:min(860px,100%);max-height:calc(100vh - 4rem);overflow-y:auto;-webkit-overflow-scrolling:touch}.quick-modal{position:fixed;inset:0;background:#000000a6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:flex-start;justify-content:center;padding:6rem 1.5rem;z-index:60}.quick-panel{width:min(640px,100%);border-radius:16px;border:1px solid var(--border);background:var(--bg-elevated);box-shadow:0 20px 40px #00000073;overflow:hidden}.quick-input{display:flex;align-items:center;gap:.6rem;padding:.9rem 1rem;border-bottom:1px solid var(--border);color:var(--text-muted)}.quick-input input{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:1rem}.quick-hint{font-size:.7rem;color:var(--text-muted)}.quick-results{display:flex;flex-direction:column;gap:.2rem;max-height:320px;overflow:auto}.quick-item{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1rem;background:transparent;border:none;color:var(--text-primary);text-align:left;cursor:pointer}.quick-item span{color:var(--text-muted);font-size:.8rem}.quick-item.active,.quick-item:hover{background:#10a37f26}.quick-empty{padding:1.5rem;text-align:center;color:var(--text-muted)}@media(max-width:1100px){.machines-layout{grid-template-columns:1fr}}@media(max-width:900px){.machine-row{grid-template-columns:32px 1fr;gap:.8rem}.row-info,.row-actions{grid-column:1 / -1;justify-content:flex-start}}@media(max-width:900px){.toolbar-right{flex-basis:100%;width:100%;gap:.5rem}.quick-btn span:last-child{display:none}}@media(max-width:768px){.machines-page{padding:1.5rem 1rem 2.5rem}.machines-toolbar{flex-direction:column;gap:.75rem}.toolbar-left{width:100%;flex-direction:column;gap:.75rem}.title-group h2{font-size:1.5rem}.toolbar-search,.toolbar-filter{width:100%;height:44px}.toolbar-right{width:100%;gap:.5rem;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.machines-layout{grid-template-columns:1fr}.machines-filters{display:none}.machine-row{grid-template-columns:44px 1fr;gap:.75rem;padding:.75rem}.machine-row.menu-open{border-color:#10a37f80}.row-info{grid-column:2;flex-direction:row;gap:.75rem;justify-content:flex-start;align-items:center;text-align:left;font-size:.85rem;margin-top:.25rem}.row-actions{grid-column:2;justify-content:flex-start;gap:.5rem;margin-top:.5rem}.connect-btn{padding:8px 12px}.machine-menu{position:fixed;min-width:160px}.machine-grid{grid-template-columns:1fr}.machine-card{border-radius:10px}.select-all-row{font-size:.95rem}.bulk-bar{flex-direction:column;gap:.75rem;padding:.75rem}.bulk-info{width:100%;justify-content:space-between}.bulk-actions{width:100%;flex-direction:column;gap:.5rem}.bulk-actions input{width:100%;height:44px}.bulk-btn{width:100%;height:44px;padding:10px}.quick-modal{padding:2rem 1rem}.quick-panel{width:100%}.machine-modal{padding:1rem}.machine-modal-content{width:100%}}@media(max-width:600px){.machines-page{padding:1rem .75rem 2rem}.title-group h2{font-size:1.3rem}.toolbar-search input{font-size:1rem}.filter-toggle{width:100%;justify-content:center}.quick-btn{flex:1;justify-content:center}.machine-row{grid-template-columns:44px 1fr;gap:.5rem;padding:.5rem}.machine-name{font-size:.95rem;font-weight:600}.machine-host{font-size:.8rem}.row-meta{font-size:.8rem;gap:.5rem}.tag-chip{font-size:.7rem;padding:2px 6px}.status-pill{font-size:.7rem;padding:3px 8px}.row-title{font-size:.95rem}.inline-edit{grid-template-columns:1fr;gap:.4rem}.inline-edit input{height:44px;font-size:1rem}.connect-btn{flex:1;justify-content:center;min-height:44px;padding:8px}.quick-item{padding:.75rem;font-size:.9rem}}@media(max-width:480px){.machines-page{padding:.75rem .5rem 1.5rem}.title-group{margin-bottom:.75rem}.title-group h2{font-size:1.2rem;margin-bottom:.25rem}.count-pill{font-size:.75rem}.toolbar-search{height:44px}.filter-toggle span,.quick-btn span{display:none}.filter-toggle,.quick-btn{width:44px;padding:0;justify-content:center}.view-toggle button{padding:8px 12px;font-size:.9rem}.machine-row{padding:.5rem}.row-select{min-width:40px}.row-select input{width:18px;height:18px}.icon-btn{min-width:40px;min-height:40px;width:40px;height:40px}.group-header{padding:.5rem 0;font-size:.7rem}.empty-state{padding:2rem 1rem}.empty-state h3{font-size:1.1rem}.empty-state p,.filter-option{font-size:.9rem}.filter-section h5{font-size:.75rem}.tag-folder{padding:.5rem}.tag-folder-title{font-size:.8rem}}@media(max-width:375px){.machines-page{padding:.5rem .375rem 1.25rem}.title-group h2{font-size:1.1rem}.toolbar-search{height:42px}.toolbar-search input{font-size:1rem}.machine-row{gap:.375rem;padding:.375rem}.machine-name{font-size:.9rem}.machine-host{font-size:.75rem}.connect-btn{font-size:.85rem;padding:6px 8px}.icon-btn{min-width:36px;min-height:36px;width:36px;height:36px;font-size:.85rem}.btn-primary{font-size:.9rem;padding:8px 12px}.tag-chip{font-size:.65rem}}.profile-page{--profile-bg: var(--bg-dark);--profile-panel: var(--bg-card);--profile-panel-soft: var(--bg-elevated);--profile-border: var(--border);--profile-text: var(--text-main);--profile-muted: var(--text-muted);--profile-accent: var(--primary);--profile-accent-soft: rgba(16, 163, 127, .16);--profile-danger: var(--status-danger);--profile-danger-soft: rgba(239, 68, 68, .18);--profile-shadow: 0 24px 60px rgba(0, 0, 0, .35);padding:2rem;max-width:1120px;margin:0 auto;color:var(--profile-text);font-family:var(--font-sans)}.profile-shell{background:radial-gradient(circle at top left,rgba(16,163,127,.08),transparent 45%),radial-gradient(circle at 80% 10%,rgba(16,163,127,.05),transparent 40%),var(--profile-bg);border:1px solid var(--profile-border);border-radius:18px;padding:1.5rem;box-shadow:var(--profile-shadow);position:relative;overflow:hidden}.profile-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;margin-bottom:1.5rem}.profile-eyebrow{display:inline-block;font-size:.7rem;text-transform:uppercase;letter-spacing:.18em;color:var(--profile-muted);margin-bottom:.3rem}.profile-title{font-size:1.5rem;font-weight:700;margin:0 0 .3rem}.profile-subtitle{color:var(--profile-muted);font-size:.85rem;margin:0;max-width:400px;line-height:1.5}.profile-header-actions{display:flex;gap:.75rem;flex-wrap:wrap}.profile-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:10px;border:1px solid var(--profile-border);background:transparent;color:var(--profile-text);font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s ease}.profile-btn svg{font-size:.9rem;color:var(--profile-muted)}.profile-btn:hover{background:var(--profile-panel-soft);border-color:#fff3}.profile-btn-ghost{background:transparent}.profile-btn-primary{background:linear-gradient(135deg,#10a37f,#0f766e);border:none;color:#fff;box-shadow:0 12px 24px #10a37f40}.profile-btn-primary svg{color:#fff}.profile-btn-primary:hover{filter:brightness(1.05)}.profile-btn:disabled{opacity:.6;cursor:not-allowed}.profile-btn-danger{border-color:#ef444466;color:#fecaca}.profile-btn-danger svg{color:#f87171}.profile-btn-danger:hover{background:var(--profile-danger-soft);border-color:#ef444499}.profile-hero{display:grid;grid-template-columns:minmax(240px,1fr) minmax(240px,1fr);gap:1rem;margin-bottom:1rem}.profile-login{display:grid;grid-template-columns:minmax(240px,1fr) minmax(220px,.9fr);gap:1.5rem;align-items:center}.profile-login-actions{margin-top:1rem;display:flex;flex-direction:column;gap:.6rem}.profile-login-note{display:inline-flex;align-items:center;gap:.4rem;color:var(--profile-muted);font-size:.75rem}.profile-login-card{background:var(--profile-panel);border:1px solid var(--profile-border);border-radius:14px;padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;text-align:left}.profile-login-card h2{margin:0;font-size:1.1rem;font-weight:600}.profile-login-card p{margin:0;color:var(--profile-muted);font-size:.8rem;line-height:1.5}.profile-login-icon{width:48px;height:48px;border-radius:12px;background:#10a37f1f;border:1px solid rgba(16,163,127,.4);display:grid;place-items:center;color:var(--profile-accent)}.profile-login-icon svg{font-size:1.2rem}.profile-login-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.2rem}.profile-login-chip{font-size:.68rem;padding:3px 8px;border-radius:999px;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);color:var(--profile-muted)}.profile-card{background:var(--profile-panel);border:1px solid var(--profile-border);border-radius:14px;padding:1.25rem;box-shadow:inset 0 1px #ffffff08}.profile-card-header{display:flex;align-items:flex-start;gap:.6rem;margin-bottom:.75rem}.profile-card-header svg{color:var(--profile-accent);font-size:1rem}.profile-card-header h3{margin:0;font-size:.95rem;font-weight:600}.profile-card-header p{margin:.2rem 0 0;color:var(--profile-muted);font-size:.75rem;line-height:1.4}.profile-identity{display:flex;gap:1rem;align-items:center}.profile-avatar{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(140deg,#10a37f2e,#10a37f0a);border:1px solid rgba(16,163,127,.35);color:var(--profile-accent);flex-shrink:0}.profile-avatar svg{font-size:1.4rem}.profile-avatar img{width:100%;height:100%;border-radius:12px;object-fit:cover}.profile-identity-text h2{margin:0 0 .2rem;font-size:1rem;font-weight:700}.profile-identity-text p{margin:0;color:var(--profile-muted);font-size:.8rem}.profile-badges{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.profile-badge{font-size:.68rem;padding:3px 8px;border-radius:999px;background:#10a37f1f;color:var(--profile-accent);border:1px solid rgba(16,163,127,.3);text-transform:uppercase;letter-spacing:.08em}.profile-meta-grid{margin-top:1rem;padding-top:.75rem;border-top:1px dashed rgba(255,255,255,.08);display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.profile-meta-item{display:flex;flex-direction:column;gap:.2rem}.profile-meta-label{color:var(--profile-muted);font-size:.65rem;text-transform:uppercase;letter-spacing:.12em}.profile-meta-value{font-weight:600;color:var(--profile-text);font-size:.8rem}.profile-stats-grid{display:grid;gap:.75rem}.profile-stat{padding:.75rem;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:var(--profile-panel-soft);display:flex;flex-direction:column;gap:.2rem}.profile-stat-value{font-size:1.2rem;font-weight:700;color:var(--profile-accent)}.profile-stat-label{font-size:.8rem;font-weight:600}.profile-stat-meta{color:var(--profile-muted);font-size:.7rem}.profile-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.profile-kv-list{display:grid;gap:.5rem}.profile-kv-row{display:flex;justify-content:space-between;gap:1rem}.profile-kv-label{color:var(--profile-muted);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em}.profile-kv-value{color:var(--profile-text);font-weight:600;text-align:right;max-width:220px;font-size:.85rem}.profile-session-list{list-style:none;padding:0;margin:.75rem 0 0;display:grid;gap:.5rem}.profile-session-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.5rem .75rem;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:var(--profile-panel-soft)}.profile-session-title{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem}.profile-session-title svg{color:var(--profile-accent);font-size:.8rem}.profile-session-time{color:var(--profile-muted);font-size:.7rem}.profile-session-empty{color:var(--profile-muted);font-size:.85rem}.profile-card-actions{margin-top:1rem;display:flex;justify-content:flex-end}.profile-preferences-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.6rem}.profile-preference{background:var(--profile-panel-soft);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:.6rem .75rem;display:flex;flex-direction:column;gap:.2rem;color:var(--profile-muted)}.profile-preference strong{color:var(--profile-text);font-size:.8rem}@media(max-width:1024px){.profile-hero,.profile-login{grid-template-columns:1fr}}@media(max-width:860px){.profile-header{flex-direction:column;align-items:flex-start}.profile-grid{grid-template-columns:1fr}}@media(max-width:640px){.profile-page{padding:1rem}.profile-shell{padding:1.25rem;border-radius:16px}.profile-identity{flex-direction:column;align-items:flex-start;gap:1rem}.profile-avatar{width:72px;height:72px;font-size:1.5rem}.profile-meta h2{font-size:1.4rem}.profile-kv-row{flex-direction:column;align-items:flex-start;gap:.75rem}.profile-kv-label{font-size:.9rem}.profile-kv-value{text-align:left;font-size:.95rem}.profile-action{width:100%;min-height:44px}.profile-section{margin-bottom:1.5rem}.profile-fields{gap:.75rem}}@media(max-width:480px){.profile-page{padding:.75rem}.profile-shell{padding:1rem}.profile-avatar{width:60px;height:60px}.profile-meta h2{font-size:1.2rem}.profile-action{min-height:44px;padding:10px;font-size:.95rem}.profile-fields input,.profile-fields textarea{min-height:44px;font-size:1rem}}@media(max-width:375px){.profile-page{padding:.5rem}.profile-shell{padding:.875rem}.profile-avatar{width:52px;height:52px}.profile-meta h2{font-size:1.1rem}.profile-section-title{font-size:.95rem}input,textarea{font-size:1rem}}.recordings-page{padding:24px;max-width:1200px;margin:0 auto}.recordings-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.recordings-header h1{font-size:24px;font-weight:600;color:var(--text);margin:0}.recordings-count{font-size:14px;color:var(--text-muted);background:var(--bg-hover);padding:4px 12px;border-radius:12px}.recordings-loading,.recordings-error{text-align:center;padding:48px;color:var(--text-muted)}.recordings-error p{margin-bottom:16px;color:var(--danger)}.btn-retry{background:var(--primary);color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;transition:opacity .15s}.btn-retry:hover{opacity:.9}.recordings-empty{text-align:center;padding:64px 24px;color:var(--text-muted)}.recordings-empty .empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.recordings-empty p{font-size:18px;margin-bottom:8px;color:var(--text)}.recordings-empty span{font-size:14px}.recordings-list{display:flex;flex-direction:column;gap:12px}.recording-card{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-radius:12px;transition:transform .15s,box-shadow .15s;gap:24px}.recording-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.recording-info{flex:1;min-width:0}.recording-machine{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:500;color:var(--text);margin-bottom:6px}.recording-machine .icon{color:var(--primary);flex-shrink:0}.recording-machine span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recording-meta{display:flex;align-items:center;flex-wrap:wrap;gap:20px;font-size:13px;color:var(--text-muted)}.recording-meta .icon{margin-right:4px}.recording-date{display:flex;align-items:center}.recording-actions{display:flex;gap:8px}.recording-actions button{width:36px;height:36px;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.recording-actions button:hover:not(:disabled){background:var(--bg-hover)}.recording-actions .btn-play:hover{color:var(--success);border-color:var(--success)}.recording-actions .btn-download:hover{color:var(--primary);border-color:var(--primary)}.recording-actions .btn-delete:hover{color:var(--danger);border-color:var(--danger)}.recording-actions button:disabled{opacity:.5;cursor:not-allowed}.recordings-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:24px;padding-top:24px;border-top:1px solid var(--border)}.btn-page{background:var(--bg-card);border:1px solid var(--border);color:var(--text);padding:8px 16px;border-radius:6px;cursor:pointer;transition:all .15s}.btn-page:hover:not(:disabled){background:var(--bg-hover);border-color:var(--primary)}.btn-page:disabled{opacity:.5;cursor:not-allowed}.page-info{font-size:14px;color:var(--text-muted)}.player-modal{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.player-container{background:var(--bg-card);border-radius:12px;max-width:1200px;width:95%;height:80vh;overflow:visible;display:flex;flex-direction:column}.player-header{display:flex;align-items:center;gap:16px;padding:16px 20px;border-bottom:1px solid var(--border)}.player-header h3{margin:0;font-size:16px;font-weight:500;color:var(--text)}.player-header span{font-size:13px;color:var(--text-muted)}.player-header .btn-close{margin-left:auto;background:none;border:none;font-size:24px;color:var(--text-muted);cursor:pointer;padding:0;line-height:1;transition:color .15s}.player-header .btn-close:hover{color:var(--text)}.player-body{flex:1;display:flex;flex-direction:column;background:#121314;min-height:500px;position:relative}.player-body:fullscreen{background:#121314}.asciinema-player-area{flex:1;min-height:400px;padding:16px}.asciinema-player-area>div{width:100%!important;height:100%!important}.asciinema-player-area div[class*=control-bar],.asciinema-player-area .ap-control-bar{display:none!important}.player-controls{display:flex;align-items:center;justify-content:center;gap:16px;padding:16px;background:#1e1e1ef2;border-top:1px solid var(--border);z-index:100}.player-body:fullscreen .player-controls{position:absolute;bottom:0;left:0;right:0}.btn-control{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;border-radius:50%;background:var(--primary);color:#fff;cursor:pointer;transition:all .15s;font-size:16px}.btn-control:hover{background:var(--primary-hover);transform:scale(1.1)}.btn-control:active{transform:scale(.95)}@media(max-width:768px){.recordings-page{padding:1.5rem}.recordings-header{flex-direction:column;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.recordings-header h1{font-size:1.5rem}.recordings-count{font-size:.9rem;padding:6px 10px}.recordings-list{gap:1rem}.recording-card{padding:1rem;border-radius:10px;gap:1rem}.recording-preview{min-width:100%;max-width:none;width:100%;aspect-ratio:16 / 9}.recording-info{flex:1}.recording-actions{width:100%;gap:.5rem}.recording-action{flex:1;min-height:40px;font-size:.9rem;padding:8px}.btn-retry{min-height:44px;padding:10px 16px}}@media(max-width:600px){.recordings-page{padding:1rem}.recordings-header h1{font-size:1.3rem}.recording-card{padding:.875rem;flex-direction:column}.recording-title{font-size:1rem}.recording-session{font-size:.9rem}.recording-date,.recording-duration,.recording-size{font-size:.85rem}.recording-action{min-height:40px;font-size:.85rem}.btn-control{min-width:40px;min-height:40px;width:40px;height:40px}}@media(max-width:480px){.recordings-page{padding:.75rem}.recordings-header h1{font-size:1.2rem}.recordings-empty{padding:2rem 1rem}.recordings-empty .empty-icon{font-size:2.5rem;margin-bottom:1rem}.recordings-empty p{font-size:1.05rem}.recordings-empty span{font-size:.9rem}.recording-card{padding:.75rem;gap:.75rem}.recording-title{font-size:.95rem;font-weight:600}.recording-session{font-size:.85rem}.recording-date,.recording-duration,.recording-size{font-size:.8rem}.recording-action{min-height:36px;font-size:.8rem;padding:6px}.btn-control{min-width:36px;min-height:36px}.btn-retry{min-height:40px;padding:8px 12px;font-size:.9rem}}@media(max-width:375px){.recordings-page{padding:.5rem}.recordings-header h1{font-size:1.1rem}.recording-card{padding:.65rem;gap:.5rem}.recording-title{font-size:.9rem}.recording-session{font-size:.8rem}.recording-date,.recording-duration,.recording-size{font-size:.75rem}.recording-action{min-height:32px;font-size:.75rem}.btn-control{min-width:32px;min-height:32px}}.sessions-page{max-width:1200px;margin:0 auto;padding:2rem 1.5rem 3rem}.sessions-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem 2rem;color:var(--text-muted)}.sessions-header{margin-bottom:2rem}.header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.header-title h1{margin:0 0 .5rem;font-size:1.75rem;font-weight:700;color:var(--text-main)}.header-stats{display:flex;gap:.5rem}.stat-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:500;background:#10a37f1f;color:var(--primary);border:1px solid rgba(16,163,127,.2)}.stat-badge.secondary{background:#64748b1a;color:var(--text-muted);border-color:var(--border)}.header-actions{display:flex;align-items:center;gap:.75rem}.btn-icon{width:36px;height:36px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s ease}.btn-icon:hover{border-color:var(--primary);color:var(--primary)}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.status-indicator{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:#22c55e1a;color:#22c55e;border:1px solid rgba(34,197,94,.2)}.status-indicator.error{background:#ef44441a;color:#ef4444;border-color:#ef444433}.status-dot{width:6px;height:6px;border-radius:50%;background:currentColor;animation:pulse 2s ease-in-out infinite}.status-indicator.error .status-dot{animation:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.header-search{display:flex;align-items:center;gap:.75rem;padding:0 1rem;height:44px;border-radius:12px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);transition:border-color .15s ease}.header-search:focus-within{border-color:var(--primary)}.header-search input{flex:1;background:transparent;border:none;color:var(--text-main);font-size:.9rem;outline:none}.header-search input::placeholder{color:var(--text-muted)}.search-clear{width:20px;height:20px;border-radius:50%;border:none;background:var(--border);color:var(--text-muted);cursor:pointer;font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center}.search-clear:hover{background:var(--text-muted);color:var(--bg-card)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;border-radius:16px;background:var(--bg-card);border:1px dashed var(--border)}.empty-icon{width:80px;height:80px;border-radius:50%;background:#10a37f1a;color:var(--primary);display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem}.empty-state h2{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:var(--text-main)}.empty-state p{margin:0 0 1.5rem;color:var(--text-muted);font-size:.9rem}.btn-primary{display:inline-flex;align-items:center;gap:.5rem;padding:10px 20px;border-radius:10px;border:none;background:var(--primary);color:#fff;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .15s ease}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.sessions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.machine-group{border-radius:14px;border:1px solid var(--border);background:var(--bg-card);overflow:hidden}.group-header{display:flex;align-items:center;gap:.75rem;width:100%;padding:1rem 1.25rem;border:none;background:transparent;color:var(--text-main);cursor:pointer;text-align:left;transition:background .15s ease}.group-header:hover{background:#ffffff05}.group-toggle{color:var(--text-muted);width:16px;display:flex;align-items:center;justify-content:center}.group-icon{color:var(--primary);font-size:1rem}.group-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.group-name{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-env{font-size:.7rem;color:var(--text-muted);text-transform:capitalize}.group-count{font-size:.7rem;color:var(--text-muted);padding:3px 8px;border-radius:999px;background:#ffffff0d;white-space:nowrap}.group-sessions{padding:0 .75rem .75rem}.session-card{display:flex;flex-direction:column;padding:1rem;border-radius:10px;background:#ffffff05;border:1px solid rgba(255,255,255,.05);transition:all .15s ease}.session-card:hover{border-color:#10a37f4d;background:#10a37f08}.card-main{flex:1;margin-bottom:.75rem}.card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.session-id{font-family:var(--font-mono);font-size:.8rem;color:var(--text-main);font-weight:500}.recording-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border-radius:4px;font-size:.65rem;font-weight:600;text-transform:uppercase;background:#ef444426;color:#ef4444;animation:rec-pulse 1.5s ease-in-out infinite}@keyframes rec-pulse{0%,to{opacity:1}50%{opacity:.6}}.card-details{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.35rem}.detail{font-size:.8rem;color:var(--text-main);font-family:var(--font-mono)}.detail.muted{color:var(--text-muted)}.card-meta{font-size:.75rem;color:var(--text-muted)}.card-actions{display:flex;gap:.5rem}.action-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:8px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-muted);cursor:pointer;font-size:.8rem;transition:all .15s ease}.action-btn:hover{border-color:var(--text-muted);color:var(--text-main)}.action-btn.primary{background:#10a37f1f;border-color:#10a37f4d;color:var(--primary)}.action-btn.primary:hover{background:#10a37f33}.action-btn.danger{border-color:#ef44444d;color:#ef4444}.action-btn.danger:hover{background:#ef44441a}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinning{animation:spin 1s linear infinite}@media(max-width:1100px){.sessions-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.sessions-page{padding:1.5rem 1rem 2rem}.sessions-grid{grid-template-columns:1fr}.header-top{flex-direction:column;align-items:stretch;gap:1rem}.header-search input{width:100%;min-height:44px;font-size:1rem}.header-actions{justify-content:space-between;gap:.5rem}.header-actions button{min-height:44px}.session-card{padding:1rem;border-radius:10px}.card-header{gap:.75rem}.session-stat{font-size:.9rem}.session-action{padding:8px 12px;min-height:40px}.group-header{padding:.875rem 0;font-size:.85rem}}@media(max-width:600px){.sessions-page{padding:1rem}.header-title h1{font-size:1.3rem}.header-stats{flex-direction:column;gap:.5rem}.stat-item{flex:1;min-height:44px;font-size:.9rem}.session-card{padding:.875rem}.card-header{flex-direction:column;align-items:flex-start}.session-action{width:100%}}@media(max-width:480px){.sessions-page{padding:.75rem}.header-title h1{font-size:1.2rem}.header-stats{flex-wrap:wrap;gap:.375rem}.stat-item{min-height:40px;padding:.5rem .75rem;font-size:.85rem}.group-header{padding:.75rem 0;font-size:.8rem}.session-card{padding:.75rem;border-radius:8px}.session-stat{font-size:.8rem}.session-action{min-height:40px;padding:8px;font-size:.85rem}.session-info{gap:.375rem}}@media(max-width:375px){.sessions-page{padding:.5rem}.header-title h1{font-size:1.1rem}.stat-item{min-height:36px;font-size:.8rem}.session-card{padding:.65rem}.session-action{min-height:36px;font-size:.8rem}}.settings-page{--settings-bg: var(--bg-dark);--settings-panel: var(--bg-card);--settings-panel-soft: var(--bg-elevated);--settings-border: var(--border);--settings-text: var(--text-main);--settings-muted: var(--text-muted);--settings-accent: var(--primary);--settings-accent-soft: rgba(16, 163, 127, .18);--settings-danger: var(--status-danger);padding:2rem;max-width:1180px;margin:0 auto;color:var(--settings-text);font-family:var(--font-sans)}.settings-shell{background:radial-gradient(circle at 12% 0%,rgba(16,163,127,.08),transparent 45%),radial-gradient(circle at 90% 20%,rgba(16,163,127,.06),transparent 40%),var(--settings-bg);border:1px solid var(--settings-border);border-radius:24px;padding:2.5rem;box-shadow:0 24px 60px #00000059}.settings-header{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:2rem}.settings-eyebrow{display:inline-block;font-size:.75rem;text-transform:uppercase;letter-spacing:.16em;color:var(--settings-muted);margin-bottom:.5rem}.settings-title{font-size:2rem;font-weight:700;margin:0 0 .5rem}.settings-subtitle{margin:0;color:var(--settings-muted);font-size:.95rem;line-height:1.6;max-width:520px}.settings-header-actions{display:flex;align-items:center;gap:1rem}.settings-save{display:inline-flex;align-items:center;gap:8px;padding:12px 18px;border-radius:12px;border:1px solid transparent;background:linear-gradient(135deg,#10a37f,#0f766e);color:#fff;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 12px 24px #10a37f40}.settings-save.saved{background:linear-gradient(135deg,#059669,#047857);cursor:default}.settings-save:disabled{opacity:.7;cursor:default}.settings-layout{display:grid;grid-template-columns:260px 1fr;gap:1.8rem}.settings-nav{background:var(--settings-panel);border:1px solid var(--settings-border);border-radius:18px;padding:1.5rem;height:fit-content;position:sticky;top:24px}.settings-nav-title{display:block;color:var(--settings-muted);font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;margin-bottom:1rem}.settings-nav-list{display:flex;flex-direction:column;gap:.6rem}.settings-nav-item{display:flex;gap:.8rem;align-items:flex-start;padding:.85rem .9rem;border-radius:14px;background:transparent;border:1px solid transparent;color:var(--settings-muted);cursor:pointer;transition:all .2s ease;text-align:left}.settings-nav-item:hover{background:var(--settings-panel-soft);border-color:#ffffff14;color:var(--settings-text)}.settings-nav-item.active{background:var(--settings-accent-soft);border-color:#10a37f66;color:var(--settings-accent)}.settings-nav-icon{width:34px;height:34px;border-radius:10px;background:#ffffff0a;display:grid;place-items:center;color:inherit;flex-shrink:0}.settings-nav-text{display:flex;flex-direction:column;gap:4px}.settings-nav-label{font-weight:600;font-size:.95rem}.settings-nav-hint{font-size:.78rem;color:inherit;opacity:.7}.settings-content{display:flex;flex-direction:column;gap:1.5rem}.settings-error{padding:1rem 1.25rem;border-radius:12px;background:#ef444414;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.settings-section{background:var(--settings-panel);border:1px solid var(--settings-border);border-radius:18px;padding:1.75rem}.settings-section-header{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.5rem}.settings-section-icon{width:44px;height:44px;border-radius:14px;background:#10a37f1f;border:1px solid rgba(16,163,127,.4);display:grid;place-items:center;color:var(--settings-accent);font-size:1.1rem}.settings-section-header h2{margin:0 0 .3rem;font-size:1.2rem;font-weight:600}.settings-section-header p{margin:0;color:var(--settings-muted);font-size:.9rem}.settings-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:1.5rem;align-items:center;padding:1rem 0;border-bottom:1px solid rgba(255,255,255,.06)}.settings-row:last-of-type{border-bottom:none}.settings-row-info label{display:block;font-weight:600;margin-bottom:.35rem}.settings-row-info p{margin:0;font-size:.85rem;color:var(--settings-muted);line-height:1.5}.settings-row-control{display:inline-flex;align-items:center;gap:.8rem;justify-self:end}.settings-row-wide{min-width:220px}.settings-row-wide input[type=range]{flex:1}.settings-row-control input[type=number]{width:90px;padding:10px 12px;background:var(--bg-input);border:1px solid var(--settings-border);border-radius:10px;color:var(--settings-text);font-size:.95rem;font-weight:600;text-align:center}.settings-row-control input[type=range]{width:180px;height:6px;background:var(--bg-input);border-radius:999px;appearance:none}.settings-row-control input[type=range]::-webkit-slider-thumb{appearance:none;width:16px;height:16px;border-radius:50%;background:var(--settings-accent);box-shadow:0 4px 12px #10a37f66;cursor:pointer}.settings-row-control select{padding:10px 36px 10px 14px;background:var(--bg-input);border:1px solid var(--settings-border);border-radius:10px;color:var(--settings-text);font-size:.9rem;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239b9b9b' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.settings-unit{color:var(--settings-muted);font-size:.85rem}.settings-value{min-width:60px;font-weight:600;color:var(--settings-accent);font-family:var(--font-mono)}.settings-toggle{position:relative;width:52px;height:28px}.settings-toggle input{opacity:0;width:0;height:0}.settings-toggle-track{position:absolute;inset:0;border-radius:999px;background:var(--bg-input);border:1px solid var(--settings-border);transition:all .2s ease}.settings-toggle-track:before{content:"";position:absolute;width:20px;height:20px;border-radius:50%;background:var(--settings-muted);top:3px;left:3px;transition:all .2s ease}.settings-toggle input:checked+.settings-toggle-track{background:var(--settings-accent);border-color:transparent}.settings-toggle input:checked+.settings-toggle-track:before{transform:translate(24px);background:var(--text-main)}.settings-toggle-label{font-size:.85rem;color:var(--settings-muted)}.settings-cursor-grid{display:flex;gap:.6rem;flex-wrap:wrap}.settings-cursor-option{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.7rem .9rem;border-radius:12px;border:1px solid var(--settings-border);background:var(--bg-input);color:var(--settings-muted);font-size:.8rem;cursor:pointer;transition:all .2s ease}.settings-cursor-option.active{border-color:#10a37f80;color:var(--settings-accent);background:#10a37f1f}.settings-cursor-preview{width:16px;height:20px;background:var(--settings-accent);border-radius:2px}.settings-cursor-preview.underline{height:3px;align-self:flex-end}.settings-cursor-preview.bar{width:3px}.settings-about{display:flex;flex-direction:column;gap:1.25rem;align-items:flex-start}.settings-about-logo{display:inline-flex;align-items:center;gap:12px}.settings-logo-mark{font-size:1.8rem;font-weight:700;color:var(--settings-accent);background:#10a37f1f;padding:10px 14px;border-radius:12px;font-family:var(--font-mono)}.settings-logo-text{font-size:1.6rem;font-weight:700}.settings-about-meta{display:inline-flex;align-items:center;gap:10px;background:var(--bg-input);border:1px solid var(--settings-border);border-radius:999px;padding:6px 14px}.settings-about-label{font-size:.75rem;color:var(--settings-muted);text-transform:uppercase;letter-spacing:.1em}.settings-about-value{font-weight:600;color:var(--settings-accent);font-family:var(--font-mono)}.settings-about-description{margin:0;color:var(--settings-muted);line-height:1.7;max-width:560px}.settings-about-stack{display:flex;flex-wrap:wrap;gap:.6rem}.settings-about-stack span{padding:6px 12px;border-radius:999px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);font-size:.78rem;color:var(--settings-muted)}.settings-github-link{display:inline-flex;align-items:center;gap:.5rem;padding:10px 18px;border-radius:12px;border:1px solid var(--settings-border);color:var(--settings-text);text-decoration:none;transition:all .2s ease}.settings-github-link:hover{border-color:#10a37f80;color:var(--settings-accent)}.settings-keybindings-help{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--settings-border)}.settings-keybindings-help h4{font-size:.85rem;font-weight:600;color:var(--settings-muted);margin:0 0 1rem;text-transform:uppercase;letter-spacing:.05em}.settings-keybindings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.settings-keybinding-item{display:flex;align-items:center;justify-content:space-between;padding:.6rem .9rem;background:var(--bg-input);border:1px solid var(--settings-border);border-radius:8px}.settings-keybinding-keys{display:flex;gap:.25rem}.settings-keybinding-keys kbd{display:inline-block;padding:.2rem .5rem;font-size:.75rem;font-family:var(--font-mono);background:var(--bg-secondary);border:1px solid var(--settings-border);border-radius:4px;color:var(--settings-text)}.settings-keybinding-desc{font-size:.8rem;color:var(--settings-muted)}@media(max-width:980px){.settings-layout{grid-template-columns:1fr}.settings-nav{position:static}.settings-nav-list{flex-direction:row;flex-wrap:wrap}.settings-nav-item{flex:1 1 200px}.settings-row{grid-template-columns:1fr;align-items:flex-start}.settings-row-control{justify-self:start}}@media(max-width:640px){.settings-page{padding:1rem}.settings-shell{padding:1.25rem;border-radius:18px}.settings-header{flex-direction:column;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.settings-title{font-size:1.5rem}.settings-subtitle{font-size:.9rem}.settings-nav-item{flex:1 1 100%;min-height:44px}.settings-save{padding:10px 16px;min-height:44px}.settings-content{padding:1rem 0}.settings-section{margin-bottom:1.5rem}.settings-row{gap:.75rem}}@media(max-width:480px){.settings-page{padding:.75rem}.settings-shell{padding:1rem;border-radius:16px}.settings-header{gap:.75rem}.settings-title{font-size:1.3rem}.settings-eyebrow{font-size:.7rem}.settings-header-actions{width:100%}.settings-save{width:100%;justify-content:center}.settings-nav-list{gap:.5rem}.settings-nav-item{padding:10px;min-height:40px;font-size:.9rem}.settings-control{min-height:44px}.settings-toggle{min-width:50px;min-height:28px}.settings-theme-option{padding:.6rem .8rem;font-size:.75rem}}@media(max-width:375px){.settings-page{padding:.5rem}.settings-shell{padding:.875rem}.settings-title{font-size:1.2rem}.settings-subtitle{font-size:.85rem}.settings-nav-item{padding:8px;font-size:.85rem}.settings-save{font-size:.9rem;padding:8px 12px}.settings-row{grid-template-columns:1fr}.settings-control{min-height:40px}input,select,textarea{font-size:1rem}}.settings-theme-grid{display:flex;gap:.5rem}.settings-theme-option{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.75rem 1rem;border-radius:10px;border:1px solid var(--settings-border);background:var(--settings-panel-soft);color:var(--settings-muted);cursor:pointer;transition:all .2s ease;font-size:.8rem}.settings-theme-option:hover{border-color:var(--settings-accent);color:var(--settings-text)}.settings-theme-option.active{border-color:var(--settings-accent);background:var(--settings-accent-soft);color:var(--settings-accent)}.settings-theme-option svg{font-size:1.1rem}.sidebar{width:72px;height:calc(100vh - 32px);margin:16px;display:flex;flex-direction:column;padding:1.5rem .75rem;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;position:relative;z-index:100}.sidebar.expanded{width:280px;padding:1.5rem 1.25rem}.sidebar-header{display:flex;align-items:center;gap:12px;margin-bottom:2rem;padding:0 2px;height:48px;min-width:0;overflow:visible;position:relative}.logo-icon{width:40px;height:40px;min-width:40px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;box-shadow:0 4px 15px var(--primary-glow);flex-shrink:0}.logo-text{font-size:1.3rem;font-weight:700;letter-spacing:-.5px;white-space:nowrap;opacity:0;max-width:0;overflow:hidden;transition:opacity .3s ease,max-width .3s cubic-bezier(.4,0,.2,1)}.sidebar.expanded .logo-text{opacity:1;max-width:300px;margin-left:0}.accent{color:var(--primary)}.sidebar-toggle-btn{position:absolute;right:2px;top:50%;transform:translateY(-50%);width:44px;height:44px;min-width:44px;min-height:44px;border:none;border-radius:8px;background:transparent;color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0;z-index:10;-webkit-tap-highlight-color:rgba(16,163,127,.2)}.sidebar-toggle-btn:hover{background:var(--bg-card-hover);color:var(--text-main)}.sidebar-toggle-btn:active{transform:translateY(-50%) scale(.95)}.sidebar-toggle-btn svg{font-size:.9rem}.sidebar-nav{display:flex;flex-direction:column;gap:.5rem;flex:1}.nav-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;color:var(--text-muted);text-decoration:none;transition:all .2s ease;font-weight:500;border:1px solid transparent;white-space:nowrap;min-height:48px;height:48px;overflow:hidden;min-width:44px}.nav-item svg{flex-shrink:0;min-width:18px}.nav-label{opacity:0;transform:translate(-10px);transition:all .25s ease}.sidebar.expanded .nav-label{opacity:1;transform:translate(0)}.nav-item:hover{background:var(--bg-card-hover);color:var(--text-main)}.nav-item.active{background:#10a37f1f;color:var(--primary);border-color:#10a37f4d}.nav-item.active svg{filter:drop-shadow(0 0 4px rgba(16,163,127,.5))}.sidebar-footer{margin-top:auto;border-top:1px solid var(--border);padding-top:.5rem}.user-profile-link{display:flex;align-items:center;gap:10px;padding:12px;border-radius:12px;border:1px solid transparent;color:var(--text-muted);text-decoration:none;transition:all .2s ease;min-height:48px;height:48px;box-sizing:border-box;overflow:hidden;min-width:44px}.sidebar.expanded .user-profile-link{padding:12px}.user-profile-link:hover{background:var(--bg-card-hover);color:var(--text-main)}.user-profile-link.active{background:#10a37f1f;color:var(--primary)}.user-avatar{width:24px;height:24px;min-width:24px;border-radius:6px;background:linear-gradient(140deg,#10a37f2e,#10a37f0a);border:1px solid rgba(16,163,127,.35);display:flex;align-items:center;justify-content:center;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.avatar-initials{font-size:.6rem;font-weight:700;color:var(--primary)}.user-info{display:flex;flex-direction:column;justify-content:center;gap:1px;min-width:0;flex:1;overflow:hidden}.user-name{font-size:.8rem;font-weight:600;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2;margin:0}.user-email{font-size:.68rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2;margin:0}.chevron-icon{font-size:.55rem;color:var(--text-muted);opacity:0;transform:rotate(-90deg);transition:all .2s ease;flex-shrink:0}.sidebar.expanded .chevron-icon{opacity:1;transform:rotate(0)}.sidebar.collapsed .user-profile-link{position:relative;padding:12px 10px;height:48px;overflow:hidden}.sidebar.collapsed .user-avatar{width:24px;height:24px;min-width:24px;border-radius:6px}.sidebar.collapsed .user-info,.sidebar.collapsed .chevron-icon{display:none}.sidebar.collapsed .user-profile-link:after{content:"Profile";position:absolute;left:100%;top:50%;transform:translateY(-50%);margin-left:12px;padding:6px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-main);font-size:.85rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;z-index:1000}.sidebar.collapsed .user-profile-link:hover:after{opacity:1}.sidebar.collapsed .nav-item{position:relative}.sidebar.collapsed .nav-item:after{content:attr(data-tooltip);position:absolute;left:100%;top:50%;transform:translateY(-50%);margin-left:12px;padding:6px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-main);font-size:.85rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;z-index:1000}.sidebar.collapsed .nav-item:hover:after{opacity:1}.sidebar.collapsed:after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:3px;height:40px;background:linear-gradient(to bottom,transparent,var(--primary),transparent);border-radius:3px;opacity:0;transition:opacity .3s}.sidebar.collapsed:hover:after{opacity:.5}@media(max-width:768px){.sidebar{position:fixed;left:0;top:0;height:100vh;margin:0;border-radius:0;z-index:1000;width:280px;padding:1.5rem 1.25rem}.sidebar.collapsed{transform:translate(-100%)}.sidebar.expanded{transform:translate(0)}.sidebar-toggle-btn{width:48px;height:48px;min-width:48px;min-height:48px}.nav-item{height:48px;min-height:48px;padding:12px;font-size:.95rem}.sidebar.collapsed .nav-label{display:none}}@media(max-width:480px){.sidebar{width:280px}.logo-text{font-size:1.1rem}.nav-item{padding:10px}.user-email{display:none}}@media(max-width:375px){.sidebar{width:260px}.logo-text{font-size:1rem}.nav-item{height:44px;padding:8px}.sidebar-header{height:40px}}.clipboard-paste-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10003;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.clipboard-paste-dialog{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;width:90%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;animation:pasteDialogIn .2s ease-out;overflow:hidden}@keyframes pasteDialogIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.clipboard-paste-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.clipboard-paste-header h3{margin:0;font-size:16px;color:var(--text-main);font-weight:600}.clipboard-paste-close{background:none;border:none;font-size:20px;color:var(--text-muted);cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.clipboard-paste-close:hover{background:var(--border);color:var(--text-main)}.clipboard-paste-warning{background:#ef44441a;border-bottom:1px solid rgba(239,68,68,.3);padding:12px 16px;color:var(--status-danger);font-size:12px;line-height:1.5}.clipboard-paste-warning strong{display:block;margin-bottom:8px;color:var(--status-danger);font-weight:600}.clipboard-paste-warning ul{margin:8px 0 8px 20px;padding:0}.clipboard-paste-warning li{margin:4px 0}.clipboard-paste-warning p{margin:8px 0 0;font-weight:500}.clipboard-paste-content{flex:1;overflow:auto;padding:12px;min-height:100px;max-height:400px}.clipboard-paste-preview{margin:0;padding:10px 12px;background:var(--bg-deep);border:1px solid var(--border);border-radius:6px;color:var(--text-muted);font-size:12px;line-height:1.5;font-family:Courier New,monospace;word-break:break-all;white-space:pre-wrap;max-height:300px;overflow:auto}.clipboard-paste-edit{width:100%;height:200px;padding:10px 12px;background:var(--bg-deep);border:1px solid var(--border);border-radius:6px;color:var(--text-main);font-size:12px;font-family:Courier New,monospace;resize:vertical;box-sizing:border-box;outline:none}.clipboard-paste-edit:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.clipboard-paste-actions{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border);justify-content:flex-end}.paste-btn-edit,.paste-btn-cancel,.paste-btn-confirm{padding:8px 14px;border:none;border-radius:6px;font-weight:600;font-size:12px;cursor:pointer;transition:all .2s ease}.paste-btn-edit{background:var(--bg-deep);color:var(--text-main);border:1px solid var(--border)}.paste-btn-edit:hover{background:var(--border)}.paste-btn-cancel{background:var(--bg-deep);color:var(--text-main);border:1px solid var(--border)}.paste-btn-cancel:hover{background:var(--border)}.paste-btn-confirm{background:var(--primary);color:#fff}.paste-btn-confirm:hover{opacity:.9}.clipboard-paste-hint{padding:0 16px 12px;font-size:11px;color:var(--text-muted);font-style:italic}@media(max-width:480px){.clipboard-paste-dialog{width:95%;max-height:90vh}.clipboard-paste-actions{flex-direction:column-reverse}.paste-btn-edit,.paste-btn-cancel,.paste-btn-confirm{width:100%}}.file-explorer{display:flex;flex-direction:column;height:100%;background:var(--bg-card);border-radius:12px;border:1px solid var(--border);overflow:hidden}.file-explorer-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-deep);border-bottom:1px solid var(--border)}.file-explorer-title{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--text-main)}.file-explorer-title .title-icon{color:var(--primary)}.file-explorer-close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .15s ease}.file-explorer-close:hover{background:var(--bg-card);color:var(--status-danger)}.file-explorer-toolbar{display:flex;align-items:center;gap:4px;padding:8px 12px;background:var(--bg-deep);border-bottom:1px solid var(--border)}.file-explorer-toolbar button{background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);padding:6px 10px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.file-explorer-toolbar button:hover:not(:disabled){background:var(--bg-hover);color:var(--text-main);border-color:var(--primary)}.file-explorer-toolbar button:disabled{opacity:.5;cursor:not-allowed}.toolbar-separator{width:1px;height:20px;background:var(--border);margin:0 8px}.file-explorer-path{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-deep);border-bottom:1px solid var(--border);font-size:12px}.path-label{color:var(--text-muted)}.path-value{color:var(--text-main);font-family:var(--font-mono, monospace);background:var(--bg-card);padding:4px 8px;border-radius:4px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-explorer-new-folder{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-hover);border-bottom:1px solid var(--border)}.file-explorer-new-folder input{flex:1;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:6px 10px;color:var(--text-main);font-size:13px}.file-explorer-new-folder input:focus{outline:none;border-color:var(--primary)}.file-explorer-new-folder button{background:var(--primary);border:none;color:#fff;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:12px;transition:all .15s ease}.file-explorer-new-folder button:last-child{background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted)}.file-explorer-new-folder button:hover{opacity:.9}.file-explorer-error{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#ef44441a;border-bottom:1px solid rgba(239,68,68,.3);color:var(--status-danger);font-size:13px}.file-explorer-error button{background:transparent;border:none;color:var(--status-danger);cursor:pointer;padding:2px}.file-explorer-content{flex:1;overflow:auto}.file-explorer-loading,.file-explorer-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:14px}.file-list{width:100%;border-collapse:collapse;font-size:13px}.file-list thead{position:sticky;top:0;background:var(--bg-deep);z-index:1}.file-list th,.file-list td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border)}.file-list th{color:var(--text-muted);font-weight:500;white-space:nowrap}.file-list .col-name,.file-list .file-name{width:auto}.file-list .col-size,.file-list .file-size{text-align:right;width:70px;min-width:70px}.file-list .col-modified,.file-list .file-date{width:120px;min-width:120px;white-space:nowrap}.file-list .col-actions,.file-list .file-actions{text-align:right;width:70px;min-width:70px}.file-row{cursor:pointer;transition:background .1s ease}.file-row:hover{background:var(--bg-hover)}.file-row.selected{background:#3b82f61a}.file-row td{padding:8px 10px;border-bottom:1px solid var(--border);overflow:hidden}.file-name{color:var(--text-main)}.file-name-content{display:flex;align-items:center;gap:6px;overflow:hidden}.file-name-content span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-icon{color:var(--text-muted);flex-shrink:0}.file-icon.folder{color:var(--primary)}.file-size,.file-date{color:var(--text-muted);white-space:nowrap}.file-actions{text-align:right;white-space:nowrap}.file-actions button{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px 6px;border-radius:4px;transition:all .15s ease;margin-left:4px}.file-actions button:hover{background:var(--bg-card);color:var(--text-main)}.file-actions .delete-btn:hover{color:var(--status-danger)}.rename-input{background:var(--bg-card);border:1px solid var(--primary);border-radius:4px;padding:2px 6px;color:var(--text-main);font-size:13px;width:200px}.rename-input:focus{outline:none}.file-explorer-uploading{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:var(--bg-deep);border-top:1px solid var(--border);color:var(--text-main);font-size:13px}.upload-spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.mobile-toolbar{position:fixed;bottom:0;left:0;right:0;height:auto;background:#14141ef2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.1);padding:12px 16px;z-index:999;display:flex;align-items:center;justify-content:space-between;box-shadow:0 -4px 12px #0000004d}.toolbar-status{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;animation:pulse 2s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.6}to{opacity:1}}.status-text{color:#fff;font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toolbar-status-subtext{position:absolute;bottom:-22px;left:16px;font-size:11px;color:#fff9;white-space:nowrap}.toolbar-actions{display:flex;gap:8px;align-items:center;margin-left:auto}.toolbar-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;cursor:pointer;transition:all .2s ease;font-size:16px}.toolbar-btn:active{background:#fff3;transform:scale(.95)}.toolbar-btn:hover{background:#ffffff26;border-color:#ffffff4d}.toolbar-refresh:hover{color:#4ade80;border-color:#4ade80}.toolbar-settings:hover{color:#3b82f6;border-color:#3b82f6}.toolbar-disconnect:hover{color:#ef4444;border-color:#ef4444}.toolbar-toggle{background:#3b82f633;border-color:#3b82f666;color:#60a5fa}.toolbar-toggle:hover{background:#3b82f64d;border-color:#3b82f699}.toolbar-actions.expanded{gap:6px}.toolbar-actions.expanded .toolbar-btn{width:32px;height:32px;font-size:14px}@media(min-width:768px){.mobile-toolbar{display:none}}@media(max-width:360px){.mobile-toolbar{padding:10px 12px}.toolbar-btn{width:32px;height:32px;font-size:14px}.status-text{font-size:12px}}.mobile-toolbar.with-special-keys{padding-bottom:70px}.quick-commands-container{position:fixed;top:60px;left:0;right:0;z-index:100;background:transparent}.quick-commands-bar{display:flex;gap:6px;padding:8px 12px;overflow-x:auto;overflow-y:hidden;background:#14141ecc;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.1);scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.quick-command-btn{flex-shrink:0;padding:6px 12px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#fff;font-size:12px;font-weight:500;border-radius:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap;-webkit-user-select:none;user-select:none}.quick-command-btn:active{background:#3b82f680;border-color:#3b82f6cc;transform:scale(.95)}.quick-command-btn:hover{background:#ffffff1f;border-color:#ffffff40}.quick-command-settings{background:#3b82f626;border-color:#3b82f64d;font-size:14px;padding:6px 10px}.quick-command-settings:hover{background:#3b82f640;border-color:#3b82f680}.quick-commands-customize{background:var(--bg-card);border:1px solid var(--border);border-top:none;border-bottom:1px solid var(--border);padding:16px;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.quick-commands-customize h3{margin:0 0 12px;font-size:14px;color:var(--text-main);font-weight:600}.customize-input-group{display:flex;gap:8px;margin-bottom:12px}.customize-input{flex:1;padding:8px 10px;background:var(--bg-deep);border:1px solid var(--border);border-radius:4px;color:var(--text-main);font-size:13px;outline:none}.customize-input:focus{border-color:var(--primary)}.customize-input::placeholder{color:var(--text-muted)}.customize-btn-add{padding:8px 14px;background:var(--primary);border:none;border-radius:4px;color:#fff;font-weight:600;font-size:12px;cursor:pointer;transition:all .2s ease}.customize-btn-add:hover{opacity:.9;transform:translateY(-1px)}.customize-btn-add:active{transform:translateY(0)}.customize-list{max-height:200px;overflow-y:auto;margin-bottom:12px;padding-bottom:8px}.customize-label{margin:0 0 8px;font-size:12px;color:var(--text-muted);font-weight:500}.customize-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;background:var(--bg-deep);border:1px solid var(--border);border-radius:4px;margin-bottom:6px;font-size:13px;color:var(--text-main)}.customize-btn-remove{background:none;border:none;color:var(--status-danger);cursor:pointer;font-size:14px;padding:0 4px;transition:all .2s ease}.customize-btn-remove:hover{transform:scale(1.2)}.customize-actions{display:flex;gap:8px;justify-content:flex-end}.customize-btn-reset,.customize-btn-close{padding:8px 14px;border:1px solid var(--border);border-radius:4px;background:var(--bg-deep);color:var(--text-main);font-weight:600;font-size:12px;cursor:pointer;transition:all .2s ease}.customize-btn-reset:hover{background:var(--bg-card);border-color:var(--status-warning);color:var(--status-warning)}.customize-btn-close:hover{background:var(--primary);border-color:var(--primary);color:#fff}@media(min-width:768px){.quick-commands-container{display:none}}.quick-commands-bar::-webkit-scrollbar{height:4px}.quick-commands-bar::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.quick-commands-bar::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.customize-list::-webkit-scrollbar{width:4px}.customize-list::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.customize-list::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.template-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.template-dialog{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:20px;max-width:400px;width:90%;box-shadow:0 10px 40px #0000004d;animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.template-dialog h3{margin:0 0 16px;font-size:16px;color:var(--text-main);font-weight:600;word-break:break-word}.template-inputs{margin-bottom:16px}.template-input-group{margin-bottom:12px}.template-input-group label{display:block;margin-bottom:4px;font-size:12px;color:var(--text-muted);font-weight:500}.template-input-group input{width:100%;padding:8px 10px;background:var(--bg-deep);border:1px solid var(--border);border-radius:4px;color:var(--text-main);font-size:13px;box-sizing:border-box;outline:none}.template-input-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.template-input-group input::placeholder{color:var(--text-muted)}.template-actions{display:flex;gap:8px;justify-content:flex-end}.template-btn-submit,.template-btn-cancel{padding:8px 16px;border:none;border-radius:4px;font-weight:600;font-size:12px;cursor:pointer;transition:all .2s ease}.template-btn-submit{background:var(--primary);color:#fff}.template-btn-submit:hover{opacity:.9;transform:translateY(-1px)}.template-btn-submit:active{transform:translateY(0)}.template-btn-cancel{background:var(--bg-deep);color:var(--text-main);border:1px solid var(--border)}.template-btn-cancel:hover{background:var(--border)}.customize-hint{font-size:11px;color:var(--text-muted);margin:-6px 0 12px;font-style:italic}.special-key-buttons-container{position:fixed;bottom:20px;left:20px;right:20px;display:flex;gap:10px;justify-content:flex-start;z-index:1000;max-width:250px;padding:10px;background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:12px;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a}.special-key-btn{flex:1;padding:10px 12px;background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;font-weight:600;font-size:12px;border-radius:8px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;min-height:40px;display:flex;align-items:center;justify-content:center}.special-key-btn:active,.special-key-btn.active{background:#3b82f699;border-color:#3b82f6cc;box-shadow:0 0 12px #3b82f680;transform:scale(.95)}.special-key-btn:hover{background:#ffffff40;border-color:#fff6}@media(min-width:768px){.special-key-buttons-container{display:none}}@media(max-width:360px){.special-key-buttons-container{bottom:10px;left:10px;right:10px;max-width:none}.special-key-btn{font-size:11px;padding:8px 10px;min-height:36px}}.terminal-page{height:100%;display:flex;flex-direction:column}.terminal-search-bar{position:absolute;top:8px;right:8px;z-index:100;display:flex;align-items:center;gap:6px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:6px 10px;box-shadow:0 4px 12px #0000004d;flex-wrap:wrap;max-width:90%}.terminal-search-input{background:var(--bg-deep);border:1px solid var(--border);border-radius:6px;padding:8px 12px;color:var(--text-main);font-size:13px;min-width:140px;outline:none;min-height:32px}.terminal-search-input:focus{border-color:var(--primary)}.terminal-search-input::placeholder{color:var(--text-muted)}.terminal-search-btn{background:var(--bg-deep);border:1px solid var(--border);border-radius:6px;color:var(--text-muted);min-width:36px;min-height:36px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;transition:all .15s ease;flex-shrink:0}.terminal-search-btn:hover{background:var(--bg-card);color:var(--text-main);border-color:var(--primary)}.terminal-search-close:hover{color:var(--status-danger);border-color:var(--status-danger)}.terminal-wrapper{flex:1;min-height:0;padding:1rem;overflow:hidden;position:relative;background:var(--bg-deep);display:flex;flex-direction:column}.xterm-container{width:100%;height:100%;min-height:0;flex:1;overflow:hidden}.xterm-viewport::-webkit-scrollbar{display:block}.xterm-viewport::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.terminal-page-container{height:100%;display:flex;flex-direction:column;min-height:0}.terminal-content{flex:1;overflow:hidden;position:relative;min-height:0}.terminal-page.with-file-explorer{flex-direction:row}.terminal-page.with-file-explorer .terminal-wrapper{flex:1;min-width:0}.resize-handle{width:4px;height:100%;background:transparent;cursor:col-resize;flex-shrink:0;transition:background .15s ease}.resize-handle:hover{background:var(--primary)}.file-explorer-panel{min-width:350px;max-width:70%;height:100%;border-left:1px solid var(--border);background:var(--bg-card);flex-shrink:0;overflow:hidden;display:flex;flex-direction:column}.terminal-close-btn{position:absolute;top:12px;right:12px;z-index:100;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-muted);min-width:44px;min-height:44px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;opacity:.7;font-size:1rem}.terminal-close-btn:hover{background:#ef444426;color:#ef4444;border-color:#ef444466;opacity:1}.terminal-files-btn{position:absolute;top:12px;right:120px;z-index:100;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-muted);min-width:44px;min-height:44px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;opacity:.7;font-size:1rem}.terminal-files-btn:hover{background:var(--bg-hover);color:var(--primary);border-color:var(--primary);opacity:1}.terminal-record-btn{position:absolute;top:12px;right:188px;z-index:100;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-muted);min-width:44px;min-height:44px;height:44px;padding:0 12px;display:flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:all .15s ease;opacity:.7;font-size:.95rem}.terminal-record-btn:hover{background:var(--bg-hover);color:#e74c3c;border-color:#e74c3c;opacity:1}.terminal-record-btn.recording{background:#e74c3c26;border-color:#e74c3c;color:#e74c3c;opacity:1;animation:pulse-recording 1.5s ease-in-out infinite}.terminal-record-btn.recording:hover{background:#e74c3c40}@keyframes pulse-recording{0%,to{box-shadow:0 0 #e74c3c66}50%{box-shadow:0 0 0 6px #e74c3c00}}.recording-duration{font-size:13px;font-weight:500;font-family:JetBrains Mono,monospace}.terminal-zen-btn{position:absolute;top:12px;right:64px;z-index:100;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-muted);min-width:44px;min-height:44px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;opacity:.7;font-size:1rem}.terminal-zen-btn:hover{background:var(--bg-hover);color:var(--primary);border-color:var(--primary);opacity:1}.terminal-page.zen-mode{background:var(--bg-deep)}.terminal-page.zen-mode .terminal-wrapper{border-radius:0;border:none}.terminal-page.zen-mode .terminal-close-btn,.terminal-page.zen-mode .terminal-files-btn,.terminal-page.zen-mode .terminal-record-btn{opacity:0;transition:opacity .3s ease}.terminal-page.zen-mode:hover .terminal-close-btn,.terminal-page.zen-mode:hover .terminal-files-btn,.terminal-page.zen-mode:hover .terminal-record-btn,.terminal-page.zen-mode:hover .terminal-zen-btn{opacity:.7}.terminal-page.zen-mode .terminal-zen-btn{opacity:.3}.terminal-page.zen-mode:hover .terminal-zen-btn:hover{opacity:1}.terminal-context-menu{position:fixed;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #00000080;z-index:10000;min-width:140px;overflow:hidden;animation:contextMenuAppear .15s ease-out}@keyframes contextMenuAppear{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.context-menu-item{display:block;width:100%;padding:12px 16px;background:none;border:none;color:var(--text-main);text-align:left;cursor:pointer;font-size:14px;transition:all .15s ease;border-bottom:1px solid var(--border)}.context-menu-item:last-child{border-bottom:none}.context-menu-item:active,.context-menu-item:hover{background:var(--bg-deep)}@media(pointer:fine){.terminal-context-menu{display:none}}.replay-message{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000c;border:2px solid var(--primary);border-radius:8px;padding:16px 24px;color:var(--primary);font-size:14px;font-weight:600;text-align:center;z-index:50;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:pulseMessage 1s infinite;pointer-events:none}@keyframes pulseMessage{0%,to{opacity:1}50%{opacity:.7}}@media(max-width:768px){.terminal-wrapper{padding:.75rem}.terminal-search-bar{top:6px;right:6px;padding:4px 6px;gap:4px}.terminal-search-input{min-width:120px;padding:6px 10px;font-size:12px;min-height:32px}.terminal-search-btn{min-width:32px;min-height:32px;width:32px;height:32px}.terminal-close-btn{top:8px;right:8px;min-width:40px;min-height:40px;width:40px;height:40px}.terminal-files-btn{top:8px;right:108px;min-width:40px;min-height:40px;width:40px;height:40px}.terminal-record-btn{top:8px;right:168px;min-width:40px;min-height:40px;height:40px;padding:0 8px;font-size:.85rem}.terminal-zen-btn{top:8px;right:56px;min-width:40px;min-height:40px;width:40px;height:40px}.file-explorer-panel{min-width:300px;display:none}.terminal-page.with-file-explorer .file-explorer-panel{display:flex}}@media(max-width:600px){.terminal-wrapper{padding:.5rem}.terminal-search-bar{flex-direction:column;top:4px;right:4px;width:calc(100% - 8px);max-width:none}.terminal-search-input{width:100%;min-width:unset}.terminal-close-btn{top:60px;right:8px}.terminal-files-btn{top:60px;right:56px}.terminal-record-btn{top:60px;right:104px}.terminal-zen-btn{top:60px;right:152px}.terminal-page.zen-mode .terminal-close-btn,.terminal-page.zen-mode .terminal-files-btn,.terminal-page.zen-mode .terminal-record-btn,.terminal-page.zen-mode .terminal-zen-btn{top:8px;opacity:0}.file-explorer-panel{display:none;min-width:100%}.terminal-page.with-file-explorer{flex-direction:column}.terminal-page.with-file-explorer .terminal-wrapper{flex:0 0 60%;border-right:none;border-bottom:1px solid var(--border)}.terminal-page.with-file-explorer .file-explorer-panel{display:flex;flex:0 0 40%;border-left:none;border-top:1px solid var(--border);min-width:100%}.resize-handle{display:none}}@media(max-width:480px){.terminal-wrapper{padding:.375rem}.terminal-search-bar{top:2px;right:2px;padding:2px 4px;gap:2px}.terminal-search-input{min-width:100px;font-size:11px;padding:4px 8px}.terminal-search-btn{min-width:28px;min-height:28px;width:28px;height:28px;font-size:10px}.terminal-close-btn,.terminal-files-btn,.terminal-record-btn,.terminal-zen-btn{min-width:36px;min-height:36px;width:36px;height:36px;font-size:.85rem}.terminal-close-btn{top:4px;right:4px}.terminal-files-btn{top:4px;right:44px}.terminal-record-btn{top:4px;right:84px}.terminal-zen-btn{top:4px;right:124px}.context-menu-item{padding:10px 12px;font-size:13px}.replay-message{padding:12px 16px;font-size:12px}}@media(max-width:375px){.terminal-wrapper{padding:.25rem}.terminal-search-bar{top:0;right:0;padding:2px 3px;border-radius:0 0 0 8px;gap:2px}.terminal-search-input{min-width:80px;font-size:10px;padding:3px 6px}.terminal-search-btn{min-width:24px;min-height:24px;width:24px;height:24px;font-size:9px}.terminal-close-btn,.terminal-files-btn,.terminal-record-btn,.terminal-zen-btn{min-width:32px;min-height:32px;width:32px;height:32px;font-size:.8rem}.terminal-page.with-file-explorer .terminal-wrapper,.terminal-page.with-file-explorer .file-explorer-panel{flex:0 0 50%}}.app-container{display:flex;height:100vh;background-color:var(--bg-dark);background-image:radial-gradient(circle at 12% 18%,rgba(16,163,127,.08),transparent 35%),radial-gradient(circle at 82% 12%,rgba(16,163,127,.05),transparent 40%)}.main-content{flex:1;padding:16px;overflow:auto;position:relative;display:flex;flex-direction:column;min-height:0;overscroll-behavior:contain}@media(max-width:768px){.main-content{padding:12px}}@media(max-width:480px){.main-content{padding:8px}}:root{--font-sans: "Soehne", "ui-sans-serif", "system-ui", "sans-serif";--font-mono: "Soehne Mono", "ui-monospace", "SFMono-Regular", "Menlo", "Monaco", "Consolas", monospace;--glass-blur: 12px;--glass-opacity: .92;--bg-dark: #212121;--bg-card: #171717;--bg-card-hover: #2f2f2f;--bg-input: #2f2f2f;--bg-elevated: #1b1b1b;--bg-deep: #111111;--bg-code: #0f0f0f;--primary: #10a37f;--primary-glow: rgba(16, 163, 127, .3);--accent: #0f766e;--accent-glow: rgba(15, 118, 110, .28);--text-main: #ececec;--text-muted: #9b9b9b;--text-primary: var(--text-main);--border: #424242;--glass-bg: rgba(23, 23, 23, var(--glass-opacity));--glass-border: rgba(255, 255, 255, .04);--glass-shadow: 0 18px 40px rgba(0, 0, 0, .35);--status-success: #22c55e;--status-warning: #f59e0b;--status-danger: #ef4444;--status-online: #22c55e;--status-offline: #ef4444;--status-unknown: #6b7280;--transition-fast: .2s ease;--transition-smooth: .3s cubic-bezier(.4, 0, .2, 1)}:root[data-theme=light]{--bg-dark: #f5f5f5;--bg-card: #ffffff;--bg-card-hover: #f0f0f0;--bg-input: #ffffff;--bg-elevated: #fafafa;--bg-deep: #e5e5e5;--bg-code: #f8f8f8;--text-main: #1a1a1a;--text-muted: #6b6b6b;--text-primary: var(--text-main);--border: #d4d4d4;--glass-bg: rgba(255, 255, 255, var(--glass-opacity));--glass-border: rgba(0, 0, 0, .06);--glass-shadow: 0 18px 40px rgba(0, 0, 0, .1)}@media(prefers-color-scheme:light){:root[data-theme=auto]{--bg-dark: #f5f5f5;--bg-card: #ffffff;--bg-card-hover: #f0f0f0;--bg-input: #ffffff;--bg-elevated: #fafafa;--bg-deep: #e5e5e5;--bg-code: #f8f8f8;--text-main: #1a1a1a;--text-muted: #6b6b6b;--text-primary: var(--text-main);--border: #d4d4d4;--glass-bg: rgba(255, 255, 255, var(--glass-opacity));--glass-border: rgba(0, 0, 0, .06);--glass-shadow: 0 18px 40px rgba(0, 0, 0, .1)}}:root[data-animations=off] *,:root[data-animations=off] *:before,:root[data-animations=off] *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-dark);color:var(--text-main);-webkit-font-smoothing:antialiased;overflow-x:hidden;height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-dark)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.glass-panel{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:16px}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--accent));border:none;color:#fff;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;cursor:pointer;transition:var(--transition-fast);box-shadow:0 6px 16px #10a37f40;min-height:44px;display:inline-flex;align-items:center;justify-content:center}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px var(--primary-glow);filter:brightness(1.05)}.btn-icon{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:8px;border-radius:8px;transition:var(--transition-fast);display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px}.btn-icon:hover{background:var(--bg-card-hover);color:var(--text-main)}input,select,textarea{background:var(--bg-input);border:1px solid var(--border);color:var(--text-main);padding:.75rem 1rem;border-radius:8px;font-family:var(--font-sans);font-size:.95rem;outline:none;transition:var(--transition-fast);min-height:44px}input[type=checkbox],input[type=radio]{width:18px;height:18px;cursor:pointer}label input[type=checkbox],label input[type=radio]{margin-right:.5rem}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow)}label{display:block;margin-bottom:.5rem;font-size:.9rem;font-weight:500;color:var(--text-muted);cursor:pointer}label>input,label>select,label>textarea{margin-top:.4rem}.loading-state,.error-state{padding:2rem;border-radius:12px;border:1px solid rgba(255,255,255,.08);background:#0c0c1099;color:var(--text-muted)}.error-state{border-color:#ef444466;color:#fca5a5}@media(max-width:768px){body{font-size:16px}.btn-primary{padding:.65rem 1.25rem;font-size:.95rem}input,select,textarea{font-size:1rem}}@media(max-width:480px){.btn-primary{width:100%;padding:.75rem 1rem}input,select,textarea{width:100%;padding:.875rem 1rem}label{font-size:.95rem;margin-bottom:.6rem}.loading-state,.error-state{padding:1.5rem;font-size:.9rem}}@media(max-width:375px){body{font-size:14px}.btn-primary{padding:.65rem .875rem;font-size:.9rem}input,select,textarea{padding:.75rem .875rem}.glass-panel{border-radius:12px}}
