.app{display:flex;min-height:100vh;padding-top:var(--nav-h)}
.app:has(.auth-page){padding-top:0}
.app:has(.auth-page) .main{margin-left:0}
.app:has(.auth-page) ~ .bottom-nav{display:none !important}
.main{flex:1;margin-left:var(--sidebar-w);min-width:0}
.container{max-width:1200px;margin:0 auto;padding:0 var(--space-6);width:100%}

/* Sidebar */
.sidebar{
  position:fixed;top:var(--nav-h);left:0;bottom:0;width:var(--sidebar-w);
  background:var(--canvas);border-right:1px solid var(--hairline);
  display:flex;flex-direction:column;z-index:50;transition:transform .25s;
  overflow-y:auto;
}
.sidebar-section{padding:var(--space-4) var(--space-4)}
.sidebar-section h3{
  font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  color:var(--mute);margin-bottom:var(--space-2);padding:0 var(--space-2);
}
.sidebar-item{
  display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);
  border-radius:var(--radius-sm);font-size:.875rem;color:var(--body);transition:all .15s;cursor:pointer;
}
.sidebar-item:hover{background:var(--primary-soft);color:var(--primary)}
.sidebar-item.active{background:var(--primary-soft);color:var(--primary);font-weight:600}
.sidebar-item .icon{width:18px;height:18px;flex-shrink:0;display:flex;align-items:center;justify-content:center}

/* Top nav */
.topnav{
  position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:100;
  background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur)) saturate(1.5);
  -webkit-backdrop-filter:blur(var(--glass-blur)) saturate(1.5);
  border-bottom:1px solid var(--glass-border);
  display:flex;align-items:center;padding:0 var(--space-6);gap:var(--space-3);
}
.topnav-logo{
  display:flex;align-items:center;gap:var(--space-2);font-weight:700;font-size:1.125rem;
  color:var(--ink);text-decoration:none;
}
.topnav-logo .mark{
  width:30px;height:30px;border-radius:var(--radius-sm);
  background:linear-gradient(135deg,var(--primary),var(--accent-purple));
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:.875rem;font-weight:700;
  box-shadow:0 2px 8px rgba(37,99,235,.3);
}
.topnav-search{
  flex:1;max-width:320px;position:relative;
}
.topnav-search input{
  width:100%;height:36px;padding:0 var(--space-8) 0 var(--space-4);
  border:1px solid var(--hairline);border-radius:var(--radius-full);
  font-size:.875rem;outline:none;transition:border-color .15s;background:var(--canvas);
}
.topnav-search input:focus{border-color:var(--primary)}
.topnav-search .search-icon{
  position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);
  color:var(--mute);width:14px;height:14px;pointer-events:none;
}
.topnav-actions{display:flex;align-items:center;gap:var(--space-2);margin-left:auto}

/* Bottom tab (mobile) */
.bottom-nav{display:none}

/* Page sections */
.page{padding:var(--space-6) 0 var(--space-10)}
.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);flex-wrap:wrap;gap:var(--space-3)}
.page-header h1{font-size:1.5rem;font-weight:700;letter-spacing:-.03em}
.page-header .sub{font-size:.875rem;color:var(--body)}

/* Breadcrumb */
.breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:.875rem;color:var(--mute);margin-bottom:var(--space-4);flex-wrap:wrap}
.breadcrumb a{color:var(--body)}.breadcrumb a:hover{color:var(--primary)}.breadcrumb .sep{color:var(--hairline);font-size:.75rem}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:6px;height:36px;min-height:44px;
  padding:0 var(--space-4);font-size:.875rem;font-weight:600;border:none;
  border-radius:var(--radius-sm);transition:all .15s;white-space:nowrap;
}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 1px 3px rgba(37,99,235,.2)}
.btn-primary:hover{background:var(--primary-hover);box-shadow:0 2px 8px rgba(37,99,235,.3)}
.btn-ghost{background:transparent;color:var(--body);border:1px solid var(--hairline)}
.btn-ghost:hover{background:var(--soft);color:var(--ink)}
.btn-success{background:var(--success);color:#fff}
.btn-danger{background:var(--danger);color:#fff}
.btn-sm{height:32px;min-height:36px;padding:0 var(--space-3);font-size:.8125rem}
.btn-icon{
  width:36px;height:36px;min-width:44px;min-height:44px;
  display:inline-flex;align-items:center;justify-content:center;padding:0;
}

/* Toolbar */
.toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-4)}
.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}

