:root{--primary: #0e3d52;--primary-hover: #0a3142;--primary-press: #07252f;--primary-grad: linear-gradient(135deg, #0e3d52, #1a6076);--primary-container: #dceef2;--primary-soft: rgba(14, 61, 82, .06);--secondary: #0e7490;--tertiary: #0f766e;--coral: #e07a5f;--coral-strong: #c2603f;--coral-container: #fbe3dd;--success: #1f9d6b;--warning: #f59e0b;--error: #ef4444;--error-container: #ffdad6;--on-error-container: #93000a;--bg: #f7fbfc;--panel: #ffffff;--surface-dim: #f4f8fa;--surface-high: #e6eef1;--line: #eceef3;--line-strong: #e3e1ee;--ink: #1c1a24;--ink-soft: #484555;--muted: #797587;--radius-sm: 10px;--radius: 14px;--radius-lg: 16px;--radius-xl: 20px;--radius-3xl: 24px;--shadow-soft: 0 4px 20px -2px rgba(0, 0, 0, .05);--shadow-card: 0 1px 2px rgba(28, 26, 36, .04), 0 4px 16px rgba(28, 26, 36, .05);--shadow-pop: 0 16px 40px -8px rgba(28, 26, 36, .16);--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}a{color:inherit;text-decoration:none}.app-shell{min-height:100vh}.sidebar{position:fixed;left:0;top:0;bottom:0;width:280px;z-index:30;display:flex;flex-direction:column;padding:28px 16px;background:var(--panel);border-right:1px solid var(--line);overflow:hidden}.brand{display:flex;align-items:center;gap:12px;padding:0 12px 4px}.brand-logo{width:44px;height:44px;object-fit:contain;flex-shrink:0}.brand h1{margin:0;font-size:16px;font-weight:700;letter-spacing:-.01em;color:var(--ink);line-height:1.15}.brand p{margin:0;font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--primary);opacity:.85}.btn-new{display:flex;align-items:center;justify-content:center;gap:8px;margin:24px 0 18px;padding:12px;width:100%;border:0;border-radius:var(--radius);background:var(--primary-grad);color:#fff;font-size:14px;font-weight:600;box-shadow:0 8px 20px #0e3d5259;transition:transform .12s ease,box-shadow .12s ease}.btn-new:hover{transform:translateY(-1px);box-shadow:0 10px 26px #0e3d5273}.nav-scroll{flex:1;min-height:0;overflow-y:auto;padding-bottom:8px}.nav{display:flex;flex-direction:column;gap:4px}.nav-label{margin:20px 16px 8px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.nav-item{display:flex;align-items:center;gap:12px;padding:11px 16px;border-radius:var(--radius);color:var(--ink-soft);font-size:14px;font-weight:500;transition:background .12s ease,color .12s ease}.nav-item:hover{background:var(--primary-soft);color:var(--primary)}.nav-item.active{background:var(--primary-container);color:var(--primary);font-weight:600}.nav-item .dot{display:inline-flex;width:26px;height:26px;align-items:center;justify-content:center;border-radius:9px;color:#fff;flex-shrink:0}.nav-item .truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-loading{display:flex;align-items:center;gap:10px;padding:11px 16px;color:var(--muted);font-size:13px}.sidebar-foot{margin-top:auto;padding-top:16px}.sidebar-user{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--radius);border:1px solid var(--line);background:var(--surface-dim)}.sidebar-user .meta{min-width:0}.sidebar-user .name{font-size:13px;font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user .email{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.avatar{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:11px;background:var(--primary-container);color:var(--primary);font-weight:700;font-size:12px}.avatar.lg{width:38px;height:38px;font-size:13px}.avatar.sm{width:40px;height:40px;border:2px solid var(--primary-container)}.main{margin-left:280px;min-height:100vh;min-width:0}.topbar{position:sticky;top:0;z-index:15;display:flex;align-items:center;gap:16px;height:80px;padding:0 40px;background:var(--panel);border-bottom:1px solid var(--line)}.search{display:flex;align-items:center;gap:10px;flex:1;max-width:580px;padding:11px 16px;border-radius:var(--radius-lg);background:var(--surface-dim);border:1px solid transparent;color:var(--muted);transition:border-color .12s ease,background .12s ease,box-shadow .12s ease}.search:focus-within{background:#fff;border-color:#9fc6d2;box-shadow:0 0 0 3px #0e3d521f}.search input{flex:1;border:0;outline:none;background:transparent;font-size:14px;color:var(--ink)}.search kbd{font-family:var(--font);font-size:10px;font-weight:700;color:var(--muted);background:#fff;border:1px solid var(--line-strong);border-radius:7px;padding:2px 6px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:var(--radius-lg);border:0;background:transparent;color:var(--ink-soft);position:relative;transition:background .12s ease,color .12s ease}.icon-btn:hover{background:var(--surface-high);color:var(--ink)}.icon-btn .badge{position:absolute;top:11px;right:12px;width:8px;height:8px;border-radius:50%;background:var(--error);border:2px solid var(--panel)}.topbar-right{display:flex;align-items:center;gap:16px;margin-left:auto}.topbar-user-wrap{position:relative}.topbar-user{display:flex;align-items:center;gap:12px;padding:6px 8px 6px 16px;border:0;border-left:1px solid var(--line);background:transparent;border-radius:var(--radius);transition:background .12s ease}.topbar-user:hover{background:var(--surface-dim)}.topbar-user>svg{color:var(--muted)}.topbar-user .tu-meta{text-align:right;line-height:1.25}.user-menu{position:absolute;top:calc(100% + 10px);right:0;width:248px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-pop);padding:8px;z-index:40}.user-menu-head{padding:10px 12px;margin-bottom:6px;border-bottom:1px solid var(--line)}.user-menu-head .name{font-size:14px;font-weight:700;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-head .email{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:0;background:transparent;border-radius:var(--radius-sm);font-size:14px;font-weight:500;color:var(--ink-soft);text-align:left}.user-menu-item:hover{background:var(--surface-dim);color:var(--primary)}.user-menu-item.danger:hover{background:var(--error-container);color:var(--error)}.topbar-user .tu-name{font-size:14px;font-weight:700;color:var(--ink)}.topbar-user .tu-role{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--primary)}.menu-btn{display:none}.page{padding:40px;position:relative;z-index:1}.main:before{content:"";position:fixed;right:-100px;bottom:-120px;width:540px;height:540px;background:url(/entreamigos-mark.png) no-repeat center / contain;filter:blur(7px) saturate(1.1);opacity:.07;pointer-events:none;z-index:0}.greeting{font-size:28px;font-weight:700;letter-spacing:-.02em;margin:0}.subtitle{margin:6px 0 0;color:var(--ink-soft);font-size:14px}.section-head{display:flex;align-items:center;justify-content:space-between;margin:36px 0 24px}.section-head h2{font-size:22px;font-weight:700;letter-spacing:-.01em;margin:0}.link-more{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--line-strong);border-radius:999px;background:var(--panel);color:var(--primary);font:inherit;font-size:13px;font-weight:700;cursor:pointer;transition:background .15s ease,border-color .15s ease}.link-more:hover{background:var(--primary-soft);border-color:var(--primary)}.link-more svg{transition:transform .15s ease}.link-more:hover svg{transform:translate(2px)}.toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.seg{display:inline-flex;padding:3px;border-radius:var(--radius);border:1px solid var(--line-strong);background:#fff}.seg button{display:inline-flex;align-items:center;justify-content:center;width:34px;height:32px;border:0;border-radius:9px;background:transparent;color:var(--muted)}.seg button.active{background:var(--primary-container);color:var(--primary)}.btn-ghost{display:inline-flex;align-items:center;gap:8px;height:42px;padding:0 18px;border-radius:var(--radius);border:1px solid var(--line-strong);background:#fff;color:var(--ink-soft);font-size:14px;font-weight:600}.btn-ghost:hover{background:var(--surface-dim)}.btn-ghost.active{border-color:#9fc6d2;color:var(--primary)}.btn-primary{display:inline-flex;align-items:center;gap:9px;height:42px;padding:0 22px;border:0;border-radius:var(--radius);background:var(--primary-grad);color:#fff;font-size:14px;font-weight:600;box-shadow:0 8px 20px #0e3d524d;transition:transform .12s ease,opacity .12s ease}.btn-primary:hover{opacity:.92;transform:translateY(-1px)}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px}.card{position:relative;text-align:left;padding:16px;border-radius:var(--radius-lg);border:1px solid var(--line-strong);border-top:3px solid var(--card-accent, var(--primary));background:var(--panel);box-shadow:var(--shadow-soft);overflow:hidden;transition:transform .25s ease,box-shadow .25s ease}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-pop)}.card.active{border:2px solid rgba(14,61,82,.2);box-shadow:0 0 0 4px #0e3d520f,var(--shadow-pop)}.card.active:after{content:"";position:absolute;top:0;right:0;width:72px;height:72px;background:#0e3d520d;border-bottom-left-radius:80px}.card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px;position:relative;z-index:1}.card .tile{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px}.card.active .tile{background:var(--primary-grad)!important;color:#fff!important;box-shadow:0 8px 16px #0e3d524d}.card .title{font-size:15px;font-weight:700;margin:0;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card .sub{margin:2px 0 12px;font-size:11px;color:var(--muted)}.card-foot{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--line)}.chip{display:inline-block;padding:4px 11px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.02em;text-transform:uppercase}.chip-blob{background:var(--primary-container);color:var(--primary)}.chip-sftp{background:var(--coral-container);color:var(--coral-strong)}.chip-active{background:var(--coral);color:#fff}.card-foot .count{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase}.card-more{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--muted);background:var(--surface-dim);border-top-color:var(--line-strong);border-style:dashed}.card-more .tile{background:#fff;color:var(--primary)}.explorer{border-radius:var(--radius-3xl);border:1px solid var(--line-strong);background:var(--panel);box-shadow:var(--shadow-soft);overflow:hidden}.explorer-head{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;padding:24px 32px;border-bottom:1px solid var(--line)}.crumbs{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.crumbs button{border:0;background:var(--surface-dim);color:var(--ink-soft);font-size:12px;font-weight:600;padding:6px 12px;border-radius:var(--radius)}.crumbs button:hover{color:var(--primary)}.crumbs button:last-child{background:var(--primary-container);color:var(--primary);font-weight:700}.crumbs svg{color:var(--muted)}.filearea{position:relative}.filearea.drag{outline:2px dashed var(--primary);outline-offset:-6px}.drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;display:flex;align-items:center;justify-content:center;gap:12px;background:#dcecf1f0;color:var(--primary);font-size:16px;font-weight:700;pointer-events:none}.filetable{width:100%;border-collapse:collapse;font-size:14px}.filetable th{text-align:left;padding:18px 32px;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:#dcecf199}.filetable th.col-size{text-align:center}.filetable th.col-actions{text-align:right}.filetable td{padding:14px 32px;border-top:1px solid var(--line);color:var(--ink-soft);vertical-align:middle}.filetable td.col-size{text-align:center;font-size:12px;font-weight:500}.filetable td.col-mod{font-size:12px;font-weight:500}.filetable tbody tr{transition:background .1s ease;cursor:default}.filetable tbody tr:hover{background:#0e3d520a}.filetable .col-actions{width:150px;text-align:right}.fname{display:flex;align-items:center;gap:16px}.fname .fmeta{min-width:0}.fname .fttl{display:block;font-size:14px;font-weight:700;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:52ch}.fname button.fttl{border:0;background:transparent;padding:0;text-align:left;cursor:pointer}.fname button.fttl:hover{color:var(--primary)}.fsub{display:block;font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-top:2px}.ftile{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:14px;font-size:10px;font-weight:800;letter-spacing:.02em;flex-shrink:0}.row-actions{display:inline-flex;gap:8px;justify-content:flex-end;opacity:0;transform:translate(6px);transition:opacity .14s ease,transform .14s ease}.filetable tbody tr:hover .row-actions{opacity:1;transform:translate(0)}.row-actions button{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:0;border-radius:11px;background:var(--primary-container);color:var(--primary);transition:background .12s ease,color .12s ease}.row-actions button:hover{background:var(--primary);color:#fff}.row-actions button.danger{background:var(--error-container);color:var(--error)}.row-actions button.danger:hover{background:var(--error);color:#fff}.explorer-foot{display:flex;align-items:center;justify-content:space-between;padding:22px 32px;border-top:1px solid var(--line);background:#f8fafc66}.explorer-foot .count{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.pager{display:inline-flex;align-items:center;gap:6px}.pager button{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 10px;border:1px solid var(--line-strong);border-radius:var(--radius);background:#fff;color:var(--ink-soft);font-size:13px;font-weight:700}.pager button:hover:not(:disabled):not(.active){border-color:var(--primary);color:var(--primary)}.pager button.active{background:var(--primary-grad);border-color:transparent;color:#fff;box-shadow:0 6px 14px #0e3d524d}.pager button:disabled{opacity:.3;cursor:default}.filegrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:16px;padding:24px 32px}.filecard{display:flex;flex-direction:column;gap:12px;padding:18px;border-radius:var(--radius-lg);border:1px solid var(--line-strong);background:#fff;text-align:left;transition:transform .12s ease,box-shadow .12s ease}.filecard:hover{transform:translateY(-2px);box-shadow:var(--shadow-pop)}.filecard .name{font-size:13px;font-weight:700;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filecard .meta{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;padding:72px 24px}.empty-state.drag{background:var(--primary-soft)}.empty-state-icon{display:inline-flex;align-items:center;justify-content:center;width:76px;height:76px;border-radius:var(--radius-xl);margin-bottom:14px;background:var(--primary-container);color:var(--primary)}.empty-state h3{margin:0;font-size:22px;font-weight:700;color:var(--ink)}.empty-state p{margin:0 0 18px;font-size:15px;color:var(--muted)}.fab{position:fixed;right:40px;bottom:40px;z-index:20;display:inline-flex;align-items:center;justify-content:center;height:64px;min-width:64px;padding:0 20px;border:0;border-radius:var(--radius-lg);background:var(--primary-grad);color:#fff;box-shadow:0 10px 30px #0e3d5266;transition:transform .2s ease}.fab:hover{transform:scale(1.1)}.fab:active{transform:scale(.95)}.fab-label{max-width:0;opacity:0;white-space:nowrap;font-size:15px;font-weight:600;transition:max-width .22s ease,opacity .18s ease,margin-left .22s ease}.fab:hover .fab-label,.fab:focus-visible .fab-label{max-width:200px;opacity:1;margin-left:10px}.empty{padding:40px;text-align:center;color:var(--muted);font-size:14px}.error{margin:0 0 14px;padding:12px 16px;border-radius:var(--radius-sm);background:var(--error-container);border-left:3px solid var(--error);color:var(--on-error-container);font-size:14px;font-weight:500;word-break:break-word}.hint{margin-top:16px;color:var(--muted);font-size:13px;line-height:1.6}.hint code{background:var(--surface-dim);border:1px solid var(--line);border-radius:6px;padding:1px 6px;font-size:12px}.spin{padding:28px 0;color:var(--muted);font-size:14px}.spinner{display:inline-block;width:18px;height:18px;border:2.5px solid var(--primary-container);border-top-color:var(--primary);border-radius:50%;animation:fh-spin .7s linear infinite;flex-shrink:0}.loader{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:80px 24px;color:var(--muted);font-size:14px}@keyframes fh-spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.spinner{animation-duration:1.6s}}.profile-grid{display:grid;gap:1px;max-width:560px;margin-top:8px;border:1px solid var(--line-strong);border-radius:var(--radius);overflow:hidden;background:var(--line)}.profile-grid .row{display:grid;grid-template-columns:160px 1fr;background:#fff}.profile-grid .row>div{padding:13px 16px;font-size:14px}.profile-grid .k{color:var(--muted);font-weight:500}.tag{display:inline-block;padding:3px 10px;border-radius:999px;background:var(--primary-container);color:var(--primary);font-size:12px;font-weight:600;margin:2px 4px 2px 0}.login-bg{position:relative;overflow:hidden;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(120% 120% at 50% 0%,#15506a,#0e3d52 45%,#0a2e3e)}.login-bg:before{content:"";position:absolute;top:-35%;right:-35%;bottom:-35%;left:-35%;z-index:0;background:radial-gradient(38% 38% at 20% 30%,rgba(224,122,95,.55) 0%,transparent 60%),radial-gradient(42% 42% at 80% 22%,rgba(26,118,150,.55) 0%,transparent 60%),radial-gradient(46% 46% at 68% 82%,rgba(15,118,110,.5) 0%,transparent 62%),radial-gradient(34% 34% at 28% 78%,rgba(194,96,63,.45) 0%,transparent 60%);filter:blur(64px) saturate(1.1);animation:login-aurora 24s ease-in-out infinite alternate;will-change:transform}.login-bg:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px);background-size:24px 24px}@keyframes login-aurora{0%{transform:translate(0) rotate(0) scale(1)}50%{transform:translate(3%,-2%) rotate(8deg) scale(1.18)}to{transform:translate(-3%,2%) rotate(-6deg) scale(1.1)}}@media (prefers-reduced-motion: reduce){.login-bg:before{animation:none}}.login-card{position:relative;z-index:1;width:100%;max-width:520px;background:#fff;border-radius:28px;padding:48px 48px 36px;text-align:center;box-shadow:0 40px 90px #00000059}.login-logo{display:block;width:100%;max-width:300px;height:auto;margin:0 auto 28px}.login-card h1{margin:0 0 8px;font-size:30px;font-weight:800;letter-spacing:-.02em;color:var(--ink)}.login-sub{margin:0 0 28px;color:var(--muted);font-size:15px}.login-ms-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:16px;border:1px solid var(--line-strong);border-radius:var(--radius-lg);background:var(--surface-dim);color:var(--ink);font-size:16px;font-weight:700;transition:background .14s ease,box-shadow .14s ease,border-color .14s ease,transform .14s ease}.login-ms-btn:hover{background:#fff;border-color:#9fc6d2;box-shadow:var(--shadow-soft);transform:translateY(-1px)}.login-divider{display:flex;align-items:center;gap:16px;margin:28px 0;color:var(--muted);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--line)}.login-info{border:1.5px dashed var(--line-strong);border-radius:var(--radius-lg);background:var(--surface-dim);padding:18px 20px;text-align:left}.login-info strong{display:block;font-size:15px;font-weight:700;color:var(--ink);margin-bottom:6px}.login-info p{margin:0;font-size:13px;color:var(--muted);line-height:1.6}.login-foot{margin:26px 0 0;font-size:13px;color:var(--muted)}@media (max-width: 560px){.login-card{padding:36px 24px 28px}.page{padding:18px 14px 40px}.cards{grid-template-columns:1fr 1fr;gap:12px}.card{padding:13px}.card-top{margin-bottom:10px}.card .tile{width:34px;height:34px;border-radius:10px}.card .title{font-size:14px}.card .sub{margin:2px 0 10px}.card-foot{padding-top:10px}.card.active:after{width:52px;height:52px}.section-head{gap:10px}.section-head h2{font-size:20px}.toolbar{flex-wrap:wrap}.filetable th.col-mod,.filetable td.col-mod,.filetable th.col-size,.filetable td.col-size{display:none}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:32px;background:#1c1a2480;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{display:flex;flex-direction:column;width:min(1040px,100%);height:min(86vh,900px);background:#fff;border-radius:var(--radius-3xl);overflow:hidden;box-shadow:0 40px 100px #1c1a2466}.modal-head{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line)}.modal-title{flex:1;min-width:0}.modal-title .name{font-size:15px;font-weight:700;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-title .meta{font-size:12px;color:var(--muted)}.modal-body{flex:1;min-height:0;overflow:auto;background:var(--surface-dim);display:flex;flex-direction:column}.preview-img{margin:auto;max-width:100%;max-height:100%;object-fit:contain;padding:16px}.preview-frame{flex:1;width:100%;border:0}.preview-audio{margin:auto;width:min(560px,90%)}.preview-video{margin:auto;max-width:100%;max-height:100%}.preview-text{margin:0;padding:18px 20px;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:13px;line-height:1.6;color:#1f2430;white-space:pre;-moz-tab-size:2;tab-size:2}.preview-fallback{margin:auto;display:flex;flex-direction:column;align-items:center;gap:14px;color:var(--muted);font-size:14px}.sheet-wrap{display:flex;flex-direction:column;flex:1;min-height:0;background:#fff}.sheet-tabs{display:flex;gap:4px;padding:8px 12px;border-bottom:1px solid var(--line);overflow-x:auto}.sheet-tab{border:0;background:transparent;padding:6px 12px;border-radius:8px;font-size:13px;font-weight:500;color:var(--muted);white-space:nowrap}.sheet-tab.active{background:var(--primary-container);color:var(--primary)}.sheet-scroll{flex:1;min-height:0;overflow:auto}.sheet-table{border-collapse:collapse;font-size:13px;color:var(--ink)}.sheet-table td,.sheet-table th{border:1px solid var(--line);padding:6px 10px;white-space:nowrap;max-width:360px;overflow:hidden;text-overflow:ellipsis}.sheet-table .sheet-rownum{position:sticky;left:0;background:var(--surface-dim);color:var(--muted);font-weight:500;text-align:right;min-width:42px}.sheet-table tr:first-child td{background:var(--surface-dim);font-weight:600}.backdrop{display:none}@media (max-width: 920px){.sidebar{transform:translate(-100%);transition:transform .2s ease}.sidebar.open{transform:translate(0)}.backdrop.show{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:25;background:#1c1a2473}.menu-btn{display:inline-flex}.main{margin-left:0}.topbar{padding:0 18px;gap:12px}.topbar-user .tu-meta,.search kbd{display:none}.page{padding:22px 18px 40px}.greeting{font-size:24px}.explorer-head,.filetable th,.filetable td,.explorer-foot{padding-left:18px;padding-right:18px}.profile-grid .row{grid-template-columns:120px 1fr}}.admin-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:18px}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:22px}.tab{display:inline-flex;align-items:center;gap:8px;padding:11px 16px;background:none;border:0;border-bottom:2px solid transparent;margin-bottom:-1px;font:inherit;font-weight:600;font-size:14px;color:var(--muted);cursor:pointer}.tab:hover{color:var(--ink-soft)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:var(--surface-high);color:var(--ink-soft);font-size:11px;font-weight:700}.tab.active .tab-count{background:var(--primary-container);color:var(--primary)}.empty-box{display:flex;flex-direction:column;align-items:center;gap:16px;padding:56px 24px;text-align:center;color:var(--muted);background:var(--panel);border:1px dashed var(--line-strong);border-radius:var(--radius-xl)}.admin-table{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-card)}.at-head,.at-row{display:grid;grid-template-columns:minmax(150px,1.5fr) 64px minmax(130px,1.4fr) minmax(150px,1.8fr) 120px;align-items:center;gap:12px;padding:12px 18px}.at-roles{display:flex;flex-wrap:wrap;gap:5px}.at-muted{font-size:12.5px;color:var(--muted)}.at-head{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);background:var(--surface-dim);border-bottom:1px solid var(--line)}.at-row{border-bottom:1px solid var(--line);font-size:14px}.at-row:last-child{border-bottom:0}.at-name{display:flex;align-items:center;gap:11px;min-width:0}.at-name strong{display:block;font-weight:600;color:var(--ink)}.at-name .slug{display:block;font-style:normal;font-size:12px;color:var(--muted);font-family:ui-monospace,SF Mono,Menlo,monospace}.at-origin{font-size:12.5px;color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.at-actions{display:flex;gap:4px;justify-content:flex-end}.dot{display:inline-flex;width:28px;height:28px;align-items:center;justify-content:center;border-radius:9px;color:#fff;flex-shrink:0}.grant-name .dot{width:24px;height:24px}.dot.teal{background:var(--primary-grad)}.dot.coral{background:linear-gradient(135deg,var(--coral),var(--coral-strong))}.icon-btn.sm{width:32px;height:32px;border-radius:9px}.icon-btn.danger:hover{background:var(--error-container);color:var(--on-error-container)}.role-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.role-card{display:flex;flex-direction:column;gap:10px;padding:18px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow-card)}.rc-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.rc-title{display:flex;align-items:center;gap:8px;min-width:0}.rc-admin-ic{display:inline-flex;color:var(--coral-strong)}.rc-name{font-weight:700;font-size:15px;color:var(--ink)}.rc-actions{display:flex;gap:4px}.rc-desc{margin:0;font-size:13px;color:var(--muted)}.rc-body{min-height:28px}.rc-pill{display:inline-block;padding:5px 11px;border-radius:999px;font-size:12px;font-weight:600}.rc-pill.admin{background:var(--coral-container);color:var(--coral-strong)}.rc-pill.muted{background:var(--surface-high);color:var(--muted)}.rc-grants{display:flex;flex-wrap:wrap;gap:6px}.rc-grant{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:8px;background:var(--primary-soft);color:var(--primary);font-size:12px;font-weight:600}.rc-grant em{font-style:normal;font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.03em;opacity:.7}.rc-foot{margin:4px 0 0;font-size:11.5px;color:var(--muted)}.tag.admin{background:var(--coral-container);color:var(--coral-strong)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:24px;background:#1c1a2480;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.admin-modal{display:flex;flex-direction:column;width:min(540px,100%);max-height:90vh;background:#fff;border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 40px 100px #1c1a2466}.admin-modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 22px;border-bottom:1px solid var(--line)}.admin-modal-head h2{margin:0;font-size:17px;font-weight:700;color:var(--ink)}.form{display:flex;flex-direction:column;gap:16px;padding:22px;overflow:auto}.fld{display:flex;flex-direction:column;gap:6px}.fld>span{font-size:13px;font-weight:600;color:var(--ink-soft)}.fld-hint{font-style:normal;font-weight:400;font-size:12px;color:var(--muted)}.fld input,.fld select,.grant-row select{width:100%;padding:10px 12px;font:inherit;font-size:14px;color:var(--ink);background:var(--surface-dim);border:1px solid var(--line-strong);border-radius:var(--radius-sm);outline:none}.fld input:focus,.fld select:focus,.grant-row select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.fld input:disabled{color:var(--muted);background:var(--surface-high)}.fld-row{display:flex;gap:12px}.fld-row .fld{flex:1}.fld-row .fld.port{flex:0 0 96px}.check-row{display:flex;align-items:flex-start;gap:12px;padding:14px;background:var(--surface-dim);border:1px solid var(--line);border-radius:var(--radius);cursor:pointer}.check-row input{margin-top:3px;width:18px;height:18px;accent-color:var(--primary);flex-shrink:0}.check-row span{display:flex;flex-direction:column;gap:2px;font-size:14px}.check-row em{font-style:normal;font-size:12.5px;color:var(--muted)}.form-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:4px}.grant-list{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.grant-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-bottom:1px solid var(--line)}.grant-row:last-child{border-bottom:0}.grant-name{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;color:var(--ink);min-width:0}.grant-row select{width:auto;flex:0 0 auto;padding:7px 10px;font-size:13px}@media (max-width: 720px){.at-head{display:none}.at-row{grid-template-columns:1fr auto;grid-template-areas:"name actions" "origin origin";row-gap:6px}.at-row .at-name{grid-area:name}.at-row .at-actions{grid-area:actions}.at-row .at-origin{grid-area:origin}.at-row>span:nth-child(2),.at-row>span:nth-child(4){display:none}}.btn-ghost.btn-icon{padding-left:10px;padding-right:10px}@keyframes ea-spin{to{transform:rotate(360deg)}}.spinning{animation:ea-spin .8s linear infinite;transform-origin:center}.mon-actions{display:flex;gap:10px;flex-wrap:wrap}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:18px}.kpi{display:flex;flex-direction:column;gap:4px;padding:20px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow-card)}.kpi-ic{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:13px;margin-bottom:8px}.kpi-ic.teal{background:var(--primary-container);color:var(--primary)}.kpi-ic.coral{background:var(--coral-container);color:var(--coral-strong)}.kpi-label{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.kpi-value{font-size:30px;font-weight:800;letter-spacing:-.02em;color:var(--ink);line-height:1.1}.kpi-hint{font-size:12.5px;color:var(--muted)}.mon-row{display:grid;grid-template-columns:1.7fr 1fr;gap:16px;margin-bottom:18px}@media (max-width: 900px){.mon-row{grid-template-columns:1fr}}.mon-card{padding:22px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow-card)}.mon-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.mon-card-head h2{margin:0;font-size:17px;font-weight:700;color:var(--ink)}.mon-tag{font-size:12px;font-weight:600;color:var(--muted);background:var(--surface-dim);border:1px solid var(--line);border-radius:999px;padding:5px 12px}.chart{display:flex;flex-direction:column;gap:10px}.chart-bars{display:flex;align-items:flex-end;gap:4px;height:200px;padding-top:8px}.chart-bar{flex:1;min-width:0;border-radius:5px 5px 0 0;background:var(--primary-grad);opacity:.85;transition:opacity .12s ease}.chart-bar:hover{opacity:1}.chart-foot{display:flex;justify-content:space-between;font-size:11.5px;color:var(--muted);border-top:1px solid var(--line);padding-top:10px}.conn-status{display:flex;flex-direction:column;gap:6px}.cs-row{display:flex;align-items:center;gap:11px;padding:9px 0;border-bottom:1px solid var(--line)}.cs-row:last-child{border-bottom:0}.cs-meta{display:flex;flex-direction:column;min-width:0;flex:1}.cs-meta strong{font-size:14px;font-weight:600;color:var(--ink)}.cs-meta em{font-style:normal;font-size:12px;color:var(--muted)}.cs-latency{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}.cs-state{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600}.cs-state i{width:8px;height:8px;border-radius:50%}.cs-state.online{color:var(--success)}.cs-state.online i{background:var(--success)}.cs-state.offline{color:var(--error)}.cs-state.offline i{background:var(--error)}.admin-table.flush{box-shadow:none;border-color:var(--line)}.log-head,.log-row{display:grid;grid-template-columns:minmax(180px,2fr) minmax(100px,1.1fr) minmax(110px,1.1fr) minmax(110px,1fr) 108px 104px;align-items:center;gap:12px;padding:12px 16px}.log-head{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);background:var(--surface-dim);border-bottom:1px solid var(--line)}.log-row{width:100%;text-align:left;border:0;border-bottom:1px solid var(--line);background:transparent;font:inherit;font-size:13.5px;cursor:pointer;transition:background .12s ease}.log-row:hover{background:var(--surface-dim)}.log-row:last-child{border-bottom:0}.log-evt{display:flex;flex-direction:column;gap:2px;font-weight:600;color:var(--ink);min-width:0}.log-path{font-style:normal;font-weight:400;font-size:12px;color:var(--muted);font-family:ui-monospace,SF Mono,Menlo,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.log-detail{display:inline-flex;align-items:center;gap:4px;justify-content:flex-end;font-size:12px;font-weight:600;color:var(--primary)}.detail-grid{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.detail-row{display:grid;grid-template-columns:130px 1fr;gap:12px;padding:10px 14px;border-bottom:1px solid var(--line);font-size:13.5px}.detail-row:last-child{border-bottom:0}.detail-row .k{color:var(--muted);font-weight:600}.detail-row .v{color:var(--ink);word-break:break-word}.log-user,.log-time{color:var(--ink-soft)}.log-badge{display:inline-block;padding:4px 11px;border-radius:999px;font-size:11px;font-weight:700}.log-badge.ok{background:#dff3e9;color:#1f7a55}.log-badge.err{background:var(--error-container);color:var(--on-error-container)}@media (max-width: 760px){.log-head{display:none}.log-row{grid-template-columns:1fr auto;row-gap:4px}.log-row>span:nth-child(2),.log-row>span:nth-child(3),.log-row>span:nth-child(4),.log-row>.log-detail{display:none}}.nav-filter{display:flex;align-items:center;gap:8px;margin:0 8px 8px;padding:8px 10px;border-radius:var(--radius-sm);background:var(--surface-dim);border:1px solid transparent;color:var(--muted);transition:border-color .12s ease,background .12s ease}.nav-filter:focus-within{background:#fff;border-color:#9fc6d2}.nav-filter input{flex:1;min-width:0;border:0;outline:none;background:transparent;font:inherit;font-size:13px;color:var(--ink)}.nav-filter-clear{display:inline-flex;align-items:center;justify-content:center;border:0;background:transparent;color:var(--muted);padding:2px;border-radius:6px}.nav-filter-clear:hover{background:var(--surface-high);color:var(--ink)}.sh-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.notif-wrap{position:relative}.notif-count{position:absolute;top:6px;right:6px;min-width:17px;height:17px;padding:0 4px;border-radius:999px;background:var(--error);color:#fff;font-size:10px;font-weight:800;line-height:17px;text-align:center;box-shadow:0 0 0 2px var(--panel)}.notif-menu{position:absolute;top:calc(100% + 10px);right:0;width:360px;max-width:86vw;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-pop);z-index:40;overflow:hidden}.notif-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line);font-size:14px}.notif-head span{font-size:12px;color:var(--muted)}.notif-empty{padding:28px 16px;text-align:center;color:var(--muted);font-size:13.5px}.notif-list{max-height:420px;overflow:auto}.notif-item{display:flex;align-items:flex-start;gap:10px;padding:13px 16px;border-bottom:1px solid var(--line)}.notif-item:last-child{border-bottom:0}.ni-body{flex:1;min-width:0}.ni-title{font-size:13.5px;font-weight:600;color:var(--ink)}.ni-title em{font-style:normal;font-weight:500;color:var(--primary)}.ni-sub{font-size:12px;color:var(--muted);margin-top:2px;word-break:break-word}.ni-reason{font-size:12.5px;color:var(--ink-soft);margin-top:4px;font-style:italic}.ni-actions{display:flex;gap:6px;flex-shrink:0}.ni-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;border:1px solid var(--line-strong);background:var(--panel)}.ni-btn.ok{color:var(--success)}.ni-btn.ok:hover{background:#dff3e9;border-color:var(--success)}.ni-btn.no{color:var(--error)}.ni-btn.no:hover{background:var(--error-container);border-color:var(--error)}.ni-btn:disabled{opacity:.5}.req-controls{display:flex;align-items:center;gap:8px;flex-shrink:0}.btn-primary.sm{padding:7px 14px;font-size:13px}.req-pending{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:600;color:var(--success)}.btn-ghost:disabled,.btn-primary:disabled{opacity:.5;cursor:not-allowed}.filearea-error{display:flex;flex-direction:row;align-items:center;gap:14px;padding:24px;flex-wrap:wrap}.filearea-error .error{margin:0}.filearea-error .btn-ghost{flex-shrink:0}.fld-req{font-style:normal;color:var(--error);font-weight:700}
