:root{--bg-primary: #0a0a0f;--bg-secondary: #111118;--bg-surface: #16161f;--bg-hover: #1c1c28;--border: #26263a;--border-light: #2e2e44;--text-primary: #ececf1;--text-secondary:#8e8ea0;--text-muted: #6e6e80;--accent: #10a37f;--accent-hover: #1a7f64;--accent-soft: rgba(16, 163, 127, 0.12);--red: #ef4444;--red-soft: rgba(239, 68, 68, 0.12);--yellow: #eab308;--yellow-soft: rgba(234, 179, 8, 0.12);--blue: #3b82f6;--blue-soft: rgba(59, 130, 246, 0.12);--purple: #a78bfa;--purple-soft: rgba(167, 139, 250, 0.12);--sidebar-w: 240px;--radius: 8px;--radius-sm: 6px;--content-narrow: 520px}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}body{font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100vh;display:flex}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}.icon{display:inline-block;vertical-align:middle;flex-shrink:0}.app-main{margin-left:var(--sidebar-w);flex:1;min-height:100vh}.main{max-width:1000px;margin:0 auto;padding:2rem 2.5rem}.content-header{margin-bottom:2rem}.content-header h1{font-size:1.5rem;font-weight:600;letter-spacing:-0.02em;margin-bottom:.25rem}.login-wrapper{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100%}.sidebar{width:var(--sidebar-w);min-height:100vh;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100}.sidebar-brand{padding:1.25rem 1.25rem 1rem;font-weight:700;font-size:1rem;color:var(--text-primary);letter-spacing:-0.02em;display:flex;align-items:center;gap:.6rem}.sidebar-brand .dot{width:8px;height:8px;background:var(--accent);border-radius:50%;display:inline-block}.sidebar-nav{flex:1;padding:.5rem .75rem;overflow-y:auto}.sidebar-nav .nav-section{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:1rem .5rem .4rem;font-weight:600}.sidebar-nav a{display:flex;align-items:center;gap:.6rem;padding:.5rem .65rem;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.875rem;transition:all .15s ease}.sidebar-nav a:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-nav a.active{background:var(--accent-soft);color:var(--accent)}.sidebar-nav a .nav-icon{width:18px;display:inline-flex;align-items:center;justify-content:center;font-style:normal;font-size:.85rem;opacity:.7;vertical-align:middle}.sidebar-nav a .nav-icon svg{display:block}.sidebar-back{padding:.75rem .5rem}.sidebar-back a{font-size:.8rem;color:var(--text-muted)}.sidebar-balance{margin:.5rem .5rem .25rem;padding:.65rem .75rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm)}.sidebar-balance-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:500;margin-bottom:.2rem}.sidebar-balance-row{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}.sidebar-balance-amount{font-size:1.05rem;font-weight:600;color:var(--text-primary);letter-spacing:-0.02em}.sidebar-balance-topup{font-size:.7rem;color:var(--accent);text-decoration:none;opacity:.85;transition:opacity .15s}.sidebar-balance-topup:hover{opacity:1;text-decoration:underline}.sidebar-balance-floating{font-size:.65rem;color:var(--text-muted);margin-top:.2rem}.sidebar-balance-floating span{font-weight:600;color:var(--text-secondary)}.sidebar-footer{padding:.75rem;border-top:1px solid var(--border);position:relative}.sidebar-user{display:flex;align-items:center;gap:.6rem;color:var(--text-secondary);padding:.35rem .5rem;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s}.sidebar-user:hover{background:var(--bg-hover)}.sidebar-user .avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;flex-shrink:0}.sidebar-user .user-info{flex:1;min-width:0}.sidebar-user .user-name{font-size:.8rem;color:var(--text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user .user-role{font-size:.7rem;color:var(--text-muted)}.sidebar-user .chevron{font-size:.65rem;color:var(--text-muted);transition:transform .15s}.sidebar-user.open .chevron{transform:rotate(180deg)}.user-dropdown{display:none;position:absolute;bottom:100%;left:.75rem;right:.75rem;background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:.35rem;margin-bottom:.5rem;box-shadow:0 -4px 24px rgba(0,0,0,.4);z-index:200}.user-dropdown.show{display:block}.user-dropdown .dd-section{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:.5rem .6rem .25rem;font-weight:600}.user-dropdown a,.user-dropdown .dd-item{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.82rem;cursor:pointer;transition:all .1s}.user-dropdown a:hover,.user-dropdown .dd-item:hover{background:var(--bg-hover);color:var(--text-primary)}.user-dropdown .dd-icon{width:16px;display:inline-flex;align-items:center;justify-content:center;font-style:normal;font-size:.75rem;opacity:.6;vertical-align:middle}.user-dropdown .dd-icon svg{display:block}.user-dropdown .dd-divider{height:1px;background:var(--border);margin:.3rem .4rem}.user-dropdown .dd-project-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}.user-dropdown .dd-logout{color:var(--red)}.user-dropdown .dd-logout:hover{background:var(--red-soft);color:var(--red)}.card-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));gap:1rem}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.card form{margin-top:.75rem}.card p{margin-bottom:.25rem;font-size:.9rem;color:var(--text-secondary)}.card-narrow{max-width:var(--content-narrow);margin-left:auto;margin-right:auto}.card--dashed{border-style:dashed}.card-admin{border-color:var(--yellow);border-style:dashed}.card-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:500;margin-bottom:.4rem}.stat-value{font-size:1.85rem;font-weight:700;letter-spacing:-0.03em;color:var(--text-primary);line-height:1.2}.stat-value.accent{color:var(--accent)}.stat-sub{font-size:.8rem;color:var(--text-muted);margin-top:.25rem}.metric-list{margin-top:.6rem}.metric-row{display:flex;justify-content:space-between;padding:.35rem 0;border-bottom:1px solid var(--border);font-size:.85rem}.metric-row:last-child{border-bottom:none}.metric-key{color:var(--text-secondary)}.metric-val{color:var(--text-primary);font-weight:500}.balance-floating{font-size:.72rem;color:var(--text-muted);margin-top:.2rem}.balance-floating span{font-weight:600;color:var(--text-secondary)}.info-list{margin-top:.75rem;font-size:.85rem;color:var(--text-muted);display:flex;flex-direction:column;gap:.4rem}.info-list .info-label{color:var(--text-secondary)}.form-box{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;max-width:420px;margin:6rem auto}.form-box h2{text-align:center;margin-bottom:1.5rem;font-weight:600;font-size:1.25rem}.form-box-footer{text-align:center;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border);font-size:.82rem;color:var(--text-muted)}.form-box-footer a{color:var(--accent);font-weight:500;margin-left:.3rem}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:.3rem;font-weight:500}.form-group input[type=text],.form-group input[type=password],.form-group input[type=email],.form-group input[type=search],.form-group input[type=number],.form-group textarea{width:100%;padding:.55rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;font-family:inherit;transition:border-color .15s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent)}.form-group select,.form-group .form-select{width:100%;padding:.55rem 2rem .55rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;font-family:inherit;cursor:pointer;transition:border-color .15s;-webkit-appearance:none;-moz-appearance:none;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='%236e6e80' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .65rem center}.form-group select:focus,.form-group .form-select:focus{outline:none;border-color:var(--accent)}.form-group select:hover,.form-group .form-select:hover{border-color:var(--border-light)}.form-group select option,.form-group .form-select option{background:var(--bg-surface);color:var(--text-primary);padding:.3rem}.form-select{width:100%;padding:.55rem 2rem .55rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;font-family:inherit;cursor:pointer;transition:border-color .15s;-webkit-appearance:none;-moz-appearance:none;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='%236e6e80' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .65rem center}.form-select:focus{outline:none;border-color:var(--accent)}.form-select:hover{border-color:var(--border-light)}.form-select option{background:var(--bg-surface);color:var(--text-primary)}.form-control{width:100%;padding:.55rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;font-family:inherit;transition:border-color .15s}.form-control:focus{outline:none;border-color:var(--accent)}.select-inline{padding:.3rem 1.8rem .3rem .55rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:.8rem;font-family:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'%3E%3Cpath fill='%236e6e80' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center;transition:border-color .15s}.select-inline:focus{outline:none;border-color:var(--accent)}.select-inline:hover{border-color:var(--border-light)}.select-inline option{background:var(--bg-surface);color:var(--text-primary)}.form-row{display:flex;gap:.75rem}.form-row>.form-group{flex:1}.form-group--inline{display:inline-block;margin-right:.5rem}.form-group--align-btn{padding-top:1.2rem}.btn{display:inline-block;padding:.5rem 1rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;cursor:pointer;color:var(--text-primary);background:var(--bg-surface);font-family:inherit;transition:all .15s;text-align:center}.btn:hover{background:var(--bg-hover);border-color:var(--border-light)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-primary.full{width:100%}.btn-sm{padding:.35rem .7rem;font-size:.8rem}.btn-danger{color:var(--red);border-color:rgba(239,68,68,.3)}.btn-danger:hover{background:var(--red-soft);border-color:var(--red)}.btn-outline{background:rgba(0,0,0,0);border-color:var(--border);color:var(--text-secondary)}.btn-outline:hover{background:var(--bg-hover);border-color:var(--border-light);color:var(--text-primary)}.btn-icon-danger{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid rgba(0,0,0,0);border-radius:var(--radius-sm);background:rgba(0,0,0,0);color:var(--text-muted);cursor:pointer;transition:all .15s;font-size:.85rem;padding:0}.btn-icon-danger:hover{background:var(--red-soft);border-color:rgba(239,68,68,.25);color:var(--red)}.alert{padding:.7rem 1rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.875rem}.alert-error{background:var(--red-soft);border:1px solid rgba(239,68,68,.25);color:#fca5a5}.alert-success{background:var(--accent-soft);border:1px solid rgba(16,163,127,.25);color:#6ee7b7}.data-table{width:100%;border-collapse:collapse;font-size:.85rem}.data-table th{text-align:left;color:var(--text-muted);font-weight:500;padding:.5rem .6rem;border-bottom:1px solid var(--border);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.data-table td{padding:.55rem .6rem;border-bottom:1px solid var(--border);color:var(--text-secondary)}.data-table tr:hover td{background:var(--bg-hover)}.table{width:100%;border-collapse:collapse}.table td{padding:.55rem .6rem;border-bottom:1px solid var(--border);color:var(--text-secondary);font-size:.85rem}.table .col-label{width:200px}.badge{font-size:.72rem;padding:.15rem .5rem;border-radius:3px;font-weight:500}.badge-status-0{background:var(--yellow-soft);color:var(--yellow)}.badge-status-1{background:var(--accent-soft);color:var(--accent)}.badge-status-2{background:var(--red-soft);color:var(--red)}.badge-status-3{background:var(--purple-soft);color:var(--purple)}.badge-role{background:var(--blue-soft);color:var(--blue)}.badge-info{background:var(--blue-soft);color:var(--blue)}.badge-warning{background:var(--yellow-soft);color:var(--yellow)}.badge-danger{background:var(--red-soft);color:var(--red)}.badge-secondary{background:var(--bg-hover);color:var(--text-secondary)}.modal-overlay{position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;animation:modalFadeIn .15s ease}.modal-box{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 32px rgba(0,0,0,.3);width:100%;max-width:380px;padding:1.5rem;animation:modalSlideIn .15s ease}.modal-body{margin-bottom:1.25rem}.modal-body p{margin:0;font-size:.92rem;color:var(--text-primary);line-height:1.5}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem}@keyframes modalFadeIn{from{opacity:0}to{opacity:1}}@keyframes modalSlideIn{from{opacity:0;transform:translateY(-8px) scale(0.97)}to{opacity:1;transform:translateY(0) scale(1)}}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.empty-state .empty-icon{font-size:2.5rem;margin-bottom:1rem;opacity:.5}.empty-state p{margin-bottom:1rem}.action-right{margin-top:.75rem;text-align:right}.usage-bar-track{height:6px;background:var(--border);border-radius:3px;margin-top:.75rem;overflow:hidden}.usage-bar-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .4s ease}.mono{font-family:"SF Mono","Fira Code","Cascadia Code",monospace}code,.code-block{font-family:"SF Mono","Fira Code","Cascadia Code",monospace;font-size:.82rem}.code-block{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.75rem 1rem;overflow-x:auto;color:var(--text-secondary)}.filter-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.5rem}.project-filter{max-width:320px}.project-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));gap:.75rem}.project-card{display:flex;flex-direction:column;gap:.6rem;padding:1.15rem 1.25rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);transition:all .15s;color:var(--text-primary);text-decoration:none}.project-card:hover{border-color:var(--accent);background:var(--bg-hover);color:var(--text-primary)}.project-card .project-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);flex-shrink:0}.project-card .project-name{font-weight:500;font-size:.95rem;word-break:break-word}.project-card .project-role{font-size:.72rem;align-self:flex-start}.project-card--create{border-style:dashed;justify-content:center}.project-card--create:hover{border-color:var(--border-light);background:var(--bg-surface)}.project-card--invite{border-color:var(--accent);border-left:3px solid var(--accent);cursor:default}.project-card--invite:hover{border-color:var(--accent);background:var(--bg-surface)}.invite-header{display:flex;align-items:center;gap:.4rem;color:var(--accent);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.invite-label{line-height:1}.invite-actions{display:flex;gap:.5rem;margin-top:.25rem}.badge-pending{background:var(--warning, #e6a817);color:#fff;font-size:.68rem;padding:.1em .5em;border-radius:3px;margin-left:.4rem;vertical-align:middle}.project-create-form{display:flex;flex-direction:column;gap:.6rem;margin-top:0}.project-create-form .form-control{font-size:.85rem}.project-create-icon{font-size:1.5rem;color:var(--text-muted);font-weight:300;line-height:1}.member-list{display:flex;flex-direction:column}.member-row{display:flex;align-items:center;gap:.85rem;padding:.75rem 0;border-bottom:1px solid var(--border)}.member-row:last-child{border-bottom:none}.member-avatar{width:34px;height:34px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:600;flex-shrink:0;letter-spacing:.02em}.member-info{flex:1;min-width:0}.member-name{font-size:.88rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-mail{font-size:.78rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-meta{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.member-meta>*{display:flex;align-items:center}.member-meta form{margin-top:0}.member-since{font-size:.75rem;color:var(--text-muted);white-space:nowrap;height:1.85rem;display:flex;align-items:center}.member-you{font-size:.7rem;color:var(--text-muted);background:var(--bg-hover);padding:.15rem .5rem;border-radius:3px}.add-member-row{display:flex;gap:.6rem;align-items:flex-end;flex-wrap:wrap}.add-member-row .form-group{margin-bottom:0}.add-member-row .fg-email{flex:1;min-width:180px}.add-member-row .fg-role{min-width:140px}.add-member-row .fg-btn{padding-bottom:1px}.content-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.content-header-actions{padding-top:.25rem;flex-shrink:0}.perm-matrix-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.perm-matrix{width:100%;border-collapse:collapse;min-width:500px}.perm-matrix th,.perm-matrix td{padding:.5rem .7rem;border-bottom:1px solid var(--border);font-size:.85rem;vertical-align:middle}.perm-matrix th{color:var(--text-muted);font-weight:500;text-align:center;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.perm-matrix .perm-matrix-label{text-align:left;min-width:220px}.perm-matrix .perm-matrix-role{min-width:100px;max-width:160px;position:relative}.perm-matrix .perm-matrix-role-name{display:block;margin-bottom:.2rem}.perm-matrix .perm-matrix-group::before{content:"";display:table-row;height:1.25rem}.perm-matrix .perm-matrix-group td{background:var(--bg-secondary);border-bottom-color:var(--border-light);border-bottom-width:.5px}.perm-matrix .perm-matrix-group .perm-matrix-group-row td{padding-top:.85rem}.perm-matrix .perm-matrix-group tr:last-child td{border-bottom:none}.perm-matrix .perm-matrix-group-row td{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding-bottom:.35rem;border-bottom:none}.perm-matrix td{color:var(--text-secondary)}.perm-matrix input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}.btn-icon{background:none;border:none;cursor:pointer;font-size:1rem;line-height:1;padding:.15rem .35rem;border-radius:var(--radius-sm);color:var(--text-muted);transition:color .15s,background .15s}.btn-icon:hover{color:var(--text-primary);background:var(--bg-hover)}.btn-icon-danger:hover{color:var(--red);background:var(--red-soft)}.perm-matrix-delete{margin-top:.15rem}.perm-matrix-footer{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;margin-top:1.25rem;padding-top:.75rem}.perm-unsaved{font-size:.8rem;color:var(--yellow)}.perm-matrix-wrap{margin-bottom:.5rem}.translation-table{width:100%;border-collapse:collapse;font-size:.85rem}.translation-table th{text-align:left;color:var(--text-muted);font-weight:500;padding:.5rem .6rem;border-bottom:1px solid var(--border);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.translation-table td{padding:.55rem .6rem;border-bottom:1px solid var(--border);color:var(--text-secondary);vertical-align:middle}.translation-table tr:hover td{background:var(--bg-hover)}.translation-table .col-source{width:40%}.translation-table .col-translation{width:40%}.translation-table .col-status{width:20%}.translation-source{font-size:.85rem;color:var(--text-secondary)}.mono{font-family:"JetBrains Mono","Fira Code","Cascadia Code","Consolas",monospace;font-size:.82em;letter-spacing:-0.01em}.inst-status-bar{display:flex;gap:.4rem;margin-bottom:1.25rem;flex-wrap:wrap}.inst-counter{display:flex;align-items:center;gap:.4rem;padding:.35rem .75rem;border-radius:var(--radius-sm);background:var(--bg-surface);border:1px solid var(--border);font-size:.78rem;color:var(--text-secondary)}.inst-counter-val{font-weight:700;font-family:"JetBrains Mono","Fira Code","Consolas",monospace;font-size:.9rem;color:var(--text-primary)}.inst-counter--running .inst-counter-val{color:var(--accent)}.inst-counter--stopped .inst-counter-val{color:var(--text-muted)}.inst-counter--error .inst-counter-val{color:var(--red)}.inst-counter--scheduled .inst-counter-val{color:var(--yellow)}.inst-counter-label{text-transform:uppercase;letter-spacing:.04em;font-size:.65rem;font-weight:600}.inst-create-toggle{margin-bottom:1.25rem}.inst-create-toggle>summary{cursor:pointer;list-style:none;display:inline-flex}.inst-create-toggle>summary::-webkit-details-marker{display:none}.inst-create-toggle>summary::marker{display:none;content:""}.inst-create-toggle[open]>summary{margin-bottom:.75rem}.inst-create-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.15rem}.inst-schedule-toggle{margin:.75rem 0;padding-top:.5rem;border-top:1px solid var(--border)}.inst-schedule-check{display:inline-flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--text-secondary);cursor:pointer}.inst-schedule-check input[type=checkbox]{accent-color:var(--accent)}.inst-schedule-fields{margin-top:.65rem}.inst-table{width:100%;font-size:.82rem}.inst-table th{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:600;padding:.5rem .6rem;border-bottom:1px solid var(--border);white-space:nowrap}.inst-table td{padding:.55rem .6rem;border-bottom:1px solid var(--border);vertical-align:middle;white-space:nowrap}.inst-table tbody tr{transition:background .12s}.inst-table tbody tr:hover{background:var(--bg-hover)}.inst-th-status{width:24px}.inst-dot{display:inline-block;width:8px;height:8px;border-radius:50%;vertical-align:middle}.inst-dot--running{background:var(--accent);box-shadow:0 0 6px rgba(16,163,127,.55);animation:inst-pulse 2s ease-in-out infinite}.inst-dot--stopped{background:var(--text-muted);opacity:.6}.inst-dot--error{background:var(--red);box-shadow:0 0 6px rgba(239,68,68,.4)}.inst-dot--scheduled{background:var(--yellow);box-shadow:0 0 5px rgba(234,179,8,.35)}@keyframes inst-pulse{0%,100%{opacity:1}50%{opacity:.45}}.inst-row-active{background:rgba(16,163,127,.035)}.inst-row-scheduled{background:rgba(234,179,8,.02)}.inst-row-past{opacity:.5}.inst-link{color:var(--text-primary);text-decoration:none;font-weight:500}.inst-link:hover{color:var(--accent)}.inst-id{display:inline-block;margin-left:.4rem;font-size:.7rem;color:var(--text-muted);opacity:.7}.inst-rate{color:var(--text-secondary);font-size:.78rem}.inst-rate-unit{font-size:.65rem;color:var(--text-muted);margin-left:1px}.inst-uptime{color:var(--accent);font-weight:500}.inst-sched-name{font-weight:500;color:var(--text-primary)}.inst-repeat-badge{display:inline-block;margin-left:.35rem;font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;background:var(--yellow-soft);color:var(--yellow);padding:.1rem .35rem;border-radius:3px}.inst-sched-time{color:var(--text-secondary)}.inst-sched-time--pending{color:var(--yellow);font-weight:500}.inst-actions-cell{display:flex;gap:.3rem;align-items:center;justify-content:flex-end}.inline-form{display:inline-flex}.inst-btn{display:inline-flex;align-items:center;justify-content:center;position:relative;width:28px;height:28px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text-secondary);font-size:.72rem;cursor:pointer;transition:background .12s,border-color .12s,color .12s;text-decoration:none}.inst-btn:hover{background:var(--bg-hover);border-color:var(--border-light);color:var(--text-primary)}.inst-btn--start{color:var(--accent);border-color:rgba(16,163,127,.3)}.inst-btn--start:hover{background:var(--accent-soft);color:var(--accent)}.inst-btn--stop{color:var(--red);border-color:rgba(239,68,68,.25)}.inst-btn--stop:hover{background:var(--red-soft);color:var(--red)}.inst-btn--open{color:var(--blue);border-color:rgba(59,130,246,.25);font-size:.8rem}.inst-btn--open:hover{background:var(--blue-soft);color:var(--blue)}.inst-btn--connect{width:auto;padding:0 .5rem;gap:.35rem;color:var(--blue);border-color:rgba(59,130,246,.25);font-size:.78rem;white-space:nowrap}.inst-btn--connect:hover{background:var(--blue-soft);color:var(--blue)}.inst-btn--copy{color:var(--text-muted);font-size:.8rem}.inst-btn--copy:hover{background:var(--bg-hover);border-color:var(--border-light);color:var(--text-primary)}.inst-btn--loading{pointer-events:none;opacity:.45}.inst-btn--loading .inst-btn-label{visibility:hidden}.inst-btn--loading::after{content:"";display:block;width:10px;height:10px;border:1.5px solid currentColor;border-right-color:rgba(0,0,0,0);border-radius:50%;animation:inst-btn-spin .6s linear infinite;flex-shrink:0}.inst-btn--loading:not(.inst-btn--connect) svg{visibility:hidden}.inst-btn--loading:not(.inst-btn--connect)::after{position:absolute}@keyframes inst-btn-spin{to{transform:rotate(360deg)}}.inst-btn-label{font-size:.72rem;line-height:1}.instance-form-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));gap:.75rem 1rem;margin-bottom:1rem}.instance-detail-status{display:flex;align-items:center;gap:.6rem}.instance-detail-actions{display:flex;gap:.5rem;flex-wrap:wrap}.instance-type-form-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(160px, 1fr));gap:.75rem 1rem;margin-bottom:1rem}.form-actions{display:flex;gap:.5rem;align-items:center}.inst-toast{position:fixed;bottom:1.5rem;right:1.5rem;padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.78rem;font-weight:500;color:var(--text-primary);pointer-events:none;opacity:0;transform:translateY(8px);transition:opacity .2s,transform .2s;z-index:9999}.inst-toast--success{background:var(--accent);color:#fff}.inst-toast--error{background:var(--red);color:#fff}.inst-toast--visible{opacity:1;transform:translateY(0)}.pod-log-output{background:var(--bg-dark, #0d1117);color:var(--text-muted, #8b949e);font-family:"Menlo","Consolas","Courier New",monospace;font-size:.72rem;line-height:1.5;padding:.75rem 1rem;border-radius:6px;max-height:28rem;overflow:auto;white-space:pre-wrap;word-break:break-all;margin:0}@media(max-width: 768px){.inst-table{display:block;overflow-x:auto}.inst-status-bar{gap:.3rem}.inst-counter{padding:.25rem .5rem}.instance-form-grid,.instance-type-form-grid{grid-template-columns:1fr}}.preset-list{display:flex;flex-direction:column;gap:0}.preset-row{display:flex;align-items:center;gap:1rem;padding:.85rem 1rem;border-bottom:1px solid var(--border);transition:background .15s}.preset-row:last-child{border-bottom:none}.preset-row:hover{background:var(--bg-hover)}.preset-info{flex:1;min-width:0}.preset-name{font-size:.92rem;font-weight:500;color:var(--text-primary)}.preset-desc{font-size:.8rem;color:var(--text-secondary);margin-top:.1rem}.preset-meta{font-size:.72rem;color:var(--text-muted);margin-top:.2rem}.preset-actions{display:flex;gap:.4rem;flex-shrink:0}.preset-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem 1rem;margin-bottom:.75rem}@media(max-width: 640px){.preset-row{flex-wrap:wrap}.preset-actions{width:100%}.preset-form-grid{grid-template-columns:1fr}}.res-breadcrumbs{display:flex;align-items:center;gap:.35rem;padding:.5rem .75rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.85rem;overflow-x:auto;white-space:nowrap}.res-crumb{color:var(--text-secondary);text-decoration:none;display:inline-flex;align-items:center;gap:.3rem}.res-crumb:hover{color:var(--accent)}.res-crumb:last-child{color:var(--text-primary);font-weight:500}.res-crumb-sep{color:var(--text-muted);font-size:.8rem}.res-toolbar{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap}.res-upload-form{display:flex;align-items:center}.res-upload-btn{cursor:pointer;display:inline-flex;align-items:center;gap:.35rem}.res-folder-form{display:flex;align-items:center;gap:.35rem}.res-folder-input{width:160px}.res-dropzone{border:2px dashed var(--border);border-radius:var(--radius);padding:1.5rem;text-align:center;transition:border-color .2s,background .2s;margin-bottom:1rem}.res-dropzone-inner{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--text-muted);pointer-events:none}.res-dropzone-inner p{margin:0;font-size:.85rem}.res-dropzone--active{border-color:var(--accent);background:var(--accent-soft)}.res-dropzone--active .res-dropzone-inner{color:var(--accent)}.res-table .res-th-icon{width:32px;padding-right:0}.res-icon-cell{width:32px;padding-right:0;color:var(--text-muted)}.res-row--folder .res-icon-cell{color:var(--yellow)}.res-name{color:var(--text-primary);text-decoration:none;font-weight:450}.res-name:hover{color:var(--accent)}.res-folder-link{font-weight:500}.res-actions{display:flex;align-items:center;gap:.35rem;justify-content:flex-end}.res-upload-toast{position:fixed;bottom:1.5rem;right:2rem;width:340px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem 1rem;z-index:200;box-shadow:0 8px 24px rgba(0,0,0,.4);transform:translateY(120%);opacity:0;transition:transform .3s ease,opacity .3s ease;pointer-events:none}.res-upload-toast--visible{transform:translateY(0);opacity:1;pointer-events:auto}.res-upload-toast-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.85rem;font-weight:500;color:var(--text-primary)}.res-upload-toast-bar{height:6px;background:var(--bg-hover);border-radius:3px;overflow:hidden;margin-bottom:.4rem}.res-upload-toast-fill{height:100%;width:0;background:var(--accent);border-radius:3px;transition:width .25s ease}.res-upload-toast--done .res-upload-toast-fill{background:var(--accent)}.res-upload-toast--error .res-upload-toast-fill{background:var(--red)}.res-upload-toast-detail{margin:0;font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.res-upload-toast--done .res-upload-toast-header{color:var(--accent)}.res-upload-toast--error .res-upload-toast-header{color:var(--red)}.btn-icon-danger{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.2rem;border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;transition:color .15s,background .15s}.btn-icon-danger:hover{color:var(--red);background:var(--red-soft)}.res-error-detail{margin-top:1rem;padding:.75rem 1rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--red);font-size:.75rem;font-family:monospace;white-space:pre-wrap;word-break:break-all;max-height:200px;overflow-y:auto;text-align:left;display:inline-block;max-width:600px}.cluster-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));gap:1rem;margin-bottom:1.5rem}.cluster-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.cluster-card-header{display:flex;align-items:center;gap:.5rem;padding:.65rem 1rem;border-bottom:1px solid var(--border);font-size:.82rem;font-weight:600;color:var(--text-primary)}.cluster-card-header .icon{color:var(--text-muted)}.cluster-card-header .badge{margin-left:auto}.cluster-card-body{padding:.75rem 1rem}.cluster-kv{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;padding:.3rem 0;font-size:.78rem}.cluster-kv+.cluster-kv{border-top:1px solid var(--border)}.cluster-kv-label{color:var(--text-muted);font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;font-weight:600;white-space:nowrap;flex-shrink:0}.cluster-kv-val{color:var(--text-primary);text-align:right;word-break:break-all}.cluster-kv-truncate{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cluster-kv--error .cluster-kv-val{color:var(--red);font-size:.72rem}.cluster-scale-actions{display:flex;align-items:center;gap:.35rem;margin-top:.65rem;padding-top:.65rem;border-top:1px solid var(--border)}.cluster-scale-actions .btn-sm{min-width:2rem;text-align:center;padding:.3rem .5rem;font-family:"JetBrains Mono","Consolas",monospace;font-size:.75rem}.cluster-scale-actions .btn-sm--active{background:var(--accent);color:#fff;border-color:var(--accent)}.cluster-scale-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-left:.25rem}.cluster-section{margin-top:1.25rem}.cluster-section-title{font-size:.95rem;font-weight:600;margin-bottom:.75rem;color:var(--text-primary);display:flex;align-items:center;gap:.4rem}.cluster-section-title .badge{font-size:.7rem}.cluster-section-title svg{color:var(--text-secondary)}.cluster-section-hint{font-size:.72rem;font-weight:400;color:var(--text-muted);margin-left:.25rem}.cluster-section-subtitle{font-size:.78rem;font-weight:600;color:var(--text-secondary);margin:.75rem 0 .5rem}.cluster-pods-table{font-size:.78rem}.cluster-pods-table th{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:600}.cluster-pods-table .mono{font-family:"JetBrains Mono","Fira Code","Consolas",monospace;font-size:.75rem;letter-spacing:-0.01em}.cluster-link{color:var(--text-secondary)}.cluster-link:hover{color:var(--accent)}.cluster-node-usage{margin-top:.5rem}.cluster-node-bars{display:flex;flex-direction:column;gap:.4rem}.cluster-node-bar{display:flex;align-items:center;gap:.65rem}.cluster-node-name{font-size:.7rem;color:var(--text-secondary);min-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cluster-bar-track{flex:1;height:6px;background:var(--bg-hover);border-radius:3px;overflow:hidden}.cluster-bar-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .3s ease}.cluster-node-count{font-size:.72rem;color:var(--text-secondary);min-width:2.5rem;text-align:right}.cluster-empty{color:var(--text-muted);font-size:.85rem;padding:1.5rem 0;text-align:center}.cluster-resources-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));gap:.65rem}.cluster-res-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:.65rem .75rem;display:flex;flex-direction:column;gap:.45rem}.cluster-res-card--ok{border-color:rgba(16,163,127,.25)}.cluster-res-card--warn{border-color:rgba(234,179,8,.35)}.cluster-res-header{display:flex;align-items:center;justify-content:space-between;gap:.4rem}.cluster-res-id{font-size:.75rem;color:var(--text-primary);font-weight:600;letter-spacing:-0.01em}.cluster-res-items{display:flex;gap:.3rem;flex-wrap:wrap}.cluster-res-item{display:inline-flex;align-items:center;gap:.2rem;padding:.15rem .4rem;border-radius:var(--radius-sm);font-size:.65rem;font-weight:600;letter-spacing:.02em;border:1px solid rgba(0,0,0,0)}.cluster-res-item--ok{background:rgba(16,163,127,.1);color:var(--accent);border-color:rgba(16,163,127,.2)}.cluster-res-item--miss{background:rgba(239,68,68,.08);color:var(--red);border-color:rgba(239,68,68,.2);opacity:.7}.cluster-res-item--pend{background:rgba(234,179,8,.1);color:var(--yellow, #eab308);border-color:rgba(234,179,8,.25)}.cluster-res-item--term{background:rgba(156,163,175,.1);color:var(--text-muted);border-color:rgba(156,163,175,.25);text-decoration:line-through}.cluster-res-item--err{background:rgba(239,68,68,.1);color:var(--red);border-color:rgba(239,68,68,.25)}.cluster-res-node{font-size:.65rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cluster-res-nlb{font-size:.6rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;opacity:.7}.log-filters{margin-bottom:1rem}.log-filters .form-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.75rem}.form-group-inline{display:flex;flex-direction:column;gap:.25rem}.form-group-inline label{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.log-row.log-level-error{background:var(--red-soft)}.log-row.log-level-warning{background:var(--yellow-soft)}.log-detail-row td{padding:0}.log-detail{margin:0;padding:.5rem 1rem;background:var(--bg-primary);border-top:1px solid var(--border);border-bottom:1px solid var(--border);font-size:.72rem;color:var(--text-secondary);white-space:pre-wrap;word-break:break-all;max-height:10rem;overflow-y:auto}.log-purge-form .form-inline{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;font-size:.82rem}.text-mono{font-family:"Courier New",Courier,monospace}.text-sm{font-size:.78rem}.text-xs{font-size:.68rem}.text-muted{color:var(--text-muted)}.pagination{display:flex;align-items:center;gap:.75rem;margin-top:1rem;font-size:.82rem}.pagination-info{color:var(--text-secondary)}.mt-3{margin-top:1rem}.mb-3{margin-bottom:1rem}.mr-2{margin-right:.5rem}.text-muted{color:var(--text-muted);font-size:.875rem}.text-secondary{color:var(--text-secondary)}.text-positive{color:var(--accent)}.text-negative{color:var(--red)}.text-warning{color:var(--yellow)}.text-info{color:var(--blue)}.text-xs{font-size:.75rem}.text-sm{font-size:.85rem}.text-center{text-align:center}.text-right{text-align:right}.mt-0{margin-top:0}.mb-0{margin-bottom:0}.mt-1{margin-top:.25rem}.mb-1{margin-bottom:.25rem}.mt-2{margin-top:.5rem}.mb-2{margin-bottom:.5rem}.mt-3{margin-top:.75rem}.mb-3{margin-bottom:.75rem}.mt-4{margin-top:1rem}.mb-4{margin-bottom:1rem}.mt-5{margin-top:1.25rem}.mb-5{margin-bottom:1.25rem}.mt-6{margin-top:1.5rem}.mb-6{margin-bottom:1.5rem}.mt-8{margin-top:2rem}.mb-8{margin-bottom:2rem}.d-flex{display:flex}.d-inline{display:inline}.d-inline-block{display:inline-block}.flex-1{flex:1}.flex-col{flex-direction:column}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.w-auto{width:auto}.w-full{width:100%}.m-0{margin:0}.mb-0{margin-bottom:0}@media(max-width: 768px){.sidebar{display:none}.app-main{margin-left:0}.main{padding:1.5rem 1rem}.card-grid{grid-template-columns:1fr}.project-grid{grid-template-columns:1fr}.form-row{flex-direction:column;gap:0}.role-header{flex-direction:column;align-items:stretch;gap:.5rem}}
