/* ═══════════════════════════════════════════════════════════════
   SEGVLAB DRIVE · app.css
   ═══════════════════════════════════════════════════════════════ */

/* ── Theme tokens ─────────────────────────────────────────────── */
:root {
  --bg:#0b0d10;--surface:#111419;--surface-2:#161a20;--surface-3:#1c2128;
  --border:rgba(255,255,255,0.07);--divider:rgba(255,255,255,0.05);
  --text:#eef0f3;--text-muted:#8a95a3;--text-faint:#505a66;
  --primary:#5ec9be;--primary-hover:#4db8ad;--primary-dim:rgba(94,201,190,0.10);--primary-ink:#062220;
  --danger:rgba(248,113,113,0.13);--danger-border:rgba(248,113,113,0.22);
  --danger-text:#fca5a5;--danger-hover:rgba(248,113,113,0.20);
  --r-sm:6px;--r-md:10px;--r-lg:14px;--r-xl:18px;--r-full:9999px;
  --s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:20px;--s6:24px;--s8:32px;--s10:40px;--s12:48px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.3);--shadow-md:0 4px 16px rgba(0,0,0,.35);--shadow-lg:0 12px 40px rgba(0,0,0,.5);
  --font-body:'General Sans','Inter',system-ui,sans-serif;--ease:160ms cubic-bezier(0.16,1,0.3,1);
  --sidebar-overlay:rgba(0,0,0,.55);
}
[data-theme="light"]{
  --bg:#f2f4f7;--surface:#ffffff;--surface-2:#f7f8fa;--surface-3:#eef0f3;
  --border:rgba(0,0,0,.09);--divider:rgba(0,0,0,.06);
  --text:#111419;--text-muted:#505a66;--text-faint:#9ba5b0;
  --primary:#0e9e93;--primary-hover:#0c8a80;--primary-dim:rgba(14,158,147,.10);--primary-ink:#ffffff;
  --danger:rgba(220,38,38,.08);--danger-border:rgba(220,38,38,.2);--danger-text:#dc2626;--danger-hover:rgba(220,38,38,.14);
  --shadow-sm:0 1px 3px rgba(0,0,0,.07);--shadow-md:0 4px 16px rgba(0,0,0,.10);--shadow-lg:0 12px 40px rgba(0,0,0,.15);
  --sidebar-overlay:rgba(0,0,0,.3);
}

/* ── Reset ────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth}
body{min-height:100dvh;font-family:var(--font-body);font-size:15px;line-height:1.6;color:var(--text);background-color:var(--bg);transition:background-color .25s ease,color .25s ease}
img,svg,video,iframe{display:block;max-width:100%}
input,button,select,textarea{font:inherit;color:inherit}
button{cursor:pointer;background:none;border:none}
a{color:inherit;text-decoration:none}
table{border-collapse:collapse;width:100%}
.hidden{display:none!important}
:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:var(--r-sm)}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(128,128,128,.15);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:rgba(128,128,128,.28)}

/* ── Brand ────────────────────────────────────────────────────── */
.brand{display:flex;align-items:center;gap:var(--s3)}
.brand-mark{width:36px;height:36px;border-radius:var(--r-md);background:linear-gradient(145deg,#161e25,#0e1419);border:1px solid rgba(94,201,190,.15);display:grid;place-items:center;flex-shrink:0;box-shadow:var(--shadow-sm)}
[data-theme="light"] .brand-mark{background:linear-gradient(145deg,#e0f4f3,#c8eded)}
.brand-mark svg{width:22px;height:22px}
.brand-name{font-size:15px;font-weight:700;letter-spacing:-.03em;color:var(--text)}
.brand-name span{color:var(--text-faint);font-weight:500}

/* ── Layout ───────────────────────────────────────────────────── */
.shell{display:grid;grid-template-columns:230px minmax(0,1fr);grid-template-rows:auto 1fr;min-height:100dvh}
.topbar{grid-column:1/-1;height:54px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 var(--s4);gap:var(--s3);position:sticky;top:0;z-index:200;transition:background .25s,border-color .25s}
.topbar-brand{flex:1;display:flex;align-items:center;gap:var(--s3)}
.topbar-actions{display:flex;align-items:center;gap:var(--s2)}
.main{padding:var(--s4);display:flex;flex-direction:column;gap:var(--s4);min-width:0}

/* ── Sidebar ──────────────────────────────────────────────────── */
.sidebar{background:var(--surface);border-right:1px solid var(--border);padding:var(--s3) var(--s3);display:flex;flex-direction:column;gap:var(--s3);overflow-y:auto;height:calc(100dvh - 54px);position:sticky;top:54px;transition:background .25s,border-color .25s}
.sidebar-section-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);padding:0 var(--s2)}

/* ── Mobile sidebar ───────────────────────────────────────────── */
.sidebar-overlay{display:none;position:fixed;inset:0;z-index:300;background:var(--sidebar-overlay);backdrop-filter:blur(3px);opacity:0;transition:opacity .2s ease}
.sidebar-overlay.open{opacity:1}
.sidebar-drawer{position:fixed;top:0;left:0;height:100dvh;width:272px;z-index:301;background:var(--surface);border-right:1px solid var(--border);padding:var(--s4) var(--s3);display:flex;flex-direction:column;gap:var(--s3);overflow-y:auto;transform:translateX(-100%);transition:transform .25s cubic-bezier(0.16,1,0.3,1)}
.sidebar-drawer.open{transform:translateX(0)}
.drawer-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--s3);border-bottom:1px solid var(--border);margin-bottom:2px}
.menu-btn{display:none;width:34px;height:34px;border-radius:var(--r-md);align-items:center;justify-content:center;color:var(--text-muted);border:1px solid var(--border);background:transparent;cursor:pointer;transition:all var(--ease);flex-shrink:0}
.menu-btn:hover{background:var(--surface-3);color:var(--text)}
.menu-btn svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round}

