:root{--bg-base: #121212;--bg-surface: #181818;--bg-mid: #1f1f1f;--text-base: #ffffff;--text-muted: #b3b3b3;--text-soft: #cbcbcb;--brand: #1ed760;--brand-press: #1db954;--negative: #f3727f;--warning: #ffa42b;--announcement: #539df5;--border: #4d4d4d;--border-light: #7c7c7c;--status-pending: #ffa42b;--status-pending-bg: rgba(255, 164, 43, .18);--status-approved: #539df5;--status-approved-bg: rgba(83, 157, 245, .18);--status-connected: #1ed760;--status-connected-bg: rgba(30, 215, 96, .18);--status-disconnected: #b3b3b3;--status-disconnected-bg: rgba(179, 179, 179, .18);--status-rejected: #f3727f;--status-rejected-bg: rgba(243, 114, 127, .18);--shadow-card: rgba(0, 0, 0, .3) 0px 8px 8px;--shadow-dialog: rgba(0, 0, 0, .5) 0px 8px 24px;--shadow-inset: rgb(18, 18, 18) 0px 1px 0px, rgb(124, 124, 124) 0px 0px 0px 1px inset;--font-ui: "SpotifyMixUI", "CircularSp-Arab", "CircularSp-Hebr", "CircularSp-Cyrl", "CircularSp-Grek", "CircularSp-Deva", "Helvetica Neue", helvetica, arial, "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Apple SD Gothic Neo", "Pretendard", "Noto Sans KR", "Meiryo", "MS Gothic", sans-serif;--font-title: "SpotifyMixUITitle", var(--font-ui);--font-mono: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg-base);color:var(--text-base);font-family:var(--font-ui);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input{font-family:inherit;color:inherit}a{color:var(--brand)}h1,h2,h3{font-family:var(--font-title);font-weight:700;margin:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;border:0;border-radius:9999px;padding:.6rem 1.4rem;font-size:.88rem;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;cursor:pointer;transition:transform .06s ease,background-color .15s ease,color .15s ease,border-color .15s ease;white-space:nowrap}.btn:active{transform:scale(.98)}.btn[disabled],.btn[aria-busy=true]{opacity:.65;cursor:progress}.btn-primary{background:var(--brand);color:#000}.btn-primary:hover:not([disabled]){background:#1fdf64}.btn-secondary{background:var(--bg-mid);color:var(--text-base)}.btn-secondary:hover:not([disabled]){background:#2a2a2a}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border-light)}.btn-ghost:hover:not([disabled]){color:var(--text-base);border-color:var(--text-base)}.btn-danger{background:var(--negative);color:#000}.btn-danger:hover:not([disabled]){background:#f4848f}.page-login{min-height:100vh;display:grid;place-items:center;padding:1.5rem}.login-wrap{width:100%;max-width:24rem}.brand{text-align:center;margin-bottom:1.5rem}.brand h1{font-size:1.75rem;letter-spacing:-.01em;color:var(--text-base)}.brand-sub{margin:.35rem 0 0;color:var(--text-muted);font-size:.88rem;font-weight:400}.card{background:var(--bg-surface);border-radius:8px;padding:1.75rem 1.5rem;box-shadow:var(--shadow-dialog)}.field{display:block;margin-bottom:1rem}.field-label{display:block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.45rem}.field input{width:100%;background:var(--bg-mid);border:0;border-radius:4px;padding:.7rem .9rem;font-size:1rem;color:var(--text-base);box-shadow:var(--shadow-inset);outline:none;transition:box-shadow .15s ease}.field input:focus{box-shadow:#121212 0 1px,var(--brand) 0 0 0 1px inset}.error{color:var(--negative);font-size:.85rem;min-height:1.2rem;margin:0 0 .75rem}.card .btn-primary{width:100%;padding:.85rem 1.5rem}.page-devices{min-height:100vh}.devices-shell{max-width:1280px;margin:0 auto;padding:1.75rem 1.5rem 3rem}.topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:1.25rem;margin-bottom:1.5rem;flex-wrap:wrap}.topbar-title h1{font-size:1.5rem;letter-spacing:-.01em}.meta{color:var(--text-muted);font-size:.82rem;margin-top:.35rem}.actions{display:flex;gap:.5rem;align-items:center}.actions .btn{padding:.5rem 1.1rem;font-size:.78rem}.status-msg{padding:.85rem 1.1rem;border-radius:8px;margin-bottom:1.25rem;font-size:.92rem;border:1px solid transparent}.status-msg.empty{color:var(--text-muted);background:var(--bg-surface);border-color:var(--border);border-style:dashed;text-align:center}.status-msg.error{color:var(--negative);background:#f3727f1f;border-color:#f3727f73}.status-msg.success{color:var(--brand);background:#1ed7601f;border-color:#1ed76073}.toast-region{position:fixed;right:1.25rem;bottom:1.25rem;z-index:1000;display:flex;flex-direction:column;gap:.6rem;max-width:min(24rem,calc(100vw - 2rem));pointer-events:none}.toast{padding:.85rem 1.1rem;border-radius:8px;font-size:.92rem;color:var(--brand);background:var(--bg-surface);border:1px solid rgba(30,215,96,.45);box-shadow:var(--shadow-dialog);animation:toast-in .2s ease both}.toast.toast-leaving{animation:toast-out .2s ease both}@keyframes toast-in{0%{opacity:0;transform:translateY(.75rem)}to{opacity:1;transform:translateY(0)}}@keyframes toast-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(.75rem)}}@media (max-width: 640px){.toast-region{left:.9rem;right:.9rem;bottom:.9rem;max-width:none}}.table-wrap{margin:0;background:var(--bg-surface);border-radius:8px;box-shadow:var(--shadow-card);overflow-x:auto}.devices-table{width:100%;min-width:56rem;border-collapse:collapse;font-size:.92rem}.devices-table thead th{background:var(--bg-mid);color:var(--text-muted);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;text-align:left;padding:.75rem 1rem;border-bottom:1px solid var(--border);white-space:nowrap}.devices-table tbody td{padding:.8rem 1rem;vertical-align:middle;white-space:nowrap;border-bottom:1px solid rgba(77,77,77,.35);color:var(--text-base)}.devices-table tbody tr:last-child td{border-bottom:0}.devices-table tbody tr:hover td{background:#ffffff08}.devices-table tbody tr.clickable-row{cursor:pointer}.devices-table tbody tr.clickable-row:focus-visible{outline:2px solid var(--brand);outline-offset:-2px}.mono{font-family:var(--font-mono);font-size:.85rem;color:var(--text-soft)}.dash{color:var(--text-muted)}.badge{display:inline-block;padding:.18rem .7rem;border-radius:999px;font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;border:1px solid currentColor;line-height:1.4}.badge-pending{color:var(--status-pending);background:var(--status-pending-bg)}.badge-approved{color:var(--status-approved);background:var(--status-approved-bg)}.badge-connected{color:var(--status-connected);background:var(--status-connected-bg)}.badge-disconnected{color:var(--status-disconnected);background:var(--status-disconnected-bg)}.badge-rejected,.badge-revoked{color:var(--status-rejected);background:var(--status-rejected-bg)}.badge-approved:after{content:"";display:inline-block;width:.9em;text-align:left;animation:connecting-dots 1.4s steps(4,end) infinite}@keyframes connecting-dots{0%{content:""}25%{content:"."}50%{content:".."}75%,to{content:"..."}}.row-actions{display:flex;gap:.4rem;flex-wrap:wrap}.row-actions button{margin:0;padding:.32rem .85rem;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border-radius:9999px;border:1px solid currentColor;background:transparent;cursor:pointer;transition:background-color .15s ease,color .15s ease,border-color .15s ease,transform .06s ease}.row-actions button:active{transform:scale(.97)}.row-actions button[disabled]{opacity:.55;cursor:progress}.row-actions .approve-btn,.row-actions .connect-btn{color:#000;background:var(--brand);border-color:var(--brand)}.row-actions .approve-btn:hover:not([disabled]),.row-actions .connect-btn:hover:not([disabled]){background:#1fdf64;border-color:#1fdf64}.reject-btn{color:var(--negative)}.reject-btn:hover:not([disabled]){background:#f3727f1f}.delete-btn{color:var(--negative)}.delete-btn:hover:not([disabled]){background:#f3727f1f}.disconnect-btn{color:var(--warning)}.disconnect-btn:hover:not([disabled]){background:#ffa42b1f}.revoke-btn{color:var(--warning)}.revoke-btn:hover:not([disabled]){background:#ffa42b2e}@media (max-width: 640px){.devices-shell{padding:1rem .9rem 2rem}.topbar{align-items:stretch}.actions{width:100%;justify-content:flex-end}.devices-table thead th,.devices-table tbody td{padding:.65rem .75rem}}.nav-tabs{display:flex;gap:.4rem;margin:-.25rem 0 1.25rem;border-bottom:1px solid var(--border);padding-bottom:.5rem}.nav-tabs a{display:inline-flex;align-items:center;padding:.45rem 1rem;border-radius:9999px;text-decoration:none;color:var(--text-muted);font-size:.82rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;transition:background-color .15s ease,color .15s ease}.nav-tabs a:hover{color:var(--text-base);background:#ffffff0a}.nav-tabs a.active{color:#000;background:var(--brand)}.page-users{min-height:100vh}.toolbar{display:flex;gap:.6rem;margin-bottom:1rem;flex-wrap:wrap;align-items:center}.toolbar .search{flex:1 1 18rem;display:block;margin:0}.toolbar .search input{width:100%;background:var(--bg-mid);border:0;border-radius:9999px;padding:.6rem 1.1rem;font-size:.95rem;color:var(--text-base);box-shadow:var(--shadow-inset);outline:none;transition:box-shadow .15s ease}.toolbar .search input:focus{box-shadow:#121212 0 1px,var(--brand) 0 0 0 1px inset}.toolbar .btn{padding:.55rem 1.2rem;font-size:.78rem}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.expand-btn{background:transparent;border:1px solid var(--border-light);color:var(--text-base);padding:.28rem .7rem;border-radius:9999px;font-size:.78rem;cursor:pointer;transition:background-color .15s ease,border-color .15s ease}.expand-btn:hover{background:#ffffff0a;border-color:var(--text-base)}.badge.status-active{color:var(--status-connected);background:var(--status-connected-bg)}.badge.status-inactive{color:var(--status-disconnected);background:var(--status-disconnected-bg)}.badge.status-unknown{color:var(--text-muted);background:#b3b3b31f}.row-actions .edit-btn{color:var(--text-base);border-color:var(--border-light)}.row-actions .edit-btn:hover:not([disabled]){border-color:var(--text-base);background:#ffffff0a}.row-actions .force-logout-btn{color:var(--announcement)}.row-actions .force-logout-btn:hover:not([disabled]){background:#539df51f}.row-actions .deactivate-btn{color:var(--warning)}.row-actions .deactivate-btn:hover:not([disabled]){background:#ffa42b1f}.row-actions .activate-btn{color:#000;background:var(--brand);border-color:var(--brand)}.row-actions .activate-btn:hover:not([disabled]){background:#1fdf64;border-color:#1fdf64}.row-actions .detach-btn{color:var(--warning)}.row-actions .detach-btn:hover:not([disabled]){background:#ffa42b1f}.devices-table .expand-row td{background:#ffffff05;padding:1rem 1.25rem;white-space:normal}.expand-wrap{display:flex;flex-direction:column;gap:.75rem}.expand-heading{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.expand-heading h3{font-size:.92rem;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted)}.expand-heading .attach-btn{padding:.4rem 1rem;font-size:.7rem}.device-list{display:flex;flex-direction:column;gap:.5rem}.device-item{display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:.55rem .85rem;background:var(--bg-mid);border-radius:6px;border:1px solid rgba(77,77,77,.4)}.device-main{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;min-width:0}.device-main .device-ip{color:var(--text-muted)}.device-item .detach-btn{margin:0;padding:.32rem .85rem;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border-radius:9999px;border:1px solid currentColor;background:transparent;cursor:pointer}.expand-info{color:var(--text-muted);font-size:.88rem;padding:.5rem 0}dialog.modal{border:0;padding:0;background:transparent;color:var(--text-base);max-width:min(28rem,92vw);width:100%}dialog.modal::backdrop{background:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}dialog.modal form{background:var(--bg-surface);border-radius:10px;padding:1.5rem 1.4rem 1.25rem;box-shadow:var(--shadow-dialog);display:flex;flex-direction:column;gap:.6rem}dialog.modal h2{font-size:1.15rem;margin:0 0 .4rem}dialog.modal .modal-desc{color:var(--text-muted);font-size:.88rem;margin:0 0 .5rem;line-height:1.4}dialog.modal .modal-help{color:var(--text-muted);font-size:.8rem;margin:.25rem 0 0;min-height:1.1rem}dialog.modal .field{margin-bottom:.6rem}dialog.modal .field input:disabled{opacity:.65;cursor:not-allowed}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.6rem}.modal-actions .btn{padding:.55rem 1.2rem;font-size:.78rem}.select{width:100%;background:var(--bg-mid);border:0;border-radius:4px;padding:.7rem 2.2rem .7rem .9rem;font-size:1rem;color:var(--text-base);box-shadow:var(--shadow-inset);outline:none;transition:box-shadow .15s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--text-muted) 50%),linear-gradient(135deg,var(--text-muted) 50%,transparent 50%);background-position:calc(100% - 18px) calc(50% - 2px),calc(100% - 13px) calc(50% - 2px);background-size:5px 5px,5px 5px;background-repeat:no-repeat}.select:focus{box-shadow:#121212 0 1px,var(--brand) 0 0 0 1px inset}@media (max-width: 640px){.device-item{flex-direction:column;align-items:stretch}.device-main{flex-wrap:wrap}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}.dm-info-grid{grid-template-columns:1fr;gap:.15rem 0}.dm-info-grid .dm-info-label{padding-top:.5rem}.dm-detail-grid,.dm-section-wide .dm-section-body{grid-template-columns:1fr}}dialog.modal.modal-wide{max-width:min(72rem,94vw)}.modal-card{position:relative;background:var(--bg-surface);border-radius:10px;padding:1.5rem 1.4rem 1.25rem;box-shadow:var(--shadow-dialog);display:flex;flex-direction:column;gap:.6rem}.modal-card h2{font-size:1.15rem;margin:0 0 .4rem;padding-right:2rem}.modal-card form{display:flex;flex-direction:column;gap:.4rem}.dm-hostname-row{display:flex;align-items:center;gap:.6rem}.dm-hostname-label{flex:none;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);white-space:nowrap}.dm-hostname-input{flex:1 1 auto;min-width:0;background:var(--bg-mid);border:0;border-radius:4px;padding:.5rem .8rem;font-size:.95rem;color:var(--text-base);box-shadow:var(--shadow-inset);outline:none;transition:box-shadow .15s ease}.dm-hostname-input:focus{box-shadow:#121212 0 1px,var(--brand) 0 0 0 1px inset}.dm-hostname-save{flex:none;padding:.55rem 1.2rem;font-size:.78rem}.dm-hostname-form .error{margin:0}.dm-hostname-form .error:empty{display:none}.modal-close{position:absolute;top:.7rem;right:.7rem;width:1.9rem;height:1.9rem;display:inline-flex;align-items:center;justify-content:center;padding:0;border:0;border-radius:9999px;background:transparent;color:var(--text-muted);font-size:.95rem;line-height:1;cursor:pointer;transition:background-color .15s ease,color .15s ease}.modal-close:hover{color:var(--text-base);background:#ffffff0f}.modal-close:focus-visible{outline:2px solid var(--brand);outline-offset:1px}.dm-note{margin:0;font-size:.8rem;color:var(--warning)}.dm-muted{margin:0;font-size:.85rem;color:var(--text-muted)}.dm-metrics-stamp{margin:0;font-size:.78rem}.dm-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;gap:.75rem 1.5rem}.dm-detail-grid>.dm-section-wide,.dm-detail-grid>.dm-metrics-stamp{grid-column:1 / -1}.dm-section{display:flex;flex-direction:column;gap:.5rem;padding-top:.7rem;border-top:1px solid var(--border)}.dm-section h3{font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.dm-section-body{display:flex;flex-direction:column;gap:.6rem}.dm-section-wide .dm-section-body{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.6rem 1.5rem}.dm-section-wide .dm-section-body>.dm-info-grid{grid-column:1 / -1}.dm-info-grid{display:grid;grid-template-columns:max-content 1fr;gap:.35rem 1rem;font-size:.9rem}.dm-info-label{color:var(--text-muted)}.dm-info-value{color:var(--text-base);word-break:break-word}.metric-row{display:flex;flex-direction:column;gap:.3rem}.metric-head{display:flex;justify-content:space-between;align-items:baseline;gap:.75rem;font-size:.9rem}.metric-name{color:var(--text-base);font-weight:700}.metric-figure{color:var(--text-soft);font-variant-numeric:tabular-nums}.metric-detail{font-size:.82rem;color:var(--text-muted)}.metric-bar{height:.5rem;border-radius:9999px;background:var(--bg-mid);overflow:hidden}.metric-bar-fill{height:100%;border-radius:inherit;background:var(--brand);transition:width .2s ease}.metric-bar-fill-warn{background:var(--warning)}.metric-bar-fill-danger{background:var(--negative)}.metric-graph{height:40px;margin-top:.15rem}.sparkline{display:block;width:100%;height:100%;overflow:visible}.sparkline-line{fill:none;stroke:var(--brand);stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}.sparkline-area{fill:var(--brand);fill-opacity:.14;stroke:none}.sparkline-dot{fill:var(--brand);stroke:none}.metric-graph-note{display:flex;align-items:center;font-size:.75rem;color:var(--text-muted)}.devices-table thead th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.devices-table thead th.sortable:hover{color:var(--text-base);background:#2a2a2a}.devices-table thead th.sortable:focus-visible{outline:2px solid var(--brand);outline-offset:-2px}.sort-indicator{display:inline-block;width:1em;margin-left:.2rem;color:var(--brand);font-size:.6rem;vertical-align:middle}.devices-table .select-cell{width:1px;text-align:center;padding-left:.9rem;padding-right:.5rem}.devices-table .select-cell input[type=checkbox]{width:.95rem;height:.95rem;margin:0;vertical-align:middle;accent-color:var(--brand);cursor:pointer}.select-count{margin-left:auto;color:var(--brand);font-size:.82rem;font-weight:700;white-space:nowrap}dialog.modal.modal-terminal{max-width:min(56rem,96vw);width:96vw}.modal-card.ssh-card{padding:0;background:var(--bg-surface);display:flex;flex-direction:column;gap:0}.ssh-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);background:var(--bg-mid)}.ssh-header h2{margin:0;font-size:1rem;font-weight:700;color:var(--text-base);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ssh-meta{flex:1;color:var(--text-muted);font-family:var(--font-mono);font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ssh-header .modal-close{position:static}.ssh-status{padding:.5rem 1rem;min-height:1.5rem;font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg-surface)}.ssh-status.error{color:var(--negative)}.ssh-status.ok{color:var(--brand)}.ssh-term{background:#000;padding:.5rem .75rem;height:min(70vh,36rem);overflow:hidden}.ssh-term .xterm,.ssh-term .xterm-viewport,.ssh-term .xterm-screen{height:100%!important;background:#000!important}.ssh-term .xterm-viewport::-webkit-scrollbar{width:.5rem}.ssh-term .xterm-viewport::-webkit-scrollbar-thumb{background:var(--border);border-radius:.25rem}.ssh-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .7rem;font-family:var(--font-ui);font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;background:var(--bg-mid);color:var(--text-base);border:1px solid var(--border);border-radius:9999px;cursor:pointer;transition:background .12s ease,border-color .12s ease}.ssh-btn:hover{background:var(--border);border-color:var(--border-light)}.ssh-btn:focus-visible{outline:2px solid var(--announcement);outline-offset:2px}@media (max-width: 640px){.ssh-term{height:60vh;padding:.25rem .5rem}.ssh-header{flex-wrap:wrap}}
