@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";*,: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}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.flex-shrink{flex-shrink:1}.border-collapse{border-collapse:collapse}.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))}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.border{border-width:1px}.border-red-500{--tw-border-opacity: 1;border-color:rgb(239 68 68 / var(--tw-border-opacity, 1))}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.outline{outline-style:solid}.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-filter{-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}:root{font-family:Inter,SF Pro Display,Segoe UI,system-ui,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body,#root{margin:0;padding:0;width:100%;height:100%;overflow:hidden;font-family:Inter,SF Pro Display,Segoe UI,system-ui,sans-serif}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#0ea5e966;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#0ea5e9b8}a{font-weight:500;color:#0891b2;text-decoration:inherit}a:hover{color:#0c4a6e}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease}button:focus,button:focus-visible{outline:2px solid rgba(14,165,233,.5);outline-offset:2px}.landing-page{position:relative;width:100%;height:100%;min-height:100vh;min-height:100dvh;background:linear-gradient(145deg,#f5f7fb,#edf4f6 45%,#fdf4ea);color:#132333;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch}.landing-background-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(19,35,51,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(19,35,51,.06) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(circle at 50% 35%,rgba(0,0,0,.75),transparent 75%);mask-image:radial-gradient(circle at 50% 35%,rgba(0,0,0,.75),transparent 75%);pointer-events:none}.landing-background-glow{position:absolute;border-radius:999px;filter:blur(24px);opacity:.45;pointer-events:none;animation:floatGlow 12s ease-in-out infinite}.glow-one{width:340px;height:340px;top:-120px;left:-80px;background:#0ea5e9}.glow-two{width:300px;height:300px;bottom:-120px;right:-60px;background:#f59e0b;animation-delay:2s}.landing-shell{position:relative;z-index:2;width:min(1120px,calc(100% - 48px));margin:24px auto;border:1px solid rgba(19,35,51,.12);border-radius:24px;background:#ffffffc2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 20px 60px #1323331f;display:flex;flex-direction:column}.landing-topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:18px 24px;border-bottom:1px solid rgba(19,35,51,.1)}.landing-brand-mini{display:flex;align-items:center;gap:12px}.brand-cube{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#0891b2,#0ea5e9);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:800;letter-spacing:.5px}.brand-mini-title,.brand-mini-subtitle{margin:0}.brand-mini-title{font-size:14px;font-weight:700;color:#0f2235}.brand-mini-subtitle{font-size:11px;color:#5a6b7f;letter-spacing:.8px;text-transform:uppercase}.landing-topbar-actions{display:flex;align-items:center;gap:10px}.landing-menu-toggle{display:none;width:38px;height:38px;border:1px solid rgba(14,165,233,.24);border-radius:10px;background:#0ea5e91a;align-items:center;justify-content:center;flex-direction:column;gap:4px;cursor:pointer}.landing-menu-toggle span{width:16px;height:2px;border-radius:999px;background:#0c4a6e;transition:transform .2s ease,opacity .2s ease}.landing-menu-toggle.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}.landing-menu-toggle.open span:nth-child(2){opacity:0}.landing-menu-toggle.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.topbar-btn{border:none;border-radius:12px;height:38px;padding:0 16px;font-size:13px;font-weight:700;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.topbar-btn:hover{transform:translateY(-1px)}.topbar-btn.ghost{background:#0ea5e91a;color:#0c4a6e}.topbar-btn.ghost:hover{background:#0ea5e92e}.topbar-btn.solid{background:linear-gradient(135deg,#0891b2,#0ea5e9);color:#fff;box-shadow:0 10px 24px #0ea5e947}.landing-content{display:grid;grid-template-columns:1.1fr 1fr;gap:26px;padding:34px 24px 28px}.hero-block{animation:revealUp .6s ease forwards}.hero-chip{margin:0;display:inline-flex;align-items:center;height:30px;padding:0 12px;border-radius:999px;background:#0ea5e929;color:#0c4a6e;font-size:12px;font-weight:700;letter-spacing:.6px;text-transform:uppercase}.hero-title{margin:18px 0 14px;font-size:clamp(28px,4vw,44px);line-height:1.1;font-weight:800;color:#0f2235;max-width:18ch}.hero-description{margin:0;font-size:15px;line-height:1.65;color:#35506c;max-width:58ch}.hero-cta-row{margin-top:24px;display:flex;flex-wrap:wrap;align-items:center;gap:12px}.cta-primary,.cta-secondary{height:44px;border-radius:12px;padding:0 18px;font-size:14px;font-weight:700;cursor:pointer;border:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.cta-primary{color:#fff;background:linear-gradient(135deg,#0f766e,#0ea5e9);box-shadow:0 12px 26px #0f766e40}.cta-secondary{color:#fff;background:linear-gradient(135deg,#059669,#10b981);box-shadow:0 12px 26px #0596693d}.cta-secondary:before{content:"WA";width:22px;height:22px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;letter-spacing:.3px;color:#065f46;background:#ffffffe0}.cta-primary:hover,.cta-secondary:hover{transform:translateY(-2px)}.cta-secondary:hover{background:linear-gradient(135deg,#047857,#059669);box-shadow:0 14px 30px #0596694d}.hero-metrics{margin-top:28px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.metric-item{border:1px solid rgba(19,35,51,.14);border-radius:14px;padding:12px;background:#ffffffd1;display:flex;flex-direction:column;gap:5px;min-height:72px}.metric-value{font-size:15px;font-weight:800;color:#0f2235}.metric-label{font-size:11px;color:#5a6b7f;text-transform:uppercase;letter-spacing:.8px}.feature-grid{display:grid;gap:12px;align-content:start;animation:revealUp .7s ease forwards}.feature-card{border:1px solid rgba(19,35,51,.14);border-radius:16px;padding:16px;background:#ffffffe6;transition:transform .2s ease,box-shadow .2s ease}.feature-card:hover{transform:translateY(-2px);box-shadow:0 10px 24px #1323331f}.feature-icon{width:58px;height:28px;border-radius:999px;background:linear-gradient(135deg,#0ea5e9,#14b8a6);color:#fff;font-size:10px;font-weight:800;display:grid;place-items:center;letter-spacing:.7px}.feature-card h3{margin:12px 0 8px;font-size:18px;color:#0f2235}.feature-card p{margin:0;font-size:14px;line-height:1.6;color:#35506c}.landing-footer{padding:14px 24px 20px;border-top:1px solid rgba(19,35,51,.1);display:flex;align-items:center;justify-content:center;gap:10px;color:#5a6b7f;font-size:12px}.footer-dot{opacity:.6}@keyframes revealUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes floatGlow{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-16px) scale(1.04)}}@media(max-width:980px){.landing-shell{width:min(1120px,calc(100% - 24px))}.landing-content{grid-template-columns:1fr;gap:18px}}@media(max-width:768px){.landing-page{overflow-x:clip}.landing-shell{width:calc(100% - 16px);margin:8px auto;border-radius:16px}.landing-topbar{position:relative;flex-direction:row;align-items:center;justify-content:space-between;gap:12px;padding:14px}.landing-brand-mini{justify-content:flex-start}.landing-topbar-actions{position:absolute;left:14px;right:14px;top:calc(100% + 8px);z-index:20;display:none;flex-direction:column;gap:8px;padding:10px;border-radius:12px;border:1px solid rgba(19,35,51,.14);background:#fffffff5;box-shadow:0 12px 24px #13233324}.landing-topbar-actions.open{display:flex}.landing-menu-toggle{display:inline-flex}.topbar-btn{width:100%}.landing-content{padding:18px 14px;gap:14px}.hero-chip{font-size:11px}.hero-title{margin-top:14px;font-size:clamp(22px,7.8vw,32px);line-height:1.16;max-width:none}.hero-description{font-size:14px;line-height:1.58}.hero-cta-row{margin-top:18px}.cta-primary,.cta-secondary{width:100%}.hero-metrics{margin-top:18px;grid-template-columns:1fr;gap:8px}.feature-grid{gap:10px}.feature-card{padding:14px}.feature-card h3{font-size:16px}.feature-card p{font-size:13px}.glow-one{width:250px;height:250px;top:-90px;left:-90px}.glow-two{width:220px;height:220px;right:-90px;bottom:-90px}}@media(max-width:640px){.landing-shell{width:calc(100% - 12px)}.landing-content{padding:16px 12px}.hero-title{font-size:clamp(21px,8vw,30px)}.metric-item{min-height:66px;padding:10px}.metric-value{font-size:14px}.metric-label{font-size:10px}.landing-footer{flex-direction:column;gap:4px;padding:12px 14px 16px}.footer-dot{display:none}}@media(max-width:420px){.landing-shell{width:calc(100% - 10px);border-radius:14px}.landing-content{padding:14px 10px}.hero-chip{height:28px;padding:0 10px;letter-spacing:.4px}.hero-title{font-size:clamp(20px,9vw,28px)}.hero-description{font-size:13px}.topbar-btn,.cta-primary{height:42px;font-size:13px}.feature-icon{width:52px;height:26px;font-size:9px}.landing-footer{font-size:11px;text-align:center}}.login-container{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#f5f7fb,#edf4f6 45%,#fdf4ea);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;padding:20px;overflow:hidden;margin:0}.login-container:before{content:"";position:absolute;top:-120px;left:-120px;width:500px;height:500px;background:radial-gradient(circle,rgba(14,165,233,.2) 0%,transparent 70%);animation:floatOrb1 12s ease-in-out infinite;pointer-events:none}.login-container:after{content:"";position:absolute;bottom:-100px;right:-80px;width:420px;height:420px;background:radial-gradient(circle,rgba(245,158,11,.16) 0%,transparent 70%);animation:floatOrb2 15s ease-in-out infinite;pointer-events:none}@keyframes floatOrb1{0%,to{transform:translate(0) scale(1)}33%{transform:translate(40px,60px) scale(1.1)}66%{transform:translate(-30px,30px) scale(.95)}}@keyframes floatOrb2{0%,to{transform:translate(0) scale(1)}40%{transform:translate(-50px,-40px) scale(1.08)}70%{transform:translate(20px,-20px) scale(.95)}}.login-container.dark{background:linear-gradient(145deg,#08131d,#0c1a26 55%,#102432)}.login-container.dark:before{background:radial-gradient(circle,rgba(14,165,233,.24) 0%,transparent 70%)}.login-container.dark:after{background:radial-gradient(circle,rgba(245,158,11,.18) 0%,transparent 70%)}.theme-toggle{position:fixed;top:20px;right:20px;width:44px;height:44px;border:none;border-radius:12px;background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:18px;z-index:100;box-shadow:0 2px 12px #00000014}.login-container.dark .theme-toggle{background:#141428d9;color:#94a3b8;box-shadow:0 2px 12px #0006}.theme-toggle:hover{background:#fff;color:#0891b2;transform:scale(1.08) rotate(12deg);box-shadow:0 6px 20px #0ea5e940}.login-container.dark .theme-toggle:hover{background:#1e1e3f;color:#22d3ee;box-shadow:0 6px 20px #0ea5e94d}.login-card{background:#ffffffeb;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:24px;box-shadow:0 24px 48px #0ea5e91f,0 0 0 1px #fffc;padding:48px 44px;width:100%;max-width:420px;position:relative;z-index:10;transition:all .3s ease}.login-card:hover{box-shadow:0 32px 64px #0ea5e92e,0 0 0 1px #ffffffe6;transform:translateY(-2px)}.login-container.dark .login-card{background:#0e0e1ceb;box-shadow:0 24px 48px #00000080,0 0 0 1px #0ea5e926}.login-container.dark .login-card:hover{box-shadow:0 32px 64px #0009,0 0 0 1px #0ea5e940}.login-header{text-align:center;margin-bottom:36px}.login-header:before{content:"⚡";display:block;width:56px;height:56px;background:linear-gradient(135deg,#0891b2,#0ea5e9);border-radius:16px;font-size:26px;line-height:56px;margin:0 auto 16px;box-shadow:0 8px 24px #0ea5e973}.login-header h1{margin:0 0 6px;font-size:28px;font-weight:800;background:linear-gradient(135deg,#0f766e,#0891b2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.login-container.dark .login-header h1{background:linear-gradient(135deg,#22d3ee,#67e8f9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-form{display:flex;flex-direction:column;gap:16px}.form-group input{padding:13px 16px;border:1.5px solid rgba(148,163,184,.3);border-radius:12px;font-size:15px;transition:all .25s cubic-bezier(.4,0,.2,1);background:#ffffffb3;color:#0f172a;outline:none;font-weight:500;font-family:inherit}.form-group input::-moz-placeholder{color:#94a3b8;font-weight:400}.form-group input::placeholder{color:#94a3b8;font-weight:400}.login-container.dark .form-group input{background:#1e1e37b3;border-color:#0ea5e93d;color:#e2e8f0}.login-container.dark .form-group input::-moz-placeholder{color:#4b5563}.login-container.dark .form-group input::placeholder{color:#4b5563}.form-group input:focus{border-color:#0891b2;background:#fff;box-shadow:0 0 0 4px #0ea5e91a;transform:translateY(-1px)}.login-container.dark .form-group input:focus{border-color:#22d3ee;background:#1e1e37e6;box-shadow:0 0 0 4px #0ea5e926}.form-group input.error{border-color:#ef4444;background:#ef44440a}.form-group input.error:focus{border-color:#ef4444;box-shadow:0 0 0 4px #ef44441a}.form-group input:disabled{opacity:.5;cursor:not-allowed;transform:none}.error-message{color:#ef4444;font-size:12.5px;font-weight:500;margin-top:3px;margin-left:2px}.login-button{background:linear-gradient(135deg,#0f766e,#0ea5e9);color:#fff;border:none;padding:14px 28px;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);margin-top:8px;outline:none;box-shadow:0 6px 20px #0ea5e966;position:relative;overflow:hidden;font-family:inherit}.login-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.login-button:hover:before{left:100%}.login-button:hover:not(:disabled){background:linear-gradient(135deg,#0c4a6e,#0891b2);transform:translateY(-2px);box-shadow:0 10px 28px #0ea5e980}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.login-footer{text-align:center;margin-top:28px;padding-top:20px;border-top:1px solid rgba(148,163,184,.2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;font-size:13.5px;color:#64748b}.login-admin-note{font-size:12.5px;line-height:1.6;color:#64748b;max-width:34ch}.login-contact-admin{display:inline-flex;align-items:center;justify-content:flex-start;gap:10px;min-height:48px;padding:8px 12px;border-radius:12px;text-decoration:none;font-size:12px;font-weight:700;color:#065f46;background:linear-gradient(180deg,#10b9811f,#10b9812e);border:1px solid rgba(5,150,105,.34);box-shadow:0 8px 20px #10b98124;transition:all .24s ease;margin-top:2px}.login-contact-admin:hover{background:linear-gradient(180deg,#10b9812e,#10b9813d);border-color:#05966980;transform:translateY(-1px) scale(1.01);box-shadow:0 12px 24px #10b98133}.contact-wa-icon{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:10px;letter-spacing:.4px;font-weight:800;color:#fff;background:linear-gradient(135deg,#059669,#10b981);box-shadow:0 4px 12px #0596695c}.contact-wa-text{display:flex;flex-direction:column;line-height:1.15;align-items:flex-start}.contact-wa-text small{font-size:11px;font-weight:600;color:#0f766e;opacity:.9}.login-container.dark .login-footer{color:#64748b;border-top-color:#0ea5e91f}.login-container.dark .login-admin-note{color:#94a3b8}.login-container.dark .login-contact-admin{color:#a7f3d0;background:linear-gradient(180deg,#0596692e,#05966947);border-color:#10b9816b;box-shadow:0 10px 22px #05966938}.login-container.dark .login-contact-admin:hover{background:linear-gradient(180deg,#0596693d,#05966957)}.login-container.dark .contact-wa-text small{color:#6ee7b7}.link{color:#0891b2;text-decoration:none;font-weight:600;transition:all .2s ease;position:relative;padding:3px 0}.link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:1.5px;background:linear-gradient(90deg,#0891b2,#0ea5e9);transition:width .3s ease}.link:hover:after{width:100%}.login-container.dark .link{color:#22d3ee}.login-container.dark .link:after{background:linear-gradient(90deg,#22d3ee,#67e8f9)}.link:hover{color:#0c4a6e;transform:translateY(-1px)}.login-container.dark .link:hover{color:#67e8f9}.divider{color:#cbd5e1;font-weight:300;font-size:16px}.login-container.dark .divider{color:#64748b}@media(max-width:640px){.login-container{padding:12px}.login-card{padding:32px 24px;margin:0;border-radius:16px;max-width:100%;width:100%}.login-header{margin-bottom:24px}.login-header h1{font-size:26px}.login-form{gap:16px}.form-group input{padding:13px 16px;font-size:16px}.login-button{padding:13px 24px;font-size:16px;margin-top:8px}.login-footer{flex-direction:column;gap:12px;margin-top:24px;padding-top:20px}.login-contact-admin{width:100%;justify-content:center}.divider{display:none}.theme-toggle{top:16px;right:16px;width:44px;height:44px;font-size:18px}}@media(max-width:400px){.login-container{padding:8px}.login-card{padding:24px 16px;border-radius:12px}.login-header{margin-bottom:20px}.login-header h1{font-size:22px}.login-form{gap:14px}.form-group input{padding:11px 14px;font-size:16px}.login-button{padding:11px 20px;font-size:15px;margin-top:6px}.login-footer{margin-top:20px;padding-top:16px;gap:10px;font-size:13px}.theme-toggle{top:12px;right:12px;width:40px;height:40px;font-size:16px;border-radius:10px}}.confirm-backdrop{position:fixed;inset:0;background:#1323336b;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-dialog{background:#fffffff2;border:1px solid var(--border-color);border-radius:14px;box-shadow:0 16px 40px #1323333d;width:90%;max-width:480px;animation:slideUp .2s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.confirm-header{display:flex;align-items:center;gap:12px;padding:20px 24px;border-bottom:1px solid var(--border-color)}.confirm-icon{font-size:24px;line-height:1}.confirm-header h3{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.confirm-dialog.danger .confirm-header h3{color:#dc2626}.confirm-dialog.danger .confirm-header{border-bottom-color:#dc262633}.confirm-body{padding:24px}.confirm-body p{margin:0;font-size:15px;line-height:1.6;color:var(--text-secondary);white-space:pre-line}.confirm-actions{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border-color);background:#0ea5e90f}.confirm-actions .btn{min-width:100px;padding:8px 16px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.confirm-actions .btn:hover{background:#0ea5e91a;border-color:var(--accent-primary)}.confirm-actions .btn.primary{background:linear-gradient(135deg,#0891b2,#0ea5e9);color:#fff;border-color:transparent}.confirm-actions .btn.primary:hover{background:linear-gradient(135deg,#0c4a6e,#0891b2)}.confirm-actions .btn.danger{background:#dc2626;color:#fff;border-color:#dc2626;font-weight:600}.confirm-actions .btn.danger:hover{background:#b91c1c;border-color:#b91c1c;transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.confirm-actions .btn:disabled{opacity:.5;cursor:not-allowed}[data-theme=dark] .confirm-backdrop{background:#000000b3}[data-theme=dark] .confirm-dialog{box-shadow:0 8px 32px #00000080}html,body{margin:0;padding:0;width:100%;height:100%;overflow:hidden;font-family:SF Pro Display,Segoe UI,system-ui,sans-serif;transition:background-color .3s ease,color .3s ease}[data-theme=light]{--bg-primary: #f5f7fb;--bg-secondary: #edf4f6;--bg-card: rgba(255, 255, 255, .98);--bg-sidebar: rgba(255, 255, 255, .98);--text-primary: #132333;--text-secondary: #5a6b7f;--border-color: rgba(19, 35, 51, .16);--accent-primary: #0ea5e9;--accent-secondary: #0f766e;--accent-gradient: linear-gradient(135deg, #0891b2 0%, #0ea5e9 100%);--shadow-color: rgba(14, 165, 233, .14);--shadow-lg: 0 20px 40px rgba(0, 0, 0, .08);--glow: 0 0 20px rgba(14, 165, 233, .25)}[data-theme=dark]{--bg-primary: #08131d;--bg-secondary: #0c1a26;--bg-card: rgba(10, 21, 31, .95);--bg-sidebar: rgba(8, 18, 28, .98);--text-primary: #e6f6ff;--text-secondary: #95b4c8;--border-color: rgba(14, 165, 233, .2);--accent-primary: #22d3ee;--accent-secondary: #0ea5e9;--accent-gradient: linear-gradient(135deg, #0f766e 0%, #0ea5e9 100%);--shadow-color: rgba(14, 165, 233, .25);--shadow-lg: 0 20px 40px rgba(0, 0, 0, .4);--glow: 0 0 20px rgba(14, 165, 233, .3)}.main-layout{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;overflow:hidden;background:var(--bg-primary);transition:background-color .3s ease}.sidebar{position:fixed;top:0;left:0;width:260px;height:100dvh;max-height:100dvh;background:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:1000;overflow:hidden;box-shadow:4px 0 24px #0ea5e91a}.sidebar.open{transform:translate(0)}.sidebar-header{padding:20px 16px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;min-height:80px;position:relative}.sidebar-header-content{flex:1;display:flex;justify-content:center}.brand-text{text-align:center;display:flex;flex-direction:column;gap:4px}.brand-text h2{margin:0;font-size:15px;font-weight:800;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.5px;line-height:1.2}.brand-text span{font-size:10px;color:var(--text-secondary);font-weight:600;letter-spacing:1.5px;text-transform:uppercase}.brand-text-collapsed{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:var(--accent-gradient);color:#fff;border-radius:10px;font-size:18px;font-weight:800;box-shadow:0 4px 12px #0ea5e966}.sidebar-toggle-btn{width:30px;height:30px;background:#0ea5e914;border:1px solid rgba(14,165,233,.2);color:var(--text-secondary);border-radius:8px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-size:16px;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.sidebar-toggle-btn:hover{background:var(--accent-gradient);color:#fff;border-color:transparent;box-shadow:0 4px 12px #0ea5e966;transform:scale(1.05)}.sidebar-toggle-btn:active{transform:scale(.95)}.sidebar.collapsed{width:70px}.sidebar.collapsed .sidebar-header{justify-content:center;padding:20px 8px;flex-direction:column;gap:12px}.sidebar.collapsed .sidebar-header-content{width:100%}.sidebar.collapsed .brand-text{display:none}.sidebar.collapsed .sidebar-toggle-btn{width:100%;max-width:48px}.navigation{flex:1;padding:12px 0;overflow-y:auto;overflow-x:hidden;min-height:0}.nav-section{margin-bottom:20px}.nav-section:last-child{margin-bottom:0}.nav-section-title{padding:0 16px;margin-bottom:8px;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.nav-items{display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:transparent;border:none;color:var(--text-secondary);text-align:left;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-size:13.5px;font-weight:500;border-radius:10px;margin:0 8px;position:relative}.nav-item:hover{background:#0ea5e914;color:var(--text-primary);transform:translate(2px)}.nav-item.active{background:var(--accent-gradient);color:#fff;box-shadow:0 4px 15px #0ea5e959;font-weight:600}.nav-item.collapsed{justify-content:center;padding:10px}.nav-item.collapsed .nav-label{display:none}.nav-icon{font-size:18px;min-width:18px;display:flex;align-items:center;justify-content:center}.nav-label{flex:1;font-weight:500}.nav-category{display:flex;flex-direction:column;margin:0 8px}.nav-category-header{display:flex;align-items:center;gap:10px;padding:10px 14px;background:transparent;border:none;color:var(--text-secondary);text-align:left;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-size:13.5px;border-radius:10px;font-weight:500}.nav-category-header:hover,.nav-category-header.has-active-child{background:#0ea5e914;color:var(--text-primary)}.nav-category-header.collapsed{justify-content:center;padding:10px}.nav-category-header.collapsed .nav-label,.nav-category-header.collapsed .nav-expand-icon{display:none}.nav-expand-icon{margin-left:auto;font-size:10px;transition:transform .2s ease;color:var(--text-secondary);opacity:.6}.nav-expand-icon.expanded{transform:rotate(180deg)}.nav-submenu{margin-left:8px;margin-top:2px;margin-bottom:2px;display:flex;flex-direction:column;gap:2px;padding-left:28px}.nav-subitem{display:flex;align-items:center;gap:10px;padding:8px 12px;background:transparent;border:none;color:var(--text-secondary);text-align:left;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-size:13px;border-radius:8px;font-weight:500}.nav-subitem:hover{background:#0ea5e914;color:var(--text-primary);transform:translate(2px)}.nav-subitem.active{background:var(--accent-gradient);color:#fff;box-shadow:0 3px 10px #0ea5e94d}.nav-sub-icon{font-size:16px;min-width:16px;display:flex;align-items:center;justify-content:center}.nav-sub-label{flex:1;font-weight:400}.sidebar-footer{padding:12px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:8px;flex-shrink:0;margin-top:auto}.sidebar-theme-toggle{width:100%;height:36px;display:flex;align-items:center;gap:8px;padding:0 12px;background:#0ea5e90d;border:1px solid rgba(14,165,233,.15);border-radius:10px;color:var(--text-secondary);font-size:12.5px;font-weight:500;cursor:pointer;transition:all .2s ease}.sidebar-theme-toggle:hover{background:#0ea5e91f;color:var(--text-primary);border-color:#0ea5e94d}.theme-icon{font-size:16px}.theme-label{flex:1;text-align:left}.sidebar.collapsed .sidebar-theme-toggle{padding:0;justify-content:center}.sidebar-status{display:flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:11px;font-weight:500;padding:0 4px}.status-indicator{width:7px;height:7px;border-radius:50%;background:#10b981;flex-shrink:0;box-shadow:0 0 6px #10b981b3}.status-indicator.online{background:#10b981;animation:onlinePulse 2.5s ease-in-out infinite}@keyframes onlinePulse{0%,to{box-shadow:0 0 4px #10b98180}50%{box-shadow:0 0 10px #10b981e6}}.main-content{flex:1;display:flex;flex-direction:column;margin-left:0;transition:margin-left .3s ease}.main-content.sidebar-open{margin-left:260px}.app-header{height:62px;background:var(--bg-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);display:flex;align-items:center;padding:0 20px;position:sticky;top:0;z-index:100;gap:16px;box-shadow:0 1px 20px #0000000f}.header-left{display:flex;align-items:center;gap:12px}.header-center{flex:1;display:flex;justify-content:center;max-width:400px;margin:0 auto}.header-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.menu-toggle-btn{width:36px;height:36px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:transparent;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;padding:0;transition:all .2s ease}.menu-toggle-btn:hover{background:#0ea5e914;border-color:#0ea5e94d}.hamburger-line{width:16px;height:2px;background:var(--text-primary);border-radius:2px;transition:all .2s}.menu-toggle-btn.active .hamburger-line:nth-child(1){transform:rotate(45deg) translate(4px,4px)}.menu-toggle-btn.active .hamburger-line:nth-child(2){opacity:0}.menu-toggle-btn.active .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.page-title h1{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.header-search{position:relative;width:100%}.search-input{width:100%;height:36px;padding:0 36px 0 14px;background:transparent;border:1px solid var(--border-color);border-radius:18px;color:var(--text-primary);font-size:13px;outline:none}.search-input:focus{border-color:var(--text-secondary)}.search-input::-moz-placeholder{color:var(--text-secondary);opacity:.5}.search-input::placeholder{color:var(--text-secondary);opacity:.5}.search-btn{position:absolute;right:2px;top:50%;transform:translateY(-50%);width:30px;height:30px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-size:14px;border-radius:50%;display:flex;align-items:center;justify-content:center}.search-btn:hover{background:var(--bg-secondary)}.theme-toggle-wrapper,.notification-wrapper,.user-menu-wrapper{position:relative;display:flex;align-items:center;height:36px}.header-action-btn{width:36px;height:36px;padding:0;margin:0;background:transparent;border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.header-action-btn:hover{background:var(--bg-secondary);border-color:var(--border-color)}.notification-badge{position:absolute;top:-4px;right:-4px;width:16px;height:16px;background:#ef4444;color:#fff;font-size:10px;font-weight:600;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-card)}.user-menu-btn{height:36px;padding:0 8px;margin:0;display:flex;align-items:center;gap:6px;background:transparent;border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;flex-shrink:0}.user-menu-btn:hover{background:var(--bg-secondary);border-color:var(--border-color)}.user-avatar-small{width:26px;height:26px;background:var(--accent-gradient);color:#fff;font-size:11px;font-weight:700;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px #0ea5e959}.user-menu-arrow{font-size:10px;color:var(--text-secondary)}.notifications-dropdown,.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:280px;background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:14px;box-shadow:0 16px 40px #0003,0 0 0 1px #6366f114;z-index:1000;overflow:hidden}.dropdown-header{padding:16px 20px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.dropdown-header h3{margin:0;color:var(--text-primary);font-size:16px;font-weight:600}.unread-count{color:var(--text-secondary);font-size:12px;font-weight:500}.dropdown-content{max-height:300px;overflow-y:auto}.notification-item{padding:12px 20px;border-bottom:1px solid var(--border-color);display:flex;align-items:flex-start;gap:12px;cursor:pointer;transition:background .3s ease}.notification-item:hover{background:#ffffff08}.notification-item.unread{background:#ffffff05;border-left:3px solid rgba(148,163,184,.35)}.notification-icon{font-size:20px;margin-top:2px}.notification-content{flex:1}.notification-title{color:var(--text-primary);font-weight:600;font-size:14px;margin-bottom:4px}.notification-message{color:var(--text-secondary);font-size:13px;margin-bottom:4px;line-height:1.4}.notification-time{color:var(--text-secondary);font-size:11px;opacity:.8}.no-notifications{padding:40px 20px;text-align:center;color:#8892a0;font-style:italic}.dropdown-footer{padding:12px 20px;border-top:1px solid rgba(14,165,233,.1);text-align:center}.view-all-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-primary);border-radius:6px;padding:8px 16px;cursor:pointer;font-size:13px;transition:all .3s ease}.view-all-btn:hover{background:#ffffff0a}.user-info{padding:20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border-color)}.user-avatar-large{width:48px;height:48px;border-radius:14px;background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:20px;box-shadow:0 4px 14px #0ea5e966}.user-details{flex:1}.user-full-name{color:var(--text-primary);font-weight:600;font-size:16px;margin-bottom:2px}.user-email{color:var(--text-secondary);font-size:14px;margin-bottom:2px}.user-role{color:var(--text-secondary);font-size:12px;font-weight:500;text-transform:capitalize}.dropdown-menu{padding:8px 0}.dropdown-item{width:100%;padding:12px 20px;background:transparent;border:none;color:var(--text-primary);text-align:left;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:12px;font-size:14px}.dropdown-item:hover{background:#ffffff0a}.dropdown-item.logout:hover{background:#ff47571a;color:#ff4757}.item-icon{font-size:16px;min-width:16px}.dropdown-divider{height:1px;background:var(--border-color);margin:8px 0}.page-content{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--bg-primary);max-width:100%;box-sizing:border-box;padding-bottom:env(safe-area-inset-bottom,0px);scrollbar-width:thin;scrollbar-color:rgba(14,165,233,.4) transparent}.content-wrapper{width:100%;max-width:100%;margin:0 auto;padding:24px;min-height:calc(100vh - 70px);box-sizing:border-box;overflow-x:hidden;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}@media(max-width:1024px){.content-wrapper{padding:20px}}@media(max-width:768px){.content-wrapper{padding:16px}}.mobile-overlay,.sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);transition:opacity .3s ease,visibility .3s ease;opacity:0;visibility:hidden}.mobile-overlay.active,.sidebar-overlay.active{opacity:1;visibility:visible}@keyframes pulse{0%,to{transform:scale(1);opacity:.7}50%{transform:scale(1.1);opacity:1}}@media(min-width:768px){.sidebar{position:static;transform:translate(0);z-index:auto}.sidebar-overlay,.mobile-overlay,.menu-toggle-btn{display:none}}@media(max-width:767px){.sidebar{width:280px}.main-content.sidebar-open{margin-left:0}.app-header{padding:0 16px;gap:10px}.header-left{gap:12px}.header-center{display:none}.header-search{max-width:280px}.search-input{padding:10px 40px 10px 16px;font-size:13px}.search-btn{font-size:14px;padding:6px}.header-actions{gap:6px}.header-action-btn{width:36px;height:36px;font-size:14px}.user-menu-btn{padding:4px 8px}.user-avatar-small{width:24px;height:24px;font-size:11px}.page-title h1{font-size:18px}.menu-toggle-btn{width:36px;height:36px;padding:8px}.hamburger-line{width:16px}.theme-toggle-btn,.notification-btn{width:36px;height:36px;font-size:16px}.user-menu-btn{padding:6px 10px}.notifications-dropdown,.user-dropdown{position:fixed;top:70px;width:calc(100vw - 32px);right:16px;left:16px;min-width:auto;max-width:none}}@media(max-width:480px){.content-wrapper{padding:12px;padding-bottom:calc(120px + env(safe-area-inset-bottom,0px))}.page-content{padding-bottom:calc(100px + env(safe-area-inset-bottom,0px))}.sidebar-header,.sidebar-user{padding:16px}.navigation{padding:16px 0}.sidebar-footer{padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}.sidebar-theme-toggle{display:flex!important;visibility:visible!important;opacity:1!important}.brand-text h2{font-size:18px}.brand-text span{font-size:11px}}@media print{.sidebar,.app-header,.mobile-overlay,.sidebar-overlay{display:none!important}.main-content{margin-left:0!important}.content-wrapper{padding:0!important}}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px;margin-bottom:24px;max-width:100%;box-sizing:border-box;overflow-x:hidden}.project-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:18px;padding:22px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;gap:14px;box-sizing:border-box;max-width:100%;overflow:hidden;position:relative}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent-gradient);transform:scaleX(0);transform-origin:left;transition:transform .3s ease;border-radius:18px 18px 0 0}.project-card:hover{transform:translateY(-5px);border-color:#0ea5e952;box-shadow:0 16px 40px #0ea5e933}.project-card:hover:before{transform:scaleX(1)}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.project-card-header h3{margin:0;font-size:17px;font-weight:700;color:var(--text-primary);line-height:1.3;flex:1}.project-status{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;white-space:nowrap;padding:4px 10px;border-radius:999px;letter-spacing:.3px}.project-card-body{flex:1;display:flex;flex-direction:column;gap:14px}.project-description{margin:0;font-size:13px;color:var(--text-secondary);line-height:1.55;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:40px}.project-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:14px 16px;background:#0ea5e90f;border-radius:12px;border:1px solid rgba(14,165,233,.1)}.stat-item{display:flex;flex-direction:column;align-items:center;gap:4px}.stat-value{font-size:20px;font-weight:800;color:var(--text-primary);line-height:1}.stat-value.online{color:#10b981}.stat-value.offline{color:#ef4444}.stat-label{font-size:10px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.8px;font-weight:600}.health-bar-wrap{display:flex;align-items:center;gap:10px}.health-bar-track{flex:1;height:6px;background:#ef444433;border-radius:999px;overflow:hidden}.health-bar-fill{height:100%;background:linear-gradient(90deg,#10b981,#34d399);border-radius:999px;transition:width .6s cubic-bezier(.4,0,.2,1)}.health-bar-label{font-size:11px;font-weight:700;color:var(--text-secondary);white-space:nowrap;min-width:58px;text-align:right}.project-card-footer{padding-top:14px;border-top:1px solid var(--border-color)}.view-details{font-size:12.5px;font-weight:700;color:var(--accent-primary);display:flex;align-items:center;gap:4px;letter-spacing:.2px;transition:gap .2s ease}.project-card:hover .view-details{gap:8px}@media(max-width:768px){.projects-grid{grid-template-columns:1fr}}@media(max-width:480px){.project-card{padding:16px}.project-card-header h3{font-size:15px}.project-stats{padding:10px 12px;gap:6px}.stat-value{font-size:17px}}.dashboard-content{width:100%;max-width:100%;padding:28px;background:transparent;min-height:calc(100vh - 80px);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;box-sizing:border-box;overflow-x:hidden}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.dash-hero{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:28px 32px;background:var(--accent-gradient);border-radius:20px;margin-bottom:24px;box-sizing:border-box;max-width:100%;overflow-x:hidden;position:relative;overflow:hidden;box-shadow:0 8px 32px #0ea5e94d}.dash-hero:before{content:"";position:absolute;top:-60px;right:-60px;width:220px;height:220px;background:#ffffff12;border-radius:50%;pointer-events:none}.dash-hero:after{content:"";position:absolute;bottom:-80px;right:120px;width:160px;height:160px;background:#ffffff0d;border-radius:50%;pointer-events:none}.dash-hero-left h1{margin:0;font-size:24px;font-weight:800;color:#fff;letter-spacing:-.02em}.dash-hero-left .dash-subtitle{margin:6px 0 0;font-size:13px;color:#ffffffbf}.dash-hero-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.dash-time{text-align:right;color:#ffffffb3;font-size:12px}.dash-time strong{display:block;color:#fff;font-size:18px;font-weight:800;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;letter-spacing:.05em}.dash-status{display:inline-flex;align-items:center;gap:8px;padding:5px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.3);background:#ffffff1f;color:#fff;font-size:12px;font-weight:600;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.dash-status .dot{width:7px;height:7px;border-radius:999px;background:#4ade80;box-shadow:0 0 8px #4ade80e6;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.dash-section-title{font-size:11px;font-weight:700;color:var(--text-secondary);margin-bottom:14px;margin-top:30px;text-transform:uppercase;letter-spacing:1.2px;display:flex;align-items:center;gap:8px}.dash-section-title:before{content:"";display:inline-block;width:3px;height:14px;background:var(--accent-gradient);border-radius:2px}.dash-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin-bottom:28px;max-width:100%;box-sizing:border-box;overflow-x:hidden}.dash-action-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:20px 16px;border-radius:16px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);font-weight:600;font-size:13px;width:100%;min-height:80px;text-align:center;position:relative;overflow:hidden}.dash-action-btn:before{content:"";position:absolute;inset:0;background:var(--accent-gradient);opacity:0;transition:opacity .25s ease;border-radius:16px}.dash-action-btn:hover{transform:translateY(-3px);border-color:transparent;color:#fff;box-shadow:0 8px 24px #0ea5e959}.dash-action-btn:hover:before{opacity:1}.dash-action-btn span{position:relative;z-index:1}.dash-action-btn span[aria-hidden=true]{font-size:24px}.dash-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px;max-width:100%;box-sizing:border-box;overflow-x:hidden}.dash-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:18px;padding:22px;transition:all .25s cubic-bezier(.4,0,.2,1);box-sizing:border-box;max-width:100%;width:100%;overflow-x:hidden;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;overflow:hidden}.dash-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--accent-gradient);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.dash-card:hover{transform:translateY(-4px);border-color:#0ea5e947;box-shadow:0 12px 32px #0ea5e933}.dash-card:hover:after{transform:scaleX(1)}.dash-card-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:4px;box-shadow:0 4px 14px #0f233333}.dash-card .label{color:var(--text-secondary);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px}.dash-card .value{color:var(--text-primary);font-size:36px;font-weight:800;letter-spacing:-.03em;line-height:1}.dash-card .hint{color:var(--text-secondary);font-size:11.5px;opacity:.8}.dash-card-summary{cursor:default!important}.dash-card-summary:hover{transform:none;border-color:var(--border-color);box-shadow:none}.dash-card-summary:hover:after{transform:scaleX(0)}.dash-skeleton{height:10px;border-radius:999px;background:#ffffff14;overflow:hidden;position:relative}.dash-skeleton:after{content:"";position:absolute;inset:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);animation:shimmer 1.2s infinite}@keyframes shimmer{to{transform:translate(100%)}}@media(max-width:1024px){.dash-actions,.dash-kpis{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:768px){.dash-actions,.dash-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.dash-hero{flex-direction:column;align-items:flex-start;padding:22px 24px}.dash-hero-right{width:100%;flex-direction:row;justify-content:space-between;align-items:center}}@media(max-width:640px){.dashboard-content{padding:16px}}@media(max-width:420px){.dashboard-content{padding:12px}.dash-hero-left h1{font-size:20px}.dash-actions,.dash-kpis{grid-template-columns:1fr 1fr}}.users-page{width:100%;max-width:100%;padding:24px;background:transparent;min-height:calc(100vh - 80px);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;box-sizing:border-box;overflow-x:hidden}.users-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;max-width:100%;box-sizing:border-box;overflow-x:hidden;flex-wrap:wrap;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:0 8px 24px #13233314;transition:background-color .3s ease,border-color .3s ease}.users-header h2{margin:0;color:var(--text-primary);font-size:18px;font-weight:700}.users-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;max-width:100%;box-sizing:border-box}.users-search{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--border-color);border-radius:12px;background:#ffffffdb;box-sizing:border-box;max-width:100%}.users-search input{border:none;outline:none;background:transparent;color:var(--text-primary);min-width:220px}.users-table-container{width:100%;max-width:100%;overflow-x:auto;box-sizing:border-box;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:0 10px 28px #13233314;transition:background-color .3s ease,border-color .3s ease}.users-table{width:100%;max-width:100%;padding-top:12px;border-collapse:collapse;background:transparent;border:none;border-radius:0;overflow:hidden;table-layout:auto;box-sizing:border-box;box-shadow:none;transition:none}.users-table thead{background:var(--bg-secondary);transition:background-color .3s ease;position:sticky;top:0;z-index:10}.users-table th{color:var(--accent-primary);font-size:14px;font-weight:600;padding:14px 12px;text-align:left;border-bottom:2px solid var(--border-color);transition:color .3s ease,border-color .3s ease;white-space:nowrap}.users-table td{padding:14px 12px;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:14px;transition:color .3s ease,border-color .3s ease;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;box-sizing:border-box;text-align:left}.users-table tbody tr:hover{background:#0ea5e914;transition:background-color .3s ease}.users-table tbody tr:last-child td{border-bottom:none}.users-table tbody td .card-label{display:none}.users-table tbody td .card-value{text-align:left;word-break:break-word}@media(max-width:768px){.users-page{padding:16px}.users-header{flex-direction:column;align-items:flex-start;gap:16px}.users-controls{width:100%;flex-direction:column;align-items:stretch}.users-search{width:100%}.users-search input{min-width:0;width:100%}.users-table-container{overflow-x:hidden}.users-table{display:block;width:100%;max-width:100%}.users-table thead{display:none}.users-table tbody{display:block}.users-table tbody tr{display:block;margin-bottom:16px;background:var(--bg-card);border:2px solid var(--border-color);border-radius:14px;padding:20px;box-sizing:border-box;transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.users-table tbody tr:hover{border-color:var(--accent-primary);box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.users-table tbody td{display:block;padding:0;border:none;text-align:left!important;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;font-size:14px;line-height:1.5}.users-table tbody td.card-name-header{padding:0 0 12px;margin-bottom:12px;color:var(--text-primary);font-weight:700;font-size:17px;line-height:1.3;word-break:break-word}.users-table tbody td.card-email{padding:0 0 12px;margin-bottom:12px;color:var(--text-secondary);font-size:14px;font-weight:400;display:flex;justify-content:space-between;align-items:center;gap:12px}.users-table tbody td.card-status{padding:0 0 16px;margin-bottom:16px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;gap:12px}.users-table tbody td.card-created{padding:0 0 16px;margin-bottom:16px;color:var(--text-secondary);font-size:13px;font-weight:400;border-bottom:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;gap:12px}.users-table tbody td .card-label{display:inline-block;font-weight:600;color:var(--text-secondary);opacity:.8;flex-shrink:0}.users-table tbody td .card-value{text-align:right;word-break:break-word}.users-table tbody td.card-actions{padding:0}.users-table tbody td.card-actions .row-actions{display:flex;gap:10px;justify-content:stretch}.users-table tbody td.card-actions .btn{flex:1;display:flex;align-items:center;justify-content:center;padding:12px 20px;font-size:14px;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease}.users-table tbody td.card-actions .btn-edit{background:var(--accent-primary);color:#fff}.users-table tbody td.card-actions .btn-edit:hover{background:var(--accent-primary);opacity:.9;transform:translateY(-1px);box-shadow:0 2px 8px #0ea5e94d}.users-table tbody td.card-actions .btn-delete{background:#ef4444;color:#fff}.users-table tbody td.card-actions .btn-delete:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 2px 8px #ef44444d}.users-table tbody tr td[colspan]{display:table-cell!important;text-align:center;padding:60px 20px;border:none}.users-table tbody tr td[colspan]:before{display:none!important}.form-grid{grid-template-columns:1fr}.users-pagination{flex-direction:column;align-items:stretch}.pagination-info{text-align:center}.pagination-controls{justify-content:center;flex-wrap:wrap}.pagination-numbers{flex-wrap:wrap;justify-content:center}}.users-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:16px;border-top:1px solid var(--border-color);flex-wrap:wrap;gap:16px;transition:border-color .3s ease}.users-pagination .pagination-info{font-size:14px;color:var(--text-secondary);transition:color .3s ease}.users-pagination .pagination-controls{display:flex;align-items:center;gap:8px}.users-pagination .pagination-btn{padding:8px 16px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.users-pagination .pagination-btn:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--accent-primary);color:var(--accent-primary)}.users-pagination .pagination-btn:disabled{opacity:.5;cursor:not-allowed}.users-pagination .pagination-numbers{display:flex;align-items:center;gap:4px}.users-pagination .pagination-number{min-width:36px;height:36px;padding:0 8px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.users-pagination .pagination-number:hover{background:var(--bg-secondary);border-color:var(--accent-primary);color:var(--accent-primary)}.users-pagination .pagination-number.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;font-weight:600}.users-pagination .pagination-number.active:hover{background:var(--accent-primary);opacity:.9}.users-pagination .pagination-ellipsis{padding:0 4px;color:var(--text-secondary);font-size:14px;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:color .3s ease}@media(max-width:480px){.users-page{padding:12px}.users-table th,.users-table td{padding:8px 6px;font-size:11px}.users-table tbody tr{padding:16px;margin-bottom:12px}.users-table tbody td.card-name-header{font-size:16px}.users-table tbody td.card-email{font-size:13px}}.tenants-page{width:100%;max-width:100%;padding:24px;background:transparent;min-height:calc(100vh - 80px);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;box-sizing:border-box;overflow-x:hidden}.tenants-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;max-width:100%;box-sizing:border-box;overflow-x:hidden;flex-wrap:wrap;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:0 1px 3px var(--shadow-color);transition:background-color .3s ease,border-color .3s ease}.tenants-header h2{margin:0;color:var(--text-primary);font-size:18px;font-weight:700}.tenants-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;max-width:100%;box-sizing:border-box}.tenants-search{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--border-color);border-radius:12px;background:var(--bg-card);box-sizing:border-box;max-width:100%}.tenants-search input{border:none;outline:none;background:transparent;color:var(--text-primary);min-width:220px}.tenants-table-container{width:100%;max-width:100%;overflow-x:auto;box-sizing:border-box;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:0 1px 3px var(--shadow-color);transition:background-color .3s ease,border-color .3s ease}.tenants-table{width:100%;max-width:100%;padding-top:12px;border-collapse:collapse;background:transparent;border:none;border-radius:0;overflow:hidden;table-layout:auto;box-sizing:border-box;box-shadow:none;transition:none}.tenants-table thead{background:var(--bg-secondary);transition:background-color .3s ease;position:sticky;top:0;z-index:10}.tenants-table th{color:var(--accent-primary);font-size:14px;font-weight:600;padding:14px 12px;text-align:left;border-bottom:2px solid var(--border-color);transition:color .3s ease,border-color .3s ease;white-space:nowrap}.tenants-table td{padding:14px 12px;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:14px;transition:color .3s ease,border-color .3s ease;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;box-sizing:border-box;text-align:left}.tenants-table tbody tr:hover{background:var(--bg-secondary);transition:background-color .3s ease}.tenants-table tbody tr:last-child td{border-bottom:none}@media(max-width:768px){.tenants-page{padding:16px}.tenants-header{flex-direction:column;align-items:flex-start;gap:16px}.tenants-controls{width:100%;flex-direction:column;align-items:stretch}.tenants-search{width:100%}.tenants-search input{min-width:0;width:100%}.tenants-table-container{overflow-x:hidden}.tenants-table{display:block;width:100%;max-width:100%}.tenants-table thead{display:none}.tenants-table tbody{display:block}.tenants-table tbody tr{display:block;margin-bottom:16px;background:var(--bg-card);border:2px solid var(--border-color);border-radius:14px;padding:20px;box-sizing:border-box;transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.tenants-table tbody tr:hover{border-color:var(--accent-primary);box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.tenants-table tbody td{display:block;padding:0;border:none;text-align:left!important;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;font-size:14px;line-height:1.5}.tenants-table tbody td.card-name-header{padding:0 0 16px;margin-bottom:16px;border-bottom:1px solid rgba(255,255,255,.12);color:var(--text-primary);font-weight:700;font-size:17px;line-height:1.3;word-break:break-word}.tenants-table tbody td.card-description{padding:0 0 12px;margin-bottom:12px;color:var(--text-secondary);font-size:14px;font-weight:400;line-height:1.5}.tenants-table tbody td.card-created{padding:0 0 16px;margin-bottom:16px;color:var(--text-secondary);font-size:13px;font-weight:400;border-bottom:1px solid rgba(255,255,255,.08)}.tenants-table tbody td .card-label{font-weight:600;color:var(--text-secondary);opacity:.8;margin-right:8px}.tenants-table tbody td.card-actions{padding:0}.tenants-table tbody td.card-actions .row-actions{display:flex;gap:10px;justify-content:stretch}.tenants-table tbody td.card-actions .btn{flex:1;display:flex;align-items:center;justify-content:center;padding:12px 20px;font-size:14px;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease}.tenants-table tbody td.card-actions .btn-edit{background:var(--accent-primary);color:#fff}.tenants-table tbody td.card-actions .btn-edit:hover{background:var(--accent-primary);opacity:.9;transform:translateY(-1px);box-shadow:0 2px 8px #0ea5e94d}.tenants-table tbody td.card-actions .btn-delete{background:#ef4444;color:#fff}.tenants-table tbody td.card-actions .btn-delete:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 2px 8px #ef44444d}.tenants-table tbody tr td[colspan]{display:table-cell!important;text-align:center;padding:60px 20px;border:none}.tenants-table tbody tr td[colspan]:before{display:none!important}.form-grid{grid-template-columns:1fr}.tenants-pagination{flex-direction:column;align-items:stretch}.pagination-info{text-align:center}.pagination-controls{justify-content:center;flex-wrap:wrap}.pagination-numbers{flex-wrap:wrap;justify-content:center}}.tenants-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:16px;border-top:1px solid var(--border-color);flex-wrap:wrap;gap:16px;transition:border-color .3s ease}.tenants-pagination .pagination-info{font-size:14px;color:var(--text-secondary);transition:color .3s ease}.tenants-pagination .pagination-controls{display:flex;align-items:center;gap:8px}.tenants-pagination .pagination-btn{padding:8px 16px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.tenants-pagination .pagination-btn:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--accent-primary);color:var(--accent-primary)}.tenants-pagination .pagination-btn:disabled{opacity:.5;cursor:not-allowed}.tenants-pagination .pagination-numbers{display:flex;align-items:center;gap:4px}.tenants-pagination .pagination-number{min-width:36px;height:36px;padding:0 8px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.tenants-pagination .pagination-number:hover{background:var(--bg-secondary);border-color:var(--accent-primary);color:var(--accent-primary)}.tenants-pagination .pagination-number.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;font-weight:600}.tenants-pagination .pagination-number.active:hover{background:var(--accent-primary);opacity:.9}.tenants-pagination .pagination-ellipsis{padding:0 4px;color:var(--text-secondary);font-size:14px;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:color .3s ease}@media(max-width:480px){.tenants-page{padding:12px}.tenants-table th,.tenants-table td{padding:8px 6px;font-size:11px}.tenants-table tbody tr{padding:16px;margin-bottom:12px}.tenants-table tbody td.card-name-header{font-size:16px}.tenants-table tbody td.card-description{font-size:13px}}.projects-page{width:100%;max-width:100%;padding:24px;background:transparent;min-height:calc(100vh - 80px);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;box-sizing:border-box;overflow-x:hidden}.projects-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;max-width:100%;box-sizing:border-box;overflow-x:hidden;flex-wrap:wrap;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:0 8px 24px #13233314;transition:background-color .3s ease,border-color .3s ease}.projects-header h2{margin:0;color:var(--text-primary);font-size:18px;font-weight:700}.projects-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;max-width:100%;box-sizing:border-box}.projects-search{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--border-color);border-radius:12px;background:#ffffffdb;box-sizing:border-box;max-width:100%}.projects-search input{border:none;outline:none;background:transparent;color:var(--text-primary);min-width:220px}.projects-table-container{width:100%;max-width:100%;overflow-x:auto;box-sizing:border-box;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:0 10px 28px #13233314;transition:background-color .3s ease,border-color .3s ease}.projects-table{width:100%;max-width:100%;padding-top:12px;border-collapse:collapse;background:transparent;border:none;border-radius:0;overflow:hidden;table-layout:auto;box-sizing:border-box;box-shadow:none;transition:none}.projects-table thead{background:var(--bg-secondary);transition:background-color .3s ease;position:sticky;top:0;z-index:10}.projects-table th{color:var(--accent-primary);font-size:14px;font-weight:600;padding:14px 12px;text-align:left;border-bottom:2px solid var(--border-color);transition:color .3s ease,border-color .3s ease;white-space:nowrap}.projects-table td{padding:14px 12px;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:14px;transition:color .3s ease,border-color .3s ease;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;box-sizing:border-box;text-align:left}.projects-table tbody tr:hover{background:#0ea5e914;transition:background-color .3s ease}.projects-table tbody tr:last-child td{border-bottom:none}.badge.active{color:#0c4a6e;border-color:#0ea5e959;background:#0ea5e91f}.badge.inactive{color:#92400e;border-color:#f59e0b59;background:#f59e0b24}@media(max-width:768px){.projects-page{padding:16px}.projects-header{flex-direction:column;align-items:flex-start;gap:16px}.projects-controls{width:100%;flex-direction:column;align-items:stretch}.projects-search{width:100%}.projects-search input{min-width:0;width:100%}.projects-table-container{overflow-x:hidden}.projects-table{display:block;width:100%;max-width:100%}.projects-table thead{display:none}.projects-table tbody{display:block}.projects-table tbody tr{display:block;margin-bottom:16px;background:var(--bg-card);border:2px solid var(--border-color);border-radius:14px;padding:20px;box-sizing:border-box;transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.projects-table tbody tr:hover{border-color:var(--accent-primary);box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.projects-table tbody td{display:block;padding:0;border:none;text-align:left!important;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;font-size:14px;line-height:1.5}.projects-table tbody td.card-name-header{padding:0 0 16px;margin-bottom:16px;border-bottom:1px solid rgba(255,255,255,.12);color:var(--text-primary);font-weight:700;font-size:17px;line-height:1.3;word-break:break-word}.projects-table tbody td.card-tenant{padding:0 0 12px;margin-bottom:12px;color:var(--text-secondary);font-size:13px;font-weight:400}.projects-table tbody td.card-description{padding:0 0 12px;margin-bottom:12px;color:var(--text-secondary);font-size:14px;font-weight:400;line-height:1.5}.projects-table tbody td.card-created{padding:0 0 16px;margin-bottom:16px;color:var(--text-secondary);font-size:13px;font-weight:400;border-bottom:1px solid rgba(255,255,255,.08)}.projects-table tbody td .card-label{font-weight:600;color:var(--text-secondary);opacity:.8;margin-right:8px}.projects-table tbody td.card-actions{padding:0}.projects-table tbody td.card-actions .row-actions{display:flex;gap:10px;justify-content:stretch}.projects-table tbody td.card-actions .btn{flex:1;display:flex;align-items:center;justify-content:center;padding:12px 20px;font-size:14px;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease}.projects-table tbody td.card-actions .btn-edit{background:var(--accent-primary);color:#fff}.projects-table tbody td.card-actions .btn-edit:hover{background:var(--accent-primary);opacity:.9;transform:translateY(-1px);box-shadow:0 2px 8px #0ea5e94d}.projects-table tbody td.card-actions .btn-delete{background:#ef4444;color:#fff}.projects-table tbody td.card-actions .btn-delete:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 2px 8px #ef44444d}.projects-table tbody tr td[colspan]{display:table-cell!important;text-align:center;padding:60px 20px;border:none}.projects-table tbody tr td[colspan]:before{display:none!important}.form-grid{grid-template-columns:1fr}.projects-pagination{flex-direction:column;align-items:stretch}.pagination-info{text-align:center}.pagination-controls{justify-content:center;flex-wrap:wrap}.pagination-numbers{flex-wrap:wrap;justify-content:center}}.projects-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:16px;border-top:1px solid var(--border-color);flex-wrap:wrap;gap:16px;transition:border-color .3s ease}.projects-pagination .pagination-info{font-size:14px;color:var(--text-secondary);transition:color .3s ease}.projects-pagination .pagination-controls{display:flex;align-items:center;gap:8px}.projects-pagination .pagination-btn{padding:8px 16px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.projects-pagination .pagination-btn:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--accent-primary);color:var(--accent-primary)}.projects-pagination .pagination-btn:disabled{opacity:.5;cursor:not-allowed}.projects-pagination .pagination-numbers{display:flex;align-items:center;gap:4px}.projects-pagination .pagination-number{min-width:36px;height:36px;padding:0 8px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.projects-pagination .pagination-number:hover{background:var(--bg-secondary);border-color:var(--accent-primary);color:var(--accent-primary)}.projects-pagination .pagination-number.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;font-weight:600}.projects-pagination .pagination-number.active:hover{background:var(--accent-primary);opacity:.9}.projects-pagination .pagination-ellipsis{padding:0 4px;color:var(--text-secondary);font-size:14px;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:color .3s ease}@media(max-width:480px){.projects-page{padding:12px}.projects-table th,.projects-table td{padding:8px 6px;font-size:11px}.projects-table tbody tr{padding:16px;margin-bottom:12px}.projects-table tbody td.card-name-header{font-size:16px}.projects-table tbody td.card-description{font-size:13px}}.types-page{width:100%;max-width:100%;padding:24px;background:transparent;min-height:calc(100vh - 80px);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;box-sizing:border-box;overflow-x:hidden}.types-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;max-width:100%;box-sizing:border-box;overflow-x:hidden;flex-wrap:wrap;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:0 1px 3px var(--shadow-color);transition:background-color .3s ease,border-color .3s ease}.types-header h2{margin:0;color:var(--text-primary);font-size:18px;font-weight:700}.types-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;max-width:100%;box-sizing:border-box}.types-search{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--border-color);border-radius:12px;background:var(--bg-card);box-sizing:border-box;max-width:100%}.types-search input{border:none;outline:none;background:transparent;color:var(--text-primary);min-width:220px}.btn.primary{border-color:#0ea5e959}.btn:hover{transform:translateY(-1px);border-color:#0ea5e973}.types-table-container{width:100%;max-width:100%;overflow-x:auto;box-sizing:border-box;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:0 1px 3px var(--shadow-color);transition:background-color .3s ease,border-color .3s ease}.types-table{width:100%;max-width:100%;padding-top:12px;border-collapse:collapse;background:transparent;border:none;border-radius:0;overflow:hidden;table-layout:auto;box-sizing:border-box;box-shadow:none;transition:none}.types-table thead{background:var(--bg-secondary);transition:background-color .3s ease;position:sticky;top:0;z-index:10}.types-table th{color:var(--accent-primary);font-size:14px;font-weight:600;padding:14px 12px;text-align:left;border-bottom:2px solid var(--border-color);transition:color .3s ease,border-color .3s ease;white-space:nowrap}.types-table td{padding:14px 12px;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:14px;transition:color .3s ease,border-color .3s ease;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;box-sizing:border-box;text-align:left}.types-table tbody tr:hover{background:var(--bg-secondary);transition:background-color .3s ease}.types-table tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1px solid var(--border-color);font-size:12px;font-weight:700}.badge.active{color:var(--accent-primary)}.badge.inactive{color:#f59e0b}.modal{width:100%;max-width:520px;background:var(--bg-card);border:2px solid var(--border-color);border-radius:16px;padding:16px;box-sizing:border-box}.form-group input,.form-group select{padding:10px 12px;border:1px solid var(--border-color);border-radius:12px;background:#ffffff05;color:var(--text-primary);outline:none}.types-table tbody td .card-label{display:none}.types-table tbody td .card-value{text-align:left;word-break:break-word}@media(max-width:768px){.types-page{padding:16px}.types-table tbody td .card-label{display:inline-block;font-weight:600;color:var(--text-secondary);opacity:.8;flex-shrink:0}.types-table tbody td .card-value{text-align:right}.types-header{flex-direction:column;align-items:flex-start;gap:16px}.types-controls{width:100%;flex-direction:column;align-items:stretch}.types-search{width:100%}.types-search input{min-width:0;width:100%}.types-table-container{overflow-x:hidden}.types-table{display:block;width:100%;max-width:100%}.types-table thead{display:none}.types-table tbody{display:block}.types-table tbody tr{display:block;margin-bottom:16px;background:var(--bg-card);border:2px solid var(--border-color);border-radius:14px;padding:20px;box-sizing:border-box;transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.types-table tbody tr:hover{border-color:var(--accent-primary);box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.types-table tbody td{display:block;padding:0;border:none;text-align:left!important;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;font-size:14px;line-height:1.5}.types-table tbody td.card-name-header{padding:0 0 16px;margin-bottom:16px;border-bottom:1px solid rgba(255,255,255,.12);color:var(--text-primary);font-weight:700;font-size:17px;line-height:1.3;word-break:break-word}.types-table tbody td.card-description{padding:0 0 12px;margin-bottom:12px;color:var(--text-secondary);font-size:14px;font-weight:400;line-height:1.5;display:flex;justify-content:space-between;align-items:center;gap:12px}.types-table tbody td.card-groups{padding:0 0 12px;margin-bottom:12px;color:var(--text-secondary);font-size:13px;font-weight:400;display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.types-table tbody td.card-created{padding:0 0 16px;margin-bottom:16px;color:var(--text-secondary);font-size:13px;font-weight:400;border-bottom:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;gap:12px}.types-table tbody td.card-actions{padding:0}.types-table tbody td.card-actions .row-actions{display:flex;gap:10px;justify-content:stretch}.types-table tbody td.card-actions .btn{flex:1;display:flex;align-items:center;justify-content:center;padding:12px 20px;font-size:14px;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease}.types-table tbody td.card-actions .btn-edit{background:var(--accent-primary);color:#fff}.types-table tbody td.card-actions .btn-edit:hover{background:var(--accent-primary);opacity:.9;transform:translateY(-1px);box-shadow:0 2px 8px #0ea5e94d}.types-table tbody td.card-actions .btn-delete{background:#ef4444;color:#fff}.types-table tbody td.card-actions .btn-delete:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 2px 8px #ef44444d}.types-table tbody tr td[colspan]{display:table-cell!important;text-align:center;padding:60px 20px;border:none}.types-table tbody tr td[colspan]:before{display:none!important}.form-grid{grid-template-columns:1fr}.types-pagination{flex-direction:column;align-items:stretch}.pagination-info{text-align:center}.pagination-controls{justify-content:center;flex-wrap:wrap}.pagination-numbers{flex-wrap:wrap;justify-content:center}}.types-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:16px;border-top:1px solid var(--border-color);flex-wrap:wrap;gap:16px;transition:border-color .3s ease}.types-pagination .pagination-info{font-size:14px;color:var(--text-secondary);transition:color .3s ease}.types-pagination .pagination-controls{display:flex;align-items:center;gap:8px}.types-pagination .pagination-btn{padding:8px 16px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.types-pagination .pagination-btn:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--accent-primary);color:var(--accent-primary)}.types-pagination .pagination-btn:disabled{opacity:.5;cursor:not-allowed}.types-pagination .pagination-numbers{display:flex;align-items:center;gap:4px}.types-pagination .pagination-number{min-width:36px;height:36px;padding:0 8px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.types-pagination .pagination-number:hover{background:var(--bg-secondary);border-color:var(--accent-primary);color:var(--accent-primary)}.types-pagination .pagination-number.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;font-weight:600}.types-pagination .pagination-number.active:hover{background:var(--accent-primary);opacity:.9}.types-pagination .pagination-ellipsis{padding:0 4px;color:var(--text-secondary);font-size:14px;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:color .3s ease}@media(max-width:480px){.types-page{padding:12px}.types-table th,.types-table td{padding:8px 6px;font-size:11px}.types-table tbody tr{padding:16px;margin-bottom:12px}.types-table tbody td.card-name-header{font-size:16px}.types-table tbody td.card-description{font-size:13px}.types-table tbody td .card-label{display:inline-block;font-weight:600;color:var(--text-secondary);opacity:.8;flex-shrink:0}.types-table tbody td .card-value{text-align:right}}.devices-page{width:100%;max-width:100%;padding:24px;background:transparent;min-height:calc(100vh - 80px);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;box-sizing:border-box;overflow-x:hidden}.devices-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;max-width:100%;box-sizing:border-box;overflow-x:hidden;flex-wrap:wrap;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:0 8px 24px #13233314;transition:background-color .3s ease,border-color .3s ease}.devices-header h2{margin:0;color:var(--text-primary);font-size:18px;font-weight:700}.devices-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;max-width:100%;box-sizing:border-box}.devices-search{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--border-color);border-radius:12px;background:#ffffffdb;box-sizing:border-box;max-width:100%}.devices-search input{border:none;outline:none;background:transparent;color:var(--text-primary);min-width:220px}.devices-table-container{width:100%;max-width:100%;overflow-x:auto;box-sizing:border-box;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:0 10px 28px #13233314;transition:background-color .3s ease,border-color .3s ease}.devices-table{width:100%;max-width:100%;padding-top:12px;border-collapse:collapse;background:transparent;border:none;border-radius:0;overflow:hidden;table-layout:auto;box-sizing:border-box;box-shadow:none;transition:none}.devices-table thead{background:var(--bg-secondary);transition:background-color .3s ease;position:sticky;top:0;z-index:10}.devices-table th{color:var(--accent-primary);font-size:14px;font-weight:600;padding:14px 12px;text-align:left;border-bottom:2px solid var(--border-color);transition:color .3s ease,border-color .3s ease;white-space:nowrap}.devices-table td{padding:14px 12px;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:14px;transition:color .3s ease,border-color .3s ease;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;box-sizing:border-box;vertical-align:top;text-align:left}.devices-table tbody tr:hover{background:#0ea5e914;transition:background-color .3s ease}.devices-table tbody tr:last-child td{border-bottom:none}.row-actions{display:flex;gap:8px;justify-content:flex-end;align-items:center}.row-actions .btn{display:flex;align-items:center;justify-content:center;min-width:36px;padding:8px}.row-actions .btn-edit{color:var(--accent-primary)}.row-actions .btn-edit:hover{background:var(--bg-secondary);border-color:var(--accent-primary);color:var(--accent-primary)}.row-actions .btn-delete{color:#ef4444;border-color:#ef4444}.row-actions .btn-delete:hover{background:#ef4444;border-color:#ef4444;color:#fff}.tb-toggle-wrap{display:flex;align-items:center;gap:8px}.tb-config-btn{padding:6px 10px;font-size:12px}.tb-switch{position:relative;width:44px;height:24px;display:inline-flex}.tb-switch input{opacity:0;width:0;height:0}.tb-slider{position:absolute;inset:0;background:#9ca3af;border-radius:999px;cursor:pointer;transition:background-color .2s ease}.tb-slider:before{content:"";position:absolute;left:3px;top:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .2s ease}.tb-switch input:checked+.tb-slider{background:#0891b2}.tb-switch input:checked+.tb-slider:before{transform:translate(20px)}.tb-modal-subtitle{margin-top:-6px;margin-bottom:12px;color:var(--text-secondary);font-size:13px}.tb-active-label{display:inline-flex;align-items:center;gap:8px;color:var(--text-secondary)}.tb-message{margin-top:10px;color:#0c4a6e;font-size:13px;font-weight:600}.modal-backdrop{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;padding:16px;z-index:999}.modal{width:100%;max-width:520px;background:#fffffff2;border:2px solid var(--border-color);border-radius:16px;padding:16px;box-sizing:border-box;box-shadow:0 18px 40px #13233333}.modal h3{margin:0 0 12px;color:var(--text-primary);font-size:16px;font-weight:700}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{color:var(--text-secondary);font-size:12px;font-weight:700}.form-group input,.form-group select{padding:10px 12px;border:1px solid var(--border-color);border-radius:12px;background:#ffffffc7;color:var(--text-primary);outline:none}.form-group textarea{padding:10px 12px;border:1px solid var(--border-color);border-radius:12px;background:#ffffffc7;color:var(--text-primary);outline:none;font-family:inherit;resize:vertical}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:14px}.error{margin:10px 0 0;color:#ef4444;font-size:13px;font-weight:600}.devices-table tbody td .card-label{display:none}.devices-table tbody td .card-value{text-align:left;word-break:break-word}@media(max-width:768px){.devices-page{padding:16px}.devices-header{flex-direction:column;align-items:flex-start;gap:16px}.devices-controls{width:100%;flex-direction:column;align-items:stretch}.devices-search{width:100%}.devices-search input{min-width:0;width:100%}.devices-table-container{overflow-x:hidden}.devices-table{display:block;width:100%;max-width:100%}.devices-table thead{display:none}.devices-table tbody{display:block}.devices-table tbody tr{display:block;margin-bottom:16px;background:var(--bg-card);border:2px solid var(--border-color);border-radius:14px;padding:20px;box-sizing:border-box;transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.devices-table tbody tr:hover{border-color:var(--accent-primary);box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.devices-table tbody td{display:block;padding:0;border:none;text-align:left!important;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;font-size:14px;line-height:1.5}.devices-table tbody td.card-serial-header{padding:0 0 12px;margin-bottom:12px;border-bottom:1px solid rgba(255,255,255,.12)}.devices-table tbody td.card-serial-header span{color:var(--text-primary);font-weight:700;font-size:16px;line-height:1.3;word-break:break-word;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.devices-table tbody td.card-alias{padding:0 0 16px;margin-bottom:16px;color:var(--text-primary);font-weight:600;font-size:15px;line-height:1.3;border-bottom:1px solid rgba(255,255,255,.08)}.devices-table tbody td.card-tenant,.devices-table tbody td.card-project,.devices-table tbody td.card-type{padding:0 0 12px;margin-bottom:12px;color:var(--text-secondary);font-size:13px;font-weight:400;display:flex;justify-content:space-between;align-items:center;gap:12px}.devices-table tbody td.card-notes{padding:0 0 16px;margin-bottom:16px;color:var(--text-secondary);font-size:13px;font-weight:400;border-bottom:1px solid rgba(255,255,255,.08);line-height:1.6;display:flex;justify-content:space-between;align-items:center;gap:12px}.devices-table tbody td .card-label{display:inline-block;font-weight:600;color:var(--text-secondary);opacity:.8;flex-shrink:0}.devices-table tbody td .card-value{text-align:right;word-break:break-word}.devices-table tbody td.card-actions{padding:0}.devices-table tbody td.card-actions .row-actions{display:flex;gap:10px;justify-content:stretch}.devices-table tbody td.card-actions .btn{flex:1;display:flex;align-items:center;justify-content:center;padding:12px 20px;font-size:14px;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease}.devices-table tbody td.card-actions .btn-edit{background:var(--accent-primary);color:#fff}.devices-table tbody td.card-actions .btn-edit:hover{background:var(--accent-primary);opacity:.9;transform:translateY(-1px);box-shadow:0 2px 8px #0ea5e94d}.devices-table tbody td.card-actions .btn-delete{background:#ef4444;color:#fff}.devices-table tbody td.card-actions .btn-delete:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 2px 8px #ef44444d}.devices-table tbody tr td[colspan]{display:table-cell!important;text-align:center;padding:60px 20px;border:none}.devices-table tbody tr td[colspan]:before{display:none!important}.form-grid{grid-template-columns:1fr}.devices-pagination{flex-direction:column;align-items:stretch}.pagination-info{text-align:center}.pagination-controls{justify-content:center;flex-wrap:wrap}.pagination-numbers{flex-wrap:wrap;justify-content:center}}.devices-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:16px;border-top:1px solid var(--border-color);flex-wrap:wrap;gap:16px;transition:border-color .3s ease}.devices-pagination .pagination-info{font-size:14px;color:var(--text-secondary);transition:color .3s ease}.devices-pagination .pagination-controls{display:flex;align-items:center;gap:8px}.devices-pagination .pagination-btn{padding:8px 16px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.devices-pagination .pagination-btn:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--accent-primary);color:var(--accent-primary)}.devices-pagination .pagination-btn:disabled{opacity:.5;cursor:not-allowed}.devices-pagination .pagination-numbers{display:flex;align-items:center;gap:4px}.devices-pagination .pagination-number{min-width:36px;height:36px;padding:0 8px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.devices-pagination .pagination-number:hover{background:var(--bg-secondary);border-color:var(--accent-primary);color:var(--accent-primary)}.devices-pagination .pagination-number.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;font-weight:600}.devices-pagination .pagination-number.active:hover{background:var(--accent-primary);opacity:.9}.devices-pagination .pagination-ellipsis{padding:0 4px;color:var(--text-secondary);font-size:14px;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:color .3s ease}@media(max-width:480px){.devices-page{padding:12px}.devices-table th,.devices-table td{padding:8px 6px;font-size:11px}.devices-table tbody tr{padding:16px;margin-bottom:12px}.devices-table tbody td.card-serial-header span{font-size:15px}.devices-table tbody td.card-alias{font-size:14px}}.device-detail-page{width:100%;max-width:100%;padding:24px;background:transparent;min-height:calc(100vh - 80px);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;box-sizing:border-box;overflow-x:hidden}.device-header-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 1px 3px var(--shadow-color);transition:background-color .3s ease,border-color .3s ease;box-sizing:border-box;max-width:100%;overflow-x:hidden}.device-header-content{display:flex;gap:24px;align-items:center;max-width:100%;box-sizing:border-box;flex-wrap:wrap}.device-identification{display:flex;gap:16px;align-items:flex-start}.device-image-placeholder{width:80px;height:80px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0;transition:background-color .3s ease,border-color .3s ease,color .3s ease}.device-info{display:flex;flex-direction:column;gap:8px}.device-name-row{display:flex;align-items:center;gap:8px}.device-status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;transition:background-color .3s}.device-status-dot.online{background:#16a34a}.device-status-dot.offline{background:#ef4444}.device-name{font-size:18px;font-weight:600;color:var(--text-primary);transition:color .3s ease}.device-mqtt-topic{display:flex;align-items:center;gap:8px;margin-top:4px;flex-wrap:wrap}.mqtt-label{font-size:12px;color:var(--text-secondary);font-weight:500;transition:color .3s ease}.mqtt-topic-text{font-size:13px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;background:var(--bg-secondary);border:1px solid var(--border-color);padding:4px 10px;border-radius:6px;color:var(--accent-primary);transition:background-color .3s ease,border-color .3s ease,color .3s ease;word-break:break-all}.device-id{font-size:14px;color:var(--text-secondary);font-family:monospace;transition:color .3s ease}.device-type{font-size:14px;color:var(--text-secondary);transition:color .3s ease}.version-info{display:grid;grid-template-columns:1fr 1fr;gap:16px;flex:1}.version-item{display:flex;flex-direction:column;gap:4px}.version-label{font-size:12px;color:#6b7280;font-weight:500}.version-value{font-size:14px;color:#111827;font-weight:600}.version-value-with-icon{display:flex;align-items:center;gap:6px;font-size:14px;color:#111827;font-weight:600}.info-icon{font-size:16px;color:#6b7280;cursor:help}.device-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:2px solid var(--border-color);transition:border-color .3s ease}.device-tab{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;margin-bottom:-2px}.stream-notice{margin:-8px 0 16px;padding:10px 12px;border-radius:10px;border:1px solid rgba(245,158,11,.35);background:#f59e0b1f;color:#92400e;font-size:13px;font-weight:600}.device-tab:hover{color:var(--accent-primary);background:var(--bg-secondary)}.device-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary);font-weight:600}.btn-back{padding:8px 16px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-card);color:var(--text-primary);font-size:14px;cursor:pointer;transition:all .2s}.btn-back:hover{background:var(--bg-secondary);border-color:var(--accent-primary);color:var(--accent-primary)}.device-detail-content{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px;max-width:100%;box-sizing:border-box;overflow-x:hidden}.status-column{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:0 1px 3px var(--shadow-color);transition:background-color .3s ease,border-color .3s ease;box-sizing:border-box;max-width:100%;overflow-x:hidden;min-width:0}.section-title{color:var(--accent-primary);font-size:18px;font-weight:600;margin:0 0 24px;padding-bottom:12px;border-bottom:2px solid var(--border-color);transition:color .3s ease,border-color .3s ease;display:flex;flex-direction:column;gap:6px}.section-subtitle{font-size:12px;font-weight:400;color:var(--text-secondary);opacity:.8;margin-top:4px}.status-item{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border-color);transition:border-color .3s ease}.status-item:last-child{border-bottom:none}.status-label{display:flex;align-items:center;gap:10px;color:var(--text-secondary);font-size:14px;font-weight:500;transition:color .3s ease}.status-icon{font-size:20px;color:var(--accent-primary);flex-shrink:0;transition:color .3s ease}.status-value{color:var(--text-primary);font-size:14px;font-weight:600;text-align:right;transition:color .3s ease}.data-logs-column{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:0 1px 3px var(--shadow-color);transition:background-color .3s ease,border-color .3s ease;box-sizing:border-box;max-width:100%;overflow-x:hidden;min-width:0}.data-logs-table-container{width:100%;max-width:100%;overflow-x:hidden;box-sizing:border-box}.data-logs-table{width:100%;max-width:100%;margin-top:12px;border-collapse:collapse;table-layout:fixed;box-sizing:border-box}.data-logs-table thead{background:var(--bg-secondary);transition:background-color .3s ease}.data-logs-table th{color:var(--accent-primary);font-size:14px;font-weight:600;padding:14px 12px;text-align:left;border-bottom:2px solid var(--border-color);position:relative;transition:color .3s ease,border-color .3s ease;vertical-align:top}.data-logs-table th:first-child{width:35%;min-width:0}.data-logs-table th:nth-child(2){width:30%;min-width:0}.data-logs-table th:nth-child(3){width:35%;min-width:0}.sort-indicator{margin-left:4px;font-size:10px;opacity:.7}.data-logs-table td{padding:14px 12px;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:14px;transition:color .3s ease,border-color .3s ease;vertical-align:top;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;max-width:0;overflow:hidden;text-overflow:ellipsis;box-sizing:border-box}.data-logs-table tbody tr:hover{background:var(--bg-secondary);transition:background-color .3s ease}.data-logs-table tbody tr:last-child td{border-bottom:none}.no-data{padding:80px 20px;text-align:center;color:var(--text-secondary);transition:color .3s ease}.no-data p{margin:0;font-size:15px;font-weight:500}.historical-data-section{display:flex;align-items:center;justify-content:space-between;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:0 1px 3px var(--shadow-color);transition:background-color .3s ease,border-color .3s ease;box-sizing:border-box;max-width:100%;overflow-x:hidden;flex-wrap:wrap;gap:16px}.historical-data-section .section-title{margin:0;border-bottom:none;padding-bottom:0}.export-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--accent-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.export-btn:hover{background:var(--bg-primary);border-color:var(--accent-primary);color:var(--accent-primary)}.export-icon{font-size:18px}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite;transition:border-color .3s ease}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.error-message{color:#ef4444;font-size:16px;margin-bottom:16px}@media(max-width:1024px){.device-detail-content{grid-template-columns:1fr}.device-header-content{flex-direction:column;gap:24px}.version-info{grid-template-columns:1fr}.device-detail-page{padding:20px}}@media(max-width:768px){.device-identification{flex-direction:column;align-items:center;text-align:center}.device-header-content{align-items:center}.device-detail-page,.device-header-section,.status-column,.data-logs-column,.historical-data-section{padding:16px}.data-logs-table th,.data-logs-table td{padding:10px 8px;font-size:12px}.data-logs-table{display:block;width:100%;max-width:100%}.data-logs-table thead{display:none}.data-logs-table tbody{display:block}.data-logs-table tbody tr{display:block;margin-bottom:12px;background:var(--bg-card);border:2px solid var(--border-color);border-radius:14px;padding:16px;box-sizing:border-box;transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.data-logs-table tbody tr:hover{border-color:var(--accent-primary);box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.data-logs-table tbody td{display:block;padding:0;border:none;text-align:left!important;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;font-size:14px;line-height:1.5;max-width:100%;overflow:visible;text-overflow:clip}.data-logs-table tbody td.card-hidden{display:none}.data-logs-table tbody tr{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.data-logs-table tbody td.card-tag{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0;color:var(--text-primary);font-size:14px;font-weight:500;line-height:1.4}.data-logs-table tbody td.card-tag:before{content:"Tag :";font-weight:600;font-size:11px;color:var(--text-secondary);opacity:.8;text-transform:uppercase;letter-spacing:.5px}.data-logs-table tbody td.card-value{flex:1;display:flex;flex-direction:column;gap:6px;align-items:flex-end;text-align:right;min-width:0;color:var(--text-primary);font-size:14px;font-weight:500;line-height:1.4}.data-logs-table tbody td.card-value:before{content:"Value :";font-weight:600;font-size:11px;color:var(--text-secondary);opacity:.8;text-transform:uppercase;letter-spacing:.5px}.data-logs-table tbody tr td[colspan]{display:table-cell!important;text-align:center;padding:60px 20px;border:none}.historical-data-section{flex-direction:column;align-items:flex-start}}.analytics-filter-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;margin-bottom:24px;margin-top:24px;box-shadow:0 1px 3px var(--shadow-color);transition:background-color .3s ease,border-color .3s ease}.filter-header{display:flex;align-items:center;gap:8px;margin-bottom:16px;color:var(--accent-primary);font-size:16px;font-weight:600}.filter-icon{font-size:20px}.filter-title{color:var(--text-primary);transition:color .3s ease}.filter-controls{display:flex;gap:16px;align-items:flex-end;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:8px;flex:1;min-width:180px}.filter-group label{font-size:14px;font-weight:500;color:var(--text-secondary);transition:color .3s ease}.date-input{padding:10px 12px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;transition:all .2s;font-family:inherit}.date-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px rgba(var(--accent-primary-rgb, 59, 130, 246),.1)}.filter-actions{display:flex;gap:8px;align-items:flex-end}.btn-filter{padding:10px 20px;border:1px solid var(--border-color);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-apply{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.btn-apply:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 2px 4px var(--shadow-color)}.btn-reset{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-color);transition:background-color .3s ease,color .3s ease,border-color .3s ease}.btn-reset:hover{background:var(--bg-primary);border-color:var(--accent-primary);color:var(--accent-primary)}.analytics-table-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:0 1px 3px var(--shadow-color);transition:background-color .3s ease,border-color .3s ease}.analytics-table-section .section-title{margin:0 0 24px;padding-bottom:12px;border-bottom:2px solid var(--border-color)}.analytics-loading,.analytics-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px}.analytics-loading p,.analytics-error p{color:var(--text-secondary);font-size:14px;margin:0;transition:color .3s ease}.analytics-table-container{width:100%;max-width:100%;overflow-x:auto;box-sizing:border-box}.analytics-table{width:100%;margin-top:12px;border-collapse:collapse;table-layout:auto;box-sizing:border-box}.analytics-table thead{background:var(--bg-secondary);transition:background-color .3s ease;position:sticky;top:0;z-index:10}.analytics-table th{color:var(--accent-primary);font-size:14px;font-weight:600;padding:14px 12px;text-align:left;border-bottom:2px solid var(--border-color);transition:color .3s ease,border-color .3s ease;white-space:nowrap}.analytics-table th:first-child{min-width:200px;position:sticky;left:0;background:var(--bg-secondary);z-index:5;text-align:center}.analytics-table td:first-child{position:sticky;left:0;background:var(--bg-card);z-index:4;text-align:center}.analytics-table tbody tr:hover td:first-child{background:var(--bg-secondary)}.analytics-table th:not(:first-child){min-width:120px;text-align:center}.analytics-table td:not(:first-child){text-align:center}.analytics-table td{padding:14px 12px;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:14px;transition:color .3s ease,border-color .3s ease;word-wrap:break-word;overflow-wrap:break-word}.analytics-table tbody tr:hover{background:var(--bg-secondary);transition:background-color .3s ease}.analytics-table tbody tr:last-child td{border-bottom:none}.analytics-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:16px;border-top:1px solid var(--border-color);flex-wrap:wrap;gap:16px;transition:border-color .3s ease}.pagination-info{font-size:14px;color:var(--text-secondary);transition:color .3s ease}.pagination-controls{display:flex;align-items:center;gap:8px}.pagination-btn{padding:8px 16px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--accent-primary);color:var(--accent-primary)}.pagination-numbers{display:flex;align-items:center;gap:4px}.pagination-number{min-width:36px;height:36px;padding:0 8px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.pagination-number:hover{background:var(--bg-secondary);border-color:var(--accent-primary);color:var(--accent-primary)}.pagination-number.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;font-weight:600}.pagination-number.active:hover{background:var(--accent-primary);opacity:.9}.pagination-ellipsis{padding:0 4px;color:var(--text-secondary);font-size:14px;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:color .3s ease}@media(max-width:768px){.filter-controls{flex-direction:column;align-items:stretch}.filter-group{min-width:100%}.filter-actions{width:100%;flex-direction:column}.btn-filter{width:100%}.analytics-table-container{overflow-x:hidden}.analytics-table{display:block;width:100%;max-width:100%}.analytics-table thead{display:none}.analytics-table tbody{display:block}.analytics-table tbody tr{display:block;margin-bottom:16px;background:var(--bg-card);border:2px solid var(--border-color);border-radius:14px;padding:20px;box-sizing:border-box;transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.analytics-table tbody tr:hover{border-color:var(--accent-primary);box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.analytics-table tbody td{display:block;padding:0;border:none;text-align:left!important;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;font-size:14px;line-height:1.5}.analytics-table tbody td.card-date-header{padding:0 0 16px;margin-bottom:16px;border-bottom:1px solid rgba(255,255,255,.12);color:var(--text-primary);font-weight:700;font-size:16px;line-height:1.3;text-align:center!important}.analytics-table tbody td.card-tag-value{padding:0;margin-bottom:8px;border-bottom:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;align-items:center;gap:12px;color:var(--text-primary);font-size:14px;font-weight:500;min-width:0}.analytics-table tbody td.card-tag-value:last-child{border-bottom:none;margin-bottom:0}.analytics-table tbody td.card-tag-value:before{content:attr(data-tag) " :";font-weight:600;font-size:13px;color:var(--text-secondary);opacity:.8;flex-shrink:0;min-width:80px}.analytics-table tbody tr td[colspan]{display:table-cell!important;text-align:center;padding:60px 20px;border:none}.analytics-filter-section,.analytics-table-section{padding:16px}.analytics-pagination{flex-direction:column;align-items:stretch}.pagination-info{text-align:center}.pagination-controls{justify-content:center;flex-wrap:wrap}.pagination-numbers{flex-wrap:wrap;justify-content:center}}.apikeys-page{width:100%;max-width:100%;padding:24px;background:transparent;min-height:calc(100vh - 80px);color:var(--text-primary);box-sizing:border-box;overflow-x:hidden}.apikeys-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;flex-wrap:wrap;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:0 8px 24px #13233314}.apikeys-header h2{margin:0;font-size:1.5rem;color:var(--text-primary)}.apikeys-controls{display:flex;gap:12px}.btn{border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);padding:10px 12px;border-radius:12px;cursor:pointer;font-weight:600;transition:transform .15s ease,border-color .15s ease,background .15s ease}.btn.primary{border-color:transparent;background:linear-gradient(135deg,#0891b2,#0ea5e9);color:#fff;box-shadow:0 8px 22px #0ea5e93d}.btn:hover{transform:translateY(-1px);border-color:#0ea5e973;background:#0ea5e914}.btn.primary:hover{border-color:transparent;background:linear-gradient(135deg,#0c4a6e,#0891b2);color:#fff}.apikeys-table-container{width:100%;max-width:100%;overflow-x:auto;box-sizing:border-box;background:var(--bg-card);border-radius:12px;box-shadow:0 10px 28px #13233314;overflow:hidden;border:1px solid var(--border-color)}.apikeys-table{width:100%;border-collapse:collapse;font-size:.95rem}.apikeys-table th{background:var(--bg-secondary);padding:14px 18px;text-align:left;font-weight:600;color:var(--accent-primary);border-bottom:1px solid var(--border-color)}.apikeys-table td{padding:16px 18px;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.apikeys-table tr:last-child td{border-bottom:none}.apikeys-table tr:hover{background:#0ea5e914}.apikeys-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding:16px 4px 0;border-top:1px solid var(--border-color)}.pagination-btn{padding:8px 16px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-card);color:var(--text-primary);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.pagination-btn:hover:not(:disabled){border-color:var(--accent-primary);background:#0ea5e914;color:var(--accent-primary)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.btn-icon{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;color:var(--text-secondary);transition:all .2s}.btn-icon:hover{background:#0ea5e91a;color:var(--accent-primary)}.card-key-display code{-webkit-user-select:all;-moz-user-select:all;user-select:all}@media(max-width:768px){.apikeys-page{padding:16px}.apikeys-header{padding:16px;flex-direction:column;align-items:flex-start}.apikeys-pagination{flex-direction:column;align-items:flex-start;gap:10px}}.project-monitor{width:100%;max-width:100%;padding:24px;background:transparent;min-height:calc(100vh - 80px);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;box-sizing:border-box;overflow-x:hidden;overflow:visible;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:20px}.loading-spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{color:#ef4444;font-size:16px;font-weight:600}.monitor-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:24px;padding:20px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;box-sizing:border-box;max-width:100%;overflow-x:hidden}.monitor-header-left{display:flex;align-items:flex-start;gap:16px}.btn-back{padding:8px 16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-back:hover{background:#0ea5e914;border-color:var(--accent-primary)}.monitor-header h1{margin:0;font-size:24px;font-weight:700;color:var(--text-primary)}.monitor-header p{margin:6px 0 0;font-size:14px;color:var(--text-secondary)}.mqtt-topic-guide{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color);display:flex;align-items:center;gap:12px;font-size:13px;flex-wrap:wrap}.topic-text{color:var(--text-secondary)}.topic-text code{font-family:Monaco,Menlo,Ubuntu Mono,monospace;color:var(--accent-primary);background:transparent;padding:0;border:none;font-size:12px;margin:0 4px}.btn-copy-topic{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s ease;flex-shrink:0}.btn-copy-topic:hover{background:linear-gradient(135deg,#0891b2,#0ea5e9);color:#fff;border-color:transparent}.btn-copy-topic:active{transform:scale(.95)}.connection-status{display:flex;align-items:center}.status-connected,.status-disconnected{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600}.monitor-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;padding-top:16px;margin-bottom:24px;max-width:100%;box-sizing:border-box;overflow-x:hidden}.monitor-stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;padding:20px;display:flex;align-items:center;gap:16px;transition:all .2s ease;box-shadow:0 10px 26px #13233314}.monitor-stat-card:hover{border-color:var(--accent-primary);transform:translateY(-2px)}.monitor-stat-card.stat-online{border-left:4px solid #22c55e}.monitor-stat-card.stat-offline{border-left:4px solid #ef4444}.stat-icon{font-size:32px;line-height:1}.stat-content{flex:1;display:flex;flex-direction:column;gap:4px}.stat-label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.stat-value{font-size:28px;font-weight:700;color:var(--text-primary);line-height:1}.status-connected{background:#22c55e1a;color:#22c55e;border:1px solid rgba(34,197,94,.2)}.status-disconnected{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.pulse-dot{width:8px;height:8px;background:#22c55e;border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.monitor-table-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;box-shadow:0 10px 28px #13233314;transition:background-color .3s ease,border-color .3s ease;max-width:100%;box-sizing:border-box}.monitor-table-header{display:flex;justify-content:space-between;align-items:center;margin:0 0 24px;padding-bottom:12px;border-bottom:2px solid var(--border-color)}.monitor-table-header h2{margin:0;font-size:18px;font-weight:700;color:var(--text-primary)}.device-count{font-size:13px;color:var(--text-secondary);font-weight:600;padding:6px 12px;background:#0ea5e91f;border-radius:6px}.monitor-table-wrapper{width:100%;max-width:100%;overflow-x:auto;box-sizing:border-box}.monitor-table{width:100%;margin-top:12px;border-collapse:collapse;table-layout:auto;box-sizing:border-box}.monitor-table thead{background:var(--bg-secondary);transition:background-color .3s ease;position:sticky;top:0;z-index:10}.monitor-table th{color:var(--accent-primary);font-size:14px;font-weight:600;padding:14px 12px;text-align:left;border-bottom:2px solid var(--border-color);transition:color .3s ease,border-color .3s ease;white-space:nowrap}.monitor-table td{padding:14px 12px;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:14px;transition:color .3s ease,border-color .3s ease;word-wrap:break-word;overflow-wrap:break-word;text-align:left}.monitor-table tbody tr:hover{background:#0ea5e914;transition:background-color .3s ease}.monitor-table tbody tr:last-child td{border-bottom:none}.device-row-online{border-left:3px solid #22c55e}.device-row-offline{border-left:3px solid #ef4444}.card-status-indicator{display:flex;align-items:center;justify-content:center;padding:0!important;height:100%;min-height:60px;vertical-align:middle}.status-dot{width:12px;height:12px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.status-dot.status-online{background:#22c55e;animation:pulseOnline 2s ease-in-out infinite;box-shadow:0 0 8px #22c55e99}.status-dot.status-offline{background:#ef4444}@keyframes pulseOnline{0%,to{opacity:1;box-shadow:0 0 8px #22c55e99}50%{opacity:.6;box-shadow:0 0 15px #22c55e4d}}.device-name strong{color:var(--text-primary);font-weight:600}.serial-number{font-family:monospace;font-size:12px;color:var(--text-secondary)}.status-badge{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:12px;padding:4px 10px;border-radius:6px;background:#0ea5e91a}.last-seen{color:var(--text-secondary);font-size:12px}.card-last-update .card-value-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.metric-bar{display:flex;flex-direction:column;gap:4px}.metric-value{font-size:12px;font-weight:600;color:var(--text-primary)}.bar{width:100%;height:6px;background:#0ea5e926;border-radius:3px;overflow:hidden}.bar-fill{height:100%;transition:width .3s ease;border-radius:3px}.btn-sm{padding:6px 12px;font-size:12px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:6px;cursor:pointer;font-weight:600;transition:all .2s}.btn-sm:hover{background:linear-gradient(135deg,#0891b2,#0ea5e9);color:#fff;border-color:transparent}.monitor-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:16px;border-top:1px solid var(--border-color);flex-wrap:wrap;gap:16px;transition:border-color .3s ease}.monitor-pagination .pagination-info{font-size:14px;color:var(--text-secondary);transition:color .3s ease}.monitor-pagination .pagination-controls{display:flex;align-items:center;gap:8px}.monitor-pagination .pagination-btn{padding:8px 16px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.monitor-pagination .pagination-btn:hover:not(:disabled){background:#0ea5e914;border-color:var(--accent-primary);color:var(--accent-primary)}.monitor-pagination .pagination-btn:disabled{opacity:.5;cursor:not-allowed}.monitor-pagination .pagination-numbers{display:flex;align-items:center;gap:4px}.monitor-pagination .pagination-number{min-width:36px;height:36px;padding:0 8px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.monitor-pagination .pagination-number:hover{background:#0ea5e914;border-color:var(--accent-primary);color:var(--accent-primary)}.monitor-pagination .pagination-number.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;font-weight:600}.monitor-pagination .pagination-number.active:hover{background:var(--accent-primary);opacity:.9}.monitor-pagination .pagination-ellipsis{padding:0 4px;color:var(--text-secondary);font-size:14px;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:color .3s ease}@media(max-width:1024px){.project-monitor{padding:0 16px}.monitor-stats{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.monitor-stat-card{padding:16px}.stat-icon{font-size:28px}.stat-value{font-size:24px}}@media(max-width:768px){.project-monitor{padding:0 12px}.monitor-header{flex-direction:column;padding:16px;gap:16px}.monitor-header-left{flex-direction:column;width:100%;gap:12px}.btn-back{align-self:flex-start}.monitor-header h1{font-size:20px}.monitor-header p{font-size:13px}.mqtt-topic-guide{flex-direction:column;align-items:flex-start;gap:8px}.connection-status{width:100%}.status-connected,.status-disconnected{width:100%;justify-content:center;font-size:12px;padding:10px 14px}.monitor-stats{grid-template-columns:1fr;gap:12px;margin-bottom:20px}.monitor-stat-card{padding:16px}.stat-icon{font-size:24px}.stat-label{font-size:11px}.stat-value{font-size:22px}.monitor-table-header{flex-direction:column;align-items:flex-start;gap:12px;padding:16px}.monitor-table-header h2{font-size:16px}.device-count{font-size:12px;padding:5px 10px}.monitor-table-container,.monitor-table-wrapper{overflow-x:hidden}.monitor-table{width:100%;max-width:100%;table-layout:auto}.monitor-table th,.monitor-table td{word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;padding:14px 12px;font-size:14px}.device-name strong{font-size:13px}.serial-number{font-size:11px}.status-badge{font-size:11px;padding:3px 8px}.metric-bar{gap:3px}.metric-value{font-size:11px}.bar{height:5px}.btn-sm{padding:5px 10px;font-size:11px}}@media(max-width:480px){.project-monitor{padding:0 8px;padding-bottom:calc(100px + env(safe-area-inset-bottom,0px))}.monitor-header{padding:12px;border-radius:10px;margin-bottom:16px}.monitor-header h1{font-size:18px}.monitor-header p{font-size:12px}.btn-back{padding:8px 12px;font-size:13px}.status-connected,.status-disconnected{font-size:11px;padding:8px 12px}.monitor-stats{gap:10px;margin-bottom:16px}.monitor-stat-card{padding:14px;border-radius:10px}.stat-icon{font-size:20px}.stat-label{font-size:10px}.stat-value{font-size:20px}.monitor-table-container{padding:16px;border-radius:10px}.monitor-table-header{margin-bottom:16px;padding-bottom:10px}.monitor-table-header h2{font-size:15px}.device-count{font-size:11px}.monitor-table{display:block;width:100%;max-width:100%}.monitor-table thead{display:none}.monitor-table tbody{display:block}.monitor-table tbody tr{display:block;margin-bottom:16px;background:var(--bg-card);border:2px solid var(--border-color);border-radius:14px;padding:20px;box-sizing:border-box;transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.monitor-table tbody tr:hover{border-color:var(--accent-primary);box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.monitor-table tbody tr.device-row-online{border-left:4px solid #22c55e;background:linear-gradient(to right,rgba(34,197,94,.03),var(--bg-card))}.monitor-table tbody tr.device-row-offline{border-left:4px solid #ef4444;background:linear-gradient(to right,rgba(239,68,68,.03),var(--bg-card))}.monitor-table tbody td{display:block;padding:0;border:none;text-align:left!important;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;font-size:14px;line-height:1.5}.monitor-table tbody td.card-hidden{display:none}.monitor-table tbody td.card-device-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;border-bottom:1px solid rgba(255,255,255,.12)}.monitor-table tbody td .device-name-card{flex:1}.monitor-table tbody td .device-name-card strong{display:block;color:var(--text-primary);font-weight:700;font-size:17px;line-height:1.3;word-break:break-word;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.monitor-table tbody td .device-status-card{flex-shrink:0;margin-left:12px}.monitor-table tbody td .status-badge{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:13px;padding:6px 12px;border-radius:6px;background:#ffffff0d}.monitor-table tbody td.card-last-update{padding:0 0 12px;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center;gap:12px}.monitor-table tbody td.card-uptime{margin-bottom:16px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;gap:12px}.monitor-table tbody td.card-uptime:before,.monitor-table tbody td.card-last-update:before{content:attr(data-label) " :";font-weight:600;color:var(--text-secondary);opacity:.8;flex-shrink:0;font-size:13px}.monitor-table tbody td .card-value-text{color:var(--text-primary);font-size:13px;font-weight:500;text-align:right;flex:1}.monitor-table tbody td.card-actions{padding:0}.monitor-table tbody td .btn{width:100%;margin-top:0;padding:12px 20px;font-size:14px;font-weight:600;border-radius:8px;background:var(--accent-primary);color:#fff;border:none;cursor:pointer;transition:all .2s ease}.monitor-table tbody td .btn:hover{background:var(--accent-primary);opacity:.9;transform:translateY(-1px);box-shadow:0 2px 8px #0ea5e94d}.monitor-table tbody tr td[colspan]{display:table-cell!important;text-align:center;padding:60px 20px;border:none}.monitor-table tbody tr td[colspan]:before{display:none!important}.monitor-pagination{flex-direction:column;align-items:stretch;margin-bottom:calc(env(safe-area-inset-bottom,0px) + 100px)}.monitor-pagination .pagination-info{text-align:center}.monitor-pagination .pagination-controls{justify-content:center;flex-wrap:wrap}.monitor-pagination .pagination-numbers{flex-wrap:wrap;justify-content:center}.mobile-safe-area-spacer{height:calc(100px + env(safe-area-inset-bottom,0px));width:100%;flex-shrink:0}}.documentation-page{display:flex;flex-direction:column;gap:16px;color:var(--text-primary, #132333)}.public-doc-page{height:100vh;height:100dvh;background:linear-gradient(145deg,#f5f7fb,#edf4f6 45%,#fdf4ea);padding:16px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;box-sizing:border-box}.public-doc-shell{width:min(1120px,100%);margin:0 auto}.public-doc-header{display:flex;justify-content:flex-end;gap:10px;margin-bottom:12px}.public-doc-btn{border:none;border-radius:12px;height:38px;padding:0 14px;font-size:13px;font-weight:700;cursor:pointer}.public-doc-btn.ghost{background:#0ea5e91f;color:#0c4a6e}.public-doc-btn.solid{background:linear-gradient(135deg,#0891b2,#0ea5e9);color:#fff}.documentation-page.light,.documentation-page.light .documentation-hero h1,.documentation-page.light .doc-section h2,.documentation-page.light .doc-section h3,.documentation-page.light .doc-topic-samples p,.documentation-page.light .doc-card strong,.documentation-page.light .doc-list strong{color:#132333}.documentation-page.light .documentation-hero p,.documentation-page.light .doc-note,.documentation-page.light .doc-text,.documentation-page.light .doc-list,.documentation-page.light .doc-label{color:#35506c}.documentation-page.light .doc-code,.documentation-page.light code{color:#0f2235}.documentation-hero{border:1px solid var(--border-primary, rgba(19, 35, 51, .14));border-radius:16px;padding:20px;background:var(--bg-card, rgba(255, 255, 255, .9));box-shadow:0 14px 34px #0f233314}.doc-kicker{margin:0;display:inline-flex;align-items:center;height:26px;padding:0 10px;border-radius:999px;background:#0ea5e924;color:#0c4a6e;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.7px}.documentation-hero h1{margin:12px 0 10px;font-size:clamp(24px,3.2vw,34px);color:var(--text-primary, #0f2235)}.documentation-hero p{margin:0;color:var(--text-secondary, #35506c);line-height:1.65}.doc-section{border:1px solid var(--border-primary, rgba(19, 35, 51, .14));border-radius:16px;padding:18px;background:var(--bg-card, rgba(255, 255, 255, .92))}.doc-section h2{margin:0 0 10px;font-size:20px;color:var(--text-primary, #0f2235)}.doc-section h3{margin:18px 0 10px;font-size:16px;color:var(--text-primary, #0f2235)}.doc-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.doc-card{border:1px solid rgba(14,165,233,.25);border-radius:12px;padding:12px;background:linear-gradient(180deg,#0ea5e914,#14b8a614);display:flex;flex-direction:column;gap:6px}.doc-label{font-size:11px;text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted, #64748b)}.doc-card strong{font-size:15px;color:var(--text-primary, #0f2235);overflow-wrap:anywhere}.doc-note,.doc-text{margin:12px 0 0;color:var(--text-secondary, #35506c);line-height:1.6}.doc-list{margin:8px 0 0;padding-left:20px;color:var(--text-secondary, #35506c);line-height:1.7}.doc-list.ordered{padding-left:22px}.doc-topic-samples{display:grid;grid-template-columns:1fr;gap:10px;margin-top:10px}.doc-topic-samples p{margin:0 0 6px;color:var(--text-primary, #0f2235);font-weight:600}.doc-code{margin:0;padding:12px;border-radius:12px;border:1px solid var(--border-primary, rgba(19, 35, 51, .14));background:var(--bg-soft, rgba(19, 35, 51, .05));font-size:12px;line-height:1.6;overflow-x:auto;white-space:pre}@media(max-width:980px){.doc-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.public-doc-page{padding:10px}.public-doc-header{justify-content:stretch}.public-doc-btn{flex:1}.documentation-hero,.doc-section{border-radius:14px;padding:14px}.doc-grid{grid-template-columns:1fr}.doc-code{font-size:11px}}#root{width:100%;height:100%;margin:0;padding:0}
