@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg-root:#0a0a0f;--bg-sidebar:#0f0f19d9;--bg-card:#161623bf;--bg-card-hover:#1e1e30d9;--bg-input:#19192899;--bg-modal:#0c0c14f2;--bg-badge:#6366f126;--border-subtle:#ffffff0f;--border-default:#ffffff1a;--border-active:#6366f166;--text-primary:#f0f0f5;--text-secondary:#8b8ba3;--text-muted:#5a5a72;--text-accent:#818cf8;--accent-primary:#6366f1;--accent-hover:#818cf8;--accent-glow:#6366f140;--success:#34d399;--warning:#fbbf24;--error:#f87171;--info:#60a5fa;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 12px #00000080;--shadow-lg:0 8px 30px #0009;--shadow-glow:0 0 20px var(--accent-glow);--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:20px;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-8:32px;--sp-10:40px;--sp-12:48px;--sidebar-width:260px;--header-height:64px;--ease:cubic-bezier(.4, 0, .2, 1);--duration-fast:.15s;--duration-normal:.25s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg-root);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6}a{color:var(--text-accent);transition:color var(--duration-fast) var(--ease);text-decoration:none}a:hover{color:var(--accent-hover)}.glass-card{background:var(--bg-card);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--duration-normal) var(--ease);box-shadow:0 1px 2px #0003}.glass-card:hover{background:var(--bg-card-hover);border-color:var(--border-default);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn{align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);border:1px solid var(--border-default);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease);font-size:.875rem;font-weight:500;display:inline-flex}.btn:hover{background:var(--bg-card-hover);border-color:var(--border-active)}.btn-primary{background:linear-gradient(135deg, var(--accent-primary), #a78bfa);color:#fff;border-color:#0000}.btn-primary:hover{background:linear-gradient(135deg, var(--accent-hover), #c4b5fd);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.badge{letter-spacing:.02em;border-radius:999px;align-items:center;gap:4px;padding:2px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-success{color:var(--success);background:#34d39926}.badge-warning{color:var(--warning);background:#fbbf2426}.badge-error{color:var(--error);background:#f8717126}.badge-info{color:var(--info);background:#60a5fa26}.badge-accent{background:var(--bg-badge);color:var(--text-accent)}.input{padding:var(--sp-2) var(--sp-3);background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);transition:border-color var(--duration-fast) var(--ease);outline:none;font-size:.875rem}.input::placeholder{color:var(--text-muted)}.input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-glow)}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;padding:var(--sp-3) var(--sp-4);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-default);font-size:.75rem;font-weight:600}.data-table td{padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border-subtle);font-size:.875rem}.data-table tr:hover td{background:#ffffff05}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes slideIn{0%{opacity:0;transform:translate(-100%)}to{opacity:1;transform:translate(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOverlay{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .4s var(--ease) forwards}.pulse{animation:pulse 2s var(--ease) infinite}.skeleton{background:linear-gradient(90deg, var(--bg-card) 25%, var(--bg-card-hover) 50%, var(--bg-card) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite shimmer}.app-layout{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-sidebar);-webkit-backdrop-filter:blur(20px);border-right:1px solid var(--border-subtle);height:100vh;padding:var(--sp-6) 0;flex-direction:column;display:flex;overflow-y:auto}.sidebar-logo{align-items:center;gap:var(--sp-3);padding:0 var(--sp-6);margin-bottom:var(--sp-8);color:var(--text-primary);background:linear-gradient(135deg, var(--accent-primary), #a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:700;display:flex}.sidebar-logo span{-webkit-text-fill-color:initial;font-size:1.5rem}.sidebar-section{margin-bottom:var(--sp-6)}.sidebar-section-label{padding:0 var(--sp-6);margin-bottom:var(--sp-2);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:.65rem;font-weight:600}.sidebar-link{align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-6);margin:1px var(--sp-2);border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--duration-fast) var(--ease);font-size:.875rem;font-weight:500;text-decoration:none;display:flex}.sidebar-link:hover{color:var(--text-primary);background:#ffffff0a}.sidebar-link.active{background:var(--accent-glow);color:var(--text-accent)}.sidebar-link svg{opacity:.7;width:18px;height:18px}.sidebar-link.active svg{opacity:1}.main-area{flex-direction:column;flex:1;display:flex;overflow:hidden}.top-bar{height:var(--header-height);min-height:var(--header-height);padding:0 var(--sp-8);border-bottom:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(12px);background:#0a0a0f99;justify-content:space-between;align-items:center;display:flex}.top-bar h1{font-size:1.125rem;font-weight:600}.top-bar-right{align-items:center;gap:var(--sp-3);display:flex}.content{padding:var(--sp-8);flex:1;overflow-y:auto}.metric-grid{gap:var(--sp-5);margin-bottom:var(--sp-8);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.metric-card{padding:var(--sp-5) var(--sp-6)}.metric-card .metric-icon{border-radius:var(--radius-md);width:40px;height:40px;margin-bottom:var(--sp-3);justify-content:center;align-items:center;display:flex}.metric-card .metric-value{letter-spacing:-.02em;font-size:1.75rem;font-weight:700;line-height:1.2}.metric-card .metric-label{color:var(--text-secondary);margin-top:var(--sp-1);font-size:.8rem}.page-header{margin-bottom:var(--sp-6);justify-content:space-between;align-items:center;display:flex}.page-header h2{font-size:1.25rem;font-weight:600}.filter-bar{align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-5);flex-wrap:wrap;display:flex}.filter-chip{padding:var(--sp-1) var(--sp-3);border:1px solid var(--border-default);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease);background:0 0;border-radius:999px;font-size:.8rem;font-weight:500}.filter-chip:hover{border-color:var(--border-active);color:var(--text-primary)}.filter-chip.active{background:var(--accent-glow);border-color:var(--accent-primary);color:var(--text-accent)}.vocab-grid{gap:var(--sp-4);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.vocab-card{padding:var(--sp-5);text-align:center;cursor:pointer;flex-direction:column;align-items:center;display:flex}.vocab-card img{object-fit:contain;width:64px;height:64px;margin-bottom:var(--sp-3);border-radius:var(--radius-sm)}.vocab-card .vocab-id{color:var(--text-accent);margin-bottom:var(--sp-1);font-family:SF Mono,Fira Code,monospace;font-size:.8rem}.vocab-card .vocab-label{font-size:.875rem;font-weight:500}.vocab-card .vocab-category{color:var(--text-muted);margin-top:var(--sp-1);font-size:.7rem}.asset-grid{gap:var(--sp-4);grid-template-columns:repeat(auto-fill,minmax(160px,1fr));display:grid}.asset-card{padding:var(--sp-4);text-align:center;cursor:pointer;flex-direction:column;align-items:center;display:flex}.asset-card img{object-fit:contain;width:80px;height:80px;margin-bottom:var(--sp-3);transition:transform var(--duration-normal) var(--ease)}.asset-card:hover img{transform:scale(1.1)}.asset-card .asset-name{color:var(--text-secondary);word-break:break-all;font-family:SF Mono,Fira Code,monospace;font-size:.75rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;animation:fadeIn .2s var(--ease);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-modal);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--sp-8);width:90%;max-width:600px;max-height:80vh;box-shadow:var(--shadow-lg);overflow-y:auto}.modal-header{margin-bottom:var(--sp-5);justify-content:space-between;align-items:center;display:flex}.modal-header h3{font-size:1.125rem;font-weight:600}.modal-close{color:var(--text-muted);cursor:pointer;padding:var(--sp-1);border-radius:var(--radius-sm);transition:color var(--duration-fast) var(--ease);background:0 0;border:none}.modal-close:hover{color:var(--text-primary)}.json-viewer{border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--sp-4);white-space:pre-wrap;word-break:break-all;color:var(--text-secondary);background:#0000004d;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:.8rem;line-height:1.7;overflow-x:auto}.json-key{color:#818cf8}.json-str{color:#34d399}.json-num{color:#fbbf24}.json-bool{color:#f87171}.json-null{color:var(--text-muted);font-style:italic}.status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.status-dot.online{background:var(--success);box-shadow:0 0 6px var(--success)}.status-dot.offline{background:var(--error);box-shadow:0 0 6px var(--error)}.empty-state{padding:var(--sp-12) var(--sp-6);color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state svg{width:48px;height:48px;margin-bottom:var(--sp-4);opacity:.4}.empty-state p{font-size:.9rem}.loader{padding:var(--sp-12);justify-content:center;align-items:center;display:flex}.loader-spinner{border:3px solid var(--border-default);border-top-color:var(--accent-primary);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.section-card{padding:var(--sp-6);margin-bottom:var(--sp-5)}.section-card h3{margin-bottom:var(--sp-4);color:var(--text-primary);font-size:.95rem;font-weight:600}.settings-grid{gap:var(--sp-5);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));display:grid}.setting-item{padding:var(--sp-3) 0;border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;display:flex}.setting-item:last-child{border-bottom:none}.setting-label{font-size:.875rem;font-weight:500}.setting-value{color:var(--text-accent);font-family:SF Mono,Fira Code,monospace;font-size:.8rem}.activity-list{list-style:none}.activity-item{align-items:flex-start;gap:var(--sp-3);padding:var(--sp-3) 0;border-bottom:1px solid var(--border-subtle);display:flex}.activity-item:last-child{border-bottom:none}.activity-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.activity-body{flex:1;min-width:0}.activity-body .activity-title{font-size:.85rem;font-weight:500}.activity-body .activity-meta{color:var(--text-muted);font-size:.75rem}.expand-row td{border-bottom:1px solid var(--border-subtle);padding:0!important}.expand-content{padding:var(--sp-3) var(--sp-4) var(--sp-4)}.chart-container{padding:var(--sp-5) var(--sp-6)}.chart-container h3{margin-bottom:var(--sp-4);font-size:.95rem;font-weight:600}.login-page{background:var(--bg-root);min-height:100vh;padding:var(--sp-6);justify-content:center;align-items:center;display:flex}.login-card{width:100%;max-width:400px;padding:var(--sp-10) var(--sp-8);animation:fadeIn .5s var(--ease) forwards;flex-direction:column;align-items:center;display:flex}.login-logo{margin-bottom:var(--sp-4);font-size:3rem}.login-title{margin-bottom:var(--sp-2);font-size:1.5rem;font-weight:700}.login-subtitle{color:var(--text-secondary);margin-bottom:var(--sp-8);font-size:.875rem}.login-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:var(--sp-2);align-self:flex-start;font-size:.75rem;font-weight:600}.login-input{width:100%;padding:var(--sp-3) var(--sp-4);font-size:.95rem}.login-error{margin-top:var(--sp-3);color:var(--error);align-self:flex-start;font-size:.8rem}.login-btn{width:100%;margin-top:var(--sp-6);padding:var(--sp-3) var(--sp-4);justify-content:center;font-size:.95rem}.login-btn:disabled{opacity:.5;cursor:not-allowed}.dashboard-grid{gap:var(--sp-5);grid-template-columns:1fr 1fr;display:grid}.table-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}.hamburger-btn{color:var(--text-primary);cursor:pointer;padding:var(--sp-2);border-radius:var(--radius-sm);transition:background var(--duration-fast) var(--ease);background:0 0;border:none;display:none}.hamburger-btn:hover{background:#ffffff0f}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99;animation:fadeOverlay .2s var(--ease);background:#0009;display:none;position:fixed;inset:0}.bottom-nav{background:var(--bg-sidebar);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-subtle);z-index:90;height:64px;padding:0 var(--sp-2);display:none;position:fixed;bottom:0;left:0;right:0}.bottom-nav-inner{justify-content:space-around;align-items:center;height:100%;display:flex}.bottom-nav-link{padding:var(--sp-1) var(--sp-2);border-radius:var(--radius-sm);color:var(--text-muted);transition:all var(--duration-fast) var(--ease);flex-direction:column;align-items:center;gap:2px;min-width:56px;font-size:.6rem;font-weight:500;text-decoration:none;display:flex}.bottom-nav-link:hover{color:var(--text-secondary)}.bottom-nav-link.active{color:var(--text-accent)}.bottom-nav-link svg{width:20px;height:20px}.event-card-list{gap:var(--sp-3);flex-direction:column;display:none}.event-card{padding:var(--sp-4)}.event-card-header{margin-bottom:var(--sp-2);justify-content:space-between;align-items:center;display:flex}.event-card-body{gap:var(--sp-1);flex-direction:column;font-size:.85rem;display:flex}.event-card-row{justify-content:space-between;align-items:center;display:flex}.event-card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem}.event-card-value{color:var(--text-secondary);font-size:.85rem}.event-card-payload{margin-top:var(--sp-2);padding-top:var(--sp-2);border-top:1px solid var(--border-subtle)}@media (width<=768px){.sidebar{z-index:100;transition:transform .3s var(--ease);box-shadow:var(--shadow-lg);position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.open{animation:slideIn .3s var(--ease);transform:translate(0)}.sidebar-overlay.visible{display:block}.hamburger-btn{display:flex}.bottom-nav{display:block}.main-area{padding-bottom:64px}.content{padding:var(--sp-5)}.top-bar{padding:0 var(--sp-4)}.top-bar h1{font-size:1rem}.dashboard-grid{grid-template-columns:1fr}.metric-grid{gap:var(--sp-3);grid-template-columns:repeat(2,1fr)}.settings-grid{grid-template-columns:1fr}.vocab-grid{gap:var(--sp-3);grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.asset-grid{gap:var(--sp-3);grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.page-header{align-items:flex-start;gap:var(--sp-3);flex-direction:column}.filter-bar{flex-wrap:wrap}.filter-bar>div[style*="flex: 0 0 260px"],.filter-bar>div[style*="flex: 1"]{flex:100%!important;max-width:100%!important}.table-scroll{margin:0 calc(var(--sp-5) * -1);padding:0 var(--sp-5)}.modal-content{width:100%;max-width:100%;height:100%;max-height:100vh;padding:var(--sp-6);border-radius:0}.glass-card:hover{transform:none}.event-card-list{display:flex}.desktop-table-view{display:none}.setting-item{align-items:flex-start;gap:var(--sp-1);flex-direction:column}}@media (width<=480px){.content{padding:var(--sp-4)}.metric-grid{grid-template-columns:1fr}.metric-card .metric-value{font-size:1.4rem}.vocab-grid,.asset-grid{grid-template-columns:repeat(2,1fr)}.vocab-card img{width:48px;height:48px}.filter-chip{padding:var(--sp-2) var(--sp-3);min-height:36px;font-size:.75rem}.btn{min-height:44px;padding:var(--sp-2) var(--sp-4)}.login-card{padding:var(--sp-8) var(--sp-5)}.section-card{padding:var(--sp-4)}.json-viewer{padding:var(--sp-3);font-size:.7rem}}.drop-zone{align-items:center;gap:var(--sp-2);padding:var(--sp-6);border:2px dashed var(--border-default);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s var(--ease);text-align:center;flex-direction:column;display:flex}.drop-zone:hover,.drop-zone-active{border-color:var(--accent);background:#6366f10d}.drop-zone-hint{align-items:center;gap:var(--sp-2);color:var(--text-muted);margin-top:var(--sp-2);font-size:.8rem;display:flex}.inline-edit-group{gap:var(--sp-1);flex-direction:column;display:flex}.inline-edit-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.inline-edit-input{padding:var(--sp-2) var(--sp-3);border:1px solid var(--border-default);border-radius:var(--radius-md);background:var(--bg-surface);color:var(--text-primary);transition:border-color .2s var(--ease);font-size:.9rem}.inline-edit-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #6366f11a}select.inline-edit-input{appearance:none;padding-right:var(--sp-8);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat}.add-card{justify-content:center;align-items:center;gap:var(--sp-2);border:2px dashed var(--border-default);color:var(--text-muted);transition:all .2s var(--ease);flex-direction:column;min-height:180px;display:flex;background:0 0!important}.add-card:hover{border-color:var(--accent);color:var(--accent);background:#6366f10a!important}.delete-confirm{margin-top:var(--sp-4);padding:var(--sp-4);border-radius:var(--radius-md);gap:var(--sp-2);animation:fadeIn .15s var(--ease);background:#ef444414;border:1px solid #ef444433;flex-direction:column;font-size:.85rem;display:flex}.delete-confirm svg{color:#ef4444}.btn-danger{color:#ef4444;background:#ef44441a;border:1px solid #ef444433}.btn-danger:hover{background:#ef444433}.btn-sm{padding:var(--sp-1) var(--sp-3);min-height:unset;font-size:.78rem}.btn.active{color:var(--accent);background:#6366f126}.version-history{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--sp-5);animation:fadeIn .2s var(--ease)}.version-history-header{align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-4);display:flex}.version-history-header h4{margin:0;font-size:.95rem}.version-restore-default{width:100%;margin-bottom:var(--sp-4);border:1px dashed var(--border-default);justify-content:center}.version-timeline{padding-left:var(--sp-4);flex-direction:column;gap:0;display:flex;position:relative}.version-timeline:before{content:"";background:var(--border-default);width:2px;position:absolute;top:8px;bottom:8px;left:6px}.version-item{gap:var(--sp-3);padding:var(--sp-3) 0;display:flex;position:relative}.version-dot{left:calc(-1 * var(--sp-4) + 2px);top:calc(var(--sp-3) + 4px);background:var(--accent);border:2px solid var(--bg-card);z-index:1;border-radius:50%;width:10px;height:10px;position:absolute}.version-content{flex:1;min-width:0}.version-meta{align-items:center;gap:var(--sp-2);flex-wrap:wrap;display:flex}.version-badge{border-radius:var(--radius-sm);color:var(--accent);background:#6366f11a;padding:2px 6px;font-size:.7rem;font-weight:600}.version-time{color:var(--text-muted);align-items:center;gap:3px;font-size:.7rem;display:flex}.version-summary{color:var(--text-secondary);margin-top:var(--sp-1);font-size:.8rem}.version-info{color:var(--text-muted);font-size:.7rem;font-family:var(--font-mono);margin-top:2px}.version-confirm{margin-top:var(--sp-2);padding:var(--sp-3);border-radius:var(--radius-md);gap:var(--sp-2);animation:fadeIn .15s var(--ease);background:#6366f10f;border:1px solid #6366f126;flex-direction:column;font-size:.8rem;display:flex}.page-header{justify-content:space-between;align-items:center;gap:var(--sp-3);flex-wrap:wrap;display:flex}