/* ── Sidebar compact stat cards ──────────────────────────────── */
.sidebar-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:10px 12px;display:flex;flex-direction:column;gap:7px;transition:background .25s,border-color .25s}
.sidebar-card-title{font-size:10px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--text-faint)}
.sc-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.sc-label{font-size:11px;color:var(--text-muted);font-weight:500}
.sc-value{font-size:12px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}
.sc-value.hi{color:var(--primary)}
.sc-bar{width:100%;height:3px;background:rgba(128,128,128,.12);border-radius:99px;overflow:hidden}
.sc-bar-fill{height:100%;border-radius:inherit;background:var(--primary);transition:width .4s}
.sc-bar-fill.warn{background:linear-gradient(90deg,#f97316,#facc15)}
.sc-bar-fill.danger{background:#f87171}
.sc-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.sc-gi{background:var(--surface-3);border-radius:var(--r-sm);padding:6px 8px}
.sc-gi-label{font-size:10px;color:var(--text-faint);font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.sc-gi-value{font-size:13px;font-weight:700;color:var(--text);margin-top:1px}

/* ── Apollo miner button ──────────────────────────────────────── */
.apollo-btn{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-lg);background:linear-gradient(135deg,rgba(15,52,96,.55) 0%,rgba(26,26,46,.75) 100%);border:1px solid rgba(94,201,190,.22);text-decoration:none;transition:all var(--ease);box-shadow:0 2px 10px rgba(94,201,190,.05)}
[data-theme="light"] .apollo-btn{background:linear-gradient(135deg,rgba(14,158,147,.08) 0%,rgba(6,34,32,.04) 100%);border-color:rgba(14,158,147,.25)}
.apollo-btn:hover{border-color:rgba(94,201,190,.45);box-shadow:0 4px 18px rgba(94,201,190,.13);transform:translateY(-1px)}
.apollo-logo{width:36px;height:36px;flex-shrink:0}
.apollo-btn-text{display:flex;flex-direction:column;gap:1px;min-width:0}
.apollo-btn-label{font-size:12px;font-weight:700;color:var(--text);letter-spacing:-.01em;white-space:nowrap}
.apollo-btn-sub{font-size:10px;color:var(--primary);font-weight:600;letter-spacing:.02em}

/* ── Roundcube webmail button ─────────────────────────────────── */
.webmail-btn{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-lg);background:linear-gradient(135deg,rgba(7,24,40,.8) 0%,rgba(10,37,64,.9) 100%);border:1px solid rgba(29,167,225,.28);text-decoration:none;transition:all var(--ease);box-shadow:0 2px 10px rgba(29,167,225,.05);min-height:44px}
[data-theme="light"] .webmail-btn{background:linear-gradient(135deg,rgba(29,167,225,.10) 0%,rgba(10,40,80,.04) 100%);border-color:rgba(29,167,225,.3)}
.webmail-btn:hover{border-color:rgba(29,167,225,.55);box-shadow:0 4px 18px rgba(29,167,225,.18);transform:translateY(-1px)}
.webmail-logo{width:36px;height:36px;flex-shrink:0;display:block}
.webmail-btn-text{display:flex;flex-direction:column;gap:1px;min-width:0}
.webmail-btn-label{font-size:12px;font-weight:700;color:var(--text);letter-spacing:-.01em;white-space:nowrap}
.webmail-btn-sub{font-size:10px;color:#1da7e1;font-weight:600;letter-spacing:.02em}

/* ── Apollo min-height mobile fix ─────────────────────────────── */
.apollo-btn{min-height:44px}

/* ── Grid thumbnail ───────────────────────────────────────────── */
.grid-icon.grid-thumb{background:var(--surface-3);overflow:hidden;padding:0;border:1px solid var(--border)}
.grid-icon.grid-thumb img{width:100%;height:100%;object-fit:cover;display:block}

/* ── Theme toggle ─────────────────────────────────────────────── */
.theme-toggle{width:34px;height:34px;border-radius:var(--r-md);display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:transparent;color:var(--text-muted);cursor:pointer;transition:all var(--ease);flex-shrink:0}
.theme-toggle:hover{background:var(--surface-3);color:var(--text)}
.theme-toggle svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
[data-theme="dark"] .icon-sun{display:none}[data-theme="dark"] .icon-moon{display:block}
[data-theme="light"] .icon-sun{display:block}[data-theme="light"] .icon-moon{display:none}

/* ── Nav ──────────────────────────────────────────────────────── */
.nav-item{display:flex;align-items:center;gap:var(--s2);padding:7px var(--s3);border-radius:var(--r-md);font-size:13px;color:var(--text-muted);font-weight:500;transition:background var(--ease),color var(--ease)}
.nav-item:hover{background:var(--surface-3);color:var(--text)}
.nav-item.active{background:var(--primary-dim);color:var(--primary)}

/* ── Card ─────────────────────────────────────────────────────── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;animation:fadeIn .25s ease both;transition:background .25s,border-color .25s}
.card-header{padding:var(--s3) var(--s4);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:var(--s3)}
.card-title{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}
.card-body{padding:var(--s4)}

/* Admin stat (legacy compat) */
.stat{display:flex;flex-direction:column;gap:var(--s1)}.stat-label{font-size:11px;color:var(--text-faint);font-weight:600;text-transform:uppercase;letter-spacing:.07em}.stat-value{font-size:19px;font-weight:700;letter-spacing:-.02em}.stat-sub{font-size:12px;color:var(--text-faint)}
.progress{width:100%;height:5px;background:rgba(128,128,128,.1);border-radius:99px;overflow:hidden;margin-top:var(--s1)}.progress-fill{height:100%;border-radius:inherit;background:var(--primary);transition:width .4s}.progress-fill.warn{background:linear-gradient(90deg,#f97316,#facc15)}.progress-fill.danger{background:#f87171}.stat-divider{height:1px;background:var(--divider)}

/* ── Buttons ──────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--s2);padding:0 var(--s4);height:36px;border-radius:var(--r-md);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--ease);border:1px solid transparent;white-space:nowrap;flex-shrink:0}
.btn-primary{background:var(--primary);color:var(--primary-ink)}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 14px rgba(94,201,190,.22)}
.btn-ghost{background:transparent;color:var(--text-muted);border-color:var(--border)}.btn-ghost:hover{background:var(--surface-3);color:var(--text);border-color:rgba(128,128,128,.18)}
.btn-danger{background:var(--danger);color:var(--danger-text);border-color:var(--danger-border)}.btn-danger:hover{background:var(--danger-hover)}
.btn-icon{width:32px;height:32px;padding:0;border-radius:var(--r-md)}.btn-icon-sm{width:27px;height:27px;padding:0;border-radius:var(--r-sm)}.btn:disabled{opacity:.45;pointer-events:none}

/* ── Inputs ───────────────────────────────────────────────────── */
.input{width:100%;height:38px;padding:0 var(--s3);background:rgba(128,128,128,.04);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text);font-size:13px;transition:border-color var(--ease),box-shadow var(--ease);outline:none}
.input:focus{border-color:rgba(94,201,190,.4);box-shadow:0 0 0 3px rgba(94,201,190,.08)}
.input::placeholder{color:var(--text-faint)}.input-group{display:flex;gap:var(--s2);align-items:center}

/* ── Global search ────────────────────────────────────────────── */
.gsearch-wrap{position:relative;flex:1;max-width:340px}
.gsearch-input{padding-left:32px!important;height:34px!important;font-size:13px!important}
.gsearch-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:13px;height:13px;color:var(--text-faint);pointer-events:none;fill:none;stroke:currentColor;stroke-width:2.2}
.gsearch-results{position:absolute;top:calc(100% + 5px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);z-index:500;max-height:380px;overflow-y:auto;display:none;animation:fadeIn .15s ease}
.gsearch-results.open{display:block}
.gsr-item{display:flex;align-items:center;gap:10px;padding:10px 13px;cursor:pointer;transition:background var(--ease);border-bottom:1px solid var(--divider);text-decoration:none;color:var(--text)}
.gsr-item:last-child{border-bottom:none}.gsr-item:hover{background:var(--surface-2)}
.gsr-icon{font-size:15px;width:22px;text-align:center;flex-shrink:0}
.gsr-body{min-width:0;flex:1}.gsr-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gsr-path{font-size:11px;color:var(--text-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gsr-size{font-size:11px;color:var(--text-faint);flex-shrink:0}
.gsr-empty{padding:28px 14px;text-align:center;color:var(--text-faint);font-size:13px}
.gsr-spinner{padding:18px 14px;text-align:center;color:var(--text-faint);font-size:12px}

/* ── Alerts ───────────────────────────────────────────────────── */
.alert{display:flex;align-items:flex-start;gap:var(--s3);padding:var(--s3) var(--s4);border-radius:var(--r-md);font-size:13px;line-height:1.5}
.alert-danger{background:var(--danger);border:1px solid var(--danger-border);color:var(--danger-text)}
.alert-success{background:rgba(74,222,128,.08);border:1px solid rgba(74,222,128,.18);color:#16a34a}
[data-theme="dark"] .alert-success{color:#86efac}
.alert-info{background:rgba(94,201,190,.08);border:1px solid rgba(94,201,190,.18);color:var(--primary)}

/* ── Breadcrumb ───────────────────────────────────────────────── */
.breadcrumb{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.breadcrumb a,.breadcrumb span{font-size:12px;color:var(--text-faint);font-weight:500;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
.breadcrumb a{color:var(--text-muted);transition:color var(--ease)}.breadcrumb a:hover{color:var(--primary)}

/* ── File table ───────────────────────────────────────────────── */
.file-table-wrap{overflow-x:auto}.file-table{min-width:560px}
.file-table th{padding:var(--s2) var(--s3);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--text-faint);background:rgba(128,128,128,.03);border-bottom:1px solid var(--border);white-space:nowrap;text-align:left}
.file-table td{padding:9px var(--s3);border-bottom:1px solid var(--divider);vertical-align:middle;font-size:13px}
.file-table tr:last-child td{border-bottom:none}
.file-table tbody tr{transition:background var(--ease)}.file-table tbody tr:hover td{background:rgba(128,128,128,.04)}
.file-name-cell{display:flex;align-items:center;gap:var(--s2)}
.file-icon{width:28px;height:28px;border-radius:var(--r-sm);flex-shrink:0;display:grid;place-items:center;background:rgba(128,128,128,.05);border:1px solid var(--border);font-size:12px;color:var(--text-muted)}
.file-icon.folder{background:rgba(94,201,190,.08);border-color:rgba(94,201,190,.12);color:var(--primary)}
.file-name-text{font-weight:600;color:var(--text)}.file-name-text a:hover{color:var(--primary)}
.size-text{color:var(--text-faint);font-size:12px;font-variant-numeric:tabular-nums}
.row-actions{display:flex;align-items:center;gap:3px;opacity:0;transition:opacity var(--ease)}.file-table tbody tr:hover .row-actions{opacity:1}
.rename-form{display:flex;align-items:center;gap:var(--s2);flex-wrap:wrap}

/* ── Upload zone ──────────────────────────────────────────────── */
.upload-zone{border:1.5px dashed rgba(94,201,190,.2);border-radius:var(--r-lg);padding:var(--s3) var(--s4);display:flex;align-items:center;gap:var(--s3);flex-wrap:wrap;background:rgba(94,201,190,.02);transition:border-color var(--ease),background var(--ease)}
.upload-zone.dragover{border-color:rgba(94,201,190,.5);background:rgba(94,201,190,.06)}
.upload-zone-label{display:flex;flex-direction:column;gap:2px}.upload-zone-label strong{font-size:13px;font-weight:600;color:var(--text)}.upload-zone-label span{font-size:12px;color:var(--text-faint)}
.progress-bar-wrap{display:none;flex:1;min-width:150px}.progress-bar-track{height:5px;background:rgba(128,128,128,.1);border-radius:99px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--primary);width:0;border-radius:inherit;transition:width .15s}.progress-label{font-size:11px;color:var(--text-faint);margin-top:3px}

/* ── File grid ────────────────────────────────────────────────── */
.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(145px,1fr));gap:var(--s3);padding:var(--s4)}
.grid-item{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface-2);padding:var(--s3);display:flex;flex-direction:column;align-items:center;gap:var(--s2);text-align:center;cursor:pointer;transition:all var(--ease);position:relative}
.grid-item:hover{border-color:rgba(94,201,190,.25);background:var(--surface-3);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.grid-item-top{display:flex;align-items:center;justify-content:space-between;width:100%}.grid-icon{width:42px;height:42px;border-radius:var(--r-md);display:grid;place-items:center;font-size:20px;margin-bottom:3px}.grid-name{font-size:12px;font-weight:600;color:var(--text);word-break:break-word;line-height:1.3}.grid-size{font-size:10px;color:var(--text-faint)}

/* ── Toolbar ──────────────────────────────────────────────────── */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--s2);flex-wrap:wrap}
.toolbar-left{display:flex;align-items:center;gap:var(--s2);flex-wrap:wrap;min-width:0}
.toolbar-right{display:flex;align-items:center;gap:var(--s2);flex-shrink:0}
.view-toggle{display:flex;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}
.view-btn{width:32px;height:32px;display:grid;place-items:center;color:var(--text-faint);transition:all var(--ease)}.view-btn:hover{color:var(--text);background:rgba(128,128,128,.06)}.view-btn.active{background:var(--primary-dim);color:var(--primary)}

/* ── Empty state ──────────────────────────────────────────────── */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--s3);padding:60px var(--s8) 70px;text-align:center}
.empty-illu{margin-bottom:var(--s2)}.empty-title{font-size:16px;font-weight:700;color:var(--text)}.empty-desc{font-size:13px;color:var(--text-muted);max-width:28ch;line-height:1.65}.empty-actions{display:flex;gap:var(--s2);flex-wrap:wrap;justify-content:center;margin-top:var(--s1)}

/* ── User pill ────────────────────────────────────────────────── */
.user-pill{display:inline-flex;align-items:center;gap:var(--s2);padding:0 var(--s3);height:32px;border-radius:var(--r-full);background:var(--surface-2);border:1px solid var(--border);font-size:12px;color:var(--text-muted);font-weight:500}
.user-avatar{width:20px;height:20px;border-radius:50%;background:var(--primary-dim);display:grid;place-items:center;font-size:10px;font-weight:700;color:var(--primary);flex-shrink:0}

/* ── Bulk bar ─────────────────────────────────────────────────── */
.bulk-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 16px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:rgba(94,201,190,.04)}
.bulk-actions{display:flex;gap:6px;flex-wrap:wrap}
.browser-content{padding:0}.sort-link{color:inherit}.sort-link:hover{color:var(--primary)}

