@font-face{font-family:Public Sans Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/public-sans-vietnamese-wght-normal-CtlIRbEm.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Public Sans Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/public-sans-latin-ext-wght-normal-MQgHevqp.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Public Sans Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/public-sans-latin-wght-normal-DdeTHZLK.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Barlow;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/barlow-vietnamese-400-normal-Dpl4UHAZ.woff2) format("woff2"),url(/assets/barlow-vietnamese-400-normal-BFeobeCK.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Barlow;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/barlow-latin-ext-400-normal-HxX4XjxC.woff2) format("woff2"),url(/assets/barlow-latin-ext-400-normal-CvBsJvxq.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Barlow;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/barlow-latin-400-normal-qiz4-Cze.woff2) format("woff2"),url(/assets/barlow-latin-400-normal-fsAxiSwU.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Barlow;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/barlow-vietnamese-500-normal-zTViEIzf.woff2) format("woff2"),url(/assets/barlow-vietnamese-500-normal-GNfB7rCE.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Barlow;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/barlow-latin-ext-500-normal-DOaysfXq.woff2) format("woff2"),url(/assets/barlow-latin-ext-500-normal-CJPcKP2Q.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Barlow;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/barlow-latin-500-normal-BPAOfeC8.woff2) format("woff2"),url(/assets/barlow-latin-500-normal-C1h8hMer.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Barlow;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/barlow-vietnamese-600-normal-DcjprdFV.woff2) format("woff2"),url(/assets/barlow-vietnamese-600-normal-CA_GiK2e.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Barlow;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/barlow-latin-ext-600-normal-B8NK_A3D.woff2) format("woff2"),url(/assets/barlow-latin-ext-600-normal-DMVRjfRT.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Barlow;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/barlow-latin-600-normal-DILqtrty.woff2) format("woff2"),url(/assets/barlow-latin-600-normal-CNwfPWQD.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Barlow;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/barlow-vietnamese-700-normal-D6euyNzi.woff2) format("woff2"),url(/assets/barlow-vietnamese-700-normal-4Jt4k04K.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Barlow;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/barlow-latin-ext-700-normal-BLuWmldJ.woff2) format("woff2"),url(/assets/barlow-latin-ext-700-normal-CctuGmmz.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Barlow;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/barlow-latin-700-normal-A9pxMQ4z.woff2) format("woff2"),url(/assets/barlow-latin-700-normal-__SGTsZ1.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root,[data-theme=light]{--bg: #ffffff;--bg-surface: #f9fafb;--bg-surface-2: #f4f6f8;--bg-overlay: rgba(0, 0, 0, .48);--text-primary: #1c252e;--text-secondary: #637381;--text-disabled: #919eab;--text-inverse: #ffffff;--border: #e5e8ef;--border-strong: #c4cdd5;--border-focus: #5166fe;--color-primary: #5166fe;--color-primary-hover: #3d4ecd;--color-primary-active: #3742a4;--color-primary-subtle: #cad0ff;--color-primary-text: #ffffff;--color-secondary: #8e33ff;--color-secondary-hover: #5119b7;--color-secondary-subtle: #efd6ff;--color-secondary-text: #ffffff;--color-error: #ff5630;--color-error-hover: #b71d18;--color-error-bg: rgba(255, 86, 48, .08);--color-error-border: rgba(255, 86, 48, .24);--color-error-text: #b71d18;--color-warning: #ffab00;--color-warning-bg: rgba(255, 171, 0, .08);--color-warning-border: rgba(255, 171, 0, .24);--color-warning-text: #7a4100;--color-success: #22c55e;--color-success-bg: rgba(34, 197, 94, .08);--color-success-border: rgba(34, 197, 94, .24);--color-success-text: #065e49;--color-info: #00b8d9;--color-info-bg: rgba(0, 184, 217, .08);--color-info-border: rgba(0, 184, 217, .24);--color-info-text: #006c9c;--nav-bg: rgba(255, 255, 255, .94);--nav-border: rgba(0, 0, 0, .08);--nav-item-hover: rgba(81, 102, 254, .06);--nav-item-active-bg: rgba(81, 102, 254, .1);--nav-item-active-text: #5166fe;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12);--shadow-xl: 0 24px 48px rgba(0, 0, 0, .18);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--transition-fast: .12s cubic-bezier(.16, 1, .3, 1);--transition-base: .2s cubic-bezier(.16, 1, .3, 1);--transition-slow: .3s cubic-bezier(.16, 1, .3, 1);--font-primary: "Public Sans Variable", "Public Sans", system-ui, sans-serif;--font-secondary: "Barlow", system-ui, sans-serif;--font-mono: "Fira Mono", "Cascadia Mono", "JetBrains Mono", ui-monospace, monospace;--z-nav: 100;--z-drawer: 200;--z-modal: 300;--z-toast: 400}[data-theme=dark]{--bg: #0a0a0c;--bg-surface: #141a21;--bg-surface-2: #1c252e;--bg-overlay: rgba(0, 0, 0, .72);--text-primary: #f4f4f4;--text-secondary: #a1a1aa;--text-disabled: #637381;--text-inverse: #1c252e;--border: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .2);--border-focus: #8897ff;--color-primary: #8897ff;--color-primary-hover: #cad0ff;--color-primary-active: #cad0ff;--color-primary-subtle: rgba(81, 102, 254, .18);--color-primary-text: #0a0a0c;--color-secondary: #c684ff;--color-secondary-hover: #efd6ff;--color-secondary-subtle: rgba(142, 51, 255, .18);--color-secondary-text: #0a0a0c;--color-error: #ff8a80;--color-error-hover: #ffab9f;--color-error-bg: rgba(255, 86, 48, .12);--color-error-border: rgba(255, 86, 48, .24);--color-error-text: #ff8a80;--color-warning: #ffcc40;--color-warning-bg: rgba(255, 171, 0, .12);--color-warning-border: rgba(255, 171, 0, .24);--color-warning-text: #ffcc40;--color-success: #4ade80;--color-success-bg: rgba(34, 197, 94, .12);--color-success-border: rgba(34, 197, 94, .24);--color-success-text: #4ade80;--color-info: #38d9ef;--color-info-bg: rgba(0, 184, 217, .12);--color-info-border: rgba(0, 184, 217, .24);--color-info-text: #38d9ef;--nav-bg: rgba(20, 26, 33, .96);--nav-border: rgba(255, 255, 255, .08);--nav-item-hover: rgba(136, 151, 255, .08);--nav-item-active-bg: rgba(136, 151, 255, .14);--nav-item-active-text: #8897ff;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .4);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .5);--shadow-md: 0 4px 16px rgba(0, 0, 0, .6);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .7);--shadow-xl: 0 24px 48px rgba(0, 0, 0, .8)}@media(prefers-color-scheme:dark){[data-theme=system]{--bg: #0a0a0c;--bg-surface: #141a21;--bg-surface-2: #1c252e;--bg-overlay: rgba(0, 0, 0, .72);--text-primary: #f4f4f4;--text-secondary: #a1a1aa;--text-disabled: #637381;--text-inverse: #1c252e;--border: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .2);--border-focus: #8897ff;--color-primary: #8897ff;--color-primary-hover: #cad0ff;--color-primary-active: #cad0ff;--color-primary-subtle: rgba(81, 102, 254, .18);--color-primary-text: #0a0a0c;--color-secondary: #c684ff;--color-secondary-hover: #efd6ff;--color-secondary-subtle: rgba(142, 51, 255, .18);--color-secondary-text: #0a0a0c;--color-error: #ff8a80;--color-error-hover: #ffab9f;--color-error-bg: rgba(255, 86, 48, .12);--color-error-border: rgba(255, 86, 48, .24);--color-error-text: #ff8a80;--color-warning: #ffcc40;--color-warning-bg: rgba(255, 171, 0, .12);--color-warning-border: rgba(255, 171, 0, .24);--color-warning-text: #ffcc40;--color-success: #4ade80;--color-success-bg: rgba(34, 197, 94, .12);--color-success-border: rgba(34, 197, 94, .24);--color-success-text: #4ade80;--color-info: #38d9ef;--color-info-bg: rgba(0, 184, 217, .12);--color-info-border: rgba(0, 184, 217, .24);--color-info-text: #38d9ef;--nav-bg: rgba(20, 26, 33, .96);--nav-border: rgba(255, 255, 255, .08);--nav-item-hover: rgba(136, 151, 255, .08);--nav-item-active-bg: rgba(136, 151, 255, .14);--nav-item-active-text: #8897ff;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .4);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .5);--shadow-md: 0 4px 16px rgba(0, 0, 0, .6);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .7);--shadow-xl: 0 24px 48px rgba(0, 0, 0, .8)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:var(--font-primary);font-size:14px;line-height:1.6;color:var(--text-primary);background-color:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition-slow),color var(--transition-slow)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}img,svg{display:block;max-width:100%}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-disabled{color:var(--text-disabled)}.text-error{color:var(--color-error-text)}.text-success{color:var(--color-success-text)}.text-mono{font-family:var(--font-mono);font-size:.8125rem}.font-bold{font-weight:700}.font-semi{font-weight:600}.font-medium{font-weight:500}.truncate{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.flex-1{flex:1}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.flex-wrap{flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:var(--radius-md);font-family:var(--font-primary);font-size:.875rem;font-weight:600;line-height:1;cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);text-decoration:none;padding:0 16px;height:38px;outline:none;position:relative}.btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background-color:var(--color-primary);color:var(--color-primary-text)}.btn-primary:hover{background-color:var(--color-primary-hover)}.btn-primary:active{background-color:var(--color-primary-active)}.btn-secondary{background-color:transparent;color:var(--text-primary);border:1px solid var(--border-strong)}.btn-secondary:hover{background-color:var(--bg-surface);border-color:var(--border-focus);color:var(--color-primary)}.btn-ghost{background-color:transparent;color:var(--text-secondary);border:none}.btn-ghost:hover{background-color:var(--bg-surface);color:var(--text-primary)}.btn-danger{background-color:var(--color-error);color:var(--color-primary-text)}.btn-danger:hover{background-color:var(--color-error-hover)}.btn-danger-outline{background-color:transparent;color:var(--color-error-text);border:1px solid var(--color-error-border)}.btn-danger-outline:hover{background-color:var(--color-error-bg)}.btn-sm{height:30px;padding:0 12px;font-size:.8125rem;border-radius:var(--radius-sm)}.btn-lg{height:46px;padding:0 24px;font-size:.9375rem}.btn-icon{padding:0;width:34px;height:34px;border-radius:var(--radius-md);flex-shrink:0}.btn-icon.btn-sm{width:28px;height:28px}.card{background-color:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.card-surface{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.card-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.card-body{padding:20px}.card-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;gap:8px}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;line-height:1.5;white-space:nowrap;border:1px solid transparent}.badge-default{background-color:var(--bg-surface-2);color:var(--text-secondary);border-color:var(--border)}.badge-primary{background-color:var(--color-primary-subtle);color:var(--color-primary);border-color:transparent}.badge-success{background-color:var(--color-success-bg);color:var(--color-success-text);border-color:var(--color-success-border)}.badge-warning{background-color:var(--color-warning-bg);color:var(--color-warning-text);border-color:var(--color-warning-border)}.badge-error{background-color:var(--color-error-bg);color:var(--color-error-text);border-color:var(--color-error-border)}.badge-info{background-color:var(--color-info-bg);color:var(--color-info-text);border-color:var(--color-info-border)}.badge-outlined{background-color:transparent}.badge-action{cursor:pointer;transition:all var(--transition-fast)}.badge-action:hover{filter:brightness(1.1)}.badge-delete-btn{display:inline-flex;align-items:center;cursor:pointer;opacity:.6;transition:opacity var(--transition-fast);margin-left:2px;margin-right:-2px;padding:0;background:none;border:none;color:inherit}.badge-delete-btn:hover{opacity:1}.alert{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:var(--radius-md);border:1px solid;font-size:.875rem;line-height:1.5}.alert-icon{flex-shrink:0;margin-top:1px}.alert-close{margin-left:auto;flex-shrink:0;background:none;border:none;cursor:pointer;padding:0;color:inherit;opacity:.6;transition:opacity var(--transition-fast)}.alert-close:hover{opacity:1}.alert-error{background-color:var(--color-error-bg);border-color:var(--color-error-border);color:var(--color-error-text)}.alert-warning{background-color:var(--color-warning-bg);border-color:var(--color-warning-border);color:var(--color-warning-text)}.alert-success{background-color:var(--color-success-bg);border-color:var(--color-success-border);color:var(--color-success-text)}.alert-info{background-color:var(--color-info-bg);border-color:var(--color-info-border);color:var(--color-info-text)}.alert-block{padding:14px 16px}.alert-block .alert-icon{margin-top:2px}.alert-content{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.alert-title{font-weight:600;font-size:.9375rem;line-height:1.4}.alert-description{color:inherit;opacity:.9;word-break:break-word}.alert-actions{display:flex;gap:8px;margin-top:8px}.alert-action{font:inherit;font-size:.8125rem;font-weight:600;background:transparent;border:1px solid currentColor;color:inherit;border-radius:var(--radius-sm);padding:4px 10px;cursor:pointer;transition:background-color var(--transition-fast)}.alert-action:hover{background-color:color-mix(in srgb,currentColor 10%,transparent)}.alert-action-ghost{border-color:transparent;opacity:.75}.alert-action-ghost:hover{opacity:1;background-color:transparent}.field-group{display:flex;flex-direction:column;gap:4px}.field-label{font-size:.8125rem;font-weight:600;color:var(--text-primary);line-height:1.4}.field-hint{font-size:.75rem;color:var(--text-secondary);line-height:1.4}.field-error-msg{font-size:.75rem;color:var(--color-error-text);line-height:1.4}.field{width:100%;height:38px;padding:0 12px;border:1px solid var(--border-strong);border-radius:var(--radius-md);background-color:var(--bg);color:var(--text-primary);font-family:var(--font-primary);font-size:.875rem;line-height:1;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;appearance:none}.field::placeholder{color:var(--text-disabled)}.field:hover:not(:disabled):not(:focus){border-color:var(--text-secondary)}.field:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--color-primary-subtle)}.field:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.field:disabled{background-color:var(--bg-surface-2);color:var(--text-disabled);cursor:not-allowed}.field-error{border-color:var(--color-error)!important;box-shadow:none!important}.field-error:focus{box-shadow:0 0 0 3px var(--color-error-bg)!important}.field-sm{height:32px;font-size:.8125rem;padding:0 10px}.field-lg{height:46px;font-size:.9375rem;padding:0 14px}textarea.field{height:auto;padding:10px 12px;resize:vertical;line-height:1.5}select.field{padding-right:32px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23637381' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:16px;cursor:pointer}.field-wrapper{position:relative;display:flex;align-items:center}.field-wrapper .field{padding-right:40px}.field-adornment{position:absolute;right:10px;display:flex;align-items:center;color:var(--text-secondary);pointer-events:none}.field-adornment.interactive{pointer-events:auto;cursor:pointer}.field-adornment.interactive:hover{color:var(--text-primary)}.spinner{display:inline-block;width:24px;height:24px;border:2.5px solid var(--border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.spinner-sm{width:16px;height:16px;border-width:2px}.spinner-lg{width:36px;height:36px;border-width:3px}.spinner-white{border-color:#ffffff4d;border-top-color:var(--color-primary-text)}@keyframes spin{to{transform:rotate(360deg)}}.page-loader{display:flex;align-items:center;justify-content:center;min-height:100vh;background-color:var(--bg)}.page-loader-inline{display:flex;align-items:center;justify-content:center;min-height:50vh}.switch-wrapper{display:inline-flex;align-items:center;gap:8px;cursor:pointer;user-select:none}.switch-track{position:relative;width:40px;height:22px;border-radius:var(--radius-full);background-color:var(--border-strong);transition:background-color var(--transition-fast);flex-shrink:0}.switch-track:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background-color:var(--bg);transition:transform var(--transition-fast);box-shadow:var(--shadow-xs)}input[type=checkbox].switch-input{position:absolute;opacity:0;width:0;height:0}input[type=checkbox].switch-input:checked+.switch-track{background-color:var(--color-primary)}input[type=checkbox].switch-input:checked+.switch-track:after{transform:translate(18px)}.switch-label{font-size:.875rem;color:var(--text-primary)}.checkbox-wrapper{display:inline-flex;align-items:center;gap:8px;cursor:pointer;user-select:none}.checkbox{appearance:none;width:16px;height:16px;border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);background-color:var(--bg);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;position:relative}.checkbox:checked{background-color:var(--color-primary);border-color:var(--color-primary)}.checkbox:checked:after{content:"";position:absolute;top:2px;left:5px;width:4px;height:8px;border:2px solid var(--color-primary-text);border-top:none;border-left:none;transform:rotate(45deg)}.checkbox:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.checkbox-label{font-size:.875rem;color:var(--text-primary)}.tabs{display:flex;border-bottom:1px solid var(--border);gap:0}.tab{padding:10px 16px;font-family:var(--font-primary);font-size:.875rem;font-weight:500;color:var(--text-secondary);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;outline:none}.tab:hover{color:var(--text-primary)}.tab.tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.tab:focus-visible{outline:2px solid var(--border-focus);outline-offset:-2px}.toggle-group{display:inline-flex;border:1px solid var(--border-strong);border-radius:var(--radius-md);overflow:hidden;gap:0}.toggle-btn{padding:6px 12px;font-family:var(--font-primary);font-size:.8125rem;font-weight:500;color:var(--text-secondary);background:none;border:none;border-right:1px solid var(--border-strong);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;outline:none}.toggle-btn:last-child{border-right:none}.toggle-btn:hover{background-color:var(--bg-surface);color:var(--text-primary)}.toggle-btn.toggle-btn-active{background-color:var(--color-primary-subtle);color:var(--color-primary);font-weight:600}.toggle-btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:-2px;position:relative;z-index:1}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.table{width:100%;border-collapse:collapse;font-size:.875rem}.table th,.table td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--border);line-height:1.4}.table th{font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;background-color:var(--bg-surface);white-space:nowrap}.table th:first-child,.table td:first-child{padding-left:20px}.table th:last-child,.table td:last-child{padding-right:20px}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover td{background-color:var(--bg-surface-2)}.table-cell-mono{font-family:var(--font-mono);font-size:.8rem}.table-cell-truncate{display:inline-block;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}.spin{display:inline-flex;animation:spin 1s linear infinite}.link-inline{color:var(--color-primary);text-decoration:none;font-weight:500}.link-inline:hover{text-decoration:underline}.link-inline:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px;border-radius:2px}.link-button{background:none;border:none;cursor:pointer;color:var(--color-primary);padding:0;text-align:left}.link-button:hover{text-decoration:underline}.link-button:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px;border-radius:2px}.table-empty{text-align:center;padding:48px 20px!important;color:var(--text-secondary)}.table-align-right{text-align:right}.table-sticky th{position:sticky;top:0;z-index:1}@media(max-width:768px){.table{font-size:.8125rem}.table th,.table td{padding:.625rem .75rem;white-space:nowrap}.table th:first-child,.table td:first-child{padding-left:.875rem}.table th:last-child,.table td:last-child{padding-right:.875rem}}.pagination{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:10px 20px;border-top:1px solid var(--border);font-size:.8125rem;color:var(--text-secondary)}.modal-backdrop{position:fixed;inset:0;background-color:var(--bg-overlay);z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:16px;animation:fade-in var(--transition-fast)}.modal{background-color:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-height:calc(100vh - 32px);overflow-y:auto;animation:scale-in var(--transition-base);position:relative}.modal-sm{max-width:400px}.modal-md{max-width:520px}.modal-lg{max-width:720px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.modal-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.modal-body{padding:20px 24px}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:16px 24px 20px;border-top:1px solid var(--border)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes scale-in{0%{opacity:0;transform:scale(.96) translateY(4px)}to{opacity:1;transform:scale(1) translateY(0)}}@media(max-width:768px){.modal{width:calc(100vw - 2rem);max-width:calc(100vw - 2rem);max-height:calc(100vh - 4rem)}}.drawer-backdrop{position:fixed;inset:0;background-color:var(--bg-overlay);z-index:var(--z-drawer);animation:fade-in var(--transition-fast)}.drawer{position:fixed;top:0;right:0;height:100%;background-color:var(--bg);border-left:1px solid var(--border);box-shadow:var(--shadow-xl);z-index:calc(var(--z-drawer) + 1);overflow-y:auto;animation:slide-in-right var(--transition-base);padding:24px}.drawer-sm{width:360px}.drawer-md{width:420px}.drawer-lg{width:560px}.drawer-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.drawer-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}@keyframes slide-in-right{0%{transform:translate(100%)}to{transform:translate(0)}}@media(max-width:768px){.drawer{width:100%!important;max-width:100%}}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background-color:var(--color-primary);color:var(--color-primary-text);font-weight:700;font-family:var(--font-primary);flex-shrink:0;overflow:hidden}.avatar-sm{width:28px;height:28px;font-size:.6875rem}.avatar-md{width:36px;height:36px;font-size:.8125rem}.avatar-lg{width:48px;height:48px;font-size:1rem}.avatar-xl{width:64px;height:64px;font-size:1.25rem}.divider{height:1px;background-color:var(--border);border:none;margin:0}.divider-v{width:1px;background-color:var(--border);align-self:stretch}.stepper{display:flex;align-items:center;gap:0;margin-bottom:32px}.stepper-step{display:flex;align-items:center;flex:1;gap:0}.stepper-step:last-child{flex:none}.stepper-circle{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0;border:2px solid var(--border-strong);background-color:var(--bg);color:var(--text-secondary);transition:all var(--transition-fast)}.stepper-circle.active{border-color:var(--color-primary);background-color:var(--color-primary);color:var(--color-primary-text)}.stepper-circle.done{border-color:var(--color-success);background-color:var(--color-success);color:var(--color-primary-text)}.stepper-label{font-size:.75rem;color:var(--text-secondary);margin-top:4px;white-space:nowrap}.stepper-label.active{color:var(--color-primary);font-weight:600}.stepper-connector{flex:1;height:2px;background-color:var(--border);margin:0 8px}.stepper-connector.done{background-color:var(--color-success)}.dashboard-root{display:flex;min-height:100vh;background-color:var(--bg-surface)}.dashboard-main{flex:1;min-height:100vh;display:flex;flex-direction:column;transition:background-color var(--transition-slow)}.dashboard-content{flex:1;padding:24px}@media(max-width:767px){.dashboard-content{padding:16px}}.app-header{position:sticky;top:0;z-index:var(--z-nav);height:56px;background-color:var(--nav-bg);border-bottom:1px solid var(--nav-border);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);display:flex;align-items:center;padding:0 20px;gap:12px}.app-header-spacer{flex:1}.app-header-brand{display:none;align-items:center}@media(max-width:767px){.app-header-brand{display:inline-flex}}.app-header-email{display:inline-block;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}@media(max-width:1024px){.app-header-email{max-width:160px}}.app-header-tenant{min-width:220px;max-width:280px}@media(max-width:640px){.app-header-tenant{min-width:0;max-width:160px}}.nav-sidebar{width:260px;height:100vh;position:sticky;top:0;background-color:var(--bg);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;transition:width var(--transition-base),background-color var(--transition-slow)}.nav-sidebar.collapsed{width:72px}.nav-logo{display:flex;align-items:center;gap:12px;height:56px;padding:0 16px;border-bottom:1px solid var(--nav-border);text-decoration:none;color:var(--text-primary);overflow:hidden;flex-shrink:0}.nav-sidebar.collapsed .nav-logo{justify-content:center;padding:0}.moder-logo .moder-logo-light{display:block}.moder-logo .moder-logo-dark,[data-theme=dark] .moder-logo .moder-logo-light{display:none}[data-theme=dark] .moder-logo .moder-logo-dark{display:block}@media(prefers-color-scheme:dark){[data-theme=system] .moder-logo .moder-logo-light{display:none}[data-theme=system] .moder-logo .moder-logo-dark{display:block}}.nav-list{list-style:none;margin:0;padding:12px 10px;display:flex;flex-direction:column;gap:2px;flex:1;overflow-y:auto}.nav-list-bottom{padding:10px;border-top:1px solid var(--border)}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:all var(--transition-fast);cursor:pointer;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background-color:var(--nav-item-hover);color:var(--text-primary)}.nav-item.active{background-color:var(--nav-item-active-bg);color:var(--nav-item-active-text);font-weight:600}.nav-item:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.nav-item-icon{width:20px;height:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.nav-item-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.nav-sidebar.collapsed .nav-item{justify-content:center;gap:0;padding:9px 0}.nav-sidebar.collapsed .nav-item-label{display:none}.nav-collapse-row{padding:10px;border-top:1px solid var(--border);display:flex;justify-content:flex-end}.nav-sidebar.collapsed .nav-collapse-row{justify-content:center}.nav-collapse-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.nav-collapse-btn:hover{background-color:var(--nav-item-hover);color:var(--text-primary)}.nav-collapse-btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.nav-collapse-btn svg{transition:transform var(--transition-base)}.nav-sidebar.collapsed .nav-collapse-btn svg{transform:rotate(180deg)}.nav-overlay{position:fixed;inset:0;background-color:var(--bg-overlay);z-index:calc(var(--z-nav) + 9);animation:fade-in var(--transition-fast)}.nav-sidebar-mobile{position:fixed;top:0;left:0;height:100%;z-index:calc(var(--z-nav) + 10);animation:slide-in-left var(--transition-base)}@keyframes slide-in-left{0%{transform:translate(-100%)}to{transform:translate(0)}}@media(max-width:767px){.nav-sidebar{display:none}}@media(min-width:768px){.nav-overlay,.nav-sidebar-mobile,.mobile-menu-btn{display:none!important}}.auth-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1c252e,#2d3a47,#1c252e);padding:24px 16px}.auth-card{width:100%;max-width:420px;background-color:var(--bg);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:40px 36px}@media(max-width:480px){.auth-card{padding:28px 20px}}.page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap;min-height:40px}.page-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.3}.page-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}@media(max-width:640px){.page-header{flex-direction:column;align-items:flex-start;gap:.75rem}.page-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}.page-title{font-size:1.25rem}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;gap:12px;color:var(--text-secondary);text-align:center}.empty-state-icon{opacity:.3;margin-bottom:4px}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}@media(max-width:1024px){.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:540px){.kpi-grid{grid-template-columns:1fr}}.kpi-card{padding:14px 18px;display:flex;flex-direction:column;gap:6px;min-height:104px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.kpi-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-xs)}.kpi-label{font-size:.6875rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary)}.kpi-value{font-size:1.625rem;font-weight:700;line-height:1.15;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.01em}.kpi-skeleton{height:1.875rem;width:60%;border-radius:var(--radius-md);background:linear-gradient(90deg,var(--bg-surface) 0%,var(--bg-surface-2) 50%,var(--bg-surface) 100%);background-size:200% 100%;animation:kpi-shimmer 1.4s ease-in-out infinite}@keyframes kpi-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.kpi-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:auto}.kpi-delta{display:inline-flex;align-items:center;gap:2px;font-size:.75rem;font-weight:600;font-variant-numeric:tabular-nums;padding:2px 8px;border-radius:999px;line-height:1.4}.kpi-delta-positive{color:var(--color-success-text);background:var(--color-success-bg)}.kpi-delta-negative{color:var(--color-error-text);background:var(--color-error-bg)}.kpi-delta-neutral{color:var(--text-secondary);background:transparent;padding:2px 0}.kpi-spark{flex:1;max-width:96px;height:28px}.reports-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px}.reports-row-single{grid-template-columns:minmax(0,1fr)}@media(max-width:1024px){.reports-row{grid-template-columns:minmax(0,1fr)}}.card-body-chart{padding:16px 20px 8px}.reports-tabs{padding:0 20px}.settings-layout{max-width:720px}.settings-section{margin-bottom:32px}.settings-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin:0 0 16px}.theme-picker{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.theme-option{border:2px solid var(--border);border-radius:var(--radius-lg);padding:20px 12px 14px;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;transition:all var(--transition-fast);background:none;outline:none;font-family:var(--font-primary)}.theme-option:hover{border-color:var(--border-strong);background-color:var(--bg-surface)}.theme-option.selected{border-color:var(--color-primary);background-color:var(--color-primary-subtle)}.theme-option:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.theme-option-preview{width:56px;height:40px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border);display:flex;flex-direction:column}.theme-option-label{font-size:.8125rem;font-weight:600;color:var(--text-primary)}.preview-light .preview-top{flex:1;background:#f9fafb;border-bottom:1px solid #e5e8ef}.preview-light .preview-bottom{height:12px;background:#fff;display:flex;gap:3px;padding:3px 4px}.preview-light .preview-dot{width:6px;height:6px;border-radius:50%;background:#5166fe}.preview-dark .preview-top{flex:1;background:#141a21;border-bottom:1px solid rgba(255,255,255,.1)}.preview-dark .preview-bottom{height:12px;background:#0a0a0c;display:flex;gap:3px;padding:3px 4px}.preview-dark .preview-dot{width:6px;height:6px;border-radius:50%;background:#8897ff}.preview-system{background:linear-gradient(135deg,#f9fafb 50%,#141a21 50%);flex:1}@media(max-width:480px){.theme-picker{grid-template-columns:1fr}.theme-option{flex-direction:row;padding:14px 16px}}@media(max-width:640px){.hide-mobile{display:none!important}}@media(min-width:641px){.show-mobile-only{display:none!important}}.mb-0{margin-bottom:0}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mb-8{margin-bottom:32px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.w-full{width:100%}.min-w-0{min-width:0}html{height:100%;-webkit-overflow-scrolling:touch}body,#root{display:flex;flex:1 1 auto;min-height:100%;flex-direction:column}img{max-width:100%;vertical-align:middle}ul{margin:0;padding:0;list-style-type:none}
