:root{--md-hue: 240;--md-chroma: .13;--md-primary: oklch(.5 var(--md-chroma) var(--md-hue));--md-on-primary: #ffffff;--md-primary-container: oklch(.92 calc(var(--md-chroma) * .45) var(--md-hue));--md-on-primary-container: oklch(.2 var(--md-chroma) var(--md-hue));--md-secondary: oklch(.55 .04 var(--md-hue));--md-secondary-container: oklch(.93 .02 var(--md-hue));--md-on-secondary-container: oklch(.25 .03 var(--md-hue));--md-tertiary: oklch(.55 .1 calc(var(--md-hue) + 80));--md-tertiary-container: oklch(.93 .04 calc(var(--md-hue) + 80));--md-on-tertiary-container: oklch(.25 .06 calc(var(--md-hue) + 80));--md-error: oklch(.55 .18 25);--md-error-container: oklch(.93 .05 25);--md-on-error-container: oklch(.3 .12 25);--md-success: oklch(.55 .13 150);--md-warning: oklch(.7 .14 75);--md-bg: oklch(.985 .003 var(--md-hue));--md-surface: oklch(.99 .002 var(--md-hue));--md-surface-container-lowest: #ffffff;--md-surface-container-low: oklch(.97 .003 var(--md-hue));--md-surface-container: oklch(.95 .004 var(--md-hue));--md-surface-container-high: oklch(.93 .005 var(--md-hue));--md-surface-container-highest: oklch(.91 .005 var(--md-hue));--md-on-surface: oklch(.2 .01 var(--md-hue));--md-on-surface-variant: oklch(.42 .01 var(--md-hue));--md-outline: oklch(.72 .008 var(--md-hue));--md-outline-variant: oklch(.86 .005 var(--md-hue));--md-elev-1: 0 1px 2px rgba(0,0,0,.06), 0 1px 3px 1px rgba(0,0,0,.04);--md-elev-2: 0 1px 2px rgba(0,0,0,.08), 0 2px 6px 2px rgba(0,0,0,.05);--md-elev-3: 0 1px 3px rgba(0,0,0,.1), 0 4px 8px 3px rgba(0,0,0,.06);--md-elev-4: 0 2px 3px rgba(0,0,0,.12), 0 6px 10px 4px rgba(0,0,0,.07);--md-shape-xs: 4px;--md-shape-sm: 8px;--md-shape-md: 12px;--md-shape-lg: 16px;--md-shape-xl: 28px;--md-shape-full: 9999px;--md-font: "Roboto Flex", "Roboto", -apple-system, system-ui, "Segoe UI", sans-serif;--md-density-y: 16px;--md-density-x: 16px;--md-row-h: 52px;--md-control-h: 40px}[data-theme=dark]{--md-primary: oklch(.78 calc(var(--md-chroma) * .7) var(--md-hue));--md-on-primary: oklch(.18 var(--md-chroma) var(--md-hue));--md-primary-container: oklch(.32 calc(var(--md-chroma) * .85) var(--md-hue));--md-on-primary-container: oklch(.92 calc(var(--md-chroma) * .5) var(--md-hue));--md-secondary-container: oklch(.32 .03 var(--md-hue));--md-on-secondary-container: oklch(.9 .02 var(--md-hue));--md-tertiary-container: oklch(.32 .06 calc(var(--md-hue) + 80));--md-on-tertiary-container: oklch(.9 .05 calc(var(--md-hue) + 80));--md-error-container: oklch(.32 .1 25);--md-on-error-container: oklch(.9 .05 25);--md-bg: oklch(.16 .01 var(--md-hue));--md-surface: oklch(.16 .01 var(--md-hue));--md-surface-container-lowest: oklch(.13 .01 var(--md-hue));--md-surface-container-low: oklch(.18 .01 var(--md-hue));--md-surface-container: oklch(.21 .01 var(--md-hue));--md-surface-container-high: oklch(.24 .01 var(--md-hue));--md-surface-container-highest: oklch(.27 .01 var(--md-hue));--md-on-surface: oklch(.92 .005 var(--md-hue));--md-on-surface-variant: oklch(.78 .01 var(--md-hue));--md-outline: oklch(.5 .01 var(--md-hue));--md-outline-variant: oklch(.32 .008 var(--md-hue))}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{font-family:var(--md-font);background:var(--md-bg);color:var(--md-on-surface);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}button{font-family:inherit;font-size:inherit}input,textarea,select{font-family:inherit}.app{display:grid;grid-template-rows:auto 1fr;height:100vh;overflow:hidden}.appbar{background:var(--md-primary);color:var(--md-on-primary);display:flex;align-items:center;gap:8px;padding:0 24px;height:64px;border-bottom:1px solid color-mix(in oklch,black 14%,var(--md-primary));position:relative;z-index:30;box-shadow:var(--md-elev-1)}.appbar-brand{display:flex;align-items:center;gap:10px;padding-right:20px;margin-right:8px;border-right:1px solid color-mix(in oklch,var(--md-on-primary) 24%,transparent);height:100%;cursor:pointer;-webkit-user-select:none;user-select:none}.appbar-brand-mark{width:32px;height:32px;border-radius:8px;background:var(--md-on-primary);color:var(--md-primary);display:grid;place-items:center;font-weight:700;font-size:14px}.appbar-brand-name{font-weight:600;font-size:16px;letter-spacing:-.01em;color:var(--md-on-primary)}.appbar .search-field{background:color-mix(in oklch,var(--md-on-primary) 16%,transparent);color:var(--md-on-primary);max-width:360px}.appbar .search-field input{color:var(--md-on-primary)}.appbar .search-field input::placeholder{color:color-mix(in oklch,var(--md-on-primary) 70%,transparent)}.appbar-btn{color:color-mix(in oklch,var(--md-on-primary) 90%,transparent)}.appbar-btn:hover{background:color-mix(in oklch,var(--md-on-primary) 14%,transparent);color:var(--md-on-primary)}.appbar--collapsed{height:36px;padding:0 12px;min-height:unset}.appbar-collapse-btn{display:inline-flex;align-items:center;gap:5px;height:28px;padding:0 12px;border-radius:9999px;border:1px solid color-mix(in oklch,var(--md-on-primary) 28%,transparent);background:color-mix(in oklch,var(--md-on-primary) 10%,transparent);color:color-mix(in oklch,var(--md-on-primary) 75%,transparent);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s,color .15s,border-color .15s;white-space:nowrap}.appbar-collapse-btn:hover{background:color-mix(in oklch,var(--md-on-primary) 18%,transparent);color:var(--md-on-primary);border-color:color-mix(in oklch,var(--md-on-primary) 50%,transparent)}.navmenus{display:flex;align-items:stretch;height:100%}.topnav-item{position:relative;height:100%;display:flex;align-items:center;gap:6px;padding:0 16px;font-weight:500;font-size:14px;color:color-mix(in oklch,var(--md-on-primary) 80%,transparent);cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:3px solid transparent;transition:color .15s,background .15s,border-color .15s}.topnav-item:hover{color:var(--md-on-primary);background:color-mix(in oklch,var(--md-on-primary) 10%,transparent)}.topnav-item.active{color:var(--md-on-primary);border-bottom-color:var(--md-on-primary)}.topnav-item.open{color:var(--md-on-primary);background:color-mix(in oklch,var(--md-on-primary) 14%,transparent)}.topnav-item .ic{width:18px;height:18px}.topnav-menu{position:absolute;top:calc(100% + 1px);left:0;min-width:240px;background:var(--md-surface-container-high);border-radius:var(--md-shape-md);padding:8px;box-shadow:var(--md-elev-3);z-index:40;animation:pop .15s cubic-bezier(.2,0,0,1)}.topnav-menu .menu-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--md-shape-sm);cursor:pointer;font-size:14px;color:var(--md-on-surface);transition:background .1s;white-space:nowrap}.topnav-menu .menu-item:hover{background:color-mix(in oklch,var(--md-on-surface) 8%,transparent)}.topnav-menu .menu-item.active{background:var(--md-secondary-container);color:var(--md-on-secondary-container);font-weight:500}.topnav-menu .menu-item .ic{width:18px;height:18px;color:var(--md-on-surface-variant)}.topnav-menu .menu-item.active .ic{color:var(--md-on-secondary-container)}.grow{flex:1}.content{overflow:hidden;display:flex;flex-direction:column}.content-inner{max-width:1440px;margin:0 auto;padding:24px}.content-iframe{width:100%;flex:1;border:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:var(--md-control-h);padding:0 24px;border-radius:9999px;border:0;font-weight:500;font-size:14px;letter-spacing:.01em;cursor:pointer;transition:box-shadow .15s,background .15s,transform .05s;white-space:nowrap}.btn:active{transform:scale(.98)}.btn-filled{background:var(--md-primary);color:var(--md-on-primary)}.btn-filled:hover{box-shadow:var(--md-elev-1);filter:brightness(1.05)}.btn-tonal{background:var(--md-secondary-container);color:var(--md-on-secondary-container)}.btn-tonal:hover{box-shadow:var(--md-elev-1)}.btn-outlined{background:transparent;color:var(--md-primary);border:1px solid var(--md-outline)}.btn-outlined:hover{background:color-mix(in oklch,var(--md-primary) 8%,transparent)}.btn-text{background:transparent;color:var(--md-primary);padding:0 12px}.btn-text:hover{background:color-mix(in oklch,var(--md-primary) 8%,transparent)}.btn-icon{width:40px;height:40px;padding:0;border-radius:9999px;background:transparent;color:var(--md-on-surface-variant)}.btn-icon:hover{background:color-mix(in oklch,var(--md-on-surface) 8%,transparent);color:var(--md-on-surface)}.card{background:var(--md-surface-container-low);border-radius:var(--md-shape-md);padding:24px;border:1px solid var(--md-outline-variant)}.card-elevated{background:var(--md-surface-container-lowest);box-shadow:var(--md-elev-1);border:0}.search-field{display:flex;align-items:center;gap:8px;height:44px;padding:0 16px;border-radius:9999px;background:var(--md-surface-container);color:var(--md-on-surface-variant);flex:1;max-width:480px}.search-field input{flex:1;border:0;background:transparent;outline:none;font-size:14px;color:var(--md-on-surface)}.tf{position:relative;display:block}.tf input,.tf textarea,.tf select{width:100%;height:56px;padding:0 16px;border-radius:var(--md-shape-xs);border:1px solid var(--md-outline);background:var(--md-surface);color:var(--md-on-surface);font-size:16px;outline:none;transition:border-color .15s,border-width .15s}.tf textarea{height:auto;padding:16px;resize:vertical;min-height:96px}.tf select{-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:44px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='currentColor' d='M0 0h12L6 8z'/></svg>");background-repeat:no-repeat;background-position:right 16px center}.tf input:hover,.tf textarea:hover,.tf select:hover{border-color:var(--md-on-surface)}.tf input:focus,.tf textarea:focus,.tf select:focus{border-color:var(--md-primary);border-width:2px;padding:0 15px}.tf textarea:focus{padding:15px}.tf-label{position:absolute;top:50%;left:16px;transform:translateY(-50%);background:var(--md-surface);padding:0 4px;color:var(--md-on-surface-variant);font-size:16px;pointer-events:none;transition:top .15s,font-size .15s,color .15s}.tf input:focus~.tf-label,.tf input:not(:placeholder-shown)~.tf-label,.tf textarea:focus~.tf-label,.tf textarea:not(:placeholder-shown)~.tf-label,.tf.filled .tf-label{top:0;font-size:12px;color:var(--md-primary)}.tf.error input,.tf.error textarea,.tf.error select{border-color:var(--md-error)}.tf.error .tf-label{color:var(--md-error)}.tf-helper{font-size:12px;color:var(--md-on-surface-variant);margin-top:4px;padding:0 16px}.tf.error .tf-helper{color:var(--md-error)}.chip-status{display:inline-flex;align-items:center;gap:6px;height:24px;padding:0 10px;border-radius:6px;font-size:12px;font-weight:500}.chip-status.success{background:color-mix(in oklch,var(--md-success) 16%,transparent);color:var(--md-success)}.chip-status.warning{background:color-mix(in oklch,var(--md-warning) 22%,transparent);color:#694500;color:oklch(.42 .13 75)}.chip-status.error{background:color-mix(in oklch,var(--md-error) 14%,transparent);color:var(--md-error)}.chip-status.neutral{background:var(--md-surface-container-high);color:var(--md-on-surface-variant)}.chip-status .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.table-wrap{background:var(--md-surface-container-lowest);border:1px solid var(--md-outline-variant);border-radius:var(--md-shape-md);overflow:hidden}.table-toolbar{display:flex;align-items:center;gap:12px;padding:16px 24px;border-bottom:1px solid var(--md-outline-variant);flex-wrap:wrap}.table{width:100%;border-collapse:collapse;font-size:14px}.table thead th{background:var(--md-surface-container-low);font-weight:500;font-size:13px;color:var(--md-on-surface-variant);text-align:left;padding:14px 24px;border-bottom:1px solid var(--md-outline-variant);white-space:nowrap;-webkit-user-select:none;user-select:none}.table tbody td{padding:16px 24px;border-bottom:1px solid var(--md-outline-variant);vertical-align:middle;height:var(--md-row-h)}.table tbody tr:last-child td{border-bottom:0}.table tbody tr{transition:background .1s;cursor:pointer}.table tbody tr:hover{background:color-mix(in oklch,var(--md-on-surface) 4%,transparent)}.user-cell{display:flex;align-items:center;gap:12px}.avatar{width:36px;height:36px;border-radius:50%;background:var(--md-tertiary-container);color:var(--md-on-tertiary-container);display:grid;place-items:center;font-weight:600;font-size:13px;flex-shrink:0}.avatar.sm{width:28px;height:28px;font-size:11px}.user-cell .name{font-weight:500;color:var(--md-on-surface)}.user-cell .email{font-size:12px;color:var(--md-on-surface-variant)}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:100;display:grid;place-items:center;animation:fade .15s ease}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes pop{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.dialog{background:var(--md-surface-container-high);border-radius:var(--md-shape-xl);padding:24px;width:560px;max-width:calc(100vw - 32px);max-height:calc(100vh - 64px);overflow-y:auto;box-shadow:var(--md-elev-4);animation:pop .2s cubic-bezier(.2,0,0,1)}.dialog h3{font-size:24px;font-weight:400;margin:0 0 16px;letter-spacing:-.01em}.dialog p{color:var(--md-on-surface-variant);margin:0 0 24px}.dialog-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:24px}.tabs{display:flex;gap:0;border-bottom:1px solid var(--md-outline-variant);margin-bottom:24px}.tab{padding:14px 20px;font-size:14px;font-weight:500;color:var(--md-on-surface-variant);border-bottom:3px solid transparent;cursor:pointer;position:relative;transition:color .15s,border-color .15s;-webkit-user-select:none;user-select:none}.tab:hover{color:var(--md-on-surface)}.tab.active{color:var(--md-primary);border-bottom-color:var(--md-primary)}.list-item{display:flex;align-items:center;gap:16px;padding:12px 16px;border-radius:var(--md-shape-sm);cursor:pointer;transition:background .15s}.list-item:hover{background:color-mix(in oklch,var(--md-on-surface) 5%,transparent)}.list-item .li-text{flex:1;min-width:0}.list-item .li-title{font-weight:500;font-size:14px}.list-item .li-sub{font-size:12px;color:var(--md-on-surface-variant);margin-top:2px}.section-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-h h2{font-size:16px;font-weight:600;margin:0;letter-spacing:-.01em}.login-root{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;background:var(--md-bg)}@media(max-width:768px){.login-root{grid-template-columns:1fr}.login-brand{display:none}}.login-brand{background:var(--md-primary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:48px;color:var(--md-on-primary)}.login-logo{width:180px;height:180px;object-fit:contain;border-radius:var(--md-shape-xl);background:color-mix(in oklch,var(--md-on-primary) 10%,transparent);padding:16px}.login-brand-title{font-size:32px;font-weight:700;margin:0;letter-spacing:-.02em}.login-brand-sub{font-size:15px;margin:0;opacity:.8;text-align:center;max-width:280px;line-height:1.5}.login-panel{display:flex;align-items:center;justify-content:center;padding:32px 24px}.login-card{width:100%;max-width:400px}.login-title{font-size:28px;font-weight:400;margin:0 0 8px;color:var(--md-on-surface);letter-spacing:-.01em}.login-desc{font-size:14px;color:var(--md-on-surface-variant);margin:0 0 32px;line-height:1.5}.login-form{display:flex;flex-direction:column;gap:20px}.login-error{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:var(--md-shape-sm);background:var(--md-error-container);color:var(--md-on-error-container);font-size:14px;line-height:1.4}.login-btn{width:100%;height:48px;font-size:15px;margin-top:4px}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-spinner{width:20px;height:20px;border:2px solid color-mix(in oklch,var(--md-on-primary) 30%,transparent);border-top-color:var(--md-on-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.kpi{background:var(--md-surface-container-lowest);border-radius:var(--md-shape-md);padding:20px;border:1px solid var(--md-outline-variant);display:flex;flex-direction:column;gap:8px}.kpi-icon{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;margin-bottom:4px}.kpi-label{font-size:13px;color:var(--md-on-surface-variant);font-weight:500}.kpi-value{font-size:32px;font-weight:600;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.switch{width:52px;height:32px;border-radius:9999px;border:2px solid var(--md-outline);background:var(--md-surface-container-highest);position:relative;cursor:pointer;transition:all .2s;flex-shrink:0}.switch:after{content:"";position:absolute;top:50%;left:4px;width:16px;height:16px;border-radius:50%;background:var(--md-outline);transform:translateY(-50%);transition:all .2s}.switch[data-on=true]{background:var(--md-primary);border-color:var(--md-primary)}.switch[data-on=true]:after{background:var(--md-on-primary);width:24px;height:24px;left:22px}.chip{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border-radius:var(--md-shape-sm);border:1px solid var(--md-outline-variant);background:var(--md-surface);font-size:13px;font-weight:500;color:var(--md-on-surface-variant);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.chip:hover{background:color-mix(in oklch,var(--md-on-surface) 6%,transparent)}.chip.selected{background:var(--md-secondary-container);color:var(--md-on-secondary-container);border-color:transparent}.snackbar{position:fixed;left:50%;bottom:32px;transform:translate(-50%);background:var(--md-on-surface);color:var(--md-surface);padding:14px 16px 14px 20px;border-radius:var(--md-shape-xs);display:flex;align-items:center;gap:24px;font-size:14px;box-shadow:var(--md-elev-3);z-index:200;animation:snack-in .25s cubic-bezier(.2,0,0,1);min-width:320px;max-width:560px}@keyframes snack-in{0%{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%)}}.snackbar button{background:transparent;border:0;color:oklch(.78 .13 var(--md-hue));font-weight:500;cursor:pointer;padding:4px 8px;border-radius:4px}