/* Cards */
.card{
  background:var(--canvas);border:1px solid var(--hairline);
  border-radius:var(--radius-md);padding:var(--space-5);transition:all .2s;
}
.card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-sm)}
.card-glass{
  background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));
  border:1px solid var(--glass-border);border-radius:var(--radius-md);
  padding:var(--space-5);box-shadow:var(--shadow-sm);transition:all .2s;
}
.card-glass:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}

/* Bento grid */
.bento-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);
  grid-auto-rows:180px;
}

/* File grid */
.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-3)}
.file-card{
  background:var(--canvas);border:1px solid var(--hairline);
  border-radius:var(--radius-md);overflow:hidden;transition:all .2s;cursor:pointer;
}
.file-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.file-card.selected{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light);background:var(--primary-soft)}
.file-card .thumb{
  aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;
  font-size:2.5rem;position:relative;overflow:hidden;
}
.file-card .thumb .badge{
  position:absolute;top:var(--space-2);right:var(--space-2);
  padding:1px 6px;font-size:.625rem;font-weight:600;text-transform:uppercase;
  background:var(--glass-bg);backdrop-filter:blur(8px);border:1px solid var(--glass-border);
  border-radius:var(--radius-sm);color:var(--body);
}
.file-card .info{padding:var(--space-2) var(--space-3) var(--space-3)}
.file-card .info .name{font-size:.8125rem;font-weight:600;line-height:1.3;color:var(--ink)}
.file-card .info .meta{display:flex;justify-content:space-between;font-size:.6875rem;color:var(--mute);margin-top:2px}

/* List view */
.file-list{display:none;flex-direction:column;gap:2px}
.file-list .file-card{display:flex;align-items:center;gap:var(--space-4);border-radius:var(--radius-sm)}
.file-list .file-card .thumb{width:40px;height:40px;aspect-ratio:1;border-radius:var(--radius-xs);font-size:1.25rem;flex-shrink:0}
.file-list .file-card .info{flex:1;padding:var(--space-2);display:flex;align-items:center;gap:var(--space-4)}
.file-list .file-card .name{margin:0;flex:1}
.file-list .meta{gap:var(--space-6)}
.view-grid .file-list{display:none}.view-grid .file-grid{display:grid}
.view-list .file-grid{display:none}.view-list .file-list{display:flex}

/* Form */
.form-group{margin-bottom:var(--space-4)}
.form-group label{display:block;font-size:.875rem;font-weight:600;margin-bottom:var(--space-1);color:var(--ink)}
.form-input{
  width:100%;height:40px;min-height:44px;padding:0 var(--space-3);
  border:1px solid var(--hairline);border-radius:var(--radius-sm);
  font-size:.875rem;outline:none;transition:border-color .15s;background:var(--canvas);
}
.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.form-error{font-size:.8125rem;color:var(--danger);margin-top:var(--space-1)}

/* Storage bar */
.storage-bar{height:8px;background:var(--hairline);border-radius:var(--radius-full);overflow:hidden}
.storage-bar .fill{height:100%;border-radius:var(--radius-full);background:linear-gradient(90deg,var(--primary),var(--accent-purple));transition:width .6s ease}

/* Stat card */
.stat-value{font-size:1.5rem;font-weight:700;letter-spacing:-.03em;line-height:1}
.stat-label{font-size:.8125rem;color:var(--body);margin-top:2px}

/* Modal overlay */
.modal-overlay{
  position:fixed;inset:0;z-index:200;background:rgba(15,23,42,.4);
  backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;
  padding:var(--space-6);
}
.modal{
  background:var(--canvas);border-radius:var(--radius-lg);width:100%;max-width:480px;
  max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);
  padding:var(--space-6);
}
.modal h2{font-size:1.125rem;font-weight:700;margin-bottom:var(--space-4)}
.modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-5)}