/* ── Context menu ─────────────────────────────────────────────── */
.context-menu{position:fixed;z-index:9999;min-width:175px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:5px}
.context-menu button{width:100%;text-align:left;padding:8px 11px;border-radius:var(--r-md);color:var(--text);font-size:13px;font-weight:500}.context-menu button:hover{background:var(--surface-2)}

/* ── Preview modal ────────────────────────────────────────────── */
.preview-modal{position:fixed;inset:0;z-index:10000}
.preview-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(6px)}
.preview-panel{position:relative;z-index:1;max-width:960px;height:min(88vh,820px);margin:5vh auto;background:var(--surface);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden}
.preview-header{display:flex;align-items:center;justify-content:space-between;padding:13px 18px;border-bottom:1px solid var(--divider)}
.preview-body{flex:1;padding:13px;background:var(--surface-2);display:grid;place-items:center}
.preview-body iframe,.preview-body img,.preview-body video{width:100%;height:100%;border:0;object-fit:contain}
.preview-body audio{width:min(560px,100%)}

/* ── Hover preview ────────────────────────────────────────────── */
.hover-preview{position:absolute;z-index:9998;max-width:270px;width:270px;height:190px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden;pointer-events:none}
.hover-preview iframe,.hover-preview img{width:100%;height:100%;border:0;object-fit:cover}

