:root{--text:#0f172a;--text-secondary:#334155;--muted:#64748b;--bg:#f1f5f9;--surface:#fff;--surface-2:#f8fafc;--surface-3:#e2e8f0;--border:#e2e8f0;--border-strong:#cbd5e1;--accent:#4f46e5;--accent-hover:#4338ca;--accent-soft:#eef2ff;--accent-muted:#c7d2fe;--danger:#ef4444;--danger-soft:#fef2f2;--success:#10b981;--radius:12px;--radius-sm:8px;--shadow-sm:0 1px 2px #0f172a0d;--shadow:0 4px 6px -1px #0f172a12, 0 2px 4px -2px #0f172a0d;--shadow-lg:0 20px 40px -12px #0f172a1f;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:Plus Jakarta Sans,system-ui,sans-serif;line-height:1.5}*,:before,:after{box-sizing:border-box}body{min-height:100vh;margin:0}#root{min-height:100vh}.page{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}h1,h2,h3{letter-spacing:-.02em;color:var(--text);margin:0;font-weight:600}.btn{font:inherit;cursor:pointer;border-radius:var(--radius-sm);border:none;justify-content:center;align-items:center;gap:.4rem;padding:.55rem 1rem;font-size:.875rem;font-weight:500;transition:background .15s,color .15s,border-color .15s,box-shadow .15s;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed}.btn--primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm)}.btn--primary:hover:not(:disabled){background:var(--accent-hover)}.btn--ghost{background:var(--surface);color:var(--text-secondary);border:1px solid var(--border)}.btn--ghost:hover:not(:disabled){background:var(--surface-2);border-color:var(--border-strong)}.btn--danger{background:var(--danger-soft);color:var(--danger);border:1px solid #fecaca}.btn--danger:hover:not(:disabled){background:#fee2e2}.btn--icon{padding:.45rem}.btn--sm{padding:.35rem .65rem;font-size:.8rem}.page-alert{border-radius:var(--radius-sm);margin:0 1.5rem;padding:.65rem 1rem;font-size:.85rem}.page-alert code{font-size:.8em}.page-alert--error{background:var(--danger-soft);color:#991b1b;border:1px solid #fecaca}.page-alert--success{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0}.page-alert--success code{font-size:.85em}.page-hint{color:var(--muted);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);margin:0;padding:.75rem 1rem;font-size:.8rem;line-height:1.5}.page-hint code{background:var(--surface);border-radius:4px;padding:.1rem .35rem;font-size:.78em}.uploader-page .page-alert{margin:0}.icon-box{flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.icon-box--accent{background:var(--accent-soft);color:var(--accent);border-radius:var(--radius-sm)}.icon-box--muted{background:var(--surface-2);color:var(--muted);border-radius:var(--radius-sm)}.badge{text-transform:uppercase;letter-spacing:.04em;background:var(--accent-soft);color:var(--accent);border-radius:999px;align-items:center;gap:.25rem;padding:.2rem .55rem;font-size:.7rem;font-weight:600;display:inline-flex}.badge--viewer{color:#059669;background:#ecfdf5}.login{background:radial-gradient(ellipse 80% 60% at 50% -10%, var(--accent-soft), transparent), var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.login__card{background:var(--surface);border:1px solid var(--border);width:100%;max-width:420px;box-shadow:var(--shadow-lg);border-radius:16px;padding:2rem}.login__hero{text-align:center;margin-bottom:1.75rem}.login__icon{border-radius:14px;width:56px;height:56px;margin:0 auto 1rem}.login__hero h1{margin-bottom:.35rem;font-size:1.5rem}.login__hero p{color:var(--muted);margin:0;font-size:.9rem}.login__form{flex-direction:column;gap:1rem;display:flex}.field{flex-direction:column;gap:.35rem;display:flex}.field__label{color:var(--text-secondary);font-size:.8rem;font-weight:500}.field__input-wrap{align-items:center;display:flex;position:relative}.field__icon{color:var(--muted);pointer-events:none;position:absolute;left:.75rem}.field__input-wrap input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;font:inherit;background:var(--surface-2);color:var(--text);padding:.65rem .75rem .65rem 2.35rem;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.field__input-wrap input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--surface);outline:none}.login__error{color:var(--danger);background:var(--danger-soft);border-radius:var(--radius-sm);margin:0;padding:.5rem .75rem;font-size:.85rem}.login__form .btn--primary{width:100%;margin-top:.25rem;padding:.7rem}.header{background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;padding:.875rem 1.5rem;display:flex}.header__brand{align-items:center;gap:.875rem;display:flex}.header__logo{width:40px;height:40px}.header h1{font-size:1.05rem;font-weight:600}.header__role{color:var(--muted);align-items:center;gap:.5rem;margin:.2rem 0 0;font-size:.8rem;display:flex}.header-confirm__backdrop{z-index:10000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a73;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.header-confirm__dialog{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:380px;box-shadow:var(--shadow-lg);padding:1.5rem}.header-confirm__message{color:var(--text);text-align:center;margin:0 0 1.25rem;font-size:1rem;line-height:1.45}.header-confirm__actions{justify-content:center;gap:.75rem;display:flex}.header-confirm__actions .btn{min-width:5rem}.header-confirm__actions .btn--primary{width:auto}.upload-zone{border:2px dashed var(--border-strong);border-radius:var(--radius);text-align:center;cursor:pointer;background:var(--surface);padding:2.5rem 1.5rem;transition:border-color .2s,background .2s,box-shadow .2s}.upload-zone:hover:not(.upload-zone--busy){border-color:var(--accent-muted);background:var(--accent-soft)}.upload-zone--active{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 4px #4f46e51a}.upload-zone--busy{opacity:.7;cursor:wait}.upload-zone__icon-wrap{background:var(--accent-soft);width:56px;height:56px;color:var(--accent);border-radius:14px;justify-content:center;align-items:center;margin-bottom:.75rem;display:inline-flex}.upload-zone__title{color:var(--text);margin:0 0 .25rem;font-size:.95rem;font-weight:600}.upload-zone__sub{color:var(--muted);margin:0;font-size:.85rem}.file-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.file-list__item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:.75rem;padding:.75rem 1rem;transition:box-shadow .15s;display:flex}.file-list__item:hover{box-shadow:var(--shadow-sm)}.file-list__icon{width:36px;height:36px}.file-list__info{text-align:left;flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.file-list__name{text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;font-weight:500;overflow:hidden}.file-list__meta{color:var(--muted);font-size:.75rem}.file-list__empty{text-align:center;color:var(--muted);padding:2rem;font-size:.9rem}.uploader-page{flex-direction:column;gap:1.75rem;width:100%;max-width:760px;margin:0 auto;padding:1.5rem;display:flex}.uploader-page__list h2{align-items:center;gap:.5rem;margin:0 0 1rem;font-size:.95rem;display:flex}.uploader-page__count{background:var(--accent-soft);min-width:1.5rem;height:1.5rem;color:var(--accent);border-radius:999px;justify-content:center;align-items:center;margin-left:auto;padding:0 .4rem;font-size:.75rem;font-weight:600;display:inline-flex}.file-grid{flex-direction:column;gap:.35rem;margin:0;padding:0;list-style:none;display:flex}.file-grid__row{align-items:stretch;gap:.25rem;display:flex}.file-grid__item{border-radius:var(--radius-sm);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;flex:1;align-items:center;gap:.65rem;min-width:0;padding:.6rem .75rem;transition:background .15s,border-color .15s;display:flex}.file-grid__item:hover{background:var(--surface-2)}.file-grid__item--active{background:var(--accent-soft);border-color:var(--accent-muted)}.file-grid__icon{width:32px;height:32px}.file-grid__name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.85rem;font-weight:500;overflow:hidden}.file-grid__meta{color:var(--muted);flex-shrink:0;font-size:.7rem}.file-grid__dl{color:var(--accent);flex-shrink:0;align-self:center}.file-grid__dl:hover:not(:disabled){background:var(--accent-soft);border-color:var(--accent-muted)}.file-grid__empty{text-align:center;color:var(--muted);padding:1.5rem 1rem;font-size:.85rem}.zoom-controls{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:.35rem;padding:.25rem;display:flex}.zoom-controls__label{text-align:center;min-width:3rem;color:var(--text-secondary);font-size:.8rem;font-weight:600}.file-preview{background:var(--surface);flex-direction:column;flex:1;min-height:0;display:flex}.file-preview__toolbar{border-bottom:1px solid var(--border);background:var(--surface);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1.25rem;display:flex}.file-preview__name{text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary);flex:1;min-width:0;font-size:.9rem;font-weight:500;overflow:hidden}.file-preview__actions{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:.5rem;display:flex}.file-preview__download{color:var(--accent)}.file-preview__download:hover:not(:disabled){background:var(--accent-soft);border-color:var(--accent-muted)}.file-preview__dl-unsupported{margin-top:1rem}.file-preview__viewport{background:var(--surface-2);flex:1;justify-content:center;align-items:center;min-height:400px;padding:1.5rem;display:flex;overflow:auto}.file-preview__canvas{transform-origin:50%;transition:transform .15s}.file-preview__canvas img,.file-preview__canvas iframe,.file-preview__canvas video{border-radius:var(--radius-sm);max-width:100%;max-height:70vh;box-shadow:var(--shadow);display:block}.file-preview__canvas iframe{border:none;width:80vw;height:70vh}.file-preview__canvas pre{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:left;white-space:pre-wrap;word-break:break-word;max-width:80vw;max-height:70vh;box-shadow:var(--shadow-sm);padding:1.25rem;font-size:.85rem;overflow:auto}.file-preview__unsupported{text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--muted);padding:2.5rem}.file-preview__type{margin-top:.5rem;font-size:.8rem}.viewer-protected{-webkit-user-select:none;user-select:none}.viewer-protected img{pointer-events:none}.tab-block{z-index:9999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;background:#0f172af2;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.tab-block__content{text-align:center;max-width:320px;padding:2rem}.tab-block__icon-wrap{color:#fff;background:#ffffff1a;border-radius:16px;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:1rem;display:inline-flex}.tab-block h2{color:#fff;margin:0 0 .5rem;font-size:1.25rem}.tab-block p{color:#ffffffa6;margin:0;font-size:.9rem}.page--viewer{flex-direction:column;min-height:100vh;display:flex}.page--viewer .page-alert{flex-shrink:0;margin:.75rem 1rem 0}.viewer-page{flex:1;grid-template-columns:280px 1fr;min-height:0;display:grid}.viewer-page__sidebar{background:var(--surface);border-right:1px solid var(--border);padding:1rem;overflow-y:auto}.viewer-page__sidebar h2{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);align-items:center;gap:.4rem;margin:0 0 .75rem;font-size:.8rem;font-weight:600;display:flex}.viewer-page__main{background:var(--surface-2);flex-direction:column;min-height:0;display:flex}.viewer-page__placeholder{color:var(--muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.5rem;display:flex}.viewer-page__placeholder-icon{background:var(--surface);border:1px solid var(--border);width:64px;height:64px;color:var(--accent);border-radius:16px;justify-content:center;align-items:center;margin-bottom:.5rem;display:flex}.viewer-page__placeholder p{color:var(--text-secondary);margin:0;font-weight:500}.viewer-page__note{color:var(--success);align-items:center;gap:.35rem;margin-top:.25rem;font-size:.8rem;display:inline-flex}@media (width<=768px){.viewer-page{grid-template-rows:auto 1fr;grid-template-columns:1fr}.viewer-page__sidebar{border-right:none;border-bottom:1px solid var(--border);max-height:220px}}