/* Toast */
.toast-container{position:fixed;top:calc(var(--nav-h) + var(--space-3));right:var(--space-4);z-index:300;display:flex;flex-direction:column;gap:var(--space-2);pointer-events:none}
.toast{
  pointer-events:auto;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);
  font-size:.875rem;font-weight:500;box-shadow:var(--shadow-lg);
  animation:toastIn .25s ease;max-width:360px;
  display:flex;align-items:center;gap:var(--space-2);
}
.toast.success{background:var(--success);color:#fff}
.toast.error{background:var(--danger);color:#fff}
.toast.info{background:var(--primary);color:#fff}
.toast.warning{background:var(--warning);color:#fff}
.toast.removing{animation:toastOut .2s ease forwards}
@keyframes toastIn{from{opacity:0;transform:translateX(80px)}}
@keyframes toastOut{to{opacity:0;transform:translateX(80px)}}

/* Drop zone */
.drop-zone{
  border:2px dashed var(--hairline);border-radius:var(--radius-lg);
  padding:var(--space-10);text-align:center;transition:all .2s;
  cursor:pointer;position:relative;
}
.drop-zone:hover,.drop-zone.dragover{border-color:var(--primary);background:var(--primary-soft)}
.drop-zone .icon{font-size:2.5rem;margin-bottom:var(--space-2)}
.drop-zone p{font-size:.875rem;color:var(--body)}

/* Upload queue */
.upload-queue{position:fixed;bottom:var(--space-4);right:var(--space-4);z-index:250;width:360px;max-height:300px;overflow-y:auto;background:var(--canvas);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);border:1px solid var(--hairline);display:none}
.upload-queue.show{display:block}
.upload-item{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--hairline);font-size:.8125rem}
.upload-item:last-child{border-bottom:none}
.upload-item .name{font-weight:600;color:var(--ink)}
.upload-item .progress{height:4px;background:var(--hairline);border-radius:2px;margin-top:4px;overflow:hidden}
.upload-item .progress .bar{height:100%;background:var(--primary);border-radius:2px;transition:width .2s}
.upload-item .status{font-size:.75rem;color:var(--mute);margin-top:2px}

/* Confirm dialog */
.confirm-text{font-size:.875rem;color:var(--body);line-height:1.6}
.confirm-warning{color:var(--danger);font-weight:600}

/* Context menu */
.context-menu{
  position:fixed;z-index:220;background:var(--canvas);border:1px solid var(--hairline);
  border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);padding:var(--space-1);min-width:160px;
}
.context-menu-item{
  display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);
  font-size:.8125rem;color:var(--body);border-radius:var(--radius-xs);cursor:pointer;transition:background .1s;
}
.context-menu-item:hover{background:var(--primary-soft);color:var(--primary)}
.context-menu-item.danger{color:var(--danger)}.context-menu-item.danger:hover{background:var(--danger-soft)}

/* Scrollable folder row */
.folder-row{display:flex;gap:var(--space-3);overflow-x:auto;padding-bottom:var(--space-2);margin-bottom:var(--space-4);-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.folder-row::-webkit-scrollbar{height:4px}
.folder-row::-webkit-scrollbar-thumb{background:var(--mute);border-radius:4px}
.folder-chip{
  flex-shrink:0;padding:var(--space-2) var(--space-4);border:1px solid var(--hairline);
  border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;color:var(--body);
  background:var(--canvas);cursor:pointer;transition:all .15s;white-space:nowrap;
}
.folder-chip:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}
.folder-chip .ct{font-size:.6875rem;color:var(--mute);margin-left:4px}

/* Preview modal */
.preview-modal{max-width:900px;max-height:85vh}
.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}
.preview-header .name{font-weight:600;font-size:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.preview-body{display:flex;align-items:center;justify-content:center;min-height:200px;max-height:65vh;overflow:hidden}
.preview-body img{max-width:100%;max-height:65vh;object-fit:contain;border-radius:var(--radius-sm)}
.preview-body iframe{width:100%;height:65vh;border:none;border-radius:var(--radius-sm)}
.preview-body video,.preview-body audio{width:100%;max-height:65vh}
.preview-body pre{width:100%;max-height:65vh;overflow:auto;background:var(--ink);color:#e2e8f0;padding:var(--space-4);border-radius:var(--radius-sm);font-size:.8125rem;line-height:1.5;white-space:pre-wrap;word-break:break-all}

/* Empty state */
.empty-state{text-align:center;padding:var(--space-16) var(--space-6)}
.empty-state .icon{font-size:3rem;margin-bottom:var(--space-3)}
.empty-state p{color:var(--body);margin-bottom:var(--space-4)}

/* Auth page */
.auth-page{
  display:flex;align-items:center;justify-content:center;
  min-height:100vh;height:100vh;padding:var(--space-4);
  background:linear-gradient(135deg,var(--primary-soft),var(--canvas));
  box-sizing:border-box;
}
.auth-card{width:100%;max-width:400px;padding:var(--space-8);background:var(--canvas);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid var(--hairline);margin:auto}
.auth-card .logo{text-align:center;margin-bottom:var(--space-6)}
.auth-card .logo .mark{display:inline-flex}

/* Settings */
.settings-section{margin-bottom:var(--space-8)}
.settings-section h2{font-size:1rem;font-weight:700;margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--hairline)}

/* Admin */
.admin-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}
.stat-box{text-align:center;padding:var(--space-4)}
.stat-box .num{font-size:1.75rem;font-weight:700;letter-spacing:-.04em}
.stat-box .lbl{font-size:.8125rem;color:var(--body);margin-top:2px}
