@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap";.altcha{background:var(--altcha-color-base, transparent);border:var(--altcha-border-width, 1px) solid var(--altcha-color-border, #a0a0a0);border-radius:var(--altcha-border-radius, 3px);color:var(--altcha-color-text, currentColor);display:flex;flex-direction:column;max-width:var(--altcha-max-width, 260px);position:relative}.altcha:focus-within{border-color:var(--altcha-color-border-focus, currentColor)}.altcha[data-floating]{background:var(--altcha-color-base, white);display:none;filter:drop-shadow(3px 3px 6px rgba(0,0,0,.2));left:-100%;position:fixed;top:-100%;width:var(--altcha-max-width, 260px);z-index:999999}.altcha[data-floating=top] .altcha-anchor-arrow{border-bottom-color:transparent;border-top-color:var(--altcha-color-border, #a0a0a0);bottom:-12px;top:auto}.altcha[data-floating=bottom]:focus-within:after{border-bottom-color:var(--altcha-color-border-focus, currentColor)}.altcha[data-floating=top]:focus-within:after{border-top-color:var(--altcha-color-border-focus, currentColor)}.altcha[data-floating]:not([data-state=unverified]){display:block}.altcha-anchor-arrow{border:6px solid transparent;border-bottom-color:var(--altcha-color-border, #a0a0a0);content:"";height:0;left:12px;position:absolute;top:-12px;width:0}.altcha-main{align-items:center;display:flex;gap:.4rem;padding:.7rem;position:relative}.altcha-code-challenge{background:var(--altcha-color-base, white);border:1px solid var(--altcha-color-border-focus, currentColor);border-radius:var(--altcha-border-radius, 3px);filter:drop-shadow(3px 3px 6px rgba(0,0,0,.2));padding:.5rem;position:absolute;top:2.5rem;z-index:9999999}.altcha-code-challenge>form{display:flex;flex-direction:column;gap:.5rem}.altcha-code-challenge-input{border:1px solid currentColor;border-radius:3px;box-sizing:border-box;outline:none;font-size:16px;padding:.35rem;width:220px}.altcha-code-challenge-input:focus{outline:2px solid color-mix(in srgb,var(--altcha-color-active, #1D1DC9) 20%,transparent)}.altcha-code-challenge-input:disabled{opacity:.7}.altcha-code-challenge-image{background-color:#fff;border:1px solid currentColor;border-radius:3px;box-sizing:border-box;-o-object-fit:contain;object-fit:contain;height:50px;width:220px}.altcha-code-challenge-audio,.altcha-code-challenge-reload{background:color-mix(in srgb,var(--altcha-color-text, currentColor) 10%,transparent);border:0;border-radius:3px;color:var(--altcha-color-text, currentColor);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.35rem}.altcha-code-challenge-audio:disabled,.altcha-code-challenge-reload:disabled{opacity:.7;pointer-events:none}.altcha-code-challenge-audio>*,.altcha-code-challenge-reload>*{height:20px;width:20px}.altcha-code-challenge-buttons{display:flex;justify-content:space-between}.altcha-code-challenge-buttons-left{display:flex;gap:.25rem}.altcha-code-challenge-verify{align-items:center;background:var(--altcha-color-active, #1D1DC9);border:0;border-radius:3px;color:#fff;cursor:pointer;display:flex;gap:.5rem;font-size:100%;padding:.35rem 1rem}.altcha-code-challenge-verify:disabled{opacity:.7;pointer-events:none}.altcha-code-challenge-arrow{border:6px solid transparent;border-bottom-color:var(--altcha-color-border, currentColor);content:"";height:0;left:.15rem;position:absolute;top:-12px;width:0}.altcha[data-floating=top] .altcha-code-challenge{top:-150px}.altcha[data-floating=top] .altcha-code-challenge-arrow{border-bottom-color:transparent;border-top-color:var(--altcha-color-border, currentColor);bottom:-12px;top:auto}.altcha-label{cursor:pointer;flex-grow:1}.altcha-logo{color:currentColor!important;opacity:.7}.altcha-logo:hover{opacity:1}.altcha-error{color:var(--altcha-color-error-text, #f23939);display:flex;font-size:.85rem;gap:.3rem;padding:0 .7rem .7rem}.altcha-footer{align-items:center;background-color:var(--altcha-color-footer-bg, transparent);display:flex;font-size:.75rem;opacity:.7;justify-content:end;padding:.2rem .7rem}.altcha-footer:hover{opacity:1}.altcha-footer a{color:currentColor}.altcha-checkbox{display:flex;align-items:center;justify-content:center;height:24px;position:relative;width:24px}.altcha-checkbox .altcha-spinner{inset:0;position:absolute}.altcha-checkbox input{width:18px;height:18px;margin:0}.altcha-checkbox-verifying input{-webkit-appearance:none;-moz-appearance:none;appearance:none;opacity:0;pointer-events:none}.altcha-spinner{animation:altcha-spinner .75s infinite linear;transform-origin:center}.altcha-overlay{--altcha-color-base: #fff;--altcha-color-text: #000;animation:overlay-slidein .5s forwards;display:flex;flex-direction:column;gap:.5rem;left:50%;width:260px;opacity:0;position:fixed;top:45%;transform:translate(-50%,-50%)}.altcha-overlay-backdrop{background:#00000080;display:none;inset:0;position:fixed;z-index:99999999}.altcha-overlay-close-button{align-self:flex-end;background:none;border:none;padding:.25rem;cursor:pointer;color:currentColor;font-size:130%;line-height:1;opacity:.7}@media(max-height:450px){.altcha-overlay{top:10%!important;transform:translate(-50%)}}@keyframes overlay-slidein{to{opacity:1;top:50%}}@keyframes altcha-spinner{to{transform:rotate(360deg)}}.ecme-bg-primary{background-color:var(--surface-bg)}.ecme-bg-card{background-color:var(--surface-card)}.ecme-bg-hover{background-color:var(--surface-hover)}.ecme-bg-active{background-color:var(--surface-active)}.ecme-text-primary{color:var(--text-primary)}.ecme-text-secondary{color:var(--text-secondary)}.ecme-text-muted{color:var(--text-muted)}.ecme-border{border-color:var(--border-color)}.ecme-border-focus{border-color:var(--border-focus)}.ecme-card{background-color:var(--surface-card);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--card-shadow);transition:box-shadow var(--transition-normal)}.ecme-card:hover{box-shadow:var(--card-shadow-hover)}.ecme-table-header{background-color:var(--surface-bg);border-bottom:1px solid var(--border-color)}.ecme-table-row{border-bottom:1px solid var(--border-color);transition:background-color var(--transition-fast)}.ecme-table-row:hover{background-color:var(--surface-hover)}.ecme-btn-primary{background-color:var(--primary-500);color:var(--text-inverse);border-radius:6px;padding:8px 16px;transition:background-color var(--transition-fast)}.ecme-btn-primary:hover{background-color:var(--primary-600)}.ecme-input{background-color:var(--surface-card);border:1px solid var(--border-color);border-radius:6px;padding:8px 12px;color:var(--text-primary);transition:border-color var(--transition-fast)}.ecme-input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #3b82f61a}.ecme-input::-moz-placeholder{color:var(--text-muted)}.ecme-input::placeholder{color:var(--text-muted)}.ecme-sidebar-active{background-color:var(--surface-active);color:var(--primary-600);border-left:3px solid var(--primary-500)}.ecme-sidebar-active:hover{background-color:var(--surface-active);color:var(--primary-600)}.ecme-badge-active{background-color:var(--success-bg);color:var(--success-dark);border-radius:var(--radius-md);padding:2px 8px;font-size:12px;font-weight:600}.ecme-badge-blocked{background-color:var(--error-bg);color:var(--error-dark);border-radius:9999px;padding:2px 8px;font-size:12px;font-weight:600}.ecme-glass{background:#fffc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(229,231,235,.5)}.ecme-focus-ring{outline:2px solid var(--primary-500);outline-offset:2px}.ecme-hover-lift{transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.ecme-hover-lift:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.ecme-scrollbar::-webkit-scrollbar{width:8px;height:8px}.ecme-scrollbar::-webkit-scrollbar-track{background:var(--surface-hover);border-radius:9999px}.ecme-scrollbar::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:9999px;-webkit-transition:background var(--transition-fast);transition:background var(--transition-fast)}.ecme-scrollbar::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}.ecme-selection::-moz-selection{background-color:var(--primary-500);color:var(--text-inverse)}.ecme-selection::selection{background-color:var(--primary-500);color:var(--text-inverse)}.ecme-link{color:var(--primary-500);text-decoration:none;transition:color var(--transition-fast)}.ecme-link:hover{color:var(--primary-600);text-decoration:underline}.ecme-divider{border:none;border-top:1px solid var(--border-color);height:1px;margin:var(--space-4) 0}.ecme-spinner{width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--primary-500);border-radius:50%;animation:ecme-spin .8s linear infinite}.ecme-pulse{animation:ecme-pulse-animation 2s ease-in-out infinite}@keyframes ecme-pulse-animation{0%,to{opacity:1}50%{opacity:.5}}.ecme-glow{box-shadow:var(--shadow-glow)}.ecme-glow-success{box-shadow:var(--shadow-glow-success)}.ecme-glow-error{box-shadow:var(--shadow-glow-error)}.ecme-status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:8px}.ecme-status-active{background-color:var(--success-light)}.ecme-status-inactive{background-color:var(--gray-400)}.ecme-status-error{background-color:var(--error-light)}.ecme-status-warning{background-color:var(--warning-light)}.ecme-tag{display:inline-flex;align-items:center;padding:4px 12px;border-radius:9999px;font-size:13px;font-weight:500;background-color:var(--gray-100);color:var(--gray-700);border:1px solid var(--border-color);transition:all var(--transition-fast)}.ecme-tag:hover{background-color:var(--gray-200)}.ecme-progress-bar{width:100%;height:8px;background-color:var(--gray-100);border-radius:9999px;overflow:hidden}.ecme-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-500),var(--primary-600));border-radius:9999px;transition:width var(--transition-normal)}.ecme-tooltip{position:relative;display:inline-block}.ecme-tooltip:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:6px 12px;background-color:var(--gray-900);color:var(--text-inverse);font-size:12px;border-radius:var(--radius-md);white-space:nowrap;opacity:0;visibility:hidden;transition:opacity var(--transition-fast),visibility var(--transition-fast);pointer-events:none;z-index:var(--z-tooltip)}.ecme-tooltip:hover:after{opacity:1;visibility:visible}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:var(--gray-200)}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:var(--font-family);font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--font-mono);font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:var(--gray-400)}input::placeholder,textarea::placeholder{opacity:1;color:var(--gray-400)}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.invisible{visibility:hidden}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.inset-x-0{left:0;right:0}.left-1\/2{left:50%}.left-2{left:.5rem}.right-2{right:.5rem}.right-3{right:.75rem}.right-5{right:1.25rem}.top-0{top:0}.top-1\/2{top:50%}.top-5{top:1.25rem}.isolate{isolation:isolate}.z-50{z-index:50}.m-0{margin:0}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.my-1{margin-top:.25rem;margin-bottom:.25rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mr-2{margin-right:.5rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-6{margin-top:1.5rem}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.\!table{display:table!important}.table{display:table}.table-column{display:table-column}.\!grid{display:grid!important}.grid{display:grid}.contents{display:contents}.hidden{display:none}.aspect-square{aspect-ratio:1 / 1}.h-10{height:2.5rem}.h-12{height:3rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-px{height:1px}.max-h-96{max-height:24rem}.max-h-\[calc\(100vh-16vh\)\]{max-height:84vh}.w-10{width:2.5rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-72{width:18rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-\[420px\]{width:420px}.w-\[560px\]{width:560px}.w-\[720px\]{width:720px}.w-\[900px\]{width:900px}.w-\[var\(--radix-popover-trigger-width\)\]{width:var(--radix-popover-trigger-width)}.w-auto{width:auto}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.max-w-\[90vw\]{max-width:90vw}.max-w-\[calc\(100\%-2rem\)\]{max-width:calc(100% - 2rem)}.flex-1{flex:1 1 0%}.flex-shrink-0,.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.-translate-x-1\/2{--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-180{--tw-rotate: 180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-default{cursor:default}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-none{border-style:none}.border-\[color\:var\(--border-color\)\],.border-\[var\(--border-color\)\],.border-border{border-color:var(--border-color)}.border-gray-200{border-color:var(--gray-200)}.border-gray-400{border-color:var(--gray-400)}.border-gray-700{border-color:var(--gray-700)}.border-red-500\/50{border-color:#ef444480}.bg-\[var\(--surface-card\)\]{background-color:var(--surface-card)}.bg-\[var\(--surface-elevated\)\]{background-color:var(--surface-elevated)}.bg-emerald-600{--tw-bg-opacity: 1;background-color:rgb(5 150 105 / var(--tw-bg-opacity, 1))}.bg-gray-100{background-color:var(--gray-100)}.bg-gray-700{background-color:var(--gray-700)}.bg-popover{background-color:var(--surface-card)}.bg-primary{background-color:var(--primary-500)}.bg-surface-bg{background-color:var(--surface-bg)}.bg-surface-card{background-color:var(--surface-card)}.bg-surface-hover{background-color:var(--surface-hover)}.bg-surface-overlay{background-color:var(--surface-overlay)}.bg-transparent{background-color:transparent}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.from-success{--tw-gradient-from: var(--success-light) var(--tw-gradient-from-position);--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-warning{--tw-gradient-from: var(--warning-light) var(--tw-gradient-from-position);--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.to-success-dark{--tw-gradient-to: var(--success-dark) var(--tw-gradient-to-position)}.to-warning-dark{--tw-gradient-to: var(--warning-dark) var(--tw-gradient-to-position)}.stroke-\[3\]{stroke-width:3}.p-0{padding:0}.p-0\.5{padding:.125rem}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pl-2{padding-left:.5rem}.pl-8{padding-left:2rem}.pr-1{padding-right:.25rem}.pr-10{padding-right:2.5rem}.pr-2{padding-right:.5rem}.pr-8{padding-right:2rem}.text-left{text-align:left}.text-center{text-align:center}.text-\[0\.8rem\]{font-size:.8rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.ordinal{--tw-ordinal: ordinal;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-none{line-height:1}.text-\[var\(--primary-400\)\]{color:var(--primary-400)}.text-\[var\(--text-muted\)\]{color:var(--text-muted)}.text-\[var\(--text-primary\)\]{color:var(--text-primary)}.text-current{color:currentColor}.text-gray-400{color:var(--gray-400)}.text-gray-500{color:var(--gray-500)}.text-gray-600{color:var(--gray-600)}.text-muted{color:var(--surface-elevated)}.text-popover-foreground{color:var(--text-primary)}.text-primary{color:var(--primary-500)}.text-primary-400{color:var(--primary-400)}.text-primary-foreground{color:var(--text-inverse)}.text-red-400{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.text-success-foreground{color:var(--text-inverse)}.text-text-muted{color:var(--text-muted)}.text-text-primary{color:var(--text-primary)}.text-text-secondary{color:var(--text-secondary)}.text-warning-foreground{color:var(--text-inverse)}.underline-offset-4{text-underline-offset:4px}.placeholder-text-muted::-moz-placeholder{color:var(--text-muted)}.placeholder-text-muted::placeholder{color:var(--text-muted)}.opacity-0{opacity:0}.opacity-50{opacity:.5}.shadow-2xl{--tw-shadow: var(--shadow-2xl);--tw-shadow-colored: var(--shadow-2xl);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_0_0_1px_rgba\(148\,163\,184\,0\.35\)\,0_0_10px_rgba\(148\,163\,184\,0\.25\)\]{--tw-shadow: 0 0 0 1px rgba(148,163,184,.35),0 0 10px rgba(148,163,184,.25);--tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color), 0 0 10px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_0_0_1px_rgba\(59\,130\,246\,0\.35\)\,0_0_12px_rgba\(59\,130\,246\,0\.25\)\]{--tw-shadow: 0 0 0 1px rgba(59,130,246,.35),0 0 12px rgba(59,130,246,.25);--tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color), 0 0 12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-glow-success{--tw-shadow: var(--shadow-glow-success);--tw-shadow-colored: var(--shadow-glow-success);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: var(--shadow-sm);--tw-shadow-colored: var(--shadow-sm);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow: var(--shadow-xl);--tw-shadow-colored: var(--shadow-xl);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.ring-offset-background{--tw-ring-offset-color: var(--surface-bg)}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.invert{--tw-invert: invert(100%);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-150{transition-duration:.15s}.duration-200{transition-duration:.2s}@keyframes enter{0%{opacity:var(--tw-enter-opacity, 1);transform:translate3d(var(--tw-enter-translate-x, 0),var(--tw-enter-translate-y, 0),0) scale3d(var(--tw-enter-scale, 1),var(--tw-enter-scale, 1),var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity, 1);transform:translate3d(var(--tw-exit-translate-x, 0),var(--tw-exit-translate-y, 0),0) scale3d(var(--tw-exit-scale, 1),var(--tw-exit-scale, 1),var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0))}}.duration-150{animation-duration:.15s}.duration-200{animation-duration:.2s}.running{animation-play-state:running}:root{--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-400: #60a5fa;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--primary-800: #1e40af;--primary-900: #1e3a8a;--accent-50: #f0fdfa;--accent-100: #ccfbf1;--accent-200: #99f6e4;--accent-300: #5eead4;--accent-400: #2dd4bf;--accent-500: #14b8a6;--accent-600: #0d9488;--accent-700: #0f766e;--accent-800: #115e59;--accent-900: #134e4a;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--gray-950: #030712;--surface-bg: #f8f9fb;--surface-card: #ffffff;--surface-elevated: #f3f4f6;--surface-hover: #f3f4f6;--surface-active: #eff6ff;--surface-overlay: rgba(0, 0, 0, .5);--border-color: #e5e7eb;--border-hover: #d1d5db;--border-focus: #3b82f6;--select-row-separator: rgba(148, 163, 184, .3);--text-primary: #0f172a;--text-secondary: #64748b;--text-muted: #94a3b8;--text-disabled: #cbd5e1;--text-inverse: #ffffff;--success-light: #22c55e;--success-dark: #15803d;--success-bg: #d1fae5;--success-border: #86efac;--warning-light: #f59e0b;--warning-dark: #b45309;--warning-bg: #fef3c7;--warning-border: #fcd34d;--error-light: #ef4444;--error-dark: #b91c1c;--error-bg: #fee2e2;--error-border: #fca5a5;--info-light: #3b82f6;--info-dark: #1d4ed8;--info-bg: #dbeafe;--info-border: #93c5fd;--font-family: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--font-light: 300;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--font-extrabold: 800;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.625;--leading-loose: 2;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-none: 0;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-3xl: 2rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px -1px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .05);--shadow-glow: 0 0 20px rgba(59, 130, 246, .2);--shadow-glow-accent: 0 0 20px rgba(20, 184, 166, .2);--shadow-glow-success: 0 0 20px rgba(34, 197, 94, .2);--shadow-glow-error: 0 0 20px rgba(239, 68, 68, .2);--card-shadow: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--card-shadow-hover: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--transition-instant: 50ms ease;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-tooltip: 600;--z-toast: 700;--z-max: 9999;--sidebar-width: 280px;--sidebar-collapsed: 72px;--header-height: 64px;--content-max-width: 1400px;--container-max-width: 1200px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--text-base);font-weight:var(--font-normal);line-height:var(--leading-relaxed);color:var(--text-primary);background-color:var(--surface-bg);min-height:100vh;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:var(--font-semibold);line-height:var(--leading-tight);color:var(--text-primary)}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}p{color:var(--gray-700);line-height:var(--leading-relaxed)}a{color:var(--primary-400);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-300)}:focus-visible{outline:2px solid var(--primary-400);outline-offset:2px}::-moz-selection{background-color:var(--primary-500);color:var(--text-inverse)}::selection{background-color:var(--primary-500);color:var(--text-inverse)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-100);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:var(--radius-full);-webkit-transition:background var(--transition-fast);transition:background var(--transition-fast)}::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}button:not([class*=btn]){font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;background:transparent;border:none}input:focus,textarea:focus,select:focus{outline:none}table{border-collapse:collapse;width:100%}ul,ol{list-style:none}img{max-width:100%;height:auto;display:block}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes glow{0%,to{box-shadow:0 0 20px #3b82f633}50%{box-shadow:0 0 40px #3b82f64d}}.animate-fade-in{animation:fadeIn var(--transition-normal) forwards}.animate-fade-in-up{animation:fadeInUp var(--transition-normal) forwards}.animate-fade-in-down{animation:fadeInDown var(--transition-normal) forwards}.animate-slide-in-left{animation:slideInLeft var(--transition-normal) forwards}.animate-slide-in-right{animation:slideInRight var(--transition-normal) forwards}.animate-scale-in{animation:scaleIn var(--transition-fast) forwards}.animate-spin{animation:spin 1s linear infinite}.animate-pulse{animation:pulse 2s ease-in-out infinite}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.stagger-6{animation-delay:.3s}.glass{background:#fffc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(229,231,235,.5)}.gradient-text{background:linear-gradient(135deg,var(--primary-400),var(--accent-400));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.loading-spinner-sm{width:20px;height:20px;border-width:2px}.loading-spinner-lg{width:60px;height:60px;border-width:4px}.loading-container p{color:var(--gray-500);font-size:var(--text-sm)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.focus-ring{outline:2px solid var(--primary-500);outline-offset:2px}.hover-lift{transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.hover-lift:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.glow{box-shadow:var(--shadow-glow)}.glow-success{box-shadow:var(--shadow-glow-success)}.glow-error{box-shadow:var(--shadow-glow-error)}@media(max-width:1280px){:root{--content-max-width: 1200px}}@media(max-width:1024px){:root{--sidebar-width: 240px;--content-max-width: 100%}}@media(max-width:768px){:root{--sidebar-width: 100%;--sidebar-collapsed: 0px;--header-height: 56px}html{font-size:15px}}@media(max-width:480px){html{font-size:14px}}.placeholder\:text-\[var\(--text-muted\)\]::-moz-placeholder{color:var(--text-muted)}.placeholder\:text-\[var\(--text-muted\)\]::placeholder{color:var(--text-muted)}.hover\:-translate-y-0\.5:hover{--tw-translate-y: -.125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-gray-300:hover{border-color:var(--gray-300)}.hover\:bg-\[var\(--surface-elevated\)\]:hover{background-color:var(--surface-elevated)}.hover\:bg-\[var\(--surface-hover\)\]:hover{background-color:var(--surface-hover)}.hover\:bg-emerald-700:hover{--tw-bg-opacity: 1;background-color:rgb(4 120 87 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-100:hover{background-color:var(--gray-100)}.hover\:bg-gray-200:hover{background-color:var(--gray-200)}.hover\:bg-gray-700:hover{background-color:var(--gray-700)}.hover\:bg-primary-400:hover{background-color:var(--primary-400)}.hover\:bg-red-500\/10:hover{background-color:#ef44441a}.hover\:bg-surface-hover:hover{background-color:var(--surface-hover)}.hover\:text-\[var\(--text-primary\)\]:hover{color:var(--text-primary)}.hover\:text-primary-foreground:hover{color:var(--text-inverse)}.hover\:text-red-300:hover{--tw-text-opacity: 1;color:rgb(252 165 165 / var(--tw-text-opacity, 1))}.hover\:text-text-primary:hover{color:var(--text-primary)}.hover\:underline:hover{text-decoration-line:underline}.hover\:shadow-\[0_0_0_1px_rgba\(148\,163\,184\,0\.45\)\,0_0_12px_rgba\(148\,163\,184\,0\.3\)\]:hover{--tw-shadow: 0 0 0 1px rgba(148,163,184,.45),0 0 12px rgba(148,163,184,.3);--tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color), 0 0 12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-\[0_0_0_1px_rgba\(59\,130\,246\,0\.5\)\,0_0_16px_rgba\(59\,130\,246\,0\.35\)\]:hover{--tw-shadow: 0 0 0 1px rgba(59,130,246,.5),0 0 16px rgba(59,130,246,.35);--tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color), 0 0 16px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-lg:hover{--tw-shadow: var(--shadow-lg);--tw-shadow-colored: var(--shadow-lg);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.focus\:border-\[color\:var\(--border-focus\)\]:focus{border-color:var(--border-focus)}.focus\:bg-primary:focus{background-color:var(--primary-500)}.focus\:bg-surface-hover:focus{background-color:var(--surface-hover)}.focus\:text-popover-foreground:focus{color:var(--text-primary)}.focus\:text-primary-foreground:focus{color:var(--text-inverse)}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-\[3px\]:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-\[rgba\(59\,130\,246\,0\.2\)\]:focus{--tw-ring-color: rgba(59,130,246,.2)}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-primary-400:focus-visible{--tw-ring-color: var(--primary-400)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color: var(--primary-500)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width: 2px}.focus-visible\:ring-offset-surface-card:focus-visible{--tw-ring-offset-color: var(--surface-card)}.active\:shadow-\[0_0_0_1px_rgba\(148\,163\,184\,0\.4\)\,0_0_8px_rgba\(148\,163\,184\,0\.2\)\]:active{--tw-shadow: 0 0 0 1px rgba(148,163,184,.4),0 0 8px rgba(148,163,184,.2);--tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color), 0 0 8px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.active\:shadow-\[0_0_0_1px_rgba\(59\,130\,246\,0\.45\)\,0_0_10px_rgba\(59\,130\,246\,0\.25\)\]:active{--tw-shadow: 0 0 0 1px rgba(59,130,246,.45),0 0 10px rgba(59,130,246,.25);--tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color), 0 0 10px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.has-\[\:focus\]\:border-primary:has(:focus){border-color:var(--primary-500)}.has-\[\:focus\]\:ring-2:has(:focus){--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=checked\]\:border-primary-400[data-state=checked]{border-color:var(--primary-400)}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:var(--primary-500)}.data-\[state\=checked\]\:text-primary-foreground[data-state=checked]{color:var(--text-inverse)}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=checked\]\:shadow-glow[data-state=checked]{--tw-shadow: var(--shadow-glow);--tw-shadow-colored: var(--shadow-glow);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.data-\[state\=open\]\:animate-in[data-state=open]{animation-name:enter;animation-duration:.15s;--tw-enter-opacity: initial;--tw-enter-scale: initial;--tw-enter-rotate: initial;--tw-enter-translate-x: initial;--tw-enter-translate-y: initial}.data-\[state\=closed\]\:animate-out[data-state=closed]{animation-name:exit;animation-duration:.15s;--tw-exit-opacity: initial;--tw-exit-scale: initial;--tw-exit-rotate: initial;--tw-exit-translate-x: initial;--tw-exit-translate-y: initial}.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity: 0}.data-\[state\=open\]\:fade-in-0[data-state=open]{--tw-enter-opacity: 0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale: .95}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale: .95}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y: -.5rem}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x: .5rem}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x: -.5rem}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y: .5rem}.data-\[state\=closed\]\:slide-out-to-left-1\/2[data-state=closed]{--tw-exit-translate-x: -50%}.data-\[state\=closed\]\:slide-out-to-top-\[2\%\][data-state=closed]{--tw-exit-translate-y: -2%}.data-\[state\=open\]\:slide-in-from-left-1\/2[data-state=open]{--tw-enter-translate-x: -50%}.data-\[state\=open\]\:slide-in-from-top-\[2\%\][data-state=open]{--tw-enter-translate-y: -2%}@media(min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:flex-row{flex-direction:row}}.\[\&\>span\]\:line-clamp-1>span{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:1rem;height:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.toast-container{position:fixed;bottom:var(--space-6);left:50%;transform:translate(-50%);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-3);max-width:480px;width:calc(100% - var(--space-8));pointer-events:none}.toast{position:relative;display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);overflow:hidden;pointer-events:auto;animation:toastSlideUp .3s ease-out forwards}@keyframes toastSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.toast-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:32px;height:32px;border-radius:var(--radius-lg)}.toast-message{flex:1;font-size:var(--text-sm);color:var(--text-primary);margin:0;padding-top:6px;line-height:1.4}.toast-action{flex-shrink:0;padding:6px 12px;font-size:var(--text-xs);font-weight:600;color:var(--primary);background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.toast-action:hover{background:var(--surface-hover)}.toast-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast)}.toast-close:hover{background:var(--surface-hover);color:var(--text-primary)}.toast-progress{position:absolute;bottom:0;left:0;height:3px;border-radius:0 0 var(--radius-xl) var(--radius-xl);animation:toastProgress linear forwards}@keyframes toastProgress{0%{width:100%}to{width:0%}}.toast-success{border-left:3px solid var(--success-light)}.toast-success .toast-icon{background:var(--success-bg);color:var(--success-dark)}.toast-success .toast-progress{background:var(--success-light)}.toast-error{border-left:3px solid var(--error-light)}.toast-error .toast-icon{background:var(--error-bg);color:var(--error-dark)}.toast-error .toast-progress{background:var(--error-light)}.toast-warning{border-left:3px solid var(--warning-light)}.toast-warning .toast-icon{background:var(--warning-bg);color:var(--warning-dark)}.toast-warning .toast-progress{background:var(--warning-light)}.toast-info{border-left:3px solid var(--info-light)}.toast-info .toast-icon{background:var(--info-bg);color:var(--info-dark)}.toast-info .toast-progress{background:var(--info-light)}@media(max-width:640px){.toast-container{left:var(--space-4);right:var(--space-4);transform:none;max-width:100%;width:auto}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:var(--surface-bg)}.login-bg{position:absolute;inset:0;overflow:hidden;z-index:0}.gradient-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;animation:float 20s ease-in-out infinite}.orb-1{width:600px;height:600px;background:radial-gradient(circle,var(--primary-500),transparent 70%);top:-200px;right:-100px;animation-delay:0s}.orb-2{width:500px;height:500px;background:radial-gradient(circle,var(--accent-500),transparent 70%);bottom:-150px;left:-100px;animation-delay:-7s}.orb-3{width:400px;height:400px;background:radial-gradient(circle,var(--primary-400),transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-14s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.05)}66%{transform:translate(-20px,20px) scale(.95)}}.grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgba(15,23,42,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(15,23,42,.04) 1px,transparent 1px);background-size:60px 60px;-webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 70%);mask-image:radial-gradient(ellipse at center,black 30%,transparent 70%)}.login-wrapper{position:relative;z-index:1;padding:var(--space-4);width:100%;display:flex;align-items:center;justify-content:center}.login-card{width:100%;max-width:420px;background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-2xl);padding:var(--space-10);box-shadow:var(--shadow-lg);animation:scaleIn var(--transition-slow) forwards}.login-header{text-align:center;margin-bottom:var(--space-8)}.login-logo{display:inline-flex;align-items:center;justify-content:center;margin-bottom:var(--space-5)}.logo-icon{display:flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:var(--radius-2xl);background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:var(--text-inverse);box-shadow:var(--shadow-md)}.login-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0 0 var(--space-2) 0}.login-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.login-form{display:flex;flex-direction:column;gap:var(--space-5)}.input-group{display:flex;flex-direction:column;gap:var(--space-2)}.input-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.input-wrapper{position:relative}.input-icon{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;transition:color var(--transition-fast)}.input-field{width:100%;padding:var(--space-4);padding-left:calc(var(--space-4) + 28px);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-sm);transition:all var(--transition-fast)}.input-field::-moz-placeholder{color:var(--text-muted)}.input-field::placeholder{color:var(--text-muted)}.input-field:hover{border-color:var(--border-hover)}.input-field:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #3b82f633;background:var(--surface-card)}.input-field:focus+.input-icon,.input-wrapper:focus-within .input-icon{color:var(--primary-500)}.input-field:disabled{opacity:.5;cursor:not-allowed}.error-alert{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--error-bg);border:1px solid var(--error-border);border-radius:var(--radius-lg);color:var(--error-dark);font-size:var(--text-sm);animation:fadeInDown var(--transition-fast) forwards}.login-button{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4);background:var(--surface-card);border:1px solid var(--primary-400);border-radius:var(--radius-lg);color:var(--primary-600);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--transition-fast);box-shadow:0 0 0 1px #3b82f659,0 0 12px #3b82f640}.login-button:hover:not(:disabled){border-color:var(--primary-500);box-shadow:0 0 0 1px #3b82f680,0 0 16px #3b82f659;transform:translateY(-1px)}.login-button:active:not(:disabled){transform:translateY(0);box-shadow:0 0 0 1px #3b82f673,0 0 10px #3b82f640}.login-button:focus-visible{outline:none;box-shadow:0 0 0 2px #3b82f680,0 0 14px #3b82f659}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-button .spin{animation:spin 1s linear infinite}.login-footer{margin-top:var(--space-8);text-align:center}.login-footer p{font-size:var(--text-xs);color:var(--text-secondary);margin:0}@media(max-width:480px){.login-card{padding:var(--space-6);border-radius:var(--radius-xl)}.logo-icon{width:60px;height:60px}.logo-icon svg{width:28px;height:28px}.login-title{font-size:var(--text-xl)}.gradient-orb{filter:blur(60px);opacity:.3}.orb-1{width:400px;height:400px}.orb-2{width:300px;height:300px}.orb-3{width:250px;height:250px}}.auth-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--surface-bg)}.auth-loading-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-5);text-align:center}.auth-loading-icon{display:flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:var(--radius-2xl);background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;box-shadow:0 0 40px #3b82f666}.auth-spinner{color:var(--primary-400);animation:spin 1s linear infinite}.auth-loading-content p{color:var(--text-secondary);font-size:var(--text-sm);margin:0}.realtime-settings-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem;color:var(--text-secondary)}.realtime-settings-loading p{font-size:var(--text-sm)}.realtime-settings-list{display:flex;flex-direction:column;gap:1rem}.realtime-setting-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast)}.realtime-setting-item:hover{background:var(--surface-hover);border-color:var(--border-hover)}.realtime-setting-icon{flex-shrink:0;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;background:var(--surface-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--primary-500)}.realtime-setting-info{flex:1;min-width:0}.realtime-setting-label{display:block;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:.25rem;cursor:pointer;transition:color var(--transition-fast)}.realtime-setting-label:hover{color:var(--primary-500)}.realtime-setting-description{font-size:var(--text-xs);color:var(--text-secondary);line-height:1.4;margin:0}.realtime-setting-toggle{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.realtime-setting-saving{color:var(--primary-500);animation:spin 1s linear infinite}.realtime-settings-error{display:flex;align-items:center;justify-content:center;padding:2rem;color:var(--error-light)}.realtime-settings-error p{font-size:var(--text-sm)}.dashboard-layout{display:flex;min-height:100vh;background:var(--surface-bg)}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--surface-card);border-bottom:1px solid var(--gray-200);padding:0 var(--space-4);align-items:center;justify-content:space-between;z-index:var(--z-fixed)}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-lg);color:var(--gray-300);transition:all var(--transition-fast)}.mobile-menu-btn:hover{background:var(--surface-elevated);color:var(--gray-900)}.mobile-logo{display:flex;align-items:center;gap:var(--space-2);font-weight:var(--font-semibold);color:var(--gray-900);font-size:var(--text-sm)}.mobile-logo .logo-icon{color:var(--primary-500);width:20px;height:20px;flex-shrink:0}.mobile-user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:var(--font-bold)}.mobile-overlay{display:none;position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:calc(var(--z-fixed) + 50);animation:fadeIn var(--transition-fast) forwards}.sidebar{position:fixed;left:0;top:0;height:100vh;background:var(--surface-card);border-right:1px solid var(--gray-200);display:flex;flex-direction:column;z-index:var(--z-fixed);transition:width var(--transition-normal);overflow:hidden}.sidebar.expanded{width:var(--sidebar-width)}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--gray-200);height:var(--header-height);min-height:var(--header-height)}.logo-link{display:flex;align-items:center;gap:var(--space-3);text-decoration:none;color:var(--gray-900)}.logo-icon-wrapper{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;flex-shrink:0;transition:all var(--transition-fast)}.logo-icon-wrapper svg{width:24px;height:24px}.logo-text{font-size:var(--text-lg);font-weight:var(--font-bold);white-space:nowrap;background:linear-gradient(135deg,var(--gray-900),var(--gray-700));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-md);color:var(--gray-400);background:var(--surface-elevated);transition:all var(--transition-fast)}.sidebar-toggle:hover{background:var(--gray-200);color:var(--gray-900)}.sidebar-nav{flex:1;padding:var(--space-4) var(--space-3);overflow-y:auto}.nav-list{display:flex;flex-direction:column;gap:var(--space-2)}.nav-item,.nav-category{animation:fadeInUp var(--transition-normal) forwards;opacity:0}.nav-category-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-2) var(--space-4);margin-bottom:var(--space-1);background:none;border:none;cursor:pointer;transition:all var(--transition-fast);border-radius:var(--radius-md)}.nav-category-header:hover{background:var(--surface-elevated)}.nav-category-header.has-active{color:var(--primary-400)}.nav-category-label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;transition:color var(--transition-fast)}.nav-category-header.has-active .nav-category-label{color:var(--primary-400)}.nav-category-chevron{color:var(--gray-500);transition:transform var(--transition-fast),color var(--transition-fast);flex-shrink:0}.nav-category-chevron.expanded{transform:rotate(180deg)}.nav-category-header.has-active .nav-category-chevron{color:var(--primary-400)}.nav-category-list{display:flex;flex-direction:column;gap:var(--space-1);overflow:hidden;transition:max-height var(--transition-normal),opacity var(--transition-normal),margin-bottom var(--transition-normal);max-height:500px;opacity:1;margin-bottom:var(--space-1)}.nav-category-list.collapsed{max-height:0;opacity:0;margin-bottom:0}.nav-category-list.expanded{max-height:500px;opacity:1}.nav-sub-item{padding-left:var(--space-4)}.nav-sub-item .nav-link{padding-left:var(--space-5)}.nav-link{position:relative;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);color:var(--gray-400);text-decoration:none;font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast);overflow:hidden}.nav-link:hover{background:var(--surface-elevated);color:var(--gray-900)}.nav-link.active{background:var(--surface-active);color:var(--primary-600)}.nav-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--primary-500);border-radius:0 var(--radius-full) var(--radius-full) 0}.nav-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:20px;height:20px}.nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-indicator{position:absolute;right:var(--space-3);width:6px;height:6px;border-radius:var(--radius-full);background:var(--primary-500);animation:pulse 2s ease-in-out infinite}.sidebar.collapsed .logo-text{display:none}.sidebar.collapsed .logo-icon-wrapper{width:36px;height:36px}.sidebar.collapsed .logo-icon-wrapper svg{width:20px;height:20px}.sidebar.collapsed .nav-link{justify-content:center;padding:var(--space-3)}.sidebar.collapsed .nav-link:before{display:none}.sidebar.collapsed .nav-link.active{background:var(--surface-active);border:1px solid var(--primary-300)}.sidebar.collapsed .nav-label,.sidebar.collapsed .nav-category-header{display:none}.sidebar.collapsed .nav-sub-item{padding-left:0}.sidebar.collapsed .nav-sub-item .nav-link{padding-left:var(--space-3)}.sidebar.collapsed .user-info,.sidebar.collapsed .sign-out-btn span{display:none}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--gray-200);display:flex;flex-direction:column;gap:var(--space-3)}.user-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-lg);background:var(--surface-elevated)}.user-card.collapsed{justify-content:center;padding:var(--space-2)}.user-avatar{width:40px;height:40px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary-500),var(--accent-500));color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:var(--font-bold);flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.user-role{font-size:var(--text-xs);color:var(--gray-500);margin:0}.sign-out-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius-lg);background:var(--surface-elevated);color:var(--gray-400);font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast)}.sign-out-btn:hover{background:var(--error-bg);color:var(--error-light)}.main-wrapper{flex:1;display:flex;flex-direction:column;min-height:100vh;transition:margin-left var(--transition-normal)}.main-wrapper.sidebar-expanded{margin-left:var(--sidebar-width)}.main-wrapper.sidebar-collapsed{margin-left:var(--sidebar-collapsed)}.top-header{position:sticky;top:0;background:var(--surface-card);border-bottom:1px solid var(--gray-200);padding:0 var(--space-8);height:var(--header-height);display:flex;align-items:center;z-index:var(--z-sticky)}.header-content{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:var(--content-max-width);margin:0 auto}.breadcrumb{display:flex;align-items:center;gap:var(--space-3)}.breadcrumb-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-lg);background:var(--surface-elevated);color:var(--primary-500)}.user-badge{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--surface-elevated);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--gray-700)}.user-badge svg{color:var(--primary-500)}.connection-status-badge{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);transition:all var(--transition-fast)}.connection-status-badge.connected{background:var(--success-bg);color:var(--success-light);border:1px solid var(--success-border)}.connection-status-badge.disconnected,.connection-status-badge.error{background:var(--error-bg);color:var(--error-light);border:1px solid var(--error-border)}.realtime-settings-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-lg);background:var(--surface-elevated);border:1px solid var(--gray-300);color:var(--primary-500);transition:all var(--transition-fast);cursor:pointer}.realtime-settings-btn:hover{background:var(--gray-200);border-color:var(--primary-500);color:var(--primary-600);transform:translateY(-1px)}.realtime-settings-btn:active{transform:translateY(0)}.header-separator{width:1px;height:24px;background:var(--gray-300);margin:0 var(--space-2)}.pending-requests-badge{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--surface-elevated);border:1px solid var(--gray-300);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--gray-700);cursor:pointer;transition:all var(--transition-fast)}.pending-requests-badge:hover{background:var(--gray-200);border-color:var(--warning-500);color:var(--gray-900)}.pending-requests-badge svg{color:var(--warning-400);flex-shrink:0}.pending-count{display:flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--space-1);background:var(--warning-500);color:#fff;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-bold)}.pending-label{font-weight:var(--font-semibold);color:var(--warning-500)}.main-content{flex:1;--main-content-padding: var(--space-8);--main-content-body-height: calc(100vh - var(--header-height) - (var(--main-content-padding) * 2));padding:var(--main-content-padding);background:var(--surface-bg);overflow-y:auto}.content-container{max-width:var(--content-max-width);margin:0 auto;min-height:var(--main-content-body-height);animation:fadeInUp var(--transition-normal) forwards}@media(max-width:1024px){.sidebar.expanded{width:240px}.main-wrapper.sidebar-expanded{margin-left:240px}.main-content{--main-content-padding: var(--space-6);--main-content-body-height: calc(100vh - var(--header-height) - (var(--main-content-padding) * 2));padding:var(--main-content-padding)}.top-header{padding:0 var(--space-6)}}@media(max-width:768px){.mobile-header{display:flex}.mobile-overlay{display:block}.sidebar{position:fixed;left:0;top:0;width:var(--sidebar-width)!important;transform:translate(-100%);z-index:calc(var(--z-fixed) + 100);transition:transform var(--transition-normal)}.sidebar.mobile-open{transform:translate(0)}.sidebar.collapsed{width:var(--sidebar-width)!important}.sidebar.collapsed .logo-text,.sidebar.collapsed .nav-label,.sidebar.collapsed .user-info,.sidebar.collapsed .sign-out-btn span{display:block}.sidebar.collapsed .logo-icon-wrapper{width:40px;height:40px}.sidebar.collapsed .logo-icon-wrapper svg{width:24px;height:24px}.sidebar.collapsed .nav-link{justify-content:flex-start;padding:var(--space-3) var(--space-4)}.sidebar.collapsed .user-card{justify-content:flex-start;padding:var(--space-3)}.sidebar.collapsed .sign-out-btn{justify-content:flex-start}.hide-mobile{display:none!important}.main-wrapper{margin-left:0!important;padding-top:var(--header-height)}.top-header{display:none}.main-content{--main-content-padding: var(--space-4);--main-content-body-height: calc(100vh - var(--header-height) - (var(--main-content-padding) * 2));padding:var(--main-content-padding)}.mobile-logo .logo-icon{width:24px;height:24px}}@media(max-width:480px){.sidebar{width:100%!important}.main-content{--main-content-padding: var(--space-3);--main-content-body-height: calc(100vh - var(--header-height) - (var(--main-content-padding) * 2));padding:var(--main-content-padding)}}.dashboard{max-width:100%;padding:0}.dashboard-welcome{margin-bottom:var(--space-8)}.welcome-title{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0 0 var(--space-2) 0;background:linear-gradient(135deg,var(--primary-500),var(--primary-400));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-subtitle{font-size:var(--text-base);color:var(--text-secondary);margin:0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5);margin-bottom:var(--space-8)}.stat-card{position:relative;background-color:var(--surface-card);border:1px solid var(--border-color);border-radius:8px;padding:var(--space-5);overflow:hidden;animation:fadeInUp var(--transition-normal) forwards;opacity:0;transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast);box-shadow:var(--card-shadow);display:flex;flex-direction:column;justify-content:center;align-items:flex-start;min-height:120px}.stat-card:hover{transform:translateY(-4px);border-color:var(--gray-300);box-shadow:var(--shadow-lg)}.stat-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-4)}.stat-icon{display:flex;align-items:center;justify-content:center}.stat-icon.gradient-blue svg{color:#3b82f6!important;stroke:#3b82f6!important}.stat-icon.gradient-green svg{color:#22c55e!important;stroke:#22c55e!important}.stat-icon.gradient-purple svg{color:#a855f7!important;stroke:#a855f7!important}.stat-icon.gradient-amber svg{color:#f59e0b!important;stroke:#f59e0b!important}.stat-trend{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:var(--font-semibold);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md)}.stat-trend.trend-up{background-color:var(--success-bg);color:var(--success-dark)}.stat-trend.trend-neutral{background-color:var(--warning-bg);color:var(--warning-dark)}.stat-content{position:relative;z-index:1;display:flex;align-items:baseline;gap:var(--space-2)}.stat-value{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0;letter-spacing:-.5px;line-height:1}.stat-label{font-size:var(--text-sm);color:var(--text-secondary);margin:0;line-height:1}.stat-glow{position:absolute;bottom:-30%;right:-30%;width:120px;height:120px;border-radius:50%;filter:blur(40px);opacity:.15;transition:opacity var(--transition-fast)}.stat-card:hover .stat-glow{opacity:.25}.stat-glow.gradient-blue{background:var(--primary-500)}.stat-glow.gradient-green{background:var(--success-light)}.stat-glow.gradient-purple{background:#8b5cf6}.stat-glow.gradient-amber{background:var(--warning-light)}.recent-users-section{margin-bottom:var(--space-8)}.recent-users-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) 0 var(--space-4) 0}.recent-users-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.dashboard .table-scroll{overflow-y:hidden}.dashboard .table{font-size:14px}.dashboard .table tbody tr{animation:fadeInUp .4s ease forwards;opacity:0}.dashboard .table tbody tr:nth-child(1){animation-delay:.1s}.dashboard .table tbody tr:nth-child(2){animation-delay:.2s}.dashboard .table tbody tr:nth-child(3){animation-delay:.3s}.dashboard .table tbody tr:nth-child(4){animation-delay:.4s}.dashboard .table tbody tr:nth-child(5){animation-delay:.5s}.dashboard .table tbody tr:hover{background-color:#f3f4f6}.error-container{display:flex;align-items:center;justify-content:center;min-height:400px}.error-card{text-align:center;padding:var(--space-8);background-color:var(--surface-card);border:1px solid var(--border-color);border-radius:8px;max-width:400px;box-shadow:var(--card-shadow)}.error-icon{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:var(--radius-full);background-color:var(--error-bg);color:var(--error-light);margin-bottom:var(--space-5)}.error-card h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-2) 0}.error-card p{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-5) 0}@media(max-width:1280px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.stats-grid{grid-template-columns:1fr;gap:var(--space-4)}.dashboard-welcome{margin-bottom:var(--space-6)}.welcome-title{font-size:var(--text-2xl)}.stat-card{padding:var(--space-4)}.stat-value{font-size:var(--text-2xl)}.user-avatar-sm{width:32px;height:32px}}@media(max-width:480px){.dashboard-welcome{margin-bottom:var(--space-5)}.stats-grid{gap:var(--space-3)}.welcome-title{font-size:var(--text-xl)}.stat-card{padding:var(--space-3)}.stat-header{margin-bottom:var(--space-3)}.stat-icon-wrapper{width:40px;height:40px}.stat-value{font-size:var(--text-xl)}.dashboard .table-container{border-radius:0;border-left:none;border-right:none}.dashboard .badge{padding:var(--space-1) var(--space-2);font-size:11px}.error-card{padding:var(--space-6);max-width:100%;margin:var(--space-4)}}.user-management{max-width:100%;padding:0}.user-cell{display:flex;align-items:center;gap:var(--space-3)}.user-avatar-sm{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary-500),var(--accent-500));color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:var(--font-bold);flex-shrink:0}.user-info .user-name{font-weight:var(--font-semibold);color:var(--text-primary);font-size:var(--text-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-management .table-scroll{overflow-y:hidden}.user-management .table tbody tr{animation:fadeInUp .35s ease forwards;opacity:0}.user-management .table tbody tr:nth-child(1){animation-delay:.05s}.user-management .table tbody tr:nth-child(2){animation-delay:.1s}.user-management .table tbody tr:nth-child(3){animation-delay:.15s}.user-management .table tbody tr:nth-child(4){animation-delay:.2s}.user-management .table tbody tr:nth-child(5){animation-delay:.25s}.user-management .table tbody tr:nth-child(6){animation-delay:.3s}.user-management .table tbody tr:nth-child(7){animation-delay:.35s}.user-management .table tbody tr:nth-child(8){animation-delay:.4s}.user-management .table tbody tr:nth-child(9){animation-delay:.45s}.user-management .table tbody tr:nth-child(10){animation-delay:.5s}.user-management .code-badge{display:inline-block;padding:var(--space-1) var(--space-2);background-color:var(--gray-50);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--text-xs);font-family:var(--font-mono);color:var(--accent-500);font-weight:var(--font-medium)}.role-badges{display:flex;gap:var(--space-2);align-items:center}.user-management .table-pagination{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-3) var(--space-4);border-top:1px solid var(--border-color);background:var(--surface-card)}.user-management .pagination-info{font-size:var(--text-sm);color:var(--text-secondary)}.user-management .pagination-controls{display:flex;align-items:center;gap:var(--space-3)}.user-management .pagination-page{font-size:var(--text-sm);color:var(--text-primary);font-weight:var(--font-medium)}.user-form{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4) var(--space-5);align-items:start}.user-form .form-group-permissions{grid-column:span 2}.user-profile-view{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5)}.profile-view-section{display:flex;flex-direction:column;gap:var(--space-2);background-color:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4)}.profile-view-section-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--primary-500);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--space-2) 0;padding-bottom:var(--space-2);border-bottom:1px solid var(--border-color)}.profile-view-details{display:flex;flex-direction:column;gap:0}.profile-view-detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0;border-bottom:1px solid var(--border-color)}.profile-view-detail-row:last-child{border-bottom:none;padding-bottom:0}.profile-view-detail-row:first-child{padding-top:0}.profile-view-label{font-size:var(--text-xs);color:var(--text-secondary);font-weight:var(--font-medium)}.profile-view-value{font-size:var(--text-sm);color:var(--text-primary);font-weight:var(--font-medium);text-align:right}@media(max-width:1280px){.user-management .table{min-width:900px}}@media(max-width:1024px){.user-form{grid-template-columns:repeat(2,1fr)}.user-form .form-group-permissions{grid-column:span 2}.user-profile-view{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.user-form{grid-template-columns:1fr;gap:var(--space-4)}.user-form .form-group-permissions{grid-column:span 1}.user-profile-view{grid-template-columns:1fr}}@media(max-width:768px){.user-management .table-container{border-radius:0;border-left:none;border-right:none}.user-management .table{min-width:100%}.user-management .table th:nth-child(4),.user-management .table th:nth-child(5),.user-management .table th:nth-child(6),.user-management .table td:nth-child(4),.user-management .table td:nth-child(5),.user-management .table td:nth-child(6){display:none}}@media(max-width:640px){.user-management .table-container{border:none;border-radius:0;overflow:visible}.user-management .table-scroll{overflow-x:visible}.user-management .table{display:block;min-width:100%}.user-management .table thead{display:none}.user-management .table tbody{display:flex;flex-direction:column;gap:var(--space-3)}.user-management .table tr{display:block;background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:0;animation:fadeInUp .3s ease forwards}.user-management .table tr:hover{background:var(--surface-card);border-color:var(--border-hover)}.user-management .table td{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0;border:none;font-size:var(--text-sm)}.user-management .table td:first-child{padding-top:0}.user-management .table td:last-child{padding-bottom:0}.user-management .table td:before{content:attr(data-label);font-weight:var(--font-semibold);color:var(--text-secondary);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.5px}.user-management .table td:first-child{flex-direction:column;align-items:flex-start;gap:var(--space-2);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-color);margin-bottom:var(--space-3)}.user-management .table td:first-child:before{content:"USER";align-self:flex-start}.user-management .table td:nth-child(2):before{content:"CREW CODE"}.user-management .table td:nth-child(3):before{content:"CONTACT"}.user-management .table td:nth-child(4):before{content:"BASE"}.user-management .table td:nth-child(5):before{content:"RANK"}.user-management .table td:nth-child(6):before{content:"CONTRACT"}.user-management .table td:nth-child(7):before{content:"STATUS"}.user-management .table td:nth-child(8):before{content:"ROLE"}.user-management .table td:nth-child(9){padding-top:var(--space-3);border-top:1px solid var(--border-color);margin-top:var(--space-3);justify-content:stretch;flex-direction:column;gap:var(--space-2)}.user-management .table td:nth-child(9):before{content:"ACTIONS";margin-bottom:var(--space-2);align-self:flex-start;font-size:10px}.user-management .table td:nth-child(9) .action-buttons{width:100%;justify-content:space-between;gap:var(--space-2)}.user-management .table td:nth-child(9) .action-btn{flex:1;height:40px;min-width:40px;border-radius:var(--radius-md);padding:0}.user-management .table .user-cell{width:100%;gap:var(--space-2)}.user-management .table .user-info{width:100%;min-width:auto;flex:1}.user-management .table .user-name{font-size:var(--text-base);font-weight:var(--font-semibold);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.user-management .table .user-email{font-size:var(--text-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.user-management .table .role-badges{flex-wrap:wrap;gap:var(--space-2)}.user-management .table-pagination{flex-direction:column;gap:var(--space-4);padding:var(--space-4)}.user-management .pagination-controls{width:100%;justify-content:space-between}.user-management .pagination-controls button{flex:1;padding:var(--space-3) var(--space-4)}.user-management .pagination-page{order:-1;text-align:center;margin-bottom:var(--space-2)}}@media(max-width:375px){.user-management .table tr{padding:var(--space-3)}.user-management .table td:before{font-size:10px}.user-management .table .user-name{font-size:var(--text-sm)}.user-management .table .user-email{font-size:var(--text-xs)}.user-management .table td:nth-child(9) .action-buttons{gap:var(--space-1)}.user-management .table td:nth-child(9) .action-btn{padding:0}}.invitation-management{max-width:100%;padding:0}.filter-toggle.active{background-color:var(--primary-500);color:#fff;border-color:var(--primary-500)}.invitation-management .table-scroll{overflow-y:hidden}.filter-panel{background-color:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-4)}.invitation-management .table tbody tr{animation:fadeInUp .35s ease forwards;opacity:0}.invitation-management .table tbody tr:nth-child(1){animation-delay:.05s}.invitation-management .table tbody tr:nth-child(2){animation-delay:.1s}.invitation-management .table tbody tr:nth-child(3){animation-delay:.15s}.invitation-management .table tbody tr:nth-child(4){animation-delay:.2s}.invitation-management .table tbody tr:nth-child(5){animation-delay:.25s}.invitation-management .table tbody tr:nth-child(6){animation-delay:.3s}.invitation-management .table tbody tr:nth-child(7){animation-delay:.35s}.invitation-management .table tbody tr:nth-child(8){animation-delay:.4s}.invitation-management .table tbody tr:nth-child(9){animation-delay:.45s}.invitation-management .table tbody tr:nth-child(10){animation-delay:.5s}.invitation-management .table-pagination{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-3) var(--space-4);border-top:1px solid var(--border-color);background:var(--surface-card)}.invitation-management .pagination-info{font-size:var(--text-sm);color:var(--text-secondary)}.invitation-management .pagination-controls{display:flex;align-items:center;gap:var(--space-3)}.invitation-management .pagination-page{font-size:var(--text-sm);color:var(--text-primary);font-weight:var(--font-medium)}.bulk-progress-banner{margin-bottom:var(--space-6);background-color:var(--surface-card);border:1px solid var(--primary-500);border-radius:var(--radius-xl);padding:var(--space-4);box-shadow:0 4px 12px #3b82f633}.bulk-progress-banner-content{display:flex;flex-direction:column;gap:var(--space-3)}.bulk-progress-banner-info{display:flex;align-items:center;gap:var(--space-3)}.bulk-progress-banner-info svg{color:var(--primary-500);flex-shrink:0}.bulk-progress-banner-info strong{display:block;font-size:var(--text-base);color:var(--text-primary);margin-bottom:var(--space-1)}.bulk-progress-banner-detail{display:block;font-size:var(--text-sm);color:var(--text-secondary)}.bulk-progress-banner-stats{display:flex;gap:var(--space-3);flex-wrap:wrap}.email-icon{color:var(--text-muted);flex-shrink:0}.invitation-management .table th:last-child,.invitation-management .table td:last-child{text-align:center}.invitation-management .action-buttons{justify-content:center}.invitation-form,.bulk-invite-form{display:flex;flex-direction:column;gap:var(--space-5)}.form-info{display:flex;gap:var(--space-3);padding:var(--space-4);background-color:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);border-left:4px solid var(--primary-500)}.form-info svg{flex-shrink:0;width:20px;height:20px;color:var(--primary-500);margin-top:2px}.form-info-content{flex:1}.form-info-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-2) 0}.form-info-list{margin:0;padding-left:var(--space-5);list-style:none}.form-info-list li{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-2);position:relative}.form-info-list li:before{content:"•";position:absolute;left:calc(-1 * var(--space-5));color:var(--primary-500);font-weight:700}.form-info-list li:last-child{margin-bottom:0}.form-info-list strong{color:var(--text-primary);font-weight:var(--font-semibold)}.form-warning-box{display:flex;gap:var(--space-3);padding:var(--space-4);background-color:var(--warning-bg);border:1px solid rgba(245,158,11,.5);border-radius:var(--radius-lg);border-left:4px solid var(--warning-light)}.form-warning-box.form-warning-active{background-color:#f59e0b1f;border-color:#f59e0b66;animation:pulse-warning 2s ease-in-out infinite}@keyframes pulse-warning{0%,to{border-color:#f59e0b66;box-shadow:0 0 #f59e0b33}50%{border-color:#f59e0b99;box-shadow:0 0 0 4px #f59e0b1a}}.form-warning-box svg{flex-shrink:0;width:20px;height:20px;color:var(--warning-light);margin-top:2px}.form-warning-content{flex:1}.form-warning-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--warning-dark);margin:0 0 var(--space-2) 0}.form-warning-text{font-size:var(--text-sm);color:var(--warning-dark);margin:0;line-height:1.6;opacity:.9}.bulk-progress{margin-top:var(--space-4);padding:var(--space-4);background-color:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.progress-header h4{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.progress-text{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-medium)}.progress-stats{display:flex;gap:var(--space-4);flex-wrap:wrap}.stat{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium)}.stat-success{color:var(--success-dark)}.stat-error{color:var(--error-dark)}.stat-warning{color:var(--warning-dark)}.delete-confirmation-detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) 0;border-bottom:1px solid var(--border-color)}.detail-value{font-size:var(--text-sm);color:var(--text-primary);font-weight:var(--font-semibold)}.resend-confirmation{text-align:center;padding:var(--space-4)}.resend-confirmation-message{font-size:var(--text-base);color:var(--text-primary);margin-bottom:var(--space-4);line-height:1.6}.resend-confirmation-details{background-color:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4);margin-top:var(--space-4)}.resend-confirmation-detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) 0;border-bottom:1px solid var(--border-color)}.resend-confirmation-detail-row:last-child{border-bottom:none;padding-bottom:0}.copy-token-content{padding:var(--space-4)}.copy-token-message{font-size:var(--text-base);color:var(--text-primary);margin-bottom:var(--space-4);line-height:1.6}.token-display{background-color:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4);margin:var(--space-4) 0;word-break:break-all;max-height:200px;overflow-y:auto}.token-text{font-family:Courier New,monospace;font-size:var(--text-sm);color:var(--text-primary);line-height:1.6}.copy-token-warning{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--warning-dark);background-color:var(--warning-bg);border:1px solid rgba(245,158,11,.5);border-radius:var(--radius-lg);padding:var(--space-3);margin-top:var(--space-4)}@media(max-width:1024px){.progress-stats{flex-direction:column;gap:var(--space-2)}}@media(max-width:768px){.filter-grid{grid-template-columns:1fr}}@media(max-width:640px){.progress-stats{flex-direction:column;gap:var(--space-2)}}@media(max-width:480px){.table-container{border-radius:0;border-left:none;border-right:none}.bulk-progress-banner{border-radius:var(--radius-lg)}}.access-requests{max-width:100%;padding:0}.page-header h1{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0 0 var(--space-2) 0;background:linear-gradient(135deg,var(--primary-500),var(--primary-400));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-stats{display:flex;gap:var(--space-4)}.stat-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background-color:var(--surface-card);border:1px solid var(--border-color);border-radius:8px;min-width:120px;box-shadow:var(--card-shadow)}.stat-card svg{color:var(--primary-500)}.stat-value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);line-height:1}.stat-label{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-1)}.access-requests .table-scroll{overflow-y:hidden}.filter-toggle{position:relative}.filter-badge{position:absolute;top:-4px;right:-4px;width:8px;height:8px;border-radius:var(--radius-full);background-color:var(--error-light);border:2px solid var(--surface-card)}.filter-panel{background-color:var(--surface-card);border:1px solid var(--border-color);border-radius:8px;padding:var(--space-5);margin-bottom:var(--space-4);box-shadow:var(--card-shadow)}.access-requests .table tbody tr{animation:fadeInUp .35s ease forwards;opacity:0}.access-requests .table tbody tr:nth-child(1){animation-delay:.05s}.access-requests .table tbody tr:nth-child(2){animation-delay:.1s}.access-requests .table tbody tr:nth-child(3){animation-delay:.15s}.access-requests .table tbody tr:nth-child(4){animation-delay:.2s}.access-requests .table tbody tr:nth-child(5){animation-delay:.25s}.access-requests .table tbody tr:nth-child(6){animation-delay:.3s}.access-requests .table tbody tr:nth-child(7){animation-delay:.35s}.access-requests .table tbody tr:nth-child(8){animation-delay:.4s}.access-requests .table tbody tr:nth-child(9){animation-delay:.45s}.access-requests .table tbody tr:nth-child(10){animation-delay:.5s}.access-requests .table-pagination{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-3) var(--space-4);border-top:1px solid var(--border-color);background:var(--surface-card)}.access-requests .pagination-info{font-size:var(--text-sm);color:var(--text-secondary)}.access-requests .pagination-controls{display:flex;align-items:center;gap:var(--space-3)}.access-requests .pagination-page{font-size:var(--text-sm);color:var(--text-primary);font-weight:var(--font-medium)}.requests-section{margin-bottom:var(--space-6)}.requests-section:last-of-type{margin-bottom:0}.requests-section h2{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-4)}.requests-table-container{background-color:transparent;border:1px solid var(--border-color);border-radius:8px;overflow:hidden;overflow-y:hidden;box-shadow:var(--card-shadow)}.requests-table{width:100%;border-collapse:collapse;table-layout:fixed;font-size:14px}.requests-table thead{background-color:var(--surface-bg);border-bottom:1px solid var(--border-color)}.requests-table th{padding:12px 16px;text-align:left;font-size:var(--text-sm);font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.requests-table th:nth-child(1){width:20%;padding-left:16px}.requests-table th:nth-child(2){width:25%}.requests-table th:nth-child(3){width:12%}.requests-table th:nth-child(4){width:12%}.requests-table th:nth-child(5){width:12%}.requests-table th:nth-child(6){width:19%;padding-right:16px}.requests-table td{padding:12px 16px;border-top:1px solid var(--border-color);font-size:var(--text-sm);color:var(--text-primary);vertical-align:middle}.requests-table td:first-child{padding-left:16px}.requests-table td:last-child{padding-right:16px}.requests-table tbody tr{transition:background-color .2s ease;border-bottom:1px solid var(--border-color);animation:fadeInUp .4s ease forwards;opacity:0}.requests-table tbody tr:nth-child(1){animation-delay:.05s}.requests-table tbody tr:nth-child(2){animation-delay:.1s}.requests-table tbody tr:nth-child(3){animation-delay:.15s}.requests-table tbody tr:nth-child(4){animation-delay:.2s}.requests-table tbody tr:nth-child(5){animation-delay:.25s}.requests-table tbody tr:nth-child(6){animation-delay:.3s}.requests-table tbody tr:nth-child(7){animation-delay:.35s}.requests-table tbody tr:nth-child(8){animation-delay:.4s}.requests-table tbody tr:nth-child(9){animation-delay:.45s}.requests-table tbody tr:nth-child(10){animation-delay:.5s}.requests-table tbody tr:hover{background-color:var(--surface-hover)}.requests-table tbody tr:last-child td{border-bottom:none}.name-cell{display:flex;align-items:center;gap:var(--space-3);font-weight:var(--font-medium);color:var(--text-primary)}.email-cell{display:flex;align-items:center;gap:var(--space-3)}.email-icon{color:var(--text-secondary);flex-shrink:0}.date-text{color:var(--text-secondary);font-size:var(--text-sm)}.access-requests .table th:last-child,.access-requests .table td:last-child{text-align:center}.access-requests .action-buttons{justify-content:center}.status-pending{background-color:var(--warning-bg);color:var(--warning-dark);border:1px solid var(--warning-border)}.status-accepted{background-color:var(--success-bg);color:var(--success-light);border:1px solid var(--success-border)}.status-rejected{background-color:var(--error-bg);color:var(--error-light);border:1px solid var(--error-border)}.empty-state{padding:var(--space-16)}.accept-modal-content{display:flex;flex-direction:column;gap:var(--space-4)}.request-info{background-color:var(--surface-card);padding:var(--space-4);border-radius:var(--radius-md);border:1px solid var(--border-color)}.request-info p{margin:var(--space-2) 0;color:var(--text-primary)}.modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-4)}.delete-confirmation-details{background-color:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4);margin-top:var(--space-4);text-align:left}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--space-4);color:var(--text-secondary)}.loading-spinner{width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--primary-500);border-radius:var(--radius-full);animation:spin .8s linear infinite}@keyframes fadeInUp{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:1280px){.requests-table{min-width:900px}}@media(max-width:1024px){.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.header-stats{width:100%;justify-content:flex-start}.requests-table{min-width:800px}}@media(max-width:768px){.search-filter-bar{flex-direction:column;align-items:stretch}.search-filter-bar .btn{width:100%;justify-content:center}.filter-grid{grid-template-columns:1fr}.requests-table{min-width:700px}.page-header h1{font-size:var(--text-2xl)}}@media(max-width:640px){.requests-table-container{border-radius:0;border-left:none;border-right:none}.badge{padding:var(--space-1) var(--space-2);font-size:11px}.empty-state{padding:var(--space-8) var(--space-4)}.page-header h1{font-size:var(--text-xl)}}@media(max-width:480px){.header-stats{flex-direction:column;gap:var(--space-3)}.stat-card{width:100%;min-width:auto}.requests-table{min-width:600px}}.configurable-options{max-width:100%;padding:0}.configurable-options .header-status{display:flex;align-items:center;gap:var(--space-3)}.configurable-options .last-update-badge{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--surface-hover);border:1px solid var(--border-color);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-secondary)}.configurable-options .last-update-badge svg{color:var(--primary-500)}.configurable-options .type-tabs{display:flex;gap:var(--space-2);padding:var(--space-1);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);margin-bottom:var(--space-6)}.configurable-options .type-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:all var(--transition-fast)}.configurable-options .type-tab:hover{background:var(--surface-hover);color:var(--text-primary)}.configurable-options .type-tab.active{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:var(--text-inverse);box-shadow:0 4px 12px #3b82f64d}.configurable-options .type-tab.active svg{color:var(--text-inverse)}.configurable-options .section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);margin-bottom:var(--space-6)}.configurable-options .section-info{display:flex;align-items:center;gap:var(--space-3)}.configurable-options .section-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-lg);color:var(--text-inverse)}.configurable-options .section-icon.gradient-blue{background:linear-gradient(135deg,var(--primary-500),var(--primary-600))}.configurable-options .section-icon.gradient-green{background:linear-gradient(135deg,var(--success-light),#16a34a)}.configurable-options .section-icon.gradient-purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.configurable-options .section-text{display:flex;flex-direction:column;gap:var(--space-1)}.configurable-options .section-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.configurable-options .section-description{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.configurable-options .section-actions{display:flex;align-items:center;gap:var(--space-3)}.configurable-options .options-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-4)}.configurable-options .option-card{background:var(--surface-card);border:1px solid var(--border-color);border-radius:8px;padding:var(--space-5);transition:all var(--transition-fast);animation:fadeInUp var(--transition-normal) forwards;opacity:0}.configurable-options .option-card[draggable=true]{cursor:grab}.configurable-options .option-card.dragging{opacity:.6;transform:scale(.99);cursor:grabbing}.configurable-options .option-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.configurable-options .option-card-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.configurable-options .option-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-lg);color:var(--text-inverse);flex-shrink:0}.configurable-options .option-icon.gradient-blue{background:linear-gradient(135deg,var(--primary-500),var(--primary-600))}.configurable-options .option-icon.gradient-green{background:linear-gradient(135deg,var(--success-light),#16a34a)}.configurable-options .option-icon.gradient-purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.configurable-options .option-info{flex:1;min-width:0}.configurable-options .option-name{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-1) 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.configurable-options .option-value{display:inline-block;padding:var(--space-1) var(--space-2);background:var(--surface-hover);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--text-xs);font-family:var(--font-mono);color:var(--accent-400)}.configurable-options .option-header-actions{display:flex;align-items:center;gap:var(--space-2)}.configurable-options .option-drag-handle{display:flex;align-items:center;justify-content:center;color:var(--gray-500);cursor:grab;opacity:0;transition:opacity var(--transition-fast),color var(--transition-fast)}.configurable-options .option-card:hover .option-drag-handle,.configurable-options .option-card.dragging .option-drag-handle{opacity:1}.configurable-options .option-drag-handle:active{cursor:grabbing;color:var(--gray-300)}.configurable-options .option-description{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-4) 0;line-height:var(--leading-normal)}.configurable-options .option-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:var(--space-4);border-top:1px solid var(--border-color)}.configurable-options .option-meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-secondary)}.configurable-options .option-actions{display:flex;gap:var(--space-2)}.configurable-options .empty-state-card{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);background:var(--surface-card);border:1px dashed var(--border-color);border-radius:var(--radius-xl);text-align:center}.configurable-options .empty-icon{display:flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:var(--radius-full);color:var(--text-inverse);margin-bottom:var(--space-5);opacity:.8}.configurable-options .empty-icon.gradient-blue{background:linear-gradient(135deg,var(--primary-500),var(--primary-600))}.configurable-options .empty-icon.gradient-green{background:linear-gradient(135deg,var(--success-light),#16a34a)}.configurable-options .empty-icon.gradient-purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.configurable-options .option-form{display:flex;flex-direction:column;gap:var(--space-5)}.configurable-options .delete-confirmation{text-align:center;padding:var(--space-2) 0}.configurable-options .delete-confirmation-icon{display:flex;justify-content:center;margin-bottom:var(--space-4);color:var(--error-light)}.configurable-options .delete-confirmation-icon svg{width:48px;height:48px}.configurable-options .delete-confirmation-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-3) 0}.configurable-options .delete-confirmation-message{font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0 0 var(--space-5) 0}.configurable-options .delete-confirmation-message strong{color:var(--text-primary);font-weight:var(--font-semibold)}.configurable-options .delete-confirmation-details{background:var(--surface-hover);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4);margin-top:var(--space-4);text-align:left}.configurable-options .delete-confirmation-detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0;border-bottom:1px solid var(--border-color)}.configurable-options .delete-confirmation-detail-row:last-child{border-bottom:none;padding-bottom:0}.configurable-options .detail-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-medium)}.configurable-options .detail-value{font-size:var(--text-sm);color:var(--text-primary);font-weight:var(--font-medium)}.configurable-options .loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--space-4)}.configurable-options .loading-container p{color:var(--text-secondary);font-size:var(--text-sm)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.configurable-options .page-header{flex-direction:column;align-items:stretch;gap:var(--space-4)}.configurable-options .header-status{justify-content:flex-end}}@media(max-width:768px){.configurable-options .type-tabs{flex-direction:column;gap:var(--space-1)}.configurable-options .type-tab{justify-content:flex-start;padding:var(--space-4)}.configurable-options .section-header{flex-direction:column;align-items:stretch;gap:var(--space-4)}.configurable-options .section-header .btn{width:100%}.configurable-options .options-grid{grid-template-columns:1fr}.configurable-options .modal-sm{max-width:100%;border-radius:0;max-height:100%}}@media(max-width:640px){.configurable-options .option-card-footer{flex-direction:column;gap:var(--space-3)}.configurable-options .option-actions{width:100%}.configurable-options .option-actions .action-btn{flex:1}}.cla-figures{max-width:100%}body.cla-figures-page .main-content,body.cla-figures-page .content-container{overflow:visible!important}.rank-tabs{display:flex;-moz-column-gap:2px;column-gap:2px;row-gap:6px;padding:3px;background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);margin-bottom:var(--space-6);flex-wrap:wrap}.rank-tab{flex:0 1 auto;min-width:96px;display:flex;align-items:center;justify-content:center;gap:3px;padding:4px 8px;border-radius:var(--radius-lg);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--gray-400);background:transparent;border:none;cursor:pointer;transition:all var(--transition-fast)}.rank-tab svg{width:14px;height:14px}.rank-tab:hover{background:var(--surface-elevated);color:var(--gray-200)}.rank-tab.active{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;box-shadow:0 4px 12px #0072db4d}.cla-figures .section-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);margin-bottom:var(--space-4)}.cla-figures .section-info{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:0}.cla-figures .section-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-lg);color:#fff}.cla-figures .section-icon.gradient-blue{background:linear-gradient(135deg,var(--primary-500),var(--primary-600))}.cla-figures .section-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.cla-figures .section-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0;line-height:1.3;width:100%;padding:0;border:0;text-transform:none;letter-spacing:normal}.cla-figures .section-total{display:flex;flex-direction:column;align-items:flex-end;gap:2px;padding:var(--space-3) var(--space-4);background:#0072db1a;border:1px solid rgba(0,114,219,.2);border-radius:var(--radius-lg);opacity:0;visibility:hidden;transition:opacity .15s ease,visibility .15s ease;flex-shrink:0}.cla-figures .section-total.visible{opacity:1;visibility:visible}.cla-figures .section-total .total-label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px}.cla-figures .section-total .total-value{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--primary-400);font-family:var(--font-mono)}.cla-figures .section-description{font-size:var(--text-sm);color:var(--gray-500);margin:8px 0 0;line-height:1.4;width:100%;padding-left:0;padding-right:0;padding-top:8px;border-top:1px solid var(--border-color)}.saving-indicator{display:inline-flex;align-items:center;gap:4px;font-size:var(--text-xs);color:var(--primary-400);font-weight:var(--font-medium);margin-left:var(--space-2)}.unit-names-legend{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--surface-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:var(--space-4);font-size:var(--text-xs);color:var(--gray-400);flex-wrap:wrap}.unit-names-legend svg{color:var(--primary-500);flex-shrink:0}.unit-names-legend .legend-label{font-weight:var(--font-semibold);color:var(--text-primary);margin-right:var(--space-1)}.unit-names-legend code{background:var(--surface-card);padding:2px 6px;border-radius:var(--radius-sm);color:var(--primary-400);font-weight:var(--font-semibold);font-size:var(--text-xs)}.unit-names-legend .legend-desc{color:var(--gray-500)}.unit-names-legend .legend-sep{color:var(--gray-600)}.unit-names-legend .copy-to-section{display:flex;align-items:center;gap:var(--space-2);margin-left:auto;padding-left:var(--space-4);border-left:1px solid var(--gray-800)}.unit-names-legend .copy-to-section .btn{height:28px;padding:var(--space-1) var(--space-3);font-size:var(--text-xs);gap:var(--space-1)}.unit-names-legend .copy-to-section .btn svg{flex-shrink:0;width:14px;height:14px;color:#fff}.unit-names-legend .copy-to-select{min-width:150px;height:28px;font-size:var(--text-xs);padding:var(--space-1) var(--space-2)}.cla-figures .table-container{margin-top:var(--space-4)}.cla-table th:first-child,.cla-table td:first-child{width:40px;padding-left:var(--space-3);text-align:center}.drag-handle{display:flex;align-items:center;justify-content:center;color:var(--gray-400);cursor:grab;transition:color var(--transition-fast)}.cla-table tbody tr.dragging{opacity:.5;background:var(--primary-500)!important}.cla-table tbody tr{cursor:default}.cla-table th.col-name,.cla-table td.col-name{text-align:left;min-width:180px}.cla-table td{vertical-align:middle;text-align:center}.item-name-cell{display:flex;flex-direction:column;gap:2px}.item-name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);line-height:1.3}.item-description{font-size:11px;color:var(--gray-500);line-height:1.2}.jolly-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;margin-left:var(--space-2)}.amount-input-wrapper{display:flex;align-items:center;justify-content:center;gap:var(--space-1);width:100%}.amount-input{width:90px;padding:var(--space-1) var(--space-2);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--text-xs);color:var(--text-primary);font-family:var(--font-mono);text-align:right;transition:all var(--transition-fast)}.amount-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 2px #3b82f633}.amount-input:disabled{opacity:.5;cursor:not-allowed;background:var(--gray-50)}.amount-display{display:inline-block;padding:var(--space-1) var(--space-2);font-size:var(--text-xs);color:var(--text-secondary);font-family:var(--font-mono);text-align:right}.saving-spinner{animation:spin 1s linear infinite;color:var(--primary-500)}.inactive-amount{color:var(--text-muted);font-style:italic;font-size:var(--text-xs);display:block;text-align:center}.action-buttons{display:flex;align-items:center;justify-content:center;gap:var(--space-1)}.add-item-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-color);background:var(--surface-elevated);display:flex;justify-content:flex-end}.add-item-footer .btn{display:flex;align-items:center;gap:var(--space-2)}.form-help-text{display:block;margin-top:var(--space-1);font-size:var(--text-xs);color:var(--gray-500)}.empty-icon{color:var(--gray-600);margin-bottom:var(--space-5);opacity:.5}.name-form{display:flex;flex-direction:column;gap:var(--space-5)}.modal-icon.gradient-purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.modal-icon.gradient-red{background:linear-gradient(135deg,#ef4444,#dc2626)}.unit-input{width:50px;padding:var(--space-1) var(--space-2);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--text-xs);transition:all var(--transition-fast);text-align:center}.unit-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 2px #0072db1a}.unit-input::-moz-placeholder{color:var(--gray-600);font-size:10px}.unit-input::placeholder{color:var(--gray-600);font-size:10px}.tax-input{width:52px;padding:var(--space-1);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--text-xs);font-weight:var(--font-medium);text-align:center;transition:all var(--transition-fast)}.tax-input::-webkit-outer-spin-button,.tax-input::-webkit-inner-spin-button{-webkit-appearance:none;appearance:none;margin:0}.tax-input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.tax-input:focus{outline:none;box-shadow:0 0 0 2px #0072db1a}.tax-input.tax-free{border-color:#10b981;background:#10b98126}.tax-input.tax-partial{border-color:#f59e0b;background:#f59e0b26}.tax-input.tax-full{border-color:#ef4444;background:#ef444426}.tax-free-display{display:inline-block;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--font-semibold);min-width:40px;text-align:center}.tax-free-display.tax-free{background:#10b98133;color:#10b981}.tax-free-display.tax-partial{background:#f59e0b33;color:#f59e0b}.tax-free-display.tax-full{background:#ef444433;color:#ef4444}.inactive-text{color:var(--gray-500);font-style:italic;display:block;text-align:center;width:100%}.calculator-tooltip{position:relative;display:inline-block}.calculator-tooltip:hover:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:var(--space-2) var(--space-3);background:var(--gray-900);color:var(--text-primary);font-size:var(--text-xs);border-radius:var(--radius-md);white-space:nowrap;z-index:1000;margin-bottom:var(--space-2);box-shadow:0 4px 12px #0000004d}@media(max-width:768px){.rank-tabs{flex-direction:column;gap:var(--space-1)}.rank-tab{justify-content:flex-start;padding:var(--space-4)}.section-header{flex-direction:column;align-items:stretch;gap:var(--space-4)}.payslip-items-table{overflow-x:auto}.items-table{min-width:600px}.items-table th,.items-table td{padding:var(--space-3) var(--space-4);font-size:var(--text-xs)}.amount-input{width:120px}}@media(max-width:640px){.items-table{min-width:500px}.item-name-cell{min-width:150px}.amount-input{width:100px}}.delete-confirmation-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--gray-100);margin:0 0 var(--space-3) 0}.delete-confirmation-message{font-size:var(--text-base);color:var(--gray-400);line-height:1.6;margin:0 0 var(--space-5) 0}.delete-confirmation-message strong{color:var(--gray-200);font-weight:var(--font-semibold)}.delete-confirmation-details{background:var(--surface-elevated);border:1px solid var(--gray-700);border-radius:var(--radius-lg);padding:var(--space-4);margin-top:var(--space-4);text-align:left}.delete-confirmation-detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0;border-bottom:1px solid var(--gray-800)}.detail-label{font-size:var(--text-sm);color:var(--gray-500);font-weight:var(--font-medium)}.detail-value{font-size:var(--text-sm);color:var(--gray-200);font-weight:var(--font-semibold);text-align:right}.field-config-form{display:flex;flex-direction:column;gap:var(--space-4)}.field-config-footer{display:flex;gap:var(--space-3);justify-content:flex-end}.custom-select{position:relative;width:100%}.custom-select-button{display:flex;align-items:center;justify-content:space-between;width:100%;text-align:left;cursor:pointer;padding-right:var(--space-4)}.custom-select-button:disabled{cursor:not-allowed;opacity:.5}.custom-select-chevron{flex-shrink:0;transition:transform var(--transition-fast);color:var(--text-muted)}.custom-select-chevron-open{transform:rotate(180deg)}.custom-select-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:var(--space-1);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 4px 12px #0000001a;z-index:1000;max-height:240px;overflow-y:auto;display:flex;flex-direction:column}.custom-select-option{padding:var(--space-3) var(--space-4);background:transparent;border:none;color:var(--text-primary);font-size:var(--text-sm);text-align:left;cursor:pointer;transition:background-color var(--transition-fast)}.custom-select-option:hover{background-color:var(--surface-hover)}.custom-select-option-selected{background-color:var(--surface-hover);color:var(--primary-500);font-weight:var(--font-medium)}.custom-select-option:first-child{border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md)}.custom-select-option:last-child{border-bottom-left-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md)}.form-input-code{font-family:var(--font-mono);font-size:var(--text-sm)}.form-hint{font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-1)}.form-input-error{border-color:var(--error-light)!important}.form-input-error:focus{border-color:var(--error-light)!important;box-shadow:0 0 0 3px var(--error-bg)!important}.options-list{display:flex;flex-direction:column;gap:var(--space-2)}.option-item{display:flex;gap:var(--space-2);align-items:flex-start}.option-input-group{display:flex;flex-direction:column;gap:var(--space-1)}.option-input-group:first-of-type{flex:1;min-width:0}.option-input-group:nth-of-type(2){width:150px;flex-shrink:0}.option-input-group .form-input,.option-input-group .form-input-code{width:100%;box-sizing:border-box}.validation-fields{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);align-items:start}.validation-field{display:flex;flex-direction:column;gap:var(--space-2)}.validation-field label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--gray-700)}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.icon-btn:hover{background-color:var(--surface-hover);border-color:transparent;color:var(--text-primary)}.icon-btn-danger:hover{color:var(--error-dark);background-color:var(--error-bg)}@media(max-width:768px){.validation-fields{grid-template-columns:1fr}.option-item{flex-direction:column;align-items:stretch}.option-input-group{flex:1!important}}.form-builder{display:flex;flex-direction:column;gap:var(--space-6)}.form-builder-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);gap:var(--space-4)}.form-builder-loading .spinner{animation:spin 1s linear infinite;color:var(--primary-500)}.form-builder-section{display:flex;flex-direction:column;gap:var(--space-4)}.form-builder-section-header{display:flex;justify-content:space-between;align-items:center}.form-builder-section-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.form-builder-fields{display:flex;flex-direction:column;gap:var(--space-4)}.form-checkbox{margin-right:var(--space-2);width:20px;height:20px;cursor:pointer;accent-color:var(--primary-500);border:1px solid var(--border-color);border-radius:4px;background:var(--surface-card)}.form-builder-empty{padding:var(--space-8);text-align:center;color:var(--text-secondary);background:var(--surface-card);border:1px dashed var(--border-color);border-radius:var(--radius-md)}.form-builder-fields-list{display:flex;flex-direction:column;gap:var(--space-3)}.form-builder-field-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);transition:all .2s ease;cursor:move}.form-builder-field-item:hover{border-color:var(--border-hover);box-shadow:var(--shadow-sm)}.form-builder-field-item:active{opacity:.7}.form-builder-field-drag{display:flex;align-items:center;color:var(--text-muted);cursor:grab}.form-builder-field-drag:active{cursor:grabbing}.form-builder-field-content{flex:1;display:flex;flex-direction:column;gap:var(--space-2)}.form-builder-field-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3)}.form-builder-field-label{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin-right:var(--space-2)}.form-builder-field-type{display:inline-block;padding:var(--space-1) var(--space-2);background:var(--info-bg);color:var(--info-dark);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--font-medium);margin-right:var(--space-2)}.form-builder-field-required{display:inline-block;padding:var(--space-1) var(--space-2);background:var(--error-bg);color:var(--error-dark);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--font-medium)}.form-builder-field-key{font-size:var(--text-xs);color:var(--text-secondary)}.form-builder-field-key code{padding:var(--space-1) var(--space-2);background:var(--surface-bg);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-family:var(--font-mono);color:var(--primary-600)}.form-builder-field-actions{display:flex;gap:var(--space-2);flex-shrink:0}.form-builder-actions{display:flex;justify-content:flex-end;padding-top:var(--space-4);border-top:1px solid var(--border-color)}.icon-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.icon-btn:hover{background:var(--surface-hover);color:var(--text-primary)}.icon-btn-danger:hover{background:var(--error-bg);color:var(--error-light)}.reporting-forms-container{max-width:100%;background-color:var(--surface-bg);min-height:100%}.page-icon{color:var(--primary-500)}.saving-indicator{display:inline-flex;align-items:center;gap:var(--space-1);color:var(--primary-500);font-size:var(--text-xs);margin-left:var(--space-2)}.reporting-forms-container .searchbar-container{margin-bottom:var(--space-6)}.templates-list{display:flex;flex-direction:column;gap:var(--space-3)}.template-card{background-color:var(--surface-card);border:1px solid var(--border-color);border-radius:8px;padding:var(--space-4) var(--space-5);transition:all var(--transition-fast);cursor:move;box-shadow:var(--card-shadow)}.template-card:hover{border-color:var(--primary-500);box-shadow:var(--card-shadow-hover);background-color:var(--surface-card)}.template-card:hover .template-drag-handle{color:var(--text-secondary)}.template-card-content{display:flex;align-items:center;gap:var(--space-4);width:100%}.template-drag-handle{display:flex;align-items:center;justify-content:center;cursor:grab;color:var(--text-muted);transition:color var(--transition-fast);flex-shrink:0}.template-drag-handle:active{cursor:grabbing}.template-card.dragging{opacity:.5;background-color:var(--primary-500)!important;border-color:var(--primary-500)!important}.template-card[draggable=true]{cursor:grab}.template-card[draggable=true]:active{cursor:grabbing}.template-name{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0;flex:1;min-width:0}.template-status{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);border-radius:9999px;font-size:var(--text-xs);font-weight:var(--font-semibold);flex-shrink:0;white-space:nowrap}.template-status.active{background-color:var(--success-bg);color:var(--success-light)}.template-status.inactive{background-color:var(--error-bg);color:var(--error-light)}.template-date{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.template-actions{display:flex;gap:var(--space-2);flex-shrink:0;margin-left:auto}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);text-align:center;color:var(--text-secondary)}.loading-container p{margin-top:var(--space-4);font-size:var(--text-base)}.loading-spinner{color:var(--primary-500)}.modal-footer-actions{display:flex;gap:var(--space-3);justify-content:flex-end}.delete-confirmation-details{background-color:var(--surface-bg);border:1px solid var(--border-color);border-radius:8px;padding:var(--space-4);margin-top:var(--space-4);text-align:left}.detail-value{font-size:var(--text-sm);color:var(--text-primary);font-weight:var(--font-medium);text-align:right;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:768px){.template-card-header{flex-direction:column}.template-actions{align-self:flex-end}.template-card{padding:var(--space-3) var(--space-4)}.template-card-content{flex-wrap:wrap;gap:var(--space-3)}.template-name{width:100%;order:-2}.template-status{order:-1}.template-date{width:100%;font-size:var(--text-xs)}.template-actions{width:100%;justify-content:flex-end;margin-left:0}}@media(max-width:480px){.template-actions{flex-wrap:wrap}}.submissions-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);gap:var(--space-4)}.submissions-loading .spinner{animation:spin 1s linear infinite;color:var(--primary-500)}.submissions-empty{padding:var(--space-8);text-align:center;color:var(--text-secondary)}.submissions-list{display:flex;flex-direction:column;gap:var(--space-4)}.submissions-summary{padding:var(--space-3) 0;color:var(--text-secondary);font-size:var(--text-sm)}.submissions-summary strong{color:var(--text-primary);font-weight:var(--font-semibold)}.submissions-table{overflow-x:auto;background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--card-shadow)}.submissions-table table{width:100%;min-width:700px;border-collapse:collapse}.submissions-table td{padding:var(--space-4) var(--space-5);font-size:var(--text-sm);color:var(--gray-700)}.submission-user{display:flex;align-items:center;gap:var(--space-2)}.submission-user svg{color:var(--text-secondary);flex-shrink:0}.submission-user-code{font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-1)}.submission-status{display:inline-block;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--font-medium)}.submission-status.submitted{background:var(--success-bg);color:var(--success-dark);border:1px solid rgba(34,197,94,.5)}.submission-status.draft{background:var(--warning-bg);color:var(--warning-dark);border:1px solid rgba(245,158,11,.5)}.submission-date svg{color:var(--text-secondary)}.delete-confirmation-details{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4);margin-top:var(--space-4);text-align:left}@media(max-width:768px){.submissions-table{font-size:var(--text-xs)}.submissions-table th,.submissions-table td{padding:var(--space-2)}}.submissions-page-container{max-width:100%;background:var(--surface-bg);min-height:100vh}.page-icon{color:var(--primary-500);flex-shrink:0;margin-top:2px}.btn-back{display:inline-flex;align-items:center;gap:var(--space-2);flex-shrink:0}.submissions-page-container .page-actions{margin-bottom:var(--space-4)}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);gap:var(--space-4);text-align:center;color:var(--text-secondary);background:var(--surface-card);border:1px solid var(--border-color);border-radius:8px}.error-state p{font-size:var(--text-base);color:var(--text-secondary)}@media(max-width:768px){.submissions-page-container .page-header{flex-direction:column;align-items:stretch}.btn-back{width:100%;justify-content:center}.submissions-page-container .page-title{font-size:var(--text-xl)}.submissions-page-container .card{padding:var(--space-4)}.error-state{padding:var(--space-8)}}@media(max-width:480px){.submissions-page-container .page-title-section{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.page-icon{margin-top:0}.submissions-page-container .page-title{font-size:var(--text-lg)}.submissions-page-container .page-subtitle{font-size:var(--text-xs)}}.submission-details-container{max-width:100%;background:var(--surface-bg);min-height:100vh}.submission-details-container .page-header{margin-bottom:var(--space-4)}.btn-back{display:inline-flex;align-items:center;gap:var(--space-2);padding-left:var(--space-4)}.submission-details-content{display:flex;flex-direction:column;gap:var(--space-4)}.details-section{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--card-shadow)}.details-section-compact{padding:var(--space-4)}.compact-header-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}.compact-section{display:flex;flex-direction:column;gap:var(--space-3)}.compact-section-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);margin:0;padding-bottom:var(--space-2);border-bottom:1px solid var(--border-color)}.compact-section-title svg{color:var(--primary-500);width:16px;height:16px}.compact-info-grid{display:flex;flex-direction:column;gap:var(--space-2)}.compact-info-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--border-color)}.compact-info-item:last-child{border-bottom:none}.compact-label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;min-width:100px;flex-shrink:0}.compact-value{font-size:var(--text-sm);color:var(--text-primary);word-break:break-word;text-align:right;flex:1}.submission-details-container .section-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-3) 0;padding-bottom:var(--space-2);border-bottom:1px solid var(--border-color)}.submission-details-container .section-title svg{color:var(--primary-500);width:18px;height:18px}.form-fields-list{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-3)}.form-field-card{display:flex;flex-direction:column;background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition-fast);box-shadow:var(--shadow-xs)}.form-field-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-sm)}.form-field-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--surface-bg);border-bottom:1px solid var(--border-color);gap:var(--space-2)}.form-field-label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);display:flex;align-items:center;gap:var(--space-1);flex:1;min-width:0}.required-indicator{color:var(--error-500);font-weight:var(--font-bold)}.form-field-type{font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;padding:var(--space-1) var(--space-2);background:var(--surface-hover);border-radius:var(--radius-sm);flex-shrink:0}.form-field-content{padding:var(--space-4);min-height:60px;display:flex;align-items:flex-start}.field-value-text{font-size:var(--text-sm);color:var(--text-primary);word-break:break-word;line-height:1.5;width:100%}.field-value-empty{color:var(--text-muted);font-style:italic;font-size:var(--text-sm);width:100%}.field-file-wrapper{display:flex;flex-direction:column;gap:var(--space-3);width:100%}.field-file-header{width:100%}.field-file-info{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--surface-bg);border:1px solid var(--border-color);border-radius:var(--radius-md)}.field-file-icon{color:var(--primary-500);flex-shrink:0}.field-file-details{display:flex;flex-direction:column;gap:var(--space-1);flex:1;min-width:0}.field-file-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);word-break:break-word}.field-file-meta{font-size:var(--text-xs);color:var(--text-secondary)}.field-file-actions{display:flex;gap:var(--space-2);flex-wrap:wrap}.field-file-preview{margin-top:var(--space-4);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--surface-card);overflow:hidden;animation:slideDown var(--transition-normal) ease-out}@keyframes slideDown{0%{opacity:0;max-height:0;transform:translateY(-10px)}to{opacity:1;max-height:1000px;transform:translateY(0)}}.field-file-preview-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--surface-bg);border-bottom:1px solid var(--border-color)}.field-file-preview-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.field-file-preview-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);padding:0}.field-file-preview-close:hover{background:var(--surface-hover);color:var(--text-primary)}.field-file-preview-close svg{width:16px;height:16px}.field-file-preview-content{padding:var(--space-4);display:flex;justify-content:center;align-items:center;min-height:300px;max-height:800px;overflow:auto;background:var(--surface-bg)}.field-file-preview-image{max-width:100%;max-height:700px;height:auto;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);-o-object-fit:contain;object-fit:contain}.field-file-preview-pdf{width:100%;min-height:600px;border:none;border-radius:var(--radius-sm);background:#fff}.field-signature-wrapper{display:flex;justify-content:center;align-items:center;width:100%;min-height:150px;padding:var(--space-4);background:var(--surface-bg);border:1px solid var(--border-color);border-radius:var(--radius-md)}.field-signature-wrapper .signature-svg{width:100%;max-width:100%;height:auto;min-height:150px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:#fff;padding:var(--space-3)}.field-signature-wrapper .signature-image{max-width:100%;max-height:300px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:#fff;padding:var(--space-2)}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);gap:var(--space-4);text-align:center;color:var(--text-secondary)}.status-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.5px;border-radius:var(--radius-md)}.status-badge.submitted{background:var(--success-bg);color:var(--success-dark);border:1px solid rgba(34,197,94,.5)}.status-badge.draft{background:var(--warning-bg);color:var(--warning-dark);border:1px solid rgba(245,158,11,.5)}@media(max-width:1024px){.compact-header-grid{grid-template-columns:1fr;gap:var(--space-4)}}@media(max-width:768px){.submission-details-content{gap:var(--space-3)}.details-section{padding:var(--space-3)}.compact-info-item{flex-direction:column;align-items:flex-start;gap:var(--space-1)}.compact-value{text-align:left}.form-fields-list{gap:var(--space-2)}.form-field-header{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.field-file-actions{width:100%}.field-file-preview-content{padding:var(--space-2);min-height:200px;max-height:500px}.field-file-preview-image{max-height:400px}.field-file-preview-pdf{min-height:400px}}.all-submissions-container{max-width:100%}.search-filter-bar{display:flex;gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap;align-items:center}.filter-toggle{position:relative;display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background-color:var(--surface-card);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast);cursor:pointer}.filter-toggle:hover{background-color:var(--surface-hover);border-color:var(--border-hover)}.filter-toggle.active{background-color:var(--primary-500);color:var(--text-inverse);border-color:var(--primary-500)}.filter-badge{position:absolute;top:-4px;right:-4px;width:8px;height:8px;border-radius:var(--radius-full);background:var(--error-light);border:2px solid var(--surface-card)}.filter-panel{background:var(--surface-card);border:1px solid var(--border-color);border-radius:8px;padding:var(--space-5);margin-bottom:var(--space-4);box-shadow:var(--card-shadow)}.filter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-4)}.filter-group{display:flex;flex-direction:column;gap:var(--space-2)}.filter-group label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.filter-select,.filter-input{padding:var(--space-2) var(--space-3);background:var(--surface-card);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:var(--text-sm);outline:none;transition:border-color var(--transition-fast)}.filter-select:focus,.filter-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #3b82f61a}.filter-select{cursor:pointer}.filter-input::-moz-placeholder{color:var(--text-muted)}.filter-input::placeholder{color:var(--text-muted)}.results-summary{padding:var(--space-3) 0;color:var(--text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-4)}.results-summary strong{color:var(--text-primary);font-weight:var(--font-semibold)}.submissions-table-wrapper{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--card-shadow)}.submissions-table{width:100%;border-collapse:collapse}.submissions-table thead{background:var(--gray-50);border-bottom:1px solid var(--border-color)}.submissions-table th{padding:var(--space-4) var(--space-5);text-align:left;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--gray-600);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.submissions-table tbody tr{border-bottom:1px solid var(--border-color);transition:background-color var(--transition-fast)}.submissions-table tbody tr:hover{background:var(--gray-50)}.submissions-table tbody tr:last-child td{border-bottom:none}.submissions-table td{padding:var(--space-4) var(--space-5);font-size:var(--text-sm);color:var(--gray-700);border-bottom:1px solid var(--border-color)}.submission-user{display:flex;align-items:flex-start;gap:var(--space-2)}.submission-user svg{color:var(--text-muted);flex-shrink:0;margin-top:2px}.submission-user-name{font-weight:var(--font-medium);color:var(--text-primary)}.submission-user-code,.submission-user-email{font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-1)}.submission-template{display:flex;align-items:center;gap:var(--space-2);color:var(--text-primary)}.submission-template svg{color:var(--primary-500);flex-shrink:0}.submission-date{display:flex;align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:var(--text-xs)}.submission-date svg{color:var(--text-muted)}.submission-actions{display:flex;align-items:center;gap:var(--space-2)}.delete-confirmation-icon{display:flex;justify-content:center;margin-bottom:var(--space-4);color:var(--error-light)}.delete-confirmation-message{font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0 0 var(--space-5) 0}.delete-confirmation-details{background:var(--surface-hover);border:1px solid var(--border-color);border-radius:8px;padding:var(--space-4);margin-top:var(--space-4);text-align:left}.detail-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-medium)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);gap:var(--space-4);text-align:center;color:var(--text-secondary)}@media(max-width:768px){.search-filter-bar{flex-direction:column;align-items:stretch}.filter-grid{grid-template-columns:1fr}.submissions-table-wrapper{overflow-x:auto}.submissions-table{min-width:800px}}.analytics-page{max-width:100%}.page-icon{color:var(--primary-500);flex-shrink:0}.analytics-filters-panel{display:flex;gap:var(--space-4);padding:var(--space-4);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:var(--space-6);flex-wrap:wrap;align-items:flex-end}.analytics-filter-group{display:flex;flex-direction:column;gap:var(--space-2);min-width:200px}.analytics-filter-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.analytics-filter-select,.analytics-filter-input{padding:var(--space-2) var(--space-3);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);transition:all var(--transition-fast)}.analytics-filter-select:hover,.analytics-filter-input:hover{border-color:var(--border-hover)}.analytics-filter-select:focus,.analytics-filter-input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #3b82f61a}.analytics-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5);margin-bottom:var(--space-8)}.analytics-stats .stat-card{position:relative;background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-5);overflow:hidden;transition:all var(--transition-fast)}.analytics-stats .stat-card:hover{transform:translateY(-4px);border-color:var(--border-hover);box-shadow:var(--shadow-lg)}.analytics-stats .stat-value{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-2)}.analytics-stats .stat-label{font-size:var(--text-sm);color:var(--text-secondary)}.charts-grid{display:grid;grid-template-columns:1fr;gap:var(--space-6);margin-bottom:var(--space-8)}.chart-card{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);transition:all var(--transition-fast)}.chart-card:hover:not(.chart-card-no-hover){border-color:var(--border-hover);box-shadow:var(--shadow-lg)}.chart-card-no-hover{transition:none}.chart-card-no-hover:hover{transform:none;border-color:var(--border-color);box-shadow:none}.chart-card-wide{grid-column:1 / -1}.chart-container{width:100%;overflow-x:auto;display:flex;justify-content:center}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:var(--space-3)}.chart-header .chart-title{margin:0;padding-bottom:0;border-bottom:none}.chart-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-4) 0;padding-bottom:var(--space-3);border-bottom:1px solid var(--border-color)}.chart-view-toggle{display:flex;align-items:center;gap:var(--space-2);background:transparent;border:none;padding:0}.chart-view-toggle .toggle-badge{cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.chart-view-toggle .toggle-badge.badge-info{background:var(--primary-500);color:var(--text-inverse);border-color:var(--primary-500);box-shadow:0 1px 3px #3b82f64d}.chart-view-toggle .toggle-badge.badge-neutral{background:var(--gray-50);color:var(--text-secondary);border-color:var(--border-color)}.chart-view-toggle .toggle-icon{color:var(--text-muted);margin-left:var(--space-1);flex-shrink:0}.empty-chart{display:flex;align-items:center;justify-content:center;height:300px;color:var(--text-muted);font-size:var(--text-sm)}.submitters-table .submissions-count{font-weight:var(--font-semibold);color:var(--primary-500);text-align:center}.submitters-table th:last-child,.submitters-table td:last-child{text-align:center}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--space-4);color:var(--text-muted)}.loading-spinner{animation:spin 1s linear infinite;color:var(--primary-500)}@media(max-width:1400px){.charts-grid{grid-template-columns:1fr}.chart-card-wide{grid-column:1}}@media(max-width:1024px){.analytics-stats{grid-template-columns:repeat(2,1fr)}.analytics-filters-panel{flex-direction:column;align-items:stretch}.analytics-filter-group{min-width:100%}}@media(max-width:640px){.analytics-stats{grid-template-columns:1fr}.chart-header{flex-direction:column;align-items:flex-start}.chart-view-toggle{width:100%;justify-content:center}}.calendar-events{max-width:100%}.calendar-events .table th,.calendar-events .table td{padding:12px 16px}.calendar-events .table th:first-child,.calendar-events .table td:first-child{padding-left:16px}.calendar-events .table th:last-child,.calendar-events .table td:last-child{padding-right:16px}.calendar-events .table td:nth-child(2){max-width:160px;min-width:100px}.calendar-events .table td:nth-child(3){max-width:140px;min-width:100px}.event-title-cell{display:flex;align-items:center;gap:var(--space-3)}.event-icon{color:var(--primary-500);flex-shrink:0}.event-title{font-weight:var(--font-semibold);color:var(--text-primary)}.time-cell{display:flex;align-items:center;gap:var(--space-2);color:var(--text-secondary)}.time-cell svg{color:var(--gray-400);flex-shrink:0}.creator-cell{display:flex;align-items:center;gap:var(--space-2);color:var(--text-secondary)}.creator-cell svg{color:var(--gray-400);flex-shrink:0}.event-bases-cell,.event-location-cell{display:flex;align-items:center;gap:var(--space-2);min-width:0}.event-bases-cell svg,.event-location-cell svg{color:var(--primary-500);flex-shrink:0}.truncated-cell{position:relative;max-width:100%;min-width:0}.truncated-text{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.text-muted{color:var(--text-muted)}.event-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:var(--space-2);opacity:0;pointer-events:none;transition:opacity var(--transition-fast),visibility var(--transition-fast);visibility:hidden;z-index:var(--z-tooltip);width:320px}.truncated-cell:hover .event-tooltip{opacity:1;visibility:visible;pointer-events:auto}.tooltip-content{background-color:var(--gray-900);border:1px solid var(--gray-700);border-radius:var(--radius-md);padding:var(--space-3);box-shadow:var(--shadow-lg);font-size:var(--text-sm);max-width:300px}.tooltip-content:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--gray-700)}.tooltip-content p{color:var(--gray-200);margin:0;line-height:1.5;word-wrap:break-word}.event-form{display:flex;flex-direction:column;gap:var(--space-5)}.select-all-bases{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);color:var(--text-secondary);font-size:var(--text-sm)}.select-all-bases input{accent-color:var(--primary-500)}.event-form .form-group{display:flex;flex-direction:column;gap:var(--space-2)}.event-form label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.event-form input,.event-form textarea{background-color:var(--surface-card);border:1px solid var(--border-color);border-radius:6px;padding:var(--space-3);font-size:var(--text-sm);color:var(--text-primary);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.event-form input:focus,.event-form textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #3b82f61a}.event-form input::-moz-placeholder,.event-form textarea::-moz-placeholder{color:var(--text-muted)}.event-form input::placeholder,.event-form textarea::placeholder{color:var(--text-muted)}.color-picker{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-top:var(--space-1)}.color-swatch{width:28px;height:28px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);border:2px solid transparent;padding:0}.color-swatch:hover{transform:scale(1.15);box-shadow:var(--shadow-md)}.color-swatch.selected{border-color:var(--gray-200)!important;box-shadow:0 0 0 1px var(--gray-800),0 0 0 3px var(--gray-200)}.delete-modal-content{text-align:center;padding:var(--space-2) 0}.delete-modal-icon{display:flex;justify-content:center;margin-bottom:var(--space-4);color:var(--error-light)}.delete-modal-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-3) 0}.delete-modal-description{font-size:var(--text-base);color:var(--text-secondary);line-height:1.6;margin:0 0 var(--space-5) 0}.delete-modal-actions{display:flex;gap:var(--space-3);justify-content:center;margin-top:var(--space-5)}.attendees-cell{display:flex;align-items:center;gap:6px}.attendees-list{max-height:400px;overflow-y:auto}.attendee-item{display:flex;align-items:center;padding:var(--space-3);border-bottom:1px solid var(--border-color);gap:var(--space-3);transition:background-color var(--transition-fast)}.attendee-item:hover{background-color:var(--surface-hover)}.attendee-avatar{width:40px;height:40px;border-radius:var(--radius-full);background-color:var(--surface-hover);display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--primary-500);flex-shrink:0}.attendee-name{font-size:var(--text-base);color:var(--text-primary);flex:1}.attendance-actions{margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-color)}.attendance-actions button{width:100%;justify-content:center}.attendance-actions button.btn-outline{background-color:transparent;border:1px solid var(--error-light);color:var(--error-light)}.attendance-actions button.btn-outline:hover{background-color:#ef44441a}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--space-4)}.loading-container p{color:var(--text-secondary);font-size:var(--text-sm)}.event-form input:focus-visible,.event-form textarea:focus-visible{outline:2px solid var(--primary-500);outline-offset:2px}@media(max-width:1280px){.table{min-width:900px}}@media(max-width:768px){.table{min-width:800px}.modal{max-width:100%;max-height:100%;border-radius:0}}.calendar-events-view{max-width:100%}.calendar-events-container{display:grid;grid-template-columns:400px 1fr;gap:var(--space-6);align-items:start}.calendar-section{background:var(--surface-card);border-radius:8px;padding:var(--space-4);border:1px solid var(--border-color);box-shadow:var(--card-shadow);position:sticky;top:var(--space-4);height:-moz-fit-content;height:fit-content;transition:box-shadow var(--transition-normal)}.calendar-section:hover{box-shadow:var(--card-shadow-hover)}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.calendar-month{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.calendar-nav-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border-color);background:var(--surface-card);color:var(--text-secondary);border-radius:6px;cursor:pointer;transition:all var(--transition-fast)}.calendar-nav-btn:hover{background:var(--surface-hover);border-color:var(--border-hover);color:var(--text-primary)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--space-2)}.calendar-day-header{text-align:center;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-secondary);padding:var(--space-1)}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border:1px solid var(--border-color);background:var(--surface-card);color:var(--text-primary);border-radius:6px;cursor:pointer;transition:all var(--transition-fast);position:relative;font-size:var(--text-xs);font-weight:var(--font-medium);min-height:32px}.calendar-day:hover{background:var(--surface-hover);border-color:var(--border-hover)}.calendar-day.empty{border:none;background:transparent;cursor:default}.calendar-day.today{background:var(--primary-500);border-color:var(--primary-500);color:var(--text-inverse);font-weight:var(--font-semibold)}.calendar-day.today:hover{background:var(--primary-600);border-color:var(--primary-600)}.calendar-day.selected{background:var(--primary-500);border-color:var(--primary-500);color:var(--text-inverse);font-weight:var(--font-semibold)}.calendar-day.selected:hover{background:var(--primary-600);border-color:var(--primary-600)}.calendar-day.has-events{border-color:var(--primary-400)}.calendar-day.has-events .event-dot{position:absolute;bottom:4px;width:4px;height:4px;border-radius:50%;background:var(--primary-400)}.calendar-day.selected .event-dot,.calendar-day.today .event-dot{background:var(--text-inverse)}.events-section{min-width:0;background:var(--surface-card);border-radius:8px;padding:0;border:1px solid var(--border-color);box-shadow:var(--card-shadow);height:-moz-fit-content;height:fit-content;transition:box-shadow var(--transition-normal);display:flex;flex-direction:column}.events-section:hover{box-shadow:var(--card-shadow-hover)}.events-section-title{padding:var(--space-4) var(--space-5);text-align:left;font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.5px;color:var(--gray-600);background:var(--surface-bg);border-bottom:1px solid var(--border-color);white-space:nowrap;margin:0}.events-section-content{padding:var(--space-4);flex:1;display:flex;flex-direction:column}.events-section:has(.empty-state){min-height:calc((var(--space-4) * 2) + (32px * 6) + (var(--space-2) * 42) + var(--space-4))}.events-list{display:flex;flex-direction:column;gap:var(--space-4)}.event-card{background:var(--surface-card);border:1px solid var(--border-color);border-left-width:4px;border-radius:8px;padding:var(--space-5);transition:all var(--transition-fast)}.event-card:hover{border-color:var(--border-hover);box-shadow:var(--card-shadow-hover)}.event-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-3)}.event-card-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0;flex:1;margin-right:var(--space-3)}.event-card-actions{display:flex;gap:var(--space-1)}.event-card-description{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--space-4)}.event-card-meta{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.event-meta-row{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary)}.event-meta-row svg{color:var(--text-muted);flex-shrink:0}.info-btn{background:transparent;border:none;color:var(--primary-500);cursor:pointer;padding:4px;font-size:14px;margin-left:var(--space-2);transition:color var(--transition-fast)}.info-btn:hover{color:var(--primary-600)}.event-attendance{padding-top:var(--space-4);border-top:1px solid var(--border-color)}.event-attendance button{height:36px;font-size:var(--text-sm)}.calendar-events-view .empty-state-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin:0 auto var(--space-6);background:var(--gray-50);border-radius:var(--radius-full);color:var(--gray-400)}.calendar-events-view .empty-state-icon svg{width:40px;height:40px}.calendar-events-view .event-form{display:flex;flex-direction:column;gap:var(--space-5)}.calendar-events-view .select-all-bases{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);color:var(--text-secondary);font-size:var(--text-sm)}.calendar-events-view .select-all-bases input{accent-color:var(--primary-500)}.calendar-events-view .form-group input,.calendar-events-view .form-group textarea{padding:var(--space-3);border:1px solid var(--border-color);background:var(--surface-card);color:var(--text-primary);border-radius:6px;font-size:var(--text-sm);transition:all var(--transition-fast)}.calendar-events-view .form-group input:focus,.calendar-events-view .form-group textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #3b82f61a}.calendar-events-view .form-group input::-moz-placeholder,.calendar-events-view .form-group textarea::-moz-placeholder{color:var(--text-muted)}.calendar-events-view .form-group input::placeholder,.calendar-events-view .form-group textarea::placeholder{color:var(--text-muted)}.calendar-events-view .color-picker{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-top:var(--space-1)}.calendar-events-view .color-swatch{width:28px;height:28px;border-radius:6px;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);border:2px solid transparent;padding:0}.calendar-events-view .color-swatch:hover{transform:scale(1.15);box-shadow:var(--shadow-md)}.calendar-events-view .color-swatch.selected{border-color:var(--surface-card)!important;box-shadow:0 0 0 1px var(--border-color),0 0 0 3px var(--surface-card)}.calendar-events-view .location-type-toggle{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.calendar-events-view .toggle-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border:1px solid var(--border-color);background:var(--surface-card);color:var(--text-secondary);border-radius:6px;cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast)}.calendar-events-view .toggle-btn:hover{background:var(--surface-hover);border-color:var(--border-hover)}.calendar-events-view .toggle-btn.active{background:var(--primary-500);border-color:var(--primary-500);color:var(--text-inverse)}.calendar-events-view .bases-selection{margin-top:var(--space-2)}.calendar-events-view .bases-checkboxes{display:flex;flex-direction:column;gap:var(--space-2);max-height:200px;overflow-y:auto;padding:var(--space-2);border:1px solid var(--border-color);border-radius:6px;background:var(--surface-card)}.calendar-events-view .base-checkbox-label{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);cursor:pointer;border-radius:6px;transition:background var(--transition-fast)}.calendar-events-view .base-checkbox-label:hover{background:var(--surface-hover)}.calendar-events-view .base-checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-500)}.calendar-events-view .base-checkbox-label span{color:var(--text-primary);font-size:var(--text-sm)}.calendar-events-view .custom-multi-select{position:relative;width:100%}.calendar-events-view .custom-multi-select-button{display:flex;align-items:center;justify-content:space-between;width:100%;text-align:left;cursor:pointer;padding-right:var(--space-4)}.calendar-events-view .custom-multi-select-placeholder{color:var(--text-muted)}.calendar-events-view .custom-multi-select-chevron{flex-shrink:0;transition:transform var(--transition-fast);color:var(--text-secondary)}.calendar-events-view .custom-multi-select-chevron-open{transform:rotate(180deg)}.calendar-events-view .custom-multi-select-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:var(--space-1);background:var(--surface-card);border:1px solid var(--border-color);border-radius:6px;box-shadow:var(--shadow-lg);z-index:1000;max-height:240px;overflow-y:auto;display:flex;flex-direction:column}.calendar-events-view .custom-multi-select-empty{padding:var(--space-3) var(--space-4);color:var(--text-muted);font-size:var(--text-sm);text-align:center}.calendar-events-view .custom-multi-select-option{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:transparent;border:none;color:var(--text-primary);font-size:var(--text-base);text-align:left;cursor:pointer;transition:background-color var(--transition-fast)}.calendar-events-view .custom-multi-select-option:hover,.calendar-events-view .custom-multi-select-option-selected{background-color:var(--surface-hover)}.calendar-events-view .custom-multi-select-checkbox{display:flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0;border:2px solid var(--border-color);border-radius:4px;background:transparent;transition:all var(--transition-fast)}.calendar-events-view .custom-multi-select-option-selected .custom-multi-select-checkbox{border-color:var(--primary-500);background:var(--primary-500);color:#fff}.calendar-events-view .custom-multi-select-option:first-child{border-top-left-radius:6px;border-top-right-radius:6px}.calendar-events-view .custom-multi-select-option:last-child{border-bottom-left-radius:6px;border-bottom-right-radius:6px}.calendar-events-view .custom-date-picker{position:relative;width:100%}.calendar-events-view .custom-date-picker-button{display:flex;align-items:center;gap:var(--space-2);width:100%;text-align:left;cursor:pointer}.calendar-events-view .custom-date-picker-placeholder{color:var(--text-muted)}.calendar-events-view .custom-date-picker-dropdown{position:absolute;bottom:100%;left:0;margin-bottom:var(--space-1);background:var(--surface-card);border:1px solid var(--border-color);border-radius:6px;box-shadow:var(--shadow-lg);z-index:1000;width:280px;padding:var(--space-3)}.calendar-events-view .custom-date-picker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.calendar-events-view .custom-date-picker-month-year{font-weight:var(--font-semibold);color:var(--text-primary);font-size:var(--text-base)}.calendar-events-view .custom-date-picker-nav{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:4px;transition:all var(--transition-fast)}.calendar-events-view .custom-date-picker-nav:hover{background:var(--surface-hover);color:var(--text-primary)}.calendar-events-view .custom-date-picker-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--space-1);margin-bottom:var(--space-2)}.calendar-events-view .custom-date-picker-weekday{text-align:center;font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-secondary);padding:var(--space-1)}.calendar-events-view .custom-date-picker-days{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--space-1)}.calendar-events-view .custom-date-picker-day{aspect-ratio:1;border:none;background:transparent;color:var(--text-primary);font-size:var(--text-sm);cursor:pointer;border-radius:4px;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.calendar-events-view .custom-date-picker-day:hover:not(.empty):not(.past):not(:disabled){background:var(--surface-hover);color:var(--text-primary)}.calendar-events-view .custom-date-picker-day.today{background:var(--primary-500);color:var(--text-inverse);font-weight:var(--font-semibold)}.calendar-events-view .custom-date-picker-day.today:hover:not(:disabled){background:var(--primary-600)}.calendar-events-view .custom-date-picker-day.selected{background:var(--primary-600);color:var(--text-inverse);font-weight:var(--font-semibold)}.calendar-events-view .custom-date-picker-day.selected:hover:not(:disabled){background:var(--primary-700)}.calendar-events-view .custom-date-picker-day.past{color:var(--text-muted);cursor:not-allowed}.calendar-events-view .custom-date-picker-day:disabled{opacity:.4;cursor:not-allowed}.calendar-events-view .custom-date-picker-day.empty{cursor:default}.calendar-events-view .custom-date-picker-footer{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border-color);display:flex;justify-content:center}.calendar-events-view .custom-date-picker-today{padding:var(--space-2) var(--space-4);background:transparent;border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast)}.calendar-events-view .custom-date-picker-today:hover{background:var(--surface-hover);border-color:var(--primary-500);color:var(--primary-500)}.calendar-events-view .delete-modal-content{text-align:center;padding:var(--space-2) 0}.calendar-events-view .delete-modal-icon{display:flex;justify-content:center;margin-bottom:var(--space-4);color:var(--error-light)}.calendar-events-view .delete-modal-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-3) 0}.calendar-events-view .delete-modal-description{font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0 0 var(--space-5) 0}.calendar-events-view .modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-5)}.calendar-events-view .delete-modal-actions{justify-content:center}@media(max-width:1024px){.calendar-events-container{grid-template-columns:1fr;gap:var(--space-4)}.calendar-section{position:static}}@media(max-width:768px){.calendar-grid{gap:var(--space-1)}.calendar-day{font-size:var(--text-xs);min-height:28px}.calendar-day-header{font-size:10px;padding:4px 2px}.calendar-section{padding:var(--space-3)}.calendar-header{margin-bottom:var(--space-3)}.calendar-month{font-size:var(--text-base)}.calendar-nav-btn{width:32px;height:32px}.event-card{padding:var(--space-4)}.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.page-header .btn{width:100%}.calendar-events-view .form-row{grid-template-columns:1fr}.calendar-events-view .modal-actions{flex-direction:column}.calendar-events-view .modal-actions .btn{width:100%}.events-section-title,.event-card-title{font-size:var(--text-base)}}@media(max-width:480px){.page-title{font-size:var(--text-xl)}.calendar-section,.events-section,.event-card{padding:var(--space-3)}.calendar-nav-btn{width:28px;height:28px}.calendar-day{min-height:24px}}.google-drive-picker-dialog{max-width:600px;max-height:80vh}.picker-auth-prompt{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1rem;text-align:center}.picker-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1rem}.picker-breadcrumbs{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:1rem;flex-wrap:wrap}.picker-breadcrumb-btn{display:flex;align-items:center;padding:.25rem .5rem;background:transparent;border:none;color:var(--text-primary);font-size:var(--text-sm);cursor:pointer;border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.picker-breadcrumb-btn:hover{background:var(--surface-hover);color:var(--text-primary)}.picker-breadcrumb-separator{color:var(--text-secondary);flex-shrink:0}.picker-files-list{max-height:400px;overflow-y:auto}.picker-section{margin-bottom:1.5rem}.picker-section-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.picker-items{display:flex;flex-direction:column;gap:.25rem}.picker-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.picker-item:hover{background:var(--surface-hover);border-color:var(--border-hover)}.picker-folder{justify-content:space-between}.picker-file{position:relative}.picker-thumbnail{width:40px;height:40px;-o-object-fit:cover;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.picker-file-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.picker-item-info{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.picker-item-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.picker-item-meta{font-size:var(--text-xs);color:var(--text-secondary)}.picker-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem;color:var(--text-secondary);text-align:center}.picker-empty svg{opacity:.5}.communications-page{max-width:100%}.header-actions{display:flex;align-items:center;gap:var(--space-4)}.last-update{font-size:var(--text-sm);color:var(--text-secondary)}.filters-section{margin-bottom:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.year-filter-container{margin-bottom:var(--space-4);overflow-x:auto;-webkit-overflow-scrolling:touch}.year-filter-container.ecme-scrollbar{scrollbar-width:thin}.year-filter-scroll{display:flex;gap:var(--space-2);padding:var(--space-2) 0;min-width:-moz-min-content;min-width:min-content}.year-filter-button{padding:var(--space-2) var(--space-4);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;flex-shrink:0}.year-filter-button:hover{background:var(--surface-hover);border-color:var(--border-hover);color:var(--text-primary)}.year-filter-button.active{background:var(--primary-500);border-color:var(--primary-500);color:var(--text-inverse)}.filter-controls{position:relative;display:flex;gap:var(--space-2);align-items:center}.filter-toggle{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast)}.filter-toggle:hover{background:var(--surface-hover);border-color:var(--border-hover)}.filter-toggle.active{background:var(--primary-500);border-color:var(--primary-500);color:var(--text-inverse)}.filters-panel{position:absolute;top:calc(100% + var(--space-2));left:0;z-index:var(--z-dropdown);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;gap:var(--space-4);flex-wrap:wrap;align-items:flex-end;min-width:300px;box-shadow:var(--shadow-lg)}.filter-group{display:flex;flex-direction:column;gap:var(--space-2);min-width:150px}.filter-group label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.clear-filters{align-self:flex-end}.communications-list{display:flex;flex-direction:column;gap:var(--space-4)}.communication-card{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-3) var(--space-3) var(--space-2) var(--space-3);transition:all var(--transition-fast);cursor:default;box-shadow:var(--card-shadow)}.communication-card:hover{border-color:var(--border-hover);box-shadow:var(--card-shadow-hover)}.communication-card.dragging{opacity:.5;background:var(--primary-500)!important;cursor:grabbing}.communication-card[draggable=true]{cursor:move}.communication-card[draggable=true]:hover{cursor:grab}.card-header-inline{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);margin-bottom:var(--space-2)}.drag-handle{display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:grab;transition:color var(--transition-fast);flex-shrink:0;padding:var(--space-1);margin-right:var(--space-2)}.drag-handle:active{cursor:grabbing}.communication-card:hover .drag-handle{color:var(--text-secondary)}.card-title-wrapper{display:flex;align-items:center;gap:var(--space-2);flex:1;min-width:0}.type-icon{color:var(--primary-500);flex-shrink:0}.card-title-wrapper h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-header-right{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.priority-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.priority-normal{background:var(--gray-100);color:var(--text-secondary);border:1px solid var(--gray-200)}.priority-important{background:var(--warning-bg);color:var(--warning-dark);border:1px solid var(--warning-border)}.priority-urgent{background:var(--error-bg);color:var(--error-dark);border:1px solid var(--error-border)}.card-actions{display:flex;gap:var(--space-2)}.card-separator{height:1px;background:var(--border-color);margin-bottom:var(--space-1);margin-top:var(--space-1)}.card-footer{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-xs);color:var(--text-muted);padding-top:var(--space-1)}.created-by{flex:1}.inactive-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);background:var(--error-bg);color:var(--error-dark);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);gap:var(--space-4);color:var(--text-secondary)}.loading-spinner{width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--primary-500);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.user-search-input-wrapper .form-input.user-search-input{padding-left:52px!important;padding-right:44px!important}.radio-option{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-fast)}.radio-option:hover{background:var(--surface-hover);border-color:var(--border-hover)}.radio-option input[type=radio]{margin:0;cursor:pointer}.radio-option.priority-option{border:none!important;padding:var(--space-2) var(--space-3);font-weight:var(--font-medium);font-size:var(--text-sm);border-radius:var(--radius-lg);justify-content:center;min-width:85px;transition:all .15s ease;position:relative}.radio-option.priority-option:not(.selected){background:var(--gray-100);color:var(--text-secondary);border:1px solid var(--gray-200)!important}.radio-option.priority-option:not(.selected):hover{background:var(--gray-200);border-color:var(--gray-300)!important;color:var(--text-primary)}.radio-option.priority-option.selected.priority-normal-selected{background:var(--gray-500);color:var(--text-inverse);border:none!important}.radio-option.priority-option.selected.priority-normal-selected:hover{background:var(--gray-600)}.radio-option.priority-option.selected.priority-important-selected{background:var(--warning-light);color:var(--text-inverse);border:none!important}.radio-option.priority-option.selected.priority-important-selected:hover{background:var(--warning-dark)}.radio-option.priority-option.selected.priority-urgent-selected{background:var(--error-light);color:var(--text-inverse);border:none!important}.radio-option.priority-option.selected.priority-urgent-selected:hover{background:var(--error-dark)}.file-upload-label{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4);background:var(--surface-card);border:2px dashed var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);color:var(--text-secondary)}.file-info{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);background:var(--gray-100);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--text-secondary)}.remove-file{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:var(--space-1);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast)}.remove-file:hover{background:var(--error-bg);color:var(--error-dark)}.url-input-group{display:flex;gap:var(--space-2)}.url-validation-result{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);font-size:var(--text-sm)}.url-validation-result.valid{background:var(--success-bg);color:var(--success-dark);border:1px solid var(--success-border)}.url-validation-result.invalid{background:var(--error-bg);color:var(--error-dark);border:1px solid var(--error-border)}.form-hint{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}.target-selection{display:flex;flex-direction:column;gap:var(--space-5);padding:var(--space-5);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);margin-top:var(--space-2)}.user-search-input-wrapper .search-icon{position:absolute;left:12px;color:var(--text-muted);pointer-events:none;z-index:1}.user-search-input-wrapper .search-spinner{position:absolute;right:12px;color:var(--text-muted);pointer-events:none}.user-list-container{display:flex;flex-direction:column;gap:var(--space-2)}.user-list-header{font-size:var(--text-xs);color:var(--text-muted);padding:var(--space-1) var(--space-2)}.user-search-empty{padding:var(--space-4);text-align:center;color:var(--text-secondary);font-size:var(--text-sm);background:var(--gray-100);border-radius:var(--radius-lg)}.selected-users-summary{padding:var(--space-2) var(--space-3);background:var(--info-bg);border:1px solid var(--info-border);border-radius:var(--radius-lg);font-size:var(--text-sm)}.checkbox-group{display:flex;flex-direction:column;gap:var(--space-2);max-height:300px;overflow-y:auto;padding:var(--space-2);background:var(--gray-100);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.checkbox-group.user-list{max-height:300px}.checkbox-option{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.checkbox-option:hover{background:var(--gray-200)}.checkbox-option input[type=checkbox]{margin:0;cursor:pointer;width:18px;height:18px;accent-color:var(--primary-500);flex-shrink:0}.checkbox-option span{flex:1;font-size:var(--text-sm);color:var(--text-primary)}.spinner{animation:spin 1s linear infinite}.icon-picker-grid{display:flex;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-2);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.icon-picker-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:var(--gray-100);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);color:var(--text-secondary);flex-shrink:0}.icon-picker-button:hover{background:var(--gray-200);border-color:var(--gray-300);color:var(--text-primary);transform:translateY(-2px)}.icon-picker-button.selected{background:var(--info-bg);border-color:var(--primary-500);color:var(--primary-500)}.icon-picker-button.selected:hover{background:var(--info-bg);border-color:var(--primary-600)}.delete-confirmation{text-align:center;padding:var(--space-2) 0}.delete-confirmation-icon{display:flex;justify-content:center;margin-bottom:var(--space-4);color:var(--error-dark)}.delete-confirmation-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-3) 0}.delete-confirmation-message{font-size:var(--text-base);color:var(--text-secondary);line-height:1.6;margin:0 0 var(--space-5) 0}.delete-confirmation-message strong{color:var(--text-primary);font-weight:var(--font-semibold)}.delete-confirmation-details{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-4);margin-top:var(--space-4);text-align:left}.delete-confirmation-detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0;border-bottom:1px solid var(--border-color)}.delete-confirmation-detail-row:last-child{border-bottom:none;padding-bottom:0}.detail-label{font-size:var(--text-sm);color:var(--text-muted);font-weight:var(--font-medium)}.detail-value{font-size:var(--text-sm);color:var(--text-primary);font-weight:var(--font-medium)}.view-message-content{display:flex;flex-direction:column;gap:var(--space-5)}.message-full-text{padding:var(--space-4);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-base);line-height:1.6;max-height:400px;overflow-y:auto}.message-full-text p{margin:0;word-wrap:break-word}.view-message-meta{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.view-meta-row{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}.meta-label{font-size:var(--text-sm);color:var(--text-muted);font-weight:var(--font-medium)}.meta-value{font-size:var(--text-sm);color:var(--text-primary);font-weight:var(--font-medium)}.view-pdf-content{display:flex;flex-direction:column;gap:var(--space-4)}.file-info-section{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-4);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.file-info-header{display:flex;align-items:flex-start;gap:var(--space-3)}.file-info-header .storage-icon{color:var(--primary-500);flex-shrink:0;margin-top:2px}.file-info-details{display:flex;flex-direction:column;gap:var(--space-1);flex:1}.file-name-large{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.file-name-clickable{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--primary-500);background:transparent;border:none;padding:0;cursor:pointer;text-align:left;transition:color var(--transition-fast);text-decoration:underline;text-decoration-color:transparent;transition:all var(--transition-fast)}.file-name-clickable:hover{color:var(--primary-600);text-decoration-color:var(--primary-600)}.file-size-large{font-size:var(--text-sm);color:var(--text-secondary)}.storage-type-label{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}@media(max-width:768px){.header-actions{flex-direction:column;align-items:stretch}.filters-panel{position:static;box-shadow:none}.card-header-inline{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.card-header-right{width:100%;justify-content:space-between}.communication-card{padding:var(--space-4)}.year-filter-scroll{flex-wrap:nowrap}.filter-controls{flex-wrap:wrap}}@media(max-width:480px){.card-actions{flex-wrap:wrap}.card-footer{flex-direction:column;align-items:flex-start;gap:var(--space-1)}}.create-communication-page{padding:var(--space-6);max-width:1200px;margin:0 auto;background-color:var(--surface-bg);min-height:100vh}.header-content{display:flex;align-items:center;gap:var(--space-4)}.back-button{display:flex;align-items:center;gap:var(--space-2);background-color:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);color:var(--text-secondary);transition:all var(--transition-fast)}.back-button:hover{background-color:var(--surface-hover);border-color:var(--gray-300);color:var(--text-primary)}.form-container{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--card-shadow)}.form-content{display:flex;flex-direction:column;gap:var(--space-5)}.radio-group{display:flex;gap:var(--space-4);flex-wrap:wrap}.radio-option{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.radio-option:hover{background:var(--surface-hover);border-color:var(--gray-300)}.radio-option input[type=radio]{margin:0;cursor:pointer;accent-color:var(--primary-500)}.radio-option input[type=radio]:checked+svg,.radio-option input[type=radio]:checked~span{color:var(--primary-500)}.radio-option.priority-option{border:1px solid var(--border-color)!important;padding:var(--space-2) var(--space-3);font-weight:var(--font-medium);font-size:var(--text-sm);border-radius:var(--radius-md);justify-content:center;min-width:85px;transition:all .15s ease;position:relative;background:var(--surface-card);color:var(--text-secondary)}.radio-option.priority-option input[type=radio]{position:absolute;opacity:0;pointer-events:none;width:0;height:0}.radio-option.priority-option span{border:none!important;background:none!important;padding:0!important;border-radius:0!important;font-size:inherit!important;font-weight:inherit!important;text-transform:none!important;color:inherit!important;display:inline;white-space:nowrap}.radio-option.priority-option:not(.selected):hover{background:var(--surface-hover);border-color:var(--gray-300)!important;color:var(--text-primary)}.radio-option.priority-option.selected.priority-normal-selected{background:#6b7280;color:#fff;border-color:#6b7280!important}.radio-option.priority-option.selected.priority-normal-selected:hover{background:#4b5563;border-color:#4b5563!important}.radio-option.priority-option.selected.priority-important-selected{background:#f97316;color:#fff;border-color:#f97316!important}.radio-option.priority-option.selected.priority-important-selected:hover{background:#ea580c;border-color:#ea580c!important}.radio-option.priority-option.selected.priority-urgent-selected{background:#ef4444;color:#fff;border-color:#ef4444!important}.radio-option.priority-option.selected.priority-urgent-selected:hover{background:#dc2626;border-color:#dc2626!important}.file-upload-area{display:flex;flex-direction:column;gap:var(--space-2)}.file-input{display:none}.file-upload-label{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4);background:var(--surface-card);border:2px dashed var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);color:var(--text-secondary)}.file-upload-label:hover{border-color:var(--primary-500);background:var(--surface-hover);color:var(--text-primary)}.file-info{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);background:var(--surface-hover);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-secondary)}.remove-file{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:var(--space-1);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.remove-file:hover{background:var(--error-bg);color:var(--error-light)}.url-input-group{display:flex;gap:var(--space-2);align-items:flex-start}.url-input-group .form-input{flex:1}.url-validation-result{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);margin-top:var(--space-2)}.url-validation-result.valid{background:var(--success-bg);color:var(--success-light);border:1px solid var(--success-border)}.url-validation-result.invalid{background:var(--error-bg);color:var(--error-light);border:1px solid var(--error-border)}.icon-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:var(--space-2);margin-top:var(--space-2)}.icon-picker-button{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);color:var(--text-muted)}.icon-picker-button:hover{background:var(--surface-hover);border-color:var(--gray-300);color:var(--text-secondary)}.icon-picker-button.selected{background:var(--primary-50);border-color:var(--primary-500);color:var(--primary-500)}.target-selection{margin-top:var(--space-4);padding:var(--space-4);background:var(--surface-bg);border-radius:var(--radius-md);border:1px solid var(--border-color)}.user-search-container{display:flex;flex-direction:column;gap:var(--space-2)}.user-search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:var(--space-3);color:var(--text-muted);pointer-events:none}.user-search-input{padding-left:40px!important;padding-right:40px!important}.search-spinner{position:absolute;right:var(--space-3);color:var(--primary-500)}.user-list-container{max-height:300px;overflow-y:auto;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--surface-card);margin-top:var(--space-2)}.user-list-header{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-color);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);background:var(--surface-bg);position:sticky;top:0;z-index:1}.checkbox-group{display:flex;flex-direction:column}.checkbox-option{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);border-bottom:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast);color:var(--text-primary)}.checkbox-option:last-child{border-bottom:none}.checkbox-option:hover{background:var(--surface-hover)}.checkbox-option input[type=checkbox]{margin:0;cursor:pointer;accent-color:var(--primary-500)}.user-search-empty{padding:var(--space-4);text-align:center;color:var(--text-muted);font-size:var(--text-sm)}.selected-users-summary{padding:var(--space-2) var(--space-3);background:var(--surface-hover);border-radius:var(--radius-md);font-size:var(--text-sm);border:1px solid var(--border-color)}.selected-count{color:var(--primary-500);font-weight:var(--font-medium)}.form-hint{font-size:var(--text-xs);color:var(--text-muted)}.form-footer{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--border-color)}@media(max-width:768px){.create-communication-page,.form-container{padding:var(--space-4)}.header-content{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.radio-group{flex-direction:column;width:100%}.radio-option{width:100%;justify-content:flex-start}.url-input-group{flex-direction:column}.url-input-group .form-input{width:100%}.form-footer{flex-direction:column}.form-footer button{width:100%}}@media(max-width:480px){.create-communication-page,.form-container{padding:var(--space-3)}.icon-picker-grid{grid-template-columns:repeat(auto-fill,minmax(40px,1fr))}.icon-picker-button{width:40px;height:40px}}.document-categories{max-width:100%}.document-categories .header-status{display:flex;align-items:center;gap:var(--space-3)}.document-categories .last-update-badge{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--surface-elevated);border:1px solid var(--border-color);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--text-secondary)}.document-categories .section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);margin-bottom:var(--space-6)}.document-categories .section-actions,.document-categories .section-info{display:flex;align-items:center;gap:var(--space-3)}.document-categories .section-text{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.document-categories .section-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-lg);color:#fff}.document-categories .section-icon.gradient-blue{background:linear-gradient(135deg,var(--primary-500),var(--primary-600))}.document-categories .section-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0;width:100%;padding:0;border:0;text-transform:none;letter-spacing:normal}.document-categories .section-description{font-size:var(--text-sm);color:var(--text-secondary);margin:8px 0 0;width:100%;padding-left:0;padding-right:0;padding-top:8px;border-top:1px solid var(--border-color)}.document-categories .categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-4)}.document-categories .category-card{background:var(--surface-card);border:2px solid;border-radius:var(--radius-xl);padding:var(--space-5);transition:all var(--transition-fast);animation:fadeInUp var(--transition-normal) forwards;opacity:0;position:relative;overflow:hidden;display:flex;flex-direction:column}.document-categories .category-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);opacity:1}.document-categories .category-card-header{display:flex;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-4)}.document-categories .category-drag-handle{display:flex;align-items:center;justify-content:center;color:var(--text-secondary);cursor:grab;padding:var(--space-1);margin-left:calc(var(--space-2) * -1);transition:color var(--transition-fast)}.document-categories .category-drag-handle:hover{color:var(--text-primary)}.document-categories .category-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-lg);color:#fff;flex-shrink:0}.document-categories .category-info{flex:1;min-width:0}.document-categories .category-name{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-1) 0}.document-categories .category-icon-label{display:inline-block;padding:var(--space-1) var(--space-2);background:var(--surface-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--text-xs);font-family:var(--font-mono);color:var(--primary-400)}.document-categories .category-description{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-4) 0;line-height:1.5}.document-categories .category-card-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-color);margin-top:auto;flex-shrink:0}.document-categories .category-meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-secondary)}.document-categories .category-actions{display:flex;gap:var(--space-2);flex-shrink:0}.document-categories .empty-state-card{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);background:var(--surface-card);border:1px dashed var(--border-color);border-radius:var(--radius-xl);text-align:center}.document-categories .empty-icon{display:flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:var(--radius-full);color:#fff;margin-bottom:var(--space-5);opacity:.8}.document-categories .empty-state-card h3{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-2) 0}.document-categories .empty-state-card p{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-6) 0}.category-form{display:flex;flex-direction:column;gap:var(--space-5)}.color-select-value{display:flex;align-items:center;gap:var(--space-2)}.color-preview{width:16px;height:16px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.2);flex-shrink:0}.color-option{display:flex;align-items:center;gap:var(--space-2)}.document-categories .delete-confirmation{text-align:center;padding:var(--space-2) 0}.document-categories .delete-confirmation-icon{display:flex;justify-content:center;margin-bottom:var(--space-4);color:var(--error-light)}.document-categories .delete-confirmation-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-3) 0}.document-categories .delete-confirmation-message{font-size:var(--text-base);color:var(--text-secondary);line-height:1.6;margin:0 0 var(--space-5) 0}.document-categories .delete-confirmation-message strong{color:var(--text-primary);font-weight:var(--font-semibold)}.document-categories .delete-confirmation-details{background:var(--surface-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-4);margin-top:var(--space-4);text-align:left}.document-categories .delete-confirmation-detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0;border-bottom:1px solid var(--border-color)}.document-categories .delete-confirmation-detail-row:last-child{border-bottom:none;padding-bottom:0}.document-categories .detail-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-medium)}.document-categories .detail-value{font-size:var(--text-sm);color:var(--text-primary);font-weight:var(--font-medium)}@media(max-width:1024px){.document-categories .page-header{flex-direction:column;align-items:stretch;gap:var(--space-4)}.document-categories .header-status{justify-content:flex-end}}@media(max-width:768px){.document-categories .section-header{flex-direction:column;align-items:stretch;gap:var(--space-4)}.document-categories .section-header .btn{width:100%}.categories-grid{grid-template-columns:1fr}}@media(max-width:640px){.category-form .form-row{grid-template-columns:1fr;gap:var(--space-4)}.document-categories .category-card-footer{flex-direction:column;gap:var(--space-3)}.document-categories .category-actions{width:100%}.document-categories .category-actions .action-btn{flex:1}}.document-library-page{width:100%}.document-library-page .header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-4)}.document-library-page .header-actions{display:flex;align-items:center;gap:var(--space-4)}.document-library-page .last-update{font-size:var(--text-sm);color:var(--text-muted)}.breadcrumb-nav{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.breadcrumb-link{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);background:var(--surface-card);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.breadcrumb-link:hover{background:var(--surface-hover);border-color:var(--border-hover);color:var(--text-primary)}.breadcrumb-separator{color:var(--text-muted);flex-shrink:0}.breadcrumb-current{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-medium)}.header-title-section{display:flex;flex-direction:column;gap:var(--space-2)}.document-library-page .filters-section{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-bottom:var(--space-6)}.document-library-page .filter-controls{display:flex;align-items:flex-start;gap:var(--space-3);flex-wrap:wrap}.document-library-page .filter-toggle{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast)}.document-library-page .filter-toggle:hover{border-color:var(--border-hover);color:var(--text-primary);background:var(--surface-hover)}.document-library-page .filter-toggle.active{background:var(--primary-500);border-color:var(--primary-500);color:var(--text-inverse)}.document-library-page .filters-panel{display:flex;gap:var(--space-4);align-items:flex-end;padding:var(--space-4);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.document-library-page .filter-group{display:flex;flex-direction:column;gap:var(--space-2);min-width:150px}.document-library-page .filter-group label{font-size:var(--text-xs);color:var(--text-secondary);font-weight:var(--font-medium)}.categories-grid{width:100%}.categories-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.category-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.category-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.category-card .category-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:var(--radius-lg);color:#fff;flex-shrink:0;background:var(--category-color, #3b82f6)}.category-card .category-info{flex:1;display:flex;flex-direction:column;gap:var(--space-1);min-width:0}.category-card .category-name{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.category-card .category-count{font-size:var(--text-sm);color:var(--text-secondary)}.category-card .category-arrow{color:var(--text-muted);flex-shrink:0;transition:transform var(--transition-fast)}.category-card:hover .category-arrow{transform:translate(4px);color:var(--text-secondary)}.category-card.uncategorized .category-icon{background:var(--gray-500)}.documents-list{display:flex;flex-direction:column;gap:var(--space-2)}.document-card{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:.375rem var(--space-4);transition:all var(--transition-fast);min-height:0}.document-card[draggable=true]{cursor:move}.document-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md);background:var(--surface-hover)}.document-card.expired{opacity:.7;border-color:var(--error-light)}.document-card.dragging{opacity:.5;background:var(--primary-500)!important}.document-card .card-content{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);min-height:0}.document-card .card-left{display:flex;align-items:center;gap:var(--space-2);flex:1;min-width:0}.document-card .drag-handle{display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:grab;transition:color var(--transition-fast);padding:var(--space-1);flex-shrink:0}.document-card .drag-handle:active{cursor:grabbing}.document-card:hover .drag-handle{color:var(--text-secondary)}.document-card .category-badge{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);color:#fff;flex-shrink:0}.document-card .title-info{flex:1;min-width:0}.document-card .document-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0;padding:0;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.document-card .document-subtitle{font-size:var(--text-sm);color:var(--text-muted);font-style:italic}.document-card .card-right{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.document-card .document-badges{display:flex;align-items:center;gap:var(--space-2)}.document-card .notify-badge{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-full);background:var(--surface-elevated);color:var(--text-muted)}.document-card .notify-badge.active{background:var(--success-bg);color:var(--success-light)}.document-card .notify-badge.warning{background:var(--warning-bg);color:var(--warning-light)}.document-card .expiry-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.document-card .expiry-badge.warning{background:var(--warning-bg);color:var(--warning-light)}.document-card .expiry-badge.expired{background:var(--error-bg);color:var(--error-light)}.document-card .card-actions{display:flex;gap:var(--space-1)}.document-form{display:flex;flex-direction:column;gap:var(--space-5)}.document-form .form-hint{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}.document-form .form-actions{display:flex;justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-4);border-top:1px solid var(--border-color)}.document-details{display:flex;flex-direction:column;gap:var(--space-4);text-align:left}.document-details .detail-row{display:flex;flex-direction:column;gap:var(--space-1);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-color);text-align:left}.document-details .detail-row:last-child{border-bottom:none;padding-bottom:0}.document-details .detail-label{font-size:var(--text-xs);color:var(--text-secondary);font-weight:var(--font-medium);text-align:left}.document-details .detail-value{font-size:var(--text-sm);color:var(--text-primary);text-align:left;word-wrap:break-word;overflow-wrap:break-word}.document-details .detail-link{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);color:var(--primary-500);text-decoration:none;text-align:left}.document-details .detail-link:hover{text-decoration:underline}.document-library-page .delete-confirmation{text-align:center;padding:var(--space-4) 0}.document-library-page .delete-confirmation-icon{display:flex;justify-content:center;margin-bottom:var(--space-4);color:var(--error-light)}.document-library-page .delete-confirmation-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-3) 0}.document-library-page .delete-confirmation-message{font-size:var(--text-base);color:var(--text-secondary);line-height:1.6;margin:0}.document-library-page .delete-confirmation-message strong{color:var(--text-primary)}@media(max-width:768px){.document-library-page .header-content{flex-direction:column;align-items:stretch}.document-library-page .header-actions{justify-content:space-between}.document-library-page .filters-panel{flex-direction:column;width:100%}.document-library-page .filter-group{width:100%}.document-card .card-content{flex-wrap:wrap}.document-card .card-right{width:100%;justify-content:space-between;margin-top:var(--space-2)}.categories-list{grid-template-columns:1fr}}.document-details-page{width:100%}.document-details-page .header-content{display:flex;align-items:center;gap:var(--space-4)}.document-details-page .back-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-lg);background:var(--surface-card);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.document-details-page .back-button:hover{background:var(--surface-elevated);color:var(--text-primary);border-color:var(--border-hover)}.document-details-page .header-title{display:flex;flex-direction:column;gap:var(--space-1)}.document-details-page .header-actions{display:flex;align-items:center;gap:var(--space-3)}.details-content{display:grid;grid-template-columns:1fr;gap:var(--space-6);padding-bottom:var(--space-20)}.details-main-column,.details-side-column{display:flex;flex-direction:column;gap:var(--space-6)}@media(min-width:1024px){.details-content{grid-template-columns:1.8fr 1fr;align-items:start}}.section-card{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6)}.section-header-inner{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-color)}.section-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-lg);color:#fff;flex-shrink:0}.section-icon.gradient-blue{background:linear-gradient(135deg,var(--primary-500),var(--primary-600))}.section-icon.gradient-purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.section-icon.gradient-green{background:linear-gradient(135deg,var(--success-light),var(--success-dark))}.section-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-1) 0}.section-description{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.section-header-inner .btn-sm{margin-left:auto}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-5)}.form-grid .form-group.full-width{grid-column:1 / -1}.category-option{display:flex;align-items:center;gap:var(--space-2)}.category-color{width:12px;height:12px;border-radius:var(--radius-sm);flex-shrink:0}.notify-option{display:flex;align-items:center;gap:var(--space-2)}.empty-section{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);text-align:center;color:var(--text-secondary)}.empty-section svg{margin-bottom:var(--space-3);opacity:.5}.chapters-list{display:flex;flex-direction:column;gap:var(--space-2);max-height:600px;overflow-y:auto;padding-right:var(--space-2)}.chapters-list.ecme-scrollbar::-webkit-scrollbar{width:6px}.chapters-list.ecme-scrollbar::-webkit-scrollbar-track{background:var(--surface-card);border-radius:var(--radius-sm)}.chapters-list.ecme-scrollbar::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:var(--radius-sm)}.chapters-list.ecme-scrollbar::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}.chapter-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--surface-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.chapter-item:hover{border-color:var(--border-hover)}.chapter-drag{color:var(--text-secondary);cursor:grab}.chapter-number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-full);background:var(--primary-500);color:#fff;font-size:var(--text-xs);font-weight:var(--font-bold);flex-shrink:0}.chapter-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-1)}.chapter-title{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.chapter-file{font-size:var(--text-xs);color:var(--text-secondary)}.chapter-actions{display:flex;gap:var(--space-1)}.chapter-actions .icon-button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-md);background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.chapter-actions .icon-button:hover{background:var(--surface-card);color:var(--text-primary)}.chapter-actions .icon-button.danger:hover{background:var(--error-bg);color:var(--error-light)}.chapter-form{display:flex;flex-direction:column;gap:var(--space-5)}.target-section{display:flex;flex-direction:column;gap:var(--space-6)}.target-type-selector{display:flex;gap:var(--space-4);flex-wrap:wrap}.target-type-selector .radio-option{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--surface-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);flex:1;min-width:200px}.target-type-selector .radio-option:hover{border-color:var(--border-hover)}.target-type-selector .radio-option input{accent-color:var(--primary-500)}.target-type-selector .radio-option span{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.target-type-selector .radio-option svg{color:var(--text-secondary)}.target-options{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-5)}@media(min-width:1024px){.details-side-column .target-options{grid-template-columns:1fr}.details-side-column .target-type-selector{flex-direction:column}.details-side-column .target-type-selector .radio-option{min-width:unset}.details-side-column .chapters-list{max-height:500px}.details-side-column .chapter-item{padding:var(--space-2) var(--space-3)}.details-side-column .chapter-info{min-width:0}.details-side-column .chapter-title{font-size:var(--text-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}}.target-group{display:flex;flex-direction:column;gap:var(--space-2)}.user-search{display:flex;flex-direction:column;gap:var(--space-3)}.search-input-wrapper{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--surface-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md)}.search-input-wrapper svg{color:var(--text-secondary);flex-shrink:0}.search-input-wrapper .form-input{flex:1;background:transparent;border:none;padding:0}.search-input-wrapper .form-input:focus{outline:none;border:none}.document-details-page .delete-confirmation{text-align:center;padding:var(--space-4) 0}.document-details-page .delete-confirmation-icon{display:flex;justify-content:center;margin-bottom:var(--space-4);color:var(--error-light)}.document-details-page .delete-confirmation-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-3) 0}.document-details-page .delete-confirmation-message{font-size:var(--text-base);color:var(--text-secondary);line-height:1.6;margin:0}.document-details-page .delete-confirmation-message strong{color:var(--text-primary)}.document-footer{position:fixed;bottom:0;left:0;right:0;background:var(--surface-card);border-top:1px solid var(--border-color);padding:var(--space-4) var(--space-6);z-index:100;box-shadow:0 -4px 6px -1px #0000001a,0 -2px 4px -2px #0000001a}.footer-content{max-width:1400px;margin:0 auto;display:flex;justify-content:flex-end;gap:var(--space-3);align-items:center}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16);text-align:center;color:var(--text-secondary)}.error-container svg{margin-bottom:var(--space-4);opacity:.5}.error-container h3{font-size:var(--text-lg);color:var(--text-primary);margin:0 0 var(--space-4) 0}@media(max-width:768px){.document-details-page .page-header{flex-direction:column;align-items:stretch}.document-details-page .header-actions{justify-content:flex-end}.form-grid{grid-template-columns:1fr}.form-grid .form-group.full-width{grid-column:1}.target-options,.form-row{grid-template-columns:1fr}.document-footer{padding:var(--space-3) var(--space-4)}.footer-content{flex-direction:column-reverse;width:100%}.footer-content button{width:100%}}.rag-document-manager-page{width:100%}.rag-document-manager-page .upload-section{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);margin-bottom:var(--space-8)}.rag-document-manager-page .upload-label{display:block;font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-3)}.rag-document-manager-page .upload-progress{margin-top:var(--space-3);font-size:var(--text-sm);color:var(--primary-400);font-weight:var(--font-medium)}.rag-document-manager-page .documents-list{display:flex;flex-direction:column;gap:var(--space-4)}.rag-document-manager-page .document-item{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);transition:all var(--transition-fast)}.rag-document-manager-page .document-item:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.rag-document-manager-page .document-content{flex:1;min-width:0}.rag-document-manager-page .document-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:var(--space-1)}.rag-document-manager-page .document-meta{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-2)}.rag-document-manager-page .document-schema{font-size:var(--text-xs);color:var(--text-secondary);margin-bottom:var(--space-2);line-height:1.4}.rag-document-manager-page .document-status{font-size:var(--text-sm);margin-top:var(--space-1)}.rag-document-manager-page .status-text{font-weight:var(--font-semibold);color:var(--text-primary)}.rag-document-manager-page .status-error{color:var(--error-light);margin-left:var(--space-1)}.rag-document-manager-page .document-actions{display:flex;gap:var(--space-3);flex-shrink:0}.rag-document-manager-page .loading-state{padding:var(--space-6);text-align:center;color:var(--text-secondary);font-size:var(--text-sm)}.rag-document-manager-page .upload-hint{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-3)}.rag-document-manager-page .language-selector-row{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;margin-bottom:var(--space-3)}.rag-document-manager-page .language-selector-row .language-selector-label{font-size:var(--text-sm);color:var(--text-secondary);margin:0;line-height:1.5}.rag-document-manager-page .language-selector-row select.form-select{width:auto;min-width:120px}.rag-document-manager-page .progress-main{font-weight:var(--font-semibold);color:var(--primary-400);padding-top:var(--space-2)}.rag-document-manager-page .progress-detail{font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-1)}.rag-upload-summary-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4)}.rag-upload-summary-content{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);max-width:900px;width:100%;max-height:90vh;overflow:auto;box-shadow:var(--shadow-2xl)}.rag-document-manager-page .upload-summary-modal,.rag-upload-summary-content.upload-summary-modal{padding:var(--space-6)}.rag-document-manager-page .upload-summary-header,.rag-upload-summary-content .upload-summary-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-5)}.rag-document-manager-page .upload-summary-titlewrap,.rag-upload-summary-content .upload-summary-titlewrap{min-width:0}.rag-document-manager-page .upload-summary-title,.rag-upload-summary-content .upload-summary-title{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-1)}.rag-document-manager-page .upload-summary-subtitle,.rag-upload-summary-content .upload-summary-subtitle{font-size:var(--text-sm);color:var(--text-secondary);max-width:62ch;word-break:break-word}.rag-document-manager-page .upload-summary-actions,.rag-upload-summary-content .upload-summary-actions{display:flex;gap:var(--space-3);flex-shrink:0}.rag-document-manager-page .upload-summary-kv,.rag-upload-summary-content .upload-summary-kv{padding:var(--space-4);border:1px solid var(--border-color);border-radius:var(--radius-xl);background:var(--surface-elevated);margin-bottom:var(--space-5)}.rag-document-manager-page .upload-summary-kv-item,.rag-upload-summary-content .upload-summary-kv-item{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-4)}.rag-document-manager-page .upload-summary-kv-label,.rag-upload-summary-content .upload-summary-kv-label{font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.rag-document-manager-page .upload-summary-kv-value,.rag-upload-summary-content .upload-summary-kv-value{font-size:var(--text-sm);color:var(--text-primary)}.rag-document-manager-page .mono,.rag-upload-summary-content .mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.rag-document-manager-page .upload-summary-grid,.rag-upload-summary-content .upload-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.rag-document-manager-page .upload-summary-card,.rag-upload-summary-content .upload-summary-card{border:1px solid var(--border-color);border-radius:var(--radius-xl);background:var(--surface-card);padding:var(--space-4)}.rag-document-manager-page .upload-summary-card-label,.rag-upload-summary-content .upload-summary-card-label{font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-2)}.rag-document-manager-page .upload-summary-card-value,.rag-upload-summary-content .upload-summary-card-value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);line-height:1.1}.rag-document-manager-page .upload-summary-card-sub,.rag-upload-summary-content .upload-summary-card-sub{font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-2)}.rag-document-manager-page .upload-summary-section,.rag-upload-summary-content .upload-summary-section{border-top:1px solid var(--border-color);padding-top:var(--space-5)}.rag-document-manager-page .upload-summary-section-title,.rag-upload-summary-content .upload-summary-section-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-1)}.rag-document-manager-page .upload-summary-section-sub,.rag-upload-summary-content .upload-summary-section-sub{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-4)}.rag-document-manager-page .upload-summary-warning,.rag-upload-summary-content .upload-summary-warning{background:#eab3081f;border:1px solid rgba(234,179,8,.3);color:var(--text-primary);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);margin-bottom:var(--space-4)}.rag-document-manager-page .upload-summary-muted,.rag-upload-summary-content .upload-summary-muted{font-size:var(--text-sm);color:var(--text-secondary)}.rag-document-manager-page .upload-summary-accordions,.rag-upload-summary-content .upload-summary-accordions{display:flex;flex-direction:column;gap:var(--space-3)}.rag-document-manager-page .upload-summary-accordion,.rag-upload-summary-content .upload-summary-accordion{border:1px solid var(--border-color);border-radius:var(--radius-xl);background:var(--surface-card);overflow:hidden}.rag-document-manager-page .upload-summary-accordion-summary,.rag-upload-summary-content .upload-summary-accordion-summary{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);cursor:pointer;padding:var(--space-4);background:var(--surface-elevated);border-bottom:1px solid var(--border-color)}.rag-document-manager-page .upload-summary-accordion-title,.rag-upload-summary-content .upload-summary-accordion-title{color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-semibold);word-break:break-word;min-width:0}.rag-document-manager-page .upload-summary-accordion-meta,.rag-upload-summary-content .upload-summary-accordion-meta{color:var(--text-secondary);font-size:var(--text-xs);flex-shrink:0}.rag-document-manager-page .upload-summary-prose,.rag-upload-summary-content .upload-summary-prose{margin:0;padding:var(--space-4);background:var(--gray-900);color:var(--gray-200);font-size:var(--text-sm);line-height:1.55;max-height:360px;overflow:auto;white-space:pre-wrap;word-break:break-word}.rag-document-manager-page .upload-summary-table-wrap,.rag-upload-summary-content .upload-summary-table-wrap{overflow:auto;max-height:360px;border-top:1px solid var(--border-color)}.rag-document-manager-page .upload-summary-table,.rag-upload-summary-content .upload-summary-table{width:100%;border-collapse:collapse;font-size:var(--text-xs)}.rag-document-manager-page .upload-summary-table th,.rag-document-manager-page .upload-summary-table td,.rag-upload-summary-content .upload-summary-table th,.rag-upload-summary-content .upload-summary-table td{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-color);text-align:left;vertical-align:top}.rag-document-manager-page .upload-summary-table th,.rag-upload-summary-content .upload-summary-table th{position:sticky;top:0;background:var(--surface-elevated);z-index:1;font-weight:var(--font-semibold);color:var(--text-primary)}.rag-document-manager-page .upload-summary-table td,.rag-upload-summary-content .upload-summary-table td{color:var(--text-secondary);white-space:nowrap}@media(max-width:1024px){.rag-document-manager-page .document-item{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.rag-document-manager-page .document-actions{width:100%;justify-content:flex-end}}@media(max-width:768px){.rag-document-manager-page .page-header{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.rag-document-manager-page .page-title{font-size:var(--text-2xl)}.rag-document-manager-page .upload-section,.rag-document-manager-page .document-item{padding:var(--space-4)}.rag-document-manager-page .upload-summary-grid,.rag-upload-summary-content .upload-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:480px){.rag-document-manager-page .document-meta,.rag-document-manager-page .document-schema{font-size:var(--text-xs)}.rag-document-manager-page .btn-danger{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}.rag-document-manager-page .upload-summary-grid,.rag-upload-summary-content .upload-summary-grid{grid-template-columns:1fr}}.delete-confirmation{text-align:center;padding:var(--space-4) 0}.delete-confirmation-message strong{color:var(--text-primary)}.ai-management-page{width:100%}.ai-management-page .settings-grid{display:grid;gap:var(--space-6);grid-template-columns:1fr 1fr;margin-bottom:var(--space-8);align-items:stretch}.ai-management-page .settings-card{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;flex-direction:column;min-height:420px}.ai-management-page .global-settings-card{height:auto;min-height:290px}.ai-management-page .per-user-override{height:auto;min-height:290px;overflow:visible}.ai-management-page .settings-card.full-width{grid-column:1 / -1;min-height:auto}.ai-management-page .settings-card h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-3) 0}.ai-management-page .settings-card p{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-4) 0;line-height:1.5}.ai-management-page .form-field{display:flex;flex-direction:column;gap:var(--space-2)}.ai-management-page .input-group{display:flex;flex-direction:column;gap:var(--space-2);align-items:flex-start}.ai-management-page .form-actions{display:flex;gap:var(--space-3);margin-top:var(--space-2)}.ai-management-page .form-field-actions{align-items:flex-end;margin-top:auto}.ai-management-page .global-settings-form,.ai-management-page .user-override-form{flex:1;display:flex;flex-direction:column;margin-bottom:0}.ai-management-page .global-settings-form.inline{display:grid;grid-template-columns:repeat(2,minmax(240px,1fr));gap:var(--space-4)}.ai-management-page .global-settings-form.inline .form-field-actions{grid-column:1 / -1;align-items:flex-start}.ai-management-page .override-collapsed-note{font-size:var(--text-sm);color:var(--text-secondary);padding:var(--space-2) 0}.ai-management-page .override-row{display:flex;gap:var(--space-3);align-items:flex-start;flex-wrap:wrap}.ai-management-page .override-row .input-group{flex:1 1 200px}.ai-management-page .rag-settings-form{display:flex;flex-direction:column;gap:var(--space-6)}.ai-management-page .rag-settings-section h4{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-3) 0}.ai-management-page .rag-settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-4)}.ai-management-page .triple-input{display:grid;grid-template-columns:repeat(3,minmax(70px,1fr));gap:var(--space-2);align-items:center}.ai-management-page .inline-toggle{display:flex;flex-direction:row;align-items:center;gap:var(--space-3)}.ai-management-page .unsaved-alert{display:inline-flex;align-items:center;gap:var(--space-2);padding:4px 10px;border-radius:var(--radius-lg);background:#ef44441f;color:#b91c1c;font-size:var(--text-xs);font-weight:var(--font-semibold);border:1px solid rgba(239,68,68,.45)}.ai-management-page .delete-confirmation{text-align:center;padding:var(--space-2) 0}.ai-management-page .delete-confirmation-icon{display:flex;justify-content:center;margin-bottom:var(--space-4);color:var(--error-light)}.ai-management-page .delete-confirmation-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-3) 0}.ai-management-page .delete-confirmation-message{font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0}.ai-management-page .form-field-actions .form-actions{margin-top:0}.ai-management-page .form-field-actions .form-actions button{white-space:nowrap}.ai-management-page .current-value{font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-2)}.ai-management-page .default-value{margin-top:2px;font-size:var(--text-xs);color:var(--text-secondary)}.ai-management-page .current-value b{color:var(--text-primary)}.ai-management-page .user-select{width:100%}.ai-management-page .user-search-container{display:flex;flex-direction:column;gap:var(--space-2);position:relative;z-index:20}.ai-management-page .user-search-input-wrapper{position:relative;display:flex;align-items:center}.ai-management-page .user-search-dropdown{position:absolute;top:100%;left:0;right:0;z-index:50;margin-top:4px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:2px;max-height:220px;overflow-y:auto;padding:var(--space-2);border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-card)}.ai-management-page .user-search-option{text-align:left;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid transparent;background:var(--gray-100);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.ai-management-page .user-search-option:hover{border-color:var(--border-hover);background:var(--gray-200)}.ai-management-page .wide-search-bar{min-width:400px;max-width:600px}.ai-management-page .search-spinner{position:absolute;right:56px;width:14px;height:14px;border-radius:var(--radius-full);border:2px solid rgba(229,231,235,.5);border-top-color:var(--primary-500);animation:spin .8s linear infinite;pointer-events:none}.ai-management-page .form-hint{font-size:var(--text-xs);color:var(--text-secondary)}.ai-management-page .user-search-empty{font-size:var(--text-xs);color:var(--text-secondary);padding:var(--space-2) 0}.ai-management-page .override-info{font-size:var(--text-xs);color:var(--text-secondary)}.ai-management-page .chat-actions-row{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4);flex-wrap:wrap}.ai-management-page .chat-management-section{display:flex;flex-direction:column;gap:var(--space-6)}.ai-management-page .chat-grid{display:grid;gap:var(--space-6);grid-template-columns:1fr 1.5fr}.ai-management-page .chat-section{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);overflow:hidden}.ai-management-page .chat-section-header{margin-bottom:var(--space-4)}.ai-management-page .chat-section h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-2) 0}.ai-management-page .section-info{font-size:var(--text-sm);color:var(--text-secondary)}.ai-management-page .cleanup-section{margin-top:var(--space-4)}.ai-management-page .session-list{display:flex;flex-direction:column;gap:var(--space-2);max-height:400px;overflow-y:auto}.ai-management-page .session-item{padding:var(--space-4);background:var(--gray-100);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left;display:flex;flex-direction:column;gap:var(--space-1)}.ai-management-page .session-item:hover{border-color:var(--border-hover);background:var(--gray-200)}.ai-management-page .session-item.selected{border-color:var(--primary-500);background:#3b82f61a}.ai-management-page .session-title{font-weight:var(--font-semibold);font-size:var(--text-sm);color:var(--text-primary);margin-bottom:var(--space-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ai-management-page .session-date{font-size:var(--text-xs);color:var(--text-secondary)}.ai-management-page .session-item-top{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.ai-management-page .cleanup-list{display:flex;flex-direction:column;gap:var(--space-3)}.ai-management-page .cleanup-row{display:flex;gap:var(--space-4);justify-content:space-between;align-items:flex-start;padding:var(--space-4);background:var(--gray-100);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.ai-management-page .cleanup-row-title{font-size:var(--text-sm);color:var(--text-primary);margin-bottom:var(--space-1)}.ai-management-page .cleanup-row-meta{font-size:var(--text-xs);color:var(--text-secondary);margin-bottom:var(--space-1)}.ai-management-page .cleanup-row-id{font-size:var(--text-xs);color:var(--text-secondary);word-break:break-all}.ai-management-page .cleanup-row-actions{flex-shrink:0}.ai-management-page .message-list{display:flex;flex-direction:column;gap:var(--space-3);max-height:400px;overflow-y:auto}.ai-management-page .message-item{padding:var(--space-4);background:var(--gray-100);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.ai-management-page .message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.ai-management-page .message-role{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.5px;border-radius:var(--radius-full)}.ai-management-page .message-role.user{background-color:var(--success-bg);color:var(--success-light)}.ai-management-page .message-role.assistant{background-color:var(--gray-600);color:var(--text-inverse)}.ai-management-page .message-role.system{background-color:var(--error-bg);color:var(--error-light)}.ai-management-page .message-timestamp{font-size:var(--text-xs);color:var(--text-secondary)}.ai-management-page .message-content{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;white-space:pre-wrap;word-wrap:break-word}.ai-management-page .empty-state{padding:var(--space-8) var(--space-4)}@media(max-width:1024px){.ai-management-page .settings-grid,.ai-management-page .chat-grid{grid-template-columns:1fr;gap:var(--space-4)}.ai-management-page .page-title{font-size:var(--text-2xl)}.ai-management-page .form-label{min-width:180px}}@media(max-width:768px){.ai-management-page .page-header{margin-bottom:var(--space-6)}.ai-management-page .settings-card,.ai-management-page .chat-section{padding:var(--space-4)}.ai-management-page .form-field,.ai-management-page .input-group{align-items:stretch}.ai-management-page .session-list,.ai-management-page .message-list{max-height:300px}}.chat-sessions-page{width:100%;display:flex;flex-direction:column;min-height:800px;height:100%}.page-header{margin-bottom:var(--space-8)}.chat-sessions-content{display:grid;gap:var(--space-6);grid-template-columns:2fr 1fr;align-items:stretch;flex:1 1 auto;min-height:0;max-height:100%;overflow:hidden}.sessions-section{background:var(--surface-card);border:1px solid var(--border-color);border-radius:8px;padding:var(--space-6);overflow:hidden;display:flex;flex-direction:column;min-height:0;height:100%;box-shadow:var(--card-shadow)}.sessions-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4);flex:0 0 auto}.sessions-section h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.session-stats{font-size:var(--text-sm);color:var(--text-secondary)}.session-stats b{color:var(--text-primary)}.user-search-filter{margin-bottom:var(--space-4);flex:0 0 auto;display:flex;flex-direction:row;flex-wrap:wrap;gap:var(--space-2);align-items:center}.user-search-filter>.user-search-container{flex:1;min-width:200px;display:flex;flex-direction:column;gap:var(--space-2);position:relative;z-index:20}.user-search-filter>.user-search-actions{display:flex;gap:var(--space-2);align-items:center}.user-search-input-wrapper{position:relative}.user-search-input-wrapper .search-spinner{position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);width:16px;height:16px;border-radius:999px;border:2px solid var(--gray-200);border-top-color:var(--primary-500);animation:ecme-spin .8s linear infinite}.chat-sessions-page .user-search-dropdown{position:absolute;top:100%;left:0;right:0;z-index:50;margin-top:4px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:2px;max-height:220px;overflow-y:auto;padding:var(--space-2);border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-card)}.chat-sessions-page .user-search-option{text-align:left;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid transparent;background:var(--gray-100);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);width:100%}.chat-sessions-page .user-search-option:hover{border-color:var(--border-hover);background:var(--gray-200)}.chat-sessions-page .user-search-option.selected{background:var(--primary-50);border-color:var(--primary-200);color:var(--primary-700)}.delete-all-chats-btn{display:flex;align-items:center;gap:var(--space-2)}.user-search-empty{padding:var(--space-2);text-align:center;color:var(--text-secondary);font-size:var(--text-sm)}.form-hint{display:block;margin-top:var(--space-1);color:var(--text-secondary);font-size:var(--text-xs)}.table th.sortable-header{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background-color var(--transition-fast)}.table th.sortable-header:hover{background:var(--surface-hover)}.sort-icon{margin-left:var(--space-1);font-size:var(--text-xs);opacity:.7}.sort-icon.asc,.sort-icon.desc{color:var(--primary-500)}.table tbody tr.needs-attention{background:#ef44440d}.table tbody tr.needs-attention:hover{background:#ef44441a}.table tbody tr.selected{background:var(--surface-active);border-left:3px solid var(--primary-500)}.session-title-cell{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;max-width:300px;line-height:1.4}.user-cell{font-weight:var(--font-medium);color:var(--text-primary);max-width:200px;word-wrap:break-word}.user-info{display:flex;flex-direction:column;min-width:0}.user-name-row{display:flex;align-items:center;gap:var(--space-2);min-width:0}.user-info .user-name{font-weight:var(--font-medium);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.needs-attention-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.5px;border-radius:var(--radius-md);background:var(--error-bg);color:var(--error-dark);border:1px solid rgba(239,68,68,.5);white-space:nowrap}.user-info .user-email{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loading-row,.empty-row{text-align:center;padding:var(--space-8) var(--space-4);color:var(--text-secondary);font-size:var(--text-sm)}.loading-row{position:relative;height:300px;vertical-align:middle}.loading-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.pagination{display:flex;justify-content:center;align-items:center;gap:var(--space-2);margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--border-color);flex:0 0 auto}.pagination-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-medium);line-height:1;border-radius:var(--radius-lg);transition:all var(--transition-fast);cursor:pointer;white-space:nowrap;min-width:80px;background:var(--surface-card);color:var(--text-primary);border:1px solid var(--border-color)}.pagination-btn:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-300);color:var(--text-primary)}.pagination-btn.active{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));border-color:transparent;color:var(--text-inverse);box-shadow:0 4px 14px #3b82f659}.pagination-btn.active:hover{background:linear-gradient(135deg,var(--primary-400),var(--primary-500));box-shadow:0 6px 20px #3b82f673;transform:translateY(-1px)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-pages{display:flex;gap:var(--space-1)}.messages-section{background:var(--surface-card);border:1px solid var(--border-color);border-radius:8px;padding:var(--space-6);overflow:hidden;display:flex;flex-direction:column;min-height:0;height:100%;box-shadow:var(--card-shadow)}.messages-section .section-header{margin-bottom:var(--space-4);display:flex;align-items:center;justify-content:space-between;flex:0 0 auto}.messages-section h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.messages-section .section-info{font-size:var(--text-sm);color:var(--text-secondary)}.messages-container{flex:1 1 auto;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:var(--space-3);min-height:0}.messages-container::-webkit-scrollbar{width:8px;height:8px}.messages-container::-webkit-scrollbar-track{background:var(--surface-hover);border-radius:9999px}.messages-container::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:9999px;-webkit-transition:background var(--transition-fast);transition:background var(--transition-fast)}.messages-container::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}.message-item{padding:var(--space-4);background:var(--surface-card);border:1px solid var(--border-color);border-radius:8px;transition:all var(--transition-fast)}.message-item.user{border-color:var(--primary-300);background:var(--surface-active)}.message-item.assistant{border-color:var(--border-color);background:var(--surface-card)}.message-item.system{border-color:var(--error-border);background:var(--error-bg)}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.message-role{display:inline-flex;align-items:center;font-weight:var(--font-semibold);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.5px;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:var(--primary-500);color:var(--text-inverse)}.message-item.assistant .message-role{background:var(--gray-600);color:var(--text-inverse)}.message-item.system .message-role{background:var(--error-light);color:var(--text-inverse)}.message-timestamp{font-size:var(--text-xs);color:var(--text-secondary)}.message-content{font-size:var(--text-sm);color:var(--text-primary);line-height:1.5;white-space:pre-wrap;word-wrap:break-word;margin:0;font-family:inherit}.md-container{display:flex;flex-direction:column}.md-paragraph{margin:0 0 6px}.md-paragraph-no-bottom-gap{margin-bottom:0}.md-blank-line{height:8px}.md-list-top-spacing{margin-top:8px}.md-list-item-row{display:flex;align-items:flex-start;margin-bottom:4px}.md-list-item-row-nested{margin-left:16px}.md-list-label{min-width:22px;text-align:right;margin-right:8px}.md-list-label-nested{min-width:18px}.md-list-item-text{flex:1}.md-bold{font-weight:700}.md-italic{font-style:italic}.md-link{color:var(--primary-500);text-decoration:underline}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);text-align:center}.loading-spinner{width:24px;height:24px;border:2px solid var(--gray-200);border-top-color:var(--primary-500);border-radius:50%;animation:ecme-spin .8s linear infinite;margin-bottom:var(--space-2)}@keyframes ecme-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.delete-modal-content{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-4)}.delete-modal-icon{color:var(--error-light);display:flex;align-items:center;justify-content:center}.delete-modal-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.delete-modal-description{color:var(--text-secondary);line-height:1.5;margin:0}@media(max-width:1200px){.chat-sessions-page{height:auto;min-height:0}.chat-sessions-content{grid-template-columns:1fr;gap:var(--space-4)}.messages-section{order:-1}}@media(max-width:1024px){.table th,.table td{padding:var(--space-3) var(--space-2);font-size:var(--text-xs)}.user-cell{max-width:150px}}@media(max-width:768px){.page-header{margin-bottom:var(--space-8)}.sessions-section,.messages-section{padding:var(--space-4)}.sessions-section .section-header{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.table{font-size:var(--text-xs)}.table th,.table td{padding:var(--space-2)}.pagination{flex-wrap:wrap;gap:var(--space-1)}.pagination-btn{padding:var(--space-2) var(--space-3);font-size:var(--text-xs);min-width:60px}}@media(max-width:640px){.table th:nth-child(3),.table td:nth-child(3){display:none}.messages-container{max-height:400px}}.tax-brackets-page{padding:0;max-width:100%}.content-grid{display:grid;grid-template-columns:1fr 400px;gap:var(--space-6)}.preview-card{position:sticky;top:var(--space-8)}.preview-input{margin-bottom:var(--space-6)}.preview-input label{display:block;margin-bottom:var(--space-2);font-weight:var(--font-medium);color:var(--text-secondary)}.preview-result{background:var(--surface-hover);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-4)}.result-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) 0;border-bottom:1px solid var(--border-color)}.result-row:last-child{border-bottom:none}.result-label{font-weight:var(--font-medium);color:var(--text-secondary)}.result-value{font-weight:var(--font-semibold);color:var(--text-primary);font-family:var(--font-mono)}.result-value.highlight{color:var(--warning-light);font-size:var(--text-lg)}.result-value.success{color:var(--success-light);font-size:var(--text-lg)}.preview-info{margin-top:var(--space-4);padding:var(--space-4);background:var(--info-bg);border-left:3px solid var(--primary-500);border-radius:var(--radius-md)}.info-text{margin:0;font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed)}@media(max-width:768px){.content-grid{grid-template-columns:1fr}.preview-card{position:static}.table{font-size:var(--text-xs)}.table th,.table td{padding:var(--space-2) var(--space-2)}}.tax-deductions-page{padding:0;max-width:100%}.editing-row{background:var(--warning-bg)!important;border-left:3px solid var(--warning-light)}.type-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);white-space:nowrap}.type-badge.type-work_income{background:var(--primary-bg);color:var(--primary-500)}.type-badge.type-dependent{background:var(--success-bg);color:var(--success-light)}.type-badge.type-bonus{background:var(--warning-bg);color:var(--warning-light)}.type-badge.type-ulteriore_decalage{background:transparent;color:var(--primary-500);padding:0;border-radius:0;font-weight:var(--font-medium)}.amount-cell{font-weight:var(--font-semibold);color:var(--primary-500);font-family:var(--font-mono)}.monthly-cell{color:var(--text-secondary);font-size:var(--text-sm);font-family:var(--font-mono)}.monthly-preview{color:var(--text-secondary);font-size:var(--text-sm);font-style:italic}.formula-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;background:var(--info-bg);color:var(--primary-500)}.formula-params{font-size:var(--text-xs);color:var(--text-secondary);line-height:1.5}.formula-params div{margin:var(--space-1) 0}.info-card .note{margin:0;padding:var(--space-4);background:var(--warning-bg);border-left:3px solid var(--warning-light);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-primary)}.tax-deductions-page .info-card{margin-top:var(--space-6)}@media(max-width:768px){.table{font-size:var(--text-xs)}}.inps-rates-page{padding:0;max-width:100%}.content-grid{display:grid;grid-template-columns:1fr 400px;gap:var(--space-6);align-items:start}@media(max-width:1200px){.content-grid{grid-template-columns:1fr}}.card-header h2{margin:0 0 var(--space-2) 0;font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary)}.card-header h3{margin:0;font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary)}.card-description{margin:0;font-size:var(--text-sm);color:var(--text-secondary)}.card-content{padding:var(--space-6)}.editing-row{background:#f59e0b1a!important;border-left:3px solid var(--warning-light)}.rate-type-cell{display:flex;flex-direction:column;gap:var(--space-1)}.rate-type-cell strong{color:var(--text-primary);font-size:var(--text-sm)}.rate-description{color:var(--text-secondary);font-size:var(--text-xs)}.rate-cell{font-weight:var(--font-semibold);color:var(--primary-400);font-family:var(--font-mono)}.total-row{background:var(--surface-hover)!important;font-weight:var(--font-semibold);border-top:2px solid var(--border-color)}.total-cell{color:var(--success-light)!important;font-size:var(--text-lg);font-family:var(--font-mono)}.sidebar-cards{display:flex;flex-direction:column;gap:var(--space-6)}.info-card .card-content p{margin:0 0 var(--space-4) 0;color:var(--text-secondary);line-height:1.6}.info-card .card-content ul{margin:0 0 var(--space-4) 0;padding-left:var(--space-6);color:var(--text-secondary)}.info-card .card-content li{margin:var(--space-2) 0;line-height:1.6}.info-card .note{display:flex;align-items:flex-start;gap:var(--space-3);margin:0;padding:var(--space-4);background:var(--info-bg);border-left:3px solid var(--primary-500);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-primary)}.example-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) 0}.example-label{color:var(--text-secondary);font-size:var(--text-sm)}.example-value{font-weight:var(--font-semibold);color:var(--text-primary);font-family:var(--font-mono)}.example-percent{color:var(--text-secondary);font-size:var(--text-xs);font-weight:400;margin-left:var(--space-1)}.example-divider{height:1px;background:var(--border-color);margin:var(--space-2) 0}.example-row.total{padding-top:var(--space-3);margin-top:var(--space-2);border-top:2px solid var(--border-color)}.example-row.total .example-value{color:var(--success-light);font-size:var(--text-base)}.example-row.result{padding:var(--space-4);margin-top:var(--space-2);background:var(--info-bg);border-radius:var(--radius-md);border-left:3px solid var(--primary-500)}.example-row.result .example-value{color:var(--primary-400);font-size:var(--text-lg)}.inps-rates-page .loading-container svg{color:var(--primary-400)}.inps-rates-page .loading-container p{margin:0;font-size:var(--text-base)}@media(max-width:1200px){.sidebar-cards{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}}@media(max-width:768px){.sidebar-cards{grid-template-columns:1fr}.table{font-size:var(--text-xs)}.table th,.table td{padding:var(--space-2) var(--space-2)}}.bonus-rules-page{display:flex;flex-direction:column;gap:20px}.rules-table-card{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:0}.rules-table-card .card-header{display:flex;flex-direction:column;gap:8px;padding:var(--space-5);border-bottom:1px solid var(--border-color)}.rules-table-card .card-header h2{margin:0;font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary)}.rules-table-card .card-description{margin:0;font-size:var(--text-sm);color:var(--text-muted);line-height:1.5}.rules-table-card .table-responsive{overflow-x:auto}.bonus-rules-page .rules-table,.bonus-rules-page .overrides-table{width:100%;min-width:720px;border-collapse:separate;border-spacing:0;table-layout:fixed}.bonus-rules-page .rules-table{min-width:780px}.bonus-rules-page .rules-table thead,.bonus-rules-page .overrides-table thead{background:var(--surface-bg)}.bonus-rules-page .rules-table thead th,.bonus-rules-page .overrides-table thead th{border-bottom:2px solid var(--border-color)}.bonus-rules-page .rules-table th,.bonus-rules-page .overrides-table th{padding:var(--space-3) var(--space-2);text-align:center;font-size:10px;font-weight:var(--font-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;background:var(--surface-bg);white-space:nowrap}.bonus-rules-page .rules-table td,.bonus-rules-page .overrides-table td{padding:var(--space-2) var(--space-2);vertical-align:middle;font-size:var(--text-sm);color:var(--text-primary);text-align:center;overflow:hidden;text-overflow:ellipsis}.bonus-rules-page .rules-table th:first-child,.bonus-rules-page .overrides-table th:first-child,.bonus-rules-page .rules-table td:first-child,.bonus-rules-page .overrides-table td:first-child{text-align:left;padding-left:var(--space-3)}.bonus-rules-page .rules-table .col-left,.bonus-rules-page .overrides-table .col-left{text-align:left}.bonus-rules-page .rules-table .col-actions,.bonus-rules-page .overrides-table .col-actions{text-align:center}.bonus-rules-page .rules-table .col-spacer,.bonus-rules-page .overrides-table .col-spacer,.bonus-rules-page .rules-table--toggles .col-spacer,.bonus-rules-page .rules-table--toggles th.col-spacer,.bonus-rules-page .rules-table--toggles td.col-spacer{color:transparent}.bonus-rules-page .rules-table .col-item{width:260px}.bonus-rules-page .rules-table .col-active{width:90px}.bonus-rules-page .rules-table .col-default,.bonus-rules-page .rules-table .col-payout,.bonus-rules-page .rules-table .col-eligible{width:150px}.bonus-rules-page .rules-table .col-sector,.bonus-rules-page .rules-table .col-rate{width:140px}.bonus-rules-page .rules-table .col-actions{width:90px}.bonus-rules-page .rules-table tbody tr,.bonus-rules-page .overrides-table tbody tr{border-bottom:1px solid var(--border-color);transition:background-color var(--transition-fast)}.bonus-rules-page .rules-table tbody tr:hover,.bonus-rules-page .overrides-table tbody tr:hover{background:var(--surface-hover)}.overrides-rank-section .table-responsive{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow-x:auto}.overrides-rank-section .data-table{min-width:1000px}.overrides-table{min-width:1240px}.overrides-table .col-drag{width:40px}.overrides-table .col-item{width:180px;min-width:140px;max-width:180px}.overrides-table .col-active,.overrides-table .col-fixed,.overrides-table .col-var,.overrides-table .col-legacy,.overrides-table .col-deduct,.overrides-table .col-ctrv,.overrides-table .col-prl,.overrides-table .col-new,.overrides-table .col-merge,.overrides-table .col-excl-prl,.overrides-table .col-excl-vto{width:60px}.overrides-table .col-eur{width:90px}.overrides-table .col-unit{width:50px}.overrides-table .col-tax,.overrides-table .col-free{width:60px}.overrides-table .col-actions{width:110px}.overrides-table td{font-size:var(--text-sm)}.overrides-table thead{background:var(--surface-bg)}.overrides-table thead th{border-bottom:2px solid var(--border-color)}.overrides-table tbody tr{border-bottom:1px solid var(--border-color);transition:background-color var(--transition-fast);cursor:move;transition:transform .15s ease-out,opacity .15s ease-out,background-color var(--transition-fast)}.overrides-table tbody tr:hover{background:var(--surface-hover)}.overrides-table tbody tr.active-row{background:#0072db0d}.overrides-table tbody tr.active-row:hover{background:#0072db1a}.overrides-table tbody tr.dragging{opacity:.5;background:var(--primary-500)!important}.overrides-table tbody tr:hover .drag-handle{color:var(--text-secondary)}.overrides-table .drag-handle-cell{padding:var(--space-2) var(--space-1);width:40px}.overrides-table .drag-handle{display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:grab;transition:color var(--transition-fast)}.overrides-table .drag-handle:active{cursor:grabbing}.overrides-table td:nth-child(11){font-family:var(--font-mono);font-weight:var(--font-medium);color:var(--text-primary)}.overrides-table td:nth-child(13),.overrides-table td:nth-child(14){font-family:var(--font-mono);font-size:var(--text-xs)}.overrides-table td:nth-child(13){color:var(--text-secondary)}.overrides-table td:nth-child(14){color:var(--text-secondary)}.rule-item-cell{display:flex;flex-direction:column;gap:4px;align-items:flex-start}.rule-item-cell strong{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);line-height:1.3}.rule-item-code{font-size:11px;color:var(--text-muted);line-height:1.2}.bonus-rule-form{display:flex;flex-direction:column;gap:14px}.form-row{display:grid;grid-template-columns:180px 1fr;align-items:center;gap:12px}.form-control{display:flex;flex-direction:column;gap:6px}.form-value{color:var(--text-primary)}.muted{color:var(--text-secondary)}.switch-row{display:inline-flex;align-items:center;gap:10px;color:var(--text-primary)}.bonus-rules-page .rules-table input[type=checkbox],.bonus-rules-page .overrides-table input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary-500);cursor:pointer}.status-pill{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.5px;border-radius:var(--radius-full)}.status-pill.status-yes,.status-pill.status-on{background-color:var(--success-bg);color:var(--success-dark)}.status-pill.status-no,.status-pill.status-off{background-color:var(--error-bg);color:var(--error-dark)}.overrides-controls{display:flex;flex-direction:column;gap:12px;margin-top:12px;padding:var(--space-4) var(--space-5);background:var(--surface-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.bonus-rules-page .overrides-select,.bonus-rules-modal .overrides-select{border:1px solid var(--border-color);background:var(--surface-card);color:var(--text-primary)}.bonus-rules-page .overrides-select:hover,.bonus-rules-modal .overrides-select:hover{border-color:var(--border-hover)}.bonus-rules-page .overrides-select:focus,.bonus-rules-page .overrides-select:focus-visible,.bonus-rules-modal .overrides-select:focus,.bonus-rules-modal .overrides-select:focus-visible{border-color:var(--border-focus);box-shadow:0 0 0 3px #3b82f633}.overrides-ranks{display:flex;flex-direction:column;gap:var(--space-6);margin-top:var(--space-4)}.overrides-rank-section{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:0}.overrides-rank-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--surface-bg);border-bottom:1px solid var(--border-color);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.overrides-rank-title{margin:0;font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary)}.overrides-rank-header .btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm)}.overrides-actions{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-1)}.bonus-rules-page .action-btn--hidden{visibility:hidden;pointer-events:none}.overrides-range-row{display:grid;grid-template-columns:1fr auto 1fr;gap:10px;align-items:center}.overrides-merge-splits{display:flex;flex-direction:column;gap:10px}.overrides-merge-split-row{display:grid;grid-template-columns:140px 1fr 40px;gap:10px;align-items:center}.bonus-rules-modal .modal-icon{width:42px;height:42px;border-radius:var(--radius-lg);display:inline-flex;align-items:center;justify-content:center;color:#fff}.bonus-rules-modal .modal-icon.gradient-blue{background:linear-gradient(135deg,var(--primary-500),var(--primary-600))}.bonus-rules-modal .modal-icon.gradient-purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.bonus-rules-modal .form-label{font-weight:600;color:var(--text-primary)}.bonus-rules-modal .form-value{color:var(--text-primary)}.bonus-rules-modal .modal-section{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--surface-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.bonus-rules-modal .modal-section-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.bonus-rules-modal .modal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-4)}.bonus-rules-modal .modal-field{display:flex;flex-direction:column;gap:6px}.bonus-rules-modal .modal-field--full{grid-column:1 / -1}.bonus-rules-modal .modal-note{font-size:var(--text-xs);color:var(--text-secondary);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4)}@media(max-width:900px){.overrides-rank-header{flex-direction:column;align-items:stretch;gap:var(--space-3)}.overrides-controls{padding:var(--space-3)}}@media(max-width:720px){.bonus-rule-form{gap:12px}.form-row{grid-template-columns:1fr;gap:6px}.overrides-range-row{grid-template-columns:1fr;gap:8px}.overrides-merge-split-row{grid-template-columns:1fr}.bonus-rules-page .data-table{min-width:560px}.bonus-rules-page .rules-table{min-width:640px}.rules-table-card .card-header{padding:var(--space-4)}.overrides-rank-header{padding:var(--space-3)}}.drive-file-preview{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);margin-bottom:1.5rem}.file-preview-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--surface-elevated);border-radius:var(--radius-md);overflow:hidden}.file-preview-emoji{font-size:1.75rem;display:flex;align-items:center;justify-content:center}.file-preview-name{font-size:.9375rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.25rem}.file-preview-meta .meta-item{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--text-secondary)}.file-preview-meta .meta-item svg{color:var(--text-muted)}.file-preview-link{width:36px;height:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast)}.file-preview-link:hover{background:var(--surface-hover);border-color:var(--border-hover);color:var(--primary-500)}@media(max-width:640px){.drive-file-preview{flex-direction:column;text-align:center}.file-preview-meta{justify-content:center}.file-preview-link{position:absolute;top:.5rem;right:.5rem}.drive-file-preview{position:relative}}.drive-file-preview,.file-mapping-preview{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:1rem}.file-preview-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:var(--radius-md);background:var(--surface-elevated);overflow:hidden}.file-preview-thumbnail{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.file-preview-emoji{font-size:1.5rem;display:flex;align-items:center;justify-content:center}.file-preview-info{flex:1;min-width:0}.file-preview-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);margin-bottom:.25rem;word-break:break-word}.file-preview-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:.25rem;font-size:var(--text-xs);color:var(--text-secondary)}.file-preview-link{display:flex;align-items:center;justify-content:center;width:32px;height:32px;color:var(--text-muted);transition:color var(--transition-fast)}.file-preview-link:hover{color:var(--primary-500)}.loading-input{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary)}.loading-chapters{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:2rem;color:var(--text-secondary)}.form-hint{font-size:var(--text-xs);color:var(--text-secondary);margin-top:.25rem}.chapters-section{margin-top:1.5rem;border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.section-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem;background:var(--surface-card);border:none;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background var(--transition-fast)}.section-header:hover{background:var(--surface-hover)}.section-header-left{display:flex;align-items:center;gap:.5rem}.section-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.section-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 .375rem;background:var(--primary-500);color:#fff;border-radius:10px;font-size:var(--text-xs);font-weight:var(--font-semibold)}.section-badge.replace{background:var(--warning-light)}.file-mappings-list{padding:1rem;display:flex;flex-direction:column;gap:1rem}.file-mapping-card{padding:1rem;background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.file-mapping-controls{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1rem}.file-mapping-controls .form-group{margin-bottom:0}.existing-chapter-info{grid-column:1 / -1;padding:.75rem;background:var(--surface-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-top:.5rem}.info-label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-secondary);margin-bottom:.5rem}.info-content{font-size:var(--text-xs);color:var(--text-secondary);display:flex;flex-direction:column;gap:.25rem}.info-content strong{color:var(--text-primary);margin-right:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:var(--text-sm);color:var(--text-primary);cursor:pointer}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:2px solid var(--primary-500);border-radius:4px;background:var(--surface-card);display:inline-flex;align-items:center;justify-content:center;transition:background var(--transition-fast),border-color var(--transition-fast)}.checkbox-label input[type=checkbox]:after{content:"";width:6px;height:10px;border:2px solid var(--text-inverse);border-top:0;border-left:0;transform:rotate(45deg);display:none}.checkbox-label input[type=checkbox]:checked{background:var(--primary-500);border-color:var(--primary-500)}.checkbox-label input[type=checkbox]:checked:after{display:block}.text-muted{color:var(--text-secondary);font-size:var(--text-sm)}@media(max-width:768px){.file-mapping-controls{grid-template-columns:1fr}.file-mapping-preview{flex-direction:column;align-items:flex-start}}.gdrive-manager-page{padding:0}.gdrive-connect-card{max-width:500px;margin:var(--space-16) auto;padding:var(--space-12);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);text-align:center}.connect-icon{width:100px;height:100px;margin:0 auto var(--space-6);background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);border-radius:var(--radius-2xl);display:flex;align-items:center;justify-content:center;color:var(--text-inverse)}.gdrive-connect-card h2{font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-3)}.gdrive-connect-card>p{color:var(--text-secondary);font-size:var(--text-sm);line-height:var(--leading-relaxed);margin-bottom:var(--space-6)}.connect-error{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--error-bg);border:1px solid var(--error-border);border-radius:var(--radius-md);color:var(--error-dark);font-size:var(--text-sm);margin-bottom:var(--space-6)}.connect-btn{width:100%}.connect-hint{margin-top:var(--space-6);font-size:var(--text-xs);color:var(--text-secondary)}.gdrive-manager-page .page-header .header-content{display:flex;justify-content:space-between;align-items:center}.drive-oauth-status{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--surface-card);color:var(--text-secondary);font-size:var(--text-xs);font-weight:var(--font-semibold);cursor:pointer}.drive-oauth-status.ok{background:var(--success-bg);border-color:var(--success-border);color:var(--success-dark)}.drive-oauth-status.expired,.drive-oauth-status.error{background:var(--error-bg);border-color:var(--error-border);color:var(--error-dark)}.drive-oauth-status.checking{opacity:.8}.drive-oauth-status.is-disabled{cursor:default}.drive-oauth-dot{width:8px;height:8px;border-radius:999px;background:currentColor}.drive-oauth-text{white-space:nowrap}.disconnect-btn{color:var(--text-secondary)}.disconnect-btn:hover{color:var(--error-light);border-color:var(--error-light)}.gdrive-toolbar{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-6);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:var(--space-0);flex-wrap:wrap}.toolbar-left{flex:1;min-width:var(--space-0)}.toolbar-right{display:flex;align-items:center;gap:var(--space-2)}.breadcrumbs{display:flex;align-items:center;gap:var(--space-1);overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:var(--space-1) var(--space-2);border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-card)}.breadcrumbs::-webkit-scrollbar{display:none}.breadcrumb-item{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.breadcrumb-item:hover:not(:disabled){background:var(--surface-elevated);color:var(--text-primary)}.breadcrumb-item.current{color:var(--text-primary);font-weight:var(--font-medium);cursor:default}.breadcrumb-item.drag-over{background:#0072db33;border:1px solid var(--primary-500);color:var(--primary-300)}.file-card .file-name,.file-card .file-info,.file-card .file-icon,.file-card .file-card-main,.file-card .file-meta,.file-card .file-card-title{border:none!important;outline:none!important;background:transparent!important}.file-card .file-card-title,.file-card:hover .file-card-title{border:none!important;outline:none!important;background:transparent!important;box-shadow:none!important}.file-card.selected{background:#0072db14;border:2px solid var(--primary-500)!important}.file-card.selected .file-card-title{background:transparent!important;border:none!important;color:var(--primary-300)!important}.file-card.selection-mode{cursor:pointer}.file-card.selection-mode:hover{background:#0072db14!important}.file-card.selection-mode.selected:hover{background:#0072db33!important}.file-checkbox{position:absolute;top:var(--space-3);left:var(--space-3);z-index:20;display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--radius-sm);color:var(--text-inverse);pointer-events:none}.file-card.selection-mode .file-library-badge{display:none}.file-card.selection-mode .file-checkbox{pointer-events:auto}.file-card.selected .file-checkbox{background:var(--primary-500);color:var(--text-inverse)}.breadcrumb-separator{color:var(--text-secondary);flex-shrink:0}.gdrive-file-list{background:var(--surface-bg);border:none;border-radius:var(--radius-none);min-height:400px;overflow:auto}.gdrive-manager-page .loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-8);color:var(--text-secondary);text-align:center}.gdrive-manager-page .loading-state p{margin-top:var(--space-4);font-size:var(--text-base);color:var(--text-primary)}.file-section{padding:var(--space-0)}.file-section:not(:last-child){border-bottom:1px solid var(--border-color);padding-bottom:var(--space-6);margin-bottom:var(--space-6)}.gdrive-manager-page .section-title{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);margin-bottom:var(--space-3);padding:0 var(--space-6);padding-top:var(--space-6)}.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-4);padding:var(--space-2) var(--space-6) var(--space-6)}.file-card{display:flex;flex-direction:column;align-items:stretch;background:var(--surface-card)!important;border:1px solid var(--border-color)!important;border-radius:var(--radius-xl);transition:all var(--transition-fast);position:relative;overflow:visible;padding:var(--space-3);cursor:pointer;min-height:88px;outline:none;box-shadow:var(--shadow-sm)}.file-card:hover{border-color:var(--border-hover)!important;box-shadow:var(--shadow-lg)}.file-card[draggable=true]{cursor:grab}.file-card[draggable=true]:active{cursor:grabbing}.file-card.dragging{opacity:.3;transform:scale(.95)}.file-card.folder.drag-over{background:#0072db33;border:2px dashed var(--primary-500)}.file-card.folder.drag-over .file-icon{color:var(--primary-300);transform:scale(1.1)}.file-card.folder.drag-over .file-card-title{color:var(--primary-300)}.file-card.folder .file-card-main{cursor:pointer}.file-card-main{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) 0 var(--space-1);flex:1;min-width:var(--space-0);justify-content:center}.file-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;font-size:2.25rem;flex-shrink:0;border-radius:var(--radius-md);background:var(--surface-elevated);border:1px solid var(--border-color);transition:all var(--transition-fast);color:var(--text-secondary);margin-bottom:0}.file-icon.folder-icon{color:#ffb84d}.file-card:hover .file-icon{color:var(--text-primary);transform:scale(1.02)}.file-card:hover .file-icon.folder-icon{color:#ffc970}.file-thumbnail{width:64px;height:64px;-o-object-fit:cover;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--surface-elevated)}.file-icon .hidden{display:none}.file-info{width:100%;display:flex;flex-direction:column;align-items:center;gap:var(--space-1);overflow:visible;text-align:center;padding:var(--space-0);border:none;background:transparent!important}.file-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);width:100%;min-height:64px}.file-card-header:hover .file-card-title{color:var(--text-primary)}.file-card-header:hover .file-meta{color:var(--text-secondary)}.file-card-titlewrap{display:flex;align-items:flex-start;gap:var(--space-3);min-width:0;flex:1}.file-card-text{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-1);min-width:0;flex:1;justify-content:flex-start;margin-top:2px}.file-card-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;max-width:100%}.file-menu-trigger{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--surface-elevated);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);align-self:flex-start;margin-top:2px}.file-card.menu-open{z-index:5}.file-menu-trigger:hover{color:var(--text-primary);border-color:var(--border-hover);box-shadow:var(--shadow-sm)}.file-action-menu{position:absolute;top:44px;right:var(--space-4);min-width:200px;background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:var(--space-2);z-index:1000}.file-action-item{width:100%;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:none;background:transparent;color:var(--text-primary);font-size:var(--text-sm);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left}.file-action-item:hover:not(:disabled){background:var(--surface-elevated)}.file-action-item:disabled{color:var(--text-secondary);cursor:not-allowed}.file-action-item.danger{color:var(--error-light)}.file-name{font-size:var(--text-xs);font-weight:var(--font-normal);color:var(--text-primary);white-space:normal;overflow:visible;text-overflow:clip;line-height:1.4;word-break:break-word;-webkit-hyphens:auto;hyphens:auto;max-width:100%;padding:var(--space-0);border-radius:var(--radius-none);border:none!important;background:transparent!important;transition:color var(--transition-fast);display:block;text-align:center;margin-top:var(--space-1)}.file-card:hover .file-card-title{background:transparent!important;border:none!important;color:var(--text-primary)}.file-meta{font-size:.6875rem;color:var(--text-secondary);line-height:1.3;margin-top:var(--space-0);border:none;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.load-more{display:flex;justify-content:center;padding:var(--space-6);border-top:1px solid var(--border-color)}.delete-confirmation{text-align:center;padding:var(--space-4) var(--space-0)}.delete-confirmation-icon{color:var(--warning-light);margin-bottom:var(--space-4)}.delete-confirmation-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.delete-confirmation-message{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed)}@media(max-width:768px){.gdrive-toolbar{flex-direction:column;align-items:stretch}.toolbar-left{order:2}.toolbar-right{order:1;justify-content:flex-end;margin-bottom:var(--space-3)}.file-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-4);padding:var(--space-4)}.file-icon{width:56px;height:56px;font-size:var(--text-2xl)}.file-thumbnail{width:56px;height:56px}.gdrive-connect-card{margin:var(--space-8) var(--space-4);padding:var(--space-8)}}.file-library-badge{position:absolute;bottom:var(--space-3);right:var(--space-3);transform:none;z-index:2;display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#0072dbe6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--radius-sm);color:var(--text-inverse);pointer-events:none;box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}.support-email-settings{width:100%;display:flex;flex-direction:column;gap:var(--space-6)}.support-email-settings .last-update-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--surface-hover);border:1px solid var(--border-color);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-secondary);line-height:1}.support-email-settings .last-update-badge svg{display:block;color:var(--primary-500)}.settings-layout{display:flex;flex-direction:column;gap:var(--space-4)}.settings-top-grid,.settings-pairs-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4);align-items:start}@media(min-width:1000px){.settings-top-grid{grid-template-columns:1.2fr 1fr}.settings-pairs-grid{grid-template-columns:1fr 1fr}}.settings-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4)}@media(min-width:1000px){.settings-grid{grid-template-columns:1fr 1fr;align-items:start}}.settings-card{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden}.support-email-settings .card-title{display:inline-flex;align-items:center;gap:var(--space-3)}.card-actions{display:flex;align-items:center;gap:var(--space-3)}.form{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.checkbox-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:1px solid var(--border-color);border-radius:var(--radius-lg);background-color:var(--surface-card);color:var(--text-primary);transition:background-color var(--transition-fast),border-color var(--transition-fast)}.checkbox-row:hover{background-color:var(--surface-hover);border-color:var(--gray-300)}.checkbox-row input[type=checkbox]{accent-color:var(--primary-500);cursor:pointer}.secrets{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-3)}.secrets-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:1px solid var(--border-color);border-radius:var(--radius-lg);background-color:var(--surface-card);transition:background-color var(--transition-fast)}.secrets-row:hover{background-color:var(--surface-hover)}.secrets-label{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-primary);font-weight:var(--font-medium)}.secrets-hint{margin:6px 2px 0;font-size:var(--text-xs);color:var(--text-secondary)}.recipients{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.recipients-hint{margin:0;font-size:var(--text-xs);color:var(--text-secondary)}.recipients-add{display:flex;align-items:center;gap:var(--space-3)}.recipients-add .form-input{flex:1}.recipients-loading,.recipients-empty{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:1px solid var(--border-color);border-radius:var(--radius-lg);background-color:var(--surface-card);color:var(--text-secondary);font-size:var(--text-sm)}.recipients-list{display:flex;flex-direction:column;gap:var(--space-3)}.recipient-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:1px solid var(--border-color);border-radius:var(--radius-lg);background-color:var(--surface-card);transition:background-color var(--transition-fast)}.recipient-row:hover{background-color:var(--surface-hover)}.recipient-left{display:flex;align-items:center;gap:var(--space-3);min-width:0}.recipient-email{color:var(--text-primary);font-size:var(--text-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:520px}.recipient-actions{display:flex;align-items:center;gap:var(--space-3)}@media(max-width:1024px){.settings-top-grid,.settings-pairs-grid{grid-template-columns:1fr}}@media(max-width:768px){.card-actions{width:100%;justify-content:flex-start}.recipients-add{flex-direction:column}.recipients-add .form-input,.recipients-add .btn{width:100%}.recipient-row{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.recipient-actions{width:100%;justify-content:flex-start}.recipient-email{max-width:100%}}@media(max-width:640px){.form,.secrets,.recipients{padding:var(--space-4)}.card-header{padding:var(--space-3) var(--space-4)}.btn{padding:var(--space-2) var(--space-3)}.badge{padding:var(--space-1) var(--space-2);font-size:11px}}@media(max-width:480px){.form-input{padding:var(--space-2)}}.analytics-mailing-settings{width:100%;display:flex;flex-direction:column;gap:var(--space-6)}.analytics-mailing-settings .last-update-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--surface-hover);border:1px solid var(--border-color);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-secondary);line-height:1}.analytics-mailing-settings .last-update-badge svg{display:block;color:var(--primary-500)}.analytics-mailing-settings .settings-layout{display:flex;flex-direction:column;gap:var(--space-4)}.analytics-mailing-settings .settings-top-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4);align-items:stretch}@media(min-width:1000px){.analytics-mailing-settings .settings-top-grid{grid-template-columns:1.2fr 1fr}}.analytics-mailing-settings .settings-top-grid .settings-card{display:flex;flex-direction:column;min-height:0}.analytics-mailing-settings .settings-top-grid .settings-card .form{flex:1;display:flex;flex-direction:column}.analytics-mailing-settings .settings-card{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden}.analytics-mailing-settings .settings-card.dropdown-open{overflow:visible}.analytics-mailing-settings .card-title{display:inline-flex;align-items:center;gap:var(--space-3)}.analytics-mailing-settings .form{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.analytics-mailing-settings .form-hint{margin:4px 0 0;font-size:var(--text-xs);color:var(--text-secondary)}.analytics-mailing-settings .analytics-checkboxes-card .form{padding-top:0}.analytics-mailing-settings .analytics-checkboxes{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-3)}.analytics-mailing-settings .analytics-checkboxes .checkbox-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:1px solid var(--border-color);border-radius:var(--radius-lg);background-color:var(--surface-card);color:var(--text-primary);transition:background-color var(--transition-fast),border-color var(--transition-fast)}.analytics-mailing-settings .analytics-checkboxes .checkbox-row:hover{background-color:var(--surface-hover);border-color:var(--gray-300)}.analytics-mailing-settings .analytics-checkboxes .checkbox-row input[type=checkbox]{accent-color:var(--primary-500);cursor:pointer}.analytics-mailing-settings .analytics-row-with-count{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-3)}.analytics-mailing-settings .checkbox-clickable{display:flex;align-items:center;gap:var(--space-3);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.analytics-mailing-settings .checkbox-inline{display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;font-size:var(--text-sm);color:var(--text-secondary)}.analytics-mailing-settings .analytics-row-with-count .checkbox-clickable{flex:0 1 auto}.analytics-mailing-settings .top-count-and-include{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.analytics-mailing-settings .top-count-input{display:flex;align-items:center;gap:var(--space-2)}.analytics-mailing-settings .form-label-inline{font-size:var(--text-xs);color:var(--text-secondary)}.analytics-mailing-settings .form-input-narrow{width:4rem;min-width:3rem;max-width:none;box-sizing:border-box;padding-left:var(--space-2);padding-right:1rem;text-align:right}.analytics-mailing-settings .form-input-narrow::-webkit-outer-spin-button,.analytics-mailing-settings .form-input-narrow::-webkit-inner-spin-button{margin-left:4px}.analytics-mailing-settings .form-input-narrow:disabled{opacity:.6;cursor:not-allowed}.analytics-mailing-settings .secrets{padding:0 var(--space-6) var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.analytics-mailing-settings .secrets-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:1px solid var(--border-color);border-radius:var(--radius-lg);background-color:var(--surface-card)}.analytics-mailing-settings .secrets-label{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-primary);font-weight:var(--font-medium)}.analytics-mailing-settings .admin-select-container{position:relative;z-index:100}.analytics-mailing-settings .admin-select-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);text-align:left}.analytics-mailing-settings .admin-select-trigger:hover{border-color:var(--border-hover)}.analytics-mailing-settings .admin-select-trigger:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #3b82f633}.analytics-mailing-settings .admin-select-dropdown{position:absolute;top:100%;left:0;right:0;z-index:150;margin-top:4px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:2px;max-height:220px;overflow-y:auto;padding:var(--space-2);border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-card)}.analytics-mailing-settings .admin-select-option{text-align:left;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid transparent;background:var(--gray-100);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);width:100%}.analytics-mailing-settings .admin-select-option:hover{border-color:var(--border-hover);background:var(--gray-200)}.analytics-mailing-settings .admin-select-option.selected{background:var(--primary-50);border-color:var(--primary-200);color:var(--primary-700)}.analytics-mailing-settings .admin-select-placeholder{color:var(--text-muted)}.analytics-mailing-settings .admin-select-chevron{flex-shrink:0;margin-left:var(--space-2);color:var(--text-secondary);transition:transform var(--transition-fast)}.analytics-mailing-settings .admin-select-container.open .admin-select-chevron{transform:rotate(180deg)}.welcome-email-settings{display:flex;flex-direction:column;gap:1.5rem}.welcome-email-settings .page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.welcome-email-settings .page-title-wrapper{display:flex;flex-direction:column;gap:.25rem}.welcome-email-settings .page-title{margin:0;font-size:1.5rem}.welcome-email-settings .page-subtitle{margin:0;font-size:.9rem;color:var(--text-secondary)}.welcome-email-settings .page-actions{display:flex;align-items:center;gap:.5rem}.welcome-email-settings .last-update-badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;padding:.15rem .4rem;border-radius:999px;background:var(--surface-elevated);color:var(--text-secondary)}.welcome-email-settings .last-update-badge svg{width:.75rem;height:.75rem}.welcome-email-settings .settings-layout{display:flex;flex-direction:column;gap:1.25rem}.welcome-email-settings .settings-top-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1.3fr);gap:1.25rem}.welcome-email-settings .settings-right-column{display:flex;flex-direction:column;gap:1.25rem}.welcome-email-settings .attachments-card .form-row{grid-template-columns:minmax(0,1fr)}.welcome-email-settings .attachments-actions{margin-top:.5rem;display:flex;justify-content:flex-end}@media(max-width:900px){.welcome-email-settings .settings-top-grid{grid-template-columns:minmax(0,1fr)}}.welcome-email-settings .settings-card{background:var(--surface-card);border-radius:.75rem;border:1px solid var(--border-subtle);padding:1rem 1.1rem 1.1rem;display:flex;flex-direction:column;gap:.75rem}.welcome-email-settings .card-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.25rem}.welcome-email-settings .card-title{display:inline-flex;align-items:center;gap:.4rem}.welcome-email-settings .card-title h3{margin:0;font-size:.95rem}.welcome-email-settings .card-actions{display:flex;align-items:center;gap:.5rem}.welcome-email-settings .form{display:flex;flex-direction:column;gap:.75rem}.welcome-email-settings .form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}@media(max-width:800px){.welcome-email-settings .form-row{grid-template-columns:minmax(0,1fr)}}.welcome-email-settings .form-group{display:flex;flex-direction:column;gap:.25rem}.welcome-email-settings .form-group.welcome-email-base-select{max-width:50%}.welcome-email-settings .form-label{font-size:.85rem;font-weight:500}.welcome-email-settings .form-input,.welcome-email-settings .form-textarea{border-radius:.5rem;border:1px solid var(--border-subtle);padding:.45rem .6rem;font-size:.9rem;background:var(--surface-elevated);color:var(--text-primary)}.welcome-email-settings .form-input:focus,.welcome-email-settings .form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 1px color-mix(in srgb,var(--primary) 30%,transparent)}.welcome-email-settings .welcome-email-select{border-radius:.5rem;border:1px solid var(--border-subtle);padding:.45rem .6rem;font-size:.9rem;background:var(--surface-elevated);color:var(--text-primary)}.welcome-email-settings .welcome-email-select:hover{border-color:var(--border-hover, var(--border-subtle))}.welcome-email-settings .welcome-email-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 1px color-mix(in srgb,var(--primary) 30%,transparent)}.welcome-email-settings .form-textarea{resize:vertical;min-height:6rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.welcome-email-settings .form-hint{margin:0;font-size:.75rem;color:var(--text-secondary)}.welcome-email-settings .template-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}@media(max-width:900px){.welcome-email-settings .template-grid{grid-template-columns:minmax(0,1fr)}}.welcome-email-settings code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.78rem;background:var(--surface-elevated);border-radius:.35rem;padding:.15rem .3rem}.welcome-email-settings .contacts-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}@media(max-width:900px){.welcome-email-settings .contacts-grid{grid-template-columns:minmax(0,1fr)}}.welcome-email-settings .contacts-column{display:flex;flex-direction:column;gap:.5rem}.welcome-email-settings .contacts-title{margin:0 0 .2rem;font-size:.9rem;font-weight:600}.welcome-email-settings .recipients-add{display:flex;align-items:flex-start;gap:.5rem}.welcome-email-settings .recipients-add .contact-lang-fields{flex:1;display:flex;flex-direction:column;gap:.35rem}.welcome-email-settings .contact-lang-label{font-size:.7rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.welcome-email-settings .recipients-add .form-textarea,.welcome-email-settings .recipients-add .contact-lang-fields .form-textarea{flex:1;min-height:3rem}.welcome-email-settings .recipient-row .contact-lang-fields{display:flex;flex-direction:column;gap:.35rem}.welcome-email-settings .recipient-row .contact-lang-fields .form-textarea{min-height:3rem}.welcome-email-settings .contact-edit-two-lines{width:100%}.welcome-email-settings .contact-edit-two-lines .contact-lang-line{display:flex;flex-direction:column;gap:.25rem}.welcome-email-settings .contact-edit-two-lines .contact-lang-line+.contact-lang-line{margin-top:.75rem}.welcome-email-settings .contacts-four-sections{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.welcome-email-settings .contacts-section{display:flex;flex-direction:column;gap:.5rem}@media(max-width:768px){.welcome-email-settings .contacts-four-sections{grid-template-columns:1fr}}.welcome-email-settings .recipients-list{margin-top:.25rem;display:flex;flex-direction:column;gap:.4rem}.welcome-email-settings .recipient-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;padding:.5rem .6rem;border-radius:.5rem;background:var(--surface-elevated);border:1px solid var(--border-subtle)}.welcome-email-settings .recipient-row.recipient-row-editing{flex-direction:column;align-items:stretch}.welcome-email-settings .recipient-row.recipient-row-editing .recipient-left{width:100%}.welcome-email-settings .recipient-row.recipient-row-editing .recipient-actions{margin-top:.25rem;padding-top:.5rem;border-top:1px solid var(--border-subtle)}.welcome-email-settings .recipient-left{display:flex;flex-direction:column;gap:.15rem;min-width:0}.welcome-email-settings .recipient-email-two-lines{display:flex;flex-direction:column;gap:.35rem}.welcome-email-settings .recipient-email-line,.welcome-email-settings .recipient-email{font-size:.85rem;color:var(--text-primary);word-wrap:break-word;overflow-wrap:break-word}.welcome-email-settings .recipient-actions{display:flex;align-items:center;gap:.4rem}.welcome-email-settings .recipients-empty{margin-top:.4rem;font-size:.8rem;color:var(--text-secondary)}.welcome-email-settings .attachments-list{margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.4rem}.welcome-email-settings .attachment-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .6rem;border-radius:999px;border:1px solid var(--border-subtle);background:var(--surface-elevated);cursor:pointer}.welcome-email-settings .attachment-name{font-size:.8rem;color:var(--text-primary);max-width:220px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.welcome-email-settings .attachment-actions{display:flex;align-items:center}.welcome-email-settings .btn-icon{padding:.15rem;min-width:auto}.welcome-email-settings .sent-log-table-wrap{overflow-x:auto;border:1px solid var(--border-subtle);border-radius:.5rem}.welcome-email-settings .sent-log-table{width:100%;border-collapse:collapse;font-size:.85rem}.welcome-email-settings .sent-log-table th,.welcome-email-settings .sent-log-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--border-subtle)}.welcome-email-settings .sent-log-table th{background:var(--surface-elevated);font-weight:600;color:var(--text-secondary)}.welcome-email-settings .sent-log-table tbody tr:last-child td{border-bottom:none}.welcome-email-settings .sent-log-recipient{max-width:220px;display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-settings-page{max-width:640px}.app-settings-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-8);color:var(--text-secondary)}.app-settings-loading .animate-spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-settings-card{padding:var(--space-6);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl)}.app-settings-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2)}.app-settings-header h2{margin:0;font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary)}.app-settings-header svg{color:var(--primary-500)}.app-settings-description{margin:0 0 var(--space-6) 0;font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-normal)}.app-settings-field{margin-bottom:var(--space-6)}.app-settings-field label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);margin-bottom:var(--space-2)}.app-settings-field input{width:100%;max-width:240px;padding:var(--space-3) var(--space-4);font-size:var(--text-sm);border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface-bg);color:var(--text-primary)}.app-settings-field input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}.app-settings-field input:disabled{opacity:.6;cursor:not-allowed}.app-settings-error{display:block;margin-top:var(--space-2);font-size:var(--text-xs);color:var(--error-500)}.app-settings-divider{height:1px;background:var(--border-color);margin:var(--space-6) 0}.app-settings-pilot-section{margin-bottom:var(--space-6)}.app-settings-pilot-header{margin-bottom:var(--space-2)}.app-settings-pilot-title{margin:0;font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.app-settings-toggle-row{display:inline-flex;align-items:center;gap:var(--space-3);cursor:pointer;font-size:var(--text-sm);color:var(--text-primary);margin-bottom:var(--space-4)}.app-settings-toggle-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-500);cursor:pointer}.app-settings-pilot-email{margin-top:var(--space-4)}.app-settings-actions{display:flex;gap:var(--space-3)}.app-settings-save-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:var(--text-sm);font-weight:var(--font-medium);background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:var(--text-inverse);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.app-settings-save-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-400),var(--primary-500));transform:translateY(-1px)}.app-settings-save-btn:disabled{opacity:.5;cursor:not-allowed}.app-settings-save-btn .animate-spin{animation:spin 1s linear infinite}.pdf-coords-page{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem 2rem}.pdf-coords-header{display:flex;justify-content:space-between;gap:1.5rem;align-items:center}.pdf-coords-header h1{margin:0 0 .25rem;font-size:1.4rem}.pdf-coords-header p{margin:0;font-size:.9rem;color:var(--text-secondary, #64748b)}.pdf-coords-toggle{display:flex;gap:.75rem}.pdf-coords-toggle label{display:flex;align-items:center;gap:.35rem;font-size:.9rem}.pdf-coords-layout{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,3fr);gap:1.5rem;align-items:flex-start}.pdf-coords-left{display:flex;flex-direction:column;gap:.75rem}.pdf-coords-canvas{position:relative;width:100%;padding-top:calc(842 / 595 * 100%);border-radius:12px;border:1px solid #e2e8f0;background-color:#f8fafc;overflow:hidden;cursor:crosshair}.pdf-coords-canvas-inner{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:contain;object-fit:contain;background:#e5e7eb}.pdf-coords-canvas-overlay{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:center;padding:.5rem;background:linear-gradient(to top,rgba(15,23,42,.5),transparent);color:#fff;font-size:.8rem;pointer-events:none}.pdf-coords-hint{margin:0;font-size:.8rem;color:var(--text-secondary, #64748b)}.pdf-coords-right{display:flex;flex-direction:column;gap:1rem}.pdf-coords-field-group{border-radius:10px;border:1px solid #e2e8f0;padding:.75rem;background:#fff}.pdf-coords-field-group-title{font-size:.85rem;font-weight:600;margin-bottom:.5rem;color:#0f172a}.pdf-coords-field-list{display:flex;flex-wrap:wrap;gap:.4rem}.pdf-coords-field-chip{border-radius:999px;border:1px solid #e2e8f0;padding:.25rem .6rem;font-size:.8rem;display:inline-flex;align-items:center;gap:.35rem;background:#f8fafc;cursor:pointer}.pdf-coords-field-chip.active{border-color:#3b82f6;background:#eff6ff}.pdf-coords-field-chip.has-coords{border-style:solid;border-color:#10b981}.pdf-coords-field-name{white-space:nowrap}.pdf-coords-field-coords{font-size:.7rem;color:#64748b}.pdf-coords-export{border-radius:10px;border:1px solid #e2e8f0;padding:.75rem;background:#fff;display:flex;flex-direction:column;gap:.5rem}.pdf-coords-export-header{display:flex;justify-content:space-between;align-items:center}.pdf-coords-export-header h2{margin:0;font-size:.95rem}.pdf-coords-export-header button{font-size:.8rem;padding:.3rem .7rem;border-radius:999px;border:1px solid #e2e8f0;background:#f8fafc;cursor:pointer}.pdf-coords-export textarea{width:100%;border-radius:8px;border:1px solid #e2e8f0;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.75rem;padding:.4rem .5rem;resize:vertical}@media(max-width:960px){.pdf-coords-layout{grid-template-columns:minmax(0,1fr)}}.mobile-admin-policies{padding:0}.info-banner{display:flex;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:linear-gradient(135deg,#3b82f61a,#6366f11a);border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-xl);margin-bottom:var(--space-8);color:var(--text-primary)}.info-banner svg{flex-shrink:0;margin-top:var(--space-1);color:var(--primary-500)}.info-content{flex:1}.info-title{font-weight:var(--font-semibold);font-size:var(--text-sm);margin:0 0 var(--space-2) 0}.info-text{font-size:var(--text-sm);line-height:var(--leading-normal);margin:0;color:var(--text-secondary)}.table th.text-center,.table td.text-center{text-align:center}.table td{vertical-align:middle}.resource-cell{display:flex;align-items:center;gap:var(--space-3)}.resource-icon{flex-shrink:0;color:var(--primary-500)}.category-indent{width:var(--space-5);flex-shrink:0;border-left:2px solid var(--border-color);height:var(--space-5);margin-left:var(--space-2)}.resource-name{font-weight:var(--font-semibold);color:var(--text-primary)}.resource-description{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-normal)}.access-summary-cell{display:flex;align-items:center;gap:var(--space-2)}.access-summary-cell svg{flex-shrink:0;color:var(--success-dark)}.access-summary-cell span{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-medium)}.saving-indicator{display:inline-flex;align-items:center;justify-content:center;width:var(--space-5);height:var(--space-5);margin-left:var(--space-1)}.saving-indicator svg{color:var(--primary-500)}@media(max-width:768px){.info-banner{flex-direction:column;gap:var(--space-3)}}.mobile-admin-policies .loading-spinner{animation:spin 1s linear infinite;color:var(--primary-500)}.landing-page{color:var(--text-primary);background:var(--surface-bg);min-height:100vh;display:flex;flex-direction:column;font-family:Plus Jakarta Sans,sans-serif;overflow-x:hidden}.landing-hero{background:linear-gradient(135deg,#036,#005bb5,#0090ff);color:#fff;padding:120px 24px;text-align:center;position:relative;overflow:hidden;clip-path:none}.hero-background{position:absolute;inset:0;background-image:radial-gradient(circle at 10% 20%,rgba(255,255,255,.1) 0%,transparent 20%),radial-gradient(circle at 90% 80%,rgba(255,255,255,.1) 0%,transparent 20%);z-index:0;pointer-events:none}.landing-hero-content{max-width:800px;margin:0 auto;position:relative;z-index:1}.eyebrow-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:9999px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--primary-100);border:1px solid rgba(255,255,255,.2);margin-bottom:32px}.landing-hero h1{font-size:64px;line-height:1.1;margin:0 0 24px;font-weight:800;letter-spacing:-.03em;text-shadow:0 2px 10px rgba(0,0,0,.1);color:#fff}.landing-subtitle{font-size:20px;max-width:600px;margin:0 auto 48px;opacity:.9;line-height:1.6;color:var(--primary-50)}.hero-actions{display:grid;gap:16px;justify-items:center}.app-store-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.store-button{display:inline-flex;align-items:center;background:var(--gray-900);color:var(--text-inverse);padding:10px 24px;border-radius:12px;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);min-width:190px;border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.store-button:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;background:var(--gray-800)}.store-icon{width:28px;height:28px;margin-right:14px;flex:0 0 auto}.store-text{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.download-on{font-size:10px;text-transform:uppercase;opacity:.7;margin-bottom:2px;font-weight:600}.store-name{font-size:19px;font-weight:700;line-height:1.1;letter-spacing:.01em}.landing-section{padding:120px 24px;max-width:1200px;margin:0 auto;width:100%}.how-it-works-section{background:var(--surface-card);max-width:none}.landing-page .landing-how-it-works-content{max-width:1200px;margin:0 auto}.landing-page .section-header{text-align:center;margin-bottom:80px;max-width:700px;margin-left:auto;margin-right:auto}.landing-page .landing-section-title{color:var(--text-primary);font-size:40px;font-weight:800;margin-bottom:16px;letter-spacing:-.02em}.landing-page .section-description{font-size:20px;color:var(--text-secondary);line-height:1.6}.landing-page .landing-steps-container{display:grid;gap:32px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.landing-page .landing-step-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px}.landing-page .landing-step-number-badge{width:48px;height:48px;background:var(--primary-500);color:var(--text-inverse);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:var(--font-extrabold);font-size:20px;margin-bottom:24px;box-shadow:0 0 0 8px var(--info-bg)}.landing-page .landing-step-card h3{font-size:20px;font-weight:700;margin-bottom:12px;color:var(--text-primary)}.landing-page .landing-step-card p{color:var(--text-secondary);font-size:16px;line-height:1.6}.landing-footer{background:var(--gray-900);color:var(--text-muted);padding:64px 24px;margin-top:auto;border-top:1px solid var(--gray-800)}.landing-footer .landing-footer-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:32px}.landing-footer .landing-footer-brand{display:flex;flex-direction:column;gap:8px}.landing-footer .landing-footer-logo{font-size:20px;font-weight:800;color:var(--text-inverse)}.landing-footer .landing-footer-links{display:flex;gap:32px}.landing-footer .landing-footer-links a{color:var(--gray-300);text-decoration:none;font-size:14px;font-weight:500;transition:color .2s ease}.landing-footer-link-button{color:var(--gray-300);font-size:14px;font-weight:500;transition:color .2s ease}.landing-footer .landing-footer-links a:hover,.landing-footer-link-button:hover{color:var(--text-inverse)}.landing-footer .landing-footer-copyright{font-size:14px;color:var(--gray-300)}.contact-dialog-overlay{position:fixed;inset:0;background:#0206178c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000}.contact-dialog-content{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);width:min(640px,calc(100vw - 32px));max-height:calc(100vh - 32px);overflow:auto;background:var(--surface-card);border-radius:20px;border:1px solid var(--border-color);box-shadow:0 30px 90px #02061759;padding:22px;z-index:1001}.contact-dialog-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}.contact-dialog-title{font-size:20px;font-weight:800;color:var(--text-primary);margin:0}.contact-dialog-description{margin:6px 0 0;color:var(--text-secondary);font-size:14px;line-height:1.5}.contact-dialog-close{width:36px;height:36px;border-radius:10px;border:1px solid var(--border-color);background:var(--surface-card);color:var(--text-primary);font-size:22px;line-height:1}.contact-dialog-close:hover{background:var(--surface-bg)}.landing-contact-form{display:grid;gap:14px}.landing-contact-field{display:grid;gap:8px}.landing-contact-field span{font-size:13px;font-weight:700;color:var(--text-primary)}.landing-contact-field input,.landing-contact-field textarea{border:1px solid var(--border-color);border-radius:12px;padding:12px;font-size:14px;background:var(--surface-card);color:var(--text-primary)}.landing-contact-field textarea{resize:vertical}.landing-contact-honeypot{display:none}.landing-contact-captcha{margin-top:6px}.landing-contact-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}.landing-contact-submit{flex:1;min-width:180px;display:inline-flex;align-items:center;justify-content:center;padding:12px 14px;border-radius:12px;background:var(--primary-500);color:var(--text-inverse);font-weight:800;border:1px solid var(--primary-500)}.landing-contact-submit:disabled{opacity:.55;cursor:not-allowed}.landing-contact-cancel{padding:12px 14px;border-radius:12px;background:var(--surface-card);color:var(--text-primary);font-weight:700;border:1px solid var(--border-color)}.landing-contact-cancel:hover{background:var(--surface-bg)}.landing-contact-status{margin:6px 0 0;font-size:14px;font-weight:600}.landing-contact-status.sent{color:var(--success-dark)}.landing-contact-status.error{color:var(--error-dark)}.privacy-page{background:var(--surface-card)}.privacy-page .privacy-header{background:var(--surface-bg);padding:48px 24px;border-bottom:1px solid var(--border-color)}.privacy-page .privacy-header-content{max-width:800px;margin:0 auto}.privacy-page .back-button{display:inline-flex;align-items:center;color:var(--text-secondary);text-decoration:none;font-weight:600;margin-bottom:32px;font-size:14px;transition:color .2s}.privacy-page .back-button:hover{color:var(--primary-500)}.privacy-page .privacy-title-wrapper h1{font-size:40px;font-weight:800;color:var(--text-primary);margin:0 0 8px;letter-spacing:-.02em}.privacy-page .privacy-updated{font-size:14px;color:var(--text-secondary);font-weight:500}.privacy-page .privacy-container{max-width:800px;margin:0 auto;padding:64px 24px}.privacy-page .privacy-section-card{margin-bottom:48px}.privacy-page .privacy-section-card h2{font-size:24px;font-weight:700;color:var(--primary-500);margin-bottom:24px;letter-spacing:-.01em}.privacy-page .privacy-section-card h3{font-size:18px;font-weight:700;color:var(--text-primary);margin:24px 0 16px}.privacy-page .privacy-section-card p{color:var(--gray-700);line-height:1.8;margin-bottom:16px;font-size:16px}.privacy-page .contact-info{font-style:italic;color:var(--text-secondary);font-weight:500}.privacy-page .in-short-box{background:var(--primary-50);border-left:4px solid var(--primary-500);padding:16px 20px;margin-bottom:24px;border-radius:0 8px 8px 0}.privacy-page .in-short-box p{margin:0;font-weight:500;color:var(--primary-900);font-style:italic}.privacy-page .privacy-list{padding-left:24px;margin-bottom:24px;list-style-type:disc}.privacy-page .privacy-list li{color:var(--gray-700);margin-bottom:8px;line-height:1.6;padding-left:8px}@media(max-width:768px){.landing-hero{padding:80px 24px;clip-path:none}.landing-hero h1{font-size:40px}.store-button{width:100%;justify-content:center}.landing-section{padding:64px 24px}.landing-footer .landing-footer-content{flex-direction:column;text-align:center}.privacy-title-wrapper h1{font-size:32px}}.du-page{min-height:100vh;position:relative;overflow:hidden;background:var(--surface-bg);display:flex;flex-direction:column}.du-bg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}.du-orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:.25;animation:float 22s ease-in-out infinite}.du-orb-1{width:700px;height:700px;background:radial-gradient(circle,var(--primary-500),transparent 70%);top:-250px;right:-200px;animation-delay:0s}.du-orb-2{width:500px;height:500px;background:radial-gradient(circle,var(--accent-500),transparent 70%);bottom:-200px;left:-150px;animation-delay:-10s}.du-grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgba(15,23,42,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(15,23,42,.035) 1px,transparent 1px);background-size:60px 60px;-webkit-mask-image:radial-gradient(ellipse at center,black 20%,transparent 75%);mask-image:radial-gradient(ellipse at center,black 20%,transparent 75%)}.du-center{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-5);padding:var(--space-8);text-align:center}.du-center-text{color:var(--text-secondary);font-size:var(--text-sm);margin:0}.du-spinner{color:var(--primary-500);animation:spin .9s linear infinite}.du-success-icon{display:inline-flex;align-items:center;justify-content:center;width:88px;height:88px;border-radius:50%;background:var(--success-bg);color:var(--success-dark);animation:scaleIn var(--transition-slow) forwards}.du-success-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0}.du-success-desc{font-size:var(--text-sm);color:var(--text-secondary);max-width:380px;margin:0}.du-wrapper{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;max-width:700px;width:100%;margin:0 auto;padding:var(--space-8) var(--space-5) var(--space-10)}.du-header{margin-bottom:var(--space-8);animation:fadeInDown var(--transition-normal) forwards}.du-header-inner{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4)}.du-page-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0 0 var(--space-1) 0;background:linear-gradient(135deg,var(--primary-500),var(--primary-400));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.du-page-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.du-card{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-2xl);padding:var(--space-8);box-shadow:var(--shadow-lg);animation:scaleIn var(--transition-slow) forwards;display:flex;flex-direction:column;gap:var(--space-8)}.du-avatar-row{display:flex;align-items:center;gap:var(--space-5)}.du-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--primary-500),var(--accent-500));color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);font-weight:var(--font-bold);flex-shrink:0;box-shadow:0 0 0 3px var(--border-color)}.du-user-name{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-1) 0}.du-user-email{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-2) 0}.du-badge{display:inline-flex;align-items:center;padding:2px var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold)}.du-badge-admin{background:#3b82f61f;color:var(--primary-600);border:1px solid rgba(59,130,246,.25)}.du-section{display:flex;flex-direction:column;gap:var(--space-4)}.du-section+.du-section{border-top:1px solid var(--border-color);padding-top:var(--space-8)}.du-section-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin:0}.du-fields-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.du-field{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--surface-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:border-color var(--transition-fast)}.du-field:hover{border-color:var(--border-hover)}.du-field-icon{color:var(--primary-500);flex-shrink:0;margin-top:2px}.du-field-content{display:flex;flex-direction:column;gap:2px;min-width:0}.du-field-label{font-size:var(--text-xs);color:var(--text-muted);font-weight:var(--font-medium);white-space:nowrap}.du-field-value{font-size:var(--text-sm);color:var(--text-primary);font-weight:var(--font-medium);word-break:break-word}.du-danger-title{color:var(--error-dark)!important}.du-danger-desc{font-size:var(--text-sm);color:var(--text-secondary);margin:0;line-height:1.6}.du-admin-notice{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--warning-bg);border:1px solid var(--warning-border);border-radius:var(--radius-lg);color:var(--warning-dark);font-size:var(--text-sm);line-height:1.5}.du-admin-notice-icon{flex-shrink:0;margin-top:1px}.du-admin-notice p{margin:0}.du-error-alert{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--error-bg);border:1px solid var(--error-border);border-radius:var(--radius-lg);color:var(--error-dark);font-size:var(--text-sm)}.du-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--transition-fast);border:1px solid transparent;white-space:nowrap}.du-btn:disabled{opacity:.65;cursor:not-allowed}.du-btn-primary{background:var(--primary-500);color:#fff;border-color:var(--primary-500)}.du-btn-primary:hover:not(:disabled){background:var(--primary-600);border-color:var(--primary-600);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f659}.du-btn-ghost{background:transparent;color:var(--text-secondary);border-color:var(--border-color)}.du-btn-ghost:hover:not(:disabled){background:var(--surface-bg);border-color:var(--border-hover);color:var(--text-primary)}.du-btn-danger{background:transparent;color:var(--error-dark);border-color:var(--error-border)}.du-btn-danger:hover:not(:disabled){background:var(--error-bg);box-shadow:0 0 0 2px var(--error-border);transform:translateY(-1px)}.du-btn-spinner{animation:spin .9s linear infinite}.du-modal-backdrop{position:fixed;inset:0;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-5);animation:fadeIn var(--transition-fast) forwards}.du-modal{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-2xl);padding:var(--space-8);max-width:440px;width:100%;box-shadow:var(--shadow-lg);animation:scaleIn var(--transition-normal) forwards;display:flex;flex-direction:column;gap:var(--space-4);position:relative}.du-modal-header{display:flex;align-items:center;justify-content:space-between}.du-modal-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;background:var(--error-bg);color:var(--error-dark)}.du-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.du-modal-close:hover:not(:disabled){background:var(--surface-bg);color:var(--text-primary)}.du-modal-title{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0}.du-modal-body{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6;margin:0}.du-modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-2)}@media(max-width:640px){.du-wrapper{padding:var(--space-5) var(--space-4) var(--space-8)}.du-card{padding:var(--space-5)}.du-fields-grid{grid-template-columns:1fr}.du-header-inner{flex-direction:column;gap:var(--space-3)}.du-modal-actions{flex-direction:column-reverse}.du-modal-actions .du-btn{width:100%;justify-content:center}.du-page-title{font-size:var(--text-xl)}.du-avatar{width:56px;height:56px;font-size:var(--text-lg)}}.auth-callback{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6);background:radial-gradient(circle at top,var(--primary-50) 0%,var(--surface-bg) 45%,var(--gray-100) 100%);color:var(--text-primary)}.auth-callback-card{background:var(--surface-card);border-radius:var(--radius-3xl);padding:var(--space-8);max-width:560px;width:100%;text-align:center;box-shadow:0 24px 60px #0f172a1f;border:1px solid var(--border-color);display:grid;gap:var(--space-4)}.auth-callback-card h1{color:var(--text-primary);margin:0;font-size:var(--text-2xl);font-weight:var(--font-semibold)}.auth-callback-card p{color:var(--text-secondary);margin:0;line-height:1.6}.auth-callback-actions{display:flex;gap:var(--space-3);justify-content:center;flex-wrap:wrap;margin-top:var(--space-2)}.auth-callback-note{margin-top:var(--space-2);font-size:var(--text-sm);color:var(--text-muted)}.auth-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);min-width:160px;font-weight:var(--font-semibold);font-size:var(--text-sm);line-height:1.1;border:1px solid transparent}.auth-button:focus-visible{outline:none;box-shadow:0 0 0 3px #3b82f633}.auth-button.primary{background:var(--primary-500);color:var(--text-inverse);border-radius:var(--radius-full);padding:var(--space-3) var(--space-5);text-decoration:none;transition:background-color var(--transition-fast),box-shadow var(--transition-fast)}.auth-button.primary:hover{background:var(--primary-600);box-shadow:0 10px 20px #3b82f633}.auth-button.ghost{border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--radius-full);padding:var(--space-3) var(--space-5);text-decoration:none;transition:border-color var(--transition-fast),color var(--transition-fast)}.auth-button.ghost:hover{border-color:var(--gray-400);color:var(--text-primary)}@media(max-width:640px){.auth-callback{padding:var(--space-4)}.auth-callback-card{padding:var(--space-6);border-radius:var(--radius-2xl);text-align:left}.auth-callback-actions{flex-direction:column;align-items:stretch}.auth-button{width:100%}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:var(--text-sm);font-weight:var(--font-medium);line-height:1;border-radius:var(--radius-lg);transition:all var(--transition-fast);cursor:pointer;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:var(--text-inverse);box-shadow:0 4px 14px #3b82f659}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-400),var(--primary-500));box-shadow:0 6px 20px #3b82f673;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #3b82f64d}.btn-secondary{background:var(--surface-card);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-300);color:var(--text-primary)}.btn-success{background:linear-gradient(135deg,var(--success-light),#16a34a);color:var(--text-inverse);box-shadow:0 4px 14px #22c55e59}.btn-success:hover:not(:disabled){box-shadow:0 6px 20px #22c55e73;transform:translateY(-1px)}.btn-danger{background:linear-gradient(135deg,var(--error-light),#dc2626);color:var(--text-inverse);box-shadow:0 4px 14px #ef444459}.btn-danger:hover:not(:disabled){box-shadow:0 6px 20px #ef444473;transform:translateY(-1px)}.field-control{background:var(--surface-card)!important;border:1px solid var(--border-color)!important;color:var(--text-primary)}.field-control:hover:not(:disabled){border-color:var(--border-hover)!important}.select-content .select-item:not(:last-child){border-bottom:1px solid var(--select-row-separator, var(--border-color))}.btn-destructive-glow{background:linear-gradient(135deg,var(--error-light),var(--error-dark));color:var(--text-inverse);border:1px solid var(--error-light);box-shadow:0 0 0 1px #ef444466,0 0 12px #ef444459;transition:all var(--transition-fast)}.btn-destructive-glow:hover:not(:disabled){box-shadow:0 0 0 1px #ef44448c,0 0 16px #ef444473;transform:translateY(-1px)}.btn-destructive-glow:active:not(:disabled){transform:translateY(0);box-shadow:0 0 0 1px #ef444480,0 0 10px #ef444459}.btn-ghost{background:transparent;color:var(--gray-600)}.btn-ghost:hover:not(:disabled){background:var(--gray-100);color:var(--text-primary)}.btn-icon{padding:var(--space-2);aspect-ratio:1}.btn-icon svg{width:20px;height:20px}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--text-base)}.form-group{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-3)}.form-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--gray-700)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-3) var(--space-4);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-sm);transition:all var(--transition-fast)}.form-input::-moz-placeholder,.form-textarea::-moz-placeholder{color:var(--text-muted)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-input:hover,.form-select:hover,.form-textarea:hover{border-color:var(--border-hover)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #3b82f633}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{opacity:.5;cursor:not-allowed;background:var(--gray-100)}.form-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.form-textarea{min-height:100px;resize:vertical}.form-checkbox-group{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center}.form-checkbox-label{display:inline-flex;align-items:center;gap:var(--space-3);cursor:pointer;font-size:var(--text-sm);color:var(--gray-700);-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:all .15s ease;padding:0 var(--space-3);border-radius:var(--radius-lg);background:var(--surface-card);border:1px solid var(--border-color);height:42px}.form-checkbox-label:hover{color:var(--text-primary);border-color:var(--border-hover);background:var(--gray-50)}.form-checkbox-label span{font-weight:var(--font-medium)}.form-checkbox-label input[type=checkbox],.form-checkbox-label input[type=radio]{width:18px;height:18px;accent-color:var(--primary-500);cursor:pointer}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);align-items:start}@media(max-width:640px){.form-row{grid-template-columns:1fr}}.form-error{color:var(--error-light);font-size:var(--text-xs);margin-top:var(--space-1)}.card{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden}.card-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.card-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary)}.card-body{padding:var(--space-6)}.card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color);background:var(--gray-50)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.5px;border-radius:var(--radius-md)}.badge-success{background:var(--success-bg);color:var(--success-dark);border:1px solid rgba(34,197,94,.5)}.badge-warning{background:var(--warning-bg);color:var(--warning-dark);border:1px solid rgba(245,158,11,.5)}.badge-error{background:var(--error-bg);color:var(--error-dark);border:1px solid rgba(239,68,68,.5)}.badge-info{background:var(--info-bg);color:var(--info-dark);border:1px solid rgba(59,130,246,.5)}.badge-neutral{background:#6b72801a;color:var(--gray-600);border:1px solid var(--border-color)}.table-container{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden}.table-scroll{overflow-x:auto}.table{width:100%;min-width:700px}.table th{padding:var(--space-4) var(--space-5);text-align:left;font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.5px;color:var(--gray-600);background:var(--surface-bg);border-bottom:1px solid var(--border-color);white-space:nowrap}.table td{padding:var(--space-4) var(--space-5);font-size:var(--text-sm);color:var(--gray-700);border-bottom:1px solid var(--border-color)}.table tbody tr{transition:background-color var(--transition-fast)}.table tbody tr:hover{background:var(--gray-50)}.table tbody tr:last-child td{border-bottom:none}.alert{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);animation:fadeInDown var(--transition-normal) forwards}.alert-icon{flex-shrink:0;width:20px;height:20px}.alert-content{flex:1}.alert-dismiss{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-md);opacity:.7;transition:opacity var(--transition-fast)}.alert-dismiss:hover{opacity:1}.alert-success{background:var(--success-bg);border:1px solid rgba(34,197,94,.5);color:var(--success-dark)}.alert-error{background:var(--error-bg);border:1px solid rgba(239,68,68,.5);color:var(--error-dark)}.alert-warning{background:var(--warning-bg);border:1px solid rgba(245,158,11,.5);color:var(--warning-dark)}.alert-info{background:var(--info-bg);border:1px solid rgba(59,130,246,.5);color:var(--info-dark)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);text-align:center}.empty-state-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:var(--gray-50);border-radius:var(--radius-full);margin-bottom:var(--space-6);color:var(--gray-400)}.empty-state-icon svg{width:40px;height:40px}.empty-state-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--text-sm);color:var(--gray-500);max-width:400px}.page-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-8)}.page-title-section{display:flex;align-items:center;gap:var(--space-4);flex:1}.page-title-wrapper{display:flex;flex-direction:column;gap:var(--space-1)}.page-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0}.page-subtitle{font-size:var(--text-sm);color:var(--gray-500);margin:var(--space-1) 0 0 0}.page-actions{display:flex;align-items:center;gap:var(--space-3)}@media(max-width:640px){.page-header{flex-direction:column;align-items:stretch}.page-actions{flex-direction:column}.page-actions .btn{width:100%}}.search-wrapper{position:relative;max-width:320px;width:100%}.search-icon{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);color:var(--gray-400);pointer-events:none}.search-input{width:100%;padding:var(--space-3) var(--space-4);padding-left:calc(var(--space-4) + 24px);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-sm);transition:all var(--transition-fast)}.search-input::-moz-placeholder{color:var(--text-muted)}.search-input::placeholder{color:var(--text-muted)}.search-input:hover{border-color:var(--border-hover)}.search-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #3b82f633}@media(max-width:640px){.search-wrapper{max-width:100%}}.action-buttons{display:flex;align-items:center;gap:var(--space-2)}.action-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.action-btn:hover{background-color:var(--surface-hover);border-color:transparent;color:var(--text-primary)}.action-btn-view{color:var(--primary-500)}.action-btn-view:hover{color:var(--primary-600);background-color:var(--primary-50)}.action-btn-edit{color:var(--warning-light)}.action-btn-edit:hover{color:var(--warning-dark);background-color:var(--warning-bg)}.action-btn-delete{color:var(--error-light)}.action-btn-delete:hover{color:var(--error-dark);background-color:var(--error-bg)}.action-btn svg{width:16px;height:16px}.action-btn-placeholder{visibility:hidden;pointer-events:none}@media(max-width:1024px){.hide-lg{display:none!important}}@media(max-width:768px){.hide-md{display:none!important}.show-md{display:block!important}}@media(max-width:640px){.hide-sm{display:none!important}.show-sm{display:block!important}}
