:root{color:#0f172a;background:#f6f8fc;font-family:Inter,SF Pro Text,PingFang SC,Microsoft YaHei,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;--primary: #2563eb;--primary-hover: #1d4ed8;--primary-soft: #eff6ff;--accent: #d97706;--surface: #ffffff;--surface-muted: #f8fafc;--background: #f6f8fc;--foreground: #0f172a;--muted: #64748b;--muted-strong: #475569;--border: #e2e8f0;--border-strong: #cbd5e1;--danger: #dc2626;--danger-soft: #fef2f2;--success: #15803d;--success-soft: #f0fdf4;--info-soft: #eff6ff;--focus: #2563eb;--sidebar: #0f172a;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--shadow-sm: 0 1px 2px rgb(15 23 42 / .05);--shadow-md: 0 12px 32px rgb(15 23 42 / .08);color-scheme:light}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;min-height:100dvh;background:var(--background)}button,input,select{font:inherit}button,a,summary,label[for]{-webkit-tap-highlight-color:transparent}button,a,summary{touch-action:manipulation}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.5}a{color:inherit}h1,h2,h3,p{margin-top:0}h1,h2,h3,strong{letter-spacing:-.02em}button,input,select,summary,a{outline:none}button:focus-visible,input:focus-visible,select:focus-visible,summary:focus-visible,a:focus-visible{box-shadow:0 0 0 3px #2563eb38}.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.kicker{margin:0 0 8px;color:#bfdbfe;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:11px;font-weight:700;letter-spacing:.15em}.kicker--blue{color:var(--primary)}.brand-lockup{display:inline-flex;align-items:center;gap:11px;color:#fff;font-size:18px;font-weight:750;letter-spacing:-.03em}.brand-mark{display:inline-grid;width:42px;height:42px;flex:0 0 auto;place-items:center;border-radius:12px;background:var(--primary);color:#fff}.button{display:inline-flex;min-height:44px;align-items:center;justify-content:center;gap:9px;padding:10px 16px;border:1px solid transparent;border-radius:10px;font-weight:700;transition:background-color .18s ease,border-color .18s ease,color .18s ease}.button--primary{border-color:var(--primary);background:var(--primary);color:#fff}.button--primary:hover:not(:disabled){border-color:var(--primary-hover);background:var(--primary-hover)}.button--secondary{border-color:var(--border-strong);background:var(--surface);color:var(--muted-strong)}.button--secondary:hover:not(:disabled){border-color:#93c5fd;background:var(--primary-soft);color:var(--primary-hover)}.button--large{width:100%;min-height:50px}.icon-button{display:inline-grid;width:44px;height:44px;flex:0 0 auto;padding:0;place-items:center;border:1px solid transparent;border-radius:10px;background:transparent;color:var(--muted-strong);text-decoration:none;transition:background-color .18s ease,border-color .18s ease,color .18s ease}.icon-button:hover:not(:disabled){border-color:var(--border);background:var(--surface-muted);color:var(--foreground)}.icon-button--danger:hover:not(:disabled){border-color:#fecaca;background:var(--danger-soft);color:var(--danger)}.spinner{width:18px;height:18px;flex:0 0 auto;border:2px solid rgb(255 255 255 / .42);border-top-color:currentColor;border-radius:999px;animation:spin .7s linear infinite}.spinner--blue{border-color:#bfdbfe;border-top-color:var(--primary)}.spinner--small{width:16px;height:16px;border-color:#fecaca;border-top-color:var(--danger)}@keyframes spin{to{transform:rotate(360deg)}}.login-page{display:grid;min-height:100vh;min-height:100dvh;padding:32px;place-items:center;background:#eef2f7}.login-shell{display:grid;width:min(1040px,100%);min-height:650px;overflow:hidden;grid-template-columns:minmax(0,1.05fr) minmax(420px,.95fr);border:1px solid #dbe3ee;border-radius:24px;background:var(--surface);box-shadow:var(--shadow-md)}.login-brand{position:relative;display:flex;overflow:hidden;flex-direction:column;justify-content:space-between;padding:52px;background:#123b8f;color:#fff;isolation:isolate}.login-brand:before,.login-brand:after{position:absolute;z-index:-1;width:300px;height:300px;border:56px solid rgb(255 255 255 / .07);border-radius:999px;content:""}.login-brand:before{top:-150px;right:-130px}.login-brand:after{right:-190px;bottom:-190px}.login-brand-copy{max-width:440px}.login-brand-copy h1{margin-bottom:22px;font-size:clamp(38px,5vw,60px);line-height:1.05}.login-brand-copy>p:last-child{margin-bottom:0;color:#dbeafe;font-size:16px;line-height:1.75}.security-list{display:grid;gap:13px;margin:0;padding:0;list-style:none;color:#dbeafe;font-size:14px}.security-list li{display:flex;align-items:center;gap:10px}.security-list svg{color:#93c5fd}.login-panel{display:grid;padding:48px;place-items:center}.login-panel__inner{width:min(360px,100%)}.login-icon{display:grid;width:48px;height:48px;margin-bottom:28px;place-items:center;border-radius:13px;background:var(--primary-soft);color:var(--primary)}.login-panel h2{margin-bottom:10px;font-size:30px}.login-intro{margin-bottom:32px;color:var(--muted);line-height:1.6}.login-form{display:grid;gap:10px}.login-form>label,.settings-form>label{margin-top:8px;color:var(--muted-strong);font-size:13px;font-weight:700}.input-shell{display:flex;min-height:48px;align-items:center;gap:10px;padding-left:14px;border:1px solid var(--border-strong);border-radius:10px;background:var(--surface);color:#94a3b8;transition:border-color .18s ease,box-shadow .18s ease}.input-shell:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}.input-shell input{min-width:0;flex:1;align-self:stretch;padding:0;border:0;background:transparent;color:var(--foreground);outline:0}.input-action{width:46px;height:46px;border-radius:8px}.form-error{margin:4px 0 2px;padding:10px 12px;border:1px solid #fecaca;border-radius:9px;background:var(--danger-soft);color:#b91c1c;font-size:13px;line-height:1.5}.login-form .button{margin-top:12px}.login-footnote{margin:22px 0 0;color:#94a3b8;font-size:12px;text-align:center}.session-loader{display:grid;min-height:100vh;min-height:100dvh;align-content:center;justify-items:center;gap:18px;color:var(--muted)}.session-loader p{margin:0}.dashboard-shell{display:flex;min-height:100vh;min-height:100dvh}.sidebar{position:sticky;top:0;display:flex;width:248px;height:100vh;height:100dvh;flex:0 0 auto;flex-direction:column;padding:30px 20px 20px;background:var(--sidebar);color:#cbd5e1}.sidebar .brand-lockup{margin:0 10px 42px}.sidebar-nav{display:grid;gap:6px}.nav-item{display:flex;min-height:46px;align-items:center;gap:12px;padding:10px 12px;border:0;border-radius:10px;background:transparent;color:#94a3b8;font-size:14px;font-weight:650;text-decoration:none;transition:background-color .18s ease,color .18s ease}.nav-item:hover{background:#1e293b;color:#f8fafc}.nav-item--active{background:#1e3a8a;color:#fff}.nav-item--active:hover{background:#1e40af}.nav-count{min-width:24px;margin-left:auto;padding:2px 7px;border-radius:99px;background:#ffffff1a;font-family:SFMono-Regular,Consolas,monospace;font-size:11px;text-align:center}.sidebar-security{display:flex;align-items:center;gap:10px;margin-top:auto;margin-bottom:12px;padding:14px 12px;border:1px solid #334155;border-radius:12px;color:#86efac}.sidebar-security div{display:grid;gap:2px}.sidebar-security strong{color:#e2e8f0;font-size:12px}.sidebar-security span{color:#64748b;font-size:11px}.nav-item--button{width:100%}.dashboard-main{width:calc(100% - 248px);max-width:1440px;margin:0 auto;padding:30px clamp(24px,3vw,48px) 22px}.topbar{display:flex;align-items:center;gap:24px;margin-bottom:36px}.topbar-copy h1{margin:0;font-size:28px}.mobile-brand{display:none}.user-chip{display:flex;align-items:center;gap:11px;margin-left:auto}.user-chip>span:nth-child(2){display:grid;gap:2px}.user-chip small{color:var(--muted);font-size:11px}.user-chip strong{max-width:180px;overflow:hidden;font-size:13px;text-overflow:ellipsis}.user-avatar{display:grid;width:40px;height:40px;place-items:center;border:1px solid #bfdbfe;border-radius:12px;background:var(--primary-soft);color:var(--primary);font-size:14px;font-weight:800}.toast{position:fixed;z-index:30;top:24px;right:24px;display:flex;width:min(420px,calc(100% - 48px));min-height:52px;align-items:center;gap:10px;padding:8px 8px 8px 14px;border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:var(--shadow-md);color:var(--muted-strong);animation:toast-in .18s ease-out both}.toast>span{flex:1;font-size:14px}.toast--success>svg{color:var(--success)}.toast--error{border-color:#fecaca}.toast--error>svg{color:var(--danger)}.toast--info>svg{color:var(--primary)}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px)}}.welcome-row{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:22px}.welcome-row h2{margin-bottom:7px;font-size:clamp(24px,3vw,32px)}.welcome-row p{margin:0;color:var(--muted);line-height:1.6}.provider-status{display:inline-flex;min-height:36px;flex:0 0 auto;align-items:center;gap:8px;padding:7px 12px;border:1px solid #bbf7d0;border-radius:99px;background:var(--success-soft);color:#166534;font-size:12px;font-weight:700}.status-dot{width:7px;height:7px;border-radius:99px;background:#22c55e;box-shadow:0 0 0 3px #dcfce7}.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:18px}.stat-card{display:flex;min-height:96px;align-items:center;gap:15px;padding:18px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);box-shadow:var(--shadow-sm)}.stat-card>div{display:grid;gap:5px}.stat-card span{color:var(--muted);font-size:12px}.stat-card strong{font-size:clamp(20px,2vw,26px);font-variant-numeric:tabular-nums}.stat-icon{display:grid;width:46px;height:46px;flex:0 0 auto;place-items:center;border-radius:12px}.stat-icon--blue{background:var(--primary-soft);color:var(--primary)}.stat-icon--amber{background:#fffbeb;color:var(--accent)}.stat-icon--violet{background:#f5f3ff;color:#7c3aed}.content-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(310px,.85fr);gap:18px;margin-bottom:18px}.panel{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm)}.upload-panel,.storage-panel{padding:22px}.panel-heading{display:flex;min-height:42px;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}.panel-heading h2,.files-toolbar h2{margin:0;font-size:20px}.panel-badge{padding:5px 9px;border-radius:7px;background:var(--surface-muted);color:var(--muted);font-family:SFMono-Regular,Consolas,monospace;font-size:11px}.drop-zone{display:grid;min-height:252px;align-content:center;justify-items:center;padding:28px;border:1.5px dashed #93c5fd;border-radius:14px;background:#f8fbff;text-align:center;transition:border-color .18s ease,background-color .18s ease}.drop-zone--active{border-color:var(--primary);background:var(--primary-soft)}.drop-zone input{display:none}.drop-zone__icon{display:grid;width:58px;height:58px;margin-bottom:15px;place-items:center;border:1px solid #dbeafe;border-radius:15px;background:#fff;color:var(--primary)}.drop-zone strong{margin-bottom:6px;font-size:16px}.drop-zone>span:not(.drop-zone__icon){margin-bottom:18px;color:var(--muted);font-size:13px}.panel-note{display:flex;align-items:center;gap:7px;margin:12px 0 0;color:var(--muted);font-size:11px}.panel-note svg{color:var(--success)}.provider-options{display:grid;gap:10px}.provider-option{display:grid;width:100%;min-height:70px;grid-template-columns:42px minmax(0,1fr) 20px;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--foreground);text-align:left;transition:border-color .18s ease,background-color .18s ease}.provider-option:hover:not(:disabled){border-color:#93c5fd;background:#f8fbff}.provider-option--active,.provider-option--active:hover{border-color:#93c5fd;background:var(--primary-soft);opacity:1}.provider-option>span:nth-child(2){display:grid;gap:4px;min-width:0}.provider-option strong,.provider-option small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.provider-option strong{font-size:13px}.provider-option small{color:var(--muted);font-size:11px}.provider-option__icon{display:grid;width:42px;height:42px;place-items:center;border-radius:10px;background:#f1f5f9;color:var(--muted-strong)}.provider-option__icon--dropbox{background:#e0ecff;color:var(--primary)}.provider-option__icon--google{background:#f0fdf4;color:#15803d}.google-settings{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px;padding:12px;border:1px solid var(--border);border-radius:12px;background:var(--surface-muted)}.google-settings>div{display:flex;min-width:0;align-items:center;gap:10px}.google-settings>div>span:last-child{display:grid;min-width:0;gap:3px}.google-settings strong,.google-settings small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.google-settings strong{font-size:12px}.google-settings small{color:var(--muted);font-size:10px}.radio-dot{width:16px;height:16px;border:1px solid var(--border-strong);border-radius:99px;background:var(--surface)}.provider-option--active .radio-dot{border:4px solid var(--primary)}.dropbox-settings{margin-top:14px;border-top:1px solid var(--border)}.dropbox-settings summary{display:flex;min-height:48px;align-items:center;justify-content:space-between;color:var(--muted-strong);cursor:pointer;font-size:12px;font-weight:700;list-style:none}.dropbox-settings summary::-webkit-details-marker{display:none}.dropbox-settings summary>span{display:flex;align-items:center;gap:8px}.summary-chevron{transition:transform .18s ease}.dropbox-settings[open] .summary-chevron{transform:rotate(180deg)}.settings-form{display:grid;gap:7px;padding:4px 0 2px}.settings-form label span{color:#94a3b8;font-weight:500}.settings-form input,.search-box input,.files-controls select{width:100%;min-height:44px;border:1px solid var(--border-strong);border-radius:9px;background:var(--surface);color:var(--foreground)}.settings-form input{padding:9px 11px}.redirect-note{margin:7px 0;color:var(--muted);font-size:11px;line-height:1.5;overflow-wrap:anywhere}.redirect-note code{color:var(--muted-strong);font-family:SFMono-Regular,Consolas,monospace}.files-panel{padding:22px;scroll-margin-top:24px}.files-toolbar{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:18px}.files-toolbar h2 span{margin-left:4px;color:#94a3b8;font-family:SFMono-Regular,Consolas,monospace;font-size:13px}.files-controls{display:flex;gap:9px}.search-box{display:flex;width:min(260px,30vw);min-height:44px;align-items:center;gap:8px;padding-left:12px;border:1px solid var(--border-strong);border-radius:9px;color:#94a3b8}.search-box:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}.search-box input{min-width:0;border:0;outline:0}.files-controls select{width:auto;padding:0 34px 0 12px}.file-list{display:grid}.file-row{display:grid;min-height:72px;grid-template-columns:44px minmax(160px,1fr) auto auto;align-items:center;gap:13px;border-top:1px solid var(--border)}.file-type-icon{display:grid;width:40px;height:40px;place-items:center;border-radius:10px;background:#f1f5f9;color:var(--muted-strong)}.file-info{min-width:0}.file-info strong{display:block;overflow:hidden;font-size:13px;text-overflow:ellipsis;white-space:nowrap}.file-info p{display:flex;flex-wrap:wrap;gap:12px;margin:5px 0 0;color:var(--muted);font-size:11px}.file-info p span+span:before{margin-right:12px;color:var(--border-strong);content:"•"}.source-pill{padding:5px 8px;border-radius:7px;font-size:10px;font-weight:750}.source-pill--local{background:#f1f5f9;color:var(--muted-strong)}.source-pill--dropbox{background:var(--primary-soft);color:var(--primary-hover)}.source-pill--google-drive{background:#f0fdf4;color:#15803d}.file-actions{display:flex;gap:2px}.file-actions .icon-button{width:40px;height:40px}.empty-state{display:grid;min-height:260px;align-content:center;justify-items:center;padding:24px;border-top:1px solid var(--border);text-align:center}.empty-state>span{display:grid;width:58px;height:58px;margin-bottom:14px;place-items:center;border-radius:15px;background:#f1f5f9;color:#94a3b8}.empty-state h3{margin-bottom:7px;font-size:16px}.empty-state p{max-width:420px;margin:0;color:var(--muted);font-size:13px;line-height:1.6}.file-skeletons{display:grid}.file-skeleton{height:72px;border-top:1px solid var(--border);background:#f8fafc;animation:pulse 1.2s ease-in-out infinite alternate}@keyframes pulse{to{opacity:.45}}.dashboard-footer{display:flex;justify-content:space-between;gap:16px;padding:20px 2px 0;color:#94a3b8;font-size:11px}.dashboard-footer span:first-child{display:flex;align-items:center;gap:6px}@media(max-width:1100px){.content-grid{grid-template-columns:1fr}.drop-zone{min-height:220px}}@media(max-width:900px){.sidebar{display:none}.dashboard-main{width:100%;padding-top:20px}.topbar{margin-bottom:30px}.topbar-copy{display:none}.mobile-brand{display:inline-flex;color:var(--foreground)}.stats-grid{gap:10px}}@media(max-width:720px){.login-page{padding:0;background:var(--surface)}.login-shell{min-height:100vh;min-height:100dvh;grid-template-columns:1fr;border:0;border-radius:0;box-shadow:none}.login-brand{min-height:270px;padding:28px 24px}.login-brand-copy{margin-top:40px}.login-brand-copy h1{margin-bottom:12px;font-size:36px}.login-brand-copy>p:last-child{font-size:14px}.security-list{display:none}.login-panel{padding:38px 24px 48px;place-items:start center}.login-icon{display:none}.stats-grid{grid-template-columns:1fr}.stat-card{min-height:80px}.files-toolbar{align-items:stretch;flex-direction:column}.files-controls,.search-box{width:100%}.files-controls select{flex:0 0 auto}.file-row{grid-template-columns:42px minmax(0,1fr) auto;padding:12px 0}.source-pill{display:none}.file-actions{grid-column:2 / -1;justify-content:flex-end}}@media(max-width:560px){.dashboard-main{padding:16px 14px 20px}.mobile-brand .brand-mark{width:38px;height:38px}.user-chip>span:nth-child(2){display:none}.welcome-row{align-items:flex-start;flex-direction:column}.welcome-row h2{font-size:25px}.provider-status{align-self:stretch;justify-content:center}.upload-panel,.storage-panel,.files-panel{padding:17px;border-radius:14px}.drop-zone{min-height:240px;padding:22px 14px}.files-controls{flex-direction:column}.files-controls select{width:100%}.file-info p span:last-child{display:none}.dashboard-footer{align-items:center;flex-direction:column}.toast{top:12px;right:12px;width:calc(100% - 24px)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