/* ── Toast ────────────────────────────────────────────────────── */
.toast{position:fixed;bottom:20px;right:20px;z-index:10001;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:11px 16px;font-size:13px;color:var(--text);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:8px;max-width:300px;animation:fadeIn .2s ease}
.toast[data-type="success"]{border-color:rgba(74,222,128,.25);color:#16a34a}[data-theme="dark"] .toast[data-type="success"]{color:#86efac}
.toast[data-type="danger"]{border-color:var(--danger-border);color:var(--danger-text)}
.toast[data-type="info"]{color:var(--primary)}

/* ── Tooltips ─────────────────────────────────────────────────── */
[data-tip]{position:relative}[data-tip]::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 5px);left:50%;transform:translateX(-50%);background:var(--surface-3);border:1px solid var(--border);color:var(--text-muted);font-size:10px;font-weight:600;white-space:nowrap;padding:3px 7px;border-radius:var(--r-sm);opacity:0;pointer-events:none;transition:opacity var(--ease);z-index:200}[data-tip]:hover::after{opacity:1}

/* ── Share modal ──────────────────────────────────────────────── */
.share-modal{position:fixed;inset:0;z-index:10000}
.share-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px)}
.share-panel{position:relative;z-index:1;max-width:480px;margin:10vh auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);overflow:hidden}
.share-header{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;border-bottom:1px solid var(--divider)}
.share-body{padding:18px;display:flex;flex-direction:column;gap:14px}
.share-url-row{display:flex;gap:8px;align-items:center}
.share-url-input{flex:1;font-family:monospace;font-size:11px;height:34px}
.share-ttl-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.share-ttl-label{font-size:11px;color:var(--text-muted);font-weight:600}
.share-ttl-btn{padding:3px 10px;height:26px;font-size:11px;border-radius:var(--r-sm);border:1px solid var(--border);background:transparent;color:var(--text-muted);cursor:pointer;transition:all var(--ease);font-weight:600}
.share-ttl-btn:hover,.share-ttl-btn.active{background:var(--primary-dim);color:var(--primary);border-color:rgba(94,201,190,.3)}
.share-info{font-size:12px;color:var(--text-faint);line-height:1.6;background:var(--surface-2);border-radius:var(--r-md);padding:10px 12px;border:1px solid var(--border)}

