.sidebar{width:260px;background:#0378a6;color:#fff;padding:0;display:flex;flex-direction:column;overflow-x:hidden;transition:background .3s ease}[data-theme=dark] .sidebar{background:#1e1b20}.brand{display:flex;align-items:center;justify-content:center;padding:16px;border-bottom:1px solid rgba(255,255,255,.1);background:#fff}.brand-link{display:inline-flex;align-items:center;justify-content:center;text-decoration:none}.brand-logo{display:block;height:60px;width:auto;max-width:100%}.sidebar nav{flex:1;display:flex;flex-direction:column;padding:12px 10px;overflow-y:auto}.nav{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border:none;background:transparent;color:#ffffffbf;font-size:14px;font-weight:500;text-align:left;text-decoration:none;border-radius:8px;cursor:pointer;position:relative;transition:background .15s ease,color .15s ease;margin-bottom:2px}.nav:hover{background:#ffffff1a;color:#fff}.nav.active{background:#ffffff26;color:#fff}.nav.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:#60d4ff;border-radius:0 4px 4px 0;animation:slideIn .2s ease}[data-theme=dark] .nav.active:before{background:#a78bfa}@keyframes slideIn{0%{opacity:0;transform:translateY(-50%) scaleY(0)}to{opacity:1;transform:translateY(-50%) scaleY(1)}}.nav svg{opacity:.85;flex-shrink:0;transition:opacity .15s ease,transform .15s ease}.nav:hover svg{opacity:1;transform:scale(1.05)}.nav-group{margin:4px 0}.nav-group__toggle{font-weight:600}.nav-group__toggle span{flex:1}.chev{opacity:.6;transition:transform .25s ease;margin-left:auto}.chev.open{transform:rotate(180deg)}.nav-group__children{display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s ease}.nav-group__children.open{grid-template-rows:1fr}.nav-group__inner{overflow:hidden;padding-left:12px}.theme-row{cursor:default}.theme-row span{flex:1}.theme-switch{width:44px;height:24px;border-radius:12px;border:none;background:#fff3;cursor:pointer;position:relative;transition:background .2s ease;flex-shrink:0}.theme-switch:hover{background:#ffffff4d}.theme-switch.on{background:#a78bfa}.theme-switch__thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 2px 4px #0003;transition:transform .2s ease}.theme-switch.on .theme-switch__thumb{transform:translate(20px)}.nav-footer{margin-top:auto;padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}.sign-out-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;border:none;background:#fffffff2;color:#374151;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .15s ease}.sign-out-btn:hover{background:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.sign-out-btn:active{transform:translateY(0);box-shadow:none}[data-theme=dark] .sign-out-btn{background:#fffffff2;color:#1f2937}[data-theme=dark] .sign-out-btn:hover{background:#fff}.dealer-badge{padding:6px 16px;text-align:center;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:#ffffffe6;background:#00000026;border-bottom:1px solid rgba(255,255,255,.1)}[data-theme=dark] .dealer-badge{background:#ffffff14}.user-email{padding:8px 12px;margin-bottom:8px;text-align:center}.user-email__label{display:block;font-size:12px;font-weight:500;color:#ffffffb3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}:root{--bg: #fafafa;--text: #111827;--muted: #6b7280;--card: #ffffff;--border: #e5e7eb;--chip-bg: #eef;--accent: #6366f1;--brand: #4f46e5;color-scheme:light}[data-theme=dark]{--bg: #0f1115;--text: #e8e8e8;--muted: #a3a3a3;--card: #14171c;--border: #2a2f36;--chip-bg: #263a6b;color-scheme:dark}html,body{background:var(--bg);color:var(--text)}.app-shell{position:relative;min-height:100vh;max-width:100%;overflow-x:hidden}.app-shell:not(.no-sidebar) .sidebar{position:fixed;top:0;left:0;bottom:0;width:240px;z-index:1000}.app-shell:not(.no-sidebar) .app-main{margin-left:240px}.app-shell.no-sidebar .app-main{margin-left:0!important}.app-main{padding:16px 20px;background:var(--bg);color:var(--text);min-width:0}.app-main--full{width:100%}.content h1{margin:4px 0 12px}.muted{color:var(--muted)}.error{color:#b00020}.table-wrap{width:100%;overflow-x:hidden}.grid{width:100%;border-collapse:collapse;table-layout:fixed}.grid th,.grid td{padding:8px 10px;border-top:1px solid var(--border);overflow-wrap:anywhere;word-break:break-word;white-space:normal;vertical-align:top}.chip{background:var(--chip-bg);border-radius:999px;padding:2px 8px;margin-right:6px}.pdf-stage{position:relative;display:inline-block;-webkit-user-select:none;user-select:none}.pdf-stage .react-pdf__Page__textContent{-webkit-user-select:none;user-select:none}.pdf-stage .react-pdf__Page__annotations{pointer-events:none}.pdf-draw-overlay{position:absolute;inset:0;z-index:10;cursor:crosshair;touch-action:none}.fullscreen-center{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg);color:var(--text)}.login-card{width:min(92vw,560px);background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:12px;padding:24px 20px;box-shadow:0 6px 18px #0000000f}.input,.app-main input,.app-main select,.app-main textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--card);color:var(--text)}.input:focus,.app-main input:focus,.app-main select:focus,.app-main textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 15%,transparent)}.input:-webkit-autofill,.app-main input:-webkit-autofill,.app-main select:-webkit-autofill,.app-main textarea:-webkit-autofill{-webkit-text-fill-color:var(--text);box-shadow:0 0 0 1000px var(--card) inset;transition:background-color 9999s ease-out}input[type=checkbox],input[type=radio],progress,meter{accent-color:var(--accent)}.app-main button{font:inherit;color:var(--text)}.app-main button:not(.primary-btn){background:transparent;border:1px solid var(--border);color:var(--text);padding:6px 10px;border-radius:6px;cursor:pointer}.app-main button:not(.primary-btn):hover{background:#00000008}[data-theme=dark] .app-main button:not(.primary-btn):hover{background:#ffffff0f}.primary-btn{width:100%;padding:10px 12px;border-radius:8px;border:1px solid transparent;background:var(--brand);color:#fff;font-weight:600;cursor:pointer}.app-shell.no-sidebar .sidebar{display:none!important}.pdf-field-btn{background:transparent}.pdf-field-btn:focus{outline:none}.irsig-script{font-family:Great Vibes,Segoe Script,Snell Roundhand,Brush Script MT,cursive;font-weight:400;letter-spacing:.5px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}:root{color-scheme:light}[data-theme=dark]{color-scheme:dark}.login-fullscreen,.fullscreen-center{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--bg);color:var(--text)}.login-card{width:min(92vw,520px);background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:12px;padding:24px 20px;box-shadow:0 6px 18px #0000000f;display:grid;gap:10px}.login-brand{display:grid;place-items:center;margin-bottom:6px}.login-brand img{height:64px;width:auto;display:block}.login-title{margin:0;text-align:center;font-size:22px;font-weight:700}.login-subtitle{margin:0 0 10px;text-align:center;color:var(--muted);font-size:14px}.login-label{display:block;font-size:13px;color:var(--text);opacity:.9;margin-top:6px;margin-bottom:6px}.login-card .login-input,.login-card .input,.login-card input,.login-card select,.login-card textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--card);color:var(--text);font-size:14px}.login-card .login-input:focus,.login-card .input:focus,.login-card input:focus,.login-card select:focus,.login-card textarea:focus{outline:none;border-color:var(--accent, #6366f1);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent, #6366f1) 15%,transparent)}.login-card input:-webkit-autofill,.login-card select:-webkit-autofill,.login-card textarea:-webkit-autofill{-webkit-text-fill-color:var(--text);box-shadow:0 0 0 1000px var(--card) inset;transition:background-color 9999s ease-out}.login-primary{width:100%;padding:10px 12px;border-radius:8px;border:1px solid transparent;background:#4f46e5;color:#fff;font-weight:600;cursor:pointer;margin-top:6px}.login-primary:disabled{opacity:.65;cursor:not-allowed}.login-error{margin-top:4px;color:#b00020;font-size:14px}.login-card a{color:var(--text);opacity:.9;text-decoration:underline}.login-card .secondary{width:100%;padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text);cursor:pointer}.password-wrapper{position:relative;width:100%}.password-wrapper .input{padding-right:40px}.eye-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#9ca3af;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px}.eye-toggle:hover{color:#374151}:root{--react-pdf-annotation-layer: 1;--annotation-unfocused-field-background: url("data:image/svg+xml;charset=UTF-8,<svg width='1px' height='1px' xmlns='http://www.w3.org/2000/svg'><rect width='100%' height='100%' style='fill:rgba(0, 54, 255, 0.13);'/></svg>");--input-focus-border-color: Highlight;--input-focus-outline: 1px solid Canvas;--input-unfocused-border-color: transparent;--input-disabled-border-color: transparent;--input-hover-border-color: black;--link-outline: none}@media screen and (forced-colors: active){:root{--input-focus-border-color: CanvasText;--input-unfocused-border-color: ActiveText;--input-disabled-border-color: GrayText;--input-hover-border-color: Highlight;--link-outline: 1.5px solid LinkText}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid selectedItem}.annotationLayer .linkAnnotation:hover{-webkit-backdrop-filter:invert(100%);backdrop-filter:invert(100%)}}.annotationLayer{position:absolute;top:0;left:0;pointer-events:none;transform-origin:0 0;z-index:3}.annotationLayer[data-main-rotation="90"] .norotate{transform:rotate(270deg) translate(-100%)}.annotationLayer[data-main-rotation="180"] .norotate{transform:rotate(180deg) translate(-100%,-100%)}.annotationLayer[data-main-rotation="270"] .norotate{transform:rotate(90deg) translateY(-100%)}.annotationLayer canvas{position:absolute;width:100%;height:100%}.annotationLayer section{position:absolute;text-align:initial;pointer-events:auto;box-sizing:border-box;margin:0;transform-origin:0 0}.annotationLayer .linkAnnotation{outline:var(--link-outline)}.textLayer.selecting~.annotationLayer section{pointer-events:none}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a{position:absolute;font-size:1em;top:0;left:0;width:100%;height:100%}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a:hover{opacity:.2;background:#ff0;box-shadow:0 2px 10px #ff0}.annotationLayer .textAnnotation img{position:absolute;cursor:pointer;width:100%;height:100%;top:0;left:0}.annotationLayer .textWidgetAnnotation :is(input,textarea),.annotationLayer .choiceWidgetAnnotation select,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{background-image:var(--annotation-unfocused-field-background);border:2px solid var(--input-unfocused-border-color);box-sizing:border-box;font:calc(9px * var(--total-scale-factor)) sans-serif;height:100%;margin:0;vertical-align:top;width:100%}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid red}.annotationLayer .choiceWidgetAnnotation select option{padding:0}.annotationLayer .buttonWidgetAnnotation.radioButton input{border-radius:50%}.annotationLayer .textWidgetAnnotation textarea{resize:none}.annotationLayer .textWidgetAnnotation :is(input,textarea)[disabled],.annotationLayer .choiceWidgetAnnotation select[disabled],.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input[disabled]{background:none;border:2px solid var(--input-disabled-border-color);cursor:not-allowed}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:hover{border:2px solid var(--input-hover-border-color)}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation.checkBox input:hover{border-radius:2px}.annotationLayer .textWidgetAnnotation :is(input,textarea):focus,.annotationLayer .choiceWidgetAnnotation select:focus{background:none;border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) :focus{background-image:none;background-color:transparent}.annotationLayer .buttonWidgetAnnotation.checkBox :focus{border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.radioButton :focus{border:2px solid var(--input-focus-border-color);outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after,.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{background-color:CanvasText;content:"";display:block;position:absolute}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{height:80%;left:45%;width:1px}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before{transform:rotate(45deg)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{transform:rotate(-45deg)}.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{border-radius:50%;height:50%;left:30%;top:20%;width:50%}.annotationLayer .textWidgetAnnotation input.comb{font-family:monospace;padding-left:2px;padding-right:0}.annotationLayer .textWidgetAnnotation input.comb:focus{width:103%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{appearance:none}.annotationLayer .popupTriggerArea{height:100%;width:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{position:absolute;font-size:calc(9px * var(--total-scale-factor));width:100%;min-width:calc(180px * var(--total-scale-factor));pointer-events:none}.annotationLayer .popup{position:absolute;max-width:calc(180px * var(--total-scale-factor));background-color:#ff9;box-shadow:0 calc(2px * var(--total-scale-factor)) calc(5px * var(--total-scale-factor)) #888;border-radius:calc(2px * var(--total-scale-factor));padding:calc(6px * var(--total-scale-factor));margin-left:calc(5px * var(--total-scale-factor));cursor:pointer;font:message-box;white-space:normal;word-wrap:break-word;pointer-events:auto}.annotationLayer .popup>*{font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .popup h1{display:inline-block}.annotationLayer .popupDate{display:inline-block;margin-left:calc(5px * var(--total-scale-factor))}.annotationLayer .popupContent{border-top:1px solid rgba(51,51,51,1);margin-top:calc(2px * var(--total-scale-factor));padding-top:calc(2px * var(--total-scale-factor))}.annotationLayer .richText>*{white-space:pre-wrap;font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .highlightAnnotation,.annotationLayer .underlineAnnotation,.annotationLayer .squigglyAnnotation,.annotationLayer .strikeoutAnnotation,.annotationLayer .freeTextAnnotation,.annotationLayer .lineAnnotation svg line,.annotationLayer .squareAnnotation svg rect,.annotationLayer .circleAnnotation svg ellipse,.annotationLayer .polylineAnnotation svg polyline,.annotationLayer .polygonAnnotation svg polygon,.annotationLayer .caretAnnotation,.annotationLayer .inkAnnotation svg polyline,.annotationLayer .stampAnnotation,.annotationLayer .fileAttachmentAnnotation{cursor:pointer}.annotationLayer section svg{position:absolute;width:100%;height:100%;top:0;left:0}.annotationLayer .annotationTextContent{position:absolute;width:100%;height:100%;opacity:0;color:transparent;-webkit-user-select:none;user-select:none;pointer-events:none}.annotationLayer .annotationTextContent span{width:100%;display:inline-block}:root{--react-pdf-text-layer: 1;--highlight-bg-color: rgba(180, 0, 170, 1);--highlight-selected-bg-color: rgba(0, 100, 0, 1)}@media screen and (forced-colors: active){:root{--highlight-bg-color: Highlight;--highlight-selected-bg-color: ButtonText}}[data-main-rotation="90"]{transform:rotate(90deg) translateY(-100%)}[data-main-rotation="180"]{transform:rotate(180deg) translate(-100%,-100%)}[data-main-rotation="270"]{transform:rotate(270deg) translate(-100%)}.textLayer{position:absolute;text-align:initial;inset:0;overflow:hidden;line-height:1;text-size-adjust:none;forced-color-adjust:none;transform-origin:0 0;z-index:2}.textLayer :is(span,br){color:transparent;position:absolute;white-space:pre;cursor:text;margin:0;transform-origin:0 0}.textLayer span.markedContent{top:0;height:0}.textLayer .highlight{margin:-1px;padding:1px;background-color:var(--highlight-bg-color);border-radius:4px}.textLayer .highlight.appended{position:initial}.textLayer .highlight.begin{border-radius:4px 0 0 4px}.textLayer .highlight.end{border-radius:0 4px 4px 0}.textLayer .highlight.middle{border-radius:0}.textLayer .highlight.selected{background-color:var(--highlight-selected-bg-color)}.textLayer br::selection{background:transparent}.textLayer .endOfContent{display:block;position:absolute;inset:100% 0 0;z-index:-1;cursor:default;-webkit-user-select:none;user-select:none}.textLayer.selecting .endOfContent{top:0}.hiddenCanvasElement{position:absolute;top:0;left:0;width:0;height:0;display:none}.audit-overlay{position:fixed;inset:0;z-index:9000;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;animation:auditFadeIn .18s ease-out}@keyframes auditFadeIn{0%{opacity:0}to{opacity:1}}.audit-modal{background:#fff;border-radius:16px;width:100%;max-width:680px;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 0 0 1px #0000000a,0 24px 48px -12px #0000002e;animation:auditSlideUp .22s ease-out;overflow:hidden}@keyframes auditSlideUp{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.audit-header{border-bottom:1px solid #e5e7eb;flex-shrink:0}.audit-header-top{display:flex;align-items:flex-start;gap:14px;padding:20px 24px 12px}.audit-header-icon{width:40px;height:40px;border-radius:10px;background:#f0f9ff;color:#0369a1;display:flex;align-items:center;justify-content:center;flex-shrink:0}.audit-header-text{flex:1;min-width:0}.audit-header-text h2{margin:0;font-size:18px;font-weight:700;color:#111827;letter-spacing:-.02em}.audit-header-sub{margin:2px 0 0;font-size:13px;color:#6b7280}.audit-close{background:none;border:none;cursor:pointer;padding:6px;border-radius:8px;color:#9ca3af;transition:all .15s;flex-shrink:0}.audit-close:hover{background:#f3f4f6;color:#374151}.audit-info-bar{display:flex;flex-wrap:wrap;gap:8px 16px;padding:10px 24px 14px;background:#fafbfc;border-top:1px solid #f3f4f6}.audit-info-item{display:flex;align-items:center;gap:5px;font-size:12px;color:#6b7280}.audit-info-label{font-weight:600;color:#374151}.audit-info-value{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.audit-info-code{font-family:SF Mono,Menlo,Consolas,monospace;font-size:11px;background:#f3f4f6;padding:2px 6px;border-radius:4px;color:#4b5563}.audit-copy-btn{background:none;border:none;cursor:pointer;padding:2px;color:#9ca3af;border-radius:4px;display:flex;align-items:center}.audit-copy-btn:hover{color:#374151}.audit-body{flex:1;overflow-y:auto;padding:20px 24px;min-height:200px}.audit-loading{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 0;color:#6b7280;font-size:14px}.audit-spinner{animation:auditSpin .8s linear infinite;color:#3b82f6}@keyframes auditSpin{to{transform:rotate(360deg)}}.audit-error{display:flex;align-items:center;gap:10px;padding:14px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;color:#b91c1c;font-size:13px}.audit-retry{margin-left:auto;background:#fff;border:1px solid #fca5a5;border-radius:6px;padding:4px 12px;font-size:12px;color:#b91c1c;cursor:pointer}.audit-retry:hover{background:#fef2f2}.audit-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:48px 0;color:#9ca3af;text-align:center}.audit-empty span{font-size:15px;font-weight:500;color:#6b7280}.audit-empty p{font-size:13px;margin:0}.audit-timeline{display:flex;flex-direction:column}.timeline-event{display:flex;gap:16px;position:relative}.timeline-event:not(.last){padding-bottom:6px}.timeline-rail{display:flex;flex-direction:column;align-items:center;width:32px;flex-shrink:0;position:relative}.timeline-dot{width:32px;height:32px;border-radius:8px;border:2px solid;display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:1;background:#fff}.timeline-line{width:2px;flex:1;min-height:12px;background:#e5e7eb;margin:4px 0}.timeline-card{flex:1;min-width:0;background:#fafbfc;border:1px solid #f0f0f2;border-radius:10px;padding:14px 16px;margin-bottom:10px;transition:border-color .15s,box-shadow .15s}.timeline-card:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000000a}.timeline-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}.timeline-title{font-size:14px;font-weight:650;color:#111827;letter-spacing:-.01em}.timeline-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;border-radius:6px;flex-shrink:0}.timeline-description{font-size:13px;line-height:1.5;color:#4b5563;margin:0 0 8px;word-break:break-word}.timeline-meta{margin-bottom:8px}.timeline-time{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:#9ca3af}.timeline-relative{font-style:normal;color:#b0b5bd}.timeline-badges{display:flex;flex-wrap:wrap;gap:6px}.t-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:3px 8px;border-radius:6px;font-weight:500;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.t-badge.ip{background:#fef3c7;color:#92400e}.t-badge.device{background:#e0e7ff;color:#3730a3}.t-badge.signer{background:#ecfdf5;color:#065f46}.t-badge.role{background:#f5f3ff;color:#5b21b6}.t-badge.step{background:#f0f9ff;color:#075985;font-weight:600}.t-badge.hash{background:#f3f4f6;color:#6b7280;font-family:SF Mono,Menlo,Consolas,monospace;font-size:10px}.audit-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;border-top:1px solid #e5e7eb;background:#fafbfc;flex-shrink:0}.audit-footer-note{font-size:12px;color:#9ca3af}.audit-footer-close{padding:8px 20px;border-radius:8px;font-size:13px;font-weight:600;border:1px solid #d1d5db;background:#fff;color:#374151;cursor:pointer;transition:all .15s}.audit-footer-close:hover{background:#f9fafb;border-color:#9ca3af}@media (max-width: 640px){.audit-overlay{padding:12px}.audit-modal{max-height:94vh;border-radius:14px}.audit-header-top{padding:16px 16px 10px}.audit-info-bar{padding:8px 16px 12px}.audit-body{padding:16px}.audit-footer{padding:10px 16px}.timeline-card{padding:12px}.t-badge{font-size:10px;padding:2px 6px}}.dashboard{padding:24px 32px;max-width:1400px;margin:0 auto}.dashboard-header{margin-bottom:24px}.dashboard-header h1{font-size:28px;font-weight:700;color:#111827;margin:0 0 4px}.dashboard-subtitle{color:#6b7280;font-size:14px;margin:0}[data-theme=dark] .dashboard-header h1{color:#f9fafb}[data-theme=dark] .dashboard-subtitle{color:#9ca3af}.dashboard-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px}[data-theme=dark] .dashboard-error{background:#450a0a;border-color:#7f1d1d;color:#fca5a5}.dashboard-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000d}[data-theme=dark] .dashboard-card{background:#1f1f23;border-color:#374151}.search-input{padding:8px 8px 8px 10px;font-size:13px;border:none!important;width:200px;background:transparent!important;color:#111827;outline:none!important;box-shadow:none!important;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:0}.page-size-wrapper{display:flex;align-items:center;gap:8px}.page-size-wrapper label{font-size:13px;color:#6b7280}[data-theme=dark] .page-size-wrapper label{color:#9ca3af}.page-size-select{padding:6px 28px 6px 10px;font-size:13px;border:1px solid #d1d5db;border-radius:6px;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 8px center;color:#111827;cursor:pointer;appearance:none;transition:border-color .15s ease}.page-size-select:hover{border-color:#9ca3af}.page-size-select:focus{outline:none;border-color:#3b82f6}[data-theme=dark] .page-size-select{background-color:#27272a;border-color:#374151;color:#f3f4f6;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E")}[data-theme=dark] .page-size-select:hover{border-color:#4b5563}.card-count{font-size:13px;color:#6b7280;background:#e5e7eb;padding:4px 10px;border-radius:999px}[data-theme=dark] .card-count{background:#374151;color:#9ca3af}.dashboard-table{width:100%;border-collapse:collapse;font-size:14px}.dashboard-table th{text-align:left;padding:12px 16px;font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;background:#f9fafb;border-bottom:1px solid #e5e7eb;white-space:nowrap}.dashboard-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s ease,color .15s ease}.dashboard-table th.sortable:hover{background:#f3f4f6;color:#374151}.dashboard-table th.sortable span{margin-right:6px}[data-theme=dark] .dashboard-table th{background:#18181b;color:#9ca3af;border-color:#374151}[data-theme=dark] .dashboard-table th.sortable:hover{background:#27272a;color:#e5e7eb}.dashboard-table td{padding:14px 16px;border-bottom:1px solid #f3f4f6;color:#374151;vertical-align:middle}[data-theme=dark] .dashboard-table td{border-color:#27272a;color:#d1d5db}.dashboard-table tbody tr:hover{background:#f9fafb}[data-theme=dark] .dashboard-table tbody tr:hover{background:#27272a}.dashboard-table tbody tr:last-child td{border-bottom:none}.cell-filename{max-width:200px}[data-theme=dark] .filename-text{color:#f3f4f6}.cell-id{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace}.id-wrapper{display:flex;align-items:center;gap:6px}.request-id{font-size:12px;background:#f3f4f6;padding:4px 8px;border-radius:4px;color:#4b5563}[data-theme=dark] .request-id{background:#27272a;color:#a1a1aa}.icon-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;border-radius:6px;cursor:pointer;color:#9ca3af;transition:all .15s ease}.icon-btn:hover{background:#e5e7eb;color:#374151}[data-theme=dark] .icon-btn:hover{background:#374151;color:#f3f4f6}.icon-btn .copied{color:#10b981}.progress-wrapper{display:flex;align-items:center;gap:10px}.progress-bar{flex:1;height:6px;background:#e5e7eb;border-radius:999px;overflow:hidden}[data-theme=dark] .progress-bar{background:#374151}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:999px;transition:width .3s ease}.progress-text{font-size:12px;color:#6b7280;min-width:32px}.status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:500;white-space:nowrap}.status-signed{background:#d1fae5;color:#047857}[data-theme=dark] .status-signed{background:#064e3b;color:#6ee7b7}.status-progress{background:#dbeafe;color:#1d4ed8}[data-theme=dark] .status-progress{background:#1e3a5f;color:#93c5fd}.status-pending{background:#fef3c7;color:#b45309}[data-theme=dark] .status-pending{background:#451a03;color:#fcd34d}.status-cancelled{background:#fee2e2;color:#dc2626}[data-theme=dark] .status-cancelled{background:#450a0a;color:#fca5a5}.signer-chip{display:inline-block;padding:3px 8px;background:#f3f4f6;border-radius:4px;font-size:12px;color:#4b5563;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.signer-chip.signed{background:#d1fae5;color:#047857}[data-theme=dark] .signer-chip{background:#27272a;color:#a1a1aa}[data-theme=dark] .signer-chip.signed{background:#064e3b;color:#6ee7b7}.signer-more{font-size:11px;color:#9ca3af;padding:3px 6px}.action-link{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;font-size:12px;font-weight:500;color:#4b5563;background:#f3f4f6;border-radius:6px;text-decoration:none;transition:all .15s ease}.action-link:hover{background:#e5e7eb;color:#111827}.action-link.primary{background:#3b82f6;color:#fff}.action-link.primary:hover{background:#2563eb;color:#fff}[data-theme=dark] .action-link{background:#27272a;color:#d1d5db}[data-theme=dark] .action-link:hover{background:#374151;color:#f9fafb}[data-theme=dark] .action-link.primary{background:#3b82f6;color:#fff}.no-actions{color:#d1d5db}.pagination{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-top:1px solid #e5e7eb;background:#f9fafb}[data-theme=dark] .pagination{background:#18181b;border-color:#374151}.pagination-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .15s ease}.pagination-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}[data-theme=dark] .pagination-btn{background:#27272a;border-color:#374151;color:#d1d5db}[data-theme=dark] .pagination-btn:hover:not(:disabled){background:#374151}.pagination-info{font-size:13px;color:#6b7280}.pagination-info strong{color:#111827}.pagination-count{color:#9ca3af}[data-theme=dark] .pagination-info strong{color:#f3f4f6}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-top:24px}.summary-card{display:flex;align-items:center;gap:14px;padding:18px 20px;background:#fff;border:1px solid #e5e7eb;border-radius:10px}[data-theme=dark] .summary-card{background:#1f1f23;border-color:#374151}.summary-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px}.summary-icon.pending{background:#fef3c7;color:#b45309}.summary-icon.completed{background:#d1fae5;color:#047857}[data-theme=dark] .summary-icon.pending{background:#451a03;color:#fcd34d}[data-theme=dark] .summary-icon.completed{background:#064e3b;color:#6ee7b7}.summary-content{display:flex;flex-direction:column}.summary-value{font-size:24px;font-weight:700;color:#111827;line-height:1.2}[data-theme=dark] .summary-value{color:#f9fafb}.summary-label{font-size:13px;color:#6b7280}.refresh-btn{background:none;border:1px solid #e5e7eb;border-radius:6px;padding:5px 7px;cursor:pointer;color:#6b7280;display:flex;align-items:center;margin-left:4px;transition:all .15s}.refresh-btn:hover{background:#f3f4f6;color:#374151;border-color:#d1d5db}.refresh-btn:disabled{cursor:not-allowed;opacity:.5}.refresh-btn .spinning{animation:spin .8s linear infinite}.templates-page{padding:24px 32px;max-width:1200px;margin:0 auto}.templates-header{margin-bottom:24px}.templates-header h1{font-size:28px;font-weight:700;color:#111827;margin:0 0 4px}.templates-subtitle{color:#6b7280;font-size:14px;margin:0}[data-theme=dark] .templates-header h1{color:#f9fafb}[data-theme=dark] .templates-subtitle{color:#9ca3af}.templates-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px}[data-theme=dark] .templates-error{background:#450a0a;border-color:#7f1d1d;color:#fca5a5}.templates-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000d}[data-theme=dark] .templates-card{background:#1f1f23;border-color:#374151}.card-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.template-count{font-size:13px;color:#6b7280;background:#e5e7eb;padding:4px 10px;border-radius:999px}[data-theme=dark] .template-count{background:#374151;color:#9ca3af}.refresh-btn{display:inline-flex;align-items:center;justify-content:center;padding:8px;font-size:13px;color:#374151;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .15s ease}.refresh-btn:hover{background:#e5e7eb;border-color:#9ca3af}[data-theme=dark] .refresh-btn{background:#27272a;border-color:#374151;color:#d1d5db}[data-theme=dark] .refresh-btn:hover{background:#374151;border-color:#4b5563}.templates-table{width:100%;border-collapse:collapse;font-size:14px}.templates-table th{text-align:left;padding:12px 16px;font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;background:#f9fafb;border-bottom:1px solid #e5e7eb;white-space:nowrap}.templates-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s ease,color .15s ease}.templates-table th.sortable:hover{background:#f3f4f6;color:#374151}.templates-table th.sortable span{margin-right:6px}[data-theme=dark] .templates-table th{background:#18181b;color:#9ca3af;border-color:#374151}[data-theme=dark] .templates-table th.sortable:hover{background:#27272a;color:#e5e7eb}.templates-table td{padding:16px;border-bottom:1px solid #f3f4f6;color:#374151;vertical-align:middle}[data-theme=dark] .templates-table td{border-color:#27272a;color:#d1d5db}.templates-table tbody tr:hover{background:#f9fafb}[data-theme=dark] .templates-table tbody tr:hover{background:#27272a}.templates-table tbody tr:last-child td{border-bottom:none}.cell-template{min-width:250px}.template-info{display:flex;flex-direction:column;gap:4px}.template-name{font-weight:600;color:#111827}[data-theme=dark] .template-name{color:#f3f4f6}.template-id{font-size:12px;color:#6b7280;background:#f3f4f6;padding:2px 6px;border-radius:4px;font-family:monospace;display:inline-block;word-break:break-all}[data-theme=dark] .template-id{background:#27272a;color:#9ca3af}.cell-actions{width:220px}.actions-wrapper{display:flex;gap:10px;justify-content:flex-end}.templates-table .action-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;font-size:14px;font-weight:500;border-radius:6px;cursor:pointer;transition:all .15s ease;white-space:nowrap;font-family:inherit;line-height:1;min-width:80px}.templates-table .action-btn svg{flex-shrink:0}.templates-table .action-btn.use{background:#3b82f6;color:#fff;border:none}.templates-table .action-btn.use:hover{background:#2563eb}.templates-table .action-btn.delete{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;min-width:100px}.templates-table .action-btn.delete:hover:not(:disabled){background:#fee2e2;border-color:#fca5a5}.templates-table .action-btn.delete:disabled{opacity:.6;cursor:not-allowed}[data-theme=dark] .templates-table .action-btn.delete{background:#450a0a;border-color:#7f1d1d;color:#fca5a5}[data-theme=dark] .templates-table .action-btn.delete:hover:not(:disabled){background:#7f1d1d}.contacts-page{padding:24px 32px;max-width:1200px;margin:0 auto}.contacts-header{margin-bottom:24px}.contacts-header h1{font-size:28px;font-weight:700;color:#111827;margin:0 0 4px}.contacts-subtitle{color:#6b7280;font-size:14px;margin:0}[data-theme=dark] .contacts-header h1{color:#f9fafb}[data-theme=dark] .contacts-subtitle{color:#9ca3af}.contacts-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px}[data-theme=dark] .contacts-error{background:#450a0a;border-color:#7f1d1d;color:#fca5a5}.contacts-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000d;margin-bottom:20px}[data-theme=dark] .contacts-card{background:#1f1f23;border-color:#374151}.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e5e7eb;background:#f9fafb;flex-wrap:wrap;gap:12px}[data-theme=dark] .card-header{background:#18181b;border-color:#374151}.card-title{display:flex;align-items:center;gap:10px;font-weight:600;font-size:16px;color:#111827}[data-theme=dark] .card-title{color:#f9fafb}.card-controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.contact-count{font-size:13px;color:#6b7280;background:#e5e7eb;padding:4px 10px;border-radius:999px}[data-theme=dark] .contact-count{background:#374151;color:#9ca3af}.add-contact-form{padding:20px}.form-row{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap}.form-group{display:flex;flex-direction:column;gap:6px;flex:1;min-width:200px}.form-group label{font-size:13px;font-weight:500;color:#374151}[data-theme=dark] .form-group label{color:#d1d5db}.form-group input{padding:10px 14px;font-size:14px;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#111827;transition:border-color .15s ease,box-shadow .15s ease}.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input::placeholder{color:#9ca3af}[data-theme=dark] .form-group input{background:#27272a;border-color:#374151;color:#f3f4f6}[data-theme=dark] .form-group input:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa26}.add-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:500;color:#fff;background:#3b82f6;border:none;border-radius:8px;cursor:pointer;transition:background .15s ease;white-space:nowrap;height:42px}.add-btn:hover:not(:disabled){background:#2563eb}.add-btn:disabled{opacity:.6;cursor:not-allowed}.search-form{display:flex;align-items:center;gap:8px}.search-input-wrapper{position:relative;display:flex;align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:6px;transition:border-color .15s ease,box-shadow .15s ease}.search-input-wrapper:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}[data-theme=dark] .search-input-wrapper{background:#27272a;border-color:#374151}[data-theme=dark] .search-input-wrapper:focus-within{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa26}.search-icon{margin-left:10px;color:#9ca3af;flex-shrink:0}.search-input{padding:8px 8px 8px 10px;font-size:13px;border:none!important;width:180px;background:transparent!important;color:#111827;outline:none!important;box-shadow:none!important;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:0}.search-input::placeholder{color:#9ca3af}.search-input:focus{outline:none!important;border:none!important;box-shadow:none!important}[data-theme=dark] .search-input{color:#f3f4f6;background:transparent!important}.search-clear{display:flex;align-items:center;justify-content:center;width:20px;height:20px;margin-right:8px;border:none;background:#d1d5db;border-radius:50%;cursor:pointer;color:#374151;flex-shrink:0;transition:background .15s ease;font-size:16px;font-weight:700;line-height:1}.search-clear:hover{background:#9ca3af;color:#111827}[data-theme=dark] .search-clear{background:#4b5563;color:#e5e7eb}[data-theme=dark] .search-clear:hover{background:#6b7280;color:#f9fafb}.search-btn{padding:8px 14px;font-size:13px;font-weight:500;color:#fff;background:#3b82f6;border:none;border-radius:6px;cursor:pointer;transition:background .15s ease}.search-btn:hover{background:#2563eb}.search-result-banner{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:#eff6ff;border-bottom:1px solid #bfdbfe;font-size:13px;color:#1e40af}[data-theme=dark] .search-result-banner{background:#1e3a5f;border-color:#1e40af;color:#93c5fd}.clear-search-btn{padding:4px 10px;font-size:12px;font-weight:500;color:#1e40af;background:#fff;border:1px solid #bfdbfe;border-radius:4px;cursor:pointer;transition:all .15s ease}.clear-search-btn:hover{background:#dbeafe;border-color:#93c5fd}[data-theme=dark] .clear-search-btn{background:#27272a;border-color:#1e40af;color:#93c5fd}[data-theme=dark] .clear-search-btn:hover{background:#374151}.table-container{position:relative;overflow-x:auto}.table-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:10px;background:#ffffffd9;z-index:10;font-size:14px;color:#6b7280}[data-theme=dark] .table-loading{background:#1f1f23e6}.spinner{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.contacts-table{width:100%;border-collapse:collapse;font-size:14px}.contacts-table th{text-align:left;padding:12px 16px;font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;background:#f9fafb;border-bottom:1px solid #e5e7eb;white-space:nowrap}.contacts-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s ease,color .15s ease}.contacts-table th.sortable:hover{background:#f3f4f6;color:#374151}.contacts-table th.sortable span{margin-right:6px}[data-theme=dark] .contacts-table th{background:#18181b;color:#9ca3af;border-color:#374151}[data-theme=dark] .contacts-table th.sortable:hover{background:#27272a;color:#e5e7eb}.sort-icon{vertical-align:middle;transition:opacity .15s ease,color .15s ease}.sort-icon.inactive{opacity:.4}.sort-icon.active{opacity:1;color:#3b82f6}[data-theme=dark] .sort-icon.active{color:#60a5fa}.contacts-table td{padding:14px 16px;border-bottom:1px solid #f3f4f6;color:#374151;vertical-align:middle}[data-theme=dark] .contacts-table td{border-color:#27272a;color:#d1d5db}.contacts-table tbody tr:hover{background:#f9fafb}[data-theme=dark] .contacts-table tbody tr:hover{background:#27272a}.contacts-table tbody tr:last-child td{border-bottom:none}.cell-name{font-weight:500;color:#111827;min-width:150px}[data-theme=dark] .cell-name{color:#f3f4f6}.name-text{display:block}.cell-email{color:#6b7280;min-width:200px}[data-theme=dark] .cell-email{color:#9ca3af}.email-text{display:block}.cell-date{white-space:nowrap;font-size:13px;color:#6b7280}[data-theme=dark] .cell-date{color:#9ca3af}.edit-input{padding:6px 10px;font-size:14px;border:1px solid #3b82f6;border-radius:6px;background:#fff;color:#111827;width:100%;max-width:200px}.edit-input:focus{outline:none;box-shadow:0 0 0 3px #3b82f61a}[data-theme=dark] .edit-input{background:#27272a;border-color:#60a5fa;color:#f3f4f6}.cell-actions{width:100px}.actions-wrapper{display:flex;gap:8px}.action-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;transition:all .15s ease}.action-btn.edit{background:#f3f4f6;color:#4b5563}.action-btn.edit:hover{background:#e5e7eb;color:#111827}.action-btn.delete{background:#fef2f2;color:#dc2626}.action-btn.delete:hover{background:#fee2e2;color:#b91c1c}.action-btn.save{background:#d1fae5;color:#047857}.action-btn.save:hover{background:#a7f3d0;color:#065f46}.action-btn.cancel{background:#f3f4f6;color:#4b5563}.action-btn.cancel:hover{background:#e5e7eb;color:#111827}[data-theme=dark] .action-btn.edit{background:#27272a;color:#d1d5db}[data-theme=dark] .action-btn.edit:hover{background:#374151;color:#f9fafb}[data-theme=dark] .action-btn.delete{background:#450a0a;color:#fca5a5}[data-theme=dark] .action-btn.delete:hover{background:#7f1d1d;color:#fecaca}[data-theme=dark] .action-btn.save{background:#064e3b;color:#6ee7b7}[data-theme=dark] .action-btn.save:hover{background:#065f46;color:#a7f3d0}[data-theme=dark] .action-btn.cancel{background:#27272a;color:#d1d5db}[data-theme=dark] .action-btn.cancel:hover{background:#374151;color:#f9fafb}.empty-state svg{margin-bottom:8px;opacity:.5}.users-page{max-width:1200px;margin:0 auto;padding:32px 24px 80px;width:100%;box-sizing:border-box}.users-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.users-header-text h1{display:flex;align-items:center;gap:10px;margin:0;font-size:22px;font-weight:700;color:#111827;letter-spacing:-.02em}.users-header-text p{margin:4px 0 0;font-size:14px;color:#6b7280;display:flex;align-items:center;gap:8px}.users-header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.users-refresh-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;cursor:pointer;color:#6b7280;transition:all .15s}.users-refresh-btn:hover{background:#f3f4f6;color:#374151}.users-refresh-btn .spinning{animation:usersSpin .8s linear infinite}.users-create-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:8px;background:#2563eb;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.users-create-btn:hover{background:#1d4ed8}.users-stats{display:flex;gap:16px;margin-bottom:16px;flex-wrap:wrap}.stat-item{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;font-size:13px;font-weight:500;color:#374151;background:#f9fafb;border:1px solid #e5e7eb}.stat-item.warn{background:#fffbeb;border-color:#fde68a;color:#92400e}.users-banner{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:16px}.users-banner.error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.users-banner button{margin-left:auto;background:none;border:none;cursor:pointer;font-size:16px;color:inherit;padding:0 4px}.users-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow-x:auto;width:100%;box-sizing:border-box}.users-table{width:100%;border-collapse:collapse}.users-table thead th{padding:12px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;background:#f9fafb;border-bottom:1px solid #e5e7eb;text-align:left;white-space:nowrap}.users-table thead th:first-child{width:auto}.users-table thead th:nth-child(5){width:auto;min-width:180px}.section-header td{padding:10px 16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#6b7280;background:#f3f4f6;border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb}.section-header td svg{display:inline;vertical-align:-2px;margin-right:4px}.unassigned-header td{color:#92400e;background:#fffbeb}.user-row td{padding:12px 16px;border-bottom:1px solid #f3f4f6;font-size:14px;color:#374151;vertical-align:middle}.user-row:last-child td{border-bottom:none}.user-row:hover td{background:#fafbfc}.admin-row td{background:#fafbfe}.admin-row.expanded td{border-bottom-color:#e5e7eb}.user-row.indent td{background:#fdfdfe}.user-row.indent td:first-child{padding-left:40px}.user-row .cell-name,.admin-row .cell-name{display:table-cell}.admin-expand{display:inline-block;vertical-align:middle;margin-right:6px;color:#9ca3af}.indent-line{color:#d1d5db;margin-right:6px;font-size:13px}.name-stack{display:inline-block;vertical-align:middle}.user-display-name{display:block;font-weight:550;color:#111827;font-size:14px;line-height:1.3}.user-email{display:block;font-size:12px;color:#9ca3af;line-height:1.3;overflow:hidden;text-overflow:ellipsis}.child-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:6px;border-radius:9px;background:#e0e7ff;color:#3b5bdb;font-size:11px;font-weight:600;vertical-align:middle}.role-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:5px;font-size:11px;font-weight:600;letter-spacing:.02em;white-space:nowrap}.role-super{background:#fef3c7;color:#92400e;border:1px solid #fde68a}.role-admin{background:#e0e7ff;color:#3730a3;border:1px solid #c7d2fe}.role-user{background:#f3f4f6;color:#4b5563;border:1px solid #e5e7eb}.status-dot{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500}.status-dot:before{content:"";width:7px;height:7px;border-radius:50%;flex-shrink:0}.status-dot.active:before{background:#22c55e;box-shadow:0 0 4px #22c55e66}.status-dot.inactive:before{background:#d1d5db}.parent-label{font-size:13px;color:#6b7280}.no-parent{color:#d1d5db}.cell-actions{overflow:visible}.user-actions{display:flex;align-items:center;gap:8px}.action-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;border:none;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}.action-btn.promote{color:#fff;background:#4f46e5}.action-btn.promote:hover{background:#4338ca}.action-btn.demote{color:#fff;background:#dc2626}.action-btn.demote:hover{background:#b91c1c}.action-btn.assign{color:#fff;background:#059669}.action-btn.assign:hover{background:#047857}.action-spinner{animation:usersSpin .8s linear infinite;color:#6b7280}.self-label{font-size:12px;color:#9ca3af;font-style:italic}.users-loading{display:flex;flex-direction:column;align-items:center;gap:12px;padding:80px 0;color:#6b7280;font-size:14px}.users-spinner{animation:usersSpin .8s linear infinite;color:#2563eb}@keyframes usersSpin{to{transform:rotate(360deg)}}.users-error-full{display:flex;flex-direction:column;align-items:center;gap:12px;padding:80px 0;color:#6b7280}.users-retry-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid #d1d5db;border-radius:8px;background:#fff;font-size:13px;cursor:pointer}.users-retry-btn:hover{background:#f9fafb}.empty-state{text-align:center;padding:48px 16px!important;color:#9ca3af}.empty-state svg{margin-bottom:8px}.empty-state span{display:block;font-size:14px}.modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-card{background:#fff;border-radius:12px;width:100%;max-width:420px;box-shadow:0 20px 60px #00000026;overflow:hidden;animation:modalSlideUp .2s ease-out}.modal-card.wide{max-width:520px}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid #f3f4f6}.modal-header h3{margin:0;font-size:16px;font-weight:650;color:#111827;display:flex;align-items:center;gap:8px}.modal-close{background:none;border:none;cursor:pointer;color:#9ca3af;padding:4px;border-radius:6px;display:flex}.modal-close:hover{color:#374151;background:#f3f4f6}.modal-body{padding:20px 22px}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:14px 22px;border-top:1px solid #f3f4f6;background:#f9fafb}.modal-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.modal-btn.cancel{background:#fff;border:1px solid #d1d5db;color:#374151}.modal-btn.cancel:hover{background:#f3f4f6}.modal-btn.confirm{background:#2563eb;border:1px solid #2563eb;color:#fff}.modal-btn.confirm:hover{background:#1d4ed8}.modal-btn.confirm:disabled{opacity:.6;cursor:not-allowed}.assign-label{margin:0 0 12px;font-size:14px;color:#374151}.assign-select{width:100%;padding:9px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;color:#374151;background:#fff;box-sizing:border-box}.assign-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.create-error{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;font-size:13px;margin-bottom:16px}.form-row{margin-bottom:16px}.form-row label{display:block;font-size:13px;font-weight:550;color:#374151;margin-bottom:5px}.form-input{width:100%;padding:9px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;color:#374151;box-sizing:border-box;transition:border-color .15s}.form-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-input::placeholder{color:#9ca3af}.form-select{width:100%;padding:9px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;color:#374151;background:#fff;box-sizing:border-box}.form-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-hint{display:block;font-size:12px;color:#9ca3af;margin-top:4px}.checkbox-row label{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer}.checkbox-row input[type=checkbox]{width:16px;height:16px;accent-color:#2563eb}.branding-row td{padding:0!important;background:#f8fafc}.branding-open td{border-bottom-color:#e0e7ff!important}.branding-panel{border-top:1px solid #e5e7eb;padding:20px 24px}.branding-header{display:flex;align-items:center;gap:8px;margin-bottom:16px;font-size:15px;font-weight:600;color:#374151}.branding-header .close-branding{margin-left:auto;background:none;border:none;cursor:pointer;color:#9ca3af;padding:4px;border-radius:6px;display:flex}.branding-header .close-branding:hover{color:#374151;background:#f3f4f6}.branding-error{padding:10px 14px;border-radius:8px;background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;font-size:13px;margin-bottom:16px}.branding-content{display:grid;grid-template-columns:200px 1fr;gap:24px}.branding-section{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:16px}.section-title{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#374151;margin-bottom:12px}.logo-preview{width:100%;aspect-ratio:1;border:1px dashed #d1d5db;border-radius:8px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#fafafa;margin-bottom:12px}.logo-preview img{max-width:100%;max-height:100%;object-fit:contain}.no-logo{display:flex;flex-direction:column;align-items:center;gap:8px;color:#9ca3af;font-size:12px}.logo-actions{display:flex;gap:8px}.upload-btn,.clear-logo-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.upload-btn{background:#2563eb;color:#fff;border:none}.upload-btn:hover{background:#1d4ed8}.upload-btn:disabled{opacity:.6;cursor:not-allowed}.clear-logo-btn{background:#fff;color:#dc2626;border:1px solid #fecaca}.clear-logo-btn:hover{background:#fef2f2}.clear-logo-btn:disabled{opacity:.6;cursor:not-allowed}.color-picker-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}.color-picker{width:40px;height:40px;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;padding:2px}.color-input{flex:1;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-family:monospace}.color-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.branding-form-group{margin-bottom:12px}.branding-form-group label{display:block;font-size:12px;font-weight:550;color:#6b7280;margin-bottom:4px}.branding-form-group input,.branding-form-group textarea{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;box-sizing:border-box}.branding-form-group input:focus,.branding-form-group textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.branding-form-group textarea{resize:vertical;font-family:inherit}.branding-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid #f3f4f6}.clear-fields-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 14px;border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:13px;font-weight:500;color:#6b7280;cursor:pointer}.clear-fields-btn:hover{background:#f3f4f6}.save-branding-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 16px;border:none;border-radius:6px;background:#2563eb;font-size:13px;font-weight:600;color:#fff;cursor:pointer}.save-branding-btn:hover{background:#1d4ed8}.save-branding-btn:disabled{opacity:.6;cursor:not-allowed}.spinner{animation:usersSpin .8s linear infinite}@media (max-width: 768px){.users-page{padding:20px 16px 80px}.users-header{flex-direction:column}.users-stats{gap:8px}.users-table{min-width:0}.users-table thead th:nth-child(4),.users-table tbody td:nth-child(4){display:none}.user-row.indent td:first-child{padding-left:28px}.action-btn span{display:none}.branding-content{grid-template-columns:1fr}.logo-preview{max-width:150px;margin:0 auto 12px}}.settings-page{max-width:780px;margin:0 auto;padding:32px 24px 80px;width:100%;box-sizing:border-box}.settings-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap}.settings-header-text h1{display:flex;align-items:center;gap:10px;margin:0;font-size:22px;font-weight:700;color:#111827;letter-spacing:-.02em}.settings-header-text p{margin:4px 0 0;font-size:14px;color:#6b7280}.settings-save-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:8px;font-size:13px;font-weight:600;border:1px solid #d1d5db;background:#f9fafb;color:#9ca3af;cursor:not-allowed;transition:all .2s;white-space:nowrap;flex-shrink:0}.settings-save-btn.active{background:#2563eb;border-color:#2563eb;color:#fff;cursor:pointer;box-shadow:0 1px 3px #2563eb4d}.settings-save-btn.active:hover{background:#1d4ed8}.settings-banner{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:20px}.settings-banner.error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.settings-banner.success{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46}.settings-banner button{margin-left:auto;background:none;border:none;cursor:pointer;font-size:16px;color:inherit;padding:0 4px}.settings-grid{display:flex;flex-direction:column;gap:20px;width:100%}.settings-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;transition:box-shadow .15s;width:100%;box-sizing:border-box}.settings-card:hover{box-shadow:0 2px 12px #0000000a}.settings-card-header{display:flex;align-items:flex-start;gap:14px;padding:20px 22px;border-bottom:1px solid #f3f4f6;width:100%;box-sizing:border-box}.settings-card-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.reminder-icon{background:#fff7ed;color:#ea580c}.expiry-icon{background:#f0f9ff;color:#0369a1}.notif-icon{background:#f5f3ff;color:#7c3aed}.settings-card-header h2{margin:0;font-size:15px;font-weight:650;color:#111827}.settings-card-header>div:nth-child(2){flex:1 1 auto;min-width:0}.settings-card-header p{margin:2px 0 0;font-size:13px;color:#9ca3af;white-space:normal;word-wrap:break-word}.settings-card-body{padding:6px 22px 18px;width:100%;box-sizing:border-box}.settings-card-body.disabled-section{opacity:.45;pointer-events:none;-webkit-user-select:none;user-select:none}.setting-row{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:20px;padding:14px 0;border-bottom:1px solid #f3f4f6;width:100%;box-sizing:border-box}.setting-row:last-child{border-bottom:none}.setting-label{display:flex;flex-direction:row;align-items:flex-start;gap:10px;flex:1 1 0%;min-width:200px;overflow:visible}.setting-label>svg{margin-top:2px;flex-shrink:0}.setting-label>div{display:block;width:auto;min-width:0;flex:1 1 auto}.label-main{display:block;font-size:14px;font-weight:550;color:#1f2937;line-height:1.4;white-space:normal;word-wrap:break-word;overflow-wrap:break-word}.label-sub{display:block;font-size:12px;color:#9ca3af;margin-top:2px;line-height:1.4;white-space:normal;word-wrap:break-word;overflow-wrap:break-word}.setting-select{padding:7px 32px 7px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:13px;color:#374151;background:#fff;cursor:pointer;width:180px;min-width:180px;flex-shrink:0;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;transition:border-color .15s;box-sizing:border-box;max-width:200px;width:auto;min-width:unset;text-overflow:ellipsis}.setting-select:hover{border-color:#9ca3af}.setting-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.setting-select:disabled{opacity:.5;cursor:not-allowed}.expiry-note{margin-top:8px;padding:10px 14px;background:#f9fafb;border-radius:8px;font-size:12px;color:#6b7280;line-height:1.5;border-left:3px solid #e5e7eb;white-space:normal;word-wrap:break-word}.settings-loading{display:flex;flex-direction:column;align-items:center;gap:12px;padding:80px 0;color:#6b7280;font-size:14px}.settings-spinner{animation:settingsSpin .8s linear infinite;color:#2563eb}@keyframes settingsSpin{to{transform:rotate(360deg)}}.settings-error-full{display:flex;flex-direction:column;align-items:center;gap:12px;padding:80px 0;color:#6b7280}.settings-error-full span{font-size:14px}.settings-retry-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid #d1d5db;border-radius:8px;background:#fff;font-size:13px;cursor:pointer}.settings-retry-btn:hover{background:#f9fafb}.settings-sticky-save{position:fixed;bottom:0;left:0;right:0;display:none;align-items:center;justify-content:space-between;padding:12px 20px;background:#fff;border-top:1px solid #e5e7eb;box-shadow:0 -4px 12px #0000000f;z-index:100;font-size:13px;color:#6b7280}.settings-sticky-save button{padding:8px 20px;border-radius:8px;border:none;background:#2563eb;color:#fff;font-weight:600;font-size:13px;cursor:pointer}.settings-sticky-save button:hover{background:#1d4ed8}.settings-sticky-save button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 640px){.settings-page{padding:20px 16px 100px}.settings-header{flex-direction:column;gap:12px}.settings-save-btn{width:100%;justify-content:center}.setting-row{flex-direction:column;align-items:flex-start;gap:8px;overflow:hidden}.setting-label{min-width:unset;width:100%}.setting-select{width:100%;min-width:unset}.settings-sticky-save{display:flex}}.input-with-unit{display:flex;align-items:center;gap:8px;flex-shrink:0}.setting-input{width:80px;padding:7px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:13px;color:#374151;background:#fff;text-align:center;transition:border-color .15s;box-sizing:border-box}.setting-input:hover{border-color:#9ca3af}.setting-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.input-unit{font-size:13px;color:#6b7280;white-space:nowrap}.settings-no-access{display:flex;flex-direction:column;align-items:center;gap:12px;padding:80px 24px;text-align:center;color:#6b7280}.settings-no-access svg{color:#d1d5db}.settings-no-access h2{margin:0;font-size:17px;font-weight:650;color:#374151}.settings-no-access p{margin:0;font-size:14px;line-height:1.6;max-width:400px;color:#9ca3af}.reports-page{max-width:1200px;margin:0 auto;padding:32px 24px 80px;width:100%;box-sizing:border-box}.reports-header{margin-bottom:24px}.reports-header-text h1{display:flex;align-items:center;gap:10px;margin:0;font-size:22px;font-weight:700;color:#111827;letter-spacing:-.02em}.reports-header-text p{margin:4px 0 0;font-size:14px;color:#6b7280}.reports-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;margin-bottom:20px;transition:box-shadow .15s}.reports-card:hover{box-shadow:0 2px 12px #0000000a}.reports-card .card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #f3f4f6;gap:12px;flex-wrap:wrap}.reports-card .card-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:650;color:#111827}.reports-card .card-title .muted{font-weight:400;color:#9ca3af;font-size:13px}.filters-card{padding:20px}.filters-form{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.04em}.filter-date{padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:13px;color:#374151;background:#fff;transition:border-color .15s;min-width:150px}.filter-date:hover{border-color:#9ca3af}.filter-date:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.toggle-group{flex-direction:row;align-items:center;gap:8px;padding-bottom:4px}.toggle-group label{text-transform:none;font-size:13px;font-weight:550;color:#374151}.toggle-btn{background:none;border:none;cursor:pointer;padding:2px;display:flex;align-items:center;flex-shrink:0}.toggle-on{color:#2563eb}.toggle-off{color:#d1d5db}.run-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 20px;border-radius:8px;font-size:13px;font-weight:600;border:none;background:#2563eb;color:#fff;cursor:pointer;transition:background .15s;white-space:nowrap}.run-btn:hover:not(:disabled){background:#1d4ed8}.run-btn:disabled{opacity:.6;cursor:not-allowed}.reports-banner{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:20px}.reports-banner.error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.reports-banner button{margin-left:auto;background:none;border:none;cursor:pointer;font-size:16px;color:inherit;padding:0 4px}.summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px;margin-bottom:20px}.summary-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:18px 16px;display:flex;align-items:center;gap:14px;transition:box-shadow .15s;overflow:hidden;position:relative}.summary-card:hover{box-shadow:0 2px 12px #0000000a}.summary-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.total-icon{background:#f0f9ff;color:#0369a1}.pending-icon{background:#fff7ed;color:#ea580c}.progress-icon{background:#eff6ff;color:#2563eb}.completed-icon{background:#ecfdf5;color:#059669}.cancelled-icon{background:#fef2f2;color:#dc2626}.rate-icon{background:#f5f3ff;color:#7c3aed}.summary-content{display:flex;flex-direction:column;min-width:0}.summary-value{font-size:22px;font-weight:700;color:#111827;line-height:1.2}.summary-label{font-size:12px;color:#6b7280;margin-top:2px}.rate-card{flex-direction:column;align-items:stretch;gap:10px}.rate-card>.summary-icon{position:absolute;top:16px;right:16px;width:36px;height:36px}.rate-card>.summary-content{padding-right:50px}.rate-bar-bg{width:100%;height:6px;background:#f3f4f6;border-radius:3px;overflow:hidden}.rate-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#7c3aed,#a78bfa);transition:width .5s ease}.user-breakdown-section{margin-bottom:20px}.ub-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:10px}.ub-title{display:flex;align-items:center;gap:8px}.ub-title h2{margin:0;font-size:16px;font-weight:700;color:#111827}.ub-count{font-size:12px;color:#9ca3af;background:#f3f4f6;padding:2px 10px;border-radius:9999px;font-weight:600}.clear-filter-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border:1px solid #2563eb;border-radius:8px;background:#eff6ff;color:#2563eb;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.clear-filter-btn:hover{background:#dbeafe}.user-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.user-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:18px;cursor:pointer;transition:all .18s;position:relative;display:flex;flex-direction:column;gap:14px}.user-card:hover{border-color:#bfdbfe;box-shadow:0 2px 16px #2563eb14;transform:translateY(-1px)}.user-card.uc-active{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb2e,0 4px 20px #2563eb1a}.uc-top{display:flex;align-items:center;gap:12px}.uc-avatar{width:38px;height:38px;border-radius:10px;background:#f0f9ff;color:#0369a1;display:flex;align-items:center;justify-content:center;flex-shrink:0}.uc-identity{flex:1;min-width:0;display:flex;flex-direction:column}.uc-name{font-size:14px;font-weight:650;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.uc-total-label{font-size:12px;color:#9ca3af;margin-top:1px}.donut-chart{flex-shrink:0}.donut-fill{transition:stroke-dashoffset .6s ease}.donut-label{font-size:13px;font-weight:700;font-family:inherit}.stacked-bar{display:flex;height:8px;border-radius:4px;overflow:hidden;background:#f3f4f6}.stacked-bar.empty-bar{background:#f3f4f6}.bar-seg{height:100%;min-width:2px;transition:width .4s ease}.seg-completed{background:#059669}.seg-progress{background:#2563eb}.seg-pending{background:#f59e0b}.seg-cancelled{background:#dc2626}.uc-stats{display:flex;flex-wrap:wrap;gap:6px}.uc-stat{display:inline-flex;align-items:center;gap:4px;background:#f9fafb;border:1px solid #f3f4f6;padding:3px 10px;border-radius:8px;font-size:12px;transition:background .1s}.uc-stat:hover{background:#f3f4f6}.uc-stat-num{font-weight:700;color:#111827}.uc-stat-total{background:#111827;border-color:#111827}.uc-stat-total .uc-stat-num{color:#fff}.uc-stat-total .uc-stat-lbl{color:#ffffffb3}.uc-stat-lbl{color:#9ca3af;font-weight:500}.uc-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.uc-dot-completed{background:#059669}.uc-dot-progress{background:#2563eb}.uc-dot-pending{background:#f59e0b}.uc-dot-cancelled{background:#dc2626}.uc-filter-tag{text-align:center;font-size:11px;font-weight:600;color:#2563eb;background:#eff6ff;padding:4px 10px;border-radius:6px;margin-top:-4px}.bar-legend{display:flex;align-items:center;gap:16px;margin-top:12px;font-size:12px;color:#6b7280;flex-wrap:wrap}.bar-legend span{display:inline-flex;align-items:center;gap:5px}.charts-row{display:flex;gap:14px;margin-bottom:20px}.charts-row .chart-card{flex:1;min-width:0}.charts-row:not(.charts-row-split) .chart-card{flex:1}.charts-row-split .chart-card:first-child{flex:3}.charts-row-split .chart-card:last-child{flex:2}.chart-body{padding:16px 20px 20px;overflow-x:auto}.pie-body{display:flex;align-items:center;justify-content:center}.line-chart-svg{width:100%;height:auto;max-height:240px;display:block}.chart-axis-label{font-size:10px;fill:#9ca3af;font-family:inherit}.pie-chart-wrap{display:flex;align-items:center;gap:20px;flex-wrap:wrap;justify-content:center}.pie-chart-svg{width:180px;height:180px;flex-shrink:0}.pie-slice{transition:opacity .15s,transform .15s;transform-origin:110px 110px}.pie-slice:hover{opacity:.85;transform:scale(1.03)}.pie-slice.pie-active{opacity:1;transform:scale(1.06);filter:drop-shadow(0 2px 6px rgba(0,0,0,.15))}.pie-center-total{font-size:22px;font-weight:700;fill:#111827;font-family:inherit}.pie-center-label{font-size:11px;fill:#9ca3af;font-family:inherit;text-transform:uppercase;letter-spacing:.05em}.pie-legend{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto}.pie-legend-item{display:flex;align-items:center;gap:8px;padding:4px 10px;border-radius:6px;cursor:pointer;transition:background .12s;font-size:13px}.pie-legend-item:hover{background:#f3f4f6}.pie-legend-item.pie-legend-active{background:#eff6ff}.pie-legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.pie-legend-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#374151;font-weight:500}.pie-legend-val{font-weight:700;color:#111827;font-size:13px}.pie-legend-pct{color:#9ca3af;font-size:12px;min-width:32px;text-align:right}.table-container{overflow-x:auto}.reports-table{width:100%;border-collapse:collapse;font-size:13px}.reports-table thead th{text-align:left;padding:10px 16px;font-weight:600;color:#6b7280;font-size:11px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid #e5e7eb;background:#fafafa;white-space:nowrap;position:sticky;top:0}.reports-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.reports-table th.sortable:hover{color:#111827}.reports-table th span{display:inline-flex;align-items:center;gap:4px}.reports-table tbody tr{transition:background .1s}.reports-table tbody tr:hover{background:#f9fafb}.reports-table td{padding:11px 16px;border-bottom:1px solid #f3f4f6;color:#374151;vertical-align:middle}.cell-date{white-space:nowrap;font-size:12px;color:#6b7280}.cell-filename{max-width:220px}.filename-text{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500;color:#111827}.cell-brand{font-size:12px;color:#6b7280;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-progress{min-width:100px}.progress-wrapper{display:flex;align-items:center;gap:8px}.progress-bar{flex:1;height:6px;background:#f3f4f6;border-radius:3px;overflow:hidden;min-width:40px}.progress-fill{height:100%;border-radius:3px;background:#2563eb;transition:width .3s ease}.progress-text{font-size:12px;font-weight:600;color:#6b7280;white-space:nowrap}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:9999px;font-size:12px;font-weight:600;white-space:nowrap}.status-signed{background:#ecfdf5;color:#059669}.status-progress{background:#eff6ff;color:#2563eb}.status-pending{background:#fff7ed;color:#ea580c}.status-cancelled{background:#fef2f2;color:#dc2626}.signers-list{display:flex;flex-wrap:wrap;gap:4px}.signer-chip{display:inline-block;padding:2px 8px;background:#f3f4f6;border-radius:9999px;font-size:11px;color:#6b7280;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.signer-chip.signed{background:#ecfdf5;color:#059669}.signer-more{font-size:11px;color:#9ca3af;padding:2px 6px}.sort-icon{flex-shrink:0}.sort-icon.inactive{opacity:.3}.sort-icon.active{opacity:1;color:#2563eb}.export-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border:1px solid #d1d5db;border-radius:8px;background:#fff;font-size:12px;font-weight:600;color:#374151;cursor:pointer;transition:all .15s;white-space:nowrap}.export-btn:hover{background:#f9fafb;border-color:#9ca3af}.empty-state{text-align:center;padding:48px 20px!important;color:#9ca3af}.empty-state span{display:block;margin-top:8px;font-size:13px}.reports-empty-prompt{display:flex;flex-direction:column;align-items:center;gap:12px;padding:80px 24px;text-align:center;color:#9ca3af}.reports-empty-prompt svg{color:#d1d5db}.reports-empty-prompt h3{margin:0;font-size:17px;font-weight:650;color:#374151}.reports-empty-prompt p{margin:0;font-size:14px;line-height:1.6;max-width:400px;color:#9ca3af}.spinner{animation:reportsSpin .8s linear infinite}@keyframes reportsSpin{to{transform:rotate(360deg)}}@media (max-width: 768px){.reports-page{padding:20px 16px 80px}.filters-form{flex-direction:column;align-items:stretch;gap:12px}.filter-date{width:100%;min-width:unset}.run-btn{width:100%;justify-content:center}.summary-grid{grid-template-columns:repeat(2,1fr)}.user-cards-grid{grid-template-columns:1fr}.charts-row{flex-direction:column}.charts-row-split .chart-card:first-child,.charts-row-split .chart-card:last-child{flex:1}.pie-chart-wrap{flex-direction:column}.reports-table td,.reports-table th{padding:8px 10px}.cell-filename{max-width:140px}}@media (max-width: 480px){.summary-grid{grid-template-columns:1fr}}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}html,body,#root{height:100%}*{box-sizing:border-box}.chip{display:inline-block;padding:2px 8px;border-radius:12px;background:#eef2ff;font-size:12px}.chip--pending{background:#fff7ed}.chip--in_progress{background:#ecfeff}.chip--signed{background:#ecfdf5}:root{--font-sans: "Poppins", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji", sans-serif;font-family:var(--font-sans);line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body,#root{font-family:var(--font-sans)}button,input,select,textarea{font:inherit}h1{font-size:3.2em;line-height:1.1;font-weight:600}h2,h3{font-weight:600}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}}
