:root{--oe-primary:#1d2e52;--oe-secondary:#2a5fa5;--oe-accent:#c94a2b;--oe-accent-h:#a83a1e;--oe-bg:#f4f6f8;--oe-sidebar-bg:#f8f9fb;--oe-white:#fff;--oe-text:#1e2533;--oe-muted:#5a6577;--oe-border:#dce2eb;--oe-link:#2a5fa5;--oe-link-h:#1d2e52;--oe-success:#1e7e44;--oe-warn:#856404;--oe-warn-bg:#fff3cd;--oe-tag-bg:#edf2fb;--oe-tag-text:#2a5fa5;--logo-bar-h:54px;--nav-bar-h:44px;--header-h:98px;--content-max:1200px;--radius:4px;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 3px 10px #0000001a;--transition:.18s ease;--font:"Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-xs:.6875rem;--font-sm:.8125rem;--font-base:.9375rem;--font-lg:1.125rem;--font-xl:1.5rem;--font-2xl:2rem}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:16px}body{font-family:var(--font);font-size:var(--font-base);color:var(--oe-text);background:var(--oe-bg);line-height:1.6}a{color:var(--oe-link);text-decoration:none}a:hover{color:var(--oe-link-h);text-decoration:underline}.csp-header{z-index:100;position:fixed;top:0;left:0;right:0}.csp-header__logo-bar{height:var(--logo-bar-h);background:var(--oe-white);border-bottom:1px solid var(--oe-border)}.csp-header__logo-bar-inner{height:100%;max-width:var(--content-max);align-items:center;gap:14px;margin:0 auto;padding:0 24px;display:flex}.csp-header__logo-link{align-items:center;text-decoration:none;display:flex}.csp-header__logo-img{width:auto;height:36px}.csp-header__divider{background:var(--oe-border);flex-shrink:0;width:1px;height:28px}.csp-header__portal-name{font-size:var(--font-sm);color:var(--oe-secondary);white-space:nowrap;font-weight:600;text-decoration:none}.csp-header__portal-name:hover{color:var(--oe-primary);text-decoration:none}.csp-header__actions{align-items:center;gap:10px;margin-left:auto;display:flex}.csp-header__user-menu{position:relative}.csp-header__user-btn{border:1px solid var(--oe-border);border-radius:var(--radius);cursor:pointer;font-family:var(--font);font-size:var(--font-sm);color:var(--oe-text);transition:background var(--transition);background:0 0;align-items:center;gap:8px;padding:5px 10px;display:flex}.csp-header__user-btn:hover{background:var(--oe-bg)}.csp-header__avatar{background:var(--oe-secondary);color:#fff;width:28px;height:28px;font-size:var(--font-xs);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:600;display:flex}.csp-header__user-name{text-overflow:ellipsis;white-space:nowrap;max-width:100px;overflow:hidden}.csp-header__role-tag{text-transform:uppercase;letter-spacing:.5px;border-radius:10px;padding:2px 6px;font-size:10px;font-weight:600}.csp-header__role-tag.staff{background:var(--oe-secondary);color:#fff}.csp-header__role-tag.client{background:var(--oe-tag-bg);color:var(--oe-tag-text)}.csp-header__dropdown{background:var(--oe-white);border:1px solid var(--oe-border);border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:200;min-width:220px;margin-top:4px;padding:4px 0;position:absolute;top:100%;right:0}.csp-header__dropdown-email{font-size:var(--font-xs);color:var(--oe-muted);word-break:break-all;padding:10px 16px 6px}.csp-header__dropdown-item{width:100%;font-family:var(--font);font-size:var(--font-sm);color:var(--oe-text);cursor:pointer;text-align:left;transition:background var(--transition);background:0 0;border:none;padding:8px 16px;text-decoration:none;display:block}.csp-header__dropdown-item:hover{background:var(--oe-bg);color:var(--oe-secondary);text-decoration:none}.csp-header__dropdown-divider{background:var(--oe-border);height:1px;margin:4px 0}.csp-header__nav-bar{height:var(--nav-bar-h);background:linear-gradient(90deg,#001f3f 0%,#003466 50%,#1a5296 100%);align-items:center;gap:2px;padding:0 24px;display:flex}.csp-header__nav-item{color:#ffffffd9;font-size:var(--font-sm);transition:all var(--transition);white-space:nowrap;border-bottom:2px solid #0000;padding:10px 14px;font-weight:500;text-decoration:none}.csp-header__nav-item:hover{color:#fff;border-bottom-color:#fff6;text-decoration:none}.csp-header__nav-item.active{color:#fff;border-bottom-color:#fff}.csp-wrap{flex-direction:column;min-height:100vh;display:flex}.csp-main{margin-top:var(--header-h);flex:1}.csp-content{max-width:var(--content-max);margin:0 auto;padding:28px 40px}.page-container{max-width:960px}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header h1{font-size:var(--font-xl);color:var(--oe-primary);font-weight:700;line-height:1.3}.page-subtitle{color:var(--oe-muted);font-size:var(--font-sm);margin-top:4px}.breadcrumb{font-size:var(--font-sm);color:var(--oe-muted);align-items:center;gap:6px;margin-bottom:16px;display:flex}.breadcrumb a{color:var(--oe-secondary)}.breadcrumb a:hover{text-decoration:underline}.breadcrumb-sep{color:var(--oe-border)}.card-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.card{background:var(--oe-white);border:1px solid var(--oe-border);border-radius:var(--radius);transition:box-shadow var(--transition);flex-direction:column;display:flex}.card:hover{box-shadow:var(--shadow-md)}.card-body{flex:1;padding:20px}.card-title{font-size:var(--font-base);color:var(--oe-primary);margin-bottom:8px;font-weight:600}.card-title-link{color:var(--oe-primary);text-decoration:none}.card-title-link:hover{color:var(--oe-secondary);text-decoration:none}.card-meta{font-size:var(--font-xs);color:var(--oe-muted)}.card-actions{border-top:1px solid var(--oe-border);background:var(--oe-sidebar-bg);border-radius:0 0 var(--radius) var(--radius);gap:8px;padding:12px 20px;display:flex}.btn{border-radius:var(--radius);font-family:var(--font);font-size:var(--font-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;padding:8px 16px;font-weight:500;text-decoration:none;display:inline-flex}.btn:hover{text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--oe-secondary);color:#fff}.btn-primary:hover:not(:disabled){background:#245291}.btn-secondary{color:var(--oe-muted);border-color:var(--oe-border);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--oe-bg);color:var(--oe-text)}.btn-danger{background:var(--oe-accent);color:#fff}.btn-danger:hover:not(:disabled){background:var(--oe-accent-h)}.btn-danger-outline{color:var(--oe-accent);border-color:var(--oe-accent);background:0 0}.btn-danger-outline:hover:not(:disabled){background:#c94a2b0f}.btn-text{color:var(--oe-secondary);cursor:pointer;background:0 0;border:none;padding:4px 8px}.btn-text:hover{text-decoration:underline}.btn-sm{font-size:var(--font-xs);padding:5px 12px}.btn-block{width:100%}.inline-form{flex-wrap:wrap;align-items:flex-end;gap:10px;margin-bottom:20px;display:flex}.input,.select{border:1px solid var(--oe-border);border-radius:var(--radius);font-family:var(--font);font-size:var(--font-base);background:var(--oe-white);color:var(--oe-text);transition:border-color var(--transition);min-width:200px;padding:8px 12px}.input:focus,.select:focus{border-color:var(--oe-secondary);outline:none;box-shadow:0 0 0 3px #2a5fa51f}.select{min-width:120px}.form-error{color:var(--oe-accent);font-size:var(--font-sm);border-radius:var(--radius);border-left:3px solid var(--oe-accent);background:#c94a2b0f;margin:8px 0;padding:8px 12px}.data-table{border-collapse:collapse;background:var(--oe-white);border-radius:var(--radius);width:100%;box-shadow:var(--shadow-sm);overflow:hidden}.data-table th{text-align:left;font-size:var(--font-xs);color:var(--oe-muted);text-transform:uppercase;letter-spacing:.04em;background:var(--oe-sidebar-bg);border-bottom:1px solid var(--oe-border);padding:10px 14px;font-weight:600}.data-table td{font-size:var(--font-sm);border-bottom:1px solid var(--oe-border);padding:10px 14px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#2a5fa50a}.file-name{color:var(--oe-primary);font-weight:500}.actions-cell{gap:6px;display:flex}.section{margin-top:32px}.section-title{font-size:var(--font-base);color:var(--oe-primary);border-bottom:2px solid var(--oe-border);margin-bottom:14px;padding-bottom:8px;font-weight:600}.role-badge{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.03em;border-radius:var(--radius);border:1px solid;padding:2px 8px;font-weight:500;display:inline-block}.role-badge.staff{border-color:var(--oe-secondary);color:var(--oe-secondary);background:#2a5fa50f}.role-badge.client{border-color:var(--oe-muted);color:var(--oe-muted)}.role-badge.viewer{border-color:var(--oe-secondary);color:var(--oe-secondary)}.role-badge.editor{border-color:var(--oe-success);color:var(--oe-success)}.role-badge.admin{border-color:var(--oe-accent);color:var(--oe-accent);background:#c94a2b0f}.role-badge.member{border-color:var(--oe-secondary);color:var(--oe-secondary)}.role-select{border:1px solid var(--oe-border);border-radius:var(--radius);font-family:var(--font);font-size:var(--font-xs);color:var(--oe-text);background:var(--oe-white);cursor:pointer;transition:border-color var(--transition);padding:4px 8px;font-weight:500}.role-select:focus{border-color:var(--oe-secondary);outline:none;box-shadow:0 0 0 2px #2a5fa51f}.upload-zone{border:2px dashed var(--oe-border);border-radius:var(--radius);text-align:center;cursor:pointer;transition:all var(--transition);background:var(--oe-white);margin-bottom:24px;padding:32px}.upload-zone:hover{border-color:var(--oe-secondary);background:#2a5fa505}.upload-zone.drag-over{border-color:var(--oe-secondary);background:var(--oe-tag-bg)}.upload-zone.uploading{cursor:default;border-style:solid}.folder-toolbar{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.new-folder-form{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;display:flex}.new-folder-form .input{max-width:280px}.folder-path{font-size:var(--font-sm);flex-wrap:wrap;align-items:center;gap:4px;margin-bottom:12px;display:flex}.folder-crumb{cursor:pointer;color:var(--oe-secondary);font-size:var(--font-sm);background:0 0;border:none;padding:2px 4px}.folder-crumb:hover{text-decoration:underline}.folder-row td{background:#2a5fa505}.folder-link{cursor:pointer;color:var(--oe-text);font-weight:600;font-size:inherit;background:0 0;border:none;align-items:center;gap:6px;padding:0;display:inline-flex}.folder-link:hover{color:var(--oe-secondary);text-decoration:underline}.folder-icon{font-size:16px}.upload-icon{margin-bottom:8px;font-size:32px}.upload-prompt p{color:var(--oe-muted);font-size:var(--font-sm)}.upload-hint{margin-top:4px;font-size:var(--font-xs)!important}.upload-progress{text-align:center}.upload-progress p{font-size:var(--font-sm);color:var(--oe-text)}.progress-bar{background:var(--oe-border);border-radius:3px;width:100%;max-width:400px;height:6px;margin:12px auto;overflow:hidden}.progress-fill{background:var(--oe-secondary);border-radius:3px;height:100%;transition:width .3s}.progress-text{font-size:var(--font-xs);color:var(--oe-muted)}.dialog-overlay{z-index:300;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.dialog{background:var(--oe-white);border-radius:8px;width:90%;max-width:480px;box-shadow:0 8px 32px #0000002e}.dialog-title{font-size:var(--font-base);border-bottom:1px solid var(--oe-border);padding:16px 20px;font-weight:600}.dialog-message{font-size:var(--font-sm);color:var(--oe-muted);padding:20px;line-height:1.6}.dialog-actions{border-top:1px solid var(--oe-border);justify-content:flex-end;gap:8px;padding:12px 20px;display:flex}.login-page,.verify-page{background:linear-gradient(135deg,#001f3f 0%,#003466 50%,#1a5296 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card,.verify-card{background:var(--oe-white);border-radius:8px;width:100%;max-width:420px;overflow:hidden;box-shadow:0 8px 32px #0003}.login-header{background:var(--oe-white);text-align:center;border-bottom:1px solid var(--oe-border);padding:28px 32px 20px}.login-header img{height:40px;margin-bottom:8px}.login-header h1{font-size:var(--font-sm);color:var(--oe-secondary);margin-top:4px;font-weight:600}.login-form{padding:28px 32px}.login-form label{font-size:var(--font-sm);color:var(--oe-muted);margin-bottom:6px;font-weight:500;display:block}.login-form input{border:1px solid var(--oe-border);border-radius:var(--radius);width:100%;font-family:var(--font);font-size:var(--font-base);color:var(--oe-text);margin-bottom:16px;padding:10px 12px}.login-form input:focus{border-color:var(--oe-secondary);outline:none;box-shadow:0 0 0 3px #2a5fa51f}.login-hint{font-size:var(--font-xs);color:var(--oe-muted);text-align:center;margin-top:12px}.login-sent{text-align:center;padding:32px}.sent-icon{margin-bottom:12px;font-size:48px}.login-sent h2{font-size:var(--font-lg);color:var(--oe-primary);margin-bottom:10px;font-weight:600}.login-sent p{font-size:var(--font-sm);color:var(--oe-muted);line-height:1.6}.sent-hint{font-size:var(--font-xs);color:var(--oe-muted);margin-top:12px}.verify-card{text-align:center;padding:40px}.error-icon{color:var(--oe-accent);margin-bottom:12px;font-size:48px}.verify-card h2{font-size:var(--font-lg);color:var(--oe-primary);margin-bottom:10px;font-weight:600}.verify-card p{font-size:var(--font-sm);color:var(--oe-muted);margin-bottom:20px}.denied-page{justify-content:center;align-items:center;min-height:60vh;display:flex}.denied-card{text-align:center;max-width:400px}.denied-icon{margin-bottom:12px;font-size:48px}.denied-card h2{font-size:var(--font-xl);color:var(--oe-primary);margin-bottom:10px;font-weight:600}.denied-card p{font-size:var(--font-sm);color:var(--oe-muted);margin-bottom:20px;line-height:1.6}.denied-actions{justify-content:center;gap:10px;display:flex}.empty-state{text-align:center;color:var(--oe-muted);background:var(--oe-white);border:1px solid var(--oe-border);border-radius:var(--radius);padding:48px}.empty-hint{font-size:var(--font-xs);margin-top:6px}.page-loading,.loading-screen{color:var(--oe-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px;display:flex}.spinner{border:3px solid var(--oe-border);border-top-color:var(--oe-secondary);border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spin}.activity-log{background:var(--oe-white);border:1px solid var(--oe-border);border-radius:var(--radius);max-height:400px;padding:16px 20px;overflow-y:auto}.activity-item{border-bottom:1px solid #f0f2f5;gap:12px;padding:10px 0;display:flex}.activity-item:last-child{border-bottom:none}.activity-dot{background:var(--oe-secondary);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:6px}.activity-content{flex:1}.activity-action{font-size:var(--font-sm);color:var(--oe-text);font-weight:500}.activity-detail{font-size:var(--font-sm);color:var(--oe-muted)}.activity-meta{font-size:var(--font-xs);color:var(--oe-muted);margin-top:2px}.share-form-bulk{margin-bottom:20px}.share-form-fields{align-items:flex-end;gap:12px;display:flex}.share-textarea-wrap{flex:1}.share-textarea-wrap label{font-size:var(--font-sm);color:var(--oe-muted);margin-bottom:6px;font-weight:500;display:block}.share-textarea{border:1px solid var(--oe-border);border-radius:var(--radius);width:100%;font-family:var(--font);font-size:var(--font-sm);resize:vertical;min-height:80px;color:var(--oe-text);background:var(--oe-white);transition:border-color var(--transition);padding:10px 12px;line-height:1.6}.share-textarea:focus{border-color:var(--oe-secondary);outline:none;box-shadow:0 0 0 3px #2a5fa51f}.share-textarea::placeholder{color:var(--oe-border)}.share-form-actions{flex-direction:column;align-self:flex-end;gap:8px;padding-bottom:2px;display:flex}.share-results{font-size:var(--font-sm);margin-top:12px}.share-success{color:var(--oe-success);border-radius:var(--radius);border-left:3px solid var(--oe-success);background:#1e7e440f;margin-bottom:8px;padding:8px 12px}.share-failures{color:var(--oe-accent);border-radius:var(--radius);border-left:3px solid var(--oe-accent);background:#c94a2b0f;padding:8px 12px}.share-failures ul{margin-top:4px;list-style:none}.share-failures li{font-size:var(--font-xs);padding:2px 0}@media (width<=768px){.share-form-fields{flex-direction:column}.share-form-actions{flex-direction:row;width:100%}}.recycle-type-badge{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.04em;border-radius:var(--radius);padding:2px 8px;font-weight:600;display:inline-block}.recycle-type-badge.accent{color:var(--oe-accent);background:#c94a2b14}.recycle-type-badge.secondary{color:var(--oe-secondary);background:#2a5fa514}.recycle-type-badge.muted{background:var(--oe-bg);color:var(--oe-muted)}.days-badge{font-size:var(--font-xs);color:var(--oe-muted);font-weight:500}.days-badge.urgent{color:var(--oe-accent);font-weight:600}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=768px){.csp-header__logo-bar-inner{gap:10px;padding:0 16px}.csp-header__nav-bar{padding:0 16px}.csp-header__user-name{display:none}.csp-content{padding:20px 16px}.inline-form{flex-direction:column}.inline-form .input{min-width:unset;width:100%}.card-grid{grid-template-columns:1fr}.data-table{font-size:var(--font-xs)}.data-table th,.data-table td{padding:8px 10px}.actions-cell{flex-direction:column}}@media (width<=480px){.csp-header__logo-img{height:28px}.csp-header__portal-name{font-size:var(--font-xs)}.csp-header__role-tag{display:none}.login-card,.verify-card{margin:16px}}
