@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--primary:#f37021;--primary-light:#ff8c42;--primary-dark:#d45a10;--primary-bg:#f3702114;--primary-border:#f3702140;--bg:#f1f5f9;--surface:#fff;--surface-hover:#fafafa;--text:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--border:#e2e8f0;--border-light:#f1f5f9;--danger:#ef4444;--danger-bg:#ef444414;--success:#22c55e;--success-bg:#22c55e14;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 25px -5px #00000014, 0 8px 10px -6px #0000000a;--shadow-xl:0 20px 50px -12px #00000026;--radius-sm:6px;--radius:10px;--radius-lg:14px;--radius-xl:20px;--transition:.2s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);height:100%;color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.login-page{background:linear-gradient(160deg,#fff7ed 0%,#f1f5f9 40%,#e2e8f0 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";pointer-events:none;background:radial-gradient(circle,#f370211f 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:-30%;right:-20%}.login-page:after{content:"";pointer-events:none;background:radial-gradient(circle,#f3702114 0%,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;bottom:-20%;left:-10%}.login-card{z-index:1;background:var(--surface);border-radius:var(--radius-xl);width:100%;max-width:420px;box-shadow:var(--shadow-xl);border:1px solid var(--border);padding:3rem 2.5rem;animation:.5s ease-out fadeInUp;position:relative}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-logo{text-align:center;margin-bottom:2rem}.login-logo img{width:120px;height:auto;margin-bottom:.75rem}.login-logo h1{color:var(--text-secondary);letter-spacing:-.02em;font-size:1.1rem;font-weight:600}.login-form{flex-direction:column;gap:1.25rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.input-field{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;color:var(--text);transition:var(--transition);outline:none;padding:.8rem 1rem;font-size:.95rem}.input-field::placeholder{color:var(--text-muted)}.input-field:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.btn{border-radius:var(--radius);cursor:pointer;transition:var(--transition);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.8rem 1.5rem;font-size:.95rem;font-weight:600;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{color:#fff;background:linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%);width:100%;box-shadow:0 2px 8px #f370214d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%);transform:translateY(-1px);box-shadow:0 4px 14px #f3702166}.btn-secondary{color:var(--text);background:var(--surface);border:1.5px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface-hover);border-color:var(--primary-border)}.btn-danger{color:var(--danger);background:var(--danger-bg);border:1.5px solid #0000}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff}.btn-sm{border-radius:var(--radius-sm);padding:.45rem .9rem;font-size:.8rem}.btn-icon{border-radius:var(--radius);border:1.5px solid var(--border);background:var(--surface);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:var(--transition);justify-content:center;align-items:center;padding:0;display:inline-flex}.btn-icon:hover{border-color:var(--primary-border);color:var(--primary);background:var(--primary-bg)}.login-error{background:var(--danger-bg);color:var(--danger);border-radius:var(--radius);text-align:center;padding:.75rem 1rem;font-size:.85rem;font-weight:500;animation:.4s shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.dashboard{height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--surface);border-right:1px solid var(--border);z-index:10;flex-direction:column;width:270px;min-width:270px;display:flex}.sidebar-header{border-bottom:1px solid var(--border-light);align-items:center;gap:.75rem;padding:1.5rem;display:flex}.sidebar-header img{object-fit:contain;width:40px;height:40px}.sidebar-header h2{color:var(--text);font-size:.95rem;font-weight:700;line-height:1.2}.sidebar-header span{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;font-weight:500}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;padding:1rem .75rem;display:flex;overflow-y:auto}.nav-item{border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;transition:var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:.75rem;width:100%;padding:.7rem 1rem;font-size:.875rem;font-weight:500;display:flex}.nav-item:hover{background:var(--primary-bg);color:var(--primary)}.nav-item.active{background:var(--primary-bg);color:var(--primary);font-weight:600}.nav-item svg{flex-shrink:0;width:20px;height:20px}.sidebar-footer{border-top:1px solid var(--border-light);padding:1rem .75rem}.user-info{border-radius:var(--radius);align-items:center;gap:.75rem;padding:.6rem .75rem;display:flex}.user-avatar{background:linear-gradient(135deg, var(--primary), var(--primary-light));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.8rem;font-weight:700;display:flex}.user-details{flex:1;min-width:0}.user-details .name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:600;overflow:hidden}.user-details .role{color:var(--text-muted);font-size:.7rem}.main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.topbar{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:1rem;height:64px;padding:0 2rem;display:flex}.topbar-title{color:var(--text);flex-shrink:0;font-size:1.15rem;font-weight:700}.search-box{flex:1;max-width:500px;position:relative}.search-box svg{width:18px;height:18px;color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:.875rem;transform:translateY(-50%)}.search-box input{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--bg);width:100%;color:var(--text);transition:var(--transition);outline:none;padding:.6rem 1rem .6rem 2.5rem;font-size:.875rem}.search-box input:focus{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 3px var(--primary-bg)}.topbar-actions{align-items:center;gap:.5rem;margin-left:auto;display:flex}.content{flex:1;padding:1.75rem 2rem;overflow-y:auto}.breadcrumb{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:.4rem;margin-bottom:1.5rem;font-size:.8rem;display:flex}.breadcrumb button{color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:4px;padding:.2rem .3rem;font-size:.8rem;font-weight:500}.breadcrumb button:hover{background:var(--primary-bg);color:var(--primary)}.breadcrumb .separator{color:var(--text-muted);font-size:.7rem}.breadcrumb .current{color:var(--text);font-weight:600}.section-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:.8rem;font-weight:600}.folder-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.folder-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition);text-align:center;flex-direction:column;align-items:center;gap:.75rem;padding:1.25rem;display:flex;position:relative}.folder-card:hover{border-color:var(--primary-border);box-shadow:var(--shadow-md);transform:translateY(-2px)}.folder-card .folder-icon{width:48px;height:48px;color:var(--primary);transition:var(--transition)}.folder-card:hover .folder-icon{transform:scale(1.08)}.folder-card .folder-name{color:var(--text);word-break:break-word;font-size:.85rem;font-weight:600;line-height:1.3}.folder-card .folder-meta{color:var(--text-muted);font-size:.7rem}.folder-card .folder-actions{opacity:0;transition:var(--transition);gap:.25rem;display:flex;position:absolute;top:.5rem;right:.5rem}.folder-card:hover .folder-actions{opacity:1}.file-list{flex-direction:column;gap:.5rem;display:flex}.file-row{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);transition:var(--transition);align-items:center;gap:1rem;padding:.75rem 1rem;display:flex}.file-row:hover{border-color:var(--primary-border);box-shadow:var(--shadow-sm)}.file-icon{border-radius:var(--radius-sm);text-transform:uppercase;color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:.65rem;font-weight:700;display:flex}.file-icon.pdf{background:#ef4444}.file-icon.xlsx,.file-icon.xls{background:#22c55e}.file-icon.docx,.file-icon.doc{background:#3b82f6}.file-icon.png,.file-icon.jpg,.file-icon.jpeg{background:#a855f7}.file-icon.pptx,.file-icon.ppt{background:#ea580c}.file-icon.psd{background:#2563eb}.file-icon.mp4,.file-icon.mov,.file-icon.avi{background:#ec4899}.file-icon.ia,.file-icon.ai{background:#d97706}.file-icon.default{background:var(--text-muted)}.file-info{flex:1;min-width:0}.file-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.file-meta{color:var(--text-muted);margin-top:.15rem;font-size:.75rem}.file-actions{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0006;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:85vh;animation:.3s ease-out modalSlide;overflow-y:auto}@keyframes modalSlide{0%{opacity:0;transform:translateY(10px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 1rem;display:flex}.modal-header h3{font-size:1.1rem;font-weight:700}.modal-body{flex-direction:column;gap:1rem;padding:1.25rem 1.5rem;display:flex}.modal-footer{border-top:1px solid var(--border-light);justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem 1.5rem;display:flex}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:var(--transition);background:var(--bg);padding:2rem}.upload-zone:hover,.upload-zone.dragover{border-color:var(--primary);background:var(--primary-bg)}.upload-zone svg{width:40px;height:40px;color:var(--text-muted);margin-bottom:.75rem}.upload-zone p{color:var(--text-secondary);font-size:.85rem;font-weight:500}.upload-zone span{color:var(--text-muted);margin-top:.3rem;font-size:.75rem;display:block}.checkbox-list{flex-direction:column;gap:.5rem;max-height:250px;padding:.25rem;display:flex;overflow-y:auto}.checkbox-item{border-radius:var(--radius);cursor:pointer;transition:var(--transition);align-items:center;gap:.75rem;padding:.6rem .75rem;display:flex}.checkbox-item:hover{background:var(--primary-bg)}.checkbox-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}.checkbox-item span{font-size:.85rem;font-weight:500}.badge{text-transform:uppercase;letter-spacing:.04em;border-radius:99px;align-items:center;padding:.2rem .6rem;font-size:.7rem;font-weight:600;display:inline-flex}.badge-admin{background:var(--primary-bg);color:var(--primary)}.badge-franchisee{color:#3b82f6;background:#3b82f614}.users-table{border-collapse:separate;border-spacing:0;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);width:100%;overflow:hidden}.users-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg);border-bottom:1.5px solid var(--border);padding:.75rem 1rem;font-size:.75rem;font-weight:600}.users-table td{border-bottom:1px solid var(--border-light);padding:.85rem 1rem;font-size:.875rem}.users-table tr:last-child td{border-bottom:none}.users-table tr:hover td{background:var(--surface-hover)}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 1rem}.empty-state svg{opacity:.4;width:56px;height:56px;margin-bottom:1rem}.empty-state h3{color:var(--text-secondary);margin-bottom:.35rem;font-size:1rem;font-weight:600}.empty-state p{font-size:.85rem}.toast{background:var(--text);color:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:200;padding:.85rem 1.25rem;font-size:.85rem;font-weight:500;animation:.3s ease-out slideIn;position:fixed;bottom:1.5rem;right:1.5rem}.toast.error{background:var(--danger)}.toast.success{background:#059669}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.sidebar{display:none}.content{padding:1rem}.topbar{padding:0 1rem}.folder-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}.spinner{border:2.5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.access-folder-item{border:1.5px solid var(--border);border-radius:var(--radius);transition:var(--transition);justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.75rem 1rem;display:flex}.access-folder-item:hover{border-color:var(--primary-border)}.access-folder-name{align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;display:flex}.access-count{color:var(--text-muted);font-size:.75rem}.folder-card.drag-over{border-color:var(--primary)!important;background:var(--primary-bg)!important;box-shadow:0 0 0 3px #f3702126, var(--shadow-lg)!important;transform:scale(1.03)!important}.folder-card[draggable=true]{cursor:grab}.folder-card[draggable=true]:active{cursor:grabbing;opacity:.7}.file-row[draggable=true]:active{opacity:.6;cursor:grabbing}.drag-handle{width:28px;height:28px;color:var(--text-muted);cursor:grab;border-radius:var(--radius-sm);transition:var(--transition);justify-content:center;align-items:center;display:inline-flex}.drag-handle:hover{color:var(--primary);background:var(--primary-bg)}.select-all-item{align-items:center;display:flex}.view-only-badge{text-transform:uppercase;letter-spacing:.03em;color:var(--danger);vertical-align:middle;background:#ef444414;border-radius:99px;align-items:center;gap:.25rem;margin-left:.5rem;padding:.1rem .5rem;font-size:.6rem;font-weight:600;display:inline-flex}.btn-icon-locked{background:#ef44440f!important;border-color:#ef444433!important}.viewer-page{-webkit-user-select:none;user-select:none;background:#1a1a2e;flex-direction:column;width:100vw;height:100vh;display:flex;overflow:hidden}.viewer-topbar{background:#16162a;border-bottom:1px solid #ffffff14;flex-shrink:0;align-items:center;gap:1rem;padding:.75rem 1.5rem;display:flex}.viewer-back-btn{color:#fffc;border-radius:var(--radius);cursor:pointer;transition:var(--transition);background:#ffffff0f;border:1px solid #ffffff1a;align-items:center;gap:.4rem;padding:.45rem .85rem;font-size:.8rem;font-weight:500;display:inline-flex}.viewer-back-btn:hover{color:#fff;background:#ffffff1f}.viewer-filename{color:#fff;white-space:nowrap;text-overflow:ellipsis;flex:1;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;display:flex;overflow:hidden}.viewer-filename svg{color:var(--primary);flex-shrink:0}.viewer-badge{text-transform:uppercase;letter-spacing:.05em;color:var(--danger);background:#ef44441a;border:1px solid #ef444433;border-radius:99px;flex-shrink:0;align-items:center;padding:.3rem .75rem;font-size:.65rem;font-weight:700;display:inline-flex}.viewer-content{flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.viewer-iframe{background:#fff;border:none;width:100%;height:100%}.viewer-image-container{justify-content:center;align-items:center;width:100%;height:100%;padding:2rem;display:flex;overflow:auto}.viewer-image{object-fit:contain;border-radius:var(--radius);pointer-events:none;max-width:100%;max-height:100%;box-shadow:0 8px 32px #00000080}.viewer-loading,.viewer-error,.viewer-unsupported{text-align:center;color:#fff9;flex-direction:column;align-items:center;gap:.75rem;display:flex}.viewer-loading p,.viewer-error h2,.viewer-unsupported h2{color:#fffc;font-size:1rem}.viewer-error p,.viewer-unsupported p{color:#ffffff80;font-size:.85rem}.viewer-loading svg,.viewer-error svg,.viewer-unsupported svg{opacity:.4}@media print{.viewer-page,body{display:none!important}}.d4sign-grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1rem;display:grid}.d4sign-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);transition:var(--transition);overflow:hidden}.d4sign-card:hover{border-color:var(--primary-border);box-shadow:var(--shadow-md)}.d4sign-card-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;gap:.75rem;padding:1rem 1.25rem;display:flex}.d4sign-card-title{color:var(--text);align-items:center;gap:.6rem;min-width:0;font-size:.9rem;font-weight:600;display:flex}.d4sign-card-title span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.d4sign-card-title svg{color:var(--text-muted);flex-shrink:0}.d4sign-status-badge{white-space:nowrap;border-radius:2rem;flex-shrink:0;align-items:center;gap:.35rem;padding:.3rem .7rem;font-size:.72rem;font-weight:600;display:inline-flex}.d4sign-card-body{flex-direction:column;gap:.5rem;padding:1rem 1.25rem;display:flex}.d4sign-detail{align-items:flex-start;gap:.5rem;font-size:.8rem;line-height:1.4;display:flex}.d4sign-label{color:var(--text-muted);flex-shrink:0;min-width:100px;font-weight:500}.d4sign-value{color:var(--text-secondary);word-break:break-word}.d4sign-card-footer{border-top:1px solid var(--border-light);justify-content:flex-end;gap:.5rem;padding:.75rem 1.25rem;display:flex}.spin-animation{animation:1s linear infinite spin}