/* ── Login ────────────────────────────────────────────────────── */
.login-page{display:grid;place-items:center;min-height:100dvh;padding:var(--s5)}
.login-shell{width:100%;max-width:400px;display:flex;flex-direction:column;gap:var(--s4)}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg)}
.login-card-header{padding:var(--s5);border-bottom:1px solid var(--border)}
.login-card-body{padding:var(--s5);display:flex;flex-direction:column;gap:var(--s4)}
.field{display:flex;flex-direction:column;gap:var(--s2)}.field label{font-size:12px;font-weight:600;color:var(--text-muted)}
.input-pw-wrap{position:relative}.input-pw-wrap .input{padding-right:64px}
.pw-toggle{position:absolute;right:var(--s2);top:50%;transform:translateY(-50%);height:26px;padding:0 var(--s2);border-radius:var(--r-sm);font-size:11px;font-weight:700;color:var(--text-muted);background:rgba(128,128,128,.06);border:1px solid var(--border)}.pw-toggle:hover{color:var(--text)}
.login-submit{width:100%;height:43px;border-radius:var(--r-md);background:var(--primary);color:var(--primary-ink);font-size:14px;font-weight:700;border:none;transition:all var(--ease)}.login-submit:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 20px rgba(94,201,190,.22)}
.login-footer{font-size:12px;color:var(--text-faint);text-align:center}.eyebrow{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--primary);margin-bottom:var(--s2)}.login-heading{font-size:22px;font-weight:700;letter-spacing:-.03em}.login-subheading{font-size:13px;color:var(--text-muted);margin-top:var(--s1)}.lockout-hint{font-size:12px;color:var(--text-faint);line-height:1.5}

