:root{--bg: #fafaf9;--surface: #ffffff;--surface-2: #f5f5f4;--surface-hover: #f0efed;--sidebar-bg: #fafaf9;--border: #e7e5e4;--border-strong: #d6d3d1;--text: #1c1917;--text-muted: #78716c;--text-subtle: #a8a29e;--primary: #1c1917;--primary-hover: #292524;--on-primary: #fafaf9;--accent: #65a30d;--accent-strong: #4d7c0f;--accent-bright: #84cc16;--accent-soft: #f3f9e6;--accent-soft-text: #3f6212;--accent-soft-border: #d6ecaf;--danger: #dc2626;--danger-soft: #fef2f2;--danger-soft-border: #fecaca;--danger-soft-text: #b42318;--success-soft: #f0faf3;--success-soft-border: #bbe7c6;--success-soft-text: #15803d;--star: #d97706;--public: #2563eb;--ring: rgba(101, 163, 13, .32);--shadow-sm: 0 1px 1px rgba(28, 25, 23, .04);--shadow-md: 0 2px 8px rgba(28, 25, 23, .07), 0 1px 2px rgba(28, 25, 23, .04);--shadow-lg: 0 12px 34px rgba(28, 25, 23, .14), 0 2px 6px rgba(28, 25, 23, .06);--radius-sm: 6px;--radius: 8px;--radius-lg: 11px;--sidebar-w: 260px;--topbar-h: 58px}[data-theme=dark]{--bg: #0c0c0d;--surface: #161617;--surface-2: #1c1c1e;--surface-hover: #242427;--sidebar-bg: #121213;--border: #262629;--border-strong: #33333a;--text: #ededee;--text-muted: #9b9ba2;--text-subtle: #6c6c74;--primary: #fafaf9;--primary-hover: #e7e5e4;--on-primary: #1c1917;--accent: #a3e635;--accent-strong: #bef264;--accent-bright: #a3e635;--accent-soft: #1a2410;--accent-soft-text: #bef264;--accent-soft-border: #324516;--danger: #f05252;--danger-soft: #2a1517;--danger-soft-border: #5a2a2c;--danger-soft-text: #fca5a5;--success-soft: #0f2418;--success-soft-border: #1f4d35;--success-soft-text: #86efac;--star: #fbbf24;--public: #60a5fa;--ring: rgba(163, 230, 53, .3);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .5);--shadow-md: 0 4px 14px rgba(0, 0, 0, .5);--shadow-lg: 0 16px 44px rgba(0, 0, 0, .62)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:14px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font:inherit;cursor:pointer;color:inherit}input{font:inherit}svg{display:block}:focus-visible{outline:2px solid var(--ring);outline-offset:1px}.centered{display:grid;place-items:center;height:100%;min-height:240px}.muted,.fic{color:var(--text-muted)}.fic-folder{color:var(--accent)}.spinner{width:30px;height:30px;border:2.5px solid var(--border-strong);border-top-color:var(--text);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn{border:1px solid var(--border-strong);background:var(--surface);color:var(--text);padding:7px 13px;border-radius:var(--radius-sm);font-weight:500;display:inline-flex;align-items:center;gap:7px;transition:background .14s,border-color .14s,box-shadow .14s,transform .04s}.btn:hover{background:var(--surface-hover);border-color:var(--border-strong)}.btn:active{transform:translateY(.5px)}.btn.primary{background:var(--primary);border-color:var(--primary);color:var(--on-primary)}.btn.primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn.primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn.ghost{border-color:transparent;background:transparent}.btn.ghost:hover{background:var(--surface-hover)}.btn.danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn.block{width:100%;justify-content:center}.icon-btn{border:none;background:transparent;padding:7px;border-radius:var(--radius-sm);color:var(--text-muted);line-height:0;display:inline-grid;place-items:center;transition:background .14s,color .14s}.icon-btn:hover{background:var(--surface-hover);color:var(--text)}.link{border:none;background:none;color:var(--text-muted);padding:0;text-decoration:none;font-weight:500;transition:color .14s}.link:hover{color:var(--text);text-decoration:underline;text-underline-offset:2px}.alert{padding:9px 12px;border-radius:var(--radius-sm);font-size:13.5px;margin:6px 0}.alert.error{background:var(--danger-soft);color:var(--danger-soft-text);border:1px solid var(--danger-soft-border)}.alert.ok{background:var(--success-soft);color:var(--success-soft-text);border:1px solid var(--success-soft-border)}.auth-wrap{position:relative;min-height:100%;display:grid;place-items:center;padding:24px;background:var(--bg)}.auth-theme{position:fixed;top:16px;right:16px;border:1px solid var(--border);background:var(--surface)}.auth-card{width:100%;max-width:384px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:30px 30px 26px;display:flex;flex-direction:column;gap:13px}.brand{display:flex;align-items:center;gap:10px}.brand h1{font-size:18px;margin:0;font-weight:600;letter-spacing:-.02em}.brand .logo{display:inline-grid;place-items:center;color:var(--text);flex-shrink:0}.brand.small{font-weight:600;cursor:pointer;gap:9px}.auth-head{display:flex;flex-direction:column;gap:4px;margin:6px 0 2px}.auth-eyebrow{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-strong);margin:0}.auth-title{font-size:21px;font-weight:600;letter-spacing:-.02em;margin:0}.auth-sub{color:var(--text-muted);margin:4px 0 6px;font-size:13.5px}.auth-card label,.modal label{display:flex;flex-direction:column;gap:6px;font-size:12.5px;font-weight:500;color:var(--text-muted)}.auth-card input,.modal input{padding:10px 12px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text);background:var(--surface);transition:border-color .14s,box-shadow .14s}.auth-card input::placeholder,.modal input::placeholder{color:var(--text-subtle)}.auth-card input:focus,.modal input:focus,.search input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--ring)}.auth-card input.otp-input{font-size:22px;letter-spacing:8px;text-align:center;font-variant-numeric:tabular-nums}.auth-card input.otp-input::placeholder{letter-spacing:8px}.auth-card .btn.primary{margin-top:4px;padding:10px 14px;justify-content:center}.auth-links{display:flex;justify-content:space-between;margin-top:6px;font-size:13.5px}.account-wrap{min-height:100%;background:var(--bg)}.account-head{display:flex;align-items:center;justify-content:space-between;gap:14px;height:var(--topbar-h);padding:0 22px;background:var(--surface);border-bottom:1px solid var(--border)}.account-head .brand.small{border:none;background:none}.account-head-right{display:flex;align-items:center;gap:10px}.account-body{width:100%;max-width:560px;margin:0 auto;padding:34px 22px 56px;display:flex;flex-direction:column;gap:18px}.account-title{font-size:22px;font-weight:600;letter-spacing:-.02em;margin:0 0 2px}.account-card{max-width:none;gap:15px;box-shadow:none}.account-card-head h2{font-size:15px;margin:0;font-weight:600;letter-spacing:-.01em}.account-card-head .auth-sub{margin:5px 0 0;font-size:13px}.account-card form{display:flex;flex-direction:column;gap:14px}.account-card input:disabled{opacity:.6;cursor:not-allowed;background:var(--surface-2)}.account-card .modal-actions{margin-top:2px}.app{display:grid;grid-template-columns:var(--sidebar-w) minmax(0,1fr);height:100%}.sidebar{display:flex;flex-direction:column;gap:6px;padding:14px 12px;background:var(--sidebar-bg);border-right:1px solid var(--border);min-height:0}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:6px 8px 14px;font-weight:600;font-size:15px;letter-spacing:-.02em;cursor:pointer}.sidebar-brand .logo{display:inline-grid;place-items:center;color:var(--text)}.new-menu-wrap{position:relative;margin-bottom:6px}.btn-new{width:100%;border:1px solid var(--primary);border-radius:var(--radius);background:var(--primary);color:var(--on-primary);padding:10px 14px;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .14s,transform .04s}.btn-new:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-new:active{transform:translateY(.5px)}.new-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:30;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:5px;display:flex;flex-direction:column}.new-menu button{display:flex;align-items:center;gap:10px;border:none;background:none;text-align:left;padding:9px 10px;border-radius:var(--radius-sm);color:var(--text);font-size:13.5px}.new-menu button:hover{background:var(--surface-hover)}.new-menu button svg{color:var(--text-muted)}.side-nav{display:flex;flex-direction:column;gap:2px}.side-section{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle);padding:14px 12px 6px}.side-link{position:relative;display:flex;align-items:center;gap:10px;border:none;background:none;text-align:left;width:100%;padding:8px 11px;border-radius:var(--radius-sm);color:var(--text);font-size:13.5px;font-weight:500;transition:background .14s,color .14s}.side-link .ic{display:inline-grid;place-items:center;width:20px;color:var(--text-muted);flex-shrink:0}.side-link:hover{background:var(--surface-hover)}.side-link.active{background:var(--surface-2);color:var(--text);font-weight:600}.side-link.active .ic{color:var(--text)}.side-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);height:16px;width:2.5px;border-radius:2px;background:var(--accent)}.side-scroll{flex:1;min-height:0;overflow-y:auto;margin:4px -6px 0;padding:0 6px}.side-empty{font-size:12px;color:var(--text-subtle);margin:0;padding:0 12px 6px;line-height:1.45}.starred-list{display:flex;flex-direction:column;gap:1px}.starred-item{display:flex;align-items:center;border-radius:var(--radius-sm)}.starred-item:hover{background:var(--surface-hover)}.starred-open{flex:1;min-width:0;display:flex;align-items:center;gap:10px;border:none;background:none;text-align:left;padding:7px 4px 7px 11px;color:var(--text);font-size:13.5px}.starred-open .ic{display:inline-flex;flex-shrink:0}.starred-open .nm{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.starred-open:hover .nm{text-decoration:underline;text-underline-offset:2px}.starred-unstar{border:none;background:none;color:var(--star);line-height:0;padding:7px 9px;border-radius:var(--radius-sm);flex-shrink:0;opacity:.9}.starred-unstar:hover{opacity:1;background:var(--surface-2)}.star-on,.shared-on,.public-on{display:inline-flex;flex-shrink:0}.star-on{color:var(--star)}.shared-on{color:var(--accent)}.shared-on.whole{color:var(--danger)}.public-on{color:var(--public)}.filecard-badges{position:absolute;top:8px;left:9px;z-index:4;display:flex;gap:5px;pointer-events:none;filter:drop-shadow(0 1px 1px rgba(0,0,0,.25))}.filecard-badge{display:inline-flex;line-height:0}.filecard-badge.star{color:var(--star)}.filecard-badge.share{color:var(--accent)}.filecard-badge.share.whole{color:var(--danger)}.filecard-badge.public{color:var(--public)}.side-foot{padding-top:12px}.storage-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:12px 13px}.storage-card .label{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:9px}.storage-card .label svg{color:var(--text-subtle)}.storage-bar{height:6px;background:var(--surface-2);border:1px solid var(--border);border-radius:5px;overflow:hidden}.storage-bar span{display:block;height:100%;border-radius:5px;background:var(--accent-bright);transition:width .3s ease}.storage-meta{font-size:11.5px;color:var(--text-muted);margin-top:8px}.main{display:flex;flex-direction:column;min-width:0;min-height:0;height:100%}.topbar{display:flex;align-items:center;gap:12px;height:var(--topbar-h);padding:0 20px;background:var(--surface);border-bottom:1px solid var(--border)}.hamburger{display:none}.search{flex:1;max-width:480px;position:relative}.search .search-ic{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-subtle);pointer-events:none;display:inline-flex}.search input{width:100%;padding:8px 14px 8px 34px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2);color:var(--text);font-size:13.5px}.search input::placeholder{color:var(--text-subtle)}.topbar-right{display:flex;align-items:center;gap:8px;margin-left:auto}.avatar{width:32px;height:32px;border:none;padding:0;border-radius:var(--radius);background:var(--primary);color:var(--on-primary);display:grid;place-items:center;font-weight:600;font-size:13px;flex-shrink:0;transition:box-shadow .14s,transform .04s}button.avatar:hover{box-shadow:0 0 0 3px var(--ring)}button.avatar:active{transform:translateY(.5px)}.toolbar{display:flex;align-items:center;gap:16px;padding:16px 22px 10px}.breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:2px;font-size:17px;font-weight:600;letter-spacing:-.02em;min-width:0}.crumb{border:none;background:none;color:var(--text-muted);padding:3px 7px;border-radius:var(--radius-sm);font:inherit;transition:background .14s,color .14s}.crumb:hover{background:var(--surface-hover);color:var(--text)}.crumb.current{color:var(--text)}.breadcrumb .sep{color:var(--text-subtle);font-weight:400}.toolbar-actions{margin-left:auto;display:flex;align-items:center;gap:10px}.view-toggle{display:inline-flex;border:1px solid var(--border-strong);border-radius:var(--radius-sm);overflow:hidden;background:var(--surface)}.view-btn{border:none;background:transparent;color:var(--text-muted);padding:7px 10px;line-height:0;transition:background .14s,color .14s}.view-btn:hover{background:var(--surface-hover);color:var(--text)}.view-btn.active{background:var(--primary);color:var(--on-primary)}.view-btn+.view-btn{border-left:1px solid var(--border-strong)}.uploads{padding:0 22px 6px;display:flex;flex-direction:column;gap:6px}.upload{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 13px;font-size:13.5px;box-shadow:var(--shadow-sm)}.upload.failed{border-color:var(--danger-soft-border);background:var(--danger-soft)}.upload-name{display:inline-flex;align-items:center;gap:8px;min-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-muted)}.upload-name svg{flex-shrink:0}.upload-pct{position:relative;flex:1;height:16px;display:flex;align-items:center}.upload-fill{position:absolute;left:0;height:5px;background:var(--accent-bright);border-radius:4px;transition:width .2s}.upload-pct em{margin-left:auto;font-style:normal;font-size:12px;color:var(--text-muted)}.upload-err{color:var(--danger);flex:1}.filearea{position:relative;flex:1;margin:8px 22px 22px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:auto}.filearea.dragging{outline:1.5px dashed var(--accent);outline-offset:-5px}.drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--accent-soft);opacity:.96;display:grid;place-items:center;font-size:16px;color:var(--accent-soft-text);font-weight:600;pointer-events:none}.filetable{width:100%;border-collapse:collapse}.filetable thead th{text-align:left;font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-subtle);padding:11px 18px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:1}.filetable td{padding:3px 18px;border-bottom:1px solid var(--border)}.filetable tbody tr:last-child td{border-bottom:none}.filetable tbody tr:hover{background:var(--surface-2)}.name-btn{display:flex;align-items:center;gap:12px;border:none;background:none;padding:9px 0;text-align:left;width:100%;color:var(--text);font-size:14px;font-weight:450}.name-btn .ic{display:inline-flex;flex-shrink:0}.name-btn .nm{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.name-btn:hover .nm{text-decoration:underline;text-underline-offset:2px}.cell-sub{display:block;margin:-4px 0 6px 32px;font-size:11.5px;color:var(--text-subtle);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-size,.col-date{color:var(--text-muted);font-size:13px;white-space:nowrap;width:1%}.col-actions{width:1%;text-align:right}.filegrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(158px,1fr));gap:12px;padding:18px}.filecard{position:relative;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);transition:border-color .14s,box-shadow .14s,transform .08s}.filecard:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-1px)}.filecard-menu{position:absolute;top:6px;right:6px;z-index:5}.filecard-open{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%;border:none;background:none;padding:22px 12px 14px;text-align:center;color:var(--text)}.filecard-icon{line-height:0;height:64px;display:grid;place-items:center}.filecard-thumb{width:100%;height:64px;object-fit:cover;object-position:top;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border)}.filecard-doc{width:100%;height:64px;overflow:hidden;border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff}.filecard-doc-page{width:320px;transform-origin:top left;padding:12px 14px;font-size:12px;line-height:1.45;color:#1f2937;text-align:left;pointer-events:none}.filecard-doc-page>*:first-child{margin-top:0}.filecard-doc-page img{display:none}.filecard-doc-page h1,.filecard-doc-page h2,.filecard-doc-page h3{font-size:15px;margin:0 0 6px}.filecard-doc-page table{border-collapse:collapse;font-size:11px}.filecard-doc-page td,.filecard-doc-page th{border:1px solid #d1d5db;padding:2px 6px;white-space:nowrap}.filecard-name{font-size:13.5px;font-weight:500;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filecard-open:hover .filecard-name{text-decoration:underline;text-underline-offset:2px}.filecard-meta{font-size:12px;color:var(--text-muted);width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.row-menu-wrap{position:relative}.row-menu{position:absolute;right:0;top:100%;z-index:20;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;padding:5px;min-width:172px}.row-menu button{display:flex;align-items:center;gap:10px;border:none;background:none;text-align:left;padding:8px 10px;border-radius:var(--radius-sm);color:var(--text);font-size:13.5px}.row-menu button svg{color:var(--text-muted);flex-shrink:0}.row-menu button:hover{background:var(--surface-hover)}.row-menu button.danger{color:var(--danger)}.row-menu button.danger svg{color:var(--danger)}.user-menu{min-width:230px;padding:7px}.user-menu-head{display:flex;align-items:center;gap:11px;padding:6px 8px 10px}.user-menu-head .avatar{width:38px;height:38px;font-size:15px}.user-menu-id{display:flex;flex-direction:column;gap:1px;min-width:0}.user-menu-name{font-weight:600;font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-menu-email{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-menu-sep{height:1px;background:var(--border);margin:2px 2px 5px}.context-menu{position:fixed;right:auto;top:auto;z-index:90;animation:ctx-pop .08s ease-out}@keyframes ctx-pop{0%{opacity:0;transform:scale(.97)}}.empty{display:grid;place-items:center;text-align:center;height:100%;min-height:320px;color:var(--text);gap:6px}.empty-icon{line-height:0;color:var(--text-subtle);margin-bottom:4px}.empty p{margin:2px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0c0c0d6b;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;z-index:100;padding:16px}.modal{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:12px}.modal-head{display:flex;align-items:center;justify-content:space-between}.modal-head h3{margin:0;font-size:16px;font-weight:600;letter-spacing:-.01em}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}.modal form{display:flex;flex-direction:column;gap:12px}.move-crumbs{display:flex;flex-wrap:wrap;gap:4px;align-items:center;font-size:13.5px}.move-crumbs .sep{color:var(--text-subtle)}.move-list{border:1px solid var(--border);border-radius:var(--radius);max-height:260px;overflow:auto;padding:5px;min-height:80px}.move-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;border:none;background:none;padding:8px 10px;border-radius:var(--radius-sm);color:var(--text);font-size:13.5px}.move-item:hover{background:var(--surface-hover)}.share-hint{font-size:12.5px;line-height:1.45;margin:-2px 0 2px}.pw-input{position:relative;display:flex}.pw-input input{width:100%;padding-right:38px}.pw-toggle{position:absolute;right:5px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.modal-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin:-2px 0 14px}.modal-tab{border:none;background:none;padding:9px 12px;font-size:13.5px;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .14s,border-color .14s}.modal-tab:hover{color:var(--text)}.modal-tab.active{color:var(--text);font-weight:600;border-bottom-color:var(--accent)}.people-search{position:relative;display:flex;align-items:center}.people-search .ic{position:absolute;left:11px;top:50%;transform:translateY(-50%);display:inline-grid;place-items:center;color:var(--text-subtle);pointer-events:none}.people-search input{width:100%;padding-left:34px}.people-results{display:flex;flex-direction:column;gap:1px;max-height:220px;overflow:auto;border:1px solid var(--border);border-radius:var(--radius);padding:4px;margin-top:-4px}.people-result{display:flex;align-items:center;gap:10px;width:100%;text-align:left;border:none;background:none;padding:6px 8px;border-radius:var(--radius-sm);color:var(--text)}.people-result:hover:not(:disabled){background:var(--surface-hover)}.people-result:disabled{opacity:.6;cursor:default}.people-empty{font-size:12.5px;margin:0;padding:6px 8px;line-height:1.45}.share-access-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-subtle);margin:4px 0 -2px}.share-list{display:flex;flex-direction:column;gap:2px;max-height:240px;overflow:auto}.share-row{display:flex;align-items:center;gap:10px;padding:6px 4px 6px 6px;border-radius:var(--radius-sm)}.share-row:hover{background:var(--surface-hover)}.share-who{flex:1;min-width:0;display:flex;align-items:center;gap:10px}.avatar.sm{width:28px;height:28px;font-size:12px}.share-id{display:flex;flex-direction:column;min-width:0}.share-name{font-size:13.5px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-email{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-role{font-size:11.5px;color:var(--text-subtle);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.public-add{display:flex;gap:8px}.public-pw-field{position:relative;flex:1;min-width:0;display:flex}.public-add input{width:100%;padding-right:38px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.pw-regen{position:absolute;right:5px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.public-add .btn{flex-shrink:0}.public-list{display:flex;flex-direction:column;gap:10px;margin-top:10px}.public-item{display:flex;flex-direction:column;gap:6px;padding:8px;border:1px solid var(--border);border-radius:var(--radius)}.public-row{display:flex;align-items:center;gap:6px}.public-url{flex:1;min-width:0;font-size:12.5px;color:var(--text-muted)}.public-row .btn{flex-shrink:0;padding:8px 12px}.public-msg{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 2px;font-size:12.5px}.public-pw{color:var(--text-muted)}.public-pw code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px;color:var(--text);background:var(--surface-2);padding:1px 6px;border-radius:4px;-webkit-user-select:all;user-select:all}.public-wrap{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.public-head{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border)}.public-head .brand{display:flex;align-items:center;gap:10px;font-weight:600}.public-head .logo{display:inline-flex}.public-main{flex:1;width:100%;max-width:880px;margin:0 auto;padding:24px 20px 60px}.public-card{max-width:380px;margin:8vh auto 0;text-align:center}.public-card h1{font-size:20px;margin:4px 0 2px}.public-card label{text-align:left}.public-lock{display:inline-grid;place-items:center;width:52px;height:52px;margin:0 auto 6px;border-radius:50%;background:var(--surface-2);color:var(--accent)}.public-viewer{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.public-bar{display:flex;align-items:center;gap:14px;flex-shrink:0;padding:10px 18px;border-bottom:1px solid var(--border);background:var(--surface)}.public-bar-left{flex:1;min-width:0;display:flex;align-items:center;gap:14px}.public-bar-left .logo{display:inline-flex;flex-shrink:0;color:var(--text)}.public-bar-title{min-width:0;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.public-bar-title .breadcrumb{font-weight:600}.public-bar-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.public-stage{flex:1;min-height:0;display:flex;flex-direction:column;overflow:auto}.public-viewer.dark .public-stage{background:#0b0b0c;display:grid;place-items:center;padding:28px}.public-stage .preview-media{max-height:calc(100vh - 124px)}.public-stage .preview-frame{width:min(1100px,100%);height:calc(100vh - 124px)}.public-stage .preview-text,.public-stage .preview-rich{max-height:calc(100vh - 124px)}.public-viewer.dark .public-stage .empty,.public-viewer.dark .public-stage .empty p,.public-viewer.dark .public-stage .empty .fic,.public-viewer.dark .public-stage .empty .empty-icon{color:#cbd5e1}.public-gridwrap{width:100%;max-width:1280px;margin:0 auto;padding:20px 24px 48px}.shared-banner{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding:8px 12px;border-radius:var(--radius-sm);background:var(--accent-soft);color:var(--accent-soft-text);border:1px solid var(--accent-soft-border);font-size:13px}.shared-banner strong{font-weight:600}.preview-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0a0a0bf7;display:flex;flex-direction:column;animation:preview-fade .12s ease-out}@keyframes preview-fade{0%{opacity:0}}.preview-head{position:absolute;top:0;left:0;right:0;z-index:3;display:flex;align-items:center;gap:16px;padding:14px 18px;color:#fff;background:linear-gradient(to bottom,#0000008c,#0000)}.preview-title{display:flex;align-items:center;gap:10px;min-width:0;font-weight:600}.preview-title .ic{display:inline-flex}.preview-title .fic{color:currentColor}.preview-title .nm{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-count{font-size:13px;color:#ffffffb3;white-space:nowrap}.preview-tools{margin-left:auto;display:flex;align-items:center;gap:8px;flex-shrink:0}.preview-head .btn{background:#ffffff1f;border-color:#ffffff2e;color:#fff}.preview-head .btn:hover{background:#fff3}.preview-head .icon-btn{color:#fff}.preview-head .icon-btn:hover{background:#ffffff29;color:#fff}.preview-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:46px;height:46px;border:none;border-radius:50%;background:#ffffff1a;color:#fff;line-height:0;display:grid;place-items:center;transition:background .14s}.preview-nav:hover{background:#ffffff38}.preview-nav.prev{left:18px}.preview-nav.next{right:18px}.preview-body{flex:1;min-height:0;overflow:auto;display:grid;place-items:center;padding:72px 80px 32px}.preview-media{max-width:100%;max-height:calc(100vh - 104px);object-fit:contain;border-radius:4px;box-shadow:0 8px 40px #00000080}.preview-audio{width:min(560px,100%)}.preview-frame{width:min(1100px,100%);height:calc(100vh - 96px);border:none;background:#fff;border-radius:6px}.preview-text{margin:0;padding:24px 28px;width:min(1000px,100%);max-height:calc(100vh - 104px);overflow:auto;background:#fff;color:#1f2937;border-radius:8px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.preview-body .empty{color:#e5e7eb}.preview-body .empty .empty-icon,.preview-body .empty .fic,.preview-body .empty .muted,.preview-body .empty p{color:#cbd5e1}.preview-rich{width:min(900px,100%);max-height:calc(100vh - 104px);overflow:auto;background:#fff;color:#1f2937;border-radius:8px;box-shadow:0 8px 40px #0006;padding:40px 48px;line-height:1.6}.preview-rich.spreadsheet{width:min(1100px,100%);padding:0}.preview-rich>*:first-child{margin-top:0}.preview-rich h1,.preview-rich h2,.preview-rich h3{line-height:1.25}.preview-rich img{max-width:100%;height:auto}.preview-rich a{color:var(--accent-strong)}.preview-rich pre{background:#f3f4f6;padding:12px 14px;border-radius:8px;overflow:auto}.preview-rich code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.9em}.preview-rich :not(pre)>code{background:#f3f4f6;padding:1px 5px;border-radius:4px}.preview-rich table{border-collapse:collapse;width:100%;font-size:13px}.preview-rich td,.preview-rich th{border:1px solid #d1d5db;padding:5px 9px;text-align:left}.preview-rich thead th,.preview-rich tr:first-child td{background:#f8fafc;font-weight:600}.preview-rich blockquote{margin:0 0 1em;padding-left:14px;border-left:3px solid var(--border-strong);color:var(--text-muted)}.sidebar-backdrop{display:none}@media (max-width: 860px){.app{grid-template-columns:minmax(0,1fr)}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);z-index:60;transform:translate(-100%);transition:transform .22s ease;box-shadow:var(--shadow-lg)}.app.nav-open .sidebar{transform:translate(0)}.app.nav-open .sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0c0c0d73}.hamburger{display:inline-grid}}@media (max-width: 720px){.col-date{display:none}.breadcrumb{font-size:16px}.upload-name{min-width:120px}.preview-body{padding:64px 12px 16px}.preview-nav{width:40px;height:40px}.preview-nav.prev{left:6px}.preview-nav.next{right:6px}.preview-rich{padding:24px 18px}}
