:root{--color-primary: #2563EB;--color-primary-hover: #1D4ED8;--color-primary-active: #1E3A8A;--color-primary-subtle: rgba(37, 99, 235, .08);--color-primary-light: rgba(37, 99, 235, .14);--color-success: #16A34A;--color-success-subtle: rgba(22, 163, 74, .1);--color-warning: #D97706;--color-warning-subtle: rgba(217, 119, 6, .1);--color-danger: #DC2626;--color-danger-subtle: rgba(220, 38, 38, .1);--color-purple: #7C3AED;--color-purple-subtle: rgba(124, 58, 237, .1);--color-teal: #0EA5E9;--color-teal-subtle: rgba(14, 165, 233, .1);--surface-page: #FAFAFA;--surface-card: #ffffff;--surface-sidebar: rgba(255, 255, 255, .92);--surface-topbar: rgba(255, 255, 255, .88);--surface-input: #F4F4F5;--surface-overlay: rgba(9, 9, 11, .42);--bg-card: var(--surface-card);--bg-page: #FAFAFA;--bg-hover: rgba(9, 9, 11, .04);--bg-input: #ffffff;--text-primary: #09090B;--text-secondary: #52525B;--text-tertiary: #A1A1AA;--text-disabled: #D4D4D8;--text-inverse: #FFFFFF;--border: #E4E4E7;--border-strong: #D4D4D8;--border-focus: #2563EB;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--sp-16: 64px;--sp-20: 80px;--radius-xs: 4px;--radius-sm: 4px;--radius-md: 4px;--radius-lg: 6px;--radius-xl: 8px;--radius-2xl: 12px;--radius-full: 9999px;--shadow-xs: 0 0 0 1px rgba(9, 9, 11, .04);--shadow-sm: 0 0 0 1px rgba(9, 9, 11, .05), 0 1px 2px rgba(9, 9, 11, .04);--shadow-md: 0 0 0 1px rgba(9, 9, 11, .05), 0 2px 4px rgba(9, 9, 11, .05), 0 4px 8px rgba(9, 9, 11, .04);--shadow-lg: 0 0 0 1px rgba(9, 9, 11, .06), 0 4px 8px rgba(9, 9, 11, .06), 0 12px 24px rgba(9, 9, 11, .06);--shadow-xl: 0 0 0 1px rgba(9, 9, 11, .06), 0 8px 16px rgba(9, 9, 11, .08), 0 24px 48px rgba(9, 9, 11, .1);--shadow-focus: 0 0 0 2px rgba(37, 99, 235, .2);--shadow-card-hover: 0 0 0 1px rgba(9, 9, 11, .07), 0 4px 12px rgba(9, 9, 11, .08), 0 12px 32px rgba(9, 9, 11, .08);--font-family: Inter, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica, Arial, sans-serif;--font-mono: JetBrains Mono, SF Mono, Fira Code, Consolas, monospace;--sidebar-width: 248px;--topbar-height: 56px;--t-fast: .12s;--t-base: .2s;--t-slow: .32s;--z-dropdown: 200;--z-sticky: 300;--z-sidebar: 400;--z-topbar: 500;--z-modal: 600;--z-toast: 700}:root[data-theme=dark],[data-theme=dark]{--color-primary: #3B82F6;--color-primary-hover: #60A5FA;--color-primary-active: #2563EB;--color-primary-subtle: rgba(59, 130, 246, .14);--color-primary-light: rgba(59, 130, 246, .22);--color-success: #22C55E;--color-success-subtle: rgba(34, 197, 94, .16);--color-warning: #F59E0B;--color-warning-subtle: rgba(245, 158, 11, .16);--color-danger: #EF4444;--color-danger-subtle: rgba(239, 68, 68, .16);--color-purple: #A78BFA;--color-purple-subtle: rgba(167, 139, 250, .16);--color-teal: #38BDF8;--color-teal-subtle: rgba(56, 189, 248, .16);--surface-page: #09090B;--surface-card: #18181B;--surface-sidebar: rgba(24, 24, 27, .92);--surface-topbar: rgba(24, 24, 27, .92);--surface-input: #1F1F23;--surface-overlay: rgba(0, 0, 0, .66);--bg-card: var(--surface-card);--bg-page: var(--surface-page);--bg-hover: rgba(255, 255, 255, .05);--bg-input: #18181B;--text-primary: #FAFAFA;--text-secondary: #A1A1AA;--text-tertiary: #71717A;--text-disabled: #52525B;--text-inverse: #09090B;--border: #27272A;--border-strong: #3F3F46;--border-focus: var(--color-primary);--shadow-xs: 0 0 0 1px rgba(255, 255, 255, .04);--shadow-sm: 0 0 0 1px rgba(255, 255, 255, .04), 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 0 0 1px rgba(255, 255, 255, .05), 0 2px 4px rgba(0, 0, 0, .32), 0 4px 8px rgba(0, 0, 0, .28);--shadow-lg: 0 0 0 1px rgba(255, 255, 255, .05), 0 4px 8px rgba(0, 0, 0, .34), 0 12px 24px rgba(0, 0, 0, .36);--shadow-xl: 0 0 0 1px rgba(255, 255, 255, .06), 0 8px 16px rgba(0, 0, 0, .4), 0 24px 48px rgba(0, 0, 0, .5);--shadow-focus: 0 0 0 3px rgba(59, 130, 246, .26);--shadow-card-hover: 0 0 0 1px rgba(255, 255, 255, .06), 0 4px 12px rgba(0, 0, 0, .36), 0 12px 32px rgba(0, 0, 0, .38)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{min-height:100vh;line-height:1.5;background-color:#eff4fb;background-image:linear-gradient(rgba(0,122,255,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(0,122,255,.07) 1px,transparent 1px),linear-gradient(rgba(0,122,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,122,255,.03) 1px,transparent 1px);background-size:80px 80px,80px 80px,20px 20px,20px 20px}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}a{color:inherit;text-decoration:none}ul,ol{list-style:none}button{background:none;border:none;cursor:pointer}table{border-collapse:collapse}#root,#__next{isolation:isolate}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:13px;color:var(--text-primary);background:var(--surface-page)}h1{font-size:28px;font-weight:700;letter-spacing:-.03em;line-height:1.15}h2{font-size:22px;font-weight:700;letter-spacing:-.025em;line-height:1.2}h3{font-size:18px;font-weight:600;letter-spacing:-.02em;line-height:1.25}h4{font-size:16px;font-weight:600;letter-spacing:-.015em;line-height:1.3}h5{font-size:14px;font-weight:600;letter-spacing:-.01em;line-height:1.35}h6{font-size:13px;font-weight:600;letter-spacing:-.01em;line-height:1.4}p{color:var(--text-secondary);line-height:1.6}.text-xs{font-size:11px}.text-sm{font-size:12px}.text-base{font-size:13px}.text-md{font-size:14px}.text-lg{font-size:16px}.text-xl{font-size:18px}.text-2xl{font-size:22px}.text-3xl{font-size:28px}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-disabled{color:var(--text-disabled)}.text-accent{color:var(--color-primary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-mono{font-family:JetBrains Mono,SF Mono,Fira Code,Consolas,monospace}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.leading-tight{line-height:1.25}.leading-normal{line-height:1.5}.leading-loose{line-height:1.75}.tracking-tight{letter-spacing:-.025em}.tracking-normal{letter-spacing:0}.tracking-wide{letter-spacing:.025em}.label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-tertiary)}.value-display{font-size:18px;font-weight:700;letter-spacing:-.03em;color:var(--text-primary);font-variant-numeric:tabular-nums}@keyframes shimmer{0%{background-position:-1200px 0}to{background-position:1200px 0}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-down{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@keyframes scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes bounce-in{0%{transform:scale(.3);opacity:0}50%{transform:scale(1.05)}70%{transform:scale(.95)}to{transform:scale(1);opacity:1}}.animate-fade-in{animation:fade-in .2s cubic-bezier(.4,0,.2,1) both}.animate-slide-up{animation:slide-up .2s cubic-bezier(.4,0,.2,1) both}.animate-spin{animation:spin .8s linear infinite}.animate-pulse{animation:pulse 2s ease-in-out infinite}.stagger>*:nth-child(1){animation-delay:0ms}.stagger>*:nth-child(2){animation-delay:40ms}.stagger>*:nth-child(3){animation-delay:80ms}.stagger>*:nth-child(4){animation-delay:.12s}.stagger>*:nth-child(5){animation-delay:.16s}.stagger>*:nth-child(6){animation-delay:.2s}.stagger>*:nth-child(7){animation-delay:.24s}.stagger>*:nth-child(8){animation-delay:.28s}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-full);font-size:11px;font-weight:600;white-space:nowrap}.badge--primary{background:var(--color-primary-subtle);color:var(--color-primary)}.badge--success{background:var(--color-success-subtle);color:var(--color-success)}.badge--warning{background:var(--color-warning-subtle);color:var(--color-warning)}.badge--danger{background:var(--color-danger-subtle);color:var(--color-danger)}.badge--purple{background:var(--color-purple-subtle);color:var(--color-purple)}.badge--teal{background:var(--color-teal-subtle);color:var(--color-teal)}.badge--neutral{background:var(--surface-input);color:var(--text-secondary)}.badge--blue{background:var(--color-primary-subtle);color:var(--color-primary)}.badge--green{background:var(--color-success-subtle);color:var(--color-success)}.badge--red{background:var(--color-danger-subtle);color:var(--color-danger)}.badge--orange{background:var(--color-warning-subtle);color:var(--color-warning)}.badge--yellow{background:#eab3081f;color:#a16207}.badge--cyan{background:var(--color-teal-subtle);color:var(--color-teal)}.badge--gray{background:var(--surface-input);color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 20px;height:40px;font-size:12px;font-weight:600;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;border-radius:var(--radius-md);border:none;cursor:pointer;white-space:nowrap;letter-spacing:-.01em;transition:all .12s cubic-bezier(.4,0,.2,1)}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;pointer-events:none}.btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.btn--primary{background:var(--color-primary);color:var(--text-inverse)}.btn--primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn--primary:active{background:var(--color-primary-active)}.btn--secondary{background:var(--surface-input);color:var(--text-primary)}.btn--secondary:hover:not(:disabled){background:var(--border)}.btn--ghost{background:transparent;color:var(--text-secondary)}.btn--ghost:hover:not(:disabled){background:var(--surface-input);color:var(--text-primary)}.btn--danger{background:var(--color-danger-subtle);color:var(--color-danger)}.btn--danger:hover:not(:disabled){background:var(--color-danger);color:var(--text-inverse)}.btn--sm{height:32px;padding:0 12px;font-size:11px}.btn--lg{height:48px;padding:0 24px;font-size:14px}.btn--icon{width:40px;padding:0}.btn--sm.btn--icon{width:32px}.input{width:100%;height:44px;padding:0 16px;background:var(--surface-input);border:1.5px solid transparent;border-radius:var(--radius-md);font-size:13px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text-primary);transition:all .12s cubic-bezier(.4,0,.2,1)}.input::placeholder{color:var(--text-tertiary)}.input:hover{background:var(--surface-card);border-color:var(--border)}.input:focus{outline:none;background:var(--surface-card);border-color:var(--border-focus);box-shadow:var(--shadow-focus)}.input:focus-visible{outline:none;box-shadow:var(--shadow-focus)}textarea.input{height:auto;padding:12px 16px;resize:vertical;line-height:1.5}.input-group{position:relative}.input-group .input{padding-left:40px}.input-group .input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none;display:flex}.input-group--right .input{padding-left:16px;padding-right:40px}.input-group--right .input-icon{left:auto;right:12px}.field{display:flex;flex-direction:column;gap:8px}.field__label{font-size:12px;font-weight:500;color:var(--text-primary)}.field__hint{font-size:11px;color:var(--text-tertiary)}.field__error{font-size:11px;color:var(--color-danger)}.field--error .input{border-color:var(--color-danger)}.field--error .input:focus{box-shadow:0 0 0 4px var(--color-danger-subtle)}.select{width:100%;height:44px;padding:0 16px;background:var(--surface-input);border:1.5px solid transparent;border-radius:var(--radius-md);font-size:13px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text-primary);transition:all .12s cubic-bezier(.4,0,.2,1)}.select::placeholder{color:var(--text-tertiary)}.select:hover{background:var(--surface-card);border-color:var(--border)}.select:focus{outline:none;background:var(--surface-card);border-color:var(--border-focus);box-shadow:var(--shadow-focus)}.select{appearance:none;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='%23AEAEB2' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.card{background:var(--surface-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden;padding:24px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card__title{font-size:14px;font-weight:600;color:var(--text-primary);letter-spacing:-.015em}.card__footer{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.card--hoverable{transition:box-shadow .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1)}.card--hoverable:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.card--hoverable{cursor:pointer}.card--flush{padding:0}.divider{height:1px;background:var(--border);border:none;margin:16px 0}.divider--vertical{width:1px;height:auto;align-self:stretch;margin:0 12px}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);font-weight:600;flex-shrink:0;overflow:hidden;background:var(--color-primary-subtle);color:var(--color-primary)}.avatar--xs{width:24px;height:24px;font-size:11px}.avatar--sm{width:32px;height:32px;font-size:12px}.avatar--md{width:40px;height:40px;font-size:13px}.avatar--lg{width:48px;height:48px;font-size:14px}.avatar--xl{width:64px;height:64px;font-size:18px}.avatar img{width:100%;height:100%;object-fit:cover}.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}.spinner--sm{width:14px;height:14px}.spinner--lg{width:28px;height:28px;border-width:3px}.spinner--white{border-color:#ffffff4d;border-top-color:#fff}.empty-state{display:flex;flex-direction:column;gap:12px;align-items:center;padding:64px 24px;text-align:center}.empty-state__icon{width:56px;height:56px;border-radius:var(--radius-xl);background:var(--surface-input);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);margin-bottom:4px}.empty-state__title{font-size:14px;font-weight:600;color:var(--text-primary)}.empty-state__subtitle{font-size:12px;color:var(--text-tertiary);max-width:280px}.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.table{width:100%;font-size:12px}.table thead tr{border-bottom:1px solid var(--border)}.table th{padding:12px 16px;text-align:left;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-tertiary);white-space:nowrap}.table td{padding:12px 16px;color:var(--text-primary);border-bottom:1px solid var(--border);vertical-align:middle}.table tbody tr{transition:background .12s cubic-bezier(.4,0,.2,1)}.table tbody tr:hover{background:var(--surface-input)}.table tbody tr:last-child td{border-bottom:none}.modal-backdrop{position:fixed;inset:0;background:var(--surface-overlay);z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;animation:fade-in .18s cubic-bezier(.4,0,.2,1) both}.modal{position:fixed;left:1rem;right:1rem;top:clamp(1rem,5vh,3rem);margin:0 auto;z-index:calc(var(--z-modal) + 1);background:var(--bg-card, #ffffff);color:var(--text-primary);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);width:auto;max-width:520px;max-height:calc(100vh - clamp(2rem,10vh,6rem));overflow:auto;animation:slide-up .2s cubic-bezier(.16,1,.3,1) both}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-card, #ffffff);z-index:1}.modal__title{font-size:16px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;margin:0}.modal__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;flex-shrink:0}.modal__close:hover{background:var(--surface-input);color:var(--text-primary)}.modal__body{padding:24px;color:var(--text-primary)}.modal__footer{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border);background:var(--bg-card, #ffffff)}.modal--sm{max-width:380px}.modal--lg{max-width:720px}.modal--xl{max-width:900px}.form-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);margin-bottom:12px}.form-group{display:flex;flex-direction:column;gap:4px}.form-label{font-size:12px;font-weight:500;color:var(--text-secondary)}.form-label.required:after{content:" *";color:var(--color-danger)}.form-control{width:100%;padding:8px 12px;font-size:12px;font-family:var(--font-family);color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);outline:none;transition:border-color .15s,box-shadow .15s;appearance:auto}.form-control:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}.form-control::placeholder{color:var(--text-tertiary)}.form-control[disabled]{opacity:.6;cursor:not-allowed;background:var(--surface-input)}textarea.form-control{resize:vertical;min-height:72px}.form-grid{display:grid;gap:12px}.form-grid--2{grid-template-columns:1fr 1fr}.form-grid--3{grid-template-columns:1fr 1fr 1fr}@media(max-width:600px){.form-grid--2,.form-grid--3{grid-template-columns:1fr}}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:10;max-height:200px;overflow-y:auto;margin-top:4px}.autocomplete-item{padding:10px 12px;cursor:pointer;font-size:12px;border-bottom:1px solid var(--border)}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover{background:var(--bg-hover)}.toast-container{position:fixed;bottom:24px;right:24px;z-index:var(--z-toast);display:flex;flex-direction:column;gap:12px;align-items:flex-end}.toast{display:flex;align-items:center;justify-content:flex-start;gap:12px;padding:12px 16px;background:var(--text-primary);color:var(--text-inverse);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);font-size:12px;font-weight:500;min-width:240px;max-width:380px;animation:slide-up .2s cubic-bezier(.16,1,.3,1) both}.toast--success{background:var(--color-success)}.toast--warning{background:var(--color-warning)}.toast--danger{background:var(--color-danger)}.stat-card{background:var(--surface-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden;padding:20px}.stat-card__label{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:8px}.stat-card__value{font-size:22px;font-weight:700;letter-spacing:-.03em;color:var(--text-primary);font-variant-numeric:tabular-nums}.stat-card__delta{display:flex;align-items:center;justify-content:flex-start;gap:4px;margin-top:8px;font-size:11px;font-weight:600}.stat-card__delta--up{color:var(--color-success)}.stat-card__delta--down{color:var(--color-danger)}.stat-card__delta--flat{color:var(--text-tertiary)}.stat-card__icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.chip{display:flex;align-items:center;justify-content:flex-start;gap:4px;display:inline-flex;padding:3px 8px;background:var(--surface-input);border:1px solid var(--border);border-radius:var(--radius-full);font-size:11px;font-weight:500;color:var(--text-primary)}.chip__remove{display:flex;color:var(--text-tertiary);cursor:pointer}.chip__remove:hover{color:var(--color-danger)}.dropdown{position:relative;display:inline-block}.dropdown__menu{position:absolute;top:calc(100% + 4px);right:0;min-width:180px;background:var(--surface-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);overflow:hidden;animation:scale-in .14s cubic-bezier(.16,1,.3,1) both;transform-origin:top right}.dropdown__item{display:flex;align-items:center;justify-content:flex-start;gap:12px;padding:8px 16px;font-size:12px;color:var(--text-primary);cursor:pointer;transition:background .12s cubic-bezier(.4,0,.2,1)}.dropdown__item:hover{background:var(--surface-input)}.dropdown__item--danger{color:var(--color-danger)}.dropdown__item--danger:hover{background:var(--color-danger-subtle)}.dropdown__divider{height:1px;background:var(--border);margin:4px 0}.page{padding:24px;max-width:1440px}.page__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}.page__title{font-size:22px;font-weight:700;letter-spacing:-.025em}.page__subtitle{font-size:12px;color:var(--text-secondary);margin-top:4px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}.page-title{font-size:22px;font-weight:800;letter-spacing:-.03em;color:var(--text-primary);margin:0}.page-sub{font-size:12px;color:var(--text-secondary);margin:4px 0 0}.tab-bar{display:flex;align-items:center;gap:2px;background:var(--surface-input);border-radius:var(--radius-lg);padding:3px}.tab-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:calc(var(--radius-lg) - 2px);border:none;background:transparent;font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.tab-btn:hover{background:var(--surface-card);color:var(--text-primary)}.tab-btn--active{background:var(--surface-card);color:var(--text-primary);font-weight:600;box-shadow:var(--shadow-sm)}.patient-search,.patient-search-wrap{position:relative}.patient-search-spinner{position:absolute;right:10px;top:50%;transform:translateY(-50%);display:flex;align-items:center;pointer-events:none}.patient-search-status{font-size:12px;color:var(--text-secondary);padding:6px 2px 0}.patient-selected{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--color-primary-subtle);border:1px solid var(--color-primary-light);border-radius:var(--radius-md)}.patient-selected__info{display:flex;flex-direction:column;gap:2px}.patient-selected__name{font-size:14px;font-weight:600;color:var(--text-primary)}.patient-selected__phone{font-size:12px;color:var(--text-secondary)}.patient-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);overflow:hidden;max-height:240px;overflow-y:auto}.patient-dropdown__item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;cursor:pointer;transition:background .12s}.patient-dropdown__item:hover{background:var(--surface-input)}.patient-dropdown__name{font-size:14px;font-weight:500;color:var(--text-primary)}.patient-dropdown__phone{font-size:12px;color:var(--text-secondary)}.test-checklist{display:flex;flex-direction:column;gap:6px;max-height:220px;overflow-y:auto;padding:4px 0}.test-check-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:background .12s,border-color .12s;-webkit-user-select:none;user-select:none}.test-check-item__box{flex-shrink:0;width:16px;height:16px;border:2px solid var(--border-strong);border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--color-primary);transition:border-color .12s,background .12s}.test-check-item__name{flex:1;font-size:13px;font-weight:500;color:var(--text-primary)}.test-check-item__cat{flex-shrink:0}.test-check-item__price{font-size:13px;font-weight:600;color:var(--text-secondary);flex-shrink:0}.test-check-item--selected{background:var(--color-primary-subtle);border-color:var(--color-primary-light)}.test-check-item--selected .test-check-item__box{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.test-check-item:hover{background:var(--surface-input)}.test-check-item--selected:hover{background:var(--color-primary-subtle)}.row-actions{display:flex;align-items:center;gap:4px;opacity:0;transition:opacity .12s}tr:hover .row-actions{opacity:1}.th-sort{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.th-sort .sort-icon{opacity:.35;vertical-align:middle;margin-left:3px;transition:opacity .12s}.th-sort:hover{color:var(--text-primary)}.th-sort:hover .sort-icon{opacity:.65}.th-sort.th-sort--active{color:var(--color-primary)}.th-sort.th-sort--active .sort-icon{opacity:1}.data-table{width:100%;border-collapse:collapse;font-size:12px}.data-table th{padding:10px 14px;text-align:left;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-tertiary);background:var(--bg-hover);border-bottom:1px solid var(--border);white-space:nowrap}.data-table th.text-right{text-align:right}.data-table td{padding:10px 14px;color:var(--text-primary);border-bottom:1px solid var(--border);vertical-align:middle}.data-table td.text-right{text-align:right}.data-table td.empty-state{text-align:center;padding:40px 16px;color:var(--text-tertiary);font-size:12px}.data-table td.text-center{text-align:center}.data-table tbody tr{transition:background .1s}.data-table tbody tr:hover td{background:var(--bg-hover)}.data-table tbody tr:last-child td{border-bottom:none}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-tertiary);cursor:pointer;transition:background .12s,color .12s;flex-shrink:0}.icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.icon-btn--danger:hover{background:var(--color-danger-subtle);color:var(--color-danger)}.icon-btn--primary:hover{background:var(--color-primary-subtle);color:var(--color-primary)}.search-box{display:flex;align-items:center;gap:8px;height:36px;padding:0 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-tertiary);transition:border-color .15s,box-shadow .15s}.search-box:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle);color:var(--text-primary)}.search-box input{flex:1;border:none;outline:none;background:transparent;font-size:12px;color:var(--text-primary);min-width:160px}.search-box input::placeholder{color:var(--text-tertiary)}.fw-400{font-weight:400}.fw-500{font-weight:500}.fw-600{font-weight:600}.fw-700{font-weight:700}.py-4{padding-top:16px;padding-bottom:16px}.py-8{padding-top:32px;padding-bottom:32px}.px-4{padding-left:16px;padding-right:16px}.table-pagination{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid var(--border-subtle);gap:12px}.table-pagination__info{font-size:13px;color:var(--text-tertiary)}.table-pagination__size{display:flex;align-items:center;gap:6px}.table-pagination__size-label{font-size:12px;color:var(--text-tertiary);white-space:nowrap}.table-pagination__size-select{height:30px;padding:0 8px;border:1px solid var(--border-default);border-radius:6px;background:var(--bg-surface);color:var(--text-primary);font-size:13px;cursor:pointer}.table-pagination__size-select:focus{outline:none;border-color:var(--color-primary)}.table-pagination__controls{display:flex;gap:6px}.gw-tooltip{position:absolute;top:0;left:0;z-index:9999;padding:6px 10px;background:#09090b;color:#fff;font-family:var(--font-family);font-size:12px;line-height:1.4;border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);pointer-events:none;-webkit-user-select:none;user-select:none;opacity:0;transform:translateY(4px);transition:opacity .12s ease,transform .12s ease}.gw-tooltip.is-visible{opacity:1;transform:translateY(0)}.gw-tooltip__arrow{position:absolute;width:8px;height:8px;background:#09090b;transform:rotate(45deg)}.gw-tooltip--top .gw-tooltip__arrow{bottom:-3px;left:50%;margin-left:-4px}.gw-tooltip--bottom .gw-tooltip__arrow{top:-3px;left:50%;margin-left:-4px}.gw-tooltip--left .gw-tooltip__arrow{right:-3px;top:50%;margin-top:-4px}.gw-tooltip--right .gw-tooltip__arrow{left:-3px;top:50%;margin-top:-4px}@media(prefers-reduced-motion:reduce){.gw-tooltip{transition-duration:0ms}}.gw-toast{display:flex;align-items:flex-start;gap:10px;width:360px;padding:12px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-family:var(--font-family);font-size:13px;line-height:1.4;color:var(--text-primary);animation:gw-toast-in .22s cubic-bezier(.16,1,.3,1);--gw-toast-accent: var(--color-primary)}.gw-toast__icon{color:var(--gw-toast-accent);flex-shrink:0;margin-top:1px}.gw-toast__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.gw-toast__title{margin:0;font-weight:600}.gw-toast__desc{margin:0;color:var(--text-secondary);font-size:12px}.gw-toast__action{border:0;background:transparent;color:var(--gw-toast-accent);font:inherit;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);align-self:center}.gw-toast__action:hover{background:var(--surface-input)}.gw-toast__close{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border:0;background:transparent;color:var(--text-tertiary);border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0}.gw-toast__close:hover{background:var(--surface-input);color:var(--text-primary)}.gw-toast--info{--gw-toast-accent: var(--color-primary)}.gw-toast--success{--gw-toast-accent: var(--color-success)}.gw-toast--warning{--gw-toast-accent: var(--color-warning)}.gw-toast--danger{--gw-toast-accent: var(--color-danger)}@keyframes gw-toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.gw-toast{animation:none}}.app-shell{display:grid;grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:var(--topbar-height) 1fr;min-height:100vh;background:var(--surface-page);position:relative;z-index:1}.app-shell .app-topbar{grid-column:1/-1;grid-row:1;position:sticky;top:0;z-index:var(--z-topbar);height:var(--topbar-height);background:var(--surface-topbar);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid rgba(0,122,255,.08)}.app-shell .app-sidebar{grid-column:1;grid-row:2;position:sticky;top:var(--topbar-height);height:calc(100vh - var(--topbar-height));overflow-y:auto;background:var(--surface-sidebar);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);border-right:1px solid rgba(0,122,255,.08);z-index:var(--z-sidebar)}.app-shell .app-content{grid-column:2;grid-row:2;overflow-y:auto;min-height:0}@media(max-width:1024px){.app-shell{grid-template-columns:60px 1fr}.app-shell .app-sidebar{overflow:visible}}@media(max-width:768px){.app-shell{grid-template-columns:1fr;grid-template-rows:var(--topbar-height) 1fr auto}.app-shell .app-topbar{grid-column:1}.app-shell .app-sidebar{grid-column:1;grid-row:3;height:auto;position:sticky;bottom:0;top:auto;border-right:none;border-top:1px solid var(--border);z-index:var(--z-topbar)}.app-shell .app-content{grid-column:1;grid-row:2}}@media(max-width:768px){.page{padding:16px}.page-header{gap:12px}.inv-summary,.branch-grid,.form-grid{grid-template-columns:1fr!important}.field--full{grid-column:auto!important}.tab-bar{overflow-x:auto}}@media(max-width:1024px){.page{padding:20px}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}:focus{outline:none}:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.mt-0{margin-top:0}.mb-0{margin-bottom:0}.mt-1{margin-top:var(--sp-1)}.mb-1{margin-bottom:var(--sp-1)}.mt-2{margin-top:var(--sp-2)}.mb-2{margin-bottom:var(--sp-2)}.mt-3{margin-top:var(--sp-3)}.mb-3{margin-bottom:var(--sp-3)}.mt-4{margin-top:var(--sp-4)}.mb-4{margin-bottom:var(--sp-4)}.mt-6{margin-top:var(--sp-6)}.mb-6{margin-bottom:var(--sp-6)}.mt-8{margin-top:var(--sp-8)}.mb-8{margin-bottom:var(--sp-8)}.gap-1{gap:var(--sp-1)}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.gap-6{gap:var(--sp-6)}.gap-8{gap:var(--sp-8)}.d-flex{display:flex}.d-grid{display:grid}.d-block{display:block}.d-none{display:none}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.flex-1{flex:1}.shrink-0{flex-shrink:0}.w-full{width:100%}.h-full{height:100%}.min-w-0{min-width:0}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
