:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;--brand-blue: #2e78fd;--brand-cyan: #2db0fd;--brand-purple: #4a24e7;--brand-ink: #24136f;--brand-soft: #eef4ff;--brand-softer: #f7f9ff;color:#1f2933;background:#f7f9ff}:root{--drive-bg: #f5f7fb;--drive-surface: #ffffff;--drive-surface-2: #f8fafc;--drive-border: #dbe3ef;--drive-text: #172033;--drive-muted: #667085;--drive-primary: #2563eb;--drive-primary-strong: #1d4ed8;--drive-accent: #0f766e;--drive-danger: #dc2626;--drive-shadow: 0 16px 48px rgba(15, 23, 42, .08)}body{color:var(--drive-text);background:var(--drive-bg)}button.primary-action,.primary-action{background:var(--drive-primary)}button.primary-action:hover:not(:disabled),.primary-action:hover:not(:disabled){background:var(--drive-primary-strong)}button.danger{background:var(--drive-danger)}button.danger:hover:not(:disabled){background:#b91c1c}.login-page{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(360px,440px);align-items:center;gap:40px;min-height:100vh;width:min(1180px,calc(100% - 40px));margin:0 auto;padding:40px 0}.login-visual{display:grid;gap:20px;align-content:center}.login-visual img{width:220px;height:auto}.login-visual h1{margin:0;max-width:660px;font-size:48px;line-height:1.08;letter-spacing:0}.login-visual p{margin:0;max-width:600px;color:var(--drive-muted);font-size:18px;line-height:1.7}.login-feature-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;max-width:680px}.login-feature-grid span{padding:14px;border:1px solid var(--drive-border);border-radius:8px;background:var(--drive-surface);color:var(--drive-accent);font-weight:800;text-align:center}.login-card{display:grid;gap:18px;padding:28px;border:1px solid var(--drive-border);border-radius:8px;background:var(--drive-surface);box-shadow:var(--drive-shadow)}.login-card h2{margin:4px 0 0;font-size:28px;letter-spacing:0}.eyebrow{margin:0;color:var(--drive-accent);font-size:13px;font-weight:900}.drive-shell{display:flex;flex-direction:column;min-height:100vh;padding:0;margin:0}.drive-topbar{position:fixed;top:0;left:0;right:0;z-index:100;display:grid;grid-template-columns:minmax(260px,1fr) minmax(360px,720px);align-items:center;gap:16px;padding:14px 18px;border-bottom:1px solid var(--drive-border);background:#fffffff5;box-shadow:0 10px 32px #0f172a0f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);height:80px}.drive-brand{display:flex;align-items:center;min-width:0;gap:14px}.drive-brand img{width:144px;max-width:36vw;height:auto}.drive-brand h1,.drive-brand p{margin:0}.drive-brand h1{font-size:24px;letter-spacing:0}.drive-brand p{margin-top:4px;color:var(--drive-muted);overflow-wrap:anywhere}.drive-top-actions,.drive-toolbar,.compact-toolbar{display:flex;align-items:center;justify-content:flex-end;gap:10px;min-width:0}.drive-search{min-width:240px}.drive-layout{display:flex;flex:1;min-height:calc(100vh - 80px);margin-top:80px}.drive-sidebar,.drive-main,.admin-panel{border:none;border-radius:0;background:var(--drive-surface)}.drive-sidebar{position:fixed;top:80px;left:0;bottom:0;width:300px;z-index:50;display:flex;flex-direction:column;gap:14px;overflow:hidden;padding:0;border-right:1px solid var(--drive-border)}.drive-main{flex:1;display:flex;flex-direction:column;gap:16px;min-width:0;margin-left:300px;overflow-y:auto;max-height:calc(100vh - 80px);padding:18px}.drive-toolbar{justify-content:flex-start;flex-wrap:wrap}.drive-toolbar input{width:auto;min-width:220px;flex:1 1 240px}.drive-path{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 14px;border:1px solid var(--drive-border);border-radius:8px;background:var(--drive-surface-2)}.drive-path span{min-width:0;color:var(--drive-muted);overflow-wrap:anywhere}.selection-bar{position:fixed;top:10px;left:50%;transform:translate(-50%);z-index:100;display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:10px 16px;border:1px solid #bfdbfe;border-radius:8px;background:#eff6ff;box-shadow:0 4px 12px #0f172a1a;max-width:calc(100% - 40px)}.selection-bar span{margin-right:auto;color:var(--drive-primary-strong);font-weight:800}.sort-header{width:100%;justify-content:flex-start;padding:0;border:0;background:transparent;color:inherit;font:inherit;font-weight:800;box-shadow:none}.sort-header:hover,.sort-header:focus-visible{color:var(--drive-primary);background:transparent;box-shadow:none}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.gallery-card{position:relative;display:grid;gap:10px;min-width:0;padding:12px;border:1px solid var(--drive-border);border-radius:8px;background:var(--drive-surface)}.gallery-card.selected{border-color:var(--drive-primary);box-shadow:0 0 0 3px #2563eb24}.gallery-card.dragging{opacity:.72}.gallery-select{position:absolute;top:10px;left:10px;z-index:2;display:block;padding:4px;border-radius:999px;background:#ffffffdb}.gallery-preview{display:grid;place-items:center;width:100%;aspect-ratio:4 / 3;overflow:hidden;padding:0;border:1px solid var(--drive-border);border-radius:8px;background:#eef2f7;color:var(--drive-text)}.gallery-preview img{width:100%;height:100%;object-fit:cover}.gallery-placeholder{display:grid;place-items:center;width:72px;height:72px;border-radius:8px;background:var(--drive-surface);color:var(--drive-accent);font-weight:900}.gallery-meta{display:grid;gap:4px;min-width:0}.gallery-meta strong,.gallery-meta span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gallery-meta span{color:var(--drive-muted);font-size:13px}.gallery-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.gallery-actions button{min-width:0;padding:8px 10px}.admin-layout-v2{grid-template-columns:320px minmax(0,1fr);min-height:calc(100vh - 156px)}.admin-main{background:transparent;border:0;box-shadow:none;padding:0}.admin-panel{display:grid;gap:14px;padding:18px}.account-list{display:grid;gap:8px}.account-item{display:grid;gap:4px;width:100%;padding:12px;border:1px solid var(--drive-border);background:var(--drive-surface-2);color:var(--drive-text);text-align:left;white-space:normal}.account-item:hover,.account-item.selected{border-color:var(--drive-primary);background:#eff6ff;color:var(--drive-primary-strong)}.account-item span,.account-item em{color:var(--drive-muted);font-size:13px;font-style:normal}.account-create-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr)) auto auto auto;align-items:center;gap:10px}.check-line{display:inline-flex;align-items:center;gap:8px;color:var(--drive-text);font-weight:700;white-space:nowrap}.account-table{display:grid;gap:10px}.account-row{display:grid;grid-template-columns:minmax(160px,1.1fr) minmax(130px,1fr) minmax(150px,1fr) auto auto auto auto auto;align-items:center;gap:10px;padding:12px;border:1px solid var(--drive-border);border-radius:8px;background:var(--drive-surface-2)}.account-row>div{display:grid;gap:4px;min-width:0}.account-row span{min-width:0;color:var(--drive-muted);overflow:hidden;text-overflow:ellipsis}.protected-badge{display:inline-flex;justify-content:center;padding:6px 8px;border-radius:999px;background:#ecfdf5;color:#047857!important;font-size:12px;font-weight:900}.file-workspace{display:grid;grid-template-columns:260px minmax(0,1fr);gap:14px;align-items:start}.file-work-main{display:grid;gap:14px;min-width:0}.compact-toolbar{justify-content:flex-start;flex-wrap:wrap}.compact-toolbar input{flex:1 1 220px;min-width:180px}@media(max-width:980px){.login-page{grid-template-columns:1fr;align-content:center}.login-visual h1{font-size:36px}.drive-topbar{grid-template-columns:1fr}.drive-top-actions{justify-content:flex-start;flex-wrap:wrap}.drive-search{min-width:min(100%,260px);flex:1 1 220px}.drive-layout{display:flex;flex-direction:column;margin-top:80px}.drive-main{margin-left:0;padding:12px;max-height:calc(100vh - 80px)}.drive-sidebar{position:fixed;top:80px;left:0;z-index:70;width:min(88vw,360px);height:calc(100vh - 80px);max-height:none;overflow:auto;border-radius:0 8px 8px 0;transform:translate(-104%);transition:transform .2s ease;border-right:1px solid var(--drive-border)}.drive-sidebar.open{transform:translate(0)}.mobile-only{display:inline-flex;align-items:center;justify-content:center}.account-create-grid,.account-row{grid-template-columns:1fr}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr))}}.qr-modal{width:min(420px,calc(100vw - 32px));max-height:calc(100dvh - 32px);overflow:auto;display:grid;gap:18px;padding:22px;border-radius:18px;background:#fff;box-shadow:0 24px 80px #0f172a38}.qr-body{display:grid;gap:12px;text-align:center}.qr-code-box{display:grid;place-items:center;min-height:260px;padding:18px;border:1px solid rgba(148,163,184,.35);border-radius:16px;background:#f8fafc}.qr-code-box img{width:min(260px,100%);height:auto;border-radius:12px}.qr-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.move-modal{width:min(680px,calc(100vw - 40px));max-height:min(760px,calc(100dvh - 40px));display:grid;grid-template-rows:auto auto minmax(0,1fr);gap:14px;padding:22px;overflow:hidden;border-radius:18px;background:#fff;box-shadow:0 24px 80px #0f172a3d}.move-current-path{min-width:0;padding:10px 12px;border:1px solid rgba(148,163,184,.35);border-radius:8px;color:var(--drive-muted);background:#f8fafc;overflow-wrap:anywhere}.move-folder-list{min-height:0;overflow:auto;display:grid;gap:8px;padding:2px 4px 2px 2px}.move-folder-option{width:100%;min-height:46px;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px 12px;border:1px solid rgba(148,163,184,.38);border-radius:8px;color:var(--drive-text);background:#fff;box-shadow:none;text-align:left}.move-folder-option span{min-width:0;overflow-wrap:anywhere}.move-folder-option small{padding:3px 8px;border-radius:999px;color:#64748b;background:#e2e8f0;font-size:12px;white-space:nowrap}.move-folder-option:hover:not(:disabled),.move-folder-option:focus-visible:not(:disabled){border-color:#2563eb73;color:#1d4ed8;background:#eff6ff}.move-folder-option:disabled{cursor:not-allowed;opacity:.68}.folder-scroll-shell{position:relative;display:flex;flex:1;min-height:0;overflow:hidden}.folder-scroll-shell .folder-tree-wrap{width:100%}.sidebar-scroll-progress{position:absolute;top:10px;right:5px;bottom:10px;z-index:4;width:4px;overflow:hidden;border-radius:999px;background:#94a3b82e;pointer-events:none}.sidebar-scroll-progress span{position:absolute;left:0;right:0;top:0;min-height:18px;border-radius:inherit;background:linear-gradient(180deg,var(--drive-primary),var(--brand-purple));transition:height .12s ease}.folder-create-modal,.folder-package-modal{width:min(560px,calc(100vw - 40px));display:grid;gap:16px;padding:22px;border-radius:8px;background:#fff;box-shadow:0 24px 80px #0f172a3d}.trash-modal{width:min(860px,calc(100vw - 40px));max-height:min(760px,calc(100dvh - 40px));display:grid;grid-template-rows:auto minmax(0,1fr);gap:16px;padding:22px;overflow:hidden;border-radius:8px;background:#fff;box-shadow:0 24px 80px #0f172a3d}.trash-batch-list{display:grid;gap:10px;min-height:0;overflow:auto;padding-right:4px}.trash-batch-card{display:grid;grid-template-columns:minmax(0,1fr) minmax(160px,auto) auto;align-items:center;gap:12px;padding:12px;border:1px solid var(--drive-border);border-radius:8px;background:#fff}.trash-batch-main,.trash-batch-meta{display:grid;gap:4px;min-width:0}.trash-batch-main strong{overflow:hidden;color:var(--drive-text);text-overflow:ellipsis;white-space:nowrap}.trash-batch-main span,.trash-batch-meta span{color:var(--drive-muted);font-size:13px}.trash-batch-actions{display:flex;gap:8px}.package-progress-body{display:grid;gap:12px}.package-status-line{display:flex;align-items:center;justify-content:space-between;gap:12px}.package-status-line strong,.package-status-line span{min-width:0}.package-status-line strong{overflow:hidden;color:var(--drive-text);text-overflow:ellipsis;white-space:nowrap}.package-status-line span{color:var(--drive-primary-strong);font-weight:900}.package-file-name{min-width:0;max-width:100%;padding:9px 11px;border:1px solid rgba(148,163,184,.24);border-radius:8px;color:var(--drive-muted);background:#f8fafc;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.package-progress{height:12px}.package-meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.package-meta-grid span{min-width:0;padding:10px 12px;border-radius:8px;color:var(--drive-muted);background:#f8fafc;overflow-wrap:anywhere}.folder-name-field{display:grid;grid-template-columns:minmax(120px,max-content) minmax(0,1fr);align-items:center;overflow:hidden;border:1px solid var(--drive-border);border-radius:8px;background:#fff}.folder-name-field span{max-width:min(260px,44vw);min-width:0;padding:10px 12px;border-right:1px solid var(--drive-border);color:var(--drive-muted);background:#f8fafc;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-name-field input{min-width:0;border:0;border-radius:0}.folder-name-field input:focus{outline:2px solid rgba(37,99,235,.26);outline-offset:-2px}.modal-actions{display:flex;justify-content:flex-end;gap:10px}@media(max-width:540px){.drive-shell .table-wrap{display:block}.drive-shell .drive-top-actions,.drive-shell .drive-toolbar,.drive-shell .gallery-actions{display:grid;grid-template-columns:1fr}.qr-modal{width:100vw;max-height:100dvh;min-height:100dvh;border-radius:0;padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left))}.qr-code-box{min-height:220px}.qr-actions{grid-template-columns:1fr}.move-modal{width:100vw;max-height:100dvh;min-height:100dvh;border-radius:0;padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left))}.move-folder-option{grid-template-columns:1fr}.folder-create-modal,.folder-package-modal,.trash-modal{width:100vw;min-height:100dvh;max-height:100dvh;border-radius:0;padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left))}.folder-name-field{grid-template-columns:1fr}.folder-name-field span{max-width:none;border-right:0;border-bottom:1px solid var(--drive-border)}.modal-actions{display:grid;grid-template-columns:1fr 1fr}.package-meta-grid,.trash-batch-card{grid-template-columns:1fr}.trash-batch-actions{display:grid;grid-template-columns:1fr 1fr}}@media(max-width:540px){.login-page,.drive-shell{width:100%;padding:12px}.login-feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.login-card,.drive-topbar,.drive-main,.admin-panel{padding:14px}.drive-brand{align-items:flex-start}.drive-brand img{width:112px}.drive-toolbar,.drive-top-actions,.gallery-actions{display:grid;grid-template-columns:1fr;width:100%}.drive-toolbar input,.drive-top-actions input,.drive-toolbar button,.drive-top-actions button{width:100%;min-width:0}.drive-path,.selection-bar{display:grid;justify-items:stretch}.selection-bar{bottom:12px;top:auto}.gallery-grid{grid-template-columns:1fr}.table-wrap{display:block}}*{box-sizing:border-box}body{margin:0}button,input{font:inherit}button{border:0;border-radius:6px;background:linear-gradient(135deg,var(--brand-blue),var(--brand-purple));color:#fff;padding:10px 14px;cursor:pointer;white-space:nowrap}button:hover:not(:disabled){background:linear-gradient(135deg,#2168ef,#3d18c9)}button:disabled{cursor:not-allowed;opacity:.55}button.danger{background:#4a24e7}button.danger:hover:not(:disabled){background:#3d18c9}.ghost-button{border:1px solid #cbd5e1;background:#fff;color:#1f2933}.ghost-button:hover:not(:disabled){background:#f1f5f9}.drive-shell .drive-toolbar button,.drive-shell .toolbar button{border-width:1px;font-weight:800;box-shadow:0 1px 2px #0f172a0a;transition:background-color .16s ease,border-color .16s ease,color .16s ease,box-shadow .16s ease,transform .16s ease}.drive-shell .drive-toolbar button:hover:not(:disabled),.drive-shell .toolbar button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 18px #0f172a14}.toolbar-button-neutral{border-color:#cbd5e1;background:#fff;color:#172033}.toolbar-button-neutral:hover:not(:disabled){border-color:#94a3b8;background:#f8fafc}.toolbar-button-video{border-color:#bfdbfe;background:#eff6ff;color:#1d4ed8}.toolbar-button-video:hover:not(:disabled){border-color:#60a5fa;background:#dbeafe}.toolbar-button-create{border-color:#bbf7d0;background:#f0fdf4;color:#047857}.toolbar-button-create:hover:not(:disabled){border-color:#34d399;background:#dcfce7}.toolbar-button-package{border-color:#99f6e4;background:#ecfeff;color:#0f766e}.toolbar-button-package:hover:not(:disabled){border-color:#2dd4bf;background:#ccfbf1}.toolbar-button-trash{border-color:#fecdd3;background:#fff1f2;color:#be123c}.toolbar-button-trash:hover:not(:disabled){border-color:#fb7185;background:#ffe4e6}.toolbar-button-refresh{border-color:#e2e8f0;background:#f8fafc;color:#475569}.toolbar-button-refresh:hover:not(:disabled){border-color:#cbd5e1;background:#f1f5f9;color:#334155}.toolbar-button-upload{border:1px solid #4f46e5;background:linear-gradient(135deg,#2563eb,#4f46e5);color:#fff;box-shadow:0 10px 24px #2563eb38}.toolbar-button-upload:hover:not(:disabled){border-color:#4338ca;background:linear-gradient(135deg,#1d4ed8,#4338ca)}input{width:100%;border:1px solid #cbd5e1;border-radius:6px;padding:10px 12px;color:#1f2933;background:#fff}input[type=checkbox]{width:18px;height:18px;accent-color:var(--brand-purple)}label{display:grid;gap:8px;color:#475569;font-weight:600}a{color:var(--brand-purple);text-decoration:none}.app-shell{min-height:100vh}.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:14px clamp(16px,4vw,44px);border-bottom:1px solid #d8e1ea;background:#fffffff0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.brand{display:inline-flex;align-items:center}.brand img{display:block;width:180px;max-width:42vw;height:auto}.topbar nav{display:flex;gap:14px}.topbar .router-link-active{font-weight:800}.page{display:grid;gap:18px;width:min(1180px,calc(100% - 32px));margin:0 auto;padding:24px 0 48px}.hero{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:24px 0 8px}.hero h1{margin:0 0 8px;font-size:clamp(28px,4vw,42px);letter-spacing:0}.hero p{margin:0;color:#52616f}.client-page{width:min(1320px,calc(100% - 32px))}.client-hero{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:16px 0 2px}.client-brand-card{display:flex;align-items:center;gap:20px}.client-brand-card img{width:220px;max-width:36vw;height:auto}.client-brand-card h1{margin:0 0 6px;font-size:clamp(26px,4vw,40px);letter-spacing:0}.client-brand-card p{margin:0;color:#52616f}.client-workspace{display:grid;grid-template-columns:300px minmax(0,1fr);align-items:start;gap:18px}.client-folder-panel{position:sticky;top:82px;display:grid;gap:14px;padding:16px;border:1px solid #d8e1ea;border-radius:8px;background:#fff;box-shadow:0 10px 30px #0f172a0f}.sidebar-title{display:flex;align-items:center;justify-content:space-between;gap:12px;position:sticky;top:0;left:-16px;right:-16px;padding:12px 16px;background:#f3f4f6;border-radius:8px 8px 0 0}.sidebar-title h2{margin:0;font-size:20px}.sidebar-title button{padding:8px 10px}.sidebar-actions{display:flex;align-items:center;gap:8px}.mobile-only{display:none}.folder-nav{display:grid;gap:8px}.folder-nav button,.folder-tree-button{display:grid;grid-template-columns:24px 1fr;align-items:center;gap:10px;min-height:48px;padding:10px 12px;border:1px solid #d8e1ea;background:var(--brand-softer);color:var(--brand-ink);text-align:left;white-space:normal}.folder-nav button:hover,.folder-nav button.selected,.folder-tree-button:hover,.folder-tree-button.selected{border-color:var(--brand-blue);background:linear-gradient(135deg,var(--brand-blue),var(--brand-purple));color:#fff}.folder-nav button.expanded:not(.selected){border-color:#b7c7ff;background:var(--brand-soft);color:var(--brand-purple)}.folder-nav button:hover *,.folder-nav button.selected *,.folder-tree-button:hover *,.folder-tree-button.selected *,.folder-tabs button:hover *,.folder-tabs button.selected *,.subfolder-card:hover *,.subfolder-card.selected *,.folder-list button:hover *,.folder-list button.selected *{color:#fff}.folder-tree{display:grid;gap:4px;padding-left:10px}.folder-tree-node{display:grid;gap:4px}.folder-tree-children{margin-left:0;padding-left:20px}.folder-tree-button{width:100%;min-height:36px;padding:6px 10px;border:none;background:transparent;color:#1f2937;font-size:16px;text-align:left;cursor:pointer;display:flex;align-items:center;gap:4px;border-radius:4px;transition:background-color .15s}.folder-tree-button:hover{background-color:#dbeafe}.folder-tree-button.selected{background-color:#bfdbfe}.folder-expand-icon{color:#6b7280;flex-shrink:0;transition:transform .2s}.folder-tree-button.expanded .folder-expand-icon{transform:rotate(90deg)}.folder-icon{color:#f59e0b;flex-shrink:0;width:20px;height:20px}.folder-tree-row{display:flex;align-items:center;gap:2px;position:relative}.folder-tree-delete{position:absolute;top:-4px;right:-4px;width:24px;height:24px;padding:0;border:none;border-radius:50%;background:#fff1f2;color:#dc2626;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;display:flex;align-items:center;justify-content:center;z-index:10}.folder-tree-row:hover .folder-tree-delete,.folder-tree-delete:focus-visible{opacity:1;visibility:visible}.folder-tree-delete:hover{background:#dc2626;color:#fff}.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.folder-tree-wrap{display:flex;flex-direction:column;gap:8px;padding:16px;border-top:1px solid #e2e8f0;flex:1;overflow:auto}.company-tree{gap:8px}.company-tree-node{display:grid;gap:6px}.company-folder-tree{margin-left:20px}.folder-mark{position:relative;display:inline-block;width:22px;height:16px;border-radius:3px;background:currentColor;opacity:.88}.folder-mark:before{position:absolute;top:-5px;left:2px;width:9px;height:6px;border-radius:3px 3px 0 0;background:currentColor;content:""}.client-main{display:grid;gap:18px;min-width:0}.compact-panel{padding-block:14px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px;text-align:center}.empty-icon{color:#94a3b8;margin-bottom:8px}.empty-state h2,.empty-state p{margin:0}.empty-state p{color:#64748b}.panel,.login-panel,.folder-panel{border:1px solid #d8e1ea;border-radius:8px;background:#fff;box-shadow:0 10px 30px #0f172a0f}.panel,.login-panel{padding:18px}.panel-title{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px}.panel-title h2,.login-panel h2{margin:0;font-size:20px}.form-row{display:grid;grid-template-columns:1fr auto;align-items:end;gap:14px}.toolbar{display:flex;align-items:center;gap:10px}.toolbar input{min-width:220px}.inline-hint{margin-top:0}.create-folder{display:grid;gap:8px}.folder-tabs{display:flex;flex-wrap:wrap;gap:10px}.folder-tabs button{background:#eef2f7;color:#1f2933}.folder-tabs button:hover,.folder-tabs button.selected{background:linear-gradient(135deg,var(--brand-blue),var(--brand-purple));color:#fff}.subfolder-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:16px}.subfolder-card{min-height:74px;border:1px solid #cbd5e1;background:var(--brand-softer);color:var(--brand-ink);text-align:left}.subfolder-card:hover,.subfolder-card.selected{border-color:var(--brand-blue);background:linear-gradient(135deg,var(--brand-blue),var(--brand-purple));color:#fff}.admin-page{padding-top:18px}.admin-hero-actions{display:flex;align-items:center;gap:12px}.admin-login{margin:24px auto 0;width:min(420px,100%)}.admin-workspace{grid-template-columns:320px minmax(0,1fr)}.admin-sidebar{max-height:calc(100vh - 104px);overflow:auto}.admin-create{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.admin-create button{padding-inline:12px}.admin-count{margin-top:-2px}.admin-folder-nav{max-height:calc(100vh - 360px);overflow:auto;padding-right:2px}.admin-summary-panel .panel-title{margin-bottom:0}.admin-share-link{margin-top:12px;padding:10px 12px;border:1px solid #d8e1ea;border-radius:8px;background:#f8fafc;color:#475569;font-size:13px;line-height:1.5;word-break:break-all}.admin-subfolder-grid .subfolder-card{display:grid;grid-template-columns:28px 1fr;align-items:center;gap:12px;min-height:86px;padding:14px;white-space:normal}.dropzone{display:grid;gap:12px;place-items:center;min-height:360px;border:2px dashed #9fb3c8;border-radius:8px;background:#f7fafc;color:#52616f;cursor:pointer;transition:border-color .2s ease,background .2s ease}.upload-icon{display:grid;place-items:center;width:92px;height:92px;border-radius:999px;background:var(--brand-soft);color:var(--brand-purple)}.upload-icon svg{width:50px;height:50px}.upload-surface{display:grid;gap:14px}.upload-target{display:grid;gap:4px;padding:12px 14px;border:1px solid #d8e1ea;border-radius:8px;background:#f8fafc}.upload-target span{color:#64748b;font-size:13px}.upload-target strong{color:#102a43;word-break:break-all}.upload-actions{display:flex;justify-content:flex-end}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:24px;background:#0f172a73}.upload-modal{width:min(860px,100%);max-height:min(760px,calc(100vh - 48px));overflow:auto;border-radius:8px;background:#fff;padding:20px;box-shadow:0 24px 80px #0f172a47}.preview-modal{display:grid;grid-template-rows:auto minmax(0,1fr);width:min(1120px,100%);height:min(820px,calc(100vh - 48px));border-radius:8px;background:#fff;padding:20px;box-shadow:0 24px 80px #0f172a47}.modal-title{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}.modal-title h2,.modal-title p{margin:0}.modal-title p{margin-top:6px;color:#64748b;word-break:break-all}.preview-title{margin-bottom:12px}.preview-surface{display:grid;place-items:center;min-height:0;overflow:hidden;border:1px solid #d8e1ea;border-radius:8px;background:var(--brand-softer)}.preview-surface img{display:block;max-width:100%;max-height:100%;object-fit:contain}.preview-video-frame{display:grid;place-items:center;width:min(100%,calc((100vh - 220px)*.5625));height:min(100%,calc((100vw - 120px) * 16 / 9));max-width:100%;max-height:100%;aspect-ratio:9 / 16;background:#000}.preview-video-frame .preview-video{display:block;width:100%;height:100%;background:#000;object-fit:contain!important}.preview-surface audio{width:min(640px,calc(100% - 32px))}.preview-surface iframe{width:100%;height:100%;border:0;background:#fff}.dropzone strong{color:#1f2933;font-size:18px}.dropzone.active{border-color:var(--brand-blue);background:var(--brand-soft)}.dropzone.disabled{opacity:.58}.upload-list{display:grid;gap:10px;margin-top:14px}.upload-row{display:grid;grid-template-columns:minmax(180px,1fr) minmax(220px,360px) auto auto;align-items:center;gap:12px;padding:12px;border:1px solid #e2e8f0;border-radius:8px}.upload-row.success{border-color:#bbf7d0;background:#f0fdf4}.upload-row.error{border-color:#fecaca;background:#fff7f7}.upload-progress{display:grid;grid-template-columns:minmax(120px,1fr) 48px;align-items:center;gap:10px}.upload-progress strong{color:var(--brand-purple);font-size:13px;text-align:right}.progress{overflow:hidden;height:10px;border-radius:999px;background:#e2e8f0}.progress div{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--brand-cyan),var(--brand-purple));transition:width .2s ease}.progress.success{background:#bbf7d0}.progress.success div{background:linear-gradient(90deg,var(--brand-cyan),var(--brand-blue))}.progress.error div{background:#dc2626}.upload-row .error-text{grid-column:1 / -1}.status{min-width:78px;color:#52616f;font-size:13px;font-weight:700}.status.success{color:var(--brand-purple)}.status.error{color:#b42318}.table-wrap{overflow-x:auto}.file-card-list{display:none}table{width:100%;border-collapse:collapse;min-width:850px}th,td{padding:13px 12px;border-bottom:1px solid #e2e8f0;text-align:left;vertical-align:middle}th{color:#475569;font-size:13px;background:#f8fafc}.select-cell{width:46px;text-align:center}.file-name{color:#102a43;font-weight:700;word-break:break-word}.file-key{margin-top:4px;color:#748094;font-size:12px;word-break:break-all}.file-card-info{display:flex;align-items:center;gap:10px;min-width:0}.file-thumbnail{width:48px;height:48px;object-fit:cover;border-radius:6px;border:1px solid #e2e8f0;flex-shrink:0}.file-thumbnail-placeholder{width:48px;height:48px;border-radius:6px;border:1px solid #e2e8f0;background:#f1f5f9;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#64748b;font-size:11px;font-weight:600}.table-file-name{display:flex;align-items:center;gap:10px;min-width:0}.table-thumbnail{width:36px;height:36px;object-fit:cover;border-radius:4px;border:1px solid #e2e8f0;flex-shrink:0}.table-thumbnail-placeholder{width:36px;height:36px;border-radius:4px;border:1px solid #e2e8f0;background:#f1f5f9;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#64748b;font-size:10px;font-weight:600}.actions{display:flex;flex-wrap:wrap;gap:8px}.actions button{padding:8px 10px}.warning,.error-box,.success-box{display:grid;gap:4px;padding:12px 14px;border-radius:8px}.warning{border:1px solid #f7c948;background:#fff8db;color:#7c2d12}.error-box{margin-bottom:12px;border:1px solid #fecaca;background:#fff1f2;color:#b42318}.success-box{margin-top:14px;border:1px solid #c7d2fe;background:var(--brand-softer);color:var(--brand-purple);font-weight:700}.error-text{color:#b42318;font-size:13px;font-weight:700}.hint{margin-top:10px;color:#64748b;font-size:14px}.empty{color:#748094;text-align:center}.login-panel{display:grid;gap:14px;max-width:420px}.admin-layout{display:grid;grid-template-columns:280px 1fr;align-items:start;gap:18px}.folder-panel{position:sticky;top:78px;display:grid;gap:12px;padding:14px}.folder-list{display:grid;gap:8px;max-height:calc(100vh - 230px);overflow:auto}.folder-list button{width:100%;background:#eef2f7;color:#1f2933;text-align:left}.folder-list button:hover,.folder-list button.selected{background:linear-gradient(135deg,var(--brand-blue),var(--brand-purple));color:#fff}.files-panel{min-width:0}@media(max-width:820px){html,body,#app,.app-shell{width:100%;max-width:100%;overflow-x:hidden}.page{width:100%;max-width:100%;padding:14px 12px 36px}.client-page{width:100%}.topbar,.hero,.panel-title,.form-row,.admin-layout{grid-template-columns:1fr}.topbar,.hero,.client-hero,.client-brand-card,.admin-hero-actions,.panel-title{display:grid;align-items:start}.client-workspace,.admin-workspace{grid-template-columns:1fr}.admin-page{gap:14px}.admin-page .client-hero{width:100%;gap:12px;padding:4px 0 0}.admin-page .client-brand-card{min-width:0;gap:12px}.admin-page .client-brand-card img{width:176px;max-width:72vw}.admin-page .client-brand-card h1{font-size:26px;line-height:1.2}.admin-page .client-brand-card p{max-width:100%;font-size:15px;line-height:1.55;overflow-wrap:anywhere}.admin-hero-actions{width:100%;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.admin-hero-actions a,.admin-hero-actions button{display:inline-flex;align-items:center;justify-content:center;min-width:0;min-height:44px}.admin-hero-actions a{border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:var(--brand-purple);font-weight:700}.mobile-only{display:inline-flex;align-items:center;justify-content:center}.client-folder-panel{position:fixed;top:0;left:0;z-index:70;width:min(86vw,360px);height:100vh;max-height:none;overflow:auto;border-radius:0 8px 8px 0;transform:translate(-104%);transition:transform .2s ease}.client-folder-panel.open{transform:translate(0)}.mobile-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#0f172a73}.admin-sidebar,.admin-folder-nav{max-height:none}.admin-create{grid-template-columns:1fr}.panel,.login-panel{padding:16px}.admin-summary-panel .panel-title{gap:14px}.admin-summary-panel .toolbar{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.admin-summary-panel .toolbar>*{flex-basis:auto}.client-brand-card img{max-width:240px}.toolbar{width:100%;flex-wrap:wrap}.toolbar>*{flex:1 1 100%}.toolbar button{min-height:44px}.toolbar input{min-width:0}.empty-state{padding:26px 12px}.empty-state h2{font-size:24px;line-height:1.25}.empty-state p{line-height:1.55}.table-wrap{display:none}.file-card-list{display:grid;gap:12px}.file-card{display:grid;gap:12px;padding:14px;border:1px solid #d8e1ea;border-radius:8px;background:#fff}.file-card-head{display:grid;grid-template-columns:26px minmax(0,1fr);align-items:start;gap:10px}.file-meta-grid{display:grid;grid-template-columns:1fr;gap:8px;padding:10px 12px;border-radius:8px;background:var(--brand-softer)}.file-meta-grid div{display:grid;grid-template-columns:74px minmax(0,1fr);gap:10px}.file-meta-grid span{color:#64748b;font-size:13px}.file-meta-grid strong{min-width:0;color:#1f2933;font-weight:700;word-break:break-word}.file-card-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.file-card-actions button{min-height:44px}.file-card-empty{padding:24px 0}.upload-row{grid-template-columns:1fr}.folder-panel{position:static}.modal-backdrop{padding:0;place-items:stretch}.modal-title{display:grid}.preview-modal{width:100vw;height:100dvh;max-height:100dvh;overflow:hidden;border-radius:0;padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));grid-template-rows:auto minmax(0,1fr)}.preview-title{min-width:0}.preview-title h2,.preview-title p{overflow-wrap:anywhere}.preview-title .toolbar{display:grid;grid-template-columns:1fr 1fr 1fr;width:100%}.preview-title .toolbar>*{flex-basis:auto;min-width:0}.preview-surface{width:100%;min-width:0;overflow:hidden;padding:12px}.preview-surface img{width:auto;height:auto;max-width:100%;max-height:100%}.preview-video-frame{width:min(100%,calc(100vw - 56px));height:auto;max-width:100%;max-height:100%;aspect-ratio:9 / 16}}.drive-shell button.danger,.login-page button.danger{background:var(--drive-danger)}.drive-shell button.danger:hover:not(:disabled),.login-page button.danger:hover:not(:disabled){background:#b91c1c}.drive-shell .table-wrap{display:block}@media(max-width:540px){.drive-shell .table-wrap{display:block}.drive-shell .drive-top-actions,.drive-shell .drive-toolbar,.drive-shell .gallery-actions{display:grid;grid-template-columns:1fr}}.tip-container{position:fixed;top:20px;right:20px;z-index:1000;display:flex;flex-direction:column;gap:10px}.tip{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:200px;max-width:400px}.tip-icon{flex-shrink:0}.tip-text{flex:1;font-size:14px;line-height:1.4}.tip-close{flex-shrink:0;background:transparent;border:none;cursor:pointer;padding:2px;opacity:.6;transition:opacity .2s}.tip-close:hover{opacity:1}.tip.success{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}.tip.error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.tip.warning{background:#fffbeb;border:1px solid #fde68a;color:#92400e}.tip.info{background:#f0f9ff;border:1px solid #7dd3fc;color:#0369a1}.tip-enter-active,.tip-leave-active{transition:all .3s ease}.tip-enter-from,.tip-leave-to{opacity:0;transform:translate(100%)}.tip-move{transition:transform .3s ease}
