*,: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:#e5e7eb}: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:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";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:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;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:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}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}}.\!visible{visibility:visible!important}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.left-0{left:0}.right-2{right:.5rem}.right-4{right:1rem}.top-0{top:0}.top-1\/2{top:50%}.top-4{top:1rem}.z-\[10000\]{z-index:10000}.z-\[9999\]{z-index:9999}.mx-auto{margin-left:auto;margin-right:auto}.my-6{margin-top:1.5rem;margin-bottom:1.5rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-4{margin-left:1rem}.mr-2{margin-right:.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.block{display:block}.inline{display:inline}.flex{display:flex}.grid{display:grid}.hidden{display:none}.h-5{height:1.25rem}.h-full{height:100%}.max-h-\[70vh\]{max-height:70vh}.w-1{width:.25rem}.w-5{width:1.25rem}.w-72{width:18rem}.w-\[800px\]{width:800px}.w-full{width:100%}.max-w-\[200px\]{max-width:200px}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.-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))}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.resize-none{resize:none}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0\.5{gap:.125rem}.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-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.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-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * 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-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.25rem * var(--tw-space-y-reverse))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.break-all{word-break:break-all}.rounded{border-radius:.25rem}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-l{border-left-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-\[var\(--border\)\]{border-color:var(--border)}.border-green-400{--tw-border-opacity: 1;border-color:rgb(74 222 128 / var(--tw-border-opacity, 1))}.border-red-400{--tw-border-opacity: 1;border-color:rgb(248 113 113 / var(--tw-border-opacity, 1))}.border-red-500{--tw-border-opacity: 1;border-color:rgb(239 68 68 / var(--tw-border-opacity, 1))}.border-red-500\/20{border-color:#ef444433}.border-red-500\/30{border-color:#ef44444d}.bg-\[var\(--accent\)\]{background-color:var(--accent)}.bg-\[var\(--bg\)\]{background-color:var(--bg)}.bg-\[var\(--panel\)\]{background-color:var(--panel)}.bg-\[var\(--panel-2\)\]{background-color:var(--panel-2)}.bg-\[var\(--surface\)\]{background-color:var(--surface)}.bg-black\/30{background-color:#0000004d}.bg-emerald-500{--tw-bg-opacity: 1;background-color:rgb(16 185 129 / var(--tw-bg-opacity, 1))}.bg-green-500\/90{background-color:#22c55ee6}.bg-red-500\/10{background-color:#ef44441a}.bg-red-500\/90{background-color:#ef4444e6}.p-1{padding:.25rem}.p-2{padding:.5rem}.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-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.pl-4{padding-left:1rem}.pr-10{padding-right:2.5rem}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.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-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.text-\[var\(--muted\)\]{color:var(--muted)}.text-\[var\(--text\)\]{color:var(--text)}.text-blue-400{--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity, 1))}.text-emerald-400{--tw-text-opacity: 1;color:rgb(52 211 153 / var(--tw-text-opacity, 1))}.text-green-400{--tw-text-opacity: 1;color:rgb(74 222 128 / var(--tw-text-opacity, 1))}.text-red-400{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.opacity-50{opacity:.5}.shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -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-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.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)}.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{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;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}.duration-300{transition-duration:.3s}:root{--bg: #f0f2f5;--bg-white: #ffffff;--bg-card: #ffffff;--bg-elevated: #f7f8fa;--bg-input: #ffffff;--accent: #0064E0;--accent-dim: rgba(0, 100, 224, .08);--accent-hover: #0143B5;--accent-light: #47A5FA;--text: #1C2B33;--text-primary: #1C2B33;--text-secondary: #465A69;--muted: #8595A4;--text-muted: #8595A4;--border: #DEE3E9;--border-light: #CED0D4;--red: #C80A28;--red-bg: rgba(200, 10, 40, .07);--green: #007D1E;--green-bg: rgba(0, 125, 30, .07);--orange: #c2410c;--orange-bg: rgba(194, 65, 12, .07);--purple: #6441D2;--purple-bg: rgba(100, 65, 210, .08);--nav-h: 60px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 24px;--radius-pill: 100px;--shadow-card: 0 1px 3px rgba(0, 0, 0, .06), 0 4px 16px rgba(0, 0, 0, .05);--shadow-pop: 0 8px 32px rgba(0, 0, 0, .12);--surface: var(--bg-card);--panel: var(--bg-card);--panel-2: var(--bg-elevated)}[data-theme=dark]{--bg: #050A1D;--bg-white: #071233;--bg-card: #0B1737;--bg-elevated: #111D42;--bg-input: #08122F;--accent: #F8FAFC;--accent-dim: rgba(248, 250, 252, .1);--accent-hover: #DBEAFE;--accent-light: #93C5FD;--text: #F8FAFC;--text-primary: #F8FAFC;--text-secondary: #DDE7F6;--muted: #9BA9C4;--text-muted: #9BA9C4;--border: rgba(226, 232, 240, .14);--border-light: rgba(248, 250, 252, .28);--red: #FF6B7D;--red-bg: rgba(255, 107, 125, .13);--green: #65E38B;--green-bg: rgba(101, 227, 139, .13);--orange: #FDBA74;--orange-bg: rgba(253, 186, 116, .14);--purple: #C4B5FD;--purple-bg: rgba(196, 181, 253, .13);--shadow-card: 0 1px 0 rgba(255, 255, 255, .04), 0 18px 46px rgba(0, 0, 0, .22);--shadow-pop: 0 20px 70px rgba(0, 0, 0, .45)}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Space Grotesk,sans-serif;background:var(--bg);color:var(--text-primary);font-size:14px;line-height:1.5;overflow:hidden}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.mono{font-family:JetBrains Mono,monospace}.app-shell{height:100vh;min-height:0;display:flex;background:var(--bg);overflow:hidden}.app-sidebar{width:264px;height:100vh;min-height:0;background:var(--bg-white);border-right:1px solid var(--border);box-shadow:1px 0 18px #0712330f;display:flex;flex-direction:column;padding:22px 16px;position:sticky;top:0;flex-shrink:0;overflow:hidden}.sidebar-brand{display:flex;flex-direction:column;gap:12px;margin-bottom:28px}.sidebar-logo{width:178px;max-width:100%;height:auto;display:block}.sidebar-brand-title{font-size:12px;font-weight:700;color:var(--text-primary);letter-spacing:.08em;text-transform:uppercase}.sidebar-brand-sub{font-size:11px;color:var(--text-muted);font-weight:600;margin-top:2px}.sidebar-links{display:flex;flex-direction:column;gap:6px;flex:1}.nav-link{display:flex;align-items:center;gap:10px;min-height:42px;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:600;color:var(--text-secondary);transition:all .16s ease;position:relative;-webkit-user-select:none;-moz-user-select:none;user-select:none;white-space:nowrap;text-decoration:none}.nav-link:hover{background:var(--bg-elevated);color:var(--text-primary)}.nav-link.active{color:var(--accent);background:var(--accent-dim);font-weight:600}.sidebar-footer{display:flex;flex-direction:column;gap:10px;padding-top:18px;border-top:1px solid var(--border)}.theme-toggle{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;min-height:40px;padding:9px 12px;border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;font-family:Space Grotesk,sans-serif;font-size:13px;font-weight:700;transition:all .15s ease}.theme-toggle:hover{color:var(--text-primary);border-color:var(--border-light)}.user-pill{display:flex;align-items:center;gap:8px;padding:5px 12px 5px 5px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-pill);cursor:pointer;transition:all .15s ease;width:100%}.user-pill:hover{border-color:var(--border-light);box-shadow:var(--shadow-card)}.user-avatar{width:26px;height:26px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}[data-theme=dark] .user-avatar{color:#071233}.user-name{font-size:13px;font-weight:600;color:var(--text-secondary)}.logout-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:7px 14px;border-radius:var(--radius-sm);background:transparent;border:1px solid var(--border);cursor:pointer;font-family:Space Grotesk,sans-serif;font-size:13px;font-weight:500;color:var(--text-muted);transition:all .15s ease;width:100%}.logout-btn:hover{color:var(--red);border-color:#c80a284d;background:var(--red-bg)}.app-main{flex:1;min-width:0;min-height:0;overflow-y:auto}.app-content{max-width:1200px;margin:0 auto;min-height:100%;padding:28px 28px 48px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.card-contrast{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md)}.card-hover:hover{transform:translateY(-2px);box-shadow:var(--shadow-pop)}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-family:Space Grotesk,sans-serif;font-size:13px;font-weight:600;transition:all .15s ease;white-space:nowrap}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 2px 8px #0064e04d}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 16px #0064e066}.btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg-elevated);color:var(--text-primary)}.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid rgba(200,10,40,.2)}.btn-danger:hover{background:#c80a281f}.btn-sm{padding:6px 12px;font-size:12px}.btn-icon{padding:7px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s ease;font-family:Space Grotesk,sans-serif}.btn-icon:hover{color:var(--text-primary);border-color:var(--border-light)}.btn-icon:disabled{opacity:.4;cursor:not-allowed}.btn-accent{display:inline-flex;align-items:center;justify-content:center;padding:9px 18px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-family:Space Grotesk,sans-serif;font-size:13px;font-weight:600;background:var(--accent);color:#fff;box-shadow:0 2px 8px #0064e04d;transition:all .15s ease;gap:7px}.btn-accent:hover{background:var(--accent-hover);transform:translateY(-1px)}.btn-accent:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 18px;border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;font-family:Space Grotesk,sans-serif;font-size:13px;font-weight:600;background:var(--bg-elevated);color:var(--text-secondary);transition:all .15s ease}.btn-secondary:hover{background:var(--bg-card);color:var(--text-primary);border-color:var(--border-light)}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}input[type=text],input[type=password],input[type=date],input[type=number],select,textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:13px;padding:9px 12px;width:100%;transition:border-color .15s ease,box-shadow .15s ease;outline:none}input[type=text]:focus,input[type=password]:focus,input[type=date]:focus,input[type=number]:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}input::-moz-placeholder{color:var(--text-muted)}input::placeholder{color:var(--text-muted)}.overlay{position:fixed;inset:0;background:#1c2b3373;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-pop);width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-wide{max-width:720px}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 24px 0;flex-shrink:0}.modal-title{font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.modal-subtitle{font-size:12px;color:var(--text-muted);margin-top:3px}.modal-close{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);transition:all .15s ease;flex-shrink:0}.modal-close:hover{color:var(--text-primary);border-color:var(--border-light)}.modal-body{padding:20px 24px;overflow-y:auto;flex:1}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-shrink:0;background:var(--bg-elevated)}.conference-modal-name-section{padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--bg-card)}.conference-modal-split{display:flex;flex:1;overflow:hidden;min-height:0}.conference-modal-search{width:40%;display:flex;flex-direction:column;border-right:1px solid var(--border);min-width:0}.conference-modal-base{width:60%;display:flex;flex-direction:column;min-width:0}.conference-selected-item{padding:12px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--bg-elevated) 70%,var(--bg-card))}.conference-modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;flex-shrink:0;background:var(--bg-elevated)}.detail-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.detail-value{font-size:14px;font-weight:500;color:var(--text-primary)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.detail-section{margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}.detail-section-title{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px}.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-pill);font-size:11px;font-weight:600}.chip-accent{background:var(--accent-dim);color:var(--accent)}.chip-green{background:var(--green-bg);color:var(--green)}.chip-red{background:var(--red-bg);color:var(--red)}.chip-orange{background:var(--orange-bg);color:var(--orange)}.chip-purple{background:var(--purple-bg);color:var(--purple)}.chip-gray{background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border)}.cat-badge{display:inline-flex;padding:3px 10px;border-radius:var(--radius-pill);font-size:11px;font-weight:600}.cat-badge.fert{background:var(--green-bg);color:var(--green)}.cat-badge.seed{background:var(--orange-bg);color:var(--orange)}.cat-badge.maq{background:var(--purple-bg);color:var(--purple)}.data-table{width:100%;border-collapse:collapse}.data-table thead th{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:10px 12px;text-align:left;border-bottom:1px solid var(--border);background:var(--bg-elevated)}.data-table tbody td{padding:12px;border-bottom:1px solid var(--border);font-size:13px;color:var(--text-primary)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:var(--bg-elevated)}.stock-table-card{overflow:hidden;padding:0;display:flex;flex-direction:column}.stock-table-scroll{max-height:min(58vh,620px);overflow-y:auto}.reader-history-card{overflow:hidden;padding:0;display:flex;flex-direction:column;min-height:0}.reader-history-scroll{max-height:min(36vh,420px);overflow-y:auto;overscroll-behavior:contain}.reader-fixed-page{min-height:0}.reader-live-card{flex:0 0 auto}.login-shell{display:flex;height:100vh;width:100vw;background:var(--bg)}.login-image-side{flex:1;position:relative;overflow:hidden}.login-image-side img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;filter:brightness(.75)}.login-image-overlay{position:absolute;inset:0;background:linear-gradient(120deg,#0064e08c,#0000008c);display:flex;flex-direction:column;justify-content:flex-end;padding:48px}.login-image-tag{display:inline-flex;align-items:center;gap:8px;background:#ffffff1f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-pill);padding:6px 14px;font-size:12px;font-weight:600;color:#fff;letter-spacing:.06em;text-transform:uppercase;margin-bottom:16px;width:-moz-fit-content;width:fit-content}.login-image-headline{font-size:36px;font-weight:700;color:#fff;line-height:1.15;letter-spacing:-.02em;max-width:380px;margin-bottom:12px}.login-image-sub{font-size:14px;color:#ffffffa6;max-width:320px;line-height:1.6}.login-form-side{width:440px;min-width:440px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:56px 48px;background:var(--bg-white);border-left:1px solid var(--border);position:relative}.login-theme-btn{position:absolute;top:24px;right:24px;display:inline-flex;align-items:center;gap:7px;padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:700;transition:all .15s ease}.login-theme-btn:hover{color:var(--text-primary);border-color:var(--border-light)}.login-logo{display:flex;flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:40px;align-self:flex-start}.login-logo img{width:210px;max-width:100%;height:auto;display:block}.login-logo-sub{font-size:11px;color:var(--text-muted);font-weight:700;letter-spacing:.08em;text-transform:uppercase}.login-heading{font-size:26px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:6px;align-self:flex-start}.login-sub{font-size:13px;color:var(--text-muted);margin-bottom:32px;align-self:flex-start}.login-form{width:100%;display:flex;flex-direction:column;gap:16px}.login-field{display:flex;flex-direction:column;gap:6px}.login-label{font-size:12px;font-weight:600;color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase}.login-input-wrap{position:relative}.login-input-wrap svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--text-muted);pointer-events:none}.login-input-wrap input{padding-left:38px}.login-btn{margin-top:8px;width:100%;padding:13px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-family:Space Grotesk,sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .18s ease;letter-spacing:.02em;box-shadow:0 4px 18px #0064e059}.login-btn:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 24px #0064e073}.login-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}.login-error{background:var(--red-bg);border:1px solid rgba(200,10,40,.2);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;color:var(--red);font-weight:500;display:flex;align-items:center;gap:8px}.login-footer{margin-top:32px;font-size:11px;color:var(--text-muted);text-align:center;line-height:1.7;align-self:center}.page-wrap{flex:1;overflow-y:auto}.content{max-width:1200px;margin:0 auto;padding:28px 28px 48px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px}.page-title{font-size:24px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.page-subtitle{font-size:13px;color:var(--text-muted);margin-top:3px}.dash-hero{background:linear-gradient(135deg,#0064e0,#0143b5 60%,#003a9a);border-radius:var(--radius-xl);padding:32px 36px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;overflow:hidden;position:relative}.dash-hero:before{content:"";position:absolute;right:-60px;top:-60px;width:280px;height:280px;border-radius:50%;background:#ffffff0d;pointer-events:none}.dash-hero:after{content:"";position:absolute;right:60px;bottom:-80px;width:200px;height:200px;border-radius:50%;background:#ffffff0d;pointer-events:none}.hero-greeting{font-size:13px;font-weight:600;color:#ffffffa6;letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px}.hero-title{font-size:30px;font-weight:700;color:#fff;letter-spacing:-.02em;margin-bottom:12px}.hero-chips{display:flex;gap:8px;flex-wrap:wrap}.hero-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:var(--radius-pill);background:#ffffff26;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.2);font-size:12px;font-weight:600;color:#fff;cursor:pointer;transition:background .15s}.hero-chip:hover{background:#ffffff38}.hero-right{display:flex;gap:16px;position:relative;z-index:1}.hero-stat{background:#ffffff1f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);padding:18px 22px;text-align:center;min-width:100px}.hero-stat-val{font-size:32px;font-weight:700;color:#fff;letter-spacing:-.02em;line-height:1}.hero-stat-label{font-size:11px;color:#fff9;font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-top:6px}.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:18px 20px;box-shadow:var(--shadow-card);transition:all .2s ease;cursor:default}.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-pop)}.dashboard-chart-card{padding:22px 24px;margin-bottom:20px}.dashboard-chart-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}.dashboard-chart-title{font-size:15px;font-weight:700;color:var(--text-primary)}.dashboard-chart-subtitle{font-size:12px;color:var(--text-muted);margin-top:2px}.dashboard-chart-link{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);border-radius:var(--radius-sm);padding:8px 10px;font-size:12px;font-weight:700;text-decoration:none;white-space:nowrap;transition:all .15s ease}.dashboard-chart-link:hover{border-color:var(--border-light);color:var(--text-primary)}.dashboard-chart-body{height:280px;min-height:280px}.dashboard-chart-empty{height:100%;display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;border:1px dashed var(--border);border-radius:var(--radius-md);background:var(--bg-elevated)}.chart-tooltip{min-width:180px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);box-shadow:var(--shadow-pop);padding:10px 12px}.chart-tooltip-title{font-size:12px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.chart-tooltip-row{display:flex;align-items:center;justify-content:space-between;gap:16px;font-size:11px;color:var(--text-muted)}.chart-tooltip-row+.chart-tooltip-row{margin-top:4px}.chart-tooltip-row strong{color:var(--text-primary);font-size:12px}.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.kpi-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.kpi-icon-blue{background:var(--accent-dim);color:var(--accent)}.kpi-icon-green{background:var(--green-bg);color:var(--green)}.kpi-icon-orange{background:var(--orange-bg);color:var(--orange)}.kpi-icon-purple{background:var(--purple-bg);color:var(--purple)}.kpi-value{font-size:28px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;line-height:1}.kpi-label{font-size:12px;color:var(--text-muted);font-weight:500;margin-top:5px}.readers-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.reader-status-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .15s ease;text-decoration:none}.reader-status-card:hover{border-color:var(--border-light);background:var(--bg-card);box-shadow:var(--shadow-card)}.reader-status-icon{width:38px;height:38px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.reader-name{font-size:13px;font-weight:600;color:var(--text-primary)}.reader-state{font-size:11px;font-weight:500;margin-top:2px}.toggle{position:relative;display:inline-flex;height:22px;width:40px;align-items:center;border-radius:100px;transition:background-color .15s ease;cursor:pointer;border:none;flex-shrink:0}.toggle[aria-checked=true]{background:var(--accent)}.toggle[aria-checked=false]{background:var(--border)}.toggle-thumb{display:inline-block;height:16px;width:16px;border-radius:50%;background:#fff;transition:transform .15s ease;box-shadow:0 1px 3px #0003}.toggle[aria-checked=true] .toggle-thumb{transform:translate(20px)}.toggle[aria-checked=false] .toggle-thumb{transform:translate(3px)}.status-dot-green{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--green)}.status-dot-red{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--red)}.status-dot-orange{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--orange)}.status-dot-gray{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--border-light)}.alert-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:500}.alert-banner-red{background:var(--red-bg);border:1px solid rgba(200,10,40,.2);color:var(--red)}.alert-banner-orange{background:var(--orange-bg);border:1px solid rgba(194,65,12,.2);color:var(--orange)}.alert-banner-green{background:var(--green-bg);border:1px solid rgba(0,125,30,.2);color:var(--green)}.filter-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.filter-bar input,.filter-bar select{height:38px;font-size:13px}.search-wrap{position:relative;flex:1;min-width:200px}.search-wrap svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;width:15px;height:15px}.search-wrap input{padding-left:36px}.drawer-overlay{position:fixed;inset:0;background:#1c2b334d;z-index:80}.drawer{position:fixed;top:0;right:0;height:100vh;width:380px;background:var(--bg-card);border-left:1px solid var(--border);box-shadow:var(--shadow-pop);z-index:90;display:flex;flex-direction:column;overflow:hidden}.drawer-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.drawer-body{flex:1;overflow-y:auto;padding:16px 24px}.tab-bar{display:flex;gap:2px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px}.tab-btn{flex:1;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .15s ease;border:none;background:transparent;font-family:Space Grotesk,sans-serif;white-space:nowrap}.tab-btn:hover{color:var(--text-primary);background:#fff9}.tab-btn.active{background:var(--bg-white);color:var(--accent);font-weight:600;box-shadow:0 1px 3px #00000014}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;color:var(--text-muted);text-align:center;gap:8px}.empty-state-title{font-size:15px;font-weight:600;color:var(--text-secondary)}.empty-state-sub{font-size:13px;color:var(--text-muted)}[data-theme=dark] .sidebar-logo,[data-theme=dark] .login-logo img{filter:brightness(0) invert(1)}[data-theme=dark] .btn-primary,[data-theme=dark] .btn-accent,[data-theme=dark] .login-btn{background:#f8fafc;color:#071233;box-shadow:0 8px 24px #f8fafc2e}[data-theme=dark] .btn-primary:hover,[data-theme=dark] .btn-accent:hover,[data-theme=dark] .login-btn:hover{background:#dbeafe;color:#071233;box-shadow:0 10px 28px #f8fafc3d}[data-theme=dark] .tab-btn:hover{background:#f8fafc14}@media(min-width:981px){.reader-fixed-page{display:flex;flex-direction:column}.reader-history-card{flex:0 0 auto}.reader-history-scroll{max-height:min(36vh,420px);min-height:0}}@media(max-width:980px){.app-shell{flex-direction:column}.app-sidebar{width:100%;height:auto;min-height:0;position:sticky;top:0;z-index:60;padding:14px 16px;overflow:visible}.app-main{flex:1;height:auto}.sidebar-brand{flex-direction:row;align-items:center;justify-content:space-between;margin-bottom:12px}.sidebar-logo{width:150px}.sidebar-links{flex-direction:row;gap:8px;overflow-x:auto;padding-bottom:2px}.nav-link{flex:0 0 auto}.sidebar-footer{flex-direction:row;align-items:center;border-top:none;padding-top:12px}.theme-toggle,.logout-btn,.user-pill{width:auto}.app-content{padding:22px 18px 40px}.conference-modal-split{flex-direction:column}.conference-modal-search,.conference-modal-base{width:100%;min-height:0}.conference-modal-search{border-right:none;border-bottom:1px solid var(--border)}}@media(max-width:720px){.login-shell{min-height:100vh;height:auto;flex-direction:column}.login-image-side{min-height:300px}.login-form-side{width:100%;min-width:0;padding:76px 28px 40px;border-left:none;border-top:1px solid var(--border)}.login-logo img{width:180px}.sidebar-footer{flex-wrap:wrap}.user-name,.theme-toggle span,.logout-btn{font-size:12px}.dash-hero,.page-header{flex-direction:column;gap:16px}.dashboard-chart-header{flex-direction:column}.dashboard-chart-link{width:100%;justify-content:center}.dashboard-chart-body{height:240px;min-height:240px}.kpi-row,.readers-grid{grid-template-columns:1fr}}.last\:border-0:last-child{border-width:0px}.hover\:border-\[var\(--accent\)\]:hover{border-color:var(--accent)}.hover\:bg-\[var\(--panel-2\)\]:hover{background-color:var(--panel-2)}.hover\:bg-\[var\(--panel-3\)\]:hover{background-color:var(--panel-3)}.hover\:bg-blue-500\/20:hover{background-color:#3b82f633}.hover\:bg-red-500\/20:hover{background-color:#ef444433}.hover\:bg-white\/20:hover{background-color:#fff3}.hover\:text-\[var\(--text\)\]:hover{color:var(--text)}.focus\:ring-\[var\(--accent\)\]:focus{--tw-ring-color: var(--accent)}.focus\:ring-red-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(239 68 68 / var(--tw-ring-opacity, 1))}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}@media(min-width:640px){.sm\:inline{display:inline}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:768px){.md\:col-span-2{grid-column:span 2 / span 2}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}
