*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}html{-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.5;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font:inherit;cursor:pointer}a{color:var(--color-primary-600);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;display:block}input,textarea,select{font:inherit;color:inherit}:root,.theme-light{--color-primary-50: #EFF6FF;--color-primary-100: #DBEAFE;--color-primary-200: #BFDBFE;--color-primary-300: #93C5FD;--color-primary-400: #60A5FA;--color-primary-500: #3B82F6;--color-primary-600: #2563EB;--color-primary-700: #1D4ED8;--color-primary-800: #1E40AF;--color-primary-900: #1E3A8A;--color-gray-50: #F9FAFB;--color-gray-100: #F3F4F6;--color-gray-200: #E5E7EB;--color-gray-300: #D1D5DB;--color-gray-400: #9CA3AF;--color-gray-500: #6B7280;--color-gray-600: #4B5563;--color-gray-700: #374151;--color-gray-800: #1F2937;--color-gray-900: #111827;--color-bg: #F9FAFB;--color-surface: #FFFFFF;--color-surface-alt: #F3F4F6;--color-text: #111827;--color-text-muted: #6B7280;--color-border: #E5E7EB;--color-border-strong:#D1D5DB;--color-success: #16A34A;--color-warning: #D97706;--color-danger: #DC2626;--color-info: var(--color-primary-600);--sidebar-bg: #0F172A;--sidebar-hover: #1E293B;--sidebar-active: #1E3A5F;--sidebar-text: #94A3B8;--sidebar-text-active: #FFFFFF;--sidebar-border: #1E293B;--sidebar-width: 260px;--sidebar-collapsed: 64px;--topbar-height: 64px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 10px 30px rgba(0,0,0,.12);--z-modal: 200;--z-toast: 250;--z-sidebar: 60;--z-topbar: 50;--transition: .15s ease}.theme-dark{--color-bg: #0B1220;--color-surface: #111827;--color-surface-alt: #1F2937;--color-text: #F3F4F6;--color-text-muted: #9CA3AF;--color-border: #1F2937;--color-border-strong:#374151;--shadow-sm: 0 1px 2px rgba(0,0,0,.4);--shadow-md: 0 4px 12px rgba(0,0,0,.5);--shadow-lg: 0 10px 30px rgba(0,0,0,.6)}.auth-loading{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:var(--color-bg);color:var(--color-text-muted)}.spinner{width:32px;height:32px;border-radius:50%;border:3px solid var(--color-border);border-top-color:var(--color-primary-600);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-shell{display:flex;min-height:100vh}.app-main{flex:1;display:flex;flex-direction:column;min-width:0;margin-left:var(--sidebar-width);transition:margin-left var(--transition)}.app-shell--sidebar-collapsed .app-main{margin-left:var(--sidebar-collapsed)}.app-content{flex:1;padding:16px 24px 64px;overflow-x:hidden}@media (max-width: 1024px){.app-main{margin-left:0}}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;z-index:var(--z-sidebar);transition:width var(--transition),transform var(--transition);border-right:1px solid var(--sidebar-border)}.sidebar--collapsed{width:var(--sidebar-collapsed)}.sidebar__header{height:var(--topbar-height);display:flex;align-items:center;justify-content:center;padding:0 16px;border-bottom:1px solid var(--sidebar-border)}.sidebar__logo-full{display:block;max-height:32px}.sidebar__logo-mark{display:none;max-height:28px}.sidebar--collapsed .sidebar__logo-full{display:none}.sidebar--collapsed .sidebar__logo-mark{display:block}.sidebar__nav{flex:1;overflow-y:auto;padding:12px 8px;scrollbar-width:thin;scrollbar-color:#334155 transparent}.sidebar__section{margin-bottom:8px}.sidebar__section-title{padding:12px 12px 6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#64748b}.sidebar--collapsed .sidebar__section-title{display:none}.sidebar__item{display:flex;align-items:center;gap:12px;padding:9px 12px;margin:2px 0;border-radius:var(--radius-md);color:var(--sidebar-text);font-size:14px;cursor:pointer;user-select:none;text-decoration:none;white-space:nowrap;position:relative}.sidebar__item:hover{background:var(--sidebar-hover);color:var(--sidebar-text-active);text-decoration:none}.sidebar__item--active{background:var(--sidebar-active);color:var(--sidebar-text-active);font-weight:500}.sidebar__item-icon{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.sidebar__item-label{flex:1;overflow:hidden;text-overflow:ellipsis}.sidebar--collapsed .sidebar__item-label,.sidebar--collapsed .sidebar__item-arrow,.sidebar--collapsed .sidebar__star{display:none}.sidebar__item-arrow{width:14px;height:14px;transition:transform var(--transition)}.sidebar__item--open>.sidebar__item-arrow{transform:rotate(90deg)}.sidebar__sub{margin-left:32px;padding-left:4px;border-left:1px solid var(--sidebar-border)}.sidebar--collapsed .sidebar__sub{display:none}.sidebar__star{width:16px;height:16px;color:#475569;opacity:0;transition:opacity var(--transition)}.sidebar__item:hover .sidebar__star{opacity:1}.sidebar__star--active{color:#fbbf24;opacity:1}.sidebar__footer{border-top:1px solid var(--sidebar-border);padding:8px}.sidebar__collapse-btn{width:100%;background:transparent;color:var(--sidebar-text);border:0;padding:8px;border-radius:var(--radius-md);display:flex;align-items:center;gap:8px}.sidebar__collapse-btn:hover{background:var(--sidebar-hover);color:var(--sidebar-text-active)}.topbar{position:sticky;top:0;z-index:var(--z-topbar);height:var(--topbar-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:0 24px;display:flex;align-items:center;gap:16px}.topbar__search{flex:1;max-width:480px;position:relative}.topbar__search-input{width:100%;height:38px;padding:0 12px 0 36px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface-alt);color:var(--color-text);outline:none}.topbar__search-input:focus{border-color:var(--color-primary-500);background:var(--color-surface)}.topbar__search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--color-text-muted)}.topbar__actions{margin-left:auto;display:flex;align-items:center;gap:8px}.topbar__action-btn{width:38px;height:38px;border-radius:var(--radius-md);background:transparent;border:1px solid transparent;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;position:relative}.topbar__action-btn:hover{background:var(--color-surface-alt);color:var(--color-text)}.topbar__badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;background:var(--color-danger);color:#fff;border-radius:999px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px}.user-menu{position:relative}.user-menu__trigger{display:flex;align-items:center;gap:8px;padding:4px 8px 4px 4px;border-radius:var(--radius-md);background:transparent;border:1px solid transparent}.user-menu__trigger:hover{background:var(--color-surface-alt)}.user-menu__dropdown{position:absolute;right:0;top:calc(100% + 4px);min-width:240px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:var(--z-modal);padding:4px}.user-menu__item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);color:var(--color-text);cursor:pointer;text-decoration:none}.user-menu__item:hover{background:var(--color-surface-alt);text-decoration:none}.user-menu__divider{height:1px;background:var(--color-border);margin:4px 0}.avatar{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;color:#fff;font-weight:600;font-size:12px;overflow:hidden;flex-shrink:0;background:var(--color-primary-600)}.avatar img{width:100%;height:100%;object-fit:cover}.avatar--sm{width:24px;height:24px;font-size:10px}.avatar--lg{width:64px;height:64px;font-size:22px}.avatar--xl{width:96px;height:96px;font-size:32px}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm)}.card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.card__title{font-size:16px;font-weight:600;margin:0}.card__subtitle{color:var(--color-text-muted);font-size:13px;margin-top:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;border-radius:var(--radius-md);font-size:14px;font-weight:500;border:1px solid transparent;background:var(--color-primary-600);color:#fff;transition:background var(--transition),border-color var(--transition),color var(--transition)}.btn:hover{background:var(--color-primary-700)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--ghost{background:var(--color-surface-alt);color:var(--color-text);border-color:var(--color-border)}.btn--ghost:hover{background:var(--color-border)}.btn--danger{background:var(--color-danger)}.btn--danger:hover{background:#b91c1c}.btn--sm{padding:4px 10px;font-size:12px}.btn--icon{padding:8px}.input,.select,.textarea{width:100%;padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.input:focus,.select:focus,.textarea:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2563eb26}.textarea{min-height:96px;resize:vertical}.label{display:block;font-size:12px;font-weight:600;color:var(--color-text-muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em}.field{margin-bottom:16px}.table{width:100%;border-collapse:collapse;background:var(--color-surface)}.table th,.table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--color-border);font-size:13px}.table th{font-weight:600;color:var(--color-text-muted);background:var(--color-surface-alt);font-size:12px;text-transform:uppercase;letter-spacing:.04em}.table tbody tr:hover{background:var(--color-surface-alt)}.table--clickable tbody tr{cursor:pointer}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;background:var(--color-surface-alt);color:var(--color-text);border:1px solid var(--color-border)}.badge--success{background:#16a34a1a;color:var(--color-success);border-color:#16a34a4d}.badge--warning{background:#d977061a;color:var(--color-warning);border-color:#d977064d}.badge--danger{background:#dc26261a;color:var(--color-danger);border-color:#dc26264d}.badge--info{background:#2563eb1a;color:var(--color-info);border-color:#2563eb4d}.modal-backdrop{position:fixed;inset:0;background:#0f172a8c;backdrop-filter:blur(4px);z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:modal-in .2s ease}@keyframes modal-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.modal__header{padding:16px 20px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.modal__title{font-size:16px;font-weight:600;margin:0}.modal__close{background:transparent;border:0;padding:4px;border-radius:var(--radius-sm);color:var(--color-text-muted)}.modal__close:hover{background:var(--color-surface-alt);color:var(--color-text)}.modal__body{padding:20px;overflow-y:auto}.modal__footer{padding:12px 20px;border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:8px}.confirm__message{margin:0 0 16px}.confirm__actions{display:flex;justify-content:flex-end;gap:8px}.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:var(--z-toast);max-width:360px}.toast{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-md);background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-md);font-size:13px;animation:toast-in .2s ease}@keyframes toast-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.toast--success .toast__icon{color:var(--color-success)}.toast--warning .toast__icon{color:var(--color-warning)}.toast--error .toast__icon{color:var(--color-danger)}.toast--info .toast__icon{color:var(--color-info)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}.page-header__title{margin:0;font-size:22px;font-weight:700;color:var(--color-text)}.page-header__subtitle{margin:4px 0 0;color:var(--color-text-muted);font-size:14px}.page-header__actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width: 768px){.grid--2,.grid--3{grid-template-columns:1fr}}.row{display:flex;gap:16px;flex-wrap:wrap}.app-footer{position:fixed;right:0;left:var(--sidebar-width);bottom:0;height:32px;background:#f9fafbe6;backdrop-filter:blur(6px);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;gap:8px;font-size:11px;color:var(--color-text-muted);z-index:10;transition:left var(--transition)}.theme-dark .app-footer{background:#0b1220d9}.app-shell--sidebar-collapsed .app-footer{left:var(--sidebar-collapsed)}.app-footer a{color:var(--color-text-muted)}.app-footer a:hover{color:var(--color-primary-600)}@media (max-width: 1024px){.app-footer{left:0}}.pagination{display:flex;gap:4px;align-items:center;justify-content:center;margin-top:16px}.pagination__btn{padding:4px 10px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:12px}.pagination__btn--active{background:var(--color-primary-600);color:#fff;border-color:var(--color-primary-600)}.stat{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:16px}.stat__label{font-size:12px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.stat__value{font-size:28px;font-weight:700;margin-top:4px}.stat__trend{font-size:12px;margin-top:4px}.stat__trend--up{color:var(--color-success)}.stat__trend--down{color:var(--color-danger)}.empty{text-align:center;padding:48px 16px;color:var(--color-text-muted)}.empty__icon{margin:0 auto 12px;color:var(--color-gray-400)}.skeleton{background:linear-gradient(90deg,var(--color-surface-alt) 0%,var(--color-border) 50%,var(--color-surface-alt) 100%);background-size:200% 100%;animation:skeleton 1.4s ease-in-out infinite;border-radius:var(--radius-sm)}@keyframes skeleton{0%{background-position:100% 0}to{background-position:-100% 0}}.stars{display:inline-flex;gap:2px;color:#fbbf24}.stars--muted{color:var(--color-gray-300)}.text-muted{color:var(--color-text-muted)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.flex{display:flex}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-gap-sm{display:flex;gap:8px;align-items:center}.mb-0{margin-bottom:0}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.hidden{display:none!important}@media (max-width: 1024px){.sidebar{transform:translate(-100%)}.sidebar--mobile-open{transform:translate(0)}.app-shell__overlay{position:fixed;inset:0;background:#00000073;z-index:calc(var(--z-sidebar) - 1)}}
