*,:after,:before{--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:rgba(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:rgba(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: }
/*! tailwindcss v3.4.18 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Noto Sans Thai,Sarabun,ui-sans-serif,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;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,pre,samp{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,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{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}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{--tw-bg-opacity:1;background-color:rgb(248 250 252/var(--tw-bg-opacity,1));font-family:Noto Sans Thai,Sarabun,ui-sans-serif,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;--tw-text-opacity:1;color:rgb(30 41 59/var(--tw-text-opacity,1))}[x-cloak]{display:none!important}.card{border-radius:1rem;border-width:1px;--tw-border-opacity:1;border-color:rgb(226 232 240/var(--tw-border-opacity,1));--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));--tw-shadow:0 8px 24px rgba(15,23,42,.06);--tw-shadow-colored:0 8px 24px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);box-shadow:0 8px 24px rgba(15,23,42,.06)}.card-header{display:flex;align-items:center;justify-content:space-between;border-bottom-width:1px;--tw-border-opacity:1;border-color:rgb(226 232 240/var(--tw-border-opacity,1));padding:1rem 1.5rem}.card-body{padding:1.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:1rem;padding:.5rem 1rem;font-size:.875rem;line-height:1.25rem;font-weight:600;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}.btn:focus{outline:2px solid transparent;outline-offset:2px}.btn:focus-visible{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000);--tw-ring-color:rgba(96,165,250,.5)}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{--tw-bg-opacity:1;background-color:rgb(37 99 235/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.btn-primary:active,.btn-primary:hover{--tw-bg-opacity:1;background-color:rgb(29 78 216/var(--tw-bg-opacity,1))}.btn-soft{display:inline-flex;align-items:center;border-radius:12px;border:1px solid #e5e7eb;background:#fff;padding:.35rem .75rem;font-size:.875rem;line-height:1.25rem;box-shadow:0 1px 2px rgba(0,0,0,.04);transition:background .15s}.btn-soft:hover{background:#f8fafc}.btn-danger{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.btn-danger:hover{background-color:rgba(239,68,68,.9)}.btn-ghost{background-color:transparent;--tw-text-opacity:1;color:rgb(51 65 85/var(--tw-text-opacity,1))}.btn-ghost:hover{--tw-bg-opacity:1;background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.btn-sm{border-radius:.75rem;padding:.375rem .75rem}.btn-sm,.btn-xs{font-size:.75rem;line-height:1rem}.btn-xs{border-radius:.5rem;padding:.25rem .5rem}.btn-lg{border-radius:1rem;padding:.75rem 1.25rem;font-size:1rem;line-height:1.5rem}.input{width:100%;border-radius:1rem;border-width:1px;--tw-border-opacity:1;border-color:rgb(226 232 240/var(--tw-border-opacity,1));--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));padding:.625rem .875rem;font-size:.875rem;line-height:1.25rem;--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.input::-moz-placeholder{--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1))}.input::placeholder{--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1))}.input:focus{--tw-border-opacity:1;border-color:rgb(147 197 253/var(--tw-border-opacity,1));outline:2px solid transparent;outline-offset:2px;--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000);--tw-ring-color:rgba(96,165,250,.4)}.input-error{--tw-border-opacity:1;border-color:rgb(239 68 68/var(--tw-border-opacity,1))}.input-error:focus{--tw-ring-color:hsla(0,94%,82%,.5)}.select{width:100%;border-radius:1rem;border-width:1px;--tw-border-opacity:1;border-color:rgb(226 232 240/var(--tw-border-opacity,1));--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));padding:.625rem .875rem;font-size:.875rem;line-height:1.25rem;--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.select::-moz-placeholder{--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1))}.select::placeholder{--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1))}.select:focus{--tw-border-opacity:1;border-color:rgb(147 197 253/var(--tw-border-opacity,1));outline:2px solid transparent;outline-offset:2px;--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000);--tw-ring-color:rgba(96,165,250,.4)}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-position:right .6rem center;background-repeat:no-repeat;padding-right:2.25rem}.textarea{width:100%;border-radius:1rem;border-width:1px;--tw-border-opacity:1;border-color:rgb(226 232 240/var(--tw-border-opacity,1));--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));padding:.625rem .875rem;font-size:.875rem;line-height:1.25rem;--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.textarea::-moz-placeholder{--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1))}.textarea::placeholder{--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1))}.textarea:focus{--tw-border-opacity:1;border-color:rgb(147 197 253/var(--tw-border-opacity,1));outline:2px solid transparent;outline-offset:2px;--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000);--tw-ring-color:rgba(96,165,250,.4)}.textarea{height:auto}.badge{display:inline-flex;align-items:center;border-radius:.75rem;border-width:1px;padding:.125rem .625rem;font-size:.75rem;line-height:1rem;font-weight:500}.badge-red{border-color:rgb(254 205 211/var(--tw-border-opacity,1));background-color:rgb(255 241 242/var(--tw-bg-opacity,1));color:rgb(190 18 60/var(--tw-text-opacity,1))}.badge-green,.badge-red{--tw-border-opacity:1;--tw-bg-opacity:1;--tw-text-opacity:1}.badge-green{border-color:rgb(187 247 208/var(--tw-border-opacity,1));background-color:rgb(240 253 244/var(--tw-bg-opacity,1));color:rgb(21 128 61/var(--tw-text-opacity,1))}.badge-amber{--tw-border-opacity:1;border-color:rgb(253 230 138/var(--tw-border-opacity,1));--tw-bg-opacity:1;background-color:rgb(255 251 235/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(180 83 9/var(--tw-text-opacity,1));opacity:1!important}.table{width:100%;font-size:.875rem;line-height:1.25rem}.table thead th{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));text-align:left;font-weight:600;color:rgb(71 85 105/var(--tw-text-opacity,1))}.table tbody td,.table thead th{padding:.625rem 1rem;--tw-text-opacity:1}.table tbody td{color:rgb(51 65 85/var(--tw-text-opacity,1))}.field{position:relative}.field-icon-left{left:.75rem}.field-icon-left,.field-icon-right{position:absolute;top:50%;--tw-translate-y:-50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1))}.field-icon-right{right:.75rem}.input-lg{height:3rem;border-radius:1rem;padding-left:1rem;padding-right:1rem;font-size:1rem;line-height:1.5rem}.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));padding-left:1.5rem;padding-right:1.5rem;height:60px;box-shadow:0 4px 110px rgba(15,23,42,.05)}.topbar .page-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600;--tw-text-opacity:1;color:rgb(15 23 42/var(--tw-text-opacity,1))}.sidebar{padding-top:8px}.sidebar .sidebar-link{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;border-radius:.75rem;font-size:.875rem;line-height:1.25rem;color:#334155;text-decoration:none}.sidebar .sidebar-link:hover{background:#f1f5f9}.sidebar .nav-icon{width:20px;height:20px;flex-shrink:0}.sidebar .sidebar-sub{padding-left:1rem;padding-right:.25rem;margin-top:.25rem}.sidebar .sidebar-sub>a.sidebar-link,.sidebar .sidebar-sub>div.sidebar-link{padding-right:.25rem}.sidebar .sidebar-sub .submenu-item{margin-left:0!important;padding-left:0!important}.btn-light{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:.5rem;border-width:1px;--tw-border-opacity:1;border-color:rgb(226 232 240/var(--tw-border-opacity,1));--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(51 65 85/var(--tw-text-opacity,1));--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.btn-light:hover{--tw-bg-opacity:1;background-color:rgb(248 250 252/var(--tw-bg-opacity,1))}.i{display:block;width:16px;height:16px;background:currentColor;-webkit-mask-position:center;mask-position:center;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:contain;mask-size:contain}.toggle{position:relative;display:inline-flex;height:1.5rem;width:3rem;align-items:center;overflow:hidden;border-radius:9999px;padding-left:.25rem;padding-right:.25rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.modal-card{max-height:min(85vh,calc(100dvh - 2rem));overflow:hidden;border-radius:.75rem}.modal-card .card-footer,.modal-card .card-header{position:sticky;background:#fff;z-index:1}.modal-card .card-header{top:0;box-shadow:0 1px 0 0 rgba(0,0,0,.06)}.modal-card .card-footer{bottom:0;box-shadow:0 -1px 0 0 rgba(0,0,0,.06)}.modal-scroll{flex:1;overflow:auto;overscroll-behavior:contain;scrollbar-gutter:stable;padding-bottom:1rem}.code-editor{min-height:360px;max-height:72vh;resize:vertical}.view-targets{--vt-px:10px;--vt-py:6px}.view-targets>div{padding:var(--vt-py) var(--vt-px)!important;gap:6px!important;line-height:1.25}.view-targets>div .btn-xs{padding:1px 8px!important;font-size:12px!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.inset-y-0{top:0;bottom:0}.bottom-4{bottom:1rem}.left-0{left:0}.left-1\/2{left:50%}.left-2{left:.5rem}.right-4{right:1rem}.top-2{top:.5rem}.z-\[100000\]{z-index:100000}.z-\[100001\]{z-index:100001}.z-\[100002\]{z-index:100002}.z-\[100003\]{z-index:100003}.z-\[10000\]{z-index:10000}.z-\[60\]{z-index:60}.col-span-1{grid-column:span 1/span 1}.col-span-12{grid-column:span 12/span 12}.col-span-2{grid-column:span 2/span 2}.col-span-3{grid-column:span 3/span 3}.col-span-4{grid-column:span 4/span 4}.col-span-5{grid-column:span 5/span 5}.col-span-6{grid-column:span 6/span 6}.m-0{margin:0}.m-0\.5{margin:.125rem}.m-1{margin:.25rem}.m-1\.5{margin:.375rem}.m-10{margin:2.5rem}.m-12{margin:3rem}.m-16{margin:4rem}.m-2{margin:.5rem}.m-2\.5{margin:.625rem}.m-3{margin:.75rem}.m-4{margin:1rem}.m-5{margin:1.25rem}.m-6{margin:1.5rem}.m-8{margin:2rem}.mx-0{margin-left:0;margin-right:0}.mx-0\.5{margin-left:.125rem;margin-right:.125rem}.mx-1{margin-left:.25rem;margin-right:.25rem}.mx-1\.5{margin-left:.375rem;margin-right:.375rem}.mx-10{margin-left:2.5rem;margin-right:2.5rem}.mx-12{margin-left:3rem;margin-right:3rem}.mx-16{margin-left:4rem;margin-right:4rem}.mx-2{margin-left:.5rem;margin-right:.5rem}.mx-2\.5{margin-left:.625rem;margin-right:.625rem}.mx-3{margin-left:.75rem;margin-right:.75rem}.mx-4{margin-left:1rem;margin-right:1rem}.mx-5{margin-left:1.25rem;margin-right:1.25rem}.mx-6{margin-left:1.5rem;margin-right:1.5rem}.mx-8{margin-left:2rem;margin-right:2rem}.mx-auto{margin-left:auto;margin-right:auto}.my-0{margin-top:0;margin-bottom:0}.my-0\.5{margin-top:.125rem;margin-bottom:.125rem}.my-1{margin-top:.25rem;margin-bottom:.25rem}.my-1\.5{margin-top:.375rem;margin-bottom:.375rem}.my-10{margin-top:2.5rem;margin-bottom:2.5rem}.my-12{margin-top:3rem;margin-bottom:3rem}.my-16{margin-top:4rem;margin-bottom:4rem}.my-2{margin-top:.5rem;margin-bottom:.5rem}.my-2\.5{margin-top:.625rem;margin-bottom:.625rem}.my-3{margin-top:.75rem;margin-bottom:.75rem}.my-4{margin-top:1rem;margin-bottom:1rem}.my-5{margin-top:1.25rem;margin-bottom:1.25rem}.my-6{margin-top:1.5rem;margin-bottom:1.5rem}.my-8{margin-top:2rem;margin-bottom:2rem}.mb-1{margin-bottom:.25rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-14{margin-left:3.5rem}.ml-3{margin-left:.75rem}.ml-auto{margin-left:auto}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-auto{margin-top:auto}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.h-2{height:.5rem}.h-20{height:5rem}.h-24{height:6rem}.h-32{height:8rem}.h-4{height:1rem}.h-40{height:10rem}.h-48{height:12rem}.h-5{height:1.25rem}.h-56{height:14rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-72{height:18rem}.h-8{height:2rem}.h-80{height:20rem}.h-96{height:24rem}.h-full{height:100%}.min-h-screen{min-height:100vh}.w-10{width:2.5rem}.w-12{width:3rem}.w-16{width:4rem}.w-20{width:5rem}.w-24{width:6rem}.w-32{width:8rem}.w-4{width:1rem}.w-40{width:10rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-56{width:14rem}.w-6{width:1.5rem}.w-64{width:16rem}.w-72{width:18rem}.w-8{width:2rem}.w-80{width:20rem}.w-96{width:24rem}.w-\[220px\]{width:220px}.w-\[260px\]{width:260px}.w-auto{width:auto}.w-full{width:100%}.max-w-7xl{max-width:80rem}.max-w-md{max-width:28rem}.max-w-xl{max-width:36rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x:-50%}.-translate-x-1\/2,.-translate-x-full{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-x-full{--tw-translate-x:-100%}.translate-x-0{--tw-translate-x:0px}.translate-x-0,.translate-x-5{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-5{--tw-translate-x:1.25rem}.translate-y-0{--tw-translate-y:0px}.translate-y-0,.translate-y-3{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-3{--tw-translate-y:0.75rem}.rotate-180{--tw-rotate:180deg}.rotate-180,.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-not-allowed{cursor:not-allowed}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.flex-col{flex-direction:column}.place-items-center{place-items:center}.content-center{align-content:center}.content-start{align-content:flex-start}.content-end{align-content:flex-end}.content-between{align-content:space-between}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0{gap:0}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-10{gap:2.5rem}.gap-12{gap:3rem}.gap-16{gap:4rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.75rem*var(--tw-space-x-reverse));margin-left:calc(.75rem*(1 - var(--tw-space-x-reverse)))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem*var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem*var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem*var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem*var(--tw-space-y-reverse))}.space-y-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.25rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.25rem*var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.5rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem*var(--tw-space-y-reverse))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse:0;border-top-width:calc(1px*(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px*var(--tw-divide-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.scroll-smooth{scroll-behavior:smooth}.truncate{overflow:hidden;text-overflow:ellipsis}.truncate,.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-amber-100{--tw-border-opacity:1;border-color:rgb(254 243 199/var(--tw-border-opacity,1))}.border-amber-200{--tw-border-opacity:1;border-color:rgb(253 230 138/var(--tw-border-opacity,1))}.border-amber-300{--tw-border-opacity:1;border-color:rgb(252 211 77/var(--tw-border-opacity,1))}.border-amber-400{--tw-border-opacity:1;border-color:rgb(251 191 36/var(--tw-border-opacity,1))}.border-amber-50{--tw-border-opacity:1;border-color:rgb(255 251 235/var(--tw-border-opacity,1))}.border-amber-500{--tw-border-opacity:1;border-color:rgb(245 158 11/var(--tw-border-opacity,1))}.border-amber-600{--tw-border-opacity:1;border-color:rgb(217 119 6/var(--tw-border-opacity,1))}.border-amber-700{--tw-border-opacity:1;border-color:rgb(180 83 9/var(--tw-border-opacity,1))}.border-amber-800{--tw-border-opacity:1;border-color:rgb(146 64 14/var(--tw-border-opacity,1))}.border-amber-900{--tw-border-opacity:1;border-color:rgb(120 53 15/var(--tw-border-opacity,1))}.border-blue-100{--tw-border-opacity:1;border-color:rgb(219 234 254/var(--tw-border-opacity,1))}.border-blue-200{--tw-border-opacity:1;border-color:rgb(191 219 254/var(--tw-border-opacity,1))}.border-blue-300{--tw-border-opacity:1;border-color:rgb(147 197 253/var(--tw-border-opacity,1))}.border-blue-400{--tw-border-opacity:1;border-color:rgb(96 165 250/var(--tw-border-opacity,1))}.border-blue-50{--tw-border-opacity:1;border-color:rgb(239 246 255/var(--tw-border-opacity,1))}.border-blue-500{--tw-border-opacity:1;border-color:rgb(59 130 246/var(--tw-border-opacity,1))}.border-blue-600{--tw-border-opacity:1;border-color:rgb(37 99 235/var(--tw-border-opacity,1))}.border-blue-700{--tw-border-opacity:1;border-color:rgb(29 78 216/var(--tw-border-opacity,1))}.border-blue-800{--tw-border-opacity:1;border-color:rgb(30 64 175/var(--tw-border-opacity,1))}.border-blue-900{--tw-border-opacity:1;border-color:rgb(30 58 138/var(--tw-border-opacity,1))}.border-danger-300{--tw-border-opacity:1;border-color:rgb(252 165 165/var(--tw-border-opacity,1))}.border-danger-500{--tw-border-opacity:1;border-color:rgb(239 68 68/var(--tw-border-opacity,1))}.border-danger-600{--tw-border-opacity:1;border-color:rgb(220 38 38/var(--tw-border-opacity,1))}.border-gray-100{--tw-border-opacity:1;border-color:rgb(243 244 246/var(--tw-border-opacity,1))}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity,1))}.border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity,1))}.border-gray-400{--tw-border-opacity:1;border-color:rgb(156 163 175/var(--tw-border-opacity,1))}.border-gray-50{--tw-border-opacity:1;border-color:rgb(249 250 251/var(--tw-border-opacity,1))}.border-gray-500{--tw-border-opacity:1;border-color:rgb(107 114 128/var(--tw-border-opacity,1))}.border-gray-600{--tw-border-opacity:1;border-color:rgb(75 85 99/var(--tw-border-opacity,1))}.border-gray-700{--tw-border-opacity:1;border-color:rgb(55 65 81/var(--tw-border-opacity,1))}.border-gray-800{--tw-border-opacity:1;border-color:rgb(31 41 55/var(--tw-border-opacity,1))}.border-gray-900{--tw-border-opacity:1;border-color:rgb(17 24 39/var(--tw-border-opacity,1))}.border-green-100{--tw-border-opacity:1;border-color:rgb(220 252 231/var(--tw-border-opacity,1))}.border-green-200{--tw-border-opacity:1;border-color:rgb(187 247 208/var(--tw-border-opacity,1))}.border-green-300{--tw-border-opacity:1;border-color:rgb(134 239 172/var(--tw-border-opacity,1))}.border-green-400{--tw-border-opacity:1;border-color:rgb(74 222 128/var(--tw-border-opacity,1))}.border-green-50{--tw-border-opacity:1;border-color:rgb(240 253 244/var(--tw-border-opacity,1))}.border-green-500{--tw-border-opacity:1;border-color:rgb(34 197 94/var(--tw-border-opacity,1))}.border-green-600{--tw-border-opacity:1;border-color:rgb(22 163 74/var(--tw-border-opacity,1))}.border-green-700{--tw-border-opacity:1;border-color:rgb(21 128 61/var(--tw-border-opacity,1))}.border-green-800{--tw-border-opacity:1;border-color:rgb(22 101 52/var(--tw-border-opacity,1))}.border-green-900{--tw-border-opacity:1;border-color:rgb(20 83 45/var(--tw-border-opacity,1))}.border-red-100{--tw-border-opacity:1;border-color:rgb(254 226 226/var(--tw-border-opacity,1))}.border-red-200{--tw-border-opacity:1;border-color:rgb(254 202 202/var(--tw-border-opacity,1))}.border-red-300{--tw-border-opacity:1;border-color:rgb(252 165 165/var(--tw-border-opacity,1))}.border-red-400{--tw-border-opacity:1;border-color:rgb(248 113 113/var(--tw-border-opacity,1))}.border-red-50{--tw-border-opacity:1;border-color:rgb(254 242 242/var(--tw-border-opacity,1))}.border-red-500{--tw-border-opacity:1;border-color:rgb(239 68 68/var(--tw-border-opacity,1))}.border-red-600{--tw-border-opacity:1;border-color:rgb(220 38 38/var(--tw-border-opacity,1))}.border-red-700{--tw-border-opacity:1;border-color:rgb(185 28 28/var(--tw-border-opacity,1))}.border-red-800{--tw-border-opacity:1;border-color:rgb(153 27 27/var(--tw-border-opacity,1))}.border-red-900{--tw-border-opacity:1;border-color:rgb(127 29 29/var(--tw-border-opacity,1))}.border-rose-100{--tw-border-opacity:1;border-color:rgb(255 228 230/var(--tw-border-opacity,1))}.border-rose-200{--tw-border-opacity:1;border-color:rgb(254 205 211/var(--tw-border-opacity,1))}.border-rose-300{--tw-border-opacity:1;border-color:rgb(253 164 175/var(--tw-border-opacity,1))}.border-rose-400{--tw-border-opacity:1;border-color:rgb(251 113 133/var(--tw-border-opacity,1))}.border-rose-50{--tw-border-opacity:1;border-color:rgb(255 241 242/var(--tw-border-opacity,1))}.border-rose-500{--tw-border-opacity:1;border-color:rgb(244 63 94/var(--tw-border-opacity,1))}.border-rose-600{--tw-border-opacity:1;border-color:rgb(225 29 72/var(--tw-border-opacity,1))}.border-rose-700{--tw-border-opacity:1;border-color:rgb(190 18 60/var(--tw-border-opacity,1))}.border-rose-800{--tw-border-opacity:1;border-color:rgb(159 18 57/var(--tw-border-opacity,1))}.border-rose-900{--tw-border-opacity:1;border-color:rgb(136 19 55/var(--tw-border-opacity,1))}.border-slate-100{--tw-border-opacity:1;border-color:rgb(241 245 249/var(--tw-border-opacity,1))}.border-slate-200{--tw-border-opacity:1;border-color:rgb(226 232 240/var(--tw-border-opacity,1))}.border-slate-300{--tw-border-opacity:1;border-color:rgb(203 213 225/var(--tw-border-opacity,1))}.border-slate-400{--tw-border-opacity:1;border-color:rgb(148 163 184/var(--tw-border-opacity,1))}.border-slate-50{--tw-border-opacity:1;border-color:rgb(248 250 252/var(--tw-border-opacity,1))}.border-slate-500{--tw-border-opacity:1;border-color:rgb(100 116 139/var(--tw-border-opacity,1))}.border-slate-600{--tw-border-opacity:1;border-color:rgb(71 85 105/var(--tw-border-opacity,1))}.border-slate-700{--tw-border-opacity:1;border-color:rgb(51 65 85/var(--tw-border-opacity,1))}.border-slate-800{--tw-border-opacity:1;border-color:rgb(30 41 59/var(--tw-border-opacity,1))}.border-slate-900{--tw-border-opacity:1;border-color:rgb(15 23 42/var(--tw-border-opacity,1))}.border-success-300{--tw-border-opacity:1;border-color:rgb(134 239 172/var(--tw-border-opacity,1))}.border-success-500{--tw-border-opacity:1;border-color:rgb(22 163 74/var(--tw-border-opacity,1))}.border-success-600{--tw-border-opacity:1;border-color:rgb(21 128 61/var(--tw-border-opacity,1))}.border-warning-300{--tw-border-opacity:1;border-color:rgb(253 230 138/var(--tw-border-opacity,1))}.border-warning-500{--tw-border-opacity:1;border-color:rgb(245 158 11/var(--tw-border-opacity,1))}.border-warning-600{--tw-border-opacity:1;border-color:rgb(217 119 6/var(--tw-border-opacity,1))}.bg-amber-100{--tw-bg-opacity:1;background-color:rgb(254 243 199/var(--tw-bg-opacity,1))}.bg-amber-200{--tw-bg-opacity:1;background-color:rgb(253 230 138/var(--tw-bg-opacity,1))}.bg-amber-300{--tw-bg-opacity:1;background-color:rgb(252 211 77/var(--tw-bg-opacity,1))}.bg-amber-400{--tw-bg-opacity:1;background-color:rgb(251 191 36/var(--tw-bg-opacity,1))}.bg-amber-50{--tw-bg-opacity:1;background-color:rgb(255 251 235/var(--tw-bg-opacity,1))}.bg-amber-500{--tw-bg-opacity:1;background-color:rgb(245 158 11/var(--tw-bg-opacity,1))}.bg-amber-600{--tw-bg-opacity:1;background-color:rgb(217 119 6/var(--tw-bg-opacity,1))}.bg-amber-700{--tw-bg-opacity:1;background-color:rgb(180 83 9/var(--tw-bg-opacity,1))}.bg-amber-800{--tw-bg-opacity:1;background-color:rgb(146 64 14/var(--tw-bg-opacity,1))}.bg-amber-900{--tw-bg-opacity:1;background-color:rgb(120 53 15/var(--tw-bg-opacity,1))}.bg-black\/40{background-color:rgba(0,0,0,.4)}.bg-blue-100{--tw-bg-opacity:1;background-color:rgb(219 234 254/var(--tw-bg-opacity,1))}.bg-blue-200{--tw-bg-opacity:1;background-color:rgb(191 219 254/var(--tw-bg-opacity,1))}.bg-blue-300{--tw-bg-opacity:1;background-color:rgb(147 197 253/var(--tw-bg-opacity,1))}.bg-blue-400{--tw-bg-opacity:1;background-color:rgb(96 165 250/var(--tw-bg-opacity,1))}.bg-blue-50{--tw-bg-opacity:1;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.bg-blue-500{--tw-bg-opacity:1;background-color:rgb(59 130 246/var(--tw-bg-opacity,1))}.bg-blue-600{--tw-bg-opacity:1;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.bg-blue-600\/10{background-color:rgba(37,99,235,.1)}.bg-blue-700{--tw-bg-opacity:1;background-color:rgb(29 78 216/var(--tw-bg-opacity,1))}.bg-blue-800{--tw-bg-opacity:1;background-color:rgb(30 64 175/var(--tw-bg-opacity,1))}.bg-blue-900{--tw-bg-opacity:1;background-color:rgb(30 58 138/var(--tw-bg-opacity,1))}.bg-danger-300{--tw-bg-opacity:1;background-color:rgb(252 165 165/var(--tw-bg-opacity,1))}.bg-danger-500{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity,1))}.bg-danger-600{--tw-bg-opacity:1;background-color:rgb(220 38 38/var(--tw-bg-opacity,1))}.bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.bg-gray-200{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity,1))}.bg-gray-300{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity,1))}.bg-gray-400{--tw-bg-opacity:1;background-color:rgb(156 163 175/var(--tw-bg-opacity,1))}.bg-gray-50{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.bg-gray-500{--tw-bg-opacity:1;background-color:rgb(107 114 128/var(--tw-bg-opacity,1))}.bg-gray-600{--tw-bg-opacity:1;background-color:rgb(75 85 99/var(--tw-bg-opacity,1))}.bg-gray-700{--tw-bg-opacity:1;background-color:rgb(55 65 81/var(--tw-bg-opacity,1))}.bg-gray-800{--tw-bg-opacity:1;background-color:rgb(31 41 55/var(--tw-bg-opacity,1))}.bg-gray-900{--tw-bg-opacity:1;background-color:rgb(17 24 39/var(--tw-bg-opacity,1))}.bg-green-100{--tw-bg-opacity:1;background-color:rgb(220 252 231/var(--tw-bg-opacity,1))}.bg-green-200{--tw-bg-opacity:1;background-color:rgb(187 247 208/var(--tw-bg-opacity,1))}.bg-green-300{--tw-bg-opacity:1;background-color:rgb(134 239 172/var(--tw-bg-opacity,1))}.bg-green-400{--tw-bg-opacity:1;background-color:rgb(74 222 128/var(--tw-bg-opacity,1))}.bg-green-50{--tw-bg-opacity:1;background-color:rgb(240 253 244/var(--tw-bg-opacity,1))}.bg-green-500{--tw-bg-opacity:1;background-color:rgb(34 197 94/var(--tw-bg-opacity,1))}.bg-green-600{--tw-bg-opacity:1;background-color:rgb(22 163 74/var(--tw-bg-opacity,1))}.bg-green-700{--tw-bg-opacity:1;background-color:rgb(21 128 61/var(--tw-bg-opacity,1))}.bg-green-800{--tw-bg-opacity:1;background-color:rgb(22 101 52/var(--tw-bg-opacity,1))}.bg-green-900{--tw-bg-opacity:1;background-color:rgb(20 83 45/var(--tw-bg-opacity,1))}.bg-red-100{--tw-bg-opacity:1;background-color:rgb(254 226 226/var(--tw-bg-opacity,1))}.bg-red-200{--tw-bg-opacity:1;background-color:rgb(254 202 202/var(--tw-bg-opacity,1))}.bg-red-300{--tw-bg-opacity:1;background-color:rgb(252 165 165/var(--tw-bg-opacity,1))}.bg-red-400{--tw-bg-opacity:1;background-color:rgb(248 113 113/var(--tw-bg-opacity,1))}.bg-red-50{--tw-bg-opacity:1;background-color:rgb(254 242 242/var(--tw-bg-opacity,1))}.bg-red-500{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity,1))}.bg-red-600{--tw-bg-opacity:1;background-color:rgb(220 38 38/var(--tw-bg-opacity,1))}.bg-red-700{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity,1))}.bg-red-800{--tw-bg-opacity:1;background-color:rgb(153 27 27/var(--tw-bg-opacity,1))}.bg-red-900{--tw-bg-opacity:1;background-color:rgb(127 29 29/var(--tw-bg-opacity,1))}.bg-rose-100{--tw-bg-opacity:1;background-color:rgb(255 228 230/var(--tw-bg-opacity,1))}.bg-rose-200{--tw-bg-opacity:1;background-color:rgb(254 205 211/var(--tw-bg-opacity,1))}.bg-rose-300{--tw-bg-opacity:1;background-color:rgb(253 164 175/var(--tw-bg-opacity,1))}.bg-rose-400{--tw-bg-opacity:1;background-color:rgb(251 113 133/var(--tw-bg-opacity,1))}.bg-rose-50{--tw-bg-opacity:1;background-color:rgb(255 241 242/var(--tw-bg-opacity,1))}.bg-rose-500{--tw-bg-opacity:1;background-color:rgb(244 63 94/var(--tw-bg-opacity,1))}.bg-rose-600{--tw-bg-opacity:1;background-color:rgb(225 29 72/var(--tw-bg-opacity,1))}.bg-rose-700{--tw-bg-opacity:1;background-color:rgb(190 18 60/var(--tw-bg-opacity,1))}.bg-rose-800{--tw-bg-opacity:1;background-color:rgb(159 18 57/var(--tw-bg-opacity,1))}.bg-rose-900{--tw-bg-opacity:1;background-color:rgb(136 19 55/var(--tw-bg-opacity,1))}.bg-slate-100{--tw-bg-opacity:1;background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.bg-slate-200{--tw-bg-opacity:1;background-color:rgb(226 232 240/var(--tw-bg-opacity,1))}.bg-slate-300{--tw-bg-opacity:1;background-color:rgb(203 213 225/var(--tw-bg-opacity,1))}.bg-slate-400{--tw-bg-opacity:1;background-color:rgb(148 163 184/var(--tw-bg-opacity,1))}.bg-slate-50{--tw-bg-opacity:1;background-color:rgb(248 250 252/var(--tw-bg-opacity,1))}.bg-slate-500{--tw-bg-opacity:1;background-color:rgb(100 116 139/var(--tw-bg-opacity,1))}.bg-slate-600{--tw-bg-opacity:1;background-color:rgb(71 85 105/var(--tw-bg-opacity,1))}.bg-slate-700{--tw-bg-opacity:1;background-color:rgb(51 65 85/var(--tw-bg-opacity,1))}.bg-slate-800{--tw-bg-opacity:1;background-color:rgb(30 41 59/var(--tw-bg-opacity,1))}.bg-slate-900{--tw-bg-opacity:1;background-color:rgb(15 23 42/var(--tw-bg-opacity,1))}.bg-slate-900\/40{background-color:rgba(15,23,42,.4)}.bg-success-300{--tw-bg-opacity:1;background-color:rgb(134 239 172/var(--tw-bg-opacity,1))}.bg-success-500{--tw-bg-opacity:1;background-color:rgb(22 163 74/var(--tw-bg-opacity,1))}.bg-success-600{--tw-bg-opacity:1;background-color:rgb(21 128 61/var(--tw-bg-opacity,1))}.bg-warning-300{--tw-bg-opacity:1;background-color:rgb(253 230 138/var(--tw-bg-opacity,1))}.bg-warning-500{--tw-bg-opacity:1;background-color:rgb(245 158 11/var(--tw-bg-opacity,1))}.bg-warning-600{--tw-bg-opacity:1;background-color:rgb(217 119 6/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.object-contain{-o-object-fit:contain;object-fit:contain}.p-0{padding:0}.p-0\.5{padding:.125rem}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-10{padding:2.5rem}.p-12{padding:3rem}.p-16{padding:4rem}.p-2{padding:.5rem}.p-2\.5{padding:.625rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-0{padding-left:0;padding-right:0}.px-0\.5{padding-left:.125rem;padding-right:.125rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-10{padding-left:2.5rem;padding-right:2.5rem}.px-12{padding-left:3rem;padding-right:3rem}.px-16{padding-left:4rem;padding-right:4rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0{padding-top:0;padding-bottom:0}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-5{padding-bottom:1.25rem}.pl-12{padding-left:3rem}.pr-1{padding-right:.25rem}.pr-12{padding-right:3rem}.text-center{text-align:center}.text-right{text-align:right}.align-middle{vertical-align:middle}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-\[12\.5px\]{font-size:12.5px}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.leading-5{line-height:1.25rem}.tracking-tight{letter-spacing:-.025em}.tracking-wider{letter-spacing:.05em}.text-amber-100{--tw-text-opacity:1;color:rgb(254 243 199/var(--tw-text-opacity,1))}.text-amber-200{--tw-text-opacity:1;color:rgb(253 230 138/var(--tw-text-opacity,1))}.text-amber-300{--tw-text-opacity:1;color:rgb(252 211 77/var(--tw-text-opacity,1))}.text-amber-400{--tw-text-opacity:1;color:rgb(251 191 36/var(--tw-text-opacity,1))}.text-amber-50{--tw-text-opacity:1;color:rgb(255 251 235/var(--tw-text-opacity,1))}.text-amber-500{--tw-text-opacity:1;color:rgb(245 158 11/var(--tw-text-opacity,1))}.text-amber-600{--tw-text-opacity:1;color:rgb(217 119 6/var(--tw-text-opacity,1))}.text-amber-700{--tw-text-opacity:1;color:rgb(180 83 9/var(--tw-text-opacity,1))}.text-amber-800{--tw-text-opacity:1;color:rgb(146 64 14/var(--tw-text-opacity,1))}.text-amber-900{--tw-text-opacity:1;color:rgb(120 53 15/var(--tw-text-opacity,1))}.text-blue-100{--tw-text-opacity:1;color:rgb(219 234 254/var(--tw-text-opacity,1))}.text-blue-200{--tw-text-opacity:1;color:rgb(191 219 254/var(--tw-text-opacity,1))}.text-blue-300{--tw-text-opacity:1;color:rgb(147 197 253/var(--tw-text-opacity,1))}.text-blue-400{--tw-text-opacity:1;color:rgb(96 165 250/var(--tw-text-opacity,1))}.text-blue-50{--tw-text-opacity:1;color:rgb(239 246 255/var(--tw-text-opacity,1))}.text-blue-500{--tw-text-opacity:1;color:rgb(59 130 246/var(--tw-text-opacity,1))}.text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity,1))}.text-blue-700{--tw-text-opacity:1;color:rgb(29 78 216/var(--tw-text-opacity,1))}.text-blue-800{--tw-text-opacity:1;color:rgb(30 64 175/var(--tw-text-opacity,1))}.text-blue-900{--tw-text-opacity:1;color:rgb(30 58 138/var(--tw-text-opacity,1))}.text-danger-300{--tw-text-opacity:1;color:rgb(252 165 165/var(--tw-text-opacity,1))}.text-danger-500{--tw-text-opacity:1;color:rgb(239 68 68/var(--tw-text-opacity,1))}.text-danger-600{--tw-text-opacity:1;color:rgb(220 38 38/var(--tw-text-opacity,1))}.text-gray-100{--tw-text-opacity:1;color:rgb(243 244 246/var(--tw-text-opacity,1))}.text-gray-200{--tw-text-opacity:1;color:rgb(229 231 235/var(--tw-text-opacity,1))}.text-gray-300{--tw-text-opacity:1;color:rgb(209 213 219/var(--tw-text-opacity,1))}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1))}.text-gray-50{--tw-text-opacity:1;color:rgb(249 250 251/var(--tw-text-opacity,1))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity,1))}.text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity,1))}.text-green-100{--tw-text-opacity:1;color:rgb(220 252 231/var(--tw-text-opacity,1))}.text-green-200{--tw-text-opacity:1;color:rgb(187 247 208/var(--tw-text-opacity,1))}.text-green-300{--tw-text-opacity:1;color:rgb(134 239 172/var(--tw-text-opacity,1))}.text-green-400{--tw-text-opacity:1;color:rgb(74 222 128/var(--tw-text-opacity,1))}.text-green-50{--tw-text-opacity:1;color:rgb(240 253 244/var(--tw-text-opacity,1))}.text-green-500{--tw-text-opacity:1;color:rgb(34 197 94/var(--tw-text-opacity,1))}.text-green-600{--tw-text-opacity:1;color:rgb(22 163 74/var(--tw-text-opacity,1))}.text-green-700{--tw-text-opacity:1;color:rgb(21 128 61/var(--tw-text-opacity,1))}.text-green-800{--tw-text-opacity:1;color:rgb(22 101 52/var(--tw-text-opacity,1))}.text-green-900{--tw-text-opacity:1;color:rgb(20 83 45/var(--tw-text-opacity,1))}.text-red-100{--tw-text-opacity:1;color:rgb(254 226 226/var(--tw-text-opacity,1))}.text-red-200{--tw-text-opacity:1;color:rgb(254 202 202/var(--tw-text-opacity,1))}.text-red-300{--tw-text-opacity:1;color:rgb(252 165 165/var(--tw-text-opacity,1))}.text-red-400{--tw-text-opacity:1;color:rgb(248 113 113/var(--tw-text-opacity,1))}.text-red-50{--tw-text-opacity:1;color:rgb(254 242 242/var(--tw-text-opacity,1))}.text-red-500{--tw-text-opacity:1;color:rgb(239 68 68/var(--tw-text-opacity,1))}.text-red-600{--tw-text-opacity:1;color:rgb(220 38 38/var(--tw-text-opacity,1))}.text-red-700{--tw-text-opacity:1;color:rgb(185 28 28/var(--tw-text-opacity,1))}.text-red-800{--tw-text-opacity:1;color:rgb(153 27 27/var(--tw-text-opacity,1))}.text-red-900{--tw-text-opacity:1;color:rgb(127 29 29/var(--tw-text-opacity,1))}.text-rose-100{--tw-text-opacity:1;color:rgb(255 228 230/var(--tw-text-opacity,1))}.text-rose-200{--tw-text-opacity:1;color:rgb(254 205 211/var(--tw-text-opacity,1))}.text-rose-300{--tw-text-opacity:1;color:rgb(253 164 175/var(--tw-text-opacity,1))}.text-rose-400{--tw-text-opacity:1;color:rgb(251 113 133/var(--tw-text-opacity,1))}.text-rose-50{--tw-text-opacity:1;color:rgb(255 241 242/var(--tw-text-opacity,1))}.text-rose-500{--tw-text-opacity:1;color:rgb(244 63 94/var(--tw-text-opacity,1))}.text-rose-600{--tw-text-opacity:1;color:rgb(225 29 72/var(--tw-text-opacity,1))}.text-rose-700{--tw-text-opacity:1;color:rgb(190 18 60/var(--tw-text-opacity,1))}.text-rose-800{--tw-text-opacity:1;color:rgb(159 18 57/var(--tw-text-opacity,1))}.text-rose-900{--tw-text-opacity:1;color:rgb(136 19 55/var(--tw-text-opacity,1))}.text-slate-100{--tw-text-opacity:1;color:rgb(241 245 249/var(--tw-text-opacity,1))}.text-slate-200{--tw-text-opacity:1;color:rgb(226 232 240/var(--tw-text-opacity,1))}.text-slate-300{--tw-text-opacity:1;color:rgb(203 213 225/var(--tw-text-opacity,1))}.text-slate-400{--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1))}.text-slate-50{--tw-text-opacity:1;color:rgb(248 250 252/var(--tw-text-opacity,1))}.text-slate-500{--tw-text-opacity:1;color:rgb(100 116 139/var(--tw-text-opacity,1))}.text-slate-600{--tw-text-opacity:1;color:rgb(71 85 105/var(--tw-text-opacity,1))}.text-slate-700{--tw-text-opacity:1;color:rgb(51 65 85/var(--tw-text-opacity,1))}.text-slate-800{--tw-text-opacity:1;color:rgb(30 41 59/var(--tw-text-opacity,1))}.text-slate-900{--tw-text-opacity:1;color:rgb(15 23 42/var(--tw-text-opacity,1))}.text-success-300{--tw-text-opacity:1;color:rgb(134 239 172/var(--tw-text-opacity,1))}.text-success-500{--tw-text-opacity:1;color:rgb(22 163 74/var(--tw-text-opacity,1))}.text-success-600{--tw-text-opacity:1;color:rgb(21 128 61/var(--tw-text-opacity,1))}.text-warning-300{--tw-text-opacity:1;color:rgb(253 230 138/var(--tw-text-opacity,1))}.text-warning-500{--tw-text-opacity:1;color:rgb(245 158 11/var(--tw-text-opacity,1))}.text-warning-600{--tw-text-opacity:1;color:rgb(217 119 6/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.underline{text-decoration-line:underline}.opacity-0{opacity:0}.opacity-100{opacity:1}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.shadow{--tw-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.shadow,.shadow-card{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-card{--tw-shadow:0 8px 24px rgba(15,23,42,.06);--tw-shadow-colored:0 8px 24px var(--tw-shadow-color)}.shadow-xl{--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-\[1px\]{--tw-backdrop-blur:blur(1px);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-150,.transition-transform{transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-in{transition-timing-function:cubic-bezier(.4,0,1,1)}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.table thead th{position:sticky;top:0;z-index:1}.table tbody tr:nth-child(odd){background:rgba(248,250,252,.5)}.dense .table tbody td,.dense .table thead th{padding:.5rem .75rem}.shadow-card{box-shadow:0 8px 24px rgba(15,23,42,.06)}.overlay-backdrop{z-index:9998!important}.trigger-top{z-index:10001!important}.spinner{width:16px;height:16px;border:2px solid #93c5fd;border-top-color:transparent;border-radius:9999px;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}@keyframes ping{0%{transform:scale(.7);opacity:.8}70%{transform:scale(1.8);opacity:0}to{opacity:0}}@keyframes status-pulse{0%{transform:scale(1);opacity:.6}70%{transform:scale(2.2);opacity:0}to{transform:scale(2.5);opacity:0}}@media (prefers-reduced-motion:reduce){.status-dot:not(.force-anim):after{animation:none}}#app,.app-root,.layout-root,.page-wrapper{display:flex;flex-direction:row;min-height:100vh;align-items:stretch;width:100%;box-sizing:border-box}.sidebar,aside.sidebar{display:flex;flex-direction:column;width:260px;max-width:30%;box-sizing:border-box;z-index:20;background:#fff;border-right:1px solid rgba(15,23,42,.04);box-shadow:0 4px 20px rgba(15,23,42,.04);border-radius:8px 0 0 8px;padding:16px 14px}.sidebar-logo{align-items:center;justify-content:center;margin-bottom:20px;text-align:center}.sidebar-logo img{height:70px!important;width:auto!important;display:block;-o-object-fit:contain;object-fit:contain}@media (max-width:480px){.sidebar-logo img{height:52px!important}.sidebar-logo{margin-bottom:26px}}.sidebar-body{flex:1 1 auto;overflow-y:auto;padding-right:6px;-webkit-overflow-scrolling:touch}.sidebar-bottom{margin-top:auto;display:grid;place-items:center;width:100%;height:32px;padding:0 10px;font-size:12px;font-weight:500;text-align:center;color:#374151;background:hsla(0,0%,100%,.55);backdrop-filter:saturate(160%) blur(10px);border-radius:10px;border:1px solid hsla(0,0%,100%,.55);box-shadow:0 6px 18px rgba(15,23,42,.04),inset 0 0 0 1px hsla(0,0%,100%,.06)}.content-area,.main-content{flex:1 1 auto;display:flex;flex-direction:column;min-width:0;box-sizing:border-box;margin-left:0;padding-left:0}aside.sidebar.fixed{width:260px;max-width:80%;background:#fff;height:100vh;top:0;left:0;position:fixed;z-index:10000}@media (min-width:1024px){aside.sidebar.fixed{position:fixed!important;top:0;left:0;height:100vh!important;transform:none!important}}@media (max-width:900px){#app,.app-root,.layout-root,.page-wrapper{flex-direction:column}.sidebar,aside.sidebar{width:100%;max-width:100%;border-radius:0;padding:12px}.content-area,.main-content{order:2}.sidebar-bottom{width:100%}.sidebar-body{max-height:60vh}}.login-brand{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1rem}.login-brand img{height:56px;width:auto;display:block;-o-object-fit:contain;object-fit:contain}.hover\:bg-red-700:hover{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity,1))}.hover\:bg-slate-100:hover{--tw-bg-opacity:1;background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.hover\:bg-slate-50:hover{--tw-bg-opacity:1;background-color:rgb(248 250 252/var(--tw-bg-opacity,1))}.hover\:text-slate-600:hover{--tw-text-opacity:1;color:rgb(71 85 105/var(--tw-text-opacity,1))}.hover\:text-slate-700:hover{--tw-text-opacity:1;color:rgb(51 65 85/var(--tw-text-opacity,1))}.hover\:text-slate-800:hover{--tw-text-opacity:1;color:rgb(30 41 59/var(--tw-text-opacity,1))}.hover\:text-slate-900:hover{--tw-text-opacity:1;color:rgb(15 23 42/var(--tw-text-opacity,1))}.hover\:underline:hover{text-decoration-line:underline}@media (min-width:640px){.sm\:inline{display:inline}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:p-6{padding:1.5rem}}@media (min-width:768px){.md\:gap-6{gap:1.5rem}.md\:p-6{padding:1.5rem}}@media (min-width:1024px){.lg\:col-span-1{grid-column:span 1/span 1}.lg\:col-span-2{grid-column:span 2/span 2}.lg\:ml-0{margin-left:0}.lg\:ml-\[260px\]{margin-left:260px}.lg\:block{display:block}.lg\:hidden{display:none}.lg\:w-auto{width:auto}.lg\:translate-x-0{--tw-translate-x:0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:justify-self-end{justify-self:end}.lg\:pl-6{padding-left:1.5rem}}@media (min-width:1280px){.xl\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}
/* =========================================================
   VIPOX UI POLISH PATCH - Dashboard, User Control, Login
   Safe CSS override only. No database change.
   ========================================================= */
:root{
  --vipox-bg:#f4f7fb;
  --vipox-surface:#ffffff;
  --vipox-surface-2:#f8fafc;
  --vipox-border:#e2e8f0;
  --vipox-border-soft:#edf2f7;
  --vipox-text:#0f172a;
  --vipox-muted:#64748b;
  --vipox-blue:#2563eb;
  --vipox-blue-2:#0ea5e9;
  --vipox-green:#16a34a;
  --vipox-red:#dc2626;
  --vipox-amber:#d97706;
  --vipox-violet:#7c3aed;
  --vipox-shadow:0 18px 50px rgba(15,23,42,.08);
  --vipox-shadow-soft:0 10px 30px rgba(15,23,42,.06);
}
html,body{background:var(--vipox-bg)!important;color:var(--vipox-text);font-family:"Noto Sans Thai","Sarabun",Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif!important}
body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:-1;background:radial-gradient(circle at 20% 0%,rgba(37,99,235,.10),transparent 32%),radial-gradient(circle at 85% 8%,rgba(14,165,233,.10),transparent 32%),linear-gradient(180deg,#f8fbff 0%,#f4f7fb 50%,#f8fafc 100%)}
.main-content{background:transparent!important}
.topbar{position:sticky;top:0;z-index:30;height:64px;background:rgba(255,255,255,.82)!important;backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid rgba(226,232,240,.80);box-shadow:0 8px 28px rgba(15,23,42,.04)}
.page-title{font-size:1.18rem!important;letter-spacing:-.025em}.topbar .rounded-full{box-shadow:inset 0 0 0 1px rgba(37,99,235,.14),0 8px 22px rgba(37,99,235,.10)}
main{padding-top:1.5rem!important;padding-bottom:3rem!important}
@media(min-width:1024px){main{padding-top:1.8rem!important}.main-content{min-height:100vh}}

/* Sidebar */
aside.sidebar{width:270px!important;padding:18px 16px!important;background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%)!important;border-right:1px solid rgba(226,232,240,.9)!important;box-shadow:14px 0 46px rgba(15,23,42,.055)!important;border-radius:0!important}
.lg\:ml-\[260px\]{margin-left:270px!important}.sidebar-logo{height:auto!important;margin:0 0 20px!important;padding:6px 4px 14px!important;border-bottom:1px solid rgba(226,232,240,.75)}.sidebar-logo img{height:58px!important;margin:0 auto!important;filter:drop-shadow(0 14px 22px rgba(15,23,42,.10))}.sidebar-body{padding-right:2px!important}.sidebar-body>p{font-size:.68rem!important;font-weight:800!important;letter-spacing:.12em!important;color:#94a3b8!important;margin:20px 8px 8px!important}.sidebar-link{position:relative!important;display:flex!important;align-items:center!important;gap:.75rem!important;min-height:44px!important;margin:4px 0!important;padding:10px 12px!important;border-radius:15px!important;color:#475569!important;transition:background .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease!important}.sidebar-link:hover{background:#eef6ff!important;color:#0f172a!important;transform:translateX(2px)}.sidebar-link.is-active{background:linear-gradient(135deg,#0f172a 0%,#1d4ed8 100%)!important;color:#fff!important;box-shadow:0 14px 30px rgba(37,99,235,.24)!important}.sidebar-link.is-active:before{content:"";position:absolute;left:-7px;top:12px;bottom:12px;width:4px;border-radius:999px;background:#38bdf8}.sidebar-link .nav-icon{width:20px!important;height:20px!important;flex:0 0 auto}.sidebar-sub{padding-left:10px!important;margin-left:10px!important;border-left:1px dashed #cbd5e1}.sidebar-bottom{height:38px!important;border-radius:14px!important;background:rgba(255,255,255,.72)!important;border:1px solid rgba(226,232,240,.8)!important;color:#64748b!important;box-shadow:0 10px 28px rgba(15,23,42,.05)!important}
@media(max-width:1023px){aside.sidebar{width:280px!important;max-width:86%!important}.lg\:ml-\[260px\]{margin-left:0!important}.topbar{height:60px}.sidebar-logo img{height:52px!important}}

/* Core surface */
.card{border:1px solid rgba(226,232,240,.9)!important;border-radius:24px!important;background:rgba(255,255,255,.92)!important;box-shadow:var(--vipox-shadow-soft)!important;overflow:hidden!important}.card-header{min-height:56px!important;padding:16px 20px!important;border-bottom:1px solid rgba(226,232,240,.82)!important;background:linear-gradient(180deg,rgba(255,255,255,.95),rgba(248,250,252,.85))!important;font-weight:700!important;color:#1e293b!important}.card-body{padding:20px!important}.ui-card-lg{box-shadow:var(--vipox-shadow)!important}.ui-card-header span{letter-spacing:-.01em}.ui-page-stack{display:flex;flex-direction:column;gap:22px}.hero-card{position:relative;overflow:hidden;border:1px solid rgba(226,232,240,.86);border-radius:28px;background:linear-gradient(135deg,#ffffff 0%,#eef6ff 58%,#e0f2fe 100%);box-shadow:var(--vipox-shadow);padding:24px 26px;display:flex;align-items:center;justify-content:space-between;gap:18px}.hero-card:after{content:"";position:absolute;right:-60px;top:-80px;width:250px;height:250px;border-radius:999px;background:rgba(37,99,235,.12)}.hero-card>*{position:relative;z-index:1}.hero-card-user{background:linear-gradient(135deg,#ffffff 0%,#f3f7ff 55%,#eef2ff 100%)}.eyebrow{font-size:.76rem;line-height:1.1;font-weight:800;text-transform:uppercase;letter-spacing:.13em;color:var(--vipox-blue);margin:0 0 8px}.hero-title{font-size:clamp(1.45rem,2.6vw,2.15rem);line-height:1.15;font-weight:850;letter-spacing:-.045em;color:#0f172a;margin:0}.hero-subtitle{margin:.48rem 0 0;color:#64748b;max-width:680px;font-size:.96rem}.hero-chip,.hero-action{display:inline-flex;align-items:center;gap:9px;border:1px solid rgba(37,99,235,.16);background:rgba(255,255,255,.75);color:#1e40af;border-radius:999px;padding:10px 14px;font-size:.86rem;font-weight:750;white-space:nowrap;box-shadow:0 12px 30px rgba(37,99,235,.10)}.hero-action:hover{background:#fff;color:#1d4ed8;text-decoration:none}.section-title-row{display:flex;justify-content:space-between;align-items:center;gap:16px}.section-title{margin:0;font-size:1.2rem;font-weight:800;letter-spacing:-.025em;color:#0f172a}.content-grid{display:grid;gap:22px}.content-grid-3{grid-template-columns:1fr}.stat-grid{display:grid;gap:16px}.stat-grid-3,.stat-grid-4{grid-template-columns:repeat(1,minmax(0,1fr))}@media(min-width:640px){.stat-grid-3,.stat-grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1024px){.content-grid-3{grid-template-columns:2fr 1fr}.stat-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.stat-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}}

/* Stats */
.stat-card{position:relative;overflow:hidden;display:flex;align-items:flex-start;gap:16px;min-height:148px;padding:20px;border-radius:24px;border:1px solid rgba(226,232,240,.9);background:rgba(255,255,255,.94);box-shadow:var(--vipox-shadow-soft);transition:transform .18s ease,box-shadow .18s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--vipox-shadow)}.stat-card:after{content:"";position:absolute;right:-44px;bottom:-58px;width:160px;height:160px;border-radius:50%;opacity:.12}.stat-blue:after{background:var(--vipox-blue)}.stat-red:after{background:var(--vipox-red)}.stat-green:after{background:var(--vipox-green)}.stat-violet:after{background:var(--vipox-violet)}.stat-icon{display:grid;place-items:center;width:44px;height:44px;border-radius:16px;font-size:1.22rem;font-weight:900;flex:0 0 auto;color:#fff;box-shadow:0 14px 28px rgba(15,23,42,.16)}.stat-blue .stat-icon{background:linear-gradient(135deg,#2563eb,#0ea5e9)}.stat-red .stat-icon{background:linear-gradient(135deg,#dc2626,#fb7185)}.stat-green .stat-icon{background:linear-gradient(135deg,#16a34a,#22c55e)}.stat-violet .stat-icon{background:linear-gradient(135deg,#7c3aed,#a855f7)}.stat-label{font-size:.83rem;font-weight:800;color:#64748b;margin:0}.stat-value{font-size:clamp(1.75rem,3vw,2.28rem);line-height:1.08;font-weight:900;letter-spacing:-.05em;color:#0f172a;margin:8px 0 0}.stat-note{font-size:.86rem;color:#64748b;margin:.35rem 0 0}

/* Tables & badges */
.ui-table-wrap{border-radius:18px;border:1px solid rgba(226,232,240,.72);overflow:auto}.table,.ui-table{width:100%;border-collapse:separate!important;border-spacing:0!important}.table thead th,.ui-table thead th{background:#f8fafc!important;color:#64748b!important;font-weight:800!important;font-size:.76rem!important;text-transform:uppercase!important;letter-spacing:.065em!important;padding:14px 16px!important;border-bottom:1px solid #e2e8f0!important}.table tbody td,.ui-table tbody td{padding:14px 16px!important;border-bottom:1px solid #edf2f7!important;vertical-align:middle}.table tbody tr:last-child td,.ui-table tbody tr:last-child td{border-bottom:0!important}.table tbody tr:nth-child(odd){background:#fff!important}.table tbody tr:hover td{background:#f8fbff!important}.empty-cell,.empty-state{color:#64748b;font-size:.92rem}.user-mini{display:inline-flex;align-items:center;min-height:28px;padding:4px 9px;border-radius:999px;background:#f1f5f9;color:#334155;font-weight:750}.badge-soft{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:999px;border:1px solid #e2e8f0;padding:5px 10px;font-size:.76rem;font-weight:800;line-height:1.1;white-space:nowrap}.badge-success{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.badge-danger{color:#991b1b;background:#fef2f2;border-color:#fecaca}.badge-warning{color:#92400e;background:#fffbeb;border-color:#fde68a}.badge-neutral{color:#475569;background:#f8fafc;border-color:#e2e8f0}.ui-link{font-size:.86rem;font-weight:800;color:#2563eb}.ui-link:hover{text-decoration:underline}.progress-bar{height:8px;border-radius:999px;overflow:hidden;background:#e2e8f0}.progress-bar span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#2563eb,#0ea5e9)}.progress-lg{height:11px}.expiry-list{display:grid;gap:14px}.expiry-item{border:1px solid #edf2f7;border-radius:18px;padding:14px;background:#fff}.expiry-top,.expiry-bottom{display:flex;align-items:center;justify-content:space-between;gap:12px}.expiry-user{font-weight:850;color:#0f172a;margin:0}.expiry-name{font-size:.78rem;color:#94a3b8;margin:2px 0 0}.expiry-bottom{font-size:.78rem;font-weight:800;color:#64748b;margin-top:7px}.account-days{font-size:2rem;line-height:1.1;font-weight:900;letter-spacing:-.045em;color:#0f172a;margin:0}.account-expiry-card .card-body{min-height:168px}

/* Notices */
.notice{border-radius:18px;padding:13px 16px;font-size:.9rem;border:1px solid #e2e8f0;box-shadow:0 10px 24px rgba(15,23,42,.04)}.notice-success{background:#f0fdf4;color:#166534;border-color:#bbf7d0}.notice-danger{background:#fef2f2;color:#991b1b;border-color:#fecaca}.notice-warning{background:#fffbeb;color:#92400e;border-color:#fde68a}

/* User Control */
.add-user-card summary::-webkit-details-marker{display:none}.summary-chip{font-size:.8rem;font-weight:800;color:#2563eb;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;padding:6px 10px}.add-user-grid{display:grid;gap:15px;grid-template-columns:1fr}.form-field{display:block}.form-field span{display:block;font-size:.82rem;font-weight:800;color:#64748b;margin-bottom:7px}.input{border-radius:14px!important;border-color:#dbe5f0!important;background:#fff!important;transition:border-color .15s ease,box-shadow .15s ease!important}.input:focus{border-color:#60a5fa!important;box-shadow:0 0 0 4px rgba(37,99,235,.12)!important;outline:none!important}.feature-picker{border:1px solid #e2e8f0;border-radius:18px;background:#f8fafc;padding:14px}.feature-picker-title{font-size:.82rem;font-weight:850;color:#475569;margin:0 0 10px}.feature-picker-row{display:flex;flex-wrap:wrap;gap:10px 16px}.create-user-btn{align-self:end}.user-card-grid{display:grid;grid-template-columns:1fr;gap:18px}@media(min-width:860px){.add-user-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.feature-picker{grid-column:1/-1}.create-user-btn{justify-self:end}}@media(min-width:1180px){.user-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.add-user-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.feature-picker{grid-column:1/5}.create-user-btn{grid-column:5/6}}.user-control-card{border:1px solid rgba(226,232,240,.9);border-radius:26px;background:rgba(255,255,255,.96);box-shadow:var(--vipox-shadow-soft);padding:18px;display:flex;flex-direction:column;gap:16px;transition:transform .18s ease,box-shadow .18s ease}.user-control-card:hover{transform:translateY(-2px);box-shadow:var(--vipox-shadow)}.user-card-head{display:flex;align-items:center;gap:12px}.user-avatar{display:grid;place-items:center;width:44px;height:44px;border-radius:16px;background:linear-gradient(135deg,#0f172a,#2563eb);color:#fff;font-weight:900;box-shadow:0 14px 28px rgba(37,99,235,.18)}.user-card-name{font-size:1.05rem;font-weight:900;color:#0f172a;margin:0}.user-card-meta{font-size:.82rem;color:#94a3b8;margin:2px 0 0}.mini-stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.mini-stat-row div{border:1px solid #edf2f7;border-radius:18px;background:#f8fafc;padding:12px}.mini-stat-row span{display:block;font-size:.72rem;font-weight:800;color:#64748b;text-transform:uppercase;letter-spacing:.06em}.mini-stat-row strong{display:block;margin-top:4px;font-size:1.18rem;color:#0f172a}.user-card-block{border:1px solid #edf2f7;border-radius:20px;background:#fff;padding:14px}.block-label-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.block-label-row span,.block-title{font-size:.82rem;font-weight:850;color:#64748b;margin:0}.block-label-row strong{font-size:.95rem;color:#0f172a}.inline-form{display:flex;gap:8px;align-items:center}.compact-input{max-width:100px}.switch-list{display:grid;grid-template-columns:1fr 1fr;gap:10px}.switch-form{margin:0}.switch-line{display:inline-flex;align-items:center;gap:9px;font-size:.86rem;font-weight:750;color:#475569;cursor:pointer}.switch-line-between{display:flex;justify-content:space-between;width:100%;border:1px solid #edf2f7;border-radius:14px;padding:10px 11px;background:#f8fafc}.switch-line input[type=checkbox]{position:absolute;opacity:0;pointer-events:none}.switch-ui{position:relative;display:inline-block;width:38px;height:22px;border-radius:999px;background:#cbd5e1;box-shadow:inset 0 1px 2px rgba(15,23,42,.12);transition:background .15s ease;flex:0 0 auto}.switch-ui:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 2px 6px rgba(15,23,42,.22);transition:transform .15s ease}.switch-line input:checked + .switch-ui,.switch-line input:checked ~ .switch-ui{background:linear-gradient(135deg,#2563eb,#0ea5e9)}.switch-line input:checked + .switch-ui:after,.switch-line input:checked ~ .switch-ui:after{transform:translateX(16px)}.switch-line input:disabled + .switch-ui,.switch-line input:disabled ~ .switch-ui{opacity:.52;cursor:not-allowed}.user-card-actions{display:grid;gap:10px;border-top:1px dashed #e2e8f0;padding-top:14px}.password-form{display:flex;gap:8px}.password-form .input{min-width:0;flex:1}.active-form{display:flex;justify-content:flex-end}

/* Login */
body.min-h-screen.grid.place-items-center{background:linear-gradient(135deg,#eef6ff 0%,#f8fafc 46%,#e0f2fe 100%)!important}.login-panel,.min-h-screen>.w-full.max-w-md{position:relative;overflow:hidden;border-radius:30px!important;border:1px solid rgba(255,255,255,.8)!important;background:rgba(255,255,255,.88)!important;backdrop-filter:blur(18px);box-shadow:0 30px 80px rgba(15,23,42,.16)!important}.min-h-screen>.w-full.max-w-md:before{content:"";position:absolute;left:-70px;top:-90px;width:210px;height:210px;border-radius:999px;background:rgba(37,99,235,.12);pointer-events:none}.min-h-screen>.w-full.max-w-md:after{content:"";position:absolute;right:-80px;bottom:-100px;width:240px;height:240px;border-radius:999px;background:rgba(14,165,233,.12);pointer-events:none}.min-h-screen>.w-full.max-w-md>*{position:relative;z-index:1}.btn-primary{background:linear-gradient(135deg,#2563eb,#0ea5e9)!important;box-shadow:0 14px 30px rgba(37,99,235,.24)!important;border:0!important}.btn-primary:hover{filter:brightness(.98);transform:translateY(-1px)}.btn-border{border-color:#dbe5f0!important;background:#fff!important;color:#334155!important}.btn-border:hover{background:#f8fafc!important;border-color:#bfdbfe!important;color:#1d4ed8!important}

@media(max-width:640px){.hero-card{align-items:flex-start;flex-direction:column;padding:20px}.hero-chip,.hero-action{width:100%;justify-content:center}.card-body{padding:16px!important}.stat-card{min-height:132px;padding:16px}.stat-icon{width:40px;height:40px;border-radius:14px}.switch-list{grid-template-columns:1fr}.password-form{flex-direction:column}.active-form{justify-content:flex-start}.mini-stat-row{grid-template-columns:1fr}.section-title-row{align-items:flex-start;flex-direction:column}.ui-page-stack{gap:18px}}

/* UI update: dashboard split hero + account expiry, user limits */
.dashboard-top-grid{display:grid;grid-template-columns:1fr;gap:18px;align-items:stretch}.hero-card-main{min-height:150px}.hero-card-main:after{display:none}.top-expiry-card{min-height:150px}.top-expiry-card .card-body{height:100%;display:flex;flex-direction:column;justify-content:center}.expiry-card-head{display:flex;align-items:center;gap:14px}.expiry-icon{display:grid;place-items:center;width:48px;height:48px;border-radius:18px;background:linear-gradient(135deg,#2563eb,#0ea5e9);color:#fff;font-size:1.2rem;box-shadow:0 16px 32px rgba(37,99,235,.22)}.expiry-card-head h3{margin:0;font-size:clamp(1.35rem,2.1vw,2rem);line-height:1.08;font-weight:900;letter-spacing:-.045em;color:#0f172a}.mini-expiry-list{display:grid;gap:7px}.mini-expiry-list div{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid #edf2f7;border-radius:13px;background:#f8fafc;padding:8px 10px;font-size:.82rem}.mini-expiry-list span{font-weight:750;color:#475569}.mini-expiry-list strong{font-weight:900;color:#0f172a;white-space:nowrap}.field-hint{display:block;margin-top:5px;font-size:.72rem;font-weight:700;color:#94a3b8}.limit-card-block{background:linear-gradient(180deg,#fff,#f8fbff)}.limit-usage-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.limit-usage-grid div{border:1px solid #e2e8f0;border-radius:14px;background:#fff;padding:10px 11px}.limit-usage-grid span,.limit-form label span{display:block;font-size:.72rem;font-weight:850;text-transform:uppercase;letter-spacing:.06em;color:#64748b}.limit-usage-grid strong{display:block;margin-top:3px;font-size:.94rem;font-weight:900;color:#0f172a}.limit-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr)) auto;gap:8px;align-items:end}.limit-form label{display:block}.limit-form .compact-input{max-width:none;width:100%}@media(min-width:1024px){.dashboard-top-grid{grid-template-columns:minmax(0,2.2fr) minmax(340px,.8fr)}.hero-card-main{padding:28px 30px}}@media(max-width:640px){.limit-usage-grid,.limit-form{grid-template-columns:1fr}.top-expiry-card,.hero-card-main{min-height:auto}.expiry-card-head{align-items:flex-start}.expiry-icon{width:44px;height:44px;border-radius:16px}}

/* UI update: Live Checker polish */
.live-checker-page{gap:22px}.live-hero-card{background:linear-gradient(135deg,#fff 0%,#eef6ff 55%,#e0f2fe 100%)}.live-hero-panel{display:flex;align-items:center;gap:12px;border:1px solid rgba(37,99,235,.15);border-radius:22px;background:rgba(255,255,255,.78);padding:14px 16px;min-width:250px;box-shadow:0 18px 38px rgba(37,99,235,.10);backdrop-filter:blur(10px)}.live-hero-icon{display:grid;place-items:center;width:44px;height:44px;border-radius:16px;background:linear-gradient(135deg,#2563eb,#0ea5e9);color:#fff;font-size:1.15rem;font-weight:900;box-shadow:0 14px 28px rgba(37,99,235,.20)}.live-hero-panel span{display:block;font-size:.72rem;font-weight:850;text-transform:uppercase;letter-spacing:.08em;color:#64748b}.live-hero-panel strong{display:block;margin-top:2px;font-size:.96rem;font-weight:900;color:#0f172a}.live-action-grid{display:grid;grid-template-columns:1fr;gap:18px;align-items:stretch}.live-form-card .card-body,.live-usage-card .card-body{height:100%}.live-card-hint{font-size:.82rem;font-weight:800;color:#64748b}.live-card-subtitle{margin-top:3px;font-size:.78rem;font-weight:650;color:#94a3b8}.live-add-form{display:grid;grid-template-columns:1fr;gap:14px}.live-submit-wrap{display:flex;align-items:end}.live-submit-btn{width:100%}.live-usage-card{background:linear-gradient(180deg,#fff,#f8fbff)!important}.live-owner-filter{display:grid;gap:12px;margin-top:16px}.live-unlimited-box{margin-top:16px;border:1px solid #bfdbfe;border-radius:18px;background:#eff6ff;color:#1d4ed8;font-size:.92rem;font-weight:850;padding:12px 14px;text-align:center}.live-table-head{align-items:flex-start!important}.live-table-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.live-table .live-domain-cell{display:flex;align-items:center;gap:10px;font-weight:850;color:#0f172a}.live-domain-icon{display:grid;place-items:center;width:30px;height:30px;border-radius:12px;background:#eff6ff;color:#2563eb;font-weight:900;flex:0 0 auto}.status-inline{display:inline-flex;align-items:center;gap:8px}.table-action-row{display:inline-flex;align-items:center;gap:12px}.danger-link{color:#dc2626!important}.live-edit-form{display:flex;justify-content:flex-end;align-items:center;gap:8px;width:100%;min-width:360px}.live-edit-form .input{min-width:190px}.empty-state-block{padding:54px 16px;text-align:center;color:#64748b}.empty-state-icon{display:grid;place-items:center;width:48px;height:48px;border-radius:18px;margin:0 auto 12px;background:#eff6ff;color:#2563eb;font-size:1.1rem;font-weight:900}.empty-state-title{font-size:1rem;font-weight:900;color:#0f172a}.empty-state-text{margin-top:4px;font-size:.9rem}@media(min-width:920px){.live-action-grid{grid-template-columns:minmax(0,2fr) minmax(330px,.8fr)}.live-add-form{grid-template-columns:repeat(3,minmax(0,1fr)) auto}.live-add-form .form-field:nth-of-type(4){grid-column:1/-2}.live-submit-wrap{align-self:end}.live-submit-btn{min-width:150px}}@media(max-width:640px){.live-hero-panel{width:100%;min-width:0}.live-table-head{gap:12px}.live-table-actions{width:100%;justify-content:space-between}.live-edit-form{min-width:280px;flex-wrap:wrap}.live-edit-form .input{min-width:100%;}.table-action-row{justify-content:flex-end}}


/* UI update: full module polish for every menu */
.module-page{gap:22px}.module-hero{background:linear-gradient(135deg,#fff 0%,#eef6ff 55%,#e0f2fe 100%);min-height:148px}.module-hero:after{display:none}.module-hero-panel{display:flex;align-items:center;gap:12px;border:1px solid rgba(37,99,235,.15);border-radius:22px;background:rgba(255,255,255,.82);padding:14px 16px;min-width:245px;box-shadow:0 18px 38px rgba(37,99,235,.10);backdrop-filter:blur(10px)}.module-hero-icon{display:grid;place-items:center;width:46px;height:46px;border-radius:17px;background:linear-gradient(135deg,#2563eb,#0ea5e9);color:#fff;font-weight:950;box-shadow:0 14px 28px rgba(37,99,235,.20)}.module-hero-panel span{display:block;font-size:.72rem;font-weight:850;text-transform:uppercase;letter-spacing:.08em;color:#64748b}.module-hero-panel strong{display:block;margin-top:2px;font-size:.98rem;font-weight:900;color:#0f172a}.module-stat-grid{margin-top:0}.module-action-grid{display:grid;grid-template-columns:1fr;gap:18px;align-items:stretch}.module-form-card .card-body,.module-info-card .card-body{height:100%}.module-form-stack{display:grid;gap:15px}.module-form-footer{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.form-help{font-size:.82rem;font-weight:700;color:#64748b}.module-textarea{min-height:230px;line-height:1.6}.alert-box{border-radius:18px;border:1px solid;padding:12px 14px;font-size:.88rem;font-weight:750}.alert-danger{border-color:#fecaca;background:#fff1f2;color:#be123c}.alert-warning{border-color:#fde68a;background:#fffbeb;color:#b45309}.module-info-card{background:linear-gradient(180deg,#fff,#f8fbff)!important}.module-tips{display:grid;gap:10px}.module-tips div{display:flex;align-items:flex-start;gap:10px;border:1px solid #e8eef8;border-radius:15px;background:#fff;padding:11px 12px}.module-tips strong{display:grid;place-items:center;width:24px;height:24px;border-radius:9px;background:#eff6ff;color:#2563eb;font-size:.8rem;flex:0 0 auto}.module-tips span{font-size:.86rem;font-weight:750;color:#475569}.module-result-table th:first-child,.module-result-table td:first-child{min-width:280px}.generated-box{border:1px solid #bfdbfe;border-radius:18px;background:#eff6ff;padding:13px 14px;display:grid;gap:4px}.generated-box span{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;font-weight:900;color:#2563eb}.generated-box strong{font-size:.92rem;color:#0f172a;word-break:break-all}.short-action-grid{align-items:start}.settings-grid{display:grid;grid-template-columns:1fr;gap:18px}.settings-switch-list{grid-template-columns:1fr}.settings-button-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.rotate-page{position:relative}.rotate-hero-card{background:linear-gradient(135deg,#fff 0%,#eef6ff 58%,#dbeafe 100%)}.rotate-table-card .card-body{padding-top:12px}.rotate-table th,.rotate-table td{vertical-align:middle}.rotate-table td:nth-child(4){max-width:280px;word-break:break-all}.rotate-table .action-group{justify-content:flex-end}.modal-card{border-radius:26px!important;border:1px solid rgba(226,232,240,.95)!important;box-shadow:0 30px 80px rgba(15,23,42,.22)!important;overflow:hidden}.modal-card .card-header{background:linear-gradient(180deg,#fff,#f8fbff)}.modal-close{display:grid;place-items:center;width:34px;height:34px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;color:#64748b;font-size:1.35rem;line-height:1}.modal-close:hover{background:#f8fafc;color:#0f172a}.btn-light{border:1px solid #e2e8f0!important;background:#fff!important;color:#334155!important}.btn-light:hover{background:#f8fafc!important;border-color:#bfdbfe!important;color:#1d4ed8!important}.code-editor{min-height:180px}.view-targets{background:#fff}.dump-hero-card{background:linear-gradient(135deg,#fff 0%,#f0f9ff 58%,#e0f2fe 100%)}.short-hero-card{background:linear-gradient(135deg,#fff 0%,#f5f3ff 55%,#e0f2fe 100%)}.settings-hero-card{background:linear-gradient(135deg,#fff 0%,#eff6ff 55%,#e0e7ff 100%)}
@media(min-width:920px){.module-action-grid{grid-template-columns:minmax(0,2fr) minmax(330px,.8fr)}.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.settings-grid>.card:nth-child(3):last-child{grid-column:auto}.rotate-stat-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(max-width:760px){.module-hero{align-items:flex-start;flex-direction:column}.module-hero-panel{width:100%;min-width:0}.module-form-footer{align-items:stretch;flex-direction:column}.module-form-footer .btn{width:100%}.settings-button-row{flex-direction:column}.settings-button-row .btn{width:100%}.rotate-table .action-group{justify-content:flex-start}.modal-card .card-header,.modal-card .card-footer{padding-left:16px!important;padding-right:16px!important}}

/* VIPOX Compact Precision UI Patch v1
   Smaller controls, tighter cards, cleaner desktop and mobile spacing. */
:root{--vipox-compact-radius:16px;--vipox-compact-shadow:0 8px 22px rgba(15,23,42,.055)}

/* Layout density */
.ui-page-stack,.module-page,.live-checker-page{gap:14px!important}.content-grid,.module-action-grid,.live-action-grid,.settings-grid{gap:14px!important}.stat-grid,.module-stat-grid{gap:12px!important}.section-title-row{gap:10px!important}.section-title{font-size:1.02rem!important}.eyebrow{font-size:.66rem!important;letter-spacing:.11em!important;margin-bottom:5px!important}

/* Sidebar and shell */
.sidebar,aside.sidebar{padding:12px 10px!important}.sidebar-logo{margin-bottom:12px!important}.sidebar-logo img{height:54px!important}.sidebar .sidebar-link{padding:.42rem .62rem!important;border-radius:11px!important;font-size:.82rem!important;gap:.62rem!important}.sidebar .nav-icon{width:18px!important;height:18px!important}.sidebar .sidebar-sub{padding-left:.55rem!important}.sidebar p.text-xs{font-size:.66rem!important;margin-top:.9rem!important}.topbar{height:54px!important;padding-left:1rem!important;padding-right:1rem!important}.topbar .page-title{font-size:1.05rem!important}.sidebar-bottom{height:28px!important;font-size:10px!important;border-radius:8px!important}
@media(min-width:1024px){aside.sidebar.fixed{width:240px!important}.main-content{margin-left:240px!important}}

/* Global components */
.card{border-radius:var(--vipox-compact-radius)!important;box-shadow:var(--vipox-compact-shadow)!important}.card-header{min-height:44px!important;padding:10px 14px!important;font-size:.9rem!important}.card-body{padding:14px!important}.ui-card-lg{box-shadow:var(--vipox-compact-shadow)!important}.notice{border-radius:14px!important;padding:10px 12px!important;font-size:.82rem!important}.badge,.badge-soft,.summary-chip{border-radius:999px!important;padding:.12rem .5rem!important;font-size:.68rem!important;line-height:.95rem!important}.btn{border-radius:11px!important;padding:.42rem .72rem!important;font-size:.78rem!important;line-height:1.05rem!important;gap:.38rem!important}.btn-sm{border-radius:9px!important;padding:.3rem .55rem!important;font-size:.7rem!important}.btn-xs{border-radius:8px!important;padding:.22rem .42rem!important;font-size:.66rem!important}.btn-lg{border-radius:12px!important;padding:.55rem .85rem!important;font-size:.84rem!important}.input,.select,.textarea{border-radius:11px!important;min-height:34px!important;padding:.42rem .62rem!important;font-size:.78rem!important;line-height:1.05rem!important}.input-lg{height:2.35rem!important;border-radius:12px!important;font-size:.86rem!important;padding-left:.8rem!important;padding-right:.8rem!important}.form-field span,.field-hint{font-size:.68rem!important}.field-hint{margin-top:3px!important}.compact-input{max-width:82px!important}

/* Hero panels */
.hero-card,.module-hero{border-radius:20px!important;min-height:106px!important;padding:16px 18px!important;gap:14px!important}.hero-card:after{width:170px!important;height:170px!important;right:-55px!important;top:-70px!important}.hero-title{font-size:clamp(1.18rem,2vw,1.62rem)!important;letter-spacing:-.04em!important}.hero-subtitle{font-size:.84rem!important;margin-top:.28rem!important;max-width:620px!important}.hero-chip,.hero-action{padding:7px 11px!important;font-size:.76rem!important}.hero-card-main,.top-expiry-card{min-height:118px!important}.expiry-icon{width:38px!important;height:38px!important;border-radius:14px!important;font-size:.95rem!important}.expiry-card-head{gap:10px!important}.expiry-card-head h3{font-size:clamp(1.05rem,1.8vw,1.45rem)!important}.mini-expiry-list{gap:5px!important}.mini-expiry-list div{padding:6px 8px!important;border-radius:10px!important;font-size:.74rem!important}.module-hero-panel,.live-hero-panel{border-radius:16px!important;padding:10px 12px!important;min-width:205px!important;gap:9px!important}.module-hero-icon,.live-hero-icon{width:36px!important;height:36px!important;border-radius:13px!important;font-size:.96rem!important}.module-hero-panel span,.live-hero-panel span{font-size:.64rem!important}.module-hero-panel strong,.live-hero-panel strong{font-size:.84rem!important}

/* Statistic cards */
.stat-card{min-height:104px!important;padding:13px 14px!important;border-radius:18px!important;gap:11px!important}.stat-card:after{width:112px!important;height:112px!important;right:-38px!important;bottom:-42px!important}.stat-icon{width:34px!important;height:34px!important;border-radius:12px!important;font-size:.96rem!important}.stat-label{font-size:.73rem!important}.stat-value{font-size:clamp(1.34rem,2.2vw,1.72rem)!important;margin-top:4px!important}.stat-note{font-size:.76rem!important;margin-top:3px!important}

/* Tables */
.ui-table-wrap{border-radius:14px!important}.table thead th,.ui-table thead th{padding:9px 11px!important;font-size:.68rem!important;letter-spacing:.055em!important}.table tbody td,.ui-table tbody td{padding:9px 11px!important;font-size:.78rem!important}.table-action-row,.action-group{gap:7px!important}.user-mini-avatar,.live-domain-icon{width:26px!important;height:26px!important;border-radius:9px!important;font-size:.72rem!important}.empty-state-block{padding:34px 12px!important}.empty-state-icon{width:40px!important;height:40px!important;border-radius:14px!important}.empty-state-title{font-size:.9rem!important}.empty-state-text{font-size:.78rem!important}

/* User Control compact */
.user-card-grid{gap:12px!important}.user-control-card{border-radius:18px!important;padding:12px!important;gap:10px!important;box-shadow:var(--vipox-compact-shadow)!important}.user-control-card:hover{transform:translateY(-1px)!important}.user-card-head{gap:9px!important}.user-avatar{width:36px!important;height:36px!important;border-radius:12px!important;font-size:.82rem!important}.user-card-name{font-size:.93rem!important}.user-card-meta{font-size:.72rem!important;margin-top:1px!important}.mini-stat-row{gap:7px!important}.mini-stat-row div{padding:8px 9px!important;border-radius:12px!important}.mini-stat-row span{font-size:.62rem!important;letter-spacing:.055em!important}.mini-stat-row strong{font-size:.98rem!important;margin-top:2px!important}.user-card-block{border-radius:14px!important;padding:10px!important}.block-label-row{margin-bottom:7px!important;gap:8px!important}.block-label-row span,.block-title{font-size:.72rem!important}.block-label-row strong{font-size:.82rem!important}.limit-usage-grid{gap:7px!important}.limit-usage-grid div{padding:7px 8px!important;border-radius:11px!important}.limit-usage-grid span,.limit-form label span{font-size:.6rem!important;letter-spacing:.055em!important}.limit-usage-grid strong{font-size:.8rem!important;margin-top:1px!important}.limit-form{gap:7px!important}.inline-form{gap:7px!important}.progress-bar{height:7px!important;border-radius:999px!important}.switch-list{gap:7px!important}.switch-line{gap:7px!important;font-size:.75rem!important}.switch-line-between{border-radius:11px!important;padding:7px 8px!important}.switch-ui{width:32px!important;height:18px!important}.switch-ui:after{width:12px!important;height:12px!important;top:3px!important;left:3px!important}.switch-line input:checked + .switch-ui:after,.switch-line input:checked ~ .switch-ui:after{transform:translateX(14px)!important}.user-card-actions{gap:7px!important;padding-top:10px!important}.password-form{gap:7px!important}.active-form{font-size:.76rem!important}.feature-picker{border-radius:14px!important;padding:10px!important}.feature-picker-title{font-size:.74rem!important;margin-bottom:7px!important}.feature-picker-row{gap:7px 12px!important}.add-user-grid{gap:10px!important}.create-user-btn{min-height:34px!important}

/* Module pages */
.module-form-stack{gap:10px!important}.module-form-footer{gap:10px!important}.module-textarea{min-height:155px!important;line-height:1.45!important}.form-help,.live-card-hint{font-size:.74rem!important}.live-card-subtitle{font-size:.7rem!important}.module-tips{gap:7px!important}.module-tips div{border-radius:11px!important;padding:8px 9px!important}.module-tips strong{width:20px!important;height:20px!important;border-radius:7px!important;font-size:.68rem!important}.module-tips span{font-size:.76rem!important}.generated-box,.alert-box,.live-unlimited-box{border-radius:13px!important;padding:9px 10px!important;font-size:.78rem!important}.modal-card{border-radius:18px!important}.modal-close{width:28px!important;height:28px!important;border-radius:9px!important;font-size:1.05rem!important}.code-editor{min-height:145px!important}

/* Mobile density: keep touch target usable but remove bulky gaps */
@media(max-width:760px){.ui-page-stack,.module-page,.live-checker-page{gap:12px!important}.card-body{padding:12px!important}.card-header{padding:9px 12px!important}.hero-card,.module-hero{padding:14px!important;border-radius:18px!important;align-items:flex-start!important}.stat-grid{gap:10px!important}.stat-card{min-height:94px!important;padding:12px!important}.user-control-card{padding:10px!important;border-radius:16px!important}.mini-stat-row{grid-template-columns:repeat(3,minmax(0,1fr))!important}.switch-list,.limit-usage-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}.limit-form{grid-template-columns:1fr 1fr auto!important}.password-form{display:grid!important;grid-template-columns:minmax(0,1fr) auto!important}.module-hero-panel,.live-hero-panel{width:100%!important;min-width:0!important}.table thead th,.ui-table thead th{padding:8px 9px!important}.table tbody td,.ui-table tbody td{padding:8px 9px!important}}
@media(max-width:420px){.switch-list,.limit-usage-grid{grid-template-columns:1fr!important}.limit-form{grid-template-columns:1fr 1fr!important}.limit-form .btn{grid-column:1/-1}.mini-stat-row div{padding:7px!important}.hero-title{font-size:1.12rem!important}.stat-value{font-size:1.25rem!important}}

/* VIPOX Balanced Compact UI Patch v1
   Slightly larger than compact mode and fixes login icon/input spacing. */
:root{
  --vipox-balanced-radius:17px;
  --vipox-balanced-control:38px;
}

/* Slightly larger global controls: still compact, but more comfortable on desktop/mobile. */
.card{border-radius:var(--vipox-balanced-radius)!important}.card-header{min-height:46px!important;padding:11px 15px!important}.card-body{padding:15px!important}.btn{border-radius:12px!important;padding:.48rem .8rem!important;font-size:.81rem!important;line-height:1.12rem!important}.btn-sm{padding:.34rem .6rem!important;font-size:.73rem!important}.btn-lg{padding:.62rem .95rem!important;font-size:.9rem!important;line-height:1.25rem!important}.input,.select,.textarea{min-height:var(--vipox-balanced-control)!important;border-radius:12px!important;padding:.5rem .72rem!important;font-size:.82rem!important;line-height:1.18rem!important}.input-lg{height:2.75rem!important;border-radius:13px!important;font-size:.92rem!important;line-height:1.25rem!important;padding-left:.95rem!important;padding-right:.95rem!important}.form-field span,.field-hint{font-size:.72rem!important}.field-hint{margin-top:4px!important}.compact-input{max-width:88px!important}

/* Login/icon input spacing fix: compact patch overrode pl-12/pr-12, causing icon overlap. */
.field{position:relative!important}.field-icon-left{left:.9rem!important}.field-icon-right{right:.9rem!important}.field-icon-left,.field-icon-right{width:1.1rem!important;height:1.1rem!important;display:flex!important;align-items:center!important;justify-content:center!important}.field-icon-left svg,.field-icon-right svg{width:1.05rem!important;height:1.05rem!important}.field .input.pl-12,.field input.pl-12{padding-left:2.75rem!important}.field .input.pr-12,.field input.pr-12{padding-right:2.75rem!important}

/* Login page rhythm. */
form.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0!important;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)))!important;margin-bottom:calc(1rem * var(--tw-space-y-reverse))!important}label.block>span.text-sm{display:block!important;margin-bottom:.32rem!important;font-size:.84rem!important;color:#475569!important}.shadow-card.border.p-6{padding:1.55rem!important;border-radius:1.15rem!important}.shadow-card.border.p-6 .flex.flex-col.items-center{gap:.55rem!important;margin-bottom:1.05rem!important}.shadow-card.border.p-6 img{height:64px!important}.shadow-card.border.p-6 h2{font-size:1.08rem!important}

/* User Control balanced density: a little bigger than compact but still precise. */
.user-control-card{padding:14px!important;gap:11px!important}.user-avatar{width:38px!important;height:38px!important}.user-card-name{font-size:.98rem!important}.user-card-meta{font-size:.74rem!important}.mini-stat-row div{padding:9px 10px!important}.mini-stat-row strong{font-size:1.04rem!important}.user-card-block{padding:11px!important;border-radius:15px!important}.limit-usage-grid div{padding:8px 9px!important}.switch-line-between{padding:8px 9px!important}.switch-ui{width:34px!important;height:19px!important}.switch-ui:after{width:13px!important;height:13px!important}.switch-line input:checked + .switch-ui:after,.switch-line input:checked ~ .switch-ui:after{transform:translateX(15px)!important}.password-form{gap:8px!important}.active-form{font-size:.8rem!important}

@media(max-width:760px){.card-body{padding:13px!important}.input,.select,.textarea{min-height:40px!important;font-size:.84rem!important}.input-lg{height:2.85rem!important}.btn{min-height:36px!important}.user-control-card{padding:12px!important}.shadow-card.border.p-6{padding:1.35rem!important}.shadow-card.border.p-6 img{height:58px!important}}


/* VIPOX Login Input Icon Alignment Fix v2
   Fixes icon/placeholder collision after compact UI patch. */
.login-card{overflow:hidden!important}.login-card label.block>span{display:block!important;margin-bottom:6px!important}.login-field{position:relative!important}.login-field .field-icon-left,.login-field .field-icon-right{position:absolute!important;top:50%!important;transform:translateY(-50%)!important;z-index:2!important;width:18px!important;height:18px!important;display:flex!important;align-items:center!important;justify-content:center!important;color:#94a3b8!important}.login-field .field-icon-left{left:16px!important;pointer-events:none!important}.login-field .field-icon-right{right:16px!important;border:0!important;background:transparent!important;padding:0!important}.login-field .field-icon-left svg,.login-field .field-icon-right svg{width:18px!important;height:18px!important;display:block!important}.login-field input.input.login-input-left,.login-field input.login-input-left{padding-left:46px!important}.login-field input.input.login-input-right,.login-field input.login-input-right{padding-right:46px!important}.login-field input.input-lg{min-height:42px!important;height:42px!important;line-height:1.25rem!important}.login-field input::placeholder{color:#94a3b8!important;opacity:1!important}.login-card form.space-y-4>:not([hidden])~:not([hidden]){margin-top:1rem!important}@media(max-width:760px){.login-field input.input-lg{min-height:44px!important;height:44px!important}.login-field .field-icon-left{left:15px!important}.login-field .field-icon-right{right:15px!important}.login-field input.input.login-input-left,.login-field input.login-input-left{padding-left:44px!important}.login-field input.input.login-input-right,.login-field input.login-input-right{padding-right:44px!important}}

/* VIPOX Settings 2-Column Layout Patch v1
   Make Settings page left/right on desktop and remove bulky one-column look. */
.settings-page{
  width:100%!important;
  max-width:none!important;
}
.settings-page .settings-hero-card{
  margin-bottom:0!important;
}
.settings-page .settings-grid{
  display:grid!important;
  width:100%!important;
  max-width:1180px!important;
  margin:0 auto!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:16px!important;
  align-items:start!important;
}
.settings-page .settings-card{
  width:100%!important;
  max-width:none!important;
  margin:0!important;
  align-self:start!important;
}
.settings-page .module-form-card .card-body{
  padding:15px!important;
}
.settings-page .module-form-stack{
  gap:11px!important;
}
.settings-page .form-field span{
  margin-bottom:6px!important;
}
.settings-page .settings-switch-list{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:8px!important;
}
.settings-page .settings-button-row{
  display:flex!important;
  align-items:center!important;
  gap:9px!important;
  flex-wrap:wrap!important;
}
.settings-page .settings-button-row .btn{
  min-width:128px!important;
}
.settings-page .settings-profile-card .module-form-stack{
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:11px 12px!important;
}
.settings-page .settings-profile-card .module-form-footer{
  grid-column:1/-1!important;
}
.settings-page .settings-profile-card .form-field:first-child{
  grid-column:1/-1!important;
}
.settings-page .module-form-footer{
  margin-top:2px!important;
}

@media(max-width:980px){
  .settings-page .settings-grid{
    grid-template-columns:1fr!important;
    max-width:720px!important;
  }
}
@media(max-width:640px){
  .settings-page .settings-grid{
    gap:12px!important;
    max-width:none!important;
  }
  .settings-page .settings-switch-list,
  .settings-page .settings-profile-card .module-form-stack{
    grid-template-columns:1fr!important;
  }
  .settings-page .settings-profile-card .form-field:first-child,
  .settings-page .settings-profile-card .module-form-footer{
    grid-column:auto!important;
  }
  .settings-page .settings-button-row .btn{
    width:100%!important;
  }
}

/* =========================================================
   VIPOX User Control Accordion Patch
   - remove top Add User hero button dependency
   - show compact user summary first
   - open full settings only when Detail is clicked
   ========================================================= */
.user-hero-clean{min-height:auto!important;padding-right:26px!important}
.user-hero-clean:after{right:-120px!important;opacity:.55!important}

.user-accordion-card{
  display:block!important;
  padding:0!important;
  gap:0!important;
  overflow:hidden!important;
}
.user-accordion-card:hover{transform:translateY(-1px)!important}
.user-card-summary{
  list-style:none!important;
  cursor:pointer!important;
  display:flex!important;
  flex-direction:column!important;
  gap:10px!important;
  padding:13px!important;
  outline:none!important;
}
.user-card-summary::-webkit-details-marker{display:none!important}
.user-card-summary::marker{display:none!important;content:""!important}
.user-card-summary:focus-visible{
  box-shadow:inset 0 0 0 3px rgba(37,99,235,.16)!important;
  border-radius:18px!important;
}
.user-card-head-actions{
  margin-left:auto!important;
  display:flex!important;
  align-items:center!important;
  gap:7px!important;
  flex:0 0 auto!important;
}
.expand-chip{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:5px!important;
  min-height:26px!important;
  border-radius:999px!important;
  border:1px solid rgba(37,99,235,.18)!important;
  background:#eff6ff!important;
  color:#1d4ed8!important;
  padding:4px 9px!important;
  font-size:.72rem!important;
  line-height:1!important;
  font-weight:850!important;
  white-space:nowrap!important;
  box-shadow:0 6px 16px rgba(37,99,235,.08)!important;
}
.expand-arrow{
  display:inline-block!important;
  transition:transform .18s ease!important;
  font-size:.82rem!important;
  line-height:1!important;
}
.expand-close-text{display:none!important}
.user-accordion-card[open] .expand-open-text{display:none!important}
.user-accordion-card[open] .expand-close-text{display:inline!important}
.user-accordion-card[open] .expand-arrow{transform:rotate(180deg)!important}

.user-summary-stats{margin-top:0!important}
.user-summary-limit{
  border:1px solid rgba(226,232,240,.92)!important;
  border-radius:14px!important;
  background:linear-gradient(180deg,#fff,#f8fbff)!important;
  padding:9px!important;
}
.summary-limit-head{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:10px!important;
  margin-bottom:7px!important;
}
.summary-limit-head span{
  font-size:.72rem!important;
  font-weight:850!important;
  color:#64748b!important;
}
.summary-limit-head strong{
  font-size:.72rem!important;
  font-weight:900!important;
  color:#0f172a!important;
  white-space:nowrap!important;
}
.summary-limit-grid{
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
}
.summary-limit-grid div{
  padding:7px 8px!important;
  border-radius:11px!important;
}
.summary-limit-grid span{
  font-size:.58rem!important;
}
.summary-limit-grid strong{
  font-size:.82rem!important;
}
.user-card-expanded{
  border-top:1px dashed #e2e8f0!important;
  padding:12px!important;
  background:linear-gradient(180deg,rgba(248,250,252,.68),rgba(255,255,255,.98))!important;
}
.user-detail-grid{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:10px!important;
}
.user-detail-grid .user-card-block{
  margin:0!important;
  min-width:0!important;
}
.user-card-actions-block .block-title{margin-bottom:8px!important}
.user-card-actions-block .user-card-actions{
  border-top:0!important;
  padding-top:0!important;
}
.user-accordion-card[open]{
  box-shadow:var(--vipox-shadow)!important;
}

@media(max-width:1120px){
  .user-detail-grid{grid-template-columns:1fr!important}
}
@media(max-width:760px){
  .user-card-summary{padding:11px!important;gap:9px!important}
  .user-card-head-actions{gap:6px!important}
  .expand-chip{min-height:24px!important;padding:4px 8px!important;font-size:.68rem!important}
  .summary-limit-grid{grid-template-columns:repeat(3,minmax(0,1fr))!important}
  .user-card-expanded{padding:10px!important}
}
@media(max-width:480px){
  .user-card-head{align-items:flex-start!important}
  .user-card-head-actions{align-items:flex-end!important;flex-direction:column!important}
  .summary-limit-grid{grid-template-columns:1fr!important}
  .mini-stat-row.user-summary-stats{grid-template-columns:repeat(3,minmax(0,1fr))!important}
  .summary-limit-head{align-items:flex-start!important;flex-direction:column!important;gap:3px!important}
}

/* =========================================================
   VIPOX User Control Accordion Fix
   - keep closed user cards at natural height when another card is expanded
   - align Detail/Tutup chevron exactly with text
   ========================================================= */
.user-card-grid{
  align-items:start!important;
}
.user-accordion-card{
  align-self:start!important;
  height:auto!important;
}
.user-accordion-card:not([open]){
  height:auto!important;
}
.user-card-head-actions{
  align-self:flex-start!important;
}
.expand-chip{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:5px!important;
  height:26px!important;
  min-height:26px!important;
  padding:0 9px!important;
  line-height:1!important;
  vertical-align:middle!important;
}
.expand-chip span{
  display:inline-flex!important;
  align-items:center!important;
  line-height:1!important;
}
.expand-arrow{
  width:12px!important;
  height:12px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  line-height:1!important;
  margin-top:0!important;
  transform-origin:center center!important;
  position:relative!important;
  top:0!important;
}
.user-accordion-card[open] .expand-arrow{
  transform:rotate(180deg)!important;
}
@media(max-width:760px){
  .expand-chip{
    height:24px!important;
    min-height:24px!important;
    padding:0 8px!important;
  }
}


/* =========================================================
   VIPOX User Control Detail Button Final Fix
   - one label only: Detail when closed, Close when opened
   - no duplicate Detail/Tutup text
   - CSS-drawn chevron stays vertically centered
   ========================================================= */
.user-accordion-card .expand-open-text,
.user-accordion-card .expand-close-text{
  display:none!important;
}
.user-accordion-card .expand-chip{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:7px!important;
  height:26px!important;
  min-height:26px!important;
  padding:0 10px!important;
  line-height:1!important;
  white-space:nowrap!important;
}
.user-accordion-card .expand-label{
  display:inline-flex!important;
  align-items:center!important;
  line-height:1!important;
}
.user-accordion-card .expand-label::before{
  content:"Detail";
}
.user-accordion-card[open] .expand-label::before{
  content:"Close";
}
.user-accordion-card .expand-arrow{
  width:7px!important;
  height:7px!important;
  display:inline-block!important;
  flex:0 0 auto!important;
  border-right:1.8px solid currentColor!important;
  border-bottom:1.8px solid currentColor!important;
  transform:rotate(45deg)!important;
  transform-origin:50% 50%!important;
  margin:0!important;
  position:relative!important;
  top:-1px!important;
  font-size:0!important;
  line-height:0!important;
  transition:transform .18s ease, top .18s ease!important;
}
.user-accordion-card[open] .expand-arrow{
  transform:rotate(-135deg)!important;
  top:2px!important;
}
@media(max-width:760px){
  .user-accordion-card .expand-chip{
    height:24px!important;
    min-height:24px!important;
    padding:0 9px!important;
    gap:6px!important;
  }
}

/* =========================================================
   VIPOX User Control Independent Expand Fix
   - use flex cards instead of CSS grid rows so one expanded user
     never stretches the neighboring closed card
   ========================================================= */
.user-card-grid{
  display:flex!important;
  flex-wrap:wrap!important;
  align-items:flex-start!important;
  align-content:flex-start!important;
  gap:12px!important;
}
.user-card-grid > .user-accordion-card{
  flex:0 0 100%!important;
  width:100%!important;
  max-width:100%!important;
  align-self:flex-start!important;
  height:auto!important;
  min-height:0!important;
}
@media(min-width:1180px){
  .user-card-grid > .user-accordion-card{
    flex-basis:calc(50% - 6px)!important;
    width:calc(50% - 6px)!important;
    max-width:calc(50% - 6px)!important;
  }
}
.user-accordion-card:not([open]){
  height:auto!important;
  min-height:0!important;
}
.user-accordion-card:not([open]) .user-card-expanded{
  display:none!important;
}
.user-accordion-card[open] .user-card-expanded{
  display:block!important;
}


/* =========================================================
   VIPOX User Control True Independent Columns + Short Limit
   - two real columns, so expanding one user never creates blank space
   - show Short Link usage/limit together with Live and Rotate
   ========================================================= */
.user-masonry-grid{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  align-items:start!important;
  gap:12px!important;
}
.user-card-column{
  display:flex!important;
  flex-direction:column!important;
  gap:12px!important;
  min-width:0!important;
}
.user-card-column > .user-accordion-card{
  width:100%!important;
  max-width:100%!important;
  flex:none!important;
  align-self:stretch!important;
  height:auto!important;
  min-height:0!important;
}
.user-masonry-grid > .user-accordion-card{
  flex:none!important;
  width:auto!important;
  max-width:none!important;
}
.mini-stat-row.user-summary-stats{
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
}
.summary-limit-grid{
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
}
.limit-card-block .limit-usage-grid{
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
}
.limit-card-block .limit-form{
  grid-template-columns:repeat(3,minmax(0,1fr)) auto!important;
}
.limit-card-block .limit-form .compact-input{
  max-width:none!important;
}
@media(max-width:1180px){
  .user-masonry-grid{
    grid-template-columns:1fr!important;
  }
}
@media(max-width:760px){
  .mini-stat-row.user-summary-stats{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .summary-limit-grid,
  .limit-card-block .limit-usage-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .limit-card-block .limit-form{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .limit-card-block .limit-form .btn{
    grid-column:1/-1!important;
  }
}
@media(max-width:420px){
  .mini-stat-row.user-summary-stats,
  .summary-limit-grid,
  .limit-card-block .limit-usage-grid,
  .limit-card-block .limit-form{
    grid-template-columns:1fr!important;
  }
}

/* VIPOX patch: make User Control action buttons visible */
.user-control-card .limit-form .btn-border:not(:disabled),
.user-control-card .inline-form .btn-border:not(:disabled),
.user-control-card .password-form .btn-border:not(:disabled){
  background:linear-gradient(135deg,#2563eb 0%,#0ea5e9 100%)!important;
  border-color:transparent!important;
  color:#fff!important;
  font-weight:850!important;
  box-shadow:0 10px 22px rgba(37,99,235,.20)!important;
}
.user-control-card .limit-form .btn-border:not(:disabled):hover,
.user-control-card .inline-form .btn-border:not(:disabled):hover,
.user-control-card .password-form .btn-border:not(:disabled):hover{
  background:linear-gradient(135deg,#1d4ed8 0%,#0284c7 100%)!important;
  color:#fff!important;
  transform:translateY(-1px);
  box-shadow:0 12px 26px rgba(37,99,235,.26)!important;
}
.user-control-card .limit-form .btn-border:not(:disabled):active,
.user-control-card .inline-form .btn-border:not(:disabled):active,
.user-control-card .password-form .btn-border:not(:disabled):active{
  transform:translateY(0);
  box-shadow:0 7px 16px rgba(37,99,235,.18)!important;
}
.user-control-card .limit-form .btn-border:disabled,
.user-control-card .inline-form .btn-border:disabled,
.user-control-card .password-form .btn-border:disabled{
  background:#eef2f7!important;
  border-color:#e2e8f0!important;
  color:#94a3b8!important;
  box-shadow:none!important;
}

/* === Security + Monitoring Dashboard Polish === */
.alert.alert-danger{
  border:1px solid rgba(244,63,94,.24);
  background:rgba(255,241,242,.92);
  color:#9f1239;
  border-radius:18px;
  padding:12px 14px;
  font-weight:700;
  font-size:13px;
}
.monitor-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:16px;
  align-items:stretch;
  margin-top:18px;
}
.monitor-card .card-body{min-height:150px;}
.monitor-meta-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
}
.monitor-meta-grid>div{
  border:1px solid rgba(148,163,184,.22);
  background:linear-gradient(180deg,#fff,rgba(248,250,252,.92));
  border-radius:14px;
  padding:11px 12px;
}
.monitor-meta-grid span{
  display:block;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-weight:800;
  color:#64748b;
}
.monitor-meta-grid strong{
  display:block;
  margin-top:4px;
  color:#0f172a;
  font-size:16px;
  font-weight:900;
}
.monitor-error{
  border:1px solid rgba(244,63,94,.22);
  background:rgba(255,241,242,.9);
  color:#be123c;
  border-radius:14px;
  padding:9px 11px;
  font-size:12px;
  font-weight:700;
}
.trend-bars{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:10px;
  min-height:112px;
}
.trend-day{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:5px;
  min-width:40px;
  flex:1;
}
.trend-stack{
  width:26px;
  min-height:6px;
  border-radius:999px;
  overflow:hidden;
  display:flex;
  flex-direction:column-reverse;
  background:#e2e8f0;
  box-shadow:inset 0 0 0 1px rgba(15,23,42,.05);
}
.trend-stack span{display:block;width:100%;}
.trend-ok{background:linear-gradient(180deg,#22c55e,#16a34a);}
.trend-blocked{background:linear-gradient(180deg,#fb7185,#e11d48);}
.trend-unknown{background:linear-gradient(180deg,#fbbf24,#f59e0b);}
.trend-day strong{font-size:12px;color:#0f172a;font-weight:900;line-height:1;}
.trend-day>span{font-size:10px;color:#64748b;font-weight:800;white-space:nowrap;}
.alert-card{margin-top:16px;margin-bottom:18px;}
.dashboard-alert-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.dashboard-alert{
  border-radius:16px;
  padding:12px 14px;
  border:1px solid rgba(148,163,184,.22);
  background:#fff;
}
.dashboard-alert strong{display:block;font-size:13px;font-weight:900;color:#0f172a;margin-bottom:3px;}
.dashboard-alert span{display:block;font-size:12px;font-weight:700;color:#64748b;}
.dashboard-alert-warning{border-color:rgba(245,158,11,.26);background:rgba(255,251,235,.84);}
.dashboard-alert-danger{border-color:rgba(244,63,94,.26);background:rgba(255,241,242,.84);}
@media (max-width: 1024px){
  .monitor-grid{grid-template-columns:1fr;}
  .dashboard-alert-list{grid-template-columns:1fr;}
}
@media (max-width: 640px){
  .monitor-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .trend-bars{gap:6px;}
  .trend-stack{width:20px;}
  .trend-day{min-width:30px;}
}
