:root{--bg-primary: #0f0f12;--bg-secondary: #18181c;--bg-tertiary: #222228;--border: #2e2e36;--text-primary: #f4f4f5;--text-secondary: #a1a1aa;--text-muted: #71717a;--accent: #6366f1;--accent-hover: #818cf8;--accent-muted: rgba(99, 102, 241, .15);--success: #22c55e;--danger: #ef4444;--radius: 8px;--radius-lg: 12px;--font: "DM Sans", -apple-system, sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100vh}@supports (padding: env(safe-area-inset-top)){body{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-header{height:56px;border-bottom:1px solid var(--border);background:var(--bg-secondary);display:flex;align-items:center;justify-content:space-between;padding:0 24px;gap:16px}.app-header-left{display:flex;align-items:center;gap:16px;min-width:0}.app-header-title{font-size:.9375rem;color:var(--text-secondary);font-weight:500}.app-header-right{display:flex;align-items:center;gap:12px;margin-left:auto}.app-header-refresh{width:40px;height:40px;border-radius:50%;border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .2s,background .2s,transform .2s}.app-header-refresh:hover{background:var(--accent-muted);color:var(--accent);border-color:var(--accent)}.app-header-refresh:active{transform:scale(.95)}.app-header-refresh-spin svg{animation:refresh-spin .6s ease-out}@keyframes refresh-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app-logo{font-weight:700;font-size:1.125rem;color:var(--text-primary);text-decoration:none;flex-shrink:0}.app-logo:hover{color:var(--text-primary)}.app-header-user{position:relative}.app-header-user-trigger{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:var(--radius);border:1px solid transparent;background:transparent;color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:background .15s,border-color .15s}.app-header-user-trigger:hover{background:var(--bg-tertiary);border-color:var(--border)}.app-header-user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-muted);color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem}.app-header-user-name{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-header-user-chevron{opacity:.7;transition:transform .2s}.app-header-user-trigger[aria-expanded=true] .app-header-user-chevron{transform:rotate(180deg)}.app-header-user-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:240px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 10px 40px #0006;padding:8px 0;z-index:1001;animation:modalSlideIn .2s ease-out}.app-header-user-menu-header{padding:12px 16px;display:flex;flex-direction:column;gap:2px}.app-header-user-menu-name{font-weight:600;font-size:.9375rem;color:var(--text-primary)}.app-header-user-menu-email{font-size:.8125rem;color:var(--text-muted)}.app-header-user-menu-role{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;margin-top:4px}.app-header-user-menu-divider{height:1px;background:var(--border);margin:4px 0}.app-header-user-menu-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px 16px;border:none;background:none;color:var(--text-primary);font-size:.875rem;text-align:left;cursor:pointer;transition:background .15s}.app-header-user-menu-item:hover{background:var(--bg-tertiary)}.app-header-user-menu-item-danger{color:var(--danger)}.app-header-user-menu-item-danger:hover{background:#ef44441a}.app-main{flex:1;display:flex;overflow:hidden}.sidebar{width:260px;border-right:1px solid var(--border);background:var(--bg-secondary);padding:16px 0;overflow-y:auto}.sidebar-nav a{display:flex;align-items:center;gap:10px;padding:10px 20px;color:var(--text-secondary);border-radius:var(--radius);margin:0 8px 2px}.sidebar-nav a:hover,.sidebar-nav a.active{background:var(--accent-muted);color:var(--accent)}.content{flex:1;overflow:auto;padding:24px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;border-radius:var(--radius);font-weight:500;font-size:.875rem;border:none;transition:background .15s,color .15s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-danger{background:#ef444426;color:var(--danger)}.btn-danger:hover{background:#ef444440}.btn-sm{padding:6px 12px;font-size:.8125rem}.input{width:100%;padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:.875rem}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-muted)}.card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.table-wrap{overflow:auto;border-radius:var(--radius);border:1px solid var(--border)}table{width:100%;border-collapse:collapse;font-size:.875rem}th,td{text-align:left;padding:12px 16px;border-bottom:1px solid var(--border)}th{background:var(--bg-tertiary);color:var(--text-secondary);font-weight:600}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg-tertiary)}.page-title{font-size:1.5rem;font-weight:600;margin-bottom:24px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:.875rem;font-weight:500;color:var(--text-secondary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-overlay-blur{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.96) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;min-width:360px;max-width:90vw}.modal-scrollable{max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.modal-scrollable .table-wrap{flex:1;min-height:0}.modal h2{font-size:1.125rem;margin-bottom:16px}.confirm-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;padding:28px;min-width:400px;max-width:90vw;box-shadow:0 25px 50px -12px #00000080;animation:modalSlideIn .25s ease-out}.confirm-modal-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:16px;flex-shrink:0}.confirm-modal-icon.danger{background:#ef444426;color:var(--danger)}.confirm-modal-title{font-size:1.125rem;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.confirm-modal-message{font-size:.9375rem;color:var(--text-secondary);line-height:1.6;margin-bottom:24px}.confirm-modal-actions{display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap}.confirm-modal-actions .btn-danger-solid{background:var(--danger);color:#fff;border:none}.confirm-modal-actions .btn-danger-solid:hover{background:#dc2626}.embed-container{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;background:var(--bg-primary)}.embed-container iframe{flex:1;width:100%;height:100%;border:none}.tree-folder,.tree-file{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--radius);cursor:pointer;font-size:.875rem}.tree-folder:hover,.tree-file:hover{background:var(--bg-tertiary)}.tree-children{margin-left:20px;border-left:1px solid var(--border);margin-bottom:4px}.content-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.content-header-actions{display:flex;gap:8px;flex-wrap:wrap}.sidebar-drawer-close{display:none}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted);font-size:.9375rem}.login-page{align-items:center;justify-content:center;padding:16px}.login-card{width:100%;max-width:400px}@media (max-width: 1024px){.app-main{flex-direction:column}.sidebar{width:100%;max-width:100%;border-right:none;border-bottom:1px solid var(--border);padding:12px 16px;max-height:none}.sidebar-nav{display:flex;flex-direction:row;flex-wrap:wrap;gap:8px;margin:0 0 8px}.sidebar-nav a{margin:0;padding:8px 14px}.content{padding:16px}.page-title{font-size:1.25rem;margin-bottom:16px}.card{padding:16px}.modal{width:100%;max-width:calc(100vw - 32px);margin:16px;max-height:calc(100vh - 32px);overflow:auto}.confirm-modal{min-width:0;width:calc(100vw - 32px);max-width:400px;margin:16px;max-height:calc(100vh - 32px);overflow:auto}}@media (max-width: 768px){.app-header{padding:8px 12px;gap:8px;flex-wrap:wrap;min-height:52px;height:auto}.app-header-left{gap:8px;flex:1 1 auto;min-width:0}.app-header-title{font-size:.8125rem;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-header-right{gap:8px;flex-shrink:0}.app-logo{font-size:1rem}.app-header-refresh{width:44px;height:44px;min-width:44px;min-height:44px}.app-header-user-trigger{padding:8px 10px;min-height:44px}.app-header-user-name{max-width:90px}.app-header-user-menu{min-width:220px;max-width:calc(100vw - 24px);right:0;left:auto}.sidebar-drawer{position:fixed;top:0;left:0;bottom:0;width:280px;max-width:85vw;z-index:1002;transform:translate(-100%);transition:transform .2s ease-out;box-shadow:none;border-right:1px solid var(--border);overflow-y:auto;padding-top:56px}.sidebar-drawer.sidebar-drawer-open{transform:translate(0);box-shadow:8px 0 24px #0000004d}.sidebar-drawer-close{display:flex;position:absolute;top:12px;right:12px;width:40px;height:40px;min-width:40px;min-height:40px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;align-items:center;justify-content:center;padding:0}.sidebar-overlay{display:none}.sidebar-overlay.sidebar-overlay-visible{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1001;animation:fadeIn .2s ease-out}.content{padding:12px}.page-title{font-size:1.125rem;margin-bottom:12px}th,td{padding:10px 12px;font-size:.8125rem}.table-wrap{margin-left:-12px;margin-right:-12px;border-radius:0;border-left:none;border-right:none}.btn{min-height:44px;padding:10px 14px}.btn-sm{min-height:40px;padding:8px 12px}.empty-state{padding:32px 16px}}@media (max-width: 480px){.confirm-modal-actions{flex-direction:column}.confirm-modal-actions .btn{width:100%}.app-header-title,.app-header-user-name{display:none}.content{padding:10px}.modal{min-width:0;max-width:calc(100vw - 20px);margin:10px;padding:16px;max-height:calc(100vh - 20px)}.confirm-modal{padding:20px;margin:10px;width:calc(100vw - 20px)}.modal h2{font-size:1rem;margin-bottom:12px}.tree-folder,.tree-file{padding:10px 12px;min-height:44px}.tree-children{margin-left:16px}}@media (hover: none) and (pointer: coarse){.btn{min-height:44px}.btn-sm{min-height:40px}.app-header-refresh{min-width:44px;min-height:44px}.app-header-user-trigger{min-height:44px}.sidebar-nav a{min-height:44px;display:inline-flex;align-items:center}}.table-wrap{-webkit-overflow-scrolling:touch}@media (max-width: 768px){.table-wrap table{min-width:520px}td .btn-sm{margin-bottom:4px}}@media (max-width: 480px){.table-wrap table{min-width:400px}}
