:root{color:#172033;background:#f4f7fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}button,input{font:inherit}button:disabled{cursor:not-allowed;opacity:.55}.app-shell{min-height:100vh;display:grid;grid-template-columns:260px 1fr}.sidebar{background:#111827;color:#e5e7eb;padding:24px}.brand{display:flex;gap:12px;align-items:center}.brand strong,.brand span{display:block}.brand-icon{width:32px;height:32px;flex:0 0 auto;object-fit:contain}.brand-icon--large{width:42px;height:42px}.brand span{color:#9ca3af;font-size:13px}.nav{display:grid;gap:8px;margin-top:36px}.nav a,.nav button{width:100%;color:#cbd5e1;text-decoration:none;display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;border:0;background:transparent;cursor:pointer;text-align:left}.nav a.active,.nav a:hover,.nav button.active,.nav button:hover{background:#1f2937;color:#fff}.workspace{padding:32px}.topbar{display:flex;justify-content:space-between;align-items:center;gap:24px}.topbar--storage{align-items:flex-start}.storage-usage__donut{--usage: 0%;--usage-color: #2563eb;position:relative;display:grid;place-items:center;width:78px;height:78px;flex:0 0 auto;border-radius:50%;background:conic-gradient(var(--usage-color) var(--usage),#e2e8f0 0)}.storage-usage__donut:after{content:"";position:absolute;width:54px;height:54px;border-radius:50%;background:#fff}.storage-usage__donut span{position:relative;z-index:1;color:#172033;font-size:17px;font-weight:900}.storage-usage--warning .storage-usage__donut{--usage-color: #d97706}.storage-usage--danger .storage-usage__donut{--usage-color: #dc2626}.storage-usage--ok .storage-usage__donut{--usage-color: #059669}.eyebrow{color:#2563eb;font-size:13px;font-weight:700;margin:0 0 6px;text-transform:uppercase}h1,h2,p{margin-top:0}h1{margin-bottom:0}.summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:28px}.summary-grid article,.dropzone,.upload-progress,.file-list,.admin-auth,.data-panel,.notice{background:#fff;border:1px solid #dbe3ef;border-radius:8px;box-shadow:0 8px 22px #0f172a0d}.summary-grid article{padding:18px}.summary-grid span{color:#64748b;display:block;font-size:13px;margin-bottom:8px}.summary-grid strong{word-break:break-word}.summary-grid--admin{grid-template-columns:repeat(4,minmax(0,1fr))}.summary-grid--storage article{display:grid;gap:4px}.summary-grid--storage .storage-summary-usage{grid-template-columns:auto minmax(0,1fr);align-items:center;column-gap:18px}.storage-summary-usage__meta{min-width:0}.storage-summary-usage__meta span,.storage-summary-usage__meta small{display:block;color:#64748b}.storage-summary-usage__meta strong{display:block;margin:6px 0 4px;color:#172033;overflow-wrap:anywhere}.summary-grid small{color:#64748b;font-size:12px}.dropzone{margin-top:24px;padding:48px;display:grid;justify-items:center;text-align:center;border-style:dashed}.dropzone p{max-width:560px;color:#64748b}.dropzone--compact{grid-template-columns:auto minmax(0,1fr) auto;justify-items:start;align-items:center;gap:12px 18px;padding:22px 24px;text-align:left}.dropzone--compact h2,.dropzone--compact p{margin-bottom:0}.dropzone--compact p{grid-column:2;max-width:none}.dropzone--compact .primary-button{grid-column:3;grid-row:1 / span 2}.upload-progress{margin-top:16px;padding:18px}.upload-progress__summary{display:flex;align-items:center;justify-content:space-between;gap:16px;color:#172033;font-weight:800}.upload-progress__bar{height:10px;margin-top:12px;overflow:hidden;border-radius:999px;background:#e2e8f0}.upload-progress__bar span{display:block;height:100%;border-radius:inherit;background:#2563eb;transition:width .18s ease}.upload-progress__items{display:grid;gap:8px;margin-top:14px}.upload-progress__item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc}.upload-progress__item strong,.upload-progress__item small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-progress__item small{margin-top:3px;color:#64748b}.upload-progress__item>span{color:#475569;font-size:13px;font-weight:800}.upload-progress__item--done>span{color:#166534}.upload-progress__item--error>span,.upload-progress__item--error small{color:#991b1b}.upload-progress--delete .upload-progress__bar span{background:#dc2626}.primary-button,.secondary-button,.table-button{border:0;border-radius:8px;cursor:pointer;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:8px}.primary-button,.secondary-button{min-height:44px;padding:12px 16px}.primary-button{background:#2563eb;color:#fff}.primary-button--danger{background:#dc2626}.primary-button--danger:hover:not(:disabled){background:#b91c1c}.secondary-button{background:#e2e8f0;color:#172033}.table-button{min-height:34px;padding:8px 12px;background:#eef4ff;color:#1d4ed8}.file-list,.data-panel{margin-top:24px;padding:24px}.file-list__header{display:flex;justify-content:space-between;gap:16px;align-items:center}.file-list__header h2{margin-bottom:0}.file-list__header span,.empty-state{color:#64748b}.empty-state{border-top:1px solid #e2e8f0;margin-top:16px;padding-top:20px}.admin-auth{margin-top:28px;padding:18px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:end}.admin-auth label,.admin-auth span{display:grid;gap:8px}.admin-auth span{color:#64748b;font-size:13px;font-weight:700}.admin-auth input{min-height:44px;border:1px solid #cbd5e1;border-radius:8px;padding:10px 12px}.admin-toolbar{display:grid;grid-template-columns:minmax(260px,1fr) minmax(180px,240px);gap:14px;align-items:end;margin-top:18px;padding-top:16px;border-top:1px solid #e2e8f0}.admin-toolbar label{display:grid;gap:8px}.admin-toolbar span{color:#64748b;font-size:13px;font-weight:800}.admin-toolbar input,.admin-toolbar select{width:100%;min-height:42px;border:1px solid #cbd5e1;border-radius:8px;padding:9px 12px;background:#fff;color:#172033}.notice{margin-top:16px;padding:12px 14px;display:flex;gap:10px;align-items:center;font-weight:700}.notice--ok{border-color:#bbf7d0;color:#166534}.notice--error{border-color:#fecaca;color:#991b1b}.table-wrap{overflow-x:auto;margin-top:16px;border-top:1px solid #e2e8f0}table{width:100%;border-collapse:collapse;min-width:760px}th,td{padding:14px 10px;text-align:left;border-bottom:1px solid #e2e8f0;vertical-align:middle}th{color:#64748b;font-size:12px;text-transform:uppercase}td small{display:block;color:#64748b;margin-top:4px;font-size:12px}.status-pill{display:inline-flex;align-items:center;min-height:28px;padding:5px 10px;border-radius:999px;background:#f1f5f9;color:#475569;font-size:12px;font-weight:800}.status-pill--ok{background:#dcfce7;color:#166534}.status-pill--warning{background:#fef3c7;color:#92400e}.status-pill--error{background:#fee2e2;color:#991b1b}.customer-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px;margin-top:18px}.customer-detail-card{padding:16px;border:1px solid #dbe3ef;border-radius:8px;background:#f8fafc}.customer-detail-card header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.customer-detail-card h3{margin:0;font-size:16px}.customer-detail-card p{margin:4px 0 0;color:#64748b;overflow-wrap:anywhere}.customer-detail-card dl{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:16px 0 0}.customer-detail-card dt{color:#64748b;font-size:12px;font-weight:800;text-transform:uppercase}.customer-detail-card dd{margin:4px 0 0;color:#172033;font-weight:800;overflow-wrap:anywhere}.customer-detail-card__footer{display:grid;gap:4px;margin-top:16px;padding-top:12px;border-top:1px solid #e2e8f0;color:#64748b;font-size:12px;overflow-wrap:anywhere}.docs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;margin-top:18px}.docs-card,.docs-list article,.docs-flow article{border:1px solid #dbe3ef;border-radius:8px;background:#f8fafc}.docs-card{padding:16px}.docs-card h3,.docs-list h3{margin:0 0 8px;font-size:16px}.docs-card p,.docs-list p{margin:0;color:#64748b;line-height:1.45}.docs-card dl{display:grid;gap:12px;margin:16px 0 0}.docs-card dt{color:#64748b;font-size:12px;font-weight:800;text-transform:uppercase}.docs-card dd{margin:4px 0 0;color:#172033;font-weight:800;overflow-wrap:anywhere}.docs-list{display:grid;gap:14px;margin-top:18px}.docs-list article{display:grid;gap:10px;padding:16px}.docs-list code{display:block;width:100%;padding:10px 12px;border-radius:8px;background:#111827;color:#e5e7eb;font-size:13px;overflow-x:auto}.docs-flow{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:18px}.docs-flow article{display:grid;gap:8px;padding:16px}.docs-flow strong{color:#172033}.docs-flow span{color:#64748b;line-height:1.45}@media (max-width: 820px){.app-shell{grid-template-columns:1fr}.sidebar{padding:18px}.summary-grid,.summary-grid--admin,.admin-auth,.admin-toolbar{grid-template-columns:1fr}.topbar{align-items:flex-start;flex-direction:column}.topbar-actions{width:100%;align-items:stretch;flex-direction:column}.summary-grid--storage .storage-summary-usage{grid-template-columns:1fr;justify-items:start}.dropzone--compact{grid-template-columns:1fr;justify-items:center;text-align:center}.dropzone--compact p,.dropzone--compact .primary-button{grid-column:auto;grid-row:auto}}.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(180deg,#f1f5f9f0,#f8fafcfa),#f8fafc}.login-panel{width:min(100%,460px);background:#fff;border:1px solid #dbe3ef;border-radius:8px;box-shadow:0 18px 42px #0f172a1f;padding:28px}.login-brand{display:flex;align-items:center;gap:12px;color:#172033}.login-brand strong,.login-brand span{display:block}.login-brand span,.login-copy p{color:#64748b}.login-copy{margin-top:32px}.login-copy h1{font-size:32px;margin-bottom:10px}.login-tabs{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:24px;padding:5px;background:#eef2f7;border-radius:8px}.login-tabs button{min-height:40px;border:0;border-radius:6px;background:transparent;color:#475569;cursor:pointer;font-weight:800}.login-tabs button.active{background:#fff;color:#172033;box-shadow:0 1px 4px #0f172a14}.login-form{display:grid;gap:16px;margin-top:24px}.login-form label{display:grid;gap:8px}.login-form label span{color:#64748b;font-size:13px;font-weight:800}.login-form input{width:100%;min-height:46px;border:1px solid #cbd5e1;border-radius:8px;padding:10px 12px}.login-form small{color:#64748b;font-size:12px;line-height:1.4}.login-form .notice{margin-top:0}.table-actions{display:flex;flex-wrap:wrap;gap:8px}.table-button--secondary{background:#e8eef7;color:#172033;display:inline-flex;align-items:center;gap:6px}.table-button--secondary:hover:not(:disabled){background:#dbe5f3}.file-input{display:none}.summary-grid small{color:#64748b;display:block;font-size:12px;margin-top:6px}.bulk-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:8px}.bulk-actions span{color:#475569;font-size:13px;font-weight:800}.checkbox-cell{width:44px}.checkbox-cell input{width:16px;height:16px;cursor:pointer}.row-actions{position:relative;display:inline-flex;justify-content:flex-end}.icon-button{width:36px;height:36px;border:0;border-radius:8px;background:#eef4ff;color:#172033;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.icon-button:hover{background:#dbe5f3}.action-menu{position:absolute;right:0;top:calc(100% + 6px);z-index:20;min-width:190px;padding:6px;background:#fff;border:1px solid #dbe3ef;border-radius:8px;box-shadow:0 18px 42px #0f172a29}.action-menu button{width:100%;min-height:38px;border:0;border-radius:6px;padding:8px 10px;background:transparent;color:#172033;display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:700;text-align:left}.action-menu button:hover{background:#f1f5f9}.action-menu button.danger,.table-button--danger{color:#b91c1c}.table-button--danger{background:#fee2e2}.table-button--danger:hover:not(:disabled){background:#fecaca}.mobile-file-list{display:none;gap:12px;margin-top:16px}.mobile-file-card{display:grid;gap:12px;padding:14px;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc}.mobile-file-card__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.mobile-file-card__check{display:inline-flex;align-items:center;gap:8px;color:#64748b;font-size:13px;font-weight:800}.mobile-file-card__check input{width:16px;height:16px}.mobile-file-card__name .file-name,.mobile-file-card__name .file-name--button{width:100%}.mobile-file-card__meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:0}.mobile-file-card__meta div{min-width:0}.mobile-file-card__meta dt{color:#64748b;font-size:12px;font-weight:800;text-transform:uppercase}.mobile-file-card__meta dd{margin:4px 0 0;color:#172033;font-weight:800;overflow-wrap:anywhere}@media (max-width: 820px){.file-list__header,.bulk-actions{align-items:flex-start;flex-direction:column}.table-wrap--files{display:none}.mobile-file-list{display:grid}}.topbar-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px}.file-name{display:inline-flex;align-items:center;gap:8px;min-width:0}.file-name svg{color:#2563eb;flex:0 0 auto}@media (max-width: 820px){.topbar-actions{justify-content:flex-start}}.preview-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:grid;place-items:center;padding:24px;background:#0f172a94}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;display:grid;place-items:center;padding:24px;background:#0f172a94}.confirm-modal{width:min(100%,560px);overflow:hidden;border:1px solid #fecaca;border-radius:8px;background:#fff;box-shadow:0 24px 64px #0f172a47}.confirm-modal header,.confirm-modal footer{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px}.confirm-modal header{border-bottom:1px solid #fee2e2}.confirm-modal h2{margin-bottom:0}.confirm-modal__body{display:grid;gap:16px;padding:18px}.confirm-modal__body p{margin:0;color:#7f1d1d;line-height:1.5}.confirm-modal__body dl{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:0}.confirm-modal__body dt{color:#64748b;font-size:12px;font-weight:800;text-transform:uppercase}.confirm-modal__body dd{margin:4px 0 0;color:#172033;font-weight:800;overflow-wrap:anywhere}.confirm-modal__body label{display:grid;gap:8px}.confirm-modal__body label span{color:#64748b;font-size:13px;font-weight:800}.confirm-modal__body input{width:100%;min-height:44px;border:1px solid #fca5a5;border-radius:8px;padding:10px 12px}.confirm-modal footer{border-top:1px solid #fee2e2;justify-content:flex-end}.preview-modal{width:min(100%,1040px);max-height:min(88vh,820px);display:grid;grid-template-rows:auto minmax(0,1fr);background:#fff;border:1px solid #dbe3ef;border-radius:8px;box-shadow:0 24px 64px #0f172a47;overflow:hidden}.preview-modal__header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;border-bottom:1px solid #e2e8f0}.preview-modal__header span,.preview-modal__header strong{display:block}.preview-modal__header span{color:#64748b;font-size:12px;font-weight:800;text-transform:uppercase}.preview-modal__header strong{margin-top:4px;word-break:break-word}.preview-modal__body{min-height:360px;display:grid;place-items:center;background:#f8fafc;overflow:auto}.preview-modal__body img{display:block;max-width:100%;max-height:72vh;object-fit:contain}.preview-modal__body iframe{width:100%;height:min(72vh,700px);border:0;background:#fff}.preview-fallback{display:grid;justify-items:center;gap:16px;padding:32px;text-align:center}.preview-fallback p{color:#475569;margin:0}@media (max-width: 820px){.preview-backdrop{padding:12px}.preview-modal{max-height:92vh}.preview-modal__body{min-height:280px}}.security-panel{margin-top:24px;padding:24px;background:#fff;border:1px solid #dbe3ef;border-radius:8px;box-shadow:0 8px 22px #0f172a0d}.security-panel p{color:#64748b;margin-bottom:0}.security-panel .password-guidance{max-width:760px;margin-top:12px;padding:12px 14px;border:1px solid #dbeafe;border-radius:8px;background:#eff6ff;color:#1e3a8a;font-size:14px;line-height:1.45}.security-form{display:grid;grid-template-columns:repeat(3,minmax(0,1fr)) auto;gap:16px;align-items:end;margin-top:22px}.security-form label{display:grid;gap:8px}.security-form span{color:#64748b;font-size:13px;font-weight:800}.security-form input{width:100%;min-height:44px;border:1px solid #cbd5e1;border-radius:8px;padding:10px 12px}.two-factor-panel{display:grid;gap:14px;align-content:start;margin-top:22px}.two-factor-secret{display:grid;gap:12px}.two-factor-setup{display:grid;grid-template-columns:260px minmax(0,1fr);gap:18px;align-items:center}.two-factor-qr{display:grid;justify-items:center;gap:10px;width:100%;max-width:250px;margin:0;padding:14px;border:1px solid #dbe5f2;border-radius:8px;background:#fff}.two-factor-qr img{width:220px;height:220px}.two-factor-qr figcaption{color:#64748b;font-size:13px;font-weight:800;text-align:center}.two-factor-secret label{display:grid;gap:6px}.two-factor-secret span{color:#64748b;font-size:13px;font-weight:800}.two-factor-secret input{width:100%;min-width:0;min-height:44px;padding:10px 12px;border:1px solid #cbd5e1;border-radius:8px;color:#172033;font:inherit}.two-factor-secret small{overflow-wrap:anywhere;color:#64748b;font-size:12px}@media (max-width: 1100px){.two-factor-setup,.security-form{grid-template-columns:1fr}.security-form .primary-button{width:100%}}.breadcrumbs{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid #e2e8f0}.breadcrumbs button{min-height:32px;border:1px solid #dbe3ef;border-radius:8px;padding:6px 10px;background:#fff;color:#475569;cursor:pointer;font-weight:800}.breadcrumbs button:hover,.breadcrumbs button.active{background:#eef4ff;color:#1d4ed8}.file-name--button{border:0;padding:0;background:transparent;color:inherit;cursor:pointer;text-align:left}.file-name--button:hover strong{color:#1d4ed8;text-decoration:underline}