/* ── Admin extras ─────────────────────────────────────────────── */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:var(--s4)}
.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--s5);display:flex;flex-direction:column;gap:var(--s1);transition:border-color var(--ease),transform var(--ease);animation:fadeIn .3s ease both}
.kpi-card:hover{border-color:rgba(94,201,190,.22);transform:translateY(-2px)}
.kpi-icon{width:34px;height:34px;border-radius:var(--r-md);display:grid;place-items:center;font-size:16px;margin-bottom:var(--s2)}
.kpi-icon.teal{background:rgba(94,201,190,.1)}.kpi-icon.amber{background:rgba(251,191,36,.1)}.kpi-icon.red{background:rgba(248,113,113,.1)}.kpi-icon.violet{background:rgba(167,139,250,.1)}.kpi-icon.green{background:rgba(74,222,128,.1)}.kpi-icon.blue{background:rgba(96,165,250,.1)}
.kpi-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--text-faint)}
.kpi-value{font-size:24px;font-weight:700;letter-spacing:-.03em;color:var(--text);line-height:1.1}
.kpi-sub{font-size:11px;color:var(--text-faint);margin-top:2px}

/* ── Responsive ───────────────────────────────────────────────── */
@media(max-width:1024px){
  .shell{grid-template-columns:1fr}.sidebar{display:none}.menu-btn{display:inline-flex}
}
@media(max-width:768px){
  .main{padding:var(--s3)}.topbar{padding:0 var(--s3);gap:var(--s2)}
  .toolbar{flex-direction:column;align-items:stretch;gap:var(--s2)}
  .toolbar-left,.toolbar-right{flex-wrap:wrap}
  .toolbar-right{justify-content:flex-end}
  .preview-panel{margin:0;height:100dvh;max-width:none;border-radius:0}
  .login-page{padding:var(--s3)}.gsearch-wrap{max-width:none;flex:1}
  /* Upload zone stacks on mobile */
  .card-body > div[style*="grid-template-columns"]{grid-template-columns:1fr!important}
  /* Bigger touch targets in table */
  .btn-icon-sm{width:34px;height:34px;border-radius:var(--r-md)}
  .row-actions{opacity:1;gap:4px}
  .file-table td{padding:10px var(--s2)}
  .file-table th{padding:var(--s2)}
  /* Service buttons full-width feel */
  .apollo-btn,.webmail-btn{width:100%}
}
@media(max-width:480px){
  .row-actions{opacity:1}
  .login-shell{max-width:100%}
  .topbar-actions .user-pill{display:none}
  /* Stack topbar on very small screens */
  .topbar{height:auto;min-height:54px;flex-wrap:wrap;padding:var(--s2) var(--s3)}
  .gsearch-wrap{order:3;flex-basis:100%;max-width:none;padding-bottom:var(--s2)}
  /* Larger tap targets */
  .nav-item{padding:10px var(--s3);min-height:44px}
  .btn{min-height:44px}
  .btn-icon{width:40px;height:40px}
  .btn-icon-sm{width:36px;height:36px}
  /* Breadcrumb compact */
  .breadcrumb a{font-size:11px}
  /* Share modal full-width */
  .share-panel{max-width:100%;margin:auto var(--s3)}
}

/* ── Animations ───────────────────────────────────────────────── */
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@keyframes spin{to{transform:rotate(360deg)}}
.anim-spin{animation:spin .8s linear infinite}
